/* ============================================================
   VYOMA AI STUDIOS — Premium Futuristic Design System
   Electric Blue (#00d4ff) + Purple (#7b2ff7) on Dark (#050510)
   ============================================================ */

/* ----------------------------------------------------------
   1. DESIGN TOKENS
   ---------------------------------------------------------- */
:root {
  --bg-primary: #050510;
  --bg-secondary: #0a0a1a;
  --bg-tertiary: #0f0f24;
  --bg-card: rgba(15, 15, 36, 0.6);
  --bg-glass: rgba(15, 15, 36, 0.4);

  --neon-blue: #00d4ff;
  --neon-blue-dim: #0088ff;
  --neon-blue-rgb: 0, 212, 255;
  --neon-purple: #7b2ff7;
  --neon-purple-light: #b44aff;
  --neon-purple-rgb: 123, 47, 247;
  --neon-gradient: linear-gradient(135deg, #00d4ff, #7b2ff7);
  --neon-gradient-reverse: linear-gradient(135deg, #7b2ff7, #00d4ff);
  --neon-gradient-h: linear-gradient(90deg, #00d4ff, #7b2ff7);

  --glow-blue: 0 0 20px rgba(0,212,255,0.3), 0 0 40px rgba(0,212,255,0.1);
  --glow-purple: 0 0 20px rgba(123,47,247,0.3), 0 0 40px rgba(123,47,247,0.1);
  --glow-blue-intense: 0 0 30px rgba(0,212,255,0.5), 0 0 60px rgba(0,212,255,0.2);
  --glow-mixed: 0 0 20px rgba(0,212,255,0.2), 0 0 40px rgba(123,47,247,0.15);

  --text-primary: #e0e0f0;
  --text-secondary: #a0a0b8;
  --text-muted: #6a6a80;
  --text-white: #ffffff;

  --glass-border: rgba(255,255,255,0.08);
  --glass-border-hover: rgba(0,212,255,0.3);
  --glass-blur: blur(20px);

  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 2rem;
  --space-xl: 4rem;
  --space-2xl: 6rem;
  --space-3xl: 8rem;

  --font-display: 'Space Grotesk', 'Inter', sans-serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: 'JetBrains Mono', 'Fira Code', monospace;

  --radius: 16px;
  --radius-sm: 8px;
  --radius-lg: 24px;
  --radius-pill: 100px;

  --transition-fast: 0.15s ease;
  --transition: 0.3s cubic-bezier(0.4,0,0.2,1);
  --transition-slow: 0.6s cubic-bezier(0.4,0,0.2,1);

  --z-base: 1;
  --z-nav: 100;
  --z-overlay: 200;
  --z-modal: 300;
  --z-cursor: 400;
  --z-loader: 500;
}

/* ----------------------------------------------------------
   2. RESET & BASE
   ---------------------------------------------------------- */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  color: var(--text-primary);
  background: var(--bg-primary);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img { max-width:100%; height:auto; display:block; }
a { color: var(--neon-blue); text-decoration:none; transition: color var(--transition); }
a:hover { color: var(--neon-purple-light); }
ul,ol { list-style:none; }

/* ----------------------------------------------------------
   3. TYPOGRAPHY
   ---------------------------------------------------------- */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-display);
  color: var(--text-white);
  line-height: 1.15;
  font-weight: 700;
}
h1 { font-size: clamp(2.5rem,6vw,4rem); }
h2 { font-size: clamp(1.8rem,4vw,2.8rem); }
h3 { font-size: clamp(1.2rem,2.5vw,1.5rem); }
h4 { font-size: 1.15rem; }
p { color: var(--text-secondary); line-height:1.7; }

.gradient-text {
  background: var(--neon-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ----------------------------------------------------------
   4. LAYOUT
   ---------------------------------------------------------- */
.container { width:100%; max-width:1200px; margin:0 auto; padding:0 var(--space-lg); }
.section { padding: var(--space-3xl) 0; position:relative; }
.section-header { text-align:center; margin-bottom: var(--space-xl); }
.section-header p { max-width:600px; margin: var(--space-md) auto 0; font-size:1.1rem; }

.section-tag {
  display:inline-block;
  font-family: var(--font-mono);
  font-size:0.8rem; font-weight:500;
  letter-spacing:0.15em; text-transform:uppercase;
  color: var(--neon-blue);
  margin-bottom: var(--space-sm);
  padding:0.35rem 1rem;
  background: rgba(0,212,255,0.08);
  border:1px solid rgba(0,212,255,0.2);
  border-radius: var(--radius-pill);
}

/* ----------------------------------------------------------
   5. UTILITIES
   ---------------------------------------------------------- */
.glass {
  background: var(--bg-glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border:1px solid var(--glass-border);
  border-radius: var(--radius);
}
.glass:hover { border-color: var(--glass-border-hover); }

.neon-border {
  border:1px solid transparent;
  background-image: linear-gradient(var(--bg-card),var(--bg-card)), var(--neon-gradient);
  background-origin: border-box;
  background-clip: padding-box, border-box;
  border-radius: var(--radius);
}

.animate-on-scroll {
  opacity:0; transform:translateY(30px);
  transition: opacity var(--transition-slow), transform var(--transition-slow);
}
.animate-on-scroll.is-visible { opacity:1; transform:translateY(0); }

.stagger-child {
  opacity:0; transform:translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.stagger-child.is-visible { opacity:1; transform:translateY(0); }

/* ----------------------------------------------------------
   6. BUTTONS
   ---------------------------------------------------------- */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:0.5rem;
  padding:0.75rem 1.75rem;
  font-family: var(--font-display); font-size:0.95rem; font-weight:600;
  border:none; border-radius: var(--radius-sm);
  cursor:pointer; transition: all var(--transition);
  position:relative; overflow:hidden; text-decoration:none;
}
.btn-primary {
  background: var(--neon-gradient); color: var(--text-white); z-index:1;
}
.btn-primary::before {
  content:''; position:absolute; inset:-2px;
  background: var(--neon-gradient); border-radius:inherit;
  z-index:-1; filter:blur(15px); opacity:0;
  transition: opacity var(--transition);
}
.btn-primary:hover { transform:translateY(-2px); color: var(--text-white); }
.btn-primary:hover::before { opacity:0.6; }

.btn-outline {
  background:transparent; color: var(--neon-blue);
  border:1px solid rgba(0,212,255,0.4);
}
.btn-outline:hover {
  background: rgba(0,212,255,0.08); border-color: var(--neon-blue);
  box-shadow: var(--glow-blue); transform:translateY(-2px); color: var(--neon-blue);
}

.btn-lg { padding:1rem 2.25rem; font-size:1.05rem; }
.btn-sm { padding:0.5rem 1.25rem; font-size:0.85rem; }
.btn-group { display:flex; gap: var(--space-md); flex-wrap:wrap; }

/* ----------------------------------------------------------
   7. PAGE LOADER
   ---------------------------------------------------------- */
.page-loader {
  position:fixed; inset:0; background: var(--bg-primary);
  display:flex; align-items:center; justify-content:center;
  z-index: var(--z-loader);
  transition: opacity 0.5s ease, visibility 0.5s ease;
}
.page-loader.loaded { opacity:0; visibility:hidden; pointer-events:none; }
.loader-ring {
  width:48px; height:48px;
  border:3px solid rgba(0,212,255,0.15);
  border-top-color: var(--neon-blue);
  border-radius:50%;
  animation: spin 0.8s linear infinite;
}

/* ----------------------------------------------------------
   7b. CINEMATIC INTRO OVERLAY
   ---------------------------------------------------------- */
#vi-overlay {
  position: fixed; inset: 0;
  z-index: 600;
  background: transparent; /* canvas is lifted to z-index 598 during intro so it covers site content */
  overflow: hidden;
  pointer-events: all;
}

#vi-stage {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
}

/* Scattered / animated letters */
.vi-letter {
  position: absolute;
  font-family: var(--font-display);
  font-weight: 800;
  line-height: 1;
  pointer-events: none;
  will-change: transform, left, top, opacity;
  letter-spacing: 0.02em;
}

/* Letter container */
#vi-lw { position: absolute; inset: 0; pointer-events: none; }

/* Styled logo (Phase 6+) */
#vi-logo {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%,-50%) scale(0.7);
  opacity: 0;
  white-space: nowrap;
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1;
  text-align: center;
  pointer-events: none;
  will-change: opacity, transform;
}
.vi-l-vyoma  { font-size: clamp(2.6rem, 7vw, 5rem); color: var(--neon-blue);         text-shadow: 0 0 30px rgba(0,212,255,0.6), 0 0 60px rgba(0,212,255,0.2); }
.vi-l-ai     { font-size: clamp(2.6rem, 7vw, 5rem); color: var(--neon-purple-light); text-shadow: 0 0 30px rgba(180,74,255,0.6), 0 0 60px rgba(180,74,255,0.2); font-style: italic; }
.vi-l-studios{ font-size: clamp(2.6rem, 7vw, 5rem); color: var(--text-muted);        font-weight: 400; }

/* Orbit container */
#vi-orbit {
  position: absolute; inset: 0;
  pointer-events: none;
  display: none;
}

/* Glowing standalone icons — no card background */
.vi-icon-wrap svg { display: block; }

/* Skip button */
#vi-skip {
  position: absolute; bottom: 2.5rem; right: 2.5rem;
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.6rem 1.1rem 0.6rem 0.85rem;
  background: rgba(255,255,255,0.12);
  border: 1.5px solid rgba(255,255,255,0.35);
  border-radius: var(--radius-pill);
  color: #fff; font-size: 0.82rem; font-family: var(--font-mono);
  cursor: pointer; letter-spacing: 0.06em;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  opacity: 0; transform: translateY(8px);
  transition: opacity 0.4s ease, transform 0.4s ease, background 0.2s, border-color 0.2s;
}
#vi-skip svg { flex-shrink: 0; }
#vi-skip:hover { background: rgba(0,212,255,0.18); border-color: rgba(0,212,255,0.6); }

/* ----------------------------------------------------------
   8. CUSTOM CURSOR
   ---------------------------------------------------------- */
.cursor-glow {
  position:fixed; width:300px; height:300px; border-radius:50%;
  background: radial-gradient(circle, rgba(0,212,255,0.05) 0%, transparent 70%);
  pointer-events:none; transform:translate(-50%,-50%);
  z-index: var(--z-cursor); will-change:left,top;
}

/* ----------------------------------------------------------
   9. NAVBAR
   ---------------------------------------------------------- */
.navbar {
  position:fixed; top:0; left:0; right:0;
  z-index: var(--z-nav); padding:1rem 0;
  transition: all var(--transition); background:transparent;
}
.navbar.scrolled {
  background: rgba(5,5,16,0.85);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--glass-border);
  padding:0.75rem 0;
}
.nav-container {
  display:flex; align-items:center; justify-content:space-between;
  max-width:1200px; margin:0 auto; padding:0 var(--space-lg);
}
.logo {
  font-family: var(--font-display); font-size:1.5rem; font-weight:700;
  display:flex; gap:0.15em; text-decoration:none;
}
.logo-vyoma { color: var(--neon-blue); }
.logo-ai { color: var(--neon-purple-light); font-style:italic; }
.logo-studios { color: var(--text-muted); font-weight:400; }

.nav-links { display:flex; align-items:center; gap:0.25rem; }

