/* ═══════════════════════════════════════════════════════════════
   CLIP IT! — Main Stylesheet  (light / playful)
   ═══════════════════════════════════════════════════════════════ */

/* ── Variables ────────────────────────────────────────────── */
:root {
  --orange:    #ff6b35;
  --orange-d:  #d94f1e;
  --orange-l:  #ff8f5e;
  --blue:      #4a90e2;
  --blue-d:    #2e6fc0;
  --green:     #27ae60;
  --green-d:   #1e8449;
  --red:       #e74c3c;
  --yellow:    #f1c40f;
  --yellow-d:  #c9a50d;
  --purple:    #9b59b6;
  --pink:      #e91e8c;

  --bg:        #eef1fa;
  --surface:   #ffffff;
  --surface2:  #f4f6fc;
  --border:    #d8ddef;
  --border-d:  #bdc5dc;
  --txt:       #1a1f3a;
  --txt-m:     #6b7499;
  --txt-l:     #a0a8c2;

  --r:         12px;
  --r-lg:      20px;
  --shadow-sm: 0 2px 8px rgba(26,31,58,.08);
  --shadow:    0 4px 18px rgba(26,31,58,.1);
  --shadow-lg: 0 8px 32px rgba(26,31,58,.13);
}

/* ── Reset ────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { overflow: hidden; height: 100%; }
html { font-size: 16px; }
body {
  display: flex; flex-direction: column;
  min-height: 100vh;
  font-family: 'Nunito', sans-serif;
  background: var(--bg);
  color: var(--txt);
  height: 100dvh;
  overflow: hidden;
}
a  { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
input  { font-family: inherit; }

/* ── Dot background ───────────────────────────────────────── */
.bg-grid {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image: radial-gradient(circle, rgba(74,144,226,.15) 1.5px, transparent 1.5px);
  background-size: 26px 26px;
}
.bg-noise { display: none; }

/* ── SPA screens ──────────────────────────────────────────── */
/* ── SPA screens (index.ejs only) ────────────────────────── */
.screen { display: none; }
.screen.active { display: flex; flex-direction: column; min-height: calc(100dvh - 62px); overflow-y: auto; overflow-x: hidden; position: relative; }

/* ═══════════════════════════════════════════════════════════
   GAME SHELL
   ═══════════════════════════════════════════════════════════ */

.game-body {
  display: flex; flex-direction: column;
  height: 100dvh; overflow: hidden;
  background: var(--bg);
}

/* ── TOP BAR ──────────────────────────────────────────────── */
.game-shell {
  display: flex; flex-direction: column;
  height: 100dvh; overflow: hidden;
}
.game-topbar {
  display: grid; grid-template-columns: 1fr auto 1fr;
  align-items: center;
  height: 52px; padding: 0 1.25rem;
  background: var(--surface);
  border-bottom: 2px solid var(--border);
  box-shadow: var(--shadow-sm);
  flex-shrink: 0; z-index: 20;
}
.gtb-left  { display: flex; align-items: center; }
.gtb-center { display: flex; justify-content: center; }
.gtb-right { display: flex; justify-content: flex-end; align-items: center; }
.gtb-logo  { height: 26px; object-fit: contain; }

.gtb-round {
  font-family: 'Bebas Neue', sans-serif; font-size: 1.1rem; letter-spacing: 0.12em;
  color: var(--txt-m);
  background: var(--surface2); border: 1.5px solid var(--border);
  padding: 0.15rem 0.65rem; border-radius: 6px;
}

.gtb-score { display: flex; flex-direction: column; align-items: flex-end; line-height: 1; gap: 1px; }
.gtb-score-label { font-size: 0.42rem; font-weight: 900; letter-spacing: 0.22em; color: var(--txt-l); text-transform: uppercase; }
.gtb-score-val {
  font-family: 'Bebas Neue', sans-serif; font-size: 1.35rem;
  color: var(--orange); letter-spacing: 0.04em;
}
.gtb-score-val.bump { animation: scoreBump .4s cubic-bezier(.34,1.56,.64,1); }
@keyframes scoreBump {
  0%,100% { transform: scale(1); }
  50%     { transform: scale(1.5); color: var(--green); }
}

/* ── PHASES ───────────────────────────────────────────────── */
.game-main { flex: 1; overflow: hidden; position: relative; }
.phase {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 1rem;
}

/* ── READY ────────────────────────────────────────────────── */
.phase--ready { background: var(--bg); overflow: hidden; }
.ready-bg-ring {
  position: absolute; border-radius: 50%;
  border: 1.5px solid rgba(255,107,53,.12);
  width: 500px; height: 500px;
  animation: ringExpand 2.5s ease-out infinite;
}
.ready-bg-ring--2 { animation-delay: 1.25s; border-color: rgba(74,144,226,.1); }
@keyframes ringExpand {
  0%   { transform: scale(.1); opacity: 1; }
  100% { transform: scale(2.4); opacity: 0; }
}
.ready-content {
  position: relative; z-index: 1;
  display: flex; flex-direction: column; align-items: center; gap: 0.25rem;
  text-align: center;
}
.ready-pill {
  background: rgba(255,107,53,.1); border: 1px solid rgba(255,107,53,.25);
  padding: 0.2rem 1rem; border-radius: 50px;
  font-size: 0.65rem; font-weight: 900; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--orange);
  margin-bottom: 0.3rem;
}
.ready-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(4rem,14vw,8rem);
  letter-spacing: 0.04em; line-height: .88;
  color: var(--txt);
}
.ready-countdown {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(6rem,22vw,12rem);
  color: var(--orange); line-height: 1;
  animation: countDrop .5s cubic-bezier(.34,1.56,.64,1);
  margin-top: -0.1em;
}
@keyframes countDrop {
  0%   { transform: scale(2) translateY(-10px); opacity: 0; filter: blur(8px); }
  100% { transform: scale(1) translateY(0); opacity: 1; filter: blur(0); }
}

/* ── BODY LAYOUT: phases + sidebar ───────────────────────── */
.game-body-layout {
  display: flex; flex-direction: row;
  flex: 1; overflow: hidden;
  min-height: 0;
}

/* ── VIDEO ────────────────────────────────────────────────── */
.phase--video { background: var(--txt); padding: 0.75rem; justify-content: flex-start; align-items: stretch; }

.video-main {
  width: 100%; height: 100%;
  display: flex; flex-direction: column; gap: 0;
  border-radius: 14px; overflow: hidden;
  box-shadow: 0 0 0 1px rgba(255,255,255,.08), 0 24px 64px rgba(0,0,0,.7);
}
.iframe-wrap {
  position: relative; width: 100%; padding-bottom: 56.25%; background: #000; flex-shrink: 0;
}
.clip-scanline {
  position: absolute; inset: 0; pointer-events: none; z-index: 3;
  background: repeating-linear-gradient(0deg, transparent, transparent 3px, rgba(0,0,0,.03) 3px, rgba(0,0,0,.03) 4px);
}
.video-footer {
  background: #1a1d27;
  border-top: 1px solid rgba(255,255,255,.06);
  display: flex; flex-direction: column;
}
.video-channel {
  padding: 0.4rem 0.85rem;
  font-size: 0.7rem; font-weight: 700; color: rgba(255,255,255,.4);
  display: flex; align-items: center; gap: 0.4rem;
}
.video-channel a { color: var(--orange); text-decoration: none; }
.clip-progress-wrap { height: 3px; background: rgba(255,255,255,.07); }
.clip-progress-bar {
  height: 100%; width: 0%;
  background: linear-gradient(90deg, var(--orange), var(--yellow));
}

/* Paused overlay */
.video-paused-overlay {
  position: absolute; inset: 0;
  background: rgba(15,17,23,.82); backdrop-filter: blur(8px);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 0.6rem; z-index: 10; animation: overlayIn .3s ease;
}
.video-paused-overlay svg { color: var(--yellow); opacity: .9; }
.video-paused-overlay span {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(1.2rem,4vw,2rem); letter-spacing: 0.12em; color: var(--yellow);
}
@keyframes overlayIn { from{opacity:0;} to{opacity:1;} }

/* ── PERSISTENT SIDEBAR ───────────────────────────────────── */
.game-sidebar {
  width: 220px; flex-shrink: 0;
  display: flex; flex-direction: column;
  background: var(--surface);
  border-left: 1px solid var(--border);
  overflow: hidden;
}

.sidebar-panel {
  display: flex; flex-direction: column;
  height: 100%; overflow: hidden;
}
.sidebar-panel.hidden { display: none; }

.sidebar-header {
  display: flex; align-items: center; gap: 0.4rem;
  padding: 0.65rem 1rem;
  font-size: 0.58rem; font-weight: 900; letter-spacing: 0.18em;
  color: var(--orange);
  border-bottom: 1px solid var(--border);
  background: var(--surface2);
  flex-shrink: 0;
}
.sidebar-header svg { color: var(--orange); }

/* Shared list used by both panels */
.sidebar-list {
  display: flex; flex-direction: column;
  overflow-y: auto; flex: 1;
}

