/* =========================================================
   ASHFALL REALMS — Dark Fantasy UI
   Aesthetic: Aged codex / engraved stone / mercenary ledger
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Crimson+Pro:ital,wght@0,300;0,400;0,600;1,400&family=Almendra+SC:wght@400;700&family=Pirata+One&family=Macondo&family=Uncial+Antiqua&family=Aldrich&display=swap');

:root {
  /* Theme display font — overridden per theme */
  --font-display: 'Almendra SC', 'Cinzel', serif;

  /* Ashfall — light charcoal grey backgrounds */
  --bg-base:       #2a2a2e;
  --bg-deep:       #222226;
  --bg-panel:      #34343a;
  --bg-raised:     #3e3e45;
  --bg-inset:      #27272c;

  /* Borders — warm amber tint on grey */
  --border-dim:    rgba(200, 180, 130, 0.16);
  --border-mid:    rgba(200, 180, 130, 0.28);
  --border-bright: rgba(210, 190, 140, 0.50);
  --border-glow:   rgba(225, 200, 150, 0.72);

  /* Text — warm off-white, readable on charcoal */
  --text:          #f0ece4;
  --text-dim:      #b8b0a0;
  --text-faint:    #787060;
  --accent:        #d4982e;
  --accent-bright: #ecb44a;
  --accent-pale:   #f5d488;

  /* Status */
  --green:         #72b868;
  --green-dim:     rgba(114, 184, 104, 0.18);
  --red:           #cc6050;
  --red-dim:       rgba(204, 96, 80, 0.18);
  --gold:          #dbb040;

  /* Shadows — lighter since bg is grey not near-black */
  --shadow-sm:     0 2px 8px rgba(0,0,0,0.28);
  --shadow-md:     0 6px 24px rgba(0,0,0,0.36);
  --shadow-lg:     0 16px 48px rgba(0,0,0,0.45);

  /* Geometry */
  --radius-sm:     4px;
  --radius-md:     6px;
  --radius-lg:     10px;
  --radius-pill:   999px;

  /* Shared scrollbar styling */
  --scrollbar-size: 10px;
  --scrollbar-track: var(--bg-inset);
  --scrollbar-thumb: var(--border-mid);
  --scrollbar-thumb-hover: var(--border-bright);
}

html {
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

body,
.sidebar,
.content,
.combat-log,
.modal-log,
.panel,
textarea,
select {
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

body::-webkit-scrollbar,
.sidebar::-webkit-scrollbar,
.content::-webkit-scrollbar,
.combat-log::-webkit-scrollbar,
.modal-log::-webkit-scrollbar,
.panel::-webkit-scrollbar,
textarea::-webkit-scrollbar,
select::-webkit-scrollbar {
  width: var(--scrollbar-size);
  height: var(--scrollbar-size);
}

body::-webkit-scrollbar-track,
.sidebar::-webkit-scrollbar-track,
.content::-webkit-scrollbar-track,
.combat-log::-webkit-scrollbar-track,
.modal-log::-webkit-scrollbar-track,
.panel::-webkit-scrollbar-track,
textarea::-webkit-scrollbar-track,
select::-webkit-scrollbar-track {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(0, 0, 0, 0.06));
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-pill);
}

body::-webkit-scrollbar-thumb,
.sidebar::-webkit-scrollbar-thumb,
.content::-webkit-scrollbar-thumb,
.combat-log::-webkit-scrollbar-thumb,
.modal-log::-webkit-scrollbar-thumb,
.panel::-webkit-scrollbar-thumb,
textarea::-webkit-scrollbar-thumb,
select::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, var(--scrollbar-thumb), var(--border-dim));
  border: 2px solid var(--scrollbar-track);
  border-radius: var(--radius-pill);
  background-clip: padding-box;
}

body::-webkit-scrollbar-thumb:hover,
.sidebar::-webkit-scrollbar-thumb:hover,
.content::-webkit-scrollbar-thumb:hover,
.combat-log::-webkit-scrollbar-thumb:hover,
.modal-log::-webkit-scrollbar-thumb:hover,
.panel::-webkit-scrollbar-thumb:hover,
textarea::-webkit-scrollbar-thumb:hover,
select::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, var(--scrollbar-thumb-hover), var(--scrollbar-thumb));
  border: 2px solid var(--scrollbar-track);
}

/* ── Per-theme display font override ────────────────────────────────────────
   Any element that uses font-family: 'Cinzel' picks up the theme font instead.
   We do this via a cascade override on the html element so specificity is low
   enough for component styles to win if needed.
   ──────────────────────────────────────────────────────────────────────── */
[data-theme] .section-title,
[data-theme] .cs-name,
[data-theme] .cs-block-label,
[data-theme] .cs-archetype,
[data-theme] .cs-ability-abbr,
[data-theme] .nav-button,
[data-theme] .nav-section-label,
[data-theme] .brand h1,
[data-theme] .topbar .brand,
[data-theme] h2,
[data-theme] h3,
[data-theme] .admin-item-name,
[data-theme] .combat-enemy-name,
[data-theme] .tavern-npc-name,
[data-theme] .party-member-name,
[data-theme] .combat-modal-char-name,
[data-theme] .combat-modal-vs-badge,
[data-theme] .cs-vital-label,
[data-theme] .cs-vital-val,
[data-theme] .combat-key-label,
[data-theme] .combat-key-val,
[data-theme] .combat-ability-label,
[data-theme] .combat-ability-score,
[data-theme] .combat-ability-mod,
[data-theme] .combat-compare-label,
[data-theme] .combat-compare-val,
[data-theme] .badge,
[data-theme] .shop-category-label,
[data-theme] .portrait-lib-label,
[data-theme] .tavern-quest-name,
[data-theme] .party-vote-zone-name,
[data-theme] .inv-tip-name,
[data-theme] .quest-prereq-title {
  font-family: var(--font-display);
}
/* =========================================================
   THEME: Bloodstone — deep crimson, bronze accents
   ========================================================= */
[data-theme="bloodstone"] {
  --font-display:  'Macondo', 'Cinzel', serif;

  /* Rich dark red backgrounds */
  --bg-base:       #1c0a08;
  --bg-deep:       #150605;
  --bg-panel:      #2a0f0c;
  --bg-raised:     #361410;
  --bg-inset:      #200c09;

  --border-dim:    rgba(200, 80, 30, 0.22);
  --border-mid:    rgba(215, 95, 40, 0.38);
  --border-bright: rgba(235, 120, 50, 0.62);
  --border-glow:   rgba(255, 150, 60, 0.85);

  --text:          #f5e0d0;
  --text-dim:      #c09078;
  --text-faint:    #7a5040;
  --accent:        #e06820;
  --accent-bright: #f07828;
  --accent-pale:   #ffaa60;

  --green:         #72b868;
  --green-dim:     rgba(114, 184, 104, 0.18);
  --red:           #ff4040;
  --red-dim:       rgba(255, 64, 64, 0.18);
  --gold:          #e0921a;

  --shadow-sm:     0 2px 8px rgba(0,0,0,0.5);
  --shadow-md:     0 6px 24px rgba(0,0,0,0.65);
  --shadow-lg:     0 16px 48px rgba(0,0,0,0.75);
}

[data-theme="bloodstone"] body {
  background-color: var(--bg-base);
  background-image:
    radial-gradient(ellipse 80% 50% at 50% -10%, rgba(220, 60, 10, 0.18) 0%, transparent 65%),
    radial-gradient(ellipse 40% 30% at 80% 80%,  rgba(180, 40,  5, 0.08) 0%, transparent 60%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
}

[data-theme="bloodstone"] .topbar {
  background: rgba(18, 5, 3, 0.96);
  border-bottom-color: rgba(200, 80, 30, 0.35);
}
[data-theme="bloodstone"] .sidebar {
  background: rgba(26, 10, 7, 0.98);
  border-right-color: rgba(200, 80, 30, 0.2);
}

/* =========================================================
   THEME: Frostmere — deep teal, ice-blue accents
   ========================================================= */
[data-theme="frostmere"] {
  --font-display:  'Pirata One', 'Cinzel', serif;

  /* Light snowy backgrounds */
  --bg-base:       #e8eff5;
  --bg-deep:       #dde6ee;
  --bg-panel:      #f2f7fb;
  --bg-raised:     #ffffff;
  --bg-inset:      #dce5ed;

  /* Icy blue borders */
  --border-dim:    rgba(90, 140, 185, 0.22);
  --border-mid:    rgba(80, 130, 175, 0.40);
  --border-bright: rgba(60, 115, 165, 0.65);
  --border-glow:   rgba(40,  95, 150, 0.85);

  /* Dark text on light background */
  --text:          #0e1e2c;
  --text-dim:      #253d52;
  --text-faint:    #5c7a90;
  --accent:        #1e6fa0;
  --accent-bright: #1882bf;
  --accent-pale:   #2598d8;

  --green:         #1e8a4a;
  --green-dim:     rgba(30, 138, 74, 0.14);
  --red:           #bf3030;
  --red-dim:       rgba(191, 48, 48, 0.12);
  --gold:          #2a7fa8;

  --shadow-sm:     0 2px 8px rgba(60,100,140,0.12);
  --shadow-md:     0 6px 24px rgba(60,100,140,0.16);
  --shadow-lg:     0 16px 48px rgba(60,100,140,0.22);
}

[data-theme="frostmere"] body {
  background-color: var(--bg-base);
  background-image:
    radial-gradient(ellipse 100% 40% at 50% 0%, rgba(200,225,245,0.8) 0%, transparent 60%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.018'/%3E%3C/svg%3E");
}

[data-theme="frostmere"] .topbar {
  background: rgba(245, 250, 255, 0.97);
  border-bottom-color: rgba(80, 130, 175, 0.25);
  box-shadow: 0 1px 12px rgba(60,100,140,0.10);
}
[data-theme="frostmere"] .sidebar {
  background: rgba(232, 242, 250, 0.99);
  border-right: 1px solid rgba(80, 130, 175, 0.18);
}
[data-theme="frostmere"] .nav-button {
  color: #253d52;
}
[data-theme="frostmere"] .nav-button:hover {
  background: rgba(30,111,160,0.07);
  color: #0e1e2c;
}
[data-theme="frostmere"] .nav-button.active {
  background: rgba(30,111,160,0.13);
  color: #1068a0;
  border-color: rgba(30,111,160,0.28);
}
[data-theme="frostmere"] .panel {
  box-shadow: 0 1px 6px rgba(60,100,140,0.08);
}
[data-theme="frostmere"] .combat-bar.player {
  background: linear-gradient(90deg, #1e6fa0, #2a98d0);
}
[data-theme="frostmere"] .brand h1 { color: #1e6fa0; }
[data-theme="frostmere"] .brand span { color: #5c7a90; }
[data-theme="frostmere"] .topbar-actions .badge { border-color: rgba(80,130,175,0.3); }
/* Ensure Cinzel headings are fully dark */
[data-theme="frostmere"] .section-title,
[data-theme="frostmere"] .cs-name,
[data-theme="frostmere"] .cs-block-label,
[data-theme="frostmere"] .admin-item-name,
[data-theme="frostmere"] .combat-enemy-name,
[data-theme="frostmere"] .tavern-npc-name,
[data-theme="frostmere"] .party-member-name,
[data-theme="frostmere"] h2,
[data-theme="frostmere"] h3,
[data-theme="frostmere"] strong { color: #0e1e2c; }
[data-theme="frostmere"] .helper-text,
[data-theme="frostmere"] .admin-item-meta,
[data-theme="frostmere"] .nav-section-label { color: #5c7a90; }
/* Badges need dark text on light bg */
[data-theme="frostmere"] .badge {
  background: rgba(30,111,160,0.10);
  color: #1e6fa0;
  border-color: rgba(30,111,160,0.25);
}
[data-theme="frostmere"] .badge.warning {
  background: rgba(160,90,10,0.10);
  color: #a05810;
  border-color: rgba(160,90,10,0.25);
}
[data-theme="frostmere"] .badge.success {
  background: rgba(20,120,60,0.10);
  color: #1a7840;
  border-color: rgba(20,120,60,0.25);
}
[data-theme="frostmere"] .badge.error {
  background: rgba(180,40,40,0.10);
  color: #b02828;
  border-color: rgba(180,40,40,0.25);
}

/* =========================================================
   THEME: Tidewatch — deep ocean, blue-green tones
   ========================================================= */
[data-theme="tidewatch"] {
  --font-display:  'Uncial Antiqua', 'Cinzel', serif;

  --bg-base:       #08141e;
  --bg-deep:       #050f17;
  --bg-panel:      #0f1f2e;
  --bg-raised:     #162838;
  --bg-inset:      #0b1924;

  --border-dim:    rgba(40, 160, 140, 0.20);
  --border-mid:    rgba(40, 170, 150, 0.36);
  --border-bright: rgba(50, 190, 165, 0.58);
  --border-glow:   rgba(60, 210, 180, 0.80);

  --text:          #d0ede8;
  --text-dim:      #80b8b0;
  --text-faint:    #456860;
  --accent:        #1aaa8c;
  --accent-bright: #22c8a8;
  --accent-pale:   #60e0c8;

  --green:         #38c878;
  --green-dim:     rgba(56, 200, 120, 0.18);
  --red:           #d05050;
  --red-dim:       rgba(208, 80, 80, 0.18);
  --gold:          #30b8d8;

  --shadow-sm:     0 2px 8px rgba(0,0,0,0.4);
  --shadow-md:     0 6px 24px rgba(0,0,0,0.52);
  --shadow-lg:     0 16px 48px rgba(0,0,0,0.62);
}

[data-theme="tidewatch"] body {
  background-color: var(--bg-base);
  background-image:
    radial-gradient(ellipse 90% 50% at 30% 100%, rgba(10, 100, 120, 0.18) 0%, transparent 60%),
    radial-gradient(ellipse 70% 40% at 80% 0%,   rgba(20, 140, 110, 0.14) 0%, transparent 55%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.022'/%3E%3C/svg%3E");
}

[data-theme="tidewatch"] .topbar {
  background: rgba(4, 10, 16, 0.96);
  border-bottom-color: rgba(30, 150, 130, 0.32);
}
[data-theme="tidewatch"] .sidebar {
  background: rgba(6, 14, 20, 0.98);
  border-right-color: rgba(30, 150, 130, 0.18);
}
[data-theme="tidewatch"] .nav-button.active {
  background: rgba(26, 170, 140, 0.15);
  color: var(--accent-pale);
  border-color: rgba(26, 170, 140, 0.30);
  box-shadow: inset 2px 0 0 var(--accent);
}
[data-theme="tidewatch"] .combat-bar.player {
  background: linear-gradient(90deg, #1aaa8c, #22c8a8);
}
[data-theme="tidewatch"] .xp-bar {
  background: linear-gradient(90deg, #1688c0, #22a8d8);
}

/* =========================================================
   THEME: Aldrich - high-contrast slate for mobile readability
   ========================================================= */
[data-theme="aldrich"] {
  --font-display:  'Aldrich', 'Cinzel', serif;

  --bg-base:       #101722;
  --bg-deep:       #0b1119;
  --bg-panel:      #1a2432;
  --bg-raised:     #223044;
  --bg-inset:      #121d2a;

  --border-dim:    rgba(150, 175, 205, 0.18);
  --border-mid:    rgba(165, 195, 225, 0.34);
  --border-bright: rgba(188, 214, 242, 0.56);
  --border-glow:   rgba(209, 229, 250, 0.78);

  --text:          #edf3fb;
  --text-dim:      #c2d3e7;
  --text-faint:    #90a7c0;
  --accent:        #5fb9ff;
  --accent-bright: #89ccff;
  --accent-pale:   #b8e2ff;

  --green:         #63c28d;
  --green-dim:     rgba(99, 194, 141, 0.18);
  --red:           #dc6c6c;
  --red-dim:       rgba(220, 108, 108, 0.18);
  --gold:          #8fd2ff;

  --shadow-sm:     0 2px 8px rgba(0,0,0,0.34);
  --shadow-md:     0 8px 26px rgba(0,0,0,0.44);
  --shadow-lg:     0 18px 56px rgba(0,0,0,0.56);
}

[data-theme="aldrich"] body {
  font-family: 'Aldrich', 'Crimson Pro', Georgia, serif;
  line-height: 1.66;
  letter-spacing: 0.01em;
  background-color: var(--bg-base);
  background-image:
    radial-gradient(ellipse 85% 50% at 50% -8%, rgba(95, 185, 255, 0.14) 0%, transparent 65%),
    radial-gradient(ellipse 55% 35% at 0% 100%, rgba(70, 130, 210, 0.10) 0%, transparent 62%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.68' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)' opacity='0.018'/%3E%3C/svg%3E");
}

[data-theme="aldrich"] .topbar {
  background: rgba(10, 16, 24, 0.95);
  border-bottom-color: rgba(150, 185, 220, 0.26);
}

[data-theme="aldrich"] .sidebar {
  background: rgba(12, 20, 30, 0.98);
  border-right-color: rgba(150, 185, 220, 0.18);
}

[data-theme="aldrich"] .nav-button.active {
  background: rgba(95, 185, 255, 0.16);
  border-color: rgba(95, 185, 255, 0.38);
  color: var(--accent-pale);
  box-shadow: inset 2px 0 0 var(--accent);
}

[data-theme="aldrich"] .panel {
  box-shadow: 0 1px 0 rgba(255,255,255,0.03), var(--shadow-sm);
}

[data-theme="aldrich"] .helper-text,
[data-theme="aldrich"] .section-copy {
  color: var(--text-dim);
}

[data-theme="aldrich"] .badge {
  letter-spacing: 0.06em;
}

@media (max-width: 900px) {
  html[data-theme="aldrich"] { font-size: 16px; }
  [data-theme="aldrich"] .nav-button { padding: 0.62rem 0.78rem; }
  [data-theme="aldrich"] .section-copy,
  [data-theme="aldrich"] .helper-text { font-size: 0.92rem; line-height: 1.62; }
}

/* =========================================================
   THEME DROPDOWN
   ========================================================= */
.theme-switcher {
  position: relative;
}

.theme-toggle-btn {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  background: var(--bg-raised);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-md);
  color: var(--text-dim);
  font-family: var(--font-display);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  padding: 0.3rem 0.6rem;
  cursor: pointer;
  width: auto;
  transition: background 120ms, border-color 120ms, color 120ms;
  white-space: nowrap;
}
.theme-toggle-btn:hover {
  background: var(--bg-panel);
  border-color: var(--border-bright);
  color: var(--text);
}
.theme-toggle-btn .theme-toggle-caret {
  font-size: 0.6rem;
  opacity: 0.6;
  transition: transform 200ms;
}
.theme-switcher.open .theme-toggle-caret { transform: rotate(180deg); }

.theme-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 160px;
  background: var(--bg-panel);
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  z-index: 200;
  overflow: hidden;
  display: none;
  flex-direction: column;
}
.theme-switcher.open .theme-dropdown { display: flex; }

.theme-dropdown-item {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.55rem 0.8rem;
  background: none;
  border: none;
  border-bottom: 1px solid var(--border-dim);
  color: var(--text-dim);
  font-family: var(--font-display);
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  cursor: pointer;
  width: 100%;
  text-align: left;
  transition: background 100ms, color 100ms;
  white-space: nowrap;
}
.theme-dropdown-item:last-child { border-bottom: none; }
.theme-dropdown-item:hover {
  background: rgba(255,255,255,0.05);
  color: var(--text);
}
.theme-dropdown-item.active {
  color: var(--accent-pale);
  background: rgba(255,255,255,0.04);
}
.theme-dropdown-item .theme-item-icon { font-size: 1rem; flex-shrink: 0; }
.theme-dropdown-item .theme-item-check { margin-left: auto; font-size: 0.7rem; opacity: 0.8; }


/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; }

html { font-size: 15px; }

body {
  font-family: 'Crimson Pro', Georgia, serif;
  font-weight: 400;
  color: var(--text);
  background-color: var(--bg-base);
  background-image:
    radial-gradient(ellipse 80% 50% at 50% -10%, rgba(200, 140, 50, 0.10) 0%, transparent 70%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
  min-height: 100vh;
  line-height: 1.55;
}

a { text-decoration: none; color: inherit; }
button, input, select, a { font: inherit; }

/* ── Typography scale ── */
h1, h2, h3, h4 {
  font-family: 'Cinzel', serif;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0.04em;
  color: var(--text);
}

/* ── App shell ── */
.app-shell { min-height: 100vh; display: flex; flex-direction: column; }

/* ── Topbar ── */
.topbar {
  position: sticky;
  top: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.6rem 1.25rem;
  background: rgba(20, 16, 24, 0.94);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border-mid);
  box-shadow: 0 1px 0 var(--border-dim), var(--shadow-sm);
}

.brand { display: flex; align-items: baseline; gap: 0.75rem; }

.brand h1 {
  font-family: 'Cinzel', serif;
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--accent-pale);
  text-shadow: 0 0 20px rgba(200, 146, 42, 0.35);
}

.brand span {
  font-size: 0.78rem;
  color: var(--text-faint);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.topbar-actions { display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }

.sidebar-toggle {
  display: none;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 4px;
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  cursor: pointer;
  box-shadow: var(--shadow-sm);
}

.sidebar-toggle span {
  display: block;
  width: 18px;
  height: 2px;
  border-radius: var(--radius-pill);
  background: currentColor;
  transition: transform 160ms ease, opacity 160ms ease;
}

.sidebar-collapse-toggle {
  display: none;
  width: 38px;
  height: 38px;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-dim);
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: background 120ms, border-color 120ms, color 120ms;
}

.sidebar-collapse-toggle:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: var(--border-mid);
  color: var(--text);
}

.sidebar-collapse-icon {
  display: block;
  font-size: 0.8rem;
  line-height: 1;
  transition: transform 180ms ease;
}

.sidebar-hover-tooltip {
  position: fixed;
  left: 0;
  top: 0;
  transform: translateY(-50%);
  padding: 0.3rem 0.52rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-mid);
  background: var(--bg-panel);
  color: var(--text);
  font-family: var(--font-display);
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  white-space: nowrap;
  box-shadow: var(--shadow-sm);
  opacity: 0;
  pointer-events: none;
  transition: opacity 60ms ease;
  z-index: 2000;
}

.sidebar-hover-tooltip.visible {
  opacity: 1;
}

.app-shell.nav-open .sidebar-toggle span:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}

.app-shell.nav-open .sidebar-toggle span:nth-child(2) {
  opacity: 0;
}

.app-shell.nav-open .sidebar-toggle span:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}

.mobile-nav-backdrop {
  display: none;
}

/* ── Layout ── */
.layout {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  flex: 1;
  min-height: 0;
  align-items: start;
  transition: grid-template-columns 180ms ease;
}

/* ── Sidebar ── */
.sidebar {
  padding: 1rem 0.75rem;
  background: var(--bg-deep);
  border-right: 1px solid var(--border-dim);
  display: flex;
  flex-direction: column;
  gap: 0;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
}

.sidebar h2 {
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-faint);
  padding: 0.5rem 0.5rem 0.4rem;
  border-bottom: 1px solid var(--border-dim);
  margin-bottom: 0.35rem;
}

.sidebar-section { margin-top: 1.25rem; }

.nav-list { display: flex; flex-direction: column; gap: 1px; }

/* ── Buttons ── */
.nav-button,
.ghost-button,
.primary-button,
.danger-button {
  display: block;
  width: 100%;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  padding: 0.5rem 0.7rem;
  font-size: 0.88rem;
  font-family: 'Crimson Pro', serif;
  letter-spacing: 0.03em;
  cursor: pointer;
  transition: background 120ms, color 120ms, border-color 120ms, box-shadow 120ms;
  text-align: left;
}

.nav-button {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  background: transparent;
  color: var(--text-dim);
  border-color: transparent;
  padding: 0.48rem 0.7rem;
  font-family: 'Cinzel', serif;
  font-size: 0.78rem;
  letter-spacing: 0.05em;
  position: relative;
  overflow: visible;
}

.nav-icon {
  font-size: 0.92rem;
  line-height: 1;
  flex-shrink: 0;
  width: 18px;
  text-align: center;
  opacity: 0.75;
  font-style: normal;
}
.nav-button:hover .nav-icon,
.nav-button.active .nav-icon { opacity: 1; }

.nav-label { flex: 1; }

.nav-section-label {
  font-family: 'Cinzel', serif;
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-faint);
  padding: 0.65rem 0.75rem 0.2rem;
  margin: 0;
  display: block;
}

.nav-button:hover {
  background: rgba(180, 140, 80, 0.07);
  color: var(--text);
  border-color: var(--border-dim);
}

.nav-button.active {
  background: rgba(180, 130, 50, 0.12);
  color: var(--accent-pale);
  border-color: var(--border-mid);
  box-shadow: inset 2px 0 0 var(--accent);
}

@media (min-width: 901px) {
  .sidebar-collapse-toggle {
    display: inline-flex;
  }

  .app-shell.sidebar-collapsed .layout {
    grid-template-columns: 72px minmax(0, 1fr);
  }

  .app-shell.sidebar-collapsed .sidebar {
    padding-left: 0.4rem;
    padding-right: 0.4rem;
  }

  .app-shell.sidebar-collapsed .sidebar-collapse-icon {
    transform: rotate(180deg);
  }

  .app-shell.sidebar-collapsed .nav-section-label {
    display: none;
  }

  .app-shell.sidebar-collapsed .nav-button {
    justify-content: center;
    gap: 0;
    padding-left: 0.4rem;
    padding-right: 0.4rem;
  }

  .app-shell.sidebar-collapsed .nav-label {
    display: none;
  }

  .app-shell.sidebar-collapsed .nav-icon {
    width: auto;
    font-size: 1rem;
    opacity: 0.95;
  }

  .app-shell.sidebar-collapsed .nav-button[data-tooltip]::after {
    content: attr(data-tooltip);
    position: absolute;
    left: calc(100% + 10px);
    top: 50%;
    transform: translateY(-50%);
    padding: 0.28rem 0.48rem;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-mid);
    background: var(--bg-panel);
    color: var(--text);
    font-family: var(--font-display);
    font-size: 0.68rem;
    letter-spacing: 0.06em;
    white-space: nowrap;
    box-shadow: var(--shadow-sm);
    opacity: 0;
    pointer-events: none;
    transition: opacity 70ms ease;
    z-index: 140;
  }

  .app-shell.sidebar-collapsed .nav-button[data-tooltip]::before {
    content: '';
    position: absolute;
    left: calc(100% + 4px);
    top: 50%;
    transform: translateY(-50%);
    border: 5px solid transparent;
    border-right-color: var(--border-mid);
    opacity: 0;
    transition: opacity 70ms ease;
    pointer-events: none;
    z-index: 139;
  }

  .app-shell.sidebar-collapsed .nav-button[data-tooltip]:hover::after,
  .app-shell.sidebar-collapsed .nav-button[data-tooltip]:hover::before,
  .app-shell.sidebar-collapsed .nav-button[data-tooltip]:focus-visible::after,
  .app-shell.sidebar-collapsed .nav-button[data-tooltip]:focus-visible::before {
    opacity: 1;
  }
}

