/* ============================================================
   PRESSBOARD — Neo-Skeuomorphic Paper Tactile System
   Light (warm paper) + Dark flavors: kraft / charcoal
   ============================================================ */

/* ---------- Tokens ---------- */
:root {
  --font-display: "Oswald", "Arial Narrow", sans-serif;
  --font-body: "Barlow", "Helvetica Neue", sans-serif;
  --font-hand: "Caveat", cursive;

  --bg: #e9e0cd;
  --bg-deep: #ddd2b9;
  --paper: #f8f4ea;
  --paper-2: #efe9da;
  --paper-3: #e6dfcc;
  --ink: #2d2719;
  --ink-soft: #5f5742;
  --ink-faint: #93886c;
  --accent: #1f7d77;
  --accent-strong: #14605c;
  --accent-soft: rgba(31, 125, 119, 0.14);
  --accent-ink: #f4f0e4;
  --accent-glow: rgba(45, 188, 178, 0.55);
  --kraft: #d9c7a2;
  --kraft-deep: #c9b489;
  --kraft-ink: #5b4b2c;
  --danger: #b3432f;
  --danger-soft: rgba(179, 67, 47, 0.12);
  --warn: #a8761f;
  --warn-soft: rgba(168, 118, 31, 0.14);
  --line: #cfc3a8;
  --line-strong: #b3a37f;
  --sh: 53, 42, 22; /* shadow rgb */
  --grain-opacity: 0.5;
  --edge-shadow: 0 1px 2px rgba(var(--sh), 0.25), 0 3px 6px rgba(var(--sh), 0.18), 0 8px 18px rgba(var(--sh), 0.14);
  --edge-shadow-lg: 0 2px 3px rgba(var(--sh), 0.22), 0 8px 16px rgba(var(--sh), 0.18), 0 22px 40px rgba(var(--sh), 0.16);
  --inset-shadow: inset 0 2px 5px rgba(var(--sh), 0.28), inset 0 -1px 1px rgba(255, 255, 255, 0.5);
  --hi: rgba(255, 255, 255, 0.65); /* paper highlight */
  color-scheme: light;
}

html[data-theme="dark"][data-flavor="midnight"] {
  --bg: #14171f;
  --bg-deep: #0d0f15;
  --paper: #232836;
  --paper-2: #1e2330;
  --paper-3: #191d29;
  --ink: #e8ebf2;
  --ink-soft: #b3bac9;
  --ink-faint: #767e90;
  --accent: #46b8c8;
  --accent-strong: #6fd4e0;
  --accent-soft: rgba(70, 184, 200, 0.15);
  --accent-ink: #0a1b22;
  --accent-glow: rgba(111, 212, 224, 0.5);
  --kraft: #2e3547;
  --kraft-deep: #262c3c;
  --kraft-ink: #c3cde0;
  --danger: #e0705a;
  --danger-soft: rgba(224, 112, 90, 0.16);
  --warn: #d8a345;
  --warn-soft: rgba(216, 163, 69, 0.16);
  --line: #333a4c;
  --line-strong: #485066;
  --sh: 0, 0, 0;
  --edge-shadow: 0 1px 2px rgba(var(--sh), 0.5), 0 4px 8px rgba(var(--sh), 0.4), 0 10px 22px rgba(var(--sh), 0.35);
  --edge-shadow-lg: 0 2px 3px rgba(var(--sh), 0.5), 0 10px 20px rgba(var(--sh), 0.42), 0 26px 48px rgba(var(--sh), 0.4);
  --inset-shadow: inset 0 2px 6px rgba(var(--sh), 0.6), inset 0 -1px 1px rgba(214, 226, 255, 0.07);
  --hi: rgba(214, 226, 255, 0.08);
  color-scheme: dark;
}