.nav-link {
  position:relative; padding:0.5rem 1rem;
  font-size:0.9rem; font-weight:500;
  color: var(--text-secondary); text-decoration:none;
  transition: color var(--transition);
}
.nav-link:hover, .nav-link.active { color: var(--text-white); }
.nav-link::after {
  content:''; position:absolute; bottom:0; left:50%;
  width:0; height:2px;
  background: var(--neon-gradient-h);
  transition: width var(--transition), left var(--transition);
  border-radius:1px;
}
.nav-link:hover::after, .nav-link.active::after { width:60%; left:20%; }

.btn-nav {
  margin-left:0.75rem; padding:0.55rem 1.35rem;
  font-size:0.85rem; font-weight:600;
  color: var(--text-white); background: var(--neon-gradient);
  border-radius: var(--radius-sm); text-decoration:none;
  transition: all var(--transition); position:relative; overflow:hidden;
}
.btn-nav::before {
  content:''; position:absolute; inset:-2px;
  background: var(--neon-gradient); border-radius:inherit;
  z-index:-1; filter:blur(10px); opacity:0;
  transition: opacity var(--transition);
}
.btn-nav:hover { transform:translateY(-1px); color: var(--text-white); }
.btn-nav:hover::before { opacity:0.5; }

.hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:4px;
  z-index: var(--z-overlay);
}
.hamburger span {
  display:block; width:24px; height:2px;
  background: var(--neon-blue); border-radius:2px;
  transition: all var(--transition);
}
.hamburger.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.active span:nth-child(2) { opacity:0; }
.hamburger.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* Mobile full-screen menu overlay */
.mobile-menu {
  display:none;
  position:fixed; inset:0;
  background: var(--bg-primary);
  z-index:200;
  flex-direction:column;
  transform:translateX(100%);
  transition: transform 0.3s cubic-bezier(0.4,0,0.2,1);
}
.mobile-menu.active { transform:translateX(0); }
.mobile-menu-nav {
  display:flex; flex-direction:column; align-items:stretch;
  padding:100px 2rem 2rem; gap:0; height:100%;
}
.mobile-nav-link {
  font-size:1.15rem; font-weight:500;
  color: var(--text-secondary);
  text-decoration:none;
  padding:1rem 0;
  border-bottom:1px solid rgba(255,255,255,0.06);
  transition: color var(--transition);
}
.mobile-nav-link:first-child { border-top:1px solid rgba(255,255,255,0.06); }
.mobile-nav-link:hover, .mobile-nav-link.active { color: var(--text-white); }
.mobile-menu-cta { margin-top:1.5rem; text-align:center; }

/* ----------------------------------------------------------
   10. HERO SECTION
   ---------------------------------------------------------- */
.hero {
  position:relative; min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; padding-top:80px;
}
.hero-particles {
  position:absolute; inset:0; z-index:0; pointer-events:none;
}
.global-particles {
  position:fixed; top:0; left:0; width:100vw; height:100vh;
  z-index:0; pointer-events:none;
}
.hero-bg-gradient {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 50% 0%, rgba(123,47,247,0.12) 0%, transparent 60%),
    radial-gradient(ellipse 80% 50% at 20% 100%, rgba(0,212,255,0.08) 0%, transparent 50%),
    radial-gradient(ellipse 50% 50% at 80% 80%, rgba(123,47,247,0.06) 0%, transparent 50%);
  z-index:0; pointer-events:none;
}
.hero-content {
  position:relative; z-index: var(--z-base);
  text-align:center; max-width:850px;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:0.6rem;
  padding:0.45rem 1.25rem;
  background: var(--bg-glass);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(0,212,255,0.15);
  border-radius: var(--radius-pill);
  color: var(--neon-blue);
  font-family: var(--font-mono); font-size:0.8rem; font-weight:500;
  letter-spacing:0.05em; margin-bottom: var(--space-lg);
}
.badge-dot {
  width:8px; height:8px; border-radius:50%;
  background: var(--neon-blue);
  box-shadow:0 0 8px rgba(0,212,255,0.6);
  animation: pulse-dot 2s ease-in-out infinite;
}
.hero-title { margin-bottom: var(--space-lg); }
.title-line {
  display:block; opacity:0; transform:translateY(40px);
  animation: revealLine 0.8s cubic-bezier(0.16,1,0.3,1) forwards;
  animation-delay: var(--delay, 0s);
}
.hero-subtitle {
  font-size:1.15rem; color: var(--text-secondary);
  max-width:580px; margin:0 auto var(--space-xl);
  opacity:0; transform:translateY(20px);
  animation: revealLine 0.8s cubic-bezier(0.16,1,0.3,1) forwards;
  animation-delay:0.5s;
}
.hero-actions {
  display:flex; gap: var(--space-md); justify-content:center; flex-wrap:wrap;
  opacity:0; transform:translateY(20px);
  animation: revealLine 0.8s cubic-bezier(0.16,1,0.3,1) forwards;
  animation-delay:0.65s;
}
.scroll-indicator {
  position:absolute; bottom:2rem; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:0.5rem;
  z-index: var(--z-base);
  opacity:0; animation: revealLine 0.8s ease forwards 1.2s;
}
.scroll-indicator span {
  font-size:0.7rem; letter-spacing:0.15em; text-transform:uppercase; color: var(--text-muted);
}
.scroll-line {
  width:1px; height:40px;
  background: linear-gradient(to bottom, var(--neon-blue), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}

/* ----------------------------------------------------------
   11. WORKFLOW SECTION
   ---------------------------------------------------------- */
.workflow-section { background: var(--bg-secondary); overflow:hidden; }
.workflow-diagram { position:relative; padding: var(--space-xl) 0; }
.workflow-svg { width:100%; height:auto; max-height:350px; }

.workflow-line {
  fill:none; stroke: rgba(0,212,255,0.15); stroke-width:2;
  stroke-dasharray:8 8; transition: all 0.8s ease;
}
.workflow-line.active {
  stroke: var(--neon-blue); stroke-opacity:0.6;
  animation: dashFlow 1.5s linear infinite;
  filter: url(#glow);
}
.node-bg {
  fill: rgba(15,15,36,0.8); stroke: rgba(0,212,255,0.15);
  stroke-width:2; transition: all 0.6s ease;
}
.workflow-node.active .node-bg {
  fill: rgba(0,212,255,0.08); stroke: var(--neon-blue);
  filter: url(#glow);
}
.node-icon { fill: var(--text-muted); transition: fill 0.6s ease; }
.workflow-node.active .node-icon { fill: var(--neon-blue); }
.node-label {
  fill: var(--text-muted); font-family: var(--font-display);
  font-size:13px; font-weight:600; transition: fill 0.6s ease;
}
.workflow-node.active .node-label { fill: var(--text-white); }
.node-sublabel {
  fill: var(--text-muted); font-family: var(--font-body);
  font-size:10px; opacity:0.6;
}
.flow-dot { fill: var(--neon-blue); opacity:0; filter: url(#glow); transition: opacity 0.4s; }
.flow-dot.active { opacity:1; }

.workflow-steps {
  display:grid; grid-template-columns: repeat(4,1fr);
  gap: var(--space-lg); margin-top: var(--space-xl);
}
.workflow-step-card {
  text-align:center; padding: var(--space-lg);
  background: var(--bg-glass);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  border:1px solid var(--glass-border); border-radius: var(--radius);
  transition: all var(--transition);
}
.workflow-step-card:hover { border-color: var(--glass-border-hover); transform:translateY(-4px); }
.workflow-step-num {
  font-family: var(--font-display); font-size:2rem; font-weight:700;
  background: var(--neon-gradient);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  margin-bottom: var(--space-sm);
}
.workflow-step-card h3 { font-size:1.05rem; margin-bottom: var(--space-sm); }
.workflow-step-card p { font-size:0.85rem; color: var(--text-muted); }

/* ----------------------------------------------------------
   12. SERVICE CARDS (Home)
   ---------------------------------------------------------- */
.services-grid {
  display:grid; grid-template-columns: repeat(3,1fr); gap: var(--space-lg);
}
.tilt-card {
  position:relative;
  background: var(--bg-glass);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--glass-border); border-radius: var(--radius);
  padding: var(--space-xl) var(--space-lg);
  transition: border-color var(--transition), box-shadow var(--transition);
  will-change:transform; overflow:hidden;
}
.tilt-card:hover { border-color: var(--glass-border-hover); box-shadow: var(--glow-mixed); }
.card-glare {
  position:absolute; inset:0; border-radius:inherit;
  pointer-events:none; opacity:0; transition: opacity var(--transition);
}
.tilt-card:hover .card-glare { opacity:1; }

.card-icon {
  width:56px; height:56px;
  display:flex; align-items:center; justify-content:center;
  border-radius:14px;
  background: rgba(0,212,255,0.08); border:1px solid rgba(0,212,255,0.15);
  margin-bottom: var(--space-lg); font-size:1.5rem; color: var(--neon-blue);
  transition: all var(--transition);
}
.tilt-card:hover .card-icon {
  background: rgba(0,212,255,0.12); box-shadow:0 0 20px rgba(0,212,255,0.15);
}
.card-icon svg {
  width:28px; height:28px; stroke: var(--neon-blue); fill:none;
  stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round;
}
.tilt-card h3 { margin-bottom: var(--space-sm); }
.tilt-card p { font-size:0.9rem; color: var(--text-secondary); margin-bottom: var(--space-lg); }

.card-link {
  display:inline-flex; align-items:center; gap:0.4rem;
  font-size:0.85rem; font-weight:600; color: var(--neon-blue);
  transition: gap var(--transition), color var(--transition);
}
.card-link:hover { gap:0.7rem; color: var(--neon-purple-light); }
.card-link svg { width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:2; }

/* ----------------------------------------------------------
   13. STATS SECTION
   ---------------------------------------------------------- */
.stats-section {
  border-top:1px solid var(--glass-border);
  border-bottom:1px solid var(--glass-border);
  background: var(--bg-secondary);
}
.stats-grid { display:grid; grid-template-columns: repeat(4,1fr); gap: var(--space-lg); }

.stat-item { text-align:center; padding: var(--space-xl) var(--space-md); position:relative; }
.stat-item:not(:last-child)::after {
  content:''; position:absolute; right:0; top:20%; height:60%; width:1px;
  background: linear-gradient(to bottom, transparent, var(--glass-border), transparent);
}
.stat-ring-container { position:relative; width:100px; height:100px; margin:0 auto var(--space-md); }
.stat-ring { width:100%; height:100%; transform:rotate(-90deg); }
.stat-ring-bg { fill:none; stroke: rgba(0,212,255,0.08); stroke-width:3; }
.stat-ring-progress {
  fill:none; stroke: var(--neon-blue); stroke-width:3;
  stroke-linecap:round;
  stroke-dasharray:283; stroke-dashoffset:283;
  transition: stroke-dashoffset 2s cubic-bezier(0.4,0,0.2,1);
  filter: drop-shadow(0 0 6px rgba(0,212,255,0.4));
}
.stat-item.counted .stat-ring-progress { stroke-dashoffset: var(--ring-offset, 30); }
.stat-number {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  font-family: var(--font-display); font-size:1.8rem; font-weight:700;
  color: var(--neon-blue); text-shadow:0 0 20px rgba(0,212,255,0.4);
}
.stat-label { font-size:0.9rem; color: var(--text-secondary); font-weight:500; }

/* ----------------------------------------------------------
   14. TESTIMONIALS
   ---------------------------------------------------------- */
.testimonials-section { overflow:hidden; }
.testimonial-carousel {
  display:flex; gap: var(--space-lg);
  overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth;
  -ms-overflow-style:none; scrollbar-width:none;
  padding: var(--space-md) 0; cursor:grab;
}
.testimonial-carousel::-webkit-scrollbar { display:none; }
.testimonial-carousel:active { cursor:grabbing; }

.testimonial-card {
  flex: 0 0 calc(33.333% - var(--space-lg));
  min-width:320px; scroll-snap-align:start;
  background: var(--bg-glass);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--glass-border); border-radius: var(--radius);
  padding: var(--space-xl); transition: border-color var(--transition);
}
.testimonial-card:hover { border-color: var(--glass-border-hover); }

.testimonial-stars { display:flex; gap:0.2rem; margin-bottom: var(--space-md); }
.testimonial-stars svg {
  width:18px; height:18px; fill: var(--neon-blue);
  filter: drop-shadow(0 0 4px rgba(0,212,255,0.4));
}
.testimonial-text {
  font-size:0.95rem; color: var(--text-secondary); line-height:1.7;
  margin-bottom: var(--space-lg); font-style:italic;
}
.testimonial-author { display:flex; align-items:center; gap: var(--space-md); }
.testimonial-avatar {
  width:44px; height:44px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family: var(--font-display); font-weight:700; font-size:0.85rem;
  color: var(--text-white); background: var(--neon-gradient);
}
.testimonial-info h4 { font-size:0.9rem; color: var(--text-white); font-weight:600; }
.testimonial-info span { font-size:0.8rem; color: var(--text-muted); }

.carousel-controls { display:flex; justify-content:center; gap: var(--space-md); margin-top: var(--space-lg); }
.carousel-btn {
  width:44px; height:44px; border-radius:50%;
  border:1px solid var(--glass-border); background: var(--bg-glass);
  color: var(--text-secondary); display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition: all var(--transition);
}
.carousel-btn:hover {
  border-color: var(--neon-blue); color: var(--neon-blue);
  box-shadow: var(--glow-blue);
}
.carousel-btn svg { width:18px; height:18px; stroke:currentColor; fill:none; stroke-width:2; }

/* ----------------------------------------------------------
   15. CTA SECTION
   ---------------------------------------------------------- */
.cta-section { position:relative; overflow:hidden; text-align:center; }
.cta-bg {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 60% 60% at 50% 50%, rgba(123,47,247,0.15) 0%, transparent 70%),
    radial-gradient(ellipse 40% 40% at 30% 70%, rgba(0,212,255,0.1) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 70% 30%, rgba(0,212,255,0.08) 0%, transparent 60%);
  pointer-events:none; animation: ctaPulse 6s ease-in-out infinite alternate;
}
.cta-content { position:relative; z-index: var(--z-base); }
.cta-content h2 { margin-bottom: var(--space-md); }
.cta-content p { max-width:550px; margin:0 auto var(--space-xl); font-size:1.1rem; }

/* ----------------------------------------------------------
   16. SERVICES PAGE
   ---------------------------------------------------------- */
.page-hero {
  padding: calc(80px + var(--space-3xl)) 0 var(--space-2xl);
  text-align:center; position:relative; overflow:hidden;
}
.page-hero-bg {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 50% 50% at 50% 0%, rgba(123,47,247,0.1) 0%, transparent 60%),
    radial-gradient(ellipse 50% 50% at 50% 100%, rgba(0,212,255,0.06) 0%, transparent 50%);
  pointer-events:none;
}
.page-hero .section-tag { margin-bottom: var(--space-md); }
.page-hero h1 { margin-bottom: var(--space-md); }
.page-hero p { max-width:600px; margin:0 auto; font-size:1.1rem; }

.service-feature { padding: var(--space-2xl) 0; position:relative; }
.service-feature:not(:last-child) { border-bottom:1px solid var(--glass-border); }

.service-feature-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap: var(--space-3xl); align-items:center;
}
.service-feature:nth-child(even) .service-feature-grid { direction:rtl; }
.service-feature:nth-child(even) .service-feature-grid > * { direction:ltr; }