.ghost-button {
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-dim);
  border-color: var(--border-dim);
}

.ghost-button:hover {
  background: rgba(255, 255, 255, 0.07);
  color: var(--text);
  border-color: var(--border-mid);
}

.primary-button {
  background: linear-gradient(160deg, #c8882a, #9a6418);
  color: #f5e8cc;
  border-color: rgba(200, 160, 90, 0.3);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-align: center;
  box-shadow: 0 1px 0 rgba(255,200,100,0.1) inset, var(--shadow-sm);
}

.primary-button:hover {
  background: linear-gradient(160deg, #d89a38, #a87020);
  box-shadow: 0 1px 0 rgba(255,200,100,0.15) inset, 0 0 12px rgba(200,136,42,0.25);
}

.danger-button {
  background: rgba(192, 88, 74, 0.12);
  color: #e8b0a8;
  border-color: rgba(192, 88, 74, 0.3);
  text-align: center;
}

.danger-button:hover {
  background: rgba(192, 88, 74, 0.2);
  border-color: rgba(192, 88, 74, 0.5);
}

button:disabled { opacity: 0.45; cursor: not-allowed; }

.inline-button { display: inline-flex; align-items: center; justify-content: center; width: auto; }
.compact-button { width: auto; padding: 0.35rem 0.7rem; font-size: 0.82rem; }

/* ── Main content area ── */
.content {
  padding: 1.25rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  min-height: 0;
  min-width: 0;
  overflow-x: clip; /* clip horizontal bleed without breaking position:sticky on children */
}

.section-gap { margin-top: 0.85rem; }

/* ── Panels & cards ── */
.panel {
  background: var(--bg-panel);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-lg);
  padding: 1rem 1.1rem;
  box-shadow: var(--shadow-sm);
  position: relative;
}

/* Subtle corner engraving effect */
.panel::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, rgba(200,160,90,0.04) 0%, transparent 50%);
  pointer-events: none;
}

.stat-card {
  background: var(--bg-raised);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  padding: 0.85rem 1rem;
  box-shadow: var(--shadow-sm);
}

.stat-card strong {
  display: block;
  font-family: 'Cinzel', serif;
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--accent-pale);
  margin-top: 0.3rem;
  line-height: 1;
}

.inventory-item,
.account-row {
  background: var(--bg-raised);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  padding: 0.7rem 0.9rem;
  transition: border-color 120ms;
}

.inventory-item:hover,
.account-row:hover {
  border-color: var(--border-mid);
}

.inventory-item h4,
.account-row h4 {
  font-size: 0.95rem;
  font-weight: 600;
  margin-bottom: 0.2rem;
}

/* ── Hero panel ── */
.hero-panel {
  background: var(--bg-panel);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-lg);
  padding: 1.5rem 1.75rem;
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

.hero-panel::after {
  content: '';
  position: absolute;
  top: -40px; right: -40px;
  width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(200, 146, 42, 0.1), transparent 70%);
  pointer-events: none;
}

.hero-title {
  font-size: clamp(1.5rem, 3vw, 2.4rem);
  color: var(--accent-pale);
  text-shadow: 0 0 30px rgba(200,160,90,0.2);
  margin-bottom: 0.4rem;
}

.hero-copy {
  color: var(--text-dim);
  font-size: 1rem;
  max-width: 55ch;
  line-height: 1.6;
}

/* ── Section titles ── */
.section-title {
  font-size: 1rem;
  font-family: 'Cinzel', serif;
  color: var(--accent-pale);
  letter-spacing: 0.06em;
  margin-bottom: 0.3rem;
}

.section-copy {
  color: var(--text-dim);
  font-size: 0.95rem;
  line-height: 1.6;
}

/* ── Badges ── */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 0.18rem 0.55rem;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border-dim);
  color: var(--text-dim);
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  font-family: 'Cinzel', serif;
  white-space: nowrap;
}

.badge.success {
  color: #b8e8b0;
  background: var(--green-dim);
  border-color: rgba(106, 170, 96, 0.3);
}

.badge.warning {
  color: var(--accent-pale);
  background: rgba(200, 146, 42, 0.1);
  border-color: rgba(200, 146, 42, 0.28);
}

.badge.error {
  color: #e8b0a8;
  background: var(--red-dim);
  border-color: rgba(192, 88, 74, 0.3);
}

/* ── Flash messages ── */
.status-text {
  font-size: 0.9rem;
  padding: 0.6rem 0.9rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-dim);
  background: var(--bg-raised);
  color: var(--text-dim);
}

.status-text.success {
  color: #b8e8b0;
  background: var(--green-dim);
  border-color: rgba(106, 170, 96, 0.3);
}

.status-text.error {
  color: #e8b0a8;
  background: var(--red-dim);
  border-color: rgba(192, 88, 74, 0.3);
}

.player-notification-banner {
  padding: 0.85rem 1rem;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(106, 170, 96, 0.35);
  background: rgba(106, 170, 96, 0.08);
}

.player-notification-banner-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.player-notification-banner-time {
  font-size: 0.74rem;
  color: var(--text-faint);
}

.player-notification-banner-title {
  margin-top: 0.45rem;
  font-family: 'Cinzel', serif;
  color: var(--text);
}

.player-notification-banner-body {
  margin-top: 0.3rem;
  color: var(--text-dim);
  line-height: 1.55;
}

.auth-flash-wrap {
  max-width: 1060px;
  margin: 1rem auto 0;
  padding: 0 1rem;
}

/* ── Text helpers ── */
.helper-text {
  color: var(--text-dim);
  font-size: 0.88rem;
  line-height: 1.55;
}

.footer-note {
  color: var(--text-faint);
  font-size: 0.85rem;
  margin-top: 0.75rem;
}

/* ── Grids ── */
.grid { display: grid; gap: 0.75rem; }
.grid.two   { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }

/* ── Split layout ── */
.split {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

/* ── Forms ── */
.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.field {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  margin-bottom: 0.75rem;
}

.field label {
  font-size: 0.78rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--text-faint);
  font-family: 'Cinzel', serif;
}

.field input,
.field select {
  background: var(--bg-inset);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-sm);
  padding: 0.55rem 0.75rem;
  color: var(--text);
  font-size: 0.95rem;
  transition: border-color 120ms, box-shadow 120ms;
  outline: none;
}

/* Prevent spinner arrows from overlapping the value in number inputs */
.field input[type="number"] {
  padding-right: 20px;
}

.field input:focus,
.field select:focus {
  border-color: var(--border-glow);
  box-shadow: 0 0 0 2px rgba(200, 146, 42, 0.15);
}

.field input::placeholder { color: var(--text-faint); }

/* ── Auth layout ── */
.auth-shell {
  width: min(1000px, calc(100% - 2rem));
  margin: 2.5rem auto;
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  border: 1px solid var(--border-mid);
  box-shadow: var(--shadow-lg);
}

.auth-hero {
  padding: 2.25rem;
  background:
    linear-gradient(160deg, rgba(22,16,20,0.4), rgba(22,16,20,0.85)),
    linear-gradient(140deg, #5a2616 0%, #281830 50%, #181420 100%);
  border-right: 1px solid var(--border-dim);
}

.auth-hero--banner {
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #0e0b08;
  overflow: hidden;
}

.auth-banner-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.auth-feature-list { display: grid; gap: 0.65rem; margin-top: 1.5rem; }

.auth-feature {
  padding: 0.75rem 0.9rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-dim);
  background: rgba(255, 255, 255, 0.025);
}