/* Score items */
.sb-item {
  display: flex; align-items: center; gap: 0.6rem;
  padding: 0.55rem 1rem; border-bottom: 1px solid var(--border);
  font-size: 0.82rem; animation: sbItemIn .3s ease both;
}
.sb-item:last-child { border-bottom: none; }
.sb-item.is-me { background: rgba(255,107,53,.05); }
.sb-item:nth-child(1){animation-delay:.04s;} .sb-item:nth-child(2){animation-delay:.08s;}
.sb-item:nth-child(3){animation-delay:.12s;} .sb-item:nth-child(4){animation-delay:.16s;}
.sb-item:nth-child(5){animation-delay:.20s;}
@keyframes sbItemIn { from{opacity:0;transform:translateX(6px);} to{opacity:1;transform:none;} }
.sb-rank  { width: 16px; font-family: 'Bebas Neue', sans-serif; font-size: 0.9rem; color: var(--txt-m); flex-shrink: 0; }
.sb-name  { flex: 1; font-weight: 800; color: var(--txt); font-size: 0.78rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sb-name small { font-size: 0.62rem; color: var(--txt-m); font-weight: 600; }
.sb-correct { font-size: .75rem; flex-shrink: 0; }
.sb-time  { font-size: 0.63rem; font-weight: 700; color: var(--txt-m); font-variant-numeric: tabular-nums; white-space: nowrap; }
.sb-score { font-family: 'Bebas Neue', sans-serif; font-size: 1rem; color: var(--orange); flex-shrink: 0; }

/* Voting count badge */
.sb-voting-count {
  padding: 0.4rem 1rem;
  font-size: 0.68rem; font-weight: 800; color: var(--txt-m);
  background: var(--surface2); border-bottom: 1px solid var(--border);
  letter-spacing: 0.04em; flex-shrink: 0;
}

/* Voting items */
.sb-vote-item {
  display: flex; align-items: center; gap: 0.6rem;
  padding: 0.5rem 1rem; border-bottom: 1px solid var(--border);
  font-size: 0.8rem; animation: sbItemIn .25s ease both;
}
.sb-vote-item:last-child { border-bottom: none; }
.sb-vote-item.is-me { background: rgba(255,107,53,.04); }
.sb-vote-av {
  width: 26px; height: 26px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.58rem; font-weight: 900; color: #fff;
  border: 2px solid rgba(255,255,255,.2);
}
.sb-vote-av--waiting { background: var(--border-d); }
.sb-vote-av--done    { background: var(--green); animation: popIn .2s cubic-bezier(.34,1.56,.64,1); }
.sb-vote-name { flex: 1; font-weight: 800; color: var(--txt); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 0.78rem; }
.sb-vote-tick {
  width: 18px; height: 18px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.sb-vote-tick--done { color: var(--green); }
.sb-vote-tick--wait { color: var(--txt-l); }

/* Mobile: sidebar becomes bottom bar */
@media(max-width:700px){
  .game-body-layout { flex-direction: column; }
  .game-sidebar {
    width: 100%; border-left: none; border-top: 1px solid var(--border);
    height: 120px; flex-direction: row;
  }
  .sidebar-panel { flex-direction: column; width: 100%; height: 100%; }
  .sidebar-header { display: none; }
  .sb-voting-count { padding: 0.25rem 0.75rem; font-size: 0.6rem; border-bottom: none; border-right: 1px solid var(--border); min-width: 70px; display: flex; align-items: center; }
  .sidebar-list { flex-direction: row; overflow-x: auto; overflow-y: hidden; }
  .sb-item { flex-direction: column; gap: 0.1rem; padding: 0.4rem 0.6rem; border-bottom: none; border-right: 1px solid var(--border); min-width: 56px; align-items: center; text-align: center; }
  .sb-rank { font-size: 0.7rem; }
  .sb-name { font-size: 0.6rem; }
  .sb-score { font-size: 0.85rem; }
  .sb-correct, .sb-time { display: none; }
  .sb-vote-item { flex-direction: column; gap: 0.1rem; padding: 0.4rem 0.5rem; border-bottom: none; border-right: 1px solid var(--border); min-width: 52px; align-items: center; }
  .sb-vote-name { font-size: 0.6rem; text-align: center; }
  .sb-vote-tick { display: none; }
}

/* ── ANSWER ───────────────────────────────────────────────── */
.phase--answer {
  background: var(--bg); padding: 0; overflow: hidden;
  justify-content: stretch; align-items: stretch;
}
.answer-layout {
  display: flex; flex-direction: column; align-items: center;
  width: 100%; height: 100%; overflow-y: auto;
  padding: 0.75rem 0.75rem 0.5rem; gap: 0.6rem;
}

/* Timer + Frage nebeneinander */
.answer-top {
  display: flex; align-items: center; gap: 1.25rem;
  width: 100%; max-width: 800px; flex-shrink: 0;
}
.answer-timer {
  position: relative; width: 96px; height: 96px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.answer-timer-svg { position: absolute; inset: 0; transform: rotate(-90deg); }
.at-track { fill: none; stroke: var(--border); stroke-width: 8; }
.at-fill {
  fill: none; stroke: var(--orange); stroke-width: 8; stroke-linecap: round;
  transition: stroke-dashoffset 1s linear, stroke .4s;
  filter: drop-shadow(0 0 4px rgba(255,107,53,.35));
}
.at-fill.urgent {
  stroke: var(--red);
  filter: drop-shadow(0 0 5px rgba(231,76,60,.5));
  animation: urgentPulse .55s ease-in-out infinite alternate;
}
@keyframes urgentPulse { from{stroke-opacity:1;} to{stroke-opacity:.55;} }
.at-glow { fill:none; stroke:var(--orange); stroke-width:8; stroke-linecap:round; opacity:0; pointer-events:none; stroke-dasharray:427; stroke-dashoffset:427; }
.at-face { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; line-height: 1; gap: 1px; }
.at-number {
  font-family: 'Bebas Neue', sans-serif; font-size: 2.2rem; letter-spacing: -0.02em;
  color: var(--txt); display: block; transition: color .4s;
}
.at-number.urgent-color { color: var(--red); }
.at-unit { font-size: 0.45rem; font-weight: 900; letter-spacing: 0.25em; color: var(--txt-m); text-transform: uppercase; }
.answer-timer.shake { animation: timerShake .4s ease; }
@keyframes timerShake { 0%,100%{transform:translateX(0);} 20%{transform:translateX(-5px);} 40%{transform:translateX(5px);} 60%{transform:translateX(-3px);} 80%{transform:translateX(3px);} }
.answer-timer.tick { animation: timerTick .2s ease; }
@keyframes timerTick { 0%,100%{transform:scale(1);} 50%{transform:scale(1.07);} }

.question-block { flex: 1; display: flex; flex-direction: column; gap: 0.2rem; }
.question-eyebrow {
  display: inline-flex; align-items: center; gap: 0.3rem;
  font-size: 0.58rem; font-weight: 900; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--txt-m);
}
.question-text {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(1.3rem,3.5vw,2rem); letter-spacing: 0.02em; line-height: 1.2;
  color: var(--txt);
}

/* Answer buttons */
.answers-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 0.55rem; width: 100%; max-width: 800px;
}
.answer-btn {
  position: relative; overflow: hidden;
  display: flex; align-items: center; gap: 0.65rem;
  padding: 0.85rem 1rem; min-height: 60px;
  border-radius: 14px; border: none; cursor: pointer;
  font-size: 0.9rem; font-weight: 800; color: #fff; text-align: left;
  transition: transform .12s, box-shadow .12s, opacity .25s, filter .2s;
  animation: answerIn .3s cubic-bezier(.34,1.3,.64,1) both;
}
.answer-btn:nth-child(1){animation-delay:.04s;}
.answer-btn:nth-child(2){animation-delay:.08s;}
.answer-btn:nth-child(3){animation-delay:.12s;}
.answer-btn:nth-child(4){animation-delay:.16s;}
@keyframes answerIn { from{opacity:0;transform:translateY(10px) scale(.97);} to{opacity:1;transform:none;} }
.answer-btn:hover:not(:disabled) { transform: translateY(-3px); }
.answer-btn:active:not(:disabled) { transform: translateY(1px); }
.answer-btn:disabled { cursor: not-allowed; }
.answer-btn--A { background: #4a90e2; box-shadow: 0 5px 0 #2e6fc0; }
.answer-btn--B { background: #27ae60; box-shadow: 0 5px 0 #1e8449; }
.answer-btn--C { background: #e6a817; box-shadow: 0 5px 0 #c8910e; }
.answer-btn--D { background: #e91e8c; box-shadow: 0 5px 0 #c01775; }
.answer-btn--A:hover:not(:disabled) { box-shadow: 0 7px 0 #2e6fc0; }
.answer-btn--B:hover:not(:disabled) { box-shadow: 0 7px 0 #1e8449; }
.answer-btn--C:hover:not(:disabled) { box-shadow: 0 7px 0 #c8910e; }
.answer-btn--D:hover:not(:disabled) { box-shadow: 0 7px 0 #c01775; }
.answer-letter {
  width: 30px; height: 30px; border-radius: 8px;
  background: rgba(0,0,0,.2);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Bebas Neue', sans-serif; font-size: 1.05rem; flex-shrink: 0;
}
.answer-text { flex: 1; line-height: 1.3; }
.answer-btn.selected { outline: 3px solid rgba(255,255,255,.9); outline-offset: 2px; }
.answer-btn.correct  {
  outline: 3px solid var(--yellow); outline-offset: 2px;
  box-shadow: 0 5px 0 #1e8449, 0 0 0 4px rgba(241,196,15,.35) !important;
  animation: correctFlash .45s ease;
}
@keyframes correctFlash { 0%,100%{filter:brightness(1.1);} 50%{filter:brightness(1.35);} }
.answer-btn.wrong { opacity: .3; filter: grayscale(.6); transform: scale(.97); }

@media(max-width:640px){
  .answers-grid { grid-template-columns: 1fr; gap: .4rem; }
  .answer-btn { min-height: 50px; padding: .7rem .85rem; }
  .answer-top { gap: 0.75rem; }
  .answer-timer { width: 80px; height: 80px; }
  .at-number { font-size: 1.8rem; }
  .question-text { font-size: 1.1rem; }
}

/* ── RESULT ───────────────────────────────────────────────── */
.phase--result {
  background: var(--bg); padding: 0;
  justify-content: stretch; align-items: stretch; overflow: hidden;
}
.result-main {
  width: 100%; height: 100%; overflow-y: auto;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 0.75rem; padding: 1.25rem;
}

.result-hero {
  display: flex; flex-direction: row; align-items: center; justify-content: space-between;
  padding: 1.1rem 1.6rem;
  border-radius: 18px; width: 100%; max-width: 600px;
  border: 2px solid var(--border);
  box-shadow: 0 4px 0 var(--border-d), var(--shadow);
  background: var(--surface);
  animation: heroIn .4s cubic-bezier(.34,1.2,.64,1);
  gap: 1rem;
}
.result-hero.correct-bg { border-color: rgba(39,174,96,.4); background: rgba(39,174,96,.05); box-shadow: 0 4px 0 rgba(39,174,96,.25), var(--shadow); }
.result-hero.wrong-bg   { border-color: rgba(231,76,60,.35); background: rgba(231,76,60,.04); box-shadow: 0 4px 0 rgba(231,76,60,.2), var(--shadow); }
@keyframes heroIn { from{opacity:0;transform:scale(.95) translateY(8px);} to{opacity:1;transform:none;} }

.result-verdict {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2.4rem,7vw,4rem); letter-spacing: 0.06em; line-height: 1;
}
.result-verdict.correct { color: var(--green); }
.result-verdict.wrong   { color: var(--red); }
.result-pts {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(1.5rem,4vw,2.2rem); color: var(--orange); letter-spacing: 0.04em;
  animation: ptsIn .35s .15s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes ptsIn { from{transform:scale(0) rotate(-8deg);} to{transform:none;} }

.result-explanation {
  font-size: 0.84rem; color: var(--txt-m); font-weight: 700; line-height: 1.5;
  text-align: center; max-width: 600px; width: 100%;
  padding: 0.5rem 1rem;
  background: var(--surface); border: 1.5px solid var(--border); border-radius: 10px;
}
.reveal-container { width: 100%; max-width: 600px; }
.reveal-container iframe {
  width: 100%; aspect-ratio: 16/9; border: none; display: block;
  border-radius: 12px; border: 2px solid rgba(39,174,96,.4);
}

/* Ready bar — redesigned: full-width card with big button */
.ready-bar {
  display: flex; flex-direction: column; align-items: center; gap: 0.85rem;
  width: 100%; max-width: 600px;
  padding: 1.25rem 1.5rem;
  background: var(--surface); border: 2px solid var(--border);
  border-radius: 18px;
  box-shadow: 0 4px 0 var(--border-d), var(--shadow);
  animation: heroIn .4s .1s cubic-bezier(.34,1.2,.64,1) both;
}
.ready-bar.hidden { display: none !important; }

.ready-btn {
  display: flex; align-items: center; justify-content: center; gap: 0.6rem;
  width: 100%; padding: 0.85rem 1.5rem; border-radius: 12px;
  background: var(--green); color: #fff;
  font-size: 1rem; font-weight: 900; font-family: inherit;
  box-shadow: 0 5px 0 var(--green-d);
  transition: transform .12s, box-shadow .12s;
  white-space: nowrap;
}
.ready-btn:hover { transform: translateY(-2px); box-shadow: 0 7px 0 var(--green-d); }
.ready-btn:active { transform: translateY(3px); box-shadow: 0 2px 0 var(--green-d); }
.ready-btn--done {
  background: var(--border-d); color: var(--txt-m);
  box-shadow: 0 4px 0 #c5ccde; cursor: default; opacity: .75;
}
.ready-btn--done:hover { transform: none; box-shadow: 0 4px 0 #c5ccde; }

.ready-progress {
  display: flex; flex-direction: column; align-items: center; gap: 0.4rem; width: 100%;
}
.ready-count {
  font-size: 0.72rem; font-weight: 900; letter-spacing: 0.06em;
  color: var(--txt-m); text-transform: uppercase;
}
.ready-pips { display: flex; gap: 0.35rem; flex-wrap: wrap; justify-content: center; }
.ready-pip {
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--border); border: 2px solid var(--border-d);
  transition: background .25s, border-color .25s, transform .2s;
}
.ready-pip--on {
  background: var(--green); border-color: var(--green-d);
  transform: scale(1.15);
  box-shadow: 0 0 6px rgba(39,174,96,.4);
}

/* ── Toast ────────────────────────────────────────────────── */
.toast {
  position: fixed; bottom: 1.5rem; left: 50%; transform: translateX(-50%);
  background: var(--txt); color: #fff;
  padding: 0.6rem 1.4rem; border-radius: 50px;
  font-weight: 800; font-size: 0.88rem; white-space: nowrap;
  z-index: 9999; box-shadow: var(--shadow);
  transition: opacity .25s, transform .25s;
}
.toast.hidden { opacity: 0; pointer-events: none; transform: translateX(-50%) translateY(6px); }

/* ── Utility ──────────────────────────────────────────────── */
.hidden { display: none !important; }
.confetti-container { position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.confetti-piece {
  position: absolute; width: 10px; height: 10px;
  animation: confettiFall linear forwards;
}
@keyframes confettiFall {
  from { transform: translateY(-20px) rotate(0deg); opacity: 1; }
  to   { transform: translateY(110vh) rotate(720deg); opacity: 0; }
}

/* ── Loading ──────────────────────────────────────────────── */
.loading-overlay {
  position: fixed; inset: 0; z-index: 999;
  background: rgba(238,241,250,.92); backdrop-filter: blur(6px);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1rem;
  font-weight: 800; color: var(--txt-m);
}
.loading-spinner {
  width: 44px; height: 44px;
  border: 3px solid var(--border);
  border-top-color: var(--orange);
  border-radius: 50%;
  animation: lspin .7s linear infinite;
}
@keyframes lspin { to { transform: rotate(360deg); } }


/* ═══════════════════════════════════════════════════════════
   HOME PAGE
   ═══════════════════════════════════════════════════════════ */

#screenHome {
  align-items: stretch; justify-content: flex-start;
  padding: 0;
  gap: 0;
}

/* Inner content wrapper — grows to fill space, pushing footer down */
.h-home-content {
  flex: 1;
  display: flex; flex-direction: column; align-items: center;
  padding: 2.5rem 1.25rem 3rem;
  gap: 2rem;
  width: 100%;
}

@media(max-width:640px){
  #screenHome { padding: 0; }
  .h-home-content {
    padding: 1.5rem 1rem 2.5rem;
    gap: 1.5rem;
  }
}

/* Logo */
.h-hero { text-align: center; animation: bounceIn .55s cubic-bezier(.34,1.5,.64,1); }
@keyframes bounceIn { from{opacity:0;transform:scale(.75) translateY(-16px);} to{opacity:1;transform:none;} }

.h-logo-wrap { display: inline-flex; align-items: center; gap: 0.65rem; margin-bottom: 0.4rem; }
.h-logo-icon {
  width: 56px; height: 56px; border-radius: 16px;
  background: var(--orange);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 5px 0 var(--orange-d), 0 8px 20px rgba(255,107,53,.3);
  flex-shrink: 0;
}
.h-logo-icon svg { color: #fff; width: 26px; height: 26px; }

.h-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(3rem, 10vw, 5rem);
  letter-spacing: 0.04em; line-height: 1; color: var(--txt);
}
.h-title span { color: var(--orange); }
.h-tagline {
  font-size: 0.85rem; font-weight: 800;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--txt-m);
}

/* Cards */
/* ── Char configurator card (full-width, above game cards) ───── */
.hc-card {
  width: 100%; max-width: 860px;
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 22px; padding: 1.25rem 1.5rem;
  box-shadow: 0 5px 0 var(--border-d), var(--shadow);
  animation: slideUp .5s .05s cubic-bezier(.34,1.3,.64,1) both;
}
.hc-card-badge {
  display: inline-flex; align-items: center; gap: 0.3rem;
  padding: 0.22rem 0.7rem; border-radius: 50px; margin-bottom: 0.85rem;
  font-size: 0.68rem; font-weight: 900; letter-spacing: 0.1em; text-transform: uppercase;
  background: rgba(155,89,182,.1); color: #9b59b6;
  border: 1.5px solid rgba(155,89,182,.25);
}
.hc-inner {
  display: flex; align-items: flex-start; gap: 1.5rem;
}
.hc-preview-side {
  display: flex; flex-direction: column; align-items: center; gap: 0.75rem;
  flex-shrink: 0;
}
.hc-canvas {
  position: relative; width: 150px; height: 150px;
  background: var(--surface2); border: 2px solid var(--border);
  border-radius: 16px; overflow: hidden;
}
.hc-random-btn {
  display: flex; align-items: center; gap: 0.4rem;
  padding: 0.5rem 0.9rem; border-radius: 10px;
  background: var(--surface2); border: 2px solid var(--border);
  font-size: 0.78rem; font-weight: 900; color: var(--txt-m);
  box-shadow: 0 2px 0 var(--border-d); cursor: pointer; font-family: inherit;
  transition: all .15s; white-space: nowrap;
}
.hc-random-btn:hover { border-color: var(--orange); color: var(--orange); background: rgba(255,107,53,.05); }
.hc-options-side {
  flex: 1; display: flex; flex-direction: column; gap: 0.65rem; min-width: 0;
}
.hc-section { display: flex; flex-direction: column; gap: 0.28rem; }
.hc-label {
  font-size: 0.62rem; font-weight: 900; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--txt-m);
}
.hc-items { display: flex; flex-wrap: wrap; gap: 0.32rem; }
.hc-item {
  width: 34px; height: 34px; border-radius: 9px;
  border: 2px solid var(--border);
  background: var(--hc, var(--surface2));
  cursor: pointer;
  transition: border-color .12s, transform .1s, box-shadow .12s;
  box-shadow: 0 2px 0 var(--border-d);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.75rem; color: var(--txt-l); font-weight: 900;
}
.hc-item:hover { border-color: var(--orange); transform: translateY(-2px); box-shadow: 0 4px 0 var(--border-d); }
.hc-item.active { border-color: var(--orange); box-shadow: 0 2px 0 var(--orange-d), 0 0 0 3px rgba(255,107,53,.18); }
.hc-item--none { background: var(--surface2); }
.hc-item--none.active { border-color: var(--border-d); box-shadow: 0 2px 0 var(--border-d); }
.hc-item--rainbow        { background: linear-gradient(135deg,red 0%,orange 25%,yellow 45%,green 60%,blue 80%,purple 100%); }
.hc-item--rainbow-green  { background: linear-gradient(135deg,#27ae60,#1abc9c); }
.hc-item--rainbow-purple { background: linear-gradient(135deg,#8e44ad,#e91e8c); }

/* Game cards row */
.h-game-cards {
  display: flex; flex-wrap: wrap; gap: 1.25rem; justify-content: center;
  width: 100%; max-width: 860px;
  animation: slideUp .5s .1s cubic-bezier(.34,1.3,.64,1) both;
}
.h-cards {
  display: flex; flex-wrap: wrap; gap: 1.25rem; justify-content: center;
  width: 100%; max-width: 760px;
  animation: slideUp .5s .08s cubic-bezier(.34,1.3,.64,1) both;
}
@keyframes slideUp { from{opacity:0;transform:translateY(18px);} to{opacity:1;transform:none;} }

.h-card {
  flex: 1; min-width: 280px; max-width: 420px;
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 22px; padding: 1.75rem;
  display: flex; flex-direction: column; gap: 1rem;
  box-shadow: 0 5px 0 var(--border-d), var(--shadow);
  transition: transform .15s, box-shadow .15s;
}
.h-card:hover { transform: translateY(-3px); box-shadow: 0 8px 0 var(--border-d), var(--shadow-lg); }
.h-card-badge {
  display: inline-flex; align-items: center; gap: 0.3rem;
  padding: 0.22rem 0.7rem; border-radius: 50px;
  font-size: 0.68rem; font-weight: 900; letter-spacing: 0.1em; text-transform: uppercase;
  width: fit-content;
}
.h-card--create .h-card-badge { background: rgba(255,107,53,.12); color: var(--orange); border: 1.5px solid rgba(255,107,53,.25); }
.h-card--join   .h-card-badge { background: rgba(74,144,226,.12);  color: var(--blue);   border: 1.5px solid rgba(74,144,226,.25); }
.h-card-badge--purple { background: rgba(155,89,182,.1); color: #9b59b6; border: 1.5px solid rgba(155,89,182,.25); }
.h-card-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.7rem; letter-spacing: 0.03em; line-height: 1; color: var(--txt);
}
.h-card-desc { font-size: 0.84rem; color: var(--txt-m); font-weight: 700; line-height: 1.5; margin-top: -.3rem; }
.h-field { display: flex; flex-direction: column; gap: 0.3rem; }
.h-label { font-size: 0.7rem; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; color: var(--txt-m); }
.h-input {
  width: 100%; padding: 0.68rem 0.9rem;
  background: var(--surface2); border: 2px solid var(--border);
  border-radius: 10px; color: var(--txt); font-size: 0.95rem; font-weight: 700;
  outline: none; transition: border-color .2s, box-shadow .2s, background .2s;
}
.h-input:focus { border-color: var(--orange); background: #fff; box-shadow: 0 0 0 3px rgba(255,107,53,.14); }
.h-card--join .h-input:focus { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(74,144,226,.14); }
.h-input::placeholder { color: var(--txt-l); }
.h-input--code {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 2rem; letter-spacing: 0.35em; text-align: center; text-transform: uppercase;
}
.h-btn {
  display: flex; align-items: center; justify-content: center; gap: 0.5rem;
  padding: 0.82rem 1.4rem; border-radius: 12px;
  font-size: 0.95rem; font-weight: 900; color: #fff;
  transition: transform .12s, box-shadow .12s; margin-top: auto;
}
.h-btn:hover  { transform: translateY(-2px); }
.h-btn:active { transform: translateY(2px); }
.h-btn--orange { background: var(--orange); box-shadow: 0 5px 0 var(--orange-d), 0 6px 18px rgba(255,107,53,.28); }
.h-btn--orange:hover { box-shadow: 0 7px 0 var(--orange-d), 0 8px 24px rgba(255,107,53,.36); }
.h-btn--blue   { background: var(--blue);   box-shadow: 0 5px 0 var(--blue-d),   0 6px 18px rgba(74,144,226,.28); }
.h-btn--blue:hover   { box-shadow: 0 7px 0 var(--blue-d), 0 8px 24px rgba(74,144,226,.36); }
.h-error { color: var(--red); font-size: 0.8rem; font-weight: 800; min-height: 1em; }

/* How to play */
.h-htp {
  display: flex; align-items: center; gap: 0.6rem; flex-wrap: wrap; justify-content: center;
  padding: 0.9rem 1.5rem;
  background: var(--surface); border: 2px solid var(--border);
  border-radius: 16px; width: 100%; max-width: 860px;
  box-shadow: var(--shadow-sm);
  animation: slideUp .5s .16s cubic-bezier(.34,1.3,.64,1) both;
}
.h-htp-step { display: flex; align-items: center; gap: 0.4rem; font-size: 0.8rem; font-weight: 800; color: var(--txt-m); }
.h-htp-num {
  width: 24px; height: 24px; border-radius: 8px; flex-shrink: 0;
  background: var(--orange); color: #fff; font-size: 0.75rem; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
}
.h-htp-arrow { color: var(--txt-l); flex-shrink: 0; }

@media(max-width:640px) {
  .hc-inner { flex-direction: column; align-items: center; }
  .hc-preview-side { flex-direction: row; align-items: center; gap: 1rem; width: 100%; }
  .hc-canvas { width: 100px; height: 100px; }
  .hc-options-side { width: 100%; }
  .h-game-cards { flex-direction: column; }
  .h-card { min-width: 0; max-width: 100%; }
  .h-htp-arrow { display: none; }
}


/* ═══════════════════════════════════════════════════════════
   LOBBY PAGE
   ═══════════════════════════════════════════════════════════ */

#screenLobby { min-height: 100vh; background: var(--bg); }

/* Top bar */
.lb-topbar {
  display: grid; grid-template-columns: 1fr auto 1fr;
  align-items: center;
  height: 56px; padding: 0 1.25rem;
  background: var(--surface);
  border-bottom: 2.5px solid var(--border);
  position: sticky; top: 0; z-index: 20;
  box-shadow: var(--shadow-sm);
}
.lb-back {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: 0.82rem; font-weight: 900; letter-spacing: 0.06em;
  color: var(--txt-m); transition: color .2s;
}
.lb-back:hover { color: var(--orange); }
.lb-logo {
  display: flex; align-items: center; gap: 0.45rem;
  font-family: 'Bebas Neue', sans-serif; font-size: 1.4rem;
  letter-spacing: 0.1em; color: var(--txt);
}
.lb-logo svg { color: var(--orange); }
.lb-topbar-right { display: flex; justify-content: flex-end; }
.lb-live-badge {
  display: inline-flex; align-items: center; gap: 0.35rem;
  font-size: 0.62rem; font-weight: 900; letter-spacing: 0.14em; text-transform: uppercase;
  background: rgba(39,174,96,.1); color: var(--green);
  padding: 0.2rem 0.65rem; border-radius: 50px;
  border: 1.5px solid rgba(39,174,96,.3);
}
.lb-live-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green); box-shadow: 0 0 6px var(--green);
  animation: livePulse 2s ease-in-out infinite;
}
@keyframes livePulse { 0%,100%{opacity:1;} 50%{opacity:.25;} }

/* Body */
.lb-body {
  display: flex; flex-wrap: wrap; gap: 1.25rem;
  padding: 1.5rem; max-width: 960px; margin: 0 auto; width: 100%;
  align-items: flex-start;
}
.lb-left  { flex: 1; min-width: 260px; display: flex; flex-direction: column; gap: 1rem; }
.lb-right { width: 280px; flex-shrink: 0; display: flex; flex-direction: column; gap: 1rem; }

/* Code card */
/* ── Gate overlay (code required for URL visitors) ───────────── */
.lb-gate {
  position: fixed; inset: 0; z-index: 200;
  background: var(--bg);
  display: flex; align-items: center; justify-content: center;
  padding: 1rem;
}
.lb-gate.hidden { display: none; }
.lb-gate-card {
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 24px; padding: 2rem 2rem 1.75rem;
  box-shadow: 0 8px 0 var(--border-d), var(--shadow-lg);
  width: 100%; max-width: 360px;
  display: flex; flex-direction: column; align-items: center; gap: 0.75rem;
  text-align: center;
  animation: heroIn .35s cubic-bezier(.34,1.2,.64,1);
}
.lb-gate-icon {
  width: 56px; height: 56px; border-radius: 16px;
  background: rgba(255,107,53,.08); border: 2px solid rgba(255,107,53,.2);
  display: flex; align-items: center; justify-content: center;
  color: var(--orange); margin-bottom: 0.25rem;
}
.lb-gate-title { font-family: 'Bebas Neue', sans-serif; font-size: 2rem; letter-spacing: 0.04em; color: var(--txt); line-height: 1; }
.lb-gate-desc  { font-size: 0.84rem; color: var(--txt-m); font-weight: 700; line-height: 1.5; }
.lb-gate-field { width: 100%; }
.lb-gate-input {
  width: 100%; text-align: center;
  font-family: 'Bebas Neue', sans-serif; font-size: 2.2rem; letter-spacing: 0.28em;
  color: var(--orange); background: var(--surface2);
  border: 2px solid var(--border); border-radius: 12px;
  padding: 0.6rem 1rem; outline: none; text-transform: uppercase;
  transition: border-color .15s;
}
.lb-gate-input:focus { border-color: var(--orange); }
.lb-gate-error {
  font-size: 0.78rem; font-weight: 800; color: var(--red);
  background: rgba(231,76,60,.06); border: 1.5px solid rgba(231,76,60,.25);
  border-radius: 8px; padding: 0.4rem 0.75rem; width: 100%;
}
.lb-gate-error.hidden { display: none; }
.lb-gate-btn {
  width: 100%; padding: 0.85rem; border-radius: 12px;
  background: var(--orange); color: #fff;
  font-size: 0.95rem; font-weight: 900; font-family: inherit;
  box-shadow: 0 4px 0 var(--orange-d);
  transition: transform .12s, box-shadow .12s;
  border: none; cursor: pointer;
}
.lb-gate-btn:hover { transform: translateY(-2px); box-shadow: 0 6px 0 var(--orange-d); }
.lb-gate-btn:active { transform: translateY(2px); box-shadow: 0 2px 0 var(--orange-d); }
.lb-gate-btn:disabled { opacity: .6; cursor: not-allowed; transform: none; }
.lb-gate-back { font-size: 0.78rem; font-weight: 700; color: var(--txt-m); text-decoration: none; }
.lb-gate-back:hover { color: var(--orange); }

.lb-code-card {
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 22px; padding: 1.5rem 1.75rem;
  box-shadow: 0 5px 0 var(--border-d), var(--shadow);
  text-align: center;
}
.lb-code-eyebrow {
  display: flex; align-items: center; justify-content: center; gap: 0.4rem;
  font-size: 0.62rem; font-weight: 900; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--txt-m); margin-bottom: 0.25rem;
}
.lb-code-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--green); box-shadow: 0 0 7px var(--green);
  animation: livePulse 2s ease-in-out infinite;
}
.lb-code-reveal-btn {
  margin-left: auto; background: none; border: none; cursor: pointer;
  color: var(--txt-l); padding: 0.2rem; border-radius: 5px;
  display: flex; align-items: center; transition: color .15s;
}
.lb-code-reveal-btn:hover { color: var(--orange); }

.lb-code-display { position: relative; margin-bottom: 1.1rem; min-height: 5.5rem; display: flex; align-items: center; justify-content: center; }
.lb-code-digits {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(3.5rem,12vw,5.5rem); letter-spacing: 0.28em; line-height: 1;
  color: var(--orange); display: block;
}
.lb-code-digits.lb-code-hidden { display: none; }
.lb-code-mask {
  font-size: clamp(2rem,8vw,3.2rem); letter-spacing: 0.35em;
  color: var(--border-d); user-select: none;
}
.lb-share-row { display: flex; gap: 0.6rem; margin-bottom: 0.65rem; }
.lb-copy-btn {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 0.4rem;
  padding: 0.58rem 0.9rem;
  border: 2px solid var(--border); border-radius: 10px;
  background: var(--surface2);
  font-size: 0.78rem; font-weight: 900; color: var(--txt-m); font-family: inherit;
  box-shadow: 0 3px 0 var(--border-d);
  transition: all .15s;
}
.lb-copy-btn:hover { border-color: var(--orange); color: var(--orange); background: rgba(255,107,53,.05); box-shadow: 0 3px 0 var(--orange-d); }
.lb-copy-btn--link:hover { border-color: var(--blue); color: var(--blue); background: rgba(74,144,226,.05); box-shadow: 0 3px 0 var(--blue-d); }
.lb-url-preview { font-size: 0.64rem; color: var(--txt-l); word-break: break-all; line-height: 1.5; }

/* Players */
.lb-players-card {
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 22px; padding: 1.1rem 1.25rem 1.25rem;
  box-shadow: 0 5px 0 var(--border-d), var(--shadow);
}
.lb-players-header {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.85rem;
}
.lb-players-title {
  display: flex; align-items: center; gap: 0.4rem;
  font-size: 0.7rem; font-weight: 900; letter-spacing: 0.14em; text-transform: uppercase; color: var(--txt-m);
}
.lb-players-title svg { color: var(--orange); }
.lb-players-count { font-family: 'Bebas Neue', sans-serif; font-size: 1rem; letter-spacing: 0.08em; color: var(--orange); }

.lb-player-list { display: flex; flex-direction: column; gap: 0.45rem; }
.player-item {
  display: flex; align-items: center; gap: 0.65rem;
  padding: 0.55rem 0.75rem;
  background: var(--surface2); border: 2px solid var(--border);
  border-radius: 12px;
  animation: playerIn .3s cubic-bezier(.34,1.4,.64,1);
}
@keyframes playerIn { from{opacity:0;transform:translateX(-10px);} to{opacity:1;transform:none;} }
.player-avatar {
  width: 34px; height: 34px; border-radius: 50%; flex-shrink: 0;
  background: var(--orange);
  display: flex; align-items: center; justify-content: center;
  font-weight: 900; font-size: 0.8rem; color: #fff;
  box-shadow: 0 2px 0 var(--orange-d);
}
/* Char avatar in lobby player list */
.player-avatar-char {
  flex-shrink: 0;
  background: var(--surface); border-radius: 10px;
  border: 2px solid var(--border);
  overflow: hidden;
}
.player-name {
  font-weight: 800; font-size: 0.88rem; flex: 1; color: var(--txt);
  display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap;
}
.player-badge {
  font-size: 0.62rem; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase;
  padding: 0.15rem 0.55rem; border-radius: 50px;
  background: var(--yellow); color: #7a5800; border: 1.5px solid rgba(0,0,0,.08);
}
.player-badge--you { background: var(--orange); color: #fff; }
.kick-btn {
  background: transparent; border: 2px solid var(--border); color: var(--txt-l);
  border-radius: 7px; width: 26px; height: 26px; font-size: .7rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .15s; flex-shrink: 0; margin-left: auto;
}
.kick-btn:hover { background: rgba(231,76,60,.08); border-color: var(--red); color: var(--red); }

/* Char avatar in scoreboard sidebar */
.sb-item .char-avatar, .sb-item .char-avatar img { border-radius: 6px; }
.sb-vote-item .char-avatar { border-radius: 50%; overflow: hidden; flex-shrink: 0; }
.sb-vote-av--waiting .char-avatar { opacity: 0.5; }

/* Info panel */
.lb-info-panel {
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 22px; padding: 1.1rem 1.25rem;
  box-shadow: 0 5px 0 var(--border-d), var(--shadow);
}
.lb-info-header {
  display: flex; align-items: center; gap: 0.5rem;
  font-size: 0.68rem; font-weight: 900; letter-spacing: 0.16em; text-transform: uppercase; color: var(--txt-m);
  margin-bottom: 0.85rem;
}
.lb-info-header svg { color: var(--txt-m); flex-shrink: 0; }
.lb-info-rows { display: flex; flex-direction: column; gap: 0.55rem; }
.lb-info-row {
  display: flex; align-items: center; gap: 0.65rem;
  font-size: 0.83rem; color: var(--txt-m); font-weight: 700;
}
.lb-info-icon {
  width: 30px; height: 30px; border-radius: 9px; flex-shrink: 0;
  background: rgba(255,107,53,.08); border: 2px solid rgba(255,107,53,.18);
  display: flex; align-items: center; justify-content: center;
}
.lb-info-icon svg { color: var(--orange); }

/* ── Host settings panel ──────────────────────────────────── */
.lb-settings { display: flex; flex-direction: column; gap: 0.6rem; }
.lb-settings.hidden { display: none; }

.lb-setting-row {
  display: flex; flex-direction: column; gap: 0.35rem;
  background: var(--surface2); border: 1.5px solid var(--border);
  border-radius: 12px; padding: 0.7rem 0.85rem;
}

.lb-setting-top {
  display: flex; align-items: center; justify-content: space-between;
}
.lb-setting-label {
  display: flex; align-items: center; gap: 0.4rem;
  font-size: 0.72rem; font-weight: 900; letter-spacing: 0.05em;
  text-transform: uppercase; color: var(--txt-m);
}
.lb-setting-label svg { color: var(--orange); flex-shrink: 0; }

.lb-setting-val {
  font-family: 'Bebas Neue', sans-serif; font-size: 1.4rem;
  color: var(--txt); letter-spacing: 0.04em; line-height: 1;
}

.lb-setting-control { display: flex; align-items: center; gap: 0.5rem; }
.lb-slider {
  flex: 1; height: 5px; border-radius: 3px; cursor: pointer;
  appearance: none; -webkit-appearance: none;
  background: var(--border); outline: none;
}
.lb-slider::-webkit-slider-thumb {
  appearance: none; -webkit-appearance: none;
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--orange); border: 2.5px solid #fff;
  box-shadow: 0 2px 6px rgba(255,107,53,.35);
  cursor: pointer; transition: transform .1s;
}
.lb-slider::-webkit-slider-thumb:hover { transform: scale(1.12); }
.lb-slider::-moz-range-thumb {
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--orange); border: 2.5px solid #fff;
  box-shadow: 0 2px 6px rgba(255,107,53,.35); cursor: pointer;
}

/* Toggle row variant */
.lb-setting-row--toggle { flex-direction: row; align-items: center; justify-content: space-between; }
.lb-setting-row--toggle .lb-setting-label { font-size: 0.72rem; }
.lb-setting-row--toggle .lb-setting-val { font-size: 1rem; color: var(--txt-m); }
.lb-setting-row--toggle.active .lb-setting-val { color: var(--green); }

.lb-toggle { position: relative; display: inline-block; width: 44px; height: 24px; flex-shrink: 0; }
.lb-toggle input { opacity: 0; width: 0; height: 0; position: absolute; }
.lb-toggle-track {
  position: absolute; inset: 0; border-radius: 24px;
  background: var(--border-d); cursor: pointer;
  transition: background .2s; border: 2px solid transparent;
}
.lb-toggle input:checked + .lb-toggle-track { background: var(--green); }
.lb-toggle-thumb {
  position: absolute; top: 3px; left: 3px;
  width: 16px; height: 16px; border-radius: 50%;
  background: #fff; transition: transform .2s;
  box-shadow: 0 1px 4px rgba(0,0,0,.25);
}
.lb-toggle input:checked + .lb-toggle-track .lb-toggle-thumb { transform: translateX(20px); }

/* Host panel */
.lb-host-panel { display: flex; flex-direction: column; gap: 0.5rem; }
.lb-start-btn {
  width: 100%; display: flex; align-items: center; justify-content: center; gap: 0.6rem;
  padding: 1rem 1.5rem; border-radius: 14px; border: none; cursor: pointer;
  font-size: 1rem; font-weight: 900; color: #fff; font-family: inherit;
  background: var(--green);
  box-shadow: 0 5px 0 var(--green-d), 0 7px 20px rgba(39,174,96,.28);
  transition: transform .12s, box-shadow .12s;
}
.lb-start-btn:hover:not(:disabled)  { transform: translateY(-2px); box-shadow: 0 7px 0 var(--green-d), 0 10px 26px rgba(39,174,96,.36); }
.lb-start-btn:active:not(:disabled) { transform: translateY(2px);  box-shadow: 0 3px 0 var(--green-d); }
.lb-start-btn:disabled { opacity: .45; cursor: not-allowed; }
.lb-start-btn svg { flex-shrink: 0; }
.lb-start-hint { font-size: 0.7rem; text-align: center; color: var(--txt-m); font-weight: 700; }

/* Guest waiting */
.lb-waiting {
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 14px; padding: 1.25rem;
  display: flex; flex-direction: column; align-items: center; gap: 0.75rem;
  font-size: 0.85rem; color: var(--txt-m); font-weight: 800;
  box-shadow: 0 4px 0 var(--border-d), var(--shadow-sm);
}
.lb-waiting-dots { display: flex; gap: 6px; }
.lb-waiting-dots span {
  width: 10px; height: 10px; border-radius: 50%; background: var(--orange);
  animation: dotBounce 1.1s infinite;
}
.lb-waiting-dots span:nth-child(2) { animation-delay:.18s; background: var(--blue); }
.lb-waiting-dots span:nth-child(3) { animation-delay:.36s; background: var(--green); }
@keyframes dotBounce { 0%,80%,100%{transform:scale(.55);opacity:.35;} 40%{transform:scale(1);opacity:1;} }

@media(max-width:680px) {
  .lb-body { flex-direction: column; }
  .lb-right { width: 100%; }
}



/* ═══════════════════════════════════════════════════════════
   GAME PAGE  (light, playful – matching home/lobby)
   ═══════════════════════════════════════════════════════════ */

.game-page {
  display: flex; flex-direction: column;
  height: calc(100dvh - 48px); overflow: hidden;
  background: var(--bg);
}

/* ═══════════════════════════════════════════════════════════
   RESULTS PAGE  (final screen)
   ═══════════════════════════════════════════════════════════ */

.results-page { background: var(--bg); }
.results-main {
  position: relative; z-index: 1;
  display: flex; flex-direction: column; align-items: center; gap: 1.75rem;
  padding: 2rem 1.5rem 4rem; max-width: 600px; margin: 0 auto; width: 100%;
}

.results-header { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 0.4rem; }
.results-crown-icon {
  width: 52px; height: 52px; color: var(--yellow-d);
  animation: float 2s ease-in-out infinite;
  filter: drop-shadow(0 4px 6px rgba(193,165,13,.3));
}
@keyframes float { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-8px);} }
.results-title {
  font-family: 'Bebas Neue', sans-serif; font-size: 3.5rem;
  color: var(--txt); letter-spacing: 0.05em;
}
.results-subtitle { font-size: 1rem; color: var(--txt-m); font-weight: 800; }

/* Podium */
.podium-section {
  display: flex; align-items: flex-end; justify-content: center; gap: 0.5rem;
  width: 100%; max-width: 460px;
}
.podium-slot { display: flex; flex-direction: column; align-items: center; flex: 1; }
.podium-avatar {
  font-family: 'Bebas Neue', sans-serif; font-size: 1.3rem;
  width: 48px; height: 48px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 0.25rem; border: 3px solid #fff;
  box-shadow: var(--shadow-sm);
}
.podium-avatar--1 { background: var(--yellow); color: #7a5800; box-shadow: 0 4px 12px rgba(241,196,15,.4); }
.podium-avatar--2 { background: #b0b8cc; color: #3a4260; }
.podium-avatar--3 { background: #cd7f32; color: #fff; }
.podium-name  { font-weight: 900; font-size: 0.85rem; text-align: center; margin-bottom: 0.2rem; word-break: break-word; color: var(--txt); }
.podium-score { font-family: 'Bebas Neue', sans-serif; font-size: 1.15rem; color: var(--orange); margin-bottom: 0.3rem; }
.podium-block { width: 100%; border-radius: 10px 10px 0 0; }
.podium-block--1 { height: 88px; background: linear-gradient(to top, var(--yellow-d), var(--yellow)); }
.podium-block--2 { height: 64px; background: linear-gradient(to top, #8a94aa, #b0b8cc); }
.podium-block--3 { height: 44px; background: linear-gradient(to top, #a0622a, #cd7f32); }

/* Full rankings */
.full-rankings { width: 100%; }
.full-rankings h3 {
  font-family: 'Bebas Neue', sans-serif; font-size: 1.3rem; letter-spacing: 0.06em;
  color: var(--txt-m); margin-bottom: 0.75rem;
}
.final-list { display: flex; flex-direction: column; gap: 0.5rem; }
.final-item {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.7rem 1rem;
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 14px; font-size: 0.9rem;
  box-shadow: 0 3px 0 var(--border-d);
  animation: slideIn .4s ease both;
}
.final-item:nth-child(1){animation-delay:.08s;} .final-item:nth-child(2){animation-delay:.16s;}
.final-item:nth-child(3){animation-delay:.24s;} .final-item:nth-child(4){animation-delay:.32s;}
.final-item.is-me { border-color: rgba(255,107,53,.5); box-shadow: 0 3px 0 var(--orange-d); }
@keyframes slideIn { from{opacity:0;transform:translateY(8px);} to{opacity:1;transform:none;} }
.final-rank  { width: 28px; font-family: 'Bebas Neue', sans-serif; font-size: 1.1rem; color: var(--txt-m); }
.final-name  { flex: 1; font-weight: 800; color: var(--txt); }
.final-score { font-family: 'Bebas Neue', sans-serif; font-size: 1.2rem; color: var(--orange); }

.results-actions { margin-top: 0.5rem; }
.results-actions .h-btn { padding: 1rem 2.5rem; font-size: 1rem; border-radius: 14px; }

/* ── iframe + misc helpers ────────────────────────────────── */
.iframe-error {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  color: var(--txt-m); font-size: .9rem; padding: 1rem; text-align: center;
}
.channel-attribution {
  display: flex; align-items: center; gap: .5rem; padding: .35rem .8rem;
  background: rgba(26,31,58,.7); border-radius: 8px;
  font-size: .78rem; font-weight: 700; color: #fff; margin-bottom: .4rem;
  backdrop-filter: blur(4px);
}
.channel-attribution a { color: var(--orange); font-weight: 800; }
#revealContainer iframe { border-radius: 10px; border: 2.5px solid rgba(39,174,96,.5); }
.clip-progress-wrap { height: 4px; background: rgba(255,255,255,.1); border-radius: 0 0 10px 10px; overflow: hidden; }
.answered-bar {
  display: flex; align-items: center; gap: .75rem; padding: .5rem 1rem;
  background: var(--surface); border: 2px solid var(--border);
  border-radius: 10px; margin-top: .75rem; flex-wrap: wrap;
}
.answered-label { font-size: .78rem; font-weight: 800; color: var(--txt-m); white-space: nowrap; }
.answered-avatars { display: flex; flex-wrap: wrap; gap: .3rem; }
.answered-av {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--green); color: #fff; font-size: .68rem; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
  animation: popIn .2s cubic-bezier(.34,1.56,.64,1);
  border: 2px solid #fff; box-shadow: 0 1px 4px rgba(0,0,0,.12);
}
.clip-spinner {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .75rem;
  background: rgba(238,241,250,.85); backdrop-filter: blur(4px);
  z-index: 10; color: var(--txt-m); font-size: .85rem; font-weight: 700; border-radius: 10px;
}
.spinner-ring {
  width: 38px; height: 38px; border: 3px solid var(--border);
  border-top-color: var(--orange); border-radius: 50%; animation: lspin .8s linear infinite;
}
.kick-btn {
  background: transparent; border: 2px solid var(--border); color: var(--txt-l);
  border-radius: 7px; width: 26px; height: 26px; font-size: .7rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .15s; flex-shrink: 0; margin-left: auto;
}
.kick-btn:hover { background: rgba(231,76,60,.08); border-color: var(--red); color: var(--red); }
.player-badge--you { background: var(--orange) !important; color: #fff !important; border-color: var(--orange-d) !important; }

/* Podium avatar number 1/2/3 */
.scoreboard-item svg { color: var(--green); flex-shrink: 0; }
.scoreboard-item svg.wrong-icon { color: var(--red); }
.scoreboard-item svg.timeout-icon { color: var(--txt-l); }
.results-crown-icon { color: var(--yellow-d); }
.podium-avatar--1 { animation: podiumBounce 1.5s ease-in-out infinite; }
@keyframes podiumBounce { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-5px);} }

/* ── Ready bar (between rounds) ───────────────────────────── */
.ready-bar {
  display: flex; align-items: center; gap: 1rem;
  width: 100%; max-width: 720px;
  padding: 0.75rem 1rem;
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 16px;
  box-shadow: 0 4px 0 var(--border-d), var(--shadow-sm);
  animation: heroIn .4s cubic-bezier(.34,1.2,.64,1);
}
.ready-bar.hidden { display: none !important; }
.ready-btn {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.75rem 1.4rem; border-radius: 12px;
  background: var(--green); color: #fff;
  font-size: 0.95rem; font-weight: 900; font-family: inherit;
  box-shadow: 0 4px 0 var(--green-d);
  transition: transform .12s, box-shadow .12s;
  flex-shrink: 0; white-space: nowrap;
}
.ready-btn:hover { transform: translateY(-2px); box-shadow: 0 6px 0 var(--green-d); }
.ready-btn:active { transform: translateY(2px); box-shadow: 0 2px 0 var(--green-d); }
.ready-btn--done {
  background: var(--border-d); color: var(--txt-m);
  box-shadow: 0 4px 0 var(--border-d); cursor: default;
  opacity: .7;
}
.ready-btn--done:hover { transform: none; }

.ready-progress {
  display: flex; flex-direction: column; gap: 0.35rem; flex: 1; min-width: 0;
}
.ready-count {
  font-size: 0.75rem; font-weight: 900; letter-spacing: 0.06em;
  color: var(--txt-m);
}
.ready-pips {
  display: flex; gap: 5px; flex-wrap: wrap;
}
.ready-pip {
  width: 22px; height: 8px; border-radius: 4px;
  background: var(--border); border: 1.5px solid var(--border-d);
  transition: background .25s, border-color .25s, transform .2s;
}
.ready-pip--on {
  background: var(--green);
  border-color: var(--green-d);
  animation: pipPop .3s cubic-bezier(.34,1.56,.64,1);
}
@keyframes pipPop { from{transform:scale(.6);} to{transform:scale(1);} }

/* next-bar stays for last-round (hidden otherwise) */
.next-bar {
  display: flex; align-items: center; gap: 0.6rem;
  font-weight: 800; color: var(--txt-m); font-size: .82rem;
}
.next-ring { position:relative; width:42px; height:42px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.next-ring svg { position:absolute; inset:0; }
.next-num { font-family:'Bebas Neue',sans-serif; font-size:1.2rem; color:var(--orange); position:relative; z-index:1; }

/* ═══════════════════════════════════════════════════════════
   HOME — Settings & Browse
   ═══════════════════════════════════════════════════════════ */

/* Settings row inside create card */
.h-settings-row {
  display: flex; flex-direction: column; gap: 0.75rem;
}
.h-setting { display: flex; flex-direction: column; gap: 0.3rem; }

/* Toggle group (Private / Öffentlich) */
.h-toggle-group {
  display: flex; gap: 0;
  background: var(--surface2); border: 2px solid var(--border);
  border-radius: 10px; overflow: hidden;
}
.h-toggle {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 0.35rem;
  padding: 0.55rem 0.75rem;
  font-size: 0.8rem; font-weight: 900; font-family: inherit;
  color: var(--txt-m); background: transparent;
  border: none; cursor: pointer;
  transition: background .15s, color .15s;
}
.h-toggle + .h-toggle { border-left: 2px solid var(--border); }
.h-toggle--active {
  background: var(--orange); color: #fff;
}
.h-toggle--active svg { color: #fff; }

/* Range slider */
.h-slider {
  width: 100%; height: 6px;
  -webkit-appearance: none; appearance: none;
  background: var(--border); border-radius: 3px; outline: none;
  cursor: pointer;
}
.h-slider::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--orange); box-shadow: 0 2px 0 var(--orange-d);
  cursor: pointer;
}
.h-slider::-moz-range-thumb {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--orange); box-shadow: 0 2px 0 var(--orange-d);
  cursor: pointer; border: none;
}

/* Browse link button */
.h-btn-browse {
  display: flex; align-items: center; justify-content: center; gap: 0.4rem;
  width: 100%; padding: 0.6rem 1rem;
  background: var(--surface2); border: 2px solid var(--border);
  border-radius: 10px; cursor: pointer;
  font-size: 0.82rem; font-weight: 900; color: var(--txt-m); font-family: inherit;
  box-shadow: 0 3px 0 var(--border-d);
  transition: all .15s; margin-top: auto;
}
.h-btn-browse:hover { border-color: var(--blue); color: var(--blue); background: rgba(74,144,226,.05); box-shadow: 0 3px 0 var(--blue-d); }

/* ═══════════════════════════════════════════════════════════
   BROWSE SCREEN
   ═══════════════════════════════════════════════════════════ */

#screenBrowse { background: var(--bg); }

.browse-main {
  flex: 1; display: flex; flex-direction: column;
  padding: 1.5rem; max-width: 720px; margin: 0 auto; width: 100%;
  gap: 1rem; position: relative; z-index: 1;
}

.browse-join-row {
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 16px; padding: 1rem 1.25rem;
  box-shadow: 0 4px 0 var(--border-d), var(--shadow-sm);
}
.browse-join-field { display: flex; flex-direction: column; gap: 0.3rem; max-width: 320px; }

.browse-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 0.25rem;
}
.browse-header-title {
  display: flex; align-items: center; gap: 0.45rem;
  font-size: 0.7rem; font-weight: 900; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--txt-m);
}
.browse-header-title svg { color: var(--orange); }
.browse-count { font-size: 0.72rem; font-weight: 800; color: var(--txt-l); }

.browse-list {
  display: flex; flex-direction: column; gap: 0.6rem;
}

/* Empty state */
.browse-empty {
  display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
  padding: 3rem 1rem; text-align: center;
  background: var(--surface); border: 2.5px dashed var(--border);
  border-radius: 20px; color: var(--txt-m);
}
.browse-empty svg { opacity: .4; }
.browse-empty p   { font-weight: 800; font-size: 0.95rem; color: var(--txt-m); }
.browse-empty span { font-size: 0.82rem; color: var(--txt-l); font-weight: 700; }

/* Lobby card */
.browse-card {
  display: flex; align-items: center;
  padding: 1rem 1.1rem;
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 16px;
  box-shadow: 0 4px 0 var(--border-d), var(--shadow-sm);
  animation: playerIn .3s cubic-bezier(.34,1.3,.64,1);
  transition: border-color .15s, box-shadow .15s;
}
.browse-card:hover { border-color: rgba(74,144,226,.4); box-shadow: 0 4px 0 rgba(74,144,226,.3), var(--shadow); }

.browse-card-left { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 0.35rem; }
.browse-card-host { font-weight: 900; font-size: 0.95rem; color: var(--txt); }
.browse-card-meta { display: flex; gap: 0.4rem; flex-wrap: wrap; }

.browse-pill {
  display: inline-flex; align-items: center; gap: 0.3rem;
  padding: 0.15rem 0.55rem; border-radius: 50px;
  font-size: 0.7rem; font-weight: 800;
  background: var(--surface2); border: 1.5px solid var(--border);
  color: var(--txt-m);
}
.browse-pill svg { color: var(--txt-m); }
.browse-pill--green {
  background: rgba(39,174,96,.08); border-color: rgba(39,174,96,.3); color: var(--green);
}
.browse-pill--green svg { color: var(--green); }

.browse-join-btn {
  display: flex; align-items: center; gap: 0.4rem;
  padding: 0.65rem 1.1rem; border-radius: 10px; border: none;
  background: var(--blue); color: #fff;
  font-size: 0.85rem; font-weight: 900; font-family: inherit; cursor: pointer;
  box-shadow: 0 4px 0 var(--blue-d);
  transition: transform .12s, box-shadow .12s;
  flex-shrink: 0; margin-left: 0.75rem;
  white-space: nowrap;
}
.browse-join-btn:hover  { transform: translateY(-2px); box-shadow: 0 6px 0 var(--blue-d); }
.browse-join-btn:active { transform: translateY(2px);  box-shadow: 0 2px 0 var(--blue-d); }

/* Browse card status badges */
.browse-pill--orange {
  background: rgba(255,107,53,.1); border-color: rgba(255,107,53,.35); color: var(--orange);
}
.browse-pill--orange svg { color: var(--orange); }
.browse-pill--red {
  background: rgba(231,76,60,.08); border-color: rgba(231,76,60,.3); color: var(--red);
}
.browse-pill--red svg { color: var(--red); }

/* Disabled join button */
.browse-join-btn--disabled {
  background: var(--surface2) !important; color: var(--txt-l) !important;
  box-shadow: 0 3px 0 var(--border-d) !important;
  cursor: not-allowed !important; opacity: .7;
}
.browse-join-btn--disabled:hover { transform: none !important; box-shadow: 0 3px 0 var(--border-d) !important; }

/* Last round ending message */
.ready-ending-msg {
  display: flex; align-items: center; gap: 0.6rem;
  font-size: 0.9rem; font-weight: 800; color: var(--txt-m);
  padding: 0.25rem 0;
  animation: dotBounce 1.2s infinite;
}
.ready-ending-msg svg { color: var(--orange); flex-shrink: 0; }

/* ── Logo image ───────────────────────────────────────────── */
.site-logo-img {
  height: 52px;
  width: auto;
  object-fit: contain;
  display: block;
  mix-blend-mode: normal;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,.15));
}

/* Hero on home page — bigger, on light bg */
.h-logo-wrap .site-logo-img {
  height: 100px;
  margin: 0 auto;
  mix-blend-mode: normal;
  filter: drop-shadow(0 3px 12px rgba(0,0,0,.12));
}

@media(max-width:640px){
  .h-logo-wrap .site-logo-img { height: 72px; }
}

/* HUD in game — on dark topbar */
.hud-center .site-logo-img {
  height: 38px;
  mix-blend-mode: normal;
}

/* Topbar (lobby/results/browse) — on light surface */
.lb-logo .site-logo-img {
  height: 36px;
  mix-blend-mode: normal;
}

/* ═══════════════════════════════════════════════════════════
   SITE HEADER
   ═══════════════════════════════════════════════════════════ */

.site-header {
  position: sticky; top: 0; z-index: 500;
  background: var(--surface);
  border-bottom: 2.5px solid var(--border);
  box-shadow: var(--shadow-sm);
}
.site-header-inner {
  display: flex; align-items: center; gap: 1rem;
  max-width: 1200px; margin: 0 auto;
  padding: 0 1.25rem; height: 62px;
}
.header-logo { display: flex; align-items: center; flex-shrink: 0; }
.header-logo-img {
  height: 44px; width: auto; object-fit: contain;
  mix-blend-mode: normal;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.15));
}
.header-nav {
  display: flex; align-items: center; gap: 0.25rem;
  margin-left: 1rem; flex: 1;
}
.header-nav-link {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.45rem 0.85rem; border-radius: 10px;
  font-size: 0.85rem; font-weight: 800; color: var(--txt-m);
  text-decoration: none;
  transition: background .15s, color .15s;
}
.header-nav-link:hover { background: var(--surface2); color: var(--txt); }
.header-nav-link.active { color: var(--orange); background: rgba(255,107,53,.08); }
.header-nav-link svg { flex-shrink: 0; }

.header-auth {
  display: flex; align-items: center; gap: 0.5rem; flex-shrink: 0;
}
.header-btn {
  display: inline-flex; align-items: center;
  padding: 0.5rem 1rem; border-radius: 10px;
  font-size: 0.85rem; font-weight: 900; text-decoration: none;
  transition: all .15s;
}
.header-btn--ghost {
  color: var(--txt-m); border: 2px solid var(--border);
  background: transparent;
}
.header-btn--ghost:hover { border-color: var(--orange); color: var(--orange); }
.header-btn--primary {
  background: var(--orange); color: #fff;
  box-shadow: 0 3px 0 var(--orange-d);
}
.header-btn--primary:hover { transform: translateY(-1px); box-shadow: 0 4px 0 var(--orange-d); }
.header-user-btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.4rem 0.8rem; border-radius: 10px;
  font-size: 0.85rem; font-weight: 800; color: var(--txt);
  text-decoration: none; background: var(--surface2);
  border: 2px solid var(--border);
  transition: all .15s;
}
.header-user-btn:hover { border-color: var(--orange); color: var(--orange); }
.header-avatar {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--orange); color: #fff;
  font-size: 0.72rem; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 0 var(--orange-d);
}
.header-logout-btn {
  width: 36px; height: 36px; border-radius: 9px;
  background: var(--surface2); border: 2px solid var(--border);
  color: var(--txt-m); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.header-logout-btn:hover { border-color: var(--red); color: var(--red); background: rgba(231,76,60,.08); }

/* Mobile */
.header-menu-btn {
  display: none; flex-direction: column; gap: 5px; padding: 6px;
  background: none; border: none; cursor: pointer; margin-left: auto;
}
.header-menu-btn span {
  display: block; width: 22px; height: 2px;
  background: var(--txt-m); border-radius: 2px;
  transition: all .2s;
}
.header-menu-btn.open span:nth-child(1) { transform: rotate(45deg) translate(5px,5px); }
.header-menu-btn.open span:nth-child(2) { opacity: 0; }
.header-menu-btn.open span:nth-child(3) { transform: rotate(-45deg) translate(5px,-5px); }

.header-mobile-nav {
  border-top: 2px solid var(--border);
  background: var(--surface);
  padding: 1rem 1.25rem;
  display: flex; flex-direction: column; gap: 0.5rem;
}
.header-mobile-nav .header-nav-link { padding: 0.6rem 0.85rem; }
.header-mobile-nav .header-auth,
#headerMobileAuth { display: flex; flex-direction: column; gap: 0.5rem; margin-top: 0.5rem; }
.header-mobile-nav .header-btn { text-align: center; justify-content: center; }

@media(max-width:700px) {
  .header-nav { display: none; }
  .header-auth { display: none; }
  .header-menu-btn { display: flex; }
}

/* ═══════════════════════════════════════════════════════════
   AUTH PAGES
   ═══════════════════════════════════════════════════════════ */

.auth-main {
  display: flex; align-items: flex-start; justify-content: center;
  padding: 3rem 1.25rem 4rem; min-height: calc(100vh - 62px);
  position: relative; z-index: 1;
}
.auth-card {
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 24px; padding: 2rem 2.5rem;
  width: 100%; max-width: 460px;
  box-shadow: 0 5px 0 var(--border-d), var(--shadow);
}
.auth-card--wide { max-width: 760px; }
.auth-card-header { margin-bottom: 1.5rem; }
.auth-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 2.2rem; letter-spacing: 0.04em; color: var(--txt);
  margin-bottom: 0.2rem;
}
.auth-sub { font-size: 0.9rem; color: var(--txt-m); font-weight: 700; }

