/* Global Styles */
:root {
  /* Dark/Blue Theme Palette - Unified with Bootstrap */
  /* Bootstrap overrides */
  --bs-blue: #2D82FE;
  --bs-indigo: #6366F1;
  --bs-purple: #A855F7;
  --bs-pink: #d63384;
  --bs-red: #dc3545;
  --bs-orange: #fd7e14;
  --bs-yellow: #ffc107;
  --bs-green: #63E2B7;
  --bs-teal: #20c997;
  --bs-cyan: #00D9FF;
  --bs-white: #FFFFFF;
  --bs-gray: #A7B9D0;
  --bs-gray-dark: #141A3C;
  
  /* Primary Bootstrap theme colors - matching our custom theme */
  --bs-primary: #2D82FE;
  --bs-secondary: #00D9FF;
  --bs-success: #63E2B7;
  --bs-info: #A7B9D0;
  --bs-warning: #ffc107;
  --bs-danger: #dc3545;
  --bs-light: #f2f5f9;
  --bs-dark: #080C17;
  
  /* Our custom variables */
  --primary-accent: var(--bs-primary);
  --secondary-accent: var(--bs-secondary);
  --highlight-color: var(--bs-success);
  --text-light: var(--bs-white);
  --text-medium: var(--bs-gray);
  --text-dark: #191716;
  --background-darkest: var(--bs-dark);
  --background-dark: #101628;
  --background-card: var(--bs-gray-dark);
  --border-color: rgba(45, 130, 254, 0.2);
  --border-light: rgba(255, 255, 255, 0.08);

  /* Gradients */
  --gradient-primary: linear-gradient(135deg, var(--primary-accent), var(--secondary-accent));
  --gradient-blue: linear-gradient(135deg, #2D82FE, #00D9FF);
  --gradient-green: linear-gradient(135deg, #00B981, #63E2B7);
  --gradient-purple: linear-gradient(135deg, #6366F1, #A855F7);

  /* Fonts */
  --font-primary: 'Inter', sans-serif;
  --font-secondary: 'Exo 2', sans-serif;
  --bs-font-sans-serif: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --bs-font-monospace: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

  /* Shadows */
  --box-shadow: 0 4px 14px rgba(0, 0, 0, 0.1);
  --box-shadow-hover: 0 10px 25px rgba(45, 130, 254, 0.2);
  --box-shadow-card: 0 10px 20px rgba(8, 12, 23, 0.1);
  --glow-shadow: 0 0 20px rgba(45, 130, 254, 0.4);

  /* Borders & Spacing */
  --border-radius: 8px;
  --border-radius-lg: 12px;
  --border-radius-xl: 20px;

  /* Animations & Timing */
  --transition-speed: 0.3s;
  --transition-timing: cubic-bezier(0.25, 0.46, 0.45, 0.94);

  /* Layout */
  --navbar-height: 80px;
  --section-padding-y: 6rem;
  --container-padding: 2rem;

  /* Z-index */
  --z-nav: 1000;
  --z-particles: 0;
  --z-floating: 1;
  --z-content: 5;
  --z-visual: 2;
  
  /* Bootstrap gradients */
  --bs-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0));
}

/* Reset & Base Styles (Mobile First) */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: var(--navbar-height);
  font-size: 16px; /* Base font size */
  line-height: 1.5;
  overflow-x: hidden;
}

@media (min-width: 992px) {
  /* Only apply scroll snap on larger screens */
  html {
    scroll-snap-type: y proximity; /* Use proximity for more natural scrolling */
  }

  section {
    scroll-snap-align: start;
    scroll-snap-stop: always;
  }
}

body {
  font-family: var(--font-primary);
  color: var(--text-light); /* Ensure text is light by default */
  background-color: var(--background-darkest); /* Enforce darkest background */
  background: radial-gradient(circle at 80% 5%, rgba(45, 130, 254, 0.07) 0%, rgba(8, 12, 23, 0) 20%),
    radial-gradient(circle at 20% 40%, rgba(0, 217, 255, 0.08) 0%, rgba(8, 12, 23, 0) 20%),
    var(--background-darkest);
  overflow-x: hidden !important; /* Override potential Bootstrap overflow */
  padding-top: var(--navbar-height);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100vh;
  position: relative;
}

/* Ensure common elements inherit background/color if needed */
main, .wrapper, .page-container { /* Add any other main wrappers you use */
    background-color: transparent; /* Ensure wrappers don't block body background */
    color: inherit;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
  width: 100%;
}

img {
  max-width: 100%;
  height: auto;
  display: block; /* Prevents bottom space */
}

a {
  color: var(--primary-accent); /* Links use gold */
  text-decoration: none;
  transition: color var(--transition-speed) var(--transition-timing);
}

a:hover {
  color: var(--secondary-accent); /* Hover uses off-white */
}

/* Headings */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-secondary);
  font-weight: 700;
  line-height: 1.2;
  margin-top: 0;
  margin-bottom: 0.5em;
  color: var(--text-light); /* Ensure headings are light */
  letter-spacing: -0.02em;
}

h1, .h1 { font-size: calc(2rem + 1.5vw); } 
h2, .h2 { font-size: calc(1.5rem + 0.6vw); }
h3, .h3 { font-size: calc(1.25rem + 0.3vw); }
h4, .h4 { font-size: 1.2rem; }
h5, .h5 { font-size: 1.1rem; } 
h6, .h6 { font-size: 1rem; }

/* Container */
.container, .container-fluid {
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
  width: 100%;
    margin-right: auto;
    margin-left: auto;
}

/* Buttons */
.btn {
  padding: 0.85rem 1.8rem;
  border-radius: var(--border-radius);
  font-weight: 600;
  transition: all var(--transition-speed) var(--transition-timing);
  text-transform: uppercase;
  font-size: 0.85rem;
  letter-spacing: 0.8px;
  border: 1px solid transparent;
  line-height: 1.5;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  position: relative;
  overflow: hidden;
  box-shadow: var(--box-shadow);
  z-index: 1;
}

.btn i {
  transition: transform var(--transition-speed) var(--transition-timing);
}

.btn:hover i {
  transform: translateX(3px);
}

.btn-primary {
  color: var(--text-light);
  background: var(--gradient-primary);
  border: none;
  box-shadow: 0 5px 15px rgba(45, 130, 254, 0.3);
  position: relative;
  overflow: hidden;
}

.btn-primary::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--gradient-blue);
  opacity: 0;
  transition: opacity var(--transition-speed) var(--transition-timing);
  z-index: -1;
}

.btn-primary:hover::before {
  opacity: 1;
}

.btn-primary::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 5px;
  height: 5px;
  background: rgba(255, 255, 255, 0.3);
  opacity: 0;
  border-radius: 100%;
  transform: scale(1, 1) translate(-50%);
  transform-origin: 50% 50%;
}

.btn-primary:hover::after {
  animation: ripple 1s ease-out;
}

@keyframes ripple {
  0% {
    transform: scale(0, 0);
    opacity: 0.5;
  }
  20% {
    transform: scale(25, 25);
    opacity: 0.3;
  }
  100% {
    opacity: 0;
    transform: scale(40, 40);
  }
}

.btn-primary:hover {
  color: var(--text-light);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(45, 130, 254, 0.4);
}

.btn-outline-primary {
  color: var(--primary-accent);
  background: transparent;
  border: 1px solid var(--primary-accent);
  position: relative;
  z-index: 1;
  overflow: hidden;
}

.btn-outline-primary::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--gradient-primary);
  z-index: -1;
  transform: translateY(100%);
  transition: transform var(--transition-speed) var(--transition-timing);
}

.btn-outline-primary:hover {
  color: var(--text-light);
  border-color: transparent;
}

.btn-outline-primary:hover::before {
  transform: translateY(0);
}

.btn-hero {
  min-width: 180px;
  height: 52px;
}

/* Navigation */
.navbar {
  height: var(--navbar-height);
  background-color: rgba(8, 12, 23, 0.85) !important; /* Darkest BG with transparency */
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border-color);
  padding-top: 0;
  padding-bottom: 0;
  transition: all var(--transition-speed) var(--transition-timing);
  z-index: var(--z-nav);
}

.navbar.scrolled {
  background-color: rgba(8, 12, 23, 0.95) !important; /* Less transparent on scroll */
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.15);
  height: 70px;
}

.navbar > .container,
.navbar > .container-fluid {
  height: 100%;
  display: flex;
  flex-wrap: inherit; 
  align-items: center;
  justify-content: space-between;
}

.navbar-brand {
  position: relative;
  display: flex;
  align-items: center;
  padding: 0;
  margin-right: 1.5rem;
  font-family: var(--font-secondary);
  font-weight: 700;
}

.brand-text {
  font-size: 1.8rem;
  color: var(--text-light) !important; 
  letter-spacing: 1.5px;
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  position: relative;
}

.brand-text::after {
  content: 'SCRIPLIT';
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0.7;
  filter: blur(8px);
  -webkit-text-fill-color: var(--primary-accent);
  z-index: -1;
}

/* Contact info in navbar */
.navbar-contact {
  display: flex;
  gap: 1.2rem;
  margin-left: 1.5rem;
}

.contact-item {
  display: flex;
  align-items: center;
  font-size: 0.8rem;
  color: var(--text-medium);
  transition: all var(--transition-speed) var(--transition-timing);
  position: relative;
  padding-left: 0.8rem;
}

.contact-item:hover {
  color: var(--primary-accent);
}

.contact-item i {
  margin-right: 0.5rem;
  color: var(--primary-accent);
    font-size: 0.9rem;
}

.contact-item::after {
  content: '';
  position: absolute;
  bottom: -3px;
  left: 0;
  height: 1px;
  width: 0;
  background: var(--primary-accent);
  transition: width 0.3s ease;
}

.contact-item:hover::after {
  width: 100%;
}

/* Mobile contact info */
.mobile-contact {
  padding: 0.8rem 0;
  border-top: 1px solid rgba(230, 175, 46, 0.1);
  margin-top: 0.5rem;
}

.nav-contact-item {
  display: block;
  color: var(--text-medium);
  padding: 0.5rem 0;
  font-size: 0.9rem;
  transition: color var(--transition-speed) var(--transition-timing);
}

.nav-contact-item i {
  color: var(--primary-accent);
  width: 20px;
  text-align: center;
  margin-right: 0.5rem;
}

a.nav-contact-item:hover {
  color: var(--primary-accent);
  text-decoration: none;
}

.navbar-toggler {
  padding: 0.25rem 0.6rem;
    font-size: 1.25rem;
  line-height: 1;
  background-color: transparent;
  border: 1px solid var(--primary-accent);
  border-radius: var(--border-radius);
  transition: all 0.15s ease-in-out;
  color: var(--primary-accent);
}

.navbar-toggler:focus {
  box-shadow: 0 0 0 0.25rem rgba(45, 130, 254, 0.4);
  outline: none;
}

.navbar-toggler:hover {
  background-color: rgba(45, 130, 254, 0.1);
}

.navbar-toggler-icon {
    display: inline-block;
    width: 1.2em;
    height: 1.2em;
    vertical-align: middle;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(45, 130, 254, 0.8)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e"); /* Gold Toggler */
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100%;
}

/* Collapsed Navbar */
.navbar-collapse {
  position: absolute;
  top: var(--navbar-height);
  left: 0;
  right: 0;
  background-color: rgba(8, 12, 23, 0.95);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border-color);
  padding: 1rem 0;
  z-index: 950;
}

.navbar-nav {
  padding-left: 0;
  margin-bottom: 0;
  list-style: none;
  text-align: center;
}

.nav-item {
    margin-bottom: 0.25rem;
}

.nav-link {
  display: block;
  padding: 0.6rem 1rem;
  color: var(--text-medium);
  text-decoration: none;
  transition: all 0.2s ease-in-out;
  font-size: 0.95rem;
  font-weight: 500;
  position: relative;
}

.nav-link::after {
  content: '';
  position: absolute;
  bottom: 0.3rem;
  left: 1rem;
  width: 0;
  height: 2px;
  background: var(--gradient-primary);
  transition: width 0.3s ease;
  opacity: 0;
}

.nav-link:hover::after,
.nav-link:focus::after,
.nav-link.active::after {
  width: calc(100% - 2rem);
  opacity: 1;
}

.nav-link:hover,
.nav-link:focus,
.nav-link.active {
  color: var(--text-light);
}

.nav-btn {
  margin: 0.75rem auto;
  width: calc(100% - 2rem);
}

/* Hero Section */
.hero-section {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding-top: var(--navbar-height);
  overflow: hidden;
  background-color: var(--background-darkest);
}

.hero-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: 
    radial-gradient(circle at 80% 20%, rgba(45, 130, 254, 0.1) 0%, rgba(8, 12, 23, 0) 30%),
    radial-gradient(circle at 20% 80%, rgba(99, 226, 183, 0.1) 0%, rgba(8, 12, 23, 0) 30%);
  z-index: var(--z-particles);
}

.hero-row {
  min-height: calc(100vh - var(--navbar-height) - 3rem);
}

.particles-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: var(--z-particles);
  opacity: 0.6;
  will-change: transform;
  pointer-events: none; /* Improves performance by disabling mouse events when not needed */
}

.floating-object {
  position: absolute;
  background: linear-gradient(135deg, rgba(45, 130, 254, 0.4), rgba(0, 217, 255, 0.4));
  border-radius: 50%;
  filter: blur(20px);
  z-index: 1;
  animation: float 10s infinite ease-in-out;
  transform: translateZ(0);
  will-change: transform;
}

.obj-1 {
    width: 200px;
    height: 200px;
    top: 20%;
    left: 10%;
    animation-delay: 0s;
}

.obj-2 {
    width: 150px;
    height: 150px;
    bottom: 15%;
    right: 10%;
    animation-delay: 2s;
}

.obj-3 {
    width: 100px;
    height: 100px;
    top: 10%;
    right: 15%;
    animation-delay: 1s;
}

.obj-4 {
    width: 120px;
    height: 120px;
    bottom: 20%;
    left: 15%;
    animation-delay: 3s;
}

@keyframes float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-20px); }
}

.hero-content {
  position: relative;
  z-index: var(--z-content);
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  background-color: rgba(45, 130, 254, 0.1);
  border: 1px solid rgba(45, 130, 254, 0.2);
  border-radius: 30px;
  padding: 0.5rem 1rem;
  margin-bottom: 1.5rem;
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}

.badge-icon {
  color: var(--primary-accent);
  margin-right: 0.5rem;
  display: inline-flex;
}

.badge-text {
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 0.5px;
  color: var(--text-medium);
}

.hero-title {
  margin-bottom: 1.5rem;
  background: linear-gradient(to right, var(--text-light), var(--text-medium));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 800;
}

.hero-subtitle {
  font-size: 1.1rem;
  color: var(--text-medium);
  margin-bottom: 2rem;
  max-width: 90%;
}

.hero-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem 3rem;
  margin-bottom: 2rem;
}

.stat-item {
  display: flex;
  flex-direction: column;
}

.stat-number {
  font-family: var(--font-secondary);
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--text-light);
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1.2;
}

.stat-label {
    font-size: 0.9rem;
  color: var(--text-medium);
  margin-top: 0.25rem;
}

.hero-cta {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

/* Hero Visual - Tech Icons Animation */
.hero-visual {
    position: relative;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: var(--z-visual);
}

.glow-circle {
    position: absolute;
  width: 280px;
  height: 280px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(45, 130, 254, 0.2) 0%, rgba(8, 12, 23, 0) 70%);
  animation: pulse 5s ease-in-out infinite;
}

@keyframes pulse {
  0%, 100% {
    transform: scale(1);
    opacity: 0.2;
  }
  50% {
    transform: scale(1.1);
    opacity: 0.3;
  }
}

