/* ===== DND DESIGN SYSTEM v3 — Dark Fantasy ===== */
:root {
  --dnd-font-title: "Unbounded", "Manrope", sans-serif;
  --dnd-font-ui: "Manrope", "Segoe UI", Tahoma, sans-serif;

  /* Dark palette */
  --dnd-bg: #0e0f14;
  --dnd-bg-warm: #12131a;
  --dnd-surface: #181a24;
  --dnd-surface-soft: #1e2030;
  --dnd-surface-muted: #252738;
  --dnd-surface-raised: #2a2d42;

  --dnd-ink: #e8e6f0;
  --dnd-ink-soft: #b0adc0;
  --dnd-ink-muted: #706d82;

  --dnd-line: rgba(255, 255, 255, 0.07);
  --dnd-line-strong: rgba(255, 255, 255, 0.12);

  --dnd-accent: #c9a040;
  --dnd-accent-hover: #ddb445;
  --dnd-accent-quiet: rgba(201, 160, 64, 0.15);
  --dnd-accent-glow: rgba(201, 160, 64, 0.25);

  --dnd-emerald: #3ddc84;
  --dnd-emerald-soft: rgba(61, 220, 132, 0.12);
  --dnd-gold: #c9a040;

  --dnd-danger: #ff5555;
  --dnd-danger-soft: rgba(255, 85, 85, 0.12);
  --dnd-success: #3ddc84;

  --dnd-purple: #9580ff;
  --dnd-purple-soft: rgba(149, 128, 255, 0.12);
  --dnd-blue: #80bfff;
  --dnd-blue-soft: rgba(128, 191, 255, 0.12);

  --dnd-r-xl: 16px;
  --dnd-r-lg: 12px;
  --dnd-r-md: 8px;
  --dnd-r-sm: 6px;

  --dnd-shadow-sm: 0 1px 3px rgba(0,0,0,0.3), 0 1px 2px rgba(0,0,0,0.2);
  --dnd-shadow-md: 0 4px 16px rgba(0,0,0,0.4);
  --dnd-shadow-lg: 0 12px 40px rgba(0,0,0,0.5);
  --dnd-shadow-xl: 0 20px 50px rgba(0,0,0,0.6);
  --dnd-shadow-glow: 0 0 20px rgba(201, 160, 64, 0.15);

  --dnd-glass: rgba(255, 255, 255, 0.03);
  --dnd-glass-border: rgba(255, 255, 255, 0.06);
}

/* ===== BASE ===== */
.dnd-main {
  position: relative;
  height: calc(100vh - 70px);
  padding: 12px;
  display: grid;
  grid-template-rows: 1fr;
  gap: 12px;
  font-family: var(--dnd-font-ui);
  color: var(--dnd-ink);
  background: var(--dnd-bg);
  background-image:
    radial-gradient(ellipse at 20% 50%, rgba(149, 128, 255, 0.04) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 20%, rgba(201, 160, 64, 0.03) 0%, transparent 50%);
}

.dnd-main [hidden] { display: none !important; }

.dnd-main h1, .dnd-main h2, .dnd-main h3, .dnd-main h4 {
  font-family: var(--dnd-font-title);
  color: var(--dnd-ink);
  letter-spacing: -0.01em;
  line-height: 1.2;
}

.dnd-main p, .dnd-main label, .dnd-main li { margin: 0; }

/* ===== SHELL LAYOUT ===== */
.dnd-page { min-height: 0; display: grid; }

.dnd-shell {
  min-height: 0;
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.dnd-shell[data-workspace="game"] {
  grid-template-columns: minmax(0, 1fr);
  align-items: stretch;
}

.dnd-shell[data-workspace="game"] .dnd-sidebar { display: none; }

/* ===== SIDEBAR ===== */
.dnd-sidebar {
  position: sticky;
  top: 82px;
  max-height: calc(100vh - 94px);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  border-radius: var(--dnd-r-xl);
  background: var(--dnd-surface);
  border: 1px solid var(--dnd-line);
  box-shadow: var(--dnd-shadow-lg);
  overflow: hidden;
}

.dnd-sidebar::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--dnd-accent) 0%, var(--dnd-purple) 50%, rgba(149,128,255,0.1) 100%);
}

.dnd-sidebar::after {
  content: "";
  position: absolute;
  width: 180px;
  height: 180px;
  right: -90px;
  bottom: -90px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(201, 160, 64, 0.08) 0%, transparent 70%);
  pointer-events: none;
}

.dnd-sidebar > * { position: relative; z-index: 1; }

