/* ============================================================
   evverywhere — design system
   Flight EV·2024 · CPT → ∀
   Hand-built. No frameworks. No CDNs.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* raw palette */
  --cream:#F2EBDD; --cream-2:#E8E0D1; --cream-3:#DDD3BE; --paper:#FBF7EE;
  --ink:#0E0E0C; --ink-2:#14120F; --ink-3:#1C1A16;
  /* accent family — rose gold (prev terracotta: #B8462E / deep #8C2F1D / ochre #A77C3F / coral #D9714A / gold #C9A35C) */
  --terra:#C4806B; --terra-deep:#9D5F4E; --ochre:#B08468;
  --teal:#4A7A70; --coral:#E2A584; --gold:#D2A969;
  /* glossy metal — highlight, body, shadow, kick */
  --metal:linear-gradient(108deg,#D89C7E 4%,#C4806B 38%,#9D5F4E 66%,#D59F7C 96%);
  --metal-lt:linear-gradient(108deg,#F4D2B8 4%,#E0A58A 40%,#C4806B 68%,#F0C9A6 96%);

  /* semantic (day) */
  --bg:var(--cream); --bg-2:var(--paper); --bg-3:var(--cream-2);
  --fg:var(--ink); --fg-soft:#3A352D; --fg-mute:#6B6357;
  --line-c:rgba(14,14,12,.12); --line:1px solid var(--line-c);
  --dark:#0E0E0C; --dark-2:#121110;
  --on-dark:var(--cream);
  --on-dark-soft:rgba(242,235,221,.62);
  --on-dark-mute:rgba(242,235,221,.42);
  --on-dark-line:rgba(242,235,221,.14);

  --serif:'Newsreader',Georgia,serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,monospace;

  --ease:cubic-bezier(.65,.05,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --pad:clamp(1.2rem,3vw,2.4rem);
  --max:1380px;
}
html[data-theme="night"]{
  --bg:#0E0E0C; --bg-2:#13110E; --bg-3:#181613;
  --fg:#F2EBDD; --fg-soft:#CFC5B2; --fg-mute:#8F8576;
  --line-c:rgba(242,235,221,.13);
  --dark:#080807; --dark-2:#0C0B0A;
  --terra:#E0A58A; --teal:#5E9A8D; --coral:#EFBD9F; --gold:#E5C28B;
  --metal:linear-gradient(108deg,#F4D2B8 4%,#E0A58A 40%,#C4806B 68%,#F0C9A6 96%);
}

/* ---------- Reset & base ---------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:auto}
body{
  background:var(--bg);color:var(--fg);
  font-family:var(--sans);font-weight:400;
  font-feature-settings:'ss01','liga','kern';
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;overflow-x:hidden;
  transition:background-color .7s ease,color .7s ease;
}
html.js body{cursor:none}
body::before{ /* paper grain */
  content:"";position:fixed;inset:0;pointer-events:none;z-index:2000;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.05;mix-blend-mode:multiply;
}
html[data-theme="night"] body::before{opacity:.08;mix-blend-mode:screen}
::selection{background:var(--terra);color:var(--cream)}
::-webkit-scrollbar{width:0;background:transparent}
img,svg,video,canvas{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{background:none;border:none;font:inherit;color:inherit}
html.js a,html.js button,html.js select,html.js input,html.js textarea,html.js label{cursor:none}
:focus{outline:none}
:focus-visible{outline:1px dashed var(--terra);outline-offset:4px}
.skip{position:fixed;top:-100px;left:1rem;z-index:9999;background:var(--ink);color:var(--cream);font-family:var(--mono);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;padding:.8rem 1.2rem;transition:top .3s}
.skip:focus{top:1rem}
.sec-w{max-width:var(--max);margin:0 auto;width:100%}

/* ---------- Boarding loader ---------- */
#ld{
  position:fixed;inset:0;background:var(--cream);z-index:9999;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .9s ease,visibility .9s;
  animation:ldAuto .8s ease 4s forwards; /* failsafe: self-dismiss without JS */
}
html[data-theme="night"] #ld{background:var(--ink)}
#ld.out{opacity:0;visibility:hidden;pointer-events:none}
@keyframes ldAuto{to{opacity:0;visibility:hidden;pointer-events:none}}
.ld-card{
  width:min(420px,86vw);border:1px solid rgba(14,14,12,.25);padding:1.6rem 1.8rem 1.4rem;
  display:flex;flex-direction:column;gap:1.1rem;position:relative;color:var(--ink);
  background:
    radial-gradient(circle at 0 52%, var(--cream) 9px, transparent 10px),
    radial-gradient(circle at 100% 52%, var(--cream) 9px, transparent 10px);
}
html[data-theme="night"] .ld-card{color:var(--cream);border-color:rgba(242,235,221,.3);background:none}
.ld-row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:.5rem;letter-spacing:.3em;text-transform:uppercase;opacity:0;animation:ldFade .8s ease forwards .2s}
.ld-word{font-family:var(--serif);font-size:2.1rem;font-style:italic;font-weight:300;letter-spacing:-.03em;font-variation-settings:"opsz" 72;opacity:0;animation:ldFade .8s ease forwards .45s}
.ld-word i{font-style:normal;color:var(--terra)}
.ld-route{display:flex;align-items:center;gap:.9rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.24em;opacity:0;animation:ldFade .8s ease forwards .7s}
.ld-line{flex:1;height:1px;background:currentColor;opacity:.35;position:relative}
.ld-plane{position:absolute;top:-2.5px;left:0;width:6px;height:6px;border-radius:50%;background:var(--terra);animation:ldFly 2.6s var(--ease) infinite .9s}
@keyframes ldFly{0%{left:0}55%,100%{left:calc(100% - 6px)}}
@keyframes ldFade{to{opacity:1}}

/* ---------- Cursor ---------- */
.cur{position:fixed;width:5px;height:5px;background:var(--cream);border-radius:50%;pointer-events:none;z-index:9990;transform:translate(-50%,-50%);transition:width .35s var(--ease),height .35s var(--ease),opacity .3s;mix-blend-mode:difference;will-change:left,top}
.cur.xl{width:58px;height:58px}
.cur.hide{opacity:0}
.cur-r{position:fixed;width:36px;height:36px;border:1px solid var(--cream);opacity:.45;border-radius:50%;pointer-events:none;z-index:9989;transform:translate(-50%,-50%);will-change:left,top;mix-blend-mode:difference}
html.no-js .cur,html.no-js .cur-r{display:none}
@media(hover:none),(pointer:coarse){.cur,.cur-r{display:none!important}html.js body,html.js a,html.js button,html.js select,html.js input,html.js textarea,html.js label{cursor:auto}}

/* ---------- Nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:300;padding:1.6rem var(--pad);display:flex;justify-content:space-between;align-items:center;mix-blend-mode:difference;color:var(--cream);transition:padding .4s var(--ease)}
.nav.sm{padding:1rem var(--pad)}
.nav-l{font-family:var(--serif);font-size:1.05rem;font-weight:400;letter-spacing:-.018em;font-variation-settings:"opsz" 54}
.nav-l i{font-style:italic;color:var(--terra);font-weight:300;display:inline-block;transition:transform .4s var(--ease)}
.nav-l:hover i{transform:scale(1.6)}
.nav-u{display:flex;gap:2.2rem;list-style:none;align-items:center}
.nav-u a{font-family:var(--mono);font-size:.55rem;letter-spacing:.32em;text-transform:uppercase;opacity:.55;transition:opacity .35s ease;display:flex;align-items:center;gap:.5rem}
.nav-u a::before{content:attr(data-n);font-size:.42rem;opacity:.6}
.nav-u a:hover,.nav-u a.act{opacity:1}
.nav-cta{font-family:var(--mono);font-size:.5rem;letter-spacing:.3em;text-transform:uppercase;border:1px solid currentColor;padding:.65rem 1.1rem;display:inline-flex;align-items:center;gap:.5rem;transition:background .3s,color .3s}
.nav-cta:hover{background:var(--cream);color:var(--ink)}
.nav-ham{display:none;width:30px;height:20px;position:relative;z-index:400}
.nav-ham span{display:block;position:absolute;left:0;width:100%;height:1px;background:currentColor;transition:transform .35s,top .35s}
.nav-ham span:nth-child(1){top:6px}
.nav-ham span:nth-child(2){top:14px}
.nav-ham.open span:nth-child(1){top:10px;transform:rotate(45deg)}
.nav-ham.open span:nth-child(2){top:10px;transform:rotate(-45deg)}
#mob{position:fixed;inset:0;background:var(--bg);z-index:290;display:none;flex-direction:column;align-items:flex-start;justify-content:center;gap:1.4rem;padding:0 2rem}
#mob.open{display:flex}
#mob a{font-family:var(--serif);font-size:2.6rem;font-style:italic;font-weight:300;color:var(--fg);font-variation-settings:"opsz" 72;display:flex;align-items:baseline;gap:1rem}
#mob a em{font-family:var(--mono);font-style:normal;font-size:.55rem;letter-spacing:.3em;color:var(--terra)}
.mob-foot{position:absolute;bottom:2rem;left:2rem;font-family:var(--mono);font-size:.5rem;letter-spacing:.32em;text-transform:uppercase;color:var(--fg-mute)}

/* ---------- Flight HUD ---------- */
.hud{
  position:fixed;left:0;right:0;bottom:0;z-index:280;
  display:grid;grid-template-columns:1fr 2fr 1fr;align-items:center;gap:1.6rem;
  padding:.85rem var(--pad);
  mix-blend-mode:difference;color:var(--cream);
  font-family:var(--mono);font-size:.5rem;letter-spacing:.28em;text-transform:uppercase;
  pointer-events:none;opacity:0;transform:translateY(8px);
  transition:opacity .8s ease 1s,transform .8s ease 1s;
}
html.js .hud.on{opacity:1;transform:none}
.hud-ch{display:flex;gap:1rem;align-items:baseline}
.hud-ch b{font-weight:500;color:var(--terra)}
.hud-ch span{opacity:.75}
.hud-track{position:relative;height:1px;background:rgba(242,235,221,.22)}
.hud-prog{position:absolute;left:0;top:0;height:1px;width:0;background:var(--cream)}
.hud-prog::after{content:"";position:absolute;right:-3px;top:-2.5px;width:6px;height:6px;border-radius:50%;background:var(--terra)}
.hud-stop{position:absolute;top:-1.5px;width:4px;height:4px;border-radius:50%;background:rgba(242,235,221,.4)}
.hud-stop[data-at="0"]{left:0}.hud-stop[data-at="1"]{left:25%}.hud-stop[data-at="2"]{left:50%}.hud-stop[data-at="3"]{left:75%}.hud-stop[data-at="4"]{right:0}
.hud-geo{display:flex;justify-content:flex-end;gap:1.4rem}
.hud-geo b{font-weight:500;opacity:.75}

/* ---------- Chapter slates ---------- */
.slate{display:flex;align-items:baseline;gap:1.2rem;font-family:var(--mono);font-size:.52rem;letter-spacing:.34em;text-transform:uppercase;color:var(--fg-mute);margin-bottom:2.6rem}
.slate b{color:var(--terra);font-weight:500}
.slate span:nth-child(2){color:var(--fg-soft)}
.slate::after{content:"";flex:1;height:1px;background:var(--line-c);transform-origin:left;align-self:center}
.slate-geo{opacity:.7}
.slate.lt{color:var(--on-dark-mute)}
.slate.lt span:nth-child(2){color:var(--on-dark-soft)}
.slate.lt::after{background:var(--on-dark-line)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;min-height:100svh;width:100%;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;background:var(--bg);transition:background-color .7s ease}
#hero-c{position:absolute;inset:0;width:100%;height:100%;z-index:1;opacity:.6;mix-blend-mode:multiply}
html[data-theme="night"] #hero-c{mix-blend-mode:screen;opacity:.5}
.hero-bar{position:absolute;top:0;left:0;right:0;padding:5.5rem var(--pad) 0;display:flex;justify-content:space-between;align-items:center;z-index:5;font-family:var(--mono);font-size:.5rem;letter-spacing:.32em;text-transform:uppercase;color:var(--fg-soft);pointer-events:none;flex-wrap:wrap;gap:.6rem}
.hero-bar > div{display:flex;align-items:center;gap:.6rem}
.hero-bar .dot{width:5px;height:5px;background:var(--terra);border-radius:50%;animation:pulse 2.4s ease-in-out infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:.4;transform:scale(.85)}50%{opacity:1;transform:scale(1.4)}}
.hero-w{position:relative;z-index:3;padding:0 var(--pad) .8rem;width:100%}
.hero-eb{font-family:var(--mono);font-size:.55rem;letter-spacing:.42em;text-transform:uppercase;color:var(--fg-soft);margin-bottom:1.2rem;display:flex;align-items:center;gap:.7rem}
.hero-eb::before{content:"";width:24px;height:1px;background:currentColor}
.hero-eb em{font-style:normal;color:var(--terra)}
.hero-h{font-family:var(--serif);font-weight:300;line-height:.86;letter-spacing:-.035em;color:var(--fg);font-size:clamp(3.6rem,16.2vw,16.5rem);font-variation-settings:"opsz" 72;padding-bottom:.18em;margin-bottom:-.04em}
.hero-h .ww{position:relative;display:inline-block;font-style:italic;line-height:.84}
.hero-h .ww b{font-style:normal;font-weight:300}
.hero-h .ww i{font-style:normal;color:var(--terra);font-weight:300;display:inline-block;transform:translateY(-.04em)}
.hero-h .ltr{display:inline-block;will-change:transform;transition:transform .35s var(--ease-out)}
.hero-h .ww-base{
  /* dark veil stacked over the photo (plain alpha — reliable with clip:text):
     guarantees every revealed glyph keeps contrast against the cream,
     even where the aerial photo is pale sky */
  background-image:linear-gradient(rgba(26,20,16,.46),rgba(26,20,16,.46)),url('https://images.unsplash.com/photo-1580060839134-75a5edca2e99?w=1800&q=90&auto=format&fit=crop');
  background-size:cover,cover;background-position:center,center 55%;background-repeat:no-repeat;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:saturate(1.08) contrast(1.18) brightness(.95);
  /* vertical padding is paint-only on inline boxes: it extends the background
     paint area so italic descenders (the y!) and ascenders keep their photo
     fill instead of clipping transparent at the em box */
  padding:.18em 0 .42em;
}
.hero-h .ww-base i{color:var(--terra);-webkit-background-clip:initial;background-clip:initial}
.hero-h .ww-cover{
  position:absolute;inset:0;color:var(--fg);
  --mx:-600px;--my:-600px;--r:280px;
  -webkit-mask-image:radial-gradient(circle var(--r) at var(--mx) var(--my),transparent 0%,transparent 55%,#000 100%);
          mask-image:radial-gradient(circle var(--r) at var(--mx) var(--my),transparent 0%,transparent 55%,#000 100%);
  pointer-events:none;will-change:mask-image;
}
/* standfirst — the plain-language answer to "what is this company?" */
.hero-sf{font-family:var(--serif);font-weight:400;font-size:clamp(1.02rem,1.55vw,1.4rem);line-height:1.55;color:var(--fg);max-width:64ch;margin-top:1rem;font-variation-settings:"opsz" 18}
.hero-sf em{font-style:italic;color:var(--terra)}
.hero-meta{display:flex;justify-content:space-between;align-items:flex-end;margin-top:.5rem;padding:1.4rem 0 1rem;border-top:var(--line);flex-wrap:wrap;gap:1rem}
.hero-meta-l{font-family:var(--mono);font-size:.5rem;letter-spacing:.34em;text-transform:uppercase;color:var(--fg-soft);max-width:380px;line-height:2.1}
.hero-meta-l b{color:var(--fg);font-weight:500}
.hero-meta-r{font-family:var(--mono);font-size:.5rem;letter-spacing:.34em;text-transform:uppercase;color:var(--fg-soft);text-align:right;line-height:2.1}
.hero-meta-r b{color:var(--fg);font-weight:500}
.hero-services{display:flex;justify-content:space-between;padding:1rem var(--pad) 3rem;font-family:var(--mono);font-size:.48rem;letter-spacing:.32em;text-transform:uppercase;color:var(--fg-soft);position:relative;z-index:3;border-top:var(--line)}
.hero-services span{flex:1;text-align:center;border-right:var(--line);padding:.4rem .5rem;display:flex;align-items:center;justify-content:center;gap:.4rem}
.hero-services span:first-child{text-align:left;justify-content:flex-start}
.hero-services span:last-child{text-align:right;border-right:0;justify-content:flex-end}
.hero-services span em{font-style:normal;color:var(--terra);font-size:.42rem}
/* hero CTAs — the visible next step, above the fold */
.hero-cta{display:flex;align-items:center;gap:1rem;margin:1.4rem 0 .4rem;flex-wrap:wrap}
.btn-pri{font-family:var(--mono);font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;background:var(--fg);color:var(--bg);padding:1rem 1.5rem;display:inline-flex;align-items:center;gap:.6rem;transition:background .3s,transform .3s var(--ease-out)}
.btn-pri:hover{background:var(--terra);color:var(--cream);transform:translateY(-2px)}
.btn-pri span{transition:transform .3s}
.btn-pri:hover span{transform:translateX(4px)}
.btn-sec{font-family:var(--mono);font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--fg);border:1px solid var(--line-c);padding:1rem 1.5rem;display:inline-flex;align-items:center;gap:.6rem;transition:border-color .3s,color .3s}
.btn-sec:hover{border-color:var(--terra);color:var(--terra)}
.hero-cta-note{font-family:var(--mono);font-size:.46rem;letter-spacing:.26em;text-transform:uppercase;color:var(--fg-mute)}

/* sticky brief pill — mobile only, appears once the journey starts */
.fly-cta{position:fixed;right:1rem;bottom:3.4rem;z-index:260;font-family:var(--mono);font-size:.55rem;letter-spacing:.26em;text-transform:uppercase;background:var(--terra);color:var(--cream);padding:.95rem 1.3rem;border-radius:999px;display:none;align-items:center;gap:.5rem;box-shadow:0 8px 28px rgba(14,14,12,.32);opacity:0;transform:translateY(12px);transition:opacity .45s ease,transform .45s var(--ease-out)}
.fly-cta.on{opacity:1;transform:none}
@media (max-width:980px){.fly-cta{display:inline-flex;pointer-events:none}.fly-cta.on{pointer-events:auto}}

.hero-scroll{position:absolute;right:var(--pad);bottom:7.2rem;z-index:4;font-family:var(--mono);font-size:.46rem;letter-spacing:.32em;text-transform:uppercase;color:var(--fg-mute);display:flex;flex-direction:column;align-items:center;gap:.7rem;writing-mode:vertical-rl}
.hero-scroll span{width:1px;height:46px;background:var(--line-c);position:relative;overflow:hidden;writing-mode:horizontal-tb}
.hero-scroll span::after{content:"";position:absolute;left:0;top:-100%;width:1px;height:100%;background:var(--terra);animation:scrollHint 2.2s var(--ease) infinite}
@keyframes scrollHint{0%{top:-100%}55%{top:0}100%{top:100%}}

/* ---------- Route ribbon (the journey, leg by leg) ---------- */
.route{position:relative;background:var(--dark);color:var(--on-dark);border-top:1px solid var(--on-dark-line);border-bottom:1px solid var(--on-dark-line);padding:2.4rem var(--pad) 3rem;transition:background-color .7s ease;overflow:hidden}
.route-cap{font-family:var(--mono);font-size:.46rem;letter-spacing:.36em;text-transform:uppercase;color:var(--on-dark-mute);display:flex;justify-content:space-between;margin-bottom:1.6rem}
.route-cap b{font-weight:400;color:var(--terra)}
.route-board{position:relative;height:96px}
.route-svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.route-stop{position:absolute;transform:translate(-50%,0);display:flex;flex-direction:column;align-items:center;gap:.55rem;background:none;border:none;padding:.4rem .2rem;font-family:var(--mono);text-transform:uppercase;color:var(--on-dark-soft);transition:color .3s}
.route-stop em{font-style:normal;font-size:.42rem;letter-spacing:.3em;color:var(--on-dark-mute);transition:color .3s}
.route-stop b{font-weight:400;font-size:.52rem;letter-spacing:.3em;white-space:nowrap}
.route-stop:hover,.route-stop.lit{color:var(--terra)}
.route-stop:hover em,.route-stop.lit em{color:var(--terra)}
.route-stop.term b{font-family:var(--serif);font-size:1.05rem;font-style:italic;letter-spacing:0;text-transform:none}
.route-hint{position:absolute;right:0;bottom:-1.6rem;font-family:var(--mono);font-size:.42rem;letter-spacing:.3em;text-transform:uppercase;color:var(--on-dark-mute)}
@media (max-width:980px){
  .route{padding:2rem var(--pad) 2.6rem}
  .route-board{height:84px}
  .route-stop b{font-size:.44rem;letter-spacing:.2em}
  .route-hint{display:none}
}
@media (max-width:560px){
  .route-stop b{display:none}
  .route-stop em{font-size:.5rem}
}

/* ---------- Manifesto (pinned ignition) ---------- */
.manif{height:300vh;position:relative}
.manif-pin{position:sticky;top:0;height:100vh;height:100svh;display:flex;align-items:center;border-bottom:var(--line);background:var(--bg);transition:background-color .7s ease}
.manif-w{max-width:var(--max);margin:0 auto;width:100%;padding:0 var(--pad);display:grid;grid-template-columns:1fr 2.4fr;gap:4rem;align-items:start}
.manif-l{font-family:var(--mono);font-size:.5rem;letter-spacing:.42em;text-transform:uppercase;color:var(--fg-mute)}
.manif-q{font-family:var(--serif);font-size:clamp(1.7rem,3.8vw,3.6rem);font-weight:300;line-height:1.22;letter-spacing:-.02em;color:var(--fg);font-variation-settings:"opsz" 72}
.manif-q span{opacity:.13;transition:opacity .45s ease,color .45s ease;will-change:opacity}
.manif-q span.lit{opacity:1}
.manif-q .acc{font-style:italic}
.manif-q .ign{font-style:italic;color:var(--fg)}
.manif-q .ign.lit{color:var(--terra)}
html.no-js .manif{height:auto}
html.no-js .manif-pin{position:static;height:auto;padding:7rem 0}
html.no-js .manif-q span{opacity:1}

/* ---------- CH.01 The System ---------- */
.svc{background:var(--dark);color:var(--on-dark);padding:8rem var(--pad) 7rem;position:relative;transition:background-color .7s ease}
.svc .slate{color:var(--on-dark-mute)}
.svc .slate span:nth-child(2){color:var(--on-dark-soft)}
.svc .slate::after{background:var(--on-dark-line)}
.svc-h{font-family:var(--serif);font-size:clamp(2.4rem,5.4vw,5.2rem);font-weight:300;line-height:.98;letter-spacing:-.026em;margin-bottom:1.6rem;max-width:18ch;font-variation-settings:"opsz" 72}
.svc-h em{font-style:italic;font-weight:300;color:var(--terra)}
.svc-sub{font-size:.8rem;line-height:1.9;color:var(--on-dark-soft);max-width:52ch;margin-bottom:5rem}
.legs{max-width:var(--max);margin:0 auto;display:flex;flex-direction:column;gap:6.5rem}
.leg{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.leg.flip .leg-vis{order:2}
.leg.flip .leg-body{order:1}
.leg-vis{position:relative;border:1px solid var(--on-dark-line);background:var(--dark-2);transition:border-color .5s ease,background-color .7s ease}
.leg:hover .leg-vis{border-color:rgba(242,235,221,.3)}
.leg-c{width:100%;aspect-ratio:4/3;display:block}
.leg-fig{position:absolute;left:0;right:0;bottom:-1.7rem;font-family:var(--mono);font-size:.44rem;letter-spacing:.3em;text-transform:uppercase;color:var(--on-dark-mute);display:flex;align-items:center;gap:.6rem}
.leg-fig::before{content:"";width:14px;height:1px;background:var(--terra)}
.leg-no{font-family:var(--mono);font-size:.5rem;letter-spacing:.34em;text-transform:uppercase;color:var(--terra);margin-bottom:1.3rem}
.leg-t{font-family:var(--serif);font-size:clamp(1.9rem,3.6vw,3.3rem);font-weight:400;line-height:1;letter-spacing:-.025em;color:var(--on-dark);margin-bottom:1.4rem;font-variation-settings:"opsz" 54}
.leg-t em{font-style:italic;font-weight:300}
.leg:hover .leg-t em{color:var(--terra);transition:color .4s}
.leg-d{font-size:.8rem;line-height:1.9;color:var(--on-dark-soft);max-width:50ch;margin-bottom:1.6rem}
.leg-d strong{color:var(--on-dark);font-weight:500}
.leg-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.8rem}
.leg-tags span{font-family:var(--mono);font-size:.45rem;letter-spacing:.22em;text-transform:uppercase;color:var(--on-dark-mute);border:1px solid var(--on-dark-line);padding:.34rem .7rem;transition:color .3s,border-color .3s}
.leg:hover .leg-tags span{color:var(--on-dark-soft);border-color:rgba(242,235,221,.3)}
.leg-a{font-family:var(--mono);font-size:.52rem;letter-spacing:.32em;text-transform:uppercase;color:var(--on-dark);display:inline-flex;align-items:center;gap:.5rem;border-bottom:1px solid var(--on-dark-line);padding-bottom:.4rem;transition:color .3s,border-color .3s}
.leg-a:hover{color:var(--terra);border-color:var(--terra)}
.leg-a span{transition:transform .35s var(--ease-out)}
.leg-a:hover span{transform:translate(3px,-3px)}

/* ---------- CH.02 Work ---------- */
.wk{background:var(--bg-2);padding:8rem var(--pad);transition:background-color .7s ease}
.wk-h{display:grid;grid-template-columns:1.3fr 1fr;gap:4rem;align-items:end;margin-bottom:4.5rem}
.wk-h h2{font-family:var(--serif);font-size:clamp(2.5rem,5.4vw,5.2rem);font-weight:300;line-height:.98;letter-spacing:-.035em;font-variation-settings:"opsz" 72;color:var(--fg)}
.wk-h h2 em{font-style:italic;font-weight:300;color:var(--terra)}
.wk-h p{font-size:.82rem;line-height:1.9;color:var(--fg-soft);max-width:38ch;justify-self:end}
.wk-g{display:grid;grid-template-columns:repeat(12,1fr);gap:1.4rem;max-width:var(--max);margin:0 auto}
.wk-i{position:relative;overflow:hidden;display:flex;flex-direction:column}
.wk-i.w7{grid-column:span 7}.wk-i.w5{grid-column:span 5}
.wk-i.w8{grid-column:span 8}.wk-i.w4{grid-column:span 4}
.wk-i.w6{grid-column:span 6}
.wk-img{aspect-ratio:4/3;overflow:hidden;position:relative;background:var(--bg-3)}
.wk-i.w7 .wk-img,.wk-i.w8 .wk-img{aspect-ratio:16/10}
.wk-i.w5 .wk-img,.wk-i.w4 .wk-img{aspect-ratio:4/5}
.wk-img img{width:100%;height:103%;object-fit:cover;transition:transform 1.3s var(--ease-out),filter 1.1s;filter:saturate(.7) contrast(.97) brightness(.97);will-change:transform}
.wk-i:hover .wk-img img{transform:scale(1.05);filter:saturate(1) contrast(1) brightness(1)}
.wk-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(14,14,12,.5) 100%);opacity:.45;transition:opacity .55s}
.wk-i:hover .wk-img::after{opacity:.7}
.wk-file{position:absolute;top:.9rem;right:.9rem;z-index:2;font-family:var(--mono);font-size:.44rem;letter-spacing:.26em;color:var(--cream);background:rgba(14,14,12,.55);padding:.4rem .65rem;backdrop-filter:blur(4px);opacity:0;transform:translateY(-4px);transition:opacity .45s,transform .45s}
.wk-i:hover .wk-file{opacity:1;transform:none}
.wk-meta{padding:1.3rem 0 0;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}
.wk-cat{font-family:var(--mono);font-size:.46rem;letter-spacing:.32em;text-transform:uppercase;color:var(--fg-mute);margin-bottom:.5rem}
.wk-t{font-family:var(--serif);font-size:clamp(1.15rem,1.85vw,1.55rem);font-weight:400;font-style:italic;line-height:1.2;color:var(--fg);font-variation-settings:"opsz" 54}
.wk-y{font-family:var(--mono);font-size:.46rem;letter-spacing:.28em;color:var(--fg-mute);padding-top:.4rem}

