:root{
  color-scheme: dark;

  /* ---- PALETTE · CONSOLE (dark-first, the brand) ---- */
  --base:        #0B0E0D;
  --base-2:      #0E1311;
  --panel:       #101513;
  --panel-2:     #141A18;
  --ink:         #E9ECE7;
  --ink-muted:   #889089;
  --ink-faint:   #7A817B;
  --hair:        rgba(233,236,231,.08);
  --hair-strong: rgba(233,236,231,.14);

  --signal:      #4ADE9E;
  --signal-deep: #18C27E;
  --signal-ink:  #06140D;
  --signal-wash: rgba(74,222,158,.08);
  --glow:        rgba(74,222,158,.14);

  --heat:        #F2845C;
  --heat-deep:   #E26A3F;
  --heat-ink:    #1A0E08;

  --warn:        #E0B15E;
  --warn-ink:    #1A1408;

  --success:     #4ADE9E;
  --danger:      #E5715C;

  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-body:    "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-mono:    "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

  --space-3xs: .25rem;
  --space-2xs: .5rem;
  --space-xs:  .75rem;
  --space-sm:  1rem;
  --space-md:  1.5rem;
  --space-lg:  2rem;
  --space-xl:  3rem;
  --space-2xl: 4.5rem;
  --space-3xl: 7rem;
  --space-4xl: 10rem;

  --radius-xs:  4px;
  --radius-sm:  8px;
  --radius-md:  12px;
  --radius-lg:  18px;
  --radius-pill: 999px;

  --shadow-sm:   0 1px 2px rgba(0,0,0,.4);
  --shadow-md:   0 8px 30px rgba(0,0,0,.45);
  --shadow-lg:   0 24px 60px -12px rgba(0,0,0,.6);
  --shadow-glow: 0 0 0 1px var(--hair), 0 0 40px -8px var(--glow);
  --ring-focus:  0 0 0 2px var(--base), 0 0 0 4px var(--signal);

  --dur-fast:   120ms;
  --dur:        220ms;
  --dur-slow:   420ms;
  --dur-settle: 640ms;
  --pulse-dur:  3.2s;
  --ease-out:    cubic-bezier(.22,.61,.36,1);
  --ease-in-out: cubic-bezier(.65,0,.35,1);
  --ease-signal: cubic-bezier(.16,1,.3,1);

  --maxw:        72rem;
  --maxw-prose:  62ch;
  --gutter:      clamp(1.25rem, 5vw, 6rem);
  --rail-h:      2.75rem;
  --grid-cell:   4.5rem;
  --z-rail:      100;
}

[data-mode="daylight"]{
  color-scheme: light;
  --base:        #F4F2EC;
  --base-2:      #EEEBE2;
  --panel:       #FBFAF6;
  --panel-2:     #FFFFFF;
  --ink:         #171A18;
  --ink-muted:   #565D57;
  --ink-faint:   #686E69;
  --hair:        rgba(20,26,24,.10);
  --hair-strong: rgba(20,26,24,.18);

  --signal:      #097A4A;
  --signal-deep: #0A7E4E;
  --signal-ink:  #FFFFFF;
  --signal-wash: rgba(14,158,99,.10);
  --glow:        rgba(14,158,99,.12);

  --heat:        #B85030;
  --heat-deep:   #AC4A28;
  --heat-ink:    #FFFFFF;

  --warn:        #8A5E12;
  --warn-ink:    #FFFFFF;
  --danger:      #C0472F;

  --shadow-sm:   0 1px 2px rgba(20,26,24,.10);
  --shadow-md:   0 8px 30px rgba(20,26,24,.10);
  --shadow-lg:   0 24px 60px -12px rgba(20,26,24,.16);
  --shadow-glow: 0 0 0 1px var(--hair), 0 0 30px -10px var(--glow);
}

@media (prefers-reduced-motion: reduce){
  :root{ --pulse-dur: 0s; --dur-settle: 0ms; }
}

