/* ═════════════════════════════════════════════════════════════════════
   SECTIONS
   ═════════════════════════════════════════════════════════════════════ */

/* ─── 01 · FRONT MATTER (hero) — limits as headline ───────────── */
.s-hero {
  min-height: 100dvh;
  padding-block: clamp(1.5rem, 4vw, 3.5rem) clamp(2rem, 6vw, 5rem);
  display: grid;
  grid-template-rows: auto auto 1fr;
  gap: clamp(1.25rem, 3vw, 2.5rem);
}
.hero-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--rule);
}
.hero-meta__brand {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
}
.hero-meta__brand .dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  background: var(--phosphor);
  border-radius: 50%;
  margin: 0 .35em -1px;
  animation: pulse 2.4s var(--easing-inout) infinite;
  box-shadow: 0 0 0 0 var(--phosphor);
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(0,255,107,0.4); }
  50%      { box-shadow: 0 0 0 10px rgba(0,255,107,0); }
}
.hero-meta__right {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  flex-wrap: wrap;
}
.hero-meta__issue {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--sub);
}
.hero-meta__issue strong {
  color: var(--ink);
  font-weight: 500;
}

/* ─── GitHub badge in hero meta bar ─── */
.hero-meta__github {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--ink);
  background: var(--paper);
  border: 1px solid var(--ink);
  padding: 0.5rem 0.75rem;
  transition: background var(--dur-fast) var(--easing-out),
              color var(--dur-fast) var(--easing-out),
              transform var(--dur-fast) var(--easing-out);
}
.hero-meta__github:hover {
  background: var(--ink);
  color: var(--phosphor);
  transform: translate(-1px, -1px);
  box-shadow: 2px 2px 0 var(--phosphor);
}

/* ─── Language switcher ─── */
.lang-switcher {
  position: relative;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
}
.lang-switcher__toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.85rem;
  background: var(--paper);
  border: 1px solid var(--ink);
  color: var(--ink);
  font-family: inherit;
  font-size: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  transition: background var(--dur-fast) var(--easing-out),
              color var(--dur-fast) var(--easing-out);
}
.lang-switcher__toggle:hover {
  background: var(--ink);
  color: var(--paper);
}
.lang-switcher__label {
  color: var(--sub);
  margin-right: 0.15rem;
}
.lang-switcher__toggle:hover .lang-switcher__label { color: var(--paper); opacity: 0.7; }
.lang-switcher__current { font-weight: 500; }
.lang-switcher__chev {
  font-size: 0.7em;
  margin-left: 0.15rem;
  transition: transform var(--dur-fast) var(--easing-out);
}
.lang-switcher__toggle[aria-expanded="true"] .lang-switcher__chev { transform: rotate(180deg); }

.lang-switcher__menu {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  background: var(--paper);
  border: 1px solid var(--ink);
  list-style: none;
  margin: 0;
  padding: 0.35rem 0;
  min-width: 12rem;
  z-index: 100;
  max-height: 16rem;
  overflow-y: auto;
  box-shadow: 6px 6px 0 var(--ink);
}
.lang-switcher__menu[hidden] { display: none; }
.lang-switcher__opt {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  width: 100%;
  padding: 0.55rem 0.85rem;
  background: transparent;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--ink);
  text-align: left;
  border: 0;
  cursor: pointer;
  transition: background var(--dur-fast) var(--easing-out),
              color var(--dur-fast) var(--easing-out);
}
.lang-switcher__opt:hover,
.lang-switcher__opt[aria-selected="true"] {
  background: var(--ink);
  color: var(--paper);
}
.lang-switcher__opt[aria-selected="true"] .lang-switcher__opt-code {
  color: var(--phosphor);
}
.lang-switcher__opt-native {
  font-family: var(--font-display);
  font-style: italic;
  text-transform: none;
  letter-spacing: 0;
  font-size: var(--fs-sm);
  margin-right: 0.75rem;
}
.lang-switcher__opt-code { color: var(--sub); }

/* ─── Smaller nameplate (was --fs-mega ~22vw, now ~12vw) ─── */
.hero-nameplate {
  font-size: clamp(4.5rem, 13vw, 12rem);
  font-family: var(--font-display);
  font-weight: 300;
  font-style: italic;
  line-height: 0.85;
  letter-spacing: -0.06em;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 0.5rem;
}
.hero-nameplate .word { display: inline-block; }
.hero-nameplate .midpoint {
  display: inline-block;
  width: 0.5em;
  height: 0.5em;
  background: var(--phosphor);
  border-radius: 50%;
  margin: 0 0.15em 0.15em;
  vertical-align: middle;
  animation: pulse 2.4s var(--easing-inout) infinite;
}
.hero-nameplate__sup {
  font-family: var(--font-mono);
  font-style: normal;
  font-size: var(--fs-sm);
  letter-spacing: var(--tr-wide);
  color: var(--sub);
  align-self: flex-start;
  text-align: right;
  font-weight: 400;
  line-height: 1.4;
  min-width: 12rem;
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(1.75rem, 3.5vw, 3rem);
  align-items: start;
}
@media (min-width: 1000px) {
  .hero-grid { grid-template-columns: minmax(0, 7fr) minmax(0, 5fr); }
}
.hero-grid > * { min-width: 0; } /* prevent grid items from inflating to content width */

