/* GENUBRA PRISM — intent workspace.
   Mythic Infrastructure Minimalism (champagne/brass on warm-noir). Mobile-first. */

:root {
  --noir-void: #0A0907; --noir-deep: #0E0C09; --noir: #13110C; --noir-soft: #1A1712; --noir-haze: #221D16; --noir-line: #2A2418;
  --gold-foil: #F4D9A0; --gold-bright: #E7C887; --gold: #C9A24B; --gold-matte: #A9863B; --gold-deep: #6E5526;
  --bone: #F5EFE2; --bone-dim: #C9C0AD; --bone-mute: #968B70;
  --ok: #8FBF7F; --warn: #D9A441; --fail: #C66B5A;
  --reality-accent: #C9A24B;
  --ease: cubic-bezier(0.25, 1, 0.5, 1);
  --fd: "Fraunces", Georgia, serif; --fb: "Inter", system-ui, -apple-system, sans-serif;
  --rad: 14px; --rad-sm: 10px;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; min-height: 100%; }
html { -webkit-text-size-adjust: 100%; }
body { background: var(--noir-deep); color: var(--bone); font-family: var(--fb); -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
.display, .fd { font-family: var(--fd); letter-spacing: -0.02em; font-weight: 400; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; color: inherit; background: none; border: none; }
input, textarea { font-family: inherit; }
svg { display: block; }
::selection { background: color-mix(in oklab, var(--gold-deep) 50%, transparent); color: var(--bone); }
*:focus-visible { outline: 1px solid color-mix(in oklab, var(--gold-bright) 55%, transparent); outline-offset: 2px; }
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-thumb { background: color-mix(in oklab, var(--gold-deep) 45%, transparent); border-radius: 999px; }
::-webkit-scrollbar-track { background: transparent; }

.bg-atmosphere { position: relative; min-height: 100vh; min-height: 100dvh; }
.bg-atmosphere::before { content: ""; position: fixed; inset: 0; z-index: 0; pointer-events: none; background: radial-gradient(58% 46% at 50% 0%, color-mix(in oklab, var(--gold-deep) 16%, transparent), transparent 70%), radial-gradient(40% 40% at 85% 95%, color-mix(in oklab, var(--noir) 80%, transparent), transparent 70%); }

/* ── Top bar ─────────────────────────────────────────── */
.shell { position: relative; z-index: 1; min-height: 100dvh; display: flex; flex-direction: column; }
.topbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 14px clamp(16px, 4vw, 34px); padding-top: calc(14px + env(safe-area-inset-top)); border-bottom: 1px solid var(--noir-line); position: sticky; top: 0; z-index: 20; background: color-mix(in oklab, var(--noir-deep) 86%, transparent); backdrop-filter: blur(14px); }
.brand { display: flex; align-items: center; gap: 12px; }
.brand-mark { height: 26px; width: auto; flex: 0 0 auto; display: block; }
/* Wordmark — Chris Do discipline x Virgil Abloh industrial caps: tracked-out, bone, the mark keeps the gold. */
.brand .mk { font-family: var(--fd); font-size: 14px; font-weight: 500; color: var(--bone); text-transform: uppercase; letter-spacing: 0.2em; line-height: 1; align-self: center; padding-right: 0.2em; }
.brand .mk b { color: var(--gold-bright); font-weight: 600; }
.topnav { display: flex; gap: 4px; }
.topnav button { color: var(--bone-dim); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; padding: 8px 13px; border: 1px solid transparent; border-radius: 8px; transition: all 0.25s var(--ease); }
.topnav button:hover { color: var(--bone); border-color: color-mix(in oklab, var(--gold) 22%, transparent); }
.topnav button.active { color: var(--gold-bright); border-color: color-mix(in oklab, var(--gold) 40%, transparent); }

.view { flex: 1; max-width: 1180px; width: 100%; margin: 0 auto; padding: clamp(22px, 5vw, 48px) clamp(16px, 4vw, 34px) 70px; }

/* ── Primitives ──────────────────────────────────────── */
.eyebrow { font-size: 9px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--bone-mute); }
.panel { background: color-mix(in oklab, var(--noir) 92%, transparent); border: 1px solid var(--noir-line); border-radius: var(--rad); position: relative; }
.panel.glow { border-color: color-mix(in oklab, var(--gold) 22%, transparent); }
.hud::before, .hud::after { content: ""; position: absolute; width: 18px; height: 18px; border-color: color-mix(in oklab, var(--gold) 38%, transparent); border-style: solid; border-width: 0; }
.hud::before { top: 0; left: 0; border-top-width: 1px; border-left-width: 1px; }
.hud::after { bottom: 0; right: 0; border-bottom-width: 1px; border-right-width: 1px; }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; background: var(--reality-accent); color: var(--noir); font-weight: 600; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; padding: 13px 22px; border-radius: var(--rad-sm); transition: all 0.25s var(--ease); }
.btn:hover { filter: brightness(1.08); transform: translateY(-1px); }
.btn:disabled { opacity: 0.5; transform: none; }
.btn-ghost { display: inline-flex; align-items: center; gap: 7px; border: 1px solid color-mix(in oklab, var(--gold) 26%, transparent); color: var(--bone-dim); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; padding: 11px 16px; border-radius: var(--rad-sm); transition: all 0.25s var(--ease); }
.btn-ghost:hover { color: var(--bone); border-color: color-mix(in oklab, var(--gold) 50%, transparent); }

/* ── Intent ──────────────────────────────────────────── */
.intent { max-width: 760px; margin: 4vh auto 0; text-align: center; }
.intent h1 { font-family: var(--fd); font-size: clamp(34px, 6.5vw, 62px); line-height: 1.02; margin: 16px 0 12px; }
.intent h1 em { color: var(--gold-bright); font-style: italic; }
.intent .lede { color: var(--bone-dim); font-size: 15px; max-width: 540px; margin: 0 auto 30px; line-height: 1.6; }
.intentbox { background: var(--noir); border: 1px solid color-mix(in oklab, var(--gold) 22%, transparent); border-radius: var(--rad); padding: 16px; text-align: left; transition: border-color 0.3s var(--ease); }
.intentbox:focus-within { border-color: color-mix(in oklab, var(--gold) 50%, transparent); }
.intentbox textarea { width: 100%; min-height: 110px; resize: vertical; background: none; border: none; outline: none; color: var(--bone); font-size: 16px; line-height: 1.5; }
.intentbox textarea::placeholder { color: var(--bone-mute); }
.intent-foot { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-top: 14px; flex-wrap: wrap; }
.model-toggle { display: flex; gap: 7px; }
.model-toggle button { font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--bone-dim); border: 1px solid color-mix(in oklab, var(--gold) 22%, transparent); padding: 8px 13px; border-radius: 8px; }
.model-toggle button.on { color: var(--gold-bright); border-color: color-mix(in oklab, var(--gold) 55%, transparent); background: color-mix(in oklab, var(--gold-deep) 22%, transparent); }
.deploy-note { font-size: 11px; color: var(--bone-mute); margin-top: 12px; letter-spacing: 0.03em; }
.deploy-note b { color: var(--gold-matte); font-weight: 500; }
.seeds { margin-top: 30px; text-align: left; }
.seeds .eyebrow { margin-bottom: 11px; display: block; }
.seed-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.seed-chips button { font-size: 12px; color: var(--bone-dim); border: 1px solid color-mix(in oklab, var(--gold) 18%, transparent); padding: 8px 12px; border-radius: 8px; transition: all 0.25s var(--ease); }
.seed-chips button:hover { color: var(--bone); border-color: color-mix(in oklab, var(--gold) 44%, transparent); }

/* ── Synthesis ───────────────────────────────────────── */
.synth-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 14px; }
.synth-head h2 { font-family: var(--fd); font-size: clamp(22px, 4vw, 28px); margin: 5px 0 0; }
.live-banner { display: flex; align-items: center; gap: 11px; padding: 13px 16px; margin: 14px 0 4px; border-radius: var(--rad-sm); border: 1px solid color-mix(in oklab, var(--ok) 40%, transparent); background: color-mix(in oklab, var(--ok) 9%, transparent); flex-wrap: wrap; }
.live-banner .pip { width: 8px; height: 8px; border-radius: 50%; background: var(--ok); box-shadow: 0 0 0 0 color-mix(in oklab, var(--ok) 60%, transparent); animation: pulse 1.6s var(--ease) infinite; flex-shrink: 0; }
.live-banner .lt { font-size: 12px; color: var(--bone-dim); }
.live-banner a { color: var(--gold-bright); font-size: 12px; margin-left: auto; }
.synth-cols { display: grid; grid-template-columns: 1fr; gap: 18px; margin-top: 18px; }
.ladder { display: flex; flex-direction: column; gap: 9px; }
.lrow { display: flex; align-items: center; gap: 14px; padding: 14px 16px; background: var(--noir); border: 1px solid var(--noir-line); border-radius: var(--rad-sm); transition: all 0.4s var(--ease); }
.lrow .lno { font-family: var(--fd); font-size: 15px; color: var(--bone-mute); width: 24px; }
.lrow .ldot { width: 10px; height: 10px; border-radius: 50%; background: var(--noir-haze); border: 1px solid color-mix(in oklab, var(--gold) 30%, transparent); flex-shrink: 0; }
.lrow .lbody { flex: 1; min-width: 0; }
.lrow .lname { font-size: 14px; color: var(--bone-dim); }
.lrow .lhint { font-size: 11px; color: var(--bone-mute); margin-top: 2px; }
.lrow .lms { font-size: 10px; color: var(--bone-mute); }
.lrow[data-st="running"] { border-color: color-mix(in oklab, var(--gold) 45%, transparent); }
.lrow[data-st="running"] .lname, .lrow[data-st="done"] .lname { color: var(--bone); }
.lrow[data-st="running"] .ldot { background: var(--gold-bright); border-color: var(--gold-bright); animation: pulse 1.4s var(--ease) infinite; }
.lrow[data-st="done"] .ldot { background: var(--ok); border-color: var(--ok); }
.lrow[data-st="failed"] .ldot { background: var(--fail); border-color: var(--fail); }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 color-mix(in oklab, currentColor 60%, transparent); } 70% { box-shadow: 0 0 0 7px transparent; } 100% { box-shadow: 0 0 0 0 transparent; } }
.log { padding: 16px; align-self: start; }
.log .eyebrow { margin-bottom: 12px; display: block; }
.signal { font-size: 12px; color: var(--bone-dim); padding: 7px 0; border-bottom: 1px solid color-mix(in oklab, var(--gold) 8%, transparent); display: flex; gap: 9px; line-height: 1.4; }
.signal .k { color: var(--gold-matte); font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; min-width: 52px; padding-top: 1px; }

/* ── DNA bar ─────────────────────────────────────────── */
.dna-bar { display: flex; align-items: center; gap: 16px; padding: 14px 18px; margin-bottom: 18px; flex-wrap: wrap; }
.dna-bar .swatches { display: flex; gap: 5px; }
.dna-bar .sw { width: 22px; height: 22px; border-radius: 5px; border: 1px solid rgba(255,255,255,0.12); }
.dna-bar .nm { font-family: var(--fd); font-size: 19px; color: var(--bone); }
.dna-bar .arch { font-size: 10px; text-transform: uppercase; letter-spacing: 0.16em; color: var(--gold-bright); }
.dna-bar .tag { font-size: 12px; color: var(--bone-dim); font-style: italic; }