.tech-icons {
  position: relative;
  width: 300px;
  height: 300px;
}

.tech-icon-wrapper {
    position: absolute;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: var(--background-card);
  border: 1px solid var(--border-color);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--box-shadow);
  transition: all 0.3s ease;
}

.tech-icon-wrapper i {
  font-size: 30px;
  color: var(--primary-accent);
}

.ti-1 {
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  animation: orbit 15s linear infinite;
}

.ti-2 {
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  animation: orbit 15s linear infinite 3s;
}

.ti-3 {
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  animation: orbit 15s linear infinite 6s;
}

.ti-4 {
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  animation: orbit 15s linear infinite 9s;
}

.ti-5 {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: 80px;
}

.ti-5 i {
  font-size: 45px;
}

@keyframes orbit {
  0% {
    transform: rotate(0deg) translateX(120px) rotate(0deg);
  }
  100% {
    transform: rotate(360deg) translateX(120px) rotate(-360deg);
  }
}

/* General Section Styling */
section {
  position: relative;
    padding: var(--section-padding-y) 0;
  overflow: hidden;
  z-index: 1;
  /* Add hardware acceleration for smoother animations */
  will-change: transform;
  transform: translateZ(0);
  backface-visibility: hidden;
  perspective: 1000px;
}

section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
  width: 100%;
    height: 100%;
  background: radial-gradient(circle at 80% 20%, rgba(45, 130, 254, 0.05) 0%, rgba(8, 12, 23, 0) 25%);
  z-index: 0;
  pointer-events: none;
}

.section-badge {
  display: inline-block;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--primary-accent);
  margin-bottom: 1.25rem;
  padding: 0.25rem 0;
    position: relative;
}

.section-badge::after {
    content: '';
  position: absolute;
  bottom: 0;
    left: 0;
  width: 3rem;
  height: 3px;
  background: var(--gradient-primary);
  border-radius: 2px;
}

.section-title {
  margin-bottom: 1.5rem;
  color: var(--text-light);
  position: relative;
}

.section-subtitle {
  font-size: 1.1rem;
  color: var(--text-medium);
  margin-bottom: 3rem;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

/* FOOTER STYLING */
.modern-footer {
  background-color: var(--background-dark);
  color: var(--text-medium);
  border-top: 1px solid var(--border-color);
}

.footer-logo {
  font-family: var(--font-secondary);
  font-weight: 700;
  font-size: 1.8rem;
  color: var(--text-light);
  letter-spacing: 1.5px;
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  position: relative;
}

.footer-logo::after {
  content: 'SCRIPLIT';
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0.5;
  filter: blur(5px);
  -webkit-text-fill-color: var(--primary-accent);
  z-index: -1;
}

.footer-about p {
  margin-bottom: 1.5rem;
  font-size: 0.95rem;
  line-height: 1.6;
}

.footer-contact-info {
  margin-bottom: 1.5rem;
}

.footer-contact-item {
  display: flex;
  align-items: center;
  margin-bottom: 0.75rem;
  color: var(--text-medium);
  font-size: 0.9rem;
}

.footer-contact-item i {
  margin-right: 0.75rem;
  font-size: 1rem;
  color: var(--primary-accent);
  width: 1.25rem;
    }

    .social-links {
  display: flex;
  gap: 1rem;
        justify-content: center;
}

.social-link {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid var(--border-color);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-medium);
  background-color: rgba(255, 255, 255, 0.05);
  transition: all 0.3s ease;
}

.social-link:hover {
  color: var(--text-light);
  background: var(--gradient-primary);
  border-color: transparent;
  transform: translateY(-3px);
}

/* SCROLL ANIMATIONS */
[data-aos="fade-up"] {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

[data-aos="fade-up"].aos-animate {
  opacity: 1;
  transform: translateY(0);
}

/* RESPONSIVE STYLES */
@media (min-width: 768px) {
  :root {
    --section-padding-y: 5rem;
    --container-padding: 1.5rem;
  }

  /* Adjust heading sizes */
  h1, .h1 { font-size: calc(2.2rem + 1.8vw); } 
  h2, .h2 { font-size: calc(1.6rem + 0.9vw); } 
  h3, .h3 { font-size: calc(1.3rem + 0.3vw); }
  h4, .h4 { font-size: 1.3rem; }

  /* Navbar */
  .navbar-expand-md .navbar-collapse {
    display: flex !important; 
    flex-basis: auto;
    position: static;
    background: none;
    border: none;
  padding: 0;
  }

  .navbar-expand-md .navbar-nav {
    flex-direction: row;
    text-align: left;
  }

  .navbar-expand-md .nav-item {
    margin-bottom: 0;
    margin-left: 0.5rem;
  }

  .navbar-expand-md .nav-link {
    padding-right: 0.8rem;
    padding-left: 0.8rem;
  }

  /* Hero Section */
  .hero-subtitle {
    font-size: 1.2rem; 
    max-width: 85%;
  }

  .hero-stats {
    flex-wrap: nowrap;
  }
}

@media (min-width: 992px) {
  :root {
    --section-padding-y: 6.5rem; 
  }

  /* Navbar */
  .navbar-expand-lg .navbar-toggler { 
    display: none; 
  }

  .navbar-expand-lg .navbar-collapse {
    display: flex !important; 
    flex-basis: auto;
    position: static;
    background: none;
    border: none;
    padding: 0;
  }

  .navbar-expand-lg .navbar-nav {
    flex-direction: row;
    text-align: left;
  }

  .navbar-expand-lg .navbar-nav .nav-link {
    padding-right: 1rem;
    padding-left: 1rem;
  }

  .navbar-expand-lg .nav-item {
    margin-left: 0.5rem;
  margin-bottom: 0;
}

  .nav-btn {
    margin: 0 0 0 0.5rem;
    width: auto;
  }

  /* Hero Section */
  .hero-subtitle { 
    font-size: 1.25rem;
    max-width: 80%;
  }

  .hero-stats {
    margin-bottom: 2.5rem;
  }

  .stat-number {
    font-size: 2.5rem;
  }
}

@media (min-width: 1200px) {
  h1, .h1 { font-size: calc(2.5rem + 2vw); }
  h2, .h2 { font-size: calc(1.8rem + 1vw); }
  
  .hero-subtitle { 
    font-size: 1.3rem;
    max-width: 75%;
  }

  .navbar-expand-lg .nav-item {
    margin-left: 1rem;
  }
}

/* GSAP / Animation Helper Classes (Keep if used by JS) */
/* No need for these if animations applied directly in JS */

/* Add any other necessary overrides below */

/* Ensure high specificity for body background */
body#page-top, html > body { /* Example of higher specificity */
    background-color: var(--background-darkest) !important;
    background-image: var(--gradient-background) !important; /* Updated gradient */
    color: var(--text-light) !important;
}

/* Apply Glassmorphism */
.glass-effect {
    background: var(--glass-bg);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: var(--glass-border);
    border-radius: var(--border-radius-lg);
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
}

/* Alternative glass effect for variety */
.glass-effect-alt {
    background: rgba(230, 175, 46, 0.08); /* More gold tint */
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid rgba(230, 175, 46, 0.2);
    border-radius: var(--border-radius-lg);
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
}

/* Web Development Section Styles */
.web-development-section {
    background-color: var(--background-darkest); /* Or another dark variant */
}

.feature-list-alt {
    padding-left: 0;
    list-style: none;
    margin-top: 1.5rem;
}

.feature-list-alt li {
    display: flex;
    align-items: flex-start; 
  margin-bottom: 0.75rem;
    color: var(--text-medium);
    font-size: 0.95rem;
}

.feature-list-alt i {
    color: var(--primary-accent);
    margin-top: 0.15rem; /* Align icon better */
    flex-shrink: 0;
    width: 20px; /* Ensure consistent spacing */
}

.tech-icons-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(60px, 1fr));
    gap: 1.5rem;
    margin-top: 1.5rem;
}

.tech-icon {
  text-align: center;
    font-size: 2.5rem; /* Icon size */
    color: var(--text-medium);
    transition: all var(--transition-speed) var(--transition-timing);
}

.tech-icon:hover {
    color: var(--primary-accent);
    transform: scale(1.1);
}

.tech-icon i {
    display: block;
}

/* SEO Services Section Styles */
.seo-services-section {
    background-color: var(--background-dark);
}

/* Content Creation Section Styles */
.content-creation-section {
    background-color: var(--background-darkest);
}

/* Why Choose Us Section */
.why-choose-visual {
    /* Style the central icon/placeholder */
    padding: 3rem 0;
}

.why-choose-visual i {
     color: var(--primary-accent);
     opacity: 0.15; /* Make it subtle */
}

/* Removed .why-choose-section .img-fluid */

/* Alternative Stats Block */
.stats-row-alt {
    padding: 2rem 1rem;
    background-color: rgba(42, 40, 39, 0.5); /* --background-dark with alpha */
    border-radius: var(--border-radius-lg);
    border: 1px solid var(--border-color);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
}

.stat-box-alt {
    text-align: center;
}

.stat-icon-alt i {
    color: var(--primary-accent);
    margin-bottom: 0.75rem;
}

.stat-value-alt {
    font-size: 2rem;
  font-weight: 700;
    font-family: var(--font-secondary);
    color: var(--text-light);
    margin-bottom: 0.2rem;
    line-height: 1.1;
}

.stat-desc-alt {
    font-size: 0.8rem;
    color: var(--text-medium);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Services Section - Fix missing objects */
.services-section .service-card-modern {
  position: relative;
  overflow: hidden;
}

.service-card-modern::before {
  content: '';
  position: absolute;
    top: -50px;
    right: -50px;
    width: 100px;
    height: 100px;
    background: radial-gradient(circle, rgba(230, 175, 46, 0.2) 0%, rgba(230, 175, 46, 0) 70%);
    border-radius: 50%;
    z-index: 0;
    opacity: 0.5;
}

.service-icon-modern {
  position: relative;
    z-index: 1;
}

/* Bootstrap Overrides */
/* This section ensures Bootstrap components follow our theme */

/* Card Overrides */
.card {
  background-color: var(--background-card);
  border: 1px solid var(--border-light);
  border-radius: var(--border-radius);
  box-shadow: var(--box-shadow-card);
  transition: all var(--transition-speed) var(--transition-timing);
}

.card:hover {
  transform: translateY(-5px);
  box-shadow: var(--box-shadow-hover);
}

.card-header {
  background: rgba(45, 130, 254, 0.1);
  border-bottom: 1px solid var(--border-light);
  font-weight: 600;
}

.card-footer {
  background: rgba(45, 130, 254, 0.05);
  border-top: 1px solid var(--border-light);
}

.card-title {
  color: var(--text-light);
  font-family: var(--font-secondary);
  font-weight: 700;
}

.card-text {
  color: var(--text-medium);
}

/* Badge Overrides */
.badge {
  font-weight: 500;
  padding: 0.5em 0.75em;
  border-radius: 6px;
}

.badge-primary {
  background-color: var(--primary-accent);
  color: var(--text-light);
}

.badge-secondary {
  background-color: var(--secondary-accent);
  color: var(--bs-dark);
}

/* Alert Overrides */
.alert {
  border: none;
  border-radius: var(--border-radius);
  padding: 1rem 1.25rem;
}

.alert-primary {
  background-color: rgba(45, 130, 254, 0.15);
  color: var(--primary-accent);
}

.alert-secondary {
  background-color: rgba(0, 217, 255, 0.15);
  color: var(--secondary-accent);
}

/* Table Overrides */
.table {
  color: var(--text-medium);
}

.table-dark {
  background-color: var(--background-dark);
  color: var(--text-light);
}

.table thead th {
  border-bottom-color: var(--border-light);
  color: var(--text-light);
  font-weight: 600;
}

.table-hover tbody tr:hover {
  background-color: rgba(45, 130, 254, 0.05);
}

/* Bootstrap Button Overrides */
.btn {
  padding: 0.85rem 1.8rem;
  border-radius: var(--border-radius);
  font-weight: 600;
  transition: all var(--transition-speed) var(--transition-timing);
  text-transform: uppercase;
  font-size: 0.85rem;
  letter-spacing: 0.8px;
  border: 1px solid transparent;
  line-height: 1.5;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  position: relative;
  overflow: hidden;
  box-shadow: var(--box-shadow);
  z-index: 1;
}

/* Background and Text Colors */
.bg-primary {
  background-color: var(--primary-accent) !important;
}

.bg-secondary {
  background-color: var(--secondary-accent) !important;
}

.bg-dark {
  background-color: var(--background-darkest) !important;
}

.bg-light {
  background-color: var(--bs-light) !important;
}

.bg-card {
  background-color: var(--background-card) !important;
}

.text-primary {
  color: var(--primary-accent) !important;
}

.text-secondary {
  color: var(--secondary-accent) !important;
}

.text-light {
  color: var(--text-light) !important;
}

.text-medium {
  color: var(--text-medium) !important;
}

.text-dark {
  color: var(--text-dark) !important;
}

/* Form Controls */
.form-control, .form-select {
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border-light);
  color: var(--text-light);
  border-radius: var(--border-radius);
  padding: 0.75rem 1rem;
  transition: all var(--transition-speed) var(--transition-timing);
}

.form-control:focus, .form-select:focus {
  background-color: rgba(255, 255, 255, 0.08);
  border-color: var(--primary-accent);
  box-shadow: 0 0 0 0.25rem rgba(45, 130, 254, 0.25);
  color: var(--text-light);
}

.form-control::placeholder {
  color: var(--text-medium);
  opacity: 0.7;
}

.form-select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23A7B9D0' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");
}

.form-check-input {
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border-light);
}

.form-check-input:checked {
  background-color: var(--primary-accent);
  border-color: var(--primary-accent);
}

.input-group-text {
  background-color: rgba(45, 130, 254, 0.1);
  border: 1px solid var(--border-light);
  color: var(--text-medium);
}

/* Navbar */
.navbar {
  height: var(--navbar-height);
  background-color: rgba(8, 12, 23, 0.85) !important; /* Darkest BG with transparency */
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border-color);
  padding-top: 0;
  padding-bottom: 0;
  transition: all var(--transition-speed) var(--transition-timing);
  z-index: var(--z-nav);
}

.navbar.scrolled {
  background-color: rgba(8, 12, 23, 0.95) !important; /* Less transparent on scroll */
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.15);
  height: 70px;
}

.navbar > .container,
.navbar > .container-fluid {
  height: 100%;
  display: flex;
  flex-wrap: inherit; 
  align-items: center;
  justify-content: space-between;
}

.navbar-brand {
  position: relative;
  display: flex;
  align-items: center;
  padding: 0;
  margin-right: 1.5rem;
  font-family: var(--font-secondary);
  font-weight: 700;
}

.brand-text {
  font-size: 1.8rem;
  color: var(--text-light) !important; 
  letter-spacing: 1.5px;
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  position: relative;
}

.brand-text::after {
  content: 'SCRIPLIT';
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0.7;
  filter: blur(8px);
  -webkit-text-fill-color: var(--primary-accent);
  z-index: -1;
}

/* Contact info in navbar */
.navbar-contact {
  display: flex;
  gap: 1.2rem;
  margin-left: 1.5rem;
}

.contact-item {
  display: flex;
  align-items: center;
  font-size: 0.8rem;
  color: var(--text-medium);
  transition: all var(--transition-speed) var(--transition-timing);
  position: relative;
  padding-left: 0.8rem;
}

.contact-item:hover {
  color: var(--primary-accent);
}

.contact-item i {
  margin-right: 0.5rem;
  color: var(--primary-accent);
    font-size: 0.9rem;
}