/* Right column wrapper: terminal on top, context-control below */
.hero-aside {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  width: 100%;
  min-width: 0;
}

/* ─── Hero pitch (limits headline) ─── */
.hero-pitch {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.hero-pitch__badge {
  display: inline-block;
  align-self: flex-start;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--paper);
  background: var(--ink);
  padding: 0.5rem 0.85rem;
  border-left: 3px solid var(--phosphor);
}
.hero-pitch__title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(2.25rem, 5.5vw, 4.25rem);
  line-height: 0.98;
  letter-spacing: -0.035em;
  color: var(--ink);
}
.hero-pitch__title em {
  color: var(--phosphor-d);
  font-style: italic;
  font-weight: 400;
  position: relative;
}
.hero-pitch__title em::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0.05em;
  height: 0.18em;
  background: var(--phosphor);
  opacity: 0.35;
  z-index: -1;
}
.hero-pitch__body {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  line-height: 1.55;
  color: var(--sub);
  max-width: 38rem;
}
.hero-pitch__body strong {
  color: var(--ink);
  font-weight: 500;
}

/* ─── Hero limits panel (the live 5h/7d meters) ─── */
.hero-limits {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  padding: 1.25rem 1.5rem;
  background: var(--paper);
  border: 1px solid var(--ink);
  box-shadow: 6px 6px 0 var(--ink);
  margin-top: 0.5rem;
  max-width: 36rem;
}
.hero-limits__row {
  display: grid;
  grid-template-columns: minmax(7rem, 9rem) 1fr 3.5rem;
  gap: 0.85rem;
  align-items: center;
}
.hero-limits__label {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--sub);
}
.hero-limits__meter {
  position: relative;
  height: 0.85rem;
  background: var(--paper-3);
  overflow: hidden;
}
.hero-limits__fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--w, 0%);
  background: var(--phosphor);
  transition: width 1.4s var(--easing-out),
              background var(--dur-base) var(--easing-out);
}
.hero-limits__fill[data-state="warn"] {
  background: var(--hot);
  animation: warnPulse 1.5s var(--easing-inout) infinite;
}
@keyframes warnPulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.6; }
}
.hero-limits__pct {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  text-align: right;
  color: var(--ink);
}
.hero-limits__pct[data-state="warn"] { color: var(--hot); }
.hero-limits__alert {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-sm);
  color: var(--sub);
  margin-top: 0.25rem;
  padding-top: 0.85rem;
  border-top: 1px solid var(--rule);
}

.hero-cta {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 1.5rem;
}

