﻿/* ============================================================
   Nanami �� Tavern hearth design system
   Wooden planks + firelight + nailed parchment
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Cormorant+SC:wght@500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');
@import url('https://cdn.jsdelivr.net/npm/lxgw-wenkai-webfont@1.7.0/style.css');

:root {
  --hue: 32;
  --parchment-strength: 1;

  /* Tavern hearth palette */
  --hearth:      oklch(0.62 0.18 45);
  --hearth-deep: oklch(0.45 0.18 35);
  --ale:         oklch(0.65 0.16 70);
  --ale-foam:    oklch(0.92 0.06 85);
  --ironwood:    oklch(0.32 0.05 40);
  --ironwood-dk: oklch(0.22 0.04 35);
  --ironwood-lt: oklch(0.45 0.06 45);
  --candle:      oklch(0.82 0.14 80);
  --bg-deep:     oklch(0.18 0.04 35);
  --bg-deeper:   oklch(0.14 0.03 30);
  --bg-pitch:    oklch(0.10 0.03 30);

  /* Sepia ink (used inside parchment cards) */
  --ink:        oklch(0.28 0.10 35);
  --ink-soft:   oklch(0.32 0.08 35);
  --ink-mute:   oklch(0.45 0.10 40);
  --ink-faint:  oklch(0.55 0.10 45);

  /* Parchment surfaces */
  --paper:      oklch(0.90 0.05 75);
  --paper-2:    oklch(0.84 0.06 70);
  --paper-3:    oklch(0.78 0.06 65);
  --paper-4:    oklch(0.85 0.04 75);
  --paper-edge: oklch(0.32 0.06 40);

  /* Bronze accents (kept) */
  --bronze:        var(--hearth);
  --bronze-deep:   var(--hearth-deep);
  --bronze-light:  oklch(0.85 0.18 70);
  --bronze-glow:   oklch(0.95 0.18 80);

  /* Fire / status */
  --fire-glow:  oklch(0.85 0.18 70);
  --night-text: oklch(0.85 0.10 65);
  --night-mute: oklch(0.65 0.08 60);
  --night-faint:oklch(0.55 0.06 55);

  --alliance:   oklch(0.55 0.14 250);
  --horde:      oklch(0.50 0.16 25);
  --success:    oklch(0.55 0.10 145);
  --warn:       oklch(0.65 0.13 55);
  --error:      oklch(0.55 0.18 25);

  --rare-poor:    oklch(0.60 0.01 40);
  --rare-common:  oklch(0.30 0.02 40);
  --rare-uncommon:oklch(0.50 0.10 145);
  --rare-rare:    oklch(0.50 0.10 250);
  --rare-epic:    oklch(0.50 0.13 305);
  --rare-legend:  oklch(0.65 0.13 60);

  --font-serif: 'EB Garamond', 'LXGW WenKai', 'Songti SC', 'STSong', 'Times New Roman', serif;
  --font-display: 'Cormorant SC', 'EB Garamond', 'LXGW WenKai', serif;
  --font-cn: 'LXGW WenKai', 'EB Garamond', 'Songti SC', serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;

  --r-sm: 2px;
  --r-md: 3px;
  --r-lg: 4px;

  --shadow-press: inset 0 1px 0 rgba(255,255,255,.4), inset 0 -1px 0 rgba(0,0,0,.08);
  --shadow-emboss: 0 4px 12px oklch(0.10 0.03 30 / .4);
  --shadow-deep: 0 8px 24px oklch(0.05 0.02 25 / .55);

  /* Legacy aliases */
  --bg:      var(--bg-deep);
  --card:    var(--paper-2);
  --border:  var(--paper-edge);
  --text:    var(--night-text);
  --muted:   var(--night-mute);
  --accent:  var(--bronze-light);
  --accent2: var(--bronze);
  --sidebar-bg: var(--bg-deep);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-serif);
  color: var(--night-text);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  min-height: 100vh;
  position: relative;
  background:
    radial-gradient(ellipse 80% 50% at 50% 100%, oklch(0.45 0.18 35 / .25), transparent 60%),
    linear-gradient(180deg, var(--bg-deep), var(--bg-deeper));
}
:lang(zh), [lang^="zh"] body { font-family: var(--font-cn); }

/* Plank background �� repeated wood plank texture */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.5;
  z-index: 0;
  background:
    repeating-linear-gradient(90deg,
      var(--bg-deep) 0 240px,
      var(--bg-deeper) 240px 242px,
      var(--bg-deep) 242px 480px,
      var(--bg-deeper) 480px 482px),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='2' seed='2'/><feColorMatrix values='0 0 0 0 0.05  0 0 0 0 0.03  0 0 0 0 0.02  0 0 0 0.55 0'/></filter><rect width='200' height='200' filter='url(%23n)' opacity='0.30'/></svg>");
}
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.07;
  background: url("../img/nanami_img.png") no-repeat right 5vw top 130px / min(42vw, 520px) auto;
  filter: sepia(1) saturate(0.75) brightness(1.18);
  mix-blend-mode: soft-light;
}

main, header, footer { position: relative; z-index: 1; }

/* ============================================================
   Header �� wooden beam
   ============================================================ */
.site-header {
  padding: 10px 28px;
  background:
    linear-gradient(180deg, oklch(0.32 0.06 40), oklch(0.24 0.05 35) 50%, oklch(0.18 0.04 30)),
    repeating-linear-gradient(90deg, oklch(0.30 0.05 40) 0 48px, oklch(0.26 0.05 38) 48px 49px);
  background-blend-mode: multiply;
  border-bottom: 4px solid var(--bg-pitch);
  box-shadow: inset 0 -8px 16px oklch(0.10 0.03 30 / .6), 0 4px 0 oklch(0.45 0.18 35 / .35);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  position: sticky; top: 0; z-index: 20;
}
.site-header .brand {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: inherit;
}
.site-logo {
  display: block;
  object-fit: cover;
  flex: 0 0 auto;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}
