/* ================================================================
   ASKMIRO — LIGHT PREMIUM v5.0
   White base · teal lighting · Figtree + JetBrains Mono
   Same modern design DNA as chat widget, inverted to light
   ================================================================ */
:root {
  /* Teal palette */
  --teal:        #0A9688;
  --teal-mid:    #0DBDAD;
  --teal-light:  #14D4C2;
  --teal-wash:   rgba(13,189,173,0.07);
  --teal-wash-2: rgba(13,189,173,0.12);
  --border-teal: rgba(13,189,173,0.28);

  /* Light surfaces */
  --bg-base:     #F4F8FB;
  --bg-surface:  #FFFFFF;
  --bg-raised:   #EBF2F8;
  --bg-alt:      #F0F7FA;

  /* Dark for nav/footer/hero */
  --navy:        #0D1C2E;
  --navy-mid:    #0e2438;

  /* Text */
  --text-1:      #0D1C2E;
  --text-2:      #3D5A74;
  --text-3:      #4E6F8A;
  --text-muted:  #6B8FA8;

  /* Borders */
  --border:      rgba(13,28,46,0.08);
  --border-md:   rgba(13,28,46,0.13);

  /* Shadows */
  --shadow-sm:   0 1px 3px rgba(13,28,46,0.06),0 1px 2px rgba(13,28,46,0.04);
  --shadow-md:   0 4px 20px rgba(13,28,46,0.08),0 2px 6px rgba(13,28,46,0.05);
  --shadow-lg:   0 12px 48px rgba(13,28,46,0.1),0 4px 12px rgba(13,28,46,0.06);
  --shadow-teal: 0 4px 20px rgba(10,150,136,0.22);
  --shadow-teal-lg: 0 8px 32px rgba(10,150,136,0.28);

  /* Motion */
  --ease:   cubic-bezier(0.25,0.46,0.45,0.94);
  --spring: cubic-bezier(0.34,1.3,0.64,1);

  /* Radii */
  --r-sm: 8px; --r-md: 14px; --r-lg: 20px; --r-xl: 28px;
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
/* font-display:swap equivalent — system font renders hero immediately, Figtree swaps in */
body { font-family:'Figtree',system-ui,-apple-system,'Segoe UI',sans-serif; background:var(--bg-base); color:var(--text-1); overflow-x:hidden; line-height:1.65; }
img { max-width:100%; display:block; }
a   { text-decoration:none; color:inherit; }

/* Skip link — accessibility */
.skip-link{position:absolute;top:-40px;left:0;background:var(--teal);color:#fff;padding:8px 16px;border-radius:0 0 8px 0;font-size:14px;font-weight:600;z-index:9999;transition:top .2s;}
.skip-link:focus{top:0;}

/* Critical hero text — paint immediately with system font, no layout shift */
.hero h1, .hero-badge, .hero-sub { font-synthesis: none; }

/* ── TEAL MESH WASH (light sections) ── */
.teal-mesh {
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(ellipse 65% 45% at 0% 0%,   rgba(13,189,173,0.09) 0%, transparent 55%),
    radial-gradient(ellipse 50% 55% at 100% 100%, rgba(10,150,136,0.07) 0%, transparent 55%),
    radial-gradient(ellipse 35% 30% at 60% 15%,  rgba(13,189,173,0.04) 0%, transparent 50%);
}

/* ── EYEBROW ── */
.eyebrow {
  font-family:'JetBrains Mono',monospace;
  font-size:0.6875rem; letter-spacing:0.12em; text-transform:uppercase;
  color:var(--teal);
}

/* ── BUTTONS ── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 26px; border-radius:var(--r-sm);
  font-family:'Figtree',sans-serif; font-size:0.875rem; font-weight:700;
  letter-spacing:0.01em; cursor:pointer; border:none;
  transition:transform .22s var(--spring), box-shadow .2s, background .2s;
  white-space:nowrap; position:relative; overflow:hidden;
}
.btn::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(105deg,transparent 38%,rgba(255,255,255,.18) 50%,transparent 62%);
  transform:translateX(-110%); transition:transform .45s var(--ease);
  pointer-events:none;
}
.btn:hover::before { transform:translateX(110%); }
.btn svg { flex-shrink:0; transition:transform .2s var(--spring); }
.btn:hover svg { transform:translateX(3px); }

.btn-primary {
  background:linear-gradient(135deg,var(--teal-mid),var(--teal));
  color:#fff; box-shadow:var(--shadow-teal);
}
.btn-primary:hover {
  transform:translateY(-2px) scale(1.02);
  box-shadow:var(--shadow-teal-lg);
}
.btn-ghost {
  background:transparent; color:var(--text-1);
  border:1.5px solid var(--border-md);
}
.btn-ghost:hover {
  border-color:var(--teal); color:var(--teal);
  background:var(--teal-wash); transform:translateY(-1px);
}
.btn-dark {
  background:var(--navy); color:#fff;
  box-shadow:var(--shadow-md);
}
.btn-dark:hover {
  background:#1a3050; transform:translateY(-2px);
  box-shadow:var(--shadow-lg);
}
.btn-ghost-light {
  background:rgba(255,255,255,0.08); color:rgba(255,255,255,0.85);
  border:1px solid rgba(255,255,255,0.18);
}
.btn-ghost-light:hover {
  background:rgba(255,255,255,0.15); color:#fff;
  border-color:rgba(255,255,255,0.35);
}

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:0 40px; height:66px;
  display:flex; align-items:center; justify-content:space-between;
  transition:background .3s, box-shadow .3s, border-color .3s;
}
nav.scrolled {
  background:rgba(255,255,255,0.95);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}
.nav-logo {
  font-size:1.25rem; font-weight:800; letter-spacing:-.02em;
  display:flex; align-items:center; gap:10px; color:#fff;
  transition:color .3s;
}
nav.scrolled .nav-logo { color:var(--text-1); }
.nav-links { display:flex; align-items:center; gap:32px; list-style:none; }
.nav-links a {
  font-size:0.875rem; font-weight:500; color:rgba(255,255,255,0.65);
  transition:color .2s; position:relative; padding-bottom:2px;
}
.nav-links a::after {
  content:''; position:absolute; bottom:0; left:0;
  width:0; height:1px; background:var(--teal-light);
  transition:width .25s var(--ease);
}
.nav-links a:hover { color:#fff; }
.nav-links a:hover::after { width:100%; }
nav.scrolled .nav-links a { color:var(--text-3); }
nav.scrolled .nav-links a:hover { color:var(--text-1); }
nav.scrolled .nav-links a::after { background:var(--teal); }
.nav-cta {
  background:linear-gradient(135deg,var(--teal-mid),var(--teal))!important;
  color:#fff!important; padding:9px 20px; border-radius:var(--r-sm);
  font-size:0.8125rem; font-weight:700; letter-spacing:.01em;
  box-shadow:var(--shadow-teal);
  transition:transform .2s var(--spring), box-shadow .2s!important;
}
.nav-cta:hover { transform:translateY(-1px) scale(1.02)!important; box-shadow:var(--shadow-teal-lg)!important; }
.nav-cta::after { display:none!important; }
.nav-mobile-btn { display:none; background:none; border:none; cursor:pointer; padding:8px; color:#fff; }
nav.scrolled .nav-mobile-btn { color:var(--text-1); }

/* ── HERO (stays dark with photo) ── */
.hero {
  position:relative; min-height:100vh;
  display:flex; flex-direction:column; justify-content:flex-end;
  overflow:hidden; background:var(--navy-mid);
}
.hero-bg { position:absolute; inset:0; z-index:0; transition:opacity 1.5s ease; }
.hero-bg img { width:100%; height:100%; object-fit:cover; filter:saturate(0.75) brightness(0.5); }
.hero-overlay {
  position:absolute; inset:0; z-index:1;
  background:
    radial-gradient(ellipse 80% 60% at 0% 100%, rgba(10,150,136,0.22) 0%, transparent 55%),
    radial-gradient(ellipse 50% 50% at 100% 0%, rgba(13,189,173,0.1) 0%, transparent 50%),
    linear-gradient(to top, rgba(13,28,46,0.97) 0%, rgba(13,28,46,0.55) 40%, rgba(13,28,46,0.1) 100%);
}
.hero-content {
  position:relative; z-index:2;
  padding:0 40px 80px; max-width:1200px; margin:0 auto; width:100%;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(13,189,173,0.12); border:1px solid rgba(13,189,173,0.3);
  border-radius:100px; padding:6px 14px; margin-bottom:32px;
}
.hero-badge .dot {
  width:6px; height:6px; background:var(--teal-mid); border-radius:50%;
  box-shadow:0 0 0 3px rgba(13,189,173,0.2);
  animation:dot-pulse 2.5s ease-in-out infinite;
  will-change: transform;
}
@keyframes dot-pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.6);opacity:.5} }
.hero-badge span { font-family:'JetBrains Mono',monospace; font-size:0.6875rem; letter-spacing:.1em; text-transform:uppercase; color:var(--teal-mid); }
.hero h1 {
  font-size:clamp(3rem,7vw,6.5rem); font-weight:800; line-height:0.92;
  letter-spacing:-0.035em; margin-bottom:28px; max-width:900px; color:#fff;
}
.hero h1 em { font-style:normal; color:var(--teal-light); }
.hero-sub { font-size:1.125rem; color:rgba(255,255,255,0.65); max-width:520px; line-height:1.75; margin-bottom:40px; }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:64px; }
.hero-stats { display:flex; gap:48px; padding-top:40px; border-top:1px solid rgba(255,255,255,0.1); }
.stat-num { font-size:2rem; font-weight:800; color:#fff; }
.stat-label { font-size:0.8125rem; color:rgba(255,255,255,0.45); margin-top:2px; }
.hero-slide-nav { position:absolute; bottom:80px; right:40px; z-index:3; display:flex; flex-direction:column; gap:6px; }
.slide-dot { width:2px; height:24px; background:rgba(255,255,255,0.2); border:none; cursor:pointer; border-radius:1px; transition:background .3s,height .3s; }
.slide-dot.active { background:var(--teal-mid); height:40px; }

/* ── MARQUEE ── */
.marquee-wrap {
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  padding:16px 0; overflow:hidden; background:var(--bg-surface);
}
.marquee-track { display:flex; gap:60px; animation:marquee 30s linear infinite; width:max-content; will-change:transform; }
.marquee-track:hover { animation-play-state:paused; }
.marquee-item {
  display:flex; align-items:center; gap:10px; white-space:nowrap;
  font-family:'JetBrains Mono',monospace; font-size:0.6875rem;
  letter-spacing:.1em; text-transform:uppercase; color:var(--text-muted);
}
.marquee-dot { width:3px; height:3px; background:var(--teal); border-radius:50%; flex-shrink:0; }
@keyframes marquee { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ── SECTIONS ── */
section { padding:120px 40px; position:relative; }
.container { max-width:1200px; margin:0 auto; }
.section-head { margin-bottom:72px; }
.section-head.center { text-align:center; }
.section-divider { width:48px; height:2px; background:linear-gradient(90deg,var(--teal),var(--teal-light)); border-radius:1px; margin-top:20px; }
.section-divider.center { margin:20px auto 0; }

/* ── WHY — BENTO ── */
.bento {
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:0;
  border:1px solid var(--border);
  border-radius:var(--r-xl); overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.bento-card {
  background:var(--bg-surface); padding:42px 36px;
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  transition:background .25s, box-shadow .25s;
  position:relative; overflow:hidden;
}
.bento-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--teal),var(--teal-light));
  transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease);
}
.bento-card:hover { background:var(--teal-wash); box-shadow:var(--shadow-md); }
.bento-card:hover::after { transform:scaleX(1); }
.bento-card.featured {
  background:linear-gradient(135deg, rgba(13,189,173,0.05) 0%, rgba(10,150,136,0.02) 100%);
}
.bento-icon {
  width:44px; height:44px;
  background:linear-gradient(135deg,var(--teal-mid),var(--teal));
  border-radius:12px; display:flex; align-items:center; justify-content:center;
  margin-bottom:22px; font-size:1.25rem;
  box-shadow:var(--shadow-teal);
  transition:transform .3s var(--spring), box-shadow .3s;
}
.bento-card:hover .bento-icon { transform:scale(1.08); box-shadow:var(--shadow-teal-lg); }
.bento-card h3 { font-size:1.1rem; font-weight:700; margin-bottom:10px; color:var(--text-1); }
.bento-card p  { font-size:0.9rem; color:var(--text-2); line-height:1.72; }