/* ── Result (live site) ──────────────────────────────── */
.result-actions { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; margin-bottom: 18px; }
.result-actions .url { font-family: "IBM Plex Mono", ui-monospace, monospace; font-size: 12px; color: var(--bone-mute); margin-right: auto; word-break: break-all; }
.browserframe { border: 1px solid var(--noir-line); border-radius: var(--rad); overflow: hidden; background: var(--noir); }
.bf-chrome { display: flex; align-items: center; gap: 8px; padding: 9px 13px; background: var(--noir-soft); border-bottom: 1px solid var(--noir-line); }
.bf-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--noir-line); }
.bf-url { flex: 1; text-align: center; font-size: 11px; color: var(--bone-mute); }
.bf-open { color: var(--gold-bright); font-size: 11px; }
.bf-frame { width: 100%; height: min(72vh, 760px); border: 0; display: block; background: #0A0907; }
.promote { margin-top: 14px; padding: 14px 16px; }
.promote .eyebrow { display: block; margin-bottom: 8px; }
.promote code { display: block; font-family: ui-monospace, monospace; font-size: 12px; color: var(--gold-bright); background: var(--noir-void); border: 1px solid var(--noir-line); border-radius: 8px; padding: 11px 13px; word-break: break-all; }
.promote p { font-size: 12px; color: var(--bone-mute); margin: 8px 0 0; line-height: 1.5; }

/* ── Explorer ────────────────────────────────────────── */
.explorer { display: grid; grid-template-columns: 1fr; gap: 18px; }
.layer-nav { display: flex; gap: 6px; overflow-x: auto; padding-bottom: 4px; -webkit-overflow-scrolling: touch; }
.layer-nav button { white-space: nowrap; color: var(--bone-mute); padding: 9px 13px; font-size: 12.5px; border-radius: 999px; border: 1px solid var(--noir-line); display: flex; gap: 7px; align-items: center; flex-shrink: 0; }
.layer-nav button .ln { font-family: var(--fd); font-size: 11px; }
.layer-nav button.active { color: var(--bone); border-color: var(--reality-accent); background: color-mix(in oklab, var(--reality-accent) 12%, transparent); }
.layer-pane h3 { font-family: var(--fd); font-size: clamp(22px, 4vw, 26px); margin: 0 0 4px; }
.layer-pane .headline { color: var(--bone-dim); font-style: italic; font-size: 14px; margin-bottom: 18px; }
.sub-grid { display: grid; grid-template-columns: 1fr; gap: 12px; }
.sub-card { padding: 16px; }
.sub-card .eyebrow { color: var(--gold-matte); margin-bottom: 11px; display: block; }
.sub-card .body { font-size: 13px; line-height: 1.62; color: var(--bone-dim); }
.sub-card .body p { margin: 0 0 8px; }
.sub-card ul { margin: 0; padding-left: 0; list-style: none; }
.sub-card li { padding: 7px 0; border-bottom: 1px solid color-mix(in oklab, var(--gold) 8%, transparent); }
.sub-card li:last-child { border-bottom: none; }
.sub-card .kv { display: block; margin: 2px 0; }
.sub-card .kv b, .sub-card .obj-row b { color: var(--bone); font-weight: 500; }
.sub-card .obj-row { display: block; padding: 3px 0; }

/* ── Library ─────────────────────────────────────────── */
.section-h { display: flex; align-items: baseline; gap: 12px; margin: 2px 0 18px; }
.section-h h2 { font-family: var(--fd); font-size: clamp(24px, 5vw, 30px); margin: 0; }
.section-h .sc { font-size: 11px; color: var(--bone-mute); }
.lib-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 16px; }
.reality-card { padding: 18px; cursor: pointer; transition: transform 0.3s var(--ease), border-color 0.3s var(--ease); }
.reality-card:hover { transform: translateY(-2px); border-color: color-mix(in oklab, var(--gold) 35%, transparent); }
.reality-card .arch { font-size: 9px; text-transform: uppercase; letter-spacing: 0.18em; color: var(--gold-matte); }
.reality-card .ttl { font-family: var(--fd); font-size: 20px; margin: 7px 0 6px; color: var(--bone); }
.reality-card .idea { font-size: 12px; color: var(--bone-mute); line-height: 1.5; height: 52px; overflow: hidden; }
.reality-card .foot { display: flex; justify-content: space-between; align-items: center; margin-top: 13px; font-size: 10px; color: var(--bone-mute); }
.badge { font-size: 9px; text-transform: uppercase; letter-spacing: 0.1em; padding: 3px 8px; border: 1px solid color-mix(in oklab, var(--gold) 30%, transparent); color: var(--gold-bright); border-radius: 5px; }
.badge[data-st="complete"] { color: var(--ok); border-color: color-mix(in oklab, var(--ok) 40%, transparent); }
.badge[data-st="partial"] { color: var(--warn); border-color: color-mix(in oklab, var(--warn) 40%, transparent); }
.badge[data-st="failed"] { color: var(--fail); border-color: color-mix(in oklab, var(--fail) 40%, transparent); }
.empty { text-align: center; color: var(--bone-mute); padding: 50px 0; font-size: 14px; }
.spin { display: inline-block; width: 13px; height: 13px; border: 2px solid color-mix(in oklab, var(--gold) 30%, transparent); border-top-color: var(--gold-bright); border-radius: 50%; animation: rot 0.8s linear infinite; vertical-align: -2px; }
@keyframes rot { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .lrow[data-st="running"] .ldot, .spin, .live-banner .pip { animation: none; } }

.toast { position: fixed; left: 50%; bottom: calc(22px + env(safe-area-inset-bottom)); transform: translateX(-50%) translateY(16px); background: var(--noir-soft); border: 1px solid color-mix(in oklab, var(--gold) 35%, transparent); color: var(--bone); padding: 11px 18px; font-size: 13px; border-radius: var(--rad-sm); opacity: 0; pointer-events: none; transition: all 0.4s var(--ease); z-index: 60; max-width: 90vw; }
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

@media (min-width: 900px) {
  .synth-cols { grid-template-columns: minmax(0, 1fr) 320px; }
  .explorer { grid-template-columns: 232px minmax(0, 1fr); }
  .layer-nav { flex-direction: column; overflow: visible; position: sticky; top: 80px; }
  .layer-nav button { border-color: transparent; border-left: 2px solid transparent; border-radius: var(--rad-sm); }
  .layer-nav button.active { border-color: transparent; border-left-color: var(--reality-accent); }
  .sub-grid { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
}

/* ── Build mode (v4) ─────────────────────────────────── */
.mode-pick { display: flex; gap: 8px; justify-content: center; margin-bottom: 22px; }
.mode-pick button { font-size: 12px; letter-spacing: 0.05em; color: var(--bone-dim); border: 1px solid color-mix(in oklab, var(--gold) 22%, transparent); padding: 9px 16px; border-radius: 999px; display: flex; align-items: center; gap: 7px; transition: all 0.25s var(--ease); }
.mode-pick button.on { color: var(--noir); background: var(--gold); border-color: var(--gold); font-weight: 600; }
.building { max-width: 680px; margin: 7vh auto 0; text-align: center; }
.building .ring { width: 58px; height: 58px; margin: 0 auto 26px; border: 2px solid color-mix(in oklab, var(--gold) 20%, transparent); border-top-color: var(--gold-bright); border-radius: 50%; animation: rot 0.9s linear infinite; }
.building h2 { font-family: var(--fd); font-size: clamp(24px, 4vw, 32px); margin: 0 0 10px; }
.building .bstat { font-size: 14px; color: var(--bone-dim); min-height: 22px; transition: opacity 0.5s var(--ease), transform 0.5s var(--ease); }
.building .belapsed { margin-top: 8px; font-family: ui-monospace, monospace; font-size: 12px; color: var(--gold-matte); letter-spacing: 0.06em; }
.building .bintent { margin: 22px auto 0; font-size: 13px; color: var(--bone-mute); font-style: italic; max-width: 480px; }
.building .breassure { margin: 16px auto 0; font-size: 12px; color: var(--bone-mute); max-width: 420px; opacity: 0; transform: translateY(4px); transition: opacity 0.6s var(--ease), transform 0.6s var(--ease); }
.building .breassure.show { opacity: 1; transform: none; }

/* ── Pricing / plan cards ── */
.paywall-card.wide { max-width: 920px; }
.plan-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin: 16px 0; }
.plan-card { position: relative; border: 1px solid var(--noir-line); border-radius: var(--rad); padding: 20px 18px; background: color-mix(in oklab, var(--noir) 92%, transparent); display: flex; flex-direction: column; }
.plan-card.best { border-color: color-mix(in oklab, var(--gold) 50%, transparent); box-shadow: 0 0 0 1px color-mix(in oklab, var(--gold) 20%, transparent); }
.plan-card.current { border-color: color-mix(in oklab, var(--ok) 45%, transparent); }
.plan-flag { position: absolute; top: -10px; left: 50%; transform: translateX(-50%); background: var(--gold); color: var(--noir-void); font-size: 9px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; padding: 3px 10px; border-radius: 999px; white-space: nowrap; }
.plan-name { font-family: var(--fd); font-size: 19px; color: var(--bone); }
.plan-price { font-family: var(--fd); font-size: 30px; color: var(--gold-bright); margin: 6px 0 12px; }
.plan-price span { font-size: 13px; color: var(--bone-mute); font-family: var(--fb); }
.plan-perks { list-style: none; padding: 0; margin: 0 0 16px; flex: 1; display: flex; flex-direction: column; gap: 7px; }
.plan-perks li { font-size: 12.5px; color: var(--bone-dim); padding-left: 18px; position: relative; line-height: 1.4; }
.plan-perks li::before { content: "✦"; position: absolute; left: 0; color: var(--gold-matte); font-size: 10px; top: 2px; }
.plan-cta { width: 100%; }
.plan-cta.ghost { background: transparent; border: 1px solid var(--noir-line); color: var(--bone-mute); cursor: default; }
@media (max-width: 720px) and (min-width: 481px) { .plan-cards { grid-template-columns: repeat(2, 1fr); } .plan-card.best { grid-column: span 2; } }
@media (max-width: 480px) { .plan-cards { grid-template-columns: 1fr; } .plan-card.best { grid-column: auto; } }

/* ── Landing sections ── */
.landing-sec { max-width: 1000px; margin: 56px auto 0; }
.landing-sec > .eyebrow { display: block; text-align: center; }
.landing-sec h2 { font-family: var(--fd); font-size: clamp(24px, 4vw, 32px); text-align: center; margin: 8px 0 6px; font-weight: 400; }
.landing-sec .sub { text-align: center; color: var(--bone-mute); font-size: 14px; margin: 0 0 26px; }
.how-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.how-step { border: 1px solid var(--noir-line); border-radius: var(--rad); padding: 18px; }
.how-step .hn { font-family: var(--fd); color: var(--gold-bright); font-size: 22px; }
.how-step .ht { color: var(--bone); font-weight: 600; font-size: 14px; margin: 6px 0 4px; }
.how-step .hd { color: var(--bone-mute); font-size: 12.5px; line-height: 1.5; }
@media (max-width: 720px) { .how-row { grid-template-columns: 1fr; } }
.landing-foot { max-width: 1000px; margin: 60px auto 30px; text-align: center; color: var(--bone-mute); font-size: 12px; border-top: 1px solid var(--noir-line); padding-top: 24px; }