.site-logo-header {
  width: 56px;
  height: 56px;
}
.site-header .brand .name {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 0.10em;
  color: oklch(0.92 0.10 70);
  line-height: 1;
}
.site-header .brand .sub {
  margin-top: 4px;
  font-family: var(--font-display);
  font-size: 9px;
  letter-spacing: 0.30em;
  color: oklch(0.70 0.12 60);
  text-transform: uppercase;
}
.site-header nav.main-nav {
  display: flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-display);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.site-header nav.main-nav a {
  padding: 8px 16px;
  text-decoration: none;
  color: oklch(0.78 0.10 65);
  border: 1px solid transparent;
  transition: filter 0.12s;
}
.site-header nav.main-nav a:hover { color: oklch(0.92 0.10 70); }
.site-header nav.main-nav a.active {
  color: oklch(0.18 0.04 30);
  background: linear-gradient(180deg, oklch(0.85 0.16 70), oklch(0.65 0.18 50));
  border: 1px solid oklch(0.30 0.10 35);
  box-shadow: inset 0 1px 0 oklch(0.95 0.10 80 / .5);
}
.site-header nav.main-nav a.user-name { color: oklch(0.85 0.16 70); font-weight: 600; }
.site-header nav.main-nav .divider { width: 1px; height: 20px; background: oklch(0.10 0.03 30); margin: 0 8px; }
.site-header nav.main-nav .lang-switch {
  display: inline-flex;
  border: 1px solid var(--ironwood-lt);
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: 0.10em;
}
.site-header nav.main-nav .lang-switch a {
  padding: 4px 10px;
  border: none;
  text-decoration: none;
  color: oklch(0.68 0.08 60);
}
.site-header nav.main-nav .lang-switch a:hover { background: oklch(0.30 0.06 40); }
.site-header nav.main-nav .lang-switch a.active {
  background: linear-gradient(180deg, oklch(0.85 0.16 70), oklch(0.55 0.18 45));
  color: oklch(0.18 0.05 30);
  font-weight: 700;
}

.nav-toggle {
  display: none;
  background: linear-gradient(180deg, oklch(0.32 0.06 40), oklch(0.22 0.05 35));
  border: 1px solid var(--ironwood-lt);
  border-radius: 2px;
  padding: 6px 8px;
  cursor: pointer;
  color: oklch(0.85 0.10 65);
}
.nav-toggle svg { display: block; }

/* ============================================================
   Footer �� slim dark beam
   ============================================================ */
.site-footer {
  margin-top: 64px;
  padding: 28px 32px 20px;
  background: linear-gradient(180deg, var(--bg-deep), var(--bg-pitch));
  border-top: 4px solid oklch(0.06 0.02 25);
  color: var(--night-faint);
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  text-align: center;
  box-shadow: inset 0 4px 8px oklch(0.05 0.02 25);
}
.site-footer .footer-grid {
  max-width: 1200px;
  margin: 0 auto 22px;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 32px;
  text-align: left;
}
.site-footer .footer-grid .motto {
  margin-top: 14px;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 14px;
  letter-spacing: 0.04em;
  text-transform: none;
  color: var(--night-mute);
  max-width: 280px;
  line-height: 1.6;
}
.site-footer .footer-col {
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: 0.20em;
  text-transform: uppercase;
}
.site-footer .footer-col .head { color: oklch(0.78 0.10 65); margin-bottom: 12px; }
.site-footer .footer-col ul {
  margin: 0; padding: 0; list-style: none;
  display: flex; flex-direction: column; gap: 8px;
  font-family: var(--font-serif);
  font-size: 13px;
  letter-spacing: 0.04em;
  text-transform: none;
  color: var(--night-mute);
}
.site-footer .footer-col a {
  color: var(--night-mute);
  text-decoration: none;
  border-bottom: 1px dotted var(--ironwood-lt);
  padding-bottom: 1px;
}
.site-footer .footer-col a:hover { color: var(--bronze-light); }
.site-footer .footer-base {
  border-top: 1px solid oklch(0.10 0.03 30);
  padding-top: 18px;
  font-family: var(--font-display);
  letter-spacing: 0.20em;
  font-size: 10px;
}

/* ============================================================
   PaperPanel �� nailed parchment card
   ============================================================ */
.paper-panel {
  position: relative;
  padding: 32px 36px;
  background:
    radial-gradient(ellipse 100% 60% at 50% 0%, oklch(0.95 0.06 80 / .35), transparent 70%),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='4'/><feColorMatrix values='0 0 0 0 0.30  0 0 0 0 0.20  0 0 0 0 0.10  0 0 0 0.45 0'/></filter><rect width='220' height='220' filter='url(%23n)' opacity='0.18'/></svg>"),
    linear-gradient(180deg, var(--paper), var(--paper-2));
  border: 2px solid var(--paper-edge);
  box-shadow: inset 0 0 0 1px oklch(0.95 0.05 75 / .5), var(--shadow-emboss);
  color: var(--ink);
}
.paper-panel.tilt-l { transform: rotate(-0.3deg); }
.paper-panel.tilt-r { transform: rotate(0.3deg); }
.paper-panel.tilt-l2 { transform: rotate(-0.15deg); }
.paper-panel.tilt-r2 { transform: rotate(0.15deg); }
.paper-panel .nail {
  position: absolute;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, oklch(0.50 0.04 40), oklch(0.20 0.03 30) 70%);
  box-shadow: inset 0 1px 0 oklch(0.65 0.04 50 / .4), 0 1px 2px oklch(0.05 0.02 25 / .8);
  pointer-events: none;
}
.paper-panel .nail.tl { top: 8px; left: 8px; }
.paper-panel .nail.tr { top: 8px; right: 8px; }
.paper-panel .nail.bl { bottom: 8px; left: 8px; }
.paper-panel .nail.br { bottom: 8px; right: 8px; }
.paper-panel .nail.sm { width: 8px; height: 8px; }

/* legacy alias */
.parchment-card { /* maps to paper-panel for backward compat */
  position: relative;
  padding: 28px 30px;
  background:
    radial-gradient(ellipse 100% 60% at 50% 0%, oklch(0.95 0.06 80 / .35), transparent 70%),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='4'/><feColorMatrix values='0 0 0 0 0.30  0 0 0 0 0.20  0 0 0 0 0.10  0 0 0 0.45 0'/></filter><rect width='220' height='220' filter='url(%23n)' opacity='0.18'/></svg>"),
    linear-gradient(180deg, var(--paper), var(--paper-2));
  border: 2px solid var(--paper-edge);
  box-shadow: inset 0 0 0 1px oklch(0.95 0.05 75 / .5), var(--shadow-emboss);
  color: var(--ink);
}

/* Bronze rule + flourish (kept) */
.bronze-rule {
  height: 2px;
  border: none;
  margin: 0;
  background: linear-gradient(90deg,
    transparent, var(--hearth-deep) 15%, var(--hearth) 50%, var(--hearth-deep) 85%, transparent);
}
.bronze-rule.thin {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--hearth-deep) 50%, transparent);
}
.bronze-flourish {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--bronze-light);
}
.bronze-flourish::before, .bronze-flourish::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--bronze), transparent);
}
.bronze-flourish-mark {
  font-size: 10px;
  letter-spacing: 0.30em;
  font-family: var(--font-display);
  text-transform: uppercase;
}

