:root {
  --bg: #050b0a;
  --bg-2: #081311;
  --panel: rgba(17, 24, 23, 0.74);
  --panel-strong: rgba(22, 30, 29, 0.92);
  --panel-soft: rgba(255,255,255,0.055);
  --line: rgba(255,255,255,0.11);
  --line-soft: rgba(255,255,255,0.065);
  --text: #f3f5ef;
  --muted: rgba(243,245,239,0.66);
  --faint: rgba(243,245,239,0.42);
  --good: #d7e9dd;
  --bad: #ecd4d4;
  --accent: #f3f5ef;
  --shadow: 0 18px 70px rgba(0,0,0,0.46);
  --shadow-soft: 0 12px 42px rgba(0,0,0,0.26);
  --radius: 26px;
  --radius-sm: 16px;
  --radius-xs: 12px;
  --gap: 16px;
  --font: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", Inter, "Segoe UI", Roboto, Arial, sans-serif;
}

[data-theme="graphite"] {
  --bg: #08080a;
  --bg-2: #121216;
  --panel: rgba(24, 24, 29, 0.76);
  --panel-strong: rgba(32, 32, 38, 0.94);
  --accent: #f1f1f2;
}

[data-theme="midnight"] {
  --bg: #05080f;
  --bg-2: #0b1220;
  --panel: rgba(14, 20, 33, 0.76);
  --panel-strong: rgba(20, 28, 44, 0.94);
  --accent: #eff4ff;
}

[data-theme="velvet"] {
  --bg: #0d070a;
  --bg-2: #160d11;
  --panel: rgba(30, 18, 22, 0.76);
  --panel-strong: rgba(37, 24, 28, 0.94);
  --accent: #fff4f6;
}

* { box-sizing: border-box; }
html { min-height: 100%; background: var(--bg); }
body {
  margin: 0;
  min-height: 100vh;
  min-height: 100dvh;
  font-family: var(--font);
  color: var(--text);
  background:
    radial-gradient(circle at 18% 8%, rgba(76, 126, 106, 0.26), transparent 34%),
    radial-gradient(circle at 82% 18%, rgba(84, 103, 122, 0.18), transparent 34%),
    linear-gradient(160deg, var(--bg), #030807 56%, var(--bg-2));
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image: url('../assets/background.jpg');
  background-size: cover;
  background-position: center;
  opacity: .22;
  mix-blend-mode: screen;
  filter: saturate(.65) contrast(1.1);
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 92px 92px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.5), transparent 88%);
  opacity: .5;
}

#noise {
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .14;
  mix-blend-mode: overlay;
  background-image: radial-gradient(rgba(255,255,255,.3) .5px, transparent .5px);
  background-size: 3px 3px;
}

a { color: inherit; }
button, input, textarea, select { font: inherit; }
button { color: inherit; }

.app-shell {
  position: relative;
  z-index: 1;
  min-height: 100vh;
  min-height: 100dvh;
  padding: max(18px, env(safe-area-inset-top)) max(18px, env(safe-area-inset-right)) max(18px, env(safe-area-inset-bottom)) max(18px, env(safe-area-inset-left));
}

.boot-card {
  width: min(520px, calc(100vw - 36px));
  margin: 12vh auto 0;
  padding: 34px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow);
  backdrop-filter: blur(24px);
  text-align: center;
}

.brand-mark {
  width: 64px;
  height: 64px;
  border-radius: 22px;
  display: grid;
  place-items: center;
  margin: 0 auto 14px;
  background: rgba(255,255,255,.1);
  border: 1px solid var(--line);
  font-size: 34px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.1), var(--shadow-soft);
}

h1, h2, h3, h4, p { margin-top: 0; }
h1 { font-size: clamp(36px, 7vw, 82px); letter-spacing: -0.065em; line-height: .92; margin-bottom: 14px; }
h2 { font-size: clamp(24px, 4vw, 44px); letter-spacing: -0.045em; margin-bottom: 10px; }
h3 { font-size: 20px; letter-spacing: -0.025em; margin-bottom: 10px; }
h4 { font-size: 15px; letter-spacing: -0.015em; margin-bottom: 8px; }
p { color: var(--muted); line-height: 1.55; }
small { color: var(--faint); }

.hidden { display: none !important; }
.muted { color: var(--muted); }
.faint { color: var(--faint); }
.nowrap { white-space: nowrap; }
.mono { font-variant-numeric: tabular-nums; }

.portal {
  width: min(1180px, 100%);
  margin: 0 auto;
  display: grid;
  gap: 20px;
}

.hero {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 20px;
  align-items: stretch;
  min-height: 480px;
}

.hero-card, .card, .panel, .floating-panel {
  border: 1px solid var(--line);
  background: var(--panel);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  backdrop-filter: blur(26px);
}

.hero-card {
  padding: clamp(28px, 6vw, 64px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
  position: relative;
}

.hero-card::after {
  content: "";
  position: absolute;
  width: 360px;
  height: 360px;
  border-radius: 999px;
  right: -120px;
  top: -120px;
  background: radial-gradient(circle, rgba(255,255,255,.13), transparent 64%);
  pointer-events: none;
}

.hero-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: max-content;
  padding: 8px 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: rgba(255,255,255,.05);
  font-size: 13px;
}

.hero-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; }

.portal-side {
  display: grid;
  gap: 14px;
}

.card {
  padding: 22px;
}

.card.compact { padding: 16px; border-radius: 20px; box-shadow: var(--shadow-soft); }

.feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.feature-card {
  padding: 18px;
  min-height: 130px;
  border-radius: 22px;
  border: 1px solid var(--line-soft);
  background: rgba(255,255,255,.045);
}

.feature-icon { font-size: 25px; margin-bottom: 12px; opacity: .88; }

.input, .textarea, .select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 13px 14px;
  color: var(--text);
  background: rgba(0,0,0,.22);
  outline: none;
  transition: border-color .16s ease, background .16s ease, box-shadow .16s ease;
}

.textarea { min-height: 96px; resize: vertical; line-height: 1.45; }
.input:focus, .textarea:focus, .select:focus {
  border-color: rgba(255,255,255,.35);
  background: rgba(0,0,0,.32);
  box-shadow: 0 0 0 4px rgba(255,255,255,.06);
}

