/* ============================================================
   Orchid Sky Consulting — "The Night Shift" operations-ledger system
   One shared stylesheet. Design tokens are a legend, not a palette:
     amber  = running / active   (the agent is working now)
     mint   = passed / healthy   (done, available)
     flag   = mismatch / needs a human (rationed — appears ~twice)
   ============================================================ */

:root{
  /* canvas — deep ink-slate with a cool teal undertone (a powered-down panel) */
  --ink:#0C1418;
  --ink-2:#111E24;
  --ink-3:#16262E;
  --ink-4:#1C313A;

  /* readout text */
  --paper:#E9F1EF;
  --paper-dim:#90A6AB;
  --paper-faint:#5E747B;

  /* legend colors — each MEANS one operational state */
  --signal:#F4A93B;            /* running / active / brand heartbeat (dots, fills, glows) */
  --signal-text:#F4A93B;       /* amber used as small TEXT — deepened in day mode for contrast */
  --signal-soft:rgba(244,169,59,.14);
  --signal-glow:rgba(244,169,59,.10);   /* pointer-following glow tint */
  --ok:#46D9A8;                /* passed / healthy / available (dots, fills) */
  --ok-text:#46D9A8;           /* mint used as small TEXT — deepened in day mode */
  --ok-soft:rgba(70,217,168,.13);
  --flag:#E5573F;              /* flagged / needs a human (rationed) */
  --flag-text:#E5573F;         /* red as TEXT — deepened slightly in day mode */

  /* lines */
  --line:rgba(233,241,239,.10);
  --line-soft:rgba(233,241,239,.055);
  --line-strong:rgba(233,241,239,.18);

  /* ambient layers (overridden in day mode) */
  --grid-line:rgba(233,241,239,.025);
  --glow-warm:rgba(244,169,59,.10);
  --glow-cool:rgba(70,217,168,.05);
  --panel-band:rgba(0,0,0,.16);      /* ledger header/footer band */
  --hairline-inset:rgba(233,241,239,.04);  /* ledger top inset highlight */
  --header-bg:rgba(12,20,24,.82);    /* sticky nav (translucent) */
  --header-solid:var(--ink);         /* sticky nav when mobile menu open */

  --disp:'Space Grotesk',system-ui,sans-serif;
  --body:'Spline Sans',system-ui,sans-serif;
  --mono:'Spline Sans Mono',ui-monospace,monospace;

  --wrap:1140px;
  --gutter:34px;
  --rail:88px;                 /* width of the persistent status rail */
}

/* ============================================================
   THE DAY SHIFT — daylight counterpart. Token overrides only;
   every component re-derives from these. Same ops-ledger identity,
   same 3-color legend (amber=running, mint=ok, red=flag) — but the
   amber/mint/red used as small TEXT are deepened so they stay legible
   on white, while the dots/fills/glows keep their bright hue.
   ============================================================ */