/* ── Landing social proof ── */
.proof { margin-top: 30px; }
.proof-h { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 12px; }
.proof-h a { font-size: 12px; color: var(--gold-bright); text-decoration: none; }
.proof-h a:hover { color: var(--gold-foil); }
.proof-row { display: flex; gap: 10px; overflow-x: auto; padding-bottom: 6px; scrollbar-width: thin; }
.proof-chip { flex: 0 0 auto; max-width: 230px; text-align: left; background: color-mix(in oklab, var(--noir) 90%, transparent); border: 1px solid var(--noir-line); border-radius: var(--rad-sm); padding: 11px 13px; cursor: pointer; transition: border-color 0.25s var(--ease), transform 0.25s var(--ease); display: flex; flex-direction: column; gap: 3px; }
.proof-chip:hover { border-color: color-mix(in oklab, var(--gold) 35%, transparent); transform: translateY(-2px); }
.proof-chip b { color: var(--bone); font-size: 13px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.proof-chip span { color: var(--bone-mute); font-size: 11px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.app-frame { width: 100%; height: min(74vh, 820px); border: 0; display: block; background: #0A0907; }
.refine-bar { display: flex; gap: 10px; margin-top: 14px; flex-wrap: wrap; }
.refine-bar input { flex: 1; min-width: 200px; background: var(--noir); border: 1px solid color-mix(in oklab, var(--gold) 22%, transparent); color: var(--bone); padding: 12px 14px; border-radius: var(--rad-sm); font-size: 14px; outline: none; }
.refine-bar input:focus { border-color: color-mix(in oklab, var(--gold) 50%, transparent); }
@media (prefers-reduced-motion: reduce) { .building .ring { animation: none; } }

/* ── Billing (v5) ────────────────────────────────────── */
.tb-right { display: flex; align-items: center; gap: 12px; min-width: 0; }
.brand { cursor: pointer; }
/* ── Account menu + avatar ───────────────────────────── */
.upgrade-pill { display: inline-flex; align-items: center; font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--noir-void); background: linear-gradient(180deg, var(--gold-foil), var(--gold)); padding: 7px 13px; border-radius: 999px; font-weight: 600; transition: filter 0.2s var(--ease); }
.upgrade-pill:hover { filter: brightness(1.08); }
.acct-wrap { position: relative; }
.avatar-btn { display: grid; place-items: center; width: 34px; height: 34px; border-radius: 999px; border: 1px solid color-mix(in oklab, var(--gold) 34%, transparent); color: var(--gold-bright); font-size: 13px; font-weight: 600; background: color-mix(in oklab, var(--gold-deep) 14%, transparent); transition: all 0.2s var(--ease); }
.avatar-btn:hover { border-color: color-mix(in oklab, var(--gold) 60%, transparent); }
.acct-menu { position: absolute; right: 0; top: calc(100% + 8px); min-width: 196px; background: color-mix(in oklab, var(--noir) 96%, transparent); border: 1px solid var(--noir-line); border-radius: var(--rad); padding: 6px; z-index: 60; box-shadow: 0 18px 48px rgba(0,0,0,0.5); backdrop-filter: blur(14px); display: flex; flex-direction: column; }
.acct-menu[hidden] { display: none; }
.acct-head { padding: 8px 10px 10px; border-bottom: 1px solid var(--noir-line); margin-bottom: 4px; }
.acct-name { font-family: var(--fd); font-size: 15px; color: var(--bone); }
.acct-plan { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold-matte); margin-top: 2px; }
.acct-menu button { text-align: left; padding: 9px 11px; border-radius: 8px; font-size: 13px; color: var(--bone-dim); transition: all 0.15s var(--ease); }
.acct-menu button:hover { background: color-mix(in oklab, var(--gold-deep) 18%, transparent); color: var(--bone); }
.acct-sep { height: 1px; background: var(--noir-line); margin: 5px 4px; }
.acct-menu button.acct-danger { color: var(--bone-mute); }
.acct-menu button.acct-danger:hover { color: var(--fail); background: color-mix(in oklab, var(--fail) 10%, transparent); }
/* ── Mobile bottom tab bar ───────────────────────────── */
.tabbar { display: none; }
@media (max-width: 820px) {
  .topbar { gap: 8px; padding-left: 14px; padding-right: 14px; }
  .brand .sb { display: none; }
  .brand .mk { font-size: 15px; }
  .topnav { display: none; }
  .tb-right { gap: 8px; }
  .view { padding-bottom: 84px; }
  .tabbar { display: grid; grid-template-columns: repeat(4, 1fr); position: fixed; left: 0; right: 0; bottom: 0; z-index: 50; background: color-mix(in oklab, var(--noir-deep) 94%, transparent); backdrop-filter: blur(16px); border-top: 1px solid var(--noir-line); padding-bottom: env(safe-area-inset-bottom); }
  .tabbar button { display: flex; flex-direction: column; align-items: center; gap: 3px; padding: 9px 0 8px; font-size: 18px; color: var(--bone-mute); transition: color 0.18s var(--ease); }
  .tabbar button span { font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase; }
  .tabbar button.active { color: var(--gold-bright); }
}
@media (max-width: 460px) {
  /* The VN mark carries the brand on small screens — drop the wordmark text to save space. */
  .brand .mk, .brand .sb { display: none; }
  .brand-mark { height: 28px; }
}
.credits-pill { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; color: var(--gold-bright); border: 1px solid color-mix(in oklab, var(--gold) 35%, transparent); padding: 7px 12px; border-radius: 999px; letter-spacing: 0.04em; }
.credits-pill:hover { border-color: color-mix(in oklab, var(--gold) 60%, transparent); background: color-mix(in oklab, var(--gold-deep) 18%, transparent); }
.credits-pill b { font-weight: 600; color: var(--gold-foil); }
/* Scrollable overlay: flex-column + margin:auto centers a short modal but lets a tall one
   (the full tier list on a phone) scroll from the top so the close button is always reachable. */
.paywall { position: fixed; inset: 0; background: rgba(0,0,0,0.66); backdrop-filter: blur(4px); z-index: 70; padding: 20px; display: flex; flex-direction: column; align-items: center; overflow-y: auto; -webkit-overflow-scrolling: touch; }
.paywall-card { width: min(440px, 100%); padding: 26px; text-align: center; margin: auto 0; }
.paywall-card .eyebrow { display: block; margin-bottom: 10px; }
.paywall-card h3 { font-size: 28px; margin: 0 0 10px; }
.paywall-card .pwp { font-size: 13px; color: var(--bone-dim); line-height: 1.6; margin: 0 0 16px; }
.paywall-card .pwp b { color: var(--gold-bright); }
.paywall-card .refine-bar { margin: 0; }
.paywall-card .pcap { font-size: 11px; color: var(--bone-mute); margin: 14px 0 0; line-height: 1.5; }
.paywall-card #pwClose { margin-top: 16px; }

/* ── PayPal buy modal (v6) ──────────────────────────── */
.tiers { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin: 8px 0 4px; }
.tier { position: relative; display: flex; flex-direction: column; align-items: center; gap: 1px; padding: 12px 6px; border: 1px solid var(--noir-line); border-radius: var(--rad-sm); transition: all 0.25s var(--ease); }
.tier:hover { border-color: color-mix(in oklab, var(--gold) 40%, transparent); }
.tier.on { border-color: var(--gold); background: color-mix(in oklab, var(--gold-deep) 22%, transparent); }
.tier.best { border-color: color-mix(in oklab, var(--gold) 55%, transparent); background: color-mix(in oklab, var(--gold-deep) 14%, transparent); }
.tier .tc { font-family: var(--fd); font-size: 20px; color: var(--bone); }
.tier .tl { font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--bone-mute); }
.tier .tp { font-size: 13px; color: var(--gold-bright); margin-top: 4px; }
.tbest { position: absolute; top: -8px; left: 50%; transform: translateX(-50%); font-size: 8px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; background: linear-gradient(180deg, var(--gold-bright), var(--gold)); color: var(--noir-deep); padding: 2px 8px; border-radius: 999px; white-space: nowrap; }
.pay-area { min-height: 6px; margin-top: 8px; }
@media (max-width: 430px) { .tiers { grid-template-columns: repeat(2, 1fr); } }

/* ── Buy modal sections (v7) ────────────────────────── */
.buy-h { display: block; text-align: left; margin: 12px 0 6px; }

/* ── Onboarding + Turnstile claim (v9) ──────────────── */
.coach { position: fixed; inset: 0; background: rgba(0,0,0,0.68); backdrop-filter: blur(5px); display: grid; place-items: center; z-index: 80; padding: 20px; }
.coach-card { width: min(440px, 100%); padding: 28px; text-align: center; }
.coach-card .eyebrow { display: block; margin-bottom: 10px; }
.coach-card h3 { font-size: 26px; margin: 0 0 12px; line-height: 1.12; }
.coach-card p { font-size: 14px; color: var(--bone-dim); line-height: 1.65; margin: 0 0 8px; }
.coach-card p b { color: var(--gold-bright); }
.coach-steps { display: flex; flex-direction: column; gap: 11px; text-align: left; margin: 16px 0 4px; }
.coach-step { display: flex; gap: 12px; align-items: flex-start; font-size: 13.5px; color: var(--bone-dim); }
.coach-step .n { font-family: var(--fd); color: var(--gold-bright); width: 20px; flex-shrink: 0; }
.coach-dots { display: flex; gap: 6px; justify-content: center; margin: 18px 0 6px; }
.coach-dots i { width: 7px; height: 7px; border-radius: 50%; background: var(--noir-line); display: block; }
.coach-dots i.on { background: var(--gold); }
.coach-actions { display: flex; gap: 10px; justify-content: center; margin-top: 14px; }
.coach-skip { display: block; margin: 12px auto 0; font-size: 11px; color: var(--bone-mute); }
.coach-skip:hover { color: var(--bone-dim); }
.cf-turnstile-wrap { display: flex; justify-content: center; margin: 16px 0 6px; min-height: 66px; }
.intentbox.pulse { animation: ibpulse 1.6s var(--ease) 2; }
@keyframes ibpulse { 0%,100% { border-color: color-mix(in oklab, var(--gold) 22%, transparent); } 50% { border-color: var(--gold-bright); box-shadow: 0 0 0 4px color-mix(in oklab, var(--gold) 12%, transparent); } }