.auth-feature strong { font-size: 0.9rem; display: block; margin-bottom: 0.2rem; color: var(--text); }
.auth-feature span   { font-size: 0.85rem; color: var(--text-dim); line-height: 1.5; }

.auth-panel {
  padding: 2rem;
  background: var(--bg-panel);
}

.auth-toggle {
  display: flex;
  gap: 0.4rem;
  margin-bottom: 1.25rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--border-dim);
}

.auth-support {
  display: grid;
  gap: 0.25rem;
  margin-top: 0.85rem;
  font-size: 0.88rem;
  color: var(--text-dim);
}

.auth-support a { color: var(--accent-bright); }
.auth-support a:hover { color: var(--accent-pale); }

/* ── Ability mod on character sheet ── */
.character-ability-card { position: relative; }

.ability-mod {
  margin-top: 0.3rem;
  font-family: 'Cinzel', serif;
  font-size: 0.85rem;
  color: var(--accent);
  letter-spacing: 0.06em;
}

/* ── Lists ── */
.inventory-list,
.accounts-list,
.enemy-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.account-actions,
.badge-row,
.inventory-actions {
  display: flex;
  gap: 0.45rem;
  flex-wrap: wrap;
  align-items: center;
}

.account-actions form,
.inventory-actions form { margin: 0; }

/* ── Divider label ── */
.divider-label {
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-faint);
  font-family: 'Cinzel', serif;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0.5rem 0;
}

.divider-label::before,
.divider-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border-dim);
}

/* ── Combat bars ── */
.combat-bar-track {
  margin-top: 0.5rem;
  height: 6px;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.06);
  overflow: hidden;
  border: 1px solid var(--border-dim);
}

.combat-bar {
  height: 100%;
  border-radius: var(--radius-pill);
  transition: width 350ms ease;
}

.combat-bar.player { background: linear-gradient(90deg, #4a9e44, #7acc70); }
.combat-bar.enemy  { background: linear-gradient(90deg, #9a3a2c, #c05a4a); }
.combat-bar.xp-bar { background: linear-gradient(90deg, #5548a8, #8070d8); }

.xp-bar-track { margin-top: 0.4rem; }

/* ── Combat actions ── */
.combat-actions {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  align-items: center;
  padding: 0.85rem 1rem;
  background: var(--bg-panel);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-lg);
}

.combat-actions form { margin: 0; }

/* ── Combat log ── */
.combat-log {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  max-height: 280px;
  overflow-y: auto;
  padding-right: 0.2rem;
}

.compact-log { max-height: 120px; margin-top: 0.65rem; }

.combat-log-line {
  margin: 0;
  padding: 0.35rem 0.65rem;
  border-radius: var(--radius-sm);
  font-size: 0.88rem;
  line-height: 1.45;
  background: var(--bg-inset);
  border-left: 2px solid var(--border-dim);
  color: var(--text-dim);
}

.combat-log-line.player { border-left-color: var(--green); color: var(--text); }
.combat-log-line.enemy  { border-left-color: var(--red); }
.combat-log-line.system { border-left-color: var(--accent); color: var(--accent-pale); }

.turn-label {
  display: inline-block;
  margin-right: 0.4rem;
  font-size: 0.72rem;
  color: var(--text-faint);
  font-family: 'Cinzel', serif;
  letter-spacing: 0.05em;
}

/* ── Outcome banners ── */
.outcome-banner {
  border-radius: var(--radius-lg);
  padding: 1rem 1.1rem;
  border: 1px solid var(--border-mid);
  background: var(--bg-panel);
}

.outcome-banner.success { border-color: rgba(106,170,96,0.35); background: rgba(106,170,96,0.05); }
.outcome-banner.error   { border-color: rgba(192,88,74,0.35);  background: rgba(192,88,74,0.05); }

/* ── Paperdoll ── */
.paperdoll-body {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  padding: 0.25rem 0;
}

.pb-row {
  display: flex;
  gap: 0.45rem;
  justify-content: center;
}

.pb-center .paperdoll-slot { width: 46%; }
.pb-three  .paperdoll-slot { flex: 1; max-width: 33%; }

.paperdoll-slot {
  min-height: 62px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-radius: var(--radius-md);
  border: 1px dashed var(--border-mid);
  background: var(--bg-inset);
  color: var(--text-faint);
  font-size: 0.8rem;
  transition: border-color 140ms, background 140ms;
}

.paperdoll-slot.filled {
  border-style: solid;
  border-color: var(--border-bright);
  background: rgba(180, 130, 50, 0.08);
}

.paperdoll-slot-inner { display: grid; gap: 0.2rem; padding: 0.4rem; }
.paperdoll-slot-inner strong { font-size: 0.78rem; font-family: 'Cinzel', serif; color: var(--text); letter-spacing: 0.04em; }
.paperdoll-slot-inner span   { font-size: 0.73rem; color: var(--text-dim); }

/* ── Shop ── */
.shop-tabs {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
  padding-bottom: 0.1rem;
  border-bottom: 1px solid var(--border-dim);
  margin-bottom: 0.1rem;
}

.shop-tabs .nav-button {
  width: auto;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.35rem 0.7rem;
  font-size: 0.82rem;
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
  border-bottom: none;
}

.shop-item-list { display: flex; flex-direction: column; gap: 0.45rem; }

.shop-category-label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-faint);
  font-family: 'Cinzel', serif;
  margin: 0.6rem 0 0.2rem;
  padding-bottom: 0.2rem;
  border-bottom: 1px solid var(--border-dim);
}

.shop-category-label:first-child { margin-top: 0; }
.shop-buy-row.unaffordable { opacity: 0.45; }

/* ── Quests ── */
.quest-counts { display: flex; gap: 0.4rem; align-items: center; flex-wrap: wrap; }

.quest-card { margin-bottom: 0; }

.quest-title {
  font-family: 'Cinzel', serif;
  font-size: 0.95rem;
  letter-spacing: 0.04em;
  color: var(--text);
  margin-bottom: 0.3rem;
}

.quest-section-label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-faint);
  font-family: 'Cinzel', serif;
  margin-bottom: 0.4rem;
}

.quest-objective { margin-top: 0.5rem; }

.quest-ready {
  border-color: rgba(200, 146, 42, 0.4);
  background: rgba(180, 120, 30, 0.06);
}

.quest-claimed { opacity: 0.5; }

/* ── Enemy card ── */
.enemy-card h4 { margin-bottom: 0.2rem; font-size: 0.95rem; }

/* ── XP bar panel ── */
.xp-bar-track { margin-top: 0.4rem; }

/* ── Responsive ── */
@media (max-width: 900px) {
  .layout { grid-template-columns: 1fr; }

  body.nav-open {
    overflow: hidden;
  }

  .topbar {
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    flex-wrap: wrap;
  }

  .sidebar-toggle {
    display: inline-flex;
    flex-shrink: 0;
  }

  .topbar-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .mobile-nav-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(8, 8, 12, 0.55);
    backdrop-filter: blur(4px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 160ms ease;
    z-index: 118;
  }

  .app-shell.nav-open .mobile-nav-backdrop {
    opacity: 1;
    pointer-events: auto;
  }

  .sidebar {
    position: fixed;
    top: 0;
    left: 0;
    width: min(320px, 88vw);
    height: 100vh;
    padding: 5.4rem 0.85rem 1rem;
    border-right: 1px solid var(--border-dim);
    border-bottom: none;
    box-shadow: var(--shadow-lg);
    z-index: 120;
    transform: translateX(calc(-100% - 1rem));
    transition: transform 180ms ease;
  }

  .app-shell.nav-open .sidebar {
    transform: translateX(0);
  }

  .sidebar h2 { display: none; }

  .nav-list {
    flex-direction: column;
    flex-wrap: nowrap;
  }

  .nav-button {
    width: 100%;
    font-size: 0.82rem;
    padding: 0.55rem 0.7rem;
  }

  .sidebar-section {
    display: block;
    margin-top: 1rem;
  }

  .auth-shell,
  .grid.two,
  .grid.three,
  .form-grid { grid-template-columns: 1fr; }

  .content { padding: 1rem; }

  .mobile-character-vitals,
  .mobile-character-action-grid {
    grid-template-columns: 1fr;
  }

  .mobile-character-abilities {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 520px) {
  .mobile-character-hero-top {
    flex-direction: column;
  }

  .mobile-character-avatar {
    width: 72px;
    height: 72px;
  }

  .mobile-character-abilities {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* =========================================================
   EQUIPMENT + INVENTORY COMBINED PAGE
   ========================================================= */

.mobile-character-page {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.mobile-character-hero {
  padding: 1rem;
}

.mobile-character-hero-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.mobile-character-avatar {
  width: 84px;
  height: 84px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--border-mid);
  background: linear-gradient(160deg, rgba(255,255,255,0.05), rgba(0,0,0,0.08));
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: var(--shadow-sm);
}

.mobile-character-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mobile-character-avatar span {
  font-family: var(--font-display);
  font-size: 1.3rem;
  color: var(--accent-pale);
}

.mobile-character-switches {
  display: flex;
  gap: 0.55rem;
  flex-wrap: wrap;
  margin-top: 0.85rem;
}

.mobile-character-vitals {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.mobile-character-stat {
  padding: 0.85rem 0.9rem;
}

.mobile-character-stat strong {
  display: block;
  margin-top: 0.35rem;
  font-size: 1rem;
  color: var(--text);
}

.mobile-character-stat--plain {
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  background: var(--bg-inset);
}

.mobile-character-actions,
.mobile-character-section {
  padding: 0.95rem 1rem;
}

.mobile-character-action-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.55rem;
  margin-top: 0.75rem;
}

.mobile-character-abilities {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.55rem;
  margin-top: 0.75rem;
}

.mobile-character-ability {
  padding: 0.7rem 0.5rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-dim);
  background: var(--bg-inset);
  text-align: center;
}

.mobile-character-ability-abbr {
  display: block;
  font-family: var(--font-display);
  font-size: 0.74rem;
  letter-spacing: 0.12em;
  color: var(--text-faint);
}

.mobile-character-ability strong {
  display: block;
  margin-top: 0.2rem;
  color: var(--text);
}

.mobile-character-ability span:last-child {
  display: block;
  margin-top: 0.15rem;
  font-size: 0.82rem;
}

.mobile-character-list {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.mobile-character-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.62rem 0.7rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-dim);
  background: var(--bg-inset);
}

.mobile-character-row-label {
  font-size: 0.82rem;
  color: var(--text-faint);
}

.mobile-character-row-value {
  text-align: right;
  font-size: 0.86rem;
  color: var(--text);
}

.mobile-character-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.mobile-character-item-list {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.mobile-character-item {
  padding: 0.8rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-dim);
  background: var(--bg-inset);
}

.mobile-character-item-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

.mobile-character-inline-form {
  margin: 0;
}

.mobile-character-item-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.7rem;
}

.mobile-world-page {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.mobile-world-hero,
.mobile-world-toolbar,
.mobile-world-selected,
.mobile-world-card,
.mobile-world-alert {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}

.mobile-world-toolbar {
  gap: 0.75rem;
}

.mobile-world-realm-form {
  width: 100%;
}

.mobile-world-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.mobile-world-stack,
.mobile-world-zone-list,
.mobile-world-list {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}

.mobile-world-selected-head,
.mobile-world-zone-card-head {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.mobile-world-selected-icon {
  width: 3rem;
  height: 3rem;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03));
  border: 1px solid var(--border-dim);
  color: var(--accent-pale);
  font-family: 'Cinzel', serif;
  font-size: 0.95rem;
  letter-spacing: 0.08em;
  flex-shrink: 0;
}

.mobile-world-selected-icon--small {
  width: 2.3rem;
  height: 2.3rem;
  border-radius: 12px;
  font-size: 0.78rem;
}

.mobile-world-action-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.mobile-world-action-form {
  margin: 0;
}

.mobile-world-list-row,
.mobile-world-dungeon {
  padding: 0.78rem 0.82rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-dim);
  background: var(--bg-inset);
}

.mobile-world-list-row {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.mobile-world-zone-card {
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.mobile-world-zone-card--selected {
  border-color: rgba(224, 192, 118, 0.42);
  box-shadow: 0 0 0 1px rgba(224, 192, 118, 0.14) inset;
}

.mobile-world-zone-name {
  display: block;
  font-family: 'Cinzel', serif;
  color: var(--accent-pale);
}

.mobile-world-zone-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.eq-header { margin-bottom: 0; }

.eq-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 0.85rem;
  align-items: start;
}

/* ── Equipment slot list (left column) ── */
.eq-slots { padding: 0.85rem 0.9rem; }

.eq-slot-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.eq-slot {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.45rem 0.5rem;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  background: var(--bg-inset);
  transition: border-color 120ms, background 120ms;
  min-height: 46px;
}

.eq-slot--filled {
  border-color: var(--border-mid);
  background: rgba(180, 130, 50, 0.07);
}

.eq-slot-icon {
  font-size: 1.15rem;
  width: 28px;
  text-align: center;
  flex-shrink: 0;
  opacity: 0.7;
}

.eq-slot--filled .eq-slot-icon { opacity: 1; }

.eq-slot-info {
  display: flex;
  flex-direction: column;
  gap: 0.08rem;
  flex: 1;
  min-width: 0;
}

.eq-slot-name {
  font-size: 0.68rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-faint);
  font-family: 'Cinzel', serif;
}

.eq-slot-item {
  font-size: 0.88rem;
  color: var(--text-dim);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.eq-slot--filled .eq-slot-item { color: var(--accent-pale); }

.eq-slot-action { margin-left: auto; flex-shrink: 0; }
.eq-slot-action button { padding: 0.2rem 0.5rem; font-size: 0.78rem; }

/* ── Inventory grid (right column) ── */
.eq-inventory { padding: 0.85rem 0.9rem; }

.inv-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(72px, 1fr));
  gap: 0.5rem;
}

.inv-cell {
  position: relative;
  aspect-ratio: 1;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-dim);
  background: var(--bg-inset);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: default;
  transition: border-color 140ms, background 140ms, box-shadow 140ms;
  overflow: hidden;
}

.inv-cell:hover {
  border-color: var(--border-bright);
  background: rgba(180, 130, 50, 0.08);
  box-shadow: 0 0 0 1px var(--border-mid);
  z-index: 1;
}

.inv-cell--equipped {
  border-color: rgba(106, 170, 96, 0.45);
  background: rgba(106, 170, 96, 0.06);
}

.inv-cell--equipped:hover {
  border-color: rgba(106, 170, 96, 0.7);
}

.inv-cell-icon {
  font-size: 1.7rem;
  line-height: 1;
  user-select: none;
  transition: transform 120ms;
}

.inv-cell:hover .inv-cell-icon { transform: scale(0.9); }

/* Quantity badge */
.inv-qty {
  position: absolute;
  bottom: 3px;
  right: 4px;
  font-size: 0.68rem;
  font-family: 'Cinzel', serif;
  color: var(--text-dim);
  background: rgba(0,0,0,0.55);
  padding: 0 3px;
  border-radius: 3px;
  line-height: 1.4;
}

/* Equipped pip */
.inv-equipped-pip {
  position: absolute;
  top: 3px;
  right: 4px;
  font-size: 0.6rem;
  font-family: 'Cinzel', serif;
  font-weight: 700;
  color: #b8e8b0;
  background: rgba(106,170,96,0.25);
  padding: 0 3px;
  border-radius: 3px;
  line-height: 1.5;
  letter-spacing: 0.04em;
}

/* Equip button — hidden until hover */
.inv-cell-form {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding-bottom: 0.3rem;
  opacity: 0;
  transition: opacity 120ms;
  pointer-events: none;
}

.inv-cell:hover .inv-cell-form {
  opacity: 1;
  pointer-events: all;
}

.inv-equip-btn {
  font-size: 0.7rem !important;
  padding: 0.18rem 0.5rem !important;
  letter-spacing: 0.06em;
  pointer-events: all;
}

/* ── Tooltip ── */
.inv-tooltip {
  position: fixed;
  z-index: 9999;
  pointer-events: none;
  background: var(--bg-panel);
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-md);
  padding: 0.65rem 0.85rem;
  min-width: 180px;
  max-width: 240px;
  box-shadow: var(--shadow-lg);
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 100ms, transform 100ms;
}

.inv-tooltip.visible {
  opacity: 1;
  transform: translateY(0);
}

.inv-tip-name {
  font-family: 'Cinzel', serif;
  font-size: 0.88rem;
  color: var(--accent-pale);
  margin-bottom: 0.2rem;
  letter-spacing: 0.04em;
}

.inv-tip-type {
  font-size: 0.75rem;
  color: var(--text-faint);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 0.35rem;
  font-family: 'Cinzel', serif;
}

.inv-tip-note {
  font-size: 0.85rem;
  color: var(--text-dim);
  line-height: 1.45;
  margin-bottom: 0.35rem;
}