/* ─── Hero CONTEXT-CONTROL panel (right column, under terminal) ─── */
.hero-context {
  background: var(--paper);
  border: 1px solid var(--ink);
  box-shadow: 6px 6px 0 var(--ink);
  padding: 1.1rem 1.25rem 1.2rem;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
.hero-context__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--sub);
}
.hero-context__title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(1.1rem, 1.6vw, 1.4rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0;
}
.hero-context__body {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  line-height: 1.45;
  color: var(--sub);
}
.hero-context__body strong { color: var(--ink); font-weight: 500; }
.hero-context__row {
  display: grid;
  grid-template-columns: minmax(6rem, auto) 1fr 3rem;
  gap: 0.65rem;
  align-items: center;
  margin-top: 0.35rem;
}
.hero-context__label {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--sub);
}
.hero-context__meter {
  position: relative;
  height: 0.85rem;
  background: var(--paper-3);
  overflow: hidden;
}
/* 60% threshold marker — vertical hairline */
.hero-context__threshold {
  position: absolute;
  top: -2px; bottom: -2px;
  left: 60%;
  width: 1px;
  background: var(--ink);
  opacity: 0.5;
  z-index: 2;
}
.hero-context__threshold::before {
  content: "60%";
  position: absolute;
  top: -0.95rem;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 0.05em;
  color: var(--sub);
  background: var(--paper);
  padding: 0 0.15rem;
  white-space: nowrap;
}
.hero-context__fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--w, 0%);
  background: var(--phosphor);
  transition: width 1.3s var(--easing-out),
              background var(--dur-base) var(--easing-out);
  z-index: 1;
}
.hero-context__fill[data-state="warn"]     { background: #F59E0B; }   /* amber */
.hero-context__fill[data-state="critical"] {
  background: var(--hot);
  animation: warnPulse 1.3s var(--easing-inout) infinite;
}
.hero-context__pct {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  text-align: right;
  color: var(--ink);
}
.hero-context__pct[data-state="warn"]     { color: #B45309; }
.hero-context__pct[data-state="critical"] { color: var(--hot); }

.hero-context__status {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--phosphor-d);
  padding-top: 0.55rem;
  margin-top: 0.4rem;
  border-top: 1px solid var(--rule);
  transition: color var(--dur-base) var(--easing-out);
  min-height: 1.5em;
}
.hero-context__status[data-state="warn"]     { color: #B45309; }
.hero-context__status[data-state="critical"] { color: var(--hot); }
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .6em;
  padding: 1.05em 1.6em;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  font-weight: 500;
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  border: 1px solid var(--ink);
  border-radius: 0;
  transition: transform var(--dur-fast) var(--easing-out),
              background var(--dur-fast) var(--easing-out),
              color var(--dur-fast) var(--easing-out);
}
.btn:hover {
  background: var(--phosphor);
  color: var(--ink);
  border-color: var(--phosphor);
  transform: translate(-2px, -2px);
  box-shadow: 4px 4px 0 var(--ink);
}
.btn--ghost {
  background: transparent;
  color: var(--ink);
  border-color: var(--ink);
}
.btn--ghost:hover {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.btn--github {
  background: var(--paper);
  color: var(--ink);
  border-color: var(--ink);
}
.btn--github:hover {
  background: var(--ink);
  color: var(--phosphor);
  border-color: var(--ink);
  box-shadow: 4px 4px 0 var(--phosphor);
}
.btn .arrow {
  transition: transform var(--dur-fast) var(--easing-out);
}
.btn:hover .arrow { transform: translateX(4px); }

/* Hero terminal wrap (small/secondary in new layout) */
.hero-terminal-wrap {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  width: 100%;
  min-width: 0;
}
.hero-terminal-wrap__label {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--sub);
}

/* Live terminal in hero — fixed-shape box that doesn't reflow when theme cycles */
.terminal {
  background: #0E0E10;
  color: #F5F2EA;
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  padding: 1.25rem 1.5rem 1.5rem;
  position: relative;
  border-radius: 6px;
  box-shadow: var(--shadow-deep);
  /* Fixed dimensions: width fills column, height stays constant regardless of cycled content */
  width: 100%;
  min-width: 0;
  height: 12.5rem;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 1.25rem;
  overflow: hidden;
  contain: layout size;  /* hard-isolate so inner content can never push outer dims */
}
.terminal::before {
  content: "● ● ●";
  display: block;
  letter-spacing: 0.3em;
  color: #4A4A48;
  font-size: 0.625rem;
}
.terminal__line { line-height: 1.5; }
.terminal__line--cmd::before {
  content: "$ ";
  color: #00FF6B;
}
.terminal__cursor {
  display: inline-block;
  width: 0.55em;
  height: 1em;
  background: #F5F2EA;
  vertical-align: -0.15em;
  margin-left: 1px;
  animation: blink 1s steps(2) infinite;
}
@keyframes blink {
  50% { opacity: 0; }
}
.terminal__statusline {
  border-top: 1px dashed #2A2A2C;
  padding-top: 1rem;
  font-size: 0.81rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: opacity var(--dur-base) var(--easing-out);
}

/* ─── 01b · VIBE-CHILL install (between hero and editor's note) ─── */
.s-vibe {
  background: var(--ink);
  color: var(--paper);
  padding-block: clamp(3rem, 6vw, 5rem);
  position: relative;
  overflow: hidden;
}
.s-vibe::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 80% 20%, rgba(0,255,107,0.10), transparent 50%);
  pointer-events: none;
}
.vibe-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 4vw, 3.5rem);
  position: relative;
  z-index: 1;
}
@media (min-width: 1000px) {
  .vibe-grid { grid-template-columns: 5fr 7fr; align-items: center; }
}
.vibe-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--phosphor);
  padding: 0.5rem 0.85rem;
  background: rgba(0,255,107,0.08);
  border-left: 3px solid var(--phosphor);
  margin-bottom: 1.25rem;
}
.vibe-eyebrow__bolt {
  font-size: 1.05em;
  filter: drop-shadow(0 0 6px rgba(0,255,107,0.7));
}
.vibe-title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 200;
  font-size: clamp(2rem, 4.5vw, 3.5rem);
  line-height: 1;
  letter-spacing: -0.035em;
  color: var(--paper);
  margin-bottom: 1.25rem;
}
.vibe-title em {
  color: var(--phosphor);
  font-style: italic;
  font-weight: 300;
}
.vibe-intro {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-md);
  line-height: 1.45;
  color: rgba(245,242,234,0.9);
  margin-bottom: 0.85rem;
  max-width: 32rem;
}
.vibe-bonus {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  line-height: 1.55;
  color: rgba(245,242,234,0.6);
  max-width: 32rem;
}
.vibe-bonus code {
  font-family: var(--font-mono);
  background: rgba(245,242,234,0.10);
  color: var(--phosphor);
  padding: 0.1em 0.4em;
}

/* The prompt panel */
.vibe-panel {
  background: var(--paper);
  color: var(--ink);
  padding: 1.5rem;
  border-radius: 4px;
  box-shadow: 12px 12px 0 var(--phosphor);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  position: relative;
}
.vibe-panel__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}
.vibe-panel__label {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
}
.vibe-panel__label .who {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  padding: 0.18rem 0.45rem;
  background: var(--ink);
  color: var(--paper);
}
.vibe-panel__hint {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--sub);
}
.copy-btn.copy-btn--vibe {
  position: static;
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.copy-btn.copy-btn--vibe:hover {
  background: var(--phosphor);
  color: var(--ink);
  border-color: var(--phosphor);
}
.vibe-prompt {
  background: transparent;
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
  border: 1px dashed var(--rule);
  padding: 1rem 1.15rem;
  margin: 0;
  max-height: 20rem;
  overflow-y: auto;
}
.vibe-panel__note {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-sm);
  color: var(--sub);
  line-height: 1.45;
}
.vibe-panel__note code {
  font-style: normal;
  background: var(--paper-3);
  padding: 0.1em 0.4em;
  color: var(--phosphor-d);
}