.contact-item::after {
    content: '';
    position: absolute;
  bottom: -3px;
    left: 0;
    height: 1px;
  width: 0;
  background: var(--primary-accent);
  transition: width 0.3s ease;
}

.contact-item:hover::after {
  width: 100%;
}

/* Mobile contact info */
.mobile-contact {
  padding: 0.8rem 0;
  border-top: 1px solid rgba(230, 175, 46, 0.1);
  margin-top: 0.5rem;
}

.nav-contact-item {
  display: block;
  color: var(--text-medium);
  padding: 0.5rem 0;
  font-size: 0.9rem;
  transition: color var(--transition-speed) var(--transition-timing);
}

.nav-contact-item i {
  color: var(--primary-accent);
  width: 20px;
  text-align: center;
  margin-right: 0.5rem;
}

a.nav-contact-item:hover {
  color: var(--primary-accent);
  text-decoration: none;
}

.navbar-toggler {
  padding: 0.25rem 0.6rem;
  font-size: 1.25rem;
  line-height: 1;
  background-color: transparent;
  border: 1px solid var(--primary-accent);
  border-radius: var(--border-radius);
  transition: all 0.15s ease-in-out;
  color: var(--primary-accent);
}

.navbar-toggler:focus {
  box-shadow: 0 0 0 0.25rem rgba(45, 130, 254, 0.4);
  outline: none;
}

.navbar-toggler:hover {
  background-color: rgba(45, 130, 254, 0.1);
}

.navbar-toggler-icon {
    display: inline-block;
    width: 1.2em;
    height: 1.2em;
    vertical-align: middle;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(45, 130, 254, 0.8)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e"); /* Gold Toggler */
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100%;
}

/* Collapsed Navbar */
.navbar-collapse {
    position: absolute;
  top: var(--navbar-height);
    left: 0;
  right: 0;
  background-color: rgba(8, 12, 23, 0.95);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border-color);
  padding: 1rem 0;
  z-index: 950;
}

.navbar-nav {
  padding-left: 0;
  margin-bottom: 0;
    list-style: none;
  text-align: center;
}

.nav-item {
    margin-bottom: 0.25rem;
}

.nav-link {
  display: block;
  padding: 0.6rem 1rem;
  color: var(--text-medium);
    text-decoration: none;
  transition: all 0.2s ease-in-out;
  font-size: 0.95rem;
  font-weight: 500;
    position: relative;
}

.nav-link::after {
  content: '';
    position: absolute;
  bottom: 0.3rem;
  left: 1rem;
  width: 0;
  height: 2px;
  background: var(--gradient-primary);
  transition: width 0.3s ease;
    opacity: 0;
}

.nav-link:hover::after,
.nav-link:focus::after,
.nav-link.active::after {
  width: calc(100% - 2rem);
    opacity: 1;
}

.nav-link:hover,
.nav-link:focus,
.nav-link.active {
  color: var(--text-light);
}

.nav-btn {
  margin: 0.75rem auto;
  width: calc(100% - 2rem);
}

/* Hero Section */
.hero-section {
  position: relative;
  min-height: 100vh;
    display: flex;
    align-items: center;
  padding-top: var(--navbar-height);
  overflow: hidden;
  background-color: var(--background-darkest);
}

.hero-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: 
    radial-gradient(circle at 80% 20%, rgba(45, 130, 254, 0.1) 0%, rgba(8, 12, 23, 0) 30%),
    radial-gradient(circle at 20% 80%, rgba(99, 226, 183, 0.1) 0%, rgba(8, 12, 23, 0) 30%);
  z-index: var(--z-particles);
}

.hero-row {
  min-height: calc(100vh - var(--navbar-height) - 3rem);
}

.particles-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: var(--z-particles);
  opacity: 0.6;
  will-change: transform;
  pointer-events: none; /* Improves performance by disabling mouse events when not needed */
}

.floating-object {
  position: absolute;
  background: linear-gradient(135deg, rgba(45, 130, 254, 0.4), rgba(0, 217, 255, 0.4));
  border-radius: 50%;
  filter: blur(20px);
  z-index: 1;
  animation: float 10s infinite ease-in-out;
  transform: translateZ(0);
  will-change: transform;
}

.obj-1 {
    width: 200px;
    height: 200px;
    top: 20%;
    left: 10%;
    animation-delay: 0s;
}

.obj-2 {
    width: 150px;
    height: 150px;
    bottom: 15%;
    right: 10%;
    animation-delay: 2s;
}

.obj-3 {
    width: 100px;
    height: 100px;
    top: 10%;
    right: 15%;
    animation-delay: 1s;
}

.obj-4 {
    width: 120px;
    height: 120px;
    bottom: 20%;
    left: 15%;
    animation-delay: 3s;
}

@keyframes float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-20px); }
}

.hero-content {
  position: relative;
  z-index: var(--z-content);
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  background-color: rgba(45, 130, 254, 0.1);
  border: 1px solid rgba(45, 130, 254, 0.2);
  border-radius: 30px;
  padding: 0.5rem 1rem;
  margin-bottom: 1.5rem;
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}

.badge-icon {
  color: var(--primary-accent);
  margin-right: 0.5rem;
  display: inline-flex;
}

.badge-text {
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 0.5px;
  color: var(--text-medium);
}

.hero-title {
  margin-bottom: 1.5rem;
  background: linear-gradient(to right, var(--text-light), var(--text-medium));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 800;
}

.hero-subtitle {
    font-size: 1.1rem;
  color: var(--text-medium);
  margin-bottom: 2rem;
  max-width: 90%;
}

.hero-stats {
    display: flex;
  flex-wrap: wrap;
  gap: 2rem 3rem;
  margin-bottom: 2rem;
}

.stat-item {
  display: flex;
  flex-direction: column;
}

.stat-number {
  font-family: var(--font-secondary);
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--text-light);
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1.2;
}

.stat-label {
    font-size: 0.9rem;
  color: var(--text-medium);
  margin-top: 0.25rem;
}

.hero-cta {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

/* Hero Visual - Tech Icons Animation */
.hero-visual {
    position: relative;
  height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  z-index: var(--z-visual);
}

.glow-circle {
    position: absolute;
  width: 280px;
  height: 280px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(45, 130, 254, 0.2) 0%, rgba(8, 12, 23, 0) 70%);
  animation: pulse 5s ease-in-out infinite;
}

@keyframes pulse {
  0%, 100% {
    transform: scale(1);
    opacity: 0.2;
  }
  50% {
    transform: scale(1.1);
    opacity: 0.3;
  }
}

.tech-icons {
    position: relative;
  width: 300px;
  height: 300px;
}

.tech-icon-wrapper {
    position: absolute;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: var(--background-card);
  border: 1px solid var(--border-color);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--box-shadow);
    transition: all 0.3s ease;
}

.tech-icon-wrapper i {
  font-size: 30px;
  color: var(--primary-accent);
}

.ti-1 {
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  animation: orbit 15s linear infinite;
}

.ti-2 {
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  animation: orbit 15s linear infinite 3s;
}

.ti-3 {
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  animation: orbit 15s linear infinite 6s;
}

.ti-4 {
  top: 50%;
    left: 0;
  transform: translateY(-50%);
  animation: orbit 15s linear infinite 9s;
}

.ti-5 {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: 80px;
}

.ti-5 i {
  font-size: 45px;
}

@keyframes orbit {
  0% {
    transform: rotate(0deg) translateX(120px) rotate(0deg);
  }
  100% {
    transform: rotate(360deg) translateX(120px) rotate(-360deg);
  }
}

/* General Section Styling */
section {
    position: relative;
    padding: var(--section-padding-y) 0;
    overflow: hidden;
    z-index: 1;
    /* Add hardware acceleration for smoother animations */
    will-change: transform;
    transform: translateZ(0);
    backface-visibility: hidden;
    perspective: 1000px;
}

section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  background: radial-gradient(circle at 80% 20%, rgba(45, 130, 254, 0.05) 0%, rgba(8, 12, 23, 0) 25%);
  z-index: 0;
  pointer-events: none;
}

.section-badge {
  display: inline-block;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--primary-accent);
  margin-bottom: 1.25rem;
  padding: 0.25rem 0;
    position: relative;
}

.section-badge::after {
    content: '';
    position: absolute;
  bottom: 0;
    left: 0;
  width: 3rem;
  height: 3px;
  background: var(--gradient-primary);
  border-radius: 2px;
}

.section-title {
  margin-bottom: 1.5rem;
  color: var(--text-light);
  position: relative;
}

.section-subtitle {
  font-size: 1.1rem;
  color: var(--text-medium);
  margin-bottom: 3rem;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

/* FOOTER STYLING */
.modern-footer {
  background-color: var(--background-dark);
  color: var(--text-medium);
  border-top: 1px solid var(--border-color);
}

.footer-logo {
  font-family: var(--font-secondary);
  font-weight: 700;
  font-size: 1.8rem;
  color: var(--text-light);
  letter-spacing: 1.5px;
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  position: relative;
}

.footer-logo::after {
  content: 'SCRIPLIT';
    position: absolute;
    left: 0;
  top: 0;
  opacity: 0.5;
  filter: blur(5px);
  -webkit-text-fill-color: var(--primary-accent);
  z-index: -1;
}

.footer-about p {
  margin-bottom: 1.5rem;
  font-size: 0.95rem;
  line-height: 1.6;
    }

    .footer-contact-info {
  margin-bottom: 1.5rem;
}

.footer-contact-item {
  display: flex;
  align-items: center;
  margin-bottom: 0.75rem;
  color: var(--text-medium);
  font-size: 0.9rem;
}

.footer-contact-item i {
  margin-right: 0.75rem;
  font-size: 1rem;
  color: var(--primary-accent);
  width: 1.25rem;
    }

    .social-links {
  display: flex;
  gap: 1rem;
        justify-content: center;
    }

.social-link {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid var(--border-color);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-medium);
  background-color: rgba(255, 255, 255, 0.05);
  transition: all 0.3s ease;
}

.social-link:hover {
  color: var(--text-light);
  background: var(--gradient-primary);
  border-color: transparent;
  transform: translateY(-3px);
}

/* SCROLL ANIMATIONS */
[data-aos="fade-up"] {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

[data-aos="fade-up"].aos-animate {
  opacity: 1;
  transform: translateY(0);
}

/* RESPONSIVE STYLES */
@media (min-width: 768px) {
  :root {
    --section-padding-y: 5rem;
    --container-padding: 1.5rem;
  }

  /* Adjust heading sizes */
  h1, .h1 { font-size: calc(2.2rem + 1.8vw); } 
  h2, .h2 { font-size: calc(1.6rem + 0.9vw); } 
  h3, .h3 { font-size: calc(1.3rem + 0.3vw); }
  h4, .h4 { font-size: 1.3rem; }

  /* Navbar */
  .navbar-expand-md .navbar-collapse {
    display: flex !important; 
    flex-basis: auto;
    position: static;
    background: none;
    border: none;
  padding: 0;
  }

  .navbar-expand-md .navbar-nav {
    flex-direction: row;
    text-align: left;
  }

  .navbar-expand-md .nav-item {
    margin-bottom: 0;
    margin-left: 0.5rem;
  }

  .navbar-expand-md .nav-link {
    padding-right: 0.8rem;
    padding-left: 0.8rem;
  }

  /* Hero Section */
  .hero-subtitle { 
  font-size: 1.2rem;
    max-width: 85%;
  }

  .hero-stats {
    flex-wrap: nowrap;
  }
}

@media (min-width: 992px) {
  :root {
    --section-padding-y: 6.5rem; 
  }

  /* Navbar */
  .navbar-expand-lg .navbar-toggler { 
    display: none; 
  }

  .navbar-expand-lg .navbar-collapse {
    display: flex !important; 
    flex-basis: auto;
    position: static;
    background: none;
    border: none;
    padding: 0;
  }

  .navbar-expand-lg .navbar-nav {
    flex-direction: row;
    text-align: left;
  }

  .navbar-expand-lg .navbar-nav .nav-link {
    padding-right: 1rem;
    padding-left: 1rem;
  }

  .navbar-expand-lg .nav-item {
    margin-left: 0.5rem;
  margin-bottom: 0;
}

  .nav-btn {
    margin: 0 0 0 0.5rem;
    width: auto;
  }

  /* Hero Section */
  .hero-subtitle { 
    font-size: 1.25rem;
    max-width: 80%;
  }

  .hero-stats {
    margin-bottom: 2.5rem;
  }

  .stat-number {
    font-size: 2.5rem;
  }
}

@media (min-width: 1200px) {
  h1, .h1 { font-size: calc(2.5rem + 2vw); }
  h2, .h2 { font-size: calc(1.8rem + 1vw); }
  
  .hero-subtitle { 
    font-size: 1.3rem;
    max-width: 75%;
  }

  .navbar-expand-lg .nav-item {
    margin-left: 1rem;
  }
}

/* GSAP / Animation Helper Classes (Keep if used by JS) */
/* No need for these if animations applied directly in JS */

/* Add any other necessary overrides below */

/* Ensure high specificity for body background */
body#page-top, html > body { /* Example of higher specificity */
    background-color: var(--background-darkest) !important;
    background-image: var(--gradient-background) !important; /* Updated gradient */
    color: var(--text-light) !important;
}

/* Apply Glassmorphism */
.glass-effect {
    background: var(--glass-bg);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: var(--glass-border);
    border-radius: var(--border-radius-lg);
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
}

/* Alternative glass effect for variety */
.glass-effect-alt {
    background: rgba(230, 175, 46, 0.08); /* More gold tint */
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid rgba(230, 175, 46, 0.2);
    border-radius: var(--border-radius-lg);
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
}

/* Web Development Section Styles */
.web-development-section {
    background-color: var(--background-darkest); /* Or another dark variant */
}

.feature-list-alt {
    padding-left: 0;
    list-style: none;
    margin-top: 1.5rem;
}

.feature-list-alt li {
    display: flex;
    align-items: flex-start; 
    margin-bottom: 0.75rem;
    color: var(--text-medium);
    font-size: 0.95rem;
}

.feature-list-alt i {
    color: var(--primary-accent);
    margin-top: 0.15rem; /* Align icon better */
    flex-shrink: 0;
    width: 20px; /* Ensure consistent spacing */
}

.tech-icons-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(60px, 1fr));
    gap: 1.5rem;
    margin-top: 1.5rem;
}

.tech-icon {
    text-align: center;
    font-size: 2.5rem; /* Icon size */
    color: var(--text-medium);
    transition: all var(--transition-speed) var(--transition-timing);
}

.tech-icon:hover {
    color: var(--primary-accent);
    transform: scale(1.1);
}

.tech-icon i {
    display: block;
}

/* SEO Services Section Styles */
.seo-services-section {
    background-color: var(--background-dark);
}

/* Content Creation Section Styles */
.content-creation-section {
    background-color: var(--background-darkest);
}

/* Why Choose Us Section */
.why-choose-visual {
    /* Style the central icon/placeholder */
    padding: 3rem 0;
}

.why-choose-visual i {
     color: var(--primary-accent);
     opacity: 0.15; /* Make it subtle */
}

/* Removed .why-choose-section .img-fluid */

/* Alternative Stats Block */
.stats-row-alt {
    padding: 2rem 1rem;
    background-color: rgba(42, 40, 39, 0.5); /* --background-dark with alpha */
    border-radius: var(--border-radius-lg);
    border: 1px solid var(--border-color);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
}

.stat-box-alt {
    text-align: center;
}

.stat-icon-alt i {
    color: var(--primary-accent);
    margin-bottom: 0.75rem;
}