/* Sidebar header */
.dnd-sidebar__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.dnd-sidebar__head h2 {
  margin: 0;
  font-size: clamp(18px, 2vw, 22px);
  color: var(--dnd-ink);
  background: linear-gradient(135deg, var(--dnd-ink) 0%, var(--dnd-accent) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.dnd-sidebar__head .button--ghost {
  min-height: 32px;
  padding: 6px 14px;
  border-color: var(--dnd-line-strong);
  background: var(--dnd-glass);
  color: var(--dnd-ink-soft);
  font-size: 12px;
}

.dnd-sidebar__head .button--ghost:hover {
  background: var(--dnd-accent);
  border-color: var(--dnd-accent);
  color: #111;
}

.dnd-sidebar__intro {
  color: var(--dnd-ink-muted);
  font-size: 12px;
  line-height: 1.5;
}

/* Sidebar sections */
.dnd-sidebar__section {
  padding: 12px;
  border-radius: var(--dnd-r-lg);
  border: 1px solid var(--dnd-line);
  background: var(--dnd-surface-soft);
  display: grid;
  gap: 10px;
}

.dnd-sidebar__section--fill {
  flex: 1 1 auto;
  min-height: 0;
  grid-template-rows: auto minmax(0, 1fr);
}

.dnd-sidebar__section-head { display: grid; gap: 4px; }

.dnd-sidebar__section-head h3 {
  margin: 0;
  color: var(--dnd-ink);
  font-size: clamp(14px, 1.3vw, 17px);
}

.dnd-sidebar .dnd-muted {
  color: var(--dnd-ink-muted);
  line-height: 1.45;
}

/* Sidebar forms */
.dnd-sidebar .dnd-form {
  padding: 12px;
  border: 1px solid var(--dnd-line);
  border-radius: var(--dnd-r-md);
  background: var(--dnd-surface-soft);
  gap: 10px;
}

.dnd-sidebar .dnd-form .form__row span { color: var(--dnd-ink-soft); }

.dnd-sidebar .input,
.dnd-sidebar .textarea,
.dnd-sidebar select.input {
  border-color: var(--dnd-line-strong);
  background: var(--dnd-surface);
  color: var(--dnd-ink);
}

.dnd-sidebar .button { font-size: 13px; font-weight: 700; }

.dnd-sidebar #session-status {
  min-height: 18px;
  color: var(--dnd-ink-muted);
  font-size: 12px;
}

.dnd-sidebar #session-status[data-state="success"] { color: var(--dnd-success); }
.dnd-sidebar #session-status[data-state="error"] { color: var(--dnd-danger); }

/* Session list */
.dnd-session-list-wrap {
  min-height: 0;
  overflow-y: auto;
  padding: 6px;
  border-radius: var(--dnd-r-md);
  background: rgba(0, 0, 0, 0.2);
}

.dnd-session-list { display: grid; gap: 6px; }

.dnd-sidebar .dnd-session-item {
  padding: 12px;
  border-radius: var(--dnd-r-md);
  border: 1px solid var(--dnd-line);
  background: var(--dnd-surface-soft);
  display: grid;
  gap: 8px;
  transition: border-color 0.25s, box-shadow 0.25s, background 0.25s;
}

.dnd-sidebar .dnd-session-item:hover {
  border-color: rgba(201, 160, 64, 0.25);
  background: var(--dnd-surface-muted);
}

.dnd-sidebar .dnd-session-item.is-active {
  border-color: var(--dnd-accent);
  box-shadow: 0 0 0 1px var(--dnd-accent-quiet), var(--dnd-shadow-glow);
  background: rgba(201, 160, 64, 0.06);
}

.dnd-sidebar .dnd-session-item__title {
  font-size: 13px;
  font-weight: 700;
  color: var(--dnd-ink);
}

.dnd-sidebar .dnd-session-item__meta {
  color: var(--dnd-ink-muted);
  font-size: 11px;
}

.dnd-sidebar .dnd-session-item__actions {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
}

.dnd-sidebar .dnd-session-item__actions .button {
  width: 100%;
  min-height: 28px;
  padding: 4px 6px;
  font-size: 11px;
  font-weight: 700;
}

.dnd-sidebar .dnd-session-item__actions .button.button--ghost {
  border-color: var(--dnd-line-strong);
  background: var(--dnd-glass);
  color: var(--dnd-ink-soft);
}

.dnd-sidebar .dnd-session-item__actions .button.button--ghost:hover {
  background: var(--dnd-ink);
  border-color: var(--dnd-ink);
  color: var(--dnd-bg);
}

/* ===== WORKSPACE ===== */
.dnd-sidebar,
.dnd-workspace {
  min-height: 0;
}

.dnd-workspace {
  padding: 16px;
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 12px;
  border-radius: var(--dnd-r-xl);
  border: 1px solid var(--dnd-line);
  background: var(--dnd-surface);
  box-shadow: var(--dnd-shadow-md);
  overflow: hidden;
}

.dnd-workspace::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  border-radius: var(--dnd-r-xl) var(--dnd-r-xl) 0 0;
  background: linear-gradient(90deg, var(--dnd-purple), var(--dnd-accent), rgba(201,160,64,0.1));
}