/* ============================================================
   Buttons �� firelit primary / wooden ghost
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 24px;
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: oklch(0.18 0.04 30);
  background: linear-gradient(180deg, var(--bronze-light) 0%, var(--bronze) 50%, oklch(0.45 0.18 40) 100%);
  border: 2px solid oklch(0.30 0.10 35);
  border-radius: var(--r-sm);
  cursor: pointer;
  text-decoration: none;
  box-shadow:
    inset 0 1px 0 oklch(0.95 0.10 80 / .6),
    inset 0 -2px 4px oklch(0.30 0.10 35 / .5),
    0 4px 12px oklch(0.55 0.18 45 / .35);
  transition: filter .12s, transform .08s;
  white-space: nowrap;
}
.btn:hover { filter: brightness(1.08); color: oklch(0.18 0.04 30); }
.btn:active { transform: translateY(1px); }
.btn:disabled, .btn[disabled] { opacity: 0.5; cursor: not-allowed; }
.btn-ghost {
  color: oklch(0.85 0.10 65);
  background: linear-gradient(180deg, oklch(0.32 0.06 40), oklch(0.22 0.05 35));
  border: 2px solid var(--ironwood-lt);
  box-shadow:
    inset 0 1px 0 oklch(0.55 0.10 50 / .4),
    inset 0 -2px 4px var(--bg-pitch),
    0 2px 6px oklch(0.10 0.03 30 / .5);
}
.btn-ghost:hover { color: oklch(0.92 0.10 70); }
.btn-sm { padding: 7px 14px; font-size: 11px; letter-spacing: 0.14em; }
.btn-lg { padding: 14px 32px; font-size: 16px; letter-spacing: 0.16em; }
.btn-block { width: 100%; }
.btn-paper {
  color: var(--ink);
  background: linear-gradient(180deg, var(--paper), var(--paper-3));
  border: 1px solid var(--paper-edge);
  box-shadow: inset 0 1px 0 oklch(0.95 0.05 75 / .5);
}
.btn-paper:hover { color: var(--ink); }
.btn-danger {
  background: linear-gradient(180deg, oklch(0.65 0.13 25), oklch(0.45 0.13 25));
  border-color: oklch(0.40 0.13 25);
  color: oklch(0.96 0.02 80);
}

/* ============================================================
   Form fields (dark / light)
   ============================================================ */
.field {
  display: block;
  width: 100%;
  padding: 10px 14px;
  font-family: var(--font-serif);
  font-size: 15px;
  color: oklch(0.20 0.06 30);
  background: linear-gradient(180deg, var(--paper-3), var(--paper-4));
  border: 1.5px solid var(--paper-edge);
  border-radius: var(--r-sm);
  box-shadow: inset 0 2px 3px oklch(0.20 0.05 35 / .25), inset 0 -1px 0 oklch(0.95 0.05 75 / .4);
  outline: none;
  transition: border-color .12s, box-shadow .12s;
}
.field:focus {
  border-color: var(--hearth);
  box-shadow:
    inset 0 2px 3px oklch(0.20 0.05 35 / .25),
    0 0 0 3px oklch(0.62 0.18 45 / .25);
}
.field::placeholder { color: oklch(0.50 0.10 45); font-style: italic; }
textarea.field { resize: vertical; min-height: 80px; }

.label {
  display: block;
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 6px;
}
.input-hint {
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-faint);
}

/* ============================================================
   TavernTile �� dark stat tile
   ============================================================ */
.tavern-tile {
  padding: 18px 20px;
  background: linear-gradient(180deg, oklch(0.26 0.06 40), oklch(0.20 0.05 35));
  border: 1.5px solid oklch(0.40 0.08 45);
  box-shadow: inset 0 1px 0 oklch(0.50 0.08 50 / .4), inset 0 -2px 4px var(--bg-pitch);
  color: var(--night-text);
}
.tavern-tile .tt-head {
  display: flex; align-items: center; gap: 10px; margin-bottom: 8px;
  font-family: var(--font-display);
  font-size: 10px; letter-spacing: 0.20em; text-transform: uppercase;
  color: var(--night-mute);
}
.tavern-tile .tt-num {
  font-family: var(--font-display);
  font-size: 30px; font-weight: 700;
  color: var(--night-text);
  line-height: 1;
}
.tavern-tile .tt-num.glow {
  color: oklch(0.85 0.16 70);
  text-shadow: 0 0 12px oklch(0.55 0.18 45 / .4);
}
.tavern-tile .tt-sub {
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--night-faint);
}

/* Light parchment "stat" inside paper-panel */
.paper-stat {
  padding: 14px 16px;
  background: linear-gradient(180deg, var(--paper), var(--paper-2));
  border: 1px solid var(--paper-edge);
  text-align: center;
}
.paper-stat .v {
  font-family: var(--font-display);
  font-size: 28px; font-weight: 700;
  color: var(--ink);
  line-height: 1;
}
.paper-stat .l {
  margin-top: 4px;
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

/* ============================================================
   Status pulse / chips
   ============================================================ */
.pulse {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--success);
  box-shadow: 0 0 0 0 oklch(0.55 0.10 145 / .6);
  animation: pulse 2.2s infinite;
  flex-shrink: 0;
}
.pulse.warn { background: var(--warn); }
.pulse.error { background: var(--error); }
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 oklch(0.55 0.10 145 / .6); }
  70%  { box-shadow: 0 0 0 8px oklch(0.55 0.10 145 / 0); }
  100% { box-shadow: 0 0 0 0 oklch(0.55 0.10 145 / 0); }
}
@keyframes flicker {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.85; }
}

.chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  background: oklch(0.85 0.04 75);
  border: 1px solid var(--paper-edge);
  color: var(--ink);
}
/* Status chip variants �� solid bg + clearly contrasting text */
.chip.success {
  background: oklch(0.92 0.08 145);
  border-color: oklch(0.45 0.13 145);
  color: oklch(0.28 0.13 145);
}
.chip.warn {
  background: oklch(0.92 0.10 75);
  border-color: oklch(0.45 0.14 60);
  color: oklch(0.30 0.14 60);
}
.chip.error {
  background: oklch(0.92 0.08 25);
  border-color: oklch(0.45 0.16 25);
  color: oklch(0.32 0.18 25);
}
.chip.fire {
  background: oklch(0.40 0.18 35);
  border-color: oklch(0.30 0.16 35);
  color: oklch(0.96 0.10 80);
  box-shadow: 0 0 8px oklch(0.55 0.18 45 / .35), inset 0 1px 0 oklch(0.95 0.10 80 / .3);
  text-shadow: 0 1px 0 oklch(0.20 0.10 30 / .5);
}
.chip.alliance {
  background: oklch(0.55 0.14 250);
  border-color: oklch(0.40 0.14 250);
  color: oklch(0.96 0.02 80);
}
.chip.horde {
  background: oklch(0.50 0.16 25);
  border-color: oklch(0.35 0.16 25);
  color: oklch(0.96 0.02 80);
}