/* ===== RESET / BASE ===== */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  font-family:var(--font-body);
  background:var(--base);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-size:clamp(1rem,.97rem + .2vw,1.0625rem);
  overflow-x:hidden;
}
img,svg{ max-width:100%; display:block; }
a{ color:var(--signal-deep); text-decoration:none; }
ul,ol{ list-style:none; padding:0; }
button,input,select,textarea{ font:inherit; color:inherit; }
:focus-visible{ outline:none; box-shadow:var(--ring-focus); border-radius:var(--radius-xs); }
@media (forced-colors: active){
  :focus-visible{ outline:2px solid Highlight; outline-offset:2px; }
}

.skip{
  position:absolute; left:var(--space-sm); top:-4rem; z-index:200;
  background:var(--panel); color:var(--ink); padding:.6rem 1rem;
  border:1px solid var(--hair-strong); border-radius:var(--radius-sm);
  transition:top var(--dur) var(--ease-out);
}
.skip:focus{ top:.6rem; }
#main:focus{ outline:none; }

/* ===== LED (only ambient motion) ===== */
.led{
  display:inline-block; width:.6em; height:.6em; border-radius:50%;
  background:var(--signal);
  box-shadow:0 0 0 0 var(--glow);
  flex:0 0 auto;
  animation:pulse var(--pulse-dur) var(--ease-in-out) infinite;
}
@keyframes pulse{
  0%,100%{ box-shadow:0 0 0 0 var(--glow), 0 0 6px 0 var(--signal); opacity:1; }
  50%{ box-shadow:0 0 0 4px transparent, 0 0 3px 0 var(--signal); opacity:.72; }
}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-family:var(--font-body); font-weight:600; font-size:.95rem;
  letter-spacing:.01em; padding:.85rem 1.35rem; border-radius:var(--radius-pill);
  border:1px solid transparent; cursor:pointer;
  transition:transform var(--dur) var(--ease-out), background var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out), color var(--dur) var(--ease-out);
}
.btn:active{ transform:translateY(1px); }
.btn--heat{
  background:var(--heat); color:var(--heat-ink); font-weight:700;
  box-shadow:0 6px 22px -8px var(--heat-deep);
}
.btn--heat:hover{ background:var(--heat-deep); }
.btn--ghost{
  background:transparent; color:var(--ink); border-color:var(--hair-strong);
}
.btn--ghost:hover{ border-color:var(--signal); color:var(--ink); background:var(--signal-wash); }
.btn--heat:focus-visible, .btn--ghost:focus-visible{ box-shadow:var(--ring-focus); }

/* ===== SECTION SCAFFOLD ===== */
.section__eyebrow{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--signal); margin-bottom:var(--space-sm);
}
.section__title{
  font-family:var(--font-display); font-optical-sizing:auto;
  font-weight:540; line-height:1.05; letter-spacing:-.015em;
  font-size:clamp(1.7rem,1.2rem + 2.4vw,3rem);
  text-wrap:balance; max-width:20ch;
}
main > section{ padding-block:clamp(3.5rem,8vw,7rem); position:relative; }