/* ---------- Departure board ---------- */
.brd{background:var(--dark);color:var(--on-dark);padding:4.5rem var(--pad);border-top:1px solid var(--on-dark-line);transition:background-color .7s ease}
.brd-head{display:grid;grid-template-columns:1fr 2fr 1.2fr 1.2fr;gap:1.5rem;font-family:var(--mono);font-size:.46rem;letter-spacing:.34em;text-transform:uppercase;color:var(--on-dark-mute);padding-bottom:1rem;border-bottom:1px solid var(--on-dark-line)}
.brd-row{display:grid;grid-template-columns:1fr 2fr 1.2fr 1.2fr;gap:1.5rem;align-items:center;padding:1.5rem 0;border-bottom:1px solid var(--on-dark-line);font-family:var(--mono);font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--on-dark-soft);position:relative;overflow:hidden}
.brd-row::before{content:"";position:absolute;left:0;top:0;height:100%;width:100%;background:linear-gradient(90deg,rgba(196,128,107,.12),transparent 55%);transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease)}
.brd-row:hover::before{transform:scaleX(1)}
.brd-row b{font-weight:500;color:var(--on-dark);font-size:1.5rem;letter-spacing:.12em;line-height:1;display:flex;gap:.06em}
.brd-row .ok{color:var(--terra);font-size:.52rem}
.roll-col{display:inline-block;overflow:hidden;height:1.5rem;line-height:1.5rem}
.roll-strip{display:flex;flex-direction:column;transform:translateY(0);will-change:transform}
.roll-strip span{height:1.5rem;line-height:1.5rem;display:block}