/* ===== WORKSPACE TOOLBAR ===== */
.dnd-workspace__head {
  padding: 12px 14px;
  border-radius: var(--dnd-r-lg);
  border: 1px solid var(--dnd-line);
  background: var(--dnd-surface-soft);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.dnd-workspace__toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.dnd-workspace__toolbar-left {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.dnd-workspace__toolbar-left h2 {
  margin: 0;
  font-size: clamp(16px, 1.5vw, 22px);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dnd-workspace__toolbar-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

/* ===== GAME TOGGLE BUTTON ===== */
.dnd-game-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 22px;
  border-radius: var(--dnd-r-md);
  font-size: 14px;
  font-weight: 700;
  border: 1.5px solid var(--dnd-emerald);
  background: var(--dnd-emerald-soft);
  color: var(--dnd-emerald);
  cursor: pointer;
  transition: all 0.25s ease;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.dnd-game-toggle:hover {
  background: var(--dnd-emerald);
  color: #111;
  box-shadow: 0 0 20px rgba(61, 220, 132, 0.3);
}

.dnd-game-toggle__icon {
  font-size: 14px;
  line-height: 1;
}

.dnd-game-toggle.is-running {
  border-color: var(--dnd-danger);
  background: var(--dnd-danger-soft);
  color: var(--dnd-danger);
}

.dnd-game-toggle.is-running:hover {
  background: var(--dnd-danger);
  color: #fff;
  box-shadow: 0 0 20px rgba(255, 85, 85, 0.3);
}

/* ===== UNIFIED TAB BAR ===== */
.dnd-unified-tabs {
  display: flex;
  gap: 2px;
  padding: 3px;
  border-radius: var(--dnd-r-md);
  background: rgba(0, 0, 0, 0.3);
  overflow-x: auto;
}

.dnd-unified-tab {
  flex: 1 1 0;
  min-height: 36px;
  min-width: max-content;
  padding: 8px 16px;
  border-radius: var(--dnd-r-sm);
  border: none;
  background: transparent;
  color: var(--dnd-ink-muted);
  font-family: var(--dnd-font-ui);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.dnd-unified-tab:hover {
  background: rgba(255, 255, 255, 0.05);
  color: var(--dnd-ink-soft);
}

.dnd-unified-tab.is-active {
  background: var(--dnd-surface-muted);
  color: var(--dnd-ink);
  box-shadow: var(--dnd-shadow-sm);
  font-weight: 700;
}

.dnd-unified-tab.is-locked::after {
  content: "\1F512";
  font-size: 10px;
  opacity: 0.4;
}

.dnd-unified-tab__indicator {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--dnd-emerald);
  box-shadow: 0 0 8px rgba(61, 220, 132, 0.5);
  animation: dnd-pulse 1.5s ease-in-out infinite;
}

@keyframes dnd-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}

/* ===== SHARED TAB BUTTON STYLES ===== */
.dnd-gear-tabs__button,
.dnd-game-tabs__button,
.dnd-mode-switch__button {
  min-height: 34px;
  padding: 7px 12px;
  border-radius: var(--dnd-r-sm);
  border: none;
  background: transparent;
  color: var(--dnd-ink-muted);
  font-family: var(--dnd-font-ui);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

.dnd-gear-tabs__button:hover,
.dnd-game-tabs__button:hover,
.dnd-mode-switch__button:hover {
  background: rgba(255, 255, 255, 0.05);
  color: var(--dnd-ink-soft);
}

.dnd-gear-tabs__button.is-active,
.dnd-game-tabs__button.is-active,
.dnd-mode-switch__button.is-active {
  background: var(--dnd-surface-muted);
  color: var(--dnd-ink);
  box-shadow: var(--dnd-shadow-sm);
  font-weight: 700;
}

/* ===== TAB PANELS ===== */
.dnd-tab-panels {
  min-height: 0;
  display: grid;
  overflow: hidden;
}

.dnd-tab-panel {
  display: none;
  min-height: 0;
  overflow: auto;
  padding-right: 4px;
  gap: 12px;
  align-content: start;
  scrollbar-gutter: stable;
}

.dnd-tab-panel.is-active { display: grid; }

.dnd-tab-layout { display: grid; gap: 12px; }

.dnd-tab-layout--world {
  grid-template-columns: minmax(0, 1fr);
  align-items: start;
}

.dnd-tab-layout--character-top {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
}

.dnd-tab-layout--character-metrics {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: start;
}

.dnd-character-top-column {
  display: grid;
  gap: 10px;
  align-content: start;
}

.dnd-character-top-column h3 {
  margin: 0;
  font-size: clamp(14px, 1.1vw, 16px);
}

/* ===== CARDS / FORMS ===== */
.dnd-form,
.dnd-scene,
.dnd-console-card,
.dnd-item,
.dnd-candidate,
.dnd-param-item,
.dnd-session-item,
.dnd-party-item,
.dnd-live-metrics-group,
.dnd-live-metric,
.dnd-progression-item,
.dnd-progression-column {
  border-radius: var(--dnd-r-lg);
  border: 1px solid var(--dnd-line);
  background: var(--dnd-surface-soft);
}

.dnd-form,
.dnd-scene,
.dnd-console-card {
  padding: 16px;
}

.dnd-form {
  display: grid;
  gap: 12px;
}

.dnd-form h3,
.dnd-play-feed--story h3,
.dnd-scene h3,
.dnd-console-card h3 {
  margin: 0;
  font-size: clamp(15px, 1.2vw, 19px);
  color: var(--dnd-ink);
}

.dnd-form--tight { gap: 10px; }
.dnd-form--gear,
.dnd-form--params,
.dnd-form--perk { gap: 12px; }

.dnd-connect-panel { border-style: dashed; border-color: var(--dnd-line-strong); }

.dnd-connect-panel__content {
  display: grid;
  gap: 10px;
}

/* ===== FORM ELEMENTS ===== */
.dnd-main .button {
  min-height: 36px;
  padding: 8px 18px;
  border-radius: var(--dnd-r-sm);
  border: none;
  background: var(--dnd-accent);
  color: #111;
  font-family: var(--dnd-font-ui);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s ease;
  letter-spacing: 0.01em;
}

.dnd-main .button:hover {
  background: var(--dnd-accent-hover);
  box-shadow: 0 0 16px rgba(201, 160, 64, 0.3);
  transform: translateY(-1px);
}

.dnd-main .button:active {
  transform: translateY(0);
  box-shadow: none;
}

.dnd-main .button:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.dnd-main .button--ghost {
  background: transparent;
  border: 1.5px solid var(--dnd-line-strong);
  color: var(--dnd-ink-soft);
}

.dnd-main .button--ghost:hover {
  background: var(--dnd-surface-raised);
  border-color: var(--dnd-ink-muted);
  color: var(--dnd-ink);
  box-shadow: none;
  transform: none;
}

.dnd-main .button--danger {
  background: var(--dnd-danger);
  border: none;
  color: #fff;
}

.dnd-main .button--danger:hover {
  background: #ff3333;
  box-shadow: 0 0 16px rgba(255, 85, 85, 0.3);
}

.dnd-main .input,
.dnd-main .textarea,
.dnd-main select.input {
  width: 100%;
  min-height: 38px;
  padding: 8px 12px;
  border-radius: var(--dnd-r-sm);
  border: 1.5px solid var(--dnd-line-strong);
  background: var(--dnd-surface);
  color: var(--dnd-ink);
  font-family: var(--dnd-font-ui);
  font-size: 14px;
  line-height: 1.45;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.dnd-main .input::placeholder,
.dnd-main .textarea::placeholder {
  color: var(--dnd-ink-muted);
  opacity: 0.6;
}

.dnd-main .textarea {
  resize: vertical;
  min-height: 68px;
}

.dnd-main .input:focus,
.dnd-main .textarea:focus,
.dnd-main select.input:focus {
  outline: none;
  border-color: var(--dnd-accent);
  box-shadow: 0 0 0 2px var(--dnd-accent-quiet);
}

.dnd-main select.input {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23706d82' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 32px;
}

.dnd-main select.input option {
  background: var(--dnd-surface);
  color: var(--dnd-ink);
}

.form__row {
  display: grid;
  gap: 4px;
}

.form__row--wide { grid-column: 1 / -1; }

.dnd-form .form__row span {
  color: var(--dnd-ink-muted);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.dnd-checkbox-row {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--dnd-ink-soft);
  font-size: 13px;
}

.dnd-checkbox-row input {
  width: 18px;
  height: 18px;
  accent-color: var(--dnd-accent);
  cursor: pointer;
}

/* ===== GRIDS ===== */
.dnd-grid { display: grid; gap: 10px; }
.dnd-grid--two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.dnd-grid--three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.dnd-grid--six { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.dnd-grid--ability .form__row span { text-align: center; }

/* ===== GENERATION BOX ===== */
.dnd-gen-box {
  display: grid;
  gap: 8px;
  border-radius: var(--dnd-r-md);
  border: 1.5px dashed var(--dnd-line-strong);
  background: rgba(149, 128, 255, 0.03);
  padding: 12px;
}

.dnd-form__actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.dnd-form__actions--wide { grid-column: 1 / -1; }

/* ===== STATUS ===== */
.dnd-status {
  min-height: 18px;
  color: var(--dnd-ink-muted);
  font-size: 12px;
}

.dnd-status[data-state="error"] { color: var(--dnd-danger); }
.dnd-status[data-state="success"] { color: var(--dnd-success); }

.dnd-muted {
  color: var(--dnd-ink-muted);
  font-size: 12px;
  line-height: 1.5;
}

.dnd-subtitle {
  grid-column: 1 / -1;
  color: var(--dnd-ink-muted);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* ===== SESSION / ITEM LISTS ===== */
.dnd-session-list,
.dnd-inventory,
.dnd-character-candidates,
.dnd-params-list,
.dnd-party-list,
.dnd-progression-list,
.dnd-npc-list {
  display: grid;
  gap: 6px;
}

.dnd-session-item,
.dnd-item,
.dnd-candidate,
.dnd-param-item,
.dnd-party-item,
.dnd-progression-item {
  padding: 10px;
}

.dnd-session-item {
  background: var(--dnd-surface-soft);
  display: grid;
  gap: 6px;
}

.dnd-session-item.is-active {
  border-color: var(--dnd-accent);
  box-shadow: 0 0 0 1px var(--dnd-accent-quiet);
}

.dnd-session-item__title,
.dnd-item__title,
.dnd-candidate__title,
.dnd-param-item__title,
.dnd-party-item__title,
.dnd-progression-item__title,
.dnd-npc-item__title {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  color: var(--dnd-ink);
}

.dnd-session-item__meta,
.dnd-item__descr,
.dnd-candidate__meta,
.dnd-param-item__meta,
.dnd-param-item__descr,
.dnd-party-item__meta,
.dnd-npc-item__meta,
.dnd-npc-item__stats,
.dnd-npc-item__memory,
.dnd-progression-item__meta,
.dnd-live-metric__meta {
  margin-top: 2px;
  color: var(--dnd-ink-muted);
  font-size: 12px;
  line-height: 1.45;
}

.dnd-session-item__actions,
.dnd-item__actions,
.dnd-candidate__actions,
.dnd-param-item__actions,
.dnd-party-item__actions,
.dnd-progression-item__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.dnd-session-item__actions .button,
.dnd-item__actions .button,
.dnd-candidate__actions .button,
.dnd-param-item__actions .button,
.dnd-party-item__actions .button,
.dnd-progression-item__actions .button {
  min-height: 26px;
  padding: 4px 10px;
  font-size: 11px;
}

.dnd-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.dnd-candidate { background: var(--dnd-surface-muted); }
.dnd-param-item { background: var(--dnd-surface-muted); }

/* ===== PARTY / MULTIPLAYER ===== */
.dnd-party-panel,
.dnd-mp-panel,
.dnd-turn-panel,
.dnd-progression-panel { border-style: dashed; }

.dnd-progression-panel { grid-column: 1 / -1; }

.dnd-party-item { background: var(--dnd-surface-soft); }

.dnd-party-item.is-active {
  border-color: var(--dnd-emerald);
  background: linear-gradient(180deg, rgba(61, 220, 132, 0.06) 0%, rgba(61, 220, 132, 0.02) 100%);
}

.dnd-party-item.is-turn:not(.is-active) {
  border-color: var(--dnd-gold);
  background: rgba(201, 160, 64, 0.04);
}

.dnd-party-item.is-locked { opacity: 0.55; }
.dnd-party-item--member.is-online { border-color: var(--dnd-emerald); }
.dnd-party-list--compact .dnd-party-item__actions .button { flex: 1 1 0; }

#turn-summary[data-state="ready"] { color: var(--dnd-success); }
#turn-summary[data-state="wait"] { color: var(--dnd-ink-muted); }

/* ===== GAME HUD ===== */
.dnd-game-hud {
  z-index: 10;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 10px 16px;
  border-radius: var(--dnd-r-lg);
  border: 1px solid var(--dnd-line-strong);
  background: linear-gradient(180deg, var(--dnd-surface-muted) 0%, var(--dnd-surface-soft) 100%);
  box-shadow: var(--dnd-shadow-md);
  flex-wrap: wrap;
}

.dnd-game-hud__char {
  display: flex;
  align-items: baseline;
  gap: 6px;
  min-width: 0;
}

.dnd-game-hud__name {
  font-family: var(--dnd-font-title);
  font-size: 18px;
  font-weight: 700;
  color: var(--dnd-accent);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 180px;
}

.dnd-game-hud__level {
  font-size: 14px;
  font-weight: 600;
  color: var(--dnd-ink-muted);
  white-space: nowrap;
}

.dnd-game-hud__hp {
  position: relative;
  min-width: 140px;
  max-width: 200px;
  flex: 1 1 140px;
  height: 24px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.4);
  border: 1px solid var(--dnd-line);
  overflow: hidden;
}

.dnd-game-hud__hp-bar {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #ff5555 0%, #ff5555 25%, #ffb86c 50%, #3ddc84 75%, #3ddc84 100%);
  background-size: 300% 100%;
  transition: width 0.5s ease, background-position 0.5s ease;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.15);
}

.dnd-game-hud__hp-text {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  text-shadow: 0 1px 3px rgba(0,0,0,0.6);
  letter-spacing: 0.02em;
}

.dnd-game-hud__mode {
  padding: 6px 16px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  white-space: nowrap;
  background: var(--dnd-emerald-soft);
  color: var(--dnd-emerald);
  border: 1px solid rgba(61, 220, 132, 0.2);
  transition: all 0.25s ease;
}

.dnd-game-hud__mode[data-mode="combat"] {
  background: var(--dnd-danger-soft);
  color: var(--dnd-danger);
  border-color: rgba(255, 85, 85, 0.2);
  animation: combat-glow 2s ease-in-out infinite;
}

@keyframes combat-glow {
  0%, 100% { box-shadow: none; }
  50% { box-shadow: 0 0 12px rgba(255, 85, 85, 0.2); }
}

.dnd-game-hud__mode[data-mode="dialog"] {
  background: var(--dnd-accent-quiet);
  color: var(--dnd-accent);
  border-color: rgba(201, 160, 64, 0.2);
}

.dnd-game-hud__stats {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-left: auto;
}

.dnd-game-hud__stat {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: var(--dnd-r-sm);
  background: rgba(0, 0, 0, 0.3);
  border: 1px solid var(--dnd-line);
  font-size: 13px;
  font-weight: 600;
  color: var(--dnd-ink-soft);
  white-space: nowrap;
}

.dnd-game-hud__stat-label {
  color: var(--dnd-ink-muted);
  font-size: 12px;
}

/* ===== GAME / PLAY LAYOUT ===== */
#tab-play.is-active {
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 12px;
  overflow: hidden;
}

/* Game play panel — fills viewport */
#tab-play.is-active {
  grid-template-rows: auto 1fr auto;
  overflow: hidden;
}

.dnd-play-layout {
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 2.5fr) minmax(240px, 0.5fr);
  gap: 12px;
  overflow: hidden;
}

.dnd-play-feed,
.dnd-play-console {
  min-height: 0;
  display: grid;
  gap: 6px;
  overflow: hidden;
}

.dnd-play-feed--story {
  padding: 0;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr auto;
  align-items: stretch;
}

.dnd-play-console--controls {
  padding: 0;
  overflow-y: auto;
  align-content: start;
  scrollbar-gutter: stable;
}

/* Scene image */
.dnd-scene__content {
  display: grid;
  min-height: 0;
  overflow: hidden;
  align-content: start;
  grid-column: 1;
  grid-row: 1;
}

.dnd-scene img,
.dnd-scene__content img {
  display: block;
  width: 100%;
  min-height: 0;
  max-height: 100%;
  margin-inline: auto;
  border-radius: var(--dnd-r-md);
  border: 1px solid var(--dnd-line);
  background: var(--dnd-surface);
  object-fit: cover;
}

/* Description log — right of image */
.dnd-play-feed--story > .dnd-log {
  grid-column: 2;
  grid-row: 1;
  min-height: 0;
  max-height: none;
  overflow-y: auto;
  align-self: stretch;
}

/* System notes — full width below */
.dnd-play-feed--story > .dnd-log--system {
  grid-column: 1 / -1;
  grid-row: 2;
  min-height: 40px;
  max-height: 120px;
}

/* ===== STICKY ACTION BAR ===== */
.dnd-action-bar {
  z-index: 10;
  padding: 12px 16px;
  border-radius: var(--dnd-r-lg) var(--dnd-r-lg) 0 0;
  border: 1px solid var(--dnd-line-strong);
  border-bottom: none;
  background: linear-gradient(180deg, var(--dnd-surface-muted) 0%, var(--dnd-surface) 100%);
  box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.4);
  display: grid;
  gap: 8px;
}