/* ─── 02 · EDITOR'S NOTE ──────────────────────────────────────── */
.s-note {
  background: var(--paper);
  padding-block: clamp(4rem, 10vw, 9rem);
}
.note-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
}
@media (min-width: 900px) {
  .note-grid { grid-template-columns: 2fr 8fr 2fr; align-items: start; }
}
.note__label {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--sub);
}
.note__body {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  line-height: 1.3;
  letter-spacing: -0.015em;
}
.note__body p + p { margin-top: 1.25em; }
.note__body .dropcap {
  float: left;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 200;
  font-size: 6em;
  line-height: 0.78;
  margin: 0.05em 0.08em -0.1em -0.04em;
  color: var(--ink);
}
.note__body strong { color: var(--phosphor-d); font-weight: 500; font-style: normal; }
.note__margin {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  line-height: var(--lh-loose);
  color: var(--sub);
  border-top: 1px solid var(--rule);
  padding-top: 1rem;
}
.note__margin em { font-style: italic; }

/* ─── 03 · NUMBERS ───────────────────────────────────────────────── */
.s-numbers {
  background: var(--ink);
  color: var(--paper);
  padding-block: clamp(3rem, 8vw, 7rem);
}
.numbers-row {
  display: grid;
  /* Two columns on phones, three on tablet, six on desktop — fixed steps avoid auto-fit overlap */
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 2.5rem 1.5rem;
  align-items: end;
}
@media (min-width: 700px) {
  .numbers-row { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (min-width: 1100px) {
  .numbers-row { grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 2rem 1rem; }
}
.num {
  text-align: left;
  border-left: 1px solid rgba(245,242,234,0.18);
  padding: 0.5rem 0 0 1rem;
  min-width: 0;          /* allow grid item to shrink instead of overflowing */
  overflow: hidden;
}
.num__value {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 200;
  /* Fits the widest "1.25%" inside a ~14rem cell at 1440px without overlap */
  font-size: clamp(2.75rem, 5.2vw, 5rem);
  line-height: 0.9;
  letter-spacing: -0.04em;
  color: var(--paper);
  font-variant-numeric: tabular-nums;
  word-break: keep-all;
  white-space: nowrap;
}
.num__value .pct { font-size: 0.45em; color: var(--phosphor); margin-left: 0.05em; }
.num--featured {
  border-left-color: var(--phosphor);
  background: linear-gradient(90deg, rgba(0,255,107,0.06), transparent 60%);
  padding-left: 1.25rem;
}
.num--featured .num__value { color: var(--phosphor); }
.num--featured .num__label { color: var(--phosphor); opacity: 0.85; }
.num__label {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--sub-2);
  margin-top: 0.85rem;
  display: block;
  line-height: 1.35;
  word-break: break-word;
}

/* ─── 04 · CATALOG INDEX ─────────────────────────────────────────── */
.s-catalog {
  padding-block: clamp(4rem, 10vw, 9rem);
}
.catalog__title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 200;
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  line-height: 0.95;
  letter-spacing: -0.04em;
  margin-bottom: 3rem;
}
.catalog__meta {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--sub);
  margin-bottom: 0.5rem;
  display: block;
}
.catalog-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-top: 1px solid var(--rule);
}
@media (min-width: 700px) {
  .catalog-list { grid-template-columns: 1fr 1fr; column-gap: 4rem; }
}
.catalog-list__item {
  display: grid;
  grid-template-columns: 2.5rem 1fr auto auto;
  align-items: baseline;
  gap: 1rem;
  padding: 1rem 0;
  border-bottom: 1px solid var(--rule);
  cursor: pointer;
  transition: background var(--dur-fast) var(--easing-out),
              padding var(--dur-fast) var(--easing-out);
  text-decoration: none;
  color: inherit;
}
.catalog-list__item:hover {
  background: var(--paper-2);
  padding-inline: 1rem;
}
.catalog-list__num {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  color: var(--sub);
  letter-spacing: var(--tr-wide);
}
.catalog-list__name {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-lg);
  letter-spacing: var(--tr-snug);
}
.catalog-list__swatches {
  display: flex;
  gap: 4px;
}
.catalog-list__swatches span {
  width: 12px;
  height: 12px;
  border-radius: 50%;
}
.catalog-list__page {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--sub);
  letter-spacing: var(--tr-wide);
}

/* ─── 05 · SPECIMENS (main wow) ──────────────────────────────────── */
.s-specimens {
  background: var(--paper-2);
  border-block: 1px solid var(--rule);
  padding-block: clamp(3rem, 6vw, 5rem);
  position: relative;
}

/* ─── Claude /statusline demo (inside Specimens) ─── */
.claude-demo {
  background: var(--paper);
  border: 1px solid var(--ink);
  box-shadow: 6px 6px 0 var(--ink);
  margin-bottom: 3rem;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}
