/* ═══════════════════════════════════════════════════════════════════════════
   EXODUS — MUD Client Styles
   ═══════════════════════════════════════════════════════════════════════════ */

* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
button { font-family: 'IBM Plex Sans', sans-serif; }

/* Scrollbar styling */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-corner { background: transparent; }

/* ═══════════════════════════════════════════════════════════════════════════
   THEME VARIABLES
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
  /* Default: Gruvbox */
  --bg: #282828;
  --panel: #32302f;
  --panel-2: #1d2021;
  --border: #504945;
  --title: #ebdbb2;
  --text: #d5c4a1;
  --muted: #928374;
  --log-bg: #232323;
  --log-text: #ebdbb2;
  --accent: #d79921;
  --exit: #8ec07c;
  --npc: #fe8019;
  --item: #fabd2f;
  --dmg: #fb4934;
  --good: #b8bb26;
  --mana: #83a598;
  --stam: #d79921;
  --gossip: #d3869b;
  --trade: #fabd2f;
  --newbie: #8ec07c;
  --say: #ebdbb2;
}

[data-theme="gruvbox"] {
  --bg: #282828; --panel: #32302f; --panel-2: #1d2021; --border: #504945;
  --title: #ebdbb2; --text: #d5c4a1; --muted: #928374;
  --log-bg: #232323; --log-text: #ebdbb2; --accent: #d79921;
  --exit: #8ec07c; --npc: #fe8019; --item: #fabd2f; --dmg: #fb4934;
  --good: #b8bb26; --mana: #83a598; --stam: #d79921;
  --gossip: #d3869b; --trade: #fabd2f; --newbie: #8ec07c; --say: #ebdbb2;
}

[data-theme="duskwood"] {
  --bg: #1a1d13; --panel: #252919; --panel-2: #181b10; --border: #3d4431;
  --title: #e0dab8; --text: #c2c7a4; --muted: #868a69;
  --log-bg: #171a10; --log-text: #ced2ad; --accent: #cba962;
  --exit: #79b896; --npc: #d27f33; --item: #d4b056; --dmg: #bd5040;
  --good: #83b860; --mana: #66adb8; --stam: #bf9244;
  --gossip: #a594b8; --trade: #d4b056; --newbie: #79b896; --say: #ced2ad;
}

[data-theme="ember"] {
  --bg: #14110e; --panel: #1f1a15; --panel-2: #110e0b; --border: #3a3027;
  --title: #ecd9c0; --text: #cbb9a3; --muted: #8a7860;
  --log-bg: #120f0c; --log-text: #d8c6ad; --accent: #d98a4e;
  --exit: #6fb59a; --npc: #d4762e; --item: #d9b259; --dmg: #c64f3c;
  --good: #8fb05a; --mana: #5fa8bd; --stam: #c79046;
  --gossip: #b094bc; --trade: #d9b259; --newbie: #6fb59a; --say: #d8c6ad;
}

[data-theme="evernight"] {
  --bg: #0e130f; --panel: #161d17; --panel-2: #0a0e0b; --border: #2c382e;
  --title: #d6e0cd; --text: #b3c0aa; --muted: #6f7d68;
  --log-bg: #0c100d; --log-text: #c0ccb6; --accent: #7fb86a;
  --exit: #6cbf9a; --npc: #cf843a; --item: #c9ad57; --dmg: #c0564a;
  --good: #84bf66; --mana: #65aab5; --stam: #bd9249;
  --gossip: #a08bb5; --trade: #c9ad57; --newbie: #6cbf9a; --say: #c0ccb6;
}

[data-theme="phosphor"] {
  --bg: #120d00; --panel: #1c1500; --panel-2: #0d0900; --border: #3a2c08;
  --title: #ffcf70; --text: #e0a838; --muted: #8a6a20;
  --log-bg: #0f0b00; --log-text: #f0bc52; --accent: #ffb52e;
  --exit: #d9a73a; --npc: #ffaa3a; --item: #ffc94a; --dmg: #d2502e;
  --good: #b8c24a; --mana: #c8923a; --stam: #e8b048;
  --gossip: #d4a85a; --trade: #ffc94a; --newbie: #d9a73a; --say: #f0bc52;
}