label.field {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 13px;
}

.field-row { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.field-row.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.field-row.auto { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }

.btn {
  border: 1px solid var(--line);
  background: rgba(255,255,255,.08);
  border-radius: 999px;
  padding: 12px 16px;
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  cursor: pointer;
  user-select: none;
  text-decoration: none;
  transition: transform .14s ease, background .14s ease, border-color .14s ease, opacity .14s ease;
}

.btn:hover { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.2); }
.btn:active { transform: scale(.985); }
.btn[disabled] { opacity: .48; cursor: not-allowed; transform: none; }
.btn.primary { color: #050807; background: var(--accent); border-color: transparent; font-weight: 720; }
.btn.ghost { background: transparent; }
.btn.soft { background: rgba(255,255,255,.055); }
.btn.danger { background: rgba(236, 212, 212, .12); border-color: rgba(236, 212, 212, .24); }
.btn.good { background: rgba(215, 233, 221, .12); border-color: rgba(215, 233, 221, .24); }
.btn.block { width: 100%; }
.btn.sm { min-height: 34px; padding: 7px 10px; font-size: 13px; }
.btn.square { width: 46px; padding-left: 0; padding-right: 0; border-radius: 16px; }
.btn.big { min-height: 58px; padding: 16px 22px; font-size: 18px; border-radius: 22px; }

.link-box {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: center;
  padding: 8px;
  border-radius: 18px;
  border: 1px solid var(--line-soft);
  background: rgba(0,0,0,.2);
}
.link-box input { border: none; background: transparent; color: var(--muted); padding: 8px; min-width: 0; outline: none; }

.topbar {
  position: sticky;
  top: max(12px, env(safe-area-inset-top));
  z-index: 30;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: center;
  width: min(1440px, 100%);
  margin: 0 auto 16px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(8, 14, 13, 0.72);
  backdrop-filter: blur(22px);
  box-shadow: var(--shadow-soft);
}

.brand-inline {
  display: flex;
  gap: 10px;
  align-items: center;
  min-width: 0;
}
.brand-inline .brand-mark { width: 42px; height: 42px; border-radius: 15px; margin: 0; font-size: 23px; }
.brand-title { font-weight: 760; letter-spacing: -0.025em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.brand-subtitle { font-size: 12px; color: var(--faint); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.tabs {
  display: flex;
  gap: 6px;
  justify-content: center;
  flex-wrap: wrap;
}
.tab {
  min-height: 38px;
  border-radius: 999px;
  padding: 8px 12px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
}
.tab.active { color: var(--text); background: rgba(255,255,255,.09); border-color: var(--line); }

.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 11px;
  border-radius: 999px;
  color: var(--muted);
  background: rgba(255,255,255,.055);
  border: 1px solid var(--line-soft);
  white-space: nowrap;
  font-size: 13px;
}
.status-dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(243,245,239,.36); box-shadow: 0 0 0 4px rgba(243,245,239,.05); }
.status-dot.ok { background: #d7e9dd; }
.status-dot.warn { background: #ede0c7; }
.status-dot.bad { background: #ecd4d4; }

.layout {
  width: min(1440px, 100%);
  margin: 0 auto;
  display: grid;
  gap: 16px;
}

.layout.two {
  grid-template-columns: minmax(320px, 420px) 1fr;
  align-items: start;
}

.sidebar {
  display: grid;
  gap: 12px;
  position: sticky;
  top: 96px;
}

.panel { padding: 18px; }
.panel-title { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.panel-title h2, .panel-title h3 { margin: 0; }

.stack { display: grid; gap: 12px; }
.stack.sm { gap: 8px; }
.stack.lg { gap: 18px; }
.inline { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.inline.between { justify-content: space-between; }
.inline.end { justify-content: flex-end; }

.round-list { display: grid; gap: 8px; }
.round-chip {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: center;
  padding: 12px;
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  background: rgba(255,255,255,.045);
  cursor: pointer;
  text-align: left;
}
.round-chip.active { border-color: rgba(255,255,255,.24); background: rgba(255,255,255,.095); }
.round-chip .type { font-size: 12px; color: var(--faint); }

.team-grid { display: grid; gap: 10px; }
.team-card, .player-card, .question-card, .media-card, .album-card, .battle-cell-editor {
  border: 1px solid var(--line-soft);
  border-radius: 20px;
  background: rgba(255,255,255,.045);
  box-shadow: 0 1px 0 rgba(255,255,255,.035) inset;
}
.team-card, .player-card { padding: 12px; }
.score-badge {
  min-width: 44px;
  height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.1);
  border: 1px solid var(--line-soft);
  font-weight: 760;
  font-variant-numeric: tabular-nums;
}

.roster-table { display: grid; gap: 8px; }
.roster-row {
  display: grid;
  grid-template-columns: 1.1fr .9fr auto;
  gap: 8px;
  align-items: center;
  padding: 10px;
  border-radius: 18px;
  border: 1px solid var(--line-soft);
  background: rgba(255,255,255,.04);
}

.segmented {
  display: flex;
  padding: 4px;
  border-radius: 999px;
  border: 1px solid var(--line-soft);
  background: rgba(0,0,0,.18);
  gap: 3px;
}
.segmented button { flex: 1; min-height: 34px; border-radius: 999px; border: 0; color: var(--muted); background: transparent; cursor: pointer; }
.segmented button.active { color: var(--text); background: rgba(255,255,255,.1); }

.host-round {
  display: grid;
  gap: 14px;
}
.round-header-card {
  display: grid;
  gap: 12px;
  padding: 18px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: var(--panel);
  backdrop-filter: blur(22px);
  box-shadow: var(--shadow-soft);
}

.jeopardy-editor { display: grid; gap: 16px; }
.category-editor {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line-soft);
  border-radius: 24px;
  background: rgba(255,255,255,.035);
}
.category-title-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 8px;
  align-items: center;
}
.questions-line {
  display: grid;
  grid-template-columns: repeat(8, minmax(92px, 1fr));
  gap: 8px;
}
.question-tile {
  min-height: 76px;
  display: grid;
  place-items: center;
  border-radius: 18px;
  border: 1px solid var(--line-soft);
  background: rgba(255,255,255,.045);
  cursor: pointer;
  position: relative;
  overflow: hidden;
}
.question-tile:hover { background: rgba(255,255,255,.08); }
.question-tile.used { opacity: .38; }
.question-tile.active { border-color: rgba(255,255,255,.35); background: rgba(255,255,255,.11); }
.question-tile .cost { font-size: 26px; font-weight: 760; letter-spacing: -.05em; }
.question-tile .mini { position: absolute; left: 8px; top: 7px; font-size: 11px; color: var(--faint); }

.question-inline-editor {
  grid-column: 1 / -1;
  padding: 14px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.15);
  background: rgba(0,0,0,.2);
  box-shadow: var(--shadow-soft);
}

.editor-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 14px;
  align-items: start;
}

.editor-actions {
  display: grid;
  gap: 8px;
}

.question-card { padding: 14px; }
.media-list { display: grid; gap: 10px; }
.media-card { padding: 12px; display: grid; gap: 10px; }
.media-preview {
  width: 100%;
  min-height: 120px;
  border-radius: 18px;
  overflow: hidden;
  background: rgba(0,0,0,.28);
  border: 1px solid var(--line-soft);
  display: grid;
  place-items: center;
}
.media-preview img, .media-preview video { width: 100%; height: 220px; object-fit: cover; }
.media-preview audio { width: 94%; }
.crop-preview { position: relative; width: 100%; height: 220px; overflow: hidden; border-radius: 18px; background: #030605; }
.crop-preview img { position: absolute; width: 100%; height: 100%; object-fit: cover; transform-origin: center; }
.slider-row { display: grid; grid-template-columns: 88px 1fr 56px; gap: 8px; align-items: center; color: var(--muted); font-size: 13px; }
input[type="range"] { width: 100%; accent-color: var(--accent); }

.break-preview {
  min-height: 360px;
  border-radius: var(--radius);
  border: 1px solid var(--line-soft);
  background: rgba(0,0,0,.22);
  display: grid;
  place-items: center;
  overflow: hidden;
}
.break-preview video { width: 100%; height: 100%; max-height: 520px; object-fit: contain; }

.albums-editor-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(140px, 1fr));
  gap: 10px;
}
.album-card { padding: 10px; display: grid; gap: 8px; }
.album-cover-thumb {
  aspect-ratio: 1 / 1;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--line-soft);
  background: rgba(0,0,0,.28);
  display: grid;
  place-items: center;
  position: relative;
}
.album-cover-thumb img { width: 100%; height: 100%; object-fit: cover; }
.cell-number {
  position: absolute;
  left: 8px;
  top: 8px;
  min-width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(5,8,7,.72);
  border: 1px solid var(--line-soft);
  font-weight: 760;
  font-size: 13px;
}

