/* =========================================================
   FILSEVEN — Group site (dark + lime, Geist + Instrument Serif)
   v2: Apple-style depth, glass, scroll motion, aurora.
   ========================================================= */

:root{
  --bg:#070707;
  --bg-2:#0e0e0e;
  --bg-3:#151515;
  --panel:#1a1a1a;
  --panel-2:#222222;
  --line:#2a2a2a;
  --line-2:#3a3a3a;
  --ink:#f5f5f3;
  --ink-2:#c8c8c4;
  --ink-3:#8e8e8a;

  --accent:#e0b66e;
  --accent-2:#f4d49b;
  --accent-ink:#0a0a0a;
  --accent-rgb:224,182,110;

  --warn:#ff7a45;
  --radius:18px;
  --radius-sm:10px;
  --maxw:1240px;

  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --ease-in-out:cubic-bezier(0.65,0,0.35,1);
}

body[data-theme="international"]{ --accent:#e0b66e; --accent-2:#f4d49b; --accent-rgb:224,182,110; }
body[data-theme="investments"]  { --accent:#34d6a8; --accent-2:#84f0ce; --accent-rgb:52,214,168; }
body[data-theme="tech"]         { --accent:#8ab4ff; --accent-2:#c0d6ff; --accent-rgb:138,180,255; }
body[data-theme="real-estate"]  { --accent:#e59a6e; --accent-2:#f6c19a; --accent-rgb:229,154,110; }
body[data-theme="energy"]       { --accent:#4de3b5; --accent-2:#93f2d1; --accent-rgb:77,227,181; }

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:"Geist",ui-sans-serif,system-ui,sans-serif;-webkit-font-smoothing:antialiased;font-feature-settings:"ss01","cv11";max-width:100%;overflow-x:hidden;overflow-x:clip}
html{scroll-behavior:smooth}
body{background:var(--bg);min-height:100vh;position:relative}

/* Aurora — fixed full-screen background that drifts behind content */
.aurora{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.aurora::before,.aurora::after{
  content:"";position:absolute;border-radius:50%;filter:blur(120px);opacity:0.55;will-change:transform;
}
.aurora::before{
  width:60vw;height:60vw;left:-15vw;top:-20vw;
  background:radial-gradient(circle, rgba(var(--accent-rgb),0.32), transparent 60%);
  animation:auroraA 28s var(--ease-in-out) infinite alternate;
}
.aurora::after{
  width:55vw;height:55vw;right:-10vw;top:30vh;
  background:radial-gradient(circle, rgba(120,90,255,0.25), transparent 60%);
  animation:auroraB 34s var(--ease-in-out) infinite alternate;
}
.aurora .blob3{
  position:absolute;width:40vw;height:40vw;left:30vw;top:60vh;
  background:radial-gradient(circle, rgba(255,150,80,0.18), transparent 60%);
  filter:blur(120px);border-radius:50%;
  animation:auroraC 40s var(--ease-in-out) infinite alternate;
}
@keyframes auroraA{from{transform:translate(0,0) scale(1)}to{transform:translate(20vw,15vh) scale(1.2)}}
@keyframes auroraB{from{transform:translate(0,0) scale(1)}to{transform:translate(-15vw,-10vh) scale(1.15)}}
@keyframes auroraC{from{transform:translate(0,0) scale(1)}to{transform:translate(-20vw,-25vh) scale(1.3)}}

/* film grain overlay */
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:0.06;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.6'/></svg>");
}

/* ensure content sits above aurora */
.nav-wrap, section, footer, .hero{position:relative;z-index:2}

a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
.mono{font-family:"Geist Mono",ui-monospace,monospace;font-weight:500;letter-spacing:-0.01em}
.serif,.it{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400}
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative}
.eyebrow{font-family:"Geist Mono",monospace;font-size:11px;text-transform:uppercase;letter-spacing:0.14em;color:var(--ink-3);display:inline-flex;align-items:center}
.eyebrow .dot{display:inline-block;width:6px;height:6px;border-radius:99px;background:var(--accent);margin-right:8px;vertical-align:1px;box-shadow:0 0 14px rgba(var(--accent-rgb),0.55);animation:dotPulse 2.4s ease-in-out infinite}
@keyframes dotPulse{0%,100%{box-shadow:0 0 14px rgba(var(--accent-rgb),0.55)}50%{box-shadow:0 0 22px rgba(var(--accent-rgb),0.85)}}

/* ---------- LOADING INTRO ---------- */
.intro{position:fixed;inset:0;z-index:9999;background:#000;display:grid;place-items:center;transition:opacity .9s var(--ease-out), visibility .9s}
.intro.gone{opacity:0;visibility:hidden}
.intro-mark{
  width:88px;height:88px;border-radius:24px;
  background:conic-gradient(from 220deg,var(--accent),var(--accent-2),var(--accent));
  position:relative;
  box-shadow:0 0 80px rgba(var(--accent-rgb),0.4), inset 0 0 0 1px rgba(0,0,0,0.5);
  animation:introSpin 2s var(--ease-in-out) infinite;
}
.intro-mark::after{content:"";position:absolute;inset:18px;background:#000;border-radius:8px}
.intro-text{
  position:absolute;bottom:14vh;left:0;right:0;text-align:center;
  font-family:"Geist Mono",monospace;font-size:11px;letter-spacing:0.3em;color:#666;text-transform:uppercase;
}
.intro-bar{
  position:absolute;bottom:11vh;left:50%;transform:translateX(-50%);
  width:160px;height:1px;background:#222;overflow:hidden;
}
.intro-bar i{display:block;height:100%;background:var(--accent);width:0;animation:introBar 1.6s var(--ease-out) forwards}
@keyframes introSpin{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(0.9)}100%{transform:rotate(360deg) scale(1)}}
@keyframes introBar{to{width:100%}}

/* ---------- NAV (glass, sticky / follows the page) ---------- */
.nav-wrap{
  position:-webkit-sticky;position:sticky;top:14px;
  z-index:50;padding:14px 0;
  transition:padding .3s var(--ease-out);
  will-change:padding;
}
.nav-wrap.scrolled{padding:8px 0}
.nav{
  max-width:var(--maxw);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px 10px 18px;
  border:1px solid rgba(224,182,110,0.22);
  background:rgba(18,18,18,0.78);
  backdrop-filter:blur(22px) saturate(180%);
  -webkit-backdrop-filter:blur(22px) saturate(180%);
  border-radius:99px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    inset 0 -1px 0 rgba(0,0,0,0.4),
    0 22px 60px -22px rgba(0,0,0,0.85),
    0 0 40px -18px rgba(224,182,110,0.25);
  transition:all .3s var(--ease-out);
}
.nav-wrap.scrolled .nav{
  background:rgba(14,14,14,0.85);
  border-color:rgba(224,182,110,0.32);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 18px 50px -18px rgba(0,0,0,0.9),
    0 0 50px -18px rgba(224,182,110,0.3);
}
.brand{display:inline-flex;align-items:center;gap:0;line-height:1;margin:-22px 0}
/* FILSEVEN GROUP brand mark — uses the actual logo PNG at assets/logo.png */
.brand-logo{
  height:100px;width:auto;display:block;
  filter:drop-shadow(0 0 22px rgba(220,176,97,0.35));
  transition:filter .3s var(--ease-out), transform .3s var(--ease-out);
}
.brand:hover .brand-logo{
  filter:drop-shadow(0 0 30px rgba(240,207,138,0.6));
  transform:translateY(-1px);
}
/* Footer logo bigger still */
.foot-brand .brand{margin:-4px 0}
.foot-brand .brand-logo{height:112px}

/* Tablet */
@media (max-width:860px){
  .brand{margin:-18px 0}
  .brand-logo{height:84px}
}

/* Mobile sizing */
@media (max-width:600px){
  .brand{margin:-14px 0}
  .brand-logo{height:72px}
  .foot-brand .brand-logo{height:84px}
}
@media (max-width:380px){
  .brand{margin:-12px 0}
  .brand-logo{height:60px}
}
.nav ul{display:flex;list-style:none;gap:6px;margin:0;padding:0;font-size:14px;color:var(--ink-2)}
.nav ul a{padding:8px 14px;border-radius:99px;transition:all .15s ease;display:inline-flex;align-items:center;gap:6px;position:relative}
.nav ul a:hover{color:var(--ink);background:rgba(255,255,255,0.04)}
.nav ul a.is-current{color:var(--accent);background:rgba(var(--accent-rgb),0.08)}
.nav-cta{display:flex;align-items:center;gap:8px}

/* Language switcher pill (EN / PT / ES) */
.lang-switch{
  display:inline-flex;align-items:center;gap:2px;
  padding:3px;
  background:rgba(20,20,20,0.65);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:99px;
  font-family:"Geist Mono",monospace;
}
.lang-btn{
  padding:5px 9px;border-radius:99px;
  background:transparent;border:0;cursor:pointer;
  color:var(--ink-3);font:inherit;font-size:10.5px;font-weight:500;
  letter-spacing:0.08em;text-transform:uppercase;
  transition:color .2s ease, background .2s ease;
}
.lang-btn:hover{color:var(--ink)}
.lang-btn.active{
  color:var(--accent-ink);
  background:linear-gradient(170deg,#f5d699,#dcb061);
}

/* mobile hamburger toggle — premium pill button (hidden on desktop) */
.nav-toggle{
  display:none;width:46px;height:46px;border-radius:14px;
  background:rgba(20,20,20,0.7);backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,0.1);
  align-items:center;justify-content:center;cursor:pointer;
  flex-shrink:0;padding:0;color:var(--ink);
  transition:all .3s var(--ease-out);
  position:relative;z-index:60;
}
.nav-toggle:hover{
  border-color:rgba(var(--accent-rgb),0.5);
  background:rgba(var(--accent-rgb),0.08);
  transform:translateY(-1px);
}
.nav-toggle span{
  width:18px;height:2px;background:var(--ink);position:relative;display:block;
  border-radius:2px;
  transition:background .3s var(--ease-out);
}
.nav-toggle span::before,.nav-toggle span::after{
  content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink);
  border-radius:2px;
  transition:transform .35s var(--ease-out), background .3s var(--ease-out);
}
.nav-toggle span::before{top:-6px}
.nav-toggle span::after{top:6px}
body.nav-open .nav-toggle{
  background:rgba(var(--accent-rgb),0.12);
  border-color:rgba(var(--accent-rgb),0.55);
}
body.nav-open .nav-toggle span{background:transparent}
body.nav-open .nav-toggle span::before{transform:translateY(6px) rotate(45deg);background:#d4a24c}
body.nav-open .nav-toggle span::after{transform:translateY(-6px) rotate(-45deg);background:#d4a24c}

.btn{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 16px;border-radius:99px;font-size:14px;font-weight:500;border:1px solid transparent;cursor:pointer;transition:all .2s var(--ease-out);white-space:nowrap;position:relative;overflow:hidden}
.btn-ghost{color:var(--ink-2);background:transparent}
.btn-ghost:hover{color:var(--ink)}
.btn-line{color:var(--ink);border-color:rgba(255,255,255,0.1);background:rgba(255,255,255,0.03);backdrop-filter:blur(10px)}
.btn-line:hover{border-color:rgba(255,255,255,0.18);background:rgba(255,255,255,0.06);transform:translateY(-1px)}
.btn-primary{background:var(--accent);color:var(--accent-ink);font-weight:600;box-shadow:0 0 0 0 rgba(var(--accent-rgb),0.45), 0 8px 24px -8px rgba(var(--accent-rgb),0.6)}
.btn-primary:hover{background:var(--accent-2);box-shadow:0 0 0 6px rgba(var(--accent-rgb),0.18), 0 12px 32px -8px rgba(var(--accent-rgb),0.7);transform:translateY(-1px)}
.btn-primary .arrow{display:inline-block;transition:transform .2s ease}
.btn-primary:hover .arrow{transform:translateX(3px)}
.btn-lg{height:48px;padding:0 24px;font-size:15px}

/* magnetic-button shell */
.magnetic{display:inline-block;will-change:transform;transition:transform .3s var(--ease-out)}

/* ---------- HERO (homepage) ---------- */
.hero{padding:60px 0 40px;position:relative;min-height:90vh;display:flex;align-items:center}
.hero-grid{
  position:absolute;inset:0;pointer-events:none;opacity:.3;z-index:1;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 800px 500px at 50% 30%, #000, transparent 70%);
}
.hero-stage{position:relative;width:100%;display:grid;grid-template-columns:1fr;gap:0;z-index:2}
.hero-globe{
  position:absolute;inset:0;z-index:1;pointer-events:none;
}
.hero-globe canvas{display:block;width:100%;height:100%}
.hero-inner{position:relative;text-align:center;max-width:980px;margin:0 auto;z-index:3}
.pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:6px 6px 6px 14px;border:1px solid rgba(255,255,255,0.08);
  border-radius:99px;font-size:12.5px;color:var(--ink-2);
  background:rgba(20,20,20,0.6);backdrop-filter:blur(10px);
}
.pill .tag{
  background:var(--accent);color:var(--accent-ink);
  font-weight:600;font-size:11px;
  padding:2px 8px;border-radius:99px;
  letter-spacing:0.02em;
}
.pill .arrow{font-size:11px;color:var(--ink-3)}
h1.display{
  font-size:clamp(48px,8.5vw,128px);
  line-height:1.1;letter-spacing:-0.05em;font-weight:600;
  margin:24px 0 0;
  text-wrap:balance;overflow-wrap:break-word;
}
h1.display .accent{
  display:inline;
  -webkit-box-decoration-break:clone;box-decoration-break:clone;
  background:linear-gradient(180deg, var(--accent) 0%, var(--accent-2) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 40px rgba(var(--accent-rgb),0.4));
  padding:0.04em 0.06em 0.18em 0;
  line-height:1.25;
}
h1.display .it{
  font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;
  color:var(--accent);
  padding:0 0.04em 0 0;
}
.hero-sub{
  font-size:20px;color:var(--ink-2);line-height:1.5;
  max-width:640px;margin:28px auto 0;text-wrap:pretty;
}
.hero-cta{margin-top:40px;display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.hero-meta{
  margin-top:32px;display:flex;justify-content:center;gap:28px;flex-wrap:wrap;
  font-size:13px;color:var(--ink-3)
}
.hero-meta span{display:inline-flex;align-items:center;gap:8px}
.hero-meta .check{width:14px;height:14px;border-radius:99px;background:var(--accent);display:inline-grid;place-items:center;color:#0a0a0a;font-size:9px;font-weight:700}

/* sub-page hero */
.sub-hero{padding:60px 0 40px;position:relative;min-height:60vh;display:flex;align-items:center}
.sub-hero .container{position:relative;width:100%}
.sub-hero-bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;
}
.sub-hero-bg::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 50% 50%, rgba(var(--accent-rgb),0.15), transparent 70%);
  filter:blur(60px);
}
.breadcrumb{font-family:"Geist Mono",monospace;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-3);display:flex;gap:8px;align-items:center;margin-bottom:24px}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .sep{opacity:0.5}
.sub-hero h1{
  font-size:clamp(44px,7vw,96px);
  line-height:1.1;letter-spacing:-0.045em;font-weight:600;
  margin:0;max-width:20ch;text-wrap:balance;overflow-wrap:break-word;
}
.sub-hero h1 .accent{
  display:inline;
  -webkit-box-decoration-break:clone;box-decoration-break:clone;
  background:linear-gradient(180deg, var(--accent) 0%, var(--accent-2) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  padding:0.04em 0.06em 0.18em 0;
  line-height:1.25;
}
.sub-hero .lead{font-size:20px;color:var(--ink-2);line-height:1.5;max-width:600px;margin:28px 0 0;text-wrap:pretty}
.sub-hero .actions{margin-top:36px;display:flex;gap:12px;flex-wrap:wrap}

/* sub-page hero with 3D companion */
.sub-hero-with-art{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
.sub-hero-art{position:relative;aspect-ratio:1;max-width:480px;margin-left:auto}
.sub-hero-art [data-orb]{position:absolute;inset:0;border-radius:24px;overflow:hidden;display:block;width:100%;height:100%}
.sub-hero-art canvas{display:block;width:100%;height:100%;border-radius:24px}

/* ---------- TICKER ---------- */
.ticker{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:rgba(10,10,10,0.6);backdrop-filter:blur(10px);
  overflow:hidden;padding:14px 0;position:relative;
}
.ticker::before,.ticker::after{
  content:"";position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none;
}
.ticker::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.ticker::after{right:0;background:linear-gradient(-90deg,var(--bg),transparent)}
.ticker-track{display:flex;gap:40px;white-space:nowrap;animation:tickerScroll 60s linear infinite;will-change:transform}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-item{display:inline-flex;align-items:center;gap:10px;font-family:"Geist Mono",monospace;font-size:12px;color:var(--ink-2);letter-spacing:0.04em}
.ticker-item .sym{color:var(--ink-3);font-weight:500}
.ticker-item .val{color:var(--ink);font-weight:600}
.ticker-item .chg.up{color:#4de3b5}
.ticker-item .chg.dn{color:#ff7a45}
.ticker-item .sep{width:4px;height:4px;border-radius:99px;background:var(--ink-3);opacity:0.5}
@keyframes tickerScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- SECTION ---------- */
section{padding:120px 0;position:relative}
.sec-head{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:60px}
.sec-head h2{
  font-size:clamp(40px,5.2vw,72px);line-height:1.18;letter-spacing:-0.04em;font-weight:600;margin:14px 0 0;
  text-wrap:balance;overflow-wrap:break-word;
}
.sec-head h2 .it{
  display:inline;
  -webkit-box-decoration-break:clone;box-decoration-break:clone;
  font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;
  background:linear-gradient(180deg, var(--accent) 0%, var(--accent-2) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  padding:0.06em 0.08em 0.22em 0;
  line-height:1.3;
}
.sec-head p{color:var(--ink-2);font-size:17px;line-height:1.55;margin:0;max-width:480px;text-wrap:pretty}

/* ---------- SUBSIDIARY CARDS (group home) — Apple-style bento with depth ---------- */
.subs{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.sub{
  background:linear-gradient(180deg, rgba(20,20,20,0.7), rgba(8,8,8,0.7));
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.06);
  padding:32px;display:flex;flex-direction:column;gap:14px;min-height:380px;position:relative;overflow:hidden;
  border-radius:24px;
  transition:all .4s var(--ease-out);
  cursor:pointer;
  transform-style:preserve-3d;
}
.sub::before{
  content:"";position:absolute;inset:0;border-radius:24px;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(var(--sub-rgb),0.18), transparent 50%);
  opacity:0;transition:opacity .4s ease;pointer-events:none;
}
.sub:hover{transform:translateY(-6px);border-color:rgba(255,255,255,0.12);box-shadow:0 30px 80px -20px rgba(0,0,0,0.6), 0 0 60px -10px var(--sub-glow,rgba(200,255,62,0.2))}
.sub:hover::before{opacity:1}
.sub.span-2{grid-column:span 2}
.sub.span-3{grid-column:span 3}
.sub .num{font-family:"Geist Mono",monospace;font-size:11px;color:var(--ink-3);letter-spacing:0.08em;display:flex;align-items:center;gap:8px;position:relative;z-index:1}
.sub .num::before{content:"";width:8px;height:8px;border-radius:99px;background:var(--sub-accent,var(--accent));box-shadow:0 0 14px var(--sub-glow,rgba(200,255,62,0.6))}
.sub h3{font-size:26px;letter-spacing:-0.025em;margin:0;font-weight:600;line-height:1.12;text-wrap:balance;position:relative;z-index:1}
.sub h3 .it{
  font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;
  color:var(--sub-accent,var(--accent));
}
.sub p{color:var(--ink-2);font-size:14.5px;line-height:1.55;margin:0;max-width:42ch;position:relative;z-index:1}
.sub .visual{flex:1;border-radius:14px;background:rgba(0,0,0,0.4);margin-top:auto;display:grid;place-items:center;color:var(--ink-3);font-family:"Geist Mono",monospace;font-size:11px;position:relative;overflow:hidden;min-height:180px;border:1px solid rgba(255,255,255,0.04)}
.sub .go{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:500;color:var(--sub-accent,var(--accent));
  margin-top:4px;position:relative;z-index:1;
}
.sub .go .arrow{transition:transform .3s var(--ease-out)}
.sub:hover .go .arrow{transform:translateX(6px)}

.sub.t-international{--sub-accent:#c8ff3e;--sub-glow:rgba(200,255,62,0.35);--sub-rgb:200,255,62}
.sub.t-investments  {--sub-accent:#34d6a8;--sub-glow:rgba(52,214,168,0.35);--sub-rgb:52,214,168}
.sub.t-tech         {--sub-accent:#8ab4ff;--sub-glow:rgba(138,180,255,0.35);--sub-rgb:138,180,255}
.sub.t-realestate   {--sub-accent:#e59a6e;--sub-glow:rgba(229,154,110,0.35);--sub-rgb:229,154,110}
.sub.t-energy       {--sub-accent:#4de3b5;--sub-glow:rgba(77,227,181,0.35);--sub-rgb:77,227,181}

/* ---------- METRICS ---------- */
.metrics{
  display:grid;grid-template-columns:repeat(4,1fr);
  border:1px solid rgba(255,255,255,0.06);border-radius:20px;overflow:hidden;
  background:linear-gradient(180deg,rgba(15,15,15,0.7),rgba(8,8,8,0.7));
  backdrop-filter:blur(10px);
}
.metric{padding:40px 32px;border-right:1px solid rgba(255,255,255,0.06);position:relative;overflow:hidden}
.metric:last-child{border-right:0}
.metric::before{
  content:"";position:absolute;top:0;left:0;width:60px;height:60px;
  background:radial-gradient(circle, rgba(var(--accent-rgb),0.18), transparent 60%);
  filter:blur(20px);
}
.metric .v{font-size:56px;font-weight:600;letter-spacing:-0.045em;line-height:1;font-feature-settings:"tnum"}
.metric .v .it{
  font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;
  color:var(--accent);
}
.metric .l{font-size:13px;color:var(--ink-3);margin-top:14px;line-height:1.4}

/* ---------- PILLARS ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.pillar{
  background:linear-gradient(180deg,rgba(20,20,20,0.6),rgba(8,8,8,0.6));
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.06);
  padding:36px;display:flex;flex-direction:column;gap:14px;min-height:260px;border-radius:20px;
  transition:all .3s var(--ease-out);
}
.pillar:hover{border-color:rgba(255,255,255,0.12);transform:translateY(-3px)}
.pillar .glyph{
  width:46px;height:46px;border-radius:12px;
  display:grid;place-items:center;
  border:1px solid rgba(var(--accent-rgb),0.2);
  background:rgba(var(--accent-rgb),0.08);
  color:var(--accent);
  margin-bottom:8px;
  box-shadow:0 0 24px rgba(var(--accent-rgb),0.15);
}
.pillar h3{font-size:22px;letter-spacing:-0.02em;margin:0;font-weight:600;line-height:1.2}
.pillar p{color:var(--ink-2);font-size:14.5px;line-height:1.55;margin:0}

/* ---------- PROCESS / STEPS ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.steps.cols-3{grid-template-columns:repeat(3,1fr)}
.step-card{
  background:linear-gradient(180deg,rgba(20,20,20,0.6),rgba(8,8,8,0.6));
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.06);
  padding:32px;display:flex;flex-direction:column;gap:14px;min-height:260px;border-radius:20px;
  transition:all .3s var(--ease-out);
}
.step-card:hover{border-color:rgba(255,255,255,0.12);transform:translateY(-3px)}
.step-card .step-num{font-family:"Geist Mono",monospace;font-size:11px;color:var(--accent);display:flex;align-items:center;gap:8px;letter-spacing:0.08em}
.step-card .step-num::before{content:"";width:24px;height:1px;background:var(--accent)}
.step-card h3{font-size:22px;font-weight:600;letter-spacing:-0.02em;margin:0;line-height:1.18}
.step-card p{color:var(--ink-2);font-size:14.5px;line-height:1.55;margin:0}

/* ---------- TILES ---------- */
.tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.tiles.cols-3{grid-template-columns:repeat(3,1fr)}
.tile{
  background:linear-gradient(180deg,rgba(20,20,20,0.6),rgba(8,8,8,0.6));
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.06);
  padding:32px;border-radius:20px;
  transition:all .3s var(--ease-out);
}
.tile:hover{border-color:rgba(255,255,255,0.12);transform:translateY(-3px)}
.tile h3,.tile h4{font-size:18px;letter-spacing:-0.015em;margin:0 0 10px;display:flex;align-items:center;gap:10px;font-weight:600}
.tile h3::before,.tile h4::before{content:"";width:6px;height:6px;border-radius:99px;background:var(--accent);box-shadow:0 0 12px rgba(var(--accent-rgb),0.5)}
.tile p{color:var(--ink-2);font-size:14.5px;line-height:1.55;margin:0;max-width:38ch}
.tile ul{list-style:none;padding:0;margin:14px 0 0;display:flex;flex-direction:column;gap:8px}
.tile ul li{font-size:13px;color:var(--ink-2);padding-left:14px;position:relative;line-height:1.5}
.tile ul li::before{content:"";position:absolute;left:0;top:0.7em;width:8px;height:1px;background:var(--accent)}

/* ---------- CHIPS ---------- */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.chip{padding:8px 14px;border:1px solid rgba(255,255,255,0.08);border-radius:99px;font-size:12px;color:var(--ink-2);background:rgba(20,20,20,0.6);backdrop-filter:blur(10px);font-family:"Geist Mono",monospace;letter-spacing:0.02em;transition:all .2s ease}
.chip:hover{border-color:var(--accent);color:var(--accent);background:rgba(var(--accent-rgb),0.08);transform:translateY(-2px)}

/* ---------- WORLD MAP ---------- */
.world-wrap{
  border:1px solid rgba(255,255,255,0.06);border-radius:24px;overflow:hidden;
  background:linear-gradient(180deg,rgba(15,15,15,0.7),rgba(8,8,8,0.7));backdrop-filter:blur(10px);
  padding:32px;position:relative;
}
.world-svg{width:100%;height:auto;display:block}
.world-svg .land{fill:rgba(255,255,255,0.04);stroke:rgba(255,255,255,0.06);stroke-width:0.4}
.world-svg .city{fill:var(--accent);filter:drop-shadow(0 0 6px rgba(var(--accent-rgb),0.7))}
.world-svg .arc{fill:none;stroke:var(--accent);stroke-width:0.6;stroke-dasharray:4 4;opacity:0.6;animation:arcPulse 6s linear infinite}
@keyframes arcPulse{from{stroke-dashoffset:0}to{stroke-dashoffset:-100}}
.world-meta{display:flex;justify-content:space-between;margin-top:18px;font-family:"Geist Mono",monospace;font-size:11px;color:var(--ink-3);letter-spacing:0.1em;text-transform:uppercase}
.world-meta .live{color:var(--accent);display:inline-flex;align-items:center;gap:8px}
.world-meta .live i{width:6px;height:6px;border-radius:99px;background:var(--accent);box-shadow:0 0 10px rgba(var(--accent-rgb),0.7);animation:dotPulse 1.6s ease-in-out infinite}

/* ---------- MAP / CITIES list ---------- */
.map-list{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.city{
  background:linear-gradient(180deg,rgba(20,20,20,0.6),rgba(8,8,8,0.6));
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.06);
  padding:24px;font-size:22px;font-weight:600;letter-spacing:-0.02em;
  border-radius:16px;transition:all .3s var(--ease-out);cursor:default;
}
.city span{display:block;font-family:"Geist Mono",monospace;font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-3);margin-top:8px;font-weight:400}
.city:hover{border-color:rgba(var(--accent-rgb),0.4);color:var(--accent);transform:translateY(-3px);box-shadow:0 0 30px rgba(var(--accent-rgb),0.15)}

/* ---------- SPECS ---------- */
.specs{display:grid;grid-template-columns:repeat(2,1fr);border-top:1px solid var(--line);margin-top:14px}
.specs .row{display:grid;grid-template-columns:9rem 1fr;gap:14px;padding:18px 0;border-bottom:1px solid var(--line);padding-right:24px}
.specs .row dt{color:var(--ink-3);font-family:"Geist Mono",monospace;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;margin:0}
.specs .row dd{color:var(--ink);font-size:15px;margin:0}

/* ---------- FAQ ---------- */
.faq{max-width:780px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line);padding:0}
.faq-item summary{
  list-style:none;cursor:pointer;padding:26px 0;
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-size:18px;font-weight:500;letter-spacing:-0.01em;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-family:"Geist Mono",monospace;font-size:22px;color:var(--ink-3);transition:transform .3s var(--ease-out);flex-shrink:0}
.faq-item[open] summary::after{content:"–";color:var(--accent);transform:rotate(180deg)}
.faq-item .a{color:var(--ink-2);font-size:15.5px;line-height:1.6;padding:0 60px 26px 0;text-wrap:pretty}

/* ---------- PULL QUOTE — pinnable ---------- */
.pull{padding:160px 0;position:relative}
.pull blockquote{
  font-size:clamp(32px,4.5vw,64px);line-height:1.25;letter-spacing:-0.03em;font-weight:500;
  color:var(--ink);max-width:24ch;margin:0;text-wrap:balance;overflow-wrap:break-word;
}
.pull blockquote .accent{
  display:inline;
  -webkit-box-decoration-break:clone;box-decoration-break:clone;
  font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;
  background:linear-gradient(180deg, var(--accent) 0%, var(--accent-2) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  padding:0.06em 0.08em 0.22em 0;
  line-height:1.3;
}
.pull cite{display:block;margin-top:36px;font-family:"Geist Mono",monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-3);font-style:normal}

/* ---------- CTA ---------- */
.cta{
  margin:0 auto;max-width:1200px;
  border:1px solid rgba(255,255,255,0.08);border-radius:32px;
  padding:96px 40px;text-align:center;position:relative;overflow:hidden;
  background:
    radial-gradient(800px 400px at 50% 100%, rgba(var(--accent-rgb),0.22), transparent 60%),
    linear-gradient(180deg,rgba(20,20,20,0.8),rgba(5,5,5,0.8));
  backdrop-filter:blur(20px);
  box-shadow:0 30px 80px -20px rgba(0,0,0,0.6);
}
.cta::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse 600px 300px at 50% 100%, transparent 30%, #000 80%);
  opacity:0.5;
}
.cta-inner{position:relative}
.cta h2{font-size:clamp(44px,6vw,84px);line-height:1.15;letter-spacing:-0.045em;font-weight:600;margin:14px 0 0;text-wrap:balance;overflow-wrap:break-word}
.cta h2 .it{
  display:inline;
  -webkit-box-decoration-break:clone;box-decoration-break:clone;
  font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;
  background:linear-gradient(180deg, var(--accent) 0%, var(--accent-2) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  padding:0.06em 0.08em 0.22em 0;
  line-height:1.3;
}
.cta p{color:var(--ink-2);font-size:18px;max-width:520px;margin:20px auto 0}
.cta .btns{margin-top:36px;display:flex;justify-content:center;gap:12px;flex-wrap:wrap}

/* ---------- WORDMARK CLOSER ---------- */
.wordmark-section{padding:80px 0 0;overflow:hidden;position:relative}
.wordmark{
  font-family:"Geist",sans-serif;
  font-size:clamp(80px,24vw,300px);
  font-weight:600;letter-spacing:-0.05em;line-height:0.85;text-align:center;
  background:linear-gradient(180deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.01) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  user-select:none;margin-bottom:-0.1em;white-space:nowrap;
}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:start}
.contact-card{
  border:1px solid rgba(255,255,255,0.06);border-radius:20px;padding:40px;
  background:linear-gradient(180deg,rgba(15,15,15,0.7),rgba(8,8,8,0.7));backdrop-filter:blur(10px);
}
.contact-card h3{font-size:18px;margin:0 0 24px;font-weight:600;letter-spacing:-0.01em}
.contact-card dl{display:grid;grid-template-columns:auto 1fr;gap:14px 24px;align-items:baseline;margin:0}
.contact-card dt{color:var(--ink-3);font-family:"Geist Mono",monospace;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;margin:0}
.contact-card dd{color:var(--ink);font-size:14.5px;margin:0}
.contact-card a{color:inherit;border-bottom:1px solid var(--line-2);padding-bottom:1px;transition:color .15s, border-color .15s}
.contact-card a:hover{color:var(--accent);border-color:var(--accent)}
.contact-form{display:flex;flex-direction:column;gap:14px}
.contact-form label{display:flex;flex-direction:column;gap:6px;font-family:"Geist Mono",monospace;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-3)}
.contact-form input,.contact-form select,.contact-form textarea{
  padding:14px 16px;border:1px solid rgba(255,255,255,0.08);background:rgba(10,10,10,0.6);backdrop-filter:blur(10px);border-radius:12px;color:var(--ink);font-size:14.5px;font-family:inherit;
  transition:border-color .2s ease, background .2s ease;
}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:var(--accent);background:rgba(var(--accent-rgb),0.04)}
.contact-form textarea{min-height:140px;resize:vertical}

/* ---------- FOOTER ---------- */
footer{padding:80px 0 32px;border-top:1px solid var(--line);margin-top:80px;position:relative;z-index:2}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:40px;margin-bottom:60px}
.foot-grid h5{font-size:12px;font-family:"Geist Mono",monospace;color:var(--ink-3);text-transform:uppercase;letter-spacing:0.12em;margin:0 0 18px;font-weight:500}
.foot-grid ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.foot-grid ul a{color:var(--ink-2);font-size:14px;transition:color .15s}
.foot-grid ul a:hover{color:var(--accent)}
.foot-brand .desc{color:var(--ink-3);font-size:13.5px;line-height:1.55;max-width:280px;margin-top:14px}
.foot-bottom{display:flex;justify-content:space-between;padding-top:28px;border-top:1px solid var(--line);font-size:12px;color:var(--ink-3);font-family:"Geist Mono",monospace;letter-spacing:0.02em;flex-wrap:wrap;gap:10px}
.foot-bottom .stat-dot{display:inline-flex;align-items:center;gap:8px}
.foot-bottom .stat-dot i{width:6px;height:6px;border-radius:99px;background:var(--accent);box-shadow:0 0 10px rgba(var(--accent-rgb),0.6);animation:dotPulse 2s ease-in-out infinite}

/* ---------- VISUALS shared ---------- */
.viz-rings{position:relative;width:100%;height:100%;display:grid;place-items:center;overflow:hidden}
.viz-rings .ring{position:absolute;border:1px dashed rgba(255,255,255,0.1);border-radius:99px;animation:ringSpin 40s linear infinite}
.viz-rings .ring.r1{width:60%;aspect-ratio:1;animation-duration:30s}
.viz-rings .ring.r2{width:80%;aspect-ratio:1;border-color:rgba(255,255,255,0.06);animation-duration:50s;animation-direction:reverse}
.viz-rings .ring.r3{width:104%;aspect-ratio:1;border-color:rgba(255,255,255,0.04);animation-duration:70s}
.viz-rings .pin{position:absolute;width:8px;height:8px;border-radius:99px;background:var(--accent);box-shadow:0 0 14px rgba(var(--accent-rgb),0.7)}
.viz-rings .pin.idle{background:#3a3a3a;box-shadow:none}
@keyframes ringSpin{to{transform:rotate(360deg)}}

.viz-bars{padding:18px;width:100%;height:100%;display:flex;align-items:flex-end;gap:6px}
.viz-bars .b{flex:1;background:linear-gradient(180deg,#222,#0e0e0e);border-radius:3px 3px 0 0;border-top:2px solid var(--accent);box-shadow:0 -8px 16px -4px rgba(var(--accent-rgb),0.3)}
.viz-bars .b.dim{border-top-color:#2a2a2a;box-shadow:none}

.viz-list{padding:18px;width:100%;display:flex;flex-direction:column;gap:8px;font-family:"Geist Mono",monospace;font-size:11px}
.viz-list .row{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid rgba(255,255,255,0.06);border-radius:8px;background:rgba(0,0,0,0.4);color:var(--ink-2)}
.viz-list .row .d{width:7px;height:7px;border-radius:99px;background:var(--accent);box-shadow:0 0 8px rgba(var(--accent-rgb),0.6)}
.viz-list .row.idle .d{background:#3a3a3a;box-shadow:none}
.viz-list .row .t{margin-left:auto;color:var(--ink-3);font-size:10px}

.viz-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;padding:14px;width:100%;height:100%}
.viz-grid i{display:block;border-radius:3px;background:#181818;aspect-ratio:1}
.viz-grid i.on{background:var(--accent);box-shadow:0 0 10px rgba(var(--accent-rgb),0.5)}
.viz-grid i.warm{background:#252525}

.viz-num{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding:18px 22px;width:100%;height:100%}
.viz-num .big{font-size:64px;font-weight:600;letter-spacing:-0.04em;line-height:1;color:var(--ink)}
.viz-num .big .it{
  font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;
  color:var(--accent);
}
.viz-num .lab{font-family:"Geist Mono",monospace;font-size:10.5px;color:var(--ink-3);letter-spacing:0.12em;text-transform:uppercase;margin-top:10px}

/* reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 1s var(--ease-out), transform 1s var(--ease-out)}
.reveal.is-in{opacity:1;transform:none}
.reveal-up{opacity:0;transform:translateY(40px);transition:opacity 1.1s var(--ease-out), transform 1.1s var(--ease-out)}
.reveal-up.is-in{opacity:1;transform:none}
.reveal-stagger > *{opacity:0;transform:translateY(20px);transition:opacity .9s var(--ease-out), transform .9s var(--ease-out)}
.reveal-stagger.is-in > *{opacity:1;transform:none}
.reveal-stagger.is-in > *:nth-child(1){transition-delay:0s}
.reveal-stagger.is-in > *:nth-child(2){transition-delay:.08s}
.reveal-stagger.is-in > *:nth-child(3){transition-delay:.16s}
.reveal-stagger.is-in > *:nth-child(4){transition-delay:.24s}
.reveal-stagger.is-in > *:nth-child(5){transition-delay:.32s}
.reveal-stagger.is-in > *:nth-child(6){transition-delay:.40s}
.reveal-stagger.is-in > *:nth-child(7){transition-delay:.48s}
.reveal-stagger.is-in > *:nth-child(8){transition-delay:.56s}

/* sound toggle (small floating control) */
.sound-toggle{
  position:fixed;bottom:20px;left:20px;z-index:40;
  width:38px;height:38px;border-radius:99px;
  background:rgba(15,15,15,0.7);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.08);
  display:grid;place-items:center;color:var(--ink-2);cursor:pointer;
  transition:all .2s ease;font-size:14px;
}
.sound-toggle:hover{border-color:var(--accent);color:var(--accent)}
.sound-toggle.on{color:var(--accent);border-color:rgba(var(--accent-rgb),0.4)}

/* ---------- CONTACT STATEMENT (replaces contact form) ---------- */
.contact-statement{display:flex;flex-direction:column}
.contact-statement h3{
  font-size:clamp(28px,3vw,38px);letter-spacing:-0.025em;font-weight:600;
  margin:14px 0 18px;line-height:1.2;text-wrap:balance;overflow-wrap:break-word;
}
.contact-statement h3 .it{
  display:inline;
  -webkit-box-decoration-break:clone;box-decoration-break:clone;
  font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;
  background:linear-gradient(180deg, var(--accent) 0%, var(--accent-2) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  padding:0.06em 0.08em 0.22em 0;
  line-height:1.3;
}
.contact-statement > p{color:var(--ink-2);font-size:15.5px;line-height:1.55;margin:0;text-wrap:pretty}
.contact-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
  margin:30px 0 26px;padding:24px 0;border-block:1px solid var(--line);
}
.contact-stats > div{display:flex;flex-direction:column;gap:8px}
.contact-stats .big{
  font-size:34px;font-weight:600;letter-spacing:-0.03em;line-height:1;color:var(--ink);
  font-feature-settings:"tnum";
}
.contact-stats .big .it{
  font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;
  color:var(--accent);
}
.contact-stats .lab{
  font-family:"Geist Mono",monospace;font-size:10.5px;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--ink-3);line-height:1.3;
}
.contact-statement-cta{display:flex;gap:10px;flex-wrap:wrap}

/* ---------- POSTER (full-bleed photo moment) ---------- */
.poster{
  position:relative;height:clamp(420px,62vh,640px);overflow:hidden;
  border-block:1px solid rgba(255,255,255,0.06);
  margin:0;padding:0;
  isolation:isolate;
  background:var(--bg-2);
}
.poster img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:brightness(0.55) saturate(0.82) contrast(1.05);
  transform:scale(1.06);
  animation:posterDrift 30s var(--ease-in-out) infinite alternate;
  z-index:-2;
}
.poster::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(60% 80% at 0% 100%, rgba(var(--accent-rgb),0.22), transparent 60%),
    linear-gradient(to top, rgba(7,7,7,0.92) 0%, rgba(7,7,7,0.18) 55%, rgba(7,7,7,0.55) 100%);
}
@keyframes posterDrift{to{transform:scale(1.13) translate(-2%,1%)}}
.poster .container{height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding-block:48px}
.poster h2{
  font-size:clamp(36px,5vw,68px);letter-spacing:-0.04em;line-height:1.18;font-weight:600;
  margin:14px 0 0;max-width:22ch;text-wrap:balance;overflow-wrap:break-word;
}
.poster h2 .it{
  display:inline;
  -webkit-box-decoration-break:clone;box-decoration-break:clone;
  font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;
  background:linear-gradient(180deg, var(--accent) 0%, var(--accent-2) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  padding:0.06em 0.08em 0.22em 0;
  line-height:1.3;
}
@media (max-width:600px){
  .poster{height:clamp(360px,55vh,460px)}
  .poster h2{font-size:clamp(30px,8vw,44px)}
}
@media (prefers-reduced-motion:reduce){
  .poster img{animation:none;transform:scale(1.03)}
}

/* ---------- RESPONSIVE ---------- */
@media (max-width:860px){
  .nav-toggle{display:inline-flex}
  .nav ul{display:none}
  .nav-cta{display:none}

  /* MOBILE DRAWER — premium full-screen takeover */
  body.nav-open{overflow:hidden}

  /* CRITICAL: when drawer is open, strip the .nav of backdrop-filter / transform / will-change
     so position:fixed children can escape the nav pill and cover the viewport */
  body.nav-open .nav-wrap{
    position:fixed;top:0;left:0;right:0;
    padding:14px 0;
    will-change:auto;
  }
  body.nav-open .nav{
    backdrop-filter:none;-webkit-backdrop-filter:none;
    background:transparent;border-color:transparent;box-shadow:none;
    transform:none;
  }

  body.nav-open .nav ul{
    display:flex !important;
    position:fixed;inset:0;z-index:40;
    flex-direction:column;align-items:stretch;
    padding:130px 24px 220px;gap:0;
    overflow-y:auto;-webkit-overflow-scrolling:touch;
    background:
      radial-gradient(70% 50% at 80% 15%, rgba(var(--accent-rgb),0.10), transparent 65%),
      radial-gradient(60% 50% at 15% 90%, rgba(220,176,97,0.06), transparent 65%),
      #050505;
    animation:drawerFade .5s var(--ease-out);
  }
  /* Eyebrow above link list */
  body.nav-open .nav ul::before{
    content:"Navigation";
    display:block;
    font-family:"Geist Mono",monospace;
    font-size:10px;letter-spacing:0.28em;text-transform:uppercase;
    color:#d4a24c;
    padding:0 4px 14px;
    border-bottom:1px solid rgba(255,255,255,0.06);
    margin-bottom:8px;
    opacity:0;animation:drawerItem .6s var(--ease-out) .12s forwards;
  }

  /* Each li: divider + staggered slide-in */
  body.nav-open .nav ul li{
    border-bottom:1px solid rgba(255,255,255,0.06);
    opacity:0;transform:translateX(-12px);
    animation:drawerItem .55s var(--ease-out) forwards;
  }
  body.nav-open .nav ul li:nth-child(1){animation-delay:.18s}
  body.nav-open .nav ul li:nth-child(2){animation-delay:.24s}
  body.nav-open .nav ul li:nth-child(3){animation-delay:.30s}
  body.nav-open .nav ul li:nth-child(4){animation-delay:.36s}
  body.nav-open .nav ul li:nth-child(5){animation-delay:.42s}
  body.nav-open .nav ul li:nth-child(6){animation-delay:.48s}

  body.nav-open .nav ul a{
    width:100%;padding:24px 4px;
    font-size:34px;font-weight:600;letter-spacing:-0.035em;
    color:var(--ink);background:transparent;border-radius:0;
    display:flex;align-items:center;justify-content:space-between;gap:14px;
    transition:color .25s ease, padding-left .25s ease;
    text-wrap:balance;
  }
  body.nav-open .nav ul a::after{
    content:"→";
    font-size:22px;font-weight:300;color:rgba(255,255,255,0.25);
    transition:color .25s ease, transform .3s var(--ease-out);
    flex-shrink:0;
  }
  body.nav-open .nav ul a:hover,
  body.nav-open .nav ul a:active,
  body.nav-open .nav ul a.is-current{
    color:#d4a24c;padding-left:14px;
  }
  body.nav-open .nav ul a:hover::after,
  body.nav-open .nav ul a:active::after,
  body.nav-open .nav ul a.is-current::after{
    color:#d4a24c;transform:translateX(6px);
  }
  body.nav-open .nav ul a.is-current{
    background:linear-gradient(90deg, rgba(212,162,76,0.06), transparent 70%);
  }

  /* Bottom CTA panel */
  body.nav-open .nav-cta{
    display:flex !important;
    position:fixed;left:24px;right:24px;bottom:0;z-index:41;
    flex-direction:column;gap:10px;
    padding:22px 0 28px;
    background:linear-gradient(to top, #050505 70%, rgba(5,5,5,0.92) 100%);
    border-top:1px solid rgba(255,255,255,0.08);
    animation:drawerItem .55s var(--ease-out) .55s backwards;
  }
  body.nav-open .nav-cta::before{
    content:"Get in touch";
    display:block;
    font-family:"Geist Mono",monospace;
    font-size:10px;letter-spacing:0.28em;text-transform:uppercase;
    color:#d4a24c;margin-bottom:4px;
  }
  body.nav-open .nav-cta::after{
    content:"corporate@filseven.com  ·  +1 (251) 910-8852";
    display:block;text-align:center;
    font-family:"Geist Mono",monospace;
    font-size:10.5px;letter-spacing:0.06em;color:var(--ink-3);
    padding-top:14px;margin-top:4px;
    border-top:1px solid rgba(255,255,255,0.05);
  }
  body.nav-open .nav-cta .btn{
    width:100%;justify-content:center;height:54px;font-size:15px;
  }
  body.nav-open .nav-cta .btn-ghost{
    display:inline-flex;
    background:rgba(255,255,255,0.04);
    border:1px solid rgba(255,255,255,0.1);
    color:var(--ink);
  }
  body.nav-open .nav-cta .btn-ghost:hover{
    background:rgba(255,255,255,0.07);
    border-color:rgba(var(--accent-rgb),0.4);
  }

  @keyframes drawerFade{
    from{opacity:0}
    to{opacity:1}
  }
  @keyframes drawerItem{
    from{opacity:0;transform:translateX(-12px)}
    to{opacity:1;transform:none}
  }

  .sec-head{grid-template-columns:1fr;gap:18px;margin-bottom:40px}
  .subs{grid-template-columns:1fr}
  .sub.span-2,.sub.span-3{grid-column:auto}
  .pillars{grid-template-columns:1fr}
  .steps,.steps.cols-3{grid-template-columns:1fr}
  .tiles,.tiles.cols-3{grid-template-columns:1fr}
  .map-list{grid-template-columns:repeat(2,1fr)}
  .metrics{grid-template-columns:repeat(2,1fr)}
  .metric{border-bottom:1px solid var(--line)}
  .metric:nth-last-child(-n+2){border-bottom:0}
  .metric:nth-child(odd){border-right:1px solid var(--line)}
  .metric:nth-child(even){border-right:0}
  .specs{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:24px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
  .sub-hero-with-art{grid-template-columns:1fr}
  .sub-hero-art{margin:30px auto 0;max-width:340px}
  .pull{padding:120px 0}
}
@media (max-width:600px){
  section{padding:72px 0}
  .container{padding:0 18px}

  /* Hero / sub-hero typography — sized for longer translations (PT/ES) */
  .hero{padding:30px 0 20px;min-height:auto}
  h1.display{font-size:clamp(30px,8.5vw,46px);letter-spacing:-0.035em;hyphens:auto;-webkit-hyphens:auto;overflow-wrap:break-word;max-width:100%}
  .hero-sub{font-size:16px;margin-top:20px}
  .hero-cta{margin-top:28px;flex-direction:column;width:100%;align-items:stretch}
  .hero-cta .btn{justify-content:center}
  .hero-meta{gap:14px 18px;font-size:12px;margin-top:24px}

  .sub-hero{padding:24px 0 16px;min-height:auto}
  .sub-hero h1{font-size:clamp(28px,7.5vw,40px);letter-spacing:-0.03em;hyphens:auto;-webkit-hyphens:auto;overflow-wrap:break-word;max-width:100%}
  .sub-hero .lead{font-size:15.5px;margin-top:18px}
  .sub-hero .actions{margin-top:24px;flex-direction:column;align-items:stretch}
  .sub-hero .actions .btn{justify-content:center}
  .sub-hero-art{max-width:260px;margin-top:24px}

  /* Section heads */
  .sec-head h2{font-size:clamp(26px,7vw,40px);letter-spacing:-0.03em;hyphens:auto;-webkit-hyphens:auto;overflow-wrap:break-word}
  .sec-head p{font-size:15px}

  /* Bento subsidiary cards */
  .subs{gap:12px}
  .sub{padding:24px;min-height:300px}
  .sub h3{font-size:22px}

  /* Metrics */
  .metrics{grid-template-columns:1fr}
  .metric{padding:28px 22px;border-right:0 !important;border-bottom:1px solid var(--line)}
  .metric:last-child{border-bottom:0}
  .metric .v{font-size:42px}
  .metric .l{font-size:12.5px}

  /* Pillars / tiles / steps */
  .pillar,.tile,.step-card{padding:24px;min-height:auto}
  .pillar h3,.step-card h3{font-size:19px}
  .tile h3,.tile h4{font-size:17px}
  .pillar p,.tile p,.step-card p{font-size:14px}

  /* Cities / map list */
  .map-list{grid-template-columns:1fr;gap:10px}
  .city{padding:18px 20px;font-size:18px}

  /* World map (homepage) */
  .world-wrap{padding:18px}
  .world-meta{flex-direction:column;gap:8px;align-items:flex-start;font-size:10px}

  /* Specs */
  .specs .row{grid-template-columns:1fr;gap:4px;padding:14px 0;padding-right:0}
  .specs .row dt{font-size:10.5px}
  .specs .row dd{font-size:14px}

  /* Pull quote */
  .pull{padding:80px 0}
  .pull blockquote{font-size:clamp(22px,5.5vw,34px);hyphens:auto;-webkit-hyphens:auto;overflow-wrap:break-word}
  .pull cite{margin-top:24px;font-size:10.5px}

  /* Poster headlines */
  .poster h2{font-size:clamp(24px,6.5vw,38px);hyphens:auto;-webkit-hyphens:auto;overflow-wrap:break-word}

  /* CTA banner h2 */
  .cta h2{font-size:clamp(28px,7.5vw,42px);letter-spacing:-0.03em;hyphens:auto;-webkit-hyphens:auto;overflow-wrap:break-word}

  /* CTA */
  .cta{padding:56px 22px;border-radius:24px}
  .cta h2{font-size:clamp(32px,9vw,48px)}
  .cta p{font-size:15px;margin-top:16px}
  .cta .btns{flex-direction:column;align-items:stretch}
  .cta .btns .btn{justify-content:center}

  /* FAQ */
  .faq-item summary{font-size:16px;padding:22px 0;gap:14px}
  .faq-item summary::after{font-size:18px}
  .faq-item .a{font-size:14.5px;padding:0 24px 22px 0}

  /* Wordmark */
  .wordmark-section{padding:50px 0 0}

  /* Footer */
  .foot-grid{grid-template-columns:1fr;gap:28px;margin-bottom:40px}
  .foot-bottom{flex-direction:column;align-items:flex-start;font-size:10.5px;gap:8px}

  /* Ticker */
  .ticker{padding:10px 0}
  .ticker-track{gap:28px}
  .ticker-item{font-size:11px;gap:8px}
  .ticker::before,.ticker::after{width:60px}

  /* Posters */
  .poster{height:clamp(320px,52vh,420px)}
  .poster .container{padding-block:36px}
  .poster h2{font-size:clamp(28px,8vw,40px);max-width:18ch}

  /* Contact card on mobile */
  .contact-card{padding:28px 22px}
  .contact-card dl{grid-template-columns:1fr;gap:6px}
  .contact-card dt{margin-top:12px}
  .contact-card dt:first-of-type{margin-top:0}
  .contact-statement-cta{flex-direction:column}
  .contact-statement-cta .btn{width:100%;justify-content:center}
  .contact-stats{grid-template-columns:1fr;gap:10px;padding:18px 0;margin:24px 0 22px}

  /* Pill (annual letter banner) */
  .pill{font-size:11.5px;padding:5px 5px 5px 12px;flex-wrap:wrap}

  /* Mobile menu drawer items slightly smaller on tiny phones */
  body.nav-open .nav ul a{font-size:22px;padding:14px 16px}
}
@media (max-width:380px){
  .container{padding:0 16px}
  h1.display{font-size:clamp(24px,8vw,36px)}
  .sub-hero h1{font-size:clamp(22px,7.5vw,32px)}
  .sec-head h2{font-size:clamp(22px,6.5vw,32px)}
  .cta h2{font-size:clamp(24px,7vw,34px)}
  .pull blockquote{font-size:clamp(20px,5.5vw,28px)}
  .poster h2{font-size:clamp(22px,6.5vw,32px)}
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.2s !important}
  .aurora,.grain{display:none}
}
