/* ============================================================================
 * css/style.css — STRUCTURE ONLY.
 * Every color is a var(--token) injected at runtime from data/theme.js.
 * Editing colors means editing the theme data file, never this file.
 * ========================================================================== */

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }
body { padding-bottom: 72px; }

body {
  background: var(--bg, #12141c);
  color: var(--ink, #e9e4d6);
  font-family: var(--font-ui);
  font-size: var(--fs-root);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3 { font-family: var(--font-display); font-weight: 600; margin: 0; }

button { font-family: var(--font-ui); cursor: pointer; }
input, select { font-family: var(--font-ui); }

/* Ghost button: shared base for icon buttons (.icon-btn) and library (.lib-action). */
.btn-ghost {
  background: var(--bg-raised); color: var(--ink-dim);
  border: 1px solid var(--line); border-radius: var(--radius-lg);
  transition: var(--t-base);
}
.btn-ghost:hover { color: var(--ink); border-color: var(--accent-dim); }
.icon-btn { padding: .45em .7em; font-size: var(--fs-90); }

/* --- Top region: roll stage + edit drawer --------------------------------- */
.top-region {
  display: flex; gap: 0; position: relative;
  padding: clamp(1rem, 3vw, 2rem) clamp(1rem, 4vw, 2.4rem) 0;
  align-items: flex-start;
}
.roll-stage { flex: 1; min-width: 0; }

/* --- Roll-line panel ------------------------------------------------------- */
.rollline-panel {
  background: var(--bg-sunken);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: 1.5rem 1.5rem 1.2rem;
  position: relative;
}
.rollline-stage { display: flex; justify-content: center; align-items: center; min-height: 120px; overflow: hidden; }
.rollline-svg { width: 100%; height: auto; max-height: 100%; overflow: visible; }
.rollline-marker {
  fill: var(--accent);
  paint-order: stroke;
  stroke: var(--marker-stroke); stroke-width: 3px;
  filter: drop-shadow(0 1px 2px var(--scrim-strong));
}

.roll-headline {
  display: flex; align-items: center; gap: .6em; margin-bottom: 1rem;
}
.roll-headline .head-actions {
  position: fixed; top: .8rem; right: .9rem; z-index: 50;
  display: flex; flex-direction: row; gap: .4rem; align-items: center; margin-left: 0;
}
.roll-headline .preset-emoji { font-size: calc(var(--fs-150) * 1.3); }
.roll-headline h2 { font-size: calc(var(--fs-150) * 1.3); }
.roll-headline .edit-toggle { margin-left: auto; }

/* --- Result readout ------------------------------------------------------- */
.result-readout {
  text-align: center; margin-top: .9rem; min-height: 2.2em;
}
.result-readout .result-label { color: var(--ink-dim); font-size: var(--fs-82); letter-spacing: .08em; text-transform: uppercase; }
.result-readout .result-value {
  font-family: var(--font-display); font-size: var(--fs-180); font-weight: 700;
  transition: color var(--t-med);
}
.result-readout .result-value.pending { color: var(--ink-faint); }

/* --- Roll button ---------------------------------------------------------- */
.roll-btn {
  display: block; margin: 1rem auto 0;
  background: var(--accent); color: var(--accent-ink);
  border: none; border-radius: var(--radius-pill);
  font-size: calc(var(--fs-105) * var(--roll-scale, 1)); font-weight: 600; letter-spacing: .02em;
  padding: .7em 2.4em; transition: transform var(--t-fast), background var(--t-base);
}
.roll-btn:hover:not(:disabled) { background: var(--accent-dim); }
.roll-btn:active:not(:disabled) { transform: scale(.97); }
.roll-btn:disabled { opacity: .8; cursor: default; }
.roll-btn.suspense { animation: suspense .32s ease-in-out infinite; }
@keyframes suspense {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.04); }
}

/* --- Outcomes table (read-only, in roll area) ----------------------------- */
.outcomes-table { width: 100%; border-collapse: collapse; margin-top: 1.3rem; font-size: calc(var(--key-scale, 1) * 0.95rem); }
.outcomes-table th {
  text-align: left; color: var(--ink-dim); font-weight: 500; font-size: var(--fs-78);
  letter-spacing: .06em; text-transform: uppercase;
  padding: .3em .5em; border-bottom: 1px solid var(--line);
}
.outcomes-table td { padding: .4em .5em; border-bottom: 1px solid var(--line-soft); }
.outcomes-table .swatch {
  display: inline-block; width: 12px; height: 12px; border-radius: var(--radius-xs);
  vertical-align: middle; margin-right: .5em;
}
.outcomes-table .pct { color: var(--ink-dim); font-variant-numeric: tabular-nums; width: 4em; }
.outcomes-table tr.hidden-row .oname { color: var(--ink-faint); letter-spacing: .15em; }
.outcomes-table { border-collapse: separate; }
.outcomes-table thead { display: none; }
.outcomes-table tbody { display: flex; gap: .45rem; }
.outcomes-table.wide tbody { flex-direction: row; flex-wrap: wrap; }
.outcomes-table:not(.wide) tbody { flex-direction: column; }
.outcomes-table tr { display: inline-flex; }
.outcomes-table td.pill {
  display: inline-flex; align-items: stretch; justify-content: center;
  border: none; padding: 0; border-radius: 999px; min-width: 1.4em; overflow: hidden;
}
.outcomes-table .pill-pct {
  display: inline-flex; align-items: center; padding: .34em .5em .34em .85em;
  font-weight: 700; font-variant-numeric: tabular-nums;
}
.outcomes-table .pill-name {
  display: inline-flex; align-items: center; padding: .34em .85em .34em .5em;
  font-size: .92em; background: rgba(0, 0, 0, .24);   /* name side dimmer */
}
.outcomes-table tr.hidden-row .pill { opacity: .8; }

/* Collapsible drawer sections */
.dsection { border-top: 1px solid var(--line); }
.dsection:first-child { border-top: none; }
.dsection-head {
  display: flex; align-items: center; gap: .5em; width: 100%;
  background: none; border: none; color: var(--ink); text-align: left; cursor: pointer;
  padding: .75rem 0; font-family: var(--font-display); font-size: calc(var(--fs-110) * 1.15); font-weight: 600;
}
.dsection-head:hover { color: var(--accent); }
.dtwirl { display: inline-block; color: var(--ink-dim); transition: transform var(--t-base); }
.dsection.collapsed .dtwirl { transform: rotate(-90deg); }
.dsection-body { padding-bottom: .5rem; }
.dsection.collapsed .dsection-body { display: none; }

/* --- Edit drawer (bouncy) ------------------------------------------------- */
.edit-drawer {
  width: var(--drawer-w, 360px); max-width: var(--drawer-w, 360px); flex: 0 0 var(--drawer-w, 360px); margin-left: 1.2rem;
  background: var(--bg-raised);
  border: 1px solid var(--line); border-radius: var(--radius-xl);
  padding: 1.2rem; align-self: stretch; position: relative;
  display: flex; flex-direction: column;
  transition: transform var(--t-bounce) var(--bounce), opacity var(--t-slow) ease, max-width var(--t-bounce) var(--bounce);
  max-height: calc(100vh - 8rem); overflow: hidden;
}
.edit-drawer .drawer-title { flex: 0 0 auto; }
#drawer-body { flex: 1 1 auto; min-height: 0; overflow-y: auto; padding-left: 6px; padding-bottom: 80px; }
/* Left-edge drag handle to resize the drawer — tall and clearly visible. */
.drawer-resize { position: absolute; left: 0; top: 0; width: 16px; height: 100%; cursor: ew-resize; z-index: 5; }
.drawer-resize::after {
  content: ''; position: absolute; left: 4px; top: 1.1rem; bottom: 1.1rem;
  width: 6px; border-radius: 5px; background: var(--accent-dim);
}
.drawer-resize:hover::after { background: var(--accent); }
body.resizing-drawer { cursor: ew-resize; user-select: none; }
.edit-drawer.closed {
  transform: translateX(100%); opacity: 0; pointer-events: none;
  max-width: 0; flex-basis: 0; margin-left: 0; padding-left: 0; padding-right: 0;
  border-width: 0; overflow: hidden;
}
.drawer-title { font-size: var(--fs-125); margin-bottom: 1rem; display: flex; align-items: center; }
.drawer-title .close-x { margin-left: auto; background: none; border: none; color: var(--ink-dim); font-size: var(--fs-130); }
.drawer-title .close-x:hover { color: var(--ink); }

.field { margin-bottom: 1rem; }
.field > label { display: block; font-size: var(--fs-80); color: var(--ink-dim); margin-bottom: .35em; letter-spacing: .03em; }
.field input[type="text"],
.field input[type="number"],
.field select {
  width: 100%; background: var(--bg-sunken); color: var(--ink);
  border: 1px solid var(--line); border-radius: var(--radius-md); padding: .5em .6em; font-size: var(--fs-92);
}
.field input:focus, .field select:focus { outline: 2px solid var(--accent-dim); outline-offset: -1px; }
.row2 { display: flex; gap: .6rem; }
.row2 > * { flex: 1; }

input[type="color"] {
  width: 100%; height: 38px; background: var(--bg-sunken);
  border: 1px solid var(--line); border-radius: var(--radius-md); padding: 2px; cursor: pointer;
}
input[type="range"] { width: 100%; accent-color: var(--accent); }
.check { display: flex; align-items: center; gap: .5em; font-size: var(--fs-90); color: var(--ink); }
.check input { accent-color: var(--accent); width: 16px; height: 16px; }

.combo { width: 100%; }
.icon-pick { display: flex; flex-direction: column; gap: .4rem; }
.icon-pick-select { width: 100%; background: var(--bg-sunken); color: var(--ink); border: 1px solid var(--line); border-radius: var(--radius-md); padding: .5em; font-size: var(--fs-92); }
.icon-pick-custom { width: 100%; background: var(--bg-sunken); color: var(--ink); border: 1px solid var(--line); border-radius: var(--radius-md); padding: .5em .6em; font-size: var(--fs-105); }
.icon-pick-select:focus, .icon-pick-custom:focus { outline: 2px solid var(--accent-dim); outline-offset: -1px; }

/* Chip pickers (icons / shapes) */
.chip-row { display: flex; flex-wrap: wrap; gap: .35rem; }
.chip {
  background: var(--bg-sunken); border: 1px solid var(--line); border-radius: var(--radius-md);
  padding: .35em .5em; font-size: var(--fs-110); line-height: 1; min-width: 2.2em; text-align: center;
  color: var(--ink); transition: var(--t-fast);
}
.chip.text { font-size: var(--fs-82); padding: .45em .7em; min-width: auto; }
.chip:hover { border-color: var(--accent-dim); }
.chip.active { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 14%, var(--bg-sunken)); }