/* ===== RAIL ===== */
.rail{
  position:sticky; top:0; z-index:var(--z-rail);
  background:var(--base);
  border-bottom:1px solid var(--hair);
}
@supports ((backdrop-filter:blur(6px)) or (-webkit-backdrop-filter:blur(6px))){
  .rail{ background:color-mix(in srgb, var(--base) 88%, transparent); -webkit-backdrop-filter:saturate(120%) blur(6px); backdrop-filter:saturate(120%) blur(6px); }
}
.rail__inner{
  min-height:var(--rail-h);
  max-width:var(--maxw); margin-inline:auto;
  padding:.3rem var(--gutter);
  display:flex; align-items:center; gap:var(--space-sm);
  flex-wrap:wrap;
}
.rail__brand{
  font-family:var(--font-mono); font-weight:600; font-size:.85rem;
  color:var(--ink); letter-spacing:.02em; flex:0 0 auto;
}
.rail__brand::before{ content:"▸ "; color:var(--signal); }
.rail__status{
  font-family:var(--font-mono); font-size:.7rem; text-transform:uppercase;
  letter-spacing:.04em; color:var(--ink-muted);
  display:flex; align-items:center; gap:.45rem; flex-wrap:wrap;
  min-width:0;
}
.rail__status b{ color:var(--ink); font-weight:600; }
.rail__sep{ color:var(--ink-faint); }
.rail__avail{
  margin-left:auto; display:inline-flex; align-items:center; gap:.45rem;
  font-family:var(--font-mono); font-size:.7rem; text-transform:uppercase;
  letter-spacing:.06em; color:var(--signal); font-weight:600;
  padding:.25rem .55rem; border:1px solid var(--hair); border-radius:var(--radius-pill);
  flex:0 0 auto;
}
.rail__avail:hover{ background:var(--signal-wash); border-color:var(--signal); }
.rail__nav{ display:flex; gap:.2rem; flex:0 0 auto; }
.rail__link{
  font-size:.82rem; color:var(--ink-muted); padding:.3rem .6rem; border-radius:var(--radius-sm);
  transition:color var(--dur) var(--ease-out), background var(--dur) var(--ease-out);
}
.rail__link:hover{ color:var(--ink); background:var(--panel); }
.rail__slug{
  font-family:var(--font-mono); font-size:.68rem; text-transform:uppercase;
  letter-spacing:.1em; color:var(--signal-deep); flex:0 0 auto;
  min-width:5rem; text-align:right;
}
.rail__slug:empty{ display:none; }
.rail__mode{
  font-family:var(--font-mono); font-size:.66rem; letter-spacing:.1em;
  background:transparent; border:1px solid var(--hair-strong); color:var(--ink-muted);
  padding:.28rem .6rem; border-radius:var(--radius-pill); cursor:pointer; flex:0 0 auto;
  transition:color var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out);
}
.rail__mode:hover{ color:var(--ink); border-color:var(--signal); }
.rail__progress{ height:2px; background:transparent; }
.rail__progress-bar{
  display:block; height:100%; background:var(--signal);
  transform:scaleX(var(--p,0)); transform-origin:left;
}
.rail__status--mini{ display:none; }
@media (max-width:760px){
  .rail__nav, .rail__slug, .rail__status .rail__seg, .rail__sep{ display:none; }
  .rail__status::after{
    content:"NOMINAL · 5/5 · OPEN"; color:var(--ink-muted);
  }
}
@media (max-width:540px){
  .rail__status{ display:none; }
  .rail__inner{ padding-inline:1.1rem; gap:.55rem; }
}

/* ===== HERO ===== */
.hero{ min-height:100svh; display:flex; align-items:center; position:relative; overflow:hidden; padding-block:clamp(3rem,9vh,6rem); }
.hero__grid{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(120% 90% at 12% 88%, var(--glow), transparent 55%),
    repeating-linear-gradient(0deg, var(--hair) 0 1px, transparent 1px var(--grid-cell)),
    repeating-linear-gradient(90deg, var(--hair) 0 1px, transparent 1px var(--grid-cell)),
    var(--base);
  -webkit-mask-image:radial-gradient(130% 100% at 50% 40%, #000 55%, transparent 100%);
  mask-image:radial-gradient(130% 100% at 50% 40%, #000 55%, transparent 100%);
}
.hero__inner{
  position:relative; z-index:1;
  max-width:var(--maxw); margin-inline:auto; width:100%;
  padding-inline:var(--gutter);
  display:grid; gap:clamp(2rem,5vw,4rem);
  grid-template-columns:1fr;
}
.hero__lead, .titleblock{ min-width:0; }
.hero__eyebrow{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--ink-muted); margin-bottom:var(--space-md);
}
.hero__h1{
  font-family:var(--font-display); font-optical-sizing:auto;
  font-variation-settings:"opsz" 120, "wght" 540;
  font-weight:540; line-height:.98; letter-spacing:-.02em;
  font-size:clamp(2.4rem,1.6rem + 4.2vw,6rem); max-width:16ch;
  overflow-wrap:break-word; text-wrap:balance; margin-bottom:var(--space-lg);
}
.hero__h1 em{ font-style:italic; color:var(--signal); }
.hero__h1[data-settle]{ animation:settle var(--dur-settle) var(--ease-signal) both; }
@keyframes settle{
  from{ opacity:0; font-variation-settings:"opsz" 40, "wght" 440; letter-spacing:.01em; }
  to{ opacity:1; font-variation-settings:"opsz" 120, "wght" 540; letter-spacing:-.02em; }
}
.hero__lede{
  font-size:clamp(1.05rem,1rem + .5vw,1.2rem); color:var(--ink-muted);
  max-width:54ch; margin-bottom:var(--space-lg); line-height:1.6;
}
.hero__link{ color:var(--signal-deep); text-decoration:underline; text-decoration-color:var(--signal); text-underline-offset:3px; }
.hero__link:hover{ color:var(--signal); }
.hero__cta{ display:flex; flex-wrap:wrap; gap:var(--space-sm); margin-bottom:var(--space-lg); }
.hero__avail{
  display:flex; flex-wrap:wrap; align-items:center; gap:.4rem .55rem; max-width:100%;
  font-family:var(--font-mono); font-size:.74rem; letter-spacing:.06em;
  text-transform:uppercase; color:var(--signal);
}
.titleblock{
  align-self:start;
  background:var(--panel); border:1px solid var(--hair); border-radius:var(--radius-md);
  box-shadow:var(--shadow-glow); padding:var(--space-sm) var(--space-md);
}
.titleblock__grid > div{
  display:grid; grid-template-columns:7.5rem 1fr; gap:.5rem;
  padding-block:.7rem; border-bottom:1px solid var(--hair);
  align-items:baseline;
}
.titleblock__grid > div:last-child{ border-bottom:0; }
.titleblock dt{
  font-family:var(--font-mono); font-size:.66rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ink-faint);
}
.titleblock dd{
  font-family:var(--font-mono); font-size:.82rem; color:var(--ink);
  display:flex; align-items:center; gap:.45rem;
}
.titleblock__rev{ color:var(--signal-deep); }
@media (min-width:960px){
  .hero__inner{ grid-template-columns:1fr 22rem; align-items:center; }
  .titleblock{ position:sticky; top:calc(var(--rail-h) + 1.5rem); }
}