.claude-demo__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--rule);
}
.claude-demo__label {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: var(--fs-md);
  letter-spacing: -0.01em;
  color: var(--ink);
}
.claude-demo__file {
  font-size: var(--fs-xs);
  color: var(--sub);
  letter-spacing: var(--tr-wide);
}
.claude-demo__intro {
  padding: 1rem 1.25rem 0;
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  color: var(--sub);
  line-height: 1.5;
  max-width: 56rem;
}
.claude-demo__intro code {
  font-family: var(--font-mono);
  background: var(--paper-3);
  padding: 0.1em 0.4em;
  color: var(--phosphor-d);
}
.claude-demo__terminal {
  background: #0E0E10;
  color: #E5E0D0;
  margin: 1rem 1.25rem;
  padding: 1.25rem 1.5rem;
  border-radius: 4px;
  font-size: clamp(0.7rem, 1.05vw, 0.84rem);
  line-height: 1.55;
  overflow-x: auto;
  box-shadow: var(--shadow-deep);
  display: grid;
  gap: 0.55rem;
}
.claude-demo__sep {
  position: relative;
  height: 1px;
  background: rgba(245,242,234,0.18);
  margin: 0.85rem 0 0.55rem;
}
.claude-demo__sep::before {
  content: "─ ─ ─";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background: #0E0E10;
  padding: 0 0.5rem;
  color: rgba(245,242,234,0.35);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
}
.claude-demo__line {
  display: grid;
  grid-template-columns: 4.25rem 1fr;
  gap: 0.85rem;
  align-items: baseline;
}
.claude-demo__line .who {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  padding: 0.18rem 0.45rem;
  text-align: center;
  align-self: start;
}
.claude-demo__line .who.you {
  background: rgba(245,242,234,0.12);
  color: #E5E0D0;
}
.claude-demo__line .who.claude {
  background: rgba(0,255,107,0.18);
  color: #00FF6B;
  border-left: 2px solid #00FF6B;
}
.claude-demo__line .cmd { color: #F5F2EA; word-break: break-word; }
.claude-demo__line .cmd .slash { color: #00FF6B; font-weight: 600; }
.claude-demo__line .cmd .arg { color: #F5F2EA; }
.claude-demo__line .cmd .arg--verb { color: #FFD700; }      /* custom / list / use */
/* Visual · between consecutive args (does NOT affect copy/paste — ::before content is excluded from selection) */
.claude-demo__line .cmd .arg + .arg::before {
  content: "·";
  color: rgba(245,242,234,0.28);
  margin-right: 0.4em;
  margin-left: -0.05em;
}
.claude-demo__line.response .msg {
  color: #B8B5A8;
  word-break: break-word;
}
.claude-demo__line .dot { color: #00FF6B; margin-right: 0.35em; }
.claude-demo__line .ok  { color: #00FF6B; margin-right: 0.35em; font-weight: 600; }
.claude-demo__line .path { color: #FFD700; }
.claude-demo__line .hl   { color: #00FFFF; font-weight: 500; }
.claude-demo__line .dim  { color: #6A6A68; }
.claude-demo__line em {
  color: #00FFFF;
  font-style: italic;
  font-family: var(--font-display);
}
.claude-demo__caption {
  padding: 0 1.25rem 1.25rem;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-sm);
  color: var(--sub);
  line-height: 1.5;
  max-width: 56rem;
}
.claude-demo__caption code {
  font-style: normal;
  font-family: var(--font-mono);
  background: var(--paper-3);
  padding: 0.1em 0.4em;
  color: var(--ink);
}
.claude-demo__caption strong { color: var(--ink); font-style: normal; }
.specimens-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 2rem;
}
.specimens-header__title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 200;
  font-size: clamp(2rem, 5vw, 3.5rem);
  letter-spacing: -0.03em;
}

/* Specimen pager nav: ‹ [• • • • • • • •] › */
.specimen-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 2rem;
}
.spec-arrow {
  width: 2.75rem;
  height: 2.75rem;
  border: 1px solid var(--ink);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  line-height: 1;
  background: var(--paper);
  color: var(--ink);
  transition: background var(--dur-fast) var(--easing-out),
              color var(--dur-fast) var(--easing-out),
              transform var(--dur-fast) var(--easing-out),
              opacity var(--dur-fast) var(--easing-out);
  flex-shrink: 0;
}
.spec-arrow:hover {
  background: var(--ink);
  color: var(--paper);
  transform: translateY(-1px);
}
.spec-arrow:active { transform: translateY(0); }
.spec-arrow:disabled {
  opacity: 0.25;
  cursor: not-allowed;
  transform: none;
}

.specimen {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  background: var(--paper);
  padding: clamp(1.5rem, 4vw, 3rem);
  border: 1px solid var(--rule);
  min-height: 30rem;
  position: relative;
}
.specimen__header {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  border-bottom: 1px solid var(--rule);
  padding-bottom: 1.5rem;
}
.specimen__meta {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1.75rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--rule);
  min-width: 0;
}
@media (min-width: 720px) {
  .specimen__meta {
    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr);
    gap: 2rem;
    align-items: start;
  }
}
.specimen__meta-col {
  min-width: 0;
}
.specimen__id {
  display: flex;
  align-items: baseline;
  gap: 0.5em;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--sub);
}
.specimen__id strong {
  color: var(--ink);
  font-size: var(--fs-sm);
  font-weight: 500;
}
.specimen__name {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 200;
  font-size: clamp(2.5rem, 6vw, 4.25rem);
  line-height: 0.95;
  letter-spacing: -0.04em;
  margin: 0;
}
.specimen__vibe {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-md);
  line-height: 1.4;
  color: var(--sub);
  max-width: 50rem;
  margin: 0;
}
.specimen__terminals {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-width: 0;
}
.specimen__terminal {
  background: #0E0E10;
  color: #F5F2EA;
  font-family: var(--font-mono);
  font-size: clamp(0.72rem, 0.95vw, 0.85rem);
  padding: 1.25rem 1.5rem;
  border-radius: 4px;
  overflow-x: hidden;
  overflow-wrap: anywhere;
  word-break: break-word;
  white-space: pre-wrap;
  box-shadow: var(--shadow-deep);
  line-height: 1.55;
  min-width: 0;
}
.specimen__terminal--paper {
  background: var(--paper-3);
  color: var(--ink);
}
.specimen__terminal-label {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--sub);
}
.specimen__compact {
  background: #0E0E10;
  color: #F5F2EA;
  font-family: var(--font-mono);
  font-size: clamp(0.7rem, 0.85vw, 0.8rem);
  padding: 1rem 1.5rem;
  border-radius: 4px;
  overflow-x: hidden;
  overflow-wrap: anywhere;
  word-break: break-word;
  white-space: pre-wrap;
  opacity: 0.92;
  line-height: 1.5;
  min-width: 0;
}
.specimen__group {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-md);
  margin: 0;
}
.specimen__meta-col h4 {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--sub);
  font-weight: 500;
  margin: 0 0 0.6rem;
}
.specimen__palette {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 6px;
}
.specimen__palette span {
  aspect-ratio: 1;
  border-radius: 2px;
}
.specimen__glyphs {
  font-family: var(--font-mono);
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  color: var(--ink);
}
.specimen__caption {
  grid-column: 1 / -1;
  border-top: 1px solid var(--rule);
  padding-top: 1rem;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-md);
  line-height: 1.5;
  color: var(--sub);
  max-width: 56rem;
}
.specimen__usages {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 0;
  align-items: stretch;
  width: 100%;
}
.specimen__usage {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--ink);
  padding: 0.55rem 0.75rem 0.65rem;
  background: var(--paper-3);
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  width: 100%;
  min-width: 0;
}
.specimen__usage code {
  display: block;
  overflow-wrap: anywhere;
  word-break: break-word;
  white-space: pre-wrap;
  line-height: 1.45;
}
.specimen__usage-label {
  color: var(--sub);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  font-size: 0.6875rem;
}
.specimen__usage code { color: var(--phosphor-d); }
.specimen__usage--slash {
  background: var(--ink);
  color: var(--paper);
}
.specimen__usage--slash .specimen__usage-label { color: var(--sub-2); }
.specimen__usage--slash code { color: var(--paper); }
.specimen__usage--slash code .slash {
  color: var(--phosphor);
  font-weight: 600;
}
.specimen__usage--source {
  background: transparent;
  border: 1px dashed var(--rule);
  text-decoration: none;
  transition: border-color var(--dur-fast) var(--easing-out),
              background var(--dur-fast) var(--easing-out);
}
.specimen__usage--source:hover {
  border-color: var(--ink);
  background: var(--paper-3);
}
.specimen__usage--source code { color: var(--ink); }
.specimen__usage--source .ext {
  color: var(--phosphor-d);
  margin-left: 0.25em;
}