/* Mode toggle */
.mode-toggle { display: inline-flex; border: 1px solid var(--line); border-radius: var(--radius-md); overflow: hidden; }
.mode-toggle button { background: var(--bg-sunken); color: var(--ink-dim); border: none; padding: .4em .9em; font-size: var(--fs-85); }
.mode-toggle button.active { background: var(--accent); color: var(--accent-ink); font-weight: 600; }

/* Outcome editor rows — CSS grid so the header and EVERY row share columns. */
.oe-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 4.8em 2.8em 7.2em 4.2em 4em 1.4em;
  gap: .4rem; align-items: center; margin-bottom: .4rem;
}
.oe-row > * { min-width: 0; }
.oe-row input.oe-name, .oe-row input.oe-value {
  width: 100%; background: var(--bg-sunken); color: var(--ink);
  border: 1px solid var(--line); border-radius: var(--radius-md);
  padding: .45em .55em; font-size: var(--fs-95);
}
.oe-row input.oe-name:focus, .oe-row input.oe-value:focus { outline: 2px solid var(--accent-dim); outline-offset: -1px; }
.oe-row input[type="color"] { width: 100%; height: 34px; padding: 2px; }
.oe-row select.oe-sound {
  width: 100%; background: var(--bg-sunken); color: var(--ink); border: 1px solid var(--line);
  border-radius: var(--radius-md); padding: .35em .25em; font-size: var(--fs-82);
}
.oe-row .oe-pct { text-align: right; color: var(--ink-dim); font-size: var(--fs-85); }
.oe-row .oe-hide { justify-self: center; }
.oe-row .oe-del { justify-self: center; background: none; border: none; color: var(--ink-faint); font-size: var(--fs-110); padding: 0; cursor: pointer; }
.oe-row .oe-del:hover { color: var(--warn); }
#oe-wrap { overflow-x: auto; }
.oe-head { color: var(--ink-dim); font-size: var(--fs-72); letter-spacing: .04em; text-transform: uppercase; margin-bottom: .4rem; align-items: end; }
.oe-head span { line-height: 1.12; }
.oe-head .oe-name, .oe-head .oe-value { padding-left: .55em; }
.oe-head .oe-pct { text-align: right; padding-right: .25em; }
.oe-head .oe-colhead, .oe-head .oe-hide { text-align: center; justify-self: stretch; }
.oe-head .oe-sound { padding-left: .3em; }
.add-outcome { background: var(--bg-sunken); border: 1px dashed var(--line); color: var(--ink-dim); border-radius: var(--radius-md); padding: .45em; width: 100%; font-size: var(--fs-85); }
.add-outcome:hover { color: var(--ink); border-color: var(--accent-dim); }