.dnd-action-bar__quick { min-height: 0; }
.dnd-action-bar__quick:empty { display: none; }

.dnd-action-bar__quick .dnd-quick__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.dnd-action-bar__quick .button {
  min-height: 28px;
  padding: 4px 10px;
  font-size: 11px;
}

.dnd-action-bar__form {
  display: grid;
  gap: 6px;
}

.dnd-action-bar__label { display: block; }

.dnd-action-bar__label span {
  color: var(--dnd-ink-muted);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.dnd-action-bar__row {
  display: flex;
  gap: 8px;
  align-items: flex-end;
}

.dnd-action-bar__row .textarea {
  flex: 1;
  min-height: 46px;
  max-height: 120px;
  resize: vertical;
  font-size: 16px;
  background: rgba(0, 0, 0, 0.3);
  border-color: var(--dnd-line-strong);
}

.dnd-action-bar__row .textarea:focus {
  border-color: var(--dnd-accent);
  box-shadow: 0 0 0 2px var(--dnd-accent-quiet);
}

.dnd-action-bar__send {
  flex-shrink: 0;
  min-height: 46px;
  padding: 8px 28px;
  font-size: 16px;
  align-self: flex-end;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* ===== MODE CARD ===== */
.dnd-console-card--mode {
  border: 1.5px solid var(--dnd-line-strong);
  background: var(--dnd-surface-soft);
}

.dnd-console-card--mode .dnd-mode-switch {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3px;
  padding: 3px;
  border-radius: var(--dnd-r-sm);
  background: rgba(0, 0, 0, 0.3);
}

.dnd-mode-switch__button {
  position: relative;
  overflow: hidden;
}

.dnd-mode-switch__button.is-active[data-game-mode="travel"] {
  background: var(--dnd-emerald-soft);
  color: var(--dnd-emerald);
  box-shadow: none;
}

.dnd-mode-switch__button.is-active[data-game-mode="combat"] {
  background: var(--dnd-danger-soft);
  color: var(--dnd-danger);
  box-shadow: none;
}

.dnd-mode-switch__button.is-active[data-game-mode="dialog"] {
  background: var(--dnd-accent-quiet);
  color: var(--dnd-accent);
  box-shadow: none;
}

/* Log */
.dnd-log {
  min-height: 0;
  overflow-y: auto;
  border-radius: var(--dnd-r-md);
  border: 1px solid var(--dnd-line);
  background: rgba(0, 0, 0, 0.2);
  padding: 10px;
  display: grid;
  gap: 6px;
  align-content: start;
}

.dnd-log-entry {
  padding: 10px 12px;
  border-radius: var(--dnd-r-md);
  border: 1px solid var(--dnd-line);
  background: var(--dnd-surface-soft);
  transition: background 0.2s;
}

.dnd-log-entry:hover {
  background: var(--dnd-surface-muted);
}

.dnd-log-entry__head {
  margin: 0 0 8px;
  color: var(--dnd-ink-muted);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dnd-log-entry__body {
  margin: 0;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  line-height: 1.75;
  font-size: 17px;
  color: var(--dnd-ink-soft);
}

.dnd-log-entry--player {
  border-left: 3px solid var(--dnd-emerald);
}
.dnd-log-entry--player .dnd-log-entry__body { color: var(--dnd-ink); }

.dnd-log-entry--dm {
  border-left: 3px solid var(--dnd-accent);
}
.dnd-log-entry--dm .dnd-log-entry__body { color: var(--dnd-ink); }

.dnd-log-entry--system {
  border-left: 3px solid var(--dnd-purple);
  background: rgba(149, 128, 255, 0.04);
}

.dnd-log-entry__image {
  width: 100%;
  max-height: 280px;
  object-fit: cover;
  border-radius: var(--dnd-r-sm);
  margin-bottom: 8px;
}

.dnd-log-entry--compact .dnd-log-entry__body {
  font-size: 15px;
  line-height: 1.65;
}

/* Action form (legacy) */
.dnd-action-form { display: grid; gap: 10px; }
.dnd-action-form .textarea { min-height: 100px; }

/* Quick actions */
.dnd-quick__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

/* Mode switch */
.dnd-mode-description {
  color: var(--dnd-ink-muted);
  font-size: 14px;
  line-height: 1.5;
}

.dnd-mode-switch {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
}

.dnd-mode-actions {
  margin-top: 8px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4px;
}

.dnd-mode-actions .button {
  min-height: 36px;
  font-size: 14px;
}

/* NPC */
.dnd-npc-card .dnd-muted { margin-bottom: 6px; }

.dnd-npc-list {
  max-height: 240px;
  overflow-y: auto;
}

.dnd-npc-item {
  border-radius: var(--dnd-r-md);
  border: 1px solid var(--npc-border-color, var(--dnd-line));
  background: var(--dnd-surface-soft);
  padding: 10px;
  transition: background 0.2s;
}

.dnd-npc-item:hover { background: var(--dnd-surface-muted); }

.dnd-npc-item--friend { --npc-border-color: var(--dnd-emerald); }
.dnd-npc-item--neutral { --npc-border-color: var(--dnd-gold); }
.dnd-npc-item--enemy { --npc-border-color: var(--dnd-danger); }
.dnd-npc-item.is-active { background: var(--dnd-surface-muted); }

.dnd-npc-item.is-dead {
  opacity: 0.5;
  border-style: dashed;
}

/* Live metrics */
.dnd-live-metrics {
  max-height: 360px;
  overflow-y: auto;
  padding-right: 4px;
  display: grid;
  gap: 8px;
}

.dnd-live-metrics-group {
  background: var(--dnd-surface-soft);
  padding: 10px;
  display: grid;
  gap: 8px;
}

.dnd-live-metrics-group__title {
  margin: 0;
  color: var(--dnd-accent);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.dnd-live-metrics-group__list { display: grid; gap: 4px; }

.dnd-live-metric {
  background: var(--dnd-surface);
  padding: 8px 10px;
  display: grid;
  gap: 4px;
}

.dnd-live-metric__head {
  margin: 0;
  display: flex;
  justify-content: space-between;
  gap: 8px;
  font-size: 15px;
  font-weight: 700;
  color: var(--dnd-ink);
}

.dnd-live-metric__bar {
  height: 5px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.3);
  overflow: hidden;
}

.dnd-live-metric__bar-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--dnd-purple) 0%, var(--dnd-accent) 100%);
  transition: width 0.5s ease;
}