.service-feature-content .section-tag { margin-bottom: var(--space-md); }
.service-feature-content h2 { font-size: clamp(1.5rem,3vw,2rem); margin-bottom: var(--space-md); }
.service-feature-content > p { margin-bottom: var(--space-lg); }

.feature-list { display:flex; flex-direction:column; gap:0.75rem; }
.feature-item {
  display:flex; align-items:center; gap:0.75rem;
  font-size:0.9rem; color: var(--text-secondary);
}
.feature-check {
  flex-shrink:0; width:22px; height:22px; border-radius:50%;
  background: rgba(0,212,255,0.1); border:1px solid rgba(0,212,255,0.3);
  display:flex; align-items:center; justify-content:center;
}
.feature-check svg {
  width:12px; height:12px; stroke: var(--neon-blue); fill:none; stroke-width:2.5;
}

.service-feature-visual { display:flex; align-items:center; justify-content:center; }
.service-icon-box {
  width:260px; height:260px;
  display:flex; align-items:center; justify-content:center;
  background: var(--bg-glass);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--glass-border); border-radius: var(--radius-lg);
  position:relative; overflow:hidden;
}
.service-icon-box::before {
  content:''; position:absolute; inset:-1px; border-radius:inherit;
  background: var(--neon-gradient); opacity:0; transition: opacity var(--transition);
  z-index:-1; filter:blur(30px);
}
.service-icon-box:hover::before { opacity:0.2; }
.service-icon-box svg {
  width:80px; height:80px; stroke: var(--neon-blue); fill:none;
  stroke-width:1.2; stroke-linecap:round; stroke-linejoin:round;
  transition: all var(--transition);
}
.service-icon-box:hover svg {
  stroke: var(--neon-purple-light);
  filter: drop-shadow(0 0 10px rgba(0,212,255,0.3));
}
.icon-pulse { animation: iconPulse 3s ease-in-out infinite; }

/* ----------------------------------------------------------
   17. ABOUT PAGE
   ---------------------------------------------------------- */
.story-section { position:relative; }
.story-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap: var(--space-3xl); align-items:center;
}
.story-content h2 { margin-bottom: var(--space-lg); }
.story-content p { margin-bottom: var(--space-md); }

.story-visual {
  position:relative; height:400px;
  display:flex; align-items:center; justify-content:center;
}
.floating-shape {
  position:absolute; border:1px solid rgba(0,212,255,0.15); opacity:0.4;
  animation: float var(--float-duration, 6s) ease-in-out infinite var(--float-delay, 0s);
}
.shape-circle {
  width:120px; height:120px; border-radius:50%;
  border-color: rgba(123,47,247,0.2); top:10%; right:10%;
}
.shape-square {
  width:80px; height:80px; border-radius:12px;
  border-color: rgba(0,212,255,0.2); bottom:15%; left:15%;
  animation-name: floatRotate;
}
.shape-triangle {
  width:0; height:0; border:none;
  border-left:40px solid transparent; border-right:40px solid transparent;
  border-bottom:70px solid rgba(0,212,255,0.06);
  top:40%; right:30%;
}
.shape-ring {
  width:160px; height:160px; border-radius:50%;
  border-width:2px; border-color: rgba(0,212,255,0.1);
  top:20%; left:5%;
}

.mvv-grid { display:grid; grid-template-columns: repeat(3,1fr); gap: var(--space-lg); }
.mvv-card {
  text-align:center; padding: var(--space-xl);
  background: var(--bg-glass);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--glass-border); border-radius: var(--radius);
  transition: all var(--transition);
}
.mvv-card:hover { border-color: var(--glass-border-hover); transform:translateY(-4px); }
.mvv-icon {
  width:64px; height:64px; margin:0 auto var(--space-lg);
  display:flex; align-items:center; justify-content:center;
  border-radius:50%;
  background: rgba(0,212,255,0.08); border:1px solid rgba(0,212,255,0.15);
}
.mvv-icon svg { width:28px; height:28px; stroke: var(--neon-blue); fill:none; stroke-width:1.5; }
.mvv-card h3 { margin-bottom: var(--space-sm); }
.mvv-card p { font-size:0.9rem; }

/* Team Flip Cards */
.team-grid { display:grid; grid-template-columns: repeat(4,1fr); gap: var(--space-lg); }
.team-card-flip { perspective:1000px; height:340px; }
.team-card-inner {
  position:relative; width:100%; height:100%;
  transition: transform 0.8s cubic-bezier(0.4,0,0.2,1);
  transform-style:preserve-3d;
}
.team-card-flip:hover .team-card-inner { transform:rotateY(180deg); }
.team-card-front, .team-card-back {
  position:absolute; inset:0;
  backface-visibility:hidden; -webkit-backface-visibility:hidden;
  background: var(--bg-glass);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--glass-border); border-radius: var(--radius);
  padding: var(--space-xl);
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center;
}
.team-card-back { transform:rotateY(180deg); justify-content:flex-start; padding-top: var(--space-xl); }
.team-avatar {
  width:80px; height:80px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family: var(--font-display); font-weight:700; font-size:1.3rem;
  color: var(--text-white); background: var(--neon-gradient);
  margin-bottom: var(--space-md);
  box-shadow:0 0 20px rgba(0,212,255,0.2);
}
.team-card-front h3 { font-size:1.1rem; margin-bottom: var(--space-xs); }
.team-role { font-size:0.85rem; color: var(--neon-blue); font-weight:500; }
.team-card-back h4 { margin-bottom: var(--space-md); color: var(--neon-blue); }
.team-card-back p { font-size:0.85rem; line-height:1.7; }
.flip-hint {
  font-size:0.7rem; color: var(--text-muted); margin-top: var(--space-md);
  letter-spacing:0.05em; text-transform:uppercase;
}

/* Timeline */
.timeline { position:relative; max-width:700px; margin:0 auto; padding-left:40px; }
.timeline::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:2px;
  background: linear-gradient(to bottom, var(--neon-blue), var(--neon-purple), transparent);
  opacity:0.3;
}
.timeline-item { position:relative; padding-bottom: var(--space-xl); }
.timeline-marker {
  position:absolute; left:-46px; top:4px; width:14px; height:14px;
  border-radius:50%; background: var(--bg-primary);
  border:2px solid rgba(0,212,255,0.3); transition: all 0.6s ease;
}
.timeline-item.is-visible .timeline-marker {
  background: var(--neon-blue); border-color: var(--neon-blue);
  box-shadow:0 0 12px rgba(0,212,255,0.5);
}
.timeline-year {
  font-family: var(--font-mono); font-size:0.8rem; color: var(--neon-blue);
  margin-bottom: var(--space-xs); letter-spacing:0.05em;
}
.timeline-content h3 { font-size:1.1rem; margin-bottom: var(--space-xs); }
.timeline-content p { font-size:0.9rem; }

/* ----------------------------------------------------------
   18. CONTACT PAGE
   ---------------------------------------------------------- */
.contact-grid {
  display:grid; grid-template-columns:1.2fr 0.8fr; gap: var(--space-xl);
}
.contact-form-container {
  background: var(--bg-glass);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-border); border-radius: var(--radius);
  padding: var(--space-xl);
}
.form-group { position:relative; margin-bottom: var(--space-lg); }
.form-group input, .form-group select, .form-group textarea {
  width:100%; padding:1rem;
  background: rgba(5,5,16,0.6);
  border:1px solid var(--glass-border); border-radius: var(--radius-sm);
  color: var(--text-white); font-family: var(--font-body); font-size:0.95rem;
  transition: all var(--transition); outline:none;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color: var(--neon-blue);
  box-shadow:0 0 0 3px rgba(0,212,255,0.1), 0 0 20px rgba(0,212,255,0.08);
}
.form-group input::placeholder, .form-group textarea::placeholder { color: var(--text-muted); }