.faction {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 10px;
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  font-weight: 700;
  color: oklch(0.96 0.02 80);
}
.faction.alliance { background: var(--alliance); }
.faction.horde { background: var(--horde); }

/* Progress (used in trade skills, reputation) */
.progress {
  position: relative;
  height: 8px;
  background: oklch(0.85 0.04 75);
  border: 1px solid var(--paper-edge);
  overflow: hidden;
}
.progress > .bar {
  height: 100%;
  background: linear-gradient(180deg, var(--bronze-light), var(--bronze) 50%, var(--bronze-deep));
  box-shadow: inset 0 1px 0 oklch(0.95 0.10 80 / .5);
}

/* Flash messages */
.flash {
  margin: 0 0 16px 0;
  padding: 10px 16px;
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.65;
  border: 1.5px solid;
  background: linear-gradient(180deg, var(--paper), var(--paper-2));
  text-shadow: none;
}
.flash.info   { border-color: oklch(0.48 0.13 245); color: oklch(0.24 0.10 245); background: linear-gradient(180deg, oklch(0.91 0.05 78), oklch(0.85 0.05 72)); }
.flash.warn,
.flash.warning{ border-color: oklch(0.52 0.16 55); color: oklch(0.27 0.10 52); background: linear-gradient(180deg, oklch(0.92 0.06 78), oklch(0.86 0.06 70)); }
.flash.error  { border-color: var(--error); color: oklch(0.28 0.13 25); background: linear-gradient(180deg, oklch(0.92 0.05 52), oklch(0.86 0.05 48)); }
.flash.success{ border-color: var(--success); color: oklch(0.24 0.10 145); background: linear-gradient(180deg, oklch(0.92 0.05 95), oklch(0.86 0.05 88)); }

/* ============================================================
   Hero �� nailed-up notice board
   ============================================================ */
.hero {
  position: relative;
  padding: 48px 24px 40px;
  text-align: center;
  overflow: hidden;
}
.hero .lantern {
  position: absolute;
  width: 60px;
  pointer-events: none;
}
.hero .lantern .lantern-cord { width: 2px; height: 30px; background: var(--bg-deep); margin: 0 auto; }
.hero .lantern .lantern-body {
  width: 44px; height: 56px; margin: 0 auto;
  background: linear-gradient(180deg, oklch(0.30 0.06 40), oklch(0.18 0.04 30));
  border: 2px solid oklch(0.10 0.03 30);
  position: relative;
  box-shadow: 0 0 40px oklch(0.85 0.18 70 / .55), 0 0 80px oklch(0.65 0.18 55 / .3);
}
.hero .lantern .lantern-body::before {
  content: ''; position: absolute; inset: 6px;
  background: radial-gradient(circle, oklch(0.95 0.18 80), oklch(0.65 0.18 55));
  box-shadow: inset 0 0 12px oklch(0.95 0.18 80);
  animation: flicker 2s infinite alternate;
}
.hero .lantern.l { left: 5%; top: 30px; }
.hero .lantern.r { right: 5%; top: 30px; }

.hero .poster {
  position: relative;
  width: 100%;
  max-width: 920px;
  margin: 0 auto;
  padding: 56px 48px 48px;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, oklch(0.95 0.08 80 / .8), transparent 70%),
    radial-gradient(ellipse 100% 100% at 50% 100%, oklch(0.50 0.12 35 / .15), transparent 70%),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 0.30  0 0 0 0 0.20  0 0 0 0 0.10  0 0 0 0.50 0'/></filter><rect width='200' height='200' filter='url(%23n)' opacity='0.22'/></svg>"),
    linear-gradient(180deg, var(--paper), var(--paper-2));
  border: 2px solid var(--paper-edge);
  box-shadow:
    inset 0 0 0 1px oklch(0.95 0.05 75 / .5),
    inset 0 0 80px oklch(0.40 0.10 40 / .25),
    0 8px 24px oklch(0.10 0.03 30 / .5),
    0 0 60px oklch(0.55 0.18 45 / .25);
  transform: rotate(-0.4deg);
  color: var(--ink);
}
.hero .poster .hero-title-lock {
  --hero-title-size: clamp(72px, 11vw, 144px);
  position: relative;
  display: inline-block;
  max-width: 100%;
  margin: 14px auto 4px;
  font-size: var(--hero-title-size);
  line-height: 0.9;
}
.hero .poster .hero-cat {
  position: absolute;
  top: -0.35em;
  right: 0.03em;
  width: 0.915em;
  height: auto;
  pointer-events: none;
  user-select: none;
  z-index: 2;
}
.hero .poster .eyebrow {
  font-family: var(--font-display);
  font-size: 11px; letter-spacing: 0.40em;
  color: oklch(0.40 0.12 35);
  text-transform: uppercase;
}
.hero .poster .divider {
  margin: 14px auto 4px;
  max-width: 200px; height: 2px;
  background: linear-gradient(90deg, transparent, var(--hearth-deep), transparent);
}
.hero .poster h1 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1em;
  font-weight: 700;
  letter-spacing: 0.10em;
  line-height: 0.9;
  color: oklch(0.30 0.10 35);
  text-shadow: 0 2px 0 oklch(0.95 0.05 75 / .6), 0 4px 12px oklch(0.50 0.18 35 / .3);
}
.hero .poster .sub {
  font-family: var(--font-cn);
  font-size: clamp(20px, 2.4vw, 30px);
  letter-spacing: 0.40em;
  color: oklch(0.45 0.15 35);
}
:lang(en) .hero .poster .sub { font-family: var(--font-display); letter-spacing: 0.16em; }
.hero .poster .tagline {
  margin: 32px 0;
  font-family: var(--font-cn);
  font-style: italic;
  font-size: clamp(16px, 2vw, 22px);
  color: oklch(0.32 0.08 35);
  line-height: 1.5;
}
:lang(en) .hero .poster .tagline { font-family: var(--font-serif); }
.hero .poster .cta-row { display: flex; justify-content: center; gap: 14px; flex-wrap: wrap; }

/* ============================================================
   Hearth status strip
   ============================================================ */