/* ---------- CH.03 Studio ---------- */
.abt{background:var(--bg-2);padding:8rem var(--pad);transition:background-color .7s ease}
.abt-w{display:grid;grid-template-columns:5fr 6fr;gap:5.5rem;align-items:start}
.abt-h{font-family:var(--serif);font-size:clamp(2.3rem,4.8vw,4.6rem);font-weight:300;line-height:1;letter-spacing:-.024em;color:var(--fg);margin-bottom:2.4rem;font-variation-settings:"opsz" 72}
.abt-h em{font-style:italic;font-weight:300;color:var(--terra)}
.abt-q{font-family:var(--serif);font-size:clamp(1.05rem,1.8vw,1.45rem);font-weight:400;font-style:italic;line-height:1.5;color:var(--fg);border-left:2px solid var(--terra);padding-left:1.4rem;margin-bottom:2.4rem;font-variation-settings:"opsz" 54}
.abt-b{font-size:.82rem;line-height:1.95;color:var(--fg-soft)}
.abt-b p{margin-bottom:1.3rem}
.abt-b strong{color:var(--fg);font-weight:500}
.fdrs{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin-top:3rem}
.fdr{border-top:var(--line);padding-top:1.2rem}
.fdr-n{font-family:var(--serif);font-size:1.7rem;font-weight:400;font-style:italic;color:var(--fg);margin-bottom:.25rem;font-variation-settings:"opsz" 54}
.fdr-r{font-family:var(--mono);font-size:.48rem;letter-spacing:.28em;text-transform:uppercase;color:var(--fg-mute)}
.abt-img{position:relative;width:100%;aspect-ratio:4/5;overflow:hidden;background:var(--ink-3)}
.abt-img img{width:100%;height:106%;object-fit:cover;filter:saturate(.78) contrast(1.02);will-change:transform}
.abt-cap{position:absolute;left:1.2rem;bottom:1.2rem;font-family:var(--mono);font-size:.46rem;letter-spacing:.32em;text-transform:uppercase;color:var(--cream)}
.abt-cap::before{content:"";display:inline-block;width:18px;height:1px;background:var(--terra);margin-right:.6rem;vertical-align:middle}