/* ===== PROOF ===== */
.proof{ background:var(--base-2); border-top:1px solid var(--hair); border-bottom:1px solid var(--hair); padding-block:var(--space-md) !important; }
.proof__row{
  max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter);
  display:flex; gap:clamp(1.25rem,4vw,3rem); flex-wrap:wrap;
}
.proof__item{ display:flex; flex-direction:column; gap:.25rem; min-width:8rem; }
.proof__k{ font-family:var(--font-mono); font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-faint); }
.proof__v{ font-family:var(--font-mono); font-size:.82rem; color:var(--ink); }
#certCountStrip{ color:var(--signal); }
@media (max-width:600px){
  .proof__row{ flex-wrap:nowrap; overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; padding-bottom:.5rem; }
  .proof__item{ scroll-snap-align:start; flex:0 0 auto; }
}

/* ===== ABOUT ===== */
.about__inner{
  max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter);
  display:grid; gap:clamp(1.5rem,4vw,3.5rem); grid-template-columns:1fr;
}
.about__quote{
  font-family:var(--font-display); font-style:italic; font-weight:500;
  font-size:clamp(1.25rem,1.1rem + 1vw,1.75rem); line-height:1.3;
  color:var(--ink); border-left:2px solid var(--signal);
  padding-left:var(--space-md); margin-block:var(--space-md);
  max-width:30ch;
}
.about__lead{ font-size:clamp(1.05rem,1rem + .5vw,1.2rem); color:var(--ink); line-height:1.65; max-width:var(--maxw-prose); }
.about__copy{ color:var(--ink-muted); margin-top:var(--space-sm); max-width:var(--maxw-prose); line-height:1.65; }
.about__facts{ display:grid; gap:.5rem; margin-top:var(--space-md); }
.about__facts li{ display:grid; grid-template-columns:6rem 1fr; gap:.75rem; align-items:baseline; padding-block:.4rem; border-bottom:1px solid var(--hair); }
.about__facts .k{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint); }
.about__facts .v{ font-family:var(--font-mono); font-size:.82rem; color:var(--ink); }
@media (min-width:960px){
  .about__inner{ grid-template-columns:18rem 1fr; }
  .about__head{ position:sticky; top:calc(var(--rail-h) + 1.5rem); align-self:start; }
}

