/* =============================================================
   FEUR — styles.css
   Archetype 05: Mouse-Reactive Gradient (Digital Agency)
   ============================================================= */

/* =============================================================
   1. Tokens
   ============================================================= */
:root {
  --bg:        #060608;
  --bg-2:      #0d0d12;
  --bg-card:   #111118;
  --ink:       #f0eeff;
  --ink-soft:  rgba(240,238,255,0.7);
  --ink-mute:  rgba(240,238,255,0.38);
  --accent:    #a855f7;
  --accent-2:  #06b6d4;
  --accent-3:  #f0abfc;
  --line:      rgba(240,238,255,0.08);
  --grad:      linear-gradient(135deg, #a855f7, #06b6d4);

  --sans:      'Inter', system-ui, sans-serif;
  --mono:      'JetBrains Mono', 'IBM Plex Mono', monospace;

  --ease-out:  cubic-bezier(0.16, 1, 0.3, 1);
  --ease-soft: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);

  --nav-h:     72px;
  --gutter:    clamp(1.25rem, 5vw, 4rem);
  --radius:    16px;
}

/* =============================================================
   2. Reset
   ============================================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; }
html {
  overflow-x: clip;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}
body {
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.6;
  background: var(--bg);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: clip;
  overscroll-behavior-y: none;
}
img, svg, video { display: block; max-width: 100%; }
img { height: auto; }
button { font: inherit; color: inherit; cursor: pointer; border: 0; background: none; }
a { color: inherit; text-decoration: none; }
p { text-wrap: pretty; }
h1,h2,h3,h4 { text-wrap: balance; line-height: 1.05; letter-spacing: -0.02em; }
::selection { background: var(--accent); color: #fff; }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 4px; }
.skip-link { position:fixed; top:-100px; left:1rem; padding:.6rem 1rem; background:var(--ink); color:var(--bg); z-index:9999; border-radius:8px; font-weight:500; transition: top .2s; }
.skip-link:focus { top:1rem; }

/* =============================================================
   3. Utilities
   ============================================================= */