.stat-value-alt {
    font-size: 2rem;
  font-weight: 700;
    font-family: var(--font-secondary);
    color: var(--text-light);
    margin-bottom: 0.2rem;
    line-height: 1.1;
}

.stat-desc-alt {
    font-size: 0.8rem;
    color: var(--text-medium);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Services Section - Fix missing objects */
.services-section .service-card-modern {
    position: relative;
    overflow: hidden;
}

.service-card-modern::before {
    content: '';
    position: absolute;
    top: -50px;
    right: -50px;
    width: 100px;
    height: 100px;
    background: radial-gradient(circle, rgba(230, 175, 46, 0.2) 0%, rgba(230, 175, 46, 0) 70%);
    border-radius: 50%;
    z-index: 0;
    opacity: 0.5;
}

.service-icon-modern {
    position: relative;
    z-index: 1;
}

/* Bootstrap Overrides */
/* This section ensures Bootstrap components follow our theme */

/* Card Overrides */
.card {
  background-color: var(--background-card);
  border: 1px solid var(--border-light);
  border-radius: var(--border-radius);
  box-shadow: var(--box-shadow-card);
  transition: all var(--transition-speed) var(--transition-timing);
}

.card:hover {
  transform: translateY(-5px);
  box-shadow: var(--box-shadow-hover);
}

.card-header {
  background: rgba(45, 130, 254, 0.1);
  border-bottom: 1px solid var(--border-light);
  font-weight: 600;
}

.card-footer {
  background: rgba(45, 130, 254, 0.05);
  border-top: 1px solid var(--border-light);
}

.card-title {
  color: var(--text-light);
  font-family: var(--font-secondary);
  font-weight: 700;
}

.card-text {
  color: var(--text-medium);
}

/* Badge Overrides */
.badge {
  font-weight: 500;
  padding: 0.5em 0.75em;
  border-radius: 6px;
}

.badge-primary {
  background-color: var(--primary-accent);
  color: var(--text-light);
}

.badge-secondary {
  background-color: var(--secondary-accent);
  color: var(--bs-dark);
}

/* Alert Overrides */
.alert {
  border: none;
  border-radius: var(--border-radius);
  padding: 1rem 1.25rem;
}

.alert-primary {
  background-color: rgba(45, 130, 254, 0.15);
  color: var(--primary-accent);
}

.alert-secondary {
  background-color: rgba(0, 217, 255, 0.15);
  color: var(--secondary-accent);
}

/* Table Overrides */
.table {
  color: var(--text-medium);
}

.table-dark {
  background-color: var(--background-dark);
  color: var(--text-light);
}

.table thead th {
  border-bottom-color: var(--border-light);
  color: var(--text-light);
  font-weight: 600;
}

.table-hover tbody tr:hover {
  background-color: rgba(45, 130, 254, 0.05);
}

/* Bootstrap Button Overrides */
.btn {
  padding: 0.85rem 1.8rem;
  border-radius: var(--border-radius);
  font-weight: 600;
  transition: all var(--transition-speed) var(--transition-timing);
  text-transform: uppercase;
  font-size: 0.85rem;
  letter-spacing: 0.8px;
  border: 1px solid transparent;
  line-height: 1.5;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  position: relative;
  overflow: hidden;
  box-shadow: var(--box-shadow);
  z-index: 1;
}

/* Newsletter Form Styling */
.newsletter-form {
  position: relative;
  display: flex;
  max-width: 100%;
}

.newsletter-form input[type="email"] {
  width: 100%;
  padding: 0.75rem 1rem;
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border-light);
  border-radius: var(--border-radius);
  color: var(--text-light);
  font-size: 0.9rem;
  transition: all var(--transition-speed) var(--transition-timing);
}

.newsletter-form input[type="email"]:focus {
  outline: none;
  border-color: var(--primary-accent);
  background-color: rgba(255, 255, 255, 0.08);
  box-shadow: 0 0 0 3px rgba(45, 130, 254, 0.15);
}

.newsletter-form input[type="email"]::placeholder {
  color: var(--text-medium);
  opacity: 0.7;
}

.newsletter-form button {
  position: absolute;
  right: 5px;
  top: 50%;
  transform: translateY(-50%);
  background: var(--gradient-primary);
  border: none;
  border-radius: var(--border-radius);
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-light);
  cursor: pointer;
  transition: all var(--transition-speed) var(--transition-timing);
}

.newsletter-form button:hover {
  transform: translateY(-50%) scale(1.05);
  box-shadow: 0 0 15px rgba(45, 130, 254, 0.3);
}

.newsletter-form button i {
  font-size: 0.9rem;
}

/* Scrolling Text Animation */
.scrolling-logos-section {
  overflow: hidden;
  background-color: var(--background-dark);
  border-top: 1px solid var(--border-light);
  border-bottom: 1px solid var(--border-light);
  padding: 1rem 0;
  position: relative;
}

.scrolling-wrapper {
  display: flex;
  width: 100%;
  overflow: hidden;
}

.scrolling-content {
  display: flex;
  animation: scroll 20s linear infinite;
  white-space: nowrap;
  flex-shrink: 0;
}

.scrolling-content span {
  display: inline-block;
  padding: 0 1.5rem;
  font-family: var(--font-secondary);
  font-weight: 600;
  font-size: 1.1rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--primary-accent);
  background: linear-gradient(90deg, var(--primary-accent), var(--secondary-accent));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

@keyframes scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}

/* 3D Objects and Animations */
.floating-object {
    position: absolute;
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.4), rgba(0, 217, 255, 0.4));
    border-radius: 50%;
    filter: blur(20px);
    z-index: 1;
    animation: float 10s infinite ease-in-out;
    transform: translateZ(0);
    will-change: transform;
}

.obj-1 {
    width: 200px;
    height: 200px;
    top: 20%;
    left: 10%;
    animation-delay: 0s;
}

.obj-2 {
    width: 150px;
    height: 150px;
    bottom: 15%;
    right: 10%;
    animation-delay: 2s;
}

.obj-3 {
    width: 100px;
    height: 100px;
    top: 10%;
    right: 15%;
    animation-delay: 1s;
}

.obj-4 {
    width: 120px;
    height: 120px;
    bottom: 20%;
    left: 15%;
    animation-delay: 3s;
}

/* 3D Objects for Service Section */
.service-3d-objects {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
}

.service-3d-object {
    position: absolute;
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.2), rgba(0, 217, 255, 0.2));
    border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%;
    z-index: 1;
    animation: morphBlob 15s infinite alternate ease-in-out;
}

.service-blob-1 {
    width: 300px;
    height: 300px;
    top: -100px;
    left: -100px;
    animation-delay: 0s;
}

.service-blob-2 {
    width: 250px;
    height: 250px;
    bottom: -100px;
    right: -50px;
    animation-delay: 5s;
}

.service-blob-3 {
    width: 200px;
    height: 200px;
    top: 50%;
    right: -50px;
    animation-delay: 2s;
}

/* 3D FAQ Objects */
.faq-3d-objects {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
}

.faq-3d-object {
    position: absolute;
    z-index: 0;
    opacity: 0.6;
    animation: rotate3D 20s infinite linear;
}

.faq-cube {
    width: 80px;
    height: 80px;
    top: 10%;
    left: 5%;
    background: rgba(45, 130, 254, 0.3);
    box-shadow: 0 0 20px rgba(45, 130, 254, 0.5);
    animation: rotateCube 25s infinite linear;
}

.faq-sphere {
    width: 100px;
    height: 100px;
    bottom: 10%;
    right: 5%;
    border-radius: 50%;
    background: rgba(0, 217, 255, 0.3);
    box-shadow: 0 0 20px rgba(0, 217, 255, 0.5);
    animation: float 15s infinite ease-in-out;
}

.faq-torus {
    width: 70px;
    height: 70px;
    top: 20%;
    right: 10%;
    border: 15px solid rgba(106, 90, 205, 0.3);
    border-radius: 50%;
    box-shadow: 0 0 20px rgba(106, 90, 205, 0.5);
    animation: rotateTorus 20s infinite linear;
}

.faq-pyramid {
    width: 0;
    height: 0;
    bottom: 20%;
    left: 10%;
    border-left: 40px solid transparent;
    border-right: 40px solid transparent;
    border-bottom: 70px solid rgba(255, 105, 180, 0.3);
    filter: drop-shadow(0 0 15px rgba(255, 105, 180, 0.5));
    animation: rotatePyramid 30s infinite linear;
}

/* About Section 3D Objects */
.about-3d-objects {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
}

.about-3d-object {
    position: absolute;
    z-index: 0;
    opacity: 0.5;
}

.about-circle {
    width: 200px;
    height: 200px;
    top: -50px;
    right: 10%;
    border-radius: 50%;
    background: radial-gradient(circle at center, rgba(45, 130, 254, 0.2), rgba(45, 130, 254, 0));
    animation: pulse 8s infinite alternate ease-in-out;
}

.about-square {
    width: 150px;
    height: 150px;
    bottom: -30px;
    left: 5%;
    background: rgba(0, 217, 255, 0.2);
    transform: rotate(45deg);
    animation: rotateSquare 15s infinite linear;
}

.about-triangle {
    width: 0;
    height: 0;
    top: 30%;
    left: -50px;
    border-left: 75px solid transparent;
    border-right: 75px solid transparent;
    border-bottom: 130px solid rgba(106, 90, 205, 0.2);
    animation: float 12s infinite ease-in-out;
}

/* Icon Styling and Animations */
.feature-icon, .service-icon, .tech-icon-wrapper, .social-icon,
.footer-contact-item i, .btn-icon, .faq-icon {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.feature-icon, .service-icon {
    width: 60px;
    height: 60px;
    border-radius: 12px;
    margin-bottom: 1.5rem;
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.15), rgba(0, 217, 255, 0.15));
    color: var(--color-primary);
    font-size: 1.5rem;
    box-shadow: 0 8px 24px rgba(45, 130, 254, 0.12);
}

.feature-icon:hover, .service-icon:hover {
    transform: translateY(-5px);
    background: var(--gradient-primary);
    color: white;
    box-shadow: 0 12px 30px rgba(45, 130, 254, 0.3);
}

.tech-icon-wrapper {
    position: absolute;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: rgba(11, 17, 33, 0.8);
    color: var(--color-primary);
    box-shadow: 0 0 20px rgba(45, 130, 254, 0.4);
    animation: orbitFloat 12s infinite linear;
}

.tech-icon-wrapper:hover {
    background: var(--gradient-primary);
    color: white;
}

.ti-1 { top: 15%; left: 20%; animation-delay: 0s; }
.ti-2 { top: 60%; left: 10%; animation-delay: 2s; }
.ti-3 { top: 80%; left: 40%; animation-delay: 4s; }
.ti-4 { top: 45%; right: 5%; animation-delay: 1s; }
.ti-5 { top: 10%; right: 20%; animation-delay: 3s; }

.social-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    color: var(--color-text-light);
    font-size: 1rem;
    margin-right: 0.5rem;
}

.social-icon:hover {
    background: var(--gradient-primary);
    transform: translateY(-3px);
}

.btn-icon {
    transition: transform 0.3s ease;
}

.btn:hover .btn-icon {
    transform: translateX(5px);
}

.faq-icon {
    color: var(--color-primary);
    font-size: 1.2rem;
}

/* Animation Keyframes */
@keyframes float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-20px); }
}

@keyframes morphBlob {
    0% { border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%; }
    25% { border-radius: 58% 42% 75% 25% / 76% 46% 54% 24%; }
    50% { border-radius: 50% 50% 33% 67% / 55% 27% 73% 45%; }
    75% { border-radius: 33% 67% 58% 42% / 63% 68% 32% 37%; }
    100% { border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%; }
}

@keyframes pulse {
    0%, 100% { transform: scale(1); opacity: 0.5; }
    50% { transform: scale(1.2); opacity: 0.8; }
}

@keyframes rotateSquare {
    0% { transform: rotate(45deg); }
    100% { transform: rotate(405deg); }
}

@keyframes rotateCube {
    0% { transform: rotateX(0) rotateY(0) rotateZ(0); }
    100% { transform: rotateX(360deg) rotateY(360deg) rotateZ(360deg); }
}

@keyframes rotateTorus {
    0% { transform: rotate(0) scale(1); }
    50% { transform: rotate(180deg) scale(1.2); }
    100% { transform: rotate(360deg) scale(1); }
}

@keyframes rotatePyramid {
    0% { transform: rotate(0) translateY(0); }
    50% { transform: rotate(180deg) translateY(-20px); }
    100% { transform: rotate(360deg) translateY(0); }
}

@keyframes orbitFloat {
    0% { transform: rotate(0) translateX(0) rotate(0); }
    100% { transform: rotate(360deg) translateX(20px) rotate(-360deg); }
}

/* Section-Specific Styling */
.section-badge {
    display: inline-block;
    padding: 0.5rem 1rem;
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.15), rgba(0, 217, 255, 0.15));
    color: var(--color-primary);
    border-radius: 30px;
    font-size: 0.85rem;
    font-weight: 600;
    margin-bottom: 1rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.section-title {
    font-size: 2.5rem;
    margin-bottom: 1.5rem;
    background: linear-gradient(90deg, #2D82FE, #00D9FF);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.section-subtitle {
    font-size: 1.1rem;
    color: var(--color-text-medium);
    max-width: 800px;
    margin: 0 auto 2rem;
}

/* Glass Effect for Cards and Containers */
.glass-effect {
    background: rgba(17, 25, 40, 0.75);
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.125);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.36);
    transition: all 0.3s ease;
}

.glass-effect:hover {
    box-shadow: 0 12px 48px 0 rgba(0, 0, 0, 0.5);
    transform: translateY(-5px);
}

/* Responsive Adjustments */
@media (max-width: 992px) {
    .floating-object {
        display: none;
    }
    
    .service-3d-objects, .faq-3d-objects, .about-3d-objects {
        display: none;
    }
    
    .section-title {
        font-size: 2rem;
    }
}

/* FAQ Section Styles */
.faq-section {
    position: relative;
    z-index: 10;
    background-color: var(--background-darkest);
    overflow: hidden;
}

.faq-section .section-title,
.faq-section .section-subtitle,
.faq-section .section-badge {
    position: relative;
    z-index: 20;
    color: var(--color-text-light);
}

.faq-section .accordion-item {
    position: relative;
    z-index: 20;
    background-color: rgba(17, 25, 40, 0.85);
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.faq-section .accordion-button {
    background-color: rgba(17, 25, 40, 0.9);
    color: var(--color-text-light);
    font-weight: 600;
    padding: 1.25rem;
    position: relative;
    z-index: 5;
}

.faq-section .accordion-button:not(.collapsed) {
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.2), rgba(0, 217, 255, 0.1));
    color: var(--color-text-light);
    box-shadow: none;
}

.faq-section .accordion-button:focus {
    box-shadow: none;
    border-color: rgba(45, 130, 254, 0.5);
}

.faq-section .accordion-button::after {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23ffffff'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}

.faq-section .accordion-body {
    background-color: rgba(11, 17, 33, 0.7);
    color: var(--color-text-medium);
    padding: 1.5rem;
    position: relative;
    z-index: 5;
}

.faq-3d-objects {
    pointer-events: none;
    z-index: 1;
}

.faq-section .btn {
    position: relative;
    z-index: 20;
}

.faq-icon {
    position: relative;
    z-index: 10;
}

/* FAQ Section Additional Styles */
.particle-container.faq-particles {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0.4;
    z-index: 1;
}

.faq-section {
    background: linear-gradient(to bottom, #081122, #0B1121);
}

.faq-section .section-title {
    color: white;
    text-shadow: 0 0 15px rgba(45, 130, 254, 0.4);
}

.faq-section .accordion-button:not(.collapsed) {
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.3), rgba(0, 217, 255, 0.2));
}