[data-theme="solarized"] {
  --bg: #002b36; --panel: #073642; --panel-2: #00242e; --border: #0f4a59;
  --title: #93a1a1; --text: #839496; --muted: #586e75;
  --log-bg: #002028; --log-text: #93a1a1; --accent: #b58900;
  --exit: #2aa198; --npc: #cb4b16; --item: #b58900; --dmg: #dc322f;
  --good: #859900; --mana: #268bd2; --stam: #c0850a;
  --gossip: #6c71c4; --trade: #b58900; --newbie: #2aa198; --say: #93a1a1;
}

[data-theme="athelas"] {
  --bg: #c9c198; --panel: #d7cfa8; --panel-2: #cbc299; --border: #a89d70;
  --title: #2d3115; --text: #3d421c; --muted: #766d40;
  --log-bg: #e3dcb6; --log-text: #2a2a13; --accent: #4e6418;
  --exit: #1c6553; --npc: #985215; --item: #856806; --dmg: #9b2c1a;
  --good: #2e6c20; --mana: #1c566b; --stam: #6a5810;
  --gossip: #634275; --trade: #856806; --newbie: #1c6553; --say: #2a2a13;
}

[data-theme="linen"] {
  --bg: #ece7da; --panel: #f3efe4; --panel-2: #e8e2d3; --border: #cfc6b2;
  --title: #2d2a18; --text: #413d2a; --muted: #786f56;
  --log-bg: #f6f2e8; --log-text: #29251a; --accent: #9a6a18;
  --exit: #1c6553; --npc: #8f4f15; --item: #856806; --dmg: #9b2c1a;
  --good: #2e6c20; --mana: #1c566b; --stam: #6a5810;
  --gossip: #634275; --trade: #856806; --newbie: #1c6553; --say: #29251a;
}

/* ═══════════════════════════════════════════════════════════════════════════
   ANIMATIONS
   ═══════════════════════════════════════════════════════════════════════════ */

@keyframes pulse {
  0%, 100% { opacity: 0.5; }
  50% { opacity: 1; }
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

@keyframes modalFade {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes modalPop {
  from { opacity: 0; transform: translateY(10px) scale(0.985); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/* ═══════════════════════════════════════════════════════════════════════════
   LAYOUT
   ═══════════════════════════════════════════════════════════════════════════ */

#app {
  height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--bg);
  color: var(--text);
  font-family: 'IBM Plex Sans', sans-serif;
  overflow: hidden;
}

.spacer { flex: 1; }

/* Header */
.header {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 0 16px;
  height: 52px;
  flex: none;
  border-bottom: 1px solid var(--border);
  background: var(--panel);
}

.header-brand {
  display: flex;
  align-items: baseline;
  gap: 11px;
}

.wordmark {
  font-family: 'JetBrains Mono', monospace;
  font-weight: 700;
  font-size: 21px;
  letter-spacing: 4px;
  color: var(--accent);
}

.tagline {
  font-size: 10.5px;
  color: var(--muted);
  letter-spacing: 2px;
}

.connection-status {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 12px;
  color: var(--muted);
}

.connection-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--muted);
}

.connection-dot.connected {
  background: var(--good);
  box-shadow: 0 0 6px var(--good);
  animation: pulse 2.4s infinite;
}

.clock {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: var(--text);
  min-width: 46px;
  text-align: right;
}

.settings-btn {
  margin-left: 6px;
  flex: none;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 7px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--muted);
  cursor: pointer;
}

.settings-btn:hover {
  background: var(--panel-2);
  color: var(--text);
}

/* Body layout */
.body {
  flex: 1;
  display: flex;
  gap: 8px;
  padding: 8px;
  min-height: 0;
}

.col-left {
  width: 252px;
  flex: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 0;
}

.col-center {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
}

.col-right {
  width: 316px;
  flex: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 0;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PANELS
   ═══════════════════════════════════════════════════════════════════════════ */

.panel {
  display: flex;
  flex-direction: column;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 7px;
  overflow: hidden;
}

.panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1.5px;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
}

.panel-header-right {
  font-weight: 500;
  letter-spacing: 0.5px;
  text-transform: none;
  color: var(--text);
}

/* Vitals Panel */
.vitals-panel { flex: none; }

.vitals-body { padding: 13px 13px 6px; }