html.day{
  --ink:#EBEFEE;               /* light cool-white canvas */
  --ink-2:#FFFFFF;             /* raised panels */
  --ink-3:#F1F5F4;
  --ink-4:#E2E9E7;

  --paper:#0E1A1E;             /* text */
  --paper-dim:#46595D;
  --paper-faint:#71868B;

  --signal:#F4A93B;            /* keep bright for dots / fills / the avatar gradient */
  --signal-text:#9A5B05;       /* deep amber — legible as text on white */
  --signal-soft:rgba(244,169,59,.16);
  --signal-glow:rgba(212,138,30,.16);
  --ok:#19B886;                /* slightly deepened so the dot reads on white too */
  --ok-text:#0B7A57;           /* deep mint — legible as text on white */
  --ok-soft:rgba(25,184,134,.14);
  --flag:#D6442D;
  --flag-text:#B5331F;         /* deep red — legible as text on white */

  --line:rgba(14,26,30,.12);
  --line-soft:rgba(14,26,30,.06);
  --line-strong:rgba(14,26,30,.20);

  --grid-line:rgba(14,26,30,.05);
  --glow-warm:rgba(244,169,59,.13);
  --glow-cool:rgba(25,184,134,.06);
  --panel-band:rgba(14,26,30,.035);
  --hairline-inset:rgba(255,255,255,.5);
  --panel-shadow:rgba(14,26,30,.22);
  --header-bg:rgba(235,239,238,.82);
  --header-solid:var(--ink);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  background:var(--ink);
  color:var(--paper);
  font-family:var(--body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .35s ease, color .35s ease;
}

/* ambient: faint instrument grid + a single warm signal-glow up top.
   Static, quiet — three layers, no orbs. Tints come from tokens so the
   grid stays visible (dark lines) and the glow stays clean in day mode. */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(120% 80% at 82% -6%, var(--glow-warm), transparent 52%),
    radial-gradient(90% 60% at 12% 0%, var(--glow-cool), transparent 55%);
}
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size:52px 52px;
  -webkit-mask-image:radial-gradient(130% 110% at 50% 0%, #000 38%, transparent 78%);
  mask-image:radial-gradient(130% 110% at 50% 0%, #000 38%, transparent 78%);
}
@media (prefers-reduced-motion:reduce){
  body{transition:none}
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.wrap{
  max-width:var(--wrap);margin:0 auto;
  padding:0 var(--gutter);position:relative;z-index:1;
}

/* ---------- type atoms ---------- */
.mono{font-family:var(--mono)}
.eyebrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--mono);font-size:.72rem;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;color:var(--paper-dim);
}
.eyebrow::before{
  content:"";width:7px;height:7px;border-radius:1px;
  background:var(--signal);box-shadow:0 0 9px var(--signal);
}
h1,h2,h3{font-family:var(--disp);font-weight:600;line-height:1.02;letter-spacing:-.025em}
h1{font-size:clamp(2.6rem,6vw,4.5rem)}
h2{font-size:clamp(1.85rem,3.9vw,2.85rem);letter-spacing:-.022em}
h3{font-size:1.3rem;letter-spacing:-.015em}
p{color:var(--paper)}
.lead{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--paper-dim);line-height:1.62;max-width:60ch}
.hl{color:var(--signal-text)}
em.hl{font-style:normal}

/* the one hollow word — enacts "not yet done / the work resolving".
   outline-only display word, filled by the amber signal underline. */
.outline{
  color:transparent;
  -webkit-text-stroke:1.4px var(--paper);
  text-stroke:1.4px var(--paper);
}

/* ---------- status chip (used as a section status + inline state) ---------- */
.chip{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--mono);font-size:.7rem;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;
  padding:.34em .66em;border:1px solid var(--line-strong);border-radius:3px;
  color:var(--paper-dim);background:var(--ink-2);
}
.chip .tick{width:6px;height:6px;border-radius:50%;background:var(--paper-faint)}
.chip--ok{color:var(--ok-text);border-color:var(--ok-soft)}
.chip--ok .tick{background:var(--ok);box-shadow:0 0 8px var(--ok)}
.chip--run{color:var(--signal-text);border-color:var(--signal-soft)}
.chip--run .tick{background:var(--signal);box-shadow:0 0 8px var(--signal);animation:pulse 1.8s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
@media (prefers-reduced-motion:reduce){.chip--run .tick{animation:none}}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--ink-3);
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--mono);font-size:.84rem;font-weight:500;letter-spacing:.02em;
  padding:.82em 1.25em;border-radius:5px;border:1px solid var(--line-strong);
  background:var(--bg);color:var(--paper);cursor:pointer;
  transition:transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.btn .arrow{transition:transform .18s ease}
.btn:hover{transform:translateY(-2px);border-color:var(--line-strong)}
.btn:hover .arrow{transform:translateX(3px)}
.btn--primary{
  background:var(--signal);color:#1A1102;border-color:var(--signal);font-weight:600;
}
.btn--primary:hover{box-shadow:0 8px 26px -10px rgba(244,169,59,.7);border-color:var(--signal)}
.btn--ghost{background:transparent}
.btn--ghost:hover{border-color:var(--paper-dim);background:var(--ink-2)}

:focus-visible{outline:2px solid var(--signal);outline-offset:3px;border-radius:3px}