/* ── SERVICES ── */
.services-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1px; background:var(--border);
  border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-lg);
}
.service-card {
  background:var(--bg-surface); padding:40px 32px;
  position:relative; overflow:hidden;
  transition:background .25s, transform .25s var(--ease);
}
.service-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--teal),var(--teal-light));
  transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease);
}
.service-card:hover { background:var(--teal-wash); transform:translateY(-2px); }
.service-card:hover::after { transform:scaleX(1); }
.service-num {
  font-family:'JetBrains Mono',monospace; font-size:0.6875rem;
  letter-spacing:.12em; color:var(--teal); margin-bottom:20px;
}
.service-card h3 { font-size:1.25rem; font-weight:700; margin-bottom:10px; color:var(--text-1); }
.service-card p  { font-size:0.9rem; color:var(--text-2); line-height:1.72; margin-bottom:20px; }
.service-tag {
  display:inline-block; padding:4px 10px;
  background:var(--teal-wash); border:1px solid var(--border-teal);
  border-radius:3px; font-family:'JetBrains Mono',monospace;
  font-size:0.625rem; color:var(--teal); letter-spacing:.08em;
}

/* ── VIDEO ── */
.video-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:2px;
  border-radius:var(--r-xl); overflow:hidden;
  background:var(--border); box-shadow:var(--shadow-lg);
}
.video-cell { position:relative; aspect-ratio:16/9; overflow:hidden; cursor:pointer; transition:transform .35s var(--ease); }
.video-cell.large { grid-column:span 2; aspect-ratio:21/9; }
.video-cell img { width:100%; height:100%; object-fit:cover; filter:saturate(0.8) brightness(0.7); transition:transform .55s var(--ease),filter .4s; }
.video-cell:hover img { transform:scale(1.04); filter:saturate(1) brightness(0.9); }
.video-overlay {
  position:absolute; inset:0; z-index:1;
  display:flex; flex-direction:column; justify-content:flex-end; padding:28px;
  background:linear-gradient(to top, rgba(13,28,46,0.82) 0%, transparent 55%);
}
.play-btn {
  width:52px; height:52px;
  background:rgba(255,255,255,0.15); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,0.3); border-radius:50%;
  display:flex; align-items:center; justify-content:center; margin-bottom:14px;
  transition:background .25s,border-color .25s,transform .3s var(--spring);
  cursor:pointer; padding:0; /* button reset */
}
.video-cell:hover .play-btn { background:var(--teal); border-color:var(--teal); transform:scale(1.1); }
.video-label { font-size:1.125rem; font-weight:700; color:#fff; }
.video-sub   { font-size:0.8125rem; color:rgba(255,255,255,0.65); margin-top:4px; }

/* ── PROCESS ── */
.process-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:0; position:relative;
}
.process-grid::before {
  content:''; position:absolute; top:27px; left:12.5%; right:12.5%; height:1px;
  background:linear-gradient(90deg,transparent,var(--border-teal),var(--border-teal),transparent);
}
.step-item { text-align:center; padding:0 20px; position:relative; z-index:1; }
.step-circle {
  width:54px; height:54px; border-radius:50%;
  background:var(--bg-surface); border:1.5px solid var(--border-md);
  display:flex; align-items:center; justify-content:center; margin:0 auto 22px;
  font-family:'JetBrains Mono',monospace; font-size:.875rem; color:var(--teal);
  box-shadow:var(--shadow-sm);
  transition:background .25s, border-color .25s, transform .3s var(--spring), box-shadow .25s;
}
.step-item:hover .step-circle {
  background:linear-gradient(135deg,var(--teal-mid),var(--teal));
  border-color:transparent; color:#fff;
  transform:scale(1.08); box-shadow:var(--shadow-teal);
}
.step-item h4 { font-size:1rem; font-weight:700; margin-bottom:8px; color:var(--text-1); }
.step-item p  { font-size:0.875rem; color:var(--text-2); line-height:1.65; }