.inv-tip-stats {
  font-size: 0.78rem;
  color: var(--accent);
  font-family: 'Cinzel', serif;
  letter-spacing: 0.04em;
  border-top: 1px solid var(--border-dim);
  padding-top: 0.3rem;
  margin-top: 0.1rem;
  min-height: 0.5rem;
}

@media (max-width: 900px) {
  .eq-layout { grid-template-columns: 1fr; }
}

/* =========================================================
   CHARACTER SHEET — three-column RPG layout
   ========================================================= */

/* Header bar */
.cs-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  padding: 0.85rem 1.1rem;
}

.cs-header-identity { display: flex; align-items: baseline; gap: 0.75rem; flex-wrap: wrap; }

.cs-name {
  font-family: 'Cinzel', serif;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--accent-pale);
  letter-spacing: 0.06em;
  margin: 0;
}

.cs-archetype {
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-faint);
  font-family: 'Cinzel', serif;
}

.cs-header-vitals {
  display: flex;
  gap: 0.1rem;
  flex-wrap: wrap;
}

.cs-vital {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0.35rem 0.7rem;
  border-radius: var(--radius-sm);
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  min-width: 52px;
}

.cs-vital-label {
  font-size: 0.62rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-faint);
  font-family: 'Cinzel', serif;
}

.cs-vital-val {
  font-family: 'Cinzel', serif;
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--accent-pale);
  line-height: 1.2;
}

/* Three-column layout */
.cs-layout {
  display: grid;
  grid-template-columns: 190px 240px 1fr;
  gap: 0.75rem;
  align-items: start;
}

.cs-col-stats,
.cs-col-equip,
.cs-col-inv {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

/* Section block inside a panel */
.cs-block { padding: 0.8rem 0.9rem; }

.cs-block-label {
  font-size: 0.65rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-faint);
  font-family: 'Cinzel', serif;
  margin-bottom: 0.6rem;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid var(--border-dim);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cs-inv-count {
  font-size: 0.68rem;
  color: var(--text-faint);
}

/* Ability scores */
.cs-abilities {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.4rem;
}

.cs-ability {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0.5rem 0.25rem;
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-sm);
  transition: border-color 120ms;
}

.cs-ability:hover { border-color: var(--border-mid); }

.cs-ability-abbr {
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-faint);
  font-family: 'Cinzel', serif;
}

.cs-ability-score {
  font-family: 'Cinzel', serif;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text);
  line-height: 1.1;
  margin: 0.1rem 0;
}

.cs-ability-mod {
  font-size: 0.72rem;
  font-family: 'Cinzel', serif;
  font-weight: 600;
}

.cs-ability-mod.pos { color: var(--green); }
.cs-ability-mod.neg { color: var(--red); }

/* Resource bars */
.cs-resource-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

.cs-resource-label {
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-faint);
  font-family: 'Cinzel', serif;
}

.cs-resource-val {
  font-family: 'Cinzel', serif;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text);
}

.cs-resource-max {
  font-size: 0.78rem;
  color: var(--text-faint);
  font-weight: 400;
}

/* Inventory grid inside character sheet — slightly smaller cells */
.cs-inv-grid {
  grid-template-columns: repeat(auto-fill, minmax(58px, 1fr));
  gap: 0.4rem;
}

/* Responsive collapse */
@media (max-width: 1100px) {
  .cs-layout { grid-template-columns: 190px 1fr; }
  .cs-col-inv { grid-column: 1 / -1; }
}

@media (max-width: 700px) {
  .cs-layout { grid-template-columns: 1fr; }
  .cs-col-inv { grid-column: auto; }
  .cs-header { flex-direction: column; align-items: flex-start; }
}

/* =========================================================
   SHOP — icon grid layout
   ========================================================= */

.shop-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  flex-wrap: wrap;
}

.shop-header-left { flex: 1; }
.shop-header-right { flex-shrink: 0; }

.shop-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  align-items: start;
}

.shop-panel { padding: 0.85rem 0.9rem; }

/* ── Item grid ── */
.shop-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(72px, 1fr));
  gap: 0.45rem;
  margin-top: 0.5rem;
}

/* ── Shop cell ── */
.shop-cell {
  position: relative;
  aspect-ratio: 1;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-dim);
  background: var(--bg-inset);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: default;
  transition: border-color 140ms, background 140ms, box-shadow 140ms;
  overflow: hidden;
}

.shop-cell:hover {
  border-color: var(--border-bright);
  background: rgba(180, 130, 50, 0.09);
  box-shadow: 0 0 0 1px var(--border-mid);
  z-index: 1;
}

/* Can't afford — dimmed */
.shop-cell--broke {
  opacity: 0.42;
}

.shop-cell--broke:hover {
  border-color: rgba(192, 88, 74, 0.4);
  background: rgba(192, 88, 74, 0.06);
  opacity: 0.7;
}

/* Sell side — slight green tint when equipped */
.shop-cell--sell {
  border-color: var(--border-dim);
}

.shop-cell--sell:hover {
  border-color: rgba(106, 170, 96, 0.5);
  background: rgba(106, 170, 96, 0.06);
}

.shop-cell--equipped {
  border-color: rgba(106, 170, 96, 0.35);
  background: rgba(106, 170, 96, 0.05);
}

/* Icon */
.shop-cell-icon {
  font-size: 1.65rem;
  line-height: 1;
  user-select: none;
  transition: transform 120ms;
  pointer-events: none;
}

.shop-cell:hover .shop-cell-icon { transform: scale(0.88); }

/* Price badge — bottom of cell */
.shop-cell-price {
  position: absolute;
  bottom: 3px;
  left: 0;
  right: 0;
  text-align: center;
  font-size: 0.65rem;
  font-family: 'Cinzel', serif;
  letter-spacing: 0.04em;
  color: var(--accent);
  background: rgba(0, 0, 0, 0.5);
  padding: 1px 3px;
  line-height: 1.5;
  pointer-events: none;
}

.shop-price--broke { color: var(--red); }
.shop-price--sell  { color: var(--green); }

/* Buy/Sell button — appears on hover */
.shop-cell-form {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding-bottom: 20px; /* sit above price label */
  opacity: 0;
  pointer-events: none;
  transition: opacity 120ms;
}

.shop-cell:not(.shop-cell--broke):hover .shop-cell-form {
  opacity: 1;
  pointer-events: all;
}

.shop-buy-btn {
  font-size: 0.68rem !important;
  padding: 0.15rem 0.45rem !important;
  letter-spacing: 0.06em;
  pointer-events: all;
}

/* ── Shop qty modal ── */
.shop-modal-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.82);
  z-index: 1000;
  align-items: center;
  justify-content: center;
}
.shop-modal-backdrop.shop-modal--open {
  display: flex;
}
.shop-modal {
  background: var(--bg-card);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-md);
  padding: 1.4rem 1.6rem;
  min-width: 260px;
  max-width: 340px;
  width: 90%;
  box-shadow: 0 8px 32px rgba(0,0,0,0.45);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.shop-modal-title {
  font-family: 'Cinzel', serif;
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
  margin: 0;
}
.shop-modal-sub {
  font-size: 0.82rem;
  color: var(--text-dim);
  margin: 0;
}
.shop-modal-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.shop-modal-input {
  width: 70px;
  text-align: center;
  background: var(--bg-inset);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-sm);
  padding: 0.35rem 0.5rem;
  color: var(--text);
  font: inherit;
  font-size: 1rem;
  outline: none;
  transition: border-color 120ms;
}
.shop-modal-input:focus { border-color: var(--border-glow); }
.shop-modal-total {
  font-size: 0.85rem;
  color: var(--accent-bright);
  margin: 0;
}
.shop-modal-actions {
  display: flex;
  gap: 0.5rem;
}

/* Tabs sit flush above layout */
.shop-tabs {
  display: flex;
  gap: 0.35rem;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--border-dim);
  padding-bottom: 0.6rem;
  margin-bottom: 0.1rem;
}

.shop-tabs .nav-button {
  width: auto;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.3rem 0.65rem;
  font-size: 0.8rem;
}

@media (max-width: 700px) {
  .shop-layout { grid-template-columns: 1fr; }
}

/* =========================================================
   WORLD MAP
   ========================================================= */

.world-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  flex-wrap: wrap;
}

.world-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 0.75rem;
  align-items: start;
}

/* ── SVG map container ── */
.world-map-wrap {
  padding: 0.65rem;
  background: var(--bg-deep);
  border-color: var(--border-mid);
  overflow: hidden;
  line-height: 0; /* no whitespace under svg */
}

.world-map-frame {
  position: relative;
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.08));
  overflow: hidden;
}

.world-map-viewport {
  overflow: auto;
  width: 100%;
  height: clamp(560px, 76vh, 920px);
  cursor: grab;
  scroll-behavior: auto;
}

.world-map-viewport.is-dragging {
  cursor: grabbing;
  user-select: none;
}

.world-map-svg {
  width: 3200px;
  height: 1120px;
  min-width: 3200px;
  max-width: none;
  display: block;
  flex: none;
}

.world-map-hint {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  z-index: 2;
  padding: 0.35rem 0.55rem;
  border-radius: var(--radius-pill);
  background: rgba(18, 22, 30, 0.7);
  border: 1px solid var(--border-dim);
  color: var(--text-dim);
  font-size: 0.72rem;
  letter-spacing: 0.03em;
  pointer-events: none;
  backdrop-filter: blur(4px);
}

/* Zone rects */
.zone-rect {
  cursor: pointer;
  transition: stroke 160ms, fill-opacity 160ms;
}

.zone-rect:hover {
  stroke: rgba(200, 146, 42, 0.6) !important;
  stroke-width: 1.5px !important;
}

.zone-locked {
  cursor: not-allowed;
}

.zone-selected {
  filter: drop-shadow(0 0 6px rgba(200,146,42,0.4));
}

.zone-link { text-decoration: none; }

/* ── Detail sidebar ── */
.world-detail {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  position: sticky;
  top: 60px;
  align-self: start;
  max-height: calc(100vh - 80px);
  overflow-y: auto;
}

.world-zone-card { padding: 0.85rem 0.9rem; }

.world-dm-party-presence {
  margin-top: 0.75rem;
  padding: 0.7rem 0.8rem;
  border-radius: var(--radius-md);
  background: rgba(36, 28, 16, 0.55);
  border: 1px solid rgba(198, 154, 84, 0.2);
}

.world-dm-party-presence--complete {
  background: rgba(32, 56, 30, 0.42);
  border-color: rgba(112, 188, 104, 0.28);
}

.world-dm-party-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.world-dm-party-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.22rem 0.5rem;
  border-radius: 999px;
  background: rgba(200, 146, 42, 0.12);
  border: 1px solid rgba(200, 146, 42, 0.24);
  color: var(--accent-pale);
  font-size: 0.73rem;
  line-height: 1.2;
}

.world-dm-party-chip--leader {
  background: rgba(214, 176, 86, 0.18);
  border-color: rgba(228, 196, 118, 0.4);
  color: #fff0b8;
}

.world-dm-party-chip--muted {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.08);
  color: var(--text-faint);
}

.world-zone-header {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
}

.world-terrain-icon {
  font-size: 2rem;
  line-height: 1;
  flex-shrink: 0;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.5));
}

/* Enemy list */
.world-enemy-list { display: flex; flex-direction: column; gap: 0.45rem; }

.world-enemy-row {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.4rem 0.5rem;
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-sm);
}

.world-enemy-icon { font-size: 1rem; flex-shrink: 0; }

.world-enemy-info {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  flex: 1;
  min-width: 0;
}

.world-enemy-name {
  font-size: 0.88rem;
  color: var(--text);
  font-family: 'Cinzel', serif;
  letter-spacing: 0.03em;
}

.world-enemy-stats {
  font-size: 0.75rem;
  color: var(--text-faint);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Shop list */
.world-shop-list { display: flex; flex-direction: column; gap: 0.45rem; }

.world-shop-row {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  padding: 0.4rem 0.5rem;
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-sm);
}

.world-shop-row > span:first-child { font-size: 1rem; flex-shrink: 0; }

.world-shop-row > div {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  min-width: 0;
  flex: 1;
}

.world-shop-row .world-enemy-stats {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  overflow-wrap: anywhere;
}

/* Responsive */
@media (max-width: 900px) {
  .world-layout { grid-template-columns: 1fr; }
  .world-map-viewport { height: clamp(420px, 68vh, 720px); }
  .world-detail { position: static; max-height: none; overflow-y: visible; }
  .world-map-hint {
    top: auto;
    bottom: 0.65rem;
    right: 0.65rem;
    font-size: 0.68rem;
  }
}

/* =========================================================
   ADMIN PAGES
   ========================================================= */

.admin-page-header { padding: 0.85rem 1.1rem; }

.admin-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  align-items: start;
}

.admin-form-panel,
.admin-list-panel { padding: 0.85rem 0.9rem; }

/* Sticky form panel — hide the outer scrollbar, let content flow naturally */
.admin-form-panel[style*="sticky"]::-webkit-scrollbar { display: none; }

/* Multi-field row inside forms */
.admin-field-row {
  display: flex;
  gap: 0.65rem;
  flex-wrap: wrap;
}

.admin-field-row .field { flex: 1; min-width: 100px; }

/* Textarea */
.admin-textarea {
  width: 100%;
  background: var(--bg-inset);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-sm);
  padding: 0.55rem 0.75rem;
  color: var(--text);
  font: inherit;
  font-size: 0.95rem;
  resize: vertical;
  outline: none;
  transition: border-color 120ms;
}

.admin-textarea:focus { border-color: var(--border-glow); }

/* File input */
.admin-file-input {
  display: block;
  font-size: 0.88rem;
  color: var(--text-dim);
  margin-top: 0.2rem;
}

/* Preview image in form */
.admin-preview-img {
  width: 48px;
  height: 48px;
  object-fit: contain;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-dim);
  vertical-align: middle;
}

/* List img in list rows */
.admin-list-img {
  width: 32px;
  height: 32px;
  object-fit: contain;
  border-radius: 3px;
}

/* Item list rows */
.admin-item-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.admin-item-row {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.45rem 0.5rem;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  background: var(--bg-inset);
  transition: border-color 120ms, background 120ms;
}

.admin-item-row:hover { border-color: var(--border-dim); background: var(--bg-raised); }

.admin-item-row--active {
  border-color: var(--border-bright);
  background: rgba(180, 130, 50, 0.08);
}

.admin-item-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  flex-shrink: 0;
}

.admin-item-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
}

.admin-item-name {
  font-size: 0.9rem;
  font-family: 'Cinzel', serif;
  color: var(--text);
  letter-spacing: 0.03em;
}

.admin-item-meta {
  font-size: 0.75rem;
  color: var(--text-faint);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.admin-item-actions {
  display: flex;
  gap: 0.35rem;
  flex-shrink: 0;
  flex-wrap: wrap;
}

.admin-item-actions form { margin: 0; }

/* Account card */
.admin-account-card { padding: 0.85rem 0.9rem; margin-bottom: 0; }

.admin-account-actions {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
  margin-top: 0.65rem;
  padding-top: 0.65rem;
  border-top: 1px solid var(--border-dim);
  align-items: center;
}

.admin-account-actions form { margin: 0; }

.admin-pw-form {
  margin-top: 0.65rem;
  padding: 0.65rem 0.75rem;
  background: var(--bg-inset);
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-dim);
}

/* Nav cards on dashboard */
.admin-nav-card {
  display: block;
  text-decoration: none;
  transition: border-color 140ms, background 140ms;
  cursor: pointer;
}

.admin-nav-card:hover {
  border-color: var(--border-bright);
  background: rgba(180, 130, 50, 0.07);
}

.admin-nav-card .section-title { font-size: 1rem; }

/* Hidden utility */
.hidden { display: none !important; }

@media (max-width: 800px) {
  .admin-layout { grid-template-columns: 1fr; }
}

/* ── World map zone tooltip ── */
.world-zone-tooltip {
  position: fixed;
  z-index: 9999;
  pointer-events: none;
  background: var(--bg-panel);
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-md);
  padding: 0.65rem 0.9rem;
  min-width: 200px;
  max-width: 280px;
  box-shadow: var(--shadow-lg);
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 100ms, transform 100ms;
}

.world-zone-tooltip.visible {
  opacity: 1;
  transform: translateY(0);
}

.world-tip-name {
  font-family: 'Cinzel', serif;
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--accent-pale);
  letter-spacing: 0.05em;
  margin-bottom: 0.2rem;
}

.world-tip-sub {
  font-size: 0.72rem;
  font-family: 'Cinzel', serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin-bottom: 0.4rem;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid var(--border-dim);
}

.world-tip-enemies,
.world-tip-party,
.world-tip-status {
  font-size: 0.74rem;
  line-height: 1.35;
}

.world-tip-party {
  color: var(--accent-pale);
  margin-top: 0.22rem;
}

.world-dm-party-marker-group {
  pointer-events: none;
}