/* --- Save control --------------------------------------------------------- */
.save-control {
  margin-top: 1.2rem; padding-top: 1rem; border-top: 1px solid var(--line);
}
.save-control .save-paths { display: flex; flex-direction: column; gap: .5rem; margin-bottom: .6rem; }
.save-control .save-paths input[type="text"] {
  width: 100%; background: var(--bg-sunken); color: var(--ink);
  border: 1px solid var(--line); border-radius: var(--radius-md); padding: .5em .6em; font-size: var(--fs-92);
}
.save-control .save-paths input:focus { outline: 2px solid var(--accent-dim); outline-offset: -1px; }
.save-control .save-paths > div { flex: 1; }
.save-control label { font-size: var(--fs-72); color: var(--ink-dim); display: block; margin-bottom: .25em; }
.save-control .save-actions { display: flex; gap: .5rem; }
.save-btn {
  flex: 1; background: var(--good); color: var(--good-ink); border: none;
  border-radius: var(--radius-lg); padding: .65em; font-weight: 600; font-size: var(--fs-95); transition: var(--t-base);
}
.save-btn:hover { filter: brightness(1.08); }
.new-btn {
  background: var(--bg-raised); color: var(--ink-dim);
  border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: .65em 1.1em; font-weight: 600; font-size: var(--fs-95); white-space: nowrap; transition: var(--t-base);
}
.new-btn:hover { color: var(--ink); border-color: var(--accent-dim); }
.save-btn.warn { background: var(--warn); color: var(--warn-ink); }
.save-feedback { font-size: var(--fs-80); text-align: center; margin-top: .5rem; min-height: 1.2em; color: var(--good); }
.save-feedback.warn { color: var(--warn); }

/* --- Settings ------------------------------------------------------------- */
.settings-section {
  margin-top: 1.2rem; padding-top: 1rem; border-top: 1px solid var(--line);
}
.settings-title { font-size: var(--fs-110); margin-bottom: .6rem; }
.settings-row { display: flex; align-items: center; gap: .6rem; }
.settings-label { color: var(--ink-dim); font-size: var(--fs-90); }

/* --- Delete confirm popup ------------------------------------------------- */
.confirm-pop {
  position: fixed; z-index: 50; width: 340px; max-width: 92vw;
  background: var(--bg-raised); border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: .9rem 1rem; box-shadow: 0 8px 24px var(--scrim-strong);
}
.confirm-msg { font-size: var(--fs-95); margin-bottom: .55rem; }
.confirm-dont { font-size: var(--fs-82); color: var(--ink-dim); margin-bottom: .6rem; }
.confirm-btns { display: flex; gap: .4rem; }
.confirm-yes, .confirm-cancel { flex: 1; border-radius: var(--radius-md); padding: .45em; font-size: var(--fs-88); font-weight: 600; border: 1px solid var(--line); }
.confirm-yes { background: var(--warn); color: var(--warn-ink); border-color: var(--warn); }
.confirm-yes:hover { filter: brightness(1.08); }
.confirm-cancel { background: var(--bg-sunken); color: var(--ink-dim); }
.confirm-cancel:hover { color: var(--ink); border-color: var(--accent-dim); }