html[data-theme="dark"][data-flavor="charcoal"] {
  --bg: #17191a;
  --bg-deep: #0f1112;
  --paper: #262b2c;
  --paper-2: #212627;
  --paper-3: #1c2122;
  --ink: #eaeeec;
  --ink-soft: #b4bfbc;
  --ink-faint: #76817e;
  --accent: #2fd0c2;
  --accent-strong: #5ee6da;
  --accent-soft: rgba(47, 208, 194, 0.14);
  --accent-ink: #06201d;
  --accent-glow: rgba(47, 208, 194, 0.55);
  --kraft: #36403f;
  --kraft-deep: #2c3535;
  --kraft-ink: #c5d4d0;
  --danger: #e76e57;
  --danger-soft: rgba(231, 110, 87, 0.15);
  --warn: #d9a946;
  --warn-soft: rgba(217, 169, 70, 0.15);
  --line: #39413f;
  --line-strong: #4d5755;
  --sh: 0, 0, 0;
  --edge-shadow: 0 1px 2px rgba(var(--sh), 0.55), 0 4px 8px rgba(var(--sh), 0.45), 0 10px 22px rgba(var(--sh), 0.4);
  --edge-shadow-lg: 0 2px 3px rgba(var(--sh), 0.55), 0 10px 20px rgba(var(--sh), 0.45), 0 26px 48px rgba(var(--sh), 0.42);
  --inset-shadow: inset 0 2px 6px rgba(var(--sh), 0.65), inset 0 -1px 1px rgba(255, 255, 255, 0.06);
  --hi: rgba(255, 255, 255, 0.06);
  color-scheme: dark;
}

html[data-theme="dark"][data-flavor="deepnight"] {
  --bg: #0a0a0f;
  --bg-deep: #050507;
  --paper: #16161f;
  --paper-2: #121119;
  --paper-3: #0d0d13;
  --ink: #e7e7ef;
  --ink-soft: #abacc0;
  --ink-faint: #6b6c82;
  --accent: #3ddfc0;
  --accent-strong: #6cf0d6;
  --accent-soft: rgba(61, 223, 192, 0.13);
  --accent-ink: #03201a;
  --accent-glow: rgba(108, 240, 214, 0.45);
  --kraft: #232331;
  --kraft-deep: #1b1b27;
  --kraft-ink: #b9bad4;
  --danger: #e76e5e;
  --danger-soft: rgba(231, 110, 94, 0.15);
  --warn: #d9a946;
  --warn-soft: rgba(217, 169, 70, 0.15);
  --line: #262635;
  --line-strong: #3a3a52;
  --sh: 0, 0, 0;
  --edge-shadow: 0 1px 2px rgba(var(--sh), 0.6), 0 4px 8px rgba(var(--sh), 0.5), 0 10px 22px rgba(var(--sh), 0.45);
  --edge-shadow-lg: 0 2px 3px rgba(var(--sh), 0.6), 0 10px 20px rgba(var(--sh), 0.5), 0 26px 48px rgba(var(--sh), 0.48);
  --inset-shadow: inset 0 2px 6px rgba(var(--sh), 0.7), inset 0 -1px 1px rgba(220, 220, 255, 0.06);
  --hi: rgba(220, 220, 255, 0.07);
  color-scheme: dark;
}

/* texture intensity */
html[data-texture="moderate"] { --grain-opacity: 0.3; }
html[data-texture="subtle"] { --grain-opacity: 0.12; }
html[data-texture="subtle"] .pface { clip-path: none !important; border-radius: 8px; }

/* ---------- Base ---------- */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--ink);
  font-size: 15px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  background-image: radial-gradient(ellipse 120% 80% at 50% -10%, var(--paper-2), transparent 60%),
    radial-gradient(ellipse 100% 60% at 80% 110%, var(--bg-deep), transparent 55%);
  background-attachment: fixed;
  transition: background-color 0.35s ease, color 0.35s ease;
}

/* full-page grain */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 2147483000;
  opacity: var(--grain-opacity);
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.45 0 0 0 0 0.4 0 0 0 0 0.32 0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 240px;
}
html[data-theme="dark"] body::after { mix-blend-mode: overlay; opacity: calc(var(--grain-opacity) * 0.8); }

h1, h2, h3, h4 { font-family: var(--font-display); margin: 0; line-height: 1.1; letter-spacing: 0.01em; }
a { color: var(--accent); }
::selection { background: var(--accent-soft); }

/* ---------- Torn paper surfaces ----------
   Each .paper / .tape gets two real child spans injected by paper-ui.js
   (PB.dressPaper): .pshadow is an UNCLIPPED shadow plate (clip-path would
   clip the shadow away); .pface is the paper face clipped by a dense
   jagged polygon (see torn-polys.css). Content stays crisp on top. */