.battle-editor-grid {
  display: grid;
  grid-template-columns: minmax(350px, 560px) 1fr;
  gap: 14px;
  align-items: start;
}
.battle-grid {
  display: grid;
  grid-template-columns: repeat(10, 1fr);
  gap: 5px;
  padding: 10px;
  border: 1px solid var(--line-soft);
  border-radius: 24px;
  background: rgba(0,0,0,.2);
}
.battle-cell {
  aspect-ratio: 1 / 1;
  border-radius: 11px;
  border: 1px solid var(--line-soft);
  background: rgba(255,255,255,.04);
  display: grid;
  place-items: center;
  cursor: pointer;
  font-weight: 760;
  color: var(--muted);
  position: relative;
}
.battle-cell.ship { background: rgba(255,255,255,.11); }
.battle-cell.miss::after { content: "•"; color: var(--faint); font-size: 32px; }
.battle-cell.hit::after { content: "×"; color: var(--text); font-size: 24px; }
.battle-cell.active { outline: 2px solid rgba(255,255,255,.38); }
.battle-cell.used { opacity: .42; }
.battle-cell-editor { padding: 14px; }

.screen {
  min-height: calc(100dvh - 36px);
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 16px;
  width: min(1800px, 100%);
  margin: 0 auto;
}
.screen-scorebar {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) 1px minmax(250px, .65fr);
  gap: 14px;
  align-items: stretch;
  padding: 12px;
  border-radius: 26px;
  border: 1px solid var(--line);
  background: rgba(8,14,13,.74);
  backdrop-filter: blur(24px);
  box-shadow: var(--shadow-soft);
}
.score-separator { background: var(--line); border-radius: 999px; }
.screen-teams {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 8px;
}
.screen-team {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 18px;
  background: rgba(255,255,255,.065);
  border: 1px solid var(--line-soft);
  min-width: 0;
}
.screen-team-name { font-weight: 720; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.screen-team-score { font-size: clamp(20px, 2.4vw, 34px); font-weight: 820; letter-spacing: -.06em; font-variant-numeric: tabular-nums; }
.top-players { display: grid; gap: 6px; }
.top-player {
  display: grid;
  grid-template-columns: 28px 1fr auto;
  gap: 8px;
  align-items: center;
  padding: 7px 10px;
  border-radius: 15px;
  background: rgba(255,255,255,.045);
  color: var(--muted);
}
.top-player strong { color: var(--text); font-weight: 730; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.screen-stage {
  min-height: 0;
  border-radius: 32px;
  border: 1px solid var(--line);
  background: rgba(8, 14, 13, 0.56);
  backdrop-filter: blur(20px);
  box-shadow: var(--shadow);
  overflow: hidden;
  display: grid;
}
.stage-inner { padding: clamp(18px, 3vw, 34px); display: grid; gap: 18px; align-content: start; }
.stage-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--muted);
  font-size: clamp(13px, 1.5vw, 17px);
}
.stage-question {
  display: grid;
  gap: 18px;
  align-content: center;
  min-height: 100%;
}
.question-text-large {
  font-size: clamp(32px, 5vw, 82px);
  letter-spacing: -.055em;
  line-height: .98;
  text-align: center;
  margin: 0 auto;
  max-width: 1200px;
}
.answer-card-large {
  width: min(980px, 100%);
  margin: 0 auto;
  padding: clamp(20px, 3vw, 34px);
  border-radius: 30px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.09);
  text-align: center;
  box-shadow: var(--shadow-soft);
}
.answer-card-large .label { color: var(--faint); text-transform: uppercase; letter-spacing: .12em; font-size: 12px; margin-bottom: 8px; }
.answer-card-large .answer { font-size: clamp(28px, 4vw, 58px); letter-spacing: -.04em; font-weight: 780; }
.media-stage-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
  width: min(1300px, 100%);
  margin: 0 auto;
}
.stage-media {
  border-radius: 28px;
  overflow: hidden;
  background: rgba(0,0,0,.32);
  border: 1px solid var(--line-soft);
  min-height: 180px;
  display: grid;
  place-items: center;
}
.stage-media img, .stage-media video { width: 100%; max-height: 54vh; object-fit: contain; }
.stage-media audio { width: min(760px, 92%); }
.stage-media.image-crop { height: min(52vh, 620px); }
.stage-media.image-crop img { height: 100%; object-fit: cover; }