/* ── Statement (ledger) ── */
.st-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 14px; margin-bottom: 26px; }
.st-card { padding: 16px 18px; }
.st-card .st-k { font-size: 9px; text-transform: uppercase; letter-spacing: 0.18em; color: var(--gold-matte); }
.st-card .st-v { font-family: var(--fd); font-size: 28px; color: var(--bone); margin: 6px 0 2px; }
.st-card .st-sub { font-size: 10.5px; color: var(--bone-mute); }
.st-list { border-top: 1px solid var(--noir-line); }
.st-row { display: grid; grid-template-columns: 120px 1fr 70px 64px 90px; gap: 10px; align-items: center; padding: 13px 4px; border-bottom: 1px solid var(--noir-line); font-size: 13px; }
.st-when { font-size: 11px; color: var(--bone-mute); }
.st-what { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.st-what b { color: var(--bone); font-weight: 600; }
.st-note { font-size: 10.5px; color: var(--bone-mute); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.st-delta { text-align: right; font-variant-numeric: tabular-nums; color: var(--bone-mute); }
.st-delta.pos { color: var(--ok); }
.st-delta.neg { color: var(--gold-bright); }
.st-bal { text-align: right; font-variant-numeric: tabular-nums; color: var(--bone-dim); }
.st-extra { text-align: right; font-size: 11px; }
.st-cash { color: var(--ok); font-variant-numeric: tabular-nums; }
.st-cash.neg { color: var(--gold-matte); }
.st-cost { color: var(--bone-mute); font-variant-numeric: tabular-nums; }
@media (max-width: 560px) {
  .st-row { grid-template-columns: 1fr auto auto; grid-template-areas: "what delta bal" "when extra extra"; row-gap: 4px; }
  .st-when { grid-area: when; } .st-what { grid-area: what; } .st-delta { grid-area: delta; } .st-bal { grid-area: bal; } .st-extra { grid-area: extra; text-align: left; }
}

/* ── Concierge chat ── */
.concierge { margin-top: 16px; padding: 16px 16px 14px; }
.cc-head { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; margin-bottom: 12px; }
.cc-hint { font-size: 11px; color: var(--bone-mute); }
.cc-log { display: flex; flex-direction: column; gap: 10px; max-height: 320px; overflow-y: auto; padding: 4px 2px 12px; }
.cc-msg { max-width: 86%; padding: 10px 13px; border-radius: 13px; font-size: 13.5px; line-height: 1.5; white-space: pre-wrap; word-wrap: break-word; }
.cc-msg.ai { align-self: flex-start; background: color-mix(in oklab, var(--noir-haze) 80%, transparent); border: 1px solid var(--noir-line); color: var(--bone-dim); border-bottom-left-radius: 4px; }
.cc-msg.me { align-self: flex-end; background: color-mix(in oklab, var(--gold) 14%, var(--noir)); border: 1px solid color-mix(in oklab, var(--gold) 28%, transparent); color: var(--bone); border-bottom-right-radius: 4px; }
.cc-msg.pending { color: var(--bone-mute); }
.cc-msg.applied { border-color: color-mix(in oklab, var(--ok) 40%, transparent); display: flex; gap: 8px; align-items: baseline; }
.cc-badge { font-size: 9px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ok); border: 1px solid color-mix(in oklab, var(--ok) 40%, transparent); padding: 2px 6px; border-radius: 5px; flex-shrink: 0; }
.cc-bar { display: flex; gap: 9px; align-items: flex-end; border-top: 1px solid var(--noir-line); padding-top: 12px; }
.cc-bar textarea { flex: 1; resize: none; background: var(--noir-deep); border: 1px solid var(--noir-line); color: var(--bone); border-radius: var(--rad-sm); padding: 11px 13px; font: inherit; font-size: 14px; line-height: 1.4; min-height: 44px; max-height: 140px; }
.cc-bar textarea:focus { outline: none; border-color: color-mix(in oklab, var(--gold) 45%, transparent); }
.cc-bar .btn { white-space: nowrap; }

/* ── Custom domain card ── */
.domain-card { padding: 15px 17px; }
.dc-hint { font-size: 13px; color: var(--bone-mute); margin: 8px 0 12px; }
.dc-have { font-size: 14px; color: var(--ok); margin: 9px 0 12px; }
.dc-have a { color: var(--gold-bright); text-decoration: none; }
.dc-have a:hover { color: var(--gold-foil); }
.dc-claim { display: flex; align-items: center; gap: 0; flex-wrap: wrap; }
.dc-claim input { background: var(--noir-deep); border: 1px solid var(--noir-line); border-right: 0; color: var(--bone); border-radius: var(--rad-sm) 0 0 var(--rad-sm); padding: 10px 12px; font: inherit; font-size: 14px; width: 150px; }
.dc-claim input:focus { outline: none; border-color: color-mix(in oklab, var(--gold) 45%, transparent); }
.dc-base { background: var(--noir-haze); border: 1px solid var(--noir-line); border-left: 0; border-right: 0; color: var(--bone-mute); font-size: 13px; padding: 10px 10px; align-self: stretch; display: flex; align-items: center; }
.dc-claim .btn { border-radius: 0 var(--rad-sm) var(--rad-sm) 0; }
.dc-actions { display: flex; gap: 7px; }
.dc-msg { margin-top: 9px; font-size: 12px; min-height: 16px; }

/* ── The Vault ── */
.btn-ghost.xs { padding: 5px 10px; font-size: 11px; }
.vault-meter { padding: 16px 18px; margin-bottom: 18px; }
.vm-top { display: flex; justify-content: space-between; align-items: baseline; }
.vm-fig { font-family: var(--fd); font-size: 19px; color: var(--bone); }
.vm-q { color: var(--bone-mute); font-size: 13px; }
.vm-bar { height: 8px; background: var(--noir-deep); border: 1px solid var(--noir-line); border-radius: 6px; overflow: hidden; margin: 11px 0 9px; }
.vm-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--gold-deep), var(--gold-bright)); transition: width 0.5s var(--ease); }
.vm-bar i[data-st="warn"] { background: linear-gradient(90deg, var(--gold-matte), var(--warn)); }
.vm-bar i[data-st="full"] { background: linear-gradient(90deg, var(--warn), var(--fail)); }
.vm-legend { display: flex; justify-content: space-between; font-size: 11px; color: var(--bone-mute); flex-wrap: wrap; gap: 6px; }
.vm-pip { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: var(--warn); margin-right: 5px; vertical-align: 1px; animation: vmpulse 1.8s var(--ease) infinite; }
@keyframes vmpulse { 0%,100% { opacity: 0.4; } 50% { opacity: 1; } }
.vault-search { display: flex; gap: 9px; margin: 4px 0 6px; }
.vault-search input { flex: 1; background: var(--noir-deep); border: 1px solid var(--noir-line); color: var(--bone); border-radius: var(--rad-sm); padding: 12px 14px; font: inherit; font-size: 14px; }
.vault-search input:focus { outline: none; border-color: color-mix(in oklab, var(--gold) 45%, transparent); }
.vault-results { display: flex; flex-direction: column; gap: 8px; margin-top: 12px; }
.vs-row { display: grid; grid-template-columns: minmax(120px, 1fr) 2fr auto; gap: 12px; align-items: baseline; padding: 11px 13px; background: color-mix(in oklab, var(--noir) 90%, transparent); border: 1px solid var(--noir-line); border-radius: var(--rad-sm); cursor: pointer; transition: border-color 0.25s var(--ease); }
.vs-row:hover { border-color: color-mix(in oklab, var(--gold) 35%, transparent); }
.vs-title { font-family: var(--fd); color: var(--bone); font-size: 15px; }
.vs-idea { font-size: 12px; color: var(--bone-mute); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.vs-open { font-size: 11px; color: var(--gold-bright); }
.vs-mode { font-size: 10px; color: var(--bone-mute); text-align: right; margin-top: 7px; text-transform: uppercase; letter-spacing: 0.12em; }
.vault-recent { display: flex; flex-direction: column; gap: 7px; }
.vr-row { display: grid; grid-template-columns: auto 1fr auto; gap: 11px; align-items: center; padding: 10px 12px; border: 1px solid var(--noir-line); border-radius: var(--rad-sm); cursor: pointer; transition: border-color 0.25s var(--ease); }
.vr-row:hover { border-color: color-mix(in oklab, var(--gold) 30%, transparent); }
.vr-label { color: var(--bone-dim); font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.vr-meta { font-size: 11px; color: var(--bone-mute); white-space: nowrap; }
.src-badge { font-size: 9px; text-transform: uppercase; letter-spacing: 0.1em; padding: 3px 7px; border-radius: 5px; border: 1px solid var(--noir-line); color: var(--bone-mute); white-space: nowrap; }
.src-badge[data-src="build"] { color: var(--gold-bright); border-color: color-mix(in oklab, var(--gold) 35%, transparent); }
.src-badge[data-src="refine"] { color: var(--bone-dim); }
.src-badge[data-src="concierge"] { color: #9fb8d9; border-color: color-mix(in oklab, #9fb8d9 35%, transparent); }
.src-badge[data-src="restore"] { color: var(--ok); border-color: color-mix(in oklab, var(--ok) 35%, transparent); }
.src-badge[data-src="branch"] { color: var(--warn); border-color: color-mix(in oklab, var(--warn) 35%, transparent); }
.history-drawer { margin-top: 16px; padding: 4px 16px; }
.history-drawer summary { cursor: pointer; padding: 12px 0; display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; list-style: none; }
.history-drawer summary::-webkit-details-marker { display: none; }
.history-drawer summary::before { content: "▸"; color: var(--gold-matte); transition: transform 0.2s var(--ease); }
.history-drawer[open] summary::before { transform: rotate(90deg); }
.hd-hint { font-size: 11px; color: var(--bone-mute); }
.timeline { display: flex; flex-direction: column; gap: 2px; padding-bottom: 12px; }
.tl-row { display: grid; grid-template-columns: 18px 1fr auto; gap: 12px; align-items: center; padding: 12px 2px; border-bottom: 1px solid color-mix(in oklab, var(--noir-line) 60%, transparent); }
.tl-node { width: 9px; height: 9px; border-radius: 50%; background: var(--noir-haze); border: 1px solid var(--gold-deep); justify-self: center; }
.tl-row.current .tl-node { background: var(--gold-bright); box-shadow: 0 0 0 3px color-mix(in oklab, var(--gold) 18%, transparent); }
.tl-head { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; }
.tl-head b { color: var(--bone); font-size: 13px; }
.tl-cur { font-size: 9px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ok); }
.tl-time { font-size: 11px; color: var(--bone-mute); }
.tl-label { font-size: 12.5px; color: var(--bone-dim); margin-top: 3px; overflow: hidden; text-overflow: ellipsis; }
.tl-actions { display: flex; gap: 6px; flex-shrink: 0; }
.drive-dormant { display: flex; gap: 12px; align-items: flex-start; padding: 16px 18px; }
.drive-dormant b { color: var(--bone); }
.drive-dormant p { font-size: 12.5px; color: var(--bone-mute); margin: 5px 0 0; }
.dropzone { border: 1.5px dashed var(--noir-line); border-radius: var(--rad); padding: 30px; text-align: center; color: var(--bone-mute); transition: all 0.25s var(--ease); }
.dropzone.over { border-color: var(--gold-bright); background: color-mix(in oklab, var(--gold) 8%, transparent); }
.dropzone #browseBtn { color: var(--gold-bright); cursor: pointer; }
.asset-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 12px; margin-top: 14px; }
.asset-card { border: 1px solid var(--noir-line); border-radius: var(--rad-sm); overflow: hidden; background: var(--noir-deep); }
.ac-thumb { height: 92px; display: flex; align-items: center; justify-content: center; background: var(--noir); overflow: hidden; }
.ac-thumb img { width: 100%; height: 100%; object-fit: cover; }
.ac-ext { font-family: var(--fd); color: var(--gold-matte); font-size: 16px; letter-spacing: 0.08em; }
.ac-name { font-size: 11.5px; color: var(--bone-dim); padding: 8px 9px 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ac-foot { display: flex; align-items: center; gap: 8px; padding: 4px 9px 9px; font-size: 10.5px; color: var(--bone-mute); }
.ac-foot a, .ac-del { margin-left: auto; color: var(--bone-mute); background: none; border: none; cursor: pointer; font-size: 13px; }
.ac-del { margin-left: 0; }
.ac-foot a:hover, .ac-del:hover { color: var(--gold-bright); }

/* ── Ops Cockpit ── */
.ops-gate { max-width: 460px; margin: 8vh auto 0; padding: 30px 28px; text-align: center; }
.ops-gate h2 { margin: 8px 0 10px; }
.ops-gate p { font-size: 13.5px; color: var(--bone-mute); margin-bottom: 18px; }
.ops-gate code { color: var(--gold-bright); }
.ops-gate-bar { display: flex; gap: 9px; }
.ops-gate-bar input { flex: 1; background: var(--noir-deep); border: 1px solid var(--noir-line); color: var(--bone); border-radius: var(--rad-sm); padding: 11px 13px; font: inherit; font-size: 14px; }
.ops-gate-bar input:focus { outline: none; border-color: color-mix(in oklab, var(--gold) 45%, transparent); }
.ops-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: 16px; }
.ops-kpi { padding: 18px 20px; }
.ops-kpi .ok-k { font-size: 10px; text-transform: uppercase; letter-spacing: 0.16em; color: var(--gold-matte); }
.ops-kpi .ok-v { font-family: var(--fd); font-size: 30px; color: var(--bone); margin: 7px 0 3px; }
.ops-kpi .ok-sub { font-size: 11px; color: var(--bone-mute); }
.ops-kpi.pos .ok-v { color: var(--ok); }
.ops-kpi.neg .ok-v { color: var(--fail); }
.ops-stats { display: flex; flex-wrap: wrap; gap: 8px 18px; font-size: 12px; color: var(--bone-mute); padding: 2px 2px 16px; }
.ops-stats b { color: var(--bone-dim); font-variant-numeric: tabular-nums; }
.ops-recon { font-size: 12px; padding: 9px 13px; border-radius: var(--rad-sm); border: 1px solid; }
.ops-recon.ok { color: var(--ok); border-color: color-mix(in oklab, var(--ok) 35%, transparent); background: color-mix(in oklab, var(--ok) 7%, transparent); }
.ops-recon.bad { color: var(--fail); border-color: color-mix(in oklab, var(--fail) 40%, transparent); background: color-mix(in oklab, var(--fail) 9%, transparent); }
.ops-bars { display: flex; align-items: flex-end; gap: 6px; height: 120px; padding: 4px 2px; }
.ob-col { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 5px; height: 100%; justify-content: flex-end; }
.ob-stack { display: flex; gap: 2px; align-items: flex-end; height: 100%; width: 100%; justify-content: center; }
.ob-stack i { width: 8px; border-radius: 2px 2px 0 0; min-height: 1px; }
.ob-rev { background: var(--ok); }
.ob-cost { background: var(--gold); }
.ob-day { font-size: 8.5px; color: var(--bone-mute); }
.ops-bars-legend { display: flex; gap: 16px; font-size: 10.5px; color: var(--bone-mute); margin-top: 8px; }
.ops-bars-legend i { display: inline-block; width: 9px; height: 9px; border-radius: 2px; vertical-align: 0; margin-right: 4px; }
.ops-cols { display: grid; grid-template-columns: 1.4fr 1fr; gap: 22px; align-items: start; }
.ops-feed { display: flex; flex-direction: column; }
.olr { display: grid; grid-template-columns: 96px 1fr 76px 56px 64px; gap: 8px; align-items: center; padding: 9px 2px; border-bottom: 1px solid color-mix(in oklab, var(--noir-line) 60%, transparent); font-size: 12px; }
.olr-when { color: var(--bone-mute); font-size: 11px; }
.olr-type { color: var(--bone-dim); }
.olr-tok { color: var(--bone-mute); font-family: ui-monospace, monospace; font-size: 10.5px; }
.olr-delta { text-align: right; font-variant-numeric: tabular-nums; color: var(--bone-mute); }
.olr-delta.pos { color: var(--ok); } .olr-delta.neg { color: var(--gold-bright); }
.olr-extra { text-align: right; }
.olr-cash { color: var(--ok); font-size: 11px; } .olr-cost { color: var(--bone-mute); font-size: 11px; }
.ops-tool { padding: 15px 17px; margin-bottom: 14px; }
.ops-tool-p { font-size: 12px; color: var(--bone-mute); margin: 6px 0 11px; }
.ops-mint { display: flex; gap: 7px; margin-top: 10px; }
.ops-mint input { width: 80px; background: var(--noir-deep); border: 1px solid var(--noir-line); color: var(--bone); border-radius: var(--rad-sm); padding: 9px 11px; font: inherit; font-size: 13px; }
.ops-mint input:focus { outline: none; border-color: color-mix(in oklab, var(--gold) 45%, transparent); }
.ops-mint-out { margin-top: 11px; display: flex; flex-wrap: wrap; gap: 7px; font-size: 12px; }
.ops-code { background: var(--noir-deep); border: 1px solid color-mix(in oklab, var(--gold) 30%, transparent); color: var(--gold-bright); padding: 5px 9px; border-radius: 6px; font-family: ui-monospace, monospace; font-size: 12px; }
@media (max-width: 720px) { .ops-kpis { grid-template-columns: 1fr; } .ops-cols { grid-template-columns: 1fr; } .olr { grid-template-columns: 80px 1fr 50px 56px; } .olr-tok { display: none; } }

/* ── Explore (v2) ────────────────────────────────────── */
.explore-sec { margin-top: 26px; }
.explore-h { display: flex; align-items: baseline; gap: 12px; margin-bottom: 14px; }
.explore-h .eyebrow { color: var(--gold-matte); }
.explore-h .sc { font-size: 11px; color: var(--bone-mute); margin-left: auto; }
.reality-card.featured { border-color: color-mix(in oklab, var(--gold) 38%, transparent); background: linear-gradient(180deg, color-mix(in oklab, var(--gold-deep) 12%, transparent), transparent); }
.reality-card.featured .arch { color: var(--gold-bright); }

/* ── Profile (v2) ────────────────────────────────────── */
.profile-top { display: flex; align-items: center; gap: 16px; padding: 18px 20px; }
.pf-avatar { width: 56px; height: 56px; border-radius: 999px; display: grid; place-items: center; font-family: var(--fd); font-size: 24px; color: var(--gold-foil); border: 1px solid color-mix(in oklab, var(--gold) 40%, transparent); background: color-mix(in oklab, var(--gold-deep) 18%, transparent); flex: 0 0 auto; }
.pf-id { flex: 1; min-width: 0; }
.pf-name { font-family: var(--fd); font-size: 22px; color: var(--bone); }
.pf-meta { font-size: 12px; color: var(--bone-mute); margin-top: 4px; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.plan-chip { font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; padding: 3px 9px; border-radius: 999px; border: 1px solid color-mix(in oklab, var(--gold) 32%, transparent); color: var(--gold-bright); }
.plan-chip.plan-free { color: var(--bone-mute); border-color: var(--noir-line); }
.plan-chip.plan-lite { background: color-mix(in oklab, var(--gold-deep) 12%, transparent); color: var(--gold-bright); }
.plan-chip.plan-pro, .plan-chip.plan-max { background: color-mix(in oklab, var(--gold-deep) 22%, transparent); color: var(--gold-foil); }
.rule-gold { height: 1px; background: color-mix(in oklab, var(--gold) 26%, transparent); border: 0; }
.pf-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 16px; }
.pf-stat { padding: 16px 18px; }
.pf-k { font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--bone-mute); }
.pf-v { font-family: var(--fd); font-size: 30px; color: var(--bone); margin: 4px 0 2px; }
.pf-sub { font-size: 11px; color: var(--bone-mute); }
.pf-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 20px; }
@media (max-width: 560px) { .pf-stats { grid-template-columns: 1fr; } }