.form-group label {
  position:absolute; left:1rem; top:1rem;
  font-size:0.9rem; color: var(--text-muted);
  pointer-events:none; transition: all var(--transition);
  background:transparent;
}
.form-group input:focus + label,
.form-group input:not(:placeholder-shown) + label,
.form-group textarea:focus + label,
.form-group textarea:not(:placeholder-shown) + label {
  top:-0.6rem; left:0.75rem; font-size:0.75rem;
  color: var(--neon-blue); background: var(--bg-tertiary);
  padding:0 0.25rem;
}
.form-group select { appearance:none; cursor:pointer; }
.form-group select option { background: var(--bg-secondary); color: var(--text-primary); }
.form-group textarea { resize:vertical; min-height:120px; }

.form-group .error-message {
  display:none; font-size:0.78rem; color:#ff4d6a;
  margin-top:0.35rem; padding-left:0.25rem;
}
.form-group.error input, .form-group.error select, .form-group.error textarea {
  border-color:#ff4d6a; box-shadow:0 0 0 3px rgba(255,77,106,0.1);
}
.form-group.error .error-message { display:block; }
.form-group.shake { animation: shake 0.5s ease; }

.btn-submit { width:100%; padding:1rem; font-size:1rem; }

/* Contact sidebar */
.contact-sidebar { display:flex; flex-direction:column; gap: var(--space-lg); }
.contact-info-card {
  background: var(--bg-glass);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--glass-border); border-radius: var(--radius);
  padding: var(--space-xl); transition: border-color var(--transition);
}
.contact-info-card:hover { border-color: var(--glass-border-hover); }
.contact-info-card h3 { font-size:1.1rem; margin-bottom: var(--space-lg); }

.contact-info-item { display:flex; align-items:flex-start; gap: var(--space-md); margin-bottom: var(--space-md); }
.contact-info-item:last-child { margin-bottom:0; }
.contact-info-icon {
  flex-shrink:0; width:40px; height:40px; border-radius:10px;
  background: rgba(0,212,255,0.08); border:1px solid rgba(0,212,255,0.15);
  display:flex; align-items:center; justify-content:center;
}
.contact-info-icon svg { width:18px; height:18px; stroke: var(--neon-blue); fill:none; stroke-width:1.5; }
.contact-info-text h4 { font-size:0.85rem; color: var(--text-muted); font-weight:500; margin-bottom:0.15rem; }
.contact-info-text p, .contact-info-text a { font-size:0.9rem; color: var(--text-primary); }

/* Form success */
.form-success { display:none; text-align:center; padding: var(--space-xl); }
.form-success.active {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  min-height:300px;
}
.success-icon {
  width:64px; height:64px; border-radius:50%;
  background: rgba(0,212,255,0.1); border:2px solid var(--neon-blue);
  display:flex; align-items:center; justify-content:center;
  margin-bottom: var(--space-lg); box-shadow: var(--glow-blue);
}
.success-icon svg {
  width:28px; height:28px; stroke: var(--neon-blue); fill:none;
  stroke-width:2.5; stroke-dasharray:40; stroke-dashoffset:40;
  animation: drawCheck 0.6s ease forwards 0.3s;
}
.form-success h3 { margin-bottom: var(--space-sm); }

/* ----------------------------------------------------------
   19. 404 PAGE
   ---------------------------------------------------------- */
.error-page {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  text-align:center; position:relative; overflow:hidden;
}
.error-page-bg {
  position:absolute; inset:0;
  background: radial-gradient(ellipse 50% 50% at 50% 50%, rgba(123,47,247,0.08) 0%, transparent 60%);
  pointer-events:none;
}
.error-content { position:relative; z-index: var(--z-base); }
.error-number {
  font-family: var(--font-display); font-size: clamp(6rem,20vw,12rem); font-weight:800;
  background: var(--neon-gradient);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  line-height:1; margin-bottom: var(--space-md);
  animation: neonFlicker 4s ease-in-out infinite alternate;
  filter: drop-shadow(0 0 30px rgba(0,212,255,0.3));
}
.error-content h2 { font-size:1.5rem; margin-bottom: var(--space-sm); }
.error-content p { margin-bottom: var(--space-xl); max-width:400px; margin-left:auto; margin-right:auto; }

/* ----------------------------------------------------------
   20. FOOTER
   ---------------------------------------------------------- */
.footer {
  background: var(--bg-secondary);
  padding: var(--space-3xl) 0 var(--space-lg);
  position:relative;
}
.footer::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background: var(--neon-gradient-h); opacity:0.4;
}
.footer-grid {
  display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr;
  gap: var(--space-xl); margin-bottom: var(--space-2xl);
}
.footer-brand .logo { margin-bottom: var(--space-md); }
.footer-brand p { font-size:0.9rem; margin-bottom: var(--space-lg); }

.footer-social { display:flex; gap:0.75rem; }
.footer-social a {
  width:40px; height:40px; border-radius:10px;
  background: rgba(255,255,255,0.04); border:1px solid var(--glass-border);
  display:flex; align-items:center; justify-content:center;
  color: var(--text-muted); transition: all var(--transition);
}
.footer-social a:hover {
  border-color: var(--neon-blue); color: var(--neon-blue);
  background: rgba(0,212,255,0.08);
  box-shadow:0 0 15px rgba(0,212,255,0.15); transform:translateY(-3px);
}
.footer-social a svg { width:18px; height:18px; fill:currentColor; }

.footer-col h4 { font-size:0.95rem; margin-bottom: var(--space-lg); color: var(--text-white); }
.footer-col ul { display:flex; flex-direction:column; gap:0.6rem; }
.footer-col a {
  font-size:0.9rem; color: var(--text-muted);
  transition: color var(--transition), padding-left var(--transition);
}
.footer-col a:hover { color: var(--neon-blue); padding-left:0.3rem; }

.footer-newsletter p { font-size:0.9rem; margin-bottom: var(--space-md); }
.newsletter-form { display:flex; gap:0.5rem; }
.newsletter-form input {
  flex:1; padding:0.7rem 1rem;
  background: rgba(5,5,16,0.6); border:1px solid var(--glass-border);
  border-radius: var(--radius-sm); color: var(--text-white); font-size:0.85rem;
  outline:none; transition: border-color var(--transition);
}
.newsletter-form input:focus { border-color: var(--neon-blue); }
.newsletter-form input::placeholder { color: var(--text-muted); }
.newsletter-form button {
  padding:0.7rem 1.25rem; background: var(--neon-gradient);
  border:none; border-radius: var(--radius-sm);
  color: var(--text-white); font-weight:600; font-size:0.85rem;
  cursor:pointer; transition: all var(--transition); white-space:nowrap;
}
.newsletter-form button:hover { transform:translateY(-1px); box-shadow:0 0 15px rgba(0,212,255,0.3); }

.footer-bottom {
  padding-top: var(--space-lg); border-top:1px solid var(--glass-border); text-align:center;
}
.footer-bottom p { font-size:0.8rem; color: var(--text-muted); }

/* ----------------------------------------------------------
   21. KEYFRAME ANIMATIONS
   ---------------------------------------------------------- */
@keyframes spin { to { transform:rotate(360deg); } }
@keyframes revealLine { to { opacity:1; transform:translateY(0); } }
@keyframes pulse-dot {
  0%,100% { box-shadow:0 0 8px rgba(0,212,255,0.6); }
  50% { box-shadow:0 0 16px rgba(0,212,255,0.9), 0 0 24px rgba(0,212,255,0.3); }
}
@keyframes dashFlow { to { stroke-dashoffset:-32; } }
@keyframes float {
  0%,100% { transform:translateY(0) rotate(0deg); }
  50% { transform:translateY(-20px) rotate(3deg); }
}
@keyframes floatRotate {
  0%,100% { transform:translateY(0) rotate(0deg); }
  50% { transform:translateY(-15px) rotate(45deg); }
}
@keyframes scrollPulse {
  0%,100% { opacity:0.3; transform:scaleY(0.6); transform-origin:top; }
  50% { opacity:1; transform:scaleY(1); }
}
@keyframes shake {
  0%,100% { transform:translateX(0); }
  20% { transform:translateX(-8px); }
  40% { transform:translateX(8px); }
  60% { transform:translateX(-5px); }
  80% { transform:translateX(5px); }
}
@keyframes drawCheck { to { stroke-dashoffset:0; } }
@keyframes neonFlicker {
  0%,100% { filter: drop-shadow(0 0 30px rgba(0,212,255,0.3)); }
  50% { filter: drop-shadow(0 0 50px rgba(123,47,247,0.4)) drop-shadow(0 0 20px rgba(0,212,255,0.2)); }
}
@keyframes ctaPulse { 0% { opacity:0.7; } 100% { opacity:1; } }
@keyframes iconPulse { 0%,100% { transform:scale(1); } 50% { transform:scale(1.05); } }

/* ----------------------------------------------------------
   22. SPACE TUNNEL 3D SCROLL
   ---------------------------------------------------------- */
.tunnel-viewport {
  position:relative; overflow-x:hidden;
}
.tunnel-section {
  will-change:transform, opacity;
  transform-origin:50% 50%;
}
.tunnel-vignette {
  position:fixed; inset:0; pointer-events:none; z-index:2;
  background:radial-gradient(ellipse 75% 75% at 50% 50%, transparent 25%, rgba(10,5,40,0.15) 50%, rgba(40,0,80,0.25) 70%, rgba(5,5,16,0.85) 100%);
  opacity:0.35; transition:opacity 0.4s ease;
}
body.tunnel-warping .tunnel-vignette {
  background:radial-gradient(ellipse 70% 70% at 50% 50%, transparent 15%, rgba(0,40,120,0.12) 40%, rgba(60,0,140,0.3) 65%, rgba(5,5,16,0.95) 100%);
}
body.tunnel-warping .global-particles { filter:brightness(1.6) contrast(1.3); }
.tilt-card, .services-grid, .team-card-flip { transform-style:flat; }
.team-card-inner { transform-style:preserve-3d; }

/* ----------------------------------------------------------
   23. REDUCED MOTION
   ---------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after {
    animation-duration:0.01ms !important; animation-iteration-count:1 !important;
    transition-duration:0.01ms !important; scroll-behavior:auto !important;
  }
  .hero-particles, .global-particles, .cursor-glow { display:none !important; }
  .title-line, .hero-subtitle, .hero-actions, .scroll-indicator,
  .animate-on-scroll, .stagger-child { opacity:1 !important; transform:none !important; }
  .tunnel-viewport { perspective:none; }
  .tunnel-section { transform:none !important; opacity:1 !important; filter:none !important; will-change:auto; }
  .tunnel-vignette { display:none !important; }
}

/* ----------------------------------------------------------
   23. RESPONSIVE — 1024px
   ---------------------------------------------------------- */