.screen-board {
  display: grid;
  gap: 12px;
}
.screen-jeopardy {
  display: grid;
  gap: 9px;
}
.screen-jeopardy-row {
  display: grid;
  grid-template-columns: 230px repeat(8, minmax(68px, 1fr));
  gap: 8px;
}
.screen-category-name, .screen-question-box {
  min-height: clamp(64px, 8vh, 98px);
  border-radius: 18px;
  border: 1px solid var(--line-soft);
  background: rgba(255,255,255,.065);
  display: grid;
  place-items: center;
  text-align: center;
  padding: 8px;
}
.screen-category-name { font-weight: 760; justify-content: start; text-align: left; }
.screen-question-box { font-size: clamp(22px, 3vw, 42px); font-weight: 820; letter-spacing: -.055em; }
.screen-question-box.used { opacity: .25; }
.screen-question-box.active { background: rgba(255,255,255,.13); border-color: rgba(255,255,255,.25); }

.screen-albums-grid {
  display: grid;
  grid-template-columns: repeat(10, 1fr);
  gap: 10px;
}
.screen-album {
  aspect-ratio: 1 / 1;
  border-radius: 18px;
  overflow: hidden;
  position: relative;
  background: rgba(255,255,255,.055);
  border: 1px solid var(--line-soft);
  display: grid;
  place-items: center;
}
.screen-album img { width: 100%; height: 100%; object-fit: cover; }
.screen-album.opened::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(8px);
}
.screen-album .album-answer {
  position: absolute;
  inset: 10px;
  display: grid;
  place-items: center;
  text-align: center;
  font-size: clamp(12px, 1.6vw, 20px);
  font-weight: 760;
  letter-spacing: -.03em;
}
.screen-album.used { opacity: .42; }

.screen-battle-wrap { display: grid; place-items: center; min-height: 100%; }
.screen-battle-grid {
  width: min(92vmin, 920px);
  display: grid;
  grid-template-columns: repeat(10, 1fr);
  gap: 8px;
  padding: 14px;
  border-radius: 30px;
  border: 1px solid var(--line-soft);
  background: rgba(0,0,0,.22);
}
.screen-battle-cell {
  aspect-ratio: 1 / 1;
  border-radius: clamp(10px, 1.2vw, 18px);
  border: 1px solid var(--line-soft);
  background: rgba(255,255,255,.045);
  display: grid;
  place-items: center;
  font-size: clamp(18px, 3vw, 38px);
  color: var(--muted);
  font-weight: 760;
}
.screen-battle-cell.miss::after { content: "•"; color: var(--faint); }
.screen-battle-cell.hit { background: rgba(255,255,255,.12); }
.screen-battle-cell.hit::after { content: "×"; color: var(--text); }
.screen-battle-cell.active { outline: 3px solid rgba(255,255,255,.38); }

.captain-shell {
  width: min(720px, 100%);
  margin: 0 auto;
  display: grid;
  gap: 14px;
}
.captain-score {
  padding: 24px;
  border-radius: 30px;
  border: 1px solid var(--line);
  background: var(--panel);
  backdrop-filter: blur(24px);
  box-shadow: var(--shadow);
}
.captain-score .score { font-size: clamp(62px, 18vw, 120px); line-height: .9; font-weight: 840; letter-spacing: -.08em; font-variant-numeric: tabular-nums; }
.captain-player {
  padding: 14px;
  border-radius: 24px;
  border: 1px solid var(--line-soft);
  background: rgba(255,255,255,.055);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: center;
}
.captain-player-name { font-size: 20px; font-weight: 760; letter-spacing: -.025em; }
.captain-player-score { color: var(--muted); font-variant-numeric: tabular-nums; }
.captain-controls { display: grid; grid-template-columns: 84px 84px; gap: 8px; }
.captain-controls .btn { min-height: 66px; border-radius: 22px; font-size: 26px; font-weight: 800; }

