/* GENUBRA · Reality Synthesis — 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: #8C8268;
  --ok: #8FBF7F; --warn: #D9A441; --fail: #C66B5A;
  --reality-accent: #C9A24B;
  --ease: cubic-bezier(0.25, 1, 0.5, 1);
  --fd: "Fraunces", Georgia, serif; --fb: "Inter", system-ui, -apple-system, sans-serif;
  --rad: 14px; --rad-sm: 10px;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; min-height: 100%; }
html { -webkit-text-size-adjust: 100%; }
body { background: var(--noir-deep); color: var(--bone); font-family: var(--fb); -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
.display, .fd { font-family: var(--fd); letter-spacing: -0.02em; font-weight: 400; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; color: inherit; background: none; border: none; }
input, textarea { font-family: inherit; }
svg { display: block; }
::selection { background: color-mix(in oklab, var(--gold-deep) 50%, transparent); color: var(--bone); }
*:focus-visible { outline: 1px solid color-mix(in oklab, var(--gold-bright) 55%, transparent); outline-offset: 2px; }
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-thumb { background: color-mix(in oklab, var(--gold-deep) 45%, transparent); border-radius: 999px; }
::-webkit-scrollbar-track { background: transparent; }

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

/* ── Top bar ─────────────────────────────────────────── */
.shell { position: relative; z-index: 1; min-height: 100dvh; display: flex; flex-direction: column; }
.topbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 14px clamp(16px, 4vw, 34px); padding-top: calc(14px + env(safe-area-inset-top)); border-bottom: 1px solid var(--noir-line); position: sticky; top: 0; z-index: 20; background: color-mix(in oklab, var(--noir-deep) 86%, transparent); backdrop-filter: blur(14px); }
.brand { display: flex; align-items: baseline; gap: 10px; }
.brand .mk { font-family: var(--fd); font-size: 17px; color: var(--bone); }
.brand .mk b { color: var(--gold-bright); font-weight: 600; }
.brand .sb { font-size: 8px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--bone-mute); }
.topnav { display: flex; gap: 4px; }
.topnav button { color: var(--bone-dim); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; padding: 8px 13px; border: 1px solid transparent; border-radius: 8px; transition: all 0.25s var(--ease); }
.topnav button:hover { color: var(--bone); border-color: color-mix(in oklab, var(--gold) 22%, transparent); }
.topnav button.active { color: var(--gold-bright); border-color: color-mix(in oklab, var(--gold) 40%, transparent); }

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

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

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

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

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

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

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

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

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

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

/* ── Build mode (v4) ─────────────────────────────────── */
.mode-pick { display: flex; gap: 8px; justify-content: center; margin-bottom: 22px; }
.mode-pick button { font-size: 12px; letter-spacing: 0.05em; color: var(--bone-dim); border: 1px solid color-mix(in oklab, var(--gold) 22%, transparent); padding: 9px 16px; border-radius: 999px; display: flex; align-items: center; gap: 7px; transition: all 0.25s var(--ease); }
.mode-pick button.on { color: var(--noir); background: var(--gold); border-color: var(--gold); font-weight: 600; }
.building { max-width: 680px; margin: 7vh auto 0; text-align: center; }
.building .ring { width: 58px; height: 58px; margin: 0 auto 26px; border: 2px solid color-mix(in oklab, var(--gold) 20%, transparent); border-top-color: var(--gold-bright); border-radius: 50%; animation: rot 0.9s linear infinite; }
.building h2 { font-family: var(--fd); font-size: clamp(24px, 4vw, 32px); margin: 0 0 10px; }
.building .bstat { font-size: 14px; color: var(--bone-dim); min-height: 22px; transition: opacity 0.3s 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; }

/* ── 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; }
/* Mobile: keep the nav usable with 5-6 items + the pill — horizontal scroll, condensed brand. */
@media (max-width: 680px) {
  .topbar { gap: 8px; padding-left: 14px; padding-right: 14px; }
  .brand { flex-shrink: 0; }
  .brand .mk { font-size: 14px; }
  .brand .sb { display: none; }
  .tb-right { gap: 8px; flex: 1; justify-content: flex-end; }
  .topnav { overflow-x: auto; flex-wrap: nowrap; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
  .topnav::-webkit-scrollbar { display: none; }
  .topnav button { flex: 0 0 auto; padding: 8px 11px; }
  .credits-pill { flex: 0 0 auto; }
}
@media (max-width: 420px) {
  .brand .mk { font-size: 0; }
  .brand .mk b { font-size: 14px; }
  .brand .mk::before { content: "✦ "; font-size: 14px; color: var(--gold); }
}
.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); }
.paywall { position: fixed; inset: 0; background: rgba(0,0,0,0.66); backdrop-filter: blur(4px); display: grid; place-items: center; z-index: 70; padding: 20px; }
.paywall-card { width: min(440px, 100%); padding: 26px; text-align: center; }
.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 { 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 .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; }
.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-cost { color: var(--bone-mute); font-variant-numeric: tabular-nums; }
@media (max-width: 560px) {
  .st-row { grid-template-columns: 1fr auto auto; grid-template-areas: "what delta bal" "when extra extra"; row-gap: 4px; }
  .st-when { grid-area: when; } .st-what { grid-area: what; } .st-delta { grid-area: delta; } .st-bal { grid-area: bal; } .st-extra { grid-area: extra; text-align: left; }
}

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

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

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

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