/* 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: #A89A7D;
  --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%); }

/* ── Reality landing ────────────────────────────────── */
.reality-landing { display: flex; flex-direction: column; gap: 22px; }
.reality-hero { display: grid; gap: 22px; padding: clamp(20px, 4vw, 34px); overflow: hidden; min-height: 560px; }
.reality-hero__copy { max-width: 620px; display: flex; flex-direction: column; justify-content: center; gap: 12px; position: relative; z-index: 2; }
.reality-hero__copy h1 { font-size: clamp(36px, 6vw, 64px); line-height: 0.95; margin: 6px 0 0; }
.reality-hero__copy .lede { max-width: 560px; margin: 0; }
.hero-cta-row { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 8px; }
.hero-metrics { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; margin-top: 8px; }
.hero-metric { padding: 12px 13px; border: 1px solid color-mix(in oklab, var(--gold) 20%, transparent); border-radius: 12px; background: color-mix(in oklab, var(--noir) 78%, transparent); }
.hero-metric b { display: block; font-family: var(--fd); font-size: 18px; color: var(--gold-bright); }
.hero-metric span { display: block; margin-top: 4px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--bone-mute); }
.reality-hero__stage { position: relative; min-height: 280px; border-radius: 18px; overflow: hidden; border: 1px solid color-mix(in oklab, var(--gold) 24%, transparent); background: radial-gradient(circle at top left, color-mix(in oklab, var(--gold-deep) 20%, transparent), transparent 48%), linear-gradient(135deg, color-mix(in oklab, var(--noir-soft) 92%, transparent), color-mix(in oklab, var(--noir) 82%, transparent)); }
.reality-canvas { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
.hero-stage-card { position: absolute; left: 22px; right: 22px; bottom: 22px; padding: 16px 16px 14px; border-radius: 14px; background: color-mix(in oklab, var(--noir-deep) 70%, transparent); backdrop-filter: blur(16px); border: 1px solid color-mix(in oklab, var(--gold) 22%, transparent); box-shadow: 0 20px 60px rgba(0,0,0,0.35); }
.hero-stage-head { display: flex; align-items: center; gap: 8px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.16em; color: var(--gold-bright); }
.hero-stage-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--gold-bright); box-shadow: 0 0 0 5px color-mix(in oklab, var(--gold) 18%, transparent); }
.hero-stage-body { display: grid; gap: 8px; margin-top: 10px; }
.hero-stage-line { display: flex; flex-direction: column; gap: 2px; padding-top: 6px; border-top: 1px solid color-mix(in oklab, var(--gold) 10%, transparent); }
.hero-stage-line span { font-size: 10px; text-transform: uppercase; letter-spacing: 0.16em; color: var(--bone-mute); }
.hero-stage-line b { font-size: 13px; color: var(--bone); line-height: 1.45; }
.reality-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.reality-panel { padding: 18px 18px 20px; }
.reality-panel h2 { font-family: var(--fd); font-size: 22px; line-height: 1.12; margin: 10px 0 8px; color: var(--bone); }
.reality-panel p { margin: 0; font-size: 13px; line-height: 1.6; color: var(--bone-dim); }
.model-cap { font-size: 11.5px; line-height: 1.45; color: var(--bone-dim); margin: 8px 2px 0; min-height: 1.2em; }

/* ══ CINEMATIC PRISM COMPOSER (pcx-v2) — the redesigned renderIntent: a prism-refraction hero over a
   centered stage. ADDITIVE — reuses the existing .intentbox glass/caustic; delete this block to revert. ══ */
.pcx-v2 { position: relative; max-width: 760px; margin: 0 auto; text-align: center; isolation: isolate; }
.pcx-v2 > * { position: relative; z-index: 2; }
.pcx-v2 .pcx-bloom { position: absolute; left: -16%; right: -16%; top: -12%; height: 420px; z-index: 0; pointer-events: none; opacity: .5; mix-blend-mode: screen; filter: blur(8px);
  background:
    radial-gradient(30% 42% at 24% 6%, color-mix(in oklab, var(--spec-1) 20%, transparent), transparent 60%),
    radial-gradient(26% 36% at 78% 14%, color-mix(in oklab, var(--spec-6) 15%, transparent), transparent 62%),
    radial-gradient(36% 44% at 50% -8%, color-mix(in oklab, var(--gold-deep) 44%, transparent), transparent 68%);
  animation: pcx-drift 22s ease-in-out infinite alternate; }
@keyframes pcx-drift { from { transform: translate3d(0,0,0) scale(1); } to { transform: translate3d(1.4%,-2%,0) scale(1.05); } }
.pcx-v2 .pcx-prism { width: 116px; height: 104px; margin: 2px auto 0; display: block; animation: pcx-float 7s ease-in-out infinite; filter: drop-shadow(0 14px 30px rgba(110,85,38,.5)); }
@keyframes pcx-float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-6px); } }
.pcx-v2 .pcx-sweep { animation: pcx-sweep 5.5s linear infinite; }
@keyframes pcx-sweep { from { transform: translateX(-46px); } to { transform: translateX(46px); } }
.pcx-v2 .pcx-hero h1 { margin-top: 10px; }
.pcx-v2 .lede { margin-left: auto; margin-right: auto; }
.pcx-v2 .intentbox { max-width: 640px; margin: 8px auto 0; text-align: left; box-shadow: var(--inner-top), 0 0 0 1px color-mix(in oklab, var(--gold) 16%, transparent), 0 34px 90px -40px color-mix(in oklab, var(--gold-deep) 80%, transparent), 0 0 72px -22px color-mix(in oklab, var(--gold) 32%, transparent); }
.pcx-v2 #goBtn { position: relative; overflow: hidden; }
.pcx-v2 #goBtn::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(105deg, transparent 32%, color-mix(in oklab, #fff 55%, transparent) 48%, transparent 62%); transform: translateX(-130%); animation: pcx-sheen 3.8s ease-in-out infinite; }
@keyframes pcx-sheen { 0%,60% { transform: translateX(-130%); } 86%,100% { transform: translateX(130%); } }
.pcx-v2 .model-cap { text-align: center; margin-left: auto; margin-right: auto; max-width: 520px; }
.pcx-v2 .pcx-tier { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin: 20px 0 0; }
.pcx-v2 .pcx-tier .muse-cta, .pcx-v2 .pcx-tier .studio-cta { width: auto; margin: 0; }
.pcx-v2 .arch-row, .pcx-v2 .seeds { justify-content: center; }
.pcx-v2 .arch-chips, .pcx-v2 .seed-chips { justify-content: center; }
.pcx-v2 .muse-drawer { text-align: left; max-width: 640px; margin: 14px auto 0; }
.pcx-v2 .deploy-note, .pcx-v2 .build-foot-link, .pcx-v2 .low-credit-warn { text-align: center; }
@media (prefers-reduced-motion: reduce) { .pcx-v2 .pcx-prism, .pcx-v2 .pcx-sweep, .pcx-v2 #goBtn::after, .pcx-v2 .pcx-bloom { animation: none !important; } }

/* ══ v3 — THE INTELLIGENCE WORKSPACE (pcx-v3): a living 3D crystal behind ONE calm, floating glass
   composer. Radically minimal — the only thing asking for attention is the user's idea. ══ */
.pcx-v3 { position: relative; min-height: calc(100vh - 188px); display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 40px 20px 64px; isolation: isolate; text-align: center; }
.pcx-v3 .pcx3-crystal { position: absolute; left: 50%; top: 45%; transform: translate(-50%, -50%); width: min(600px, 82vw); height: min(600px, 82vw); z-index: 0; opacity: .52; pointer-events: none; }
.pcx-v3 .pcx3-halo { position: absolute; left: 50%; top: 43%; transform: translate(-50%, -50%); width: min(720px, 92vw); height: min(540px, 74vw); z-index: 0; pointer-events: none; filter: blur(16px); opacity: .8;
  background: radial-gradient(46% 46% at 50% 46%, color-mix(in oklab, var(--gold-deep) 34%, transparent), transparent 70%), radial-gradient(28% 30% at 63% 66%, color-mix(in oklab, var(--spec-7) 12%, transparent), transparent 72%); }
.pcx-v3 .pcx3-stage { position: relative; z-index: 2; width: 100%; max-width: 720px; display: flex; flex-direction: column; align-items: center; }
.pcx-v3 .pcx3-hero { margin-bottom: 32px; }
.pcx-v3 h1 { font-size: clamp(38px, 6vw, 66px); line-height: 1.0; margin: 0; letter-spacing: -0.02em; }
.pcx-v3 .pcx3-sub { margin: 18px auto 0; max-width: 440px; font-size: 15.5px; line-height: 1.6; color: var(--bone-dim); }
.pcx-v3 .pcx3-composer { position: relative; width: 100%; max-width: 680px; border-radius: 22px; padding: 6px 6px 4px; text-align: left;
  background: linear-gradient(180deg, color-mix(in oklab, var(--noir-soft) 80%, transparent), color-mix(in oklab, var(--noir-deep) 88%, transparent));
  backdrop-filter: blur(18px) saturate(1.1); -webkit-backdrop-filter: blur(18px) saturate(1.1);
  border: 1px solid color-mix(in oklab, var(--gold) 22%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in oklab, var(--gold-foil) 20%, transparent), 0 44px 110px -46px rgba(0,0,0,.92), 0 0 90px -34px color-mix(in oklab, var(--gold) 34%, transparent);
  transition: border-color .35s var(--ease), box-shadow .35s var(--ease); }
.pcx-v3 .pcx3-composer::before { content: ""; position: absolute; left: 22px; right: 22px; top: -1px; height: 1.5px; border-radius: 2px; background: var(--edge-spectrum); opacity: .5; pointer-events: none; }
.pcx-v3 .pcx3-composer:focus-within { border-color: color-mix(in oklab, var(--gold) 46%, transparent); box-shadow: inset 0 1px 0 color-mix(in oklab, var(--gold-foil) 26%, transparent), 0 48px 120px -46px rgba(0,0,0,.96), 0 0 110px -28px color-mix(in oklab, var(--gold) 42%, transparent); }
.pcx-v3 .pcx3-editor { width: 100%; min-height: 84px; max-height: 340px; resize: none; overflow-y: auto; background: none; border: none; outline: none; color: var(--bone); font-family: var(--fb); font-size: 18px; line-height: 1.55; padding: 20px 20px 6px; }
.pcx-v3 .pcx3-editor::placeholder { color: #8a7f66; }
.pcx-v3 .pcx3-attach { padding: 0 18px 6px; }
.pcx-v3 .pcx3-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 8px 10px 10px 14px; }
.pcx-v3 .pcx3-tools { display: flex; gap: 6px; }
.pcx-v3 .pcx3-tool { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 11px; border: 1px solid color-mix(in oklab, var(--gold) 14%, transparent); background: rgba(255,255,255,.015); color: var(--bone-mute); cursor: pointer; transition: .18s var(--ease); }
.pcx-v3 .pcx3-tool:hover { color: var(--gold-bright); border-color: color-mix(in oklab, var(--gold) 40%, transparent); background: color-mix(in oklab, var(--gold-deep) 12%, transparent); }
.pcx-v3 .pcx3-compose { position: relative; overflow: hidden; font-family: var(--fb); font-weight: 600; font-size: 15px; letter-spacing: .01em; color: var(--noir-deep); padding: 12px 24px; border-radius: 13px; border: 0; cursor: pointer;
  background: linear-gradient(150deg, var(--gold-foil), var(--gold-bright) 45%, var(--gold)); box-shadow: 0 12px 30px -12px color-mix(in oklab, var(--gold) 72%, transparent), inset 0 1px 0 rgba(255,255,255,.45); }
.pcx-v3 .pcx3-compose span { display: inline-block; transition: transform .25s var(--ease); }
.pcx-v3 .pcx3-compose:hover span { transform: translateX(4px); }
.pcx-v3 .pcx3-compose::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(105deg, transparent 34%, rgba(255,255,255,.5) 48%, transparent 60%); transform: translateX(-130%); animation: pcx-sheen 4.2s ease-in-out infinite; }
.pcx-v3 .pcx3-compose.loading { opacity: .75; pointer-events: none; }
.pcx-v3 .pcx3-examples { margin: 20px 0 0; font-size: 12.5px; color: var(--bone-mute); transition: opacity .24s var(--ease); min-height: 1.2em; }
@media (max-width: 640px) { .pcx-v3 { min-height: calc(100vh - 150px); padding: 22px 14px 40px; } .pcx-v3 .pcx3-crystal { width: 92vw; height: 92vw; opacity: .42; } .pcx-v3 .pcx3-editor { font-size: 16.5px; } }
@media (prefers-reduced-motion: reduce) { .pcx-v3 .pcx3-compose::after { animation: none !important; } }
@media (max-width: 900px) {
  .reality-hero { grid-template-columns: 1fr; min-height: auto; }
  .reality-grid { grid-template-columns: 1fr; }
  .hero-metrics { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
  .hero-metric { padding: 10px 9px; }
}
@media (max-width: 560px) {
  .reality-hero__copy h1 { font-size: 34px; }
  .hero-stage-card { left: 14px; right: 14px; bottom: 14px; }
}

/* ── 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); }
.model-toggle.solo .prism-opt { cursor: default; }
.seeds-h { display: flex; align-items: center; justify-content: center; gap: 10px; margin-bottom: 4px; }
.seeds-refresh { width: 26px; height: 26px; display: grid; place-items: center; border-radius: 8px; border: 1px solid color-mix(in oklab, var(--gold) 22%, transparent); background: transparent; color: var(--bone-mute); cursor: pointer; font-size: 14px; line-height: 1; transition: color .18s var(--ease), border-color .18s var(--ease), transform .3s var(--ease); }
.seeds-refresh:hover { color: var(--gold-bright); border-color: color-mix(in oklab, var(--gold) 45%, transparent); transform: rotate(180deg); }
.seed-chips { transition: opacity .15s var(--ease); }
.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); }

/* ── Explore card thumbnails ── deterministic "mockup flyer" per build (id/title hash → layout +
   spectrum accent), so cards read as distinct real apps at a glance with zero screenshot infra. */
.lib-grid { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }
.reality-card.has-thumb { padding: 0; overflow: hidden; }
.reality-card.has-thumb:hover { transform: translateY(-4px) scale(1.008); box-shadow: 0 22px 48px -24px color-mix(in oklab, var(--gold-deep) 55%, transparent); }
.reality-card.has-thumb .rc-body { padding: 15px 17px 17px; }
.reality-card.has-thumb .idea { height: 40px; }
.rc-thumb { position: relative; aspect-ratio: 16 / 10; overflow: hidden; border-bottom: 1px solid var(--noir-line); }
.rc-chrome { display: flex; align-items: center; gap: 5px; padding: 8px 10px; background: color-mix(in oklab, var(--noir) 88%, transparent); position: relative; z-index: 2; }
.rc-dot { width: 5px; height: 5px; border-radius: 50%; background: color-mix(in oklab, var(--bone) 20%, transparent); }
.rc-url { flex: 1; margin-left: 4px; font-size: 9px; font-weight: 500; letter-spacing: 0.02em; color: var(--bone-mute); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; text-transform: none; }
.rc-canvas { position: absolute; inset: 30px 0 0; padding: 14px 16px; display: flex; flex-direction: column; gap: 9px; }
.rc-hover { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: color-mix(in oklab, var(--noir-void) 55%, transparent); color: var(--gold-bright); font-size: 12px; font-weight: 600; letter-spacing: 0.06em; opacity: 0; transition: opacity 0.22s var(--ease); z-index: 3; }
.reality-card.has-thumb:hover .rc-hover { opacity: 1; }
/* Layout skeletons — abstract UI shapes, not literal screenshots. */
.mk-hero { height: 34%; border-radius: 6px; background: color-mix(in oklab, var(--mk-a) 55%, transparent); }
.mk-bar { display: block; height: 7px; border-radius: 4px; background: color-mix(in oklab, var(--mk-a) 30%, transparent); }
.mk-bar.w80 { width: 80%; } .mk-bar.w70 { width: 70%; } .mk-bar.w60 { width: 60%; } .mk-bar.w55 { width: 55%; }
.mk-btn { width: 64px; height: 16px; border-radius: 999px; background: color-mix(in oklab, var(--mk-a) 65%, transparent); margin-top: 2px; }
.mk-btn.sm { width: 48px; height: 12px; }
.mk-row { display: flex; gap: 8px; }
.mk-tile { flex: 1; height: 24px; border-radius: 5px; background: color-mix(in oklab, var(--mk-a) 22%, transparent); border: 1px solid color-mix(in oklab, var(--mk-a) 35%, transparent); }
.mk-chart { display: flex; align-items: flex-end; gap: 5px; flex: 1; }
.mk-chart i { flex: 1; border-radius: 2px 2px 0 0; background: color-mix(in oklab, var(--mk-a) 40%, transparent); font-style: normal; }
.mk-chart i:nth-child(1){height:40%} .mk-chart i:nth-child(2){height:65%} .mk-chart i:nth-child(3){height:50%} .mk-chart i:nth-child(4){height:85%} .mk-chart i:nth-child(5){height:60%} .mk-chart i:nth-child(6){height:72%}
.mk-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; flex: 1; }
.mk-grid2 span { border-radius: 6px; background: color-mix(in oklab, var(--mk-a) 24%, transparent); border: 1px solid color-mix(in oklab, var(--mk-a) 36%, transparent); }
.mk-lrow { display: flex; align-items: center; gap: 8px; }
.mk-lrow em { width: 20px; height: 20px; border-radius: 5px; background: color-mix(in oklab, var(--mk-a) 50%, transparent); flex: 0 0 auto; font-style: normal; }
.mk-lrow b { flex: 1; height: 7px; border-radius: 4px; background: color-mix(in oklab, var(--mk-a) 26%, transparent); font-weight: 400; }
.mk-form { align-items: center; display: flex; flex-direction: column; gap: 8px; padding-top: 4px; }
.mk-field { width: 74%; height: 12px; border-radius: 4px; border: 1px solid color-mix(in oklab, var(--mk-a) 40%, transparent); background: color-mix(in oklab, var(--mk-a) 10%, transparent); }
.mk-field.w60 { width: 60%; }
.mk-bub { display: block; height: 12px; border-radius: 999px; background: color-mix(in oklab, var(--mk-a) 32%, transparent); }
.mk-bub.l { align-self: flex-start; } .mk-bub.r { align-self: flex-end; background: color-mix(in oklab, var(--mk-a) 55%, transparent); }
.mk-bub.w45 { width: 45%; } .mk-bub.w60 { width: 60%; } .mk-bub.w70 { width: 70%; }
.rc-canvas .mk-chat { flex-direction: column; display: flex; gap: 8px; flex: 1; padding: 0; }
.mock-c1 { --mk-a: var(--spec-1); } .mock-c2 { --mk-a: var(--spec-2); } .mock-c3 { --mk-a: var(--spec-3); }
.mock-c4 { --mk-a: var(--spec-4); } .mock-c5 { --mk-a: var(--spec-5); } .mock-c6 { --mk-a: var(--spec-6); } .mock-c7 { --mk-a: var(--spec-7); }
.rc-thumb::before { content: ""; position: absolute; inset: 0; background: radial-gradient(120% 90% at 15% 0%, color-mix(in oklab, var(--mk-a) 16%, transparent), transparent 65%), var(--noir-soft); }
/* Explore's richer thumbnail cards need full width on phones (2-up crushes the mock canvas + title).
   Scoped to #commGrid (id + class beats the plain .lib-grid mobile rule) so Library's plain text
   cards keep their existing 2-up mobile layout untouched. */