.toast {
  position: fixed;
  z-index: 200;
  left: 50%;
  bottom: calc(22px + env(safe-area-inset-bottom));
  transform: translateX(-50%) translateY(20px);
  opacity: 0;
  pointer-events: none;
  max-width: min(520px, calc(100vw - 28px));
  padding: 12px 16px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: rgba(16, 22, 21, .9);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(18px);
  color: var(--text);
  transition: opacity .2s ease, transform .2s ease;
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

.modal-backdrop {
  position: fixed;
  z-index: 100;
  inset: 0;
  padding: 18px;
  background: rgba(0,0,0,.54);
  display: grid;
  place-items: center;
}
.modal {
  width: min(860px, 100%);
  max-height: min(86dvh, 900px);
  overflow: auto;
  padding: 18px;
  border-radius: 28px;
  border: 1px solid var(--line);
  background: var(--panel-strong);
  box-shadow: var(--shadow);
  backdrop-filter: blur(28px);
}

.code-block {
  white-space: pre-wrap;
  overflow: auto;
  max-height: 420px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid var(--line-soft);
  background: rgba(0,0,0,.28);
  color: var(--muted);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 12px;
}

.empty-state {
  padding: 32px;
  text-align: center;
  border-radius: 24px;
  border: 1px dashed var(--line);
  background: rgba(255,255,255,.035);
  color: var(--muted);
}

.file-zone {
  border: 1px dashed rgba(255,255,255,.22);
  border-radius: 22px;
  padding: 16px;
  text-align: center;
  background: rgba(255,255,255,.035);
  cursor: pointer;
}
.file-zone input { display: none; }
.file-zone:hover { background: rgba(255,255,255,.06); }

.kbd {
  border: 1px solid var(--line-soft);
  border-bottom-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  border-radius: 8px;
  padding: 2px 6px;
  font-size: 12px;
  color: var(--muted);
}

@media (max-width: 1180px) {
  .hero { grid-template-columns: 1fr; min-height: auto; }
  .feature-grid { grid-template-columns: 1fr; }
  .layout.two { grid-template-columns: 1fr; }
  .sidebar { position: static; }
  .editor-grid, .battle-editor-grid { grid-template-columns: 1fr; }
  .albums-editor-grid { grid-template-columns: repeat(3, minmax(120px, 1fr)); }
  .questions-line { grid-template-columns: repeat(4, minmax(78px, 1fr)); }
  .screen-jeopardy-row { grid-template-columns: 170px repeat(8, minmax(54px, 1fr)); }
  .screen-albums-grid { grid-template-columns: repeat(6, 1fr); }
}

@media (max-width: 760px) {
  .app-shell { padding: 12px; }
  .topbar { grid-template-columns: 1fr; top: 8px; border-radius: 22px; }
  .tabs { justify-content: stretch; }
  .tab { flex: 1; }
  .field-row, .field-row.three { grid-template-columns: 1fr; }
  .roster-row { grid-template-columns: 1fr; }
  .category-title-row { grid-template-columns: 1fr; }
  .questions-line { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .question-tile { min-height: 72px; }
  .albums-editor-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .screen { min-height: calc(100dvh - 24px); gap: 10px; }
  .screen-scorebar { grid-template-columns: 1fr; gap: 8px; }
  .score-separator { height: 1px; width: 100%; }
  .screen-teams { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .screen-team { padding: 8px; border-radius: 14px; }
  .screen-stage { border-radius: 24px; }
  .screen-jeopardy-row { grid-template-columns: 1fr; gap: 5px; }
  .screen-category-name { min-height: 42px; justify-content: center; text-align: center; }
  .screen-jeopardy-row .screen-question-box { min-height: 48px; }
  .screen-albums-grid { grid-template-columns: repeat(3, 1fr); gap: 7px; }
  .screen-battle-grid { width: 100%; gap: 4px; padding: 8px; border-radius: 20px; }
  .screen-battle-cell { border-radius: 8px; }
  .captain-player { grid-template-columns: 1fr; }
  .captain-controls { grid-template-columns: 1fr 1fr; }
  .link-box { grid-template-columns: 1fr; }
}

@media (max-width: 420px) {
  .screen-teams { grid-template-columns: 1fr; }
  .captain-controls .btn { min-height: 60px; }
  .btn.big { width: 100%; }
}

/* ===== Raskayfovka v2: richer Apple-style themes and UX refinements ===== */
:root {
  --glow-a: rgba(54, 151, 119, .30);
  --glow-b: rgba(67, 105, 131, .24);
  --glow-c: rgba(226, 243, 226, .08);
  --background-dim: .55;
  --user-bg-image: url('../assets/background.jpg');
}

html[data-theme="aurora"] {
  --bg: #04100e;
  --bg-2: #071916;
  --panel: rgba(9, 24, 22, .66);
  --panel-strong: rgba(13, 29, 27, .91);
  --panel-soft: rgba(255,255,255,.07);
  --line: rgba(222, 244, 232, .14);
  --line-soft: rgba(222, 244, 232, .085);
  --text: #f5f8f2;
  --muted: rgba(245,248,242,.69);
  --faint: rgba(245,248,242,.45);
  --accent: #eff6ee;
  --glow-a: rgba(41, 155, 118, .34);
  --glow-b: rgba(65, 112, 142, .30);
  --glow-c: rgba(211, 244, 225, .11);
}

html[data-theme="studio"] {
  --bg: #080d0e;
  --bg-2: #121615;
  --panel: rgba(20, 27, 28, .68);
  --panel-strong: rgba(25, 31, 32, .94);
  --accent: #f0f2ed;
  --glow-a: rgba(164, 174, 166, .18);
  --glow-b: rgba(74, 89, 91, .26);
  --glow-c: rgba(255,255,255,.06);
}

html[data-theme="silver"] {
  --bg: #111614;
  --bg-2: #1c211f;
  --panel: rgba(35, 41, 38, .70);
  --panel-strong: rgba(39, 45, 43, .94);
  --accent: #f6f6f0;
  --glow-a: rgba(190, 209, 196, .22);
  --glow-b: rgba(134, 156, 161, .20);
  --glow-c: rgba(255,255,255,.10);
}

html[data-theme="graphite"] { --glow-a: rgba(155,155,160,.16); --glow-b: rgba(50,52,58,.28); --glow-c: rgba(255,255,255,.055); }
html[data-theme="midnight"] { --glow-a: rgba(41,83,128,.25); --glow-b: rgba(66,75,124,.26); --glow-c: rgba(223,235,255,.07); }
html[data-theme="velvet"] { --glow-a: rgba(129,61,83,.25); --glow-b: rgba(74,54,72,.24); --glow-c: rgba(255,228,235,.07); }

body {
  background:
    radial-gradient(circle at 18% 7%, var(--glow-a), transparent 34%),
    radial-gradient(circle at 78% 14%, var(--glow-b), transparent 33%),
    radial-gradient(circle at 62% 88%, var(--glow-c), transparent 38%),
    linear-gradient(160deg, var(--bg), #020807 56%, var(--bg-2));
}

body::before {
  background-image: var(--user-bg-image, url('../assets/background.jpg'));
  opacity: calc(.22 + (.18 * var(--background-dim)));
  filter: saturate(.78) contrast(1.12) brightness(.95);
}

body::after {
  background:
    linear-gradient(rgba(230,245,238,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(230,245,238,.043) 1px, transparent 1px);
  background-size: 86px 86px;
  opacity: calc(.18 + (.42 * var(--background-dim)));
}

.runtime-background-media {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
  opacity: calc(.18 + (.44 * var(--background-dim)));
  filter: saturate(.82) contrast(1.08) brightness(.72);
}
.runtime-background-media video { width: 100%; height: 100%; object-fit: cover; }

.hero-card, .card, .panel, .floating-panel, .round-header-card, .screen-scorebar, .screen-stage, .captain-score, .boot-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.028)),
    var(--panel);
  box-shadow: 0 20px 90px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.08);
}

html[data-surface-style="solid"] .hero-card,
html[data-surface-style="solid"] .card,
html[data-surface-style="solid"] .panel,
html[data-surface-style="solid"] .round-header-card,
html[data-surface-style="solid"] .screen-scorebar,
html[data-surface-style="solid"] .screen-stage,
html[data-surface-style="solid"] .captain-score {
  background: var(--panel-strong);
  backdrop-filter: none;
}

html[data-surface-style="minimal"] .hero-card,
html[data-surface-style="minimal"] .card,
html[data-surface-style="minimal"] .panel,
html[data-surface-style="minimal"] .round-header-card,
html[data-surface-style="minimal"] .screen-scorebar,
html[data-surface-style="minimal"] .screen-stage,
html[data-surface-style="minimal"] .captain-score {
  background: rgba(255,255,255,.035);
  box-shadow: none;
}

html[data-button-style="rounded"] .btn,
html[data-button-style="rounded"] .tab,
html[data-button-style="rounded"] .segmented,
html[data-button-style="rounded"] .segmented button { border-radius: 16px; }
html[data-button-style="glass"] .btn { background: rgba(255,255,255,.105); backdrop-filter: blur(18px); box-shadow: inset 0 1px 0 rgba(255,255,255,.08); }
html[data-button-style="flat"] .btn { background: transparent; box-shadow: none; }
html[data-button-style="flat"] .btn.primary { background: var(--accent); }

html[data-scale="compact"] .app-shell { padding: 12px; }
html[data-scale="compact"] .btn { min-height: 40px; padding: 9px 13px; }
html[data-scale="compact"] .panel { padding: 14px; }
html[data-scale="large"] .btn { min-height: 54px; padding: 14px 20px; font-size: 17px; }
html[data-scale="large"] .panel { padding: 24px; }
html[data-scale="large"] .input,
html[data-scale="large"] .textarea,
html[data-scale="large"] .select { padding: 15px 16px; border-radius: 18px; }

.theme-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 10px;
}
.theme-card {
  min-height: 112px;
  border-radius: 24px;
  border: 1px solid var(--line-soft);
  background:
    radial-gradient(circle at 20% 10%, var(--glow-a), transparent 46%),
    radial-gradient(circle at 90% 10%, var(--glow-b), transparent 48%),
    rgba(255,255,255,.045);
  color: var(--text);
  display: grid;
  align-content: end;
  gap: 5px;
  text-align: left;
  padding: 16px;
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.theme-card span { color: var(--muted); font-size: 12px; line-height: 1.35; }
.theme-card.active { border-color: rgba(255,255,255,.36); box-shadow: 0 0 0 4px rgba(255,255,255,.055), inset 0 1px 0 rgba(255,255,255,.12); }
.storage-grid, .help-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 12px; }
.quick-help .card { min-height: 180px; }