/* ===== CAPS ===== */
.caps__inner{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.caps__map{
  margin-block:var(--space-lg) var(--space-2xl);
  display:grid; grid-template-columns:repeat(4,1fr); gap:.75rem 1rem;
  align-items:stretch; position:relative;
  padding-bottom:3.5rem;
}
.caps__node{
  font-family:var(--font-mono); font-size:.7rem; letter-spacing:.08em; text-transform:uppercase;
  text-align:center; padding:.7rem .5rem; border:1px solid var(--hair);
  border-radius:var(--radius-sm); background:var(--panel); color:var(--ink-muted);
  grid-row:1; grid-column:var(--col);
  position:relative;
}
.caps__node--c1{ --col:1; }
.caps__node--c2{ --col:2; }
.caps__node--c3{ --col:3; }
.caps__node--c4{ --col:4; }
.caps__node--d::after{
  content:""; position:absolute; left:50%; bottom:-1.1rem; width:1px; height:1.1rem;
  background:var(--hair-strong);
}
.caps__bus{
  grid-row:2; grid-column:1 / -1; height:1px; background:var(--hair-strong);
  align-self:center; margin-top:.5rem;
}
.caps__node--core{
  grid-row:3; grid-column:2 / 4; margin-top:.9rem;
  background:var(--signal-wash); border-color:var(--signal); color:var(--signal);
  font-weight:600; padding:.85rem; line-height:1.3; position:relative;
}
.caps__node--core small{ color:var(--ink-muted); font-size:.62rem; }
.caps__node--core::before{
  content:""; position:absolute; left:50%; top:-1rem; width:1px; height:1rem; background:var(--signal);
}
@media (max-width:640px){
  .caps__map{ grid-template-columns:repeat(2,1fr); padding-bottom:2.5rem; }
  .caps__node{ grid-row:auto !important; grid-column:auto !important; }
  .caps__node--d::after, .caps__node--core::before, .caps__bus{ display:none; }
  .caps__node--core{ grid-column:1 / -1; margin-top:.5rem; }
}
.caps__group{ margin-top:var(--space-xl); }
.caps__domain{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-faint); padding-bottom:.6rem; margin-bottom:var(--space-md);
  border-bottom:1px solid var(--hair);
}
.caps__grid{ display:grid; gap:var(--space-md); grid-template-columns:repeat(auto-fill,minmax(17rem,1fr)); }
.cap{ background:var(--panel); border:1px solid var(--hair); border-radius:var(--radius-md); transition:background var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out), transform var(--dur) var(--ease-out); }
.cap__link{ display:block; padding:var(--space-md); color:inherit; height:100%; border-radius:var(--radius-md); }
.cap:hover, .cap:focus-within{ background:var(--panel-2); border-color:var(--hair-strong); transform:translateY(-2px); }
.cap__code{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.08em; color:var(--signal); }
.cap:hover .cap__code, .cap:focus-within .cap__code{ color:var(--signal-deep); }
.cap__name{ font-family:var(--font-display); font-weight:540; font-size:1.25rem; line-height:1.15; margin:.4rem 0 .5rem; letter-spacing:-.01em; }
.cap__outcome{ color:var(--ink-muted); font-size:.92rem; line-height:1.55; }
.cap__tags{ display:flex; flex-wrap:wrap; gap:.4rem; margin-top:var(--space-sm); }

/* ===== TAGS ===== */
.tag{
  font-family:var(--font-mono); font-size:.68rem; letter-spacing:.02em;
  padding:.25rem .55rem; background:var(--panel); border:1px solid var(--hair);
  border-radius:var(--radius-sm); color:var(--ink-muted);
}
.cap__tags .tag{ background:transparent; }

/* ===== STACK ===== */
.stack__inner{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.stack__cols{
  margin-top:var(--space-lg);
  display:grid; gap:var(--space-md); grid-template-columns:repeat(auto-fit,minmax(13rem,1fr));
}
.stack__col{ background:var(--panel); border:1px solid var(--hair); border-radius:var(--radius-md); padding:var(--space-md); }
.stack__k{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:var(--space-sm); }
.tags{ display:flex; flex-wrap:wrap; gap:.4rem; }
.stack__standards{
  margin-top:var(--space-lg);
  display:flex; flex-wrap:wrap; align-items:center; gap:.85rem 1.25rem;
  background:var(--signal-wash); border:1px solid var(--hair);
  border-left:3px solid var(--signal-deep); border-radius:var(--radius-sm);
  padding:var(--space-md);
}
.stack__standards-k{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--signal-deep); }
.tags--standard .tag{ border-color:var(--signal); color:var(--ink); background:transparent; }