/* ============================================================
   NAV  — fixed, mono, with a live status reading on the right
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:50;
  background:var(--header-bg);
  backdrop-filter:saturate(1.2) blur(12px);
  -webkit-backdrop-filter:saturate(1.2) blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;gap:24px;min-height:64px}
.brand{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--disp);font-weight:600;font-size:1.06rem;letter-spacing:-.02em;
  margin-right:auto;
}
.brand .glyph{
  width:13px;height:13px;border-radius:2px;
  background:conic-gradient(from 220deg, var(--signal), var(--ok), var(--signal));
  box-shadow:0 0 11px rgba(244,169,59,.5);
}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none}
.nav-links a{
  font-family:var(--mono);font-size:.82rem;letter-spacing:.02em;
  color:var(--paper-dim);padding:.5em .7em;border-radius:4px;
  transition:color .16s ease, background .16s ease;
}
.nav-links a:hover{color:var(--paper);background:var(--ink-2)}
.nav-links a[aria-current="page"]{color:var(--paper)}
.nav-links a[aria-current="page"]::after{
  content:"";display:block;height:2px;margin-top:3px;border-radius:2px;
  background:var(--signal);box-shadow:0 0 8px var(--signal);
}
.nav-cta{display:flex;align-items:center;gap:12px}

/* ---- theme toggle: a mono "shift" pill (☾ NIGHT ⇄ ☀ DAY) ---- */
.theme-toggle{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.12em;
  text-transform:uppercase;color:var(--paper-dim);cursor:pointer;
  padding:.5em .7em .5em .6em;border:1px solid var(--line-strong);border-radius:5px;
  background:var(--ink-2);
  transition:color .16s ease, border-color .16s ease, background .16s ease;
}
.theme-toggle:hover{color:var(--paper);border-color:var(--paper-faint)}
.theme-toggle .ti{font-size:.95em;line-height:1;color:var(--signal)}
/* show the label for the CURRENT shift: ☾ NIGHT by default, ☀ DAY under html.day */
.theme-toggle .t-night,.theme-toggle .t-day{display:inline-flex;align-items:center;gap:.5em}
.theme-toggle .t-day{display:none}
html.day .theme-toggle .t-night{display:none}
html.day .theme-toggle .t-day{display:inline-flex}

.nav-toggle{
  display:none;width:42px;height:38px;border:1px solid var(--line-strong);
  border-radius:5px;background:var(--ink-2);position:relative;cursor:pointer;
}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:"";position:absolute;left:50%;top:50%;width:17px;height:1.6px;
  background:var(--paper);transform:translate(-50%,-50%);transition:.2s;
}
.nav-toggle span::before{transform:translate(-50%,-7px)}
.nav-toggle span::after{transform:translate(-50%,5.4px)}

/* ============================================================
   THE STATUS RAIL — signature framing device.
   A persistent left gutter that numbers each section as a "run"
   with a timestamp + status tick, so the whole site reads as
   one continuous overnight operations log.
   ============================================================ */
.run{position:relative;padding:78px 0}
.run::before{   /* the rail line — the continuous overnight-run spine */
  content:"";position:absolute;top:0;bottom:0;
  left:max(calc((100vw - var(--wrap))/2 + var(--gutter)), var(--gutter));
  width:1px;background:linear-gradient(180deg,var(--line-strong),var(--line) 50%,var(--line-strong));
}
.run-inner{
  max-width:var(--wrap);margin:0 auto;padding:0 var(--gutter) 0 calc(var(--gutter) + var(--rail));
  position:relative;z-index:1;
}
.run-mark{   /* the timestamp + node on the spine */
  position:absolute;left:0;top:2px;width:var(--rail);
  font-family:var(--mono);font-size:.72rem;font-weight:500;color:var(--paper-dim);
  letter-spacing:.06em;text-align:left;padding-left:2px;
}
.run-mark::before{   /* node — an instrument indicator seated on the spine */
  content:"";position:absolute;left:-3px;top:-9px;width:11px;height:11px;border-radius:50%;
  background:var(--ink);border:1.6px solid var(--signal);
  box-shadow:0 0 0 4px var(--signal-soft), 0 0 12px rgba(244,169,59,.45);
}
.run-mark.ok::before{border-color:var(--ok);box-shadow:0 0 0 4px var(--ok-soft), 0 0 12px rgba(70,217,168,.45)}