/* ── Settings (v2) ───────────────────────────────────── */
.set-group { padding: 6px 20px; margin-top: 16px; }
.set-group.danger { border-color: color-mix(in oklab, var(--fail) 30%, transparent); }
.set-row { display: flex; align-items: center; gap: 16px; padding: 18px 0; border-bottom: 1px solid var(--noir-line); }
.set-group > .set-row:last-child { border-bottom: none; }
.set-row > div:first-child { flex: 1; min-width: 0; }
.set-k { font-size: 14px; color: var(--bone); }
.set-d { font-size: 12px; color: var(--bone-mute); margin-top: 3px; }
.set-row input[type="text"], .set-row select { background: var(--noir-deep); border: 1px solid var(--noir-line); color: var(--bone); border-radius: var(--rad-sm); padding: 10px 12px; font: inherit; font-size: 14px; min-width: 200px; }
.set-row input[type="text"]:focus, .set-row select:focus { outline: none; border-color: color-mix(in oklab, var(--gold) 45%, transparent); }
.switch { position: relative; display: inline-block; width: 46px; height: 26px; flex: 0 0 auto; }
.switch input { opacity: 0; width: 0; height: 0; }
.switch span { position: absolute; inset: 0; background: var(--noir-haze); border: 1px solid var(--noir-line); border-radius: 999px; transition: 0.2s var(--ease); }
.switch span::before { content: ""; position: absolute; width: 18px; height: 18px; left: 3px; top: 3px; background: var(--bone-mute); border-radius: 999px; transition: 0.2s var(--ease); }
.switch input:checked + span { background: color-mix(in oklab, var(--gold-deep) 40%, transparent); border-color: color-mix(in oklab, var(--gold) 45%, transparent); }
.switch input:checked + span::before { transform: translateX(20px); background: var(--gold-foil); }
.btn-ghost.danger { border-color: color-mix(in oklab, var(--fail) 40%, transparent); color: var(--fail); }
.btn-ghost.danger:hover { border-color: var(--fail); color: var(--fail); }

/* ── Support (v2) ────────────────────────────────────── */
.support-cols { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 20px; align-items: start; }
.support-form { padding: 20px; display: flex; flex-direction: column; }
.sp-l { font-size: 11px; letter-spacing: 0.06em; color: var(--bone-mute); margin: 14px 0 6px; }
.support-form input, .support-form select, .support-form textarea { background: var(--noir-deep); border: 1px solid var(--noir-line); color: var(--bone); border-radius: var(--rad-sm); padding: 11px 12px; font: inherit; font-size: 14px; width: 100%; }
.support-form input:focus, .support-form select:focus, .support-form textarea:focus { outline: none; border-color: color-mix(in oklab, var(--gold) 45%, transparent); }
.support-form textarea { resize: vertical; }
.support-form .btn { margin-top: 18px; align-self: flex-start; }
.sp-out { margin-top: 12px; font-size: 13px; }
.sp-out .ok { color: var(--ok); } .sp-out .err { color: var(--fail); }
.faq-item { border-bottom: 1px solid var(--noir-line); }
.faq-item summary { padding: 13px 0; font-size: 14px; color: var(--bone-dim); cursor: pointer; list-style: none; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::before { content: "+ "; color: var(--gold-matte); }
.faq-item[open] summary::before { content: "− "; }
.faq-item p { margin: 0 0 14px; font-size: 13px; color: var(--bone-mute); line-height: 1.6; }
.sp-tickets { display: flex; flex-direction: column; gap: 10px; }
.sp-ticket { border: 1px solid var(--noir-line); border-radius: var(--rad-sm); padding: 12px 14px; }
.spt-h { display: flex; align-items: center; gap: 10px; }
.spt-h b { font-size: 14px; color: var(--bone); flex: 1; }
.spt-st { font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; padding: 3px 8px; border-radius: 999px; border: 1px solid var(--noir-line); color: var(--bone-mute); }
.spt-st[data-st="answered"] { color: var(--ok); border-color: color-mix(in oklab, var(--ok) 40%, transparent); }
.spt-msg { font-size: 12px; color: var(--bone-mute); margin-top: 6px; }
.spt-resp { margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--noir-line); font-size: 13px; color: var(--bone-dim); line-height: 1.5; }
.spt-resp .eyebrow { display: block; margin-bottom: 5px; color: var(--gold-matte); }
@media (max-width: 720px) { .support-cols { grid-template-columns: 1fr; } }

/* Reduce-motion preference (Settings toggle) */
.reduce-motion *, .reduce-motion *::before, .reduce-motion *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; }

