:root {
  --bg: #1a1a2e;
  --bg-panel: #16213e;
  --text: #eaeaea;
  --accent: #0f3460;
  --highlight: #e94560;
  --success: #4ecca3;
  --muted: #8892a0;
}

[data-theme="light"] {
  --bg: #f5f5f5;
  --bg-panel: #ffffff;
  --text: #1a1a2e;
  --accent: #e0e0e0;
  --highlight: #c62828;
  --success: #2e7d32;
  --muted: #616161;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: 'JetBrains Mono', 'Fira Code', 'Consolas', monospace;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
}

.site-header {
  background: var(--bg-panel);
  border-bottom: 1px solid var(--accent);
  padding: 0.5rem 1rem;
}

.header-inner {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.logo {
  font-weight: bold;
  font-size: 1.25rem;
  color: var(--highlight);
  text-decoration: none;
}

.main-nav {
  display: flex;
  gap: 1rem;
  align-items: center;
}

.main-nav a {
  color: var(--text);
  text-decoration: none;
}

.main-nav a.active, .main-nav a:hover {
  color: var(--highlight);
}

.inline { display: inline; margin: 0; }

.link-btn {
  background: none;
  border: none;
  color: var(--text);
  cursor: pointer;
  font: inherit;
  padding: 0;
}

.link-btn:hover { color: var(--highlight); }

.theme-toggle {
  background: none;
  border: none;
  font-size: 1.25rem;
  cursor: pointer;
  padding: 0.25rem;
  line-height: 1;
  opacity: 0.9;
}
.theme-toggle:hover { opacity: 1; }

.page-main {
  max-width: 1400px;
  margin: 0 auto;
  padding: 1rem;
  min-height: calc(100vh - 120px);
}

.site-footer {
  text-align: center;
  padding: 1rem;
  color: var(--muted);
  font-size: 0.875rem;
}

/* Home */
.home-page {
  max-width: 900px;
  margin: 0 auto;
}

.home-hero {
  text-align: center;
  padding: 3rem 1rem 4rem;
  position: relative;
}

.home-hero-badge {
  display: inline-block;
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--success);
  background: rgba(78, 204, 163, 0.15);
  padding: 0.35rem 0.85rem;
  border-radius: 999px;
  margin-bottom: 1.25rem;
}

.home-hero-title {
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  line-height: 1.2;
  margin-bottom: 1rem;
  font-weight: 700;
}

.home-hero-brand {
  color: var(--highlight);
}

.home-hero-tagline {
  font-size: 1.125rem;
  color: var(--muted);
  line-height: 1.6;
  margin-bottom: 2rem;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}

.btn-hero {
  font-size: 1.1rem;
  padding: 0.9rem 2rem;
}

.home-features {
  padding: 3rem 1rem;
  border-top: 1px solid var(--accent);
}

.home-section-title {
  text-align: center;
  font-size: 1.5rem;
  margin-bottom: 2rem;
  color: var(--text);
}

.home-features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1.25rem;
}

.home-feature-card {
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 1.25rem;
  transition: border-color 0.2s, transform 0.2s;
}

.home-feature-card:hover {
  border-color: var(--highlight);
  transform: translateY(-2px);
}

.home-feature-icon {
  font-size: 2rem;
  display: block;
  margin-bottom: 0.5rem;
}

.home-feature-card h3 {
  font-size: 1rem;
  margin: 0 0 0.5rem;
  color: var(--highlight);
}

.home-feature-card p {
  font-size: 0.9rem;
  color: var(--muted);
  line-height: 1.5;
  margin: 0;
}

.home-live {
  text-align: center;
  padding: 3rem 1rem;
  background: rgba(15, 52, 96, 0.3);
  border-radius: 12px;
  margin: 0 1rem 2rem;
}

.home-live-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.85rem;
  color: var(--success);
  margin-bottom: 1rem;
}

.home-live-dot {
  width: 8px;
  height: 8px;
  background: var(--success);
  border-radius: 50%;
  animation: home-pulse 2s ease-in-out infinite;
}

@keyframes home-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}

.home-live-text {
  color: var(--muted);
  line-height: 1.6;
  max-width: 500px;
  margin: 0 auto;
}

.home-cta {
  text-align: center;
  padding: 2.5rem 1rem;
}

.home-cta-text {
  font-size: 0.95rem;
  color: var(--muted);
  margin-bottom: 1.25rem;
}

.home-hero h1 { font-size: 2.5rem; margin-bottom: 0.5rem; }
.tagline { font-size: 1.125rem; color: var(--muted); margin-bottom: 2rem; }

/* Auth */
.auth-page {
  max-width: 400px;
  margin: 2rem auto;
}

.auth-page input[type="email"] {
  width: 100%;
  padding: 0.75rem;
  margin-bottom: 1rem;
  font-size: 1rem;
  border: 1px solid var(--accent);
  background: var(--bg-panel);
  color: var(--text);
  border-radius: 4px;
}

.btn-primary {
  display: inline-block;
  padding: 0.75rem 1.5rem;
  background: var(--highlight);
  color: white;
  border: none;
  border-radius: 4px;
  font-size: 1rem;
  cursor: pointer;
  text-decoration: none;
}

.btn-primary:hover { opacity: 0.9; }

.btn-danger {
  display: inline-block;
  padding: 0.75rem 1.5rem;
  background: #c53030;
  color: white;
  border: none;
  border-radius: 4px;
  font-size: 1rem;
  cursor: pointer;
  text-decoration: none;
}
.btn-danger:hover { opacity: 0.9; color: white; }

.btn-small {
  padding: 0.25rem 0.5rem;
  font-size: 0.8rem;
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  color: var(--text);
  border-radius: 4px;
  cursor: pointer;
}
.btn-small:hover { background: var(--accent); }

/* Play */
.play-container {
  display: grid;
  grid-template-columns: 250px 1fr 270px;
  gap: 1rem;
  height: calc(100vh - 140px);
}

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

.map-panel {
  padding: 0.5rem;
  border-bottom: 1px solid var(--accent);
  min-height: 80px;
  cursor: pointer;
}
.map-panel:not(.expanded) {
  padding: 0.35rem 0.5rem;
  min-height: 0;
}

.map-mini {
  font-size: 0.75rem;
  color: var(--muted);
  line-height: 1;
}
.btn-secondary.map-expand-hint {
  padding: 0.2rem 0.6rem;
  font-size: 0.85rem;
}
.map-expand-hint {
  display: inline-block;
  cursor: pointer;
}
.map-expand-hint:hover { color: var(--highlight); border-color: var(--highlight); }

.map-expanded {
  display: none;
  font-size: 0.9rem;
}
.map-title-bar {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0;
  margin-bottom: 0.35rem;
  border-bottom: 1px solid var(--accent);
  flex-wrap: wrap;
  font-size: 0.85rem;
  color: var(--muted);
  line-height: 1;
}
.map-title-label {
  min-width: 8rem;
  line-height: 1;
}
.map-region-select {
  flex: 1;
  min-width: 12rem;
  max-width: 20rem;
  padding: 0.2rem 0.4rem;
  font-size: 0.85rem;
  background: var(--bg);
  border: 1px solid var(--accent);
  color: var(--muted);
  border-radius: 4px;
}
.btn-secondary.map-my-location-btn {
  padding: 0.2rem 0.6rem;
  font-size: 0.85rem;
}
.map-my-location-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.map-my-location-btn:disabled:hover {
  color: var(--text);
  border-color: var(--accent);
}
.map-content {
  margin-top: 0.25rem;
}

.map-panel.expanded .map-mini { display: none; }
.map-panel.expanded .map-expanded { display: block; }
.map-panel.expanded { padding-top: 0; }