/* ---------- Journal ---------- */
.jrn{background:var(--bg);padding:8rem var(--pad);border-top:var(--line);transition:background-color .7s ease}
.jrn-h{display:flex;justify-content:space-between;align-items:end;margin-bottom:4rem;flex-wrap:wrap;gap:1rem}
.jrn-h h2{font-family:var(--serif);font-size:clamp(2.3rem,4.8vw,4.4rem);font-weight:300;line-height:.96;letter-spacing:-.035em;font-variation-settings:"opsz" 72;color:var(--fg)}
.jrn-h h2 em{font-style:italic;font-weight:300;color:var(--terra)}
.jrn-cta{font-family:var(--mono);font-size:.55rem;letter-spacing:.32em;text-transform:uppercase;color:var(--fg);border-bottom:1px solid var(--fg);padding-bottom:.32rem;transition:color .3s,border-color .3s}
.jrn-cta:hover{color:var(--terra);border-color:var(--terra)}
.jrn-g{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem}
.jrn-c{padding:1.4rem 0 0;border-top:1px solid var(--line-c);position:relative}
.jrn-c::before{content:"";position:absolute;top:-1px;left:0;width:0;height:1px;background:var(--terra);transition:width .65s var(--ease)}
.jrn-c:hover::before{width:100%}
.jrn-meta{display:flex;justify-content:space-between;font-family:var(--mono);font-size:.45rem;letter-spacing:.28em;text-transform:uppercase;color:var(--fg-mute);margin-bottom:.9rem}
.jrn-t{font-family:var(--serif);font-size:clamp(1.25rem,1.95vw,1.75rem);font-weight:400;line-height:1.2;letter-spacing:-.014em;color:var(--fg);margin-bottom:1.1rem;font-variation-settings:"opsz" 54;transition:color .35s}
.jrn-c:hover .jrn-t{color:var(--terra)}
.jrn-d{font-size:.74rem;line-height:1.85;color:var(--fg-soft);margin-bottom:1.6rem}
.jrn-r{font-family:var(--mono);font-size:.45rem;letter-spacing:.32em;text-transform:uppercase;color:var(--fg);display:flex;align-items:center;gap:.5rem;transition:color .35s}
.jrn-c:hover .jrn-r{color:var(--terra)}