.world-dm-party-marker {
  fill: rgba(80, 132, 188, 0.92);
  stroke: rgba(225, 236, 248, 0.8);
  stroke-width: 0.9;
  filter: url(#glow);
}

.world-dm-party-marker--leader {
  fill: rgba(210, 164, 72, 0.98);
  stroke: rgba(255, 240, 184, 0.95);
}

.world-dm-party-marker--extra {
  fill: rgba(88, 92, 112, 0.96);
  stroke: rgba(220, 224, 236, 0.84);
}

.world-dm-party-marker-text {
  font-family: 'Cinzel', serif;
  font-size: 5px;
  font-weight: 700;
  fill: #f8f2e7;
  letter-spacing: 0.02em;
  pointer-events: none;
}

.world-tip-enemies {
  font-size: 0.82rem;
  color: var(--text-dim);
  margin-bottom: 0.3rem;
  line-height: 1.45;
  min-height: 0;
}

.world-tip-status {
  font-size: 0.78rem;
  font-family: 'Cinzel', serif;
  letter-spacing: 0.04em;
  margin-top: 0.1rem;
}

/* ── Usable item pip & use button ── */
.inv-usable-pip {
  position: absolute;
  top: 3px;
  left: 4px;
  font-size: 0.58rem;
  color: var(--accent);
  line-height: 1;
  opacity: 0.8;
  pointer-events: none;
}

.inv-use-btn {
  background: linear-gradient(160deg, #5548a8, #3a3078) !important;
  color: #d8d0ff !important;
  border-color: rgba(120, 100, 200, 0.4) !important;
}

.inv-use-btn:hover {
  background: linear-gradient(160deg, #6658b8, #4a4088) !important;
}

/* Admin field hints */
.admin-field-hint {
  font-family: 'Crimson Pro', serif;
  font-size: 0.75rem;
  font-weight: 400;
  color: var(--text-faint);
  letter-spacing: 0;
  text-transform: none;
  margin-left: 0.3rem;
}

.admin-consumable-block {
  background: rgba(85, 72, 168, 0.06);
  border: 1px solid rgba(85, 72, 168, 0.2);
  border-radius: var(--radius-md);
  padding: 0.65rem 0.75rem;
  margin-bottom: 0.65rem;
}

/* ── Admin shops three-column layout ── */
.admin-shops-layout {
  display: grid;
  grid-template-columns: 260px 1fr 1fr;
  gap: 0.75rem;
  align-items: start;
}

/* Zone checkbox list */
.admin-zone-checklist {
  display: flex;
  flex-direction: column;
  gap: 2px;
  max-height: 220px;
  overflow-y: auto;
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-sm);
  padding: 0.35rem 0.4rem;
}

.admin-zone-check-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.3rem 0.4rem;
  border-radius: 3px;
  cursor: pointer;
  font-size: 0.88rem;
  transition: background 100ms;
}

.admin-zone-check-row:hover { background: rgba(255,255,255,0.04); }

.admin-zone-check-row input[type="checkbox"] {
  flex-shrink: 0;
  accent-color: var(--accent);
  width: 14px;
  height: 14px;
}

/* Mini map inside zone panel */
.admin-map-wrap {
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: #080c14;
}

@media (max-width: 1100px) {
  .admin-shops-layout { grid-template-columns: 240px 1fr; }
  .admin-shops-layout > section:last-child { grid-column: 1 / -1; }
}

@media (max-width: 700px) {
  .admin-shops-layout { grid-template-columns: 1fr; }
}

/* ── Admin map tooltip ── */
.admin-map-wrap { position: relative; }

.admin-map-tooltip {
  position: absolute;
  z-index: 50;
  pointer-events: none;
  background: var(--bg-panel);
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-md);
  padding: 0.55rem 0.75rem;
  min-width: 170px;
  max-width: 230px;
  box-shadow: var(--shadow-lg);
  opacity: 0;
  transform: translateY(3px);
  transition: opacity 90ms, transform 90ms;
  white-space: nowrap;
}

.admin-map-tooltip.visible {
  opacity: 1;
  transform: translateY(0);
}

.admin-tip-name {
  font-family: 'Cinzel', serif;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--accent-pale);
  letter-spacing: 0.05em;
  margin-bottom: 0.2rem;
}

.admin-tip-sub {
  font-size: 0.72rem;
  font-family: 'Cinzel', serif;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin-bottom: 0.25rem;
}

.admin-tip-status {
  font-size: 0.78rem;
  font-family: 'Cinzel', serif;
  letter-spacing: 0.03em;
}

/* ── Inline enemy drop rows ── */
.enemy-drop-row {
  background: var(--bg-inset);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-md);
  padding: 0.65rem 0.75rem;
  margin-bottom: 0.5rem;
}

.enemy-drop-row-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
  font-size: 0.75rem;
  font-family: 'Cinzel', serif;
  letter-spacing: 0.08em;
  color: var(--accent);
  text-transform: uppercase;
}

/* =========================================================
   MAP EDITOR
   ========================================================= */

.map-editor-wrap { display: flex; flex-direction: column; gap: 0.6rem; }

.map-editor-toolbar {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  padding: 0.55rem 0.85rem;
}

.map-tool-group {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  flex-wrap: wrap;
}

.map-tool-btn {
  background: var(--bg-inset);
  border: 1px solid var(--border-mid);
  color: var(--text-dim);
  border-radius: var(--radius-sm);
  padding: 0.3rem 0.7rem;
  font-size: 0.82rem;
  font-family: 'Cinzel', serif;
  letter-spacing: 0.04em;
  cursor: pointer;
  width: auto;
  transition: background 120ms, color 120ms, border-color 120ms;
}

.map-tool-btn:hover {
  background: var(--bg-raised);
  color: var(--text);
  border-color: var(--border-bright);
}

.map-tool-btn.active {
  background: rgba(180,130,50,0.18);
  color: var(--accent-pale);
  border-color: var(--border-bright);
  box-shadow: inset 0 1px 0 rgba(200,160,80,0.15);
}

.map-tool-label {
  font-size: 0.8rem;
  color: var(--text-dim);
  display: flex;
  align-items: center;
  gap: 0.3rem;
  cursor: pointer;
}

.map-status-msg {
  font-size: 0.8rem;
  color: var(--green);
  font-family: 'Cinzel', serif;
  letter-spacing: 0.04em;
  min-width: 180px;
  text-align: right;
}

/* Editor body: canvas left, props right */
.map-editor-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 280px;
  gap: 0.6rem;
  align-items: start;
}

/* Wraps zoom bar + canvas so they occupy one grid cell */
.map-canvas-column {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

/* Outer frame — fixed height, clips and decorates */
.map-canvas-wrap {
  background: #0d1018;
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-lg);
  overflow: hidden;
  line-height: 0;
  position: relative;
  min-width: 0;
}

/* Scrollable viewport inside the frame */
.map-canvas-viewport {
  overflow: auto;
  width: 100%;
  height: clamp(480px, 72vh, 860px);
  cursor: grab;
  scroll-behavior: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

.map-canvas-viewport.is-panning {
  cursor: grabbing;
  user-select: none;
}

/* SVG is full 3200×1120 — scrolls inside viewport, never stretches grid */
#map-svg {
  width: 3200px;
  height: 1120px;
  display: block;
  flex: none;
}

.map-props-panel {
  padding: 0.85rem 0.9rem;
  position: sticky;
  top: 60px;
}

@media (max-width: 1000px) {
  .map-editor-body { grid-template-columns: 1fr; }
  .map-canvas-column { min-width: 0; }
  .map-props-panel { position: static; }
}

/* Road tool cursor hint */
.map-canvas-viewport.road-mode { cursor: crosshair !important; }

/* Road props panel — matches zone/continent panel aesthetics */
#road-props .road-preview-swatch {
  display: inline-block;
  width: 32px; height: 8px;
  border-radius: 4px;
  vertical-align: middle;
  margin-left: 0.4rem;
  box-shadow: 0 1px 3px rgba(0,0,0,0.4);
}


/* ── Zoom controls (shared by admin map + world map) ── */
.map-zoom-bar {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.3rem 0.5rem;
  background: var(--bg-raised);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-md);
  width: fit-content;
  margin-bottom: 0.35rem;
}
.map-zoom-btn {
  background: var(--bg-inset);
  border: 1px solid var(--border-mid);
  color: var(--text-dim);
  border-radius: var(--radius-sm);
  width: 26px; height: 26px;
  font-size: 1rem; line-height: 1;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: background 100ms, color 100ms, border-color 100ms;
  padding: 0;
}
.map-zoom-btn:hover {
  background: var(--bg-panel);
  color: var(--text);
  border-color: var(--border-bright);
}
.map-zoom-label {
  font-family: 'Cinzel', serif;
  font-size: 0.72rem;
  color: var(--text-faint);
  letter-spacing: 0.06em;
  min-width: 3.2rem;
  text-align: center;
  user-select: none;
}
.map-zoom-reset {
  font-size: 0.7rem;
  padding: 0 0.5rem;
  height: 26px;
  width: auto;
}


/* ── Dungeon explore layout (mirrors dungeon builder but read-only) ── */
.dungeon-explore-wrap {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 280px;
  gap: 0.6rem;
  align-items: start;
  margin-top: 0;
}

.dungeon-info-panel {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  position: sticky;
  top: 60px;
  align-self: start;
  max-height: calc(100vh - 80px);
  overflow-y: auto;
}

@media (max-width: 1000px) {
  .dungeon-explore-wrap { grid-template-columns: 1fr; }
  .dungeon-info-panel   { position: static; max-height: none; overflow-y: visible; }
}

/* =========================================================
   DUNGEON BUILDER
   ========================================================= */

.dungeon-builder-wrap {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 280px;
  gap: 0.6rem;
  align-items: start;
}

.dungeon-canvas-column {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.dungeon-canvas-wrap {
  background: #0e0c12;
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-lg);
  overflow: hidden;
  line-height: 0;
  position: relative;
  min-width: 0;
}

.dungeon-canvas-viewport {
  overflow: auto;
  width: 100%;
  height: clamp(480px, 72vh, 860px);
  cursor: default;
  scroll-behavior: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

#dungeon-svg {
  width: 1600px;
  height: 1000px;
  display: block;
}

.dungeon-props-panel {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  position: sticky;
  top: 60px;
  align-self: start;
  max-height: calc(100vh - 80px);
  overflow-y: auto;
  scrollbar-width: none; /* hide the outer panel scrollbar */
}
.dungeon-props-panel::-webkit-scrollbar { display: none; }

@media (max-width: 1000px) {
  .dungeon-builder-wrap { grid-template-columns: 1fr; }
  .dungeon-props-panel  { position: static; max-height: none; overflow-y: visible; }
}

/* =========================================================
   CHARACTER SELECT
   ========================================================= */

.char-select-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 0.75rem;
}

.char-select-card {
  position: relative;
  padding: 1.1rem 1.2rem;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-dim);
  transition: border-color 150ms, box-shadow 150ms;
}

.char-select-card:hover {
  border-color: var(--border-bright);
  box-shadow: var(--shadow-md);
}

.char-select-card--active {
  border-color: rgba(106,170,96,0.5);
  box-shadow: 0 0 0 1px rgba(106,170,96,0.2);
}

.char-select-new {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  cursor: pointer;
  opacity: 0.7;
  min-height: 160px;
  border: 1px dashed var(--border-mid);
  transition: opacity 150ms, border-color 150ms;
}
.char-select-new:hover { opacity: 1; border-color: var(--border-bright); }

.char-select-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

.char-select-icon {
  font-size: 2rem;
  line-height: 1;
  flex-shrink: 0;
}

.char-select-stats {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.char-delete-details summary::-webkit-details-marker { display: none; }

.char-delete-confirm {
  position: absolute;
  bottom: calc(100% + 6px);
  left: 0;
  right: 0;
  z-index: 20;
  padding: 0.75rem;
  border: 1px solid rgba(192,88,74,0.4);
  background: var(--bg-panel);
  box-shadow: var(--shadow-lg);
}

/* =========================================================
   SPELL BOOK
   ========================================================= */

.spell-book-wrap {
  margin-top: 0;
}

.spell-book-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.spell-slots-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  padding: 0.6rem 0.75rem;
  background: var(--bg-inset);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-dim);
  margin-bottom: 0.5rem;
}

.spell-slot-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.3rem;
}

.spell-slot-label {
  font-family: 'Cinzel', serif;
  font-size: 0.68rem;
  color: var(--text-faint);
  letter-spacing: 0.06em;
}

.spell-slot-pips {
  display: flex;
  gap: 3px;
}

.spell-slot-pip {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 1px solid rgba(120,100,200,0.5);
}

.spell-slot-pip--full  { background: rgba(100,80,220,0.8); }
.spell-slot-pip--spent { background: transparent; }

.spell-grid {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  margin-top: 0.35rem;
}

.spell-card {
  border: 1px solid rgba(100,80,200,0.2);
  border-radius: var(--radius-md);
  padding: 0.6rem 0.75rem;
}

.spell-card-top {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.spell-icon {
  font-size: 1.1rem;
  flex-shrink: 0;
  line-height: 1;
}

.spell-info {
  flex: 1;
  min-width: 0;
}

.spell-name {
  display: block;
  font-family: 'Cinzel', serif;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text);
  letter-spacing: 0.03em;
}

.spell-meta {
  display: block;
  font-size: 0.75rem;
  color: var(--text-faint);
  margin-top: 0.1rem;
}

.spell-desc {
  font-size: 0.82rem;
  color: var(--text-dim);
  margin-top: 0.35rem;
  line-height: 1.45;
}

/* =========================================================
   TAVERN
   ========================================================= */

.tavern-layout {
  display: grid;
  grid-template-columns: 220px 1fr 200px;
  gap: 0.75rem;
  align-items: start;
}

/* Player stat panel — third column */
.tavern-stat-panel {
  padding: 0.85rem 0.9rem;
}

@media (max-width: 860px) {
  .tavern-layout {
    grid-template-columns: 220px 1fr;
  }
  .tavern-stat-panel {
    grid-column: 1 / -1;
  }
}

@media (max-width: 600px) {
  .tavern-layout {
    grid-template-columns: 1fr;
  }
}

/* ── Keeper row: NPC header + stat card side by side ── */
.tavern-keeper-row {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  flex-wrap: wrap;
}

.tavern-keeper-row .tavern-npc-header {
  flex: 0 0 auto;
}

.tavern-stat-card {
  flex: 1;
  min-width: 220px;
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  padding: 0.75rem 0.9rem;
}

.tavern-stat-row {
  display: grid;
  grid-template-columns: 2.8rem 1fr 5.5rem;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.35rem;
}

.tavern-stat-label {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.tavern-bar-track {
  height: 7px;
  background: var(--bg-card);
  border-radius: 999px;
  overflow: hidden;
  border: 1px solid var(--border-dim);
}

.tavern-bar {
  height: 100%;
  border-radius: 999px;
  transition: width 400ms ease;
}

.tavern-stat-val {
  font-size: 0.75rem;
  color: var(--text-dim);
  text-align: right;
  white-space: nowrap;
}

.tavern-stat-val--full { color: var(--green); }

/* NPC roster sidebar */
.tavern-roster { padding: 0.85rem 0.75rem; }

.tavern-npc-row {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.5rem 0.5rem;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background 100ms;
  text-decoration: none;
  color: inherit;
  margin-bottom: 2px;
}
.tavern-npc-row:hover { background: rgba(255,255,255,0.04); }
.tavern-npc-row--active { background: rgba(180,130,50,0.12); border: 1px solid var(--border-mid); }

.tavern-npc-portrait {
  width: 52px; height: 52px;
  border-radius: var(--radius-md);
  background: var(--bg-raised);
  border: 1px solid var(--border-mid);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem; flex-shrink: 0; overflow: hidden;
}
.tavern-npc-portrait img { width: 100%; height: 100%; object-fit: contain; padding: 4px; }

.tavern-npc-info {
  display: flex; flex-direction: column; flex: 1; min-width: 0;
}
.tavern-npc-name  { font-family: 'Cinzel', serif; font-size: 0.84rem; font-weight: 600; color: var(--text); }
.tavern-npc-title { font-size: 0.73rem; color: var(--text-faint); margin-top: 0.05rem; }

/* Dialogue panel */
.tavern-dialogue { padding: 1rem 1.1rem; }

.tavern-npc-header {
  display: flex; align-items: flex-start; gap: 1rem; margin-bottom: 1rem;
}

.tavern-npc-portrait-lg {
  width: 100px; height: 100px;
  border-radius: var(--radius-md);
  background: var(--bg-raised);
  border: 1px solid var(--border-mid);
  display: flex; align-items: center; justify-content: center;
  font-size: 2.5rem; flex-shrink: 0; overflow: hidden;
}
.tavern-npc-portrait-lg img { width: 100%; height: 100%; object-fit: contain; padding: 4px; }

.tavern-speech {
  background: var(--bg-inset);
  border-left: 3px solid var(--border-bright);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  padding: 0.75rem 1rem;
  font-style: italic;
  color: var(--text-dim);
  font-size: 0.92rem;
  line-height: 1.55;
}

.tavern-speech-inline {
  background: var(--bg-inset);
  border-left: 3px solid var(--border-mid);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  padding: 0.5rem 0.75rem;
  font-style: italic;
  color: var(--text-dim);
  font-size: 0.84rem;
  line-height: 1.5;
  margin-top: 0.5rem;
}

/* Quest cards */
.tavern-quest-card {
  background: var(--bg-raised);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  padding: 0.75rem 0.85rem;
  margin-bottom: 0.55rem;
}
.tavern-quest-card--active { border-color: rgba(200,146,42,0.4); }
.tavern-quest-card--done   { border-color: rgba(106,170,96,0.35); opacity: 0.8; }

.tavern-quest-header {
  display: flex; align-items: flex-start; gap: 0.6rem;
}
.tavern-quest-icon { font-size: 1.1rem; flex-shrink: 0; line-height: 1.3; }
.tavern-quest-info { flex: 1; min-width: 0; }
.tavern-quest-name { display: block; font-family: 'Cinzel', serif; font-size: 0.9rem; font-weight: 600; }
.tavern-quest-meta { display: block; font-size: 0.75rem; color: var(--text-faint); margin-top: 0.1rem; }

@media (max-width: 768px) {
  .tavern-layout { grid-template-columns: 1fr; }
}

/* =========================================================
   PARTY SYSTEM
   ========================================================= */

.party-setup-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}