@media (max-width:1024px) {
  .services-grid { grid-template-columns: repeat(2,1fr); }
  .stats-grid { grid-template-columns: repeat(2,1fr); }
  .workflow-steps { grid-template-columns: repeat(2,1fr); }
  .team-grid { grid-template-columns: repeat(2,1fr); }
  .footer-grid { grid-template-columns: repeat(2,1fr); }
  .story-visual { display:none; }
  .story-grid { grid-template-columns:1fr; }
  .service-feature-grid { gap: var(--space-xl); }
  .scroll-indicator { display:none; }
}

/* ----------------------------------------------------------
   24. RESPONSIVE — 768px
   ---------------------------------------------------------- */
@media (max-width:768px) {
  .hamburger { display:flex; }
  .navbar { z-index:300; }
  .nav-links { display:none; }
  .mobile-menu { display:flex; }

  .section { padding: var(--space-2xl) 0; }
  .container { padding:0 var(--space-md); }
  .hero { min-height:90vh; }
  .hero-content { padding:0 var(--space-md); }

  .services-grid { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns: repeat(2,1fr); }
  .workflow-diagram { display:none; }
  .workflow-steps { grid-template-columns:1fr; }
  .mvv-grid { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:1fr 1fr; }
  .contact-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; gap: var(--space-xl); }

  .service-feature-grid { grid-template-columns:1fr; }
  .service-feature:nth-child(even) .service-feature-grid { direction:ltr; }
  .service-feature-visual { order:-1; }
  .service-icon-box { width:200px; height:200px; }

  .testimonial-card { flex:0 0 85%; min-width:280px; }
  .stat-item:not(:last-child)::after { display:none; }
  .page-hero { padding: calc(80px + var(--space-2xl)) 0 var(--space-xl); }
  .scroll-indicator { display:none; }
  .tunnel-viewport { perspective:none; }
  .tunnel-section { filter:none !important; }
}

/* ----------------------------------------------------------
   25. RESPONSIVE — 480px
   ---------------------------------------------------------- */
@media (max-width:480px) {
  .hero-actions { flex-direction:column; align-items:center; }
  .btn-group { flex-direction:column; width:100%; }
  .btn-group .btn { width:100%; }
  .stats-grid { grid-template-columns:1fr; }
  .workflow-steps { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:1fr; }
  .team-card-flip { height:300px; }
  .testimonial-card { flex:0 0 90%; }
  .newsletter-form { flex-direction:column; }
  .newsletter-form button { width:100%; }
}

/* =========================================
   Blog Section Styles
   ========================================= */

.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 2rem;
  margin-top: 3rem;
}

.blog-card {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 12px;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
  display: flex;
  flex-direction: column;
}

.blog-card:hover {
  transform: translateY(-5px);
  border-color: var(--primary);
  box-shadow: 0 10px 30px rgba(0, 240, 255, 0.1);
}

.blog-card-img-link {
  display: block;
  width: 100%;
  height: 220px;
  overflow: hidden;
}

.blog-card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.blog-card:hover .blog-card-img {
  transform: scale(1.05);
}

.blog-card-content {
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.blog-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
  font-size: 0.85rem;
  color: #a0a0b0;
}

.blog-date {
  font-family: 'JetBrains Mono', monospace;
}

.blog-card-title {
  font-size: 1.25rem;
  margin-bottom: 0.75rem;
  line-height: 1.4;
}

.blog-card-title a {
  color: var(--text);
  text-decoration: none;
  transition: color 0.3s ease;
}

.blog-card-title a:hover {
  color: var(--primary);
}

.blog-card-excerpt {
  color: #a0a0b0;
  font-size: 0.95rem;
  line-height: 1.6;
  margin-bottom: 1.5rem;
  flex-grow: 1;
}

.blog-read-more {
  align-self: flex-start;
  padding: 0.5rem 1rem;
  font-size: 0.9rem;
}

/* Single Blog Post Styles */
.blog-post-page .hero-title {
  font-size: clamp(2rem, 5vw, 3.5rem);
  text-align: left;
}

.blog-post-page .blog-header {
  padding-top: 150px;
  padding-bottom: 2rem;
  text-align: left;
}

.blog-post-page .container.text-center {
  text-align: left;
}

.blog-meta-top {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.blog-subtitle {
  text-align: left;
  max-width: 800px;
  font-size: 1.2rem;
  margin-bottom: 2rem;
}

.blog-hero-image-container {
  margin-bottom: 4rem;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.5);
}

.blog-hero-image {
  width: 100%;
  height: auto;
  max-height: 60vh;
  object-fit: cover;
  display: block;
}

.blog-container {
  max-width: 800px;
  margin: 0 auto;
}

.blog-content-body {
  font-size: 1.1rem;
  line-height: 1.8;
  color: #d0d0df;
}

.blog-content-body p {
  margin-bottom: 1.5rem;
}

.blog-content-body h2 {
  font-size: 2rem;
  margin: 3rem 0 1.5rem;
  color: var(--text);
}

.blog-content-body h3 {
  font-size: 1.5rem;
  margin: 2rem 0 1rem;
  color: var(--text);
}

.blog-content-body ul, .blog-content-body ol {
  margin-bottom: 2rem;
  padding-left: 1.5rem;
}

.blog-content-body li {
  margin-bottom: 0.5rem;
}

.blog-content-body strong {
  color: var(--primary);
}

.blog-content-body blockquote {
  border-left: 4px solid var(--primary);
  padding-left: 1.5rem;
  margin: 2rem 0;
  font-style: italic;
  color: #a0a0b0;
  background: rgba(255, 255, 255, 0.02);
  padding: 1.5rem;
  border-radius: 0 8px 8px 0;
}

.blog-footer {
  margin-top: 4rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.no-blogs {
  grid-column: 1 / -1;
  text-align: center;
  padding: 4rem 0;
  color: #a0a0b0;
  font-size: 1.2rem;
}

/* ============================================================
   PREMIUM BLOG SYSTEM — Full Redesign
   ============================================================ */

/* ------ Shared Blog Utilities ------ */
.blog-category-badge {
  display: inline-flex; align-items: center;
  padding: 0.3rem 0.85rem;
  border-radius: var(--radius-pill);
  font-size: 0.75rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
  font-family: var(--font-mono);
  background: rgba(0,212,255,0.1); color: var(--neon-blue);
  border: 1px solid rgba(0,212,255,0.25);
}
.blog-category-badge--ai-automation { background: rgba(123,47,247,0.1); color: var(--neon-purple-light); border-color: rgba(123,47,247,0.25); }
.blog-category-badge--ai-chatbots   { background: rgba(0,212,255,0.1); color: var(--neon-blue); border-color: rgba(0,212,255,0.25); }
.blog-category-badge--ai-performance{ background: rgba(255,200,80,0.1); color: #ffc850; border-color: rgba(255,200,80,0.25); }
.blog-category-badge--product-development { background: rgba(80,220,150,0.1); color: #50dc96; border-color: rgba(80,220,150,0.25); }

.blog-read-time {
  display: inline-flex; align-items: center; gap: 0.35rem;
  font-size: 0.8rem; color: var(--text-muted); font-family: var(--font-mono);
}

.blog-author-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--neon-gradient);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 1rem; color: #fff; flex-shrink: 0;
}
.blog-author-avatar--sm { width: 28px; height: 28px; font-size: 0.75rem; }

.blog-tag-pill {
  display: inline-flex; padding: 0.25rem 0.7rem;
  background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-pill); font-size: 0.75rem; color: var(--text-muted);
  font-family: var(--font-mono); letter-spacing: 0.02em;
  transition: all var(--transition);
}
.blog-tag-pill:hover { border-color: rgba(0,212,255,0.3); color: var(--neon-blue); }

/* ------ Blog List Hero ------ */
.blogs-hero {
  position: relative; padding: 180px 0 80px;
  text-align: center;
  background: radial-gradient(ellipse 70% 60% at 50% 0%, rgba(123,47,247,0.12) 0%, transparent 70%);
}
.blogs-hero-inner { max-width: 700px; margin: 0 auto; }
.blogs-hero .hero-subtitle { margin: 1rem auto 0; max-width: 600px; }

/* ------ Featured Post Card ------ */
.blogs-featured-section { padding-top: 0; }

.blog-featured-card {
  display: grid; grid-template-columns: 1fr 1fr;
  min-height: 480px; border-radius: 24px; overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
  background: var(--bg-card);
  text-decoration: none;
  transition: all var(--transition);
  position: relative;
}
.blog-featured-card:hover { border-color: rgba(0,212,255,0.3); box-shadow: 0 20px 60px rgba(0,0,0,0.4), 0 0 30px rgba(0,212,255,0.08); transform: translateY(-4px); }

.blog-featured-image-wrap { position: relative; overflow: hidden; }
.blog-featured-image { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
.blog-featured-card:hover .blog-featured-image { transform: scale(1.04); }
.blog-featured-image-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to right, transparent 60%, rgba(10,10,26,0.7) 100%),
              linear-gradient(to top, rgba(10,10,26,0.5) 0%, transparent 40%);
}

.blog-featured-content {
  display: flex; flex-direction: column; justify-content: center;
  padding: 3rem 2.5rem; gap: 1.25rem;
}
.blog-featured-meta { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.blog-featured-date { font-family: var(--font-mono); font-size: 0.8rem; color: var(--text-muted); }
.blog-featured-title {
  font-size: clamp(1.4rem, 2.5vw, 2rem); color: var(--text-white);
  line-height: 1.25; margin: 0;
  transition: color var(--transition);
}
.blog-featured-card:hover .blog-featured-title { color: var(--neon-blue); }
.blog-featured-excerpt { color: var(--text-secondary); font-size: 0.95rem; line-height: 1.7; margin: 0; }

.blog-featured-footer { display: flex; align-items: center; justify-content: space-between; margin-top: 0.5rem; }
.blog-featured-author { display: flex; align-items: center; gap: 0.75rem; }
.blog-author-name { font-size: 0.9rem; font-weight: 600; color: var(--text-white); }
.blog-featured-cta {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-size: 0.9rem; font-weight: 600; color: var(--neon-blue);
  transition: gap var(--transition), color var(--transition);
}
.blog-featured-card:hover .blog-featured-cta { gap: 0.85rem; color: var(--neon-purple-light); }

/* ------ Category Filter ------ */
.blogs-filter-section { padding: 2rem 0 0; }
.blogs-filter-bar { display: flex; gap: 0.75rem; flex-wrap: wrap; align-items: center; }
.blogs-filter-pill {
  padding: 0.5rem 1.25rem; border-radius: var(--radius-pill);
  font-size: 0.85rem; font-weight: 500; font-family: var(--font-mono);
  background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1);
  color: var(--text-secondary); cursor: pointer; transition: all var(--transition);
}
.blogs-filter-pill:hover { border-color: rgba(0,212,255,0.3); color: var(--text-white); }
.blogs-filter-pill.active {
  background: rgba(0,212,255,0.1); border-color: var(--neon-blue);
  color: var(--neon-blue);
}

/* ------ Blog Card Grid ------ */
.blogs-grid-section { padding-top: 2rem; }
.blogs-card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 2rem; }

.blog-card-premium {
  border-radius: var(--radius); overflow: hidden;
  border: 1px solid rgba(255,255,255,0.07);
  background: var(--bg-card);
  backdrop-filter: blur(12px);
  transition: all var(--transition);
  animation-delay: var(--stagger-delay, 0s);
}
.blog-card-premium:hover { border-color: rgba(0,212,255,0.25); transform: translateY(-6px); box-shadow: 0 16px 48px rgba(0,0,0,0.35), 0 0 20px rgba(0,212,255,0.06); }
.blog-card-premium-link { display: flex; flex-direction: column; height: 100%; text-decoration: none; }