.question-control-bar {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: start;
  margin-bottom: 12px;
}
.question-control-bar h3 { margin: 0 0 4px; }
.editor-grid.single { grid-template-columns: 1fr; }
.question-inline-editor {
  background:
    radial-gradient(circle at 14% 0%, rgba(255,255,255,.08), transparent 34%),
    rgba(0,0,0,.19);
}
.questions-line { align-items: start; }
.question-tile .cost { opacity: .9; }
.question-tile.used { opacity: .7; }
.question-tile.used::after {
  content: "";
  position: absolute;
  inset: 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: linear-gradient(135deg, transparent 48%, rgba(255,255,255,.16) 49%, rgba(255,255,255,.16) 51%, transparent 52%);
  pointer-events: none;
}
.manual-link summary,
.manual-score summary,
.danger-zone summary {
  cursor: pointer;
  color: var(--muted);
}
.media-status {
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid var(--line-soft);
  color: var(--muted);
  background: rgba(255,255,255,.045);
  font-size: 12px;
}
.upload-error {
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(236, 212, 212, .10);
  border: 1px solid rgba(236, 212, 212, .18);
  color: var(--bad);
  margin: 0;
}
.media-manager.compact { padding: 0; border: 0; background: transparent; box-shadow: none; }
.break-preview.multi,
.break-stage-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
  align-items: stretch;
  padding: 12px;
}
.break-preview.multi .media-preview,
.break-preview.multi .crop-preview { height: 280px; }
.break-stage-grid .stage-media { min-height: min(44vh, 440px); }

.albums-editor-grid.large { grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 14px; }
.album-card { border-radius: 24px; }
.album-cover-thumb { border-radius: 22px; }
.album-placeholder {
  font-size: clamp(26px, 4vw, 52px);
  font-weight: 820;
  color: var(--muted);
  letter-spacing: -.06em;
}
.cell-number {
  min-width: 34px;
  height: 34px;
  font-size: 14px;
  backdrop-filter: blur(12px);
}

.stage-inner.screen-board { grid-template-rows: auto minmax(0, 1fr); align-content: stretch; min-height: 100%; }
.screen-team-name {
  font-size: clamp(19px, 2.05vw, 36px);
  font-weight: 820;
  letter-spacing: -.045em;
}
.screen-team-score {
  font-size: clamp(27px, 3.3vw, 56px);
}
.top-player { min-height: 38px; }
.top-player strong { font-size: clamp(15px, 1.25vw, 22px); }