.hearth-strip {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr 1fr;
  background: linear-gradient(180deg, oklch(0.28 0.06 40), oklch(0.22 0.05 35));
  border: 2px solid oklch(0.45 0.10 40);
  box-shadow:
    inset 0 1px 0 oklch(0.55 0.10 50 / .4),
    inset 0 -2px 4px var(--bg-pitch),
    0 0 30px oklch(0.55 0.18 45 / .2);
}
.hearth-cell {
  padding: 18px 16px;
  border-left: 1px solid var(--bg-pitch);
  display: flex; flex-direction: column; justify-content: center;
  color: var(--night-text);
}
.hearth-cell:first-child { border-left: none; padding: 22px 24px; border-right: 1px solid oklch(0.55 0.10 50 / .4); }
.hearth-cell .head {
  display: flex; align-items: center; gap: 14px;
}
.hearth-cell .flame {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 60%, oklch(0.95 0.18 80), oklch(0.55 0.18 40) 70%);
  box-shadow: 0 0 16px oklch(0.85 0.18 70 / .6), inset 0 -3px 6px oklch(0.40 0.18 35);
  flex-shrink: 0;
}
.hearth-cell .head-l {
  font-family: var(--font-display);
  font-size: 16px; letter-spacing: 0.14em;
  color: oklch(0.85 0.14 70);
  text-transform: uppercase;
}
.hearth-cell .head-l.error { color: var(--error); }
.hearth-cell .head-s {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--night-mute);
  margin-top: 4px;
}
.hearth-cell .num {
  font-family: var(--font-display);
  font-size: 30px; font-weight: 700;
  color: oklch(0.85 0.16 70);
  line-height: 1;
  text-shadow: 0 0 12px oklch(0.55 0.18 45 / .4);
}
.hearth-cell .num small {
  font-size: 13px;
  color: var(--night-mute);
  margin-left: 6px;
}
.hearth-cell .lab {
  margin-top: 6px;
  font-family: var(--font-display);
  font-size: 10px; letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--night-mute);
}

/* ============================================================
   Container utilities
   ============================================================ */
.container {
  max-width: 1180px;
  margin: 0 auto;
  padding: 32px 24px;
}
.container.narrow { max-width: 920px; }
.container.tight { max-width: 540px; padding: 60px 24px; }

/* ============================================================
   Auth card (TavernAuth)
   ============================================================ */
.auth-shell {
  position: relative;
  max-width: 540px;
  margin: 60px auto;
}
.auth-shell .lantern.l { left: -80px; top: 20px; }
.auth-shell .lantern.r { right: -80px; top: 20px; }
.auth-card {
  position: relative;
  padding: 40px 44px 32px;
}
.auth-card h2 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 30px;
  letter-spacing: 0.06em;
  color: var(--ink);
  text-align: center;
}
.auth-card .sub {
  margin-top: 6px;
  font-family: var(--font-cn);
  font-style: italic;
  font-size: 14px;
  color: var(--ink-mute);
  text-align: center;
}
.auth-card .head-rule {
  margin: 14px auto 22px;
  max-width: 200px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--hearth-deep), transparent);
}

/* ============================================================
   Char card / Backup card / Snapshot timeline
   ============================================================ */
.char-roster, .backup-roster {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(520px, 1fr));
  gap: 14px;
}
.char-card {
  padding: 22px 26px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  align-items: center;
}
.char-card .lvl-medallion {
  width: 96px;
  text-align: center;
}
.char-card .lvl-medallion .crest {
  position: relative;
  aspect-ratio: 1 / 1;
  background: radial-gradient(circle at 30% 28%, oklch(0.42 0.04 50), oklch(0.18 0.03 30) 70%);
  border: 2px solid var(--paper-edge);
  box-shadow:
    inset 0 0 0 1px oklch(0.60 0.10 50 / .35),
    inset 0 -3px 0 oklch(0.10 0.02 30 / .6),
    0 1px 2px oklch(0.10 0.02 30 / .4);
  display: flex; align-items: center; justify-content: center;
}
.char-card .lvl-medallion .crest .lvl-tag {
  position: absolute;
  top: -8px; right: -8px;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: oklch(0.20 0.05 30);
  border: 2px solid var(--paper-edge);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  color: oklch(0.92 0.10 70);
  box-shadow: 0 0 8px oklch(0.55 0.18 45 / .4);
}
.char-card .lvl-medallion .crest .cls {
  position: absolute;
  bottom: 4px; left: 0; right: 0;
  font-family: var(--font-display);
  font-size: 9px; letter-spacing: 0.18em;
  text-transform: uppercase;
  color: oklch(0.70 0.10 60);
  text-align: center;
}
.char-card .lvl-medallion .faction-strip {
  margin-top: 6px;
  padding: 4px 0;
  font-family: var(--font-display);
  font-size: 9px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: oklch(0.96 0.02 80);
  text-align: center;
}
.char-card .lvl-medallion .faction-strip.alliance { background: var(--alliance); }
.char-card .lvl-medallion .faction-strip.horde { background: var(--horde); }
.char-card .lvl-medallion .faction-strip.neutral { background: var(--ironwood-lt); }
.char-card .info .name {
  font-family: var(--font-display);
  font-size: 24px; font-weight: 700;
  color: var(--ink);
  letter-spacing: 0.04em;
}
.char-card .info .meta {
  font-family: var(--font-serif);
  font-size: 14px;
  color: var(--ink-mute);
  margin-top: 4px;
}
.char-card .info .stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-top: 12px;
}

/* Snapshot table (backup list) */
.scroll-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-mono);
  font-size: 13px;
}
.scroll-table thead tr { border-bottom: 2px solid var(--paper-edge); background: oklch(0.85 0.04 75 / .35); }
.scroll-table thead th {
  text-align: left;
  padding: 10px 14px;
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--ink);
  font-weight: 600;
}
.scroll-table tbody tr {
  border-bottom: 1px dashed oklch(0.45 0.10 40 / .3);
}
.scroll-table tbody tr:nth-child(even) { background: oklch(0.85 0.04 75 / .20); }
.scroll-table tbody td { padding: 12px 14px; color: var(--ink); vertical-align: middle; }

/* Filter ribbon (chips on backup list) */
.ribbon {
  display: flex; gap: 6px; flex-wrap: wrap;
  font-family: var(--font-display);
  font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  margin-bottom: 14px;
}
.ribbon a, .ribbon button {
  padding: 6px 14px;
  background: oklch(0.20 0.05 35);
  border: 1px solid oklch(0.45 0.10 50);
  color: var(--night-text);
  text-decoration: none;
  cursor: pointer;
}
.ribbon a:hover { background: oklch(0.26 0.06 40); }
.ribbon a.active, .ribbon button.active {
  color: oklch(0.18 0.05 30);
  background: linear-gradient(180deg, oklch(0.85 0.16 70), oklch(0.65 0.18 50));
  box-shadow: inset 0 1px 0 oklch(0.95 0.10 80 / .4);
}

