/* =================================================================
   MOTO CHANNEL RIDERS — light industrial theme, dark sidebar
   Fonts: Bricolage Grotesque (display) · Hanken Grotesk (body) · JetBrains Mono (technical)
   ================================================================= */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

:root{
  --paper:#f4f1ea;        /* page background, warm bone */
  --paper-2:#ece7dc;      /* slightly deeper bone */
  --surface:#fbf9f4;      /* cards */
  --surface-2:#ffffff;
  --ink:#15171c;          /* near-black text */
  --ink-2:#54585f;        /* muted text */
  --ink-3:#8b8d88;        /* faint */
  --line:#dcd6c9;         /* warm hairline */
  --line-2:#e8e3d8;
  --amber:#ef4d18;        /* burnt orange accent */
  --amber-2:#ff6a31;
  --steel:#33414f;        /* deep slate secondary */
  --sand:#c9a98a;

  --panel:#0e1014;        /* dark sidebar */
  --panel-2:#15181e;
  --panel-line:#262a31;
  --panel-txt:#c7cad0;
  --panel-dim:#7b8089;

  --ff-display:"Bricolage Grotesque",-apple-system,sans-serif;
  --ff-body:"Hanken Grotesk",-apple-system,sans-serif;
  --ff-mono:"JetBrains Mono",ui-monospace,monospace;

  --side:266px;
  --rad:14px;
  --rad-s:9px;
  --sec:clamp(56px,8.5vh,118px);
  --ease:cubic-bezier(.2,.72,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

body{
  font-family:var(--ff-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  font-size:16.5px;
}
body.lock{overflow:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--amber);color:#fff}

.wrap{width:100%;max-width:1180px;margin-inline:auto;padding-inline:clamp(20px,4vw,52px)}
.section{padding-block:var(--sec)}
.section--tight{padding-block:clamp(34px,5vh,64px)}

/* ---------- type ---------- */
.kicker{font-family:var(--ff-mono);font-size:11px;font-weight:500;letter-spacing:.26em;text-transform:uppercase;color:var(--amber);display:inline-flex;align-items:center;gap:11px}
.kicker::before{content:"";width:24px;height:1px;background:var(--amber)}
.kicker.plain::before{display:none}
.mono{font-family:var(--ff-mono);letter-spacing:.02em}
.dim{color:var(--ink-2)}
.amber{color:var(--amber)}

.t-hero{font-family:var(--ff-display);font-weight:700;font-size:clamp(2.6rem,6.4vw,5.4rem);line-height:.98;letter-spacing:-.025em}
.t-xl{font-family:var(--ff-display);font-weight:700;font-size:clamp(2rem,4.4vw,3.5rem);line-height:1.02;letter-spacing:-.02em}
.t-lg{font-family:var(--ff-display);font-weight:600;font-size:clamp(1.5rem,2.8vw,2.3rem);line-height:1.08;letter-spacing:-.015em}
.t-md{font-family:var(--ff-display);font-weight:600;font-size:clamp(1.2rem,2vw,1.55rem);line-height:1.15}
.lede{font-size:clamp(1.05rem,1.5vw,1.32rem);line-height:1.5;color:var(--ink-2);font-weight:400}
.body-lg{font-size:1.06rem;color:var(--ink-2)}
em{font-style:normal;color:var(--amber)}
.t-hero em,.t-xl em,.t-lg em{font-style:italic;color:var(--amber)}

.tag{display:inline-block;font-family:var(--ff-mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);
  border:1px solid var(--line);border-radius:100px;padding:6px 13px;background:var(--surface)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:11px;font-family:var(--ff-mono);font-size:12.5px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;
  padding:15px 26px;border-radius:100px;border:1px solid var(--ink);background:var(--ink);color:var(--paper);cursor:pointer;transition:.4s var(--ease);position:relative;overflow:hidden}
.btn .arr{transition:transform .4s var(--ease)}
.btn:hover{background:var(--amber);border-color:var(--amber);color:#fff}
.btn:hover .arr{transform:translateX(5px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.btn--light{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.btn--light:hover{background:var(--amber);border-color:var(--amber);color:#fff}
.arr{width:14px;height:14px;flex:none}
.linklike{font-family:var(--ff-mono);font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;display:inline-flex;align-items:center;gap:10px;color:var(--ink);
  border-bottom:1px solid transparent;padding-bottom:3px;transition:.35s var(--ease)}
.linklike .arr{transition:transform .35s var(--ease)}
.linklike:hover{color:var(--amber);border-color:var(--amber)}
.linklike:hover .arr{transform:translateX(5px)}

/* ============================================================
   SIDEBAR (dark)
   ============================================================ */
.sidebar{position:fixed;inset:0 auto 0 0;width:var(--side);z-index:60;
  background:linear-gradient(176deg,var(--panel),var(--panel-2));
  border-right:1px solid var(--panel-line);
  display:flex;flex-direction:column;padding:30px 26px 26px}
.sidebar::after{content:"";position:absolute;top:0;right:0;width:1px;height:100%;
  background:linear-gradient(180deg,transparent,var(--amber),transparent);opacity:.5}
.sb-logo{display:block;margin-bottom:38px}
.sb-logo img{width:100%;height:auto;filter:drop-shadow(0 2px 14px rgba(0,0,0,.5))}
.sb-meta{font-family:var(--ff-mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--panel-dim);
  display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:18px;border-bottom:1px solid var(--panel-line)}
.sb-nav{display:flex;flex-direction:column;gap:2px;flex:1}
.sb-link{display:flex;align-items:baseline;gap:13px;padding:11px 12px;border-radius:var(--rad-s);position:relative;transition:.35s var(--ease)}
.sb-link .n{font-family:var(--ff-mono);font-size:10px;color:var(--panel-dim);width:20px;transition:.35s}
.sb-link .t{font-family:var(--ff-display);font-weight:500;font-size:1.06rem;color:var(--panel-txt);transition:.35s}
.sb-link::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);width:3px;height:60%;background:var(--amber);border-radius:3px;transition:transform .35s var(--ease)}
.sb-link:hover{background:rgba(255,255,255,.035)}
.sb-link:hover .t{color:#fff}
.sb-link:hover .n{color:var(--amber)}
.sb-link.active{background:rgba(239,77,24,.08)}
.sb-link.active::before{transform:translateY(-50%) scaleY(1)}
.sb-link.active .t{color:#fff}
.sb-link.active .n{color:var(--amber)}
.sb-foot{margin-top:26px;padding-top:22px;border-top:1px solid var(--panel-line);display:flex;flex-direction:column;gap:16px}
.sb-cta{width:100%;justify-content:center;background:var(--amber);border-color:var(--amber);color:#fff}
.sb-cta:hover{background:#fff;border-color:#fff;color:var(--panel)}
.sb-foot-note{font-family:var(--ff-mono);font-size:9.5px;letter-spacing:.13em;line-height:1.7;color:var(--panel-dim);text-transform:uppercase}
.sb-prog{position:absolute;left:0;bottom:0;width:2px;height:0;background:var(--amber);opacity:.7;transition:height .1s linear}

/* mobile top bar + drawer (hidden on desktop) */
.topbar{display:none}
.drawer{display:none}

/* ============================================================
   PAGE SHELL
   ============================================================ */
.page{margin-left:var(--side);min-height:100vh;display:flex;flex-direction:column}
.page main{flex:1}

/* ---------- scroll progress (top, content area) ---------- */
.xprog{position:fixed;top:0;left:var(--side);right:0;height:2px;background:transparent;z-index:55}
.xprog i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--amber),var(--amber-2))}

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.cur,.cur-d{position:fixed;top:0;left:0;pointer-events:none;z-index:90;border-radius:50%;mix-blend-mode:difference}
.cur{width:34px;height:34px;border:1px solid #fff;transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s,border-color .25s}
.cur-d{width:5px;height:5px;background:#fff;transform:translate(-50%,-50%)}
.cur.grow{width:62px;height:62px;background:rgba(255,255,255,.12);border-color:transparent}
body.no-cursor .cur,body.no-cursor .cur-d{display:none}

/* ============================================================
   REVEAL / ANIMATION UTILITIES
   ============================================================ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal-blur{opacity:0;transform:translateY(24px);filter:blur(10px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out),filter 1s var(--ease-out)}
.reveal-blur.in{opacity:1;transform:none;filter:blur(0)}
.reveal-x{opacity:0;transform:translateX(-34px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal-x.in{opacity:1;transform:none}
[class*="reveal"]{transition-delay:calc(var(--i,0)*90ms)}
.lines span{display:block;overflow:hidden}
.lines span i{display:block;font-style:inherit;transform:translateY(105%);transition:transform .95s var(--ease-out);transition-delay:calc(var(--i,0)*90ms)}
.lines.in span i{transform:none}

/* photo frame with curtain reveal */
.shot{position:relative;overflow:hidden;border-radius:var(--rad);background:var(--paper-2);isolation:isolate}
.shot img{width:100%;height:100%;object-fit:cover;transform:scale(1.12);transition:transform 1.4s var(--ease-out)}
.shot::after{content:"";position:absolute;inset:0;background:var(--paper);transform-origin:top;transform:scaleY(1);transition:transform 1.1s var(--ease-out);z-index:2}
.shot.in img{transform:scale(1)}
.shot.in::after{transform:scaleY(0)}
.shot--tall{aspect-ratio:3/4}
.shot--ar{aspect-ratio:4/3}
.shot--wide{aspect-ratio:16/9}
.shot--sq{aspect-ratio:1/1}
.shot-tag{position:absolute;left:14px;bottom:14px;z-index:3;font-family:var(--ff-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:#fff;background:rgba(14,16,20,.62);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.16);padding:7px 12px;border-radius:100px}
.shot-corner{position:absolute;top:13px;right:14px;z-index:3;font-family:var(--ff-mono);font-size:10px;letter-spacing:.12em;color:rgba(255,255,255,.8)}
.shot.hoverable img{transition:transform .8s var(--ease-out)}
.shot.hoverable:hover img{transform:scale(1.06)}

/* parallax inner */
.px{will-change:transform}

/* ============================================================
   HERO (split: type panel + tall photo)
   ============================================================ */
.hero{position:relative;padding-top:clamp(50px,9vh,96px);padding-bottom:var(--sec)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,4vw,68px);align-items:center}
.hero-kick{margin-bottom:26px}
.hero h1{margin-bottom:26px}
.hero-lede{max-width:42ch;margin-bottom:34px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero-shot{aspect-ratio:4/5;box-shadow:0 40px 80px -40px rgba(20,18,12,.5)}
.hero-foot{display:flex;gap:34px;margin-top:42px;flex-wrap:wrap}
.hf{display:flex;flex-direction:column;gap:5px}
.hf .k{font-family:var(--ff-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--amber)}
.hf .v{font-family:var(--ff-display);font-weight:600;font-size:1.02rem}

/* page hero variant (interior) */
.phero{position:relative;padding-top:clamp(46px,8vh,84px);padding-bottom:clamp(34px,5vh,60px)}
.phero-top{display:flex;align-items:baseline;gap:16px;margin-bottom:22px}
.phero-idx{font-family:var(--ff-mono);font-size:12px;color:var(--amber)}
.phero-grid{display:grid;grid-template-columns:1fr .85fr;gap:clamp(28px,4vw,60px);align-items:end}
.phero-shot{aspect-ratio:16/10}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{border-block:1px solid var(--line);padding-block:18px;overflow:hidden;background:var(--paper-2)}
.marquee-track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:slide 34s linear infinite}
@keyframes slide{to{transform:translateX(-50%)}}
.marquee:hover .marquee-track{animation-play-state:paused}
.mq{font-family:var(--ff-display);font-weight:600;font-size:clamp(1.1rem,2vw,1.6rem);color:var(--ink);display:inline-flex;align-items:center;padding-inline:26px}
.mq::after{content:"";width:7px;height:7px;border-radius:50%;background:var(--amber);margin-left:52px}

/* ============================================================
   PILLARS (home — 3 short cards)
   ============================================================ */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.pill{background:var(--surface);border:1px solid var(--line);border-radius:var(--rad);padding:30px 26px 28px;position:relative;overflow:hidden;transition:.5s var(--ease)}
.pill::before{content:"";position:absolute;left:0;top:0;width:100%;height:3px;background:var(--amber);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.pill:hover{transform:translateY(-7px);box-shadow:0 30px 50px -34px rgba(20,18,12,.4)}
.pill:hover::before{transform:scaleX(1)}
.pill .pn{font-family:var(--ff-mono);font-size:11px;letter-spacing:.18em;color:var(--amber);margin-bottom:22px}
.pill h3{font-family:var(--ff-display);font-weight:600;font-size:1.32rem;margin-bottom:12px}
.pill p{font-size:.97rem;color:var(--ink-2)}

/* ============================================================
   SECTION HEAD (asymmetric)
   ============================================================ */
.shead{display:grid;grid-template-columns:1fr .8fr;gap:clamp(24px,4vw,56px);align-items:end;margin-bottom:clamp(34px,5vw,58px)}
.shead.rev{grid-template-columns:.8fr 1fr}
.shead.rev .shead-main{order:2}
.shead h2{margin-top:16px}
.shead-aside p{color:var(--ink-2)}

/* ============================================================
   FEATURE SPLIT (asymmetric image + text)
   ============================================================ */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,64px);align-items:center}
.split.rev .split-text{order:2}
.split-text h2{margin-bottom:20px}
.split-text p{color:var(--ink-2);margin-bottom:18px}
.split-points{display:flex;flex-direction:column;gap:13px;margin-top:24px}
.spt{display:flex;gap:14px;align-items:flex-start}
.spt .d{width:7px;height:7px;border-radius:50%;background:var(--amber);margin-top:9px;flex:none}
.spt b{font-family:var(--ff-display);font-weight:600;display:block;margin-bottom:2px}
.spt span{color:var(--ink-2);font-size:.95rem}
.split-shot{aspect-ratio:4/5}

/* ============================================================
   SERVICES — domain grid + stepper
   ============================================================ */
.domains{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.dom{background:var(--surface);border:1px solid var(--line);border-radius:var(--rad);padding:26px 24px;display:flex;flex-direction:column;gap:12px;position:relative;transition:.45s var(--ease)}
.dom:hover{transform:translateY(-5px);border-color:var(--ink);box-shadow:0 26px 44px -32px rgba(20,18,12,.4)}
.dom-top{display:flex;align-items:baseline;justify-content:space-between;gap:14px}
.dom-n{font-family:var(--ff-mono);font-size:11px;letter-spacing:.16em;color:var(--amber)}
.dom-price{font-family:var(--ff-mono);font-size:12px;font-weight:500;color:var(--ink);background:var(--paper-2);border:1px solid var(--line);border-radius:100px;padding:5px 12px;white-space:nowrap}
.dom h3{font-family:var(--ff-display);font-weight:600;font-size:1.24rem;line-height:1.1}
.dom p{font-size:.94rem;color:var(--ink-2)}

.stepper{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.stp{border-top:2px solid var(--ink);padding-top:18px;position:relative}
.stp .sn{font-family:var(--ff-mono);font-size:11px;letter-spacing:.16em;color:var(--amber);margin-bottom:12px}
.stp h4{font-family:var(--ff-display);font-weight:600;font-size:1.1rem;margin-bottom:8px}
.stp p{font-size:.9rem;color:var(--ink-2)}

/* ============================================================
   PRICING bands
   ============================================================ */
.bands{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--rad);overflow:hidden;background:var(--surface)}
.band{display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;padding:24px clamp(20px,3vw,34px);border-top:1px solid var(--line);transition:.4s var(--ease)}
.band:first-child{border-top:none}
.band:hover{background:var(--paper-2)}
.band-n{font-family:var(--ff-mono);font-size:12px;color:var(--amber)}
.band-name{font-family:var(--ff-display);font-weight:600;font-size:clamp(1.1rem,1.8vw,1.4rem)}
.band-name span{display:block;font-family:var(--ff-body);font-weight:400;font-size:.88rem;color:var(--ink-2);margin-top:3px}
.band-val{font-family:var(--ff-mono);font-weight:500;font-size:clamp(1rem,1.6vw,1.25rem);color:var(--ink);text-align:right;white-space:nowrap}
.scope{display:flex;flex-wrap:wrap;gap:10px}
.scope .tag{background:var(--surface)}

/* ============================================================
   REVIEWS
   ============================================================ */
.revs{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.rev{background:var(--surface);border:1px solid var(--line);border-radius:var(--rad);padding:26px 24px;display:flex;flex-direction:column;gap:18px;transition:.45s var(--ease)}
.rev:hover{transform:translateY(-5px);box-shadow:0 26px 44px -32px rgba(20,18,12,.4)}
.rev .q{font-size:.99rem;line-height:1.55;color:var(--ink)}
.rev .q::before{content:"\201C";font-family:var(--ff-display);color:var(--amber);font-size:1.4rem;margin-right:2px}
.rev-who{display:flex;align-items:center;gap:12px;margin-top:auto}
.rev-ava{width:38px;height:38px;border-radius:50%;background:var(--ink);color:var(--paper);font-family:var(--ff-mono);font-size:12px;display:flex;align-items:center;justify-content:center;flex:none}
.rev-meta .nm{font-family:var(--ff-display);font-weight:600;font-size:.95rem;display:block}
.rev-meta .ro{font-size:.8rem;color:var(--ink-2)}

/* ============================================================
   CTA
   ============================================================ */
.cta{position:relative;background:linear-gradient(165deg,var(--panel),var(--panel-2));border-radius:var(--rad);overflow:hidden;padding:clamp(40px,6vw,76px)}
.cta::before{content:"";position:absolute;right:-10%;top:-40%;width:60%;height:180%;background:radial-gradient(circle,rgba(239,77,24,.28),transparent 62%)}
.cta-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.3fr .7fr;gap:40px;align-items:center}
.cta h2{font-family:var(--ff-display);font-weight:700;font-size:clamp(1.8rem,4vw,3.1rem);line-height:1.02;color:#fff;letter-spacing:-.02em}
.cta h2 em{color:var(--amber-2)}
.cta p{color:var(--panel-txt);margin-top:18px;max-width:36ch}
.cta-side{display:flex;flex-direction:column;gap:18px}
.cinfo{display:flex;flex-direction:column;gap:4px}
.cinfo .cl{font-family:var(--ff-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--panel-dim)}
.cinfo .cv{font-size:.95rem;color:#fff}
.cinfo .cv.amber{color:var(--amber-2)}

/* ============================================================
   MODAL + FORMS
   ============================================================ */
.modal{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;padding:20px}
.modal.open{display:flex}
.modal-bg{position:absolute;inset:0;background:rgba(14,16,20,.62);backdrop-filter:blur(5px);opacity:0;transition:.4s}
.modal.open .modal-bg{opacity:1}
.modal-card{position:relative;z-index:2;width:100%;max-width:880px;max-height:92vh;overflow:auto;display:grid;grid-template-columns:1fr .8fr;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--rad);transform:translateY(26px) scale(.98);opacity:0;transition:.5s var(--ease-out)}
.modal.open .modal-card{transform:none;opacity:1}
.modal-side{background:linear-gradient(165deg,var(--panel),var(--panel-2));padding:clamp(26px,3vw,36px);display:flex;flex-direction:column;gap:22px;color:#fff}
.modal-side h3{font-family:var(--ff-display);font-weight:600;font-size:1.4rem}
.modal-side p{color:var(--panel-txt);font-size:.92rem}
.modal-side .cinfo .cl{color:var(--panel-dim)}
.modal-form{padding:clamp(26px,3vw,38px)}
.modal-close{position:absolute;top:14px;right:14px;z-index:5;width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:var(--surface);cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:.3s}
.modal-close:hover{background:var(--ink);color:var(--paper);transform:rotate(90deg)}
.form-head{margin-bottom:22px}
.form-head h3{font-family:var(--ff-display);font-weight:600;font-size:1.5rem;margin-bottom:6px}
.form-head p{font-size:.92rem;color:var(--ink-2)}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:7px}
.field.full{grid-column:1/-1}
.field label{font-family:var(--ff-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2)}
.field label .req{color:var(--amber)}
.field input,.field select,.field textarea{font-family:var(--ff-body);font-size:.96rem;color:var(--ink);background:var(--surface-2);
  border:1px solid var(--line);border-radius:var(--rad-s);padding:12px 14px;transition:.3s;width:100%}
.field textarea{resize:vertical;min-height:96px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(239,77,24,.12)}
.field-err{font-family:var(--ff-mono);font-size:10.5px;color:var(--amber);display:none}
.field.show-err input,.field.show-err select,.field.show-err textarea{border-color:var(--amber)}
.field.show-err .field-err{display:block}
.form-note{font-size:.8rem;color:var(--ink-3);margin-top:14px;line-height:1.5}
.form-submit{margin-top:18px}
.form-success{display:none;text-align:left;padding:8px 0}
.form-success.show{display:block;animation:pop .5s var(--ease-out)}
@keyframes pop{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.ok-ico{width:46px;height:46px;margin-bottom:16px}
.form-success h3{font-family:var(--ff-display);font-weight:600;font-size:1.35rem;margin-bottom:10px}
.form-success p{color:var(--ink-2);font-size:.95rem}

/* contact page layout */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,4vw,56px);align-items:start}
.contact-aside{background:var(--surface);border:1px solid var(--line);border-radius:var(--rad);padding:clamp(26px,3vw,34px);display:flex;flex-direction:column;gap:24px;position:sticky;top:30px}
.contact-aside h3{font-family:var(--ff-display);font-weight:600;font-size:1.3rem}
.ca-row{display:flex;flex-direction:column;gap:5px}
.ca-row .cl{font-family:var(--ff-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber)}
.ca-row .cv{font-size:1rem}
.contact-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--rad);padding:clamp(26px,3vw,38px)}

/* ============================================================
   LEGAL
   ============================================================ */
.legal-wrap{display:grid;grid-template-columns:230px 1fr;gap:clamp(28px,5vw,72px);align-items:start}
.legal-toc{position:sticky;top:30px;display:flex;flex-direction:column;gap:2px}
.legal-toc .toc-k{font-family:var(--ff-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);margin-bottom:14px}
.legal-toc a{font-family:var(--ff-mono);font-size:11px;color:var(--ink-2);padding:8px 0 8px 14px;border-left:1px solid var(--line);transition:.3s;line-height:1.35}
.legal-toc a:hover{color:var(--amber);border-color:var(--amber)}
.legal-body{max-width:72ch}
.legal-sec{padding-block:clamp(20px,3vw,30px);border-top:1px solid var(--line)}
.legal-sec:first-child{border-top:none;padding-top:0}
.legal-sec h2{font-family:var(--ff-display);font-weight:600;font-size:clamp(1.2rem,2.2vw,1.6rem);margin-bottom:16px;display:flex;gap:13px;align-items:baseline}
.legal-sec h2 .ls-n{font-family:var(--ff-mono);font-size:13px;color:var(--amber)}
.legal-sec h3{font-family:var(--ff-display);font-weight:600;font-size:1.02rem;margin:18px 0 7px}
.legal-sec p{margin-bottom:13px;font-size:.97rem;line-height:1.7;color:var(--ink-2)}
.legal-sec ul{margin:0 0 15px 2px;display:flex;flex-direction:column;gap:8px}
.legal-sec li{display:flex;gap:11px;font-size:.95rem;color:var(--ink-2);line-height:1.6}
.legal-sec li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--amber);margin-top:9px;flex:none}
.legal-contact{margin-top:34px;border:1px solid var(--line);border-radius:var(--rad);background:var(--paper-2);padding:clamp(22px,3vw,30px)}
.legal-contact h4{font-family:var(--ff-display);font-weight:600;font-size:1.1rem;margin-bottom:14px}
.lc-row{display:flex;flex-wrap:wrap;gap:24px}
.lc-row .cinfo .cl{color:var(--ink-2)}
.lc-row .cinfo .cv{color:var(--ink)}

/* ============================================================
   404
   ============================================================ */
.stage{min-height:calc(100vh - 0px);display:flex;align-items:center;padding-block:clamp(60px,12vh,140px)}
.stage-body{max-width:640px}
.stage-code{font-family:var(--ff-mono);font-size:13px;letter-spacing:.28em;text-transform:uppercase;color:var(--amber);margin-bottom:22px}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{background:linear-gradient(180deg,var(--paper),var(--paper-2));border-top:1px solid var(--line);padding-block:clamp(46px,7vw,80px)}
.foot-top{display:grid;grid-template-columns:1.5fr .8fr .8fr;gap:clamp(26px,4vw,56px)}
.foot-brand{display:flex;flex-direction:column;gap:18px;max-width:40ch}
.foot-mark{display:flex;align-items:center;gap:13px}
.foot-mark img{width:40px;height:40px}
.foot-mark .nm{font-family:var(--ff-display);font-weight:700;font-size:1.05rem;line-height:1.05}
.foot-mark .nm span{display:block;font-family:var(--ff-mono);font-size:9px;letter-spacing:.2em;color:var(--ink-2);font-weight:400;text-transform:uppercase;margin-top:3px}
.foot-blurb{color:var(--ink-2);font-size:.93rem;line-height:1.6}
.foot-col h5{font-family:var(--ff-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);margin-bottom:18px}
.foot-col ul{list-style:none;display:flex;flex-direction:column}
.foot-col li a{font-family:var(--ff-mono);font-size:12px;color:var(--ink-2);padding:7px 0;display:inline-block;transition:.3s;position:relative}
.foot-col li a:hover{color:var(--amber);padding-left:6px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;margin-top:clamp(38px,6vw,64px);padding-top:26px;border-top:1px solid var(--line)}
.foot-bottom .mono{font-family:var(--ff-mono);font-size:10.5px;letter-spacing:.1em;color:var(--ink-3)}
.foot-big{font-family:var(--ff-display);font-weight:700;font-size:clamp(1.8rem,5vw,3.4rem);line-height:1.02;letter-spacing:-.02em;margin-bottom:clamp(36px,5vw,60px);max-width:20ch}
.foot-big em{color:var(--amber)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  :root{--side:0px}
  .sidebar{display:none}
  .page{margin-left:0}
  .xprog{left:0}
  .topbar{display:flex;position:fixed;inset:0 0 auto 0;z-index:60;height:64px;align-items:center;justify-content:space-between;
    padding-inline:clamp(18px,5vw,32px);background:rgba(244,241,234,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
  .topbar.scrolled{box-shadow:0 8px 30px -20px rgba(20,18,12,.4)}
  .tb-mark{display:flex;align-items:center;gap:10px}
  .tb-mark img{width:34px;height:34px}
  .tb-mark .nm{font-family:var(--ff-display);font-weight:700;font-size:.95rem}
  .burger{width:42px;height:42px;border:1px solid var(--line);border-radius:50%;background:var(--surface);display:flex;flex-direction:column;
    align-items:center;justify-content:center;gap:5px;cursor:pointer}
  .burger span{width:17px;height:1.6px;background:var(--ink);transition:.35s var(--ease)}
  body.menu-open .burger span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
  body.menu-open .burger span:nth-child(2){opacity:0}
  body.menu-open .burger span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}
  .page main{padding-top:64px}
  .drawer{display:block;position:fixed;inset:0;z-index:59;visibility:hidden;pointer-events:none}
  .drawer-bg{position:absolute;inset:0;background:rgba(14,16,20,.5);opacity:0;transition:.4s}
  .drawer-panel{position:absolute;inset:0 14% 0 0;max-width:380px;background:linear-gradient(176deg,var(--panel),var(--panel-2));
    border-right:1px solid var(--panel-line);padding:84px 30px 30px;transform:translateX(-100%);transition:transform .5s var(--ease-out);
    display:flex;flex-direction:column;overflow:auto}
  body.menu-open .drawer{visibility:visible;pointer-events:auto}
  body.menu-open .drawer-bg{opacity:1}
  body.menu-open .drawer-panel{transform:none}
  .dr-link{display:flex;align-items:baseline;gap:14px;padding:14px 0;border-bottom:1px solid var(--panel-line)}
  .dr-link .n{font-family:var(--ff-mono);font-size:11px;color:var(--panel-dim);width:24px}
  .dr-link .t{font-family:var(--ff-display);font-weight:600;font-size:1.5rem;color:var(--panel-txt)}
  .dr-link.active .t{color:#fff}
  .dr-foot{margin-top:auto;padding-top:24px;display:flex;flex-direction:column;gap:16px}
  .dr-cta{justify-content:center;background:var(--amber);border-color:var(--amber);color:#fff}
}
@media (max-width:920px){
  .hero-grid,.phero-grid,.split,.split.rev,.shead,.shead.rev,.cta-inner,.contact-grid,.modal-card,.legal-wrap{grid-template-columns:1fr}
  .split.rev .split-text,.shead.rev .shead-main{order:0}
  .pillars,.domains,.revs,.stepper{grid-template-columns:1fr 1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  .modal-side{display:none}
  .contact-aside{position:static}
  .hero-shot,.phero-shot{order:-1}
  .legal-toc{position:static;flex-direction:row;flex-wrap:wrap;gap:8px}
  .legal-toc a{border-left:none;border:1px solid var(--line);border-radius:100px;padding:7px 12px}
  .legal-toc .toc-k{width:100%;margin-bottom:4px}
}
@media (max-width:600px){
  body{font-size:16px}
  .pillars,.domains,.revs,.stepper,.fgrid,.foot-top{grid-template-columns:1fr}
  .band{grid-template-columns:auto 1fr;gap:14px}
  .band-val{grid-column:2;text-align:left;margin-top:4px}
  .hero-foot{gap:22px}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal,.reveal-blur,.reveal-x{opacity:1!important;transform:none!important;filter:none!important}
  .lines span i{transform:none!important}
  .shot::after{transform:scaleY(0)!important}
  .shot img{transform:scale(1)!important}
  .marquee-track{animation:none!important}
  .cur,.cur-d{display:none!important}
  .px{transform:none!important}
}