/* Specimen pagination dots — sits between the two arrows */
.specimen-pager {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  max-width: 30rem;
}
.specimen-pager button {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--rule);
  border: none;
  padding: 0;
  transition: background var(--dur-fast) var(--easing-out),
              transform var(--dur-fast) var(--easing-out);
}
.specimen-pager button.active {
  background: var(--ink);
  transform: scale(1.4);
}

/* ─── 06 · COMPARE ──────────────────────────────────────────────── */
.s-compare { padding-block: clamp(4rem, 10vw, 9rem); }
.compare-title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 200;
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  line-height: 0.95;
  letter-spacing: -0.04em;
  margin-bottom: 0.5rem;
}
.compare-sub {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--sub);
  margin-bottom: 3rem;
}
.compare-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-body);
  font-size: var(--fs-base);
}
.compare-table thead th {
  text-align: left;
  padding: 1rem 0.75rem;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--sub);
  border-bottom: 2px solid var(--ink);
  font-weight: 500;
}
.compare-table tbody td {
  padding: 1rem 0.75rem;
  border-bottom: 1px solid var(--rule);
  vertical-align: top;
}
.compare-table tbody tr:hover td {
  background: var(--paper-2);
}
.compare-table tr.cmp-highlight td {
  background: linear-gradient(90deg, rgba(0,255,107,0.10), rgba(0,255,107,0.02) 60%);
  border-bottom-color: var(--phosphor);
}
.compare-table tr.cmp-highlight .feature {
  color: var(--phosphor-d);
  font-weight: 500;
}
.compare-table .feature {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: var(--fs-md);
  letter-spacing: var(--tr-snug);
  width: 50%;
}
.compare-table .yes { color: var(--phosphor-d); font-weight: 500; }
.compare-table .no { color: var(--sub-2); }
.compare-table .yes::before { content: "● "; }
.compare-table .no::before { content: "○ "; }