.sec-head{margin-bottom:36px}
.sec-head h2{margin-top:14px;max-width:18ch}
.sec-head .lead{margin-top:14px}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;padding:0}
.hero .run-inner{padding-top:74px;padding-bottom:60px}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:54px;align-items:center}
.hero-copy .eyebrow{margin-bottom:24px}
.hero h1{margin-bottom:0}
.hero h1 .nb{white-space:nowrap}
.hero .lead{margin:26px 0 32px;max-width:52ch}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* ---- the LEDGER (signature element): a real overnight run record ---- */
.ledger{
  position:relative;
  background:linear-gradient(180deg,var(--ink-2),var(--ink-3));
  border:1px solid var(--line-strong);border-radius:12px;
  box-shadow:0 30px 70px -40px var(--panel-shadow,rgba(0,0,0,.9)), inset 0 1px 0 var(--hairline-inset);
  overflow:hidden;
}
.ledger-head{
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;border-bottom:1px solid var(--line);background:var(--panel-band);
}
.ledger-head .who{display:flex;align-items:center;gap:11px;margin-right:auto;min-width:0}
.ledger-head .avatar{
  width:38px;height:38px;border-radius:8px;flex:0 0 auto;
  display:grid;place-items:center;font-family:var(--mono);font-weight:600;font-size:.82rem;
  color:var(--ink);background:conic-gradient(from 210deg,var(--signal),var(--ok));
}
.ledger-head .nm{font-family:var(--disp);font-weight:600;font-size:.95rem;line-height:1.15}
.ledger-head .rl{font-family:var(--mono);font-size:.68rem;color:var(--paper-dim);letter-spacing:.04em}
.ledger-body{padding:6px 0}
.lrow{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;
  padding:11px 18px;border-bottom:1px solid var(--line-soft);
  font-family:var(--mono);font-size:.8rem;
}
.lrow:last-child{border-bottom:none}
.lrow .t{color:var(--paper-faint);font-size:.74rem}
.lrow .a{color:var(--paper);letter-spacing:-.01em}
.lrow .a b{color:var(--paper-dim);font-weight:400}    /* the result detail */
.lrow .s{
  display:inline-flex;align-items:center;gap:.45em;
  font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ok-text);
}
.lrow .s .d{width:6px;height:6px;border-radius:50%;background:var(--ok);box-shadow:0 0 7px var(--ok)}
.lrow.run .s{color:var(--signal-text)}
.lrow.run .s .d{background:var(--signal);box-shadow:0 0 7px var(--signal);animation:pulse 1.6s ease-in-out infinite}
@media (prefers-reduced-motion:reduce){.lrow.run .s .d{animation:none}}
.ledger-foot{
  padding:13px 18px;border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:var(--panel-band);
}
.ledger-foot .msg{font-family:var(--disp);font-weight:500;font-size:.92rem;color:var(--paper)}
.ledger-foot .avail{
  display:inline-flex;align-items:center;gap:.5em;font-family:var(--mono);
  font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ok-text);
}
.ledger-foot .avail .d{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok);animation:pulse 2.4s ease-in-out infinite}
@media (prefers-reduced-motion:reduce){.ledger-foot .avail .d{animation:none}}

/* instrument boot — a single amber scan sweeps the readout once as it reveals */
.ledger::before{
  content:"";position:absolute;left:0;right:0;top:0;height:2px;z-index:3;pointer-events:none;
  background:linear-gradient(90deg,transparent,var(--signal) 18%,var(--signal) 82%,transparent);opacity:0;
}
.js .ledger.reveal.in::before{animation:scan 1.8s cubic-bezier(.4,0,.2,1) .35s 1 both}
@keyframes scan{0%{top:0;opacity:0}12%{opacity:.8}88%{opacity:.85}100%{top:100%;opacity:0}}
@media (prefers-reduced-motion:reduce){.ledger::before{display:none}}

/* ============================================================
   STAT STRIP — four readings off the instrument
   ============================================================ */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  border:1px solid var(--line-strong);border-radius:10px;overflow:hidden;
  background:var(--ink-2);
}
.stat{position:relative;padding:26px 22px;border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
.stat .num{
  font-family:var(--disp);font-weight:600;font-size:clamp(1.7rem,3.2vw,2.4rem);
  letter-spacing:-.03em;color:var(--paper);line-height:1;
}
.stat .num.sig{color:var(--signal-text)}
.stat .label{
  margin-top:12px;font-family:var(--mono);font-size:.72rem;line-height:1.5;
  color:var(--paper-dim);letter-spacing:.01em;
}

/* ============================================================
   CARDS — principles, work, services
   ============================================================ */
.card{
  position:relative;background:var(--ink-2);
  border:1px solid var(--line);border-radius:11px;padding:26px;
  transition:border-color .2s ease, transform .2s ease, background .2s ease;
}
/* pointer-following signal glow on hover — shared across all panel surfaces */
.card::after,
.ledger::after,
.stat::after,
.contact-form::after,
.cta-band::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  opacity:0;transition:opacity .25s ease;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%), var(--signal-glow), transparent 60%);
}
.card:hover{border-color:var(--line-strong);transform:translateY(-3px);background:var(--ink-3)}
.card:hover::after,
.ledger:hover::after,
.stat:hover::after,
.contact-form:hover::after,
.cta-band:hover::after{opacity:1}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}