.screen-albums-grid {
  height: 100%;
  min-height: 0;
  grid-template-columns: repeat(10, minmax(0, 1fr));
  grid-template-rows: repeat(3, minmax(0, 1fr));
  gap: clamp(8px, 1vw, 16px);
  align-content: stretch;
}
.screen-album {
  aspect-ratio: auto;
  min-height: 0;
  border-radius: clamp(16px, 1.6vw, 30px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 12px 42px rgba(0,0,0,.26);
}
.screen-album .cell-number {
  left: clamp(8px, .8vw, 16px);
  top: clamp(8px, .8vw, 16px);
  min-width: clamp(32px, 2.5vw, 52px);
  height: clamp(32px, 2.5vw, 52px);
  font-size: clamp(13px, 1.2vw, 21px);
}
.screen-album .album-answer { font-size: clamp(13px, 1.7vw, 28px); }
.screen-album .album-answer small { display: block; margin-top: 6px; font-size: .66em; color: var(--muted); }

.roster-tools { margin-top: 12px; }
.roster-row.simplified { grid-template-columns: minmax(180px, 1.2fr) minmax(160px, .9fr) auto; }
.team-name-input { font-weight: 780; letter-spacing: -.025em; }

@media (max-width: 1180px) {
  .screen-albums-grid { grid-template-columns: repeat(6, minmax(0,1fr)); grid-template-rows: none; }
  .screen-album { aspect-ratio: 1/1; }
  .question-control-bar { grid-template-columns: 1fr; }
  .roster-row.simplified { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .theme-grid { grid-template-columns: 1fr; }
  .storage-grid, .help-grid { grid-template-columns: 1fr; }
  .break-preview.multi, .break-stage-grid { grid-template-columns: 1fr; }
  .question-control-bar .inline.end { justify-content: stretch; }
  .question-control-bar .btn { flex: 1; }
  .screen-team-name { font-size: clamp(18px, 5vw, 28px); }
  .screen-team-score { font-size: clamp(30px, 8vw, 48px); }
  .screen-albums-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
}

/* ===== Raskayfovka v3: inline hosting, album-first board, custom gradients ===== */
html[data-theme="pine"] {
  --bg: #03110e;
  --bg-2: #0c1f1a;
  --panel: rgba(8, 28, 23, .68);
  --panel-strong: rgba(12, 33, 28, .94);
  --line: rgba(216, 244, 231, .14);
  --line-soft: rgba(216, 244, 231, .08);
  --accent: #eef7ef;
  --glow-a: rgba(33, 142, 103, .34);
  --glow-b: rgba(42, 82, 94, .28);
  --glow-c: rgba(219, 242, 232, .09);
}
html[data-theme="mono"] {
  --bg: #050606;
  --bg-2: #111313;
  --panel: rgba(20, 22, 22, .70);
  --panel-strong: rgba(27, 29, 29, .94);
  --line: rgba(245, 245, 240, .12);
  --line-soft: rgba(245, 245, 240, .075);
  --accent: #f4f4ef;
  --glow-a: rgba(190, 197, 191, .15);
  --glow-b: rgba(78, 83, 85, .24);
  --glow-c: rgba(255,255,255,.05);
}
body {
  background:
    radial-gradient(circle at 18% 7%, var(--custom-glow-a, var(--glow-a)), transparent 34%),
    radial-gradient(circle at 78% 14%, var(--custom-glow-b, var(--glow-b)), transparent 33%),
    radial-gradient(circle at 62% 88%, var(--glow-c), transparent 38%),
    linear-gradient(160deg, var(--custom-bg, var(--bg)), #020807 56%, var(--custom-bg-2, var(--bg-2)));
}
html[style*="--custom-accent"] { --accent: var(--custom-accent); }

.check-row {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 44px;
  color: var(--muted);
  padding: 10px 12px;
  border: 1px solid var(--line-soft);
  border-radius: 16px;
  background: rgba(255,255,255,.035);
}
.check-row input { width: 18px; height: 18px; accent-color: var(--accent); }
.color-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
}
.color-input { min-height: 52px; padding: 6px; cursor: pointer; }

.question-builder {
  display: grid;
  gap: 12px;
  background: rgba(255,255,255,.045);
}
.builder-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.builder-grid .wide { grid-column: 1 / -1; }
.builder-preview {
  display: grid;
  gap: 4px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid var(--line-soft);
  background: rgba(0,0,0,.18);
}
.builder-preview span { color: var(--faint); font-size: 12px; }
.builder-preview strong { font-size: clamp(16px, 2vw, 24px); letter-spacing: -.03em; }
.questions-line {
  position: relative;
}
.question-tile .cost {
  font-size: 32px;
  letter-spacing: -.06em;
}
.question-inline-editor {
  margin-top: 10px;
  scroll-margin-top: 92px;
}
.category-editor:has(.question-tile.active) {
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.048);
}

.album-open-button {
  width: 100%;
  border: 1px solid var(--line-soft);
  color: inherit;
  cursor: pointer;
  padding: 0;
}
.album-open-button:hover { filter: brightness(1.08); }
.album-opened-label {
  position: absolute;
  right: 8px;
  bottom: 8px;
  padding: 5px 8px;
  border-radius: 999px;
  background: rgba(5,8,7,.74);
  border: 1px solid var(--line-soft);
  backdrop-filter: blur(12px);
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
}
.albums-editor-grid.large { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }
.album-cover-thumb { min-height: 190px; }
.screen-album.used { opacity: 1; }
.screen-album.opened::before { background: rgba(0,0,0,.66); backdrop-filter: blur(10px) saturate(.8); }

.battle-editor-grid { grid-template-columns: 1fr; }
.battle-workbench { display: grid; gap: 12px; }
.battle-toolbar {
  padding: 10px 12px;
  border: 1px solid var(--line-soft);
  border-radius: 16px;
  background: rgba(255,255,255,.035);
}
.host-battle-grid { width: min(100%, 780px); }
.battle-cell {
  min-height: clamp(42px, 6vw, 64px);
  font-size: 15px;
  overflow: hidden;
}
.battle-cell span {
  position: absolute;
  right: 6px;
  bottom: 4px;
  font-size: 9px;
  color: var(--faint);
  font-weight: 700;
}
.battle-cell.ship {
  background: linear-gradient(180deg, rgba(255,255,255,.15), rgba(255,255,255,.06));
  border-color: rgba(255,255,255,.18);
}
.battle-cell-editor {
  width: min(100%, 980px);
  margin-top: 4px;
  background:
    radial-gradient(circle at 0 0, rgba(255,255,255,.08), transparent 32%),
    rgba(0,0,0,.20);
}
.battle-bonus-banner {
  justify-self: center;
  padding: clamp(12px, 1.6vw, 20px) clamp(18px, 2.5vw, 32px);
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.10);
  backdrop-filter: blur(18px);
  box-shadow: var(--shadow-soft);
  font-size: clamp(24px, 4vw, 58px);
  font-weight: 850;
  letter-spacing: -.055em;
  text-align: center;
}