.vital-row { margin-bottom: 11px; }

.vital-label {
  display: flex;
  justify-content: space-between;
  font-size: 10.5px;
  margin-bottom: 4px;
}

.vital-label-text {
  color: var(--muted);
  letter-spacing: 1px;
}

.vital-label-value {
  font-family: 'JetBrains Mono', monospace;
  color: var(--text);
}

.vital-bar {
  height: 11px;
  border-radius: 6px;
  background: var(--panel-2);
  overflow: hidden;
  border: 1px solid var(--border);
  position: relative;
}

.vital-fill {
  height: 100%;
  border-radius: 6px 0 0 6px;
  transition: width 0.45s ease;
}

.vital-fill.health { background: var(--good); }
.vital-fill.health.low { background: var(--dmg); }
.vital-fill.mana { background: var(--mana); }
.vital-fill.stamina { background: var(--stam); }

.vital-regen {
  position: absolute;
  top: 0;
  bottom: 0;
  border-radius: 0 6px 6px 0;
  opacity: 0.32;
  pointer-events: none;
  transition: opacity 0.3s ease, left 0.45s ease, width 0.45s ease;
}

.vital-regen.flash { opacity: 0.65; }

/* Gear Panel */
.gear-panel {
  flex: 1;
  min-height: 0;
}

.gear-body {
  flex: 1;
  overflow-y: auto;
  padding: 9px;
}

.gear-box {
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--panel-2);
  margin-bottom: 8px;
  overflow: hidden;
}

.gear-box-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 11px;
  cursor: pointer;
  user-select: none;
  transition: background 0.15s ease;
}

.gear-box-header:hover { background: var(--panel); }

.gear-box-header-left {
  display: flex;
  align-items: center;
  gap: 7px;
  min-width: 0;
}

.gear-box-chevron {
  display: inline-block;
  font-size: 13px;
  line-height: 1;
  color: var(--muted);
  transition: transform 0.25s ease;
}

.gear-box.open .gear-box-chevron { transform: rotate(90deg); }

.gear-box-label {
  font-size: 10px;
  letter-spacing: 1.5px;
  font-weight: 600;
}

.gear-box-count {
  font-size: 9.5px;
  color: var(--muted);
  font-family: 'JetBrains Mono', monospace;
  white-space: nowrap;
}

.gear-box-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.gear-box.open .gear-box-body { max-height: 480px; }

.gear-box-inner { padding: 10px 11px 9px; }

/* Equipment rows */
.equip-row {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  font-size: 12px;
  margin-bottom: 5px;
  font-family: 'JetBrains Mono', monospace;
}

.equip-slot { color: var(--muted); }
.equip-item { color: var(--item); text-align: right; }
.equip-item.empty { color: var(--muted); font-style: italic; }

/* List items (inventory, herbs, potions) */
.list-item {
  font-size: 12px;
  margin-bottom: 4px;
  font-family: 'JetBrains Mono', monospace;
}

/* Log Panel */
.log-panel {
  flex: 1;
  min-height: 0;
  position: relative;
}

.log-scroll {
  flex: 1;
  overflow-y: auto;
  padding: 12px 15px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  line-height: 1.6;
  background: var(--log-bg);
  color: var(--log-text);
}

.log-line {
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  word-break: break-word;
  margin-bottom: 1px;
}

/* Log spacer for combat HUD */
.log-spacer {
  float: right;
  width: 230px;
  height: 236px;
  margin: 0 0 6px 12px;
  pointer-events: none;
}

/* Command Bar */
.command-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: none;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: 0 13px;
  height: 46px;
}

.prompt {
  font-family: 'JetBrains Mono', monospace;
  color: var(--accent);
  font-weight: 700;
  font-size: 15px;
}

#command-input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  color: var(--text);
  font-family: 'JetBrains Mono', monospace;
  font-size: 14px;
  height: 100%;
}

/* Combat HUD */
.combat-hud {
  position: absolute;
  top: 9px;
  right: 9px;
  width: 216px;
  z-index: 5;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 26px rgba(0,0,0,0.42);
  overflow: hidden;
}

.combat-hud-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 11px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1.5px;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
  background: var(--panel-2);
}