.faq-3d-object {
    transition: all 0.5s ease;
    opacity: 0.6;
}

.faq-3d-object:hover {
    opacity: 0.8;
}

.faq-cube {
    animation: floatCube 15s infinite ease-in-out;
}

.faq-sphere {
    animation: floatSphere 12s infinite ease-in-out;
}

.faq-torus {
    animation: floatTorus 18s infinite ease-in-out;
}

.faq-pyramid {
    animation: floatPyramid 20s infinite ease-in-out;
}

@keyframes floatCube {
    0%, 100% { transform: translate(0, 0) rotate3d(1, 1, 1, 0deg); }
    25% { transform: translate(15px, -15px) rotate3d(1, 1, 1, 90deg); }
    50% { transform: translate(0, 30px) rotate3d(1, 1, 1, 180deg); }
    75% { transform: translate(-15px, -15px) rotate3d(1, 1, 1, 270deg); }
}

@keyframes floatSphere {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50% { transform: translate(20px, 20px) scale(1.1); }
}

@keyframes floatTorus {
    0%, 100% { transform: translate(0, 0) rotate(0deg); }
    33% { transform: translate(15px, 10px) rotate(120deg); }
    66% { transform: translate(-15px, -10px) rotate(240deg); }
}

@keyframes floatPyramid {
    0%, 100% { transform: translate(0, 0) rotateY(0deg); }
    25% { transform: translate(10px, -15px) rotateY(90deg); }
    50% { transform: translate(0, 20px) rotateY(180deg); }
    75% { transform: translate(-10px, -15px) rotateY(270deg); }
}

/* Global Section Visibility Fix */
section {
    position: relative;
    z-index: 1;
}

.section-title-group,
.section-badge,
.section-title,
.section-subtitle,
.card,
.accordion-item,
.btn,
p,
h1, h2, h3, h4, h5, h6,
.hero-content,
.hero-subtitle,
.hero-stats,
.hero-cta,
.feature-item-modern,
.benefit-card,
.blog-card,
form,
.portfolio-card,
.testimonial-item,
.contact-card,
.service-card-modern {
    position: relative;
    z-index: 10;
}

/* Fix particles background positioning */
.particle-container,
.particles-container,
.particles-js-canvas-el {
    position: absolute !important;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
    z-index: 1 !important;
    pointer-events: none;
}

/* Add text shadow for better visibility */
.section-title {
    text-shadow: 0 2px 5px rgba(0, 0, 0, 0.5);
}

.section-subtitle,
p {
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

/* Enhance background contrast for better text visibility */
.bg-dark section::before,
.bg-dark::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(8, 12, 23, 0.6);
    z-index: 2;
}

/* Ensure glass-effect cards are properly visible */
.glass-effect {
    background: rgba(17, 25, 40, 0.75) !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3) !important;
}

/* Ensure section content has proper z-index */
.container {
    position: relative;
    z-index: 10;
}

/* About section specific fixes */
.about-agency-section {
    position: relative;
    z-index: 3;
}

.about-agency-section .container {
    position: relative;
    z-index: 15;
}

.about-agency-section p,
.about-agency-section h2,
.about-agency-section h3,
.about-agency-section h4,
.about-agency-section .feature-list-modern,
.about-agency-section .feature-item-modern,
.about-agency-section .feature-icon-modern,
.about-agency-section .stats-row-alt,
.about-agency-section .stat-box-alt {
    position: relative;
    z-index: 20;
}

/* Services section specific fixes */
.services-section {
    position: relative;
    z-index: 3;
}

.services-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, rgba(8, 12, 23, 0.7), rgba(8, 12, 23, 0.5));
    z-index: 2;
}

.services-section .container {
    position: relative;
    z-index: 15;
}

.services-section .card {
    background: rgba(17, 25, 40, 0.85) !important;
    position: relative;
    z-index: 20;
}

/* 3D objects positioning fixes */
.service-3d-objects,
.faq-3d-objects,
.about-3d-objects {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 2;
    pointer-events: none;
    overflow: hidden;
}

/* Ensure dark text sections have proper contrast */
.text-dark, .text-medium {
    text-shadow: 0 1px 2px rgba(255, 255, 255, 0.2);
}

/* FAQ Section fixes */
.faq-section {
    position: relative;
    z-index: 5;
}

.faq-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, rgba(8, 12, 23, 0.8), rgba(8, 12, 23, 0.7));
    z-index: 2;
}

.faq-section .container {
    position: relative;
    z-index: 15;
}

.faq-section .accordion-item {
    background-color: rgba(17, 25, 40, 0.9) !important;
    border: 1px solid rgba(45, 130, 254, 0.2) !important;
    position: relative;
    z-index: 20;
}

.faq-section .accordion-button {
    background-color: rgba(17, 25, 40, 0.95) !important;
    color: #fff !important;
    font-weight: 600;
    padding: 1.25rem;
    position: relative;
    z-index: 25;
}

.faq-section .accordion-button:not(.collapsed) {
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.3), rgba(0, 217, 255, 0.2)) !important;
    color: #fff !important;
}

.faq-section .accordion-body {
    background-color: rgba(11, 17, 33, 0.7) !important;
    color: var(--color-text-medium) !important;
    position: relative;
    z-index: 20;
}

/* Portfolio section fixes */
.portfolio-section {
    position: relative;
    z-index: 3;
}

.portfolio-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, rgba(8, 12, 23, 0.6), rgba(8, 12, 23, 0.4));
    z-index: 2;
}

.portfolio-section .container {
    position: relative;
    z-index: 15;
}

.portfolio-card {
    background-color: rgba(17, 25, 40, 0.85) !important;
    position: relative;
    z-index: 20;
}

/* Contact section fixes */
.contact-section {
    position: relative;
    z-index: 3;
}

.contact-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, rgba(8, 12, 23, 0.5), rgba(8, 12, 23, 0.3));
    z-index: 2;
}

.contact-section .container {
    position: relative;
    z-index: 15;
}

.contact-card {
    background-color: rgba(17, 25, 40, 0.8) !important;
    position: relative;
    z-index: 20;
}

/* Testimonials section fixes */
.testimonials-section {
    position: relative;
    z-index: 3;
}

.testimonials-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, rgba(8, 12, 23, 0.7), rgba(8, 12, 23, 0.5));
    z-index: 2;
}

.testimonials-section .container {
    position: relative;
    z-index: 15;
}

.carousel-item .glass-effect {
    background-color: rgba(17, 25, 40, 0.85) !important;
    position: relative;
    z-index: 20;
}

/* Benefits section fixes */
.key-benefits-section {
    position: relative;
    z-index: 3;
}

.key-benefits-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, rgba(8, 12, 23, 0.6), rgba(8, 12, 23, 0.4));
    z-index: 2;
}

.key-benefits-section .container {
    position: relative;
    z-index: 15;
}

.benefit-card {
    background-color: rgba(17, 25, 40, 0.85) !important;
    position: relative;
    z-index: 20;
}

/* News section fixes */
.latest-news-section {
    position: relative;
    z-index: 3;
}

.latest-news-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, rgba(8, 12, 23, 0.6), rgba(8, 12, 23, 0.4));
    z-index: 2;
}

.latest-news-section .container {
    position: relative;
    z-index: 15;
}

.blog-card {
    background-color: rgba(17, 25, 40, 0.85) !important;
    position: relative;
    z-index: 20;
}

/* Section visibility animation */
section {
    transition: opacity 0.5s ease;
}

.section-visible {
    opacity: 1;
}

/* Enhanced particle effects */
.particle-container {
    opacity: 0.5;
    transition: opacity 0.5s ease;
}

section:hover .particle-container {
    opacity: 0.7;
}

/* Make text more visible with enhanced contrast */
.section-badge, 
.section-title, 
.section-subtitle,
h1, h2, h3, h4, h5, h6,
p, 
.accordion-button,
.card-title {
    color: #ffffff !important;
    position: relative;
    z-index: 15;
}

/* Add background to text containers for better visibility */
.section-title-group {
    position: relative;
    z-index: 20;
    padding: 0.5rem;
    border-radius: 0.5rem;
    background: rgba(11, 17, 33, 0.4);
    margin-bottom: 2rem !important;
}

/* Make accordion content more visible */
.accordion-body p {
    color: #dbe4f0 !important;
    font-weight: 400;
}

/* Ensure all cards have good visibility */
.card, 
.glass-effect, 
.portfolio-card, 
.blog-card, 
.benefit-card, 
.feature-card-modern,
.stat-box-alt {
    background: rgba(17, 25, 40, 0.85) !important;
    border: 1px solid rgba(45, 130, 254, 0.15) !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3) !important;
}

/* Add subtle hover effect to all cards */
.card:hover, 
.glass-effect:hover, 
.portfolio-card:hover, 
.blog-card:hover, 
.benefit-card:hover, 
.feature-card-modern:hover,
.stat-box-alt:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4) !important;
    border: 1px solid rgba(45, 130, 254, 0.3) !important;
}

/* Icon Styling Enhancement */
i, .fas, .fab, .far, .bi, [class^="fa-"], [class*=" fa-"] {
    position: relative;
    z-index: 20;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    text-shadow: 0 0 10px rgba(45, 130, 254, 0.3);
    transition: all 0.3s ease;
}

/* Icon sizes */
.fa-1x, i { font-size: 1rem !important; }
.fa-2x { font-size: 2rem !important; }
.fa-3x { font-size: 3rem !important; }
.fa-4x { font-size: 4rem !important; }
.fa-5x { font-size: 5rem !important; }
.fa-6x { font-size: 6rem !important; }

/* Button icons */
.btn i {
    margin-left: 0.5rem;
    font-size: 0.85rem !important;
    position: relative;
    z-index: 25;
    color: inherit !important;
}

.btn:hover i {
    transform: translateX(5px);
}

/* Section icons */
.section-badge i,
.section-title i {
    margin-right: 0.5rem;
    color: var(--color-primary);
}

/* Card icons */
.card i,
.glass-effect i {
    background: linear-gradient(135deg, #2D82FE, #00D9FF);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: 1.5rem !important;
}

/* Feature icons */
.feature-icon-modern i,
.service-icon-modern i,
.benefit-icon i {
    font-size: 1.75rem !important;
    color: var(--color-primary);
    background: linear-gradient(135deg, #2D82FE, #00D9FF);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 0 5px rgba(45, 130, 254, 0.3));
}

/* Icon wrapper enhancement */
.icon-wrapper {
    position: relative;
    width: 50px;
    height: 50px;
    border-radius: 10px;
    background: rgba(45, 130, 254, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    transition: all 0.3s ease;
    z-index: 20;
}

.icon-wrapper:hover {
    transform: translateY(-5px);
    background: var(--gradient-primary);
}

.icon-wrapper:hover i {
    color: white;
    -webkit-text-fill-color: white;
}

/* Box icons */
.box-icon {
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    border-radius: 12px;
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.1), rgba(0, 217, 255, 0.1));
    z-index: 20;
    position: relative;
    transition: all 0.3s ease;
}

.box-icon i {
    font-size: 1.75rem !important;
    color: var(--color-primary);
}

.box-icon:hover {
    transform: translateY(-5px);
    background: var(--gradient-primary);
}

.box-icon:hover i {
    color: white;
    -webkit-text-fill-color: white;
}

/* Circular icons */
.circle-icon {
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.1), rgba(0, 217, 255, 0.1));
    z-index: 20;
    position: relative;
    transition: all 0.3s ease;
}

.circle-icon i {
    font-size: 1.5rem !important;
    color: var(--color-primary);
}

.circle-icon:hover {
    transform: translateY(-5px);
    background: var(--gradient-primary);
}

.circle-icon:hover i {
    color: white;
    -webkit-text-fill-color: white;
}

/* FAQ icons */
.faq-icon {
    color: var(--color-primary) !important;
    font-size: 1.2rem !important;
    margin-right: 0.75rem;
    z-index: 25;
    -webkit-text-fill-color: var(--color-primary) !important;
    filter: drop-shadow(0 0 2px rgba(45, 130, 254, 0.5));
}

/* Footer icons */
.footer-contact-item i {
    width: 24px;
    margin-right: 0.75rem;
    color: var(--color-primary);
    font-size: 1rem !important;
}

/* Social icons */
.social-link i {
    color: white !important;
    font-size: 1.1rem !important;
    -webkit-text-fill-color: white !important;
    transition: all 0.3s ease;
}

.social-link:hover i {
    transform: scale(1.2);
}

/* Form icons */
.form-control-icon {
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    color: var(--color-primary);
    z-index: 25;
}

.input-group-text i {
    color: var(--color-primary);
    font-size: 1rem !important;
}

/* Card icons in various sections */
.portfolio-icon-placeholder i,
.blog-icon-placeholder i,
.testimonial-icon i {
    font-size: 2rem !important;
    color: var(--color-primary);
    background: linear-gradient(135deg, #2D82FE, #00D9FF);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    margin-bottom: 1rem;
    display: block;
}

/* Light up icons on section hover */
section:hover .feature-icon-modern i,
section:hover .service-icon-modern i,
section:hover .benefit-icon i,
section:hover .portfolio-icon-placeholder i,
section:hover .blog-icon-placeholder i,
section:hover .testimonial-icon i {
    filter: drop-shadow(0 0 8px rgba(45, 130, 254, 0.6));
}

/* Icon animation effect */
@keyframes iconPulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.1); opacity: 0.8; }
}

.feature-icon-modern i,
.service-icon-modern i,
.benefit-icon i {
    animation: iconPulse 3s infinite ease-in-out;
}

/* Stagger animation delay */
.feature-icon-modern:nth-child(1) i { animation-delay: 0s; }
.feature-icon-modern:nth-child(2) i { animation-delay: 0.5s; }
.feature-icon-modern:nth-child(3) i { animation-delay: 1s; }
.feature-icon-modern:nth-child(4) i { animation-delay: 1.5s; }

.service-icon-modern:nth-child(1) i { animation-delay: 0.2s; }
.service-icon-modern:nth-child(2) i { animation-delay: 0.7s; }
.service-icon-modern:nth-child(3) i { animation-delay: 1.2s; }
.service-icon-modern:nth-child(4) i { animation-delay: 1.7s; }

/* FAQ section specific icon enhancements */
.faq-section .accordion-button i {
    color: var(--color-primary) !important;
    font-size: 1.25rem !important;
    margin-right: 12px;
    z-index: 25;
    -webkit-text-fill-color: var(--color-primary) !important;
    text-shadow: 0 0 10px rgba(45, 130, 254, 0.5);
    transition: all 0.3s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(45, 130, 254, 0.1);
    width: 36px;
    height: 36px;
    border-radius: 50%;
}

.faq-section .accordion-button:not(.collapsed) i {
    color: #fff !important;
    -webkit-text-fill-color: #fff !important;
    background: var(--color-primary);
    transform: scale(1.1);
}

.faq-section .accordion-button:hover i {
    transform: scale(1.1);
    filter: brightness(1.2);
}

.faq-section .section-badge i {
    font-size: 1.1rem !important;
    margin-right: 8px;
    background: linear-gradient(135deg, #2D82FE, #00D9FF);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 0 3px rgba(45, 130, 254, 0.5));
}

.faq-section .section-title i {
    font-size: 1.75rem !important;
    margin-right: 10px;
    background: linear-gradient(135deg, #2D82FE, #00D9FF);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 0 5px rgba(45, 130, 254, 0.6));
}

/* Enhance accordion body content icons if any */
.faq-section .accordion-body i {
    color: var(--color-primary) !important;
    -webkit-text-fill-color: var(--color-primary) !important;
    margin-right: 8px;
    vertical-align: middle;
}

/* FAQ section icon animation */
@keyframes faqIconPulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.15); }
}