/* ─── 07 · RECIPE (drag-and-drop builder) ─────────────────────── */
.s-recipe {
  padding-block: clamp(4rem, 10vw, 9rem);
  background: var(--paper-2);
  border-block: 1px solid var(--rule);
}
.recipe-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
}
@media (min-width: 900px) {
  .recipe-grid { grid-template-columns: 4fr 8fr; }
}
.recipe__col h3 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-2xl);
  line-height: 1;
  letter-spacing: -0.03em;
  margin-bottom: 0.5rem;
}
.recipe__intro {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-md);
  line-height: 1.4;
  color: var(--sub);
  margin-bottom: 2rem;
}
.recipe__palette {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  background: var(--paper);
  padding: 1rem;
  border: 1px solid var(--rule);
}
.recipe__palette h4 {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--sub);
  font-weight: 500;
  margin-bottom: 0.5rem;
}
.recipe__block {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  background: var(--paper-3);
  padding: 0.6rem 0.85rem;
  cursor: grab;
  user-select: none;
  border: 1px solid transparent;
  transition: all var(--dur-fast) var(--easing-out);
}
.recipe__block:hover {
  background: var(--ink);
  color: var(--paper);
  transform: translateX(4px);
}
.recipe__block:active { cursor: grabbing; }
.recipe__block .add { font-size: 1.25em; line-height: 1; }
.recipe__block.in-line { display: none; }
.recipe__block.is-used,
.recipe__block[disabled] {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
  background: var(--paper-2);
}
.recipe__block.is-used:hover {
  background: var(--paper-2);
  color: inherit;
  transform: none;
}
.recipe__block.is-used .add { display: none; }
.recipe__block.is-used::after {
  content: "✓ added";
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--phosphor-d);
  white-space: nowrap;
}

.recipe__output {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.recipe__statusline-wrap {
  background: #0E0E10;
  padding: 1.5rem;
  border-radius: 4px;
  min-height: 4rem;
  display: flex;
  align-items: center;
  overflow-x: auto;
  font-family: var(--font-mono);
  color: #F5F2EA;
  white-space: nowrap;
  font-size: var(--fs-sm);
  box-shadow: var(--shadow-deep);
}
.recipe__statusline-wrap .empty {
  color: #4A4A48;
  font-style: italic;
}
.recipe__line {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 1rem;
  background: var(--paper);
  border: 1px dashed var(--ink);
  min-height: 3.5rem;
  align-items: center;
}
.recipe__line .empty {
  color: var(--sub);
  font-family: var(--font-display);
  font-style: italic;
}
.recipe__chip {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  background: var(--ink);
  color: var(--paper);
  padding: 0.45rem 0.7rem;
}
.recipe__chip .x {
  cursor: pointer;
  opacity: 0.6;
  font-size: 1em;
}
.recipe__chip .x:hover { opacity: 1; color: var(--hot); }

.recipe__code-wrap { position: relative; }
.recipe__code {
  background: #0E0E10;
  color: #F5F2EA;
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  padding: 1.5rem;
  overflow-x: auto;
  white-space: pre;
  border-radius: 4px;
  line-height: 1.5;
}
.recipe__code .cmd { color: #00FF6B; }
.recipe__code .cmt { color: #4A4A48; font-style: italic; }
.copy-btn {
  position: absolute;
  top: 1rem;
  right: 1rem;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  background: rgba(245,242,234,0.1);
  color: #F5F2EA;
  padding: 0.4rem 0.7rem;
  border: 1px solid rgba(245,242,234,0.2);
  transition: all var(--dur-fast) var(--easing-out);
}
.copy-btn:hover {
  background: var(--phosphor);
  color: var(--ink);
  border-color: var(--phosphor);
}

/* ─── 08 · INSTALL ──────────────────────────────────────────────── */
.s-install { padding-block: clamp(4rem, 10vw, 9rem); }
.install-title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 200;
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  letter-spacing: -0.04em;
  margin-bottom: 0.5rem;
}
.install-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  margin-top: 3rem;
}
@media (min-width: 900px) {
  .install-grid { grid-template-columns: 5fr 7fr; }
}
.install-step {
  border-top: 1px solid var(--rule);
  padding-top: 1.5rem;
}
.install-step__num {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 200;
  font-size: 4rem;
  line-height: 0.85;
  color: var(--phosphor-d);
}
.install-step__title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-xl);
  margin: 0.5rem 0;
}
.install-step__desc {
  font-family: var(--font-body);
  color: var(--sub);
  font-size: var(--fs-base);
  line-height: 1.5;
}
.install__code-wrap { position: relative; }