/* --- Library -------------------------------------------------------------- */
.library {
  margin-top: 2.2rem; padding: 1.5rem clamp(1rem, 4vw, 2.4rem) 4rem;
  border-top: 1px solid var(--line);
}
.lib-action { padding: .5em .9em; font-size: var(--fs-85); }

.lib-search {
  width: 100%; box-sizing: border-box; margin-bottom: 1rem;
  background: var(--bg-sunken); border: 1px solid var(--line); border-radius: var(--radius-md);
  color: var(--ink); padding: .6em .9em; font-size: var(--fs-95); font-family: var(--font-ui);
}
.lib-search:focus { outline: none; border-color: var(--accent); }
.lib-search::placeholder { color: var(--ink-faint); }
.search-meta { color: var(--ink-faint); font-size: var(--fs-85); margin-bottom: .8rem; }

/* Tab bar */
.tab-bar { display: flex; gap: .3rem; flex-wrap: wrap; border-bottom: 1px solid var(--line); margin-bottom: 1.2rem; }
.tab {
  background: none; border: none; color: var(--ink-dim);
  padding: .55em 1em; font-size: calc(var(--fs-110) * 1.3); border-bottom: 2px solid transparent; margin-bottom: -1px;
}
.tab:hover { color: var(--ink); }
.tab.active { color: var(--accent); border-bottom-color: var(--accent); font-weight: 600; }

/* Sections (collapsible) */
.section { margin-bottom: 1.1rem; }
.section-head {
  display: flex; align-items: center; gap: .5em; width: 100%;
  background: none; border: none; color: var(--ink); padding: .4em 0;
  font-family: var(--font-display); font-size: calc(var(--fs-110) * 1.15); font-weight: 600; text-align: left;
}
.section-head .twirl { transition: transform var(--t-med) var(--bounce); color: var(--ink-dim); font-size: .8em; }
.section-head.collapsed .twirl { transform: rotate(-90deg); }
.section-head .count { color: var(--ink-faint); font-size: var(--fs-80); font-family: var(--font-ui); margin-left: .3em; }
.section-body {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 1rem; padding-top: .6rem;
}
.section-body.collapsed { display: none; }

/* Preset card */
.preset-card {
  position: relative; border: 1px solid var(--line); border-radius: var(--radius-xl);
  padding: .85rem; transition: transform var(--t-base) var(--bounce), border-color var(--t-base);
  text-align: left; color: var(--ink); cursor: pointer; overflow: hidden;
  min-height: 132px; display: flex; flex-direction: column;
}
.preset-card:hover { transform: translateY(-2px); border-color: var(--accent-dim); }
.preset-card .pc-top { display: flex; align-items: center; gap: .45em; margin-bottom: .5em; padding-right: 6.2rem; min-height: 44px; }
.preset-card .pc-emoji { font-size: var(--fs-130); }
.preset-card .pc-name { font-family: var(--font-display); font-size: var(--fs-105); font-weight: 600; line-height: 1.1; }
.preset-card .pc-mini {
  display: flex; height: 12px; margin-top: auto; overflow: hidden;
  border-radius: var(--radius-xs); border: 1px solid var(--scrim);
}
.preset-card .pc-mini > span { flex-grow: 0; flex-shrink: 0; }
.preset-card .pc-count { font-size: var(--fs-72); color: var(--ink-dim); margin-top: .4em; }
.preset-card .pc-del {
  position: absolute; top: .4rem; right: .4rem; background: var(--scrim);
  border: none; color: var(--ink-dim); width: 44px; height: 44px; border-radius: var(--radius-md);
  font-size: var(--fs-150); line-height: 1; opacity: 0; transition: var(--t-base);
}
.preset-card:hover .pc-del { opacity: 1; }
.preset-card .pc-del:hover { color: var(--warn); background: var(--scrim-strong); }

.empty-note { color: var(--ink-faint); font-style: italic; padding: 1rem 0; }