.minimap-hint { font-size: 0.75rem; color: var(--muted); }
.minimap-svg { width: 100%; max-height: 280px; display: block; }
.minimap-line { stroke: var(--accent); stroke-width: 2; opacity: 0.6; }
.minimap-room { fill: var(--bg-panel); stroke: var(--accent); stroke-width: 1; }
.minimap-room.minimap-room-clickable { cursor: pointer; }
.minimap-room.minimap-room-clickable:hover { fill: rgba(255, 255, 255, 0.08); }
.minimap-room.minimap-current { fill: rgba(76, 175, 80, 0.3); stroke: #4caf50; stroke-width: 3; }
.minimap-label { fill: var(--text); font-size: 10px; text-anchor: middle; dominant-baseline: central; }
.minimap-label.minimap-label-id { font-size: 8px; }
.minimap-legend { margin-top: 0.5rem; font-size: 0.85rem; color: var(--muted); }
.minimap-tooltip {
  position: fixed;
  z-index: 9999;
  padding: 0.5rem 0.75rem;
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 6px;
  font-size: 0.8rem;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.15s, visibility 0.15s;
  white-space: nowrap;
}
.minimap-tooltip.visible { opacity: 1; visibility: visible; }

/* Creature edit: roam room map picker */
.roam-map-container { margin-top: 0.5rem; padding: 1rem; background: var(--bg-panel); border-radius: 6px; border: 1px solid var(--border); }
.roam-map-svg { width: 100%; max-height: 400px; display: block; cursor: pointer; }
.roam-map-line { stroke: var(--accent); stroke-width: 2; opacity: 0.6; }
.roam-map-room { fill: var(--bg); stroke: var(--accent); stroke-width: 1; cursor: pointer; transition: fill 0.15s, stroke 0.15s; }
.roam-map-room:hover { fill: rgba(255, 255, 255, 0.1); }
.roam-map-room.roam-map-room-selected { fill: rgba(76, 175, 80, 0.5); stroke: #4caf50; stroke-width: 2; }
.roam-map-label { fill: var(--text); font-size: 10px; text-anchor: middle; dominant-baseline: central; }
.roam-map-label.roam-map-label-id { font-size: 8px; }
.roam-map-tooltip {
  position: fixed;
  z-index: 9999;
  padding: 0.5rem 0.75rem;
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 6px;
  font-size: 0.8rem;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.15s, visibility 0.15s;
  white-space: nowrap;
}
.roam-map-tooltip.visible { opacity: 1; visibility: visible; }
.roam-map-legend { margin-top: 0.5rem; font-size: 0.85rem; color: var(--muted); }

.output-panel {
  flex: 1;
  overflow-y: auto;
  padding: 1rem;
  font-size: 0.8rem;
  line-height: 1.5;
}

.output-panel .mud-line { margin: 0.25rem 0; }
.output-panel .mud-prompt { color: var(--muted); font-style: italic; }
.output-panel .mud-error { color: var(--highlight); }
.output-panel .mud-success { color: var(--success); }
.output-panel .mud-warning { color: var(--accent); font-weight: 500; }
.output-panel .mud-inventory { line-height: 1.4; white-space: normal; }

.npc-name-tooltip { text-decoration: underline; text-decoration-style: dotted; }
.npc-name-tooltip:hover { opacity: 0.9; }
.player-name-tooltip { text-decoration: underline; text-decoration-style: dotted; }
.player-name-tooltip:hover { opacity: 0.9; }
.room-item-tooltip { text-decoration: underline; text-decoration-style: dotted; }
.room-item-tooltip:hover { opacity: 0.9; }
.npc-tooltip-popup {
  position: fixed;
  z-index: 9999;
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 6px;
  padding: 0.5rem 0.75rem;
  font-size: 0.8rem;
  max-width: 320px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.15s, visibility 0.15s;
}
.npc-tooltip-popup.visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.npc-tooltip-popup .npc-tooltip-title {
  font-weight: bold;
  margin-bottom: 0.35rem;
  color: var(--highlight);
}
.npc-tooltip-popup .npc-tooltip-body {
  color: var(--text);
  line-height: 1.5;
}
.npc-tooltip-cmd {
  cursor: pointer;
  display: inline-block;
  padding: 0.1rem 0;
}
.npc-tooltip-cmd:hover {
  color: var(--highlight);
  text-decoration: underline;
}

.path-link,
.cmd-link {
  cursor: pointer;
  color: var(--highlight);
}
.path-link:hover,
.cmd-link:hover {
  text-decoration: underline;
}

/* NPC input modal (deposit, withdraw, etc.) */
.npc-input-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: rgba(0,0,0,0.5);
  align-items: center;
  justify-content: center;
}
.npc-input-modal.visible {
  display: flex;
}
.npc-input-modal-content {
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 1rem 1.25rem;
  min-width: 280px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.4);
}
.npc-input-modal-prompt {
  margin-bottom: 0.5rem;
  color: var(--text);
}
.npc-input-field {
  width: 100%;
  padding: 0.5rem;
  font-size: 1rem;
  background: var(--bg);
  border: 1px solid var(--accent);
  color: var(--text);
  border-radius: 4px;
  margin-bottom: 0.5rem;
}
.npc-input-field:focus {
  outline: none;
  border-color: var(--highlight);
}
.npc-input-modal-error {
  color: var(--highlight);
  font-size: 0.85rem;
  margin-bottom: 0.5rem;
  min-height: 1.2em;
}
.npc-input-modal-actions {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
}

.input-panel {
  display: flex;
  gap: 0.5rem;
  padding: 0.5rem;
  border-top: 1px solid var(--accent);
}

.input-panel input {
  flex: 1;
  padding: 0.5rem;
  font-size: 1rem;
  background: var(--bg);
  border: 1px solid var(--accent);
  color: var(--text);
  border-radius: 4px;
}

.input-panel input:focus {
  outline: none;
  border-color: var(--highlight);
}

.input-panel button {
  padding: 0.5rem 1rem;
  background: var(--highlight);
  color: white;
  border: none;
  border-radius: 4px;
  cursor: pointer;
}