.auth-form { display: flex; flex-direction: column; gap: 1rem; margin: 1.25rem 0; }
.auth-form-row { display: flex; gap: 1rem; }
.auth-form-row .h-field { flex: 1; }
@media(max-width:600px) { .auth-form-row { flex-direction: column; } }

.auth-errors {
  background: rgba(231,76,60,.08); border: 2px solid rgba(231,76,60,.3);
  border-radius: 12px; padding: 0.75rem 1rem; margin-bottom: 0.75rem;
}
.auth-error-item { color: var(--red); font-size: 0.85rem; font-weight: 700; }
.auth-success {
  background: rgba(39,174,96,.08); border: 2px solid rgba(39,174,96,.3);
  border-radius: 12px; padding: 0.75rem 1rem; margin-bottom: 0.75rem;
  color: var(--green); font-size: 0.9rem; font-weight: 700;
}
.auth-links {
  display: flex; align-items: center; gap: 0.75rem;
  justify-content: center; flex-wrap: wrap;
  font-size: 0.85rem;
}
.auth-link { color: var(--orange); font-weight: 800; text-decoration: none; }
.auth-link:hover { text-decoration: underline; }
.h-hint { font-size: 0.68rem; color: var(--txt-l); font-weight: 700; margin-top: 2px; }