.combat-hud-header-right {
  font-weight: 400;
  letter-spacing: 0.5px;
  text-transform: none;
  font-size: 9px;
  font-family: 'JetBrains Mono', monospace;
  color: var(--muted);
}

.combat-hud-body { padding: 9px 11px 10px; }

.party-row { margin-bottom: 8px; }

.party-row-top {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 4px;
}

.party-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex: none;
}

.party-dot.you {
  background: var(--accent);
  box-shadow: 0 0 6px var(--accent);
}

.party-dot.follower { background: var(--good); }

.party-name {
  font-size: 12px;
  min-width: 0;
  flex: 1 1 auto;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.party-name.you {
  font-weight: 600;
  color: var(--title);
}

.party-name.follower {
  font-weight: 500;
  color: var(--text);
}

.party-role {
  font-size: 9px;
  color: var(--muted);
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: 0.5px;
  white-space: nowrap;
  flex: none;
}

.party-bar {
  height: 5px;
  border-radius: 3px;
  background: var(--panel-2);
  overflow: hidden;
  border: 1px solid var(--border);
}

.party-bar-fill {
  height: 100%;
  background: var(--good);
  transition: width 0.3s ease;
}

.party-bar-fill.low { background: var(--dmg); }

.foes-divider {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 10px 0 8px;
}

.foes-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1.5px;
  color: var(--muted);
}

.foes-label.active { color: var(--dmg); }

.foes-line {
  flex: 1;
  height: 1px;
  background: var(--border);
}

.engaged-tag {
  font-size: 8.5px;
  letter-spacing: 1px;
  color: var(--dmg);
  font-family: 'JetBrains Mono', monospace;
  animation: pulse 1s infinite;
}

.foes-region {
  height: 90px;
  overflow-y: auto;
}

.foe-row { margin-bottom: 8px; }
.foe-row.engaged { opacity: 1; }
.foe-row:not(.engaged) { opacity: 0.82; }

.foe-row-top {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 4px;
}

.foe-mark {
  flex: none;
  width: 10px;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 700;
}

.foe-mark.engaged {
  font-size: 10px;
  color: var(--dmg);
}

.foe-mark:not(.engaged) {
  font-size: 8px;
  color: var(--npc);
}

.foe-name {
  font-size: 12px;
  min-width: 0;
  flex: 1 1 auto;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.foe-name.engaged {
  font-weight: 600;
  color: var(--npc);
}

.foe-name:not(.engaged) {
  font-weight: 500;
  color: var(--text);
}

.foe-bar {
  height: 5px;
  border-radius: 3px;
  background: var(--panel-2);
  overflow: hidden;
  border: 1px solid var(--border);
}

.foe-bar-fill {
  height: 100%;
  background: var(--dmg);
  transition: width 0.3s ease;
}

.no-foes {
  padding: 10px 0 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  color: var(--muted);
  font-style: italic;
  letter-spacing: 0.3px;
}

/* Map Panel */
.map-panel {
  flex: none;
  height: 288px;
}

.map-body {
  flex: 1;
  overflow: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--log-bg);
  padding: 12px;
}

#map-display {
  margin: 0;
  font-family: 'JetBrains Mono', monospace;
  font-size: 14px;
  line-height: 1.3;
  letter-spacing: 6px;
}

.map-cell { display: inline; }
.map-cell.you {
  color: var(--accent);
  font-weight: 700;
  text-shadow: 0 0 10px var(--accent);
}
.map-cell.room { color: var(--muted); }
.map-cell.hostile { color: var(--dmg); font-weight: 700; }
.map-cell.link { color: var(--border); }

/* Comms Panel */
.comms-panel {
  flex: 1;
  min-height: 0;
}

.comms-header-left {
  display: flex;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
}

.comms-subtitle {
  font-weight: 400;
  letter-spacing: 0.3px;
  font-size: 9.5px;
  color: var(--muted);
  white-space: nowrap;
}

.newbie-toggle {
  font-size: 9.5px;
  letter-spacing: 0.3px;
  cursor: pointer;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 4px;
  user-select: none;
  white-space: nowrap;
  flex: none;
  color: var(--newbie);
  border: 1px solid var(--newbie);
}

.newbie-toggle.off {
  color: var(--muted);
  border-color: var(--border);
  text-decoration: line-through;
  opacity: 0.7;
  font-weight: 400;
}