/* --- Modal (import) ------------------------------------------------------- */
.modal-back {
  position: fixed; inset: 0; background: var(--scrim-strong);
  display: flex; align-items: center; justify-content: center; z-index: 50;
}
.modal {
  background: var(--bg-raised); border: 1px solid var(--line); border-radius: var(--radius-xl);
  padding: 1.6rem; max-width: 420px; width: calc(100% - 2rem);
  animation: pop var(--t-slow) var(--bounce);
}
@keyframes pop { from { transform: scale(.9); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.modal h3 { font-size: var(--fs-130); margin-bottom: .6rem; }
.modal p { color: var(--ink-dim); font-size: var(--fs-90); margin: 0 0 1.1rem; }
.modal .drop-zone {
  border: 2px dashed var(--line); border-radius: var(--radius-lg); padding: 1.5rem; text-align: center;
  color: var(--ink-dim); transition: var(--t-base); cursor: pointer; margin-bottom: 1rem;
}
.modal .drop-zone.drag { border-color: var(--accent); color: var(--ink); background: color-mix(in srgb, var(--accent) 8%, transparent); }
.modal .modal-actions { display: flex; gap: .6rem; }
.modal .modal-actions button { flex: 1; border-radius: var(--radius-lg); padding: .6em; border: 1px solid var(--line); font-weight: 600; }
.modal .btn-merge { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.modal .btn-replace { background: var(--bg-sunken); color: var(--ink); }
.modal .btn-cancel { background: none; color: var(--ink-dim); }
.modal .import-err { color: var(--warn); font-size: var(--fs-85); margin-top: .6rem; min-height: 1.2em; }

/* Toast */
.toast {
  position: fixed; bottom: 1.4rem; left: 50%; transform: translateX(-50%) translateY(20px);
  background: var(--bg-raised); border: 1px solid var(--line); color: var(--ink);
  padding: .7em 1.2em; border-radius: var(--radius-pill); font-size: var(--fs-90); opacity: 0;
  transition: var(--t-slow) var(--bounce); pointer-events: none; z-index: 60; box-shadow: 0 6px 20px var(--shadow);
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* --- Responsive ----------------------------------------------------------- */
@media (max-width: 880px) {
  .top-region { flex-direction: column; }
  .edit-drawer {
    width: 100%; flex-basis: auto; margin-left: 0; margin-top: 1rem;
    max-height: none; position: relative;
  }
  .edit-drawer.closed { width: 0; height: 0; margin: 0; padding: 0; }
}

/* Visible focus for keyboard users everywhere */
button:focus-visible, input:focus-visible, select:focus-visible, [tabindex]:focus-visible {
  outline: 2px solid var(--accent); outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .001ms !important; transition-duration: .08s !important; }
}


/* --- Dark scrollbars ----------------------------------------------------- */
* { scrollbar-width: thin; scrollbar-color: var(--line) transparent; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--bg-sunken); }
::-webkit-scrollbar-thumb { background: var(--line); border-radius: 6px; border: 2px solid var(--bg-sunken); }
::-webkit-scrollbar-thumb:hover { background: var(--accent-dim); }

/* --- Bottom library drawer (hover near the bottom to reveal) -------------- */
.bottom-drawer {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 40;
  background: var(--bg-raised); border-top: 1px solid var(--line);
  box-shadow: 0 -8px 24px var(--scrim);
  transform: translateY(var(--peek, calc(100% - 52px)));
  transition: transform var(--t-med) var(--bounce);
  height: 82vh; display: flex; flex-direction: column;   /* fixed: switching tabs no longer resizes it */
}
.bottom-drawer.open { transform: translateY(0); }
.bottom-handle {
  height: 52px; flex: 0 0 52px; width: 100%;
  display: grid; grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr); align-items: center; gap: .5rem;
  padding: 0 clamp(1rem, 4vw, 2.4rem); box-sizing: border-box;
}
.handle-left { justify-self: start; display: flex; align-items: center; gap: .5rem; min-width: 0; }
.bottom-handle .bottom-pill { justify-self: center; }
.handle-right { justify-self: end; display: flex; align-items: center; gap: .5rem; }
.bottom-pill {
  display: inline-flex; align-items: center; gap: .45em; height: 38px;
  background: var(--bg-sunken); border: 1px solid var(--line); border-radius: 999px;
  padding: 0 1.2em; color: var(--ink-dim); font-size: var(--fs-95); font-weight: 600; cursor: pointer; transition: var(--t-base);
}
.bottom-pill:hover { color: var(--ink); border-color: var(--accent-dim); }
.bottom-pill[aria-expanded="true"] { color: var(--accent); border-color: var(--accent); }
.bottom-handle .fav-toggle-btn { margin: 0; width: 34px; height: 34px; font-size: var(--fs-110); }
.bottom-drawer:not(.open) .handle-action { display: none; }   /* import/export only when open */
.bottom-inner { flex: 1 1 auto; min-height: 0; overflow-y: auto; padding: 0 clamp(1rem, 4vw, 2.4rem) 2rem; }
.bottom-drawer .library { margin-top: 0; border-top: none; padding: 0 0 1rem; }

.fav-list-picker { position: relative; display: flex; align-items: center; gap: .45rem; padding: 0; flex: 0 0 auto; }
.fav-list-label { color: var(--accent); font-size: var(--fs-110); }
.fav-list-input {
  background: var(--bg-sunken); border: 1px solid var(--line); border-radius: var(--radius-md);
  color: var(--ink); padding: .35em .7em; font-size: var(--fs-90); font-family: var(--font-ui); min-width: 9rem;
}
.fav-list-input:focus { outline: none; border-color: var(--accent); }
.fav-nav { display: grid; grid-template-columns: repeat(3, 16px); grid-template-rows: repeat(3, 14px); gap: 1px; margin-left: .35rem; flex: 0 0 auto; }
.fav-nav-btn {
  background: var(--bg-sunken); border: 1px solid var(--line); border-radius: var(--radius-sm);
  color: var(--ink-dim); font-size: 9px; line-height: 1; padding: 0; cursor: pointer;
  display: flex; align-items: center; justify-content: center; transition: var(--t-fast);
}
.fav-nav-btn:hover { color: var(--accent); border-color: var(--accent-dim); }
.fav-nav-btn.up { grid-column: 2; grid-row: 1; }
.fav-nav-btn.left { grid-column: 1; grid-row: 2; }
.fav-nav-btn.right { grid-column: 3; grid-row: 2; }
.fav-nav-btn.down { grid-column: 2; grid-row: 3; }
.fl-wrap { position: relative; width: 100%; }
.fl-panel {
  position: absolute; left: 0; min-width: 14rem; max-height: 248px; overflow-y: auto;
  background: var(--bg-raised); border: 1px solid var(--accent-dim); border-radius: var(--radius-md);
  z-index: 70; padding: .25rem; display: flex; flex-direction: column; gap: 1px; box-shadow: 0 8px 24px var(--scrim-strong);
}
.fl-panel.up { bottom: calc(100% + 4px); box-shadow: 0 -8px 24px var(--scrim-strong); }
.fl-panel.down { top: calc(100% + 4px); }
.fl-opt { text-align: left; background: none; border: none; color: var(--ink); padding: .45em .65em; border-radius: var(--radius-sm); font-size: var(--fs-90); cursor: pointer; white-space: nowrap; }
.fl-opt:hover { background: var(--bg-sunken); }
.fl-opt.current { color: var(--accent); font-weight: 600; }
.fl-opt.match { background: color-mix(in srgb, var(--accent) 12%, var(--bg-sunken)); }

/* --- Favorites bar (drag to reorder) ------------------------------------- */
.fav-bar { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; padding: .8rem 0; border-bottom: 1px solid var(--line); margin-bottom: .8rem; min-height: 2.4rem; }
.fav-empty { color: var(--ink-faint); font-size: var(--fs-85); font-style: italic; }
.fav-chip {
  display: inline-flex; align-items: center; gap: .45em;
  background: var(--bg-sunken); border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: .35em .6em; cursor: grab; user-select: none; transition: var(--t-base);
}
.fav-chip:hover { border-color: var(--accent-dim); }
.fav-chip.dragging { opacity: .5; }
.fav-chip .fav-index { color: var(--ink-faint); font-size: var(--fs-78); font-variant-numeric: tabular-nums; }
.fav-chip .fav-emoji { font-size: var(--fs-110); }
.fav-chip .fav-name { font-size: var(--fs-90); color: var(--ink); max-width: 12ch; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.fav-chip .fav-remove { background: none; border: none; color: var(--accent); font-size: var(--fs-95); line-height: 1; padding: 0 0 0 .1em; cursor: pointer; }
.fav-chip .fav-remove:hover { color: var(--ink); }

/* --- Card favorite star -------------------------------------------------- */
.preset-card .pc-fav {
  position: absolute; top: .4rem; right: 3.4rem; background: var(--scrim);
  border: none; color: var(--ink-faint); width: 44px; height: 44px; border-radius: var(--radius-md);
  font-size: var(--fs-150); line-height: 1; opacity: 0; transition: var(--t-base); cursor: pointer;
}
.preset-card:hover .pc-fav { opacity: 1; }
.preset-card .pc-fav.on { opacity: 1; color: var(--accent); }
.preset-card .pc-fav:hover { color: var(--accent); background: var(--scrim-strong); }

/* --- Fullscreen spinner -------------------------------------------------- */
body.spinner-fullscreen .top-region {
  position: fixed; inset: 0; z-index: 30; margin: 0; padding: 4vh 4vw calc(4vh + var(--fs-shelf, 0px));
  background: var(--bg); display: flex; align-items: center; justify-content: center;
}
body.spinner-fullscreen .edit-drawer { display: none; }
body.spinner-fullscreen .edit-toggle,
body.spinner-fullscreen .settings-toggle,
body.spinner-fullscreen .save-toggle { display: none; }
body.spinner-fullscreen .roll-stage { width: min(1100px, 94vw); }
.fullscreen-toggle[aria-pressed="true"] { color: var(--accent); border-color: var(--accent); }

/* --- Fullscreen number-jump box ------------------------------------------ */
.fav-jump {
  position: fixed; left: 50%; top: 18%; transform: translateX(-50%); z-index: 60;
  width: 3.5em; text-align: center; background: var(--bg-raised); color: var(--ink);
  border: 2px solid var(--accent); border-radius: var(--radius-md); padding: .35em;
  font-size: var(--fs-180); font-variant-numeric: tabular-nums;
}


/* --- Custom shape (spline point) editor ---------------------------------- */
.shape-editor { margin-bottom: 1rem; }
.shape-editor-hint { font-size: var(--fs-78); color: var(--ink-dim); margin-bottom: .4rem; }
.shape-editor-svg {
  width: 100%; aspect-ratio: 3 / 2; height: auto; display: block;
  background: var(--bg-sunken); border: 1px solid var(--line); border-radius: var(--radius-md);
  touch-action: none; cursor: crosshair;
}
.sh-point { fill: var(--bg-raised); stroke: var(--accent); stroke-width: 2; cursor: grab; vector-effect: non-scaling-stroke; }
.sh-point.sel { fill: var(--accent); }
.sh-point:hover { stroke-width: 4; }
.sh-label { fill: var(--ink-dim); font-size: 16px; font-family: var(--font-ui); pointer-events: none; }
.shape-editor-ctrls { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: .5rem; }
.se-btn { background: var(--bg-sunken); color: var(--ink-dim); border: 1px solid var(--line); border-radius: var(--radius-md); padding: .42em .7em; font-size: var(--fs-82); cursor: pointer; }
.se-btn:hover:not(:disabled) { color: var(--ink); border-color: var(--accent-dim); }
.se-btn:disabled { opacity: .4; cursor: default; }


/* --- Favorites area (always-visible toggle + on-favorite indicator) ------ */
.fav-area { padding: 0 clamp(1rem, 4vw, 2.4rem); }
.fav-toggle-btn {
  position: relative; margin: .5rem 0 .2rem; width: 42px; height: 42px;
  display: inline-flex; align-items: center; justify-content: center; line-height: 1;
  background: var(--bg-sunken); border: 1px solid var(--line); border-radius: var(--radius-md);
  color: var(--ink-dim); font-size: var(--fs-140); cursor: pointer; transition: var(--t-base);
}
.fav-toggle-btn:hover { border-color: var(--accent-dim); }
.fav-toggle-btn[aria-pressed="true"] {
  color: var(--bg); background: var(--accent); border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-dim);
}
.fav-chip.active { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 16%, var(--bg-sunken)); }
.fav-chip.active .fav-name { color: var(--ink); }
.roll-headline .fav-star { background: none; border: none; cursor: pointer; font-size: calc(var(--fs-130) * 1.3); line-height: 1; color: var(--ink-faint); padding: 0; }
.roll-headline .fav-star.on { color: var(--accent); }
.roll-headline .fav-star:hover { color: var(--accent); }