.faq-section .section-badge i,
.faq-section .section-title i {
    animation: faqIconPulse 3s infinite ease-in-out;
}

.faq-section:hover .accordion-button i {
    filter: brightness(1.2) drop-shadow(0 0 8px rgba(45, 130, 254, 0.7));
}

/* Services section specific icon enhancements */
.services-section .card-header i,
.services-section .service-icon i {
    font-size: 2.25rem !important;
    margin-bottom: 1rem;
    background: linear-gradient(135deg, #2D82FE, #00D9FF);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 0 8px rgba(45, 130, 254, 0.4));
    transition: all 0.3s ease;
    display: block;
}

.services-section .card:hover i {
    filter: drop-shadow(0 0 12px rgba(45, 130, 254, 0.8));
    transform: translateY(-5px) scale(1.1);
}

/* Service icon containers */
.service-icon-container {
    width: 80px;
    height: 80px;
    border-radius: 20px;
    background: rgba(45, 130, 254, 0.05);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.5rem;
    position: relative;
    z-index: 10;
    transition: all 0.3s ease;
    border: 1px solid rgba(45, 130, 254, 0.2);
}

.services-section .card:hover .service-icon-container {
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.2), rgba(0, 217, 255, 0.2));
    transform: translateY(-8px);
    box-shadow: 0 15px 30px -10px rgba(45, 130, 254, 0.3);
}

/* Service icon animation */
@keyframes serviceIconFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
}

.services-section .card:nth-child(1) i { animation: serviceIconFloat 4s infinite ease-in-out; }
.services-section .card:nth-child(2) i { animation: serviceIconFloat 4s infinite ease-in-out 0.5s; }
.services-section .card:nth-child(3) i { animation: serviceIconFloat 4s infinite ease-in-out 1s; }
.services-section .card:nth-child(4) i { animation: serviceIconFloat 4s infinite ease-in-out 1.5s; }
.services-section .card:nth-child(5) i { animation: serviceIconFloat 4s infinite ease-in-out 2s; }
.services-section .card:nth-child(6) i { animation: serviceIconFloat 4s infinite ease-in-out 2.5s; }

/* Navigation icons styling */
.navbar-nav .nav-link i,
.navbar-nav .dropdown-item i {
    margin-right: 8px;
    font-size: 1rem !important;
    color: rgba(255, 255, 255, 0.8);
    transition: all 0.3s ease;
    position: relative;
    z-index: 100;
}

.navbar-nav .nav-link:hover i,
.navbar-nav .dropdown-item:hover i,
.navbar-nav .nav-item.active .nav-link i {
    color: var(--color-primary);
    transform: translateX(3px);
}

.navbar-brand i {
    font-size: 1.5rem !important;
    color: var(--color-primary);
    margin-right: 0.5rem;
    vertical-align: middle;
}

/* Mobile navbar icons */
.navbar-toggler i {
    font-size: 1.25rem !important;
    color: var(--color-primary);
}

/* Navigation contact icons */
.navbar-contact .contact-item i {
    color: var(--color-primary);
    font-size: 1rem !important;
    margin-right: 0.5rem;
    transition: all 0.3s ease;
}

.navbar-contact .contact-item:hover i {
    transform: scale(1.2);
}

/* Dropdown icons */
.dropdown-toggle::after {
    margin-left: 0.5rem;
    vertical-align: middle;
    transition: all 0.3s ease;
}

.dropdown-toggle:hover::after {
    transform: translateY(2px);
}

.dropdown-item i {
    width: 20px;
    text-align: center;
    margin-right: 10px;
    font-size: 0.9rem !important;
}

/* Testimonial section icon styling */
.testimonials-section .testimonial-icon i {
    font-size: 2rem !important;
    color: var(--color-primary);
    margin-bottom: 1rem;
    opacity: 0.8;
    filter: drop-shadow(0 0 10px rgba(45, 130, 254, 0.4));
    transition: all 0.3s ease;
}

.testimonials-section .carousel-item:hover .testimonial-icon i {
    opacity: 1;
    transform: scale(1.1);
    filter: drop-shadow(0 0 15px rgba(45, 130, 254, 0.7));
}

.testimonials-section .quote-icon {
    position: absolute;
    font-size: 5rem !important;
    opacity: 0.1;
    color: var(--color-primary);
    z-index: 5;
}

.testimonials-section .quote-icon.quote-left {
    top: 20px;
    left: 20px;
}

.testimonials-section .quote-icon.quote-right {
    bottom: 20px;
    right: 20px;
}

/* Portfolio section icon styling */
.portfolio-section .portfolio-icon i {
    font-size: 1.75rem !important;
    color: var(--color-primary);
    margin-bottom: 0.75rem;
    transition: all 0.3s ease;
}

.portfolio-section .portfolio-card:hover .portfolio-icon i {
    transform: translateY(-5px);
    filter: brightness(1.2);
}

.portfolio-section .tech-stack-icon {
    width: 30px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-right: 0.5rem;
    background: rgba(45, 130, 254, 0.1);
    border-radius: 50%;
    transition: all 0.3s ease;
}

.portfolio-section .tech-stack-icon i {
    font-size: 0.85rem !important;
    color: var(--color-primary);
}

.portfolio-section .portfolio-card:hover .tech-stack-icon {
    background: var(--color-primary);
}

.portfolio-section .portfolio-card:hover .tech-stack-icon i {
    color: white;
    -webkit-text-fill-color: white !important;
}

/* About section icon styling */
.about-agency-section .feature-icon i {
    font-size: 2rem !important;
    color: var(--color-primary);
    margin-bottom: 1rem;
    background: linear-gradient(135deg, #2D82FE, #00D9FF);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 0 8px rgba(45, 130, 254, 0.3));
    transition: all 0.3s ease;
}

.about-agency-section .feature-item:hover .feature-icon i {
    filter: drop-shadow(0 0 12px rgba(45, 130, 254, 0.7));
    transform: scale(1.1);
}

.about-agency-section .value-icon-container {
    width: 60px;
    height: 60px;
    border-radius: 15px;
    background: rgba(45, 130, 254, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    transition: all 0.3s ease;
}

.about-agency-section .value-icon-container i {
    font-size: 1.75rem !important;
    color: var(--color-primary);
}

.about-agency-section .value-item:hover .value-icon-container {
    background: var(--gradient-primary);
    transform: translateY(-5px);
}

.about-agency-section .value-item:hover .value-icon-container i {
    color: white;
    -webkit-text-fill-color: white !important;
}

/* Process/Steps section icon styling */
.process-step-icon {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: rgba(45, 130, 254, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    position: relative;
    z-index: 10;
    transition: all 0.3s ease;
}

.process-step-icon i {
    font-size: 1.5rem !important;
    color: var(--color-primary);
}

.process-step:hover .process-step-icon {
    background: var(--gradient-primary);
    transform: scale(1.1);
}

.process-step:hover .process-step-icon i {
    color: white;
    -webkit-text-fill-color: white !important;
}

/* Global icon visibility enhancement */
[class*="icon"] {
    position: relative;
    z-index: 20;
}

/* Fix for any dark background sections */
.bg-dark i, 
.bg-primary i, 
[class*="dark-bg"] i,
.text-white i {
    color: white;
    -webkit-text-fill-color: white;
    text-shadow: 0 0 10px rgba(255, 255, 255, 0.3);
}

/* Advanced Card & Div Hover Effects */
.card, 
.glass-effect,
.portfolio-card,
.testimonial-card,
.service-card-modern,
.blog-card,
.benefit-card {
    transition: all 0.45s cubic-bezier(0.25, 1, 0.5, 1);
    transform-style: preserve-3d;
    backface-visibility: hidden;
    transform: perspective(1000px) translateZ(0) rotateY(0) rotateX(0);
    box-shadow: 0 10px 30px -15px rgba(0, 0, 0, 0.1);
    position: relative;
    overflow: hidden;
    z-index: 20;
}

.card::before,
.glass-effect::before,
.portfolio-card::before,
.testimonial-card::before,
.service-card-modern::before,
.blog-card::before,
.benefit-card::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: -1;
    opacity: 0;
    border-radius: inherit;
    background: linear-gradient(
        45deg,
        rgba(45, 130, 254, 0.1) 0%,
        rgba(0, 217, 255, 0.1) 100%
    );
    transition: opacity 0.4s ease;
}

.card::after,
.glass-effect::after,
.portfolio-card::after,
.testimonial-card::after,
.service-card-modern::after,
.blog-card::after,
.benefit-card::after {
    content: '';
    position: absolute;
    top: -2px;
    left: -2px;
    right: -2px;
    bottom: -2px;
    z-index: -2;
    border-radius: inherit;
    background: linear-gradient(
        135deg,
        var(--color-primary) 0%,
        transparent 50%,
        var(--color-primary) 100%
    );
    opacity: 0;
    filter: blur(12px);
    transition: all 0.5s ease;
}

/* Hover state */
.card:hover,
.glass-effect:hover,
.portfolio-card:hover,
.testimonial-card:hover,
.service-card-modern:hover,
.blog-card:hover,
.benefit-card:hover {
    transform: perspective(1000px) translateZ(20px) rotateX(2deg) rotateY(-2deg);
    box-shadow: 
        0 20px 40px -20px rgba(45, 130, 254, 0.3),
        0 0 15px rgba(45, 130, 254, 0.2);
    z-index: 25;
}

.card:hover::before,
.glass-effect:hover::before,
.portfolio-card:hover::before,
.testimonial-card:hover::before,
.service-card-modern:hover::before,
.blog-card:hover::before,
.benefit-card:hover::before {
    opacity: 1;
}

.card:hover::after,
.glass-effect:hover::after,
.portfolio-card:hover::after,
.testimonial-card:hover::after,
.service-card-modern:hover::after,
.blog-card:hover::after,
.benefit-card:hover::after {
    opacity: 0.4;
}

/* Hover state content movement */
.card:hover .card-title,
.glass-effect:hover h3,
.portfolio-card:hover h4,
.service-card-modern:hover h4,
.blog-card:hover h4,
.benefit-card:hover h4 {
    transform: translateY(-5px);
    color: var(--color-primary);
    text-shadow: 0 0 5px rgba(45, 130, 254, 0.2);
}

.card:hover .card-text,
.glass-effect:hover p,
.portfolio-card:hover p,
.service-card-modern:hover p,
.blog-card:hover p,
.benefit-card:hover p {
    transform: translateY(-3px);
}

.card:hover img,
.glass-effect:hover img,
.portfolio-card:hover img,
.testimonial-card:hover img,
.blog-card:hover img {
    transform: scale(1.05);
    filter: brightness(1.1);
}

/* Card content transitions */
.card-title,
.card h3, .card h4,
.glass-effect h3, .glass-effect h4,
.portfolio-card h3, .portfolio-card h4,
.service-card-modern h3, .service-card-modern h4,
.blog-card h3, .blog-card h4,
.benefit-card h3, .benefit-card h4 {
    transition: all 0.4s ease;
}

.card-text,
.card p,
.glass-effect p,
.portfolio-card p,
.service-card-modern p,
.blog-card p,
.benefit-card p {
    transition: all 0.4s ease;
}

.card img,
.glass-effect img,
.portfolio-card img,
.testimonial-card img,
.blog-card img {
    transition: all 0.6s ease;
}

/* Service cards special hover */
.services-section .card {
    transition: all 0.5s cubic-bezier(0.25, 1, 0.5, 1);
}

.services-section .card:hover {
    transform: perspective(1000px) translateZ(30px) rotateX(3deg) rotateY(-3deg) translateY(-15px);
}

.services-section .card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, transparent 0%, rgba(45, 130, 254, 0.05) 100%);
    opacity: 0;
    z-index: -1;
    transition: opacity 0.5s ease;
}

.services-section .card:hover::before {
    opacity: 1;
}

.services-section .card::after {
    content: '';
    position: absolute;
    top: -3px;
    left: -3px;
    right: -3px;
    bottom: -3px;
    background: linear-gradient(
        135deg,
        var(--color-primary) 0%,
        transparent 50%,
        var(--color-primary) 100%
    );
    border-radius: inherit;
    opacity: 0;
    z-index: -2;
    filter: blur(16px);
    transition: all 0.6s ease;
}

.services-section .card:hover::after {
    opacity: 0.5;
}

.services-section .card:hover .card-title {
    background: linear-gradient(135deg, #2D82FE, #00D9FF);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    transform: translateY(-7px);
}

/* Portfolio cards special hover */
.portfolio-card {
    overflow: hidden;
    transition: all 0.5s cubic-bezier(0.25, 1, 0.5, 1);
}

.portfolio-card:hover {
    transform: perspective(1000px) translateZ(25px) rotateX(2deg) rotateY(-2deg) translateY(-10px);
}

.portfolio-card::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(
        135deg,
        rgba(45, 130, 254, 0.5) 0%,
        rgba(0, 217, 255, 0.5) 100%
    );
    opacity: 0;
    transition: all 0.5s ease;
    z-index: 1;
}

.portfolio-card:hover::after {
    opacity: 0.15;
}

.portfolio-card .portfolio-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(0, 0, 0, 0.8) 0%,
        rgba(0, 0, 0, 0.2) 60%,
        transparent 100%
    );
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.4s ease;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 20px;
}

.portfolio-card:hover .portfolio-overlay {
    opacity: 1;
    transform: translateY(0);
}

/* Blog cards special hover */
.blog-card {
    overflow: hidden;
    transition: all 0.5s cubic-bezier(0.25, 1, 0.5, 1);
}

.blog-card:hover {
    transform: perspective(1000px) translateZ(25px) rotateX(2deg) rotateY(-2deg) translateY(-10px);
}

.blog-card .blog-date {
    position: absolute;
    top: 15px;
    right: 15px;
    padding: 8px 12px;
    background: rgba(45, 130, 254, 0.9);
    color: white;
    border-radius: 5px;
    font-weight: 600;
    font-size: 0.8rem;
    transition: all 0.3s ease;
    z-index: 10;
}

.blog-card:hover .blog-date {
    transform: translateY(-3px);
    box-shadow: 0 5px 15px -5px rgba(45, 130, 254, 0.6);
}

.blog-card::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 5px;
    background: linear-gradient(
        to right,
        var(--color-primary) 0%,
        rgba(0, 217, 255, 1) 100%
    );
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.5s ease;
}

.blog-card:hover::after {
    transform: scaleX(1);
}

/* Testimonial cards special hover */
.testimonial-card {
    transition: all 0.5s cubic-bezier(0.25, 1, 0.5, 1);
}

.testimonial-card:hover {
    transform: perspective(1000px) translateZ(20px) rotateX(2deg) rotateY(-2deg);
}

.testimonial-card::before {
    content: '';
    position: absolute;
    width: 90%;
    height: 30px;
    bottom: -10px;
    left: 5%;
    border-radius: 50%;
    box-shadow: 0 15px 25px rgba(0, 0, 0, 0.1);
    transition: all 0.5s ease;
}

.testimonial-card:hover::before {
    box-shadow: 0 25px 35px rgba(45, 130, 254, 0.2);
}

/* Benefits cards special hover */
.benefit-card {
    transition: all 0.5s cubic-bezier(0.25, 1, 0.5, 1);
    border-bottom: 3px solid transparent;
}

.benefit-card:hover {
    transform: perspective(1000px) translateZ(20px) rotateX(2deg) rotateY(-2deg) translateY(-10px);
    border-bottom: 3px solid var(--color-primary);
}

.benefit-card::after {
    content: '';
    position: absolute;
    width: 40px;
    height: 40px;
    background: var(--color-primary);
    border-radius: 50%;
    bottom: -20px;
    right: -20px;
    opacity: 0;
    transform: scale(0);
    transition: all 0.5s ease;
}