.paper { position: relative; z-index: 0; --torn: var(--torn-a); --face: var(--paper); }
.paper > .pshadow {
  content: "";
  position: absolute;
  inset: 4px 3px 2px 3px;
  z-index: -2;
  border-radius: 10px;
  box-shadow: var(--edge-shadow);
  pointer-events: none;
  transition: box-shadow 0.25s ease, background-color 0.35s ease;
}
.paper > .pface {
  content: "";
  position: absolute;
  inset: -3px;
  z-index: -1;
  background: var(--face);
  clip-path: var(--torn);
  pointer-events: none;
  transition: background-color 0.35s ease;
}
.paper.torn-b { --torn: var(--torn-b); }
.paper.torn-c { --torn: var(--torn-c); }
.paper.torn-soft { --torn: var(--torn-soft); }
.paper.tone-2 { --face: var(--paper-2); }
.paper.tone-deep { --face: var(--paper-3); }
.paper.lift > .pshadow { box-shadow: var(--edge-shadow-lg); }
/* second sheet peeking behind: the shadow plate doubles as a tilted back sheet */
.paper.stack > .pshadow {
  background: var(--paper-2);
  inset: 6px -5px -7px 8px;
  transform: rotate(0.6deg);
}

/* inner highlight ridge for raised paper */
.ridge { box-shadow: inset 0 1px 0 var(--hi); border-radius: 6px; }

/* ---------- Tape / kraft chips ---------- */
.tape {
  display: inline-block;
  position: relative;
  z-index: 0;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--kraft-ink);
  padding: 3px 10px 4px;
  white-space: nowrap;
  transform: rotate(-1.2deg);
}
.tape { filter: drop-shadow(0 2px 2px rgba(var(--sh), 0.25)); }
.tape > .pface {
  position: absolute;
  inset: -2px;
  z-index: -1;
  background: var(--kraft);
  clip-path: var(--torn-soft);
  pointer-events: none;
}
.tape > .pshadow { display: none; }
.tape.tilt-r { transform: rotate(1.4deg); }
.tape.flat { transform: none; }
.tape.hand { font-family: var(--font-hand); text-transform: none; font-size: 16px; letter-spacing: 0; font-weight: 600; }

.hand-note {
  font-family: var(--font-hand);
  font-size: 17px;
  font-weight: 600;
  color: var(--ink-soft);
  line-height: 1.15;
}

/* ---------- Buttons ---------- */
.btn {
  -webkit-appearance: none;
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--paper);
  border: 1.5px solid var(--line-strong);
  border-radius: 13px 15px 12px 16px / 15px 12px 16px 13px;
  padding: 9px 18px 10px;
  cursor: pointer;
  text-decoration: none;
  position: relative;
  white-space: nowrap;
  box-shadow: 0 3px 0 rgba(var(--sh), 0.22), 0 5px 10px rgba(var(--sh), 0.18), inset 0 1px 0 var(--hi);
  transition: transform 0.08s ease, box-shadow 0.08s ease, background-color 0.35s ease;
  user-select: none;
}
.btn:hover { background: var(--paper-2); }
.btn:active, .btn.is-pressed {
  transform: translateY(3px);
  box-shadow: 0 0 0 rgba(var(--sh), 0.2), 0 1px 2px rgba(var(--sh), 0.15), var(--inset-shadow);
}
.btn:focus-visible { outline: none; box-shadow: 0 3px 0 rgba(var(--sh), 0.22), 0 0 0 3px var(--accent-glow); }
.btn-primary {
  background: var(--accent);
  border-color: var(--accent-strong);
  color: var(--accent-ink);
}
.btn-primary:hover { background: var(--accent-strong); }
.btn-danger { background: var(--danger); border-color: var(--danger); color: #fff4ec; }
.btn-ghost { background: transparent; border-style: dashed; box-shadow: none; }
.btn-ghost:active { transform: translateY(2px); box-shadow: var(--inset-shadow); }
.btn[disabled] {
  color: var(--ink-faint);
  background: var(--paper-3);
  border-color: var(--line);
  box-shadow: none;
  cursor: not-allowed;
  transform: none;
}
.btn-sm { font-size: 12px; padding: 5px 12px 6px; gap: 5px; }
.btn-lg { font-size: 17px; padding: 13px 26px 14px; }
.btn-icon { padding: 8px 10px; }

/* ---------- Inputs ---------- */
.field-label {
  display: block;
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 5px;
}
.input, select.input, textarea.input {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--ink);
  background: var(--paper-2);
  border: 1.5px solid var(--line-strong);
  border-radius: 8px 10px 8px 11px / 10px 8px 11px 8px;
  padding: 9px 12px;
  box-shadow: var(--inset-shadow);
  transition: box-shadow 0.15s ease, border-color 0.15s ease, background-color 0.35s ease;
}
.input::placeholder { color: var(--ink-faint); }
.input:focus { outline: none; border-color: var(--accent); box-shadow: var(--inset-shadow), 0 0 0 3px var(--accent-glow); }
.input.is-error { border-color: var(--danger); background: var(--danger-soft); }
.helper { font-size: 12.5px; color: var(--ink-faint); margin-top: 4px; }
.helper.is-error { color: var(--danger); font-weight: 600; }