.input-pw-wrap { position: relative; }
.input-pw-wrap .h-input { padding-right: 2.5rem; }
.pw-toggle {
  position: absolute; right: 10px; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer;
  color: var(--txt-l); padding: 4px;
}
.pw-toggle:hover { color: var(--orange); }
.pw-strength { min-height: 1.1em; margin-top: 3px; }

/* Benefits */
.auth-benefits {
  display: flex; flex-direction: column; gap: 0.75rem;
  margin-bottom: 1.5rem; padding: 1.1rem;
  background: var(--surface2); border: 2px solid var(--border);
  border-radius: 14px;
}
.auth-benefit { display: flex; align-items: flex-start; gap: 0.75rem; }
.auth-benefit-icon { font-size: 1.5rem; flex-shrink: 0; }
.auth-benefit strong { font-size: 0.9rem; color: var(--txt); }
.auth-benefit p { font-size: 0.8rem; color: var(--txt-m); margin: 0; font-weight: 600; }

/* Message page */
.auth-msg-icon {
  width: 64px; height: 64px; border-radius: 50%;
  background: var(--orange); color: #fff;
  font-size: 2rem; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 1rem;
}

/* Profile */
.profile-card {
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 24px; padding: 2rem 2.5rem;
  width: 100%; max-width: 560px;
  box-shadow: 0 5px 0 var(--border-d), var(--shadow);
}
.profile-header { display: flex; align-items: center; gap: 1.25rem; margin-bottom: 1.75rem; }
.profile-avatar {
  width: 72px; height: 72px; border-radius: 50%;
  background: var(--orange); color: #fff;
  font-family: 'Bebas Neue', sans-serif; font-size: 2rem;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 0 var(--orange-d), 0 6px 20px rgba(255,107,53,.25);
  flex-shrink: 0;
}
/* When profile-avatar is inside the char container, it acts as absolute fallback */
#profileCharAv .profile-avatar {
  position: absolute; inset: 0; width: 100%; height: 100%;
  border-radius: 0; box-shadow: none; font-size: 1.6rem;
}
.profile-name { font-family: 'Bebas Neue', sans-serif; font-size: 2rem; letter-spacing: 0.04em; color: var(--txt); margin: 0; }
.profile-since { font-size: 0.82rem; color: var(--txt-m); font-weight: 700; margin: 0; }
.profile-stats {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1rem; margin-bottom: 1.75rem;
}
@media(max-width:500px) { .profile-stats { grid-template-columns: repeat(2,1fr); } }
.profile-stat {
  background: var(--surface2); border: 2px solid var(--border);
  border-radius: 14px; padding: 1rem; text-align: center;
}
.profile-stat-val {
  font-family: 'Bebas Neue', sans-serif; font-size: 1.8rem;
  color: var(--orange); display: block;
}
.profile-stat-label { font-size: 0.7rem; font-weight: 900; color: var(--txt-m); text-transform: uppercase; letter-spacing: 0.1em; }
.profile-actions { display: flex; gap: 0.75rem; }