/* Snapshot detail scroll page �� grid uses gap-as-divider so wrap is consistent */
.scroll-stat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: oklch(0.32 0.06 40 / .5);
  border: 1px solid oklch(0.32 0.06 40 / .5);
  margin: 22px 0;
}
.scroll-stat {
  padding: 14px 16px;
  text-align: center;
  background: var(--paper);
}
.scroll-stat.clickable {
  cursor: pointer;
  transition: background-color .12s, filter .08s;
}
.scroll-stat.clickable:hover {
  background: oklch(0.85 0.06 75);
}
.scroll-stat.clickable:active {
  filter: brightness(0.95);
}
.scroll-stat.clickable .v {
  text-decoration: underline dotted oklch(0.45 0.15 35 / .5);
  text-underline-offset: 4px;
}
.scroll-stat .v {
  font-family: var(--font-display);
  font-size: 26px; font-weight: 700;
  color: var(--ink);
  line-height: 1;
}
.scroll-stat .l {
  margin-top: 4px;
  font-family: var(--font-display);
  font-size: 9px; letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.scroll-section { margin-bottom: 28px; }
.scroll-section .head {
  display: flex; align-items: baseline; gap: 12px; margin-bottom: 12px;
}
.scroll-section .head h3 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 18px; font-weight: 700;
  color: var(--ink);
  letter-spacing: 0.06em;
}
.scroll-section .head .rule {
  flex: 1; height: 1px;
  background: linear-gradient(90deg, var(--hearth-deep), transparent);
}
.scroll-section .head .head-sub {
  font-family: var(--font-cn);
  font-style: italic; font-size: 12px;
  color: var(--ink-mute);
}

/* ============================================================
   Admin shell �� wood-paneled control room
   ============================================================ */
.admin-shell { min-height: 100vh; display: grid; grid-template-columns: 220px 1fr; }
.admin-shell::before {
  /* hide global plank for admin (uses own bg) */
}
.admin-shell .admin-sidebar {
  position: relative; z-index: 2;
  padding: 20px 0;
  background: linear-gradient(180deg, oklch(0.20 0.04 35), oklch(0.14 0.03 30));
  border-right: 4px solid oklch(0.06 0.02 25);
  box-shadow: inset -8px 0 16px oklch(0.10 0.03 30 / .5);
}
.admin-shell .admin-sidebar .brand-block {
  padding: 0 22px 16px;
  border-bottom: 1px solid oklch(0.30 0.06 40);
  display: flex; flex-direction: column; gap: 6px;
}
.admin-shell .admin-sidebar .brand-block .admin-logo {
  width: 76px;
  height: 76px;
  margin-bottom: 4px;
}
.admin-shell .admin-sidebar .brand-block .name {
  font-family: var(--font-display);
  font-size: 14px; font-weight: 700;
  letter-spacing: 0.10em;
  color: oklch(0.92 0.10 70);
}
.admin-shell .admin-sidebar .brand-block .sub {
  font-family: var(--font-display);
  font-size: 8px; letter-spacing: 0.30em;
  color: oklch(0.65 0.12 60);
  text-transform: uppercase;
}
.site-footer .footer-logo {
  width: 50px;
  height: 50px;
}
.admin-shell .admin-sidebar nav { padding: 14px 0; }
.admin-shell .admin-sidebar nav a {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 22px;
  font-family: var(--font-display);
  font-size: 12px; letter-spacing: 0.18em;
  text-transform: uppercase;
  color: oklch(0.78 0.10 65);
  text-decoration: none;
  border-left: 3px solid transparent;
  cursor: pointer;
}
.admin-shell .admin-sidebar nav a:hover { background: oklch(0.26 0.06 40); }
.admin-shell .admin-sidebar nav a.active {
  color: oklch(0.18 0.05 30);
  background: linear-gradient(90deg, oklch(0.85 0.16 70), oklch(0.55 0.18 45));
  border-left-color: oklch(0.95 0.18 80);
}
.admin-shell .admin-sidebar nav a .icon {
  width: 14px; height: 14px;
  flex-shrink: 0;
}
.admin-shell .admin-content {
  position: relative; z-index: 1;
  padding: 28px 32px;
  min-width: 0;
  color: var(--night-text);
}
.admin-page-head { margin-bottom: 22px; }
.admin-page-head h1 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 28px; font-weight: 700;
  letter-spacing: 0.06em;
  color: oklch(0.92 0.10 70);
}
.admin-page-head .desc {
  margin-top: 4px;
  font-family: var(--font-cn);
  font-style: italic;
  font-size: 13px;
  color: var(--night-mute);
}
.admin-content .data-table { width: 100%; border-collapse: collapse; }

/* ============================================================
   Helpers
   ============================================================ */