/* checkbox + radio */
.check, .radio {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  cursor: pointer;
  font-size: 14.5px;
  color: var(--ink);
  user-select: none;
  white-space: nowrap;
}
.check input, .radio input { position: absolute; opacity: 0; pointer-events: none; }
.check .box, .radio .box {
  width: 21px; height: 21px;
  flex: none;
  background: var(--paper-2);
  border: 1.5px solid var(--line-strong);
  box-shadow: var(--inset-shadow);
  display: grid;
  place-items: center;
  transition: background-color 0.15s ease, border-color 0.15s ease;
}
.check .box { border-radius: 6px 7px 5px 7px; }
.radio .box { border-radius: 50%; }
.check .box svg { width: 13px; height: 13px; stroke: var(--accent-ink); stroke-width: 3.4; fill: none; opacity: 0; transform: scale(0.5) rotate(-8deg); transition: all 0.15s cubic-bezier(0.5, 1.6, 0.5, 1); }
.check input:checked + .box { background: var(--accent); border-color: var(--accent-strong); box-shadow: 0 2px 4px rgba(var(--sh), 0.25); }
.check input:checked + .box svg { opacity: 1; transform: scale(1) rotate(0deg); }
.radio .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--accent); opacity: 0; transform: scale(0.3); transition: all 0.15s cubic-bezier(0.5, 1.6, 0.5, 1); }
.radio input:checked + .box { border-color: var(--accent); }
.radio input:checked + .box .dot { opacity: 1; transform: scale(1); }
.check input:focus-visible + .box, .radio input:focus-visible + .box { box-shadow: 0 0 0 3px var(--accent-glow); }

/* switch */
.switch { display: inline-flex; align-items: center; gap: 9px; cursor: pointer; user-select: none; font-size: 14px; white-space: nowrap; }
.switch input { position: absolute; opacity: 0; pointer-events: none; }
.switch .track {
  width: 52px; height: 28px;
  flex: none;
  border-radius: 16px;
  background: var(--paper-3);
  border: 1.5px solid var(--line-strong);
  box-shadow: var(--inset-shadow);
  position: relative;
  transition: background-color 0.2s ease, border-color 0.2s ease;
}
.switch .knob {
  position: absolute;
  top: 2px; left: 2px;
  width: 21px; height: 21px;
  border-radius: 50%;
  background: var(--paper);
  border: 1px solid var(--line-strong);
  box-shadow: 0 2px 3px rgba(var(--sh), 0.3), inset 0 1px 0 var(--hi);
  transition: left 0.18s cubic-bezier(0.4, 1.4, 0.6, 1);
}
.switch input:checked + .track { background: var(--accent); border-color: var(--accent-strong); }
.switch input:checked + .track .knob { left: 26px; }
.switch input:focus-visible + .track { box-shadow: var(--inset-shadow), 0 0 0 3px var(--accent-glow); }