/* Gear tabs */
.dnd-gear-tabs,
.dnd-game-tabs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3px;
  padding: 3px;
  border-radius: var(--dnd-r-sm);
  background: rgba(0, 0, 0, 0.3);
}

.dnd-gear-tab-panels,
.dnd-game-tab-panels {
  min-height: 0;
  display: grid;
  gap: 10px;
}

.dnd-gear-tab-panel,
.dnd-game-tab-panel { display: none; gap: 10px; }

.dnd-gear-tab-panel.is-active,
.dnd-game-tab-panel.is-active { display: grid; }

/* Progression */
.dnd-progression-launch {
  margin-top: 8px;
  display: grid;
  gap: 6px;
}

.dnd-progression-launch .button { width: 100%; }

/* ===== COLLAPSIBLE ===== */
.dnd-collapsible-card { transition: border-color 0.2s, background 0.2s; }

.dnd-collapsible-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.dnd-collapsible-head .button {
  min-height: 28px;
  padding: 5px 12px;
  font-size: 11px;
}

.dnd-collapsible-toggle { min-width: 84px; }

.dnd-collapsible-card.is-collapsed > *:not(.dnd-collapsible-head) {
  display: none !important;
}

/* ===== DIALOGS ===== */
.dnd-character-builder-dialog,
.dnd-progression-dialog,
.dnd-content-report-dialog {
  width: min(1120px, calc(100vw - 32px));
  max-height: min(92vh, 920px);
  border: 1px solid var(--dnd-line-strong);
  border-radius: var(--dnd-r-xl);
  padding: 0;
  background: var(--dnd-surface);
  box-shadow: var(--dnd-shadow-xl);
  color: var(--dnd-ink);
}