/* ── Ops observability — Users / Errors (admin) ──────── */
.ops-subnav { display: flex; gap: 6px; margin-bottom: 18px; border-bottom: 1px solid var(--noir-line); padding-bottom: 12px; }
.ops-subnav button { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--bone-dim); padding: 8px 14px; border-radius: 8px; border: 1px solid transparent; transition: all 0.2s var(--ease); }
.ops-subnav button:hover { color: var(--bone); }
.ops-subnav button.on { color: var(--gold-bright); border-color: color-mix(in oklab, var(--gold) 40%, transparent); background: color-mix(in oklab, var(--gold-deep) 14%, transparent); }
.ops-table-wrap { overflow-x: auto; border: 1px solid var(--noir-line); border-radius: var(--rad); }
.ops-table { width: 100%; border-collapse: collapse; font-size: 13px; min-width: 720px; }
.ops-table thead th { text-align: left; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--bone-mute); font-weight: 500; padding: 12px 14px; border-bottom: 1px solid var(--noir-line); }
.ops-table tbody tr { border-bottom: 1px solid color-mix(in oklab, var(--noir-line) 60%, transparent); cursor: pointer; transition: background 0.15s var(--ease); }
.ops-table tbody tr:hover { background: color-mix(in oklab, var(--gold-deep) 10%, transparent); }
.ops-table td { padding: 11px 14px; vertical-align: middle; }
.ut-name { color: var(--bone); font-weight: 500; }
.ut-sub { font-family: ui-monospace, monospace; font-size: 10px; color: var(--bone-mute); margin-top: 2px; }
.ut-num { text-align: center; color: var(--bone-dim); font-variant-numeric: tabular-nums; }
.ut-num.ut-err { color: var(--fail); font-weight: 600; }
.ut-when { color: var(--bone-mute); white-space: nowrap; font-size: 12px; }
.ou-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; }
@media (max-width: 820px) { .ou-cols { grid-template-columns: 1fr; } }
.ou-list { display: flex; flex-direction: column; gap: 8px; }
.ou-row { display: flex; align-items: flex-start; gap: 10px; padding: 10px 12px; border: 1px solid var(--noir-line); border-radius: var(--rad-sm); }
.ou-st { font-size: 9px; letter-spacing: 0.08em; text-transform: uppercase; padding: 3px 8px; border-radius: 999px; border: 1px solid var(--noir-line); color: var(--bone-mute); white-space: nowrap; flex: 0 0 auto; }
.ou-st[data-st="ready"], .ou-st[data-st="answered"] { color: var(--ok); border-color: color-mix(in oklab, var(--ok) 40%, transparent); }
.ou-st[data-st="failed"] { color: var(--fail); border-color: color-mix(in oklab, var(--fail) 40%, transparent); }
.ou-st[data-st="building"] { color: var(--warn); border-color: color-mix(in oklab, var(--warn) 40%, transparent); }
.ou-main { flex: 1; min-width: 0; }
.ou-main b { font-size: 13px; color: var(--bone); font-weight: 500; }
.ou-err { font-size: 11px; color: var(--fail); margin-top: 3px; word-break: break-word; }
.ou-when { font-size: 11px; color: var(--bone-mute); white-space: nowrap; flex: 0 0 auto; }
/* event rows */
.ops-feed.big { max-height: none; }
.oev-wrap { cursor: pointer; }
.oev-wrap:hover { background: color-mix(in oklab, var(--gold-deep) 8%, transparent); }
.oev { display: grid; grid-template-columns: 92px 132px 1fr auto; gap: 10px; align-items: baseline; padding: 8px 10px; border-bottom: 1px solid color-mix(in oklab, var(--noir-line) 55%, transparent); font-size: 12px; }
.oev-when { color: var(--bone-mute); font-size: 11px; white-space: nowrap; }
.oev-kind { font-family: ui-monospace, monospace; font-size: 11px; color: var(--gold-matte); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.oev-msg { color: var(--bone-dim); min-width: 0; }
.oev-intent { display: block; color: var(--bone-mute); font-style: italic; margin-top: 2px; }
.oev-meta { color: var(--bone-mute); font-size: 10px; white-space: nowrap; }
.oev-error .oev-kind { color: var(--fail); }
.oev-warn .oev-kind { color: var(--warn); }
.oev-tok { display: block; font-family: ui-monospace, monospace; font-size: 10px; color: var(--bone-mute); padding: 0 10px 8px 112px; }
.ev-tally { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.ev-pill { font-size: 11px; color: var(--bone-dim); border: 1px solid var(--noir-line); border-radius: 999px; padding: 4px 11px; }
.ev-pill b { color: var(--fail); }
.ev-filters { display: flex; gap: 6px; margin-bottom: 14px; }
.ev-filters button { font-size: 11px; color: var(--bone-dim); padding: 6px 12px; border-radius: 999px; border: 1px solid var(--noir-line); transition: all 0.15s var(--ease); }
.ev-filters button.on { color: var(--gold-bright); border-color: color-mix(in oklab, var(--gold) 40%, transparent); }
@media (max-width: 560px) { .oev { grid-template-columns: 64px 1fr; } .oev-meta { display: none; } .oev-tok { padding-left: 64px; } }

/* ════════════════════════════════════════════════════════
   MOBILE POLISH PASS (2026-06-19) — bigger tap targets, denser
   grids to cut scroll length, and no-clip menus/forms on phones.
   ════════════════════════════════════════════════════════ */
/* ── Account key card (Profile) + sign-in modal ──────── */
.key-card { margin-top: 18px; padding: 18px 20px; text-align: left; }
.key-note { font-size: 12.5px; color: var(--bone-mute); line-height: 1.55; margin: 8px 0 12px; }
.key-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.key-val { flex: 1; min-width: 0; font-family: ui-monospace, monospace; font-size: 12px; color: var(--gold-bright); background: var(--noir-deep); border: 1px solid var(--noir-line); border-radius: var(--rad-sm); padding: 10px 12px; overflow-x: auto; white-space: nowrap; }
.key-hint { font-size: 11.5px; color: var(--bone-mute); margin: 12px 0 0; }
.pw-sub { font-size: 13px; color: var(--bone-dim); line-height: 1.55; margin: 0 0 14px; }
.si-input { width: 100%; background: var(--noir-deep); border: 1px solid var(--noir-line); color: var(--bone); border-radius: var(--rad-sm); padding: 12px 13px; font: inherit; font-family: ui-monospace, monospace; font-size: 13px; }
.si-input:focus { outline: none; border-color: color-mix(in oklab, var(--gold) 45%, transparent); }
.si-info { min-height: 18px; font-size: 12.5px; margin-top: 8px; text-align: left; }
.si-ok { color: var(--ok); } .si-warn { color: var(--warn); }
/* Google sign-in button (Google brand: white surface, dark text) */
.btn-google { display: flex; align-items: center; justify-content: center; gap: 10px; width: 100%; background: #fff; color: #1f1f1f; font-size: 14px; font-weight: 600; padding: 12px 16px; border-radius: var(--rad-sm); text-decoration: none; transition: filter 0.2s var(--ease); }
.btn-google:hover { filter: brightness(0.96); }
.btn-google svg { flex: 0 0 auto; }
.btn-google.sm { width: auto; padding: 10px 16px; font-size: 13px; flex: 0 0 auto; }
.si-soon { font-size: 13px; color: var(--bone-mute); background: var(--noir-deep); border: 1px solid var(--noir-line); border-radius: var(--rad-sm); padding: 12px 14px; line-height: 1.5; }
.si-toggle { display: block; width: 100%; text-align: center; color: var(--bone-mute); font-size: 12.5px; padding: 12px 0 4px; }
.si-toggle:hover { color: var(--bone-dim); }
#siKeyArea { margin-top: 6px; }
/* Avatar images (Google picture) in the top bar + profile */
.avatar-btn img { width: 100%; height: 100%; border-radius: 999px; object-fit: cover; }
.pf-avatar img { width: 100%; height: 100%; border-radius: 999px; object-fit: cover; }
.pf-avatar { overflow: hidden; }
/* Profile: sign-in nudge banner for guests */
.pf-signin { display: flex; align-items: center; gap: 16px; padding: 16px 20px; margin-bottom: 14px; border-color: color-mix(in oklab, var(--gold) 30%, transparent); }
.pf-signin > div:first-child { flex: 1; min-width: 0; }
.pf-signin-h { font-family: var(--fd); font-size: 17px; color: var(--bone); }
.pf-signin-d { font-size: 13px; color: var(--bone-mute); margin-top: 3px; line-height: 1.5; }
@media (max-width: 560px) { .pf-signin { flex-direction: column; align-items: stretch; } .btn-google.sm { width: 100%; } }

@media (max-width: 480px) {
  /* Bigger, thumb-friendly top-bar controls (was 34px / ~24px tall)… */
  .avatar-btn { width: 40px; height: 40px; font-size: 14px; }
  .credits-pill { padding: 9px 12px; min-height: 40px; }
  .upgrade-pill { padding: 9px 12px; min-height: 40px; }
  /* …and tighten the bar so the taller controls still fit on a 375px screen. */
  .topbar { padding-left: 12px; padding-right: 12px; gap: 6px; }
  .tb-right { gap: 8px; }
  .brand { min-width: 0; }
  .brand .mk { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  /* Account dropdown can't run off the right edge of a narrow screen. */
  .acct-menu { min-width: 0; width: max-content; max-width: calc(100vw - 24px); }
  .acct-menu button { padding: 12px 12px; } /* taller menu rows */
  /* Two compact cards per row → roughly half the vertical scrolling in Explore/Library. */
  .lib-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .reality-card { padding: 14px; }
  /* Custom-domain claim input grows instead of being a fixed 150px. */
  .dc-claim input { width: auto; flex: 1; min-width: 0; }
  /* Concierge composer never overflows. */
  .cc-bar textarea { min-width: 0; }
}
@media (max-width: 560px) {
  /* Settings rows stack so the inputs go full-width instead of cramping. */
  .set-row { flex-direction: column; align-items: stretch; gap: 10px; }
  .set-row > div:first-child { width: 100%; }
  .set-row input[type="text"], .set-row select { min-width: 0; width: 100%; }
  .set-row .btn, .set-row .btn-ghost { align-self: flex-start; }
  /* Profile header wraps gracefully. */
  .profile-top { flex-wrap: wrap; }
  /* Operator tools: stack the mint inputs; trim the Users table to fit. */
  .ops-mint { flex-direction: column; align-items: stretch; }
  .ops-mint input { width: 100%; }
  .ops-table { min-width: 540px; }
  .ops-table th:nth-child(6), .ops-table td:nth-child(6) { display: none; } /* hide Device col */
}
@media (max-width: 820px) {
  /* Cap the live-app preview so the concierge chat below it stays reachable. */
  .app-frame { height: min(60vh, 540px); }
}

/* ════════════════════════════════════════════════════════
   POLISH PASS — Batch 1 (2026-06-19): global a11y + feedback + HUD.
   Additive overrides (later source order wins). Warm-noir + champagne-brass.
   ════════════════════════════════════════════════════════ */

/* ── A11y: comprehensive reduced-motion (kills every infinite animation) ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; }
}
/* iOS doesn't zoom the page when a focused field is >=16px; bump form text on phones + safer tap targets. */
@media (max-width: 560px) {
  input[type="text"], input[type="email"], input[type="number"], input[type="password"], textarea, select { font-size: 16px; }
  .btn { padding: 14px 22px; }
  .btn-ghost { padding: 12px 16px; }
}

/* ── Hero headline: anchor the pivot words with a soft brass glow ── */
.intent h1 em { letter-spacing: -0.035em; text-shadow: 0 2px 18px color-mix(in oklab, var(--gold-deep) 28%, transparent); }

/* ── Build CTA: loading + disabled states ── */
.btn:disabled, .btn.loading { opacity: .72; cursor: default; filter: saturate(.8); }
.btn.loading { position: relative; color: transparent !important; }
.btn.loading::after { content: ""; position: absolute; inset: 0; margin: auto; width: 15px; height: 15px; border: 2px solid color-mix(in oklab, var(--noir) 45%, transparent); border-top-color: var(--noir); border-radius: 999px; animation: rot .8s linear infinite; }

/* ── Credits pill: low-balance warning ── */
.credits-pill.low { color: var(--warn); border-color: color-mix(in oklab, var(--warn) 45%, transparent); }
.credits-pill.low b { color: var(--warn); }
.credits-pill.low::after { content: ""; width: 6px; height: 6px; border-radius: 999px; background: var(--warn); margin-left: 2px; animation: pulse 1.4s var(--ease) infinite; }

/* ── Toast: severity + icon + sits above the mobile tab bar ── */
.toast { max-width: min(460px, 90vw); }
.toast.t-ok { border-color: color-mix(in oklab, var(--ok) 45%, transparent); }
.toast.t-error { border-color: color-mix(in oklab, var(--fail) 50%, transparent); }
.toast.t-info { border-color: color-mix(in oklab, var(--gold) 40%, transparent); }
.toast.t-ok::before { content: "✓ "; color: var(--ok); }
.toast.t-error::before { content: "✕ "; color: var(--fail); }
.toast.t-info::before { content: "✦ "; color: var(--gold-bright); }
@media (max-width: 820px) { .toast { bottom: calc(82px + env(safe-area-inset-bottom)); } }

/* ── Mobile tab bar: unmistakable active state + lift off content ── */
@media (max-width: 820px) {
  .tabbar { box-shadow: 0 -1px 0 var(--noir-line), 0 -8px 24px rgba(0,0,0,0.35); }
  .tabbar button { padding-top: 11px; padding-bottom: calc(10px + env(safe-area-inset-bottom) * 0); }
  .tabbar button.active { color: var(--gold-bright); }
  .tabbar button.active span { position: relative; }
  .tabbar button.active::before { content: ""; position: absolute; top: 4px; left: 50%; transform: translateX(-50%); width: 26px; height: 3px; border-radius: 999px; background: var(--gold); }
}

/* ── Concierge: error bubbles + stronger composer affordance ── */
.cc-msg.error { border-left: 3px solid var(--fail); background: color-mix(in oklab, var(--fail) 9%, transparent); color: var(--fail); }
.cc-msg.me { color: var(--gold-bright); }
.cc-bar textarea { border-width: 1.5px; }
.cc-bar textarea:focus { box-shadow: 0 0 0 3px color-mix(in oklab, var(--gold) 14%, transparent); }

/* ── Result actions: stack full-width on phones instead of wrapping awkwardly ── */
@media (max-width: 600px) {
  .result-actions { flex-direction: column; align-items: stretch; gap: 8px; }
  .result-actions .btn, .result-actions .btn-ghost { width: 100%; justify-content: center; }
}

/* ── Build HUD: steadier timer + clearer intent quote + reassurance ── */
.building .belapsed { font-variant-numeric: tabular-nums; }
.building .bintent { color: var(--bone-dim); }
.building .breassure.show { color: var(--gold-matte); }

/* ── OPS COCKPIT — premium operator-dashboard polish ── */
.ops-kpi { border-bottom: 3px solid color-mix(in oklab, var(--gold) 55%, transparent); transition: transform .2s var(--ease), border-color .2s var(--ease); }
.ops-kpi:hover { transform: translateY(-1px); border-bottom-color: var(--gold); }
.ops-kpi .ok-k { letter-spacing: .28em; }
.ops-kpi .ok-v { margin-top: 10px; }
.ops-kpi.pos { border-bottom-color: color-mix(in oklab, var(--ok) 55%, transparent); }
.ops-kpi.neg { border-bottom-color: color-mix(in oklab, var(--fail) 55%, transparent); }
.olr { border-left: 3px solid var(--noir-line); padding-left: 13px; transition: border-color .15s var(--ease); }
.olr:hover { border-left-color: color-mix(in oklab, var(--gold) 40%, transparent); }
/* .olr-delta pos/neg colors are defined once above (champagne neg, matching the user Statement) */
.ops-table thead th { position: sticky; top: 0; z-index: 5; background: color-mix(in oklab, var(--noir) 97%, transparent); backdrop-filter: blur(8px); }
.ops-table tbody tr { border-left: 2px solid transparent; }
.ops-table tbody tr:hover { border-left-color: var(--gold-bright); }
.ops-table td { padding: 13px 16px; }
.ou-st[data-st="ready"], .ou-st[data-st="answered"] { background: color-mix(in oklab, var(--ok) 12%, transparent); }
.ou-st[data-st="failed"] { background: color-mix(in oklab, var(--fail) 12%, transparent); }
.ou-st[data-st="building"] { background: color-mix(in oklab, var(--warn) 12%, transparent); }
.ops-tool { border-top: 2px solid color-mix(in oklab, var(--gold-deep) 70%, transparent); }
.oev-wrap { border-left: 2px solid transparent; padding-left: 4px; transition: border-color .15s var(--ease); }
.oev-error { border-left-color: color-mix(in oklab, var(--fail) 55%, transparent); }
.oev-warn { border-left-color: color-mix(in oklab, var(--warn) 55%, transparent); }
.ev-filters { position: sticky; top: 0; z-index: 4; background: color-mix(in oklab, var(--noir-deep) 90%, transparent); backdrop-filter: blur(8px); padding: 6px 0; }
.ops-recon.bad { animation: reconalert .5s var(--ease) 1; }
@keyframes reconalert { 0%,100% { transform: translateX(0) } 20%,60% { transform: translateX(-4px) } 40%,80% { transform: translateX(4px) } }

/* ── Account dropdown never clips off-screen ── */
.acct-menu { max-width: min(320px, calc(100vw - 20px)); }

/* ── B2: Billing & plan view ── */
.bill-card { padding: 22px; margin-top: 4px; }
.bill-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.bill-tier { margin-top: 8px; display: flex; align-items: center; gap: 8px; }
.bill-tier .plan-chip { font-size: 13px; padding: 5px 12px; }
.bill-credits { text-align: right; }
.bill-rows { margin: 18px 0; border-top: 1px solid var(--noir-line); }
.bill-row { display: flex; justify-content: space-between; padding: 11px 0; border-bottom: 1px solid color-mix(in oklab, var(--noir-line) 55%, transparent); font-size: 14px; }
.bill-row span { color: var(--bone-mute); } .bill-row b { color: var(--bone); }
.bill-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.bill-note { font-size: 12.5px; color: var(--bone-mute); margin: 14px 0 0; }
@media (max-width: 560px) { .bill-actions .btn, .bill-actions .btn-ghost { width: 100%; } }

/* ── B2: post-build guest sign-in nudge ── */
.signin-nudge { display: flex; align-items: center; gap: 14px; margin: 14px 0; padding: 14px 16px; border: 1px solid color-mix(in oklab, var(--gold) 32%, transparent); background: linear-gradient(180deg, color-mix(in oklab, var(--gold-deep) 12%, transparent), transparent); border-radius: var(--rad); }
.signin-nudge .sn-txt { flex: 1; min-width: 0; font-size: 13.5px; color: var(--bone-dim); line-height: 1.5; }
.signin-nudge .sn-txt b { color: var(--bone); }
.signin-nudge .sn-x { flex: 0 0 auto; color: var(--bone-mute); font-size: 14px; padding: 6px 8px; border-radius: 8px; }
.signin-nudge .sn-x:hover { color: var(--bone); background: color-mix(in oklab, var(--noir-haze) 80%, transparent); }
@media (max-width: 560px) { .signin-nudge { flex-wrap: wrap; } .signin-nudge .btn-google.sm { flex: 1; } }

/* ── B4: tier cards, send button, empty states, modal a11y ── */
.plan-card { transition: transform .2s var(--ease), border-color .2s var(--ease), box-shadow .2s var(--ease); }
.plan-card:hover { transform: translateY(-3px); border-color: color-mix(in oklab, var(--gold) 38%, transparent); box-shadow: 0 10px 30px rgba(0,0,0,0.28); }
.plan-card.best { box-shadow: 0 0 0 1px color-mix(in oklab, var(--gold) 30%, transparent), 0 8px 28px color-mix(in oklab, var(--gold-deep) 22%, transparent); }
.plan-card.best:hover { box-shadow: 0 0 0 1px color-mix(in oklab, var(--gold) 45%, transparent), 0 12px 34px color-mix(in oklab, var(--gold-deep) 30%, transparent); }
.plan-flag { font-weight: 700; box-shadow: 0 2px 8px rgba(0,0,0,0.35); }
.plan-card.current { border-color: color-mix(in oklab, var(--gold) 34%, transparent); transform: none; }
.plan-card.current::after { content: "✓ Current"; position: absolute; top: -10px; right: 12px; font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--gold-bright); background: var(--noir); border: 1px solid color-mix(in oklab, var(--gold) 30%, transparent); padding: 3px 8px; border-radius: 999px; }
.plan-card.current:hover { transform: none; box-shadow: none; }
/* Send-button inline spinner stays centered + sized */
.cc-bar .btn .spin { width: 14px; height: 14px; }
/* Empty states: a touch more presence */
.empty { line-height: 1.6; }
.empty .spin { margin-right: 4px; }
/* Account dropdown: comfortable menu rows (tap targets) */
.acct-menu button { min-height: 40px; }

/* ════════════════════════════════════════════════════════
   HOME (landing) + slim Build — IA split (2026-06-19)
   ════════════════════════════════════════════════════════ */
.home { max-width: 1080px; margin: 0 auto; }
.home-hero { text-align: center; padding: clamp(24px, 6vw, 64px) 0 8px; display: flex; flex-direction: column; align-items: center; }
.home-hero .eyebrow { margin-bottom: 18px; }
.home-hero h1 { font-family: var(--fd); font-weight: 400; font-size: clamp(38px, 7vw, 76px); line-height: 1.02; letter-spacing: -0.025em; margin: 0 0 18px; color: var(--bone); }
.home-hero h1 em { font-style: normal; color: var(--gold-bright); text-shadow: 0 2px 22px color-mix(in oklab, var(--gold-deep) 30%, transparent); }
.home-hero .lede { font-size: clamp(16px, 2.2vw, 19px); color: var(--bone-dim); max-width: 600px; margin: 0 auto 28px; line-height: 1.55; }
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
.btn.lg { padding: 16px 30px; font-size: 13px; }
.btn-ghost.lg { padding: 15px 24px; font-size: 12px; }
.hero-mark { margin-top: 40px; }
.hero-mark img { width: 64px; height: auto; opacity: .5; filter: drop-shadow(0 0 26px color-mix(in oklab, var(--gold-deep) 35%, transparent)); }
.home .proof { margin-top: 8px; }
.home-examples { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 6px; }
.ex-chip { text-align: left; background: color-mix(in oklab, var(--noir) 88%, transparent); border: 1px solid var(--noir-line); color: var(--bone-dim); font-size: 13.5px; padding: 12px 16px; border-radius: var(--rad-sm); transition: all 0.2s var(--ease); }
.ex-chip:hover { border-color: color-mix(in oklab, var(--gold) 40%, transparent); color: var(--bone); transform: translateY(-2px); }
.ex-chip::before { content: "→ "; color: var(--gold-matte); }
.home-more { text-align: right; margin-top: 14px; }
.home-more a { color: var(--gold-bright); font-size: 13px; }
.home-cta-final { text-align: center; margin-top: 12px; padding: 40px 0 12px; border-top: 1px solid var(--noir-line); }
.home-cta-final h2 { font-family: var(--fd); font-size: clamp(26px, 4vw, 36px); margin: 0 0 18px; }
/* Build view (slim): centered tool, breathing room, the explore link footer */
.intent.build-only { padding-top: clamp(8px, 3vw, 28px); }
.build-foot-link { text-align: center; margin-top: 26px; }
.build-foot-link a { color: var(--bone-mute); font-size: 13px; }
.build-foot-link a:hover { color: var(--gold-bright); }
@media (max-width: 560px) { .hero-cta .btn.lg, .hero-cta .btn-ghost.lg { width: 100%; } .home-more { text-align: center; } }
.hero-trust { font-size: 12.5px; color: var(--bone-mute); margin: 16px 0 0; letter-spacing: 0.01em; }

/* Home: "why it's different" 3-up */
.home-why .why-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 8px; }
.why-card { background: color-mix(in oklab, var(--noir) 90%, transparent); border: 1px solid var(--noir-line); border-radius: var(--rad); padding: 22px; transition: border-color .2s var(--ease); }
.why-card:hover { border-color: color-mix(in oklab, var(--gold) 30%, transparent); }
.why-i { font-size: 22px; color: var(--gold-bright); }
.why-t { font-family: var(--fd); font-size: 19px; color: var(--bone); margin: 12px 0 6px; }
.why-d { font-size: 14px; color: var(--bone-mute); line-height: 1.6; }
@media (max-width: 720px) { .home-why .why-row { grid-template-columns: 1fr; } }

/* ── Explore / Community page ── */
.community-hero { text-align: center; padding: clamp(18px, 4vw, 40px) 0 18px; }
.community-hero .eyebrow { display: block; margin-bottom: 14px; }
.community-hero h1 { font-family: var(--fd); font-weight: 400; font-size: clamp(34px, 6vw, 60px); line-height: 1.04; letter-spacing: -0.025em; margin: 0 0 14px; }
.community-hero h1 em { font-style: normal; color: var(--gold-bright); }
.community-hero .lede { font-size: clamp(15px, 2vw, 18px); color: var(--bone-dim); max-width: 560px; margin: 0 auto 22px; line-height: 1.55; }
.community-stats { display: flex; justify-content: center; flex-wrap: wrap; gap: 22px; margin-bottom: 22px; font-size: 13px; color: var(--bone-mute); }
.community-stats b { color: var(--gold-bright); font-variant-numeric: tabular-nums; font-size: 16px; margin-right: 4px; }
.community-bar { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin: 8px 0 18px; padding-bottom: 14px; border-bottom: 1px solid var(--noir-line); }
.comm-filters { display: flex; gap: 6px; }
.comm-filters button { font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--bone-dim); padding: 8px 14px; border-radius: 999px; border: 1px solid var(--noir-line); transition: all .15s var(--ease); }
.comm-filters button:hover { color: var(--bone); }
.comm-filters button.on { color: var(--gold-bright); border-color: color-mix(in oklab, var(--gold) 40%, transparent); background: color-mix(in oklab, var(--gold-deep) 14%, transparent); }
.comm-search { flex: 1; min-width: 160px; max-width: 280px; margin-left: auto; background: var(--noir-deep); border: 1px solid var(--noir-line); color: var(--bone); border-radius: 999px; padding: 9px 16px; font: inherit; font-size: 13px; }
.comm-search:focus { outline: none; border-color: color-mix(in oklab, var(--gold) 45%, transparent); }
.community-foot { text-align: center; margin-top: 28px; }
.community-foot a { color: var(--bone-mute); font-size: 12.5px; }
.community-foot a:hover { color: var(--gold-bright); }
/* Card creator credit */
.reality-card .rc-by { color: var(--bone-mute); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.reality-card .rc-open { color: var(--gold-matte); flex: 0 0 auto; }
.reality-card:hover .rc-open { color: var(--gold-bright); }
@media (max-width: 560px) { .comm-search { margin-left: 0; max-width: none; width: 100%; } }

/* ───────── POLISH: skeleton loaders · illustrated empty states · concierge time · build-HUD breath · ops codes ───────── */
@keyframes rs-shimmer { to { background-position: -200% 0; } }
.sk-card { border: 1px solid var(--noir-line); border-radius: var(--rad); padding: 18px; background: color-mix(in oklab, var(--noir) 92%, transparent); display: flex; flex-direction: column; gap: 10px; }
.sk-card.plan { padding: 20px 18px; }
.sk-line { height: 11px; border-radius: 6px; background: linear-gradient(90deg, color-mix(in oklab, var(--gold-deep) 14%, var(--noir-soft)) 25%, color-mix(in oklab, var(--gold-matte) 22%, var(--noir-haze)) 37%, color-mix(in oklab, var(--gold-deep) 14%, var(--noir-soft)) 63%); background-size: 200% 100%; animation: rs-shimmer 1.4s var(--ease) infinite; }
.sk-line.short { width: 60%; } .sk-line.tiny { width: 34%; height: 8px; }
.sk-eyebrow { width: 38%; height: 8px; } .sk-title { width: 72%; height: 18px; margin: 2px 0; }
.sk-price { width: 50%; height: 26px; } .sk-btn { height: 34px; margin-top: 6px; border-radius: var(--rad-sm); }
.sk-foot { display: flex; justify-content: space-between; margin-top: 6px; }
@media (prefers-reduced-motion: reduce) { .sk-line { animation: none; } }

.empty-vn { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 46px 20px; gap: 6px; }
.empty-vn .evn-mark { width: 58px; height: auto; opacity: 0.42; filter: drop-shadow(0 2px 14px color-mix(in oklab, var(--gold-deep) 40%, transparent)); margin-bottom: 8px; animation: evn-float 5s var(--ease) infinite; }
@keyframes evn-float { 0%, 100% { transform: translateY(0); opacity: .42; } 50% { transform: translateY(-5px); opacity: .6; } }
@media (prefers-reduced-motion: reduce) { .empty-vn .evn-mark { animation: none; } }
.empty-vn .evn-h { font-family: var(--fd); font-size: 19px; color: var(--bone); }
.empty-vn .evn-sub { font-size: 13px; color: var(--bone-mute); max-width: 340px; line-height: 1.5; }
.empty-vn .evn-cta { margin-top: 10px; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gold-bright); border: 1px solid color-mix(in oklab, var(--gold) 30%, transparent); padding: 9px 15px; border-radius: var(--rad-sm); transition: border-color .25s var(--ease), color .25s var(--ease); }
.empty-vn .evn-cta:hover { border-color: color-mix(in oklab, var(--gold) 55%, transparent); color: var(--gold-foil); }

.cc-time { display: block; font-size: 9px; letter-spacing: .06em; color: var(--bone-mute); opacity: .7; margin-top: 5px; text-align: right; }
.cc-msg.ai .cc-time { text-align: left; }

.building .ring { box-shadow: 0 0 24px color-mix(in oklab, var(--gold-deep) 30%, transparent); }
.building .bstat.in { animation: bstat-breathe 5s var(--ease) infinite; }
@keyframes bstat-breathe { 0%, 100% { letter-spacing: 0; } 50% { letter-spacing: .012em; } }
@media (prefers-reduced-motion: reduce) { .building .bstat.in { animation: none; } .building .ring { box-shadow: none; } }

.mint-codes { display: flex; flex-wrap: wrap; gap: 6px; }
.mint-acts { display: flex; gap: 8px; margin-top: 10px; }
.ops-code { cursor: pointer; }
.ops-code:hover { color: var(--gold-foil); border-color: color-mix(in oklab, var(--gold) 45%, transparent); }
.ops-codes-h { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; }
.ops-codes-sum { font-size: 11px; color: var(--bone-mute); letter-spacing: .02em; }
.ops-codes { margin-top: 10px; max-height: 320px; overflow: auto; }
.codes-tbl { width: 100%; border-collapse: collapse; font-size: 12px; }
.codes-tbl th { text-align: left; font-weight: 500; font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--bone-mute); padding: 0 8px 8px; border-bottom: 1px solid var(--noir-line); }
.codes-tbl td { padding: 8px; border-bottom: 1px solid color-mix(in oklab, var(--noir-line) 60%, transparent); vertical-align: middle; }
.codes-tbl .ct-note { color: var(--bone-dim); max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cbadge { font-size: 10px; letter-spacing: .04em; text-transform: uppercase; padding: 3px 8px; border-radius: 999px; white-space: nowrap; }
.cbadge.open { color: var(--ok); background: color-mix(in oklab, var(--ok) 16%, transparent); }
.cbadge.used { color: var(--bone-mute); background: color-mix(in oklab, var(--bone-mute) 16%, transparent); }

/* ───────── PRISM — unified composer + route confirm card ───────── */
.prism-thinking { text-align: center; }
.prism-thinking .ring { margin: 30px auto 18px; }
.prism-thinking .bintent { color: var(--bone-mute); font-style: italic; max-width: 540px; margin: 0 auto; }
.prism-confirm h1 { margin-bottom: 18px; }
.pc-card { max-width: 620px; margin: 0 auto; padding: 24px; text-align: left; }
.pc-kind { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.pc-badge { font-size: 12px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; padding: 6px 12px; border-radius: 999px; white-space: nowrap; }
.pc-badge.app { color: var(--noir-deep); background: linear-gradient(180deg, var(--gold-bright), var(--gold)); }
.pc-badge.world { color: var(--gold-foil); background: color-mix(in oklab, var(--gold-deep) 36%, transparent); border: 1px solid color-mix(in oklab, var(--gold) 40%, transparent); }
.pc-cost { font-family: var(--fd); font-size: 18px; color: var(--gold-bright); }
.pc-reason { font-size: 16px; color: var(--bone); line-height: 1.55; margin: 0 0 8px; }
.pc-desc { font-size: 13px; color: var(--bone-mute); line-height: 1.5; margin: 0 0 14px; }
.pc-intent { font-style: italic; color: var(--bone-dim); border-left: 2px solid color-mix(in oklab, var(--gold) 40%, transparent); padding: 4px 0 4px 12px; margin: 0 0 18px; font-size: 14px; }
.pc-actions { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.prism-confirm .pc-card .xs { margin-top: 14px; opacity: .7; }

/* World card — distinguishes a 10-layer world from a one-shot app in the Explore grid */
.world-card { border-color: color-mix(in oklab, var(--gold) 22%, transparent); }
.world-card .arch { color: var(--gold-bright); }

/* World layer version history (the refine undo-trail, surfaced in the layer explorer) */
.lhist { margin-top: 16px; border-top: 1px solid var(--noir-line); padding-top: 12px; }
.lhist-h { font-size: 10px; text-transform: uppercase; letter-spacing: 0.16em; color: var(--bone-mute); margin-bottom: 8px; }
.lhist-row { display: flex; align-items: center; gap: 12px; padding: 7px 0; border-bottom: 1px solid color-mix(in oklab, var(--noir-line) 60%, transparent); font-size: 12px; }
.lhist-row:last-child { border-bottom: none; }
.lhist-v { font-family: var(--fd); color: var(--gold); min-width: 34px; }
.lhist-src { color: var(--bone-dim); flex: 1; }
.lhist-t { color: var(--bone-mute); font-size: 11px; }
.lhist-restore { font-size: 11px; padding: 4px 12px; }

/* PRISM confirm-card confidence chip — shows the router's certainty in app-vs-world */
.pc-conf { font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; padding: 3px 10px; border-radius: 999px; border: 1px solid var(--noir-line); color: var(--bone-mute); white-space: nowrap; }
.pc-conf.hi { color: var(--gold-bright); border-color: color-mix(in oklab, var(--gold) 40%, transparent); }
.pc-conf.mid { color: var(--gold); border-color: color-mix(in oklab, var(--gold) 26%, transparent); }
.pc-conf.lo { color: var(--bone-dim); border-style: dashed; }

/* Home "two scales" band — app vs 10-layer world (PRISM's core value prop) */
.scales-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 6px; }
.scale-card { padding: 22px; border: 1px solid var(--noir-line); border-radius: 14px; background: color-mix(in oklab, var(--noir-soft) 60%, transparent); }
.scale-badge { display: inline-block; font-size: 12px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; padding: 6px 12px; border-radius: 999px; margin-bottom: 12px; }
.scale-badge.app { color: var(--noir-deep); background: linear-gradient(180deg, var(--gold-bright), var(--gold)); }
.scale-badge.world { color: var(--gold-foil); background: color-mix(in oklab, var(--gold-deep) 36%, transparent); border: 1px solid color-mix(in oklab, var(--gold) 40%, transparent); }
.scale-d { font-size: 14px; color: var(--bone-dim); line-height: 1.6; }
.scales-note { margin-top: 16px; font-size: 13px; color: var(--bone-mute); text-align: center; }
@media (max-width: 640px) { .scales-row { grid-template-columns: 1fr; } }

/* Composer archetype chips — optional genre shaping for app builds */
.arch-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin: 14px 0 4px; }
.arch-lbl { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--bone-mute); white-space: nowrap; }
.arch-opt { color: var(--noir-line); letter-spacing: 0.08em; }
.arch-chips { display: flex; flex-wrap: wrap; gap: 7px; }
.arch-chips button { font-size: 12px; padding: 5px 13px; border-radius: 999px; border: 1px solid var(--noir-line); background: transparent; color: var(--bone-dim); cursor: pointer; transition: border-color 0.2s var(--ease), color 0.2s var(--ease); }
.arch-chips button:hover { border-color: color-mix(in oklab, var(--gold) 30%, transparent); color: var(--bone); }
.arch-chips button.on { border-color: var(--gold); color: var(--noir-deep); background: linear-gradient(180deg, var(--gold-bright), var(--gold)); font-weight: 600; }