/* ===== FLEET ===== */
.fleet__inner{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.fleet__note{ font-family:var(--font-mono); font-size:.74rem; color:var(--ink-muted); margin-top:var(--space-sm); }
.fleet__grid{ margin-top:var(--space-lg); display:grid; gap:var(--space-md); grid-template-columns:repeat(auto-fill,minmax(16rem,1fr)); }
.node{
  background:var(--panel); border:1px solid var(--hair); border-radius:var(--radius-md);
  padding:var(--space-md); position:relative; display:grid; gap:.3rem;
  --node-c:var(--signal);
}
.node__led{
  position:absolute; top:var(--space-md); right:var(--space-md);
  width:.7rem; height:.7rem; border-radius:50%; background:var(--node-c);
  box-shadow:0 0 6px 0 var(--node-c);
  animation:pulse var(--pulse-dur) var(--ease-in-out) infinite;
}
.node__state{
  font-family:var(--font-mono); font-size:.66rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--node-c); font-weight:600;
}
.node__name{ font-family:var(--font-display); font-weight:540; font-size:1.15rem; line-height:1.2; letter-spacing:-.01em; padding-right:1rem; }
.node__issuer{ font-size:.85rem; color:var(--ink-muted); }
.node__counter{ font-family:var(--font-mono); font-size:.8rem; color:var(--node-c); margin-top:.3rem; }
.node__through{ font-family:var(--font-mono); font-size:.7rem; color:var(--ink-faint); }
.node[data-state="warn"]{ --node-c:var(--warn); border-color:color-mix(in srgb,var(--warn) 40%, var(--hair)); }
.node[data-state="danger"]{ --node-c:var(--danger); border-color:color-mix(in srgb,var(--danger) 40%, var(--hair)); }