/* principle */
.principle .pkicker{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--signal-text);margin-bottom:16px;
}
.principle h3{margin-bottom:10px}
.principle p{color:var(--paper-dim);font-size:.97rem}

/* work card */
.work-card{display:flex;flex-direction:column}
.wc-top{
  display:flex;align-items:baseline;justify-content:space-between;gap:12px;
  margin-bottom:14px;
}
.wc-index{font-family:var(--mono);font-size:.8rem;color:var(--signal-text);letter-spacing:.06em}
.wc-client{font-family:var(--mono);font-size:.68rem;color:var(--paper-faint);
  letter-spacing:.04em;text-align:right;text-transform:uppercase}
.work-card h3{margin-bottom:9px}
.work-card>p{color:var(--paper-dim);font-size:.97rem;margin-bottom:16px}
.wc-metric{
  margin:auto 0 16px;padding:11px 13px;border-radius:7px;
  background:var(--signal-soft);border:1px solid var(--signal-soft);
  font-family:var(--mono);font-size:.78rem;color:var(--paper-dim);letter-spacing:.02em;
}
.wc-metric b{color:var(--signal-text);font-weight:600}
.pills{display:flex;flex-wrap:wrap;gap:7px;margin-top:auto}
.pill{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.03em;
  padding:.34em .62em;border-radius:4px;border:1px solid var(--line);
  color:var(--paper-dim);background:var(--ink);
}

/* the one FLAGGED card accent — recon agent (rationed red) */
.work-card.flagged .wc-index{color:var(--flag-text)}
.work-card.flagged .wc-metric{background:var(--flag-soft,rgba(229,87,63,.10));border-color:var(--flag-soft-border,rgba(229,87,63,.22))}
.work-card.flagged .wc-metric b{color:var(--flag-text)}

.nda-note{
  font-family:var(--mono);font-size:.74rem;color:var(--paper-faint);
  letter-spacing:.04em;margin-top:22px;display:flex;align-items:center;gap:.6em;
}
.nda-note::before{content:"";width:6px;height:6px;border-radius:1px;background:var(--paper-faint)}

/* service card */
.service .scode{
  font-family:var(--mono);font-size:.78rem;color:var(--signal-text);
  letter-spacing:.08em;margin-bottom:14px;
}
.service h3{margin-bottom:9px}
.service p{color:var(--paper-dim);font-size:.97rem}

/* services teaser (home) */
.teaser{display:grid;gap:0;border:1px solid var(--line);border-radius:11px;overflow:hidden}
.teaser-item{
  display:flex;align-items:center;gap:18px;padding:20px 24px;
  border-bottom:1px solid var(--line);transition:background .16s ease, padding .16s ease;
}
.teaser-item:last-child{border-bottom:none}
.teaser-item:hover{background:var(--ink-2);padding-left:30px}
.teaser-item .tcode{font-family:var(--mono);font-size:.8rem;color:var(--signal-text);flex:0 0 auto;letter-spacing:.04em}
.teaser-item .ttitle{font-family:var(--disp);font-weight:500;font-size:1.1rem;letter-spacing:-.01em}
.teaser-item .tarr{margin-left:auto;color:var(--paper-faint);transition:transform .16s ease, color .16s ease}
.teaser-item:hover .tarr{transform:translateX(4px);color:var(--signal-text)}

/* ============================================================
   USE-CASE TABLE (services)
   ============================================================ */
.usecases{border:1px solid var(--line);border-radius:11px;overflow:hidden}
.uc-row{
  display:grid;grid-template-columns:minmax(180px,.85fr) 1.6fr;gap:24px;
  padding:18px 24px;border-bottom:1px solid var(--line);
  transition:background .16s ease;
}
.uc-row:last-child{border-bottom:none}
.uc-row:hover{background:var(--ink-2)}
.uc-label{
  font-family:var(--mono);font-size:.86rem;color:var(--paper);letter-spacing:.01em;
  display:flex;align-items:baseline;gap:.6em;
}
.uc-label::before{content:"›";color:var(--signal-text);font-weight:700}
.uc-desc{color:var(--paper-dim);font-size:.96rem}