.party-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  align-items: start;
}

/* Member row */
.party-member-row {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  padding: 0.65rem 0.5rem;
  border-radius: var(--radius-md);
  border-bottom: 1px solid var(--border-dim);
}
.party-member-row:last-of-type { border-bottom: none; }
.party-member-row--self { background: rgba(180,130,50,0.06); }

.party-member-icon {
  font-size: 1.5rem;
  line-height: 1;
  flex-shrink: 0;
  margin-top: 0.1rem;
}

.party-member-info { flex: 1; min-width: 0; }

.party-member-name-row {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  flex-wrap: wrap;
  margin-bottom: 0.15rem;
}

.party-member-name {
  font-family: 'Cinzel', serif;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--text);
}

.party-member-meta {
  display: block;
  font-size: 0.75rem;
  color: var(--text-faint);
  margin-bottom: 0.35rem;
}

/* HP/Mana bars */
.party-bar-wrap {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0.2rem;
}

.party-bar-track {
  flex: 1;
  height: 5px;
  background: var(--bg-inset);
  border-radius: var(--radius-pill);
  overflow: hidden;
}

.party-bar {
  height: 100%;
  border-radius: var(--radius-pill);
  transition: width 300ms;
}

.party-bar--hp   { background: linear-gradient(90deg, #4a9a44, #72b868); }
.party-bar--mana { background: linear-gradient(90deg, #4050b0, #6878d8); }
.party-bar--vote { background: linear-gradient(90deg, #a87820, #d4a835); }

.party-bar-label {
  font-size: 0.68rem;
  color: var(--text-faint);
  white-space: nowrap;
  flex-shrink: 0;
  min-width: 60px;
}

.party-vote-badge {
  display: inline-block;
  font-size: 0.72rem;
  color: var(--accent);
  font-family: 'Cinzel', serif;
  margin-top: 0.2rem;
}

/* Invite code display */
.party-invite-block {
  margin-top: 1rem;
  padding-top: 0.75rem;
  border-top: 1px solid var(--border-dim);
}

.party-invite-code {
  font-family: monospace;
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  color: var(--accent-pale);
  background: var(--bg-inset);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-md);
  padding: 0.5rem 0.85rem;
  display: inline-block;
  margin-top: 0.3rem;
}

/* Vote list */
.party-vote-list { display: flex; flex-direction: column; gap: 0.6rem; }

.party-vote-row {
  background: var(--bg-raised);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  padding: 0.6rem 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.65rem;
}

.party-vote-zone { flex: 1; min-width: 0; }
.party-vote-zone-name {
  display: block;
  font-family: 'Cinzel', serif;
  font-size: 0.88rem;
  font-weight: 600;
}
.party-vote-voters {
  display: block;
  font-size: 0.73rem;
  color: var(--text-faint);
  margin-top: 0.1rem;
}
.party-vote-bar-wrap {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  width: 120px;
  flex-shrink: 0;
}

.party-friends-list {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.party-friend-row {
  background: var(--bg-raised);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  padding: 0.65rem 0.75rem;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.party-friend-info {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  flex: 1;
  min-width: 0;
}

.party-friend-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.45rem;
  flex-wrap: wrap;
}

@media (max-width: 700px) {
  .party-setup-grid,
  .party-layout { grid-template-columns: 1fr; }
  .party-friend-row { flex-direction: column; }
  .party-friend-actions {
    width: 100%;
    justify-content: flex-start;
  }
}

/* =========================================================
   CHAT WIDGET
   ========================================================= */

.chat-widget {
  position: fixed;
  bottom: 1.2rem;
  right: 1.2rem;
  z-index: 1000;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

/* Toggle button */
.chat-toggle {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--bg-raised);
  border: 1px solid var(--border-bright);
  font-size: 1.3rem;
  cursor: pointer;
  box-shadow: var(--shadow-md);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: background 120ms, box-shadow 120ms;
}
.chat-toggle:hover {
  background: var(--bg-panel);
  box-shadow: var(--shadow-lg);
}

.chat-unread-badge {
  position: absolute;
  top: -4px; right: -4px;
  min-width: 18px; height: 18px;
  background: var(--red);
  color: #fff;
  border-radius: var(--radius-pill);
  font-size: 0.65rem;
  font-family: 'Cinzel', serif;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  line-height: 1;
}

/* Panel */
.chat-panel {
  width: 320px;
  max-height: 440px;
  background: var(--bg-panel);
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  flex-direction: column;
  overflow: hidden;
  margin-bottom: 0.5rem;
}

/* Header + tabs */
.chat-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.45rem 0.6rem;
  background: var(--bg-raised);
  border-bottom: 1px solid var(--border-dim);
  flex-shrink: 0;
}

.chat-tabs { display: flex; gap: 2px; }

.chat-tab {
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  color: var(--text-dim);
  font-family: 'Cinzel', serif;
  font-size: 0.72rem;
  letter-spacing: 0.05em;
  padding: 0.25rem 0.55rem;
  cursor: pointer;
  transition: background 100ms, color 100ms;
}
.chat-tab:hover { background: rgba(255,255,255,0.05); color: var(--text); }
.chat-tab.active {
  background: rgba(180,130,50,0.18);
  color: var(--accent-pale);
  border-color: var(--border-mid);
}

.chat-close {
  background: none;
  border: none;
  color: var(--text-faint);
  cursor: pointer;
  font-size: 0.9rem;
  padding: 0.15rem 0.3rem;
  border-radius: var(--radius-sm);
  line-height: 1;
  width: auto;
}
.chat-close:hover { color: var(--text); background: rgba(255,255,255,0.06); }

/* Private bar */
.chat-private-bar {
  padding: 0.45rem 0.6rem;
  background: var(--bg-inset);
  border-bottom: 1px solid var(--border-dim);
  position: relative;
  flex-direction: column;
  gap: 0.3rem;
  flex-shrink: 0;
}

.chat-private-bar input[type="text"] {
  width: 100%;
  font-size: 0.82rem;
  background: var(--bg-raised);
  border: 1px solid var(--border-mid);
  color: var(--text);
  border-radius: var(--radius-sm);
  padding: 0.3rem 0.55rem;
}

.chat-dm-results {
  position: absolute;
  left: 0.6rem; right: 0.6rem;
  top: calc(100% - 0.45rem);
  background: var(--bg-panel);
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-md);
  z-index: 10;
  box-shadow: var(--shadow-lg);
  max-height: 160px;
  overflow-y: auto;
}

.chat-dm-result-btn {
  display: block;
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  border-bottom: 1px solid var(--border-dim);
  color: var(--text);
  font-size: 0.82rem;
  padding: 0.4rem 0.65rem;
  cursor: pointer;
  width: auto;
}
.chat-dm-result-btn:hover { background: rgba(255,255,255,0.05); }
.chat-dm-result-btn:last-child { border-bottom: none; }

.chat-dm-target {
  align-items: center;
  justify-content: space-between;
  gap: 0.4rem;
}
.chat-dm-target span {
  font-family: 'Cinzel', serif;
  font-size: 0.8rem;
  color: var(--accent-pale);
}
.chat-dm-target button {
  background: none; border: none; color: var(--text-faint);
  cursor: pointer; font-size: 0.8rem; width: auto; padding: 0.1rem 0.3rem;
}

/* Messages */
.chat-messages {
  flex: 1;
  overflow-y: auto;
  padding: 0.55rem 0.6rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  scroll-behavior: smooth;
}

.chat-empty {
  color: var(--text-faint);
  font-size: 0.8rem;
  text-align: center;
  margin-top: 0.5rem;
}

.chat-error {
  color: var(--red);
  font-size: 0.78rem;
  text-align: center;
}

.chat-msg {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  max-width: 90%;
  align-self: flex-start;
}
.chat-msg--mine { align-self: flex-end; }

.chat-msg-sender {
  font-family: 'Cinzel', serif;
  font-size: 0.68rem;
  color: var(--text-faint);
  letter-spacing: 0.04em;
}
.chat-msg--mine .chat-msg-sender { text-align: right; }

.chat-msg-time {
  font-size: 0.62rem;
  color: var(--text-faint);
  margin-left: auto;
}
.chat-msg--mine .chat-msg-time { margin-left: 0; margin-right: 0; }

.chat-msg-body {
  background: var(--bg-raised);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  padding: 0.4rem 0.6rem;
  font-size: 0.86rem;
  color: var(--text);
  line-height: 1.45;
  word-break: break-word;
}
.chat-msg--mine .chat-msg-body {
  background: rgba(180,130,50,0.15);
  border-color: rgba(180,130,50,0.3);
}

/* Input bar */
.chat-input-bar {
  display: flex;
  gap: 0.35rem;
  padding: 0.45rem 0.55rem;
  border-top: 1px solid var(--border-dim);
  background: var(--bg-raised);
  flex-shrink: 0;
}

.chat-input-bar input {
  flex: 1;
  font-size: 0.84rem;
  background: var(--bg-inset);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-sm);
  color: var(--text);
  padding: 0.3rem 0.55rem;
}
.chat-input-bar input:focus {
  outline: none;
  border-color: var(--border-bright);
}

.chat-input-bar button {
  background: rgba(180,130,50,0.2);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-sm);
  color: var(--accent-pale);
  font-size: 0.9rem;
  padding: 0.3rem 0.6rem;
  cursor: pointer;
  width: auto;
  transition: background 100ms;
}
.chat-input-bar button:hover { background: rgba(180,130,50,0.35); }

.dm-story-widget {
  position: fixed;
  bottom: 1.2rem;
  right: 5rem;
  z-index: 999;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

.dm-story-toggle {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 1px solid var(--border-mid);
  background: linear-gradient(180deg, rgba(120,88,28,0.95), rgba(74,50,18,0.98));
  color: var(--accent-pale);
  font-family: 'Cinzel', serif;
  font-size: 0.74rem;
  letter-spacing: 0.04em;
  box-shadow: var(--shadow-lg);
}

.dm-story-panel {
  width: 340px;
  background: var(--bg-panel);
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  flex-direction: column;
  overflow: hidden;
  margin-bottom: 0.5rem;
}

.dm-story-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.6rem;
  padding: 0.6rem 0.7rem;
  background: var(--bg-raised);
  border-bottom: 1px solid var(--border-dim);
}

.dm-story-body {
  padding: 0.65rem 0.7rem 0.75rem;
  display: grid;
  gap: 0.6rem;
}

.dm-story-body textarea {
  width: 100%;
  min-height: 132px;
  resize: vertical;
  background: var(--bg-inset);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-md);
  color: var(--text);
  padding: 0.65rem 0.75rem;
  font: inherit;
  line-height: 1.5;
}

.dm-story-body textarea:focus {
  outline: none;
  border-color: var(--border-bright);
}

.dm-story-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
}

.dm-story-actions .helper-text {
  flex: 1;
  min-height: 1rem;
}

.dm-story-modal {
  position: fixed;
  right: 1.25rem;
  bottom: 5.6rem;
  width: min(360px, calc(100vw - 2rem));
  max-height: min(50vh, 420px);
  overflow-y: auto;
  z-index: 999;
  background: rgba(18, 15, 24, 0.96);
  border: 1px solid rgba(214, 166, 84, 0.42);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 0.9rem 1rem 1rem;
  pointer-events: auto;
}

.dm-story-modal-close {
  position: absolute;
  top: 0.55rem;
  right: 0.55rem;
  background: none;
  border: none;
  color: var(--text-faint);
  font-size: 0.95rem;
  width: auto;
  padding: 0.15rem 0.35rem;
}

.dm-story-modal-from {
  font-family: 'Cinzel', serif;
  color: var(--accent-pale);
  font-size: 1rem;
  margin-top: 0.5rem;
}

.dm-story-modal-time {
  color: var(--text-faint);
  font-size: 0.74rem;
  margin-top: 0.2rem;
}

.dm-story-modal-body {
  margin-top: 0.7rem;
  color: var(--text);
  line-height: 1.6;
  white-space: pre-wrap;
}

.player-notification-toast {
  position: fixed;
  right: 1.25rem;
  bottom: 5.6rem;
  width: min(360px, calc(100vw - 2rem));
  z-index: 998;
  background: rgba(17, 23, 20, 0.97);
  border: 1px solid rgba(106, 170, 96, 0.42);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 0.9rem 1rem 1rem;
}

.player-notification-close {
  position: absolute;
  top: 0.55rem;
  right: 0.55rem;
  background: none;
  border: none;
  color: var(--text-faint);
  font-size: 0.95rem;
  width: auto;
  padding: 0.15rem 0.35rem;
}

.player-notification-title {
  font-family: 'Cinzel', serif;
  color: var(--accent-pale);
  font-size: 1rem;
  margin-top: 0.5rem;
}

.player-notification-time {
  color: var(--text-faint);
  font-size: 0.74rem;
  margin-top: 0.2rem;
}

.player-notification-body {
  margin-top: 0.7rem;
  color: var(--text);
  line-height: 1.55;
  white-space: pre-wrap;
}

.player-notification-link {
  margin-top: 0.8rem;
  display: inline-flex;
}

@media (max-width: 480px) {
  .chat-panel { width: calc(100vw - 2.4rem); }
  .dm-story-widget { right: 4.7rem; }
  .dm-story-panel { width: calc(100vw - 2.8rem); }
  .dm-story-modal {
    right: 1rem;
    left: 1rem;
    width: auto;
    bottom: 5.4rem;
  }
  .player-notification-toast {
    right: 1rem;
    left: 1rem;
    width: auto;
    bottom: 5.4rem;
  }
}

/* =========================================================
   COMBAT PAGE REBUILD
   ========================================================= */

/* ── Idle layout: char left, enemies right ── */
.combat-idle-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 0.75rem;
  align-items: start;
}

/* ── Active fight layout ── */
.combat-fight-header {
  padding: 0.85rem 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.combat-fight-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 0.75rem;
  align-items: start;
}

.combat-fight-player {
  position: sticky;
  top: 60px;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.combat-fight-center {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.combat-enemy-status { padding: 0.85rem 1rem; }

.combat-enemy-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.combat-enemy-portrait {
  width: 52px; height: 52px;
  border-radius: var(--radius-md);
  background: var(--bg-raised);
  border: 1px solid var(--border-mid);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.6rem; flex-shrink: 0; overflow: hidden;
}
.combat-enemy-portrait img { width:100%;height:100%;object-fit:contain;padding:4px; }

.combat-log-panel { padding: 0.85rem 1rem; }

/* Action groups */
.combat-action-group {
  margin-top: 0.65rem;
  padding-top: 0.65rem;
  border-top: 1px solid var(--border-dim);
}
.combat-action-group:first-of-type { border-top: none; margin-top: 0; padding-top: 0; }

/* ── Vitals rows (HP/MP bars) ── */
.combat-vitals-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.3rem;
}
.combat-vital-label {
  font-family: 'Cinzel', serif;
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  color: var(--text-faint);
  width: 20px;
  flex-shrink: 0;
}
.combat-vital-val {
  font-family: 'Cinzel', serif;
  font-size: 0.78rem;
  white-space: nowrap;
  min-width: 60px;
  text-align: right;
}
.val-danger { color: var(--red); }

/* Mana bar */
.combat-bar.mana {
  background: linear-gradient(90deg, #3a45a0, #6878d8);
}

/* ── Key stats row ── */
.combat-key-stats {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.55rem;
}
.combat-key-stat {
  flex: 1;
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  padding: 0.35rem 0.4rem;
  text-align: center;
}
.combat-key-label {
  display: block;
  font-family: 'Cinzel', serif;
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  color: var(--text-faint);
  text-transform: uppercase;
}
.combat-key-val {
  display: block;
  font-family: 'Cinzel', serif;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--accent-pale);
  margin-top: 0.1rem;
}

/* ── Ability score grid ── */
.combat-ability-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
  margin-top: 0.35rem;
}
.combat-ability-cell {
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-sm);
  padding: 0.3rem 0.35rem;
  text-align: center;
}
.combat-ability-label {
  display: block;
  font-family: 'Cinzel', serif;
  font-size: 0.6rem;
  letter-spacing: 0.06em;
  color: var(--text-faint);
}
.combat-ability-score {
  display: block;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text);
  line-height: 1.2;
}
.combat-ability-mod {
  display: block;
  font-size: 0.7rem;
  font-family: 'Cinzel', serif;
}
.mod-pos { color: var(--green); }
.mod-neg { color: var(--red);   }