.sidebar-left, .sidebar-right {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.player-stats, .player-portrait, .sidebar-panel {
  background: var(--bg-panel);
  padding: 1rem;
  border-radius: 8px;
  border: 1px solid var(--accent);
}

.player-portrait { margin-bottom: 0; display: flex; flex-direction: column; align-items: center; }
.player-portrait h3 { margin-top: 0; margin-bottom: 0.5rem; font-size: 0.8rem; align-self: stretch; }
#injury-portrait { width: 100%; max-width: 120px; height: auto; display: block; color: var(--muted); }

.sidebar-panel h3 {
  margin-top: 0;
  margin-bottom: 0.5rem;
  font-size: 0.8rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

.panel-toggle {
  background: none;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 0.8rem;
  padding: 0.15rem 0.35rem;
  line-height: 1;
  transition: transform 0.2s ease;
}

.panel-toggle:hover { color: var(--highlight); }

.sidebar-panel.collapsed .panel-toggle { transform: rotate(-90deg); }
.sidebar-panel.collapsed .panel-content { display: none; }

.sidebar-panel .panel-content { font-size: 0.8rem; }

.equip-slot { font-size: 0.8rem; color: var(--muted); margin-bottom: 0.25rem; }
.equip-slot:last-child { margin-bottom: 0; }
.skill-slot { font-size: 0.8rem; color: var(--muted); margin-bottom: 0.25rem; padding: 0.2rem 0; }
.skill-slot:last-child { margin-bottom: 0; }
.buff-slot {
  font-size: 0.8rem;
  margin-bottom: 0.35rem;
  padding: 0.25rem 0.4rem;
  background: var(--accent);
  border-radius: 4px;
  cursor: pointer;
  border: 1px solid transparent;
}
.buff-slot:hover { border-color: var(--highlight); opacity: 0.9; }
.buff-duration { color: var(--muted); font-size: 0.8rem; margin-left: 0.25rem; }
.buff-popup-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.buff-popup-content {
  max-width: 360px;
  padding: 1.25rem;
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}
.buff-popup-content h4 { margin: 0 0 0.75rem; font-size: 1rem; color: var(--highlight); }
.buff-popup-content p { margin: 0 0 1rem; font-size: 0.9rem; line-height: 1.5; color: var(--text); }
.buff-popup-close { margin-top: 0.5rem; }

.status-bars { font-size: 0.8rem; }
.bar-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}
.bar-row:last-child { margin-bottom: 0; }
.bar-label { width: 2.5rem; color: var(--muted); }
.bar-track {
  flex: 1;
  height: 0.75rem;
  background: var(--bg);
  border-radius: 4px;
  overflow: hidden;
}
.bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.3s ease;
}
.bar-hp { background: var(--highlight); }
.bar-mana { background: #4a90d9; }
.bar-cast { background: #9b59b6; }
.bar-roundtime { background: #f39c12; }
.bar-encumbrance { /* color set inline: green->red gradient by fill % */ }
.bar-value { width: 3.5rem; text-align: right; color: var(--muted); font-size: 0.8rem; }
.bar-meta { margin-bottom: 0.5rem; padding-bottom: 0.5rem; border-bottom: 1px solid var(--accent); color: var(--muted); font-size: 0.8rem; }
.bar-gold, .bar-weight { display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }
.bar-gold .bar-label, .bar-weight .bar-label { min-width: 2.5rem; }
.bar-gold .bar-sep, .bar-weight .bar-sep { color: var(--muted); font-size: 0.8rem; }
.gold-item { font-size: 0.8rem; color: var(--muted); }
.gold-item .gold-coin { filter: sepia(1) saturate(4) hue-rotate(-15deg); }

/* Quests panel */
.quests-tabs {
  display: flex;
  gap: 0.25rem;
  margin-bottom: 0.5rem;
}
.quests-tab {
  flex: 1;
  padding: 0.35rem 0.5rem;
  font-size: 0.8rem;
  background: var(--bg);
  border: 1px solid var(--accent);
  color: var(--text);
  cursor: pointer;
  border-radius: 4px;
  font: inherit;
}
.quests-tab:hover { border-color: var(--highlight); color: var(--highlight); }
.quests-tab.active {
  background: var(--accent);
  border-color: var(--highlight);
  color: var(--text);
}
.quests-list { font-size: 0.8rem; }
.quests-list.quests-tab-pane { display: none; }
.quests-list.quests-tab-pane.active { display: block; }
.quest-item {
  padding: 0.4rem 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.quest-item:last-child { border-bottom: none; }
.quest-name { font-weight: bold; color: var(--text); }
.quest-progress { color: var(--success); font-size: 0.85em; margin-top: 0.15rem; }
.quest-npc { color: var(--muted); font-size: 0.9em; margin-top: 0.1rem; }
.quest-date { color: var(--muted); font-size: 0.8em; margin-top: 0.1rem; }
.quest-completed .quest-name { color: var(--muted); }

/* Characters */
.characters-page {
  max-width: 900px;
  margin: 0 auto;
}
.characters-page h1 { margin-bottom: 0.5rem; }
.characters-intro { margin-bottom: 1.5rem; color: var(--muted); }
.character-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1rem;
}
.character-card {
  display: flex;
  flex-direction: column;
  padding: 1.25rem 1.5rem;
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.character-card-name {
  font-size: 1.1rem;
  margin: 0 0 0.25rem 0;
  color: var(--highlight);
}
.character-card-meta {
  color: var(--muted);
  font-size: 0.9rem;
  margin: 0 0 1rem 0;
  line-height: 1.4;
}
.character-card-form {
  margin-top: auto;
}
.character-card-form .btn-primary { width: 100%; }
.character-card-create {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  border-style: dashed;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: 140px;
}
.character-card-create:hover {
  border-color: var(--highlight);
  background: rgba(233, 69, 96, 0.08);
}
.character-card-create-icon {
  font-size: 2rem;
  color: var(--highlight);
  margin-bottom: 0.5rem;
}
.character-card-create-title {
  font-size: 1rem;
  margin: 0 0 0.25rem 0;
}
.character-card-create .character-card-meta { margin-bottom: 0; }
.characters-empty, .characters-max { margin-top: 1rem; }
.btn-sm { padding: 0.4rem 0.8rem; font-size: 0.9rem; }
.muted { color: var(--muted); }

/* Character create */
.character-create-page { max-width: 500px; }
.form-group { margin-bottom: 1.25rem; }
.form-group label { display: block; margin-bottom: 0.25rem; font-weight: 500; }
.form-group input[type="text"],
.form-group input[type="number"],
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 0.5rem;
  font-size: 1rem;
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  color: var(--text);
  border-radius: 4px;
}
.form-group textarea {
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  color: var(--text);
  resize: vertical;
  min-height: 4rem;
}
.form-group small { display: block; margin-top: 0.25rem; color: var(--muted); font-size: 0.8rem; }
.form-error { color: var(--highlight); margin-bottom: 1rem; }
.form-success { color: var(--success); margin-bottom: 1rem; }
.area-select-row { display: flex; flex-direction: column; gap: 0.5rem; }
.area-actions-row { display: flex; gap: 0.5rem; align-items: center; flex-wrap: wrap; margin-top: 0.5rem; }
.area-create-row { display: flex; gap: 0.5rem; align-items: center; flex-wrap: wrap; }
.area-create-row input[type="text"] { flex: 1; min-width: 150px; }
.btn-danger-outline { color: var(--highlight); border: 1px solid var(--highlight); background: transparent; padding: 0.25rem 0.5rem; border-radius: 4px; cursor: pointer; font: inherit; }
.btn-danger-outline:hover { background: rgba(233, 69, 96, 0.2); }
.race-suggestions { font-size: 0.9rem; margin-top: 0.25rem; }
.stat-allocation h3 { margin: 1.5rem 0 0.5rem; }
.stat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.5rem 2rem; margin-top: 1rem; }
.stat-row { display: flex; justify-content: space-between; align-items: center; gap: 0.5rem; }
.stat-row label { margin: 0; font-weight: normal; }
.stat-row input { width: 4rem; text-align: center; }
.form-actions { margin-top: 1.5rem; display: flex; align-items: center; gap: 1rem; }
.btn-secondary {
  display: inline-block;
  padding: 0.75rem 1.5rem;
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  color: var(--text);
  border-radius: 4px;
  font-size: 1rem;
  cursor: pointer;
  text-decoration: none;
}
.btn-secondary:hover { color: var(--highlight); border-color: var(--highlight); }

/* Admin */
.admin-page h1 { margin-bottom: 0.5rem; }
.admin-page ul { list-style: none; padding: 0; }
.admin-page li { margin: 0.5rem 0; }

/* Admin dashboard (main admin index) */
.admin-dashboard .admin-dashboard-title {
  font-size: 1.75rem;
  margin-bottom: 0.25rem;
  color: var(--text);
}
.admin-dashboard .admin-dashboard-subtitle {
  color: var(--muted);
  font-size: 0.95rem;
  margin-bottom: 1.5rem;
}
.admin-dashboard .admin-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem;
}
.admin-dashboard .admin-card-group {
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 1rem 1.25rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.admin-dashboard .admin-card-group:hover {
  border-color: var(--highlight);
  box-shadow: 0 2px 12px rgba(233, 69, 96, 0.1);
}
.admin-dashboard .admin-card-group-title {
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted);
  margin: 0 0 0.75rem 0;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--accent);
}
.admin-dashboard .admin-cards {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.admin-dashboard .admin-card {
  display: block;
  padding: 0.65rem 0.85rem;
  border-radius: 6px;
  text-decoration: none;
  color: var(--text);
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid transparent;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.admin-dashboard .admin-card:hover {
  background: rgba(233, 69, 96, 0.12);
  border-color: rgba(233, 69, 96, 0.3);
  color: var(--highlight);
}
.admin-dashboard .admin-card .admin-card-label {
  display: block;
  font-weight: 600;
  font-size: 0.95rem;
  margin-bottom: 0.2rem;
}
.admin-dashboard .admin-card .admin-card-desc {
  display: block;
  font-size: 0.8rem;
  color: var(--muted);
  line-height: 1.35;
}
.admin-dashboard .admin-card:hover .admin-card-desc {
  color: var(--text);
  opacity: 0.9;
}

/* Admin settings page (card layout) */
.admin-settings-page .admin-settings-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5rem;
}
.admin-settings-page .admin-settings-title {
  font-size: 1.75rem;
  margin: 0;
  color: var(--text);
}
.admin-settings-page .admin-settings-form {
  max-width: 100%;
}
.admin-settings-page .admin-settings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}
.admin-settings-page .admin-escort-grid {
  grid-template-columns: 1fr 1fr;
}
.admin-settings-page .admin-escort-message-row + .admin-escort-message-row {
  margin-top: 1.5rem;
}
.admin-settings-page .admin-escort-message-row .admin-settings-card {
  width: 100%;
}
.admin-settings-page .admin-settings-card {
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 1.25rem 1.5rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.admin-settings-page .admin-settings-card:hover {
  border-color: var(--highlight);
  box-shadow: 0 2px 12px rgba(233, 69, 96, 0.1);
}
.admin-settings-page .admin-settings-card-title {
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted);
  margin: 0 0 1rem 0;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--accent);
}
.admin-settings-page .admin-settings-card-desc {
  font-size: 0.85rem;
  color: var(--muted);
  margin: 0 0 1rem 0;
  line-height: 1.4;
}
.admin-settings-page .admin-settings-card .form-group:last-child {
  margin-bottom: 0;
}
.admin-settings-page .form-group-toggle .toggle-label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
}
.admin-settings-page .form-group-toggle .toggle-label input[type="checkbox"] {
  width: auto;
  margin: 0;
}
.admin-settings-page .admin-settings-actions {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-top: 0.5rem;
}