.container { width:100%; max-width:1280px; margin-inline:auto; padding-inline:var(--gutter); }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }
.gradient-text { background: var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.tag {
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.3rem .75rem; border-radius:100px;
  border:1px solid var(--line);
  font-family:var(--mono); font-size:.72rem; color:var(--ink-mute);
  letter-spacing:.08em; text-transform:uppercase;
}

/* =============================================================
   4. Cursor
   ============================================================= */
.cursor-dot, .cursor-ring {
  position:fixed; top:0; left:0; pointer-events:none; z-index:9990;
  transform:translate3d(-100px,-100px,0);
  border-radius:50%; opacity:0; transition:opacity .3s var(--ease-out);
}
.cursor-dot  { width:6px; height:6px; background:var(--accent); }
.cursor-ring { width:36px; height:36px; border:1.5px solid rgba(168,85,247,.55); transition:transform .08s linear, opacity .3s; }
.cursor-dot.is-ready, .cursor-ring.is-ready { opacity:1; }
@media (hover:none) { .cursor-dot, .cursor-ring { display:none; } }

/* =============================================================
   5. Navigation
   ============================================================= */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  height:var(--nav-h);
  display:flex; align-items:center;
  padding-inline:var(--gutter);
  transition:background .4s var(--ease-soft), backdrop-filter .4s;
}
.nav.is-scrolled {
  background:rgba(6,6,8,.85);
  backdrop-filter:blur(20px) saturate(150%);
  border-bottom:1px solid var(--line);
}
.nav-inner {
  width:100%; max-width:1280px; margin-inline:auto;
  display:flex; align-items:center; justify-content:space-between;
}
.nav-logo {
  font-family:var(--mono); font-size:1.4rem; font-weight:700;
  letter-spacing:.12em; color:var(--ink);
  background: var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.nav-links { display:flex; align-items:center; gap:2rem; }
.nav-links a {
  font-size:.875rem; color:var(--ink-soft); letter-spacing:.02em;
  position:relative; transition:color .25s var(--ease-out);
}
.nav-links a::after {
  content:''; position:absolute; bottom:-2px; left:0; width:0; height:1px;
  background:var(--accent); transition:width .3s var(--ease-out);
}
.nav-links a:hover, .nav-links a.active { color:var(--ink); }
.nav-links a:hover::after, .nav-links a.active::after { width:100%; }
.nav-cta {
  padding:.55rem 1.4rem; border-radius:100px;
  background:var(--grad); color:#fff !important; font-size:.875rem; font-weight:600;
  transition:opacity .25s, transform .25s var(--ease-bounce);
}
.nav-cta:hover { opacity:.9; transform:scale(1.04); }
.nav-cta::after { display:none !important; }
.nav-burger { display:none; flex-direction:column; gap:5px; padding:.5rem; cursor:pointer; }
.nav-burger span { display:block; width:22px; height:2px; background:var(--ink); border-radius:2px; transition:transform .3s, opacity .3s; }
.nav-mobile { display:none; }

/* =============================================================
   6. Mouse-Reactive Gradient (Hero BG)
   ============================================================= */
.hero-gradient {
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(circle 700px at var(--mx,30%) var(--my,40%), rgba(168,85,247,.18) 0%, transparent 70%),
    radial-gradient(circle 600px at calc(var(--mx,30%) + 25%) calc(var(--my,40%) + 20%), rgba(6,182,212,.14) 0%, transparent 60%),
    radial-gradient(ellipse 800px 600px at 80% 80%, rgba(168,85,247,.07) 0%, transparent 70%);
  filter:blur(30px);
  transition:background .15s linear;
}
.hero-grain {
  position:absolute; inset:0; z-index:1; pointer-events:none; opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

/* =============================================================
   7. Hero
   ============================================================= */
.hero {
  position:relative; overflow:hidden;
  min-height:100vh; min-height:100svh;
  display:flex; align-items:center; justify-content:center;
  text-align:center; padding-block:calc(var(--nav-h) + 4rem) 5rem;
}
.hero-content { position:relative; z-index:2; max-width:900px; margin-inline:auto; padding-inline:var(--gutter); }
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:var(--mono); font-size:.72rem; color:var(--ink-mute); letter-spacing:.12em; text-transform:uppercase;
  margin-bottom:2rem; opacity:0; transform:translateY(20px);
  animation:fadeUp .8s var(--ease-out) .3s forwards;
}
.hero-eyebrow-dot { width:6px; height:6px; border-radius:50%; background:var(--accent); display:inline-block; animation:pulse 2s infinite; }
.hero-title {
  font-size:clamp(3rem, 9vw, 8rem); font-weight:800; line-height:.96;
  letter-spacing:-.04em; margin-bottom:1.5rem;
  opacity:0; transform:translateY(30px);
  animation:fadeUp .9s var(--ease-out) .5s forwards;
}
.hero-title em { font-style:normal; }
.hero-subtitle {
  font-size:clamp(1rem, 2.2vw, 1.3rem); color:var(--ink-soft); max-width:560px; margin-inline:auto;
  line-height:1.7; margin-bottom:3rem;
  opacity:0; transform:translateY(20px);
  animation:fadeUp .8s var(--ease-out) .75s forwards;
}
.hero-actions {
  display:flex; gap:1rem; justify-content:center; flex-wrap:wrap;
  opacity:0; transform:translateY(20px);
  animation:fadeUp .8s var(--ease-out) .95s forwards;
}
.btn {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.8rem 2rem; border-radius:100px;
  font-size:.9rem; font-weight:600; letter-spacing:.01em;
  transition:transform .25s var(--ease-bounce), opacity .25s;
  cursor:pointer;
}
.btn:hover { transform:scale(1.05); }
.btn-primary { background:var(--grad); color:#fff; }
.btn-ghost { border:1.5px solid var(--line); color:var(--ink-soft); background:transparent; }
.btn-ghost:hover { border-color:var(--accent); color:var(--ink); }
.hero-scroll {
  position:absolute; bottom:2.5rem; left:50%; transform:translateX(-50%);
  font-family:var(--mono); font-size:.65rem; color:var(--ink-mute); letter-spacing:.1em;
  display:flex; flex-direction:column; align-items:center; gap:.6rem;
  opacity:0; animation:fadeUp .6s var(--ease-out) 1.4s forwards;
}
.hero-scroll-line { width:1px; height:40px; background:linear-gradient(to bottom, var(--accent), transparent); animation:scrollLine 2s ease-in-out infinite; }

/* =============================================================
   8. Section base
   ============================================================= */
section { padding-block:clamp(4rem, 10vw, 8rem); }
.section-label { font-family:var(--mono); font-size:.7rem; color:var(--accent); letter-spacing:.12em; text-transform:uppercase; margin-bottom:1rem; }
.section-title { font-size:clamp(2rem, 5vw, 3.8rem); font-weight:800; line-height:1.05; margin-bottom:1.2rem; }
.section-sub { font-size:clamp(.95rem, 1.8vw, 1.15rem); color:var(--ink-soft); max-width:600px; line-height:1.75; }

/* =============================================================
   9. Reveal animations
   ============================================================= */
.reveal { opacity:0; transform:translateY(40px); transition:opacity .8s var(--ease-out), transform .8s var(--ease-out); }
.reveal.is-visible { opacity:1; transform:none; }
.reveal[data-split] { opacity:1; transform:none; }
.reveal-delay-1 { transition-delay:.1s; }
.reveal-delay-2 { transition-delay:.2s; }
.reveal-delay-3 { transition-delay:.3s; }
.reveal-delay-4 { transition-delay:.4s; }

/* =============================================================
   10. Marquee ticker
   ============================================================= */
.marquee-wrap { overflow:hidden; padding-block:1.5rem; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.marquee-track { display:flex; gap:2rem; width:max-content; animation:marquee 28s linear infinite; }
.marquee-item { font-family:var(--mono); font-size:.75rem; color:var(--ink-mute); letter-spacing:.1em; text-transform:uppercase; white-space:nowrap; display:flex; align-items:center; gap:1.5rem; }
.marquee-item::after { content:"✦"; color:var(--accent); font-size:.6rem; }

/* =============================================================
   11. About / Manifesto
   ============================================================= */
.about { background:var(--bg); }
.about-grid { display:grid; grid-template-columns:1fr; gap:4rem; align-items:start; }
.about-big-text {
  font-size:clamp(1.6rem, 3.5vw, 2.6rem); font-weight:700; line-height:1.25;
  letter-spacing:-.02em; color:var(--ink);
}
.about-big-text span { color:var(--ink-mute); }
.about-big-text em { font-style:normal; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.about-pillars { display:grid; grid-template-columns:1fr; gap:1.5rem; }
.pillar { padding:1.5rem; border:1px solid var(--line); border-radius:var(--radius); background:var(--bg-card); transition:border-color .3s, transform .3s var(--ease-out); }
.pillar:hover { border-color:rgba(168,85,247,.4); transform:translateY(-3px); }
.pillar-num { font-family:var(--mono); font-size:.7rem; color:var(--accent); letter-spacing:.1em; margin-bottom:.75rem; }
.pillar h3 { font-size:1rem; font-weight:700; margin-bottom:.4rem; }
.pillar p { font-size:.875rem; color:var(--ink-soft); line-height:1.65; }

/* =============================================================
   12. Services grid
   ============================================================= */
.services-grid { display:grid; grid-template-columns:1fr; gap:1.5rem; margin-top:3.5rem; }
.service-card {
  padding:2rem; border:1px solid var(--line); border-radius:var(--radius);
  background:var(--bg-card); cursor:default; position:relative; overflow:hidden;
  transition:border-color .3s var(--ease-out), transform .35s var(--ease-out), background .3s;
}
.service-card::before {
  content:''; position:absolute; inset:0; border-radius:var(--radius);
  background:radial-gradient(circle 200px at var(--cx,50%) var(--cy,50%), rgba(168,85,247,.12), transparent 70%);
  opacity:0; transition:opacity .3s;
}
.service-card:hover::before { opacity:1; }
.service-card:hover { border-color:rgba(168,85,247,.35); transform:translateY(-4px); }
.service-icon { font-size:2rem; margin-bottom:1.25rem; display:block; }
.service-title { font-size:1.1rem; font-weight:700; margin-bottom:.6rem; }
.service-desc { font-size:.875rem; color:var(--ink-soft); line-height:1.65; }

/* =============================================================
   13. Methodology steps
   ============================================================= */
.methodology { background:var(--bg-2); }
.methodology-list { margin-top:3rem; }
.method-step {
  display:grid; grid-template-columns:auto 1fr; gap:1.5rem;
  padding-block:2rem; border-bottom:1px solid var(--line);
  transition:padding-left .3s var(--ease-out);
  cursor:default;
}
.method-step:hover { padding-left:.75rem; }
.method-num { font-family:var(--mono); font-size:2.5rem; font-weight:800; color:var(--line); letter-spacing:-.04em; min-width:3.5rem; line-height:1; transition:color .3s; }
.method-step:hover .method-num { color:var(--accent); }
.method-content h3 { font-size:1.15rem; font-weight:700; margin-bottom:.5rem; }
.method-content p { font-size:.9rem; color:var(--ink-soft); line-height:1.65; }

/* =============================================================
   14. Stats
   ============================================================= */
.stats { background:var(--bg); }
.stats-grid { display:grid; grid-template-columns:1fr 1fr; gap:2rem; margin-top:3rem; }
.stat-item { text-align:center; }
.stat-value {
  font-size:clamp(2.5rem, 8vw, 5rem); font-weight:800; letter-spacing:-.04em; display:block;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.stat-label { font-size:.8rem; color:var(--ink-mute); font-family:var(--mono); letter-spacing:.06em; text-transform:uppercase; margin-top:.4rem; display:block; }

/* =============================================================
   15. Clients / Industries marquee
   ============================================================= */
.clients { background:var(--bg-2); }

/* =============================================================
   16. Video cards
   ============================================================= */
.video-grid { display:grid; grid-template-columns:1fr; gap:1.5rem; margin-top:3rem; }
.video-card {
  position:relative; border-radius:var(--radius); overflow:hidden;
  aspect-ratio:16/10; cursor:pointer;
  border:1px solid var(--line); background:var(--bg-card);
  transition:transform .4s var(--ease-out), border-color .3s;
}
.video-card:hover { transform:scale(1.02); border-color:rgba(168,85,247,.4); }
.video-card img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease-soft); }
.video-card:hover img { transform:scale(1.08); }
.video-overlay {
  position:absolute; inset:0; background:linear-gradient(to top, rgba(6,6,8,.9) 0%, rgba(6,6,8,.2) 60%, transparent 100%);
  display:flex; flex-direction:column; justify-content:flex-end; padding:1.5rem;
  transition:background .3s;
}
.video-play {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%) scale(0.8);
  width:56px; height:56px; border-radius:50%;
  background:rgba(168,85,247,.9); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .3s, transform .3s var(--ease-bounce);
}
.video-card:hover .video-play { opacity:1; transform:translate(-50%,-50%) scale(1); }
.video-play svg { width:20px; height:20px; fill:#fff; margin-left:3px; }
.video-cat { font-family:var(--mono); font-size:.65rem; color:var(--accent); letter-spacing:.1em; text-transform:uppercase; margin-bottom:.4rem; }
.video-title { font-size:1rem; font-weight:700; color:#fff; }

/* =============================================================
   17. Pricing / Plans
   ============================================================= */
.plans-grid { display:grid; grid-template-columns:1fr; gap:1.5rem; margin-top:3.5rem; }
.plan-card {
  padding:2.5rem; border:1px solid var(--line); border-radius:var(--radius);
  background:var(--bg-card); position:relative; overflow:hidden;
  transition:transform .35s var(--ease-out), border-color .3s;
}
.plan-card:hover { transform:translateY(-6px); }
.plan-card.featured { border-color:rgba(168,85,247,.5); background:rgba(168,85,247,.07); }
.plan-featured-badge {
  position:absolute; top:1.25rem; right:1.25rem;
  padding:.25rem .75rem; border-radius:100px; background:var(--grad);
  font-size:.65rem; font-weight:700; color:#fff; letter-spacing:.06em; text-transform:uppercase;
}
.plan-name { font-size:1.15rem; font-weight:700; margin-bottom:.5rem; }
.plan-videos { font-family:var(--mono); font-size:.75rem; color:var(--accent); letter-spacing:.08em; text-transform:uppercase; margin-bottom:1.5rem; }
.plan-price { display:flex; align-items:baseline; gap:.5rem; margin-bottom:1.25rem; }
.plan-price-num { font-size:clamp(2.2rem, 7vw, 3.5rem); font-weight:800; letter-spacing:-.04em; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.plan-currency { font-size:1rem; color:var(--ink-mute); font-family:var(--mono); }
.plan-desc { font-size:.875rem; color:var(--ink-soft); line-height:1.65; margin-bottom:2rem; }
.plan-cta { display:block; text-align:center; padding:.8rem; border-radius:100px; font-weight:600; font-size:.875rem; transition:transform .25s var(--ease-bounce), opacity .25s; }
.plan-cta:hover { transform:scale(1.04); opacity:.9; }
.plan-card.featured .plan-cta { background:var(--grad); color:#fff; }
.plan-card:not(.featured) .plan-cta { border:1.5px solid var(--line); color:var(--ink-soft); }
.plan-card:not(.featured) .plan-cta:hover { border-color:var(--accent); color:var(--ink); }
.plan-halo {
  position:absolute; inset:-60% -20%; border-radius:50%;
  background:radial-gradient(circle, rgba(168,85,247,.15), transparent 70%);
  filter:blur(60px); pointer-events:none;
}

/* =============================================================
   18. CTA section
   ============================================================= */
.cta-section {
  text-align:center; padding-block:clamp(5rem,12vw,10rem);
  position:relative; overflow:hidden;
}
.cta-bg {
  position:absolute; inset:-50% -20%; border-radius:50%;
  background:radial-gradient(ellipse, rgba(168,85,247,.15) 0%, rgba(6,182,212,.1) 50%, transparent 70%);
  filter:blur(80px); pointer-events:none;
}
.cta-title { font-size:clamp(2.2rem, 6vw, 5rem); font-weight:800; letter-spacing:-.04em; margin-bottom:1.5rem; }
.cta-sub { font-size:clamp(.95rem, 2vw, 1.2rem); color:var(--ink-soft); max-width:520px; margin-inline:auto; margin-bottom:2.5rem; line-height:1.75; }
.btn-whatsapp {
  display:inline-flex; align-items:center; gap:.75rem;
  padding:1rem 2.5rem; border-radius:100px; font-size:1rem; font-weight:700;
  background:linear-gradient(135deg, #25d366, #128c7e); color:#fff;
  transition:transform .25s var(--ease-bounce), box-shadow .25s;
  box-shadow:0 8px 32px rgba(37,211,102,.25);
}
.btn-whatsapp:hover { transform:scale(1.06); box-shadow:0 12px 40px rgba(37,211,102,.35); }
.btn-whatsapp svg { width:22px; height:22px; fill:#fff; }

/* =============================================================
   19. Footer
   ============================================================= */
.footer {
  border-top:1px solid var(--line); padding-block:3rem;
  background:var(--bg);
}
.footer-inner { display:flex; flex-direction:column; gap:2rem; }
.footer-brand { font-family:var(--mono); font-size:1.2rem; font-weight:700; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; letter-spacing:.1em; }
.footer-tagline { font-size:.875rem; color:var(--ink-mute); margin-top:.35rem; }
.footer-links { display:flex; flex-wrap:wrap; gap:1.5rem; }
.footer-links a { font-size:.875rem; color:var(--ink-soft); transition:color .25s; }
.footer-links a:hover { color:var(--ink); }
.footer-copy { font-family:var(--mono); font-size:.7rem; color:var(--ink-mute); letter-spacing:.05em; }
.footer-credits { font-size:.7rem; color:var(--ink-mute); margin-top:.25rem; }

/* =============================================================
   20. Page hero (inner pages)
   ============================================================= */
.page-hero {
  padding-top:calc(var(--nav-h) + 5rem); padding-bottom:4rem;
  text-align:center; position:relative; overflow:hidden;
}
.page-hero-title { font-size:clamp(2.5rem, 7vw, 6rem); font-weight:800; letter-spacing:-.04em; margin-bottom:1rem; }
.page-hero-sub { font-size:clamp(.95rem, 2vw, 1.2rem); color:var(--ink-soft); max-width:540px; margin-inline:auto; line-height:1.75; }

/* =============================================================
   21. FAQ accordion
   ============================================================= */
.faq-list { margin-top:3rem; }
.faq-item { border-bottom:1px solid var(--line); }
.faq-q {
  width:100%; text-align:left; padding:1.5rem 0;
  font-size:1rem; font-weight:600; display:flex; justify-content:space-between; align-items:center; gap:1rem;
  cursor:pointer; transition:color .25s;
}
.faq-q:hover { color:var(--accent); }
.faq-icon { font-size:1.2rem; color:var(--accent); transition:transform .3s var(--ease-out); flex-shrink:0; }
.faq-item.open .faq-icon { transform:rotate(45deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .4s var(--ease-soft); }
.faq-a p { padding-bottom:1.5rem; font-size:.9rem; color:var(--ink-soft); line-height:1.75; }

/* =============================================================
   22. What we DON'T do
   ============================================================= */
.no-list { margin-top:2rem; display:flex; flex-direction:column; gap:.75rem; }
.no-item { display:flex; align-items:center; gap:.75rem; font-size:.9rem; color:var(--ink-soft); }
.no-item::before { content:'✗'; color:var(--accent); font-weight:700; flex-shrink:0; }

/* =============================================================
   23. Keyframes
   ============================================================= */
@keyframes fadeUp {
  to { opacity:1; transform:none; }
}
@keyframes pulse {
  0%,100% { box-shadow:0 0 0 0 rgba(168,85,247,.4); }
  50%      { box-shadow:0 0 0 6px rgba(168,85,247,0); }
}
@keyframes marquee {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}
@keyframes scrollLine {
  0%,100% { opacity:1; transform:scaleY(1); transform-origin:top; }
  50%      { opacity:.3; transform:scaleY(.5); transform-origin:top; }
}
@keyframes floatY {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-12px); }
}

/* =============================================================
   24. Responsive — Tablet+
   ============================================================= */
@media (min-width: 720px) {
  .about-grid { grid-template-columns:1fr 1fr; }
  .about-pillars { grid-template-columns:1fr 1fr; }
  .services-grid { grid-template-columns:1fr 1fr; }
  .video-grid { grid-template-columns:1fr 1fr; }
  .plans-grid { grid-template-columns:1fr 1fr 1fr; }
  .stats-grid { grid-template-columns:repeat(4,1fr); }
  .footer-inner { flex-direction:row; justify-content:space-between; align-items:flex-end; }
}

@media (min-width: 960px) {
  .nav-links { gap:2.5rem; }
  .services-grid { grid-template-columns:repeat(3,1fr); }
  .video-grid { grid-template-columns:repeat(3,1fr); }
}

@media (max-width: 719px) {
  .nav-links { display:none; }
  .nav-burger { display:flex; }
  .nav-mobile {
    display:flex; flex-direction:column; gap:1.25rem;
    position:fixed; inset:0; top:var(--nav-h);
    background:rgba(6,6,8,.97); backdrop-filter:blur(20px);
    padding:2.5rem var(--gutter);
    transform:translateY(-100%); opacity:0;
    transition:transform .4s var(--ease-out), opacity .4s;
    pointer-events:none; z-index:99;
  }
  .nav-mobile.is-open { transform:translateY(0); opacity:1; pointer-events:all; }
  .nav-mobile a { font-size:1.5rem; font-weight:700; color:var(--ink); padding:.5rem 0; border-bottom:1px solid var(--line); }
  .nav-mobile .nav-cta { background:var(--grad); text-align:center; border-radius:100px; border:none; }
  .stats-grid { grid-template-columns:1fr 1fr; }
}

/* =============================================================
   25. Reduced motion — only intrusive effects
   ============================================================= */
@media (prefers-reduced-motion: reduce) {
  .marquee-track { animation:none; }
  .hero-scroll-line { animation:none; }
  .hero-eyebrow, .hero-title, .hero-subtitle, .hero-actions, .hero-scroll { animation:none; opacity:1; transform:none; }
}