/* ===== METHOD ===== */
.method__inner{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.method__steps{ margin-top:var(--space-lg); display:grid; gap:var(--space-md); grid-template-columns:repeat(auto-fit,minmax(16rem,1fr)); counter-reset:step; }
.step{ background:var(--panel); border:1px solid var(--hair); border-radius:var(--radius-md); padding:var(--space-md); position:relative; }
.step::before{ content:""; position:absolute; left:0; top:var(--space-md); width:3px; height:1.6rem; background:var(--signal); border-radius:var(--radius-pill); }
.step__title{ font-family:var(--font-mono); font-size:.85rem; letter-spacing:.04em; color:var(--ink); margin-bottom:.6rem; padding-left:.6rem; }
.step__body{ color:var(--ink-muted); font-size:.95rem; line-height:1.6; }

/* ===== ENGAGE ===== */
.engage__inner{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.engage__body{ margin-top:var(--space-sm); color:var(--ink-muted); max-width:var(--maxw-prose); font-size:1.05rem; line-height:1.65; }
.engage__list{ margin-top:var(--space-lg); display:grid; gap:var(--space-sm); max-width:48rem; }
.engage__list li{ position:relative; padding-left:1.6rem; color:var(--ink); line-height:1.55; }
.engage__list li::before{ content:"▸"; position:absolute; left:0; top:0; color:var(--signal); }

/* ===== CONTACT ===== */
.contact{ background:var(--base-2); border-top:1px solid var(--hair); }
.contact__inner{
  max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter);
  display:grid; gap:clamp(2rem,5vw,4rem); grid-template-columns:1fr;
}
.contact__body{ color:var(--ink-muted); margin-top:var(--space-sm); max-width:46ch; line-height:1.65; }
.chip{
  display:inline-flex; align-items:center; gap:.55rem; margin-top:var(--space-md);
  font-family:var(--font-mono); font-size:.85rem; color:var(--ink);
  background:var(--panel); border:1px solid var(--hair-strong); border-radius:var(--radius-pill);
  padding:.5rem .9rem; cursor:pointer;
  transition:border-color var(--dur) var(--ease-out), background var(--dur) var(--ease-out);
}
.chip:hover{ border-color:var(--signal); background:var(--signal-wash); }
.chip__icon{ color:var(--signal); }
.chip.is-copied{ border-color:var(--signal); background:var(--signal-wash); color:var(--signal); }
.chip__live{ font-family:var(--font-mono); font-size:.72rem; color:var(--signal); margin-top:.4rem; min-height:1.1em; }
.contact__avail{ display:inline-flex; align-items:center; gap:.55rem; margin-top:var(--space-md); font-family:var(--font-mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; color:var(--signal); }

.form{ background:var(--panel); border:1px solid var(--hair); border-radius:var(--radius-lg); padding:clamp(1.25rem,3vw,2rem); box-shadow:var(--shadow-md); }
.form__row{ display:grid; gap:.4rem; margin-bottom:var(--space-md); }
.form__label{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-muted); }
.form__opt{ color:var(--ink-faint); text-transform:none; letter-spacing:0; }
.form__input{
  background:var(--base); border:1px solid var(--ink-faint); border-radius:var(--radius-sm);
  padding:.7rem .85rem; color:var(--ink); font-family:var(--font-body); font-size:.95rem; width:100%;
  transition:border-color var(--dur) var(--ease-out), box-shadow var(--dur) var(--ease-out);
}
.form__input::placeholder{ color:var(--ink-faint); }
.form__input:hover{ border-color:var(--ink-faint); }
.form__input:focus{ outline:none; border-color:var(--signal); box-shadow:0 0 0 3px var(--signal-wash); }
.form__input:focus-visible{ box-shadow:var(--ring-focus); }
.form__select{ appearance:none; -webkit-appearance:none; background-image:linear-gradient(45deg,transparent 50%,var(--ink-muted) 50%),linear-gradient(135deg,var(--ink-muted) 50%,transparent 50%); background-position:calc(100% - 1.1rem) center, calc(100% - .75rem) center; background-size:6px 6px,6px 6px; background-repeat:no-repeat; padding-right:2.2rem; }
.form__textarea{ resize:vertical; min-height:7rem; line-height:1.5; }
.form__input.is-invalid{ border-color:var(--danger); }
.form__hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form__foot{ display:flex; flex-wrap:wrap; align-items:center; gap:var(--space-sm); margin-top:var(--space-sm); }
.form__submit[disabled]{ opacity:.6; cursor:progress; }
.form__status{ font-family:var(--font-mono); font-size:.8rem; min-height:1.2em; }
.form__status.is-ok{ color:var(--signal); }
.form__status.is-err{ color:var(--danger); }
.form__privacy{ margin-top:var(--space-md); font-size:.78rem; color:var(--ink-faint); line-height:1.5; }
@media (min-width:880px){
  .contact__inner{ grid-template-columns:1fr 1.05fr; align-items:start; }
  .contact__head{ position:sticky; top:calc(var(--rail-h) + 1.5rem); }
}

/* ===== FOOTER ===== */
.foot{ background:var(--base-2); border-top:1px solid var(--hair); padding-block:var(--space-xl); }
.foot__inner{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); display:flex; flex-wrap:wrap; gap:var(--space-md); align-items:center; justify-content:space-between; }
.foot__tag{ display:inline-flex; align-items:center; gap:.5rem; font-family:var(--font-mono); font-size:.78rem; color:var(--ink-muted); }
.foot__nav{ display:flex; flex-wrap:wrap; gap:.4rem 1rem; }
.foot__nav a{ font-size:.82rem; color:var(--ink-muted); }
.foot__nav a:hover{ color:var(--signal); }
.foot__legal{ width:100%; display:flex; flex-wrap:wrap; gap:.5rem 1.2rem; align-items:center; justify-content:space-between; margin-top:var(--space-sm); padding-top:var(--space-md); border-top:1px solid var(--hair); }
.foot__legalnav{ display:flex; flex-wrap:wrap; gap:.4rem 1rem; }
.foot__legalnav a{ font-size:.78rem; color:var(--ink-faint); }
.foot__legalnav a:hover{ color:var(--signal); }
.foot__copy{ font-family:var(--font-mono); font-size:.72rem; color:var(--ink-faint); }