/* Composer image picker — attach the owner's Vault images to a build */
.img-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin: 4px 0; }
.img-chips { display: flex; flex-wrap: wrap; gap: 7px; }
.img-chips button { font-size: 12px; padding: 5px 13px; border-radius: 999px; border: 1px solid var(--noir-line); background: transparent; color: var(--bone-dim); cursor: pointer; max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; transition: border-color 0.2s var(--ease), color 0.2s var(--ease); }
.img-chips button::before { content: "🖼 "; opacity: .6; }
.img-chips button:hover { border-color: color-mix(in oklab, var(--gold) 30%, transparent); color: var(--bone); }
.img-chips button.on { border-color: var(--gold); color: var(--noir-deep); background: linear-gradient(180deg, var(--gold-bright), var(--gold)); font-weight: 600; }
.img-chips button.on::before { opacity: 1; }

/* Mobile polish for the surfaces added this pass (confirm chip, version history, archetypes) */
@media (max-width: 560px) {
  .pc-kind { flex-wrap: wrap; gap: 8px; justify-content: flex-start; }
  .pc-conf { order: 3; }
  .lhist-row { flex-wrap: wrap; gap: 4px 10px; }
  .lhist-src { flex-basis: 100%; order: 4; }
  .lhist-restore { margin-left: auto; }
  .arch-row { gap: 8px; }
  .scale-card { padding: 18px; }
}
