/* ============================================================
   LUNA LXD — design system v2  ·  "Mission Control Editorial"
   Deep-space cinematic. Warm cosmic gradient, reserved.
   Poppins display · Inter body · Space Mono flight data.
   ============================================================ */

/* ---------- 0 · Tokens ---------- */
:root{
  /* brand core */
  --amber:#FFBD59; --coral:#FF784D; --pink:#FF66C4;
  --space:#0E0E14; --white:#FFFFFF;
  --mist:#FAF8F6; --ink:#15151B; --comet:#ABABB9; /* dark-context value */ --stardust:#ECE7E2;
  --cosmic:linear-gradient(110deg,#FFBD59 0%,#FF784D 52%,#FF66C4 100%);
  --cosmic-soft:linear-gradient(110deg,rgba(255,189,89,.16),rgba(255,120,77,.16) 52%,rgba(255,102,196,.16));
  /* dark-surface system */
  --panel:#14141D; --panel-2:#1A1A25;
  --edge:rgba(255,255,255,.09); --edge-hi:rgba(255,255,255,.16);
  --t-hi:#F6F5FA; --t-body:#B9B9C7; --t-dim:#8F8FA0;
  --comet:#A9A9B8; --comet-dk:#8F8FA0; --mono:var(--f-mono);
  /* light-surface system */
  --edge-lt:#E7E2DC;
  --comet-dk:#A9A9B8;
  --mono:var(--f-mono); --disp:var(--f-disp); --body:var(--f-body);
  /* type */
  --f-disp:"Poppins",system-ui,sans-serif;
  --f-body:"Inter",system-ui,sans-serif;
  --f-mono:"Space Mono",ui-monospace,monospace;
  --fs-hero:clamp(2.7rem,7.2vw,5.15rem);
  --fs-h1:clamp(2.45rem,5.6vw,4.1rem);
  --fs-h2:clamp(1.95rem,4.2vw,3.1rem);
  --fs-h3:clamp(1.3rem,2.3vw,1.7rem);
  --fs-lead:clamp(1.08rem,1.6vw,1.28rem);
  /* rhythm */
  --wrap:1180px; --gut:clamp(20px,5vw,48px);
  --sp-sec:clamp(88px,11vw,150px);
  --sp-tight:clamp(56px,7vw,92px);
  --r-card:16px; --r-dev:20px;
  --ease:cubic-bezier(.22,.75,.25,1);
  --shadow-1:0 14px 40px rgba(4,4,10,.45);
  --shadow-2:0 30px 80px rgba(4,4,10,.55);
}

/* ---------- 1 · Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
html:focus-within{scroll-behavior:smooth}
body{
  margin:0; background:var(--space); color:var(--t-body);
  font-family:var(--f-body);
  font-size:clamp(17px,1.12vw,18px); line-height:1.75;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--f-disp);color:var(--t-hi);margin:0;font-weight:700;letter-spacing:-.02em;text-wrap:balance}
h1 b,h2 b{font-weight:inherit;background:var(--cosmic);-webkit-background-clip:text;background-clip:text;color:transparent}
h1{font-size:var(--fs-h1);line-height:1.02;letter-spacing:-.03em}
h2,.h2{font-size:var(--fs-h2);line-height:1.06;letter-spacing:-.025em}
h3,.h3{font-size:var(--fs-h3);line-height:1.22;font-weight:600}
h4{font-size:1.06rem;line-height:1.35;font-weight:600;letter-spacing:-.01em}
p{margin:0}
a{color:inherit;text-decoration:none}
::selection{background:rgba(255,120,77,.85);color:#0B0B10}
:focus{outline:none}
:focus-visible{outline:2px solid var(--amber);outline-offset:3px;border-radius:4px}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
}

/* view transitions (cross-document, progressive) */
@view-transition{navigation:auto}
::view-transition-old(root){animation:vt-out .26s var(--ease) both}
::view-transition-new(root){animation:vt-in .34s var(--ease) both}
@keyframes vt-out{to{opacity:0;transform:translateY(-8px)}}
@keyframes vt-in{from{opacity:0;transform:translateY(10px)}}
html.no-vt body{animation:page-in .5s var(--ease) both}
@keyframes page-in{from{opacity:0;transform:translateY(8px)}}

/* skip link */
.skip{position:fixed;left:16px;top:-60px;z-index:200;background:var(--cosmic);color:#141018;font:600 .85rem/1 var(--f-body);padding:12px 18px;border-radius:999px;transition:top .25s var(--ease)}
.skip:focus-visible{top:14px}

/* ---------- 2 · Utilities ---------- */
.wrap{width:min(var(--wrap),100% - var(--gut)*2);margin-inline:auto}
.lift{position:relative;z-index:2}
.measure{max-width:62ch}
.flow>*+*{margin-top:1em}
.center{text-align:center}
.mt-m{margin-top:28px}
.grid{display:grid;gap:22px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.grad-text{background:var(--cosmic);-webkit-background-clip:text;background-clip:text;color:transparent}
.mono-label{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--t-dim)}
.lite .mono-label{color:var(--comet)}
.lead{font-size:var(--fs-lead);line-height:1.62;color:var(--t-body)}
.lite .lead{color:var(--comet)}

/* eyebrow — the ◀ signpost */
.eyebrow{display:inline-flex;align-items:center;gap:11px;font-family:var(--f-mono);font-size:.8rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--t-dim)}
.eyebrow::before{content:"";width:9px;height:11px;flex:none;background:linear-gradient(120deg,var(--coral),var(--pink));clip-path:polygon(100% 0,100% 100%,0 50%)}
.lite .eyebrow{color:var(--comet)}

/* crumbs */
.crumb{display:flex;flex-wrap:wrap;gap:10px;align-items:center;font-family:var(--f-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--t-dim);margin-bottom:26px}
.crumb a{color:var(--t-dim);border-bottom:1px solid transparent;transition:color .2s,border-color .2s}
.crumb a:hover{color:var(--t-hi);border-color:var(--coral)}
.crumb span:last-child{color:var(--t-body)}

/* text link */
.textlink{position:relative;display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--t-hi);padding-bottom:3px}
.textlink::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;background:var(--cosmic);transform:scaleX(.28);transform-origin:left;transition:transform .35s var(--ease)}
.textlink:hover::after{transform:scaleX(1)}
.textlink .arr{transition:transform .3s var(--ease)}
.textlink:hover .arr{transform:translateX(5px)}
.lite .textlink{color:var(--ink)}

.btn svg,.textlink svg,.read svg,.pf-go svg,.svc-go svg,.a-back svg,.pn svg{width:17px;height:17px;stroke:currentColor;fill:none;flex:none;transition:transform .3s var(--ease)}
.textlink:hover svg,.post:hover .read svg,.pf-tile:hover .pf-go svg,.svc-card:hover .svc-go svg,.btn--grad:hover svg{transform:translateX(4px)}