/* note block */
.note-block{
  border-left:2px solid var(--signal);padding:6px 0 6px 24px;max-width:70ch;
}
.note-block h3{margin-bottom:10px}
.note-block p{color:var(--paper-dim)}

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:44px;align-items:start}
.about-photo{
  position:relative;aspect-ratio:4/5;border-radius:12px;overflow:hidden;
  border:1px solid var(--line-strong);
  background:
    radial-gradient(120% 90% at 30% 10%, rgba(244,169,59,.12), transparent 55%),
    linear-gradient(160deg,var(--ink-3),var(--ink-2));
  display:grid;place-items:center;
}
.about-photo .mono-mark{font-family:var(--mono);font-weight:600;font-size:3rem;color:var(--paper-faint)}
.about-photo .ph-caption{position:absolute;left:14px;bottom:13px}
.about-photo img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.bio p{margin-bottom:18px;color:var(--paper);font-size:1.06rem}
.bio p:last-child{margin-bottom:0}
.bio strong{color:var(--paper);font-weight:600}

.creds{list-style:none;display:grid;gap:0;border-top:1px solid var(--line)}
.creds li{padding:20px 0;border-bottom:1px solid var(--line);display:grid;gap:6px}
.cred-title{font-family:var(--disp);font-weight:600;font-size:1.08rem;letter-spacing:-.01em}
.cred-meta{color:var(--paper-dim);font-size:.96rem;font-family:var(--mono);letter-spacing:.005em;line-height:1.5}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:44px;align-items:start}
.contact-methods{list-style:none;display:grid;gap:0;border:1px solid var(--line);border-radius:11px;overflow:hidden}
.contact-method{
  display:flex;flex-direction:column;gap:5px;padding:20px 22px;
  border-bottom:1px solid var(--line);transition:background .16s ease;
}
.contact-methods li:last-child .contact-method{border-bottom:none}
.contact-method:hover{background:var(--ink-2)}
.cm-k{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--paper-faint)}
.cm-v{font-family:var(--disp);font-weight:500;font-size:1.12rem;color:var(--paper);word-break:break-word}
.contact-method:hover .cm-v{color:var(--signal-text)}

.contact-form{
  position:relative;
  background:var(--ink-2);border:1px solid var(--line);border-radius:12px;padding:26px;
  display:grid;gap:16px;
}
.field{display:grid;gap:7px}
.field label{font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--paper-dim)}
.field input,.field textarea{
  font-family:var(--body);font-size:1rem;color:var(--paper);
  background:var(--ink);border:1px solid var(--line-strong);border-radius:7px;
  padding:12px 14px;transition:border-color .16s ease, box-shadow .16s ease;resize:vertical;
}
.field textarea{min-height:128px}
.field input:focus,.field textarea:focus{
  outline:none;border-color:var(--signal);box-shadow:0 0 0 3px var(--signal-soft);
}
.field input::placeholder,.field textarea::placeholder{color:var(--paper-faint)}
.form-note{font-family:var(--mono);font-size:.74rem;color:var(--paper-faint);line-height:1.5}

/* ============================================================
   CTA band / inline
   ============================================================ */
.cta-band{
  position:relative;
  border:1px solid var(--line-strong);border-radius:14px;padding:46px;text-align:center;
  background:
    radial-gradient(120% 130% at 50% 0%, rgba(244,169,59,.08), transparent 60%),
    var(--ink-2);
}
.cta-band .eyebrow{justify-content:center;margin-bottom:18px}
.cta-band h2{margin-bottom:14px}
.cta-band .lead{margin:0 auto 26px;text-align:center}
.cta-band .hero-cta{justify-content:center}
.cta-inline{display:flex;gap:14px;flex-wrap:wrap;margin-top:36px}