@media (max-width: 560px) { #commGrid .lib-grid { grid-template-columns: 1fr; gap: 14px; } }
.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 { width: min(840px, 96vw); max-width: 840px; } /* actually wide — the base rule pins width:440px, which crammed the plan cards */
.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; }
.runway-out { margin-top: 12px; font-size: 13px; line-height: 1.55; color: var(--bone-dim); }
.runway-out b { color: var(--gold-bright); font-weight: 600; }
#apiBalance { flex: 1; min-width: 0; }
#apiCpc { width: 108px; flex: none; }
.cost-tbl td:nth-child(n+2), .cost-tbl th:nth-child(n+2) { text-align: right; font-variant-numeric: tabular-nums; }
.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; flex: 1; }
.reality-card .rc-views { color: var(--bone-mute); flex: 0 0 auto; margin: 0 8px; opacity: .8; }
.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; }
}

/* ── WORKSPACE — paid live-editor environment (preview ∥ refine/versions/source) ── */
.ws-open { border-color: color-mix(in oklab, var(--gold) 40%, transparent) !important; color: var(--gold-bright) !important; }
.ws-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 16px; flex-wrap: wrap; margin-bottom: 16px; }
.ws-head-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.ws-status { font-family: "IBM Plex Mono", ui-monospace, monospace; font-size: 11px; color: var(--bone-mute); }
.ws-body { display: grid; grid-template-columns: minmax(0, 1fr) 380px; gap: 16px; align-items: start; }
.ws-preview { padding: 0; overflow: hidden; }
.ws-preview .bf-chrome { display: flex; align-items: center; gap: 7px; padding: 9px 12px; border-bottom: 1px solid var(--noir-line); }
.ws-devs { margin-left: auto; display: flex; gap: 4px; }
.ws-devs button { background: transparent; border: 1px solid var(--noir-line); border-radius: 6px; color: var(--bone-mute); width: 26px; height: 22px; cursor: pointer; font-size: 12px; line-height: 1; }
.ws-devs button.on { border-color: var(--gold); color: var(--gold-bright); }
.ws-stage { background: #fff; }
.ws-stage iframe.app-frame { width: 100%; height: 620px; border: 0; display: block; background: #fff; }
.ws-stage.mobile { display: flex; justify-content: center; background: var(--noir-void); padding: 16px 0; }
.ws-stage.mobile iframe.app-frame { width: 390px; max-width: 100%; height: 588px; border: 1px solid var(--noir-line); border-radius: 12px; }
.ws-panel { display: flex; flex-direction: column; padding: 0; overflow: hidden; max-height: 660px; }
.ws-tabs { display: flex; border-bottom: 1px solid var(--noir-line); flex-shrink: 0; }
.ws-tabs button { flex: 1; padding: 12px 8px; background: transparent; border: 0; border-bottom: 2px solid transparent; color: var(--bone-mute); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; cursor: pointer; transition: color 0.2s var(--ease), border-color 0.2s var(--ease); }
.ws-tabs button:hover { color: var(--bone-dim); }
.ws-tabs button.on { color: var(--gold-bright); border-bottom-color: var(--gold); }
.ws-tabpane { padding: 14px; overflow: auto; min-height: 0; }
.ws-quick { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.ws-chip { font-size: 11px; padding: 5px 11px; 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); }
.ws-chip:hover { border-color: color-mix(in oklab, var(--gold) 32%, transparent); color: var(--bone); }
.ws-cc { padding: 0; border: 0; background: transparent; }
.ws-cc .cc-log { max-height: 360px; min-height: 180px; overflow: auto; }
.ws-src-actions { display: flex; gap: 8px; margin-bottom: 10px; }
.ws-src { font-family: "IBM Plex Mono", ui-monospace, monospace; font-size: 11px; line-height: 1.5; color: var(--bone-dim); white-space: pre-wrap; word-break: break-word; max-height: 520px; overflow: auto; background: var(--noir-void); padding: 12px; border-radius: 8px; border: 1px solid var(--noir-line); margin: 0; }
@media (max-width: 900px) {
  .ws-body { grid-template-columns: 1fr; }
  .ws-panel { max-height: none; }
  .ws-stage iframe.app-frame { height: 460px; }
}

/* Global site footer (home) + point-of-sale disclosure (paywall) */
.site-foot { margin-top: 56px; padding-top: 28px; border-top: 1px solid var(--noir-line); text-align: center; }
.site-foot .sf-tag { font-size: 13px; color: var(--bone-mute); letter-spacing: 0.04em; }
.site-foot .sf-links { display: flex; flex-wrap: wrap; gap: 18px; justify-content: center; margin: 16px 0 10px; }
.site-foot .sf-links a { color: var(--bone-mute); text-decoration: none; font-size: 13px; transition: color 0.2s var(--ease); }
.site-foot .sf-links a:hover { color: var(--gold-bright); }
.site-foot .sf-copy { font-size: 12px; color: color-mix(in oklab, var(--bone-mute) 75%, transparent); }
.pw-fine { font-size: 11px; line-height: 1.6; color: var(--bone-mute); margin: 12px 0 0; text-align: center; }
.pw-fine a { color: var(--bone-dim); }
.pw-fine a:hover { color: var(--gold-bright); }
.price-guarantee { text-align: center; font-size: 13px; color: var(--bone-mute); margin: 20px 0 0; }
.low-credit-warn { margin-top: 12px; padding: 10px 14px; border-radius: 10px; border: 1px solid color-mix(in oklab, var(--gold) 30%, transparent); background: color-mix(in oklab, var(--gold-deep) 12%, transparent); color: var(--bone-dim); font-size: 13px; }
.low-credit-warn a { color: var(--gold-bright); text-decoration: none; }
.low-credit-warn a:hover { text-decoration: underline; }
.world-build-note { margin: -4px 0 16px; font-size: 13px; color: var(--bone-mute); line-height: 1.5; max-width: 640px; }
.world-build-note b { color: var(--gold-bright); }

/* ── Per-build Vault drive (Workspace · Assets tab) ── */
.ws-assets-note { font-size: 12.5px; color: var(--bone-mute); line-height: 1.55; margin: 2px 0 12px; }
.ws-assets-note b { color: var(--bone-dim); }
.ws-assets-acts { display: flex; gap: 8px; margin-bottom: 12px; }
.ba-up { cursor: pointer; }

/* ── Modal (asset picker · admin build editor) ── */
.modal-ov { position: fixed; inset: 0; background: rgba(8,7,5,.72); backdrop-filter: blur(3px); z-index: 1000; display: grid; place-items: center; padding: 20px; }
.modal-card { width: min(640px, 96vw); max-height: 88vh; display: flex; flex-direction: column; padding: 18px; }
.modal-card.wide { width: min(960px, 96vw); }
.modal-h { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.modal-h b { font-size: 15px; flex: 1; }
.modal-x { background: none; border: none; color: var(--bone-mute); cursor: pointer; font-size: 16px; padding: 2px 6px; }
.modal-x:hover { color: var(--bone); }
.modal-foot { display: flex; align-items: center; gap: 10px; margin-top: 14px; }
.picker-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 8px; overflow: auto; padding: 2px; }
.picker-item { display: flex; flex-direction: column; align-items: flex-start; gap: 2px; text-align: left; background: var(--noir-deep); border: 1px solid var(--noir-line); border-radius: var(--rad-sm); padding: 10px; cursor: pointer; color: var(--bone-dim); }
.picker-item:hover { border-color: color-mix(in oklab, var(--gold) 40%, transparent); }
.picker-item.on { border-color: var(--gold); background: color-mix(in oklab, var(--gold) 12%, var(--noir-deep)); }
.pi-glyph { font-size: 20px; }
.pi-name { font-size: 12px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 100%; }
.pi-size { font-size: 10px; color: var(--bone-mute); }
.admin-html { width: 100%; flex: 1; min-height: 50vh; background: var(--noir-void); border: 1px solid var(--noir-line); color: var(--bone-dim); border-radius: var(--rad-sm); padding: 12px; font-family: ui-monospace, monospace; font-size: 12px; line-height: 1.5; resize: vertical; }

/* ── God-Admin controls (Ops · user drilldown) ── */
.admin-ctl { margin-top: 14px; padding: 16px; }
.admin-ctl .eyebrow { margin-bottom: 12px; display: block; }
.ac-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 14px; }
.ac-cell label { display: block; font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--bone-mute); margin-bottom: 6px; }
.ac-inline { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.ac-inline input, .ac-inline select { background: var(--noir-deep); border: 1px solid var(--noir-line); color: var(--bone); border-radius: var(--rad-sm); padding: 7px 9px; font: inherit; font-size: 13px; }
.ac-inline input[type=number] { width: 78px; }
.ac-inline input:focus, .ac-inline select:focus { outline: none; border-color: color-mix(in oklab, var(--gold) 45%, transparent); }
.ou-acts { display: flex; gap: 4px; align-items: center; flex-shrink: 0; }
.ou-mini { background: var(--noir-deep); border: 1px solid var(--noir-line); color: var(--bone-mute); border-radius: 6px; padding: 3px 8px; font-size: 11px; cursor: pointer; text-decoration: none; }
.ou-mini:hover { color: var(--bone); border-color: color-mix(in oklab, var(--gold) 35%, transparent); }
.ou-mini.danger:hover { color: var(--fail, #d8704f); border-color: color-mix(in oklab, var(--fail, #d8704f) 45%, transparent); }
.susp-badge { display: inline-block; font-size: 9px; letter-spacing: .12em; background: color-mix(in oklab, var(--fail, #d8704f) 24%, transparent); color: color-mix(in oklab, var(--fail, #d8704f) 70%, var(--bone)); border: 1px solid color-mix(in oklab, var(--fail, #d8704f) 45%, transparent); border-radius: 4px; padding: 1px 5px; vertical-align: middle; }
.susp-badge.sm { font-size: 8px; padding: 0 4px; }
.profile-top.suspended { border-color: color-mix(in oklab, var(--fail, #d8704f) 45%, var(--noir-line)); }
tr.row-susp { opacity: .62; }
.ops-search { background: var(--noir-deep); border: 1px solid var(--noir-line); color: var(--bone); border-radius: var(--rad-sm); padding: 7px 11px; font: inherit; font-size: 13px; min-width: 240px; }
.ops-search:focus { outline: none; border-color: color-mix(in oklab, var(--gold) 45%, transparent); }

/* ── Impersonation banner ── */
.imp-banner { position: fixed; left: 0; right: 0; bottom: 0; z-index: 1100; background: linear-gradient(90deg, color-mix(in oklab, var(--gold-deep) 60%, var(--noir)), var(--noir)); border-top: 1px solid var(--gold-matte); color: var(--bone); display: flex; align-items: center; justify-content: center; gap: 14px; padding: 9px 16px; font-size: 13px; }
.imp-banner b { color: var(--gold-bright); }
.imp-banner button { background: var(--noir-deep); border: 1px solid var(--gold-matte); color: var(--gold-bright); border-radius: var(--rad-sm); padding: 5px 12px; font: inherit; font-size: 12px; cursor: pointer; }
.imp-banner button:hover { background: var(--noir); }

/* ════════════════════════════════════════════════════════════════
   SSS+ MOTION & POLISH — a cohesive motion layer over the existing ethos.
   Transform/opacity only (GPU-friendly); all guarded by prefers-reduced-motion at the end.
   ════════════════════════════════════════════════════════════════ */
:root { --ease-spring: cubic-bezier(.34, 1.4, .64, 1); --ease-soft: cubic-bezier(.4, 0, .2, 1); --dur-1: .18s; --dur-2: .34s; --dur-3: .6s; }

/* View entrance — every surface re-render fades up softly (driven by the #surface observer). */
@keyframes srf-in { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
.srf-enter { animation: srf-in .46s var(--ease-soft) both; }

/* Buttons — press feedback + a champagne sheen sweep on the primary. */
.btn { position: relative; overflow: hidden; }
.btn::after { content: ""; position: absolute; inset: 0; background: linear-gradient(110deg, transparent 30%, color-mix(in oklab, var(--gold-foil) 55%, transparent) 50%, transparent 70%); transform: translateX(-120%); transition: transform .6s var(--ease-soft); pointer-events: none; }
.btn:hover::after { transform: translateX(120%); }
.btn:active { transform: translateY(0) scale(.985); }
.btn-ghost:active { transform: scale(.985); }
/* PERF — no permanent will-change (it pins a GPU layer per button for the whole session); the hover/active
   transform composites on-demand just fine. */

/* Cards & panels — a gentle hover lift + warm border glow. */
.panel.hud, .reality-card, .scale-card, .asset-card, .picker-item, .ws-chip, .muse-spark { transition: transform var(--dur-2) var(--ease), border-color var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease); }
.reality-card:hover, .scale-card:hover { transform: translateY(-3px); border-color: color-mix(in oklab, var(--gold) 38%, transparent); box-shadow: 0 14px 40px -22px color-mix(in oklab, var(--gold-deep) 70%, transparent); }
.asset-card:hover, .picker-item:hover { transform: translateY(-2px); }

/* Inputs — focus bloom. */
.intentbox:focus-within { box-shadow: 0 0 0 4px color-mix(in oklab, var(--gold) 10%, transparent), 0 18px 50px -30px color-mix(in oklab, var(--gold-deep) 80%, transparent); }
.ops-search:focus, .ac-inline input:focus, .ac-inline select:focus, .muse-in:focus { box-shadow: 0 0 0 3px color-mix(in oklab, var(--gold) 12%, transparent); }

/* Concierge + MUSE message entrance. */
@keyframes msg-in { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.cc-msg, .muse-msg { animation: msg-in .3s var(--ease-soft) both; }

/* Workspace tab panes cross-fade in. */
@keyframes pane-in { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }
.ws-tabpane:not([hidden]) { animation: pane-in var(--dur-2) var(--ease-soft) both; }
.ws-tabs button { position: relative; }
.ws-tabs button.on::after { content: ""; position: absolute; left: 12px; right: 12px; bottom: -1px; height: 2px; background: linear-gradient(90deg, transparent, var(--gold), transparent); animation: pane-in var(--dur-2) var(--ease-soft) both; }

/* Builder luxury — the synthesis moment. Ring + breathing aura + a slow orbiting glint. */
.bsynth { position: relative; width: 96px; height: 96px; margin: 0 auto 26px; display: grid; place-items: center; }
.bsynth .ring { margin: 0; position: relative; z-index: 2; }
.baura { position: absolute; inset: -8px; border-radius: 50%; background: radial-gradient(circle, color-mix(in oklab, var(--gold) 30%, transparent), transparent 68%); filter: blur(8px); animation: baura-breathe 3.4s var(--ease) infinite; z-index: 1; }
@keyframes baura-breathe { 0%, 100% { opacity: .45; transform: scale(.94); } 50% { opacity: .9; transform: scale(1.06); } }
.borbit { position: absolute; inset: 0; z-index: 3; animation: rot 3.2s linear infinite; }
.borbit::before { content: ""; position: absolute; top: -3px; left: 50%; width: 7px; height: 7px; margin-left: -3.5px; border-radius: 50%; background: var(--gold-foil); box-shadow: 0 0 12px 2px color-mix(in oklab, var(--gold-bright) 80%, transparent); }
.building { position: relative; }
.building::before { content: ""; position: absolute; inset: -10% 0 auto; height: 220px; background: radial-gradient(60% 100% at 50% 0%, color-mix(in oklab, var(--gold-deep) 14%, transparent), transparent 70%); pointer-events: none; z-index: 0; animation: bdrift 9s var(--ease) infinite; }
@keyframes bdrift { 0%, 100% { opacity: .6; } 50% { opacity: 1; } }
.building > * { position: relative; z-index: 1; }

/* ── MUSE — the brainstorm partner widget ── */
.muse-row { margin-top: 12px; text-align: left; }
.muse-cta { font-size: 13px; color: var(--bone-mute); border: 1px dashed color-mix(in oklab, var(--gold) 26%, transparent); background: color-mix(in oklab, var(--gold-deep) 7%, transparent); padding: 9px 14px; border-radius: var(--rad-sm); cursor: pointer; transition: all var(--dur-2) var(--ease); width: 100%; }
.muse-cta b { color: var(--gold-bright); font-weight: 600; }
.muse-cta:hover, .muse-cta.on { color: var(--bone); border-color: color-mix(in oklab, var(--gold) 50%, transparent); background: color-mix(in oklab, var(--gold-deep) 14%, transparent); }
.muse-drawer { margin-top: 12px; padding: 14px; text-align: left; animation: pane-in var(--dur-2) var(--ease-soft) both; }
.muse-dh { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.muse-x { color: var(--bone-mute); font-size: 14px; padding: 2px 6px; cursor: pointer; }
.muse-x:hover { color: var(--bone); }
.muse-log { display: flex; flex-direction: column; gap: 9px; max-height: 320px; min-height: 120px; overflow: auto; padding-right: 4px; }
.muse-msg { max-width: 90%; padding: 9px 12px; border-radius: 13px; font-size: 13.5px; line-height: 1.5; white-space: pre-wrap; word-wrap: break-word; }
.muse-msg.ai { align-self: flex-start; background: color-mix(in oklab, var(--gold-deep) 16%, var(--noir)); border: 1px solid color-mix(in oklab, var(--gold) 22%, transparent); color: var(--bone-dim); border-bottom-left-radius: 4px; }
.muse-msg.me { align-self: flex-end; background: color-mix(in oklab, var(--noir-haze) 80%, transparent); border: 1px solid var(--noir-line); color: var(--bone); border-bottom-right-radius: 4px; }
.muse-msg.pending { color: var(--bone-mute); font-style: italic; }
.muse-sparks { display: flex; flex-wrap: wrap; gap: 7px; margin: 10px 0 0; }
.muse-spark { font-size: 12px; color: var(--gold-bright); border: 1px solid color-mix(in oklab, var(--gold) 34%, transparent); background: color-mix(in oklab, var(--gold-deep) 10%, transparent); padding: 6px 11px; border-radius: 999px; cursor: pointer; }
.muse-spark:hover { background: color-mix(in oklab, var(--gold-deep) 24%, transparent); border-color: var(--gold); transform: translateY(-1px); }
.muse-bar { display: flex; gap: 8px; align-items: flex-end; margin-top: 12px; }
.muse-in { flex: 1; resize: none; 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; line-height: 1.45; max-height: 120px; transition: border-color var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease); }
.muse-in:focus { outline: none; border-color: color-mix(in oklab, var(--gold) 45%, transparent); }
.muse-send { flex-shrink: 0; }
.muse-hint { font-size: 11px; color: var(--bone-mute); margin-top: 8px; }
/* MUSE in the build-wait screen (collapsible). */
.muse-wait { margin: 26px auto 0; max-width: 560px; text-align: left; border: 1px solid var(--noir-line); border-radius: var(--rad); background: color-mix(in oklab, var(--noir) 80%, transparent); overflow: hidden; }
.muse-wait > summary { list-style: none; cursor: pointer; padding: 13px 16px; font-size: 13px; color: var(--bone-dim); display: flex; align-items: center; gap: 8px; }
.muse-wait > summary::-webkit-details-marker { display: none; }
.muse-wait > summary b { color: var(--gold-bright); }
.muse-wait .mw-spark { color: var(--gold-bright); }
.muse-wait[open] > summary { border-bottom: 1px solid var(--noir-line); }
.muse-mount { padding: 14px 16px; }
/* MUSE workspace tab pane fills the panel nicely. */
#wsMuse .muse-log { max-height: 300px; }

@media (max-width: 640px) { .muse-msg { max-width: 94%; } .muse-log { max-height: 260px; } }

/* ── The PRISM model option — the flagship engine, set apart ── */
.model-toggle .prism-opt { color: var(--gold-bright); border-color: color-mix(in oklab, var(--gold) 38%, transparent); }
.model-toggle .prism-opt.on { color: var(--noir); background: linear-gradient(180deg, var(--gold-foil), var(--gold)); border-color: var(--gold); font-weight: 600; box-shadow: 0 6px 20px -10px color-mix(in oklab, var(--gold) 80%, transparent); }

/* ── PRISM REFRACTION SCENE — one beam of light → a champagne spectrum (the build animation) ──
   The prism forms once; light keeps streaming in and refracting out: one idea, unlimited possibilities. */
.building-prism .prism-scene { width: min(360px, 84vw); margin: 0 auto 22px; }
.prism-svg { width: 100%; height: auto; overflow: visible; filter: drop-shadow(0 0 26px color-mix(in oklab, var(--gold-deep) 36%, transparent)); }
.p-tri { fill: color-mix(in oklab, var(--gold-foil) 9%, transparent); stroke: var(--gold-bright); stroke-width: 1.6; stroke-linejoin: round; transform-origin: 180px 117px; animation: p-form 1s var(--ease-spring) both; filter: drop-shadow(0 0 8px color-mix(in oklab, var(--gold) 55%, transparent)); }
@keyframes p-form { 0% { opacity: 0; transform: scale(.4) rotate(-12deg); } 100% { opacity: 1; transform: none; } }
.p-in { stroke: var(--bone); stroke-width: 2.4; stroke-linecap: round; stroke-dasharray: 16 12; filter: drop-shadow(0 0 6px color-mix(in oklab, var(--bone) 70%, transparent)); animation: p-streamin 1.1s linear infinite; }
@keyframes p-streamin { to { stroke-dashoffset: -28; } }
.p-ray { stroke-width: 2.2; stroke-linecap: round; stroke-dasharray: 5 15; opacity: 0; transform-origin: 208px 118px; animation: p-fanin .7s var(--ease-soft) forwards, p-stream 1.5s linear infinite; }
.p-fan .r1 { stroke: #F4D9A0; animation-delay: .9s, .9s; }
.p-fan .r2 { stroke: #E7C887; animation-delay: 1.0s, 1.0s; }
.p-fan .r3 { stroke: #C9A24B; animation-delay: 1.1s, 1.1s; }
.p-fan .r4 { stroke: #D98E5A; animation-delay: 1.2s, 1.2s; }
.p-fan .r5 { stroke: #A9863B; animation-delay: 1.3s, 1.3s; }
.p-fan .r6 { stroke: #6E5526; animation-delay: 1.4s, 1.4s; }
@keyframes p-fanin { from { opacity: 0; } to { opacity: .92; } }
@keyframes p-stream { to { stroke-dashoffset: -40; } }
.building-prism h2 { background: linear-gradient(90deg, var(--gold-foil), var(--gold-bright), var(--gold-foil)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }

/* ── Reduced motion — disable the new motion layer for users who ask. ── */
@media (prefers-reduced-motion: reduce) {
  .srf-enter, .cc-msg, .muse-msg, .ws-tabpane:not([hidden]), .ws-tabs button.on::after, .muse-drawer { animation: none; }
  .btn::after { display: none; }
  .baura, .borbit, .building::before { animation: none; }
  .reality-card:hover, .scale-card:hover, .asset-card:hover, .picker-item:hover, .muse-spark:hover, .btn:active, .btn-ghost:active { transform: none; }
  .p-tri { animation: none; opacity: 1; }
  .p-in { animation: none; stroke-dasharray: none; }
  .p-ray { animation: none; opacity: .9; stroke-dasharray: none; }
}

/* P3 — build-quality grade KPIs (Ops) */
.grade-kpis { display: flex; flex-wrap: wrap; gap: 14px; margin: 10px 0 12px; font-size: 12px; color: var(--bone-mute); }
.grade-kpis .gk b { color: var(--bone); font-size: 15px; }

/* Idea-node queue (MUSE → build) */
.node-badge { display: inline-block; font-size: 10px; letter-spacing: .04em; background: color-mix(in oklab, var(--gold-deep) 28%, transparent); color: var(--gold-bright); border: 1px solid color-mix(in oklab, var(--gold) 40%, transparent); border-radius: 999px; padding: 1px 8px; margin-left: 6px; }
.node-queue { padding: 14px 16px; margin-bottom: 16px; border-color: color-mix(in oklab, var(--gold) 30%, transparent); }
.nq-head { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; margin-bottom: 10px; }
.nq-hint { font-size: 12px; color: var(--bone-mute); }
.nq-list { display: flex; flex-direction: column; gap: 7px; margin-bottom: 12px; }
.nq-item { display: flex; align-items: flex-start; gap: 10px; font-size: 13.5px; color: var(--bone-dim); line-height: 1.45; }
.nq-item > span { flex: 1; }
.nq-item::before { content: "✦"; color: var(--gold); flex-shrink: 0; }
.nq-x { color: var(--bone-mute); font-size: 12px; padding: 0 4px; cursor: pointer; }
.nq-x:hover { color: var(--fail); }
.nq-acts { display: flex; }

/* ════════════════════════════════════════════════════════════════════
   PRISM GLASS HUD — year-2300 reskin (design-panel spec). Champagne-gold
   stays dominant; the warm spectrum is the precise accent at edges / focus /
   signature moments only — never a fill, never a rainbow. Appended = overrides
   the base rules in source order, fully reversible (delete this block to revert).
   All light FREEZES (not disabled) under prefers-reduced-motion at the end.
   ════════════════════════════════════════════════════════════════════ */
:root {
  /* Pantone-prism: a full visible spectrum (warm coral → gold → jade → cyan → azure → violet), jewel-toned for luxe-on-noir, gold kept as the warm anchor. */
  --spec-1:#EE8C72; --spec-2:#EFA653; --spec-3:#F4D9A0; --spec-4:#84C58C; --spec-5:#62C3D4; --spec-6:#7AA6E6; --spec-7:#B98BE4;
  --edge-spectrum: linear-gradient(115deg, var(--spec-1) 0%, var(--spec-2) 17%, var(--spec-3) 34%, var(--spec-4) 52%, var(--spec-5) 68%, var(--spec-6) 84%, var(--spec-7) 100%);
  --prism-full: linear-gradient(90deg, var(--spec-1), var(--spec-2), var(--spec-3), var(--spec-4), var(--spec-5), var(--spec-6), var(--spec-7));
  --glass-1: color-mix(in oklab, var(--noir) 66%, transparent);
  --glass-2: color-mix(in oklab, var(--noir-soft) 60%, transparent);
  --glass-line: color-mix(in oklab, var(--gold) 18%, transparent);
  --glass-line-bright: color-mix(in oklab, var(--gold) 36%, transparent);
  --inner-top: inset 0 1px 0 color-mix(in oklab, var(--gold-foil) 40%, transparent), inset 0 18px 34px -24px color-mix(in oklab, var(--gold-foil) 18%, transparent);
  --depth-1: 0 22px 60px -34px color-mix(in oklab, var(--gold-deep) 50%, transparent);
  --glow-spectral: 0 0 0 1px color-mix(in oklab, var(--spec-2) 36%, transparent), 0 0 26px -8px color-mix(in oklab, var(--spec-4) 32%, transparent);
  --blur-chrome: 14px; --blur-panel: 10px; --blur-soft: 6px;
  --t-caustic: 48s; --t-shimmer: 7s;
  --prism-conic: conic-gradient(from 200deg, var(--spec-1), var(--spec-2), var(--spec-3), var(--spec-4), var(--spec-5), var(--spec-6), var(--spec-7), var(--spec-1));
}

/* ── The prism field: three planes of light, no scroll-blur ── */
.bg-atmosphere::before {
  background:
    radial-gradient(60% 48% at 50% 0%, color-mix(in oklab, var(--gold-deep) 20%, transparent), transparent 70%),
    radial-gradient(42% 42% at 85% 96%, color-mix(in oklab, var(--noir) 82%, transparent), transparent 72%),
    radial-gradient(40% 36% at 12% 90%, color-mix(in oklab, var(--gold-deep) 10%, transparent), transparent 72%);
}
.bg-atmosphere::after {
  content: ""; position: fixed; inset: -12%; z-index: 0; pointer-events: none;
  background:
    radial-gradient(28% 26% at 12% 20%, color-mix(in oklab, var(--spec-1) 22%, transparent), transparent 64%),
    radial-gradient(26% 24% at 30% 30%, color-mix(in oklab, var(--spec-2) 20%, transparent), transparent 64%),
    radial-gradient(30% 26% at 86% 24%, color-mix(in oklab, var(--spec-6) 10%, transparent), transparent 66%),
    radial-gradient(26% 24% at 70% 16%, color-mix(in oklab, var(--spec-7) 8%, transparent), transparent 66%),
    radial-gradient(40% 34% at 74% 84%, color-mix(in oklab, var(--spec-5) 9%, transparent), transparent 70%),
    radial-gradient(34% 30% at 24% 82%, color-mix(in oklab, var(--spec-4) 10%, transparent), transparent 70%),
    radial-gradient(50% 32% at 50% 46%, color-mix(in oklab, var(--spec-3) 13%, transparent), transparent 72%),
    linear-gradient(116deg, transparent 30%, color-mix(in oklab, var(--spec-1) 11%, transparent) 38%, color-mix(in oklab, var(--spec-2) 11%, transparent) 44%, color-mix(in oklab, var(--spec-3) 11%, transparent) 50%, color-mix(in oklab, var(--spec-4) 7%, transparent) 56%, color-mix(in oklab, var(--spec-5) 6%, transparent) 62%, color-mix(in oklab, var(--spec-6) 6%, transparent) 68%, transparent 76%);
  mix-blend-mode: screen; opacity: .5; will-change: transform;
  animation: prism-caustic var(--t-caustic) ease-in-out infinite alternate;
}
@keyframes prism-caustic { 0% { transform: translate3d(0,0,0) scale(1); } 100% { transform: translate3d(1.5%,-2.5%,0) scale(1.06); } }

/* ── HUD topbar: glass bar + spectral tick-ruler underline + spectral brand letter ── */
.topbar { background: linear-gradient(180deg, color-mix(in oklab, var(--noir-deep) 80%, transparent), color-mix(in oklab, var(--noir-deep) 62%, transparent)); border-bottom-color: var(--glass-line); backdrop-filter: blur(var(--blur-chrome)) saturate(1.1); -webkit-backdrop-filter: blur(var(--blur-chrome)) saturate(1.1); }
.topbar::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 1.5px; background: var(--prism-full); opacity: .6; pointer-events: none; }
.brand .mk b { background: var(--prism-full); background-size: 220% 100%; -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; animation: spec-pan var(--t-shimmer) linear infinite; }
@keyframes spec-pan { 0% { background-position: 0% 0; } 100% { background-position: 220% 0; } }
/* Hero emphasis word carries the full Pantone prism (the signature dispersion). */
.intent h1 em, .home-hero h1 em { background: var(--prism-full); background-size: 200% 100%; -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; font-style: italic; animation: spec-pan calc(var(--t-shimmer) * 1.6) linear infinite; }

/* ── Glass slab panels (with a no-backdrop-filter solid fallback) ── */
.panel { background: linear-gradient(180deg, var(--glass-2), var(--glass-1)); border-color: var(--glass-line); backdrop-filter: blur(var(--blur-panel)) saturate(1.08); -webkit-backdrop-filter: blur(var(--blur-panel)) saturate(1.08); box-shadow: var(--inner-top), var(--depth-1); }
.panel.glow, .panel.facet { border-color: var(--glass-line-bright); box-shadow: var(--inner-top), var(--depth-1), var(--glow-spectral); }
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) { .panel { background: color-mix(in oklab, var(--noir) 90%, transparent); } }

/* ── Composer = the hero glass facet + spectral refraction edge + spectral focus ── */
.intentbox { position: relative; background: linear-gradient(180deg, var(--glass-2), var(--glass-1)); backdrop-filter: blur(var(--blur-panel)); -webkit-backdrop-filter: blur(var(--blur-panel)); box-shadow: var(--inner-top); }
.intentbox::before { content: ""; position: absolute; left: 16px; right: 16px; top: -1px; height: 1.5px; border-radius: 2px; background: var(--edge-spectrum); opacity: .6; pointer-events: none; }
.intentbox:focus-within { border-color: var(--glass-line-bright); box-shadow: var(--inner-top), 0 0 0 1px color-mix(in oklab, var(--gold) 42%, transparent), 0 0 0 4px color-mix(in oklab, var(--gold) 9%, transparent), 0 0 32px -8px color-mix(in oklab, var(--spec-4) 42%, transparent); }

/* ── Spectral refraction focus ring — every input class ── */
.muse-in:focus, .ops-search:focus, .ac-inline input:focus, .ac-inline select:focus, .ops-mint input:focus, .cc-bar textarea:focus { outline: none; border-color: var(--glass-line-bright); box-shadow: 0 0 0 1px color-mix(in oklab, var(--gold) 38%, transparent), 0 0 22px -8px color-mix(in oklab, var(--spec-4) 38%, transparent); }

/* ── Buttons: gold is the only solid fill; the sheen becomes spectral; ghost = light glass ── */
.btn::after { background: linear-gradient(110deg, transparent 30%, color-mix(in oklab, var(--spec-1) 62%, transparent) 46%, color-mix(in oklab, var(--spec-4) 42%, transparent) 55%, transparent 70%); }
.btn-ghost { background: color-mix(in oklab, var(--noir-soft) 64%, transparent); }
.btn-ghost:hover { border-color: var(--glass-line-bright); }

/* ── Active tabs + chips: 2px spectral underline (gold stays the fill) ── */
.ws-tabs button.on::after { background: var(--edge-spectrum); }
.model-toggle .prism-opt.on { box-shadow: 0 6px 20px -10px color-mix(in oklab, var(--gold) 80%, transparent), 0 0 18px -8px color-mix(in oklab, var(--spec-4) 42%, transparent); }

/* ── Building: conic prism halo behind the spinner ── */
.bsynth::before { content: ""; position: absolute; inset: -16px; border-radius: 50%; background: var(--prism-conic); filter: blur(16px); opacity: .32; z-index: 0; animation: rot 6s linear infinite; }

/* ── Reduced motion: FREEZE the light, keep the look ── */
@media (prefers-reduced-motion: reduce) {
  .bg-atmosphere::after { animation: none; opacity: .42; }
  .brand .mk b, .intent h1 em, .home-hero h1 em { animation: none; background-position: 42% 0; }
  .bsynth::before { animation: none; }
}

/* ════════════════════════════════════════════════════════════════════
   THEME — monochrome base + Pantone-prism accent. Dark = "prism black"
   (default). Light = monochrome white. JS sets <html data-theme> from the
   saved choice or the OS preference; the prism --spec accents are shared.
   Token-value flip = the whole app re-themes with no per-rule rewrite.
   ════════════════════════════════════════════════════════════════════ */
:root, html[data-theme="dark"] {
  --noir-void:#08090B; --noir-deep:#0C0D10; --noir:#121318; --noir-soft:#191A20; --noir-haze:#222431; --noir-line:#2A2C36;
  --bone:#F3F4F7; --bone-dim:#BFC1CA; --bone-mute:#83858F;
}
html[data-theme="light"] {
  --noir-void:#FFFFFF; --noir-deep:#F7F7FA; --noir:#FFFFFF; --noir-soft:#F0F0F4; --noir-haze:#E8E8EE; --noir-line:#DEDEE6;
  --bone:#17171C; --bone-dim:#46474E; --bone-mute:#7A7C85;
  --glass-1: color-mix(in oklab, #FFFFFF 64%, transparent);
  --glass-2: color-mix(in oklab, #FFFFFF 80%, transparent);
  --glass-line: color-mix(in oklab, #17171C 12%, transparent);
  --glass-line-bright: color-mix(in oklab, var(--gold-matte) 55%, transparent);
  --inner-top: inset 0 1px 0 color-mix(in oklab, #FFFFFF 92%, transparent), inset 0 16px 30px -26px color-mix(in oklab, #17171C 7%, transparent);
  --depth-1: 0 20px 52px -34px color-mix(in oklab, #17171C 24%, transparent);
  --glow-spectral: 0 0 0 1px color-mix(in oklab, var(--spec-5) 52%, transparent), 0 0 24px -8px color-mix(in oklab, var(--spec-6) 40%, transparent);
}
html[data-theme="light"] { background: var(--noir-deep); }
/* Light field: multiply so the prism shows AS color on white (screen would vanish). */
html[data-theme="light"] .bg-atmosphere::after { mix-blend-mode: multiply; opacity: .4; }
html[data-theme="light"] .bg-atmosphere::before { background:
  radial-gradient(60% 46% at 50% 0%, color-mix(in oklab, var(--gold) 11%, transparent), transparent 70%),
  radial-gradient(42% 40% at 85% 96%, color-mix(in oklab, var(--spec-6) 7%, transparent), transparent 72%); }
/* Gold is a LIGHT fill in both modes → text on it stays dark always. */
html[data-theme="light"] .btn, html[data-theme="light"] .model-toggle .prism-opt.on { color: #16161b; }
html[data-theme="light"] .topbar { background: linear-gradient(180deg, color-mix(in oklab,#FFFFFF 86%,transparent), color-mix(in oklab,#FFFFFF 64%,transparent)); }
html[data-theme="light"] .topnav button.active { color: var(--gold-deep); }

/* ── Retina / adaptive polish: crisp hairlines + hover only where supported + touch targets ── */
@media (min-resolution: 2dppx) { .topbar, .panel { border-width: 0.5px; } }
@media (hover: none) {
  .btn:hover, .btn-ghost:hover, .reality-card:hover, .scale-card:hover { transform: none; }
  .btn::after { display: none; }
}
@media (pointer: coarse) {
  .topnav button, .model-toggle button, .arch-chips button, .seed-chips button, .btn-ghost, .ou-mini, .nq-x { min-height: 40px; }
}

/* ============================================================================
   PRISM WORKSPACE v2 — one-screen volumetric editor.
   A Genspark/OpenArt creation canvas crossed with the Unreal-editor's docked,
   volumetric space: the live preview is a large central VIEWPORT (the hero), an
   ever-present PRISM companion rail keeps the user in flow, and generous gutters
   let the prism caustic field show through for depth. Fills the viewport exactly
   (no page scroll); only the inner panels scroll. Scoped to .ws-v2 /
   #surface:has(.ws-v2) so every other view is untouched. Appended last → wins.
   Fully reversible (delete this block + the markup reverts to classic).
   ========================================================================== */

/* Full-bleed + lock to ONE screen — only while the workspace is mounted. */
#surface:has(.ws-v2) { max-width: none; width: 100%; margin: 0; padding: 0; display: flex; min-height: 0; }
.shell:has(.ws-v2) { height: 100dvh; overflow: hidden; }

.ws-v2 { flex: 1; min-height: 0; display: flex; flex-direction: column; gap: clamp(8px, 1vw, 13px); padding: clamp(10px, 1.4vw, 16px) clamp(10px, 1.6vw, 22px); }
.ws-v2 > #nodeQueue { flex-shrink: 0; }
.ws-v2 > #nodeQueue:empty { display: none; }

/* ---- top bar: status + title · live/share/publish · library/build/classic ---- */
.ws-bar { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 9px 14px; flex-shrink: 0; border-radius: 14px; }
.ws-bar-l { display: flex; align-items: center; gap: 13px; min-width: 0; }
.ws-bar-r { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; justify-content: flex-end; }
.ws-bar-sep { width: 1px; height: 20px; background: var(--noir-line); margin: 0 4px; }
.ws-title { font-family: "Fraunces", Georgia, serif; font-weight: 500; font-size: clamp(15px, 1.5vw, 20px); line-height: 1.1; margin: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 36vw; color: var(--bone); }
.ws-live { display: inline-flex; align-items: center; gap: 7px; font-family: "IBM Plex Mono", ui-monospace, monospace; font-size: 10.5px; letter-spacing: .03em; color: var(--bone-mute); white-space: nowrap; }
.ws-classic { opacity: .62; }
.ws-classic:hover { opacity: 1; }

/* ---- body: stage (hero) + companion rail ---- */
.ws-v2 .ws-body { flex: 1; min-height: 0; display: grid; grid-template-columns: minmax(0, 1fr) clamp(340px, 27vw, 432px); gap: clamp(10px, 1.4vw, 16px); align-items: stretch; }

/* the live preview viewport — the hero, sits highest in the volumetric stack */
.ws-stage-wrap { display: flex; flex-direction: column; min-height: 0; padding: 0; overflow: hidden; border-radius: 14px; box-shadow: 0 26px 70px -34px rgba(0,0,0,.82), inset 0 1px 0 color-mix(in oklab, var(--bone) 7%, transparent); }
.ws-stage-wrap .bf-chrome { display: flex; align-items: center; gap: 7px; padding: 9px 12px; border-bottom: 1px solid var(--noir-line); flex-shrink: 0; }
.ws-v2 .ws-stage { flex: 1; min-height: 0; background: #fff; position: relative; }
.ws-v2 .ws-stage iframe.app-frame { width: 100%; height: 100%; border: 0; display: block; background: #fff; }
/* a hairline inset frames the bright preview so it doesn't glare against the dark field (eye comfort) */
.ws-v2 .ws-stage::after { content: ""; position: absolute; inset: 0; pointer-events: none; box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--bone) 9%, transparent); }
.ws-v2 .ws-stage.mobile { display: flex; justify-content: center; align-items: flex-start; background: var(--noir-void); padding: 16px 0; overflow: auto; }
.ws-v2 .ws-stage.mobile iframe.app-frame { width: 390px; max-width: 100%; height: 100%; min-height: 700px; border: 1px solid var(--noir-line); border-radius: 16px; box-shadow: 0 16px 54px rgba(0,0,0,.45); }
.ws-v2 .ws-stage.mobile::after { display: none; }

/* ---- companion rail: an always-present PRISM partner ---- */
.ws-rail { display: flex; flex-direction: column; min-height: 0; padding: 0; overflow: hidden; border-radius: 14px; box-shadow: 0 20px 56px -32px rgba(0,0,0,.72), inset 0 1px 0 color-mix(in oklab, var(--bone) 6%, transparent); }
.ws-rail-head { display: flex; align-items: center; gap: 10px; padding: 11px 14px 10px; border-bottom: 1px solid var(--noir-line); flex-shrink: 0; }
.ws-rail-id { display: flex; flex-direction: column; line-height: 1.2; min-width: 0; }
.ws-rail-id b { font-size: 11.5px; letter-spacing: .15em; text-transform: uppercase; color: var(--bone); }
.ws-rail-sub { font-size: 10.5px; color: var(--bone-mute); }
.ws-v2 .ws-tabs { display: flex; border-bottom: 1px solid var(--noir-line); flex-shrink: 0; overflow-x: auto; scrollbar-width: none; }
.ws-v2 .ws-tabs::-webkit-scrollbar { display: none; }
.ws-v2 .ws-tabs button { flex: 1 0 auto; padding: 10px 11px; background: transparent; border: 0; border-bottom: 2px solid transparent; color: var(--bone-mute); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; cursor: pointer; white-space: nowrap; transition: color .2s var(--ease), border-color .2s var(--ease); }
.ws-v2 .ws-tabs button:hover { color: var(--bone-dim); }
.ws-v2 .ws-tabs button.on { color: var(--gold-bright); border-bottom-color: var(--gold); }
.ws-rail-body { position: relative; flex: 1; min-height: 0; }
.ws-rail-body .ws-tabpane { position: absolute; inset: 0; padding: 13px; overflow: auto; }
.ws-rail-body .ws-tabpane[hidden] { display: none; }
/* refine pane = forward "next moves" + scrolling chat log + a pinned chat bar */
.ws-rail-body .refine-pane { display: flex; flex-direction: column; padding-bottom: 13px; }
.ws-quick-wrap { flex-shrink: 0; margin-bottom: 11px; }
.ws-quick-k { display: block; font-size: 8.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--gold-matte); margin-bottom: 7px; }
.ws-v2 .ws-cc { flex: 1; min-height: 0; display: flex; flex-direction: column; padding: 0; border: 0; background: transparent; }
.ws-v2 .ws-cc .cc-log { flex: 1; min-height: 0; max-height: none; overflow: auto; }
.ws-v2 .ws-cc .cc-bar { flex-shrink: 0; }

/* ---- the living PRISM presence orb (breathes, so the companion feels alive) ---- */
.ws-orb { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; background: radial-gradient(circle at 34% 30%, var(--spec-3), var(--spec-5) 55%, var(--spec-6)); box-shadow: 0 0 8px color-mix(in oklab, var(--spec-5) 70%, transparent); animation: ws-breathe 3.4s ease-in-out infinite; }
.ws-orb.lg { width: 13px; height: 13px; box-shadow: 0 0 15px color-mix(in oklab, var(--spec-4) 78%, transparent); }
@keyframes ws-breathe { 0%, 100% { transform: scale(1); opacity: .82; } 50% { transform: scale(1.24); opacity: 1; } }
.ws-live.is-sleep .ws-orb { background: var(--bone-mute); box-shadow: none; animation: none; }

/* ---- responsive: ultrawide · laptop · tablet · phone ---- */
@media (min-width: 1700px) {
  .ws-v2 { padding-left: clamp(22px, 4vw, 86px); padding-right: clamp(22px, 4vw, 86px); }
  .ws-v2 .ws-body { grid-template-columns: minmax(0, 1fr) 448px; }
}
@media (max-width: 1024px) {
  .ws-v2 .ws-body { grid-template-columns: minmax(0, 1fr) clamp(300px, 34vw, 380px); }
}
@media (max-width: 820px) {
  /* below desktop the mobile tabbar appears; stack the viewport over the companion */
  .ws-v2 .ws-body { grid-template-columns: 1fr; grid-template-rows: minmax(38vh, 1fr) minmax(0, 1.15fr); }
  .ws-title { max-width: 52vw; }
}
@media (max-width: 560px) {
  .ws-v2 { padding: 8px; gap: 8px; }
  .ws-bar { flex-direction: column; align-items: stretch; gap: 9px; }
  .ws-bar-r { justify-content: flex-start; }
  .ws-title { max-width: 70vw; }
}
@media (prefers-reduced-motion: reduce) { .ws-orb { animation: none; } }

/* ════════════════════════════════════════════════════════════════════════════
   GALAXY CRYSTAL DUST · METEORIC DRAGONGLASS — appended override #3 (after
   PRISM GLASS HUD + WORKSPACE v2). The signature material: galaxy crystal dust
   seen THROUGH meteoric dragonglass — cosmic-obsidian dark / frosted-diamond
   light, a parallax crystal-dust starfield, dragonglass iridescent facet-edges
   + prism refraction. Fully REVERSIBLE: delete this whole block (+ revert the
   index.html ?v) to return to the prior look.
   NOTES: dust lives on the injected `.stardust` element (body::before/::after
   are taken — <body> IS .bg-atmosphere). Panel rims use box-shadow + the
   dedicated .stage-iris/.rail-iris children, NEVER .hud::before/::after (those
   are the gold corner brackets). No .ws-stage-wrap::after (it would clobber the
   bottom-right corner bracket).
   ════════════════════════════════════════════════════════════════════════════ */

/* 1 — GALAXY DEEP BLACK CRYSTAL DUST: cosmic blue-violet obsidian base + material controls */
:root, html[data-theme="dark"] {
  --noir-void:#050608; --noir-deep:#070810; --noir:#0B0D16; --noir-soft:#11131F; --noir-haze:#191C2B; --noir-line:#262A3C;
  --bone:#EEF0F8; --bone-dim:#B6BACD; --bone-mute:#7C8196;
  --cd-star:#EAF0FF; --cd-far-op:.50; --cd-near-op:.46; --cd-blend:screen;
  --fx-rim:.26; --fx-rim-hot:.62; --cd-caustic-op:.50;
  --glass-1: color-mix(in oklab, #111426 70%, transparent);
  --glass-2: color-mix(in oklab, #0B0D16 60%, transparent);
  --edge-iris: 0 0 0 1px color-mix(in oklab, var(--spec-6) 22%, transparent);
}
html, body { background: #050608; }

/* 2 — GALAXY WHITE CRYSTAL DUST: frosted-diamond pearl, delicate dispersion */
html[data-theme="light"] {
  --noir-void:#FDFDFF; --noir-deep:#F5F6FB; --noir:#FFFFFF; --noir-soft:#EFF1F7; --noir-haze:#E7E9F2; --noir-line:#DCDFEA;
  --bone:#15161C; --bone-dim:#44464F; --bone-mute:#777A88;
  --cd-star:#6E76C8; --cd-far-op:.18; --cd-near-op:.16; --cd-blend:multiply;
  --fx-rim:.30; --fx-rim-hot:.52; --cd-caustic-op:.30;
  --glass-1: color-mix(in oklab, #FFFFFF 66%, transparent);
  --glass-2: color-mix(in oklab, #FFFFFF 82%, transparent);
  --edge-iris: 0 0 0 1px color-mix(in oklab, var(--spec-6) 18%, transparent);
}
html[data-theme="light"], html[data-theme="light"] body { background: var(--noir-deep); }

/* 3 — FIELD retune (additive): nebula depth on the existing ::before, dim the shipped caustic */
:root .bg-atmosphere::before, html[data-theme="dark"] .bg-atmosphere::before {
  background:
    radial-gradient(38% 30% at 18% 22%, color-mix(in oklab,var(--spec-6) 14%,transparent), transparent 66%),
    radial-gradient(34% 28% at 82% 30%, color-mix(in oklab,var(--spec-7) 12%,transparent), transparent 66%),
    radial-gradient(46% 36% at 72% 88%, color-mix(in oklab,var(--spec-5) 11%,transparent), transparent 70%),
    radial-gradient(40% 38% at 22% 86%, color-mix(in oklab,var(--spec-1) 8%,transparent), transparent 70%),
    radial-gradient(62% 82% at 50% 50%, color-mix(in oklab,#0B0D16 70%,transparent), #050608 92%);
}
.bg-atmosphere::after { opacity: var(--cd-caustic-op); }
html[data-theme="light"] .bg-atmosphere::before {
  background:
    radial-gradient(40% 32% at 16% 16%, color-mix(in oklab,var(--spec-7) 9%,transparent), transparent 64%),
    radial-gradient(36% 30% at 84% 20%, color-mix(in oklab,var(--spec-6) 8%,transparent), transparent 64%),
    radial-gradient(50% 40% at 78% 90%, color-mix(in oklab,var(--spec-5) 7%,transparent), transparent 70%),
    radial-gradient(120% 90% at 50% 0%, color-mix(in oklab,#FFFFFF 0%,transparent), color-mix(in oklab,#E9ECF6 42%,transparent) 100%);
  mix-blend-mode: multiply;
}
html[data-theme="light"] .bg-atmosphere::after { mix-blend-mode: multiply; opacity: var(--cd-caustic-op); }

/* 4 — CRYSTAL DUST: two parallax starfield planes on the injected .stardust element. Vector
   radial-gradient hard-stops = retina-crisp at any DPR, zero image bytes; only transform animates. */
.stardust { position: fixed; inset: 0; z-index: 0; pointer-events: none; }
.stardust::before, .stardust::after { content: ""; position: absolute; inset: 0; pointer-events: none; will-change: transform; }
.stardust::before {
  background-image:
    radial-gradient(1px 1px at 17px 23px, color-mix(in oklab,var(--cd-star) 85%,transparent) 50%, transparent 51%),
    radial-gradient(1px 1px at 83px 47px, color-mix(in oklab,var(--cd-star) 68%,transparent) 50%, transparent 51%),
    radial-gradient(1.5px 1.5px at 130px 90px, color-mix(in oklab,var(--spec-6) 78%,transparent) 50%, transparent 51%),
    radial-gradient(1px 1px at 50px 160px, color-mix(in oklab,var(--cd-star) 60%,transparent) 50%, transparent 51%),
    radial-gradient(1.5px 1.5px at 175px 130px, color-mix(in oklab,var(--spec-4) 72%,transparent) 50%, transparent 51%),
    radial-gradient(1px 1px at 110px 30px, color-mix(in oklab,var(--cd-star) 55%,transparent) 50%, transparent 51%);
  background-size: 200px 200px; background-repeat: repeat;
  mix-blend-mode: var(--cd-blend); opacity: var(--cd-far-op);
  animation: cd-far 150s linear infinite;
}
.stardust::after {
  background-image:
    radial-gradient(1.5px 1.5px at 60px 80px, color-mix(in oklab,var(--cd-star) 95%,transparent) 50%, transparent 51%),
    radial-gradient(2px 2px at 230px 150px, color-mix(in oklab,var(--spec-3) 88%,transparent) 50%, transparent 51%),
    radial-gradient(1.5px 1.5px at 300px 60px, color-mix(in oklab,var(--spec-5) 82%,transparent) 50%, transparent 51%),
    radial-gradient(2px 2px at 130px 280px, color-mix(in oklab,var(--cd-star) 90%,transparent) 50%, transparent 51%),
    radial-gradient(1.5px 1.5px at 340px 320px, color-mix(in oklab,var(--spec-7) 82%,transparent) 50%, transparent 51%);
  background-size: 380px 380px; background-repeat: repeat;
  mix-blend-mode: var(--cd-blend); opacity: var(--cd-near-op);
  animation: cd-near 96s linear infinite, cd-twinkle 6.5s ease-in-out infinite;
}
@keyframes cd-far { to { transform: translate3d(0, -200px, 0); } }
@keyframes cd-near { to { transform: translate3d(-380px, -380px, 0); } }
@keyframes cd-twinkle { 0%,100% { opacity: var(--cd-near-op); } 50% { opacity: calc(var(--cd-near-op) + .18); } }

/* 5 — PANEL / STAGE / RAIL material (glass re-points to obsidian-blue / frosted-diamond via tokens). */
.panel { background: linear-gradient(180deg, var(--glass-2), var(--glass-1)); border-color: var(--glass-line); }
/* PERF — the iframe is opaque, so a backdrop-filter behind it isn't visible inside the stage but forces the
   compositor to re-rasterize the iframe into the parent backdrop EVERY frame (the worst jank on the main
   screen). Use an opaque material instead; the look is preserved. */
.ws-v2 .ws-stage-wrap { position: relative; background: color-mix(in oklab, var(--noir) 88%, transparent); box-shadow: 0 40px 92px -42px rgba(0,0,0,.90), 0 0 0 1px color-mix(in oklab,var(--spec-6) 12%,transparent), inset 0 1px 0 color-mix(in oklab,var(--bone) 8%,transparent); }
/* PERF — freeze the body starfield + caustic while the full-bleed workspace covers them (barely visible
   there) so the main screen stops perpetually compositing. Self-correcting via :has — resumes on home. */
body.bg-atmosphere:has(.ws-v2)::after { animation: none; }
body:has(.ws-v2) .stardust::before, body:has(.ws-v2) .stardust::after { animation: none; }
.ws-v2 .ws-stage::after { box-shadow: inset 0 0 0 1px color-mix(in oklab,var(--spec-6) 14%, transparent); }
html[data-theme="light"] .ws-v2 .ws-stage::after { box-shadow: inset 0 0 0 1px color-mix(in oklab,#15161C 10%, transparent); }
.ws-v2 .ws-rail { position: relative; backdrop-filter: blur(12px) saturate(1.12); -webkit-backdrop-filter: blur(12px) saturate(1.12); box-shadow: 0 24px 60px -34px rgba(0,0,0,.78), var(--edge-iris); }
.ws-rail-head { position: relative; }
.ws-rail-head::after { content: ""; position: absolute; left: 14px; right: 14px; bottom: -1px; height: 1.5px; background: var(--edge-spectrum); opacity: .45; pointer-events: none; }
.ws-orb { box-shadow: 0 0 12px color-mix(in oklab,var(--spec-5) 80%,transparent), 0 0 30px -6px color-mix(in oklab,var(--spec-7) 50%,transparent); }
.ws-orb.lg { position: relative; }
.ws-orb.lg::after { content: ""; position: absolute; inset: -5px; border-radius: 50%; background: var(--prism-conic); filter: blur(6px); opacity: .4; z-index: -1; }
.ws-rail.is-thinking .ws-orb { animation-duration: 1.2s; }

/* 6 — DRAGONGLASS iridescence: box-shadow iris ring + masked spectral rim on the two heroes. */
.panel.hud { box-shadow: var(--inner-top), var(--depth-1), var(--edge-iris); }
.panel.hud:hover { box-shadow: var(--inner-top), var(--depth-1), 0 0 0 1px color-mix(in oklab,var(--spec-6) 25%,transparent), 0 0 26px -10px color-mix(in oklab,var(--spec-5) 34%,transparent); }
.panel.hud:hover::before, .panel.hud:hover::after { border-color: color-mix(in oklab,var(--spec-6) 50%, var(--gold)); }
.stage-iris, .rail-iris {
  position: absolute; inset: 0; border-radius: inherit; padding: 1.2px; pointer-events: none; z-index: 2;
  background: var(--prism-conic);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  mix-blend-mode: screen; opacity: var(--fx-rim); transition: opacity .4s var(--ease);
}
.rail-iris { opacity: calc(var(--fx-rim) * .7); }
html[data-dev="desktop"] .ws-stage-wrap:hover .stage-iris, .ws-stage-wrap:focus-within .stage-iris,
html[data-dev="desktop"] .ws-rail:hover .rail-iris, .ws-rail:focus-within .rail-iris { opacity: var(--fx-rim-hot); }
@supports not ((mask-composite: exclude) or (-webkit-mask-composite: xor)) { .stage-iris, .rail-iris { display: none; } }
html[data-theme="light"] .stage-iris, html[data-theme="light"] .rail-iris { mix-blend-mode: normal; }

/* 7 — LEGIBILITY: scrims under running text + max-contrast reset + no-backdrop fallback */
.cc-log, .ws-src { background: color-mix(in oklab, var(--noir) 88%, transparent); }
@media (prefers-contrast: more) {
  .stardust, .bg-atmosphere::after, .stage-iris, .rail-iris { opacity: 0 !important; }
  .panel, .panel.hud { background: var(--noir); }
}
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .stardust::before, .stardust::after { opacity: .3; }
}

/* 8 — FOCUS REFRACTION: chromatic-aberration ring (light bending through a prism face) */
.intentbox:focus-within, .cc-bar textarea:focus {
  box-shadow:
    -1px 0 0 color-mix(in oklab,var(--spec-1) 55%,transparent),
    1px 0 0 color-mix(in oklab,var(--spec-6) 55%,transparent),
    0 0 0 1px var(--glass-line-bright),
    0 0 30px -8px color-mix(in oklab,var(--spec-4) 40%,transparent);
}

/* 9 — MOTION: freeze (don't disable) for reduced-motion + very low-end */
@media (prefers-reduced-motion: reduce) {
  .stardust::before, .stardust::after, .ws-orb, .ws-orb.lg { animation: none; }
}
@media (update: slow) {
  .stardust::before, .stardust::after { animation: none; }
}

/* 10 — DESKTOP: ultrawide cinematic gutters (hover affordances arm via html[data-dev=desktop] above) */
@media (min-width: 1700px) {
  .ws-v2 .ws-body { grid-template-columns: minmax(0, 1fr) 480px; }
}

/* 11 — MOBILE-RETINA, device-aware */
@media (pointer: coarse) {
  .stardust::after { display: none; }
  .stardust::before { opacity: calc(var(--cd-far-op) * .7); background-size: 300px 300px; }
  .ws-v2 .ws-tabs button { min-height: 44px; }
  .ws-chip { min-height: 38px; }
  #ccSend { min-height: 46px; }
}
@media (max-width: 820px) {
  .panel, .ws-rail { backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }
  .bg-atmosphere::after { opacity: calc(var(--cd-caustic-op) * .7); }
  .ws-v2 .ws-body { grid-template-columns: 1fr; grid-template-rows: minmax(40vh, 1fr) minmax(0, 1.2fr); }
  .ws-v2 { padding-bottom: max(8px, env(safe-area-inset-bottom)); padding-left: max(10px, env(safe-area-inset-left)); padding-right: max(10px, env(safe-area-inset-right)); }
  .ws-v2 .cc-bar { padding-bottom: max(11px, env(safe-area-inset-bottom)); }
  .ws-v2 .ws-tabs { scroll-snap-type: x proximity; }
  .ws-v2 .ws-tabs button { scroll-snap-align: start; }
}
@media (max-width: 560px) {
  .ws-v2 .ws-body { grid-template-rows: 46vh minmax(0, 1fr); }
}
@media (min-resolution: 2dppx) {
  .stage-iris, .rail-iris { padding: .8px; }
}

/* ════════════════════════════════════════════════════════════════════════════
   LIVING CRYSTAL — appended override #4 (after GALAXY CRYSTAL DUST #3).
   Carved-diamond facets · year-2300 ornament · particle/motion VFX.
   Reversible: delete this whole block + revert index.html ?v=81 → ?v=80.
   Collision-safe: .hud::before/::after stay the gold brackets (additive glow
   only); body/.bg-atmosphere = field; .stardust = dust; .stage-iris/.rail-iris
   = rims; NO .ws-stage-wrap::after; .btn::after = the live sweep (kept). Bevel
   rides box-shadow (paints under text → legible).
   ════════════════════════════════════════════════════════════════════════════ */

:root, html[data-theme="dark"] {
  --facet-bevel: inset 0 1px 0 color-mix(in oklab,var(--bone) 20%,transparent), inset 0 2px 1px -1px color-mix(in oklab,#FFFFFF 9%,transparent), inset 0 -1px 0 color-mix(in oklab,#000 52%,transparent), inset 1px 0 0 color-mix(in oklab,var(--spec-6) 8%,transparent), inset -1px 0 0 color-mix(in oklab,var(--spec-1) 7%,transparent);
  --facet-bevel-deep: inset 0 1.5px 0 color-mix(in oklab,var(--bone) 28%,transparent), inset 0 2px 10px -8px color-mix(in oklab,var(--bone) 30%,transparent), inset 0 -1.5px 0 color-mix(in oklab,#000 58%,transparent), inset 0 -10px 22px -18px color-mix(in oklab,#000 62%,transparent);
  --facet-disperse: -0.5px 0 0 color-mix(in oklab,var(--spec-1) 36%,transparent), 0.5px 0 0 color-mix(in oklab,var(--spec-6) 36%,transparent);
  --hairline: color-mix(in oklab,var(--bone) 13%,transparent);
  --hairline-bright: color-mix(in oklab,var(--bone) 24%,transparent);
  --facet-sheen: linear-gradient(157deg, color-mix(in oklab,var(--bone) 11%,transparent) 0%, transparent 22%, transparent 78%, color-mix(in oklab,#000 14%,transparent) 100%);
  --facet-sheen-blend: screen;
}
html[data-theme="light"] {
  --facet-bevel: inset 0 1px 0 color-mix(in oklab,#fff 95%,transparent), inset 0 2px 2px -1px color-mix(in oklab,#fff 78%,transparent), inset 0 -1px 0 color-mix(in oklab,#15161C 11%,transparent), inset 1px 0 0 color-mix(in oklab,#fff 60%,transparent), inset -1px 0 0 color-mix(in oklab,#15161C 7%,transparent);
  --facet-bevel-deep: inset 0 1.5px 0 #fff, inset 0 2px 9px -7px color-mix(in oklab,#fff 88%,transparent), inset 0 -1.5px 0 color-mix(in oklab,#15161C 12%,transparent), inset 0 -9px 20px -17px color-mix(in oklab,#15161C 9%,transparent);
  --facet-disperse: -0.5px 0 0 color-mix(in oklab,var(--spec-1) 26%,transparent), 0.5px 0 0 color-mix(in oklab,var(--spec-6) 26%,transparent);
  --hairline: color-mix(in oklab,#15161C 10%,transparent);
  --hairline-bright: color-mix(in oklab,#15161C 18%,transparent);
  --facet-sheen: linear-gradient(157deg, color-mix(in oklab,#fff 58%,transparent) 0%, transparent 24%, transparent 80%, color-mix(in oklab,#15161C 5%,transparent) 100%);
  --facet-sheen-blend: multiply;
}

/* Panels = one cut diamond face (bevel via box-shadow; sheen via a stacked bg layer) */
.panel { box-shadow: var(--facet-bevel), var(--inner-top), var(--depth-1); background-image: var(--facet-sheen), linear-gradient(180deg, var(--glass-2), var(--glass-1)); background-blend-mode: var(--facet-sheen-blend), normal; }
.panel.glow, .panel.facet { box-shadow: var(--facet-bevel-deep), var(--inner-top), var(--depth-1), var(--glow-spectral); }
.panel.hud { box-shadow: var(--facet-bevel), var(--inner-top), var(--depth-1), var(--edge-iris); }
.panel.hud:hover { box-shadow: var(--facet-bevel-deep), var(--inner-top), var(--depth-1), 0 0 0 1px color-mix(in oklab,var(--spec-6) 26%,transparent), 0 0 26px -10px color-mix(in oklab,var(--spec-5) 32%,transparent); }
@supports not (background-blend-mode: screen) { .panel { background-image: linear-gradient(180deg, var(--glass-2), var(--glass-1)); } }
.ws-v2 .ws-stage-wrap { box-shadow: var(--facet-bevel-deep), 0 40px 92px -42px rgba(0,0,0,.90), 0 0 0 1px color-mix(in oklab,var(--spec-6) 12%,transparent); }
.ws-v2 .ws-rail, .ws-v2 .ws-rail:hover { box-shadow: var(--facet-bevel), 0 24px 60px -34px rgba(0,0,0,.78), var(--edge-iris); }

/* Buttons / chips / tabs = small cut gems (.btn::after sweep kept; bevel on box-shadow only) */
.btn { box-shadow: var(--facet-bevel), 0 8px 22px -12px color-mix(in oklab,var(--gold-deep) 70%,transparent); }
.btn:hover { box-shadow: var(--facet-bevel), var(--facet-disperse), 0 10px 26px -12px color-mix(in oklab,var(--gold-deep) 80%,transparent); }
.btn:active { box-shadow: inset 0 2px 5px -2px color-mix(in oklab,#000 50%,transparent), inset 0 1px 0 color-mix(in oklab,var(--bone) 10%,transparent); }
.btn-ghost, .model-toggle button, .seed-chips button, .topnav button, .ws-v2 .ws-tabs button { box-shadow: var(--facet-bevel); }
.btn-ghost:hover { box-shadow: var(--facet-bevel), var(--facet-disperse); }
.btn-ghost:active, .model-toggle button:active { box-shadow: inset 0 1.5px 4px -2px color-mix(in oklab,#000 40%,transparent); }

/* Inputs = facets cut INTO the crystal (inverted bevel) */
.intentbox, .cc-bar textarea, .muse-in, .ops-search, .ac-inline input { box-shadow: inset 0 1.5px 4px -2px color-mix(in oklab,#000 44%,transparent), inset 0 -1px 0 color-mix(in oklab,var(--bone) 9%,transparent); }
html[data-theme="light"] .intentbox, html[data-theme="light"] .cc-bar textarea { box-shadow: inset 0 1.5px 4px -2px color-mix(in oklab,#15161C 9%,transparent), inset 0 -1px 0 #fff; }
.intentbox:focus-within, .cc-bar textarea:focus { box-shadow: var(--facet-disperse), 0 0 0 1px var(--glass-line-bright), 0 0 30px -8px color-mix(in oklab,var(--spec-4) 38%,transparent); }

/* ORNATE YEAR-2300 DETAILING (static engraving) */
.panel.hud::before, .panel.hud::after { box-shadow: 0 0 6px -1px color-mix(in oklab,var(--gold) 38%,transparent); }
.acct-sep { height: 1px; border: 0; background: linear-gradient(90deg, transparent, var(--hairline-bright) 18%, color-mix(in oklab,var(--spec-3) 22%,transparent) 50%, var(--hairline-bright) 82%, transparent); }
.ws-bar-sep { background: linear-gradient(180deg, transparent, var(--hairline-bright), transparent); }
.section-h { position: relative; }
.section-h::after { content: ""; position: absolute; left: 0; bottom: -6px; width: 46px; height: 1px; background: var(--edge-spectrum); opacity: .7; box-shadow: 0 3px 0 -2px var(--hairline); }
.eyebrow { letter-spacing: .34em; }
.ws-live { font-variant-numeric: tabular-nums; letter-spacing: .04em; }
.ws-rail-id b { letter-spacing: .18em; font-variant-numeric: tabular-nums; }
.brand .mk { letter-spacing: .22em; }
.ws-title::after { content: "✦"; margin-left: .5em; font-size: .6em; vertical-align: .25em; color: color-mix(in oklab,var(--spec-3) 70%,var(--gold)); opacity: .55; }
.ws-rail-head { box-shadow: inset 0 -1px 0 var(--hairline); }
.lrow { box-shadow: inset 1px 0 0 var(--hairline); }
.lrow[data-st="running"] { box-shadow: inset 1px 0 0 color-mix(in oklab,var(--spec-5) 42%,transparent); }
.intentbox::after { content: ""; position: absolute; left: 16px; top: -1px; width: 6px; height: 6px; border-left: 1px solid color-mix(in oklab,var(--spec-1) 50%,transparent); border-top: 1px solid color-mix(in oklab,var(--spec-1) 50%,transparent); pointer-events: none; }

/* PARTICLE / MOTION VFX (compositor-only) */
.ws-v2 .ws-stage-wrap, .ws-v2 .ws-rail { position: relative; }
.ws-v2 .ws-stage-wrap::before { content: ""; position: absolute; top: 0; left: 0; height: 1px; width: 64px; z-index: 3; pointer-events: none; background: linear-gradient(90deg, transparent, color-mix(in oklab,var(--spec-3) 90%,#fff), transparent); opacity: 0; animation: glint-run 9s var(--ease) infinite; }
.ws-v2 .ws-rail::before { content: ""; position: absolute; top: 0; left: 0; height: 1px; width: 48px; z-index: 3; pointer-events: none; background: linear-gradient(90deg, transparent, color-mix(in oklab,var(--spec-5) 85%,#fff), transparent); opacity: 0; animation: glint-run 11s var(--ease) 2.5s infinite; }
@keyframes glint-run { 0% { transform: translateX(-64px); opacity: 0; } 8% { opacity: .9; } 20% { transform: translateX(min(60vw,640px)); opacity: 0; } 100% { transform: translateX(min(60vw,640px)); opacity: 0; } }
.stardust .spark { position: fixed; width: 10px; height: 10px; pointer-events: none; opacity: 0; background: var(--bone); clip-path: polygon(50% 0,58% 42%,100% 50%,58% 58%,50% 100%,42% 58%,0 50%,42% 42%); box-shadow: 0 0 6px 1px color-mix(in oklab,var(--spec-3) 80%,transparent); animation: sparkle 5s ease-in-out infinite; }
@keyframes sparkle { 0%,100% { transform: scale(.2) rotate(0); opacity: 0; } 50% { transform: scale(1) rotate(45deg); opacity: .85; } }
.ws-orb.lg::after { animation: rot 6s linear infinite; filter: blur(6px); }

/* ONE-SHOT PRISM BURST (reward moment) */
.prism-burst { position: fixed; left: 50%; top: 42%; width: 10px; height: 10px; transform: translate(-50%,-50%); z-index: 9998; pointer-events: none; border-radius: 50%; }
.prism-burst::before { content: ""; position: absolute; inset: 0; border-radius: 50%; animation: burst-ring .9s var(--ease) forwards; }
.prism-burst::after { content: ""; position: absolute; inset: -40px; border-radius: 50%; background: var(--prism-conic); filter: blur(14px); opacity: 0; animation: burst-flash .9s var(--ease) forwards; }
@keyframes burst-ring { 0% { transform: scale(0); opacity: 1; box-shadow: 0 0 0 2px color-mix(in oklab,var(--spec-3) 90%,#fff), 0 0 0 0 color-mix(in oklab,var(--spec-6) 60%,transparent); } 70% { opacity: .7; } 100% { transform: scale(34); opacity: 0; box-shadow: 0 0 0 1px transparent; } }
@keyframes burst-flash { 0% { opacity: 0; transform: scale(.4); } 18% { opacity: .5; } 100% { opacity: 0; transform: scale(1.6); } }

/* Reduced-motion / in-app toggle: remove decorative motion (keep the orb's slow spin) */
@media (prefers-reduced-motion: reduce) {
  .ws-v2 .ws-stage-wrap::before, .ws-v2 .ws-rail::before, .stardust .spark { animation: none; display: none; }
  .prism-burst { display: none; }
  .ws-orb.lg::after { animation: rot 6s linear infinite; }
}
body.reduce-motion .ws-v2 .ws-stage-wrap::before, body.reduce-motion .ws-v2 .ws-rail::before, body.reduce-motion .stardust .spark { animation: none; display: none; }
body.reduce-motion .prism-burst { display: none; }
body.reduce-motion .ws-orb.lg::after { animation: rot 6s linear infinite; }

/* ════════════════════════════════════════════════════════════════════════════
   GALAXY-CRYSTAL ACCENT — appended override #5. Replaces the champagne-GOLD
   accent with a MONOCHROME galaxy-crystal accent that FLIPS with the theme:
   bright ICE / platinum crystal on the black-crystal (dark) base, deep OBSIDIAN
   crystal on the white-crystal (light) base. The prism --spec spectrum stays
   (the galaxy dispersion / ornate shimmer). Reversible: delete this block + revert ?v.
   ════════════════════════════════════════════════════════════════════════════ */

/* DARK — gold ramp → bright ice / platinum crystal */
:root, html[data-theme="dark"] {
  --gold-foil: #F6F8FF; --gold-bright: #FFFFFF; --gold: #D7DCEC; --gold-matte: #AEB4C8; --gold-deep: #7E859B;
  --reality-accent: #D7DCEC;
}
/* LIGHT — gold ramp → deep obsidian crystal */
html[data-theme="light"] {
  --gold-foil: #2A2C36; --gold-bright: #0E0F15; --gold: #1E2029; --gold-matte: #3A3C48; --gold-deep: #0A0B10;
  --reality-accent: #1E2029;
}
/* The accent fill now FLIPS, so its text must flip too: dark text on the bright dark-mode
   crystal (the base `.btn{color:var(--noir)}` is already dark) → only the LIGHT theme needs
   light text on its deep-crystal fill (override the prior dark rule). */
html[data-theme="light"] .btn, html[data-theme="light"] .model-toggle .prism-opt.on { color: #F5F6FB; }
/* The current-plan "Your plan" button is a GHOST .btn (no accent fill) — it must NOT inherit the
   light-on-fill text above, or it reads white-on-white on the light card. Restore muted ink + line. */
html[data-theme="light"] .btn.plan-cta.ghost { color: var(--bone-dim); border-color: var(--noir-line); }
/* The prism-refraction build-fan rays follow the crystal ramp (were hardcoded gold hexes). */
.p-fan .r1 { stroke: var(--gold-foil); }
.p-fan .r2 { stroke: var(--gold-bright); }
.p-fan .r3 { stroke: var(--gold); }
.p-fan .r5 { stroke: var(--gold-matte); }
.p-fan .r6 { stroke: var(--gold-deep); }
/* The brand diamond mark (a gold SVG asset) → monochrome crystal per theme. */
:root .brand-mark, html[data-theme="dark"] .brand-mark { filter: grayscale(1) brightness(1.7) contrast(.95); }
html[data-theme="light"] .brand-mark { filter: grayscale(1) brightness(.4) contrast(1.1); }
/* Slightly more intricate, crystal-toned corner brackets (the ornament now reads in the theme crystal). */
.panel.hud::before, .panel.hud::after { box-shadow: 0 0 7px -1px color-mix(in oklab,var(--gold) 46%,transparent); }
/* The accent fill is var()-driven; with `transition: all` a LIVE theme toggle leaves the button bg/text
   stuck at the old crystal until a repaint. Animate only hover props so the theme flip recolors instantly. */
.btn { transition: box-shadow .25s var(--ease), transform .25s var(--ease); }

/* ════════════════════════════════════════════════════════════════════════════
   PATCH LOG — the user-visible "What's new" changelog + a "new" indicator on the
   account avatar/menu. Appended override #6a. Reversible.
   ════════════════════════════════════════════════════════════════════════════ */
.patchlog { max-width: 760px; margin: 2vh auto 0; text-align: left; }
.patchlog .display { margin: 8px 0 6px; }
.patchlog .lede { color: var(--bone-dim); }
.pl-list { display: flex; flex-direction: column; gap: 14px; margin-top: 24px; }
.pl-entry { padding: 18px 20px; border-radius: 14px; }
.pl-head { display: flex; align-items: center; gap: 10px; margin-bottom: 9px; }
.pl-ver { font-family: "IBM Plex Mono", ui-monospace, monospace; font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--noir); background: var(--reality-accent); padding: 3px 10px; border-radius: 999px; box-shadow: var(--facet-bevel); }
.pl-date { font-size: 11px; color: var(--bone-mute); letter-spacing: .04em; font-variant-numeric: tabular-nums; }
.pl-title { font-family: "Fraunces", Georgia, serif; font-weight: 500; font-size: 19px; margin: 0 0 11px; color: var(--bone); }
.pl-items { margin: 0; padding-left: 18px; display: flex; flex-direction: column; gap: 7px; }
.pl-items li { font-size: 14px; line-height: 1.55; color: var(--bone-dim); }
.pl-items li::marker { color: color-mix(in oklab, var(--spec-5) 70%, var(--gold)); }
.acct-menu [data-act="patch"].has-new::after { content: ""; display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: var(--prism-conic); margin-left: 8px; vertical-align: middle; box-shadow: 0 0 6px color-mix(in oklab,var(--spec-5) 80%,transparent); }
#avatarBtn { position: relative; }
#avatarBtn.has-new::after { content: ""; position: absolute; top: -1px; right: -1px; width: 8px; height: 8px; border-radius: 50%; background: var(--prism-conic); box-shadow: 0 0 7px color-mix(in oklab,var(--spec-5) 85%,transparent); pointer-events: none; }

/* ════════════════════════════════════════════════════════════════════════════
   COMPOSER REDESIGN — "PRISM PRECISION INSTRUMENT" · appended override #6 · wins last.
   A machined crystal slab + a focus-gated breathing caustic, a welded segmented
   model-toggle, an apex gem SEND, and Attach promoted into the toolbar. Reuses the
   EXISTING .intentbox::before (spectral edge) + ::after (corner tick); only NEW DOM
   is the .ibx-caustic child + #attachBtn. Reversible: delete this block + the markup.
   ════════════════════════════════════════════════════════════════════════════ */

/* 1. THE MACHINED CRYSTAL SLAB */
.prism-composer .intentbox{ position:relative; isolation:isolate; padding:18px 18px 14px; border-radius:var(--rad);
  background-image:var(--facet-sheen), linear-gradient(180deg,var(--glass-2),var(--glass-1)); background-blend-mode:var(--facet-sheen-blend),normal;
  -webkit-backdrop-filter:blur(var(--blur-panel)) saturate(1.08); backdrop-filter:blur(var(--blur-panel)) saturate(1.08); border:1px solid var(--glass-line);
  box-shadow: inset 0 1.5px 4px -2px color-mix(in oklab,#000 44%,transparent), inset 0 -1px 0 color-mix(in oklab,var(--bone) 9%,transparent), inset 0 0 0 1px color-mix(in oklab,var(--bone) 5%,transparent), 0 1px 0 color-mix(in oklab,var(--bone) 7%,transparent), var(--depth-1);
  transition:box-shadow var(--dur-2) var(--ease), border-color var(--dur-2) var(--ease), transform var(--dur-2) var(--ease-spring); }
html[data-theme="light"] .prism-composer .intentbox{ box-shadow: inset 0 1.5px 4px -2px color-mix(in oklab,#15161C 9%,transparent), inset 0 -1px 0 #fff, inset 0 0 0 1px color-mix(in oklab,#15161C 4%,transparent), 0 1px 0 #fff, 0 18px 44px -30px color-mix(in oklab,#15161C 22%,transparent); }
.prism-composer .intentbox > *{ position:relative; z-index:1; }
.prism-composer .intentbox textarea{ position:relative; z-index:2; min-height:120px; font-size:16px; line-height:1.55; caret-color:var(--spec-5); }
.prism-composer .intentbox textarea::placeholder{ color:var(--bone-mute); }
.prism-composer .intentbox:focus-within{ transform:translateY(-1px); border-color:var(--glass-line-bright);
  box-shadow: var(--facet-disperse), inset 0 0 0 1px color-mix(in oklab,var(--spec-4) 14%,transparent), 0 0 0 1px color-mix(in oklab,var(--spec-5) 30%,transparent), 0 0 34px -8px color-mix(in oklab,var(--spec-4) 40%,transparent), var(--depth-1); }

/* 2. THE LIVING TOP-CUT (reuse the existing .intentbox::before spectral hairline) */
.prism-composer .intentbox::before{ background:var(--edge-spectrum); background-size:220% 100%; opacity:.5; will-change:background-position, opacity; animation:cut-caustic 14s linear infinite; }
@keyframes cut-caustic{ 0%{ background-position:0% 0; } 100%{ background-position:220% 0; } }
.prism-composer .intentbox:focus-within::before{ opacity:.95; height:2px; animation-duration:7s; filter:drop-shadow(0 0 6px color-mix(in oklab,var(--spec-4) 60%,transparent)); }
.prism-composer .intentbox:focus-within::after{ border-left-color:color-mix(in oklab,var(--spec-3) 80%,transparent); border-top-color:color-mix(in oklab,var(--spec-3) 80%,transparent); }

/* 3. TRAPPED LIGHT — a faint always-on prism caustic inside the slab ("looking through crystal"),
   which BRIGHTENS on focus. Always-on so it can never get stuck off by a fragile focus-state path;
   the breathing ::before runs continuously (frozen under reduced-motion). z:0 behind the z:2 textarea. */
.prism-composer .intentbox .ibx-caustic{ position:absolute; inset:1px; z-index:0; pointer-events:none; border-radius:inherit; overflow:hidden; opacity:.08; transition:opacity var(--dur-3) var(--ease); }
html[data-theme="light"] .prism-composer .intentbox .ibx-caustic{ opacity:.05; }
.prism-composer .intentbox.ibx-on .ibx-caustic{ opacity:.22; }
html[data-theme="light"] .prism-composer .intentbox.ibx-on .ibx-caustic{ opacity:.11; }
.prism-composer .intentbox .ibx-caustic::before{ content:""; position:absolute; inset:-40%; background:var(--prism-conic); filter:blur(46px) saturate(1.2); mix-blend-mode:screen; will-change:transform; animation:ibx-breathe 9s ease-in-out infinite, ibx-drift 30s linear infinite; }
html[data-theme="light"] .prism-composer .intentbox .ibx-caustic::before{ mix-blend-mode:multiply; filter:blur(50px) saturate(1.1); }
@keyframes ibx-breathe{ 0%,100%{ transform:scale(1) rotate(0); } 50%{ transform:scale(1.08) rotate(8deg); } }
@keyframes ibx-drift{ from{ transform:rotate(0); } to{ transform:rotate(360deg); } }

/* 4. INTERNAL TOOLBAR + ATTACH */
.prism-composer .intent-foot{ display:flex; align-items:center; justify-content:flex-end; gap:12px; flex-wrap:wrap; margin-top:12px; padding-top:12px; border-top:1px solid var(--hairline); }
.prism-composer .intent-foot .ib-tools{ display:inline-flex; align-items:center; gap:8px; margin-right:auto; }
.prism-composer #attachBtn{ width:34px; height:34px; display:grid; place-items:center; border-radius:9px; border:1px solid var(--hairline-bright); background:color-mix(in oklab,var(--bone) 4%,transparent); color:var(--bone-dim); font-size:15px; cursor:pointer; box-shadow:var(--facet-bevel); transition:color var(--dur-1) var(--ease), border-color var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease); }
.prism-composer #attachBtn:hover{ color:var(--bone); border-color:color-mix(in oklab,var(--spec-5) 40%,transparent); box-shadow:var(--facet-bevel), 0 0 16px -6px color-mix(in oklab,var(--spec-5) 50%,transparent); }
.prism-composer #attachBtn.has-files{ color:var(--gold-bright); border-color:color-mix(in oklab,var(--spec-3) 50%,transparent); }

/* 5. MODEL TOGGLE — one welded engraved segmented control */
.prism-composer .model-toggle{ display:inline-flex; gap:0; padding:3px; border-radius:10px; background:linear-gradient(180deg, color-mix(in oklab,#000 18%,transparent), transparent); box-shadow: inset 0 1.5px 4px -2px color-mix(in oklab,#000 42%,transparent), inset 0 -1px 0 color-mix(in oklab,var(--bone) 8%,transparent); }
html[data-theme="light"] .prism-composer .model-toggle{ background:linear-gradient(180deg, color-mix(in oklab,#15161C 6%,transparent), transparent); box-shadow:inset 0 1.5px 4px -2px color-mix(in oklab,#15161C 8%,transparent), inset 0 -1px 0 #fff; }
.prism-composer .model-toggle button{ position:relative; border:0; background:none; box-shadow:none; border-radius:7px; padding:7px 14px; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--bone-dim); transition:color var(--dur-1) var(--ease), background var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease); }
.prism-composer .model-toggle button + button::before{ content:""; position:absolute; left:0; top:18%; bottom:18%; width:1px; background:var(--hairline-bright); opacity:.55; }
.prism-composer .model-toggle button:hover{ color:var(--bone); background:color-mix(in oklab,var(--bone) 5%,transparent); }
.prism-composer .model-toggle button.on{ color:var(--bone); background:linear-gradient(180deg, color-mix(in oklab,var(--bone) 11%,transparent), color-mix(in oklab,var(--bone) 4%,transparent)); box-shadow: inset 0 1px 0 color-mix(in oklab,var(--bone) 22%,transparent), 0 1px 6px -3px color-mix(in oklab,#000 60%,transparent); }
.prism-composer .model-toggle button.on::before, .prism-composer .model-toggle button.on + button::before{ opacity:0; }
.prism-composer .model-toggle .prism-opt.on::after{ content:""; position:absolute; left:12px; right:12px; bottom:3px; height:1.5px; border-radius:2px; background:var(--edge-spectrum); opacity:.85; }
html[data-theme="light"] .prism-composer .model-toggle button.on{ color:var(--bone); background:linear-gradient(180deg,#fff, color-mix(in oklab,#fff 70%,transparent)); box-shadow:inset 0 1px 0 #fff, 0 1px 6px -3px color-mix(in oklab,#15161C 18%,transparent); }

/* 6. SEND — apex faceted GEM (keeps the .btn base + the kept .btn::after sweep) */
.prism-composer #goBtn{ position:relative; overflow:hidden; padding:13px 24px; border-radius:var(--rad-sm); letter-spacing:.14em;
  background:linear-gradient(157deg, color-mix(in oklab,var(--bone) 18%,var(--reality-accent)) 0%, var(--reality-accent) 42%, color-mix(in oklab,#000 12%,var(--reality-accent)) 100%);
  box-shadow: inset 0 1px 0 color-mix(in oklab,var(--bone) 40%,transparent), inset 0 -1px 0 color-mix(in oklab,#000 30%,transparent), var(--facet-bevel), 0 8px 22px -12px color-mix(in oklab,var(--gold-deep) 80%,transparent);
  transition:box-shadow var(--dur-2) var(--ease), transform var(--dur-1) var(--ease-spring); }
.prism-composer #goBtn::before{ content:""; position:absolute; inset:0; pointer-events:none; z-index:0; border-radius:inherit; background:linear-gradient(124deg, transparent 38%, color-mix(in oklab,var(--bone) 22%,transparent) 50%, transparent 62%); opacity:.6; }
.prism-composer #goBtn:hover{ transform:translateY(-1px); box-shadow: inset 0 1px 0 color-mix(in oklab,var(--bone) 50%,transparent), inset 0 -1px 0 color-mix(in oklab,#000 30%,transparent), var(--facet-bevel), var(--facet-disperse), 0 12px 30px -12px color-mix(in oklab,var(--spec-5) 50%,transparent); }
.prism-composer #goBtn:active{ transform:translateY(0) scale(.985); }
.prism-composer #goBtn.loading{ pointer-events:none; }
.prism-composer #goBtn.loading::before{ animation:gem-glint 1.1s var(--ease-soft) infinite; }
@keyframes gem-glint{ 0%{ transform:translateX(-30%); opacity:0; } 40%{ opacity:.7; } 100%{ transform:translateX(30%); opacity:0; } }
html[data-theme="light"] .prism-composer #goBtn{ background:linear-gradient(157deg, color-mix(in oklab,#fff 10%,var(--reality-accent)) 0%, var(--reality-accent) 44%, #0A0B10 100%); box-shadow:inset 0 1px 0 color-mix(in oklab,#fff 35%,transparent), inset 0 -1px 0 color-mix(in oklab,#000 40%,transparent), var(--facet-bevel), 0 8px 22px -12px color-mix(in oklab,#15161C 40%,transparent); }

/* 7. MUSE — confident spectral-edge capability key */
.prism-composer .muse-row{ margin-top:14px; }
.prism-composer .muse-cta{ width:100%; text-align:left; display:flex; align-items:center; gap:10px; border:1px solid var(--hairline-bright); border-radius:var(--rad-sm); background:linear-gradient(180deg, color-mix(in oklab,var(--bone) 4%,transparent), transparent); padding:11px 14px; color:var(--bone-dim); box-shadow:var(--facet-bevel); transition:color var(--dur-2) var(--ease), border-color var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease); }
.prism-composer .muse-cta b{ color:var(--bone); font-weight:600; }
.prism-composer .muse-cta:hover, .prism-composer .muse-cta.on{ color:var(--bone); border-color:color-mix(in oklab,var(--spec-6) 40%,transparent); box-shadow:var(--facet-bevel), 0 0 20px -8px color-mix(in oklab,var(--spec-6) 45%,transparent); }

/* 8. CHIPS — Shape + files + seeds as engraved tactile keys */
.prism-composer .arch-chips button, .prism-composer .img-chips button, .prism-composer .seed-chips button{ border:1px solid var(--hairline); border-radius:999px; padding:7px 14px; font-size:12px; color:var(--bone-dim); background:color-mix(in oklab,var(--bone) 3%,transparent); box-shadow:var(--facet-bevel); transition:color var(--dur-1) var(--ease), border-color var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease), transform var(--dur-1) var(--ease-spring); }
.prism-composer .arch-chips button:hover, .prism-composer .img-chips button:hover, .prism-composer .seed-chips button:hover{ color:var(--bone); border-color:var(--hairline-bright); box-shadow:var(--facet-bevel), var(--facet-disperse); transform:translateY(-1px); }
.prism-composer .arch-chips button.on, .prism-composer .img-chips button.on{ color:var(--gold-bright); font-weight:600; border-color:color-mix(in oklab,var(--spec-4) 45%,transparent); background:linear-gradient(180deg, color-mix(in oklab,var(--bone) 12%,transparent), color-mix(in oklab,var(--bone) 4%,transparent)); box-shadow:inset 0 1px 0 color-mix(in oklab,var(--bone) 24%,transparent), 0 0 16px -8px color-mix(in oklab,var(--spec-4) 45%,transparent); }
.prism-composer .arch-lbl, .prism-composer .arch-opt{ color:var(--bone-mute); }
.prism-composer .seeds .eyebrow{ letter-spacing:.34em; }
.prism-composer .deploy-note{ margin-top:14px; padding-left:14px; border-left:1px solid var(--hairline-bright); color:var(--bone-mute); }
.prism-composer .deploy-note b{ color:var(--bone-dim); font-weight:500; }

/* 9. MOTION FREEZE */
@media (prefers-reduced-motion: reduce){
  .prism-composer .intentbox::before{ animation:none; background-position:0 0; }
  .prism-composer .intentbox:focus-within::before{ animation:none; }
  .prism-composer .intentbox .ibx-caustic::before, .prism-composer .intentbox.ibx-on .ibx-caustic::before{ animation:none; }
  .prism-composer #goBtn.loading::before{ animation:none; opacity:.4; }
}
body.reduce-motion .prism-composer .intentbox::before{ animation:none; background-position:0 0; }
body.reduce-motion .prism-composer .intentbox:focus-within::before{ animation:none; }
body.reduce-motion .prism-composer .intentbox .ibx-caustic::before, body.reduce-motion .prism-composer .intentbox.ibx-on .ibx-caustic::before{ animation:none; }
body.reduce-motion .prism-composer #goBtn.loading::before{ animation:none; opacity:.4; }

/* 10. MOBILE: drop the slab backdrop-blur to protect INP on low-end devices */
@media (max-width:560px){ .prism-composer .intentbox{ -webkit-backdrop-filter:none; backdrop-filter:none; } .prism-composer .intent-foot{ gap:10px; } }

/* ════════════════════════════════════════════════════════════════════════════
   PRISM STUDIO — Max guided architect for CRMs / internal tools / data apps.
   ════════════════════════════════════════════════════════════════════════════ */
.studio-row{ margin-top:10px; }
.studio-cta{ width:100%; text-align:left; display:flex; align-items:center; gap:8px; flex-wrap:wrap; border:1px solid color-mix(in oklab,var(--spec-6) 30%,var(--hairline-bright)); border-radius:var(--rad-sm); background:linear-gradient(180deg, color-mix(in oklab,var(--spec-6) 8%,transparent), transparent); padding:11px 14px; color:var(--bone-dim); cursor:pointer; box-shadow:var(--facet-bevel); transition:color var(--dur-2) var(--ease), border-color var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease); }
.studio-cta b{ color:var(--bone); font-weight:600; }
.studio-cta:hover{ color:var(--bone); border-color:color-mix(in oklab,var(--spec-6) 55%,transparent); box-shadow:var(--facet-bevel), 0 0 22px -8px color-mix(in oklab,var(--spec-6) 50%,transparent); }
.studio-badge{ margin-left:auto; font-family:"IBM Plex Mono",ui-monospace,monospace; font-size:9px; letter-spacing:.16em; padding:3px 8px; border-radius:999px; color:var(--noir); background:var(--prism-full); background-size:200% 100%; box-shadow:var(--facet-bevel); }

.studio{ max-width:720px; margin:3vh auto 0; text-align:left; }
.studio-gate{ max-width:620px; margin:7vh auto 0; text-align:center; }
.studio-gate h1{ font-family:var(--fd); font-size:clamp(28px,5vw,46px); line-height:1.05; margin:14px 0 12px; }
.studio-gate h1 em{ font-style:italic; background:var(--prism-full); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.studio-gate .lede{ color:var(--bone-dim); max-width:520px; margin:0 auto 26px; line-height:1.6; }
.st-head{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:18px; }
.st-prog{ display:flex; gap:6px; }
.st-dot{ width:22px; height:4px; border-radius:2px; background:var(--hairline); transition:background var(--dur-2) var(--ease); }
.st-dot.on{ background:var(--edge-spectrum); }
.st-dot.done{ background:color-mix(in oklab,var(--spec-5) 55%,transparent); }
.st-q{ font-family:var(--fd); font-weight:500; font-size:clamp(22px,3.5vw,30px); line-height:1.12; margin:0 0 8px; color:var(--bone); display:flex; align-items:center; gap:11px; }
.st-hint{ color:var(--bone-mute); font-size:14px; line-height:1.55; margin:0 0 18px; }
.st-chips{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:14px; }
.st-chip{ border:1px solid var(--hairline); border-radius:999px; padding:8px 15px; font-size:13px; color:var(--bone-dim); background:color-mix(in oklab,var(--bone) 3%,transparent); box-shadow:var(--facet-bevel); cursor:pointer; transition:color var(--dur-1) var(--ease), border-color var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease), transform var(--dur-1) var(--ease-spring); }
.st-chip:hover{ color:var(--bone); border-color:var(--hairline-bright); transform:translateY(-1px); box-shadow:var(--facet-bevel), var(--facet-disperse); }
.st-chip.on{ color:var(--gold-bright); font-weight:600; border-color:color-mix(in oklab,var(--spec-4) 50%,transparent); background:linear-gradient(180deg, color-mix(in oklab,var(--bone) 12%,transparent), color-mix(in oklab,var(--bone) 4%,transparent)); box-shadow:inset 0 1px 0 color-mix(in oklab,var(--bone) 22%,transparent), 0 0 16px -8px color-mix(in oklab,var(--spec-4) 50%,transparent); }
.st-input{ width:100%; resize:vertical; min-height:74px; background:var(--noir); border:1px solid var(--glass-line); border-radius:var(--rad-sm); padding:12px 14px; color:var(--bone); font-size:15px; line-height:1.5; box-shadow:inset 0 1.5px 4px -2px color-mix(in oklab,#000 40%,transparent); transition:border-color var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease); }
html[data-theme="light"] .st-input{ box-shadow:inset 0 1.5px 4px -2px color-mix(in oklab,#15161C 8%,transparent); }
.st-input:focus{ outline:none; border-color:var(--glass-line-bright); box-shadow:var(--facet-disperse), 0 0 0 1px color-mix(in oklab,var(--spec-5) 28%,transparent); }
.st-input::placeholder{ color:var(--bone-mute); }
.st-actions{ display:flex; align-items:center; gap:12px; margin-top:20px; }
.st-step{ font-family:"IBM Plex Mono",ui-monospace,monospace; font-size:11px; color:var(--bone-mute); letter-spacing:.08em; }
.st-review{ padding:6px 18px; border-radius:14px; margin-bottom:16px; }
.st-rrow{ display:flex; gap:16px; padding:13px 0; border-bottom:1px solid var(--hairline); }
.st-rrow:last-child{ border-bottom:0; }
.st-rk{ flex:0 0 38%; color:var(--bone-mute); font-size:13px; }
.st-rv{ flex:1; color:var(--bone); font-size:14px; line-height:1.5; }
@media (max-width:560px){ .st-rrow{ flex-direction:column; gap:3px; } .st-rk{ flex:none; } }

/* ════════════════════════════════════════════════════════════════════════════
   TOPBAR / CREDITS — everything fits its container. The right cluster (credits ·
   upgrade · avatar) must NEVER shrink or clip; the brand + nav yield space first.
   (The base .tb-right had min-width:0, letting it squeeze the pill on a crowded bar.)
   ════════════════════════════════════════════════════════════════════════════ */
.tb-right { flex-shrink: 0; min-width: auto; }
.credits-pill, .upgrade-pill { flex-shrink: 0; white-space: nowrap; }
.credits-pill b, #creditsN { white-space: nowrap; }
.brand { min-width: 0; flex-shrink: 1; overflow: hidden; }
.brand .mk { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
.topnav { flex-shrink: 1; min-width: 0; flex-wrap: wrap; row-gap: 4px; }
/* Subscribe nav button reads as the conversion action — a subtle crystal fill. */
.topnav button[data-nav="subscribe"] { border-color: color-mix(in oklab, var(--spec-6) 34%, transparent); color: var(--bone); }
.topnav button[data-nav="subscribe"].active { color: var(--gold-bright); border-color: color-mix(in oklab, var(--gold) 50%, transparent); }
/* subscribe page + studio reuse the existing landing-sec / plan-card styling; light niceties */
.subscribe { max-width: 1000px; margin: 0 auto; }
.subscribe .sub-hero { text-align: center; max-width: 720px; margin: 3vh auto 8px; }
.subscribe .sub-hero h1 { font-family: var(--fd); font-size: clamp(30px, 5vw, 52px); line-height: 1.04; margin: 12px 0; }
.subscribe .sub-hero h1 em { font-style: italic; background: var(--prism-full); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.subscribe .sub-hero .lede { color: var(--bone-dim); margin: 0 auto; line-height: 1.6; }
.subscribe .sub-plans { margin: 26px 0 10px; }
.subscribe .sub-faq { max-width: 920px; margin: 40px auto 0; }

/* Studio v2 — per-phase "ask PRISM to suggest" + AI-suggested chips */
.st-suggest-row { margin: -4px 0 14px; }
.st-suggest { font-size: 12px; color: var(--bone-dim); border: 1px solid color-mix(in oklab,var(--spec-6) 32%,transparent); border-radius: 999px; padding: 7px 14px; background: linear-gradient(180deg, color-mix(in oklab,var(--spec-6) 8%,transparent), transparent); box-shadow: var(--facet-bevel); cursor: pointer; transition: color var(--dur-1) var(--ease), border-color var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease); }
.st-suggest:hover { color: var(--bone); border-color: color-mix(in oklab,var(--spec-6) 55%,transparent); box-shadow: var(--facet-bevel), 0 0 16px -6px color-mix(in oklab,var(--spec-6) 50%,transparent); }
.st-suggest:disabled { opacity: .6; cursor: default; }
.st-chip.ai { border-color: color-mix(in oklab,var(--spec-5) 40%,transparent); }
.st-chip.ai::before { content: "✦ "; color: color-mix(in oklab,var(--spec-5) 80%,var(--gold)); }

/* ════════════════════════════════════════════════════════════════════════════
   TOP-UP CREDITS — fit the container (flex, last row fills — no empty cell) + LTV polish.
   ════════════════════════════════════════════════════════════════════════════ */
.tiers { display: flex; flex-wrap: wrap; gap: 8px; }
.tiers .tier { flex: 1 1 110px; min-width: 104px; padding: 13px 8px 12px; }
.tier .tbuilds { font-size: 10px; color: var(--bone-mute); margin-top: 2px; }
.tier .tfree { color: var(--spec-4); font-weight: 600; }
.tier.best { box-shadow: 0 0 18px -8px color-mix(in oklab, var(--spec-4) 55%, transparent); }
.topup-sub { font-size: 11.5px; color: var(--bone-dim); text-align: left; line-height: 1.5; margin: 0 0 10px; }
.buy-h { font-size: 10px; }
@media (max-width: 430px) { .tiers .tier { flex: 1 1 44%; } }

/* ════════════════════════════════════════════════════════════════════════════
   MODULE DOCK (PRISM X · "the soul") — one-screen bottom dock in the Workspace.
   flex-shrink:0 so the stage + rail reflow above it; the module row scrolls horizontally.
   ════════════════════════════════════════════════════════════════════════════ */
.ws-v2 .ws-dock { flex-shrink: 0; display: flex; flex-direction: column; gap: 8px; padding: 9px clamp(10px, 1.2vw, 14px) 10px; border-radius: 14px; }
.ws-v2 .ws-dock-cats { display: flex; gap: 6px; flex-wrap: wrap; }
.ws-dock-cat { font-size: 10px; letter-spacing: .09em; text-transform: uppercase; color: var(--bone-mute); border: 1px solid var(--noir-line); background: transparent; border-radius: 999px; padding: 4px 11px; cursor: pointer; transition: color .2s var(--ease), border-color .2s var(--ease), background .2s var(--ease); }
.ws-dock-cat:hover { color: var(--bone-dim); }
.ws-dock-cat.on { color: var(--crystal, var(--gold-bright)); border-color: color-mix(in oklab, var(--crystal, var(--gold)) 45%, transparent); background: color-mix(in oklab, var(--crystal, var(--gold)) 9%, transparent); }
.ws-dock-mods { display: flex; gap: 6px; overflow-x: auto; scrollbar-width: none; padding-bottom: 1px; }
.ws-dock-mods::-webkit-scrollbar { display: none; }
.ws-dock-mod { flex: 0 0 auto; font-size: 12px; color: var(--bone-dim); border: 1px solid var(--noir-line); background: color-mix(in oklab, var(--bone) 3%, transparent); border-radius: 999px; padding: 6px 13px; cursor: pointer; box-shadow: var(--facet-bevel); white-space: nowrap; transition: color .15s var(--ease), border-color .15s var(--ease), transform .15s var(--ease); }
.ws-dock-mod::before { content: "+ "; color: color-mix(in oklab, var(--spec-5, var(--gold)) 75%, var(--gold)); }
.ws-dock-mod:hover { color: var(--bone); border-color: color-mix(in oklab, var(--spec-5, var(--gold)) 40%, transparent); transform: translateY(-1px); }
@media (max-width: 820px) { .ws-v2 .ws-dock { padding: 7px 10px 8px; } .ws-dock-mod { font-size: 11.5px; padding: 7px 12px; } }

/* ════════════════════════════════════════════════════════════════════════════
   PRISM FACES — the companion rail is a prism; switching faces TURNS it with a
   spectral light refraction while the build (left-stage iframe) never remounts,
   so the build stays fully intact across faces. Compositor-only (transform +
   opacity), reduced-motion safe (the JS skips the turn; the @media is a backstop).
   ════════════════════════════════════════════════════════════════════════════ */
.ws-rail-body { perspective: 1500px; perspective-origin: right center; }
.ws-rail-body .face-refraction { position: absolute; inset: 0; z-index: 6; pointer-events: none; opacity: 0; border-radius: inherit;
  background: linear-gradient(108deg, transparent 28%, color-mix(in oklab, var(--spec-1) 55%, transparent), color-mix(in oklab, var(--spec-3) 55%, transparent), color-mix(in oklab, var(--spec-4) 55%, transparent), color-mix(in oklab, var(--spec-6) 55%, transparent), transparent 72%);
  background-size: 280% 100%; mix-blend-mode: screen; }
.ws-rail-body .face-refraction.go { animation: faceRefract .52s ease-out; }
@keyframes faceRefract { 0% { opacity: 0; background-position: 130% 0; } 28% { opacity: .85; } 100% { opacity: 0; background-position: -30% 0; } }
.ws-rail-body .ws-tabpane.face-enter { z-index: 3; transform-origin: right center; animation: faceTurnIn .47s cubic-bezier(.22,.61,.36,1) both; }
.ws-rail-body .ws-tabpane.face-exit { z-index: 2; transform-origin: right center; pointer-events: none; animation: faceTurnOut .47s cubic-bezier(.4,0,.55,1) both; }
@keyframes faceTurnIn { from { opacity: 0; transform: perspective(1500px) rotateY(-26deg) translateZ(-46px); } to { opacity: 1; transform: none; } }
@keyframes faceTurnOut { from { opacity: 1; transform: none; } to { opacity: 0; transform: perspective(1500px) rotateY(16deg) translateZ(-34px); } }

/* face switcher — prismatic active state (a spectral underline instead of the flat gold one) */
.ws-v2 .ws-faces button { position: relative; }
.ws-v2 .ws-faces button.on { color: var(--crystal, var(--gold-bright)); border-bottom-color: transparent; }
.ws-v2 .ws-faces button.on::after { content: ""; position: absolute; left: 9px; right: 9px; bottom: -1px; height: 2px; border-radius: 2px; background: linear-gradient(90deg, var(--spec-1), var(--spec-3), var(--spec-4), var(--spec-6)); box-shadow: 0 0 9px color-mix(in oklab, var(--spec-4) 55%, transparent); }

/* VISUALS face — the generate-a-visual composer (stay in your build, art lands on the left) */
.vis-gen { display: flex; flex-direction: column; gap: 9px; padding: 12px; border: 1px solid color-mix(in oklab, var(--spec-5) 24%, var(--noir-line)); border-radius: 12px; background: color-mix(in oklab, var(--spec-6) 5%, transparent); box-shadow: var(--facet-bevel); }
.vis-gen-k { font-size: 11px; letter-spacing: .04em; color: var(--crystal, var(--gold-bright)); }
.vis-gen textarea { width: 100%; resize: none; border: 1px solid var(--noir-line); border-radius: 9px; background: color-mix(in oklab, var(--noir-void) 60%, transparent); color: var(--bone); padding: 9px 10px; font: inherit; font-size: 13px; box-sizing: border-box; }
.vis-gen textarea:focus { outline: none; border-color: color-mix(in oklab, var(--spec-5) 50%, transparent); }
.vis-quick { display: flex; flex-wrap: wrap; gap: 6px; }
.vis-chip { font-size: 11.5px; color: var(--bone-dim); border: 1px solid var(--noir-line); background: transparent; border-radius: 999px; padding: 5px 11px; cursor: pointer; transition: color .15s var(--ease), border-color .15s var(--ease); }
.vis-chip::before { content: "✦ "; color: color-mix(in oklab, var(--spec-5) 75%, var(--gold)); }
.vis-chip:hover { color: var(--bone); border-color: color-mix(in oklab, var(--spec-5) 42%, transparent); }
.vis-gen .btn.xs { align-self: flex-start; }
.vis-gen-hint { font-size: 10.5px; color: var(--bone-mute); line-height: 1.45; }
.vis-sep { display: flex; align-items: center; gap: 10px; margin: 14px 0 10px; color: var(--bone-mute); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; }
.vis-sep::before, .vis-sep::after { content: ""; height: 1px; flex: 1; background: linear-gradient(90deg, transparent, var(--noir-line), transparent); }

@media (prefers-reduced-motion: reduce) {
  .ws-rail-body .ws-tabpane.face-enter, .ws-rail-body .ws-tabpane.face-exit { animation: none; }
  .ws-rail-body .face-refraction.go { animation: none; }
}

/* AGENTS face — one-click expert-pass cards */
.agent-team { display: flex; flex-direction: column; gap: 11px; padding: 4px 2px; }
.agent-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; }
.agent-card { display: flex; flex-direction: column; align-items: flex-start; gap: 4px; text-align: left; padding: 12px; border: 1px solid var(--noir-line); border-radius: 12px; background: color-mix(in oklab, var(--bone) 3%, transparent); box-shadow: var(--facet-bevel); cursor: pointer; transition: border-color .15s var(--ease), transform .15s var(--ease), background .15s var(--ease); }
.agent-card:hover { border-color: color-mix(in oklab, var(--spec-5) 42%, transparent); transform: translateY(-2px); background: color-mix(in oklab, var(--spec-6) 6%, transparent); }
.agent-ico { font-size: 19px; line-height: 1; }
.agent-name { font-size: 13px; font-weight: 600; color: var(--bone); letter-spacing: .01em; }
.agent-desc { font-size: 10.5px; color: var(--bone-mute); line-height: 1.4; }
@media (max-width: 560px) { .agent-grid { grid-template-columns: 1fr; } }

/* PRISM COMMAND PALETTE (⌘K) — overlay launcher for faces + quick actions */
.cmdk { position: fixed; inset: 0; z-index: 200; background: color-mix(in oklab, var(--noir-void) 68%, transparent); backdrop-filter: blur(4px); display: grid; place-items: start center; padding-top: 13vh; }
.cmdk[hidden] { display: none; }
.cmdk-box { width: min(560px, 92vw); background: var(--noir-soft); border: 1px solid color-mix(in oklab, var(--spec-5) 30%, var(--noir-line)); border-radius: 14px; box-shadow: 0 34px 90px -22px rgba(0,0,0,.72), var(--facet-bevel); overflow: hidden; }
.cmdk-input { width: 100%; box-sizing: border-box; border: 0; border-bottom: 1px solid var(--noir-line); background: transparent; color: var(--bone); font: inherit; font-size: 15px; padding: 15px 18px; outline: none; }
.cmdk-list { max-height: 46vh; overflow: auto; padding: 6px; scrollbar-width: thin; }
.cmdk-item { width: 100%; display: flex; justify-content: space-between; align-items: center; gap: 12px; text-align: left; background: transparent; border: 0; border-radius: 9px; padding: 9px 12px; color: var(--bone-dim); font-size: 13.5px; cursor: pointer; }
.cmdk-item.on, .cmdk-item:hover { background: color-mix(in oklab, var(--spec-5) 13%, transparent); color: var(--bone); }
.cmdk-hint { font-size: 9.5px; letter-spacing: .09em; text-transform: uppercase; color: var(--bone-mute); flex-shrink: 0; }
.cmdk-empty { padding: 18px; text-align: center; color: var(--bone-mute); font-size: 13px; }
.ws-cmdk-btn { font-variant-numeric: tabular-nums; letter-spacing: .02em; }
@media (prefers-reduced-motion: reduce) { .cmdk { backdrop-filter: none; } }

/* ════════ WORKSPACE — FIT ANY DEVICE (mobile overhaul, appended last → wins) ════════
   Root cause: the flex/grid items had min-width:auto, so .ws-v2 refused to shrink below its
   content's min-content (~770px) and got clipped at the viewport (half the workspace off-screen).
   Fix = the min-width:0 cascade + a compact swipeable action bar + fixed-tabbar clearance. */
.ws-v2, .ws-v2 .ws-body, .ws-v2 .ws-stage-wrap, .ws-v2 .ws-rail, .ws-bar-l, .ws-bar-r { min-width: 0; }
.ws-v2 .ws-stage iframe.app-frame { max-width: 100%; }
@media (max-width: 820px) {
  /* the multi-button bar becomes ONE compact swipeable row (never forces width or wraps tall) */
  .ws-bar-r { flex-wrap: nowrap; overflow-x: auto; overflow-y: hidden; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
  .ws-bar-r::-webkit-scrollbar { display: none; }
  .ws-bar-r > * { flex: 0 0 auto; }
  .ws-v2 .ws-dock { display: none; } /* module dock = desktop power-tool → hide on mobile so the rail/concierge gets room (components stay addable via the Refine chat) */
  .ws-quick { flex-wrap: nowrap; overflow-x: auto; overflow-y: hidden; scrollbar-width: none; padding-bottom: 2px; } /* Next-moves → one swipeable row so the concierge input stays visible */
  .ws-quick::-webkit-scrollbar { display: none; }
  .ws-quick .ws-chip { flex: 0 0 auto; }
  .ws-v2 .ws-body { grid-template-columns: 1fr; grid-template-rows: minmax(180px, 36vh) minmax(0, 1fr); }
  .ws-v2 { padding-bottom: calc(66px + env(safe-area-inset-bottom, 0px)); } /* clear the mobile tabbar */
}
@media (max-width: 560px) {
  .ws-v2 { padding: 8px 8px calc(66px + env(safe-area-inset-bottom, 0px)); gap: 8px; }
  .ws-bar { padding: 8px 11px; gap: 6px; }
  .ws-bar-l { gap: 8px; }
  .ws-title { font-size: 15px; max-width: 58vw; }
  .ws-v2 .ws-body { grid-template-rows: minmax(170px, 34vh) minmax(0, 1fr); gap: 8px; }
  .ws-rail-body .ws-tabpane { padding: 11px; }
  .ws-quick { gap: 5px; }
}
@media (max-width: 380px) {
  .ws-title { max-width: 50vw; }
  .ws-v2 .ws-body { grid-template-rows: minmax(150px, 30vh) minmax(0, 1fr); }
  .ws-bar-r .btn-ghost.xs { padding: 6px 9px; font-size: 11px; }
}

/* one-click theme toggle in the top bar (light/dark discoverable, not buried in the menu) */
.theme-toggle { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 10px; border: 1px solid var(--noir-line); background: transparent; color: var(--bone-dim); cursor: pointer; flex-shrink: 0; transition: color .18s var(--ease), border-color .18s var(--ease), background .18s var(--ease); }
.theme-toggle svg { width: 18px; height: 18px; }
.theme-toggle:hover { color: var(--gold-bright); border-color: color-mix(in oklab, var(--gold) 42%, transparent); background: color-mix(in oklab, var(--gold-deep) 12%, transparent); }
@media (max-width: 560px) { .theme-toggle { width: 32px; height: 32px; } }

/* ════════════════════════════════════════════════════════════════════════════
   FOUNDING EARLY ACCESS — high-converting pre-launch landing + founder home.
   Spacious, spectral, premium; built on the galaxy-crystal system.
   ════════════════════════════════════════════════════════════════════════════ */
.early { max-width: 1100px; margin: 0 auto; padding: 0 clamp(16px, 4vw, 28px); overflow-x: clip; } /* clip is sticky-safe + doesn't force a scroll container — kills the sideways scroll from the decorative bloom */
.early-hero { position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: clamp(46px, 9vh, 104px) 0 0; }
.early-eyebrow { color: var(--crystal, var(--gold-bright)); font-size: 11.5px; letter-spacing: .2em; }
.early-h1 { font-family: "Fraunces", Georgia, serif; font-weight: 400; font-size: clamp(40px, 8.4vw, 92px); line-height: 1.02; letter-spacing: -.015em; margin: 18px 0 0; color: var(--bone); }
.early-h1 em { font-style: italic; background: linear-gradient(100deg, var(--spec-1), var(--spec-3), var(--spec-4), var(--spec-6)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.early-lede { max-width: 640px; margin: 22px auto 0; font-size: clamp(15px, 2vw, 18.5px); line-height: 1.62; color: var(--bone-dim); }
.early-lede.sm { font-size: 15px; max-width: 560px; }
.early-cta-row { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-top: 30px; }
.early-go { box-shadow: 0 10px 34px -10px color-mix(in oklab, var(--spec-5) 52%, transparent); }
.early-seats { display: inline-flex; align-items: center; gap: 8px; margin-top: 22px; font-size: 12px; letter-spacing: .03em; color: var(--bone-mute); }
.early-livedot { width: 7px; height: 7px; border-radius: 50%; background: var(--spec-4); animation: ea-pulse 2.4s ease-out infinite; }
@keyframes ea-pulse { 0% { box-shadow: 0 0 0 0 color-mix(in oklab, var(--spec-4) 60%, transparent); } 70%,100% { box-shadow: 0 0 0 9px transparent; } }
/* prism-dispersion aura behind the headline */
.early-aura { position: absolute; inset: 0; display: grid; place-items: center; pointer-events: none; z-index: 0; }
.early-hero > :not(.early-aura) { position: relative; z-index: 1; }
.early-prism { width: clamp(360px, 88%, 780px); aspect-ratio: 1.5; border-radius: 50%; background: radial-gradient(ellipse at 50% 40%, color-mix(in oklab, var(--spec-4) 20%, transparent), color-mix(in oklab, var(--spec-6) 12%, transparent) 36%, color-mix(in oklab, var(--spec-1) 7%, transparent) 54%, transparent 72%); filter: blur(26px); transform: translateY(-16%); animation: ea-breathe 8s ease-in-out infinite; }
@keyframes ea-breathe { 0%,100% { opacity: .78; transform: translateY(-8%) scale(1); } 50% { opacity: 1; transform: translateY(-8%) scale(1.06); } }
.early-aura .er { display: none; } /* removed the one-sided rays — they read as stray lines; the soft bloom is cleaner */
.er1 { transform: rotate(-26deg); background: linear-gradient(90deg, transparent, var(--spec-1)); }
.er2 { transform: rotate(-13deg); background: linear-gradient(90deg, transparent, var(--spec-2)); }
.er3 { transform: rotate(0deg); background: linear-gradient(90deg, transparent, var(--spec-4)); }
.er4 { transform: rotate(13deg); background: linear-gradient(90deg, transparent, var(--spec-5)); }
.er5 { transform: rotate(26deg); background: linear-gradient(90deg, transparent, var(--spec-6)); }
/* showcase marquee */
.early-marquee { overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent); mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent); margin: clamp(30px, 4vh, 46px) 0 clamp(6px, 1.5vh, 16px); }
.early-track { display: inline-flex; gap: 10px; white-space: nowrap; animation: ea-marquee 40s linear infinite; will-change: transform; }
@keyframes ea-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.early-chip { flex: 0 0 auto; font-size: 13.5px; color: var(--bone-dim); border: 1px solid var(--noir-line); border-radius: 999px; padding: 8px 16px; background: color-mix(in oklab, var(--bone) 3%, transparent); }
.early-chip::before { content: "“"; color: var(--bone-mute); }
.early-chip::after { content: "”"; color: var(--bone-mute); }
/* sections */
.early-feat, .early-plans, .early-final { text-align: center; padding: clamp(34px, 5vh, 58px) 0; }
.early-h2 { font-family: "Fraunces", Georgia, serif; font-weight: 400; font-size: clamp(28px, 5vw, 46px); line-height: 1.1; color: var(--bone); margin: 14px 0 0; }
.early-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 30px; text-align: left; }
.early-card { padding: 24px; border-radius: 16px; transition: transform .25s var(--ease), border-color .25s var(--ease); }
.early-card:hover { transform: translateY(-4px); border-color: color-mix(in oklab, var(--spec-5) 35%, var(--noir-line)); }
.early-ico { display: inline-grid; place-items: center; width: 42px; height: 42px; border-radius: 12px; font-size: 20px; background: color-mix(in oklab, var(--spec-6) 12%, transparent); border: 1px solid color-mix(in oklab, var(--spec-5) 24%, transparent); color: var(--crystal, var(--gold-bright)); }
.early-card h3 { font-size: 17px; margin: 14px 0 6px; color: var(--bone); }
.early-card p { font-size: 13.5px; line-height: 1.55; color: var(--bone-dim); margin: 0; }
.early-plans { padding-top: clamp(14px, 2.5vh, 26px); }
.early-plans .sub-plans { margin-top: 26px; }
.early-final { padding-top: clamp(40px, 6vh, 70px); padding-bottom: clamp(48px, 8vh, 88px); }
/* founder home (post-purchase) */
.early-home .early-hero { min-height: auto; padding-top: clamp(40px, 7vh, 80px); }
.early-status { max-width: 440px; margin: 30px auto 0; padding: 18px 20px; border-radius: 14px; text-align: left; display: flex; flex-direction: column; gap: 12px; }
.es-row { display: flex; justify-content: space-between; align-items: center; gap: 12px; font-size: 13.5px; }
.es-row > span { color: var(--bone-mute); }
.es-row b { color: var(--bone); }
.es-live { color: var(--spec-4) !important; }
.early-trust { margin-top: 18px; font-size: 12.5px; color: var(--bone-mute); }
.early-feat-h { text-align: center; margin-bottom: 6px; }
@media (max-width: 760px) { .early-grid { grid-template-columns: 1fr; } .early-h1 br { display: none; } }
@media (prefers-reduced-motion: reduce) { .early-prism, .early-livedot, .early-track { animation: none; } }

/* ════════════════════════════════════════════════════════════════════════════
   CINEMATIC PRODUCT SHOTS — CSS-built "screenshots" of the app for the landing.
   A browser frame (.appshot) wrapping a faithful mockup of the Workspace / built apps.
   ════════════════════════════════════════════════════════════════════════════ */
.appshot { border-radius: 14px; overflow: hidden; background: var(--noir-soft); border: 1px solid color-mix(in oklab, var(--spec-6) 16%, var(--noir-line)); box-shadow: 0 60px 130px -46px rgba(0,0,0,.85), 0 0 0 1px color-mix(in oklab, var(--bone) 5%, transparent), 0 0 90px -30px color-mix(in oklab, var(--spec-5) 40%, transparent); }
.ash-chrome { display: flex; align-items: center; gap: 7px; padding: 10px 14px; background: color-mix(in oklab, var(--noir-void) 60%, var(--noir)); border-bottom: 1px solid var(--noir-line); }
.ash-dot { width: 10px; height: 10px; border-radius: 50%; background: color-mix(in oklab, var(--bone) 18%, transparent); }
.ash-dot:nth-child(1) { background: color-mix(in oklab, var(--spec-1) 60%, transparent); }
.ash-dot:nth-child(2) { background: color-mix(in oklab, var(--spec-3) 55%, transparent); }
.ash-dot:nth-child(3) { background: color-mix(in oklab, var(--spec-4) 55%, transparent); }
.ash-url { margin-left: 12px; font-size: 11px; color: var(--bone-mute); letter-spacing: .02em; }
.ash-body { padding: 0; }

/* hero shot placement */
.hero-shot { position: relative; width: min(960px, 100%); margin: clamp(30px, 5vh, 56px) auto 0; perspective: 1800px; }
.hero-shot::after { content: ""; position: absolute; left: 8%; right: 8%; bottom: -26px; height: 70px; border-radius: 50%; background: radial-gradient(ellipse, color-mix(in oklab, var(--spec-5) 34%, transparent), transparent 72%); filter: blur(26px); z-index: -1; pointer-events: none; }
.hero-shot .appshot { transform: rotateX(4deg); transform-origin: center top; animation: shot-float 9s ease-in-out infinite; }
@keyframes shot-float { 0%,100% { transform: rotateX(4deg) translateY(0); } 50% { transform: rotateX(4deg) translateY(-9px); } }

/* ── Workspace mock ── */
.wsm { display: flex; flex-direction: column; background: var(--noir); }
.wsm-bar { display: flex; align-items: center; gap: 9px; padding: 11px 14px; border-bottom: 1px solid var(--noir-line); }
.wsm-orb { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; background: radial-gradient(circle at 34% 30%, var(--spec-3), var(--spec-5) 55%, var(--spec-6)); box-shadow: 0 0 8px color-mix(in oklab, var(--spec-5) 70%, transparent); }
.wsm-orb.sm { width: 7px; height: 7px; }
.wsm-title { font-size: 12.5px; color: var(--bone-dim); font-weight: 600; }
.wsm-kbd { margin-left: auto; font-size: 10px; color: var(--bone-mute); border: 1px solid var(--noir-line); border-radius: 6px; padding: 2px 7px; }
.wsm-tabs { display: flex; gap: 14px; padding: 9px 16px; border-bottom: 1px solid var(--noir-line); }
.wsm-tabs b, .wsm-tabs span { font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--bone-mute); position: relative; padding-bottom: 7px; }
.wsm-tabs b.on { color: var(--crystal, var(--gold-bright)); font-weight: 600; }
.wsm-tabs b.on::after { content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px; border-radius: 2px; background: linear-gradient(90deg, var(--spec-1), var(--spec-3), var(--spec-4), var(--spec-6)); }
.wsm-main { display: grid; grid-template-columns: 1fr 210px; gap: 12px; padding: 14px; min-height: 280px; }
.wsm-stage { border-radius: 10px; overflow: hidden; box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--bone) 8%, transparent); }
/* the built app (light surface) */
.fa { height: 100%; background: linear-gradient(180deg, #f7f9fc, #eef1f7); color: #14161d; padding: 16px; display: flex; flex-direction: column; gap: 13px; }
.fa-top { display: flex; align-items: center; justify-content: space-between; }
.fa-top b { font-size: 16px; font-family: "Fraunces", Georgia, serif; }
.fa-pill { font-size: 10px; color: #5a6275; border: 1px solid #d6dbe6; border-radius: 999px; padding: 3px 9px; }
.fa-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 9px; }
.fa-card { background: #fff; border: 1px solid #e4e8f0; border-radius: 9px; padding: 10px; display: flex; flex-direction: column; gap: 3px; }
.fa-card span { font-size: 9.5px; color: #6b7384; text-transform: uppercase; letter-spacing: .06em; }
.fa-card b { font-size: 17px; color: #14161d; }
.fa-chart { flex: 1; display: flex; align-items: flex-end; gap: 8px; padding-top: 6px; }
.fa-chart i { flex: 1; border-radius: 4px 4px 0 0; background: linear-gradient(180deg, var(--spec-5), var(--spec-6)); min-height: 8px; }
/* the refine rail */
.wsm-rail { display: flex; flex-direction: column; gap: 8px; padding: 12px; border-radius: 10px; background: color-mix(in oklab, var(--noir-soft) 80%, transparent); border: 1px solid var(--noir-line); }
.wsm-railh { display: flex; align-items: center; gap: 7px; font-size: 10.5px; letter-spacing: .06em; color: var(--bone-mute); text-transform: uppercase; }
.wsm-msg { font-size: 11.5px; line-height: 1.4; padding: 8px 10px; border-radius: 9px; max-width: 92%; }
.wsm-msg.me { align-self: flex-end; background: color-mix(in oklab, var(--bone) 8%, transparent); color: var(--bone-dim); }
.wsm-msg.ai { align-self: flex-start; background: color-mix(in oklab, var(--spec-5) 14%, transparent); color: var(--bone); border: 1px solid color-mix(in oklab, var(--spec-5) 24%, transparent); }
.wsm-input { margin-top: auto; display: flex; align-items: center; justify-content: space-between; font-size: 11px; color: var(--bone-mute); border: 1px solid var(--noir-line); border-radius: 9px; padding: 8px 10px; }
.wsm-input i { font-style: normal; color: var(--crystal, var(--gold-bright)); }

/* ── Synth mock ── */
.synthm { background: radial-gradient(120% 100% at 50% 0%, #14121f, var(--noir-void)); padding: 16px; }
.synthm-top { display: flex; align-items: baseline; gap: 10px; margin-bottom: 13px; }
.synthm-top b { font-size: 16px; letter-spacing: .06em; color: var(--spec-6); }
.synthm-top span { font-size: 11px; color: var(--bone-mute); }
.synthm-grid { display: grid; grid-template-columns: repeat(8, 1fr); gap: 7px; }
.pad { aspect-ratio: 1; border-radius: 7px; background: color-mix(in oklab, var(--bone) 6%, transparent); border: 1px solid var(--noir-line); }
.pad.on { background: linear-gradient(150deg, var(--spec-5), var(--spec-6)); border-color: transparent; box-shadow: 0 0 14px -2px color-mix(in oklab, var(--spec-5) 70%, transparent); }
.synthm-foot { display: flex; align-items: center; gap: 12px; margin-top: 14px; }
.sp-play { width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; background: linear-gradient(150deg, var(--spec-4), var(--spec-6)); color: #0b0d16; font-size: 12px; }
.sp-bpm { font-size: 11px; color: var(--bone-dim); }
.sp-wave { flex: 1; height: 18px; border-radius: 4px; background: repeating-linear-gradient(90deg, color-mix(in oklab, var(--spec-4) 50%, transparent) 0 2px, transparent 2px 6px); opacity: .6; }

/* ── Brand-world mock (warm, off-palette to show range) ── */
.brandm { background: linear-gradient(160deg, #14241c, #20180f); padding: 22px 20px; display: flex; flex-direction: column; gap: 12px; min-height: 230px; }
.bm-eyebrow { font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: #b6d8b0; }
.bm-h { font-family: "Fraunces", Georgia, serif; font-weight: 400; font-size: clamp(20px, 3vw, 28px); line-height: 1.1; color: #f3ead9; margin: 0; }
.bm-cta { display: flex; align-items: center; gap: 14px; }
.bm-btn { font-size: 12px; background: linear-gradient(150deg, #d8a24b, #b07a2e); color: #1b140a; padding: 8px 16px; border-radius: 999px; font-weight: 600; }
.bm-link { font-size: 12px; color: #cfe0c6; }
.bm-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: auto; }
.bm-cards span { position: relative; height: 64px; border-radius: 10px; border: 1px solid color-mix(in oklab, #f3ead9 16%, transparent); box-shadow: inset 0 1px 0 color-mix(in oklab, #f3ead9 12%, transparent); overflow: hidden; }
.bm-cards span:nth-child(1) { background: radial-gradient(circle at 50% 34%, #c98a3f, #3a2716 70%); }
.bm-cards span:nth-child(2) { background: radial-gradient(circle at 50% 34%, #8a6a3a, #2e2113 70%); }
.bm-cards span:nth-child(3) { background: radial-gradient(circle at 50% 34%, #5f7d4e, #1c2a18 70%); }
.bm-cards span::after { content: ""; position: absolute; left: 50%; top: 30%; transform: translateX(-50%); width: 22px; height: 22px; border-radius: 50%; background: color-mix(in oklab, #f3ead9 22%, transparent); box-shadow: 0 0 14px -3px color-mix(in oklab, #f3ead9 40%, transparent); }

/* ── Showcase grid ── */
.early-show { text-align: center; padding: clamp(28px, 4vh, 52px) 0 clamp(36px, 5vh, 60px); }
.show-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 34px; text-align: left; }
.show-fig { margin: 0; }
.show-fig figcaption { margin-top: 14px; font-size: 13px; color: var(--bone-mute); line-height: 1.5; }
@media (max-width: 820px) {
  .show-grid { grid-template-columns: 1fr; }
  .wsm-main { grid-template-columns: 1fr; }
  .wsm-rail { display: none; }
  .hero-shot .appshot, .hero-shot .appshot:hover { transform: none; animation: none; }
}
@media (prefers-reduced-motion: reduce) { .hero-shot .appshot { animation: none; } }

/* Kill any sideways page-scroll globally. overflow-x:clip is sticky-safe (unlike hidden, it doesn't
   create a scroll container, so the sticky topbar keeps working) and leaves vertical scrolling intact. */
html, body { overflow-x: clip; }