.blog-card-premium-image-wrap { position: relative; height: 220px; overflow: hidden; }
.blog-card-premium-image { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.blog-card-premium:hover .blog-card-premium-image { transform: scale(1.06); }
.blog-card-premium-category-overlay { position: absolute; top: 1rem; left: 1rem; }

.blog-card-premium-body { display: flex; flex-direction: column; padding: 1.5rem; flex-grow: 1; gap: 0.85rem; }

.blog-card-meta { display: flex; align-items: center; gap: 0.6rem; }
.blog-card-date { font-family: var(--font-mono); font-size: 0.78rem; color: var(--text-muted); }
.blog-card-dot { width: 3px; height: 3px; border-radius: 50%; background: var(--text-muted); }
.blog-card-readtime { display: inline-flex; align-items: center; gap: 0.3rem; font-family: var(--font-mono); font-size: 0.78rem; color: var(--text-muted); }

.blog-card-premium-title {
  font-size: 1.15rem; line-height: 1.4; color: var(--text-white);
  margin: 0; transition: color var(--transition);
}
.blog-card-premium:hover .blog-card-premium-title { color: var(--neon-blue); }
.blog-card-premium-excerpt { font-size: 0.88rem; color: var(--text-secondary); line-height: 1.65; flex-grow: 1; }

.blog-card-tags { display: flex; flex-wrap: wrap; gap: 0.4rem; }

.blog-card-premium-footer { display: flex; align-items: center; justify-content: space-between; padding-top: 0.5rem; border-top: 1px solid rgba(255,255,255,0.06); margin-top: 0.25rem; }
.blog-card-author { display: flex; align-items: center; gap: 0.6rem; font-size: 0.82rem; color: var(--text-secondary); }
.blog-card-arrow { color: var(--text-muted); transition: all var(--transition); }
.blog-card-premium:hover .blog-card-arrow { color: var(--neon-blue); transform: translateX(4px); }

/* ------ Newsletter CTA ------ */
.blogs-newsletter-section { padding-top: 0; }
.blogs-newsletter-card {
  display: flex; align-items: center; justify-content: space-between; gap: 2rem;
  background: linear-gradient(135deg, rgba(123,47,247,0.12) 0%, rgba(0,212,255,0.08) 100%);
  border: 1px solid rgba(255,255,255,0.1); border-radius: var(--radius-lg);
  padding: 3rem; flex-wrap: wrap;
}
.blogs-newsletter-content h2 { font-size: 1.8rem; margin-bottom: 0.5rem; }
.blogs-newsletter-content p { color: var(--text-secondary); max-width: 480px; }

/* ============================================================
   READING PROGRESS BAR
   ============================================================ */
.reading-progress-bar {
  position: fixed; top: 0; left: 0; height: 3px; width: 0%;
  background: var(--neon-gradient); z-index: 9999;
  transition: width 0.1s linear;
  box-shadow: 0 0 8px rgba(0,212,255,0.5);
}

/* ============================================================
   BLOG POST PAGE — Premium Design
   ============================================================ */

/* Header */
.blog-post-header {
  padding-top: 130px; padding-bottom: 3rem;
  background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(123,47,247,0.1) 0%, transparent 70%);
}
.blog-post-header-inner { max-width: 800px; }

.blog-breadcrumb {
  display: flex; align-items: center; gap: 0.5rem;
  font-size: 0.82rem; color: var(--text-muted); margin-bottom: 1.5rem;
  font-family: var(--font-mono);
}
.blog-breadcrumb a { color: var(--text-muted); text-decoration: none; transition: color var(--transition); }
.blog-breadcrumb a:hover { color: var(--neon-blue); }
.breadcrumb-sep { color: var(--text-muted); opacity: 0.5; }

.blog-post-meta-row { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.blog-post-date { font-family: var(--font-mono); font-size: 0.82rem; color: var(--text-muted); }

.blog-post-title {
  font-size: clamp(2rem, 5vw, 3.2rem); line-height: 1.15;
  color: var(--text-white); margin-bottom: 1rem;
}
.blog-post-subtitle { font-size: 1.15rem; color: var(--text-secondary); line-height: 1.7; margin-bottom: 2rem; max-width: 700px; }

.blog-post-header-author { display: flex; align-items: center; gap: 0.85rem; }
.blog-header-author-info { display: flex; flex-direction: column; gap: 0.15rem; }
.blog-header-author-name { font-size: 0.95rem; font-weight: 600; color: var(--text-white); }
.blog-header-author-role { font-size: 0.8rem; color: var(--text-muted); font-family: var(--font-mono); }

/* Hero image */
.blog-post-hero-image-wrap { margin-bottom: 4rem; }
.blog-post-hero-image-wrap .container { border-radius: var(--radius-lg); overflow: hidden; box-shadow: 0 24px 64px rgba(0,0,0,0.5); }
.blog-post-hero-image { width: 100%; height: auto; max-height: 520px; object-fit: cover; display: block; }

/* Two-column layout */
.blog-post-layout {
  display: grid;
  grid-template-columns: minmax(0, 700px) 240px;
  gap: 3.5rem;
  align-items: start;
  justify-content: center;
  margin-bottom: 6rem;
}

/* TOC Sidebar */
.blog-toc-sidebar { position: sticky; top: 100px; max-height: calc(100vh - 120px); overflow-y: auto; overflow-x: hidden; scrollbar-width: thin; scrollbar-color: rgba(255,255,255,0.1) transparent; }
.blog-toc-sidebar::-webkit-scrollbar { width: 4px; }
.blog-toc-sidebar::-webkit-scrollbar-track { background: transparent; }
.blog-toc-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 99px; }
.blog-toc-inner {
  background: rgba(15,15,36,0.6); backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,0.08); border-radius: var(--radius);
  padding: 1.5rem; display: flex; flex-direction: column; gap: 1.25rem;
}
.blog-toc-label {
  font-size: 0.75rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--text-muted); font-family: var(--font-mono); margin: 0;
}
.blog-toc-nav { display: flex; flex-direction: column; gap: 0.15rem; }
.blog-toc-link {
  display: block; padding: 0.4rem 0.75rem;
  font-size: 0.83rem; color: var(--text-secondary); text-decoration: none;
  border-left: 2px solid rgba(255,255,255,0.06);
  transition: all var(--transition); border-radius: 0 4px 4px 0;
  line-height: 1.4;
}
.blog-toc-link--sub { padding-left: 1.5rem; font-size: 0.78rem; }
.blog-toc-link:hover { color: var(--text-white); border-left-color: rgba(0,212,255,0.4); background: rgba(0,212,255,0.04); }
.blog-toc-link.active { color: var(--neon-blue); border-left-color: var(--neon-blue); background: rgba(0,212,255,0.06); }

.blog-toc-share { padding-top: 1rem; border-top: 1px solid rgba(255,255,255,0.07); }
.blog-toc-share-label { font-size: 0.75rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-muted); font-family: var(--font-mono); margin-bottom: 0.75rem; }
.blog-toc-share-buttons { display: flex; gap: 0.6rem; }
.blog-share-icon {
  width: 34px; height: 34px; border-radius: 8px;
  background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-secondary); cursor: pointer; text-decoration: none;
  transition: all var(--transition);
}
.blog-share-icon:hover { background: rgba(0,212,255,0.1); border-color: rgba(0,212,255,0.3); color: var(--neon-blue); }

/* Mobile TOC */
.blog-toc-mobile {
  display: none; margin-bottom: 2rem;
  border: 1px solid rgba(255,255,255,0.08); border-radius: var(--radius);
  background: rgba(15,15,36,0.6); overflow: hidden;
}
.blog-toc-mobile-toggle {
  padding: 1rem 1.25rem; font-size: 0.88rem; font-weight: 600;
  color: var(--text-secondary); cursor: pointer; display: flex; align-items: center; gap: 0.75rem;
  list-style: none;
}
.blog-toc-mobile-toggle::-webkit-details-marker { display: none; }
.blog-toc-mobile-nav { padding: 0.5rem 1rem 1rem; }

/* Article Content */
.blog-post-content {
  font-size: 1.08rem; line-height: 1.85; color: var(--text-secondary);
}
.blog-post-content p { margin-bottom: 1.6rem; }
.blog-post-content h2 {
  font-size: clamp(1.5rem, 3vw, 2rem); color: var(--text-white);
  margin: 3.5rem 0 1.25rem; padding-top: 0.5rem;
  border-bottom: 1px solid rgba(255,255,255,0.07); padding-bottom: 0.75rem;
}
.blog-post-content h3 { font-size: 1.3rem; color: var(--text-white); margin: 2.5rem 0 1rem; }
.blog-post-content h4 { font-size: 1.1rem; color: var(--text-white); margin: 2rem 0 0.75rem; }
.blog-post-content ul, .blog-post-content ol {
  margin-bottom: 1.75rem; padding-left: 1.75rem; list-style: none;
}
.blog-post-content ul li {
  position: relative; padding-left: 1.25rem; margin-bottom: 0.65rem;
}
.blog-post-content ul li::before {
  content: ''; position: absolute; left: 0; top: 0.6em;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--neon-blue);
}
.blog-post-content ol { list-style: decimal; }
.blog-post-content ol li { padding-left: 0.25rem; margin-bottom: 0.65rem; color: var(--text-secondary); }
.blog-post-content li::marker { color: var(--neon-blue); }
.blog-post-content strong { color: var(--neon-blue); font-weight: 600; }
.blog-post-content a { color: var(--neon-blue); text-decoration: underline; text-decoration-color: rgba(0,212,255,0.3); }
.blog-post-content a:hover { color: var(--neon-purple-light); text-decoration-color: rgba(180,74,255,0.5); }
.blog-post-content img { border-radius: var(--radius); margin: 2.5rem 0; box-shadow: 0 16px 48px rgba(0,0,0,0.4); }
.blog-post-content blockquote {
  border-left: 3px solid var(--neon-blue);
  background: rgba(0,212,255,0.04); border-radius: 0 var(--radius) var(--radius) 0;
  padding: 1.5rem 1.75rem; margin: 2.5rem 0;
  font-style: italic; color: var(--text-secondary); font-size: 1.05rem;
}
.blog-post-content code {
  font-family: var(--font-mono); font-size: 0.88em;
  background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 4px; padding: 0.15em 0.5em; color: var(--neon-blue);
}
.blog-post-content pre {
  background: rgba(5,5,16,0.8); border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius); padding: 1.5rem; margin: 2rem 0; overflow-x: auto;
}
.blog-post-content pre code { background: none; border: none; padding: 0; color: #e0e0f0; }

/* Tags Section */
.blog-post-tags { display: flex; flex-wrap: wrap; gap: 0.5rem; margin: 3rem 0; padding: 1.75rem; background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.07); border-radius: var(--radius); }

/* Author Bio Card */
.blog-author-card {
  display: flex; gap: 1.5rem; align-items: flex-start;
  background: rgba(15,15,36,0.7); backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,0.1); border-radius: var(--radius-lg);
  padding: 2rem; margin: 3rem 0;
}
.blog-author-card-avatar {
  width: 64px; height: 64px; border-radius: 50%; flex-shrink: 0;
  background: var(--neon-gradient);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem; font-weight: 700; color: #fff;
  box-shadow: 0 0 20px rgba(0,212,255,0.2);
}
.blog-author-card-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-muted); font-family: var(--font-mono); margin-bottom: 0.25rem; }
.blog-author-card-name { font-size: 1.1rem; font-weight: 700; color: var(--text-white); margin-bottom: 0.5rem; }
.blog-author-card-bio { font-size: 0.9rem; color: var(--text-secondary); line-height: 1.6; margin: 0; }