.trim-panel, .crop-panel {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  background: rgba(255,255,255,.035);
}
.slider-row.trim { grid-template-columns: 88px 1fr 120px; }
.compact-note { margin: 0; font-size: 13px; }

@media (max-width: 760px) {
  .builder-grid { grid-template-columns: 1fr; }
  .color-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .host-battle-grid { width: 100%; gap: 4px; padding: 8px; }
  .battle-cell { border-radius: 9px; min-height: 34px; font-size: 11px; }
  .battle-cell span { display: none; }
  .slider-row.trim { grid-template-columns: 64px 1fr 84px; }
  .albums-editor-grid.large { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
.screen-team-name { font-size: clamp(22px, 2.55vw, 44px); }
.screen-team-score { font-size: clamp(34px, 4.2vw, 72px); }

/* v4: compact host question editor */
.inline-edit-grid {
  grid-template-columns: repeat(8, minmax(72px, 1fr));
  align-items: start;
}
.question-editor-under-tile {
  grid-column: 1 / -1;
  animation: softReveal .18s ease both;
}
@keyframes softReveal {
  from { opacity: 0; transform: translateY(-6px); }
  to { opacity: 1; transform: translateY(0); }
}
.slim-builder { gap: 10px; }
.builder-block {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid var(--line-soft);
  border-radius: 16px;
  background: rgba(255,255,255,.025);
}
.builder-caption {
  color: var(--faint);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.checkbox-cloud,
.inline.wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.chip-check {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid var(--line-soft);
  background: rgba(255,255,255,.04);
  color: var(--muted);
  font-size: 13px;
  cursor: pointer;
  user-select: none;
}
.chip-check input,
.segmented input {
  accent-color: var(--accent);
}
.chip-check:has(input:checked) {
  color: var(--text);
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.22);
}
.mini-field-row {
  display: grid;
  grid-template-columns: minmax(80px, 110px) auto minmax(130px, 170px);
  gap: 8px;
  align-items: end;
}
.second-title-row {
  margin-top: 2px;
}
.compact-field { gap: 5px; }
.compact-input { min-height: 38px; padding: 8px 10px; }
.mini-input { min-height: 36px; padding: 7px 9px; }
.compact-textarea { min-height: 74px; padding: 10px 12px; }
.segmented.small {
  min-height: 38px;
  display: inline-flex;
  align-items: stretch;
  border: 1px solid var(--line-soft);
  border-radius: 999px;
  overflow: hidden;
  background: rgba(255,255,255,.035);
}
.segmented.small label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  font-size: 13px;
  color: var(--muted);
  cursor: pointer;
}
.segmented.small label:has(input:checked) {
  color: var(--text);
  background: rgba(255,255,255,.11);
}
.upload-warning {
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.07);
  color: var(--muted);
  font-size: 13px;
}
.trim-hint {
  color: var(--faint);
  font-size: 12px;
}

@media (max-width: 900px) {
  .inline-edit-grid { grid-template-columns: repeat(4, minmax(68px, 1fr)); }
  .mini-field-row { grid-template-columns: 1fr; }
  .segmented.small { width: 100%; }
  .segmented.small label { flex: 1; justify-content: center; }
}
@media (max-width: 560px) {
  .inline-edit-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* v4.1: чекбоксы вместо раскрывающихся списков в вопросах */
.compact-cloud { gap: 6px; }
.chip-check.big { font-weight: 750; color: var(--text); background: rgba(255,255,255,.065); }
.words-compact .mini-field-row {
  grid-template-columns: minmax(86px, 128px) auto auto minmax(128px, 170px);
  align-items: end;
}
.words-compact .second-title-row {
  grid-template-columns: minmax(116px, 148px) auto auto;
}
.trim-panel .compact-note { color: var(--muted); }
.media-card .media-status { max-width: 48vw; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
@media (max-width: 760px) {
  .inline-edit-grid { grid-template-columns: repeat(4, minmax(58px, 1fr)); }
  .words-compact .mini-field-row,
  .words-compact .second-title-row { grid-template-columns: 1fr; }
  .chip-check { width: max-content; max-width: 100%; }
}

/* v5: ещё более компактная разметка музыкального вопроса */
.builder-topline { gap: 8px; }
.compact-builder-block { padding: 9px; gap: 7px; }
.checkbox-cloud.tight { gap: 6px; }
.main-chip { color: var(--text); font-weight: 700; }
.extra-role-field { max-width: 520px; }
.words-row { grid-template-columns: minmax(72px, 96px) auto auto minmax(116px, 156px); gap: 7px; }
.words-row .mini-label { min-width: 0; }
.words-row .mini-input { width: 100%; }
.question-inline-editor .textarea.compact-textarea { min-height: 64px; }
.question-inline-editor .field.compact-field { font-size: 12px; }
.question-tile .cost { font-size: clamp(28px, 2.8vw, 42px); }
.question-editor-under-tile { margin-top: 8px; }
.media-notice {
  padding: 9px 11px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.065);
  color: var(--text);
  font-size: 13px;
}
@media (max-width: 760px) {
  .words-row { grid-template-columns: 1fr; }
  .extra-role-field { max-width: none; }
}

/* v4.1: компактный блок разметки вопроса */
.builder-section-line { align-items: center; gap: 8px; }
.builder-section-title { font-size: 13px; letter-spacing: .01em; color: var(--text); }
.slim-builder .compact-input,
.slim-builder .mini-input { min-height: 36px; padding: 8px 10px; }
.slim-builder .compact-textarea { min-height: 82px; }
.extra-role-field .compact-input { max-width: 520px; }

/* v4.1: компактные поля разметки вопроса и плитки без «стоимости» */
.question-tile .question-number { font-size: 18px; font-weight: 800; letter-spacing: .02em; }
.question-tile .cost { display: none !important; }
.checkbox-cloud.tight { gap: 6px; }
.sung-words { min-width: 112px; max-width: 140px; }
.words-row .mini-label { max-width: 115px; }
.slim-builder .input.mini-input { padding: 9px 10px; min-height: 36px; }

/* v5.2: плитка вопроса показывает номер */
.question-tile .question-number { font-size: clamp(18px, 2.2vw, 30px); font-weight: 820; letter-spacing: -.04em; }
.question-tile .mini { display: none; }