/* ── TRUST ── */
.trust-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:1px; background:var(--border);
  border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-lg);
}
.trust-card {
  background:var(--bg-surface); padding:36px; text-align:center;
  transition:background .25s, transform .25s var(--ease);
}
.trust-card:hover { background:var(--teal-wash); transform:translateY(-2px); }
.trust-icon {
  width:48px; height:48px;
  background:linear-gradient(135deg,rgba(13,189,173,.1),rgba(10,150,136,.07));
  border:1px solid var(--border-teal); border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 16px; font-size:1.375rem;
  transition:transform .3s var(--spring), box-shadow .3s;
}
.trust-card:hover .trust-icon { transform:scale(1.08) translateY(-2px); box-shadow:var(--shadow-teal); }
.trust-card h4 { font-size:.9375rem; font-weight:700; margin-bottom:6px; color:var(--text-1); }
.trust-card p  { font-size:.8125rem; color:var(--text-2); line-height:1.6; }

/* ── TESTIMONIALS ── */
.testi-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:var(--border);
  border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-lg);
}
.testi-card {
  background:var(--bg-surface); padding:40px;
  transition:background .25s, transform .25s var(--ease);
}
.testi-card:hover { background:var(--teal-wash); transform:translateY(-2px); }
.quote-mark { font-size:3rem; color:var(--teal-mid); line-height:.75; margin-bottom:18px; display:block; opacity:.6; }
.testi-text { font-size:.9375rem; color:var(--text-2); line-height:1.78; margin-bottom:24px; }
.author-name { font-size:.9rem; font-weight:700; color:var(--text-1); }
.author-role { font-size:.8125rem; color:var(--text-3); margin-top:2px; }