/* Admin professions page (card layout) */
.admin-professions-page .admin-professions-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.admin-professions-page .admin-professions-header-actions {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.admin-professions-page .admin-professions-title {
  font-size: 1.75rem;
  margin: 0 0 0.25rem 0;
  color: var(--text);
}
.admin-professions-page .admin-professions-subtitle {
  color: var(--muted);
  font-size: 0.95rem;
  margin: 0;
}
.admin-professions-page .admin-professions-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
}
.admin-professions-page .admin-profession-card {
  display: block;
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 1.25rem 1.5rem;
  text-decoration: none;
  color: var(--text);
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}
.admin-professions-page .admin-profession-card:hover {
  border-color: var(--highlight);
  box-shadow: 0 2px 12px rgba(233, 69, 96, 0.1);
  background: rgba(233, 69, 96, 0.05);
}
.admin-professions-page .admin-profession-card-name {
  display: block;
  font-weight: 600;
  font-size: 1.1rem;
  margin-bottom: 0.35rem;
  color: var(--text);
}
.admin-professions-page .admin-profession-card-desc {
  display: block;
  font-size: 0.85rem;
  color: var(--muted);
  line-height: 1.4;
  margin-bottom: 0.75rem;
}
.admin-professions-page .admin-profession-card-action {
  font-size: 0.85rem;
  color: var(--highlight);
  font-weight: 500;
}
.admin-professions-page .admin-profession-card:hover .admin-profession-card-action {
  text-decoration: underline;
}

/* Admin starter items page (card layout) */
.admin-starter-items-page .admin-starter-items-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.admin-starter-items-page .admin-starter-items-title {
  font-size: 1.75rem;
  margin: 0 0 0.25rem 0;
  color: var(--text);
}
.admin-starter-items-page .admin-starter-items-subtitle {
  color: var(--muted);
  font-size: 0.95rem;
  margin: 0 0 0.5rem 0;
  line-height: 1.4;
}
.admin-starter-items-page .admin-starter-items-success {
  color: var(--success);
  font-size: 0.9rem;
  margin: 0;
}
.admin-starter-items-page .admin-starter-items-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
}
.admin-starter-items-page .admin-starter-items-card {
  display: block;
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 1.25rem 1.5rem;
  text-decoration: none;
  color: var(--text);
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}
.admin-starter-items-page .admin-starter-items-card:hover {
  border-color: var(--highlight);
  box-shadow: 0 2px 12px rgba(233, 69, 96, 0.1);
  background: rgba(233, 69, 96, 0.05);
}
.admin-starter-items-page .admin-starter-items-card-name {
  display: block;
  font-weight: 600;
  font-size: 1.1rem;
  margin-bottom: 0.35rem;
  color: var(--text);
}
.admin-starter-items-page .admin-starter-items-card-desc {
  display: block;
  font-size: 0.85rem;
  color: var(--muted);
  line-height: 1.4;
  margin-bottom: 0.75rem;
}
.admin-starter-items-page .admin-starter-items-card-action {
  font-size: 0.85rem;
  color: var(--highlight);
  font-weight: 500;
}
.admin-starter-items-page .admin-starter-items-card:hover .admin-starter-items-card-action {
  text-decoration: underline;
}

/* Admin races page (card layout) */
.admin-races-page .admin-races-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.admin-races-page .admin-races-header-actions {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.admin-races-page .admin-races-title {
  font-size: 1.75rem;
  margin: 0 0 0.25rem 0;
  color: var(--text);
}
.admin-races-page .admin-races-subtitle {
  color: var(--muted);
  font-size: 0.95rem;
  margin: 0;
}
.admin-races-page .admin-races-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
}
.admin-races-page .admin-race-card {
  display: block;
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 1.25rem 1.5rem;
  text-decoration: none;
  color: var(--text);
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}
.admin-races-page .admin-race-card:hover {
  border-color: var(--highlight);
  box-shadow: 0 2px 12px rgba(233, 69, 96, 0.1);
  background: rgba(233, 69, 96, 0.05);
}
.admin-races-page .admin-race-card-name {
  display: block;
  font-weight: 600;
  font-size: 1.1rem;
  margin-bottom: 0.35rem;
  color: var(--text);
}
.admin-races-page .admin-race-card-stats {
  display: block;
  font-size: 0.8rem;
  color: var(--muted);
  line-height: 1.5;
  margin-bottom: 0.75rem;
  font-family: inherit;
}
.admin-races-page .admin-race-card-action {
  font-size: 0.85rem;
  color: var(--highlight);
  font-weight: 500;
}
.admin-races-page .admin-race-card:hover .admin-race-card-action {
  text-decoration: underline;
}

/* Admin items page (single card with table) */
.admin-items-page .admin-items-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5rem;
}
.admin-items-page .admin-items-title {
  font-size: 1.75rem;
  margin: 0;
  color: var(--text);
}
.admin-items-page .admin-items-card {
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 1.25rem 1.5rem;
  overflow: visible;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.admin-items-page .admin-items-card:hover {
  border-color: var(--highlight);
  box-shadow: 0 2px 12px rgba(233, 69, 96, 0.1);
}
.admin-items-page .admin-items-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}
.admin-items-page .admin-items-card-desc {
  color: var(--muted);
  font-size: 0.95rem;
  margin: 0;
  line-height: 1.4;
}
.admin-items-page .admin-items-card .filter-bar {
  margin-bottom: 1rem;
}
.admin-items-page .admin-items-table-wrap {
  overflow-x: auto;
  overflow-y: visible;
  width: 100%;
}
.admin-items-page .admin-items-table-wrap .admin-table {
  margin-top: 0;
}

/* Admin NPCs page (single card with table, matches Items layout) */
.admin-npcs-page .admin-npcs-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5rem;
}
.admin-npcs-page .admin-npcs-title {
  font-size: 1.75rem;
  margin: 0;
  color: var(--text);
}
.admin-npcs-page .admin-npcs-card {
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 1.25rem 1.5rem;
  overflow: visible;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.admin-npcs-page .admin-npcs-card:hover {
  border-color: var(--highlight);
  box-shadow: 0 2px 12px rgba(233, 69, 96, 0.1);
}
.admin-npcs-page .admin-npcs-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}
.admin-npcs-page .admin-npcs-card-desc {
  color: var(--muted);
  font-size: 0.95rem;
  margin: 0;
  line-height: 1.4;
}
.admin-npcs-page .admin-npcs-table-wrap {
  overflow-x: auto;
  overflow-y: visible;
  width: 100%;
}
.admin-npcs-page .admin-npcs-table-wrap .admin-table {
  margin-top: 0;
}