/* --- Key alignment ------------------------------------------------------- */
.outcomes-table.wide.align-left tbody { justify-content: flex-start; }
.outcomes-table.wide.align-center tbody { justify-content: center; }
.outcomes-table.wide.align-right tbody { justify-content: flex-end; }
.outcomes-table:not(.wide).align-left tbody { align-items: flex-start; }
.outcomes-table:not(.wide).align-center tbody { align-items: center; }
.outcomes-table:not(.wide).align-right tbody { align-items: flex-end; }

.oe-sum { font-size: var(--fs-90); color: var(--ink-dim); font-weight: 600; margin: .5rem 0 .2rem; }


/* --- Edit wizard (sections one-at-a-time as a modal) --------------------- */
.wiz-btn {
  margin-left: .6em; width: 34px; height: 34px; display: inline-flex; align-items: center; justify-content: center;
  line-height: 1; background: var(--bg-sunken); border: 1px solid var(--line); border-radius: var(--radius-md);
  color: var(--ink-dim); font-size: var(--fs-110); cursor: pointer; transition: var(--t-base);
}
.wiz-btn:hover { color: var(--ink); border-color: var(--accent-dim); }
.wiz-btn[aria-pressed="true"] { color: var(--bg); background: var(--accent); border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-dim); }
.wiz-bar {
  display: flex; align-items: center; justify-content: flex-start; gap: .6rem;
  padding-bottom: .7rem; margin-bottom: .5rem; border-bottom: 1px solid var(--line);
}
.wiz-bar .wiz-count { color: var(--ink-dim); font-size: var(--fs-90); min-width: 4em; text-align: center; }
.wiz-nav { background: var(--bg-sunken); color: var(--ink); border: 1px solid var(--line); border-radius: var(--radius-md); padding: .5em .95em; font-size: var(--fs-90); cursor: pointer; transition: var(--t-base); }
.wiz-nav:hover:not(:disabled) { border-color: var(--accent-dim); }
.wiz-nav.primary { background: var(--accent); color: var(--bg); border-color: var(--accent); font-weight: 600; }
.wiz-nav:disabled { opacity: .4; cursor: default; }