.benefit-card:hover::after {
    opacity: 0.2;
    transform: scale(1);
}

/* Card-hover active animation */
@keyframes cardPulse {
    0%, 100% { 
        box-shadow: 0 15px 35px -15px rgba(45, 130, 254, 0.3);
    }
    50% { 
        box-shadow: 0 15px 35px -10px rgba(45, 130, 254, 0.5);
    }
}

.card:hover,
.glass-effect:hover,
.portfolio-card:hover,
.service-card-modern:hover,
.blog-card:hover,
.benefit-card:hover {
    animation: cardPulse 2s infinite ease-in-out;
}

/* Fix for mobile hover states */
@media (max-width: 768px) {
    .card:hover,
    .glass-effect:hover,
    .portfolio-card:hover,
    .testimonial-card:hover,
    .service-card-modern:hover,
    .blog-card:hover,
    .benefit-card:hover {
        transform: translateY(-5px);
    }
}

/* Enhanced Button and Link Hover Effects in Cards */
.card .btn,
.glass-effect .btn,
.portfolio-card .btn,
.testimonial-card .btn,
.service-card-modern .btn,
.blog-card .btn,
.benefit-card .btn {
    transition: all 0.4s cubic-bezier(0.25, 1, 0.5, 1);
    position: relative;
    overflow: hidden;
    z-index: 10;
}

.card:hover .btn,
.glass-effect:hover .btn,
.portfolio-card:hover .btn,
.testimonial-card:hover .btn,
.service-card-modern:hover .btn,
.blog-card:hover .btn,
.benefit-card:hover .btn {
    transform: translateY(-3px);
    box-shadow: 0 10px 20px -10px rgba(45, 130, 254, 0.5);
}

.card .btn::before,
.glass-effect .btn::before,
.portfolio-card .btn::before,
.testimonial-card .btn::before,
.service-card-modern .btn::before,
.blog-card .btn::before,
.benefit-card .btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(
        135deg,
        rgba(45, 130, 254, 0.5) 0%,
        rgba(0, 217, 255, 0.5) 100%
    );
    opacity: 0;
    transition: opacity 0.4s ease;
    z-index: -1;
}

.card:hover .btn::before,
.glass-effect:hover .btn::before,
.portfolio-card:hover .btn::before,
.testimonial-card:hover .btn::before,
.service-card-modern:hover .btn::before,
.blog-card:hover .btn::before,
.benefit-card:hover .btn::before {
    opacity: 1;
}

/* Text links in cards */
.card a:not(.btn),
.glass-effect a:not(.btn),
.portfolio-card a:not(.btn),
.testimonial-card a:not(.btn),
.service-card-modern a:not(.btn),
.blog-card a:not(.btn),
.benefit-card a:not(.btn) {
    position: relative;
    transition: all 0.3s ease;
    z-index: 5;
}

.card a:not(.btn)::after,
.glass-effect a:not(.btn)::after,
.portfolio-card a:not(.btn)::after,
.testimonial-card a:not(.btn)::after,
.service-card-modern a:not(.btn)::after,
.blog-card a:not(.btn)::after,
.benefit-card a:not(.btn)::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 100%;
    height: 2px;
    background: var(--color-primary);
    transform: scaleX(0);
    transform-origin: right;
    transition: transform 0.4s cubic-bezier(0.25, 1, 0.5, 1);
}

.card:hover a:not(.btn)::after,
.glass-effect:hover a:not(.btn)::after,
.portfolio-card:hover a:not(.btn)::after,
.testimonial-card:hover a:not(.btn)::after,
.service-card-modern:hover a:not(.btn)::after,
.blog-card:hover a:not(.btn)::after,
.benefit-card:hover a:not(.btn)::after {
    transform: scaleX(1);
    transform-origin: left;
}

.card:hover a:not(.btn),
.glass-effect:hover a:not(.btn),
.portfolio-card:hover a:not(.btn),
.testimonial-card:hover a:not(.btn),
.service-card-modern:hover a:not(.btn),
.blog-card:hover a:not(.btn),
.benefit-card:hover a:not(.btn) {
    color: var(--color-primary);
    letter-spacing: 0.3px;
}

/* Read more links in cards */
.card .read-more,
.glass-effect .read-more,
.portfolio-card .read-more,
.testimonial-card .read-more,
.service-card-modern .read-more,
.blog-card .read-more,
.benefit-card .read-more {
    display: inline-flex;
    align-items: center;
    font-weight: 600;
    color: var(--color-primary);
    transition: all 0.3s ease;
}

.card .read-more i,
.glass-effect .read-more i,
.portfolio-card .read-more i,
.testimonial-card .read-more i,
.service-card-modern .read-more i,
.blog-card .read-more i,
.benefit-card .read-more i {
    margin-left: 8px;
    transition: transform 0.3s ease;
}

.card:hover .read-more i,
.glass-effect:hover .read-more i,
.portfolio-card:hover .read-more i,
.testimonial-card:hover .read-more i,
.service-card-modern:hover .read-more i,
.blog-card:hover .read-more i,
.benefit-card:hover .read-more i {
    transform: translateX(5px);
}

/* Card footer and header hover states */
.card:hover .card-footer,
.card:hover .card-header {
    background-color: rgba(45, 130, 254, 0.05);
    border-color: rgba(45, 130, 254, 0.2);
}

/* Glow effect for card buttons on hover */
.card .btn:hover,
.glass-effect .btn:hover,
.portfolio-card .btn:hover,
.testimonial-card .btn:hover,
.service-card-modern .btn:hover,
.blog-card .btn:hover,
.benefit-card .btn:hover {
    box-shadow: 0 0 15px rgba(45, 130, 254, 0.5);
}

/* Special mouse tracking effect */
.card.hover-3d,
.glass-effect.hover-3d {
    transition: transform 0.1s ease-out;
    will-change: transform;
}

.card.hover-3d .card-content,
.glass-effect.hover-3d .content {
    transition: transform 0.1s ease-out;
    will-change: transform;
}

/* Add subtle glow effect to card borders on hover */
.card:hover,
.glass-effect:hover,
.portfolio-card:hover,
.service-card-modern:hover,
.blog-card:hover,
.benefit-card:hover {
    border-color: rgba(45, 130, 254, 0.3);
}

/* Button Hover Effect on Cards */
.button-hovered {
    transform: perspective(1000px) translateZ(30px) rotateX(3deg) rotateY(-3deg) !important;
    box-shadow: 
        0 20px 40px -20px rgba(45, 130, 254, 0.4),
        0 0 20px rgba(45, 130, 254, 0.3) !important;
}

.button-hovered::after {
    opacity: 0.6 !important;
    filter: blur(15px) !important;
}

/* Optimize 3D hover effect */
.hover-3d {
    transform-style: preserve-3d;
    will-change: transform;
    transition: transform 0.2s cubic-bezier(0.25, 1, 0.5, 1), box-shadow 0.2s cubic-bezier(0.25, 1, 0.5, 1);
}

.hover-3d > * {
    transform: translateZ(20px);
    transition: transform 0.2s cubic-bezier(0.25, 1, 0.5, 1);
}

/* Performance optimization for devices that prefer reduced motion */
@media (prefers-reduced-motion: reduce) {
    .card:hover,
    .glass-effect:hover,
    .portfolio-card:hover,
    .service-card-modern:hover,
    .blog-card:hover,
    .benefit-card:hover,
    .hover-3d,
    .hover-3d > * {
        transition: none !important;
        transform: none !important;
        animation: none !important;
    }
}

/* Card Content Padding Enhancement */
.card, 
.glass-effect,
.portfolio-card,
.testimonial-card,
.service-card-modern,
.blog-card,
.benefit-card {
    padding: 1.5rem !important;
}

.card-body {
    padding: 1.5rem !important;
}

.card-header {
    padding: 1.25rem 1.5rem !important;
    margin: -1.5rem -1.5rem 0 -1.5rem !important;
}

.card-footer {
    padding: 1.25rem 1.5rem !important;
    margin: 0 -1.5rem -1.5rem -1.5rem !important;
}

.card-title {
    margin-bottom: 1rem !important;
}

.card-text,
.card p {
    margin-bottom: 1.25rem !important;
}

.card .btn,
.glass-effect .btn,
.portfolio-card .btn,
.testimonial-card .btn,
.service-card-modern .btn,
.blog-card .btn,
.benefit-card .btn {
    margin-top: 0.5rem;
}

/* Service cards specific padding */
.services-section .card {
    padding: 1.75rem !important;
}

.services-section .card-body {
    padding: 1.5rem 0 0 0 !important;
}

.service-icon-container {
    margin-bottom: 1.75rem;
}

/* Portfolio cards specific padding */
.portfolio-card {
    padding: 0 !important; /* Keep image without padding */
}

.portfolio-card .portfolio-content {
    padding: 1.5rem !important;
}

.portfolio-card .portfolio-overlay {
    padding: 1.75rem !important;
}

/* Blog cards specific padding */
.blog-card {
    padding: 0 !important; /* Keep image without padding */
}

.blog-card .blog-content {
    padding: 1.5rem !important;
}

.blog-card .blog-meta {
    padding: 0.75rem 1.5rem !important;
    margin-top: 0.5rem;
}

/* Testimonial cards specific padding */
.testimonial-card {
    padding: 1.75rem !important;
}

.testimonial-card .testimonial-content {
    padding: 1.25rem 0 !important;
}

.testimonial-card .testimonial-author {
    padding-top: 1rem !important;
    margin-top: 1rem !important;
    border-top: 1px solid rgba(45, 130, 254, 0.1);
}

/* Benefit cards specific padding */
.benefit-card {
    padding: 1.75rem !important;
}

/* FAQ accordion item padding */
.accordion-item {
    margin-bottom: 1rem !important;
}

.accordion-button {
    padding: 1.25rem 1.5rem !important;
}

.accordion-body {
    padding: 1.5rem !important;
}

/* Content hierarchy within cards */
.card h1, .card h2, .card h3, .card h4, .card h5, .card h6,
.glass-effect h1, .glass-effect h2, .glass-effect h3, .glass-effect h4, .glass-effect h5, .glass-effect h6,
.portfolio-card h1, .portfolio-card h2, .portfolio-card h3, .portfolio-card h4, .portfolio-card h5, .portfolio-card h6,
.testimonial-card h1, .testimonial-card h2, .testimonial-card h3, .testimonial-card h4, .testimonial-card h5, .testimonial-card h6,
.service-card-modern h1, .service-card-modern h2, .service-card-modern h3, .service-card-modern h4, .service-card-modern h5, .service-card-modern h6,
.blog-card h1, .blog-card h2, .blog-card h3, .blog-card h4, .blog-card h5, .blog-card h6,
.benefit-card h1, .benefit-card h2, .benefit-card h3, .benefit-card h4, .benefit-card h5, .benefit-card h6 {
    margin-bottom: 1rem !important;
}

/* Contact card specific padding */
.contact-card {
    padding: 2rem !important;
}

/* Form elements within cards need their own padding */
.card .form-group,
.glass-effect .form-group,
.contact-card .form-group {
    margin-bottom: 1.25rem !important;
}

.card .form-control,
.glass-effect .form-control,
.contact-card .form-control {
    padding: 0.75rem 1rem !important;
}

/* Fixed image containers within cards */
.card .img-container,
.glass-effect .img-container {
    margin: -1.5rem -1.5rem 1.5rem -1.5rem;
    overflow: hidden;
}

.card .img-container img,
.glass-effect .img-container img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

/* Fix for potential double padding in card structures */
.card .card-body,
.glass-effect .content,
.service-card-modern .card-body,
.blog-card .blog-content,
.benefit-card .benefit-content,
.portfolio-card .portfolio-content,
.testimonial-card .testimonial-content {
    padding: 0 !important;
}

/* Fix for card headers and footers when parent already has padding */
.card-header.no-margin {
    margin: 0 !important;
    border-radius: 0.5rem 0.5rem 0 0;
    border-left: none;
    border-right: none;
    border-top: none;
}

.card-footer.no-margin {
    margin: 0 !important;
    border-radius: 0 0 0.5rem 0.5rem;
    border-left: none;
    border-right: none;
    border-bottom: none;
}

/* Ensure proper spacing for list items in cards */
.card ul,
.glass-effect ul,
.portfolio-card ul,
.testimonial-card ul,
.service-card-modern ul,
.blog-card ul,
.benefit-card ul,
.accordion-body ul {
    padding-left: 1.25rem !important;
    margin-bottom: 1.25rem !important;
}

.card li,
.glass-effect li,
.portfolio-card li,
.testimonial-card li,
.service-card-modern li,
.blog-card li,
.benefit-card li,
.accordion-body li {
    margin-bottom: 0.5rem !important;
}

/* Fix spacing for the contact form in the contact section */
.contact-section .contact-card {
    padding: 2rem !important;
}

.contact-section .form-floating {
    margin-bottom: 1.25rem;
}

.contact-section .form-floating > label {
    padding-left: 1rem;
}

/* Fix spacing for portfolio grid items */
.portfolio-grid .portfolio-card {
    margin-bottom: 1.5rem;
}

/* Adjust glass effect elements for consistent padding */
.glass-effect {
    padding: 1.75rem !important;
}

/* FAQ Section Padding Enhancements */
.faq-section .accordion {
    margin-top: 2rem;
}

.faq-section .accordion-item {
    margin-bottom: 1.25rem;
    border-radius: 0.5rem;
    overflow: hidden;
}

.faq-section .accordion-button {
    padding: 1.5rem !important;
    font-weight: 600;
    font-size: 1.1rem;
}

.faq-section .accordion-button i {
    margin-right: 1rem !important;
}

.faq-section .accordion-body {
    padding: 1.5rem 1.75rem 1.75rem !important;
    line-height: 1.6;
}

.faq-section .accordion-body p:last-child {
    margin-bottom: 0 !important;
}

/* Card Button and Icon Spacing */
.card .btn,
.glass-effect .btn,
.portfolio-card .btn,
.testimonial-card .btn,
.service-card-modern .btn,
.blog-card .btn,
.benefit-card .btn {
    margin-top: 0.75rem;
    margin-bottom: 0.5rem;
    padding: 0.75rem 1.5rem !important;
}

.card .icon-container,
.glass-effect .icon-container,
.portfolio-card .icon-container,
.testimonial-card .icon-container,
.service-card-modern .icon-container,
.blog-card .icon-container,
.benefit-card .icon-container {
    margin-bottom: 1.5rem;
}

/* Space around icon elements */
.card i:not(.btn i),
.glass-effect i:not(.btn i),
.portfolio-card i:not(.btn i),
.testimonial-card i:not(.btn i),
.service-card-modern i:not(.btn i),
.blog-card i:not(.btn i),
.benefit-card i:not(.btn i) {
    margin-bottom: 0.5rem;
    margin-right: 0.5rem;
}

/* Card Content Spacing Finalization */
.card-title + p,
.glass-effect h3 + p,
.portfolio-card h4 + p,
.testimonial-card h4 + p,
.service-card-modern h4 + p,
.blog-card h4 + p,
.benefit-card h4 + p {
    margin-top: -0.5rem !important;
}

/* Form Groups in Contact Cards */
.contact-card .form-floating {
    margin-bottom: 1.25rem;
}

.contact-card .form-control {
    padding: 1.25rem 1rem 0.5rem !important;
    height: calc(3.5rem + 2px);
}

.contact-card textarea.form-control {
    height: auto;
    min-height: 8rem;
    padding-top: 1.5rem !important;
}

/* Card with featured content */
.card.featured,
.glass-effect.featured {
    padding: 2rem !important;
}