/* slider */
.slider { -webkit-appearance: none; appearance: none; width: 100%; height: 26px; background: transparent; cursor: pointer; --val: 50%; }
.slider::-webkit-slider-runnable-track {
  height: 12px;
  border-radius: 7px;
  background: linear-gradient(to right, var(--accent) var(--val), var(--paper-3) var(--val));
  border: 1.5px solid var(--line-strong);
  box-shadow: var(--inset-shadow);
}
.slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--paper);
  border: 1.5px solid var(--line-strong);
  box-shadow: 0 2px 4px rgba(var(--sh), 0.35), inset 0 1px 0 var(--hi);
  margin-top: -7.5px;
}
.slider::-moz-range-track { height: 12px; border-radius: 7px; background: var(--paper-3); border: 1.5px solid var(--line-strong); box-shadow: var(--inset-shadow); }
.slider::-moz-range-progress { height: 12px; border-radius: 7px; background: var(--accent); }
.slider::-moz-range-thumb { width: 22px; height: 22px; border-radius: 50%; background: var(--paper); border: 1.5px solid var(--line-strong); box-shadow: 0 2px 4px rgba(var(--sh), 0.35); }
.slider:focus-visible { outline: none; }
.slider:focus-visible::-webkit-slider-thumb { box-shadow: 0 0 0 3px var(--accent-glow); }

/* ---------- Navigation ---------- */
.tabs { display: flex; gap: 4px; align-items: flex-end; }
.tab {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-faint);
  background: var(--paper-3);
  border: 1.5px solid var(--line);
  border-bottom: none;
  border-radius: 9px 11px 0 0;
  padding: 8px 16px 7px;
  cursor: pointer;
  position: relative;
  transition: all 0.15s ease;
}
.tab:hover { color: var(--ink-soft); }
.tab.is-active {
  color: var(--accent);
  background: var(--paper);
  padding-bottom: 10px;
  margin-bottom: -2px;
  box-shadow: 0 -3px 8px rgba(var(--sh), 0.12);
  border-color: var(--line-strong);
}
.tab.is-active::after {
  content: "";
  position: absolute;
  left: 10px; right: 10px; bottom: 4px;
  height: 3px;
  background: var(--accent);
  border-radius: 2px;
}
.tab-rail { border-bottom: 2px solid var(--line-strong); }

.crumbs { display: flex; align-items: center; gap: 2px; font-size: 13px; color: var(--ink-soft); }
.crumbs a, .crumbs span.here { padding: 3px 9px; border-radius: 6px 8px 6px 8px; text-decoration: none; color: var(--ink-soft); white-space: nowrap; }
.crumbs a:hover { background: var(--paper-2); color: var(--accent); }
.crumbs span.here { color: var(--ink); font-weight: 600; background: var(--paper-2); box-shadow: var(--inset-shadow); }
.crumbs .sep { color: var(--ink-faint); font-size: 11px; }

.pager { display: flex; align-items: center; gap: 6px; }
.page-dot {
  width: 32px; height: 32px;
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 13px;
  color: var(--ink);
  background: var(--paper);
  border: 1.5px solid var(--line-strong);
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 2px 0 rgba(var(--sh), 0.2), inset 0 1px 0 var(--hi);
  transition: transform 0.08s ease, box-shadow 0.08s ease;
}
.page-dot:hover { background: var(--paper-2); }
.page-dot:active { transform: translateY(2px); box-shadow: var(--inset-shadow); }
.page-dot.is-active { background: var(--accent); border-color: var(--accent-strong); color: var(--accent-ink); box-shadow: var(--inset-shadow); }
.page-dot[disabled] { opacity: 0.4; cursor: not-allowed; }

/* steps */
.steps { display: flex; align-items: center; }
.step { display: flex; align-items: center; }
.step .bubble {
  width: 36px; height: 36px;
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 15px;
  border-radius: 50%;
  background: var(--paper);
  border: 2px solid var(--line-strong);
  color: var(--ink-faint);
  box-shadow: 0 2px 4px rgba(var(--sh), 0.2), inset 0 1px 0 var(--hi);
}
.step.is-done .bubble, .step.is-current .bubble { background: var(--accent); border-color: var(--accent-strong); color: var(--accent-ink); }
.step.is-current .bubble { box-shadow: 0 0 0 4px var(--accent-soft), 0 2px 5px rgba(var(--sh), 0.3); }
.step .bar { width: 38px; height: 4px; background: var(--line); border-radius: 2px; }
.step.is-done .bar { background: var(--accent); }