.t-mute { color: var(--ink-mute); }
.t-faint { color: var(--ink-faint); }
.t-mono { font-family: var(--font-mono); }
.t-italic { font-style: italic; }
.t-center { text-align: center; }
.t-right { text-align: right; }
.flex-between { display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.flex-end { display: flex; justify-content: flex-end; align-items: center; gap: 10px; }
.gap-8 { gap: 8px; } .gap-12 { gap: 12px; } .gap-16 { gap: 16px; } .gap-20 { gap: 20px; }
.mt-8 { margin-top: 8px; } .mt-12 { margin-top: 12px; } .mt-16 { margin-top: 16px; } .mt-20 { margin-top: 20px; } .mt-24 { margin-top: 24px; } .mt-32 { margin-top: 32px; } .mt-40 { margin-top: 40px; }
.mb-8 { margin-bottom: 8px; } .mb-12 { margin-bottom: 12px; } .mb-16 { margin-bottom: 16px; } .mb-20 { margin-bottom: 20px; } .mb-24 { margin-bottom: 24px; }
.h-display { font-family: var(--font-display); font-weight: 700; }
.chapter {
  font-family: var(--font-display);
  font-size: 11px; letter-spacing: 0.30em;
  text-transform: uppercase;
  color: oklch(0.45 0.12 35);
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1100px) {
  .char-roster, .backup-roster { grid-template-columns: 1fr; }
}
@media (max-width: 980px) {
  .container { padding: 24px 16px; }
  .site-header { padding: 12px 14px; gap: 10px; }
  body::after {
    opacity: 0.05;
    background-size: 360px auto;
    background-position: center 110px;
  }
  .site-header .brand .sub { display: none; }
  .nav-toggle { display: inline-flex; }
  .site-header nav.main-nav {
    position: absolute;
    top: 100%;
    right: 0;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    background: linear-gradient(180deg, oklch(0.30 0.06 40), oklch(0.20 0.05 35));
    border: 1px solid var(--ironwood-lt);
    border-top: none;
    padding: 6px 0;
    min-width: 200px;
    display: none;
    box-shadow: var(--shadow-deep);
  }
  .site-header nav.main-nav.open { display: flex; }
  .site-header nav.main-nav a { padding: 10px 18px; }
  .site-header nav.main-nav .divider { display: none; }
  .site-header nav.main-nav .lang-switch { margin: 6px 14px; }

  .hero { padding: 32px 16px 28px; }
  .hero .lantern { display: none; }
  .hero .poster { padding: 36px 20px 28px; transform: rotate(-0.2deg); }
  .hero .poster .hero-title-lock { --hero-title-size: 64px; }
  .hero .poster .hero-cat {
    top: -0.50em;
    right: -0.06em;
    width: 1.08em;
  }
  .hero .poster .sub { font-size: 18px; letter-spacing: 0.25em; }

  .hearth-strip { grid-template-columns: 1fr 1fr; }
  .hearth-cell { border-left: none; border-top: 1px solid var(--bg-pitch); padding: 14px 16px; }
  .hearth-cell:first-child, .hearth-cell:nth-child(2) { border-top: none; }
  .hearth-cell:first-child { border-right: none; padding: 18px 16px; grid-column: 1 / -1; }

  .site-footer .footer-grid { grid-template-columns: 1fr; gap: 24px; }

  .auth-shell { margin: 30px auto; max-width: 440px; }
  .auth-shell .lantern { display: none; }
  .auth-card { padding: 32px 24px 24px; }

  .admin-shell { grid-template-columns: 1fr; }
  .admin-shell .admin-sidebar {
    width: 100%;
    border-right: none;
    border-bottom: 4px solid oklch(0.06 0.02 25);
    box-shadow: inset 0 -8px 16px oklch(0.10 0.03 30 / .5);
    padding: 8px 0;
  }
  .admin-shell .admin-sidebar .brand-block { display: none; }
  .admin-shell .admin-sidebar nav { display: flex; overflow-x: auto; padding: 0 8px; gap: 0; }
  .admin-shell .admin-sidebar nav a {
    padding: 8px 14px;
    border-left: none;
    border-bottom: 3px solid transparent;
    white-space: nowrap;
  }
  .admin-shell .admin-sidebar nav a.active { border-left: none; border-bottom-color: oklch(0.95 0.18 80); }
  .admin-shell .admin-content { padding: 20px 14px; }

  .char-card { grid-template-columns: 1fr; text-align: center; gap: 12px; }
  .char-card .lvl-medallion { margin: 0 auto; }

  .scroll-stat-grid { grid-template-columns: 1fr 1fr; }
  .scroll-stat { border-right: none; border-top: 1px solid oklch(0.32 0.06 40 / .5); }
  .scroll-stat:nth-child(1), .scroll-stat:nth-child(2) { border-top: none; }
  .scroll-stat:nth-child(odd) { border-right: 1px solid oklch(0.32 0.06 40 / .5); }
}

@media (max-width: 540px) {
  .paper-panel { padding: 22px 18px; transform: none; }
  .auth-card { padding: 28px 18px 22px; }
  .btn { padding: 10px 18px; font-size: 13px; }
  .btn-lg { padding: 12px 22px; font-size: 14px; }
  .site-logo-header { width: 46px; height: 46px; }
  .site-header .brand { gap: 10px; }
  body::after { background-size: 300px auto; }
}

/* Print-friendly */
@media print {
  body::before, body::after { display: none; }
  .site-header, .site-footer, .admin-sidebar, .nav-toggle, .item-modal { display: none !important; }
  .paper-panel, .parchment-card { box-shadow: none; transform: none; }
  body { background: var(--paper); color: var(--ink); }
}

/* ============================================================
   Item modal �� bag / bank popup
   ============================================================ */
.item-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 100;
  background: oklch(0.05 0.02 25 / .75);
  align-items: center;
  justify-content: center;
  padding: 32px 16px;
  overflow: auto;
}
.item-modal.open { display: flex; }
.item-modal .modal-card {
  position: relative;
  max-width: 920px;
  width: 100%;
  max-height: 85vh;
  overflow: auto;
  padding: 28px 32px;
  background:
    radial-gradient(ellipse 100% 60% at 50% 0%, oklch(0.95 0.06 80 / .35), transparent 70%),
    linear-gradient(180deg, var(--paper), var(--paper-2));
  border: 2px solid var(--paper-edge);
  box-shadow: inset 0 0 0 1px oklch(0.95 0.05 75 / .5), 0 12px 40px oklch(0.05 0.02 25 / .6);
  color: var(--ink);
}
.item-modal .modal-head {
  display: flex; justify-content: space-between; align-items: baseline;
  border-bottom: 1px solid oklch(0.45 0.10 40 / .4);
  padding-bottom: 14px; margin-bottom: 18px;
}
.item-modal .modal-head h3 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 26px; font-weight: 700;
  color: var(--ink);
  letter-spacing: 0.06em;
}
.item-modal .modal-head .close {
  background: none; border: none; cursor: pointer;
  font-family: var(--font-display);
  font-size: 24px; color: var(--ink-mute);
  padding: 4px 12px;
  line-height: 1;
}
.item-modal .modal-head .close:hover { color: var(--error); }
.item-bag-section { margin-bottom: 22px; }
.item-bag-title {
  font-family: var(--font-display);
  font-size: 12px; letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bronze-deep);
  margin-bottom: 10px;
  display: flex; gap: 12px; align-items: baseline;
}
.item-bag-title .count {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
  text-transform: none;
}
.item-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(56px, 1fr));
  gap: 4px;
}
.item-cell {
  position: relative;
  aspect-ratio: 1;
  background: oklch(0.86 0.03 75);
  border: 2px solid var(--rare-common);
  display: flex; align-items: flex-end; justify-content: flex-end;
  padding: 2px;
}
.item-cell.empty {
  background: oklch(0.78 0.04 70 / .4);
  border-color: oklch(0.45 0.10 40 / .25);
  border-style: dashed;
}
.item-cell .stack {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  color: var(--ink);
  background: oklch(0.95 0.05 75 / .85);
  padding: 0 3px;
  border-radius: 2px;
  text-shadow: 0 1px 0 oklch(0.95 0.05 75);
}
.item-cell.q-2 { border-color: var(--rare-uncommon); }
.item-cell.q-3 { border-color: var(--rare-rare); }
.item-cell.q-4 { border-color: var(--rare-epic); }
.item-cell.q-5 { border-color: var(--rare-legend); }
.item-cell .tooltip {
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  margin-bottom: 4px;
  padding: 4px 8px;
  background: oklch(0.10 0.03 30);
  color: oklch(0.95 0.05 75);
  font-family: var(--font-serif);
  font-size: 12px;
  white-space: nowrap;
  border: 1px solid var(--paper-edge);
  z-index: 5;
  pointer-events: none;
  opacity: 0;
  transition: opacity .12s;
}
.item-cell:hover .tooltip { opacity: 1; }
.item-cell.q-2 .tooltip { color: oklch(0.78 0.10 145); }
.item-cell.q-3 .tooltip { color: oklch(0.78 0.10 250); }
.item-cell.q-4 .tooltip { color: oklch(0.78 0.13 305); }
.item-cell.q-5 .tooltip { color: oklch(0.85 0.13 60); }