.field-mini-label { font-size: var(--fs-80); color: var(--ink-dim); margin: .5rem 0 .25rem; letter-spacing: .03em; }
.grad-stops { display: grid; grid-template-columns: repeat(4, 1fr); gap: .45rem; }
.grad-stop { display: flex; align-items: center; gap: .3em; }
.grad-stop .grad-on { accent-color: var(--accent); width: 15px; height: 15px; flex: 0 0 auto; }
.grad-stop input[type="color"] { width: 100%; height: 30px; }

.shape-select { width: 100%; }

/* --- Color wizard -------------------------------------------------------- */
.color-wiz-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .45em;
  background: var(--bg-sunken); border: 1px solid var(--line); border-radius: 999px;
  color: var(--ink-dim); padding: .5em 1.2em; font-size: var(--fs-92); font-weight: 600; cursor: pointer; margin-bottom: .7rem;
}
.color-wiz-btn:hover { color: var(--ink); border-color: var(--accent-dim); }
.cw-overlay { position: fixed; inset: 0; background: var(--scrim-strong); z-index: 80; display: flex; align-items: center; justify-content: center; }
.cw-modal { width: min(640px, 94vw); max-height: 88vh; overflow-y: auto; background: var(--bg-raised); border: 1px solid var(--line); border-radius: var(--radius-xl); padding: 1.4rem; box-shadow: 0 20px 60px var(--scrim-strong); }
.cw-color { width: 100%; height: 46px; background: var(--bg-sunken); border: 1px solid var(--line); border-radius: var(--radius-md); padding: 2px; cursor: pointer; }
.cw-title { font-family: var(--font-display); font-size: var(--fs-125); font-weight: 600; margin-bottom: .8rem; }
.cw-label { font-size: var(--fs-80); color: var(--ink-dim); margin: .6rem 0 .35rem; letter-spacing: .03em; }
.cw-schemes { display: grid; grid-template-columns: repeat(3, 1fr); gap: .4rem; }
.cw-scheme { background: var(--bg-sunken); border: 1px solid var(--line); color: var(--ink-dim); border-radius: var(--radius-md); padding: .5em; font-size: var(--fs-82); cursor: pointer; }
.cw-scheme:hover { color: var(--ink); border-color: var(--accent-dim); }
.cw-scheme.active { border-color: var(--accent); color: var(--accent); background: color-mix(in srgb, var(--accent) 14%, var(--bg-sunken)); }
.cw-slider { margin: .55rem 0; }
.cw-slider label { display: block; font-size: var(--fs-80); color: var(--ink-dim); margin-bottom: .2rem; }
.cw-slider input { width: 100%; accent-color: var(--accent); }
.cw-preview { display: flex; gap: .3rem; flex-wrap: wrap; margin: .9rem 0; }
.cw-swatch { width: 30px; height: 30px; border-radius: var(--radius-sm); border: 1px solid var(--scrim); flex: 0 0 auto; }
.cw-foot { display: flex; gap: .5rem; justify-content: flex-end; margin-top: .6rem; }
.cw-btn { background: var(--bg-sunken); color: var(--ink); border: 1px solid var(--line); border-radius: var(--radius-md); padding: .55em 1.05em; font-size: var(--fs-90); cursor: pointer; }
.cw-btn.primary { background: var(--accent); color: var(--bg); border-color: var(--accent); font-weight: 600; }