/* ---------- CH.04 Everywhere ---------- */
.ct{background:var(--dark);color:var(--on-dark);padding:8rem var(--pad) 7rem;position:relative;overflow:hidden;transition:background-color .7s ease}
#map-c{position:absolute;inset:0;width:100%;height:100%;opacity:.7;z-index:0}
.ct-w{position:relative;z-index:1}
.ct-grid{display:grid;grid-template-columns:5fr 6fr;gap:5rem;align-items:start}
.ct-h{font-family:var(--serif);font-size:clamp(3rem,7.4vw,7.2rem);font-weight:300;line-height:.92;letter-spacing:-.028em;color:var(--on-dark);margin-bottom:2.4rem;font-variation-settings:"opsz" 72}
.ct-h em{font-style:italic;font-weight:300;color:var(--terra)}
.ct-sub{font-family:var(--mono);font-size:.55rem;letter-spacing:.32em;text-transform:uppercase;color:var(--on-dark-soft);margin-bottom:3rem;line-height:2.2;max-width:40ch}
.ct-pts{display:flex;flex-direction:column;border-top:1px solid var(--on-dark-line)}
.ct-pt{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--on-dark-line);padding:1.2rem 0;gap:1rem}
.ct-pt-l{font-family:var(--mono);font-size:.5rem;letter-spacing:.32em;text-transform:uppercase;color:var(--on-dark-mute)}
.ct-pt-v{font-family:var(--serif);font-size:1.1rem;font-style:italic;color:var(--on-dark);font-variation-settings:"opsz" 54;text-align:right}
.ct-pt-v a{transition:color .3s}.ct-pt-v a:hover{color:var(--terra)}
.ct-f{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--on-dark-line);position:relative}
.ct-fg{display:flex;flex-direction:column;border-bottom:1px solid var(--on-dark-line);padding:1.5rem 0;transition:border-color .4s}
.ct-fg:focus-within{border-bottom-color:var(--terra)}
.ct-fg.full{grid-column:span 2}
.ct-fg.half:first-of-type{border-right:1px solid var(--on-dark-line);padding-right:1.4rem}
.ct-fg.half:nth-of-type(2){padding-left:1.4rem}
.ct-fg label{font-family:var(--mono);font-size:.45rem;letter-spacing:.32em;text-transform:uppercase;color:var(--on-dark-mute);margin-bottom:.7rem;display:flex;align-items:center;gap:.4rem}
.ct-fg label em{font-style:normal;color:var(--terra);opacity:.8}
.ct-fg input,.ct-fg textarea,.ct-fg select{background:transparent;border:none;padding:0;font-family:var(--serif);font-size:1.05rem;color:var(--on-dark);outline:none;resize:none;width:100%;font-style:italic;font-weight:400;font-variation-settings:"opsz" 18}
.ct-fg input::placeholder,.ct-fg textarea::placeholder{color:rgba(242,235,221,.26);font-style:italic}
.ct-fg input:-webkit-autofill{-webkit-text-fill-color:var(--cream);transition:background-color 9999s ease-in-out 0s}
.ct-fg select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,rgba(242,235,221,.5) 50%),linear-gradient(135deg,rgba(242,235,221,.5) 50%,transparent 50%);background-position:calc(100% - 12px) 50%,calc(100% - 7px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:24px}
.ct-fg select option{background:var(--ink);color:var(--cream);font-style:normal}
.ct-hp{position:absolute;left:-9999px;top:-9999px;height:1px;width:1px;overflow:hidden}
.ct-btn{grid-column:span 2;background:transparent;border:none;border-bottom:1px solid var(--on-dark-line);padding:1.7rem 0;display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:.6rem;letter-spacing:.36em;text-transform:uppercase;color:var(--on-dark);transition:color .35s,padding .35s}
.ct-btn:hover:not(:disabled){color:var(--terra);padding-left:1rem}
.ct-btn:disabled{opacity:.5}
.ct-btn b{font-weight:400;display:flex;align-items:center;gap:.4rem}
.ct-btn b::before{content:"06";font-size:.46rem;letter-spacing:.32em;opacity:.4}
.ct-btn span:last-child{font-size:1.4rem;letter-spacing:0;transition:transform .35s}
.ct-btn:hover:not(:disabled) span:last-child{transform:translateX(.6rem)}
.ct-msg{grid-column:span 2;font-family:var(--mono);font-size:.5rem;letter-spacing:.2em;text-transform:uppercase;text-align:center;padding:.9rem 0 0;min-height:2rem;opacity:0;transition:opacity .5s}
.ct-msg.show{opacity:1}.ct-msg.ok{color:var(--terra)}.ct-msg.er{color:#E8838F}

/* ---------- Footer ---------- */
footer{background:var(--dark);color:var(--on-dark-mute);padding:1.8rem var(--pad);border-top:1px solid var(--on-dark-line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-family:var(--mono);font-size:.46rem;letter-spacing:.3em;text-transform:uppercase;transition:background-color .7s ease}
footer a,#theme-btn{transition:color .3s;letter-spacing:inherit;font-size:inherit;text-transform:inherit;font-family:inherit}
footer a:hover,#theme-btn:hover{color:var(--cream)}
#theme-btn{border-bottom:1px solid var(--on-dark-line);padding-bottom:.15rem}
.ft-route{color:var(--on-dark-mute)}

/* ---------- Glossy metal accents ---------- */
/* gradient-filled type: the rose gold reads as polished metal, not flat tint */
.hero-sf em,.hero-eb em,.wk-h h2 em,.abt-h em,.jrn-h h2 em,.manif-q .ign.lit{
  background-image:var(--metal);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.svc-h em,.ct-h em,.leg:hover .leg-t em{
  background-image:var(--metal-lt);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.btn-pri:hover{background:var(--metal);color:var(--ink)}
.fly-cta{
  background:var(--metal);color:var(--ink);
  box-shadow:0 8px 28px rgba(14,14,12,.32),inset 0 1px 0 rgba(255,255,255,.4),inset 0 -1px 0 rgba(14,14,12,.18);
}

/* ---------- Conversion affordances + render perf ---------- */
.wk-i{cursor:pointer}
.wk-y{transition:color .35s}
.wk-i:hover .wk-y,.wk-i:focus-visible .wk-y{color:var(--terra)}
.wk-i:focus-visible{outline:1px dashed var(--terra);outline-offset:6px}
.jrn-r{border-bottom:1px solid transparent;padding-bottom:.2rem;transition:border-color .3s}
.jrn-c:hover .jrn-r{border-color:var(--terra)}
@keyframes fieldPulse{0%,100%{border-bottom-color:var(--on-dark-line)}40%{border-bottom-color:var(--terra)}}
.ct-fg.pulse{animation:fieldPulse 1.1s ease 2}
/* below-the-fold sections render lazily — big first-paint win on mobile */
.wk,.abt,.jrn,.brd{content-visibility:auto;contain-intrinsic-size:auto 900px}

/* ---------- Reveal system ---------- */
html.js .rv{opacity:0;transform:translateY(34px)}
html.js .rv.on{opacity:1;transform:none;transition:opacity 1s var(--ease-out),transform 1s var(--ease-out)}
html.js .rv.d2.on{transition-delay:.08s}
html.js .rv.d3.on{transition-delay:.16s}

/* ---------- 404 ---------- */
.p404{min-height:100vh;min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.6rem;text-align:center;padding:2rem;background:var(--bg);color:var(--fg)}
.p404-code{font-family:var(--mono);font-size:.55rem;letter-spacing:.42em;text-transform:uppercase;color:var(--terra)}
.p404 h1{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(2.6rem,8vw,6rem);line-height:1;letter-spacing:-.03em;font-variation-settings:"opsz" 72}
.p404 p{font-family:var(--mono);font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;color:var(--fg-mute);line-height:2.2;max-width:46ch}

/* ---------- Reduced motion (media query OR html.reduced set by JS/?still=1) ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .manif{height:auto}
  .manif-pin{position:static;height:auto;padding:7rem 0}
  .manif-q span{opacity:1!important}
  html.js .rv{opacity:1;transform:none}
  .hero-scroll{display:none}
}
html.reduced .manif{height:auto}
html.reduced .manif-pin{position:static;height:auto;padding:7rem 0}
html.reduced .manif-q span{opacity:1!important}
html.reduced .rv{opacity:1!important;transform:none!important;transition:none!important}
html.reduced .hud{transition:none}
html.reduced .cur,html.reduced .cur-r,html.reduced .hero-scroll{display:none}
html.reduced #ld{transition-duration:.05s}

/* ---------- Short viewports: keep the hero stack clear of the status bar ---------- */
@media (max-height:820px) and (min-width:981px){
  .hero-h{font-size:clamp(3.6rem,13.8vw,13.5rem)}
  .hero-sf{font-size:clamp(.98rem,1.35vw,1.2rem);margin-top:.7rem}
  .hero-meta{padding:.9rem 0 .7rem}
  .hero-cta{margin:1rem 0 .3rem}
  .hero-services{padding-bottom:2.4rem}
}

/* ---------- Tablet & mobile ---------- */
@media (max-width:1080px){
  .leg{grid-template-columns:1fr;gap:2.6rem}
  .leg.flip .leg-vis{order:0}
  .leg.flip .leg-body{order:1}
  .leg-fig{position:static;margin-top:.8rem}
  .ct-grid{grid-template-columns:1fr;gap:3.5rem}
}
@media (max-width:980px){
  .nav-u,.nav-cta{display:none}.nav-ham{display:block}
  .hero-bar{padding:4.2rem var(--pad) 0}
  .hero-bar div:nth-child(3){display:none}
  .hero-scroll{display:none}
  .cur-hint{display:none}                /* no cursor on touch — reclaim the space */
  .hero-eb{margin-bottom:.8rem}
  .hero-sf{font-size:.94rem;line-height:1.5}
  .hero-cta{margin-top:1rem}
  .hero-cta-note{display:block;width:100%}
  .hero-services{flex-wrap:wrap;gap:.5rem;border-top:0}
  .hero-services span{flex:1 1 28%;border-right:0;border-bottom:var(--line);text-align:left;justify-content:flex-start}
  .manif-w{grid-template-columns:1fr;gap:1.6rem}
  .svc,.wk,.abt,.jrn,.ct{padding:5rem var(--pad)}
  .wk-h{grid-template-columns:1fr;gap:1.6rem}
  .wk-h p{justify-self:start}
  .wk-g{grid-template-columns:1fr;gap:2.4rem}
  .wk-i.w7,.wk-i.w5,.wk-i.w8,.wk-i.w4,.wk-i.w6{grid-column:span 1}
  .wk-i.w5 .wk-img,.wk-i.w4 .wk-img{aspect-ratio:4/3}
  .brd-head{display:none}
  .brd-row{grid-template-columns:1fr 1fr;gap:.8rem .6rem;font-size:.55rem}
  .brd-row b{font-size:1.2rem}
  .abt-w{grid-template-columns:1fr;gap:3rem}
  .jrn-g{grid-template-columns:1fr;gap:1.2rem}
  .ct-fg.half{grid-column:span 2;border-right:0!important;padding-left:0!important;padding-right:0!important}
  .hud{grid-template-columns:1fr 1.2fr;gap:1rem;padding:.7rem var(--pad)}
  .hud-geo{display:none}
  .slate{flex-wrap:wrap;row-gap:.4rem}
  footer{flex-direction:column;align-items:flex-start;gap:.7rem;padding-bottom:3.4rem}
}
@media (max-width:560px){
  .hero-h{font-size:clamp(2.9rem,15.5vw,7rem)}
  .hero-meta-r{text-align:left}
  .legs{gap:5rem}
  /* front-page tidy-up: one-line eyebrow, single status row, clean strip */
  .eb-cpt{display:none}
  .hero-eb{font-size:.5rem;letter-spacing:.24em;flex-wrap:nowrap;white-space:nowrap}
  #ct-time{display:none}
  .hero-sf{font-size:.9rem}
  .btn-sec{border-color:transparent;border-bottom:1px solid var(--line-c);padding:.8rem .2rem}
  .hero-cta{gap:.9rem 1.4rem}
  .hero-services{font-size:.44rem;letter-spacing:.2em;padding-bottom:3.6rem;row-gap:.2rem}
  .hero-services span{flex:1 1 46%;white-space:nowrap;overflow:hidden}
}