.dnd-character-builder-dialog::backdrop,
.dnd-progression-dialog::backdrop,
.dnd-content-report-dialog::backdrop {
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(8px);
}

.dnd-character-builder-dialog__layout,
.dnd-progression-dialog__layout,
.dnd-content-report-dialog__layout {
  padding: 20px;
  display: grid;
  gap: 12px;
}

.dnd-character-builder-dialog__head,
.dnd-progression-dialog__head,
.dnd-content-report-dialog__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.dnd-character-builder-dialog__head h3,
.dnd-progression-dialog__head h3,
.dnd-content-report-dialog__head h3 { margin: 0; }

.dnd-character-builder-dialog__content {
  max-height: min(72vh, 760px);
  overflow-y: auto;
  padding-right: 4px;
  display: grid;
  gap: 12px;
}

.dnd-content-report-list {
  max-height: min(72vh, 760px);
  overflow-y: auto;
  padding-right: 4px;
  display: grid;
  gap: 10px;
}

.dnd-content-report-entry {
  border: 1px solid var(--dnd-line);
  border-radius: var(--dnd-r-md);
  background: var(--dnd-surface-soft);
  padding: 10px 12px;
  display: grid;
  gap: 8px;
}

.dnd-content-report-entry[data-tone="success"] {
  border-color: rgba(61, 220, 132, 0.35);
}

.dnd-content-report-entry[data-tone="error"] {
  border-color: rgba(255, 85, 85, 0.35);
}

.dnd-content-report-entry[data-tone="info"] {
  border-color: var(--dnd-line-strong);
}

.dnd-content-report-entry__title {
  margin: 0;
  font-size: 12px;
  font-weight: 700;
  opacity: 0.85;
}

.dnd-content-report-entry__body {
  margin: 0;
  white-space: pre-wrap;
  word-break: break-word;
}

.dnd-content-report-entry__details summary {
  cursor: pointer;
  font-size: 12px;
  opacity: 0.85;
}

.dnd-content-report-entry__json {
  margin: 8px 0 0;
  padding: 8px;
  border-radius: var(--dnd-r-sm);
  background: var(--dnd-surface);
  border: 1px solid var(--dnd-line);
  max-height: 280px;
  overflow: auto;
  white-space: pre-wrap;
  word-break: break-word;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  font-size: 12px;
  line-height: 1.35;
}

.dnd-progression-columns {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.dnd-progression-column {
  padding: 12px;
  display: grid;
  gap: 10px;
  align-content: start;
  background: var(--dnd-surface-soft);
}

.dnd-progression-column h4 {
  margin: 0;
  font-size: 13px;
  font-weight: 800;
}

.dnd-progression-column--taken { margin-top: 2px; }

.dnd-progression-list {
  max-height: 260px;
  overflow-y: auto;
  padding-right: 2px;
}

.dnd-progression-item { background: var(--dnd-surface); }

/* ===== GAME MODES ===== */
#tab-play[data-game-mode="travel"] .dnd-play-feed {
  border: 1px solid var(--dnd-line);
  border-radius: var(--dnd-r-lg);
  padding: 14px;
  background: var(--dnd-surface-soft);
}

#tab-play[data-game-mode="travel"] .dnd-play-console {
  border-left: 2px solid rgba(61, 220, 132, 0.15);
  padding-left: 12px;
}

#tab-play[data-game-mode="combat"] .dnd-play-feed {
  border: 1px solid rgba(255, 85, 85, 0.15);
  border-radius: var(--dnd-r-lg);
  padding: 14px;
  background: rgba(255, 85, 85, 0.02);
}

#tab-play[data-game-mode="combat"] .dnd-play-console {
  border-left: 2px solid rgba(255, 85, 85, 0.2);
  padding-left: 12px;
}

#tab-play[data-game-mode="dialog"] .dnd-play-feed {
  border: 1px solid var(--dnd-accent-quiet);
  border-radius: var(--dnd-r-lg);
  padding: 14px;
  background: rgba(201, 160, 64, 0.02);
}

#tab-play[data-game-mode="dialog"] .dnd-play-console {
  border-left: 2px solid var(--dnd-accent-quiet);
  padding-left: 12px;
}

/* ===== SCROLLBARS ===== */
.dnd-session-list-wrap,
.dnd-log,
.dnd-live-metrics,
.dnd-npc-list,
.dnd-character-builder-dialog__content,
.dnd-progression-list,
.dnd-content-report-list,
.dnd-tab-panel {
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.12) transparent;
}

.dnd-session-list-wrap::-webkit-scrollbar,
.dnd-log::-webkit-scrollbar,
.dnd-live-metrics::-webkit-scrollbar,
.dnd-npc-list::-webkit-scrollbar,
.dnd-character-builder-dialog__content::-webkit-scrollbar,
.dnd-progression-list::-webkit-scrollbar,
.dnd-content-report-list::-webkit-scrollbar,
.dnd-tab-panel::-webkit-scrollbar {
  width: 5px;
}

.dnd-session-list-wrap::-webkit-scrollbar-track,
.dnd-log::-webkit-scrollbar-track,
.dnd-live-metrics::-webkit-scrollbar-track,
.dnd-npc-list::-webkit-scrollbar-track,
.dnd-character-builder-dialog__content::-webkit-scrollbar-track,
.dnd-progression-list::-webkit-scrollbar-track,
.dnd-content-report-list::-webkit-scrollbar-track,
.dnd-tab-panel::-webkit-scrollbar-track {
  background: transparent;
}

.dnd-session-list-wrap::-webkit-scrollbar-thumb,
.dnd-log::-webkit-scrollbar-thumb,
.dnd-live-metrics::-webkit-scrollbar-thumb,
.dnd-npc-list::-webkit-scrollbar-thumb,
.dnd-character-builder-dialog__content::-webkit-scrollbar-thumb,
.dnd-progression-list::-webkit-scrollbar-thumb,
.dnd-content-report-list::-webkit-scrollbar-thumb,
.dnd-tab-panel::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.15);
}