/* Highscores */
.hs-card {
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 24px; overflow: hidden;
  width: 100%; max-width: 860px;
  box-shadow: 0 5px 0 var(--border-d), var(--shadow);
}
.hs-header { padding: 2rem 2rem 0; }
.hs-cta {
  display: flex; align-items: center; gap: 0.85rem;
  margin: 1rem 2rem;
  background: rgba(255,107,53,.06); border: 2px solid rgba(255,107,53,.2);
  border-radius: 14px; padding: 1rem 1.25rem;
  font-size: 0.85rem; color: var(--txt-m);
}
.hs-cta svg { color: var(--orange); flex-shrink: 0; }
.hs-cta strong { color: var(--txt); font-size: 0.9rem; }
.hs-cta a { color: var(--orange); font-weight: 800; }
.hs-table {
  width: 100%; border-collapse: collapse; margin-top: 1rem;
  font-size: 0.88rem;
}
.hs-table thead th {
  background: var(--surface2); border-bottom: 2px solid var(--border);
  padding: 0.65rem 1rem; text-align: left;
  font-size: 0.68rem; font-weight: 900; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--txt-m);
}
.hs-table tbody tr {
  border-bottom: 1px solid var(--border);
  transition: background .1s;
}
.hs-table tbody tr:hover { background: var(--surface2); }
.hs-table tbody td { padding: 0.65rem 1rem; }
.hs-me { background: rgba(255,107,53,.05) !important; }
.hs-top td { font-weight: 800; }
.hs-rank { width: 48px; }
.hs-medal { font-size: 1.2rem; }
.hs-rank-num { font-family: 'Bebas Neue',sans-serif; font-size: 1.1rem; color: var(--txt-m); }
.hs-name { font-weight: 800; }
.hs-score { font-family: 'Bebas Neue',sans-serif; font-size: 1.1rem; color: var(--orange); }
.hs-you { font-size: 0.72rem; color: var(--orange); font-weight: 900; }
.hs-footer { padding: 1.5rem 2rem; border-top: 2px solid var(--border); }