/* ── Character card hero ── */
.combat-char-panel { padding: 0.85rem 0.9rem; position: sticky; top: 60px; }
.combat-char-hero {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  margin-bottom: 0.55rem;
  padding-bottom: 0.55rem;
  border-bottom: 1px solid var(--border-dim);
}
.combat-char-icon { font-size: 2rem; line-height: 1; flex-shrink: 0; }

/* ── Enemy list panel ── */
.combat-enemy-list-panel {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

/* ── Enemy card ── */
.combat-enemy-card {
  padding: 0.85rem 1rem;
}
.combat-enemy-card-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.65rem;
}
.combat-enemy-card-portrait {
  width: 48px; height: 48px;
  border-radius: var(--radius-md);
  background: var(--bg-raised);
  border: 1px solid var(--border-dim);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem; flex-shrink: 0; overflow: hidden;
}
.combat-enemy-card-portrait img { width:100%;height:100%;object-fit:contain;padding:4px; }
.combat-enemy-name {
  font-family: 'Cinzel', serif;
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
}

/* ── Difficulty badge ── */
.combat-diff-badge {
  font-family: 'Cinzel', serif;
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  padding: 0.15rem 0.5rem;
  border-radius: var(--radius-pill);
  border: 1px solid;
  font-weight: 600;
}
.diff-easy    { background:rgba(106,170,96,0.18); color:#72b868; border-color:rgba(106,170,96,0.35); }
.diff-fair    { background:rgba(200,146,42,0.18); color:#d4982e; border-color:rgba(200,146,42,0.35); }
.diff-hard    { background:rgba(200,120,40,0.18); color:#d07030; border-color:rgba(200,120,40,0.35); }
.diff-deadly  { background:rgba(192,88,74,0.2);  color:#cc6050; border-color:rgba(192,88,74,0.4); }

/* Diff-colored comparison values */
.diff-easy  { background:rgba(106,170,96,0.18); color:#72b868; border-color:rgba(106,170,96,0.35); }
.diff-fair  { background:rgba(200,146,42,0.18); color:#d4982e; border-color:rgba(200,146,42,0.35); }
.diff-hard  { background:rgba(200,120,40,0.18); color:#d07030; border-color:rgba(200,120,40,0.35); }

/* ── Stat comparison grid ── */
.combat-compare-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
  margin-bottom: 0.55rem;
}
.combat-compare-col {
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-sm);
  padding: 0.3rem 0.45rem;
  text-align: center;
}
.combat-compare-label {
  display: block;
  font-size: 0.62rem;
  font-family: 'Cinzel', serif;
  letter-spacing: 0.05em;
  color: var(--text-faint);
  text-transform: uppercase;
  margin-bottom: 0.15rem;
}
.combat-compare-val {
  display: block;
  font-size: 0.9rem;
  font-weight: 600;
  font-family: 'Cinzel', serif;
  color: var(--text);
}

/* Coloured comparison values (not badges) */
.combat-compare-val.diff-easy   { color: #72b868; background: none; border: none; }
.combat-compare-val.diff-fair   { color: var(--accent); background: none; border: none; }
.combat-compare-val.diff-hard   { color: #d07030; background: none; border: none; }
.combat-compare-val.diff-deadly { color: var(--red); background: none; border: none; }

/* ── Drops ── */
.combat-enemy-drops {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.3rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--border-dim);
}
.combat-drops-label {
  font-size: 0.72rem;
  color: var(--text-faint);
  font-family: 'Cinzel', serif;
  letter-spacing: 0.04em;
  margin-right: 0.2rem;
}
.combat-drop-tag {
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-pill);
  font-size: 0.72rem;
  padding: 0.15rem 0.5rem;
  color: var(--text-dim);
  display: flex;
  gap: 0.3rem;
  align-items: center;
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .combat-idle-layout  { grid-template-columns: 1fr; }
  .combat-fight-layout { grid-template-columns: 1fr; }
  .combat-char-panel   { position: static; }
  .combat-fight-player { position: static; }
}

/* =========================================================
   CHARACTER SHEET REDESIGN
   ========================================================= */

/* ── Portrait banner ── */
.cs-portrait-banner {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding: 1.1rem 1.3rem;
  flex-wrap: wrap;
  position: relative;
  overflow: hidden;
}

.cs-portrait-left { flex-shrink: 0; }

.cs-portrait-frame {
  position: relative;
  width: 72px;
  height: 72px;
}

.cs-portrait-icon {
  position: absolute;
  top: -6px;
  left: -6px;
  font-size: 1.6rem;
  z-index: 2;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.5));
}

.cs-portrait-placeholder {
  width: 72px;
  height: 72px;
  border-radius: var(--radius-lg);
  background: var(--bg-inset);
  border: 2px dashed var(--border-mid);
  display: flex;
  align-items: center;
  justify-content: center;
}

.cs-portrait-identity { flex: 1; min-width: 160px; }

.cs-name {
  font-family: 'Cinzel', serif;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--text);
  margin-bottom: 0.2rem;
}

.cs-archetype-line { display: flex; align-items: center; flex-wrap: wrap; gap: 0.35rem; }

.cs-archetype {
  font-family: 'Cinzel', serif;
  font-size: 0.82rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent);
}

.cs-portrait-vitals {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
  align-items: center;
}

/* ── Sheet two-column layout ── */
.cs-sheet-layout {
  display: grid;
  grid-template-columns: 230px minmax(0, 1fr) 360px;
  gap: 0.75rem;
  align-items: start;
}

.cs-sheet-left {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  position: sticky;
  top: 60px;
}

.cs-sheet-right { display: flex; flex-direction: column; }
.cs-sheet-third { display: flex; flex-direction: column; gap: 0.65rem; }

/* ── Paperdoll layout ── */
.eq-paperdoll {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.eq-row {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
}

.eq-paperdoll-middle {
  display: grid;
  grid-template-columns: 1fr 140px 1fr;
  gap: 0.4rem;
  align-items: start;
}

.eq-middle-col {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

/* Centre portrait in paperdoll */
.eq-paperdoll-portrait {
  display: flex;
  align-items: center;
  justify-content: center;
}

.eq-portrait-frame {
  width: 130px;
  height: 180px;
  background: var(--bg-inset);
  border: 2px dashed var(--border-mid);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  position: relative;
  overflow: hidden;
}

.eq-portrait-arch-icon {
  font-size: 2.5rem;
  line-height: 1;
  opacity: 0.6;
}

.eq-portrait-silhouette {
  width: 50px;
  height: 80px;
  opacity: 0.12;
}

.eq-portrait-silhouette-inner {
  width: 100%;
  height: 100%;
  background: var(--text);
  mask-image: linear-gradient(to bottom, transparent 0%, var(--text) 20%, var(--text) 80%, transparent 100%);
  border-radius: 50% 50% 30% 30% / 40% 40% 20% 20%;
}

.eq-portrait-name {
  font-family: 'Cinzel', serif;
  font-size: 0.68rem;
  letter-spacing: 0.1em;
  color: var(--text-faint);
  text-align: center;
  position: absolute;
  bottom: 8px;
  left: 0; right: 0;
}

/* Equipment slots - compact version for paperdoll */
.eq-slot {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.3rem 0.4rem;
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-sm);
  min-width: 0;
}

.eq-slot--filled {
  border-color: var(--border-mid);
  background: var(--bg-raised);
}

.eq-slot-icon {
  font-size: 0.9rem;
  flex-shrink: 0;
  line-height: 1;
  width: 18px;
  text-align: center;
}

.eq-slot-info {
  flex: 1;
  min-width: 0;
  overflow: hidden;
}

.eq-slot-name {
  display: block;
  font-family: 'Cinzel', serif;
  font-size: 0.6rem;
  letter-spacing: 0.06em;
  color: var(--text-faint);
  text-transform: uppercase;
}

.eq-slot-item {
  display: block;
  font-size: 0.75rem;
  color: var(--text-dim);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.eq-slot--filled .eq-slot-item { color: var(--text); }

.eq-slot-action { flex-shrink: 0; }
.eq-slot-action button { padding: 0.1rem 0.3rem; font-size: 0.7rem; }

@media (max-width: 960px) {
  .cs-sheet-layout { grid-template-columns: 1fr; }
  .cs-sheet-left   { position: static; }
  .eq-paperdoll-middle { grid-template-columns: 1fr 110px 1fr; }
}

@media (max-width: 600px) {
  .cs-portrait-banner { flex-direction: column; align-items: flex-start; }
  .eq-paperdoll-middle { grid-template-columns: 1fr 90px 1fr; }
  .eq-portrait-frame { width: 90px; height: 130px; }
}

/* =========================================================
   CHARACTER PORTRAITS
   ========================================================= */

/* Banner portrait image */
.cs-portrait-img {
  width: 72px;
  height: 72px;
  border-radius: var(--radius-lg);
  object-fit: cover;
  border: 2px solid var(--border-bright);
  box-shadow: var(--shadow-md);
}

/* Paperdoll portrait image */
.eq-portrait-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: calc(var(--radius-lg) - 2px);
}

/* ── Admin portrait page ── */
.portrait-admin-preview {
  width: 120px;
  height: 120px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--border-mid);
  background: var(--bg-inset);
  flex-shrink: 0;
}

.portrait-admin-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.portrait-admin-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
}
.portrait-admin-placeholder span { font-size: 2rem; }
.portrait-admin-placeholder p    { font-size: 0.65rem; color: var(--text-faint); }

/* Character list with portrait thumbnails */
.portrait-char-row { align-items: center; }

.portrait-thumb {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
}
.portrait-thumb img { width:100%; height:100%; object-fit:cover; }

.portrait-char-row--has-portrait .portrait-thumb {
  border-color: var(--border-bright);
}

/* =========================================================
   PORTRAIT LIBRARY — Admin
   ========================================================= */

/* Drop zone */
.portrait-drop-zone {
  position: relative;
  border: 2px dashed var(--border-mid);
  border-radius: var(--radius-lg);
  padding: 1.5rem 1rem;
  text-align: center;
  cursor: pointer;
  transition: border-color 150ms, background 150ms;
  min-height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.portrait-drop-zone:hover,
.portrait-drop-zone--over {
  border-color: var(--border-bright);
  background: rgba(180,130,50,0.06);
}

/* Library grid */
.portrait-lib-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 0.55rem;
  margin-bottom: 0.75rem;
}

.portrait-lib-card {
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--bg-raised);
  transition: border-color 120ms;
}
.portrait-lib-card:hover        { border-color: var(--border-mid); }
.portrait-lib-card--active      { border-color: var(--border-bright); }

.portrait-lib-img-wrap {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
}
.portrait-lib-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.portrait-lib-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  opacity: 0;
  transition: opacity 150ms;
}
.portrait-lib-img-wrap:hover .portrait-lib-overlay { opacity: 1; }

.portrait-lib-meta {
  padding: 0.3rem 0.4rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.25rem;
}
.portrait-lib-label {
  font-size: 0.72rem;
  color: var(--text-dim);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
}

/* Edit preview */
.portrait-lib-preview-wrap {
  width: 100%;
  aspect-ratio: 1 / 1;
  max-width: 200px;
  margin: 0 auto;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--border-mid);
}
.portrait-lib-preview-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Filter tabs */
.portrait-filter-tabs {
  display: flex;
  gap: 3px;
  flex-wrap: wrap;
}
.portrait-filter-btn {
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-sm);
  color: var(--text-dim);
  font-family: 'Cinzel', serif;
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  padding: 0.2rem 0.5rem;
  cursor: pointer;
  width: auto;
  transition: background 100ms, color 100ms;
}
.portrait-filter-btn:hover { background: var(--bg-raised); color: var(--text); }
.portrait-filter-btn.active {
  background: rgba(180,130,50,0.18);
  color: var(--accent-pale);
  border-color: var(--border-mid);
}

/* =========================================================
   PORTRAIT CHOOSER — Character sheet
   ========================================================= */

.portrait-chooser-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.4rem;
  /* Show exactly 3 rows (9 portraits) then scroll.
     Each cell is ~1/3 of container width; container is ~280px in the sidebar.
     Cell ≈ 88px + gap. 3 rows = 3*(88px) + 2*(0.4rem gap ≈ 6px) ≈ 276px. */
  max-height: 280px;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 2px; /* prevent scrollbar overlap */
  scrollbar-width: thin;
  scrollbar-color: var(--border-mid) transparent;
}
.portrait-chooser-grid::-webkit-scrollbar { width: 5px; }
.portrait-chooser-grid::-webkit-scrollbar-track { background: transparent; }
.portrait-chooser-grid::-webkit-scrollbar-thumb { background: var(--border-mid); border-radius: 3px; }

.portrait-chooser-grid--locked {
  opacity: 0.5;
  pointer-events: none;
}

.portrait-chooser-item {
  background: var(--bg-inset);
  border: 2px solid var(--border-dim);
  border-radius: var(--radius-md);
  padding: 0;
  cursor: pointer;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1 / 1;
  position: relative;
  width: 100%;
  transition: border-color 120ms, box-shadow 120ms;
}
.portrait-chooser-item:hover {
  border-color: var(--border-bright);
  box-shadow: var(--shadow-sm);
}
.portrait-chooser-item--active {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(180,130,50,0.3);
}

.portrait-chooser-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.portrait-chooser-label {
  position: absolute;
  bottom: 0;
  left: 0; right: 0;
  background: rgba(0,0,0,0.6);
  font-size: 0.6rem;
  font-family: 'Cinzel', serif;
  letter-spacing: 0.04em;
  color: var(--text-dim);
  text-align: center;
  padding: 0.15rem 0.2rem;
  opacity: 0;
  transition: opacity 150ms;
}
.portrait-chooser-item:hover .portrait-chooser-label { opacity: 1; }
.portrait-chooser-item--active .portrait-chooser-label { opacity: 1; color: var(--accent-pale); }

/* =========================================================
   COMBAT CONFIRMATION MODAL
   ========================================================= */

.combat-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 500;
  background: rgba(0, 0, 0, 0);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  pointer-events: none;
  transition: background 200ms;
}

.combat-modal-backdrop.combat-modal--open {
  background: rgba(0, 0, 0, 0.72);
  pointer-events: all;
}

.combat-modal {
  position: relative;
  background: var(--bg-panel);
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg), 0 0 60px rgba(0,0,0,0.6);
  padding: 1.5rem 1.5rem 1.25rem;
  width: 100%;
  max-width: 960px;
  max-height: 90vh;
  overflow-y: auto;
  transform: scale(0.92) translateY(16px);
  opacity: 0;
  transition: transform 200ms, opacity 200ms;
}

.combat-modal-backdrop.combat-modal--open .combat-modal {
  transform: scale(1) translateY(0);
  opacity: 1;
}

.combat-modal-close {
  position: absolute;
  top: 0.75rem;
  right: 0.85rem;
  background: none;
  border: none;
  color: var(--text-faint);
  font-size: 1rem;
  cursor: pointer;
  width: auto;
  padding: 0.2rem 0.4rem;
  border-radius: var(--radius-sm);
  line-height: 1;
  transition: color 100ms, background 100ms;
}
.combat-modal-close:hover { color: var(--text); background: rgba(255,255,255,0.07); }

.combat-modal-title {
  text-align: center;
  margin-bottom: 1.1rem;
}

/* Three-column arena */
.combat-modal-arena {
  display: grid;
  grid-template-columns: minmax(190px, 1fr) minmax(260px, 1.35fr) minmax(190px, 1fr);
  gap: 1rem;
  align-items: start;
}
.combat-modal-arena > * { min-width: 0; }

/* Player / Enemy sides */
.combat-modal-side {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  text-align: center;
  min-width: 190px;
}

.combat-modal-portrait {
  width: 100px;
  height: 100px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--bg-raised);
  border: 2px solid var(--border-mid);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  flex-shrink: 0;
  box-shadow: var(--shadow-sm);
  transition: border-color 150ms;
}

.combat-modal-side--player .combat-modal-portrait {
  border-color: rgba(106,170,96,0.5);
}
.combat-modal-side--enemy .combat-modal-portrait {
  border-color: rgba(192,88,74,0.5);
}

.combat-modal-portrait img {
  width: 100%; height: 100%; object-fit: cover;
}

.combat-modal-arch-icon { font-size: 2.5rem; }

.combat-modal-char-name {
  font-family: 'Cinzel', serif;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--text);
  margin-top: 0.2rem;
}
.combat-modal-char-sub {
  font-size: 0.72rem;
  color: var(--text-faint);
  letter-spacing: 0.04em;
}

.combat-modal-vitals {
  width: 100%;
  margin-top: 0.3rem;
}

.combat-modal-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  justify-content: center;
  margin-top: 0.2rem;
}
.combat-modal-stats span {
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-pill);
  font-size: 0.7rem;
  padding: 0.15rem 0.45rem;
  color: var(--text-dim);
  font-family: 'Cinzel', serif;
  letter-spacing: 0.03em;
}

.combat-modal-drops {
  width: 100%;
  margin-top: 0.4rem;
}