/* ---------- Data display ---------- */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: 10px 11px 9px 12px / 11px 9px 12px 10px;
  background: var(--paper-3);
  color: var(--ink-soft);
  border: 1px solid var(--line-strong);
  box-shadow: 0 1px 2px rgba(var(--sh), 0.18), inset 0 1px 0 var(--hi);
}
.badge-accent { background: var(--accent); color: var(--accent-ink); border-color: var(--accent-strong); }
.badge-soft { background: var(--accent-soft); color: var(--accent); border-color: transparent; box-shadow: none; }
.badge-danger { background: var(--danger-soft); color: var(--danger); border-color: transparent; box-shadow: none; }
.badge-warn { background: var(--warn-soft); color: var(--warn); border-color: transparent; box-shadow: none; }

.avatar {
  width: 34px; height: 34px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 13px;
  color: var(--accent-ink);
  background: var(--accent);
  border: 2px solid var(--paper);
  box-shadow: 0 2px 4px rgba(var(--sh), 0.3);
  flex: none;
}
.avatar.alt { background: var(--kraft-deep); color: var(--kraft-ink); }

/* table */
.ptable { width: 100%; border-collapse: collapse; font-size: 14px; }
.ptable th {
  font-family: var(--font-display);
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-align: left;
  color: var(--ink-soft);
  background: var(--paper-3);
  border-top: 1.5px solid var(--line-strong);
  border-bottom: 1.5px solid var(--line-strong);
  padding: 8px 12px;
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
}
.ptable th:hover { color: var(--accent); }
.ptable td { padding: 9px 12px; border-bottom: 1px dashed var(--line); }
.ptable tbody tr { transition: background-color 0.12s ease; }
.ptable tbody tr:hover { background: var(--accent-soft); }
.ptable .num { font-variant-numeric: tabular-nums; text-align: right; }
.ptable th.num { text-align: right; }

/* progress */
.progress {
  height: 18px;
  border-radius: 9px 11px 9px 11px;
  background: var(--paper-3);
  border: 1.5px solid var(--line-strong);
  box-shadow: var(--inset-shadow);
  overflow: hidden;
  position: relative;
}
.progress .fill {
  height: 100%;
  background: var(--accent);
  background-image: repeating-linear-gradient(-45deg, rgba(255, 255, 255, 0.14) 0 8px, transparent 8px 16px);
  border-radius: 0 8px 8px 0;
  transition: width 0.5s cubic-bezier(0.3, 0.9, 0.4, 1);
}

/* skeleton */
.skel {
  border-radius: 6px 8px 6px 8px;
  background: linear-gradient(100deg, var(--paper-3) 35%, var(--paper-2) 48%, var(--paper-3) 60%);
  background-size: 220% 100%;
  animation: skel-sheen 1.4s ease infinite;
}
@keyframes skel-sheen { from { background-position: 120% 0; } to { background-position: -80% 0; } }

/* spinner — torn paper ring */
.spinner {
  width: 34px; height: 34px;
  border-radius: 50%;
  border: 5px solid var(--paper-3);
  border-top-color: var(--accent);
  border-right-color: var(--accent);
  animation: spin 0.9s linear infinite;
  box-shadow: var(--inset-shadow);
}
@keyframes spin { to { transform: rotate(360deg); } }

/* tooltip */
[data-tip] { position: relative; }
[data-tip]::after {
  content: attr(data-tip);
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) rotate(-1deg) scale(0.92);
  background: var(--ink);
  color: var(--bg);
  font-size: 12.5px;
  font-family: var(--font-body);
  font-weight: 500;
  line-height: 1.3;
  padding: 5px 10px;
  border-radius: 7px 9px 7px 9px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.15s ease, transform 0.15s ease;
  z-index: 50;
  box-shadow: 0 4px 10px rgba(var(--sh), 0.3);
}
[data-tip]:hover::after { opacity: 1; transform: translateX(-50%) rotate(-1deg) scale(1); }

/* ---------- Feedback ---------- */
.alert {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  font-size: 14px;
  font-weight: 500;
}
.alert .alert-tag { font-family: var(--font-display); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; font-size: 12px; }

/* toasts */
.toast-stack {
  position: fixed;
  top: 22px;
  right: 22px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 1000;
  max-width: 320px;
}
.toast {
  padding: 11px 16px 12px;
  font-size: 14px;
  font-weight: 500;
  animation: toast-in 0.3s cubic-bezier(0.3, 1.3, 0.5, 1);
  transform-origin: top right;
}
.toast .t-title { font-family: var(--font-display); font-weight: 700; font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 2px; }
.toast.t-success .t-title { color: var(--accent); }
.toast.t-warn .t-title { color: var(--warn); }
.toast.t-error .t-title { color: var(--danger); }
.toast.leaving { animation: toast-out 0.25s ease forwards; }
@keyframes toast-in { from { opacity: 0; transform: translateY(-14px) rotate(1.5deg); } }
@keyframes toast-out { to { opacity: 0; transform: translateX(30px) rotate(2deg); } }