/* the page ends at dawn — final CTA seated on a pre-dawn sky (holds in both themes) */
.cta-band--dawn{
  padding:62px 46px 66px;
  background:
    linear-gradient(180deg, rgba(8,13,17,.42) 0%, rgba(8,13,17,.24) 46%, rgba(8,13,17,.56) 100%),
    url('assets/dawn.jpg') center 58%/cover no-repeat,
    var(--ink-2);
  border-color:rgba(244,169,59,.34);
  box-shadow:0 30px 80px -52px rgba(0,0,0,.85);
}
.cta-band--dawn .eyebrow{color:#DCE6E3}
.cta-band--dawn h2{color:#FFFFFF;text-shadow:0 1px 24px rgba(8,13,17,.55)}
.cta-band--dawn .lead{color:#E2EBE8;text-shadow:0 1px 16px rgba(8,13,17,.5)}
.cta-band--dawn .hl{color:var(--signal)}
.cta-band--dawn .btn--ghost{color:#FFFFFF;border-color:rgba(255,255,255,.45);background:rgba(8,13,17,.32)}
.cta-band--dawn .btn--ghost:hover{background:rgba(8,13,17,.55);border-color:rgba(255,255,255,.75)}

/* page intro (inner pages) */
.page-intro{padding-top:30px}
.page-intro .eyebrow{margin-bottom:20px}
.page-intro h1{max-width:16ch}
.page-intro .lead{margin-top:22px}

/* a header row with a trailing link (work/services teasers) */
.head-row{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:36px}
.head-row .lead{margin-top:14px}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{border-top:1px solid var(--line);margin-top:40px;padding:34px 0}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.footer-copy{font-family:var(--mono);font-size:.78rem;color:var(--paper-faint);letter-spacing:.02em}
.footer-links{list-style:none;display:flex;gap:22px}
.footer-links a{font-family:var(--mono);font-size:.78rem;color:var(--paper-dim);letter-spacing:.02em;transition:color .16s ease}
.footer-links a:hover{color:var(--signal-text)}

/* placeholder styling — visibly a placeholder, never invented */
.ph{
  font-family:var(--mono);font-size:.92em;color:var(--signal-text);
  background:var(--signal-soft);border:1px dashed var(--signal-text);
  border-radius:3px;padding:.05em .4em;letter-spacing:.01em;
}
.ph-link[data-ph]{border-bottom:1px dotted var(--paper-faint)}

/* ============================================================
   SCROLL REVEAL — hidden state scoped under html.js so no-JS shows all
   ============================================================ */
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1)}
.js .reveal.in{opacity:1;transform:none}
.js .reveal[data-delay="1"]{transition-delay:.08s}
.js .reveal[data-delay="2"]{transition-delay:.16s}
.js .reveal[data-delay="3"]{transition-delay:.24s}
.js .reveal[data-delay="4"]{transition-delay:.32s}
.js .reveal[data-delay="5"]{transition-delay:.40s}
@media (prefers-reduced-motion:reduce){
  .js .reveal{opacity:1;transform:none;transition:none}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:38px}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:32px}
  .about-photo{max-width:360px}
  .stats{grid-template-columns:1fr 1fr}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line)}
  .grid-3{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  :root{--rail:0px}
  .nav-links,.nav-cta .btn{display:none}
  .nav-toggle{display:block}
  /* open menu: solid header so page content never shows through the dropdown */
  .site-header:has(.nav[data-open="true"]){background:var(--header-solid);border-bottom-color:var(--line-strong)}
  .nav[data-open="true"]{flex-wrap:wrap;padding-bottom:6px}
  .nav[data-open="true"] .brand,
  .nav[data-open="true"] .nav-cta{order:0}
  .nav[data-open="true"] .nav-links{
    order:1;display:flex;flex-direction:column;align-items:stretch;width:100%;
    gap:2px;padding:8px 0 10px;border-top:1px solid var(--line);margin-top:6px;
  }
  .nav[data-open="true"] .nav-links a{padding:.7em .4em;font-size:1rem}
  .nav[data-open="true"] .nav-links a[aria-current="page"]::after{display:none}
  .nav[data-open="true"] .nav-links a[aria-current="page"]{color:var(--signal)}
  .run::before{display:none}
  .run-inner{padding-left:var(--gutter)}
  .run-mark{
    position:static;width:auto;margin-bottom:16px;display:inline-flex;align-items:center;gap:.6em;
  }
  .run-mark::before{position:static;top:0;left:0}
  .grid-3,.grid-2{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid var(--line)}
  .stat:last-child{border-bottom:none}
  .uc-row{grid-template-columns:1fr;gap:6px}
  .head-row{align-items:flex-start}
  .cta-band{padding:32px 22px}
}
@media (max-width:420px){
  :root{--gutter:20px}
  .ledger-foot{flex-direction:column;align-items:flex-start}
}