.dnd-session-list-wrap::-webkit-scrollbar-thumb:hover,
.dnd-log::-webkit-scrollbar-thumb:hover,
.dnd-live-metrics::-webkit-scrollbar-thumb:hover,
.dnd-npc-list::-webkit-scrollbar-thumb:hover,
.dnd-content-report-list::-webkit-scrollbar-thumb:hover,
.dnd-tab-panel::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.25);
}

/* ===== ANIMATIONS ===== */
.dnd-main .dnd-shell,
.dnd-main .dnd-sidebar,
.dnd-main .dnd-workspace,
.dnd-main .dnd-tab-panel.is-active {
  animation: dnd-rise 0.4s cubic-bezier(0.16, 1, 0.3, 1) both;
}

.dnd-main .dnd-shell { animation-delay: 0.04s; }
.dnd-main .dnd-sidebar { animation-delay: 0.08s; }
.dnd-main .dnd-workspace { animation-delay: 0.14s; }

@keyframes dnd-rise {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .dnd-main .dnd-shell,
  .dnd-main .dnd-sidebar,
  .dnd-main .dnd-workspace,
  .dnd-main .dnd-tab-panel.is-active { animation: none; }

  .dnd-main .button,
  .dnd-unified-tab,
  .dnd-gear-tabs__button,
  .dnd-game-tabs__button,
  .dnd-mode-switch__button { transition: none; }
}

/* ===== RESPONSIVE ===== */
@media (max-width: 1360px) {
  .dnd-tab-layout--character-metrics {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1180px) {
  .dnd-main {
    min-height: calc(100vh - 70px);
    height: auto;
    overflow: visible;
    padding: 10px;
    gap: 10px;
  }

  .dnd-shell,
  .dnd-shell[data-workspace="game"] {
    height: auto;
    grid-template-columns: 1fr;
    align-items: start;
  }

  .dnd-sidebar {
    position: relative;
    top: 0;
    max-height: none;
  }

  .dnd-workspace,
  .dnd-tab-panels,
  .dnd-tab-panel { overflow: visible; }

  #tab-play.is-active { overflow: visible; grid-template-rows: auto auto auto; }

  .dnd-play-layout {
    grid-template-columns: 1fr;
    overflow: visible;
  }

  .dnd-play-feed,
  .dnd-play-console { overflow: visible; }

  .dnd-play-feed--story {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
  }

  .dnd-play-feed--story > .dnd-scene__content {
    grid-column: 1;
    grid-row: 1;
  }

  .dnd-play-feed--story > .dnd-log {
    grid-column: 1;
    grid-row: 2;
    max-height: 260px;
  }

  .dnd-play-feed--story > .dnd-log--system {
    grid-column: 1;
    grid-row: 3;
    max-height: 160px;
  }

  .dnd-play-console--controls { max-height: none; }

  .dnd-tab-layout--world,
  .dnd-tab-layout--character-top {
    grid-template-columns: 1fr;
  }

  #tab-play[data-game-mode="travel"] .dnd-play-console,
  #tab-play[data-game-mode="combat"] .dnd-play-console,
  #tab-play[data-game-mode="dialog"] .dnd-play-console {
    border-left: 0;
    padding-left: 0;
  }
}

@media (max-width: 940px) {
  .dnd-main { padding: 8px; }

  .dnd-workspace,
  .dnd-sidebar { padding: 12px; }

  .dnd-sidebar__head {
    flex-direction: column;
    align-items: stretch;
  }

  .dnd-sidebar__head .button--ghost { width: 100%; }

  .dnd-unified-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .dnd-unified-tab {
    flex: 0 0 auto;
    min-width: 80px;
  }

  .dnd-grid--two,
  .dnd-grid--three,
  .dnd-grid--six,
  .dnd-mode-switch,
  .dnd-mode-actions,
  .dnd-progression-columns,
  .dnd-gear-tabs,
  .dnd-game-tabs {
    grid-template-columns: 1fr;
  }

  .dnd-item { flex-direction: column; }

  .dnd-game-hud {
    gap: 8px;
    padding: 8px 12px;
  }

  .dnd-game-hud__name { max-width: 120px; }
  .dnd-game-hud__stats { margin-left: 0; }
  .dnd-action-bar { padding: 10px 12px; }
}