/* ---------- 3 · Atmosphere (injected by JS into [data-starfield], .pintro, .hero, .cta-band) ---------- */
.sky{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.sky-layer{position:absolute;inset:-14% -6%;will-change:transform}
.stars-a,.stars-b{background-repeat:repeat}
.stars-a{background-image:radial-gradient(1.1px 1.1px at 22% 34%,rgba(255,255,255,.75) 49%,transparent 51%),radial-gradient(1px 1px at 68% 12%,rgba(255,255,255,.5) 49%,transparent 51%),radial-gradient(1.2px 1.2px at 84% 66%,rgba(255,255,255,.65) 49%,transparent 51%),radial-gradient(.9px .9px at 40% 82%,rgba(255,255,255,.45) 49%,transparent 51%),radial-gradient(1px 1px at 8% 62%,rgba(255,255,255,.55) 49%,transparent 51%);background-size:520px 520px}
.stars-b{background-image:radial-gradient(1.6px 1.6px at 14% 22%,rgba(255,214,166,.8) 49%,transparent 51%),radial-gradient(1.4px 1.4px at 76% 44%,rgba(255,255,255,.85) 49%,transparent 51%),radial-gradient(1.7px 1.7px at 52% 78%,rgba(255,178,206,.7) 49%,transparent 51%),radial-gradient(1.3px 1.3px at 92% 8%,rgba(255,255,255,.7) 49%,transparent 51%);background-size:760px 760px;animation:twinkle 7s ease-in-out infinite alternate}
@keyframes twinkle{from{opacity:.55}to{opacity:1}}
.nebula{position:absolute;width:56vw;max-width:820px;aspect-ratio:1;border-radius:50%;filter:blur(70px);opacity:.5;background:radial-gradient(circle at 35% 35%,rgba(255,189,89,.5),rgba(255,120,77,.32) 42%,rgba(255,102,196,.2) 66%,transparent 75%)}
.orbit-arc{position:absolute;opacity:.5}
.orbit-arc ellipse,.orbit-arc circle{fill:none;stroke:rgba(255,255,255,.3);stroke-width:1.5;stroke-dasharray:3 9;vector-effect:non-scaling-stroke;animation:dash-drift 26s linear infinite}
@keyframes dash-drift{to{stroke-dashoffset:-240}}
.orbit-arc .tint{stroke:url(#luna-grad)}
.sky .mark-float{position:absolute;width:clamp(42px,5vw,64px);opacity:.9;animation:floaty 8s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-14px) rotate(3deg)}}
.grain{position:fixed;inset:-50%;z-index:90;pointer-events:none;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='.6'/%3E%3C/svg%3E")}
/* altitude / scroll progress */
.progress{position:fixed;top:0;left:0;height:3px;width:100%;z-index:120;transform-origin:left;transform:scaleX(0);background:var(--cosmic)}

/* ---------- 4 · Header ---------- */
.site-head{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .35s,box-shadow .35s}
.site-head::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--cosmic);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.site-head.scrolled{background:rgba(12,12,18,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 8px 30px rgba(0,0,0,.35)}
.site-head.scrolled::after{transform:scaleX(1)}
.head-in{display:flex;align-items:center;justify-content:space-between;gap:20px;height:78px;transition:height .3s var(--ease)}
.site-head.scrolled .head-in{height:64px}
.brand{display:inline-flex;align-items:center}
.brand img{height:34px;width:auto;transition:height .3s var(--ease)}
.site-head.scrolled .brand img{height:29px}
.nav{display:flex;align-items:center;gap:clamp(16px,2.4vw,32px)}
.nav a{position:relative;font-size:.94rem;font-weight:500;color:var(--t-body);padding:8px 2px;transition:color .2s}
.nav a::after{content:"";position:absolute;left:0;right:0;bottom:2px;height:2px;background:var(--cosmic);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav a:hover{color:var(--t-hi)}
.nav a:hover::after,.nav a[aria-current="page"]::after{transform:scaleX(1)}
.nav a[aria-current="page"]{color:var(--t-hi)}
.nav .btn{margin-left:8px}
.burger{display:none;background:none;border:1px solid var(--edge);border-radius:10px;width:46px;height:46px;cursor:pointer;place-items:center}
.burger svg{width:20px;height:20px;stroke:var(--t-hi);stroke-width:2;fill:none;stroke-linecap:round}

/* drawer */
.drawer{position:fixed;inset:0;z-index:110;background:rgba(10,10,16,.96);backdrop-filter:blur(18px);display:grid;place-items:center;opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility 0s .35s}
.drawer.is-open{opacity:1;visibility:visible;transition:opacity .35s var(--ease)}
.drawer-in{display:grid;gap:6px;text-align:center}
.drawer-in a{font-family:var(--f-disp);font-size:clamp(1.7rem,6.5vw,2.5rem);font-weight:700;color:var(--t-hi);padding:8px 20px;letter-spacing:-.02em;display:inline-flex;gap:16px;align-items:baseline;justify-content:center;opacity:0;transform:translateY(18px);transition:opacity .5s var(--ease),transform .5s var(--ease),color .2s}
.drawer.is-open .drawer-in a{opacity:1;transform:none}
.drawer-in a i{font:700 .72rem var(--f-mono);letter-spacing:.16em;color:var(--t-dim);font-style:normal}
.drawer-in a:hover,.drawer-in a[aria-current="page"]{color:transparent;background:var(--cosmic);-webkit-background-clip:text;background-clip:text}
.drawer-x{position:absolute;top:22px;right:max(20px,calc((100vw - var(--wrap))/2));background:none;border:1px solid var(--edge);color:var(--t-hi);width:46px;height:46px;border-radius:50%;cursor:pointer;font-size:1.15rem}
.drawer-contact{margin-top:26px;font-family:var(--f-mono);font-size:.75rem;letter-spacing:.12em;color:var(--t-dim);text-transform:uppercase}

/* header CTA runs smaller */
.site-head .btn{padding:12px 22px;min-height:42px;font-size:.88rem}

/* ---------- 5 · Buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;font:600 .95rem/1 var(--f-body);padding:16px 28px;border-radius:999px;cursor:pointer;border:0;transition:transform .25s var(--ease),box-shadow .3s,color .2s;will-change:transform;min-height:48px}
.btn--grad{background:var(--cosmic);color:#161016;box-shadow:0 8px 26px rgba(255,120,77,.28)}
.btn--grad:hover{box-shadow:0 14px 40px rgba(255,120,77,.42)}
.btn--grad::before{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.5) 50%,transparent 70%);background-size:250% 100%;background-position:120% 0;transition:background-position .7s var(--ease);mix-blend-mode:soft-light}
.btn--grad:hover::before{background-position:-40% 0}
.btn--ghost{background:transparent;color:var(--t-hi);box-shadow:inset 0 0 0 1.5px var(--edge-hi)}
.btn--ghost:hover{box-shadow:inset 0 0 0 1.5px transparent;background:linear-gradient(var(--panel),var(--panel)) padding-box,var(--cosmic) border-box;border:1.5px solid transparent;padding:14.5px 26.5px}
.lite .btn--ghost{color:var(--ink);box-shadow:inset 0 0 0 1.5px #D8D2CA}
.lite .btn--ghost:hover{background:linear-gradient(var(--mist),var(--mist)) padding-box,var(--cosmic) border-box}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}

/* ---------- 6 · Sections ---------- */
.section{position:relative;padding-block:var(--sp-sec);background:var(--space)}
.section--tight{padding-block:var(--sp-tight)}
.section.dark{background:linear-gradient(180deg,#0C0C12,#111119 55%,#0C0C12)}
.section.lite{background:var(--mist);color:#6C6C77;--comet:#6C6C77;--comet-dk:#6C6C77}
.section.lite h1,.section.lite h2,.section.lite h3,.section.lite h4{color:var(--ink)}
.section+.section:not(.dark):not(.lite)::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:min(var(--wrap),100% - var(--gut)*2);height:1px;background:var(--edge)}
.sec-head{max-width:760px;margin-bottom:clamp(36px,5vw,60px)}
.sec-head .eyebrow{margin-bottom:16px}
.sec-head p{margin-top:18px}
.sec-num{font:700 clamp(1.5rem,3vw,2.3rem)/1 var(--f-mono);letter-spacing:.02em;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.22);user-select:none;white-space:nowrap}
.topline .sec-num{align-self:center}
.lite .sec-num{-webkit-text-stroke:1px #D9D2C9}
.topline{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}

/* pintro — inner-page hero */
.pintro{position:relative;padding:calc(78px + clamp(64px,9vw,120px)) 0 clamp(56px,7vw,92px);background:radial-gradient(120% 90% at 70% -10%,#191826 0%,var(--space) 60%)}
.pintro h1{max-width:16ch}
.pintro .lead{margin-top:22px}
.pintro .eyebrow{margin-bottom:18px}

/* ---------- 7 · Split / device ---------- */
.split{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,5fr);gap:clamp(30px,5vw,70px);align-items:center}
.split-media{position:relative}
.device{position:relative;border-radius:var(--r-dev);background:linear-gradient(160deg,#1C1C28,#12121B);border:1px solid var(--edge);box-shadow:var(--shadow-2);overflow:hidden;transform-style:preserve-3d}
.device .bar{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:1px solid var(--edge);background:rgba(255,255,255,.03)}
.device .bar i{width:10px;height:10px;border-radius:50%;background:#3A3A48;transition:background .35s}
.device:hover .bar i:nth-child(1){background:var(--amber)}
.device:hover .bar i:nth-child(2){background:var(--coral)}
.device:hover .bar i:nth-child(3){background:var(--pink)}
.device .u{margin-left:10px;font:400 .68rem var(--f-mono);letter-spacing:.06em;color:var(--t-dim);background:rgba(255,255,255,.05);border:1px solid var(--edge);border-radius:6px;padding:4px 10px;max-width:70%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.device .slide.lite{background:linear-gradient(160deg,#FFFDFB,#F2EEE9);--comet:#6C6C77}
.device .slide.lite .s-title{color:var(--ink)}
.device .slide.lite .s-eyebrow{color:#8A8A94}
.device .slide.lite .s-pill{color:#4C4C56;border-color:#DCD5CC}
.device .slide.lite .s-orbit{border-color:rgba(21,21,27,.16)}
.device .slide{position:relative;aspect-ratio:16/10.4;padding:clamp(18px,3vw,30px);overflow:hidden;background:radial-gradient(130% 120% at 20% 0%,#171622,#0F0F17 70%)}
/* mock internals */
.s-orbit{position:absolute;right:-70px;top:-70px;width:230px;height:230px;border:1.5px dashed rgba(255,255,255,.16);border-radius:50%;transform:rotate(14deg)}
.s-head{display:flex;align-items:center;gap:9px;margin-bottom:14px}
.s-head .sm{width:14px;height:14px;border-radius:50%;background:var(--cosmic)}
.s-head .st{font:700 .72rem var(--f-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--t-hi)}
.s-eyebrow{display:block;font:700 .64rem var(--f-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--t-dim);margin-bottom:9px}
.s-title{font:600 clamp(.98rem,1.6vw,1.22rem)/1.32 var(--f-disp);color:var(--t-hi);letter-spacing:-.015em;max-width:24ch;margin-bottom:16px}
.s-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.s-pill{font:500 .68rem/1 var(--f-body);color:var(--t-body);border:1px solid var(--edge-hi);border-radius:999px;padding:8px 13px;transition:border-color .25s,color .25s}
.device:hover .s-pill:first-child{border-color:var(--coral);color:var(--t-hi)}
.s-cta{display:inline-block;font:600 .74rem/1 var(--f-body);color:#161016;background:var(--cosmic);border-radius:999px;padding:9px 15px}
.s-bars{display:grid;gap:7px;margin:14px 0 16px;max-width:250px}
.s-bars>*{display:block;height:7px;border-radius:99px;background:rgba(255,255,255,.1);position:relative;overflow:hidden}
.s-bars>*::after{content:"";position:absolute;inset:0;width:var(--w,60%);border-radius:inherit;background:var(--cosmic);opacity:.9}
.s-bars>*:nth-child(2)::after{--w:82%}
.s-bars>*:nth-child(3)::after{--w:38%}
/* float cards */
.float-card{position:absolute;background:rgba(20,20,30,.9);backdrop-filter:blur(10px);border:1px solid var(--edge-hi);border-radius:13px;padding:13px 17px;box-shadow:var(--shadow-1);z-index:3}
.float-card.tl{top:-20px;left:-22px}
.float-card:not(.tl){bottom:-20px;right:-16px}
.fc-k{font:700 .6rem var(--f-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--t-dim);margin-bottom:4px}
.fc-v{font:600 .92rem var(--f-disp);color:var(--t-hi)}

/* gallery of screens */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(18px,3vw,30px)}
.gallery .device .slide{aspect-ratio:16/10}
.g-cap{margin-top:12px;display:flex;justify-content:space-between;gap:12px;align-items:baseline}
.g-cap b{font:600 .95rem var(--f-disp);color:var(--t-hi)}
.g-cap span{font:400 .68rem var(--f-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--t-dim)}

/* click-to-upload (project imagery) */
.shot-input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}
.shot-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:4}
.shot-badge{position:absolute;top:10px;right:10px;z-index:6;font:700 .58rem var(--f-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--t-hi);background:rgba(14,14,20,.72);border:1px solid var(--edge-hi);border-radius:999px;padding:7px 12px;cursor:pointer;opacity:.92;transition:opacity .25s,border-color .25s;backdrop-filter:blur(6px)}
.shot-badge:hover{border-color:var(--coral)}
.has-shot .shot-badge{opacity:0}
.slide:hover .shot-badge,.portrait:hover .shot-badge,.shot-badge:focus-visible{opacity:1}
.shot-overlay{position:absolute;inset:0;z-index:5;display:grid;place-items:center;gap:10px;background:rgba(10,10,16,.62);opacity:0;transition:opacity .25s;border:0;cursor:pointer;color:var(--t-hi);font:600 .85rem var(--f-body)}
.slide:hover .shot-overlay,.portrait:hover .shot-overlay,.shot-overlay:focus-visible{opacity:1}
.shot-actions{position:absolute;inset:auto 10px 10px auto;z-index:6;display:none;gap:8px}
.has-shot:hover .shot-actions{display:flex}
.shot-actions button{font:600 .68rem var(--f-body);color:var(--t-hi);background:rgba(14,14,20,.8);border:1px solid var(--edge-hi);border-radius:999px;padding:7px 13px;cursor:pointer}
.shot-actions button:hover{border-color:var(--coral)}

/* ---------- 8 · Data blocks ---------- */
.stat{border-top:1px solid var(--edge);padding-top:18px}
.lite .stat{border-color:var(--edge-lt)}
.stat .num{font:700 clamp(1.9rem,3.4vw,2.7rem)/1.12 var(--f-mono);letter-spacing:-.04em;background:var(--cosmic);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .lab{margin-top:9px;font:400 .72rem var(--f-mono);letter-spacing:.13em;text-transform:uppercase;color:var(--t-dim)}
.lite .stat .lab{color:var(--comet)}
.deflist{display:grid}
.defrow{display:grid;grid-template-columns:130px 1fr;gap:18px;padding:15px 0;border-bottom:1px solid var(--edge);transition:background .2s;align-items:baseline}
.defrow:first-child{border-top:1px solid var(--edge)}
.dk{font:700 .7rem var(--f-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--t-dim)}
.dv{color:var(--t-body);font-size:.98rem}
.lite .defrow{border-color:var(--edge-lt)}
.lite .dv{color:var(--comet)}
.cs-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,4vw,54px)}
.csm h4{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.csm h4::before{content:"";width:9px;height:11px;background:linear-gradient(120deg,var(--coral),var(--pink));clip-path:polygon(100% 0,100% 100%,0 50%)}
.csm ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.csm li{font-size:.94rem;color:var(--t-body);padding-left:16px;position:relative}
.csm li::before{content:"";position:absolute;left:0;top:.62em;width:5px;height:5px;border-radius:50%;background:var(--t-dim)}
.csm li b{color:var(--t-hi);font-weight:600}
.chips,.pill-row{display:flex;flex-wrap:wrap;gap:10px}
.chip{font:500 .82rem/1 var(--f-body);color:var(--t-body);border:1px solid var(--edge-hi);border-radius:999px;padding:11px 17px;transition:border-color .25s,transform .25s,color .25s}
.chip:hover{border-color:var(--coral);color:var(--t-hi);transform:translateY(-2px)}
.lite .chip{color:var(--comet);border-color:#DCD5CC}
.ticks{list-style:none;margin:0;padding:0;display:grid;gap:13px}
.ticks li{position:relative;padding-left:32px;color:var(--t-body)}
.ticks li::before{content:"";position:absolute;left:0;top:.28em;width:18px;height:18px;border-radius:50%;background:var(--cosmic-soft);border:1px solid rgba(255,120,77,.5)}
.ticks li::after{content:"";position:absolute;left:5px;top:.28em;width:8px;height:5px;margin-top:4px;border-left:2px solid var(--coral);border-bottom:2px solid var(--coral);transform:rotate(-45deg)}
.lite .ticks li{color:var(--comet)}

/* ---------- 9 · Pillars / accordion / process ---------- */
.pillars{display:grid;gap:0;border-top:1px solid var(--edge)}
.pillars>div{display:grid;grid-template-columns:110px 1fr;gap:clamp(18px,4vw,54px);padding:clamp(26px,4vw,44px) 0;border-bottom:1px solid var(--edge);position:relative}
.pillars>div::before{content:"";position:absolute;left:0;top:0;height:2px;width:0;background:var(--cosmic);transition:width 1s var(--ease) .15s}
.pillars>div.in-view::before{width:110px}
.pillars .num,.pillars .pk{font:700 1rem var(--f-mono);letter-spacing:.1em;color:var(--t-dim);padding-top:6px}
.pillars h3{margin-bottom:12px}
.pillars p+p{margin-top:.8em}
.lite .pillars,.lite .pillars>div{border-color:var(--edge-lt)}

.discs{display:block}
.disc{border:1px solid var(--edge);border-radius:var(--r-card);background:var(--panel);overflow:hidden;transition:border-color .3s}
.disc+.disc{margin-top:14px}
.disc.is-open{border-color:var(--edge-hi)}
.disc__btn{display:flex;align-items:center;gap:18px;width:100%;background:none;border:0;color:var(--t-hi);cursor:pointer;padding:22px clamp(18px,3vw,28px);text-align:left;font:600 clamp(1.02rem,1.6vw,1.18rem)/1.3 var(--f-disp);letter-spacing:-.01em;min-height:48px}
.disc__n{font:700 .78rem var(--f-mono);letter-spacing:.08em;color:var(--t-dim);flex:none}
.disc__t{flex:1}
.disc__icon{flex:none;width:30px;height:30px;border:1px solid var(--edge-hi);border-radius:50%;display:grid;place-items:center;position:relative;transition:transform .35s var(--ease),background .3s,border-color .3s}
.disc__icon::before,.disc__icon::after{content:"";position:absolute;background:var(--t-hi);transition:transform .35s var(--ease)}
.disc__icon::before{width:12px;height:2px}
.disc__icon::after{width:2px;height:12px}
.disc.is-open .disc__icon{transform:rotate(180deg);background:var(--cosmic);border-color:transparent}
.disc.is-open .disc__icon::before,.disc.is-open .disc__icon::after{background:#161016}
.disc.is-open .disc__icon::after{transform:scaleY(0)}
.disc__panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .45s var(--ease)}
.disc.is-open .disc__panel{grid-template-rows:1fr}
.disc__inner{overflow:hidden;min-height:0}
.disc__inner>div,.disc__inner>p{padding:0 clamp(18px,3vw,28px) 24px;color:var(--t-body)}
.disc__inner{border-left:2px solid transparent}
.disc.is-open .disc__inner{border-image:var(--cosmic) 1;border-left:2px solid}

.process{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2.5vw,26px);counter-reset:ph}
.proc-step{position:relative;border:1px solid var(--edge);border-radius:var(--r-card);background:var(--panel);padding:26px 22px;transition:transform .35s var(--ease),border-color .3s,box-shadow .35s}
.proc-step:hover{transform:translateY(-6px);border-color:var(--edge-hi);box-shadow:var(--shadow-1)}
.proc-dot{width:12px;height:12px;border-radius:50%;background:var(--cosmic);box-shadow:0 0 0 5px rgba(255,120,77,.16),0 0 18px rgba(255,120,77,.5);margin:2px 0 14px}
.proc-step h4{margin-bottom:10px}
.proc-step p{font-size:.93rem;color:var(--t-body)}
.proc-step .mono-label{display:block;margin-bottom:12px}

/* ---------- 10 · Cards ---------- */
.card{position:relative;overflow:hidden;border:1px solid var(--edge);border-radius:var(--r-card);background:var(--panel);padding:clamp(22px,3vw,32px)}
.card--hover{transition:transform .35s var(--ease),border-color .3s,box-shadow .35s}
.card--hover:hover{transform:translateY(-6px);border-color:var(--edge-hi);box-shadow:var(--shadow-1)}
.value-card{border:1px solid var(--edge);border-radius:var(--r-card);background:var(--panel);padding:clamp(22px,3vw,30px);transition:transform .35s var(--ease),border-color .3s}
.value-card:hover{transform:translateY(-4px);border-color:var(--edge-hi)}
.value-card .vc-n{font:700 .78rem var(--f-mono);letter-spacing:.14em;color:var(--t-dim);display:block;margin-bottom:14px}
.value-card h4{margin-bottom:10px}
.value-card p{font-size:.94rem}
.svc-card{position:relative;display:block;border:1px solid var(--edge);border-radius:var(--r-card);background:var(--panel);padding:clamp(24px,3.4vw,36px);overflow:hidden;transition:transform .35s var(--ease),border-color .3s,box-shadow .35s}
.svc-card::before{content:"";position:absolute;inset:0;background:radial-gradient(90% 90% at 100% 0%,rgba(255,120,77,.12),transparent 55%);opacity:0;transition:opacity .4s}
.svc-card:hover{transform:translateY(-6px);border-color:var(--edge-hi);box-shadow:var(--shadow-1)}
.svc-card:hover::before{opacity:1}
.svc-ico{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;background:var(--cosmic-soft);border:1px solid rgba(255,120,77,.35);margin-bottom:20px}
.svc-ico svg{width:22px;height:22px;stroke:var(--coral);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.svc-card h3{margin-bottom:10px}
.svc-card p{font-size:.95rem}
.svc-go{display:inline-flex;align-items:center;gap:8px;margin-top:20px;font:600 .85rem var(--f-body);color:var(--t-hi)}
.svc-go .arr{transition:transform .3s var(--ease)}
.svc-card:hover .svc-go .arr{transform:translateX(5px)}
.svc-card:hover .svc-go{background:var(--cosmic);-webkit-background-clip:text;background-clip:text;color:transparent}

.topbar{position:absolute;inset:0 0 auto 0;height:3px;background:var(--cosmic)}
.logo-chip{position:relative}
.logo-chip .dot{width:9px;height:9px;border-radius:50%;background:var(--cosmic);display:inline-block;margin-bottom:8px}
.pk{font:700 .68rem var(--f-mono);letter-spacing:.16em;text-transform:uppercase;color:#6C6C77;margin-bottom:8px}

.card .topbar,.svc-card .topbar{position:absolute;top:0;left:0;right:0;height:3px;background:var(--cosmic);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.card--hover:hover .topbar,.svc-card:hover .topbar{transform:scaleX(1)}
.card{position:relative;overflow:hidden}

/* light mock slide variant */
.slide.lite{background:linear-gradient(160deg,#FBF9F7,#ECE7E1)}
.slide.lite .s-title,.slide.lite .st{color:var(--ink)}
.slide.lite .s-eyebrow{color:#8A8A93}
.slide.lite .s-pill{color:#5C5C66;border-color:#D8D2CA}
.slide.lite .s-orbit{border-color:rgba(21,21,27,.18)}
.slide.lite .s-bars>*{background:rgba(21,21,27,.1)}

/* ---------- 11 · Portfolio grid ---------- */
.filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:clamp(28px,4vw,44px)}
.filter-bar button{font:700 .72rem var(--f-mono);letter-spacing:.13em;text-transform:uppercase;color:var(--t-dim);background:none;border:1px solid var(--edge);border-radius:999px;padding:12px 20px;cursor:pointer;transition:color .25s,border-color .25s,background .25s;min-height:44px}
.filter-bar button:hover{color:var(--t-hi);border-color:var(--edge-hi)}
.filter-bar button.active{color:#161016;background:var(--cosmic);border-color:transparent}
.pf-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,34px)}
.pf-grid--3{grid-template-columns:repeat(3,1fr)}
.pf-grid--3 .pf-body{padding:clamp(16px,2vw,22px)}
.pf-grid--3 h3{font-size:1.18rem}
.pf-tile{position:relative;display:block;border:1px solid var(--edge);border-radius:var(--r-card);background:var(--panel);overflow:hidden;transition:transform .4s var(--ease),border-color .3s,box-shadow .4s,opacity .35s,scale .35s}
.pf-tile:hover{transform:translateY(-7px);border-color:var(--edge-hi);box-shadow:var(--shadow-2)}
.pf-tile.is-hidden{display:none}
.pf-art{position:relative;aspect-ratio:16/9.4;background:radial-gradient(130% 130% at 18% 0%,#1B1A28,#101018 72%);overflow:hidden;border-bottom:1px solid var(--edge)}
.pf-art .device{position:absolute;inset:12% 9% auto;box-shadow:0 18px 50px rgba(0,0,0,.5);transition:transform .5s var(--ease)}
.pf-tile:hover .pf-art .device{transform:translateY(-7px) scale(1.015)}
.pf-mark{position:absolute;right:-46px;bottom:-52px;width:190px;height:190px;border:1.5px dashed rgba(255,255,255,.13);border-radius:50%}
.pf-body{padding:clamp(18px,2.6vw,28px)}
.pf-meta{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.pf-type{font:700 .62rem var(--f-mono);letter-spacing:.14em;text-transform:uppercase;color:#161016;background:var(--cosmic);border-radius:999px;padding:6px 11px}
.pf-client{font:400 .68rem var(--f-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--t-dim)}
.pf-body h3{margin-bottom:9px}
.pf-body p{font-size:.94rem;color:var(--t-body)}
.pf-go{display:inline-flex;align-items:center;gap:8px;margin-top:16px;font:600 .85rem var(--f-body);color:var(--t-hi)}
.pf-go .arr{transition:transform .3s var(--ease)}
.pf-tile:hover .pf-go .arr{transform:translateX(5px)}

/* ---------- 12 · Journal ---------- */
.post{display:grid;grid-template-columns:150px minmax(0,1.6fr) minmax(0,2fr);grid-template-areas:"meta title blurb" "meta read blurb";gap:10px clamp(18px,4vw,46px);align-items:start;padding:clamp(24px,4vw,38px) 0;border-bottom:1px solid var(--edge);position:relative;transition:background .25s}
.p-top{grid-area:meta}
.post h3{grid-area:title}
.post>p{grid-area:blurb;margin-top:2px}
.post .read{grid-area:read;align-self:end;justify-self:start;margin-top:8px}
.post:first-of-type{border-top:1px solid var(--edge)}
.p-top{display:grid;gap:6px;align-content:start}
.p-date{font:400 .72rem var(--f-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--t-dim)}
.p-cat{font:700 .62rem var(--f-mono);letter-spacing:.14em;text-transform:uppercase;background:var(--cosmic);-webkit-background-clip:text;background-clip:text;color:transparent}
.post h3 a{color:var(--t-hi);transition:color .2s;background-image:linear-gradient(var(--cosmic));background-size:0 2px;background-repeat:no-repeat;background-position:0 100%;transition:background-size .4s var(--ease)}
.post h3 a:hover{background-size:100% 2px}
.post p{margin-top:10px;font-size:.97rem;max-width:62ch}
.read{font:600 .85rem var(--f-body);color:var(--t-hi);white-space:nowrap;display:inline-flex;gap:8px;align-items:center}
.read .arr{transition:transform .3s var(--ease)}
.post:hover .read .arr{transform:translateX(5px)}
/* article — sits inside a .section.lite wrapper */
.article{display:block;background:var(--mist);--comet:#6C6C77;--comet-dk:#8A8A93;border-radius:calc(var(--r-dev) + 8px);width:min(920px,100%);margin-inline:auto;padding:clamp(30px,5.5vw,68px) clamp(20px,6vw,84px);box-shadow:var(--shadow-2);border:1px solid rgba(255,255,255,.9)}
.a-meta{display:flex;flex-wrap:wrap;gap:14px;align-items:center;font:400 .74rem var(--f-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--t-dim)}
.article .a-meta,.lite .a-meta{color:#6C6C77}
.a-meta .p-cat{font-weight:700}
.a-read{opacity:.9}
.article h1{color:var(--ink);font-size:clamp(2rem,4.6vw,3.2rem);max-width:22ch}
.article-lede{margin-top:22px;font-size:var(--fs-lead);line-height:1.6;color:var(--comet);max-width:58ch}
.article-body{margin-top:clamp(36px,5vw,56px);color:#3E3E49}
.article-body>*+*{margin-top:1.35em}
.article-body h2{font-size:clamp(1.4rem,2.6vw,1.85rem);color:var(--ink);margin-top:2em;letter-spacing:-.015em}
.article-body p{line-height:1.85;max-width:68ch}
.article-body strong{color:var(--ink)}
.article-body .pull{border-left:3px solid;border-image:var(--cosmic) 1;padding:6px 0 6px 26px;font:600 clamp(1.15rem,2vw,1.4rem)/1.5 var(--f-disp);color:var(--ink);letter-spacing:-.015em;max-width:30ch}
.rule{height:1px;background:var(--edge-lt);border:0;margin:2.2em 0}
.article-foot{width:min(920px,100%);margin:clamp(36px,5vw,54px) auto 0;display:flex;align-items:center;gap:18px}
.af-by{display:grid;gap:4px;color:var(--t-dim);font-size:.92rem;max-width:56ch}
.af-by b{color:var(--t-hi);font:600 1.02rem var(--f-disp)}
.af-mark{width:48px;height:48px;border-radius:50%;background:var(--cosmic);flex:none;box-shadow:0 8px 24px rgba(255,120,77,.35)}
.a-back{font:600 .9rem var(--f-body);color:var(--t-hi);display:inline-flex;gap:8px;align-items:center}
.a-back:hover{background:var(--cosmic);-webkit-background-clip:text;background-clip:text;color:transparent}

/* project prev/next */
.project-nav{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.pn{border:1px solid var(--edge);border-radius:var(--r-card);background:var(--panel);padding:24px;display:grid;gap:8px;transition:transform .35s var(--ease),border-color .3s}
.pn:hover{transform:translateY(-4px);border-color:var(--edge-hi)}
.pn .mono-label{font-size:.62rem}
.pn b{font:600 1.05rem var(--f-disp);color:var(--t-hi);letter-spacing:-.01em}
.pn-next{text-align:right;justify-items:end}

/* ---------- 13 · Contact ---------- */
.contact-grid{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,5fr);gap:clamp(30px,5vw,70px);align-items:start}
.form{display:grid;gap:18px}
.field{display:grid;gap:8px}
.field label{font:700 .7rem var(--f-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--t-dim)}
.field input,.field select,.field textarea{width:100%;background:var(--panel);border:1px solid var(--edge);border-radius:12px;color:var(--t-hi);font:400 .98rem/1.5 var(--f-body);padding:15px 17px;transition:border-color .25s,box-shadow .25s;min-height:48px}
.field textarea{min-height:150px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--coral);box-shadow:0 0 0 3px rgba(255,120,77,.18)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238F8FA0' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.field .err{display:none;font:400 .78rem var(--f-body);color:#FF9B85}
.field.invalid .err{display:block}
.field.invalid input,.field.invalid textarea,.field.invalid select{border-color:#FF7A5E}
.form-note{font-size:.9rem;color:var(--t-dim)}
.form-note a{color:var(--t-hi);border-bottom:1px solid var(--coral)}
.form-status{display:none;border:1px solid rgba(255,189,89,.5);background:rgba(255,189,89,.08);border-radius:12px;padding:15px 17px;font-size:.93rem;color:var(--t-hi)}
.form-status.show{display:block}
.contact-side{display:grid;gap:14px}
.contact-side .card{display:grid;gap:4px}
.contact-side .k{font:700 .64rem var(--f-mono);letter-spacing:.15em;text-transform:uppercase;color:var(--t-dim)}
.contact-side .v{font:600 1.02rem var(--f-disp);color:var(--t-hi);letter-spacing:-.01em;word-break:break-word}
.contact-side .v a:hover{background:var(--cosmic);-webkit-background-clip:text;background-clip:text;color:transparent}
.contact-side .l{font-size:.88rem;color:var(--t-dim)}

/* ---------- 14 · CTA band ---------- */
.cta-band{position:relative;overflow:hidden;text-align:center;border:1px solid var(--edge);border-radius:calc(var(--r-dev) + 8px);background:radial-gradient(120% 170% at 50% 135%,#231A30 0%,#12121B 58%);padding:clamp(56px,8vw,108px) clamp(22px,5vw,64px)}
.cta-band .lift{position:relative;z-index:2}
.cta-band h2{font-size:clamp(1.9rem,4.6vw,3.3rem);max-width:20ch;margin-inline:auto}
.cta-band h2 b{background:var(--cosmic);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:inherit}
.cta-band .btn-row{justify-content:center;margin-top:32px}
.cta-band .eyebrow{justify-content:center}
.cta-glow{position:absolute;left:50%;bottom:-52%;transform:translateX(-50%);width:min(820px,110%);aspect-ratio:2/1;border-radius:50%;background:radial-gradient(closest-side,rgba(255,120,77,.34),rgba(255,102,196,.15) 55%,transparent 72%);filter:blur(48px);pointer-events:none;z-index:0}

/* ---------- 15 · Footer ---------- */
.site-foot{position:relative;overflow:hidden;background:#0A0A10;border-top:1px solid var(--edge)}
.site-foot::before{content:"";position:absolute;inset:0 0 auto;height:2px;background:var(--cosmic);opacity:.85}
.foot-orbit{position:absolute;right:-190px;top:-150px;width:560px;height:560px;border:1.5px dashed rgba(255,255,255,.09);border-radius:50%;pointer-events:none}
.foot-orbit::after{content:"";position:absolute;inset:70px;border:1.5px dashed rgba(255,255,255,.06);border-radius:50%}
.foot-in{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1.5fr) repeat(3,minmax(0,1fr));gap:clamp(26px,4vw,54px);padding:clamp(56px,7vw,84px) 0 34px}
.foot-brand img{height:40px;width:auto}
.foot-brand p{margin-top:18px;font-size:.94rem;color:var(--t-dim);max-width:30ch}
.foot-col h4{font:700 .68rem var(--f-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--t-dim);margin-bottom:18px}
.foot-col ul{list-style:none;margin:0;padding:0;display:grid;gap:11px}
.foot-col a{font-size:.94rem;color:var(--t-body);transition:color .2s}
.foot-col a:hover{color:var(--t-hi)}
.foot-col .mono{font-family:var(--f-mono);font-size:.85rem;letter-spacing:.02em}
.foot-base{position:relative;z-index:2;display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;padding:22px 0 30px;border-top:1px solid var(--edge);font:400 .72rem var(--f-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--t-dim)}
.to-top{display:inline-flex;gap:8px;align-items:center;background:none;border:1px solid var(--edge);color:var(--t-body);border-radius:999px;padding:10px 16px;font:700 .66rem var(--f-mono);letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:border-color .25s,color .25s;min-height:40px}
.to-top:hover{border-color:var(--coral);color:var(--t-hi)}

/* ---------- 16 · Home hero + marquee + feature/about extras ---------- */
.hero{position:relative;min-height:min(100svh,980px);display:grid;align-items:center;padding:calc(78px + clamp(40px,6vw,80px)) 0 clamp(64px,8vw,110px);background:radial-gradient(130% 100% at 78% -12%,#1C1A2C 0%,var(--space) 58%)}
.hero-grid{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,5fr);gap:clamp(34px,5vw,72px);align-items:center}
.hero h1{font-size:var(--fs-hero);line-height:.99;letter-spacing:-.032em;max-width:12ch}
.hero .h-line{display:block;overflow:hidden;padding-bottom:.14em;margin-bottom:-.14em}
.hero .h-line>span{display:inline-block;transform:translateY(112%);animation:h-rise .95s var(--ease) forwards}
.hero .h-line:nth-child(2)>span{animation-delay:.1s}
.hero .h-line:nth-child(3)>span{animation-delay:.2s}
@keyframes h-rise{to{transform:none}}
.hero-sub{margin-top:26px;max-width:46ch}
.hero .eyebrow,.hero-sub,.hero .btn-row,.hero-foot{opacity:0;animation:h-fade .8s var(--ease) forwards}
.hero .eyebrow{animation-delay:.05s}
.hero-sub{animation-delay:.42s}
.hero .btn-row{margin-top:36px;animation-delay:.55s}
.hero-foot{display:flex;flex-wrap:wrap;gap:clamp(18px,3vw,42px);margin-top:clamp(38px,5vw,58px);animation-delay:.7s}
@keyframes h-fade{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.hf{display:grid;gap:4px}
.hf b{font:700 .95rem var(--f-disp);color:var(--t-hi);letter-spacing:-.01em}
.hf span{font:400 .68rem var(--f-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--t-dim)}
.hero-media{position:relative;opacity:0;animation:h-fade 1s var(--ease) .5s forwards}
.hero-media .device{transform:rotate(-1.6deg)}
.hero-media .float-card{z-index:4}
.hero-scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);display:grid;justify-items:center;gap:9px;font:700 .58rem var(--f-mono);letter-spacing:.24em;text-transform:uppercase;color:var(--t-dim);z-index:2}
.hero-scroll i{width:1px;height:44px;background:linear-gradient(var(--coral),transparent);animation:drip 1.8s var(--ease) infinite}
@keyframes drip{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
/* marquee */
.marquee{position:relative;overflow:hidden;padding:26px 0;border-top:1px solid var(--edge);border-bottom:1px solid var(--edge);--mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);-webkit-mask-image:var(--mask);mask-image:var(--mask)}
.marquee-track{display:flex;gap:clamp(34px,6vw,84px);width:max-content;animation:mq 30s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes mq{to{transform:translateX(-50%)}}
.mq-item{display:inline-flex;align-items:center;gap:14px;font:600 clamp(1rem,1.7vw,1.25rem) var(--f-disp);color:var(--t-dim);letter-spacing:-.01em;white-space:nowrap}
.mq-item .mono-label{font-size:.58rem;color:var(--t-dim);opacity:.75}
.mq-item::before{content:"";width:8px;height:10px;background:linear-gradient(120deg,var(--coral),var(--pink));clip-path:polygon(100% 0,100% 100%,0 50%);opacity:.85}
/* about */
.bio-grid{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);gap:clamp(30px,5vw,70px);align-items:start}
.portrait{position:relative;aspect-ratio:4/5;border-radius:var(--r-dev);overflow:hidden;background:linear-gradient(160deg,#1D1C2A,#121119);border:1px solid var(--edge);box-shadow:var(--shadow-2);display:grid;place-items:center;align-content:center;gap:18px;text-align:center;padding:28px}
.portrait>*{position:relative;z-index:1}
.ph-mark{width:76px;color:var(--t-dim)}
.ph-tag{font:700 .62rem var(--f-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--t-dim);max-width:24ch;line-height:1.8}
.ph-glow{position:absolute!important;inset:auto -30% -46% -30%;height:70%;background:radial-gradient(closest-side,rgba(255,120,77,.3),transparent 70%);filter:blur(44px);z-index:0!important}
.logos{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.logo-chip{border:1px solid var(--edge);border-radius:12px;background:var(--panel);display:grid;place-items:center;padding:20px 14px;text-align:center}
.logo-chip .lc{font:600 .92rem var(--f-disp);color:var(--t-body)}
.logo-chip .ci{font:400 .6rem var(--f-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--t-dim);margin-top:4px}
.k-num{font:700 clamp(1.7rem,3vw,2.3rem)/1 var(--f-mono);letter-spacing:-.03em;background:var(--cosmic);-webkit-background-clip:text;background-clip:text;color:transparent}
.feature-band{position:relative;display:grid;grid-template-columns:minmax(0,7fr) minmax(0,5fr);gap:clamp(26px,4vw,56px);align-items:center;border:1px solid var(--edge);border-radius:calc(var(--r-dev) + 8px);background:radial-gradient(130% 160% at 85% -20%,#1D1B2B 0%,#12121B 60%);padding:clamp(28px,4.5vw,56px);overflow:hidden;transition:transform .4s var(--ease),border-color .3s,box-shadow .4s}
.feature-band:hover{transform:translateY(-5px);border-color:var(--edge-hi);box-shadow:var(--shadow-2)}
.feature-band .device{max-width:520px;justify-self:end;width:100%}
.feature-band .slide{aspect-ratio:16/10.6}
/* 404 */
.fourohfour{position:relative;display:grid;justify-items:center;text-align:center}
.fourohfour .big{font:700 clamp(6.5rem,24vw,14rem)/1 var(--f-mono);letter-spacing:-.06em;background:var(--cosmic);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 18px 60px rgba(255,120,77,.28));margin:6px 0 4px}
.fourohfour .pill-row{gap:22px}
.planet-arc{position:absolute;border:1.5px dashed rgba(255,255,255,.14);border-radius:50%}
.planet-core{position:absolute;border-radius:50%;background:radial-gradient(circle at 32% 30%,#2A2938,#15141F 68%);border:1px solid var(--edge)}


/* legacy variants */
.float-card.br{bottom:-20px;right:-16px}
.hf .n{font:700 clamp(1.5rem,2.6vw,2rem)/1 var(--f-mono);letter-spacing:-.03em;background:var(--cosmic);-webkit-background-clip:text;background-clip:text;color:transparent}
.hf .l{font:400 .68rem var(--f-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--t-dim)}
.hf+.div{width:1px;align-self:stretch;background:var(--edge)}
.proc-step.lit{background:var(--panel-2)}

.pn-prev{text-align:left;justify-items:start}

/* ---------- 17 · Reveal system ---------- */
.reveal{opacity:0;transform:translateY(26px);filter:blur(5px);transition:opacity .8s var(--ease),transform .8s var(--ease),filter .8s var(--ease)}
.reveal.in-view{opacity:1;transform:none;filter:none}
.reveal[data-d="1"]{transition-delay:.12s}
.reveal[data-d="2"]{transition-delay:.24s}
.reveal[data-d="3"]{transition-delay:.36s}
.reveal[data-d="4"]{transition-delay:.48s}
[data-stagger]>*{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-stagger].in-view>*{opacity:1;transform:none}
[data-stagger].in-view>*:nth-child(2){transition-delay:.1s}
[data-stagger].in-view>*:nth-child(3){transition-delay:.2s}
[data-stagger].in-view>*:nth-child(4){transition-delay:.3s}
[data-stagger].in-view>*:nth-child(5){transition-delay:.4s}
[data-stagger].in-view>*:nth-child(6){transition-delay:.5s}
@media (prefers-reduced-motion:reduce){
  .reveal,[data-stagger]>*{opacity:1;transform:none;filter:none}
  .hero .h-line>span{transform:none;animation:none}
  .hero .eyebrow,.hero-sub,.hero .btn-row,.hero-foot,.hero-media{opacity:1;animation:none}
  .marquee-track{animation:none}
  .sky-layer,.device,.btn{transform:none!important}
  .progress,.hero-scroll i{display:none}
}

/* ---------- 18 · Responsive ---------- */
@media (max-width:1020px){
  .pf-grid--3{grid-template-columns:1fr 1fr}
  .split,.hero-grid,.contact-grid,.bio-grid{grid-template-columns:1fr}
  .hero-media{max-width:560px}
  .process{grid-template-columns:repeat(2,1fr)}
  .cs-meta{grid-template-columns:repeat(2,1fr)}
  .foot-in{grid-template-columns:1fr 1fr}
}
@media (max-width:860px){
  .nav{display:none}
  .pf-grid--3{grid-template-columns:1fr}
  .burger{display:grid}
  .pf-grid,.gallery{grid-template-columns:1fr}
  .post{grid-template-columns:1fr;gap:10px}
  .read{display:none}
  .split{gap:38px}
}
@media (max-width:600px){
  .device .bar .u{display:none}
  .device .slide{aspect-ratio:auto;min-height:220px;padding-bottom:26px}
  .float-card{padding:10px 13px}
  .fc-v{font-size:.8rem}
  .s-title{margin-bottom:12px}
  .post{grid-template-columns:1fr;grid-template-areas:"meta" "title" "blurb" "read"}
  .post .read{display:inline-flex}
  .feature-band{grid-template-columns:1fr}
  .feature-band .device{justify-self:stretch;max-width:none}
  .article-foot{flex-direction:row}
  :root{--gut:18px}
  .cols-2{grid-template-columns:1fr 1fr}
  .process,.cs-meta,.logos{grid-template-columns:1fr}
  .cs-meta{gap:30px}
  .defrow{grid-template-columns:1fr;gap:4px;padding:13px 0}
  .pillars>div{grid-template-columns:1fr;gap:10px}
  .pillars>div.in-view::before{width:64px}
  .float-card.tl{left:-6px;top:-14px}
  .float-card:not(.tl){right:-6px;bottom:-14px}
  .btn{padding:15px 24px;width:auto}
  .btn-row .btn{flex:1 1 auto;min-width:150px}
  .foot-in{grid-template-columns:1fr;gap:34px}
  .project-nav{grid-template-columns:1fr}
  .pn-next{text-align:left;justify-items:start}
  .hero{min-height:auto}
  .device .u{max-width:56%}
}
.ph{display:inline-block}