/* Share Buttons */
.blog-post-share {
  display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap;
  padding: 1.5rem 0; border-top: 1px solid rgba(255,255,255,0.07); border-bottom: 1px solid rgba(255,255,255,0.07);
  margin-bottom: 2rem;
}
.blog-post-share-label { font-size: 0.88rem; color: var(--text-muted); font-weight: 600; }
.blog-post-share-buttons { display: flex; gap: 0.75rem; flex-wrap: wrap; }
.blog-share-btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.55rem 1.1rem; border-radius: var(--radius-sm);
  font-size: 0.83rem; font-weight: 600; font-family: var(--font-display);
  text-decoration: none; cursor: pointer; border: 1px solid;
  transition: all var(--transition);
}
.blog-share-btn--twitter { background: rgba(0,0,0,0.3); border-color: rgba(255,255,255,0.12); color: var(--text-secondary); }
.blog-share-btn--twitter:hover { background: rgba(29,161,242,0.15); border-color: rgba(29,161,242,0.4); color: #1da1f2; }
.blog-share-btn--linkedin { background: rgba(0,119,181,0.1); border-color: rgba(0,119,181,0.25); color: #0077b5; }
.blog-share-btn--linkedin:hover { background: rgba(0,119,181,0.2); border-color: rgba(0,119,181,0.5); }
.blog-share-btn--copy { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.1); color: var(--text-secondary); }
.blog-share-btn--copy:hover { background: rgba(0,212,255,0.08); border-color: rgba(0,212,255,0.3); color: var(--neon-blue); }

.blog-post-back { margin-top: 1.5rem; }

/* Related Posts */
.blog-related-section { background: var(--bg-secondary); }
.blog-related-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.75rem; margin-top: 2.5rem; }
.blog-related-card {
  display: flex; flex-direction: column; border-radius: var(--radius); overflow: hidden;
  border: 1px solid rgba(255,255,255,0.07); background: var(--bg-card);
  text-decoration: none; transition: all var(--transition);
}
.blog-related-card:hover { border-color: rgba(0,212,255,0.25); transform: translateY(-4px); box-shadow: 0 12px 36px rgba(0,0,0,0.3); }
.blog-related-image-wrap { height: 180px; overflow: hidden; }
.blog-related-image { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.blog-related-card:hover .blog-related-image { transform: scale(1.05); }
.blog-related-body { padding: 1.25rem; flex-grow: 1; display: flex; flex-direction: column; gap: 0.75rem; }
.blog-related-meta { display: flex; align-items: center; gap: 0.75rem; }
.blog-related-title { font-size: 1.05rem; line-height: 1.4; color: var(--text-white); transition: color var(--transition); }
.blog-related-card:hover .blog-related-title { color: var(--neon-blue); }
.blog-related-excerpt { font-size: 0.85rem; color: var(--text-secondary); line-height: 1.6; flex-grow: 1; }

/* ============================================================
   BLOG RESPONSIVE
   ============================================================ */
@media (max-width: 960px) {
  .blog-featured-card { grid-template-columns: 1fr; min-height: auto; }
  .blog-featured-image-wrap { height: 280px; }
  .blog-featured-content { padding: 2rem; }
  .blog-post-layout { grid-template-columns: 1fr; gap: 0; }
  .blog-toc-sidebar { display: none; }
  .blog-toc-mobile { display: block; }
}
@media (max-width: 640px) {
  .blogs-hero { padding: 140px 0 60px; }
  .blogs-newsletter-card { flex-direction: column; align-items: flex-start; padding: 2rem; }
  .blog-post-header { padding-top: 110px; }
  .blog-author-card { flex-direction: column; }
  .blog-post-share { flex-direction: column; align-items: flex-start; gap: 1rem; }
  .blogs-card-grid { grid-template-columns: 1fr; }
  .blog-related-grid { grid-template-columns: 1fr; }
}

/* =========================================
   Redesigned Navigation (Pill-shaped)
   ========================================= */

.navbar {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1rem 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
  background: transparent;
  backdrop-filter: none;
  border-bottom: none;
}

.nav-container {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  background-color: rgba(26, 26, 36, 0.8);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 0.5rem 1.5rem;
  border-radius: 50px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}


.logo {
  margin-right: 1rem;
}

/* ============================================================
   UPGRADE 2.0 — n8n-style premium enhancements
   ============================================================ */

/* ── Hero: 2-column split layout ── */
.hero { justify-content: flex-start; }
.hero-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
  width: 100%;
  position: relative;
  z-index: var(--z-base);
}
.hero-inner .hero-content { text-align: left; max-width: none; }
.hero-inner .hero-subtitle { margin: 0 0 var(--space-xl); max-width: 500px; }
.hero-inner .hero-actions { justify-content: flex-start; }

/* ── Aurora gradient blobs ── */
.hero-aurora { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.aurora-blob {
  position:absolute; border-radius:50%;
  filter:blur(80px); opacity:0.35; will-change:transform;
}
.aurora-blob-1 {
  width:700px; height:700px;
  background:radial-gradient(circle, rgba(123,47,247,0.65) 0%, rgba(0,212,255,0.25) 50%, transparent 70%);
  top:-25%; left:-15%;
  animation:aurora-drift-1 14s ease-in-out infinite alternate;
}
.aurora-blob-2 {
  width:500px; height:500px;
  background:radial-gradient(circle, rgba(0,212,255,0.5) 0%, rgba(123,47,247,0.2) 60%, transparent 70%);
  top:10%; right:-10%;
  animation:aurora-drift-2 17s ease-in-out infinite alternate;
}
.aurora-blob-3 {
  width:450px; height:450px;
  background:radial-gradient(circle, rgba(0,212,255,0.35) 0%, transparent 70%);
  bottom:-15%; left:25%;
  animation:aurora-drift-3 11s ease-in-out infinite alternate;
}
@keyframes aurora-drift-1 { from{transform:translate(0,0) scale(1)} to{transform:translate(90px,70px) scale(1.15)} }
@keyframes aurora-drift-2 { from{transform:translate(0,0) scale(1)} to{transform:translate(-70px,90px) scale(1.1)} }
@keyframes aurora-drift-3 { from{transform:translate(0,0) scale(1)} to{transform:translate(50px,-70px) scale(1.2)} }

/* ── Grid mesh overlay ── */
.hero-mesh {
  position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(0,212,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,212,255,0.03) 1px, transparent 1px);
  background-size:55px 55px;
  -webkit-mask-image:radial-gradient(ellipse 90% 90% at 50% 50%, black 0%, transparent 85%);
  mask-image:radial-gradient(ellipse 90% 90% at 50% 50%, black 0%, transparent 85%);
}

/* ── Hero title size boost ── */
.hero-title-xl { font-size:clamp(3rem,7.5vw,5.8rem) !important; letter-spacing:-0.025em; line-height:1.04 !important; }

/* ── Hero social proof mini bar ── */
.hero-social-proof {
  display:flex; align-items:center; gap:1.25rem;
  margin-top:var(--space-lg);
  opacity:0; transform:translateY(15px);
  animation:revealLine 0.8s cubic-bezier(0.16,1,0.3,1) forwards;
  animation-delay:0.8s;
}
.hsp-item { display:flex; flex-direction:column; gap:0.1rem; }
.hsp-num { font-family:var(--font-display); font-size:1.25rem; font-weight:800; color:var(--text-white); line-height:1; }
.hsp-label { font-size:0.72rem; color:var(--text-muted); letter-spacing:0.06em; text-transform:uppercase; }
.hsp-divider { width:1px; height:30px; background:var(--glass-border); }

/* ── Workflow preview canvas (hero visual) ── */
.hero-visual {
  position:relative;
  animation:revealLine 1s ease forwards;
  animation-delay:0.4s; opacity:0;
}
.wf-canvas {
  background:rgba(10,10,22,0.85);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:var(--radius-lg);
  overflow:hidden;
  backdrop-filter:blur(20px);
  box-shadow:0 40px 80px rgba(0,0,0,0.5), 0 0 0 1px rgba(0,212,255,0.06), inset 0 1px 0 rgba(255,255,255,0.06);
}
.wf-canvas-header {
  display:flex; align-items:center; gap:0.75rem;
  padding:0.85rem 1.25rem;
  border-bottom:1px solid rgba(255,255,255,0.07);
  background:rgba(255,255,255,0.02);
}
.wf-chrome { display:flex; gap:0.45rem; }
.wf-dot { width:11px; height:11px; border-radius:50%; display:block; }
.wf-canvas-title {
  flex:1; font-size:0.78rem; font-family:var(--font-mono);
  color:var(--text-secondary); letter-spacing:0.03em;
}
.wf-live-badge {
  display:inline-flex; align-items:center; gap:0.35rem;
  padding:0.2rem 0.65rem; border-radius:var(--radius-pill);
  background:rgba(0,184,148,0.12); border:1px solid rgba(0,184,148,0.3);
  font-size:0.7rem; color:#00b894; font-family:var(--font-mono);
}
.wf-live-dot {
  width:6px; height:6px; border-radius:50%; background:#00b894;
  animation:pulse-dot 2s infinite;
}
.wf-canvas-body { padding:1.5rem 1.25rem; display:flex; flex-direction:column; gap:1rem; }

/* Workflow flow row */
.wf-flow { display:flex; align-items:center; gap:0; }
.wf-node {
  display:flex; flex-direction:column; align-items:center; gap:0.3rem;
  flex-shrink:0; position:relative;
}
.wf-node-icon {
  width:44px; height:44px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(var(--nc, 0,212,255), 0.12);
  border:1px solid rgba(var(--nc, 0,212,255), 0.3);
  transition:all var(--transition);
}
.wf-node-icon svg { width:20px; height:20px; }
.wf-node-name { font-size:0.72rem; font-weight:600; color:var(--text-white); }
.wf-node-sub  { font-size:0.62rem; color:var(--text-muted); font-family:var(--font-mono); }
.wf-node-pulse {
  position:absolute; top:-3px; right:-3px;
  width:10px; height:10px; border-radius:50%;
  background:rgba(var(--pc, 255,107,53), 0.9);
  animation:pulse-dot 1.8s infinite;
}

.wf-arrow {
  flex:1; height:2px; background:rgba(255,255,255,0.08);
  position:relative; min-width:20px; max-width:40px;
}
.wf-arrow-dot {
  position:absolute; top:50%; left:0;
  width:8px; height:8px; border-radius:50%;
  background:var(--neon-blue);
  transform:translate(-50%,-50%);
  animation:arrow-travel 2s ease-in-out infinite;
  animation-delay:var(--d, 0s);
  box-shadow:0 0 6px rgba(0,212,255,0.8);
}
@keyframes arrow-travel {
  0% { left:0%; opacity:0; }
  10% { opacity:1; }
  90% { opacity:1; }
  100% { left:100%; opacity:0; }
}