@media (max-width: 620px) {
  .dnd-main { min-height: calc(100vh - 92px); }

  .dnd-workspace__head h2 { font-size: clamp(16px, 6vw, 22px); }

  .dnd-workspace__toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .dnd-workspace__toolbar-right {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 8px;
  }

  .dnd-sidebar .dnd-session-item__actions {
    grid-template-columns: repeat(2, 1fr);
  }

  .dnd-sidebar .dnd-session-item__actions .button.button--danger {
    grid-column: 1 / -1;
  }

  .dnd-action-bar__row {
    flex-direction: column;
  }

  .dnd-action-bar__row .textarea { min-height: 56px; }

  .dnd-action-bar__send {
    width: 100%;
    min-height: 40px;
  }

  .dnd-game-hud {
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
  }

  .dnd-game-hud__hp { max-width: 100%; }
  .dnd-game-hud__char { justify-content: space-between; }

  .dnd-log {
    min-height: 120px;
    max-height: 300px;
  }

  .dnd-progression-columns {
    grid-template-columns: 1fr;
  }

  .dnd-collapsible-head {
    flex-direction: column;
    align-items: stretch;
  }

  .dnd-collapsible-head .button {
    width: 100%;
  }

  .dnd-tab-layout--character-top {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .dnd-main { padding: 6px; }

  .dnd-workspace,
  .dnd-sidebar { padding: 10px; }

  .dnd-workspace__head { padding: 10px; }

  .dnd-form,
  .dnd-scene,
  .dnd-console-card { padding: 12px; }

  .dnd-unified-tab {
    padding: 6px 10px;
    font-size: 12px;
    min-width: 60px;
  }

  .dnd-log-entry {
    padding: 8px 10px;
  }

  .dnd-log-entry__body {
    font-size: 14px;
    line-height: 1.6;
  }

  .dnd-log-entry__head {
    font-size: 11px;
  }

  .dnd-action-bar {
    padding: 8px 10px;
  }

  .dnd-action-bar__send {
    padding: 8px 16px;
    font-size: 14px;
  }

  .dnd-character-builder-dialog,
  .dnd-progression-dialog,
  .dnd-content-report-dialog {
    width: calc(100vw - 16px);
    max-height: 95vh;
  }

  .dnd-character-builder-dialog__layout,
  .dnd-progression-dialog__layout,
  .dnd-content-report-dialog__layout {
    padding: 14px;
  }

  .dnd-sidebar__section { padding: 10px; }

  .dnd-game-hud__stat {
    padding: 3px 8px;
    font-size: 12px;
  }

  .dnd-game-hud__name {
    font-size: 15px;
    max-width: 140px;
  }

  .dnd-game-hud__mode {
    padding: 4px 12px;
    font-size: 12px;
  }

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

  .dnd-game-toggle {
    width: 100%;
    justify-content: center;
    padding: 10px 16px;
    font-size: 13px;
  }

  .dnd-sidebar__head h2 {
    font-size: 17px;
  }

  .dnd-session-item__title {
    font-size: 12px;
  }

  .dnd-form h3,
  .dnd-scene h3,
  .dnd-console-card h3 {
    font-size: 15px;
  }
}

/* === Multiplayer UI === */

/* Connection indicator */
.dnd-connection-indicator {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.3px;
  margin-bottom: 8px;
  background: var(--dnd-glass);
  border: 1px solid var(--dnd-glass-border);
}
.dnd-connection-indicator::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #666;
}
.dnd-connection-indicator[data-status="connected"] { color: #3ddc84; background: rgba(61,220,132,0.08); border-color: rgba(61,220,132,0.15); }
.dnd-connection-indicator[data-status="connected"]::before { background: #3ddc84; box-shadow: 0 0 8px #3ddc84; }
.dnd-connection-indicator[data-status="connecting"],
.dnd-connection-indicator[data-status="reconnecting"] { color: #ffb86c; background: rgba(255,184,108,0.08); border-color: rgba(255,184,108,0.15); }
.dnd-connection-indicator[data-status="connecting"]::before,
.dnd-connection-indicator[data-status="reconnecting"]::before { background: #ffb86c; animation: dnd-pulse 1.2s ease-in-out infinite; }
.dnd-connection-indicator[data-status="fallback"] { color: #80bfff; background: rgba(128,191,255,0.08); border-color: rgba(128,191,255,0.15); }
.dnd-connection-indicator[data-status="fallback"]::before { background: #80bfff; }
.dnd-connection-indicator[data-status="disconnected"] { color: #706d82; background: rgba(112,109,130,0.08); border-color: rgba(112,109,130,0.15); }
.dnd-connection-indicator[data-status="disconnected"]::before { background: #706d82; }

/* Room status bar */
.dnd-room-status {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}
.dnd-room-status--connected {
  padding: 8px 12px;
  background: var(--dnd-glass);
  border: 1px solid var(--dnd-glass-border);
  border-radius: 8px;
}
.dnd-room-status__code {
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 1.5px;
  color: var(--dnd-accent);
}
.dnd-room-status__players,
.dnd-room-status__round {
  font-size: 12px;
  color: var(--dnd-ink-muted);
  padding-top: 2px;
}
.dnd-room-status__turn {
  font-size: 12px;
  color: #ffb86c;
  font-weight: 600;
  padding-top: 2px;
}
.dnd-room-status__turn--mine {
  color: var(--dnd-emerald);
  animation: dnd-pulse 1.5s ease-in-out infinite;
}

/* Player cards */
.dnd-player-cards {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}
.dnd-player-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--dnd-glass);
  border: 1px solid var(--dnd-glass-border);
  border-radius: 10px;
  min-width: 180px;
  flex: 1 1 180px;
  transition: border-color 0.2s;
}
.dnd-player-card--online {
  border-color: rgba(61,220,132,0.25);
}
.dnd-player-card--offline {
  opacity: 0.5;
}
.dnd-player-card__avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--dnd-purple) 0%, var(--dnd-accent) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 16px;
  color: #fff;
  flex-shrink: 0;
}
.dnd-player-card__info {
  flex: 1;
  min-width: 0;
}
.dnd-player-card__name {
  font-size: 14px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--dnd-ink);
}
.dnd-player-card__badge {
  font-size: 10px;
  padding: 1px 6px;
  background: var(--dnd-accent-quiet);
  color: var(--dnd-accent);
  border-radius: 4px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.dnd-player-card__meta {
  font-size: 11px;
  color: var(--dnd-ink-muted);
  margin-top: 2px;
}
.dnd-player-card__status-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.dnd-player-card--online .dnd-player-card__status-dot {
  background: var(--dnd-emerald);
  box-shadow: 0 0 8px rgba(61,220,132,0.5);
}
.dnd-player-card--offline .dnd-player-card__status-dot {
  background: #555;
}

/* Character grid */
.dnd-character-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}
.dnd-character-card {
  padding: 10px 12px;
  background: var(--dnd-glass);
  border: 2px solid var(--dnd-glass-border);
  border-radius: 10px;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
}
.dnd-character-card:hover {
  border-color: rgba(255,255,255,0.12);
  background: var(--dnd-surface-soft);
}
.dnd-character-card--selected {
  border-color: var(--dnd-blue);
  background: var(--dnd-blue-soft);
}
.dnd-character-card--mine {
  border-color: rgba(61,220,132,0.35);
}
.dnd-character-card--free {
  border-color: rgba(201,160,64,0.25);
}
.dnd-character-card__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 4px;
}
.dnd-character-card__name {
  font-weight: 700;
  font-size: 13px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--dnd-ink);
}
.dnd-character-card__level {
  font-size: 11px;
  color: var(--dnd-ink-muted);
  flex-shrink: 0;
}
.dnd-character-card__info {
  font-size: 11px;
  color: var(--dnd-ink-muted);
  margin-bottom: 6px;
}
.dnd-character-card__hp {
  position: relative;
  height: 16px;
  background: rgba(0,0,0,0.3);
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: 6px;
}
.dnd-character-card__hp-bar {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  background: linear-gradient(90deg, #ff5555, #3ddc84);
  border-radius: 4px;
  transition: width 0.3s;
}
.dnd-character-card__hp-text {
  position: relative;
  z-index: 1;
  display: block;
  text-align: center;
  font-size: 10px;
  font-weight: 600;
  line-height: 16px;
  color: #fff;
  text-shadow: 0 1px 2px rgba(0,0,0,0.6);
}
.dnd-character-card__owner {
  font-size: 10px;
  color: var(--dnd-ink-muted);
  text-align: center;
}

/* Turn bar */
.dnd-turn-bar {
  padding: 8px 14px;
  background: var(--dnd-glass);
  border: 1px solid var(--dnd-glass-border);
  border-radius: 8px;
  font-size: 13px;
  margin-bottom: 8px;
  color: var(--dnd-ink-soft);
}
.dnd-turn-bar[data-state="ready"] {
  border-color: rgba(61,220,132,0.25);
  color: var(--dnd-emerald);
}
.dnd-turn-bar[data-state="wait"] {
  border-color: rgba(255,184,108,0.25);
  color: #ffb86c;
}

/* Turn order */
.dnd-turn-order {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

@media (max-width: 620px) {
  .dnd-player-cards { flex-direction: column; }
  .dnd-character-grid { grid-template-columns: 1fr 1fr; }
  .dnd-room-status { flex-direction: column; gap: 4px; }
  .dnd-player-card { min-width: 0; }
}

@media (max-width: 480px) {
  .dnd-character-grid { grid-template-columns: 1fr; }
  .dnd-player-card { padding: 8px 10px; }
  .dnd-player-card__avatar { width: 30px; height: 30px; font-size: 13px; }
}