/* Admin players page (single card with table, matches NPCs/Items layout) */
.admin-players-page .admin-players-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5rem;
}
.admin-players-page .admin-players-title {
  font-size: 1.75rem;
  margin: 0;
  color: var(--text);
}
.admin-players-page .admin-players-card {
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 1.25rem 1.5rem;
  overflow: visible;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.admin-players-page .admin-players-card:hover {
  border-color: var(--highlight);
  box-shadow: 0 2px 12px rgba(233, 69, 96, 0.1);
}
.admin-players-page .admin-players-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}
.admin-players-page .admin-players-card-desc {
  color: var(--muted);
  font-size: 0.95rem;
  margin: 0;
  line-height: 1.4;
}
.admin-players-page .admin-players-table-wrap {
  overflow-x: auto;
  overflow-y: visible;
  width: 100%;
}
.admin-players-page .admin-players-table-wrap .admin-table {
  margin-top: 0;
}

/* Admin table-card pages (Player Actions, Herbs, Potions, Buffs, Creatures, Quests, Skills, Rooms, Room Items) */
.admin-player-actions-page .admin-player-actions-header,
.admin-herbs-page .admin-herbs-header,
.admin-potions-page .admin-potions-header,
.admin-buffs-page .admin-buffs-header,
.admin-creatures-page .admin-creatures-header,
.admin-quests-page .admin-quests-header,
.admin-skills-page .admin-skills-header,
.admin-rooms-page .admin-rooms-header,
.admin-room-items-page .admin-room-items-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5rem;
}
.admin-player-actions-page .admin-player-actions-title,
.admin-herbs-page .admin-herbs-title,
.admin-potions-page .admin-potions-title,
.admin-buffs-page .admin-buffs-title,
.admin-creatures-page .admin-creatures-title,
.admin-quests-page .admin-quests-title,
.admin-skills-page .admin-skills-title,
.admin-rooms-page .admin-rooms-title,
.admin-room-items-page .admin-room-items-title {
  font-size: 1.75rem;
  margin: 0;
  color: var(--text);
}
.admin-player-actions-page .admin-player-actions-card,
.admin-herbs-page .admin-herbs-card,
.admin-potions-page .admin-potions-card,
.admin-buffs-page .admin-buffs-card,
.admin-creatures-page .admin-creatures-card,
.admin-quests-page .admin-quests-card,
.admin-skills-page .admin-skills-card,
.admin-rooms-page .admin-rooms-card,
.admin-room-items-page .admin-room-items-card {
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 1.25rem 1.5rem;
  overflow: visible;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.admin-player-actions-page .admin-player-actions-card:hover,
.admin-herbs-page .admin-herbs-card:hover,
.admin-potions-page .admin-potions-card:hover,
.admin-buffs-page .admin-buffs-card:hover,
.admin-creatures-page .admin-creatures-card:hover,
.admin-quests-page .admin-quests-card:hover,
.admin-skills-page .admin-skills-card:hover,
.admin-rooms-page .admin-rooms-card:hover,
.admin-room-items-page .admin-room-items-card:hover {
  border-color: var(--highlight);
  box-shadow: 0 2px 12px rgba(233, 69, 96, 0.1);
}
.admin-player-actions-page .admin-player-actions-card-header,
.admin-herbs-page .admin-herbs-card-header,
.admin-potions-page .admin-potions-card-header,
.admin-buffs-page .admin-buffs-card-header,
.admin-creatures-page .admin-creatures-card-header,
.admin-quests-page .admin-quests-card-header,
.admin-skills-page .admin-skills-card-header,
.admin-rooms-page .admin-rooms-card-header,
.admin-room-items-page .admin-room-items-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}
.admin-player-actions-page .admin-player-actions-card-header .btn-primary,
.admin-herbs-page .admin-herbs-card-header .btn-primary,
.admin-potions-page .admin-potions-card-header .btn-primary,
.admin-buffs-page .admin-buffs-card-header .btn-primary,
.admin-creatures-page .admin-creatures-card-header .btn-primary,
.admin-quests-page .admin-quests-card-header .btn-primary,
.admin-skills-page .admin-skills-card-header .btn-primary,
.admin-rooms-page .admin-rooms-card-header .btn-primary,
.admin-room-items-page .admin-room-items-card-header .btn-primary {
  flex-shrink: 0;
  white-space: nowrap;
  min-width: fit-content;
}
.admin-player-actions-page .admin-player-actions-card-desc,
.admin-herbs-page .admin-herbs-card-desc,
.admin-potions-page .admin-potions-card-desc,
.admin-buffs-page .admin-buffs-card-desc,
.admin-creatures-page .admin-creatures-card-desc,
.admin-quests-page .admin-quests-card-desc,
.admin-skills-page .admin-skills-card-desc,
.admin-rooms-page .admin-rooms-card-desc,
.admin-room-items-page .admin-room-items-card-desc {
  color: var(--muted);
  font-size: 0.95rem;
  margin: 0;
  line-height: 1.4;
  min-width: 0;
  flex: 1;
}
.admin-player-actions-page .admin-player-actions-card-actions,
.admin-herbs-page .admin-herbs-card-actions,
.admin-potions-page .admin-potions-card-actions,
.admin-skills-page .admin-skills-card-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}
.admin-player-actions-page .admin-player-actions-card-actions .btn-inline,
.admin-herbs-page .admin-herbs-card-actions .btn-inline,
.admin-potions-page .admin-potions-card-actions .btn-inline,
.admin-skills-page .admin-skills-card-actions .btn-inline {
  padding: 0.75rem 1.5rem;
  font-size: 1rem;
}
.admin-player-actions-page .admin-player-actions-table-wrap,
.admin-herbs-page .admin-herbs-table-wrap,
.admin-potions-page .admin-potions-table-wrap,
.admin-buffs-page .admin-buffs-table-wrap,
.admin-creatures-page .admin-creatures-table-wrap,
.admin-quests-page .admin-quests-table-wrap,
.admin-skills-page .admin-skills-table-wrap,
.admin-rooms-page .admin-rooms-table-wrap,
.admin-room-items-page .admin-room-items-table-wrap {
  overflow-x: auto;
  overflow-y: visible;
  width: 100%;
}
.admin-player-actions-page .admin-player-actions-table-wrap .admin-table,
.admin-herbs-page .admin-herbs-table-wrap .admin-table,
.admin-potions-page .admin-potions-table-wrap .admin-table,
.admin-buffs-page .admin-buffs-table-wrap .admin-table,
.admin-creatures-page .admin-creatures-table-wrap .admin-table,
.admin-quests-page .admin-quests-table-wrap .admin-table,
.admin-skills-page .admin-skills-table-wrap .admin-table,
.admin-rooms-page .admin-rooms-table-wrap .admin-table,
.admin-room-items-page .admin-room-items-table-wrap .admin-table {
  margin-top: 0;
}