/* Game page: header is small */
.game-body .site-header { height: 48px; }
.game-body #screenGame, .game-body .game-page-wrap { height: calc(100dvh - 48px); }
.game-body .site-header-inner { height: 48px; }
.game-body .header-logo-img { height: 34px; }

/* ── Logged-in account chip on home cards ─────────────────── */
.h-account-chip {
  display: flex; align-items: center; gap: 0.6rem;
  padding: 0.6rem 0.85rem;
  background: rgba(255,107,53,.08); border: 2px solid rgba(255,107,53,.25);
  border-radius: 12px; margin-bottom: 0.25rem;
  font-size: 0.85rem; font-weight: 700; color: var(--txt-m);
}
.h-account-av {
  width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0;
  background: var(--orange); color: #fff;
  font-size: 0.78rem; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 0 var(--orange-d);
}
.h-account-chip strong { color: var(--orange); }

.lb-right-top {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 0.75rem;
}

/* ═══════════════════════════════════════════════════════════
   CHARACTER CONFIGURATOR
   ═══════════════════════════════════════════════════════════ */

.char-main {
  flex: 1; background: var(--bg);
  display: flex; flex-direction: column;
}

.char-configurator {
  display: flex; flex-direction: row; gap: 2rem;
  width: 100%; max-width: 800px;
  align-items: flex-start;
}