/* ─── "Or in Claude Code" install block ─── */
.install__claude {
  background: var(--ink);
  color: var(--paper);
  padding: 1.5rem 1.5rem 1.75rem;
  border-radius: 4px;
  border-left: 4px solid var(--phosphor);
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  position: relative;
}
.install__claude-label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--phosphor);
}
.install__claude-badge {
  font-size: 0.85em;
  color: var(--phosphor);
}
.install__claude-intro {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-md);
  line-height: 1.4;
  color: rgba(245,242,234,0.85);
  max-width: 36rem;
}
.install__claude-prompt {
  background: rgba(245,242,234,0.04);
  border: 1px solid rgba(245,242,234,0.10);
  padding: 0.85rem 1rem 1rem;
  border-radius: 4px;
  position: relative;
}
.install__claude-head {
  display: flex;
  align-items: baseline;
  gap: 0.85rem;
  margin-bottom: 0.6rem;
}
.install__claude-step {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-md);
  color: var(--phosphor);
  line-height: 1;
}
.install__claude-then {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--sub-2);
  margin-right: auto;
}
.install__claude-prompt .copy-btn {
  position: static;
  margin-left: auto;
}
.install__claude-line {
  display: grid;
  grid-template-columns: 3.5rem 1fr;
  gap: 0.75rem;
  align-items: baseline;
}
.install__claude-line .who {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  padding: 0.18rem 0.4rem;
  text-align: center;
  align-self: start;
  background: rgba(245,242,234,0.12);
  color: var(--paper);
}
.install__claude-line .msg {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  line-height: 1.55;
  color: var(--paper);
  word-break: break-word;
}
.install__claude-line .msg--cmd {
  color: #FFD700;
  font-size: var(--fs-md);
}
.install__claude-line .msg--cmd .slash {
  color: var(--phosphor);
  font-weight: 600;
}
.copy-btn--inline {
  position: static;
  font-size: var(--fs-xs);
  padding: 0.3rem 0.6rem;
}

/* ─── 09 · FAQ ──────────────────────────────────────────────────── */
.s-faq {
  padding-block: clamp(4rem, 10vw, 9rem);
  background: var(--paper-2);
  border-block: 1px solid var(--rule);
}
.faq-title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 200;
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  letter-spacing: -0.04em;
  margin-bottom: 3rem;
}
.faq-list { border-top: 1px solid var(--rule); }
.faq-item { border-bottom: 1px solid var(--rule); }
.faq-q {
  display: grid;
  grid-template-columns: 3rem 1fr 2rem;
  align-items: baseline;
  gap: 1rem;
  padding: 1.5rem 0;
  cursor: pointer;
  width: 100%;
  text-align: left;
  background: transparent;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-xl);
  letter-spacing: -0.02em;
  color: var(--ink);
  transition: color var(--dur-fast) var(--easing-out);
}
.faq-q:hover { color: var(--phosphor-d); }
.faq-q .num {
  font-family: var(--font-mono);
  font-style: normal;
  font-size: var(--fs-sm);
  color: var(--sub);
  letter-spacing: var(--tr-wide);
}
.faq-q .toggle {
  font-style: normal;
  color: var(--sub);
  transition: transform var(--dur-fast) var(--easing-out);
}
.faq-item[open] .faq-q .toggle { transform: rotate(45deg); color: var(--phosphor-d); }
.faq-a {
  padding: 0 0 1.5rem 4rem;
  max-width: 50rem;
  font-family: var(--font-body);
  font-size: var(--fs-md);
  line-height: 1.55;
  color: var(--sub);
}
.faq-a code {
  font-family: var(--font-mono);
  font-size: 0.9em;
  background: var(--paper-3);
  padding: 0.1em 0.4em;
  color: var(--ink);
}
.faq-a a { color: var(--phosphor-d); border-bottom: 1px solid var(--phosphor-d); }

/* ─── 10 · COLOPHON (footer) ──────────────────────────────────── */
.s-colophon {
  background: var(--ink);
  color: var(--paper);
  padding: clamp(3rem, 6vw, 5rem) 0 clamp(2rem, 4vw, 3rem);
}
.colophon-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
}
@media (min-width: 700px) {
  .colophon-grid { grid-template-columns: repeat(4, 1fr); }
}
.colophon h4 {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wider);
  text-transform: uppercase;
  color: var(--sub-2);
  font-weight: 500;
  margin-bottom: 1rem;
}
.colophon p, .colophon li {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  line-height: 1.55;
  color: var(--paper);
}
.colophon ul { list-style: none; }
.colophon li + li { margin-top: 0.5rem; }
.colophon a {
  color: var(--paper);
  border-bottom: 1px solid rgba(245,242,234,0.3);
  transition: color var(--dur-fast) var(--easing-out),
              border-color var(--dur-fast) var(--easing-out);
}
.colophon a:hover {
  color: var(--phosphor);
  border-color: var(--phosphor);
}
.colophon-meta {
  margin-top: 3rem;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(245,242,234,0.18);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 1rem;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--sub-2);
}

/* ─── Toast ─── */
.toast {
  position: fixed;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%) translateY(100%);
  background: var(--ink);
  color: var(--phosphor);
  padding: 0.85rem 1.25rem;
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  z-index: 1000;
  pointer-events: none;
  opacity: 0;
  transition: transform var(--dur-base) var(--easing-spring),
              opacity var(--dur-base) var(--easing-out);
}
.toast.show {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
}