/* Admin edit pages (profession, race, etc.) */
.admin-edit-page .admin-edit-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5rem;
  max-width: 863px;
  margin-left: auto;
  margin-right: auto;
}
.admin-edit-page .admin-edit-title {
  font-size: 1.75rem;
  margin: 0;
  color: var(--text);
}
.admin-edit-page .admin-edit-form {
  max-width: 863px;
  margin: 0 auto;
}
.admin-edit-page .admin-edit-card {
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 1.25rem 1.5rem;
  margin-bottom: 1.5rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.admin-edit-page .admin-edit-card:hover {
  border-color: var(--highlight);
  box-shadow: 0 2px 12px rgba(233, 69, 96, 0.1);
}
.admin-edit-page .admin-edit-card-title {
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted);
  margin: 0 0 1rem 0;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--accent);
}
.admin-edit-page .admin-edit-card-desc {
  font-size: 0.85rem;
  color: var(--muted);
  margin: 0 0 1rem 0;
  line-height: 1.4;
}
.admin-edit-page .admin-edit-card .form-group:last-child {
  margin-bottom: 0;
}
.admin-edit-page .admin-edit-actions {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.admin-edit-page .admin-edit-actions .btn-primary,
.admin-edit-page .admin-edit-actions .btn-danger {
  padding: 0.75rem 1.5rem;
  font-size: 1rem;
}
.admin-edit-page .admin-edit-actions .btn-danger {
  background: var(--highlight);
}
/* Player edit: Save and Delete match primary; Cancel uses btn-secondary (like preferences) */
.admin-player-edit-page .admin-edit-actions .btn-primary,
.admin-player-edit-page .admin-edit-actions .btn-danger {
  display: inline-block;
  padding: 0.75rem 1.5rem;
  font-size: 1rem;
  border-radius: 4px;
  cursor: pointer;
  text-decoration: none;
  border: none;
  background: var(--highlight);
  color: white;
}
.admin-player-edit-page .admin-edit-actions .btn-primary:hover,
.admin-player-edit-page .admin-edit-actions .btn-danger:hover {
  opacity: 0.9;
  color: white;
}
.admin-player-edit-page .admin-edit-actions .btn-secondary,
.admin-player-edit-page .admin-edit-actions a.btn-secondary {
  display: inline-block;
  padding: 0.75rem 1.5rem;
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  color: var(--text);
  border-radius: 4px;
  font-size: 1rem;
  cursor: pointer;
  text-decoration: none;
}
.admin-player-edit-page .admin-edit-actions .btn-secondary:hover,
.admin-player-edit-page .admin-edit-actions a.btn-secondary:hover {
  color: var(--highlight);
  border-color: var(--highlight);
}
.admin-player-edit-page .admin-edit-delete-form {
  display: inline;
  margin: 0;
}
.admin-player-edit-page .admin-player-info-card {
  max-width: 1100px;
  margin: 0 auto 1.5rem auto;
}
.admin-player-edit-page .admin-player-info-list {
  margin: 0;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.25rem 2rem;
  align-items: baseline;
  font-size: 0.9rem;
}
.admin-player-edit-page .admin-player-info-row {
  display: contents;
}
.admin-player-edit-page .admin-player-info-list dt {
  margin: 0;
  font-weight: 500;
  color: var(--text);
}
.admin-player-edit-page .admin-player-info-list dd {
  margin: 0;
  color: var(--muted);
}
.admin-player-edit-page .admin-edit-actions {
  max-width: 1100px;
  margin: 0 auto;
}
.admin-player-edit-page .admin-edit-form,
.admin-player-edit-page .admin-edit-header {
  max-width: 1100px;
}
/* Character details: 4 fields in a row */
.admin-player-edit-page .admin-player-details-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}
.admin-player-edit-page .admin-player-details-grid .form-group {
  margin-bottom: 0;
}
/* Resources + Health & Mana side by side */
.admin-player-edit-page .admin-player-cards-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}
.admin-player-edit-page .admin-player-cards-row .admin-edit-card {
  margin-bottom: 0;
}
.admin-player-edit-page .admin-player-cards-row .stat-mod-grid {
  grid-template-columns: repeat(4, 1fr);
}
.admin-edit-page .admin-item-form-card {
  overflow: visible;
}
.admin-edit-page .admin-starter-items-card .admin-starter-items-card-desc,
.admin-edit-page .admin-starter-items-card .admin-starter-items-card-hint {
  font-size: 0.85rem;
  color: var(--muted);
  margin: 0 0 1rem 0;
  line-height: 1.4;
}
.admin-edit-page .admin-starter-items-card .admin-starter-items-card-hint {
  margin-top: 0.75rem;
  margin-bottom: 1rem;
}
.admin-edit-page .admin-starter-items-card {
  overflow: visible;
}
.admin-edit-page .admin-starter-items-card .admin-starter-items-table-wrap {
  margin-bottom: 0;
  overflow: visible;
}
.admin-edit-page .admin-starter-items-card .admin-starter-items-table-wrap .admin-table {
  margin-top: 0;
  overflow-y: visible;
}

.admin-page .page-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}
.admin-page .page-header h1 { margin: 0; }
.admin-page a.btn-back {
  display: inline-block;
  padding: 0.1rem 0.3rem;
  font-size: 0.7rem;
  line-height: 1.2;
  background: var(--highlight);
  color: white;
  border: none;
  border-radius: 3px;
  text-decoration: none;
  flex-shrink: 0;
}
.admin-page a.btn-back:hover { opacity: 0.9; color: white; }
.admin-page a.btn-inline,
.admin-page button.btn-inline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.15rem 0.5rem;
  font-size: 0.85rem;
  line-height: 1;
  background: var(--highlight);
  color: white;
  border: none;
  border-radius: 4px;
  text-decoration: none;
  cursor: pointer;
  font: inherit;
}
.admin-page a.btn-inline:hover,
.admin-page button.btn-inline:hover { opacity: 0.9; color: white; }
.admin-page .filter-bar {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-top: 1rem;
  padding: 0.5rem 0;
}
.admin-page .filter-label {
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 500;
}
.admin-page .filter-links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0 0.5rem;
}
.admin-page .filter-links .filter-link {
  color: var(--muted);
  text-decoration: none;
  font-size: 0.9rem;
  padding: 0.15rem 0;
}
.admin-page .filter-links .filter-link:hover,
.admin-page .filter-links .filter-link.active {
  color: var(--highlight);
}
.admin-page .filter-links .filter-link:not(:last-child)::after {
  content: "·";
  color: var(--accent);
  margin-left: 0.5rem;
  font-weight: bold;
  pointer-events: none;
}
.admin-page a:not(.btn-primary):not(.btn-secondary):not(.btn-danger):not(.btn-inline):not(.btn-back) { color: var(--highlight); }
.admin-page a.btn-primary { color: white; }
.admin-page a.btn-primary:hover { color: white; }
.admin-page a.btn-danger { color: white; text-decoration: none; }
.admin-page a.btn-danger:hover { color: white; text-decoration: none; }
.admin-page a.btn-secondary { color: var(--text); }
.admin-page a.btn-secondary:hover { color: var(--highlight); }
.admin-table { width: 100%; border-collapse: collapse; margin-top: 1rem; }
.admin-table th, .admin-table td { padding: 0.5rem; border: 1px solid var(--accent); text-align: left; }
.admin-table th { background: var(--accent); }
.stat-mod-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0.5rem; margin: 1rem 0; }
.stat-mod-grid .form-group input { width: 4rem; }

/* Herb edit: Benefits card with 2x2 sub-cards */
.admin-herb-edit-page .herb-benefits-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  margin-top: 1rem;
}
.admin-herb-edit-page .herb-benefits-card {
  background: rgba(0, 0, 0, 0.2);
  border: 1px solid var(--accent);
  border-radius: 6px;
  padding: 1rem;
}
.admin-herb-edit-page .herb-benefits-card-title {
  font-weight: 600;
  font-size: 0.85rem;
  margin-bottom: 0.75rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--accent);
  color: var(--muted);
}
.admin-herb-edit-page .herb-benefits-card .form-group {
  margin-bottom: 0;
}
.admin-herb-edit-page .herb-benefits-card .form-group input,
.admin-herb-edit-page .herb-benefits-card .form-group select {
  width: 100%;
}

/* Potion edit: Spell card with 2x2 sub-cards */
.admin-potion-edit-page .potion-spell-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  margin-top: 1rem;
}
.admin-potion-edit-page .potion-spell-card {
  background: rgba(0, 0, 0, 0.2);
  border: 1px solid var(--accent);
  border-radius: 6px;
  padding: 1rem;
}
.admin-potion-edit-page .potion-spell-card-span {
  grid-column: span 2;
}
.admin-potion-edit-page .potion-spell-card-title {
  font-weight: 600;
  font-size: 0.85rem;
  margin-bottom: 0.75rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--accent);
  color: var(--muted);
}
.admin-potion-edit-page .potion-spell-card .form-group {
  margin-bottom: 0;
}
.admin-potion-edit-page .potion-spell-card .form-group input,
.admin-potion-edit-page .potion-spell-card .form-group select {
  width: 100%;
}