/* VS centre column */
.combat-modal-vs {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.65rem;
  padding: 0 0.5rem;
  min-width: 0;
  width: 100%;
}

.combat-modal-log-dock {
  margin-top: 0.85rem;
  padding-top: 0.65rem;
  border-top: 1px solid var(--border-dim);
}

.combat-modal-vs-badge {
  font-family: 'Cinzel', serif;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  color: var(--accent);
  text-shadow: 0 0 20px rgba(212,152,46,0.4);
  line-height: 1;
  padding: 0.5rem 0;
}

.combat-modal-vs-info {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.combat-modal-reward {
  font-family: 'Cinzel', serif;
  font-size: 0.78rem;
  color: var(--text-dim);
  letter-spacing: 0.04em;
}

.combat-modal-fight-btn {
  width: 100%;
  font-size: 1rem;
  padding: 0.65rem 1rem;
  letter-spacing: 0.08em;
}

.combat-modal-cancel {
  width: 100%;
  font-size: 0.78rem;
  opacity: 0.7;
}

/* Responsive */
@media (max-width: 560px) {
  .combat-modal-arena {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
  }
  .combat-modal-vs { flex-direction: row; flex-wrap: wrap; justify-content: center; }
  .combat-modal-vs-badge { font-size: 1.1rem; }
  .combat-modal-portrait { width: 80px; height: 80px; }
  .combat-modal-log-dock { margin-top: 0.6rem; padding-top: 0.5rem; }
}

/* =========================================================
   COMBAT MODAL — IN-FIGHT UPDATES
   ========================================================= */

.combat-modal-titlebar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  margin-bottom: 1rem;
}

.combat-modal-turn-badge {
  font-family: 'Cinzel', serif;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  color: var(--text-faint);
}

/* Action buttons inside modal */
.modal-actions {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  width: 100%;
  margin-bottom: 0.75rem;
}

.modal-action-btn {
  width: 100%;
  text-align: left;
  font-size: 0.82rem;
  padding: 0.5rem 0.7rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.modal-spell-cost {
  font-size: 0.7rem;
  color: var(--text-faint);
  margin-left: auto;
  padding-left: 0.5rem;
}

/* Battle log inside modal */
.modal-log-wrap {
  width: 100%;
  min-width: 0;
}

.modal-log {
  max-height: min(34vh, 260px);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0.4rem 0;
  scroll-behavior: smooth;
}

.modal-log .combat-log-line {
  font-size: 0.78rem;
  line-height: 1.45;
  padding: 0.2rem 0;
  border-bottom: 1px solid var(--border-dim);
  overflow-wrap: anywhere;
  word-break: break-word;
}
.modal-log .combat-log-line:last-child { border-bottom: none; }

/* Outcome screen */
.modal-outcome-icon {
  font-size: 3rem;
  text-align: center;
  margin-bottom: 0.5rem;
}

.modal-outcome-title {
  font-family: 'Cinzel', serif;
  font-size: 1.3rem;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.08em;
  color: var(--text);
  margin-bottom: 0.4rem;
}

.modal-outcome-sub {
  font-size: 0.78rem;
  color: var(--text-faint);
  text-align: center;
  line-height: 1.5;
  margin-bottom: 0.85rem;
  max-height: 100px;
  overflow-y: auto;
}

/* =========================================================
   ADMIN TAVERN PAGE
   ========================================================= */

.admin-tavern-layout {
  display: grid;
  grid-template-columns: minmax(360px, 1fr) minmax(360px, 1fr);
  gap: 0.75rem;
  align-items: start;
}

/* Tavern card grid */
.tavern-admin-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.65rem;
}

.tavern-admin-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.5rem;
}

.tavern-admin-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.55rem 0.65rem;
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  flex-wrap: wrap;
}
.tavern-admin-card--active {
  border-color: var(--border-bright);
  background: var(--bg-raised);
}

.tavern-admin-card-body {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex: 1;
  min-width: 0;
}

.tavern-admin-card-icon { font-size: 1.1rem; flex-shrink: 0; }

.tavern-admin-card-info {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.tavern-admin-card-name {
  font-family: 'Cinzel', serif;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tavern-admin-card-meta {
  font-size: 0.72rem;
  color: var(--text-faint);
}

.tavern-admin-card-actions {
  display: flex;
  gap: 0.3rem;
  flex-shrink: 0;
  align-items: center;
}

/* NPC thumbnail in list */
.npc-admin-row { align-items: center; }

.npc-admin-thumb {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}
.npc-admin-thumb img { width:100%;height:100%;object-fit:cover; }

/* Portrait edit row */
.npc-portrait-edit-row {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.npc-portrait-current {
  width: 72px;
  height: 72px;
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--border-mid);
  flex-shrink: 0;
}
.npc-portrait-current img { width:100%;height:100%;object-fit:cover; }

/* NPC portrait library picker */
.npc-portrait-picker {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(72px, 1fr));
  gap: 0.4rem;
  max-height: 240px;
  overflow-y: auto;
  padding: 0.3rem;
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
}

.npc-portrait-option { position: relative; }
.npc-portrait-option input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0; height: 0;
}

.npc-portrait-option-label {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
  cursor: pointer;
  border: 2px solid var(--border-dim);
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--bg-raised);
  transition: border-color 120ms;
  aspect-ratio: 1/1;
  justify-content: center;
}
.npc-portrait-option-label:hover { border-color: var(--border-mid); }
.npc-portrait-option input:checked + .npc-portrait-option-label {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(180,130,50,0.25);
}

.npc-portrait-option-label img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.npc-portrait-option-name {
  font-size: 0.6rem;
  color: var(--text-faint);
  text-align: center;
  padding: 0.1rem 0.2rem;
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: rgba(0,0,0,0.55);
  opacity: 0;
  transition: opacity 150ms;
}
.npc-portrait-option-label:hover .npc-portrait-option-name,
.npc-portrait-option input:checked + .npc-portrait-option-label .npc-portrait-option-name {
  opacity: 1;
}

@media (max-width: 760px) {
  .admin-tavern-layout { grid-template-columns: 1fr; }
}

/* Tavern portrait improvements */
.tavern-npc-portrait--img {
  border-color: var(--border-bright);
  background: var(--bg-deep);
}
.tavern-npc-portrait--img img {
  width: 100%; height: 100%;
  object-fit: contain; padding: 4px;
  border-radius: 0;
}

.tavern-npc-portrait-lg--img {
  border-color: var(--border-bright);
  background: var(--bg-deep);
  box-shadow: var(--shadow-md);
}
.tavern-npc-portrait-lg--img img {
  width: 100%; height: 100%;
  object-fit: contain; padding: 4px;
  border-radius: 0;
}

/* =========================================================
   QUEST CHAINS
   ========================================================= */

.quest-chain-requirement {
  font-size: 0.78rem;
  color: #b090ff;
  font-family: 'Cinzel', serif;
  letter-spacing: 0.04em;
  margin-top: 0.3rem;
  padding: 0.2rem 0.5rem;
  background: rgba(100,60,180,0.12);
  border: 1px solid rgba(120,80,200,0.25);
  border-radius: var(--radius-sm);
  display: inline-block;
}

/* Quest prereq grid in admin */
.quest-prereq-grid {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  max-height: 200px;
  overflow-y: auto;
  padding: 0.4rem;
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
}

.quest-prereq-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.25rem 0.3rem;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: 0.82rem;
  color: var(--text-dim);
  transition: background 100ms;
}
.quest-prereq-item:hover { background: rgba(255,255,255,0.04); }
.quest-prereq-item input[type="checkbox"] { flex-shrink: 0; }
.quest-prereq-title { flex: 1; }
.quest-prereq-meta  { font-size: 0.7rem; color: var(--text-faint); flex-shrink: 0; }

/* =========================================================
   SHOPKEEPER PORTRAIT
   ========================================================= */

/* Three-column layout when keeper is present */
.shop-layout--keeper {
  grid-template-columns: 1fr 160px 1fr;
}

.shop-keeper-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}

.shop-keeper-card {
  position: sticky;
  top: 60px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem 0.75rem;
  background: var(--bg-panel);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-lg);
  text-align: center;
  width: 100%;
}

.shop-keeper-card--empty {
  border-style: dashed;
  opacity: 0.6;
}

.shop-keeper-portrait {
  width: 100px;
  height: 100px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--bg-raised);
  border: 2px solid var(--border-bright);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  flex-shrink: 0;
  box-shadow: var(--shadow-md);
}
.shop-keeper-portrait img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 4px;
}

.shop-keeper-name {
  font-family: var(--font-display);
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text);
  margin-top: 0.15rem;
}

.shop-keeper-title {
  font-size: 0.72rem;
  color: var(--text-faint);
  letter-spacing: 0.04em;
}

.shop-keeper-speech {
  background: var(--bg-inset);
  border-left: 2px solid var(--border-bright);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  padding: 0.5rem 0.6rem;
  font-style: italic;
  font-size: 0.78rem;
  color: var(--text-dim);
  line-height: 1.5;
  text-align: left;
  width: 100%;
  margin-top: 0.25rem;
}

.shop-keeper-gold {
  margin-top: 0.5rem;
  padding: 0.4rem 0.65rem;
  background: var(--bg-raised);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.1rem;
  width: 100%;
}

@media (max-width: 900px) {
  .shop-layout--keeper {
    grid-template-columns: 1fr;
  }
  .shop-keeper-col { order: -1; }
  .shop-keeper-card { position: static; flex-direction: row; text-align: left; }
  .shop-keeper-portrait { width: 64px; height: 64px; flex-shrink: 0; }
  .shop-keeper-speech { display: none; }
  .shop-keeper-gold { flex-direction: row; justify-content: space-between; }
}

/* =========================================================
   ITEM ICON DRAG-AND-DROP UPLOAD
   ========================================================= */

.item-drop-zone {
  position: relative;
  border: 2px dashed var(--border-mid);
  border-radius: var(--radius-lg);
  padding: 1.1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  min-height: 110px;
  cursor: pointer;
  text-align: center;
  transition: border-color 150ms, background 150ms;
  overflow: hidden;
  background: var(--bg-inset);
}

.item-drop-zone:hover,
.item-drop-zone--over {
  border-color: var(--border-bright);
  background: rgba(255,255,255,0.03);
}

.item-drop-zone--has-file {
  border-style: solid;
  border-color: var(--border-bright);
}

.item-drop-idle {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.35rem;
  pointer-events: none;
}

.item-drop-current {
  width: 64px;
  height: 64px;
  object-fit: contain;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-dim);
  background: var(--bg-raised);
  padding: 4px;
}

.item-drop-placeholder {
  width: 64px;
  height: 64px;
  border-radius: var(--radius-md);
  border: 1px dashed var(--border-dim);
  background: var(--bg-raised);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color 150ms;
}
.item-drop-zone--over .item-drop-placeholder {
  border-color: var(--border-bright);
}

.item-drop-hint {
  font-family: var(--font-display);
  font-size: 0.78rem;
  color: var(--text-dim);
  letter-spacing: 0.04em;
}

.item-drop-sub {
  font-size: 0.68rem;
  color: var(--text-faint);
}

/* Shop cell item image */
.shop-cell-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

/* Item icon images (replace emoji fallbacks throughout the UI) */
.item-icon-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

/* Admin item list image — constrained to the icon cell */
.admin-item-icon .item-icon-img {
  width:  28px;
  height: 28px;
  object-fit: contain;
}

/* =========================================================
   D&D CHARACTER CREATION BUILDER
   ========================================================= */

.cc-wrap { margin-bottom: 0; }

.cc-layout {
  display: grid;
  grid-template-columns: 1fr 1.6fr 1fr;
  gap: 0.75rem;
  align-items: start;
}

/* Step panels */
.cc-step { padding: 1rem 1.1rem; }

.cc-step-label {
  font-family: var(--font-display);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-faint);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.cc-step-num {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--accent);
  color: var(--bg-deep);
  font-size: 0.72rem;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}

/* Class desc */
.cc-class-desc {
  margin-top: 0.65rem;
  font-size: 0.82rem;
  color: var(--text-dim);
  line-height: 1.55;
  padding: 0.5rem 0.75rem;
  background: var(--bg-inset);
  border-left: 2px solid var(--border-bright);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.cc-primary-hint {
  font-size: 0.72rem;
  color: var(--accent);
  font-family: var(--font-display);
  letter-spacing: 0.06em;
  margin-top: 0.4rem;
}

/* Method tabs */
.cc-method-tabs {
  display: flex;
  gap: 0.25rem;
  margin-bottom: 0.75rem;
  flex-wrap: wrap;
}

.cc-method-tab {
  flex: 1;
  padding: 0.4rem 0.5rem;
  font-family: var(--font-display);
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-sm);
  color: var(--text-dim);
  cursor: pointer;
  transition: background 120ms, color 120ms, border-color 120ms;
  white-space: nowrap;
}
.cc-method-tab:hover { border-color: var(--border-mid); color: var(--text); }
.cc-method-tab.active {
  background: rgba(180,140,60,0.14);
  border-color: var(--border-bright);
  color: var(--accent-pale);
}

/* Pool chips */
.cc-rolled-pool {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  min-height: 44px;
}

.cc-pool-chip {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  padding: 0.3rem 0.55rem;
  background: var(--bg-raised);
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-md);
  cursor: grab;
  user-select: none;
  transition: background 100ms, box-shadow 100ms;
  min-width: 44px;
  text-align: center;
}
.cc-pool-chip:hover { background: var(--bg-panel); box-shadow: var(--shadow-sm); }
.cc-pool-chip:active { cursor: grabbing; }

.cc-pool-val  { font-family: var(--font-display); font-size: 1.2rem; color: var(--text); line-height: 1; }
.cc-pool-mmod { font-size: 0.68rem; color: var(--text-faint); }

/* Point buy */
.cc-pb-budget {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.cc-pb-count {
  font-family: var(--font-display);
  font-size: 1.6rem;
  color: var(--accent-bright);
  min-width: 36px;
  text-align: center;
}
.cc-pb-label { font-size: 0.78rem; color: var(--text-dim); }

/* Stat assignment grid */
.cc-stat-grid { display: flex; flex-direction: column; gap: 0.3rem; }

.cc-stat-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.35rem 0.5rem;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  transition: background 100ms, border-color 100ms;
}
.cc-stat-row--primary   { background: rgba(180,140,60,0.08);  border-color: rgba(180,140,60,0.18); }
.cc-stat-row--secondary { background: rgba(255,255,255,0.03); border-color: rgba(255,255,255,0.06); }

.cc-stat-label-col {
  display: flex;
  flex-direction: column;
  min-width: 90px;
}
.cc-stat-abbr { font-family: var(--font-display); font-size: 0.82rem; color: var(--text); }
.cc-stat-full { font-size: 0.7rem;  color: var(--text-dim); }
.cc-stat-desc { font-size: 0.65rem; color: var(--text-faint); }

/* Point buy stepper */
.cc-pb-stepper {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  margin-left: auto;
}
.cc-pb-btn {
  width: 24px; height: 24px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-mid);
  background: var(--bg-raised);
  color: var(--text);
  font-size: 1rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background 100ms;
}
.cc-pb-btn:hover { background: var(--bg-panel); border-color: var(--border-bright); }
.cc-pb-val  { font-family: var(--font-display); font-size: 1rem; min-width: 24px; text-align: center; color: var(--text); }
.cc-pb-cost { font-size: 0.68rem; color: var(--text-faint); min-width: 32px; }

/* Drop zones */
.cc-drop-zone {
  margin-left: auto;
  min-width: 64px;
  height: 44px;
  border: 2px dashed var(--border-dim);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  cursor: pointer;
  transition: border-color 120ms, background 120ms;
  flex-direction: column;
  padding: 0.2rem 0.5rem;
}
.cc-drop-zone--over    { border-color: var(--accent-bright); background: rgba(180,140,60,0.08); }
.cc-drop-zone--filled  { border-style: solid; border-color: var(--border-bright); }
.cc-drop-zone--primary { border-color: var(--accent); background: rgba(180,140,60,0.12); }

.cc-drop-score { font-family: var(--font-display); font-size: 1.05rem; color: var(--text); line-height: 1; }
.cc-drop-mod   { font-size: 0.68rem; color: var(--text-faint); }

/* Primary star */
.cc-primary-star {
  font-size: 0.85rem;
  display: none;
  flex-shrink: 0;
}

/* Preview panel */
.cc-preview-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.4rem;
}
.cc-preview-stat {
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-md);
  padding: 0.5rem 0.65rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.1rem;
}
.cc-preview-label { font-size: 0.65rem; color: var(--text-faint); text-transform: uppercase; letter-spacing: 0.1em; }
.cc-preview-val   { font-family: var(--font-display); font-size: 1.3rem; color: var(--text); }

/* Score summary chips */
.cc-score-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 0.75rem;
}
.cc-sum-chip {
  font-family: var(--font-display);
  font-size: 0.72rem;
  padding: 0.2rem 0.5rem;
  background: var(--bg-inset);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-pill);
  color: var(--text-dim);
}
.cc-sum-chip small { font-size: 0.65rem; margin-left: 0.2rem; color: var(--text-faint); }

@media (max-width: 860px) {
  .cc-layout { grid-template-columns: 1fr; }
}