@media (prefers-reduced-motion: reduce){
  .led, .node__led{ animation:none; }
  .cap, .btn, .form__input, .fab{ transition:none; }
}

/* ===== FLOATING MESSAGE BUTTON + MODAL ===== */
html.fab-lock{ overflow:hidden; }
.fab{
  position:fixed; right:clamp(1rem,3vw,2rem); bottom:clamp(1rem,3vw,2rem); z-index:90;
  display:inline-flex; align-items:center; gap:.5rem;
  background:var(--heat); color:var(--heat-ink); font-weight:700; font-size:.9rem;
  border:1px solid transparent; border-radius:var(--radius-pill); padding:.8rem 1.15rem; cursor:pointer;
  box-shadow:0 12px 30px -8px var(--heat-deep), 0 1px 2px rgba(0,0,0,.3);
  transition:transform var(--dur) var(--ease-out), background var(--dur) var(--ease-out);
}
.fab:hover{ background:var(--heat-deep); transform:translateY(-2px); }
.fab:focus-visible{ box-shadow:var(--ring-focus); }
.fab__icon{ width:1.15rem; height:1.15rem; display:block; flex:0 0 auto; }

.fab-modal{ position:fixed; inset:0; z-index:120; display:grid; place-items:end center; }
.fab-modal[hidden]{ display:none; }
.fab-modal__backdrop{ position:absolute; inset:0; background:rgba(5,7,6,.62); -webkit-backdrop-filter:blur(2px); backdrop-filter:blur(2px); }
.fab-modal__panel{
  position:relative; z-index:1; width:min(31rem, calc(100vw - 1.5rem));
  max-height:calc(100dvh - 1.5rem); overflow:auto; margin:.75rem;
  background:var(--panel); border:1px solid var(--hair-strong); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg); padding:clamp(1.25rem,3vw,1.85rem);
}
@media (min-width:560px){ .fab-modal{ place-items:center; } }
.fab-modal__close{
  position:absolute; top:.55rem; right:.55rem; background:transparent; border:none;
  color:var(--ink-muted); font-size:1.5rem; line-height:1; cursor:pointer; padding:.35rem .6rem; border-radius:var(--radius-sm);
}
.fab-modal__close:hover{ color:var(--ink); background:var(--panel-2); }
.fab-modal__close:focus-visible{ box-shadow:var(--ring-focus); }
.fab-modal__title{ font-family:var(--font-display); font-weight:540; font-size:1.4rem; letter-spacing:-.01em; padding-right:1.5rem; }
.fab-modal__sub{ color:var(--ink-muted); font-size:.92rem; margin-top:.35rem; margin-bottom:var(--space-md); line-height:1.55; }
.fab-modal .form{ box-shadow:none; padding:0; border:none; background:transparent; }
.fab-modal .form__row{ margin-bottom:var(--space-sm); }

/* ===== 404 ===== */
.nf-body{ min-height:100svh; display:grid; place-items:center; text-align:center; padding:2rem;
  background-image:linear-gradient(var(--hair) 1px, transparent 1px), linear-gradient(90deg, var(--hair) 1px, transparent 1px); background-size:2.5rem 2.5rem; }
.nf-wrap{ max-width:34rem; }
.nf-tag{ font-family:var(--font-mono); font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-muted); }
.nf-led{ display:inline-block; width:.6rem; height:.6rem; border-radius:50%; background:var(--warn); box-shadow:0 0 12px 1px rgba(224,177,94,.5); vertical-align:middle; margin-right:.5rem; }
.nf-h1{ font-family:var(--font-mono); font-size:clamp(3rem,12vw,5rem); margin:.4rem 0 .2rem; color:var(--warn); font-weight:600; line-height:1; }
.nf-p{ color:var(--ink-muted); line-height:1.6; font-size:1.05rem; }
.nf-home{ display:inline-block; margin-top:1.6rem; padding:.8rem 1.4rem; border-radius:var(--radius-pill); background:var(--heat); color:var(--heat-ink); text-decoration:none; font-weight:700; font-size:.95rem; }
.nf-home:hover{ background:var(--heat-deep); }
.nf-home:focus-visible{ box-shadow:var(--ring-focus); }