/* Skin condition cards (2x2 layout) */
.skin-condition-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  margin: 1rem 0;
}
.skin-condition-card {
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 1rem;
}
.skin-condition-card-title {
  font-weight: 600;
  text-transform: capitalize;
  margin-bottom: 0.75rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--accent);
}
.skin-condition-poor { color: #e74c3c; }
.skin-condition-fair { color: #f39c12; }
.skin-condition-good { color: #f1c40f; }
.skin-condition-excellent { color: #27ae60; }
.skin-condition-card-row {
  display: flex;
  gap: 1rem;
  align-items: flex-end;
}
.skin-condition-card-row .form-group { margin-bottom: 0; flex: 1; }
.skin-condition-card-row .form-group input { width: 4rem; }

/* Creature edit: cards in cards (like skin conditions) */
.admin-creature-edit-page .creature-inner-cards {
  display: grid;
  gap: 1rem;
  margin: 0;
}
.admin-creature-edit-page .creature-inner-cards-spawn {
  grid-template-columns: repeat(3, 1fr);
}
.admin-creature-edit-page .creature-inner-cards-spawn .creature-inner-card:nth-child(4) {
  grid-column: span 2;
}
.admin-creature-edit-page .creature-inner-cards:not(.creature-inner-cards-spawn):not(.creature-inner-cards-stats) {
  grid-template-columns: 1fr 1fr;
}
.admin-creature-edit-page .creature-inner-card {
  background: rgba(0, 0, 0, 0.2);
  border: 1px solid var(--accent);
  border-radius: 6px;
  padding: 1rem;
}
.admin-creature-edit-page .creature-inner-card-title {
  font-weight: 600;
  font-size: 0.85rem;
  text-transform: capitalize;
  margin-bottom: 0.5rem;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid var(--accent);
  color: var(--muted);
}
.admin-creature-edit-page .creature-inner-card-gold .creature-inner-card-title { color: #f1c40f; }
.admin-creature-edit-page .creature-inner-card-rep .creature-inner-card-title { color: #9b59b6; }
.admin-creature-edit-page .creature-inner-card-row {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: flex-end;
}
.admin-creature-edit-page .creature-inner-card-row .form-group { margin-bottom: 0; flex: 1; min-width: 4rem; }
.admin-creature-edit-page .creature-inner-card-row .form-group input { width: 4rem; }
.admin-creature-edit-page .creature-inner-card-row.stat-mod-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0.5rem;
}
.admin-creature-edit-page .creature-inner-card-hint {
  font-size: 0.75rem;
  color: var(--muted);
  margin: 0.5rem 0 0 0;
  line-height: 1.3;
}
.admin-creature-edit-page .creature-inner-cards-stats .creature-inner-card {
  grid-column: 1 / -1;
}

/* Skill edit: wider card (35% more than default 863px) */
.admin-skill-edit-page .admin-edit-form,
.admin-skill-edit-page .admin-edit-header {
  max-width: 1165px;
}

/* Skill edit: cards in cards */
.admin-skill-edit-page .skill-inner-cards {
  display: grid;
  gap: 1rem;
  margin: 0;
}
.admin-skill-edit-page .skill-inner-cards-costs {
  grid-template-columns: repeat(2, 1fr);
}
.admin-skill-edit-page .skill-inner-cards-effects {
  grid-template-columns: repeat(2, 1fr);
}
.admin-skill-edit-page .skill-inner-card {
  background: rgba(0, 0, 0, 0.2);
  border: 1px solid var(--accent);
  border-radius: 6px;
  padding: 1rem;
}
.admin-skill-edit-page .skill-inner-card-title {
  font-weight: 600;
  font-size: 0.85rem;
  text-transform: capitalize;
  margin-bottom: 0.5rem;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid var(--accent);
  color: var(--muted);
}
.admin-skill-edit-page .skill-inner-card .form-group {
  margin-bottom: 0;
}
.admin-skill-edit-page .skill-inner-card .form-group input[type="number"] {
  width: 4rem;
}
.admin-skill-edit-page .skill-inner-card .form-group input[type="text"],
.admin-skill-edit-page .skill-inner-card .form-group select {
  width: 100%;
  min-width: 0;
}
.admin-skill-edit-page .skill-inner-card .form-group small {
  display: block;
  margin-top: 0.25rem;
}

/* Creature difficulty checker (admin creature edit) */
.creature-difficulty {
  margin: 1rem 0;
  padding: 1rem;
  border-radius: 6px;
  border-left: 4px solid var(--muted);
  background: var(--bg-panel);
}
.creature-difficulty h4 { margin: 0 0 0.5rem 0; }
.creature-difficulty .difficulty-label { font-weight: 600; font-size: 1.1rem; margin: 0.25rem 0; }
.creature-difficulty .difficulty-details { margin: 0.25rem 0; }
.creature-difficulty .difficulty-stats { margin: 0.5rem 0; font-size: 0.85rem; }
.creature-difficulty .small { font-size: 0.8rem; }
.creature-difficulty.difficulty-trivial { border-left-color: var(--success); }
.creature-difficulty.difficulty-easy { border-left-color: #8bc34a; }
.creature-difficulty.difficulty-balanced { border-left-color: #ffc107; }
.creature-difficulty.difficulty-hard { border-left-color: #ff9800; }
.creature-difficulty.difficulty-too-hard { border-left-color: var(--highlight); }
.suggest-stats-row { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; margin-top: 0.5rem; }
.suggest-stats-row select { min-width: 12rem; }
#creature-suggested-stats { margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--accent); }

.action-row { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; margin-bottom: 0.5rem; }
.action-row input, .action-row select { margin: 0; }
.btn-remove-action { font-size: 0.85rem; padding: 0.2rem 0.5rem; }
#add-action-btn { margin-bottom: 1rem; }

/* Admin help icon & popup */
.help-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.1rem;
  height: 1.1rem;
  margin-left: 0.25rem;
  padding: 0;
  font-size: 0.75rem;
  font-weight: bold;
  line-height: 1;
  color: var(--muted);
  background: var(--accent);
  border: 1px solid var(--accent);
  border-radius: 50%;
  cursor: pointer;
  vertical-align: middle;
}
.help-icon:hover {
  color: var(--text);
  background: var(--highlight);
  border-color: var(--highlight);
}
.help-popup-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 9999;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.help-popup-overlay.visible {
  display: flex;
}
.help-popup {
  max-width: 420px;
  max-height: 80vh;
  overflow-y: auto;
  padding: 1.25rem;
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}
.help-popup h4 {
  margin: 0 0 0.75rem;
  font-size: 1rem;
  color: var(--highlight);
}
.help-popup p {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.5;
  color: var(--text);
}

/* Preferences modal */
.prefs-modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  z-index: 9999;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.prefs-modal.prefs-modal-open {
  display: flex;
}
.prefs-modal-content {
  max-width: 420px;
  padding: 1.5rem;
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}
.prefs-modal-content h3 {
  margin: 0 0 0.5rem;
  font-size: 1.1rem;
  color: var(--highlight);
}
.prefs-modal-content > p {
  margin: 0 0 1rem;
  font-size: 0.9rem;
  color: var(--muted);
}
.prefs-subhead {
  margin: 1rem 0 0.5rem;
  font-size: 0.95rem;
  color: var(--text);
}
.prefs-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
}
.prefs-row label {
  flex: 0 0 140px;
  font-size: 0.9rem;
}
.prefs-row input[type="color"] {
  width: 2.5rem;
  height: 2rem;
  padding: 2px;
  border: 1px solid var(--accent);
  border-radius: 4px;
  cursor: pointer;
  background: var(--bg);
}
.prefs-row .prefs-theme {
  padding: 0.35rem 0.5rem;
  font: inherit;
  background: var(--bg);
  border: 1px solid var(--accent);
  color: var(--text);
  border-radius: 4px;
}
.prefs-row .prefs-hex {
  width: 5rem;
  padding: 0.35rem 0.5rem;
  font-family: inherit;
  font-size: 0.9rem;
  background: var(--bg);
  border: 1px solid var(--accent);
  border-radius: 4px;
  color: var(--text);
}
.prefs-actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 1.25rem;
}
/* Mobile responsive */
@media (max-width: 768px) {
  .header-inner { flex-wrap: wrap; gap: 0.5rem; }
  .main-nav { flex-wrap: wrap; gap: 0.5rem; }
  .page-main { padding: 0.75rem; }

  .play-container {
    grid-template-columns: 1fr;
    height: auto;
    min-height: calc(100vh - 140px);
  }
  .sidebar-left { order: 1; }
  .game-panel { order: 2; min-height: 50vh; }
  .sidebar-right { order: 3; }

  .character-cards { grid-template-columns: 1fr; }

  .stat-grid { grid-template-columns: 1fr; }
  .stat-mod-grid { grid-template-columns: repeat(2, 1fr); }
  .stat-mod-grid .form-group input { width: 3rem; }

  .admin-dashboard .admin-grid { grid-template-columns: 1fr; }
  .admin-settings-page .admin-settings-grid { grid-template-columns: 1fr; }
  .admin-professions-page .admin-professions-header { flex-direction: column; align-items: stretch; }
  .admin-professions-page .admin-professions-header-actions { align-self: flex-start; }
  .admin-professions-page .admin-professions-grid { grid-template-columns: 1fr; }
  .admin-starter-items-page .admin-starter-items-header { flex-direction: column; align-items: stretch; }
  .admin-starter-items-page .admin-starter-items-header .btn-back { align-self: flex-start; }
  .admin-starter-items-page .admin-starter-items-grid { grid-template-columns: 1fr; }
  .admin-races-page .admin-races-header { flex-direction: column; align-items: stretch; }
  .admin-races-page .admin-races-header-actions { align-self: flex-start; }
  .admin-races-page .admin-races-grid { grid-template-columns: 1fr; }
  .admin-items-page .admin-items-card-header { flex-direction: column; align-items: stretch; }
  .admin-items-page .admin-items-card-header .btn-primary { align-self: flex-start; }
  .admin-npcs-page .admin-npcs-card-header { flex-direction: column; align-items: stretch; }
  .admin-npcs-page .admin-npcs-card-header .btn-primary { align-self: flex-start; }
  .admin-players-page .admin-players-card-header { flex-direction: column; align-items: stretch; }
  .admin-player-actions-page .admin-player-actions-card-header,
  .admin-herbs-page .admin-herbs-card-header,
  .admin-potions-page .admin-potions-card-header,
  .admin-buffs-page .admin-buffs-card-header,
  .admin-creatures-page .admin-creatures-card-header,
  .admin-quests-page .admin-quests-card-header,
  .admin-skills-page .admin-skills-card-header,
  .admin-rooms-page .admin-rooms-card-header,
  .admin-room-items-page .admin-room-items-card-header { flex-direction: column; align-items: stretch; }
  .admin-player-actions-page .admin-player-actions-card-header .btn-primary,
  .admin-herbs-page .admin-herbs-card-header .btn-primary,
  .admin-potions-page .admin-potions-card-header .btn-primary,
  .admin-buffs-page .admin-buffs-card-header .btn-primary,
  .admin-creatures-page .admin-creatures-card-header .btn-primary,
  .admin-quests-page .admin-quests-card-header .btn-primary,
  .admin-skills-page .admin-skills-card-header .btn-primary,
  .admin-rooms-page .admin-rooms-card-header .btn-primary,
  .admin-room-items-page .admin-room-items-card-header .btn-primary { align-self: flex-start; }
  .admin-potions-page .admin-potions-card-actions,
  .admin-skills-page .admin-skills-card-actions { align-self: flex-start; }
  .admin-player-edit-page .admin-player-details-grid { grid-template-columns: 1fr; }
  .admin-player-edit-page .admin-player-cards-row { grid-template-columns: 1fr; }
  .admin-player-edit-page .admin-player-cards-row .stat-mod-grid { grid-template-columns: 1fr; }
  .admin-skill-edit-page .skill-inner-cards-costs,
.admin-skill-edit-page .skill-inner-cards-effects { grid-template-columns: repeat(2, 1fr); }
  .admin-edit-page .admin-edit-actions { flex-direction: column; }
  .admin-edit-page .admin-edit-actions .btn-primary,
  .admin-edit-page .admin-edit-actions .btn-secondary,
  .admin-edit-page .admin-edit-actions .btn-danger { width: 100%; text-align: center; }
  .admin-settings-page .admin-settings-actions { flex-direction: column; }
  .admin-settings-page .admin-settings-actions .btn-primary,
  .admin-settings-page .admin-settings-actions .btn-secondary { width: 100%; text-align: center; }
  .admin-table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .admin-edit-page .admin-starter-items-card .admin-starter-items-table-wrap .admin-table { overflow-y: visible; }
  .admin-table th, .admin-table td { padding: 0.4rem; font-size: 0.9rem; white-space: nowrap; }

  .form-actions { flex-direction: column; }
  .form-actions .btn-primary, .form-actions .btn-secondary { width: 100%; text-align: center; }

  .home-hero h1 { font-size: 1.75rem; }
  .tagline { font-size: 1rem; }
  .auth-page { margin: 1rem auto; padding: 0 0.5rem; }
  .character-create-page { max-width: 100%; }
  .input-panel input { min-height: 44px; }
  .input-panel button { min-height: 44px; }
  .btn-primary { min-height: 44px; }
}

@media (max-width: 480px) {
  .header-inner { padding: 0.5rem; }
  .main-nav a, .main-nav form { font-size: 0.9rem; }
  .stat-mod-grid { grid-template-columns: 1fr; }
  .skin-condition-cards { grid-template-columns: 1fr; }
  .admin-herb-edit-page .herb-benefits-cards { grid-template-columns: 1fr; }
  .admin-potion-edit-page .potion-spell-cards { grid-template-columns: 1fr; }
  .admin-potion-edit-page .potion-spell-card-span { grid-column: span 1; }
  .admin-creature-edit-page .creature-inner-cards-spawn { grid-template-columns: 1fr; }
  .admin-creature-edit-page .creature-inner-cards:not(.creature-inner-cards-spawn):not(.creature-inner-cards-stats) { grid-template-columns: 1fr; }
  .admin-creature-edit-page .creature-inner-card-row.stat-mod-grid { grid-template-columns: repeat(2, 1fr); }
  .admin-skill-edit-page .skill-inner-cards-costs,
  .admin-skill-edit-page .skill-inner-cards-effects { grid-template-columns: 1fr; }
}

/* Guide */
.guide-container {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 1rem 2rem;
}
.guide-nav {
  margin-bottom: 2rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--accent);
}
.guide-nav h2 {
  font-size: 1rem;
  margin: 0 0 0.75rem 0;
  color: var(--highlight);
}
.guide-nav ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.5rem;
}
.guide-nav li { margin-bottom: 0; }
.guide-nav a {
  color: var(--text);
  text-decoration: none;
  font-size: 0.9rem;
  padding: 0.35rem 0.75rem;
  border-radius: 6px;
  display: inline-block;
}
.guide-nav a:hover { background: var(--accent); color: var(--highlight); }
.guide-nav a.active {
  background: var(--highlight);
  color: white;
}
.guide-content {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: stretch;
}
.guide-content > h1 {
  font-size: 1.75rem;
  margin: 0 0 0.5rem 0;
  color: var(--highlight);
}
.guide-content > .guide-intro {
  margin-bottom: 0.5rem;
}
.guide-card {
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 1.25rem 1.5rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.guide-card h2 {
  font-size: 1.15rem;
  margin: 0 0 0.75rem 0;
  color: var(--highlight);
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--accent);
}
.guide-card h2:first-child { margin-top: 0; }
.guide-card p, .guide-card li {
  line-height: 1.6;
  margin-bottom: 0.5rem;
}
.guide-card p:last-child, .guide-card li:last-child { margin-bottom: 0; }
.guide-card ul, .guide-card ol {
  margin: 0.5rem 0;
  padding-left: 1.5rem;
}
.guide-card code {
  background: var(--accent);
  padding: 0.1em 0.4em;
  border-radius: 4px;
  font-size: 0.9em;
}
.guide-card a { color: var(--highlight); }
.guide-card .guide-table {
  width: 100%;
  border-collapse: collapse;
  margin: 0.5rem 0 0;
  font-size: 0.9rem;
}
.guide-card .guide-table th, .guide-card .guide-table td {
  border: 1px solid var(--accent);
  padding: 0.5rem 0.75rem;
  text-align: left;
}
.guide-card .guide-table th { background: var(--accent); }
@media (max-width: 768px) {
  .guide-nav ul { flex-direction: column; }
}

.hidden { display: none !important; }
