/* app.css — design tokens + component classes for the Chummer Reborn sheet.
   Dark by default; the :root token block is the single theme surface. No build step.
   Fonts are self-hosted variable woff2 (web/static/fonts/), embedded in the binary; a
   system stack is the fallback if a face fails to load. */

@font-face {
	font-family: 'Sora';
	font-weight: 100 800;
	font-display: swap;
	src: url('/static/fonts/sora.woff2') format('woff2');
}
@font-face {
	font-family: 'JetBrains Mono';
	font-weight: 100 800;
	font-display: swap;
	src: url('/static/fonts/jbmono.woff2') format('woff2');
}

:root {
	--gear-indent: 1.1rem; /* per-nesting-level left padding for nested gear name cells (slice AH) */
	--bg-0: #0a0b0e;
	--bg-1: #0c0d10;
	--panel: #101218;
	--panel-2: #0d0f14;
	--titlebar-a: #15161b;
	--titlebar-b: #101116;
	--border: #1d2029;
	--border-soft: #1b1d24;
	--border-2: #24262f;
	--row-line: #181b22;
	--accent: #ff3d7f;
	--accent-soft: #ff7aa8;
	--accent-weak: rgba(255, 61, 127, 0.12);
	--cyan: #2fe0d6;
	--cyan-soft: #5ef0e6;
	--amber: #ffb454;
	--amber-soft: #ffc987;
	--green: #5fe0a8;
	--danger: #ff6b6b;
	--t-hi: #f1f2f6;
	--t-1: #e8e9ee;
	--t-2: #b9bcc6;
	--t-3: #9b9da8;
	--t-4: #83868f;
	--t-5: #6a6d77;
	--t-6: #5a5d67;
	--mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
	--sans: 'Sora', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
	--r-sm: 7px;
	--r-md: 11px;
	--r-lg: 16px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body { background: var(--bg-1); color: var(--t-1); font-family: var(--sans); font-size: 13px; }
.mono { font-family: var(--mono); }
.dim { color: var(--t-5); }
.muted { color: var(--t-4); font-size: 11px; }
.cyan { color: var(--cyan); }
.dash { color: var(--t-6); }
.spacer { flex: 1; }
a { color: inherit; text-decoration: none; }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #23262f; border-radius: 6px; border: 2px solid var(--bg-1); }

/* ---- App shell ---- */
.app { position: fixed; inset: 0; display: flex; flex-direction: column; overflow: hidden; color: var(--t-1); }
.reactive { display: contents; }

.titlebar {
	height: 46px; flex: none; display: flex; align-items: center; gap: 14px; padding: 0 14px;
	background: linear-gradient(180deg, var(--titlebar-a), var(--titlebar-b));
	border-bottom: 1px solid var(--border); z-index: 30;
}
.brand-badge {
	width: 26px; height: 26px; border-radius: 8px; background: linear-gradient(135deg, #ff3d7f, #b8235a);
	display: flex; align-items: center; justify-content: center; font: 700 13px var(--mono); color: #fff;
	box-shadow: 0 0 14px rgba(255, 61, 127, 0.35);
}
.brand-name { font: 600 13px var(--sans); letter-spacing: 0.14em; }
.brand-accent { color: var(--accent); }
.brand-sub { color: var(--t-3); font-weight: 500; }
.titlebar-sep { width: 1px; height: 18px; background: #2a2d36; }
.titlebar-back { color: var(--t-4); font-size: 11.5px; }
.titlebar-back:hover { color: var(--t-1); }
.titlebar-id { display: flex; align-items: center; gap: 9px; }
.titlebar-alias { font: 600 12.5px var(--sans); }
.titlebar-meta { font-size: 11px; color: var(--t-5); }

.toolbar {
	height: 42px; flex: none; display: flex; align-items: center; gap: 8px; padding: 0 14px;
	background: var(--titlebar-b); border-bottom: 1px solid var(--border-soft); z-index: 20;
}
.statusbar {
	height: 30px; flex: none; display: flex; align-items: center; gap: 8px; padding: 0 16px;
	background: var(--bg-0); border-top: 1px solid var(--border-soft); font: 500 11px var(--mono);
}
.sb-label { color: var(--t-6); }
.sb-val { color: var(--t-2); }
.sb-val.cyan { color: var(--cyan); }
.sb-val.dash { color: var(--t-5); }
.sb-sep { width: 1px; height: 13px; background: #23262f; margin: 0 6px; }

.body { flex: 1; display: flex; min-height: 0; }

/* ---- Buttons / chips / fields ---- */
.btn {
	height: 27px; padding: 0 12px; display: inline-flex; align-items: center; gap: 6px;
	border-radius: var(--r-sm); background: #16181d; border: 1px solid var(--border-2);
	color: var(--t-2); font: 500 11.5px var(--sans); cursor: pointer;
}
.btn:hover { background: #1c1f26; color: #fff; }
.btn[disabled] { opacity: 0.5; cursor: not-allowed; color: #43454d; }
.btn-primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.btn-primary:hover { filter: brightness(1.08); color: #fff; }
.btn-danger { background: #c8324f; border-color: #e0455f; color: #fff; }
.btn-danger:hover { filter: brightness(1.08); color: #fff; }

.chip { display: inline-flex; align-items: center; gap: 5px; padding: 3px 8px; border-radius: 6px; font: 600 8px var(--mono); letter-spacing: 0.1em; }
.chip-dot { width: 5px; height: 5px; border-radius: 50%; background: currentColor; }
.chip-read { color: var(--cyan-soft); background: rgba(47, 224, 214, 0.08); border: 1px solid rgba(47, 224, 214, 0.2); }
.chip-live { color: var(--accent-soft); background: var(--accent-weak); border: 1px solid rgba(255, 61, 127, 0.24); }
.chip-plumb { color: var(--amber-soft); background: rgba(255, 180, 84, 0.1); border: 1px solid rgba(255, 180, 84, 0.24); }
.chip-none { color: var(--t-3); background: rgba(155, 157, 168, 0.06); border: 1px solid rgba(155, 157, 168, 0.16); }
.chip-danger { color: var(--danger); background: rgba(255, 107, 107, 0.1); border: 1px solid rgba(255, 107, 107, 0.28); }

.field { display: inline-flex; align-items: center; gap: 8px; }
.field-inline { gap: 9px; }
.field-label { font: 600 9px var(--mono); letter-spacing: 0.12em; color: var(--t-5); }
.select {
	height: 27px; padding: 0 10px; border-radius: var(--r-sm); background: #16181d;
	border: 1px solid var(--border-2); color: var(--t-1); font: 500 11.5px var(--sans); cursor: pointer;
}
.kbd { color: var(--t-2); }

.save-status { display: inline-flex; align-items: center; }
.save-ok {
	display: inline-flex; align-items: center; gap: 6px; height: 24px; padding: 0 11px;
	border-radius: var(--r-sm); background: rgba(70, 211, 154, 0.12); border: 1px solid rgba(70, 211, 154, 0.3);
	font: 600 11px var(--sans); color: var(--green);
}

/* ---- Genuine server-error banner (place 1: 4xx/5xx that aborted the stream) ---- */
.srv-error {
	display: flex; align-items: flex-start; gap: 13px; padding: 12px 16px;
	background: rgba(255, 107, 107, 0.10); border-bottom: 1px solid rgba(255, 107, 107, 0.35);
	border-left: 3px solid var(--danger);
}
.srv-error-badge {
	flex: none; margin-top: 1px; padding: 2px 8px; border-radius: var(--r-sm);
	background: rgba(255, 107, 107, 0.18); border: 1px solid rgba(255, 107, 107, 0.4);
	font: 700 11px var(--mono); letter-spacing: 0.04em; color: var(--danger);
}
.srv-error-body { display: flex; flex-direction: column; gap: 3px; flex: 1; min-width: 0; }
.srv-error-title { font: 600 12.5px var(--sans); color: var(--t-hi); }
.srv-error-msg { font-size: 11.5px; color: var(--danger); word-break: break-word; }
.srv-error-hint { font-size: 11px; color: var(--t-4); }
.srv-error-x {
	flex: none; width: 24px; height: 24px; border-radius: var(--r-sm); cursor: pointer;
	border: 1px solid var(--border-2); background: transparent; color: var(--t-3);
	font-size: 16px; line-height: 1; display: inline-flex; align-items: center; justify-content: center;
}
.srv-error-x:hover { color: var(--t-hi); border-color: var(--danger); }

/* ---- App-state notice (place 2: expected rejection on a healthy 200 stream) ---- */
.app-notice:empty { display: none; }
.app-notice {
	margin: 0 0 12px; padding: 10px 14px; border-radius: var(--r-md);
	background: rgba(255, 180, 84, 0.10); border: 1px solid rgba(255, 180, 84, 0.32);
	border-left: 3px solid var(--amber);
	font: 500 12px var(--sans); color: var(--amber-soft);
}

/* ---- Stepper nav ---- */
.stepper { width: 248px; flex: none; background: #0e0f13; border-right: 1px solid var(--border-soft); display: flex; flex-direction: column; }
.stepper-head { padding: 17px 18px 11px; font: 600 10px var(--mono); letter-spacing: 0.2em; color: var(--t-6); }
.stepper-list { flex: 1; overflow-y: auto; padding: 0 10px; display: flex; flex-direction: column; gap: 4px; }
.step-item {
	display: flex; align-items: center; gap: 12px; padding: 11px; border-radius: var(--r-md); cursor: pointer;
	border: none; border-left: 3px solid transparent; background: transparent; text-align: left; width: 100%; color: var(--t-2);
}
.step-item:hover { background: #131620; }
.step-item.active { border-left-color: var(--accent); background: #15171d; }
.step-num { width: 32px; height: 32px; flex: none; border-radius: 9px; display: flex; align-items: center; justify-content: center; font: 700 11px var(--mono); background: #15171d; color: var(--t-5); }
.step-item.active .step-num { background: var(--accent-weak); color: var(--accent-soft); }
.step-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 5px; align-items: flex-start; }
.step-label { font: 600 13px var(--sans); color: var(--t-2); }
.step-item.active .step-label { color: var(--t-hi); }

/* ---- Center column ---- */
.center { flex: 1; min-width: 0; display: flex; flex-direction: column; background: var(--bg-1); }
.step-header { flex: none; padding: 20px 32px 16px; border-bottom: 1px solid #15171d; }
.step-kicker { font: 600 10px var(--mono); letter-spacing: 0.2em; color: var(--accent); }
.step-title { font: 600 24px var(--sans); color: var(--t-hi); margin-top: 7px; letter-spacing: -0.01em; }
.center-scroll { flex: 1; overflow-y: auto; padding: 24px 32px 40px; }
.footer-nav { flex: none; display: flex; align-items: center; padding: 12px 32px; border-top: 1px solid #15171d; background: #0e0f13; }
.footer-hint { font-size: 11px; color: var(--t-6); letter-spacing: 0.04em; }

.step { display: block; }

/* ---- Section header ---- */
.section-header { display: flex; align-items: center; gap: 9px; margin: 2px 2px 11px; }
.section-label { font: 600 10px var(--mono); letter-spacing: 0.2em; color: var(--t-6); }
.section-rule { flex: 1; height: 1px; background: #16181d; }
.section-count { font: 500 11px var(--mono); color: var(--t-6); }

/* ---- Panels / cards / tables ---- */
.panel { background: var(--panel); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.card { background: var(--panel); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 16px; }
.mt { margin-top: 14px; }
.card-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 13px; }
.card-title { font: 600 11px var(--sans); color: var(--t-1); }
.card-badge { color: var(--t-3); margin-left: 6px; }
.card-grid { display: flex; gap: 14px; flex-wrap: wrap; align-items: stretch; }
.card-grid > .card { flex: 1; min-width: 280px; }

.table-wrap { padding: 0; }
table { border-collapse: collapse; width: 100%; }
th, td { padding: 10px 14px; border-bottom: 1px solid var(--row-line); text-align: left; vertical-align: top; }
th { color: var(--t-6); font: 600 8.5px var(--mono); letter-spacing: 0.06em; background: var(--panel-2); }
td { font-size: 12.5px; color: var(--t-1); }
td.num, th.num { text-align: right; }
.pool { color: var(--accent-soft); font-weight: 700; }
.total-row td { background: var(--panel-2); border-bottom: none; color: var(--t-2); font-weight: 600; }
.spec { color: var(--amber-soft); font-size: 10.5px; margin-top: 2px; }
.attr-tag { display: inline-block; padding: 4px 7px; border-radius: 6px; background: #13242a; color: var(--cyan); font: 600 9px var(--mono); }
.over-capacity { margin-left: 0.4em; color: var(--danger); font: 600 9px var(--mono); }

/* ---- Stat cards / tiles ---- */
.stat-row { display: flex; gap: 13px; flex-wrap: wrap; margin-bottom: 18px; }
.stat-card { flex: 1; min-width: 150px; padding: 14px 16px; }
.stat-label { font: 600 9px var(--mono); letter-spacing: 0.14em; color: var(--t-5); }
.stat-value { font: 700 22px var(--mono); color: var(--t-1); margin-top: 6px; }
.tile-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; }
.tile { background: var(--panel-2); border: 1px solid var(--border-soft); border-radius: var(--r-md); padding: 11px 13px; display: flex; align-items: center; justify-content: space-between; }
.tile-label { font: 500 12px var(--sans); color: var(--t-3); }
.tile-val { font: 700 20px var(--mono); color: var(--t-hi); }

/* ---- Empty / pending ---- */
.empty-state { border: 1px dashed var(--border-2); border-radius: 12px; padding: 26px; text-align: center; font: 500 12.5px var(--sans); color: var(--t-5); }
.pending { border: 1px dashed var(--border-2); border-radius: var(--r-lg); background: #0e0f13; padding: 22px; display: flex; flex-direction: column; gap: 9px; align-items: center; text-align: center; }
.pending-title { font: 600 13px var(--sans); color: var(--t-3); }
.pending-body { font: 400 12px var(--sans); color: var(--t-5); max-width: 460px; line-height: 1.5; }

/* ---- Attributes editor ---- */
.attr-group { margin-bottom: 20px; }
.attr-row { display: flex; align-items: center; gap: 13px; padding: 13px 15px; border-bottom: 1px solid var(--row-line); }
.attr-row:last-child { border-bottom: none; }
.attr-abbr { width: 42px; height: 42px; flex: none; border-radius: 12px; background: #191c23; display: flex; align-items: center; justify-content: center; font: 700 12px var(--sans); color: var(--accent); letter-spacing: 0.04em; }
.attr-name { width: 118px; flex: none; font: 500 13.5px var(--sans); color: var(--t-1); }
.attr-range { display: block; font: 500 10px var(--mono); color: var(--t-6); margin-top: 2px; }
.stepper-ctl { flex: none; text-align: center; }
.stepper-label { font: 600 8.5px var(--mono); letter-spacing: 0.1em; color: var(--t-5); margin-bottom: 4px; }
.stepper-row { display: flex; align-items: center; gap: 5px; }
.step-btn { width: 22px; height: 22px; border-radius: var(--r-sm); border: 1px solid var(--border-2); background: #15171d; color: var(--t-3); font: 600 14px var(--sans); cursor: pointer; display: flex; align-items: center; justify-content: center; line-height: 1; padding: 0; }
.step-btn:hover { background: var(--accent-weak); color: var(--accent-soft); border-color: #3a2533; }
.step-btn[disabled] { opacity: 0.4; cursor: not-allowed; }

/* Carried-gear per-row controls (slice C1): qty −/+ stepper + remove ×. Reuses the .step-btn look. */
.gear-actions { display: flex; align-items: center; justify-content: flex-end; gap: 6px; }
.gear-qty-btn { width: 20px; height: 20px; font-size: 13px; }
.gear-qty-val { width: 48px; padding: 2px 0; font-size: 12px; }
.gear-remove { width: 20px; height: 20px; flex: none; border-radius: var(--r-sm); border: 1px solid var(--border-2); background: #15171d; color: var(--t-3); font: 500 14px var(--sans); cursor: pointer; display: flex; align-items: center; justify-content: center; line-height: 1; padding: 0; }
.gear-remove:hover { background: #2a1418; color: var(--danger); border-color: #4a2226; }
.gear-add { display: inline-flex; align-items: center; margin-left: 6px; padding: 2px 8px; border-radius: var(--r-sm); border: 1px solid var(--border-2); background: #15171d; color: var(--t-3); font: 500 11px var(--sans); white-space: nowrap; cursor: pointer; text-decoration: none; }
.gear-add:hover { background: var(--panel-2); color: var(--accent-soft); border-color: var(--accent-soft); }
.gp-parent-banner { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; padding: 8px 14px; margin: 0 0 4px; border: 1px solid var(--accent-soft); border-radius: var(--r-sm); background: var(--panel-2); }
.gp-parent-label { font-size: 10px; letter-spacing: .08em; color: var(--t-3); }
.gp-parent-name { font-weight: 600; color: var(--t-hi); }
.gp-parent-cats { font-size: 11px; color: var(--t-3); }
.gp-parent-exit { margin-left: auto; font-size: 12px; color: var(--accent-soft); text-decoration: none; }
.gp-parent-exit:hover { color: var(--t-hi); }
.step-val { width: 42px; text-align: center; font: 600 15px var(--mono); color: var(--accent-soft); background: var(--panel-2); border: 1px solid var(--border-soft); border-radius: var(--r-sm); padding: 3px 0; -moz-appearance: textfield; }
.step-val::-webkit-outer-spin-button, .step-val::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.seg { flex: 1; min-width: 40px; display: flex; gap: 3px; align-items: center; }
.seg > i { flex: 1; min-width: 3px; height: 12px; border-radius: 3px; display: block; transition: background 0.15s; }
.seg-floor { background: #2c303a; }
.seg-base { background: var(--accent); }
.seg-karma { background: var(--accent-soft); }
.seg-aug { background: var(--cyan); }
.seg-open { background: #191c23; }
.seg-locked { background: #121317; }
.attr-total { width: 74px; flex: none; text-align: right; font: 700 23px var(--mono); color: var(--t-hi); }
.attr-aug { font: 600 12px var(--mono); color: var(--cyan); margin-left: 4px; }
.attr-kcost { width: 52px; flex: none; text-align: right; font: 600 11px var(--mono); color: var(--t-4); }

.ess-chip { display: inline-flex; align-items: center; gap: 8px; background: #0f1a1e; border: 1px solid #173138; border-radius: 9px; padding: 6px 12px; }
.ess-chip-label { font: 600 9px var(--mono); letter-spacing: 0.12em; color: #5a8d92; }
.ess-chip-val { font: 700 15px var(--mono); color: var(--cyan); }
.ess-chip-max { font: 500 10px var(--mono); color: #5a8d92; }

/* ---- Essence card / gauge ---- */
.ess-card { background: linear-gradient(135deg, #13202a, var(--panel)); border-color: #1d3640; margin-bottom: 18px; }
.ess-big { display: flex; align-items: baseline; gap: 9px; margin: 4px 0 13px; }
.ess-num { font: 700 40px var(--mono); color: var(--cyan); }
.ess-den { font: 500 14px var(--mono); color: #5a8d92; }
.ess-note { font: 400 11.5px var(--sans); color: #5a8d92; margin-top: 9px; }
.gauge { height: 7px; border-radius: 4px; background: #0c1418; overflow: hidden; }
.gauge-fill { height: 100%; transition: width 0.3s; }
.gauge-cyan { background: linear-gradient(90deg, var(--cyan), var(--cyan-soft)); }

/* ---- Nuyen ---- */
.nuyen-card { margin-bottom: 18px; }
.nuyen-row { display: flex; gap: 24px; }
.nuyen-cell { display: flex; flex-direction: column; gap: 4px; }
.nuyen-label { font: 600 9px var(--mono); letter-spacing: 0.12em; color: var(--t-5); }
.nuyen-val { font: 700 18px var(--mono); color: var(--t-1); }
.nuyen-val.dash { color: var(--t-5); }
.nuyen-caveat { margin-top: 11px; font-size: 10.5px; color: var(--amber-soft); }
/* budget gauge (REMAINING + spent/budget bar) */
.nuyen-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 8px; }
.nuyen-rem-label { font: 600 9px var(--mono); letter-spacing: 0.12em; color: var(--t-5); }
.nuyen-rem-val { font: 700 19px var(--mono); color: var(--cyan); }
.nuyen-gauge { margin-bottom: 8px; }
.gauge-pink { background: linear-gradient(90deg, var(--accent), var(--accent-soft)); }
.nuyen-meta { display: flex; justify-content: space-between; gap: 12px; font-size: 10px; color: var(--t-5); flex-wrap: wrap; }
.nuyen-meta-budget { color: var(--t-4); }
/* quality Karma (slice Z1) */
.karma-pool-card { margin-bottom: 14px; }
.karma-pool-head { display: flex; justify-content: space-between; gap: 18px; flex-wrap: wrap; align-items: baseline; margin-bottom: 10px; font-size: 12px; }
.karma-pool-remaining { color: var(--accent-soft); font-weight: 600; }
.karma-pool-list { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: 1fr auto; gap: 2px 18px; font-size: 11px; color: var(--t-4); }
.karma-pool-row { display: contents; }
.karma-pool-label { color: var(--t-4); }
.karma-pool-val { text-align: right; }
.qual-card { margin-bottom: 18px; }
.qual-summary { display: flex; gap: 18px; flex-wrap: wrap; align-items: baseline; margin-bottom: 12px; font-size: 11px; color: var(--t-4); }
.qual-pos { color: var(--accent-soft); }
.qual-neg { color: var(--cyan); }
.qual-net { margin-left: auto; font-weight: 700; color: var(--t-1); }
.qual-empty { font-size: 11px; color: var(--t-5); }
.qual-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.qual-row { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; padding: 6px 0; border-top: 1px solid var(--border-soft); }
.qual-row:first-child { border-top: none; }
.qual-name { font-size: 12px; color: var(--t-2); }
.qual-cost { font-size: 12px; color: var(--t-4); }

/* KARMA → NUYEN knob */
.knob-card { margin-top: 14px; padding: 13px 14px; border-radius: var(--r-md); background: var(--panel-2); border: 1px solid var(--border-soft); }
.knob-head { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.knob-title { font: 700 10px var(--mono); letter-spacing: 0.1em; color: var(--accent-soft); }
.knob-desc { margin: 0 0 12px; font-size: 11px; line-height: 1.5; color: var(--t-4); }
.knob-stepper { display: flex; align-items: center; justify-content: center; gap: 16px; margin-bottom: 10px; }
.knob-btn { width: 34px; height: 34px; font-size: 18px; border-radius: var(--r-md); }
.knob-val-wrap { display: flex; flex-direction: column; align-items: center; gap: 2px; }
.knob-val { width: 56px; font-size: 22px; padding: 4px 0; color: var(--t-hi); }
.knob-val-label { font: 600 8px var(--mono); letter-spacing: 0.14em; color: var(--t-6); }
.knob-delta { display: flex; align-items: center; justify-content: center; gap: 14px; margin-bottom: 11px; font: 600 11px var(--mono); }
.knob-delta-karma { color: var(--amber-soft); }
.knob-delta-yen { color: var(--accent-soft); }
.knob-pips { gap: 4px; }
.knob-pip { flex: 1; height: 6px; border-radius: 3px; background: #191c23; transition: background 0.15s; }
.knob-pip.on { background: var(--amber-soft); }
.nuyen-watcher { display: none; }

/* ---- Movement / CM / initiative / matrix ---- */
.move-full { font: 600 16px var(--mono); color: var(--t-hi); margin-bottom: 13px; }
.cm-track { margin-bottom: 13px; }
.cm-track:last-child { margin-bottom: 0; }
.cm-head { display: flex; justify-content: space-between; margin-bottom: 7px; }
.cm-head span:first-child { font: 500 11px var(--sans); color: var(--t-3); }
.cm-count { font-size: 11px; color: var(--t-6); }
.cm-boxes { display: flex; flex-wrap: wrap; gap: 4px; }
.cm-box { width: 17px; height: 17px; border-radius: 4px; background: var(--panel-2); border: 1px solid #23262f; display: block; }
.cm-mark { border-color: var(--accent); }
.init-list { display: flex; flex-direction: column; gap: 7px; }
.init-row { display: flex; align-items: center; justify-content: space-between; padding: 9px 12px; background: var(--panel-2); border: 1px solid var(--border-soft); border-radius: var(--r-md); }
.init-label { font: 500 12px var(--sans); color: var(--t-3); }
.init-val { font: 600 14px var(--mono); color: var(--t-hi); }
.matrix-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.matrix-commlink { flex: 1; min-width: 180px; }
.matrix-label { font: 600 9px var(--mono); letter-spacing: 0.12em; color: var(--t-5); }
.matrix-name { font: 600 14px var(--sans); color: var(--t-hi); margin-top: 4px; }
.asdf { display: flex; gap: 9px; }
.asdf-cell { width: 64px; background: var(--panel-2); border: 1px solid var(--border-soft); border-radius: var(--r-md); padding: 10px 0; text-align: center; }
.asdf-label { font: 600 9px var(--mono); color: #5a8d92; }
.asdf-val { font: 700 20px var(--mono); color: var(--cyan); margin-top: 3px; }

/* ---- Right rail ---- */
.rail { width: 286px; flex: none; background: #0e0f13; border-left: 1px solid var(--border-soft); display: flex; flex-direction: column; }
.rail-head { padding: 17px 18px 4px; font: 600 10px var(--mono); letter-spacing: 0.2em; color: var(--t-6); }
.rail-scroll { flex: 1; overflow-y: auto; padding: 13px 16px; }
.rail-cards { display: flex; gap: 11px; margin-bottom: 11px; }
.rail-stat { flex: 1; padding: 13px; }
.rail-stat-label { font: 600 9px var(--mono); letter-spacing: 0.1em; color: var(--t-5); }
.rail-stat-val { font: 700 21px var(--mono); color: var(--t-2); margin: 5px 0 8px; }
.rail-stat-val.cyan { color: var(--cyan); }
.rail-stat-sub { font: 400 9.5px var(--sans); color: var(--t-6); }
.rail-breakdown { padding: 5px 14px; }
.bd-row { display: flex; justify-content: space-between; align-items: center; padding: 9px 0; border-bottom: 1px solid var(--row-line); }
.bd-row:last-child { border-bottom: none; }
.bd-label { font: 500 11.5px var(--sans); color: var(--t-4); }
.bd-val { font: 600 12px var(--mono); color: var(--t-2); }
.bd-grey { font: 500 10px var(--sans); color: var(--t-6); }

/* ---- Landing ---- */
.landing-scroll { flex: 1; overflow-y: auto; background: var(--bg-0); }
.landing-wrap { max-width: 860px; margin: 0 auto; padding: 46px 30px 90px; }
.landing-title { font: 600 27px var(--sans); color: var(--t-hi); letter-spacing: -0.01em; }
.landing-lede { font: 400 13.5px var(--sans); color: var(--t-4); margin: 7px 0 0; max-width: 640px; line-height: 1.55; }
.char-list { display: flex; flex-direction: column; gap: 9px; }
.char-row { display: flex; align-items: center; gap: 12px; background: var(--panel); border: 1px solid var(--border); border-radius: 14px; padding: 13px 15px; }
.char-row:hover { border-color: #2a3340; background: #12151c; }
.char-link { flex: 1; display: flex; align-items: center; gap: 15px; min-width: 0; }
.char-avatar { width: 42px; height: 42px; flex: none; border-radius: 12px; background: var(--accent-weak); display: flex; align-items: center; justify-content: center; font: 700 16px var(--sans); color: var(--accent-soft); }
.char-meta { min-width: 0; }
.char-alias { font: 600 15px var(--sans); color: var(--t-hi); }
.char-sub { font-size: 11.5px; color: var(--t-5); margin-top: 2px; }
.char-del { width: 30px; height: 30px; flex: none; border-radius: 9px; border: 1px solid var(--border-2); background: #15171d; color: var(--t-4); font-size: 15px; cursor: pointer; }
.char-del:hover { background: #2a1418; color: var(--danger); border-color: #4a2226; }

.upload-form { display: flex; flex-direction: column; gap: 14px; }
.upload-drop { border: 1px dashed #2a3340; border-radius: var(--r-lg); background: #0e0f13; padding: 30px; display: flex; flex-direction: column; align-items: center; gap: 8px; text-align: center; }
.upload-icon { width: 52px; height: 52px; border-radius: 15px; background: var(--accent-weak); border: 1px solid rgba(255, 61, 127, 0.26); display: flex; align-items: center; justify-content: center; font: 600 22px var(--sans); color: var(--accent-soft); }
.upload-head { font: 600 14.5px var(--sans); color: var(--t-1); margin-top: 6px; }
.upload-sub { font: 400 12px var(--sans); color: var(--t-5); }
.upload-file { margin-top: 8px; color: var(--t-3); font-size: 12px; }
.upload-controls { display: flex; align-items: center; gap: 14px; }

/* ---- Modal ---- */
.modal-backdrop { position: fixed; inset: 0; background: rgba(6, 7, 9, 0.72); display: flex; align-items: center; justify-content: center; z-index: 60; }
.modal-card { width: 380px; background: #13151b; border: 1px solid var(--border-2); border-radius: var(--r-lg); padding: 24px; box-shadow: 0 24px 70px rgba(0, 0, 0, 0.6); }
.modal-title { font: 600 16px var(--sans); color: var(--t-hi); }
.modal-body { font: 400 12.5px var(--sans); color: var(--t-4); margin-top: 8px; line-height: 1.5; }
.modal-actions { display: flex; gap: 9px; justify-content: flex-end; margin-top: 20px; }

/* ============================================================================
   Responsive breakpoints — Laptop / Tablet / Mobile reflows.
   Desktop (≥1440px) is the baseline above: NONE of these rules fire there, so the
   3-column layout is visually unchanged. New chrome (top-step-nav, summary-strip,
   mobile-action-bar, compact footer, ⋯ menu) is display:none by default and revealed
   only inside the tier media blocks. Tiers: mobile ≤767 / tablet 768–1023 / laptop
   1024–1439 / desktop ≥1440. All values reuse the :root token layer.
   ============================================================================ */

/* New chrome hidden by default (desktop renders today's layout untouched). */
.top-step-nav,
.summary-strip,
.mobile-action-bar,
.footer-compact,
.toolbar-menu-btn,
.menu-backdrop { display: none; }

/* nav status dots (mobile pills) */
.nav-dot { width: 6px; height: 6px; border-radius: 50%; flex: none; display: inline-block; }
.nav-dot-live { background: var(--accent); }
.nav-dot-read { background: var(--cyan); }
.nav-dot-plumb { background: var(--amber); }
.nav-dot-none { background: var(--t-4); }

/* ---- Shared compact tier (mobile + tablet ≤1023): attribute cards + table scroll ---- */
@media (max-width: 1023px) {
	.stepper, .rail { display: none; }
	.top-step-nav { display: block; }

	/* Attribute editor: dense row → card via grid-template-areas (CSS-only reshape;
	   the bound <input id=sig_*> and segment pips are never moved). */
	.panel.attr-group { background: transparent; border: none; overflow: visible; }
	.attr-row {
		display: grid;
		grid-template-columns: 1fr 1fr;
		grid-template-areas:
			"abbr  total"
			"name  name"
			"seg   seg"
			"base  karma";
		gap: 10px;
		align-items: center;
		border: 1px solid var(--border);
		border-radius: var(--r-lg);
		padding: 14px;
	}
	.attr-row:last-child { border: 1px solid var(--border); } /* override the divider-only base rule */
	.attr-row .attr-abbr { grid-area: abbr; }
	.attr-row .attr-name { grid-area: name; width: auto; }
	.attr-row .attr-total { grid-area: total; width: auto; text-align: right; }
	.attr-row .seg { grid-area: seg; }
	.attr-row .stepper-base { grid-area: base; }
	.attr-row .stepper-karma { grid-area: karma; }
	.attr-row .attr-kcost { display: none; } /* per-attr karma column omitted on cards; Attr-Karma total shows in strip/bar */
	/* card stepper boxes: a touch larger + boxed */
	.attr-row .stepper-ctl { background: var(--panel-2); border: 1px solid var(--border-soft); border-radius: var(--r-md); padding: 9px 11px; }
	.attr-row .step-btn { width: 30px; height: 30px; font-size: 16px; }
	.attr-row .stepper-row { justify-content: space-between; }

	/* Wide numeric data tables scroll within their panel instead of breaking the shell. */
	.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
	.table-wrap table { min-width: 560px; }

	/* Non-tabular blocks stack. */
	.stat-row, .matrix-row, .asdf, .nuyen-row, .rail-cards { flex-direction: column; align-items: stretch; }
	.tile-grid { grid-template-columns: 1fr; }
	.card-grid { flex-direction: column; }
	.card-grid > .card { min-width: 0; }
}

/* ---- Mobile (≤767): pills, single-column cards, sticky bottom bar, ⋯ menu ---- */
@media (max-width: 767px) {
	.statusbar, .footer-hint { display: none; }

	/* top brand/back chrome condenses */
	.titlebar { gap: 9px; padding: 0 10px; }
	.titlebar-back, .titlebar-meta { display: none; }

	/* toolbar collapses into a ⋯ dropdown anchored to the toolbar's own bottom edge */
	.toolbar { position: relative; height: 40px; }
	.toolbar-menu-btn {
		display: inline-flex; align-items: center; justify-content: center;
		width: 30px; height: 27px; border-radius: var(--r-sm);
		background: #16181d; border: 1px solid var(--border-2); color: var(--t-2);
		font-size: 16px; line-height: 1; cursor: pointer;
	}
	.toolbar-actions {
		display: none; position: absolute; top: 100%; right: 8px; left: 8px;
		flex-direction: column; align-items: stretch; gap: 8px;
		background: var(--titlebar-b); border: 1px solid var(--border-2);
		border-radius: var(--r-md); padding: 10px; z-index: 50;
	}
	.toolbar-actions.open { display: flex; }
	.toolbar-actions .spacer { display: none; }
	.toolbar-actions .field-inline { justify-content: space-between; }
	.menu-backdrop { display: block; position: fixed; inset: 0; background: rgba(6, 7, 9, 0.5); z-index: 40; }

	/* step pills */
	.top-step-nav { background: linear-gradient(180deg, var(--titlebar-a), var(--titlebar-b)); border-bottom: 1px solid var(--border); }
	.top-step-scroll { display: flex; gap: 7px; overflow-x: auto; padding: 8px 14px 11px; scrollbar-width: none; }
	.top-step-scroll::-webkit-scrollbar { height: 0; }
	.top-step-item {
		display: flex; align-items: center; gap: 8px; flex: none; height: 34px; padding: 0 13px;
		border-radius: 10px; border: 1px solid var(--border); background: var(--panel);
		color: var(--t-3); font: 600 12px var(--sans); white-space: nowrap; cursor: pointer;
	}
	.top-step-item.active { border-color: #3a2533; background: var(--accent-weak); color: var(--accent-soft); }
	.top-step-num { font-size: 10px; color: var(--t-5); }
	.top-step-item.active .top-step-num { color: var(--accent-soft); }

	/* single-column cards */
	.panel.attr-group { display: grid; grid-template-columns: 1fr; gap: 9px; }

	/* paddings tighten */
	.step-header { padding: 16px 14px 12px; }
	.center-scroll { padding: 16px 14px 96px; } /* room for the sticky bottom bar */
	.footer-nav { display: none; }

	/* sticky bottom action bar */
	.mobile-action-bar {
		display: flex; align-items: center; gap: 13px; flex: none;
		position: sticky; bottom: 0; z-index: 25;
		padding: 11px 14px calc(11px + env(safe-area-inset-bottom));
		background: var(--bg-0); border-top: 1px solid var(--border-soft);
	}
	.mab-stat { display: flex; flex-direction: column; gap: 2px; }
	.mab-label { font: 600 8px var(--mono); letter-spacing: 0.1em; color: var(--t-5); }
	.mab-val { font: 700 15px var(--mono); color: var(--t-2); }
	.mab-sep { width: 1px; height: 24px; background: #23262f; }
	.next-step-mab {
		height: 40px; padding: 0 18px; border: none; border-radius: var(--r-md);
		background: var(--accent); color: #fff; font: 600 13px var(--sans); cursor: pointer;
		box-shadow: 0 4px 16px rgba(255, 61, 127, 0.28);
	}
	.next-step-mab[disabled] { background: #2a2e38; color: var(--t-5); box-shadow: none; cursor: default; }
}

/* ---- Tablet (768–1023): top tabs, 4-card summary strip, 2-up cards, compact footer ---- */
@media (min-width: 768px) and (max-width: 1023px) {
	/* top nav as tabs (number is the cue; dots hidden) */
	.top-step-nav { background: linear-gradient(180deg, var(--titlebar-a), var(--titlebar-b)); border-bottom: 1px solid var(--border); }
	.top-step-scroll { display: flex; gap: 2px; overflow-x: auto; padding: 0 12px; scrollbar-width: none; }
	.top-step-scroll::-webkit-scrollbar { height: 0; }
	.top-step-item {
		display: flex; align-items: center; gap: 8px; flex: none; padding: 14px 15px;
		border: none; background: transparent; border-bottom: 2px solid transparent;
		color: var(--t-4); font: 600 13px var(--sans); white-space: nowrap; cursor: pointer;
	}
	.top-step-item.active { border-bottom-color: var(--accent); color: var(--t-hi); }
	.top-step-num { font: 700 10px var(--mono); color: var(--t-6); }
	.top-step-item.active .top-step-num { color: var(--accent-soft); }
	.top-step-item .nav-dot { display: none; }

	/* summary strip (4 cards; Social Limit hidden until laptop) */
	.summary-strip { display: flex; align-items: center; gap: 11px; flex: none; padding: 15px 18px; border-bottom: 1px solid #15171d; overflow-x: auto; }
	.s-card-laptop { display: none; }

	/* 2-up attribute cards */
	.panel.attr-group { display: grid; grid-template-columns: 1fr 1fr; gap: 11px; }

	/* compact footer */
	.footer-hint { display: none; }
	.footer-compact { display: flex; align-items: center; justify-content: space-between; flex: 1; gap: 12px; }
}

/* ---- Laptop (1024–1439): narrowed stepper, 5-card strip, dense rows, compact footer ---- */
@media (min-width: 1024px) and (max-width: 1439px) {
	.stepper { width: 212px; }
	.rail { display: none; }

	/* summary strip (5 cards incl. Social Limit) */
	.summary-strip { display: flex; align-items: center; gap: 10px; flex: none; padding: 15px 22px; border-bottom: 1px solid #15171d; overflow-x: auto; }

	/* compact footer */
	.footer-hint { display: none; }
	.footer-compact { display: flex; align-items: center; justify-content: space-between; flex: 1; gap: 12px; }

	/* a narrow center may still need wide tables to scroll */
	.table-wrap { overflow-x: auto; }
}

/* summary-strip shared card styling (used at tablet + laptop) */
.summary-strip-label { font: 600 9px var(--mono); letter-spacing: 0.16em; color: var(--t-6); flex: none; }
.summary-card { flex: none; min-width: 128px; background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 10px 13px; }
.summary-card-label { font: 600 8.5px var(--mono); letter-spacing: 0.1em; color: var(--t-5); }
.summary-card-row { display: flex; align-items: baseline; gap: 5px; margin-top: 5px; }
.summary-card-val { font: 700 20px var(--mono); color: var(--t-hi); }
.summary-card-sub { font: 500 10px var(--mono); color: var(--t-6); }

/* compact-footer controls (tablet + laptop) */
.footer-counter { font: 500 11px var(--mono); color: var(--t-6); letter-spacing: 0.1em; }
.next-step-footer { background: var(--accent); border-color: var(--accent); color: #fff; }
.next-step-footer[disabled] { opacity: 0.5; cursor: default; }
.footer-start[disabled] { opacity: 0.4; cursor: default; }

/* ---- Print ---- */
@media print {
	.titlebar, .toolbar, .statusbar, .stepper, .rail, .footer-nav,
	.top-step-nav, .summary-strip, .mobile-action-bar { display: none; }
	.step { display: block !important; }
}

/* ============================================================================
   Gear picker (slice C2) — standalone read-only market page. Mobile-first base;
   the >=1024px block promotes it to the 3-pane desktop console. Tokens only.
   ============================================================================ */
.gp-app {
	position: relative;
	display: flex;
	flex-direction: column;
	height: 100vh;
	background: var(--bg-1);
	color: var(--t-1);
	font-family: var(--sans);
	overflow: hidden;
}
.gp-scroll { overflow-y: auto; }
.gp-scroll-x { overflow-x: auto; }

/* header */
.gp-header {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 12px 16px;
	background: linear-gradient(180deg, var(--titlebar-a), var(--titlebar-b));
	border-bottom: 1px solid var(--border-2);
	flex: none;
}
.gp-back {
	display: inline-flex;
	align-items: center;
	height: 34px;
	padding: 0 13px;
	border-radius: var(--r-md);
	background: var(--panel);
	border: 1px solid var(--border-2);
	color: var(--t-2);
	font: 600 12px var(--sans);
	text-decoration: none;
}
.gp-back:hover { color: var(--t-hi); background: var(--panel-2); }
.gp-kicker { font-size: 10px; letter-spacing: .2em; color: var(--accent); }
.gp-title { font: 700 20px var(--sans); color: var(--t-hi); margin-top: 3px; }

/* body / panes */
.gp-body { display: flex; flex: 1; min-height: 0; }
.gp-rail {
	display: none;
	flex-direction: column;
	width: 220px;
	flex: none;
	background: var(--panel-2);
	border-right: 1px solid var(--border-soft);
	padding: 8px;
}
.gp-rail-label { padding: 10px 8px; font-size: 10px; letter-spacing: .2em; color: var(--t-6); }
.gp-rail-item {
	display: flex;
	align-items: center;
	gap: 8px;
	width: 100%;
	padding: 9px 10px;
	margin-bottom: 2px;
	border: none;
	border-left: 3px solid transparent;
	border-radius: var(--r-sm);
	background: transparent;
	color: var(--t-2);
	font: 600 12.5px var(--sans);
	text-align: left;
	cursor: pointer;
}
.gp-rail-item:hover { background: var(--panel); }
.gp-rail-item.active { background: var(--panel); border-left-color: var(--accent); color: var(--t-hi); }
.gp-rail-name { flex: 1; }
.gp-rail-count { font-size: 9.5px; color: var(--t-6); }
.gp-rail-item.active .gp-rail-count { color: var(--accent-soft); }

.gp-center { display: flex; flex-direction: column; flex: 1; min-width: 0; }
.gp-head { flex: none; padding: 14px 16px; border-bottom: 1px solid var(--border-soft); }
.gp-search {
	display: flex;
	align-items: center;
	gap: 9px;
	height: 40px;
	padding: 0 13px;
	background: var(--panel);
	border: 1px solid var(--border-2);
	border-radius: var(--r-md);
}
.gp-search-icon { color: var(--t-6); }
.gp-search-in {
	flex: 1;
	background: transparent;
	border: none;
	outline: none;
	color: var(--t-1);
	font: 500 13px var(--sans);
}
.gp-search-in::placeholder { color: var(--t-6); }

.gp-chips { display: flex; gap: 7px; margin-top: 12px; padding-bottom: 2px; }
.gp-chip {
	flex: none;
	height: 32px;
	padding: 0 13px;
	white-space: nowrap;
	border: 1px solid var(--border);
	border-radius: var(--r-sm);
	background: var(--panel);
	color: var(--t-3);
	font: 600 11.5px var(--sans);
	cursor: pointer;
}
.gp-chip.active { background: var(--accent-weak); border-color: var(--accent); color: var(--accent-soft); }

.gp-filters { display: flex; align-items: center; gap: 9px; margin-top: 12px; }
.gp-filter-label { font-size: 9px; letter-spacing: .16em; color: var(--t-6); }
.gp-toggle {
	height: 30px;
	padding: 0 12px;
	border: 1px solid var(--border);
	border-radius: var(--r-sm);
	background: var(--panel);
	color: var(--t-3);
	font: 600 11px var(--sans);
	cursor: pointer;
}
.gp-toggle.on { background: var(--accent-weak); border-color: var(--accent); color: var(--accent-soft); }
.gp-toggle:disabled { opacity: .45; cursor: not-allowed; }

/* results */
.gp-results { flex: 1; padding: 12px 16px 24px; }
.gp-results-count { font-size: 10px; letter-spacing: .12em; color: var(--t-6); margin-bottom: 8px; }
.gp-rowlist { list-style: none; display: flex; flex-direction: column; gap: 7px; }
.gp-rowline { display: flex; align-items: center; gap: 8px; }
.gp-row {
	display: flex;
	align-items: center;
	gap: 12px;
	width: 100%;
	padding: 11px 13px;
	border: 1px solid var(--border);
	border-radius: var(--r-md);
	background: var(--panel);
	color: var(--t-1);
	text-align: left;
	cursor: pointer;
}
.gp-row:hover { border-color: var(--border-2); }
.gp-row.selected { border-color: var(--accent); background: var(--accent-weak); }
.gp-row-main { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.gp-row-name { font: 600 13.5px var(--sans); color: var(--t-1); }
.gp-row-sub { font: 400 11px var(--sans); color: var(--t-4); margin-top: 2px; }
.gp-row-avail { width: 58px; flex: none; text-align: center; }
.gp-col-label { display: block; font-size: 8.5px; letter-spacing: .1em; color: var(--t-6); }
.gp-avail { font: 600 12px var(--mono); color: var(--t-2); }
.gp-avail.danger, .gp-stat-val.danger { color: var(--danger); }
.gp-row-cost { width: 84px; flex: none; text-align: right; font: 600 13px var(--mono); color: var(--t-2); }
.gp-row { flex: 1; min-width: 0; }
.gp-add {
	width: 30px; height: 30px; flex: none;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: var(--r-sm);
	border: 1px solid var(--border-2);
	background: var(--accent-weak);
	color: var(--accent-soft);
	font: 600 18px var(--sans); line-height: 1;
	cursor: pointer;
}
.gp-add:hover { border-color: var(--accent); color: var(--accent); }

/* transient "Added …" confirmation flash */
.gp-status { min-height: 0; }
.gp-status-msg {
	display: block;
	margin: 8px 16px 0;
	padding: 7px 12px;
	border-radius: var(--r-sm);
	border: 1px solid var(--accent);
	background: var(--accent-weak);
	color: var(--accent-soft);
	font: 600 12px var(--mono);
}

.gp-prompt, .gp-detail-empty {
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	gap: 10px; padding: 48px 20px; text-align: center; color: var(--t-5);
	font: 500 13px var(--sans);
}
.gp-prompt-icon, .gp-detail-empty-icon { font: 600 26px var(--mono); color: var(--border-2); }
.gp-trunc { margin-top: 12px; }

/* side rail / detail */
.gp-side { display: contents; }
.gp-detail-wrap {
	position: fixed;
	left: 0; right: 0; bottom: 0;
	max-height: 86%;
	display: flex;
	flex-direction: column;
	background: var(--panel-2);
	border-top: 1px solid var(--border-2);
	border-radius: var(--r-lg) var(--r-lg) 0 0;
	padding: 8px 16px 18px;
	z-index: 20;
	box-shadow: 0 -8px 30px rgba(0, 0, 0, .5);
	overflow-y: auto;
}
.gp-sheet-close {
	align-self: flex-end;
	margin: 2px 0 8px;
	border: 1px solid var(--border-2);
	background: var(--panel);
	color: var(--t-3);
	border-radius: var(--r-sm);
	padding: 6px 11px;
	font: 600 12px var(--sans);
	cursor: pointer;
}
.gp-detail-head { display: flex; align-items: center; gap: 9px; }
.gp-detail-cat { font-size: 11px; color: var(--t-5); }
.gp-detail-src { font-size: 10px; color: var(--t-6); }
.gp-detail-name { font: 600 17px var(--sans); color: var(--t-hi); margin-top: 10px; }
.gp-detail-sub { font: 400 12px var(--sans); color: var(--t-4); margin-top: 4px; }
.gp-detail-stats { display: flex; gap: 9px; margin-top: 14px; }
.gp-stat { flex: 1; background: var(--panel); border: 1px solid var(--border); border-radius: var(--r-md); padding: 10px 12px; }
.gp-stat-label { font-size: 8.5px; letter-spacing: .12em; color: var(--t-5); }
.gp-stat-val { font: 700 17px var(--mono); color: var(--t-2); margin-top: 5px; }
.gp-stepper-row {
	display: flex; align-items: center; justify-content: space-between;
	margin-top: 10px; padding: 9px 12px;
	background: var(--panel); border: 1px solid var(--border); border-radius: var(--r-md);
}
.gp-stepper-label { font-size: 9px; letter-spacing: .12em; color: var(--t-5); }
.gp-stepper { display: flex; align-items: center; gap: 12px; }
.gp-step {
	width: 30px; height: 30px;
	display: inline-flex; align-items: center; justify-content: center;
	border: 1px solid var(--border-2); border-radius: var(--r-sm);
	background: var(--panel-2); color: var(--t-2);
	font: 600 16px var(--sans); line-height: 1; cursor: pointer;
}
.gp-step:hover { color: var(--t-hi); }
.gp-step-val { width: 36px; text-align: center; font: 700 16px var(--mono); color: var(--accent-soft); }
.gp-add-btn {
	margin-top: 13px;
	display: flex; align-items: center; justify-content: center; gap: 9px;
	height: 44px; width: 100%;
	border: none; border-radius: var(--r-md);
	background: var(--accent); color: #fff;
	font: 600 13.5px var(--sans); cursor: pointer;
}
.gp-add-btn:disabled { opacity: .5; cursor: not-allowed; }
.gp-add-line { font: 700 13px var(--mono); opacity: .9; }
.gp-detail-note { margin-top: 10px; }

/* budget */
.gp-budget { background: var(--panel-2); }
.gp-budget-side { display: none; }
.gp-budget-strip { display: block; min-width: 180px; }
.gp-budget-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.gp-budget-label { font-size: 9px; letter-spacing: .12em; color: var(--t-6); }
.gp-budget-rem { font: 700 15px var(--mono); color: var(--green); }
.gp-budget-rem.danger { color: var(--danger); }
.gp-budget-bar { height: 6px; border-radius: 4px; background: var(--row-line); overflow: hidden; margin-top: 8px; }
.gp-budget-fill { height: 100%; border-radius: 4px; background: var(--accent); transition: width .3s; }
.gp-budget-foot { display: flex; justify-content: space-between; margin-top: 7px; font-size: 10px; color: var(--t-5); }
.gp-budget-caveat { margin-top: 6px; font: 400 11px var(--sans); color: var(--t-4); }

/* tag palette (deterministic, token-based) */
.gp-tag {
	flex: none;
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 38px; height: 22px; padding: 0 6px;
	border-radius: var(--r-sm);
	font: 700 9px var(--mono); letter-spacing: .06em;
	background: var(--panel); border: 1px solid var(--border-2);
}
.gp-tag-0 { color: var(--t-3); }
.gp-tag-1 { color: var(--accent-soft); }
.gp-tag-2 { color: var(--cyan); }
.gp-tag-3 { color: var(--amber); }
.gp-tag-4 { color: var(--green); }
.gp-tag-5 { color: var(--cyan-soft); }
.gp-tag-6 { color: var(--amber-soft); }
.gp-tag-7 { color: var(--accent); }

/* >=1024px: 3-pane desktop console */
@media (min-width: 1024px) {
	.gp-rail { display: flex; }
	.gp-chips { display: none; }
	.gp-side {
		display: flex;
		flex-direction: column;
		width: 340px;
		flex: none;
		background: var(--panel-2);
		border-left: 1px solid var(--border-soft);
		min-height: 0;
	}
	.gp-detail-wrap {
		position: static !important;
		display: flex !important;
		max-height: none;
		flex: 1;
		min-height: 0;
		border-top: none;
		border-radius: 0;
		box-shadow: none;
		padding: 16px;
		z-index: auto;
	}
	.gp-sheet-close { display: none; }
	.gp-budget-side { display: block; flex: none; padding: 14px 16px; border-top: 1px solid var(--border-soft); }
	.gp-budget-strip { display: none; }
}

/* picker: loading + lock (slice C2 reliability rework) */
.gp-live-watcher { display: none; }
.gp-center { position: relative; }
.gp-loading {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	padding-top: 72px;
	background: rgba(12, 13, 16, 0.55);
	z-index: 5;
	backdrop-filter: blur(1px);
}
.gp-spinner {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	border: 3px solid var(--border-2);
	border-top-color: var(--accent);
	animation: gp-spin 0.7s linear infinite;
}
@keyframes gp-spin { to { transform: rotate(360deg); } }
/* lock the discrete click controls (category rail/chips + filter toggles) while a request is in
   flight, so the user cannot stack overlapping requests. The SEARCH box is intentionally NOT locked
   (locking the input the user is typing in would interrupt typing; it is already debounced +
   single-flight), and the detail steppers stay interactive (they only debounce-coalesce). */
.gp-busy .gp-rail,
.gp-busy .gp-chips,
.gp-busy .gp-filters {
	pointer-events: none;
	opacity: 0.55;
	transition: opacity 0.12s;
}