/* ============================================================
   Legacy admin compat layer
   Templates use var(--card)/var(--text)/var(--muted)/var(--accent) directly.
   Inside .admin-content, redefine these so legacy inline styles still work
   on dark surfaces with proper contrast.
   ============================================================ */
.admin-content {
  --card: oklch(0.22 0.05 35);
  --border: oklch(0.40 0.08 45);
  --text: var(--night-text);
  --muted: var(--night-mute);
  --accent: oklch(0.85 0.16 70);
  --accent2: var(--bronze-light);
  --bg: var(--bg-deep);
  --sidebar-bg: oklch(0.20 0.04 35);
  /* ADMIN_INK_READABILITY_APPLIED — the paper-theme --ink / --ink-mute /
     --ink-faint are dark browns meant for light cards; admin cards are dark,
     so .t-mute / .label / inline color:var(--ink*) were near-invisible
     (dark-on-dark). Re-map them to the night palette for proper contrast. */
  --ink: var(--night-text);
  --ink-mute: var(--night-mute);
  --ink-faint: var(--night-faint);
}
.admin-content .card,
.admin-content .stat,
.admin-content .panel,
.admin-content .info-card,
.admin-content .zone-card,
.admin-content .stat-card,
.admin-content .status-banner,
.admin-content .form-row,
.admin-content .filter-bar,
.admin-content .toolbar,
.admin-content .meta-card {
  background: linear-gradient(180deg, oklch(0.22 0.05 35), oklch(0.16 0.03 30));
  border: 1.5px solid oklch(0.40 0.08 45);
  box-shadow: inset 0 1px 0 oklch(0.50 0.08 50 / .4);
  padding: 18px 22px;
  margin-bottom: 14px;
  color: var(--night-text);
}
.admin-content .toolbar { padding: 12px 16px; }
.admin-content .filter-bar { padding: 12px 16px; }
.admin-content .card h2 {
  font-family: var(--font-display);
  color: oklch(0.92 0.10 70);
  font-size: 16px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  margin: 0 0 12px;
  font-weight: 700;
}
.admin-content .card h3 {
  font-family: var(--font-display);
  color: oklch(0.85 0.14 70);
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin: 14px 0 10px;
}
.admin-content .stat .value { color: oklch(0.85 0.16 70); }

.admin-content table:not(.scroll-table):not(.codes) {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-mono);
  font-size: 12px;
  margin-top: 8px;
  color: var(--night-text);
}
.admin-content table:not(.scroll-table):not(.codes) th {
  text-align: left;
  padding: 10px 12px;
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: oklch(0.78 0.10 65);
  font-weight: 600;
  border-bottom: 1px solid oklch(0.30 0.06 40);
  background: oklch(0.20 0.04 35);
}
.admin-content table:not(.scroll-table):not(.codes) td {
  padding: 10px 12px;
  border-bottom: 1px dashed oklch(0.30 0.06 40 / .35);
}
.admin-content table.codes th {
  font-family: var(--font-display) !important;
  letter-spacing: 0.18em !important;
  color: oklch(0.78 0.10 65);
  background: oklch(0.20 0.04 35);
  border-bottom: 1px solid oklch(0.30 0.06 40);
}
.admin-content table.codes td {
  border-bottom: 1px dashed oklch(0.30 0.06 40 / .35);
  color: var(--night-text);
}
.admin-content tr.disabled td { opacity: 0.45; }

.admin-content button:not(.btn):not(.subtle):not(.danger) {
  font-family: var(--font-display);
  padding: 7px 14px;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 700;
  background: linear-gradient(180deg, oklch(0.85 0.16 70), oklch(0.55 0.18 45));
  color: oklch(0.18 0.05 30);
  border: 1px solid oklch(0.30 0.10 35);
  cursor: pointer;
  box-shadow: inset 0 1px 0 oklch(0.95 0.10 80 / .5), 0 2px 6px oklch(0.55 0.18 45 / .25);
}
.admin-content button.primary {
  font-family: var(--font-display);
  padding: 11px 20px;
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 700;
  background: linear-gradient(180deg, oklch(0.85 0.16 70), oklch(0.55 0.18 45));
  color: oklch(0.18 0.05 30);
  border: 1px solid oklch(0.30 0.10 35);
  cursor: pointer;
  box-shadow: inset 0 1px 0 oklch(0.95 0.10 80 / .5);
  width: 100%;
  margin-top: 16px;
}
.admin-content button.subtle {
  background: linear-gradient(180deg, oklch(0.32 0.06 40), oklch(0.22 0.05 35));
  color: oklch(0.85 0.10 65);
  border: 1px solid var(--ironwood-lt);
}
.admin-content button.danger {
  background: linear-gradient(180deg, oklch(0.65 0.13 25), oklch(0.45 0.13 25));
  border-color: oklch(0.40 0.13 25);
  color: oklch(0.96 0.02 80);
}
.admin-content input[type=text],
.admin-content input[type=password],
.admin-content input[type=number],
.admin-content input[type=date],
.admin-content input[type=email],
.admin-content textarea,
.admin-content select {
  width: 100%;
  padding: 10px 12px;
  font-family: var(--font-serif);
  font-size: 14px;
  color: var(--night-text);
  background: oklch(0.18 0.04 35);
  border: 1.5px solid var(--ironwood-lt);
  outline: none;
}
.admin-content input:focus, .admin-content textarea:focus, .admin-content select:focus {
  border-color: var(--bronze);
  box-shadow: 0 0 0 3px oklch(0.62 0.18 45 / .25);
}
.admin-content label {
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--night-mute);
  display: block;
  margin: 12px 0 6px;
}
.admin-content .badge {
  display: inline-block;
  padding: 2px 8px;
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  background: oklch(0.20 0.05 35);
  border: 1px solid oklch(0.45 0.10 50);
  color: oklch(0.78 0.10 65);
}
.admin-content .badge.on { border-color: var(--success); color: var(--success); }
.admin-content .badge.off { border-color: var(--night-mute); color: var(--night-mute); }
.admin-content .badge.expired { border-color: var(--error); color: var(--error); }
.admin-content code.invite {
  font-family: var(--font-mono);
  color: oklch(0.85 0.14 70);
  background: oklch(0.20 0.05 35);
  padding: 3px 8px;
  letter-spacing: 0.10em;
  border: 1px solid oklch(0.45 0.10 50);
}
.admin-content .admin-wrap { max-width: 100%; margin: 0; padding: 0; }
.admin-content .row { display: flex; gap: 12px; flex-wrap: wrap; }
.admin-content .row > div { flex: 1; min-width: 160px; }