/* Fix spacing for read more links */
.card .read-more,
.glass-effect .read-more,
.portfolio-card .read-more,
.testimonial-card .read-more,
.service-card-modern .read-more,
.blog-card .read-more,
.benefit-card .read-more {
    margin-top: 1rem;
    display: inline-block;
}

/* Consistent spacing in all card sections */
.section-title-group + .row {
    margin-top: 2rem;
}

/* Feature Card Modern Padding Enhancement (KEY DIFFERENTIATORS section) */
.feature-card-modern {
    padding: 2rem !important;
    border-radius: 12px;
    transition: all 0.4s cubic-bezier(0.25, 1, 0.5, 1);
    height: 100%;
    position: relative;
    overflow: hidden;
    z-index: 10;
}

.feature-card-modern .feature-card-icon {
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    border-radius: 12px;
    background: rgba(45, 130, 254, 0.1);
    position: relative;
}

.feature-card-modern .feature-card-icon i {
    font-size: 1.75rem !important;
    color: var(--color-primary);
}

.feature-card-modern h4 {
    margin-bottom: 1rem !important;
    font-weight: 600;
}

.feature-card-modern p {
    margin-bottom: 0.5rem !important;
    color: var(--text-medium);
}

/* Portfolio Card Padding Enhancement (OUR WORK section) */
.portfolio-card {
    padding: 0 !important; /* Keep the container without padding for visual design */
    border-radius: 12px;
    overflow: hidden;
    transition: all 0.4s cubic-bezier(0.25, 1, 0.5, 1);
    height: 100%;
    border: 1px solid rgba(45, 130, 254, 0.15);
    background: rgba(25, 30, 45, 0.5);
}

.portfolio-card .portfolio-icon-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 120px;
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.1), rgba(0, 217, 255, 0.1));
    margin-bottom: 0;
}

.portfolio-card .portfolio-info {
    padding: 1.75rem !important;
}

.portfolio-card h4 {
    margin-bottom: 1rem !important;
    font-weight: 600;
}

.portfolio-card .portfolio-desc {
    margin-bottom: 1rem !important;
    color: var(--text-medium);
}

.portfolio-card span {
    display: block;
    font-size: 0.85rem;
    color: var(--color-primary);
    margin-top: 1rem;
}

/* Blog Card Padding Enhancement */
.blog-card {
    padding: 0 !important; /* Keep the container without padding for visual design */
    border-radius: 12px;
    overflow: hidden;
    transition: all 0.4s cubic-bezier(0.25, 1, 0.5, 1);
    height: 100%;
    border: 1px solid rgba(45, 130, 254, 0.15);
    background: rgba(25, 30, 45, 0.5);
}

.blog-card .blog-icon-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100px;
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.1), rgba(0, 217, 255, 0.1));
    margin-bottom: 0;
}

.blog-card .blog-content {
    padding: 1.75rem !important;
}

.blog-card .blog-meta {
    margin-bottom: 1rem;
    font-size: 0.85rem;
    color: var(--color-primary);
}

.blog-card h4 {
    margin-bottom: 1rem !important;
    font-weight: 600;
    line-height: 1.4;
}

.blog-card .blog-excerpt {
    margin-bottom: 1.5rem !important;
    color: var(--text-medium);
}

.blog-card .blog-link {
    display: inline-flex;
    align-items: center;
    font-weight: 600;
    color: var(--color-primary);
    margin-top: 0.75rem;
}

.blog-card .blog-link i {
    margin-left: 0.5rem;
    transition: transform 0.3s ease;
}

.blog-card:hover .blog-link i {
    transform: translateX(5px);
}

/* Benefit Card Padding Enhancement */
.benefit-card {
    padding: 2rem !important;
    border-radius: 12px;
    transition: all 0.4s cubic-bezier(0.25, 1, 0.5, 1);
    height: 100%;
    position: relative;
    overflow: hidden;
    z-index: 10;
    border: 1px solid rgba(45, 130, 254, 0.15);
    background: rgba(25, 30, 45, 0.5);
}

.benefit-card .benefit-icon {
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    border-radius: 12px;
    background: rgba(45, 130, 254, 0.1);
    position: relative;
}

.benefit-card .benefit-icon i {
    font-size: 1.75rem !important;
    color: var(--color-primary);
}

.benefit-card h4 {
    margin-bottom: 1rem !important;
    font-weight: 600;
}

.benefit-card p {
    margin-bottom: 0.5rem !important;
    color: var(--text-medium);
}

/* Feature Card Modern Hover Enhancement */
.feature-card-modern:hover {
    transform: perspective(1000px) translateZ(20px) rotateX(2deg) rotateY(-2deg) translateY(-5px);
    box-shadow: 0 20px 40px -20px rgba(45, 130, 254, 0.3), 0 0 15px rgba(45, 130, 254, 0.2);
    z-index: 25;
    border: 1px solid rgba(45, 130, 254, 0.25);
}

.feature-card-modern:hover .feature-card-icon {
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.2), rgba(0, 217, 255, 0.2));
    transform: translateY(-5px);
}

.feature-card-modern:hover h4 {
    color: var(--color-primary);
    transform: translateY(-3px);
}

/* Portfolio Card Hover Enhancement */
.portfolio-card:hover {
    transform: perspective(1000px) translateZ(25px) rotateX(2deg) rotateY(-2deg) translateY(-5px);
    box-shadow: 0 20px 40px -20px rgba(45, 130, 254, 0.3), 0 0 15px rgba(45, 130, 254, 0.2);
    z-index: 25;
    border: 1px solid rgba(45, 130, 254, 0.25);
}

.portfolio-card:hover .portfolio-icon-placeholder {
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.15), rgba(0, 217, 255, 0.15));
}

.portfolio-card:hover h4 {
    color: var(--color-primary);
    transform: translateY(-3px);
}

/* Blog Card Hover Enhancement */
.blog-card:hover {
    transform: perspective(1000px) translateZ(25px) rotateX(2deg) rotateY(-2deg) translateY(-5px);
    box-shadow: 0 20px 40px -20px rgba(45, 130, 254, 0.3), 0 0 15px rgba(45, 130, 254, 0.2);
    z-index: 25;
    border: 1px solid rgba(45, 130, 254, 0.25);
}

.blog-card:hover .blog-icon-placeholder {
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.15), rgba(0, 217, 255, 0.15));
}

.blog-card:hover h4 {
    color: var(--color-primary);
    transform: translateY(-3px);
}

/* Benefit Card Hover Enhancement */
.benefit-card:hover {
    transform: perspective(1000px) translateZ(20px) rotateX(2deg) rotateY(-2deg) translateY(-5px);
    box-shadow: 0 20px 40px -20px rgba(45, 130, 254, 0.3), 0 0 15px rgba(45, 130, 254, 0.2);
    z-index: 25;
    border: 1px solid rgba(45, 130, 254, 0.25);
}

.benefit-card:hover .benefit-icon {
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.2), rgba(0, 217, 255, 0.2));
    transform: translateY(-5px);
}

.benefit-card:hover h4 {
    color: var(--color-primary);
    transform: translateY(-3px);
}

/* Stats Box Padding Enhancement */
.stats-row-alt {
    margin-top: 2rem;
}

.stat-box-alt {
    padding: 2.25rem !important;
    border-radius: 12px;
    transition: all 0.4s cubic-bezier(0.25, 1, 0.5, 1);
    height: 100%;
    position: relative;
    overflow: hidden;
    z-index: 10;
    background: rgba(25, 30, 45, 0.5);
    border: 1px solid rgba(45, 130, 254, 0.15);
}

.stat-box-alt:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 40px -20px rgba(45, 130, 254, 0.3), 0 0 15px rgba(45, 130, 254, 0.2);
    z-index: 25;
    border: 1px solid rgba(45, 130, 254, 0.25);
    background: linear-gradient(135deg, rgba(25, 30, 45, 0.6), rgba(25, 30, 45, 0.8));
}

.stat-icon-alt {
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Feature Item Modern Padding Enhancement */
.feature-list-modern {
    margin: 2rem 0;
}

.feature-item-modern {
    display: flex;
    align-items: flex-start;
    margin-bottom: 2rem;
    padding: 1.75rem !important;
    border-radius: 12px;
    transition: all 0.35s cubic-bezier(0.25, 1, 0.5, 1);
    position: relative;
    overflow: hidden;
    background: rgba(25, 30, 45, 0.4);
    border: 1px solid rgba(45, 130, 254, 0.1);
}

.feature-item-modern:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 30px -15px rgba(45, 130, 254, 0.3);
    background: rgba(25, 30, 45, 0.6);
    border: 1px solid rgba(45, 130, 254, 0.2);
}

.feature-item-modern .feature-icon-modern {
    margin-right: 1.5rem;
    min-width: 55px;
    width: 55px;
    height: 55px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: rgba(45, 130, 254, 0.1);
    margin-top: 0.25rem;
}

.feature-item-modern .feature-icon-modern i {
    font-size: 1.75rem !important;
    background: linear-gradient(135deg, #2D82FE, #00D9FF);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.feature-item-modern h4 {
    margin-bottom: 0.75rem !important;
    font-weight: 600;
    font-size: 1.25rem;
}

.feature-item-modern p {
    margin-bottom: 0 !important;
    opacity: 0.9;
}

.feature-item-modern:last-child {
    margin-bottom: 0;
}

.feature-item-modern::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: -1;
    opacity: 0;
    border-radius: inherit;
    background: linear-gradient(
        45deg,
        rgba(45, 130, 254, 0.1) 0%,
        rgba(0, 217, 255, 0.1) 100%
    );
    transition: opacity 0.4s ease;
}

.feature-item-modern:hover::before {
    opacity: 1;
}

.feature-item-modern:hover .feature-icon-modern {
    background: linear-gradient(135deg, rgba(45, 130, 254, 0.2), rgba(0, 217, 255, 0.2));
}

.feature-item-modern:hover h4 {
    color: var(--color-primary);
}

/* About Agency Section Enhancement */
.about-agency-section {
    position: relative;
}

.about-agency-section .section-badge {
    margin-bottom: 1rem;
    display: inline-block;
}

.about-agency-section .section-title {
    font-weight: 700;
    margin-bottom: 1.5rem;
    position: relative;
    z-index: 10;
}

.about-agency-section .section-subtitle,
.about-agency-section p {
    color: var(--text-medium);
    font-size: 1.15rem;
    line-height: 1.7;
    margin-bottom: 1.75rem !important;
    position: relative;
    z-index: 10;
    padding: 0 0.5rem;
}

.about-agency-section .container {
    position: relative;
    z-index: 20;
}

/* Company description content area */
.about-agency-content {
    background: rgba(25, 30, 45, 0.3);
    border-radius: 15px;
    padding: 2.5rem !important;
    margin-bottom: 2rem;
    border: 1px solid rgba(45, 130, 254, 0.1);
    position: relative;
    overflow: hidden;
}

.about-agency-content::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(to right, var(--color-primary), rgba(0, 217, 255, 0.7));
    opacity: 0.7;
}

.about-agency-content:hover {
    box-shadow: 0 20px 40px -20px rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(45, 130, 254, 0.2);
    background: rgba(25, 30, 45, 0.4);
}

.about-agency-section .row {
    margin-bottom: 2rem;
}

/* Add margin between feature items */
.about-agency-section .feature-list-modern {
    margin-top: 3rem;
}

/* Complete Stat Box Alt Styling */
.stat-icon-alt i {
    font-size: 2.5rem !important;
    color: var(--color-primary);
    background: linear-gradient(135deg, #2D82FE, #00D9FF);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 0 5px rgba(45, 130, 254, 0.3));
}

.stat-value-alt {
    font-size: 3rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
    color: var(--color-primary);
    text-shadow: 0 0 15px rgba(45, 130, 254, 0.4);
}

.stat-desc-alt {
    font-size: 1.1rem;
    font-weight: 500;
    color: var(--text-light);
}

.stat-box-alt::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: -1;
    opacity: 0;
    border-radius: inherit;
    background: linear-gradient(
        45deg,
        rgba(45, 130, 254, 0.05) 0%,
        rgba(0, 217, 255, 0.05) 100%
    );
    transition: opacity 0.4s ease;
}

.stat-box-alt:hover::before {
    opacity: 1;
}

.stat-box-alt::after {
    content: '';
    position: absolute;
    top: -2px;
    left: -2px;
    right: -2px;
    bottom: -2px;
    z-index: -2;
    border-radius: inherit;
    background: linear-gradient(
        135deg,
        var(--color-primary) 0%,
        transparent 50%,
        var(--color-primary) 100%
    );
    opacity: 0;
    filter: blur(12px);
    transition: all 0.5s ease;
}

.stat-box-alt:hover::after {
    opacity: 0.4;
}

/* Back to top button styles */
.back-to-top {
    position: fixed;
    right: 30px;
    bottom: 30px;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--gradient-primary);
    color: #fff;
    transition: all 0.3s;
    z-index: 99;
    opacity: 0;
    visibility: hidden;
    box-shadow: 0 0 20px rgba(45, 130, 254, 0.3);
}

.back-to-top.active {
    opacity: 1;
    visibility: visible;
}

.back-to-top:hover {
    background: var(--gradient-primary);
    color: #fff;
    transform: translateY(-5px);
}

/* Accessibility - respect prefers-reduced-motion setting */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
    
    html {
        scroll-snap-type: none !important;
    }
    
    .floating-object, .tech-icon-wrapper, .glow-circle {
        animation: none !important;
        transform: none !important;
    }
    
    .particles-container {
        display: none !important;
    }
}

/* Animation optimizations for better performance */
@supports (animation-timeline: scroll()) {
    /* Modern scroll-based animations when supported */
    .section-title, .section-subtitle {
        animation-timeline: scroll();
        animation-range: entry 10% cover 30%;
    }
}

/* Image loading optimizations */
img {
    content-visibility: auto; /* Helps to skip rendering of off-screen images */
    contain: layout paint; /* Isolate image layout and paint */
}

/* Lazy loading effect */
img.lazy-load {
    opacity: 0;
    transition: opacity 0.3s ease;
}

img.lazy-load.loaded {
    opacity: 1;
}

/* High-performance transform properties */
.service-card:hover, 
.portfolio-card:hover, 
.blog-card:hover, 
.team-card:hover,
.feature-card:hover,
.benefit-card:hover {
    transform: translateY(-5px);
}

/* Optimized animations - use transform and opacity only */
@keyframes fadeInUp {
    0% {
        opacity: 0;
        transform: translateY(20px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeInDown {
    0% {
        opacity: 0;
        transform: translateY(-20px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Use more efficient animation properties */
.animate-fade-in-up {
    opacity: 0;
    animation: fadeInUp 0.6s cubic-bezier(0.16, 1, 0.3, 1) forwards;
    will-change: transform, opacity;
}

.animate-fade-in-down {
    opacity: 0;
    animation: fadeInDown 0.6s cubic-bezier(0.16, 1, 0.3, 1) forwards;
    will-change: transform, opacity;
}

/* Make sure that 3D objects use hardware acceleration */
.faq-3d-object, .floating-object, .tech-icon-wrapper, .glow-circle {
    transform: translate3d(0, 0, 0);
    backface-visibility: hidden;
    perspective: 1000px;
    will-change: transform;
}

/* Reduce layout thrashing for fixed elements */
.navbar, .back-to-top {
    transform: translateZ(0);
    will-change: transform;
}

/* Performance optimizations for hover effects */
.glass-effect {
    transition-property: transform, box-shadow;
    transition-duration: 0.3s;
    transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
}

/* Optimize for paint performance */
.section-badge, .hero-badge {
    transform: translateZ(0);
}