.comms-body {
  flex: 1;
  overflow-y: auto;
  padding: 9px 11px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  line-height: 1.55;
}

.chat-line {
  margin-bottom: 4px;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.chat-channel { font-weight: 700; }
.chat-channel.newbie { color: var(--newbie); }
.chat-who { font-weight: 600; color: var(--text); }
.chat-verb { color: var(--muted); }
.chat-text.say { color: var(--say); }
.chat-text.newbie { color: var(--muted); }

/* ═══════════════════════════════════════════════════════════════════════════
   MODALS
   ═══════════════════════════════════════════════════════════════════════════ */

.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 60;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.55);
  animation: modalFade 0.16s ease;
}

.modal-overlay[hidden] { display: none; }

.modal-close {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--muted);
  font-size: 14px;
  cursor: pointer;
  line-height: 1;
}

.modal-close:hover {
  background: var(--panel-2);
  color: var(--text);
}

/* Settings Modal */
.settings-dialog {
  width: 600px;
  max-width: 92%;
  height: 460px;
  max-height: 82%;
  display: flex;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 24px 64px rgba(0,0,0,0.55);
  animation: modalPop 0.19s ease;
}

.settings-nav {
  width: 172px;
  flex: none;
  border-right: 1px solid var(--border);
  background: var(--panel-2);
  display: flex;
  flex-direction: column;
  padding: 14px 10px;
}

.settings-nav-title {
  font-size: 10px;
  letter-spacing: 2px;
  color: var(--muted);
  font-weight: 600;
  padding: 0 8px 10px;
}

.settings-nav-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 11px;
  border-radius: 7px;
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 4px;
  cursor: pointer;
  color: var(--muted);
  background: transparent;
  border: 1px solid transparent;
}

.settings-nav-item:hover { color: var(--text); }

.settings-nav-item.active {
  font-weight: 700;
  color: var(--title);
  background: var(--panel);
  border-color: var(--border);
}

.settings-content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.settings-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 16px;
  border-bottom: 1px solid var(--border);
}

.settings-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--title);
  font-family: 'IBM Plex Sans', sans-serif;
}

.settings-body {
  flex: 1;
  overflow-y: auto;
  padding: 14px 16px;
  font-family: 'IBM Plex Sans', sans-serif;
}

/* Theme options */
.theme-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 8px;
  cursor: pointer;
  border: 1px solid var(--border);
  background: transparent;
  margin-bottom: 7px;
}

.theme-row:hover { border-color: var(--accent); }
.theme-row.active {
  border-color: var(--accent);
  background: var(--panel-2);
}

.theme-swatch {
  display: flex;
  flex: none;
  border-radius: 5px;
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(0,0,0,0.25);
}

.theme-swatch-chip {
  width: 15px;
  height: 26px;
}

.theme-info { flex: 1; min-width: 0; }

.theme-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}

.theme-row.active .theme-name {
  font-weight: 700;
  color: var(--title);
}

.theme-desc {
  font-size: 11px;
  color: var(--muted);
  margin-top: 1px;
}

.theme-check {
  flex: none;
  color: var(--accent);
  font-size: 15px;
  font-weight: 700;
}

/* Combat settings */
.combat-setting-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 13px 14px;
  border: 1px solid var(--border);
  border-radius: 9px;
  cursor: pointer;
}

.combat-setting-row:hover { border-color: var(--accent); }

.combat-setting-info { flex: 1; min-width: 0; }

.combat-setting-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--title);
}

.combat-setting-desc {
  font-size: 11.5px;
  color: var(--muted);
  margin-top: 3px;
  line-height: 1.4;
}

.toggle-track {
  position: relative;
  width: 40px;
  height: 23px;
  border-radius: 12px;
  flex: none;
  cursor: pointer;
  background: var(--panel-2);
  border: 1px solid var(--border);
  transition: background 0.15s ease;
}

.toggle-track.on {
  background: var(--accent);
  border-color: var(--accent);
}

.toggle-knob {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 17px;
  height: 17px;
  border-radius: 50%;
  background: var(--muted);
  transition: left 0.15s ease;
}

.toggle-track.on .toggle-knob {
  left: 19px;
  background: var(--bg);
}

