/* ==========================================================================
   Safe Check-In | bespoke flagship (safecheckin.com.au)
   "Steady signal in the dark." Deep indigo + signal teal, warm amber reserved
   only for the escalation ladder. Space Grotesk display + IBM Plex Sans body.
   Self-contained. Works with fonts/JS absent. A project of Alien IT Solutions.
   ========================================================================== */
:root{
  --bg:        oklch(0.985 0.006 250);
  --bg-2:      oklch(0.965 0.012 250);
  --paper:     oklch(1 0 0);
  --ink:       oklch(0.26 0.03 264);
  --ink-soft:  oklch(0.40 0.03 264);
  --muted:     oklch(0.52 0.025 264);
  --brand:     oklch(0.60 0.12 200);
  --brand-ink: oklch(0.46 0.105 212);
  --brand-deep:oklch(0.30 0.07 235);
  --night:     oklch(0.22 0.04 264);
  --night-2:   oklch(0.27 0.05 262);
  --accent:    oklch(0.72 0.16 62);
  --accent-ink:oklch(0.58 0.16 54);
  --ok:        oklch(0.66 0.15 158);
  --ok-deep:   oklch(0.50 0.13 160);
  --line:      oklch(0.90 0.012 250);
  --line-soft: oklch(0.93 0.008 250);
  --on-dark:   oklch(0.96 0.01 240);

  --disp: "Space Grotesk", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --sans: "IBM Plex Sans", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --maxw: 1180px;
  --gutter: clamp(1.25rem, 5vw, 5rem);
  --radius: 18px; --radius-lg: 26px; --radius-sm: 12px;
  --shadow: 0 2px 6px oklch(0.3 0.05 264 / .06), 0 26px 60px -28px oklch(0.25 0.06 264 / .32);
  --shadow-sm: 0 1px 3px oklch(0.3 0.05 264 / .07), 0 12px 26px -18px oklch(0.25 0.06 264 / .26);

  --z-nav:200; --z-demo:5;
  --ease: cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0; background:var(--bg); color:var(--ink); font-family:var(--sans);
  font-size:clamp(1.02rem,.99rem + .18vw,1.13rem); line-height:1.62;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{ max-width:100%; display:block; }
a{ color:var(--brand-ink); }
::selection{ background:oklch(0.60 0.12 200 / .26); }

h1,h2,h3,h4{ font-family:var(--disp); font-weight:600; line-height:1.05;
  letter-spacing:-0.02em; text-wrap:balance; margin:0; color:var(--ink); }
h1{ font-size:clamp(2.5rem,1.7rem + 3.8vw,4.6rem); font-weight:600; }
h2{ font-size:clamp(1.95rem,1.4rem + 2.4vw,3.2rem); }
h3{ font-size:clamp(1.25rem,1.08rem + .8vw,1.6rem); }
p{ margin:0; text-wrap:pretty; }
.lead{ font-size:clamp(1.16rem,1.04rem + .56vw,1.45rem); line-height:1.5; color:var(--ink-soft); font-family:var(--sans); }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.measure{ max-width:62ch; }
.skip{ position:absolute; left:-999px; }
.skip:focus{ left:1rem; top:1rem; z-index:999; background:var(--ink); color:#fff; padding:.7rem 1rem; border-radius:8px; }
:where(a,button,summary,input,textarea):focus-visible{ outline:3px solid var(--brand); outline-offset:3px; border-radius:6px; }

.kicker{ font-family:var(--sans); font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  color:var(--brand-ink); font-size:.78rem; display:inline-flex; align-items:center; gap:.5rem; }
.kicker svg{ width:15px; height:15px; }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.55rem; font-family:var(--sans); font-weight:600; white-space:nowrap;
  font-size:1rem; line-height:1; padding:.95rem 1.5rem; border-radius:999px; border:1.6px solid transparent;
  text-decoration:none; cursor:pointer; transition:transform .35s var(--ease), background-color .25s, box-shadow .35s, border-color .25s; }
.btn--primary{ background:var(--brand); color:oklch(0.99 0.01 200); box-shadow:0 10px 26px -12px oklch(0.60 0.12 200 / .7); }
.btn--primary:hover{ background:var(--brand-ink); transform:translateY(-2px); box-shadow:0 16px 34px -12px oklch(0.60 0.12 200 / .75); }
.btn--ghost{ background:transparent; color:var(--brand-ink); border-color:var(--line); }
.btn--ghost:hover{ border-color:var(--brand); transform:translateY(-2px); }
.btn--lg{ padding:1.08rem 1.85rem; font-size:1.06rem; }
.btn--on-dark{ background:var(--on-dark); color:var(--brand-deep); }
.btn--on-dark:hover{ background:#fff; color:var(--brand-deep); }
.btn--ghost-dark{ background:transparent; color:var(--on-dark); border-color:oklch(1 0 0 / .28); }
.btn--ghost-dark:hover{ border-color:oklch(1 0 0 / .6); transform:translateY(-2px); }
.textlink{ color:var(--brand-ink); font-weight:600; text-decoration:none; border-bottom:2px solid oklch(0.60 0.12 200 / .42); padding-bottom:1px; transition:border-color .25s; }
.textlink:hover{ border-color:var(--brand); }
@media (prefers-reduced-motion: reduce){ .btn:hover{ transform:none; } }

/* ---------- header ---------- */
.nav{ position:sticky; top:0; z-index:var(--z-nav); background:oklch(0.985 0.006 250 / .82); backdrop-filter:blur(12px) saturate(1.3);
  border-bottom:1px solid transparent; transition:border-color .3s, background-color .3s; }
.nav.is-stuck{ border-color:var(--line); }
.nav__in{ display:flex; align-items:center; justify-content:space-between; min-height:72px; gap:1rem; }
.brand{ display:inline-flex; align-items:center; gap:.6rem; text-decoration:none; color:var(--ink); font-family:var(--disp); font-weight:600; font-size:1.24rem; letter-spacing:-0.02em; }
.brand svg{ width:30px; height:30px; flex:none; }
.nav__cta{ display:flex; align-items:center; gap:1.35rem; }
.nav__cta a:not(.btn){ color:var(--ink-soft); text-decoration:none; font-weight:500; font-size:.96rem; }
.nav__cta a:not(.btn):hover{ color:var(--brand-ink); }
@media (max-width:720px){ .nav__cta a:not(.btn){ display:none; } }

/* ---------- hero ---------- */
.hero{ position:relative; background:var(--night); color:var(--on-dark); overflow:hidden;
  padding:clamp(3rem,2.5rem + 5vw,6.5rem) 0 clamp(3rem,2.5rem + 4vw,5.5rem); }
.hero::before{ content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(48% 52% at 84% 12%, oklch(0.60 0.12 200 / .3), transparent 72%),
             radial-gradient(50% 48% at 6% 96%, oklch(0.30 0.07 235 / .55), transparent 70%); }
.hero .wrap{ position:relative; z-index:1; }
.hero__in{ display:grid; grid-template-columns:1.02fr .98fr; gap:clamp(2rem,4vw,4.5rem); align-items:center; }
@media (max-width:920px){ .hero__in{ grid-template-columns:1fr; gap:2.5rem; } }
.hero h1{ color:var(--on-dark); margin:1.1rem 0 1.2rem; }
.hero h1 em{ font-style:normal; color:oklch(0.78 0.1 200); }
.hero .kicker{ color:oklch(0.78 0.1 200); }
.hero .lead{ color:oklch(0.85 0.02 240); max-width:40ch; margin-bottom:2rem; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:1rem; align-items:center; }
.hero__reassure{ margin-top:2rem; display:flex; flex-wrap:wrap; gap:.55rem 1.4rem; color:oklch(0.78 0.02 240); font-size:.95rem; font-weight:500; }
.hero__reassure span{ display:inline-flex; align-items:center; gap:.45rem; }
.hero__reassure svg{ width:18px; height:18px; color:oklch(0.74 0.12 200); flex:none; }
.hero__000{ margin-top:1.6rem; display:inline-flex; gap:.6rem; align-items:flex-start; max-width:46ch;
  background:oklch(1 0 0 / .07); border:1px solid oklch(1 0 0 / .16); border-radius:14px; padding:.75rem .95rem; color:oklch(0.86 0.02 240); font-size:.92rem; }
.hero__000 svg{ width:18px; height:18px; flex:none; color:oklch(0.8 0.12 62); margin-top:.1rem; }
.hero__000 b{ color:#fff; }

/* ---------- the demo (centrepiece) ---------- */
.demo{ position:relative; background:linear-gradient(160deg, oklch(0.27 0.05 262), oklch(0.20 0.04 266));
  border:1px solid oklch(1 0 0 / .12); border-radius:var(--radius-lg); padding:clamp(1.4rem,1rem + 2vw,2.1rem);
  box-shadow:0 40px 90px -40px #000; color:var(--on-dark); }
.demo__chrome{ display:flex; align-items:center; justify-content:space-between; gap:.8rem; margin-bottom:1.1rem; }
.demo__tag{ display:inline-flex; align-items:center; gap:.5rem; font-size:.74rem; font-weight:600; letter-spacing:.05em; text-transform:uppercase;
  color:oklch(0.8 0.02 240); background:oklch(1 0 0 / .08); border:1px solid oklch(1 0 0 / .14); border-radius:999px; padding:.32rem .7rem; }
.demo__tag .live{ width:8px; height:8px; border-radius:50%; background:var(--ok); box-shadow:0 0 0 0 oklch(0.66 0.15 158 / .7); animation:beat 2.2s var(--ease) infinite; }
@keyframes beat{ 0%{ box-shadow:0 0 0 0 oklch(0.66 0.15 158 / .6);} 70%{ box-shadow:0 0 0 8px oklch(0.66 0.15 158 / 0);} 100%{ box-shadow:0 0 0 0 oklch(0.66 0.15 158 / 0);} }
.demo__sim{ font-size:.74rem; color:oklch(0.72 0.02 240); }

.demo__core{ display:grid; grid-template-columns:auto 1fr; gap:clamp(1.1rem,3vw,2rem); align-items:center; }
@media (max-width:560px){ .demo__core{ grid-template-columns:1fr; justify-items:center; text-align:center; } }

.ring{ position:relative; width:clamp(150px,40vw,184px); aspect-ratio:1; flex:none; }
.ring svg{ width:100%; height:100%; transform:rotate(-90deg); }
.ring__track{ fill:none; stroke:oklch(1 0 0 / .12); stroke-width:9; }
.ring__prog{ fill:none; stroke:var(--ok); stroke-width:9; stroke-linecap:round; transition:stroke .5s var(--ease); }
.ring__face{ position:absolute; inset:0; display:grid; place-items:center; text-align:center; }
.ring__num{ font-family:var(--disp); font-weight:600; font-size:clamp(1.9rem,1.4rem + 2vw,2.5rem); line-height:1; color:#fff; font-variant-numeric:tabular-nums; letter-spacing:-.02em; }
.ring__label{ font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; color:oklch(0.74 0.02 240); margin-top:.35rem; }
.demo.is-ok .ring__prog{ stroke:var(--ok); }
.demo.is-warn .ring__prog{ stroke:oklch(0.82 0.12 84); }
.demo.is-esc .ring__prog{ stroke:var(--accent); }

.demo__side{ display:grid; gap:.9rem; min-width:0; }
.demo__status{ font-family:var(--sans); }
.demo__status b{ display:block; font-size:1.06rem; font-weight:600; color:#fff; }
.demo__status span{ font-size:.92rem; color:oklch(0.8 0.02 240); }
.demo__btns{ display:flex; flex-wrap:wrap; gap:.6rem; }
.checkin{ -webkit-appearance:none; appearance:none; border:0; cursor:pointer; font-family:var(--sans); font-weight:700; font-size:1.02rem;
  color:oklch(0.16 0.04 160); background:var(--ok); border-radius:999px; padding:.95rem 1.5rem; display:inline-flex; align-items:center; gap:.5rem;
  box-shadow:0 12px 26px -12px oklch(0.66 0.15 158 / .8); transition:transform .12s var(--ease), background-color .25s, box-shadow .25s; }
.checkin:hover{ background:oklch(0.7 0.15 158); transform:translateY(-1px); }
.checkin:active{ transform:scale(.96); }
.checkin svg{ width:19px; height:19px; }
.demo__mini{ -webkit-appearance:none; appearance:none; cursor:pointer; font-family:var(--sans); font-weight:600; font-size:.9rem;
  color:oklch(0.84 0.02 240); background:transparent; border:1.4px solid oklch(1 0 0 / .22); border-radius:999px; padding:.7rem 1.05rem; transition:border-color .25s, color .25s; }
.demo__mini:hover{ border-color:oklch(1 0 0 / .5); color:#fff; }

/* escalation ladder */
.ladder{ margin-top:1.3rem; border-top:1px solid oklch(1 0 0 / .12); padding-top:1.1rem; display:grid; gap:.5rem; }
.rung{ display:grid; grid-template-columns:auto 1fr auto; gap:.8rem; align-items:center; padding:.6rem .7rem; border-radius:12px;
  background:oklch(1 0 0 / .03); border:1px solid oklch(1 0 0 / .06); opacity:.5; transition:opacity .45s var(--ease), background-color .45s, border-color .45s; }
.rung__ic{ width:34px; height:34px; flex:none; border-radius:10px; background:oklch(1 0 0 / .08); display:grid; place-items:center; color:oklch(0.8 0.02 240); transition:background-color .4s, color .4s; }
.rung__ic svg{ width:18px; height:18px; }
.rung__tx b{ display:block; font-family:var(--sans); font-weight:600; font-size:.95rem; color:#fff; }
.rung__tx span{ font-size:.82rem; color:oklch(0.76 0.02 240); }
.rung__state{ font-size:.74rem; font-weight:600; letter-spacing:.03em; color:oklch(0.7 0.02 240); white-space:nowrap; }
.rung.is-on{ opacity:1; background:oklch(0.72 0.16 62 / .14); border-color:oklch(0.72 0.16 62 / .4); }
.rung.is-on .rung__ic{ background:oklch(0.72 0.16 62 / .9); color:oklch(0.2 0.04 60); }
.rung.is-on .rung__state{ color:oklch(0.86 0.12 70); }
.rung.is-done{ opacity:1; }
.rung.is-done .rung__ic{ background:oklch(0.66 0.15 158 / .9); color:oklch(0.16 0.04 160); }
.rung.is-done .rung__state{ color:oklch(0.78 0.13 158); }
.demo__foot{ margin-top:.95rem; font-size:.82rem; color:oklch(0.72 0.02 240); display:flex; gap:.5rem; align-items:flex-start; }
.demo__foot svg{ width:15px; height:15px; flex:none; margin-top:.15rem; color:oklch(0.7 0.1 200); }
@media (prefers-reduced-motion: reduce){ .demo__tag .live{ animation:none; } }

/* ---------- section rhythm ---------- */
.section{ padding:clamp(3.5rem,3rem + 4vw,7rem) 0; }
.section--tight{ padding-block:clamp(3rem,2.5rem + 3vw,5rem); }
.section__lead{ max-width:40ch; }
.section__lead h2{ margin-bottom:1rem; }
.section__lead .kicker{ margin-bottom:1rem; }
.section__lead p{ color:var(--ink-soft); font-size:1.16rem; }
.center{ margin-inline:auto; text-align:center; }
.center.section__lead{ max-width:52ch; }

/* ---------- how it works: numbered steps ---------- */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.5rem,3vw,2.6rem); margin-top:clamp(2rem,4vw,3.2rem); counter-reset:s; }
@media (max-width:820px){ .steps{ grid-template-columns:1fr; gap:0; } }
.step{ counter-increment:s; position:relative; padding-top:1.6rem; border-top:2px solid var(--line); }
@media (max-width:820px){ .step{ padding:1.6rem 0; border-top:0; } .step + .step{ border-top:1px solid var(--line); } }
.step::before{ content:counter(s,decimal-leading-zero); font-family:var(--disp); font-weight:600; font-size:1.1rem; color:var(--brand-ink); position:absolute; top:1.5rem; right:0; }
.step h3{ font-size:1.28rem; margin:.2rem 0 .5rem; }
.step p{ color:var(--ink-soft); }

/* ---------- two faces ---------- */
.faces{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.2rem,3vw,2rem); margin-top:clamp(1.8rem,3vw,2.6rem); }
@media (max-width:820px){ .faces{ grid-template-columns:1fr; } }
.face{ border-radius:var(--radius-lg); padding:clamp(1.6rem,1.2rem + 2vw,2.4rem); border:1px solid var(--line); background:var(--paper); box-shadow:var(--shadow-sm); display:flex; flex-direction:column; }
.face--personal{ background:linear-gradient(165deg, oklch(0.97 0.02 200), var(--paper) 60%); }
.face--biz{ background:linear-gradient(165deg, oklch(0.97 0.015 250), var(--paper) 60%); }
.face__tag{ display:inline-flex; align-items:center; gap:.5rem; font-size:.78rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  color:var(--brand-ink); margin-bottom:1rem; }
.face__tag svg{ width:18px; height:18px; }
.face h3{ font-size:clamp(1.5rem,1.2rem + 1.2vw,2rem); margin-bottom:.7rem; }
.face > p{ color:var(--ink-soft); }
.face ul{ list-style:none; margin:1.3rem 0 1.6rem; padding:0; display:grid; gap:.7rem; }
.face li{ display:grid; grid-template-columns:auto 1fr; gap:.6rem; align-items:start; font-size:.98rem; color:var(--ink-soft); }
.face li svg{ width:19px; height:19px; flex:none; color:var(--brand); margin-top:.15rem; }
.face .btn{ margin-top:auto; align-self:flex-start; }
.face__caveat{ margin-top:1.1rem; padding-top:1rem; border-top:1px solid var(--line); font-size:.88rem; color:var(--muted); display:flex; gap:.5rem; align-items:flex-start; }
.face__caveat svg{ width:17px; height:17px; flex:none; color:var(--accent-ink); margin-top:.12rem; }

/* ---------- proof: runs on a real stack ---------- */
.proof{ background:var(--night); color:var(--on-dark); position:relative; overflow:hidden; }
.proof::before{ content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(40% 50% at 88% 0%, oklch(0.60 0.12 200 / .22), transparent 70%),
             radial-gradient(45% 50% at 4% 100%, oklch(0.30 0.07 235 / .5), transparent 72%); }
.proof .wrap{ position:relative; z-index:1; }
.proof__lead{ max-width:46ch; }
.proof__lead h2{ color:var(--on-dark); margin-bottom:1rem; }
.proof__lead .kicker{ color:oklch(0.78 0.1 200); margin-bottom:1rem; }
.proof__lead p{ color:oklch(0.84 0.02 240); font-size:1.16rem; }
.stack{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,2.5vw,1.6rem); margin-top:clamp(2rem,4vw,3rem); }
@media (max-width:820px){ .stack{ grid-template-columns:1fr; } }
.stack__card{ background:oklch(1 0 0 / .05); border:1px solid oklch(1 0 0 / .12); border-radius:var(--radius); padding:1.5rem; }
.stack__card .ic{ width:46px; height:46px; border-radius:13px; background:oklch(0.60 0.12 200 / .2); color:oklch(0.82 0.1 200); display:grid; place-items:center; margin-bottom:1rem; }
.stack__card .ic svg{ width:24px; height:24px; }
.stack__card h3{ color:#fff; font-size:1.2rem; margin-bottom:.45rem; }
.stack__card p{ color:oklch(0.82 0.02 240); font-size:.96rem; }
.stack__card code{ font-family:ui-monospace, "SF Mono", Menlo, monospace; font-size:.84em; color:oklch(0.84 0.1 200); }
.proof__note{ margin-top:2rem; color:oklch(0.78 0.02 240); font-size:.96rem; max-width:62ch; }

/* ---------- privacy / dignity strip ---------- */
.privacy{ background:var(--bg-2); }
.privacy__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.4rem,3vw,2.4rem); margin-top:2.2rem; }
@media (max-width:820px){ .privacy__grid{ grid-template-columns:1fr; gap:1.6rem; } }
.privacy__item{ display:grid; gap:.5rem; }
.privacy__item .mark{ width:48px; height:48px; border-radius:50%; background:var(--paper); display:grid; place-items:center; color:var(--brand); box-shadow:var(--shadow-sm); margin-bottom:.4rem; }
.privacy__item .mark svg{ width:23px; height:23px; }
.privacy__item h3{ font-size:1.2rem; }
.privacy__item p{ color:var(--ink-soft); font-size:.98rem; }

/* ---------- band (callout) ---------- */
.band{ background:linear-gradient(135deg, oklch(0.46 0.105 212), oklch(0.30 0.07 235)); color:var(--on-dark); border-radius:var(--radius-lg);
  padding:clamp(2.2rem,1.8rem + 4vw,4rem); }
.band h2{ color:var(--on-dark); max-width:20ch; margin-bottom:1rem; }
.band p{ color:oklch(0.9 0.02 220); max-width:54ch; font-size:1.14rem; }
.band__chips{ display:flex; flex-wrap:wrap; gap:.7rem; margin-top:1.7rem; }
.band__chips span{ background:oklch(1 0 0 / .14); border:1px solid oklch(1 0 0 / .22); border-radius:999px; padding:.5rem 1rem; font-size:.92rem; font-weight:500; }

/* ---------- faq ---------- */
.faq{ max-width:760px; margin-top:2.4rem; }
.faq details{ border-bottom:1px solid var(--line); }
.faq summary{ list-style:none; cursor:pointer; padding:1.35rem 2.5rem 1.35rem 0; position:relative; font-family:var(--disp); font-weight:500; font-size:1.18rem; color:var(--ink); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:""; position:absolute; right:.3rem; top:50%; width:12px; height:12px; margin-top:-7px;
  border-right:2px solid var(--brand); border-bottom:2px solid var(--brand); transform:rotate(45deg); transition:transform .3s var(--ease); }
.faq details[open] summary::after{ transform:rotate(225deg); }
.faq p{ color:var(--ink-soft); padding-bottom:1.35rem; max-width:64ch; }
.faq p + p{ padding-top:0; margin-top:-.6rem; }

/* ---------- closing CTA ---------- */
.close{ text-align:center; position:relative; overflow:hidden; }
.close::before{ content:""; position:absolute; inset:auto -10% -45% -10%; height:72%; z-index:-1;
  background:radial-gradient(50% 100% at 50% 100%, oklch(0.60 0.12 200 / .2), transparent 72%); }
.close h2{ max-width:18ch; margin:0 auto 1.2rem; }
.close p{ max-width:48ch; margin:0 auto 2rem; color:var(--ink-soft); font-size:1.16rem; }
.close__cta{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.close__000{ margin-top:1.8rem; color:var(--muted); font-size:.92rem; }

/* ---------- footer ---------- */
.foot{ background:var(--night); color:oklch(0.82 0.02 240); padding:clamp(3rem,2rem + 3vw,4.5rem) 0 2.4rem; }
.foot a{ color:oklch(0.88 0.02 240); }
.foot__top{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:2.5rem; }
.foot__brand{ max-width:32ch; }
.foot__brand .brand{ color:var(--on-dark); }
.foot__brand p{ margin-top:.9rem; color:oklch(0.76 0.02 240); font-size:.96rem; }
.foot__cols{ display:flex; flex-wrap:wrap; gap:2.4rem 3.4rem; }
.foot__col h4{ font-family:var(--sans); font-size:.74rem; text-transform:uppercase; letter-spacing:.08em; color:oklch(0.78 0.1 200); margin:0 0 .9rem; }
.foot__col ul{ list-style:none; margin:0; padding:0; display:grid; gap:.55rem; }
.foot__col a{ text-decoration:none; font-size:.95rem; }
.foot__col a:hover{ color:#fff; }
.foot__000{ margin-top:2rem; padding-top:1.4rem; border-top:1px solid oklch(1 0 0 / .12); color:oklch(0.74 0.02 240); font-size:.9rem; max-width:60ch; }
.foot__bottom{ border-top:1px solid oklch(1 0 0 / .12); margin-top:1.6rem; padding-top:1.5rem; display:flex; flex-wrap:wrap; gap:.6rem 1.6rem; justify-content:space-between; color:oklch(0.68 0.02 240); font-size:.85rem; }
.foot__bottom a{ color:oklch(0.8 0.02 240); }

/* ---------- page head (inner pages) ---------- */
.pagehead{ position:relative; background:var(--night); color:var(--on-dark); overflow:hidden;
  padding:clamp(2.8rem,2.4rem + 4vw,5rem) 0 clamp(2.4rem,2rem + 3vw,3.8rem); }
.pagehead::before{ content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(50% 60% at 86% 6%, oklch(0.60 0.12 200 / .26), transparent 72%),
             radial-gradient(45% 55% at 2% 100%, oklch(0.30 0.07 235 / .5), transparent 72%); }
.pagehead .wrap{ position:relative; z-index:1; }
.pagehead .kicker{ color:oklch(0.78 0.1 200); margin-bottom:1rem; }
.pagehead h1{ color:var(--on-dark); margin-bottom:1.1rem; max-width:18ch; }
.pagehead .lead{ color:oklch(0.85 0.02 240); max-width:50ch; }

/* ---------- contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1.2fr .8fr; gap:clamp(2rem,4vw,4rem); align-items:start; }
@media (max-width:880px){ .contact-grid{ grid-template-columns:1fr; } }
.card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(1.6rem,1.2rem + 2vw,2.6rem); box-shadow:var(--shadow-sm); }
.card h2{ font-size:clamp(1.4rem,1.2rem + 1vw,1.85rem); margin-bottom:1.4rem; }
.form{ display:grid; gap:1.1rem; }
.form__honey{ position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }
.field{ display:grid; gap:.4rem; }
.field label{ font-family:var(--sans); font-weight:600; font-size:.95rem; color:var(--ink); }
.field .opt{ font-weight:400; color:var(--muted); }
.field input,.field textarea{ font-family:var(--sans); font-size:1rem; color:var(--ink); background:var(--bg); border:1.5px solid var(--line);
  border-radius:var(--radius-sm); padding:.85rem 1rem; width:100%; transition:border-color .2s, box-shadow .2s; }
.field textarea{ min-height:7.5rem; resize:vertical; line-height:1.55; }
.field input::placeholder,.field textarea::placeholder{ color:var(--muted); opacity:1; }
.field input:focus,.field textarea:focus{ outline:none; border-color:var(--brand); box-shadow:0 0 0 3px oklch(0.60 0.12 200 / .16); }
.form button{ justify-self:start; }
.form__note{ color:var(--muted); font-size:.88rem; max-width:48ch; }
.aside h2{ font-size:1.3rem; margin-bottom:.5rem; }
.aside h2 + p{ color:var(--ink-soft); }
.aside .next{ list-style:none; margin:1.4rem 0 0; padding:0; display:grid; gap:1.1rem; }
.aside .next li{ display:grid; grid-template-columns:auto 1fr; gap:.9rem; align-items:start; }
.aside .next .n{ width:30px; height:30px; flex:none; border-radius:50%; background:oklch(0.60 0.12 200 / .16); color:var(--brand-ink);
  font-family:var(--disp); font-weight:600; display:grid; place-items:center; font-size:1rem; }
.aside .next b{ font-family:var(--sans); font-weight:600; font-size:.97rem; display:block; color:var(--ink); }
.aside .next small{ color:var(--ink-soft); font-size:.92rem; line-height:1.5; }
.aside__where{ margin-top:1.8rem; padding-top:1.4rem; border-top:1px solid var(--line); color:var(--ink-soft); font-size:.95rem; }
.aside__fine{ margin-top:1.2rem; color:var(--muted); font-size:.88rem; }

/* ---------- prose (guide) ---------- */
.prose{ max-width:72ch; }
.prose h2{ margin:2.4rem 0 .9rem; }
.prose h3{ margin:1.8rem 0 .6rem; }
.prose p{ color:var(--ink-soft); margin-bottom:1rem; }
.prose ul{ color:var(--ink-soft); padding-left:1.2rem; margin:0 0 1.2rem; display:grid; gap:.5rem; }
.prose li{ padding-left:.2rem; }
.prose strong{ color:var(--ink); }
.toc{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); padding:1.4rem 1.6rem; margin-bottom:2.2rem; }
.toc h2{ font-size:1.05rem; margin:0 0 .7rem; }
.toc ul{ list-style:none; margin:0; padding:0; display:grid; gap:.45rem; }
.toc a{ text-decoration:none; color:var(--brand-ink); font-weight:500; }
.toc a:hover{ text-decoration:underline; }

/* ---------- mini hero for thanks / 404 ---------- */
.mini{ padding:clamp(3.5rem,3rem + 5vw,7rem) 0; }
.mini .kicker{ margin-bottom:.9rem; }
.mini h1{ margin-bottom:1.1rem; }
.mini .lead{ max-width:52ch; }
.mini__cta{ margin-top:1.7rem; display:flex; gap:.8rem; flex-wrap:wrap; }

/* ---------- reveal motion ---------- */
.reveal{ transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.is-pending{ opacity:0; transform:translateY(18px); }
@media (prefers-reduced-motion: reduce){ .reveal.is-pending{ opacity:1; transform:none; } .reveal{ transition:none; } }