/* modal */
.modal-veil {
  position: fixed;
  inset: 0;
  background: rgba(var(--sh), 0.45);
  backdrop-filter: blur(2px);
  display: grid;
  place-items: center;
  z-index: 900;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}
.modal-veil.open { opacity: 1; pointer-events: auto; }
.modal {
  width: min(420px, 90vw);
  padding: 26px 28px;
  text-align: center;
  transform: scale(0.92) rotate(-0.5deg);
  transition: transform 0.22s cubic-bezier(0.3, 1.4, 0.5, 1);
}
.modal-veil.open .modal { transform: scale(1) rotate(-0.5deg); }
.modal h3 { font-family: var(--font-hand); font-size: 30px; font-weight: 700; margin-bottom: 6px; }

/* ---------- Theme toggle (paper sun/moon flip card) ---------- */
.theme-toggle {
  position: relative;
  width: 64px; height: 32px;
  border: 1.5px solid var(--line-strong);
  border-radius: 18px;
  background: var(--paper-3);
  box-shadow: var(--inset-shadow);
  cursor: pointer;
  flex: none;
}
.theme-toggle .tt-knob {
  position: absolute;
  top: 2px; left: 2px;
  width: 25px; height: 25px;
  border-radius: 50%;
  background: var(--paper);
  border: 1.5px solid var(--line-strong);
  box-shadow: 0 2px 4px rgba(var(--sh), 0.35), inset 0 1px 0 var(--hi);
  display: grid;
  place-items: center;
  font-size: 13px;
  line-height: 1;
  transition: left 0.22s cubic-bezier(0.4, 1.4, 0.6, 1), transform 0.22s ease;
}
html[data-theme="dark"] .theme-toggle .tt-knob { left: 34px; transform: rotate(360deg); }
.theme-toggle:focus-visible { outline: none; box-shadow: var(--inset-shadow), 0 0 0 3px var(--accent-glow); }

/* ---------- Dark flavor picker (visible in dark mode only) ---------- */
.flavor-picker {
  display: none;
  align-items: center;
  gap: 6px;
  height: 32px;
  padding: 0 7px;
  border-radius: 9px 12px 9px 13px;
  background: var(--bg-deep);
  box-shadow: var(--inset-shadow);
  flex: none;
}
html[data-theme="dark"] .flavor-picker { display: flex; }
.fp-swatch {
  width: 24px; height: 24px;
  padding: 0;
  border: 1px solid var(--line-strong);
  border-radius: 6px 8px 5px 8px;
  cursor: pointer;
  box-shadow: 0 1px 2px rgba(var(--sh), 0.45), inset 0 1px 0 var(--hi);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.fp-swatch:hover { transform: translateY(-1px) rotate(-3deg); }
.fp-swatch.is-active {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent), 0 1px 3px rgba(var(--sh), 0.5);
  transform: rotate(-2deg);
}
.fp-swatch:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--accent-glow); }
.fp-charcoal { background: linear-gradient(135deg, #262b2c 55%, #17191a 55%); }
.fp-midnight { background: linear-gradient(135deg, #232836 55%, #14171f 55%); }
.fp-deepnight { background: linear-gradient(135deg, #16161f 55%, #0a0a0f 55%); }

/* ---------- Utility ---------- */
.row { display: flex; align-items: center; gap: 12px; }
.row.wrap { flex-wrap: wrap; }
.stack-v { display: flex; flex-direction: column; gap: 12px; }
.grow { flex: 1; min-width: 0; }
.muted { color: var(--ink-faint); }
.soft { color: var(--ink-soft); }
.accent-text { color: var(--accent); }
.mono-num { font-variant-numeric: tabular-nums; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }

.section-label {
  display: inline-block;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 17px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* scrollbars */
::-webkit-scrollbar { width: 11px; height: 11px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 6px; border: 3px solid var(--bg); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}