/* Preview column */
.char-preview-col {
  display: flex; flex-direction: column; align-items: center; gap: 1rem;
  flex-shrink: 0;
}
.char-preview-wrap {
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 24px; padding: 1.5rem;
  box-shadow: 0 5px 0 var(--border-d), var(--shadow);
}
.char-canvas {
  position: relative; width: 180px; height: 180px;
}
.char-layer {
  display: block;
}
.char-canvas .char-layer,
.hc-canvas .char-layer,
.h-char-mini .char-layer,
.char-avatar .char-layer {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: contain; image-rendering: pixelated;
}
.char-layer.hidden { display: none !important; }

.char-random-btn {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.65rem 1.25rem; border-radius: 12px;
  background: var(--surface); border: 2px solid var(--border);
  font-size: 0.85rem; font-weight: 900; color: var(--txt-m);
  box-shadow: 0 3px 0 var(--border-d);
  transition: all .15s; cursor: pointer; font-family: inherit;
}
.char-random-btn:hover { border-color: var(--orange); color: var(--orange); background: rgba(255,107,53,.05); }

/* Options column */
.char-options-col {
  flex: 1; display: flex; flex-direction: column; gap: 1.1rem;
}
.char-title {
  font-family: 'Bebas Neue', sans-serif; font-size: 2.2rem;
  letter-spacing: 0.04em; color: var(--txt); line-height: 1;
}
.char-subtitle { font-size: 0.84rem; color: var(--txt-m); font-weight: 700; margin-top: -0.5rem; }

.char-section { display: flex; flex-direction: column; gap: 0.5rem; }
.char-section-label {
  display: flex; align-items: center; gap: 0.4rem;
  font-size: 0.65rem; font-weight: 900; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--txt-m);
}
.char-section-label svg { color: var(--orange); }

.char-items { display: flex; flex-wrap: wrap; gap: 0.45rem; }

.char-item {
  width: 38px; height: 38px; border-radius: 10px;
  border: 2.5px solid var(--border); background: var(--surface);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: border-color .15s, transform .1s, box-shadow .15s;
  box-shadow: 0 2px 0 var(--border-d);
  position: relative; overflow: hidden;
}
.char-item:hover { border-color: var(--orange); transform: translateY(-2px); box-shadow: 0 4px 0 var(--border-d); }
.char-item.active { border-color: var(--orange); box-shadow: 0 2px 0 var(--orange-d), 0 0 0 3px rgba(255,107,53,.2); }
.char-item--none .char-item-none { font-size: 0.9rem; color: var(--txt-l); }
.char-item--none.active { border-color: var(--border-d); box-shadow: 0 2px 0 var(--border-d); background: var(--surface2); }

.char-color-dot {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--c, #ccc);
  border: 2px solid rgba(0,0,0,.12);
}
.char-color-dot--rainbow {
  background: linear-gradient(135deg, red 0%, orange 25%, yellow 45%, green 60%, blue 80%, purple 100%);
}
.char-color-dot--rainbow-green {
  background: linear-gradient(135deg, #27ae60 0%, #2ecc71 50%, #1abc9c 100%);
}
.char-color-dot--rainbow-purple {
  background: linear-gradient(135deg, #8e44ad 0%, #9b59b6 50%, #e91e8c 100%);
}

.char-save-btn {
  display: flex; align-items: center; justify-content: center; gap: 0.6rem;
  width: 100%; padding: 0.9rem 1.5rem; border-radius: 14px; border: none;
  background: var(--green); color: #fff;
  font-size: 1rem; font-weight: 900; font-family: inherit;
  box-shadow: 0 5px 0 var(--green-d), 0 7px 20px rgba(39,174,96,.25);
  transition: transform .12s, box-shadow .12s; cursor: pointer;
  margin-top: 0.5rem;
}
.char-save-btn:hover { transform: translateY(-2px); box-shadow: 0 7px 0 var(--green-d), 0 10px 26px rgba(39,174,96,.35); }
.char-save-btn:active { transform: translateY(2px); box-shadow: 0 3px 0 var(--green-d); }

.char-guest-note { font-size: 0.72rem; color: var(--txt-l); text-align: center; font-weight: 700; }

@media(max-width:600px){
  .char-configurator { flex-direction: column; align-items: center; }
  .char-preview-col { width: 100%; }
  .char-canvas { width: 140px; height: 140px; }
}

/* ── Char Avatar (used in lobby + game) ─────────────────────── */
.char-avatar {
  position: relative; flex-shrink: 0;
}
.char-avatar img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: contain; image-rendering: pixelated;
  pointer-events: none;
}
.char-avatar img.hidden { display: none; }

/* ── Home page char preview button ──────────────────────────── */
.h-char-preview-btn {
  display: inline-flex; align-items: center; gap: 0.75rem;
  padding: 0.5rem 1rem 0.5rem 0.5rem;
  background: var(--surface); border: 2px solid var(--border);
  border-radius: 14px; text-decoration: none;
  box-shadow: 0 3px 0 var(--border-d), var(--shadow-sm);
  transition: border-color .15s, transform .12s, box-shadow .12s;
  margin-top: 0.5rem;
}
.h-char-preview-btn:hover {
  border-color: var(--orange); transform: translateY(-2px);
  box-shadow: 0 5px 0 var(--border-d), var(--shadow);
}
.h-char-mini {
  position: relative; width: 52px; height: 52px; flex-shrink: 0;
}
.h-char-edit-label {
  display: flex; align-items: center; gap: 0.35rem;
  font-size: 0.8rem; font-weight: 900; color: var(--txt-m);
}
.h-char-edit-label svg { color: var(--orange); }

/* ── Char avatar button in card header ───────────────────────── */
.h-card-top-row {
  display: flex; align-items: center; justify-content: space-between;
}
.h-char-btn {
  position: relative; cursor: pointer;
  background: none; border: none; padding: 0;
  flex-shrink: 0;
}
.h-char-btn-canvas {
  position: relative; width: 52px; height: 52px;
  border-radius: 12px; overflow: hidden;
  background: var(--surface2); border: 2px solid var(--border);
  transition: border-color .15s, transform .12s;
}
.h-char-btn:hover .h-char-btn-canvas {
  border-color: var(--orange); transform: translateY(-2px);
}
.h-char-btn-canvas .char-layer {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: contain; image-rendering: pixelated;
}
.h-char-btn-canvas .char-layer.hidden { display: none; }
.h-char-btn-edit {
  position: absolute; bottom: -4px; right: -4px;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--orange); color: #fff;
  display: flex; align-items: center; justify-content: center;
  border: 2px solid var(--surface);
  box-shadow: 0 1px 4px rgba(255,107,53,.4);
}

/* ── Char modal ───────────────────────────────────────────────── */
.char-modal-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(0,0,0,.45); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: 1rem;
  animation: fadeIn .18s ease;
}
.char-modal-overlay.hidden { display: none; }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }

.char-modal {
  background: var(--surface); border: 2.5px solid var(--border);
  border-radius: 24px; width: 100%; max-width: 600px;
  max-height: 90dvh; display: flex; flex-direction: column;
  box-shadow: 0 8px 0 var(--border-d), 0 24px 60px rgba(0,0,0,.25);
  animation: modalIn .22s cubic-bezier(.34,1.3,.64,1);
  overflow: hidden;
}
@keyframes modalIn { from{opacity:0;transform:scale(.92) translateY(12px)} to{opacity:1;transform:none} }

.char-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem 1.4rem 1rem;
  border-bottom: 2px solid var(--border);
  flex-shrink: 0;
}
.char-modal-title {
  font-family: 'Bebas Neue', sans-serif; font-size: 1.5rem;
  letter-spacing: 0.04em; color: var(--txt);
}
.char-modal-close {
  width: 34px; height: 34px; border-radius: 9px;
  background: var(--surface2); border: 2px solid var(--border);
  color: var(--txt-m); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.char-modal-close:hover { border-color: var(--red); color: var(--red); background: rgba(231,76,60,.07); }

.char-modal-body {
  display: flex; gap: 1.25rem; padding: 1.25rem 1.4rem;
  overflow-y: auto; flex: 1;
}
.char-modal-preview {
  display: flex; flex-direction: column; align-items: center; gap: 0.75rem;
  flex-shrink: 0;
}
.char-modal-canvas {
  position: relative; width: 130px; height: 130px;
  background: var(--surface2); border: 2px solid var(--border);
  border-radius: 16px; overflow: hidden;
}
.char-modal-canvas .char-layer {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: contain; image-rendering: pixelated;
}
.char-modal-canvas .char-layer.hidden { display: none; }

.char-modal-options {
  flex: 1; display: flex; flex-direction: column; gap: 0.65rem; min-width: 0;
}

.char-modal-footer {
  padding: 1rem 1.4rem;
  border-top: 2px solid var(--border);
  flex-shrink: 0;
}
.char-modal-save {
  width: 100%; display: flex; align-items: center; justify-content: center; gap: 0.5rem;
  padding: 0.82rem; border-radius: 12px; border: none; cursor: pointer;
  background: var(--green); color: #fff;
  font-size: 0.95rem; font-weight: 900; font-family: inherit;
  box-shadow: 0 4px 0 var(--green-d);
  transition: transform .12s, box-shadow .12s;
}
.char-modal-save:hover { transform: translateY(-2px); box-shadow: 0 6px 0 var(--green-d); }
.char-modal-save:active { transform: translateY(2px); box-shadow: 0 2px 0 var(--green-d); }

@media(max-width:500px){
  .char-modal-body { flex-direction: column; align-items: center; }
  .char-modal-canvas { width: 100px; height: 100px; }
}


/* ── Page wrapper for non-game pages (lobby, char, etc.) ──── */
.page-wrap {
  display: flex; flex-direction: column;
  min-height: calc(100dvh - 62px);
  overflow-y: auto; overflow-x: hidden;
}
.page-wrap > .site-footer { margin-top: auto; flex-shrink: 0; }
.page-wrap > main { flex: 1; }

/* char-main: flex column so footer is pushed down */
.char-main {
  flex: 1;
  display: flex; flex-direction: column;
}
.char-main-content {
  flex: 1;
  display: flex; align-items: flex-start; justify-content: center;
  padding: 2rem 1.25rem 3rem;
}

/* ═══════════════════════════════════════════════════════════
   NEWS + ABOUT (index.ejs) — side by side grid
   ═══════════════════════════════════════════════════════════ */

/* Two-column grid */
.h-content-grid {
  width: 100%; max-width: 860px;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 1rem; align-items: start;
}
@media(max-width: 600px) { .h-content-grid { grid-template-columns: 1fr; } }

/* Section card */
.h-content-section {
  background: var(--surface); border: 2px solid var(--border);
  border-radius: 18px; padding: 1.1rem 1.25rem;
  box-shadow: 0 4px 0 var(--border-d), var(--shadow-sm);
  display: flex; flex-direction: column; gap: 0.75rem;
}

/* Section header label */
.h-content-header {
  display: flex; align-items: center; gap: 0.4rem;
  font-size: 0.65rem; font-weight: 900; text-transform: uppercase;
  letter-spacing: 0.12em; color: var(--txt-m);
  padding-bottom: 0.6rem; border-bottom: 2px solid var(--border);
}

/* News list */
.h-news-list { display: flex; flex-direction: column; gap: 0.5rem; }

.h-news-item {
  background: var(--surface2); border: 1.5px solid var(--border);
  border-radius: 11px; padding: 0.7rem 0.85rem;
  transition: border-color .15s;
}
.h-news-item--pinned {
  border-color: var(--orange);
  background: rgba(255,107,53,.04);
}
.h-news-item-top {
  display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap;
}
.h-news-title { font-size: 0.85rem; font-weight: 900; color: var(--txt); flex: 1; }
.h-news-date  { font-size: 0.7rem; font-weight: 800; color: var(--txt-l); white-space: nowrap; }
.h-news-body  { font-size: 0.8rem; font-weight: 700; color: var(--txt-m); margin-top: 0.35rem; line-height: 1.5; }

.h-news-badge {
  display: inline-flex; align-items: center;
  padding: 0.12rem 0.5rem; border-radius: 50px;
  font-size: 0.62rem; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase;
}
.h-news-badge--orange { background: rgba(255,107,53,.12); color: var(--orange); border: 1.5px solid rgba(255,107,53,.3); }
.h-news-badge--green  { background: rgba(39,174,96,.1);   color: var(--green);  border: 1.5px solid rgba(39,174,96,.3);  }
.h-news-badge--blue   { background: rgba(74,144,226,.1);  color: var(--blue);   border: 1.5px solid rgba(74,144,226,.3); }
.h-news-badge--red    { background: rgba(231,76,60,.1);   color: var(--red);    border: 1.5px solid rgba(231,76,60,.3);  }
.h-news-badge--purple { background: rgba(155,89,182,.1);  color: var(--purple); border: 1.5px solid rgba(155,89,182,.3); }

/* About text */
.h-about-text { font-size: 0.86rem; font-weight: 700; color: var(--txt-m); line-height: 1.65; }
.h-about-text a { color: var(--orange); font-weight: 900; }
.h-about-text strong { color: var(--txt); }

/* ═══════════════════════════════════════════════════════════
   NEWS TREE (admin/content.ejs)
   ═══════════════════════════════════════════════════════════ */
.news-tree { display: flex; flex-direction: column; gap: 0; }

.news-item {
  border-left: 3px solid var(--border);
  margin-left: 8px; padding: 0.75rem 0 0.75rem 1rem;
  position: relative; transition: border-color .15s;
}
.news-item::before {
  content: ''; position: absolute; left: -7px; top: 1.1rem;
  width: 11px; height: 11px; border-radius: 50%;
  background: var(--border); border: 2px solid var(--surface);
  transition: background .15s;
}
.news-item--pinned { border-left-color: var(--orange); }
.news-item--pinned::before { background: var(--orange); }
.news-item:last-child { border-left-color: transparent; }

.news-item-header {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 0.5rem;
}
.news-item-meta {
  display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; flex: 1;
}
.news-item-title { font-size: 0.88rem; font-weight: 900; color: var(--txt); }
.news-item-date  { font-size: 0.72rem; font-weight: 800; color: var(--txt-l); white-space: nowrap; }
.news-item-actions { display: flex; gap: 0.3rem; flex-shrink: 0; }
.news-item-body {
  font-size: 0.8rem; color: var(--txt-m); font-weight: 700;
  margin-top: 0.3rem; line-height: 1.5;
}

/* ═══════════════════════════════════════════════════════════
   LIVE STATUS BANNER
   ═══════════════════════════════════════════════════════════ */
.status-banner {
  position: sticky; top: 62px; z-index: 900;
  display: flex; align-items: center; justify-content: center;
  gap: 0.6rem; padding: 0.7rem 1.25rem;
  font-size: 0.88rem; font-weight: 800; text-align: center;
  transition: max-height .3s ease, opacity .3s ease, padding .3s ease;
  max-height: 80px; opacity: 1;
}
.status-banner-icon { font-size: 1rem; flex-shrink: 0; }
.status-banner-text { line-height: 1.4; }

.status-banner--hidden {
  max-height: 0; opacity: 0; padding: 0;
  pointer-events: none; overflow: hidden;
}

.status-banner--warning {
  background: rgba(241,196,15,.15);
  border-bottom: 2px solid rgba(241,196,15,.4);
  color: #7a6200;
}
.status-banner--info {
  background: rgba(74,144,226,.12);
  border-bottom: 2px solid rgba(74,144,226,.35);
  color: var(--blue-d);
}
.status-banner--error {
  background: rgba(231,76,60,.12);
  border-bottom: 2px solid rgba(231,76,60,.35);
  color: var(--red-d);
}
.status-banner--success {
  background: rgba(39,174,96,.1);
  border-bottom: 2px solid rgba(39,174,96,.3);
  color: var(--green-d);
}

/* ═══════════════════════════════════════════════════════════
   SITE FOOTER
   ═══════════════════════════════════════════════════════════ */
.site-footer {
  width: 100%;
  border-top: 2px solid var(--border);
  background: var(--surface);
  padding: 1rem 1.25rem;
  margin-top: 2rem;
  flex-shrink: 0;
}
.site-footer-inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; flex-wrap: wrap;
}
.site-footer-brand {
  display: flex; align-items: center; gap: 0.6rem;
}
.site-footer-logo {
  height: 24px; width: auto; object-fit: contain;
  mix-blend-mode: normal; opacity: 0.7;
}
.site-footer-copy {
  font-size: 0.75rem; font-weight: 800; color: var(--txt-l);
}
.site-footer-nav {
  display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap;
}
.site-footer-link {
  font-size: 0.75rem; font-weight: 800; color: var(--txt-l);
  text-decoration: none; transition: color .15s;
}
.site-footer-link:hover { color: var(--orange); }
.site-footer-sep {
  font-size: 0.75rem; color: var(--border-d); user-select: none;
}

@media(max-width: 500px) {
  .site-footer-inner { flex-direction: column; align-items: center; text-align: center; }
}

/* ── Browse page header ──────────────────────────────────────── */
.browse-page-header {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; margin-bottom: 1.5rem; flex-wrap: wrap;
}
.browse-page-title {
  font-family: 'Bebas Neue', sans-serif; font-size: 2rem;
  letter-spacing: 0.04em; color: var(--txt);
}
.browse-page-sub { font-size: 0.82rem; font-weight: 700; color: var(--txt-m); margin-top: 0.1rem; }

/* ── Lobby category buttons ──────────────────────────────────── */
.lb-category-btns {
  display: flex; gap: 0.4rem; flex-wrap: wrap;
}
.lb-cat-btn {
  padding: 0.35rem 0.75rem; border-radius: 8px;
  font-size: 0.78rem; font-weight: 900; font-family: inherit;
  border: 2px solid var(--border); background: var(--surface2);
  color: var(--txt-m); cursor: pointer; transition: all .15s;
}
.lb-cat-btn:hover { border-color: var(--orange); color: var(--orange); }
.lb-cat-btn--active {
  background: var(--orange); color: #fff;
  border-color: var(--orange);
  box-shadow: 0 2px 0 var(--orange-d);
}

/* ═══════════════════════════════════════════════════════════
   RESULT PHASE — Answer reveal grid with voter avatars
   ═══════════════════════════════════════════════════════════ */
.result-answers-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 0.5rem; width: 100%; max-width: 600px; margin: 0.75rem 0;
}
/* Result buttons reuse answer-btn styles */
.result-answers-grid .answer-btn {
  cursor: default;
  animation: none; /* no entrance animation in result */
}
/* Wrong answers in result — keep full color, just no transform */
.result-answers-grid .answer-btn.wrong {
  opacity: 1;
  filter: none;
  transform: none;
}
/* Correct answer glows */
.result-answers-grid .answer-btn.correct {
  outline: 3px solid var(--yellow);
  outline-offset: 2px;
  animation: correctFlash .45s ease;
}

/* Voter avatars row inside the button */
.result-voters-wrap {
  display: flex; flex-wrap: wrap; gap: 3px; margin-left: auto; flex-shrink: 0;
}
.result-voter-av {
  width: 28px; height: 28px; border-radius: 7px;
  overflow: hidden; position: relative; flex-shrink: 0;
  border: 2px solid rgba(255,255,255,.3);
  box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.result-voter-av .char-avatar {
  width: 100%; height: 100%;
}
.result-voter-av .char-avatar img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: contain; image-rendering: pixelated;
}

@media(max-width:500px) {
  .result-answers-grid { grid-template-columns: 1fr; }
}