/* ── FAQ ── */
.faq-list { border-top:1px solid var(--border); }
.faq-item { border-bottom:1px solid var(--border); }
.faq-q {
  display:flex; align-items:center; justify-content:space-between;
  padding:26px 0; cursor:pointer; gap:20px;
}
.faq-q h3 { font-size:1.0625rem; font-weight:600; color:var(--text-1); transition:color .2s; }
.faq-q:hover h3 { color:var(--teal); }
.faq-toggle {
  width:32px; height:32px; border-radius:50%;
  background:var(--bg-raised); border:1px solid var(--border-md);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  color:var(--text-2); font-size:1.25rem;
  transition:background .25s, border-color .25s, transform .3s var(--ease), color .25s;
}
.faq-item.expanded .faq-toggle {
  background:linear-gradient(135deg,var(--teal-mid),var(--teal));
  border-color:transparent; color:#fff; transform:rotate(45deg);
}
.faq-ans { max-height:0; overflow:hidden; transition:max-height .4s var(--ease),padding .3s; }
.faq-item.expanded .faq-ans { max-height:300px; padding-bottom:24px; }
.faq-ans p { font-size:.9375rem; color:var(--text-2); line-height:1.78; }

/* ── CTA (dark panel) ── */
.cta-section {
  background:var(--navy); padding:120px 40px; text-align:center;
  position:relative; overflow:hidden;
}
.cta-mesh {
  position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(ellipse 65% 70% at 50% 0%,   rgba(13,189,173,0.16) 0%, transparent 55%),
    radial-gradient(ellipse 40% 40% at 0% 100%,   rgba(10,150,136,0.1) 0%, transparent 50%),
    radial-gradient(ellipse 40% 40% at 100% 100%, rgba(10,150,136,0.1) 0%, transparent 50%);
}
.cta-section::after {
  content:''; position:absolute; top:0; left:-100%; right:auto; width:100%; height:1px;
  background:linear-gradient(90deg,transparent,var(--teal-mid),rgba(20,212,194,.7),var(--teal-mid),transparent);
  animation:scan 5s linear infinite;
  will-change:transform;
}
@keyframes scan { 0%{transform:translateX(0)} 100%{transform:translateX(200%)} }
.cta-inner { position:relative; z-index:1; max-width:700px; margin:0 auto; }
.cta-inner h2 { font-size:clamp(2.5rem,5vw,4.5rem); font-weight:800; line-height:.95; letter-spacing:-.035em; margin-bottom:22px; color:#fff; }
.cta-inner h2 em { font-style:normal; color:var(--teal-light); }
.cta-inner p { font-size:1.0625rem; color:rgba(255,255,255,0.55); margin-bottom:40px; }
.cta-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.cta-contact { margin-top:36px; display:flex; gap:32px; justify-content:center; flex-wrap:wrap; }
.cta-contact-item { display:flex; align-items:center; gap:8px; font-size:.875rem; color:rgba(255,255,255,0.4); }
.cta-contact-item a { color:rgba(255,255,255,0.75); font-weight:600; transition:color .2s; }
.cta-contact-item a:hover { color:var(--teal-light); }

/* ── FOOTER ── */
footer {
  background:var(--navy-mid); border-top:1px solid rgba(255,255,255,0.06);
  padding:64px 40px 40px;
}
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.footer-brand p { font-size:.875rem; color:rgba(255,255,255,0.38); line-height:1.72; margin-top:16px; max-width:280px; }
.footer-logo { font-size:1.25rem; font-weight:800; letter-spacing:-.02em; display:flex; align-items:center; gap:10px; color:#fff; }
.footer-col-title {
  font-family:'JetBrains Mono',monospace; font-size:.625rem; letter-spacing:.12em;
  text-transform:uppercase; color:rgba(255,255,255,0.25); margin-bottom:20px;
}
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col ul a { font-size:.875rem; color:rgba(255,255,255,0.42); transition:color .2s, padding-left .2s; }
.footer-col ul a:hover { color:#fff; padding-left:3px; }
.footer-bottom {
  padding-top:32px; border-top:1px solid rgba(255,255,255,0.06);
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px;
}
.footer-bottom p,.footer-legal a { font-size:.8125rem; color:rgba(255,255,255,0.22); }
.footer-legal { display:flex; gap:20px; }
.footer-legal a:hover { color:rgba(255,255,255,.6); }

/* ── COOKIE ── */
#cookieConsent {
  position:fixed; bottom:24px; left:24px; right:24px; max-width:480px;
  background:var(--bg-surface); border:1px solid var(--border-md);
  border-radius:var(--r-md); padding:20px 24px; z-index:9999;
  display:none; gap:16px; align-items:flex-start; box-shadow:var(--shadow-lg);
}
#cookieConsent.show { display:flex; }
#cookieConsent p { font-size:.8125rem; color:var(--text-2); line-height:1.6; flex:1; }
#cookieConsent p a { color:var(--teal); }
.cookie-btns { display:flex; gap:8px; flex-shrink:0; }
.cookie-btn {
  padding:8px 16px; border-radius:var(--r-sm); font-size:.8125rem;
  font-weight:700; cursor:pointer; border:none; font-family:'Figtree',sans-serif;
}
.cookie-accept  { background:var(--teal); color:#fff; }
.cookie-decline { background:var(--bg-raised); color:var(--text-2); border:1px solid var(--border); }

/* ── MOBILE MENU ── */
.mobile-menu {
  display:none; position:fixed; inset:0;
  background:rgba(13,28,46,0.98); backdrop-filter:blur(20px);
  z-index:999; padding:80px 40px 40px; flex-direction:column; gap:28px;
}
.mobile-menu.open { display:flex; }
.mobile-menu a { font-size:2rem; font-weight:700; color:#fff; border-bottom:1px solid rgba(255,255,255,0.08); padding-bottom:24px; }
.mobile-menu .btn { align-self:flex-start; margin-top:16px; }

/* ── SCROLL REVEAL ── */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .65s var(--ease),transform .65s var(--ease); }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ── REDUCED MOTION ── */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .bento{grid-template-columns:repeat(2,1fr)}
  .process-grid{grid-template-columns:repeat(2,1fr);gap:40px}.process-grid::before{display:none}
  .trust-grid{grid-template-columns:repeat(2,1fr)}.testi-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  section{padding:80px 24px} nav{padding:0 24px} .hero-content{padding:0 24px 60px}
  .hero-stats{gap:28px;flex-wrap:wrap} .nav-links{display:none} .nav-mobile-btn{display:block}
  .bento{grid-template-columns:1fr}  
  .video-grid{grid-template-columns:1fr} .video-cell.large{grid-column:span 1;aspect-ratio:16/9}
  .testi-grid{grid-template-columns:1fr} .trust-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr} .hero-slide-nav{display:none} .services-grid{grid-template-columns:1fr}
  .cta-actions{flex-direction:column;align-items:center} .footer-bottom{flex-direction:column;text-align:center}
}