@keyframes roll-pulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(calc(1 + var(--pulse-amp, .04))); } }
.roll-btn.pulse:not(.suspense) { animation: roll-pulse 2.8s ease-in-out infinite; }
@media (prefers-reduced-motion: reduce) { .roll-btn.pulse { animation: none; } }


/* --- Round point + offset pad + speed curve (added) --------------------- */
.sh-point.rnd { stroke-dasharray: 3 3; }
.offset-pad-wrap { display: flex; flex-direction: column; align-items: stretch; gap: .4rem; }
.offset-pad-wrap .se-btn { align-self: flex-start; }
.offset-pad { width: 100%; aspect-ratio: 3 / 2; height: auto; display: block; background: var(--bg-sunken); border: 1px solid var(--line); border-radius: var(--radius-md); touch-action: none; cursor: crosshair; }
.offset-pad .op-axis { stroke: var(--line); stroke-width: 1; }
.offset-pad .op-dot { fill: var(--accent); stroke: var(--bg); stroke-width: 2; vector-effect: non-scaling-stroke; }
.speed-curve-wrap { display: flex; flex-direction: column; align-items: stretch; gap: .4rem; }
.speed-curve-wrap .se-btn { align-self: flex-start; }
.speed-curve { width: 100%; aspect-ratio: 3 / 2; height: auto; display: block; background: var(--bg-sunken); border: 1px solid var(--line); border-radius: var(--radius-md); touch-action: none; cursor: crosshair; }
.speed-curve .sc-frame { fill: none; stroke: var(--line); stroke-width: 1; }
.speed-curve .sc-handle-line { stroke: var(--accent-dim); stroke-width: 1; }
.speed-curve .sc-curve { stroke: var(--accent); stroke-width: 2.5; }
.speed-curve .sc-handle { fill: var(--accent); stroke: var(--bg-sunken); stroke-width: 2; cursor: grab; vector-effect: non-scaling-stroke; }
.speed-curve .sc-handle:hover { stroke: var(--ink); stroke-width: 3.5; }
.speed-curve .sc-handle.sel { fill: var(--ink); stroke: var(--accent); stroke-width: 4; }

.copy-preset-btn { margin-top: .4rem; }

.preset-io-row { display: flex; gap: .4rem; margin-top: .4rem; }
.preset-io-row .se-btn { margin-top: 0; }

.se-round-wrap { display: flex; align-items: center; gap: .5rem; margin: .4rem 0; }
.se-round-lbl { font-size: var(--fs-80); color: var(--ink-dim); }
.se-round { flex: 1; }
.se-round:disabled { opacity: .4; }

.sh-label { fill: var(--ink); font-size: 17px; font-weight: 600; }
.speed-curve .sc-zero { stroke: var(--ink-faint); stroke-width: 1; stroke-dasharray: 3 3; }

.range-row { display: flex; align-items: center; gap: .6rem; }
.range-row input[type="range"] { flex: 1; }
.range-val { font-size: var(--fs-82); color: var(--ink-dim); min-width: 3em; text-align: right; }

.speed-curve .sc-ghost { stroke: #5d8bd4; stroke-width: 2; opacity: .5; }

.outcomes-table td.pill { position: relative; overflow: hidden; }
.pill.sheen::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(115deg, transparent 35%, rgba(255,255,255,.5) 50%, transparent 65%);
  transform: translateX(-130%); animation: pill-sheen .8s ease-out 1;
}
@keyframes pill-sheen { to { transform: translateX(130%); } }
@media (prefers-reduced-motion: reduce) { .pill.sheen::after { animation: none; } }

/* --- Shared tooltip (js/tooltip.js positions it; any [data-tip] triggers) - */
.app-tip {
  position: fixed; z-index: 200; pointer-events: none;
  background: var(--bg-raised); color: var(--ink);
  border: 1px solid var(--accent-dim); border-radius: var(--radius-md);
  padding: .5em .8em; font: 500 var(--fs-85)/1.45 var(--font-ui);
  letter-spacing: normal; text-transform: none; text-align: center; white-space: normal;
  max-width: 260px; box-shadow: 0 10px 28px var(--scrim-strong);
  opacity: 0; transform: translateY(4px); transition: opacity .12s ease, transform .12s ease;
}
.app-tip.show { opacity: 1; transform: translateY(0); }
.app-tip::after { content: ''; position: absolute; left: 50%; transform: translateX(-50%); border: 6px solid transparent; }
.app-tip:not(.below)::after { top: 100%; border-top-color: var(--accent-dim); }
.app-tip.below::after { bottom: 100%; border-bottom-color: var(--accent-dim); }

/* --- "Amazing" slice sparkle ------------------------------------------- */
.rollline-sparkle {
  fill: #fff; opacity: 0; pointer-events: none;
  transform-box: fill-box; transform-origin: center;
  animation: rollline-sparkle 1s ease-in-out infinite;
}
@keyframes rollline-sparkle {
  0% { opacity: 0; transform: scale(.4); }
  18%, 72% { opacity: 1; transform: scale(1); }
  100% { opacity: 0; transform: scale(.4); }
}
@media (prefers-reduced-motion: reduce) { .rollline-sparkle { animation: none; opacity: .55; } }

/* --- "Horrific" slice smoke -------------------------------------------- */
.rollline-smoke {
  opacity: 0; pointer-events: none;
  transform-box: fill-box; transform-origin: center;
  filter: blur(3px);
  animation: rollline-smoke 2.6s ease-in-out infinite;
}
@keyframes rollline-smoke {
  0%, 100% { opacity: 0; transform: scale(.55); }
  50%      { opacity: .4; transform: scale(1.15); }
}
@media (prefers-reduced-motion: reduce) { .rollline-smoke { animation: none; opacity: .28; } }