/* Log strip */
.wf-log { display:flex; flex-direction:column; gap:0.3rem; }
.wf-log-item {
  display:flex; gap:0.6rem; align-items:center;
  padding:0.35rem 0.6rem; border-radius:6px;
  background:rgba(255,255,255,0.02);
  opacity:0; transform:translateX(-8px);
  animation:log-appear 0.5s ease forwards;
  animation-delay:var(--ld, 0s);
}
.wf-log-item--success { background:rgba(0,184,148,0.06); }
@keyframes log-appear {
  to { opacity:1; transform:translateX(0); }
}
.wf-log-time { font-family:var(--font-mono); font-size:0.62rem; color:var(--text-muted); flex-shrink:0; }
.wf-log-text { font-size:0.72rem; color:var(--text-secondary); }
.wf-log-item--success .wf-log-text { color:#00b894; }

/* Metrics row */
.wf-metrics-row {
  display:flex; align-items:center; gap:1rem;
  padding:0.75rem; border-radius:var(--radius-sm);
  background:rgba(255,255,255,0.025);
  border:1px solid rgba(255,255,255,0.05);
}
.wf-metric { text-align:center; flex:1; }
.wf-metric-val {
  display:block; font-family:var(--font-display); font-size:1rem; font-weight:700;
  color:var(--neon-blue); line-height:1;
}
.wf-metric-val.success { color:#00b894; }
.wf-metric-lbl { font-size:0.62rem; color:var(--text-muted); font-family:var(--font-mono); }
.wf-metric-sep { width:1px; height:28px; background:rgba(255,255,255,0.08); flex-shrink:0; }

/* Floating hero stat cards */
.hero-float-card {
  position:absolute;
  display:flex; align-items:center; gap:0.7rem;
  padding:0.7rem 1rem;
  background:rgba(10,10,22,0.9);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:var(--radius);
  backdrop-filter:blur(16px);
  box-shadow:0 8px 30px rgba(0,0,0,0.4);
}
.hfc-1 { bottom:-18px; left:-30px; animation:float 5s ease-in-out infinite; }
.hfc-2 { top:30px; right:-30px; animation:float 7s ease-in-out infinite 1s; }
.hfc-emoji {
  width:36px; height:36px; border-radius:10px;
  background:rgba(0,212,255,0.12); display:flex; align-items:center; justify-content:center;
  font-size:1.1rem;
}
.hfc-val { font-family:var(--font-display); font-size:1.05rem; font-weight:800; color:var(--neon-blue); line-height:1; }
.hfc-lbl { font-size:0.68rem; color:var(--text-muted); }

/* ── Integrations marquee ── */
.integrations-section {
  padding:var(--space-xl) 0;
  border-top:1px solid var(--glass-border);
  border-bottom:1px solid var(--glass-border);
  background:var(--bg-secondary);
  overflow:hidden;
}
.integrations-label {
  text-align:center; font-family:var(--font-mono);
  font-size:0.72rem; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--text-muted); margin-bottom:var(--space-lg);
}
.marquee-wrapper { display:flex; flex-direction:column; gap:var(--space-md); }

.marquee-track {
  display:flex; gap:var(--space-md);
  width:max-content;
  animation:marquee-ltr 35s linear infinite;
}
.marquee-track.rtl { animation:marquee-rtl 40s linear infinite; }
.marquee-track:hover { animation-play-state:paused; }

@keyframes marquee-ltr {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}
@keyframes marquee-rtl {
  from { transform:translateX(-50%); }
  to   { transform:translateX(0); }
}

.marquee-item {
  display:inline-flex; align-items:center; gap:0.6rem;
  padding:0.55rem 1.1rem;
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:var(--radius-pill);
  font-size:0.82rem; font-weight:500; color:var(--text-secondary);
  white-space:nowrap; flex-shrink:0;
  transition:border-color 0.2s, color 0.2s;
}
.marquee-item:hover { border-color:rgba(0,212,255,0.3); color:var(--text-white); }
.mi-logo {
  width:22px; height:22px; flex-shrink:0;
  object-fit:contain; display:block;
}

/* ── Why Vyoma grid ── */
.why-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
  margin-top:var(--space-2xl);
}
.why-card {
  padding:2rem;
  background:var(--bg-card);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);
  transition:border-color 0.25s, transform 0.25s;
}
.why-card:hover {
  border-color:rgba(0,212,255,0.25);
  transform:translateY(-3px);
}
.why-icon {
  width:44px; height:44px;
  display:flex; align-items:center; justify-content:center;
  color:var(--neon-blue);
  margin-bottom:1.25rem;
}
.why-icon svg { width:100%; height:100%; }
.why-card h3 {
  font-size:1.05rem; font-weight:600;
  color:var(--text-white);
  margin-bottom:0.6rem;
}
.why-card p {
  font-size:0.88rem; line-height:1.7;
  color:var(--text-secondary);
}
@media (max-width:1024px) { .why-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px)  { .why-grid { grid-template-columns:1fr; } }

/* ── Bento services grid ── */
.bento-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.25rem;
}
.bento-card {
  position:relative; isolation:isolate;
  background:var(--bg-glass);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border:1px solid var(--glass-border);
  border-radius:var(--radius);
  padding:var(--space-xl) var(--space-lg);
  transition:border-color var(--transition), transform var(--transition), box-shadow var(--transition);
  overflow:hidden;
}
.bento-card::before {
  content:'';
  position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--neon-gradient-h);
  opacity:0; transition:opacity 0.3s;
}
.bento-card:hover { transform:translateY(-5px); box-shadow:var(--glow-mixed); border-color:rgba(0,212,255,0.25); }
.bento-card:hover::before { opacity:1; }

.bento-icon {
  width:52px; height:52px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:var(--space-lg);
  border:1px solid var(--glass-border);
  transition:all var(--transition);
}
.bento-card:hover .bento-icon { box-shadow:0 0 20px rgba(0,212,255,0.15); border-color:rgba(0,212,255,0.25); }
.bento-icon svg { width:26px; height:26px; stroke:currentColor; fill:none; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; }
.bento-card h3 { margin-bottom:var(--space-sm); font-size:1.05rem; }
.bento-card p  { font-size:0.87rem; color:var(--text-secondary); margin-bottom:var(--space-md); }
.bento-tags { display:flex; flex-wrap:wrap; gap:0.35rem; }
.bento-tag {
  padding:0.2rem 0.6rem;
  background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--radius-pill); font-size:0.68rem; color:var(--text-muted);
  font-family:var(--font-mono);
}
.bento-card-link {
  display:inline-flex; align-items:center; gap:0.4rem; margin-top:var(--space-md);
  font-size:0.82rem; font-weight:600; color:var(--neon-blue);
  transition:gap var(--transition);
}
.bento-card-link:hover { gap:0.7rem; color:var(--neon-purple-light); }
.bento-card-link svg { width:14px; height:14px; stroke:currentColor; fill:none; stroke-width:2; }

/* ── Big-number stats ── */
.stats-big {
  display:grid; grid-template-columns:repeat(4,1fr);
  border:1px solid var(--glass-border); border-radius:var(--radius);
  overflow:hidden;
}
.stat-big-item {
  padding:var(--space-2xl) var(--space-lg);
  text-align:center;
  border-right:1px solid var(--glass-border);
  position:relative; overflow:hidden;
}
.stat-big-item:last-child { border-right:none; }
.stat-big-item::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--neon-gradient-h); opacity:0;
  transition:opacity 0.6s;
}
.stat-big-item.is-visible::before { opacity:1; }
.stat-big-num {
  font-family:var(--font-display); font-weight:900;
  font-size:clamp(2.8rem,5vw,4rem); line-height:1;
  background:var(--neon-gradient);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  margin-bottom:0.5rem; display:block;
}
.stat-big-label { font-size:0.85rem; color:var(--text-secondary); font-weight:500; }
.stat-big-sub { font-size:0.72rem; color:var(--text-muted); font-family:var(--font-mono); margin-top:0.25rem; display:block; }

/* ── Testimonials ── */
.testimonials-section { background:var(--bg-secondary); }

/* ── Section divider line ── */
.section-divider {
  height:1px; background:var(--neon-gradient-h); opacity:0.15;
  margin:0; border:none;
}

/* ── Responsive: hero 2-col ── */
@media (max-width:1024px) {
  .hero-inner { grid-template-columns:1fr; gap:3rem; }
  .hero-visual { display:none; }
  .hero-inner .hero-content { text-align:center; }
  .hero-inner .hero-subtitle { margin:0 auto var(--space-xl); }
  .hero-inner .hero-actions { justify-content:center; }
  .hero-social-proof { justify-content:center; }
  .bento-grid { grid-template-columns:repeat(2,1fr); }
  .stats-big { grid-template-columns:repeat(2,1fr); }
  .stats-big .stat-big-item:nth-child(2) { border-right:none; }
  /* Tablet: tighter marquee items */
  .marquee-item { padding:0.45rem 0.85rem; font-size:0.78rem; gap:0.5rem; }
  .mi-logo { width:18px; height:18px; }
  .integrations-label { font-size:0.65rem; }
}
@media (max-width:768px) {
  .bento-grid { grid-template-columns:1fr; }
  .stats-big { grid-template-columns:repeat(2,1fr); }
  .stats-big .stat-big-item { border-right:1px solid var(--glass-border); }
  .stats-big .stat-big-item:nth-child(even) { border-right:none; }
  .stats-big .stat-big-item:nth-child(3),
  .stats-big .stat-big-item:nth-child(4) { border-top:1px solid var(--glass-border); }
  /* Mobile: only one marquee row visible */
  .marquee-track.rtl { display:none; }
  .marquee-item { padding:0.4rem 0.75rem; font-size:0.75rem; }
}

/* ── Footer legal links ── */
.footer-legal { display:flex; align-items:center; gap:0.75rem; flex-wrap:wrap; }
.footer-legal a { color:var(--text-muted); font-size:0.8rem; text-decoration:none; transition:color 0.2s; }
.footer-legal a:hover { color:var(--text-white); }
.footer-legal span { color:var(--text-muted); font-size:0.8rem; }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem; }

/* ── Cookie consent banner ── */
.cookie-banner {
  position:fixed; bottom:1.5rem; left:50%; transform:translateX(-50%);
  width:calc(100% - 3rem); max-width:640px;
  background:rgba(10,10,26,0.97);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);
  padding:1.1rem 1.4rem;
  display:flex; align-items:center; gap:1.5rem;
  z-index:9000;
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  box-shadow:0 8px 32px rgba(0,0,0,0.4);
}
.cookie-banner-content { display:flex; align-items:center; justify-content:space-between; width:100%; gap:1.5rem; flex-wrap:wrap; }
.cookie-banner-content p { font-size:0.85rem; color:var(--text-secondary); margin:0; line-height:1.5; }
.cookie-banner-content a { color:var(--neon-blue); text-decoration:underline; }
.cookie-banner-actions { display:flex; gap:0.6rem; flex-shrink:0; }
.cookie-btn { padding:0.45rem 1.1rem; border-radius:100px; font-size:0.82rem; font-weight:600; cursor:pointer; border:none; transition:all 0.2s; }
.cookie-btn--primary { background:var(--neon-gradient); color:#fff; }
.cookie-btn--outline { background:transparent; border:1px solid var(--glass-border); color:var(--text-secondary); }
.cookie-btn--outline:hover { border-color:rgba(255,255,255,0.3); color:var(--text-white); }
@media (max-width:480px) {
  .cookie-banner { bottom:0; left:0; right:0; transform:none; width:100%; border-radius:var(--radius-lg) var(--radius-lg) 0 0; }
  .footer-bottom { flex-direction:column; align-items:flex-start; }
}
