/* ============================================================
   CharacterSheet Creator — Field Manual theme
   Notion-style neutral surfaces · indigo accent · Spectral serif heads
   Theme + density are driven by CSS variables (set by Tweaks).
   ============================================================ */
:root{
  --bg:#F1F1F3;
  --surface:#FFFFFF;
  --surface-2:#FAFAFB;
  --ink:#18181B;
  --ink-2:#3F3F46;
  --muted:#6B6B73;
  --faint:#9A9AA2;
  --line:#EAEAEE;
  --line-2:#E2E2E7;
  --accent:#4F46E5;
  --accent-ink:#312E81;
  --accent-soft:#EEF0FE;
  --accent-soft-2:#E4E7FD;
  --good:#1E7A52;
  --warn:#B45309;
  --danger:#BE123C;
  --serif:'Spectral', Georgia, serif;
  --sans:'IBM Plex Sans', system-ui, sans-serif;
  --mono:'IBM Plex Mono', ui-monospace, monospace;
  --radius:12px;
  --radius-sm:8px;
  /* density scale (overridden by .density-compact) */
  --pad:1;
  --gap-card:18px;
  --pad-card:22px;
  --pad-cell:14px;
  --shadow-sm:0 1px 2px rgba(24,24,27,.05);
  --shadow:0 1px 2px rgba(24,24,27,.06), 0 10px 28px -14px rgba(24,24,27,.22);
  --shadow-pop:0 8px 36px -10px rgba(24,24,27,.28);
}
.density-compact{
  --gap-card:11px;
  --pad-card:15px;
  --pad-cell:9px;
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:15px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{ font-family:var(--serif); font-weight:600; letter-spacing:-.012em; margin:0; }
button{ font-family:inherit; cursor:pointer; }
.mono{ font-family:var(--mono); font-variant-numeric:tabular-nums; }
.serif{ font-family:var(--serif); }
.minus{ font-feature-settings:"tnum"; }

/* ---------- app shell ---------- */
.app{ min-height:100vh; display:flex; flex-direction:column; }
.topbar{
  height:56px; flex:0 0 auto; background:var(--surface);
  border-bottom:1px solid var(--line);
  display:flex; align-items:center; gap:14px; padding:0 20px;
  position:sticky; top:0; z-index:30;
}
.brand{ display:flex; align-items:center; gap:10px; font-weight:700; letter-spacing:-.01em; }
.brand .mark{
  width:26px; height:26px; border-radius:7px; background:var(--accent);
  color:#fff; display:grid; place-items:center; font-family:var(--serif);
  font-weight:600; font-size:15px; box-shadow:var(--shadow-sm);
}
.brand .name{ font-size:15px; }
.brand .name b{ font-family:var(--serif); font-weight:600; }
.topbar .spacer{ flex:1; }
.topbar .tb-btn{
  border:1px solid var(--line-2); background:var(--surface); color:var(--ink-2);
  border-radius:8px; padding:7px 13px; font-size:13.5px; font-weight:500;
  display:inline-flex; align-items:center; gap:7px; transition:.15s;
}
.topbar .tb-btn:hover{ background:var(--surface-2); border-color:var(--faint); }
.topbar .tb-btn.primary{ background:var(--accent); border-color:var(--accent); color:#fff; }
.topbar .tb-btn.primary:hover{ filter:brightness(1.06); }
.topbar .tb-btn.ghost{ border-color:transparent; background:transparent; }
.topbar .tb-btn:disabled{ opacity:.45; cursor:not-allowed; }

/* ---------- layout columns ---------- */
.work{ flex:1; display:grid; grid-template-columns:248px 1fr; min-height:0; }
.rail{
  background:var(--surface); border-right:1px solid var(--line);
  padding:22px 16px; overflow-y:auto;
}
.rail-h{ font-size:11px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--faint); margin:0 8px 12px; }
.steps{ display:flex; flex-direction:column; gap:1px; }
.stepbtn{
  display:flex; align-items:center; gap:11px; width:100%; text-align:left;
  padding:9px 11px; border:none; background:transparent; border-radius:8px;
  font-size:13.5px; color:var(--muted); transition:.13s; position:relative;
}
.stepbtn:hover:not(:disabled){ background:var(--surface-2); color:var(--ink-2); }
.stepbtn:disabled{ cursor:not-allowed; opacity:.55; }
.stepbtn .ix{ font-family:var(--mono); font-size:11px; color:var(--faint); width:16px; flex:0 0 auto; }
.stepbtn .lab{ flex:1; }
.stepbtn .pick{ font-size:11.5px; color:var(--faint); max-width:96px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.stepbtn.done{ color:var(--ink-2); }
.stepbtn.done .ix{ color:var(--accent); }
.stepbtn.done .tick{ color:var(--good); }
.stepbtn.active{ background:var(--accent-soft); color:var(--accent-ink); font-weight:600; }
.stepbtn.active .ix{ color:var(--accent); }
.rail-progress{ margin:4px 8px 18px; }
.rail-progress .bar{ height:5px; background:var(--line-2); border-radius:3px; overflow:hidden; }
.rail-progress .bar i{ display:block; height:100%; background:var(--accent); border-radius:3px; transition:width .35s cubic-bezier(.4,0,.2,1); }
.rail-progress .cap{ font-size:11px; color:var(--faint); margin-top:7px; }

/* ---------- main content ---------- */
.main{ overflow-y:auto; min-height:0; }
.canvas{ max-width:920px; margin:0 auto; padding:38px 40px 120px; }
.step-eyebrow{ font-size:12px; font-weight:600; letter-spacing:.05em; text-transform:uppercase; color:var(--accent); }
.step-title{ font-size:30px; margin-top:8px; }
.step-sub{ color:var(--muted); margin-top:9px; font-size:15px; max-width:640px; }
.section-cap{ font-size:11px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--faint); margin:30px 0 13px; display:flex; align-items:center; gap:9px; }
.section-cap .ln{ flex:1; height:1px; background:var(--line-2); }

/* ---------- option cards (species/class/background pickers) ---------- */
.opt-grid{ display:grid; gap:var(--gap-card); }
.opt-grid.cols-2{ grid-template-columns:repeat(2,1fr); }
.opt-grid.cols-3{ grid-template-columns:repeat(3,1fr); }
.opt{
  text-align:left; background:var(--surface); border:1px solid var(--line-2);
  border-radius:var(--radius); padding:var(--pad-card); transition:.15s; position:relative; overflow:hidden;
}
.opt:hover{ border-color:var(--faint); box-shadow:var(--shadow); transform:translateY(-1px); }
.opt.sel{ border-color:var(--accent); box-shadow:0 0 0 1px var(--accent), var(--shadow); }
.opt.sel::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--accent); }
.opt .o-top{ display:flex; align-items:center; gap:11px; }
.opt .o-emb{
  width:38px; height:38px; flex:0 0 auto; border-radius:9px; display:grid; place-items:center;
  background:var(--accent-soft); color:var(--accent); font-family:var(--serif); font-size:18px; font-weight:600;
}
.opt.sel .o-emb{ background:var(--accent); color:#fff; }
.opt .o-name{ font-family:var(--serif); font-size:18px; font-weight:600; }
.opt .o-meta{ font-size:12px; color:var(--faint); font-family:var(--mono); }
.opt .o-blurb{ font-size:13px; color:var(--muted); margin-top:10px; line-height:1.5; }
.opt .o-tags{ display:flex; flex-wrap:wrap; gap:6px; margin-top:12px; }
.tag{ font-size:11px; font-weight:500; color:var(--ink-2); background:var(--surface-2); border:1px solid var(--line-2); border-radius:6px; padding:3px 8px; }
.tag.acc{ color:var(--accent-ink); background:var(--accent-soft); border-color:var(--accent-soft-2); }
.opt .o-check{ position:absolute; top:14px; right:14px; width:20px; height:20px; border-radius:50%; background:var(--accent); color:#fff; display:none; place-items:center; font-size:12px; }
.opt.sel .o-check{ display:grid; }

/* ---------- detail panel ---------- */
.detail{ background:var(--surface); border:1px solid var(--line-2); border-radius:var(--radius); padding:var(--pad-card); }
.detail h3{ font-size:20px; }
.kv{ display:flex; gap:8px; font-size:13.5px; padding:4px 0; }
.kv .k{ color:var(--faint); width:120px; flex:0 0 auto; }
.kv .v{ color:var(--ink-2); }
.trait{ padding:12px 0; border-top:1px solid var(--line); }
.trait:first-of-type{ border-top:none; }
.trait .tn{ font-weight:600; font-size:14px; }
.trait .tt{ font-size:13px; color:var(--muted); margin-top:3px; line-height:1.5; }

/* ---------- pills / segmented ---------- */
.seg{ display:inline-flex; gap:4px; background:var(--surface-2); border:1px solid var(--line-2); border-radius:10px; padding:4px; }
.seg button{ border:none; background:transparent; color:var(--muted); font-size:13px; font-weight:500; padding:7px 14px; border-radius:7px; transition:.13s; }
.seg button.on{ background:var(--surface); color:var(--ink); box-shadow:var(--shadow-sm); }
.seg.sm{ padding:3px; border-radius:8px; }
.seg.sm button{ padding:5px 10px; font-size:12.5px; }

/* milestone (ASI/feat) cards */
.ms-card{ border:1px solid var(--line-2); border-radius:var(--radius); background:var(--surface); padding:14px 16px; }
.ms-head{ display:flex; align-items:center; gap:11px; flex-wrap:wrap; }
.ms-lv{ font-size:11px; font-weight:600; color:#fff; background:var(--accent); border-radius:5px; padding:3px 7px; white-space:nowrap; }
.ms-title{ font-weight:600; font-size:14px; }
.ms-body{ margin-top:13px; padding-top:13px; border-top:1px solid var(--line); }

/* feat picker (cards instead of a dropdown) */
.feat-pick{ display:grid; grid-template-columns:1fr 1fr; gap:9px; max-height:360px; overflow-y:auto; padding:2px; margin:0 -2px; }
.feat-opt{ text-align:left; background:var(--surface); border:1px solid var(--line-2); border-radius:10px; padding:11px 12px; transition:.13s; position:relative; }
.feat-opt:hover{ border-color:var(--faint); background:var(--surface-2); }
.feat-opt.sel{ border-color:var(--accent); box-shadow:0 0 0 1px var(--accent); background:var(--accent-soft); }
.feat-opt .fo-top{ display:flex; align-items:flex-start; gap:8px; }
.feat-opt .fo-name{ font-weight:600; font-size:13.5px; color:var(--ink); flex:1 1 auto; min-width:0; }
.feat-opt .fo-asi{ font-family:var(--mono); font-size:9.5px; font-weight:600; color:var(--accent); background:var(--accent-soft-2); border-radius:4px; padding:2px 5px; white-space:nowrap; flex:0 0 auto; }
.feat-opt.sel .fo-asi{ background:#fff; }
.feat-opt .fo-check{ margin-left:auto; width:18px; height:18px; border-radius:50%; background:var(--accent); color:#fff; display:grid; place-items:center; font-size:11px; flex:0 0 auto; }
.feat-opt .fo-text{ font-size:11.5px; color:var(--muted); line-height:1.45; margin-top:5px; }
@media (max-width:880px){ .feat-pick{ grid-template-columns:1fr; max-height:none; } }
.chip-row{ display:flex; flex-wrap:wrap; gap:8px; }
.chip{ font-size:13px; padding:8px 13px; border-radius:9px; border:1px solid var(--line-2); background:var(--surface); color:var(--ink-2); font-weight:500; transition:.13s; display:inline-flex; align-items:center; gap:7px; }
.chip:hover{ border-color:var(--faint); }
.chip.on{ background:var(--accent); color:#fff; border-color:var(--accent); }
.chip.on .dot{ background:#fff; }
.chip.disabled{ opacity:.4; cursor:not-allowed; }
.chip .dot{ width:7px; height:7px; border-radius:50%; background:var(--accent); }

/* ---------- ability score editor ---------- */
.abil-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap-card); }
.abil-card{ border:1px solid var(--line-2); border-radius:var(--radius); padding:16px 14px 14px; background:var(--surface); position:relative; }
.abil-card .top{ display:flex; align-items:center; justify-content:space-between; }
.abil-card .lbl{ font-size:11px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--faint); }
.abil-card .modbadge{ font-family:var(--mono); font-size:12px; font-weight:600; color:var(--accent); background:var(--accent-soft); border-radius:6px; padding:3px 7px; }
.abil-card .score{ font-family:var(--mono); font-size:34px; font-weight:600; letter-spacing:-.02em; line-height:1; margin-top:10px; }
.abil-card .score small{ font-size:13px; color:var(--faint); font-weight:500; margin-left:6px; }
.abil-card .ctrl{ display:flex; align-items:center; gap:7px; margin-top:12px; }
.abil-card .ctrl button{ flex:1; border:1px solid var(--line-2); background:var(--surface-2); border-radius:7px; font-size:16px; color:var(--ink-2); padding:5px 0; transition:.12s; }
.abil-card .ctrl button:hover:not(:disabled){ background:var(--accent-soft); color:var(--accent); border-color:var(--accent-soft-2); }
.abil-card .ctrl button:disabled{ opacity:.35; cursor:not-allowed; }
.abil-card .asitag{ font-size:11px; color:var(--good); margin-top:9px; font-weight:500; }
.abil-card select{ width:100%; margin-top:10px; }

select, input[type=text], input[type=number], textarea{
  font-family:var(--sans); font-size:14px; color:var(--ink);
  border:1px solid var(--line-2); border-radius:8px; padding:8px 10px; background:var(--surface);
  outline:none; transition:.13s; width:100%;
}
select:focus, input:focus, textarea:focus{ border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft); }

/* hide native number-input spinners (we provide custom steppers) */
input[type=number]{ -moz-appearance:textfield; appearance:textfield; }
input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }

.budget{ display:inline-flex; align-items:center; gap:10px; font-size:13px; color:var(--muted); background:var(--surface); border:1px solid var(--line-2); padding:8px 14px; border-radius:10px; }
.budget b{ font-family:var(--mono); color:var(--accent); font-size:15px; }
.budget.over b{ color:var(--danger); }
.budget .bar{ width:120px; height:6px; border-radius:4px; background:var(--line-2); overflow:hidden; }
.budget .bar i{ display:block; height:100%; background:var(--accent); transition:width .3s; }

.callout{ display:flex; gap:11px; background:var(--accent-soft); border:1px solid var(--accent-soft-2); border-radius:10px; padding:13px 15px; font-size:13.5px; color:var(--accent-ink); line-height:1.5; }
.callout.amber{ background:#FEF6E7; border-color:#F6E2B8; color:#7A4E08; }
.callout .ico{ flex:0 0 auto; margin-top:1px; }

/* ---------- footer nav ---------- */
.stepnav{ display:flex; align-items:center; gap:12px; margin-top:40px; padding-top:22px; border-top:1px solid var(--line-2); }
.stepnav .spacer{ flex:1; }
.btn{ border:1px solid var(--line-2); background:var(--surface); color:var(--ink); border-radius:9px; padding:10px 18px; font-size:14px; font-weight:500; transition:.14s; display:inline-flex; align-items:center; gap:8px; }
.btn:hover{ background:var(--surface-2); border-color:var(--faint); }
.btn.primary{ background:var(--accent); border-color:var(--accent); color:#fff; }
.btn.primary:hover{ filter:brightness(1.07); }
.btn.lg{ padding:12px 24px; font-size:15px; }
.btn:disabled{ opacity:.45; cursor:not-allowed; }
.hint{ font-size:12.5px; color:var(--faint); }

/* level bar + stepper */
.level-bar{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-top:22px; background:var(--surface); border:1px solid var(--line-2); border-radius:var(--radius); padding:14px 18px; }
.level-bar .lb-label{ font-size:11px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--faint); }
.lvl-stepper{ display:inline-flex; align-items:center; gap:6px; }
.lvl-stepper button{ width:34px; height:34px; border:1px solid var(--line-2); background:var(--surface-2); border-radius:8px; font-size:18px; color:var(--ink-2); transition:.12s; }
.lvl-stepper button:hover:not(:disabled){ background:var(--accent-soft); color:var(--accent); border-color:var(--accent-soft-2); }
.lvl-stepper button:disabled{ opacity:.35; cursor:not-allowed; }
.lvl-stepper input{ width:58px; text-align:center; font-family:var(--mono); font-size:20px; font-weight:600; padding:5px; }
.level-bar .lb-meta{ display:flex; gap:8px; flex-wrap:wrap; margin-left:auto; }
.lvtag{ font-family:var(--mono); font-size:10.5px; color:var(--accent); background:var(--accent-soft); border-radius:5px; padding:1px 6px; font-weight:600; vertical-align:middle; }
.lvtag.locked{ color:var(--faint); background:var(--surface-2); }

@media (max-width:880px){
  .work{ grid-template-columns:1fr; }
  .rail{ display:none; }
  .canvas{ padding:26px 18px 120px; }
  .opt-grid.cols-2, .opt-grid.cols-3{ grid-template-columns:1fr; }
  .abil-grid{ grid-template-columns:repeat(2,1fr); }
  .step-title{ font-size:25px; }
}