/* Records Modal */
.records-dialog {
  width: 560px;
  max-width: 92%;
  max-height: 82%;
  display: flex;
  flex-direction: column;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 24px 64px rgba(0,0,0,0.55);
  animation: modalPop 0.19s ease;
}

.records-tabs {
  display: flex;
  align-items: stretch;
  border-bottom: 1px solid var(--border);
}

.records-tab {
  padding: 13px 20px;
  font-size: 11.5px;
  letter-spacing: 1.5px;
  font-weight: 500;
  text-transform: uppercase;
  cursor: pointer;
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--muted);
}

.records-tab.active {
  font-weight: 700;
  color: var(--title);
  border-bottom-color: var(--accent);
}

.records-tabs .modal-close {
  align-self: center;
  margin-right: 10px;
}

.records-body {
  overflow-y: auto;
  padding: 14px 15px;
  font-family: 'IBM Plex Sans', sans-serif;
}

/* Achievement rows */
.ach-row {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 9px 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  margin-bottom: 5px;
  background: var(--panel-2);
}

.ach-row.pending { opacity: 0.6; }

.ach-fill {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  background: var(--accent);
  opacity: 0.13;
  pointer-events: none;
}

.ach-icon {
  position: relative;
  z-index: 1;
  width: 20px;
  flex: none;
  display: grid;
  place-items: center;
  align-self: center;
}

.ach-icon-done {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--good);
  color: var(--bg);
  display: grid;
  place-items: center;
  font-size: 11px;
  font-weight: 700;
  font-family: 'JetBrains Mono', monospace;
}

.ach-icon-progress {
  width: 15px;
  height: 15px;
  border-radius: 50%;
  border: 2px solid var(--border);
  border-top-color: var(--accent);
  animation: spin 0.9s linear infinite;
}

.ach-icon-pending {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  border: 1.5px solid var(--muted);
  opacity: 0.6;
}

.ach-info {
  flex: 1;
  min-width: 0;
  position: relative;
  z-index: 1;
}

.ach-title {
  font-size: 12.5px;
  font-weight: 500;
  color: var(--title);
}

.ach-row.done .ach-title { font-weight: 600; }
.ach-row.pending .ach-title { color: var(--muted); }

.ach-desc {
  font-size: 11px;
  color: var(--muted);
  line-height: 1.35;
  margin-top: 2px;
}

/* Quest rows */
.quest-row {
  border: 1px solid var(--border);
  border-left-width: 3px;
  border-radius: 6px;
  margin-bottom: 7px;
  background: var(--panel-2);
  overflow: hidden;
}

.quest-row.complete {
  border-left-color: var(--good);
  opacity: 0.72;
}

.quest-row.active { border-left-color: var(--accent); }
.quest-row.available { border-left-color: var(--muted); }

.quest-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 11px 13px;
  cursor: pointer;
  user-select: none;
}

.quest-row.available .quest-header { cursor: default; }

.quest-chevron {
  display: inline-block;
  width: 9px;
  font-size: 9px;
  color: var(--muted);
  transition: transform 0.25s ease;
}

.quest-row.available .quest-chevron { opacity: 0; }
.quest-row.open .quest-chevron { transform: rotate(90deg); }

.quest-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--title);
}

.quest-status {
  font-size: 10px;
  letter-spacing: 1px;
  text-transform: uppercase;
  white-space: nowrap;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 600;
}

.quest-row.complete .quest-status { color: var(--good); }
.quest-row.active .quest-status { color: var(--accent); }
.quest-row.available .quest-status { color: var(--muted); }

.quest-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.quest-row.open .quest-body { max-height: 320px; }

.quest-entries { padding: 2px 14px 12px 33px; }

.quest-entry {
  display: flex;
  gap: 8px;
  font-size: 11.5px;
  line-height: 1.45;
  margin-bottom: 5px;
  font-family: 'IBM Plex Sans', sans-serif;
}

.quest-entry.done { color: var(--text); }
.quest-entry.pending { color: var(--muted); }

.quest-entry-mark {
  flex: none;
  width: 12px;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 700;
}

.quest-entry.done .quest-entry-mark { color: var(--good); }
.quest-entry.pending .quest-entry-mark { color: var(--accent); }
