/* Dr. Smash — host console. AltSeason brand, dark control-room variant. */

@font-face { font-family:"Clash Grotesk"; src:url("/assets/fonts/ClashGrotesk-Regular.woff2") format("woff2"); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:"Clash Grotesk"; src:url("/assets/fonts/ClashGrotesk-Medium.woff2") format("woff2"); font-weight:500; font-style:normal; font-display:swap; }
@font-face { font-family:"Clash Grotesk"; src:url("/assets/fonts/ClashGrotesk-Semibold.woff2") format("woff2"); font-weight:600; font-style:normal; font-display:swap; }
@font-face { font-family:"Clash Grotesk"; src:url("/assets/fonts/ClashGrotesk-Bold.woff2") format("woff2"); font-weight:700; font-style:normal; font-display:swap; }

:root {
  --bg:        #1D1D1B;   /* page background */
  --surface:   #2B2B2B;   /* cards / appbar */
  --surface-2: #242422;   /* inputs */
  --tan:       #E3C49D;   /* hero card / accents */
  --coffee:    #8A6F5F;
  --brick:     #803E3C;
  --brick-2:   #B95653;
  --text:      #F6EFE7;   /* primary text on dark */
  --text-dim:  #A89A8A;   /* secondary text on dark */
  --ink:       #1D1D1B;   /* dark text — for use ON light surfaces (tan card, white buttons) */
  --white:     #FFFFFF;   /* provider buttons */
  --green:     #149C78;
  --line:      #34302B;
  --line-2:    #423C35;
  --font:      "Clash Grotesk", system-ui, -apple-system, sans-serif;
  --r-card:    20px;
  --r-btn:     12px;
  --r-sm:      10px;
  --shadow:    0 18px 44px -20px rgba(0,0,0,.6);
  --btn-w:     320px;
  --btn-h:     40px;   /* = GIS "large" height, so Apple + Google match exactly */
}

* { box-sizing:border-box; }
html, body { height:100%; }
body {
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--font); font-size:16px; line-height:1.5; font-weight:400;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
.app { min-height:100%; display:flex; flex-direction:column; }
button { font:inherit; color:inherit; cursor:pointer; }
:focus-visible { outline:2px solid var(--tan); outline-offset:2px; border-radius:6px; }

/* Wordmark */
.brand { font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--text); line-height:1; }
.brand--sm { font-size:18px; }

/* Login */
.login {
  flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:18px; padding:40px 22px calc(40px + env(safe-area-inset-bottom)); text-align:center;
}
.hero {
  width:min(360px,90vw); background:var(--tan); border-radius:var(--r-card);
  padding:30px 26px 26px; display:flex; flex-direction:column; align-items:center; gap:14px;
  box-shadow:var(--shadow);
}
.hero__badge { width:64px; height:64px; border-radius:50%; background:var(--ink); color:var(--tan); display:grid; place-items:center; }
.hero__badge svg { width:32px; height:32px; }
.hero__title { font-weight:700; font-size:30px; letter-spacing:.04em; text-transform:uppercase; color:var(--ink); }
.hero__tag { color:var(--ink); opacity:.8; font-size:14px; max-width:26ch; margin:0; }
.providers { display:flex; flex-direction:column; align-items:center; gap:12px; width:min(360px,90vw); }
.login__status { color:var(--text-dim); font-size:14px; min-height:18px; margin:0; }
.login__foot { color:var(--text-dim); font-size:12px; letter-spacing:.04em; opacity:.6; margin-top:6px; }

/* Buttons */
.btn {
  font-family:var(--font); font-weight:500; font-size:15px;
  border:1px solid var(--line-2); background:var(--surface); color:var(--text);
  border-radius:var(--r-btn); padding:0 18px; height:var(--btn-h);
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  transition:transform .12s ease, background .15s ease, border-color .15s ease, opacity .15s ease, box-shadow .15s ease;
}
.btn:hover { transform:translateY(-1px); }
.btn:active { transform:translateY(0); }
.btn[disabled] { opacity:.55; cursor:default; transform:none; }
.btn--sm { height:34px; padding:0 14px; font-size:14px; }
.btn--primary { background:var(--brick); border-color:var(--brick); color:#fff; font-weight:600; }
.btn--primary:hover { background:var(--brick-2); border-color:var(--brick-2); }
.btn--ghost { background:transparent; border-color:var(--line-2); color:var(--text-dim); }
.btn--ghost:hover { color:var(--text); border-color:var(--coffee); }

/* Provider buttons — Apple custom + Google (GIS) share these exact dimensions */
.btn--provider { width:100%; height:var(--btn-h); background:var(--white); color:#3C4043; font-weight:600; border:1px solid #DADCE0; border-radius:4px; }
.btn--provider:hover { background:#F8F9FA; border-color:#D2D5D9; }
.btn--provider .glyph { display:inline-flex; margin-top:-1px; }
.gbtn { width:100%; min-height:var(--btn-h); display:flex; justify-content:center; align-items:center; }

/* App shell */
.shell { flex:1; display:flex; flex-direction:column; }
.appbar {
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:14px clamp(16px,4vw,32px); background:var(--surface); border-bottom:1px solid var(--line);
  position:sticky; top:0; z-index:10;
}
.appbar__left, .appbar__right { display:flex; align-items:center; gap:12px; }
.appbar__sep { width:1px; height:18px; background:var(--line-2); }
.appbar__section { font-size:12px; letter-spacing:.16em; color:var(--tan); font-weight:600; text-transform:uppercase; }
.appbar__who { color:var(--text-dim); font-size:14px; max-width:42vw; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.main { flex:1; padding:clamp(20px,5vw,44px); width:min(100%,1040px); margin:0 auto; }

/* Launchpad */
.launch { display:grid; gap:16px; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); }
.launch-card {
  text-align:left; display:flex; flex-direction:column; gap:10px; padding:24px;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-card);
  transition:transform .14s ease, border-color .15s ease, box-shadow .15s ease;
}
.launch-card:hover { transform:translateY(-2px); border-color:var(--tan); box-shadow:var(--shadow); }
.launch-card__icon { width:42px; height:42px; border-radius:12px; background:var(--tan); color:var(--ink); display:grid; place-items:center; }
.launch-card__icon svg { width:22px; height:22px; }
.launch-card__title { font-weight:600; font-size:21px; color:var(--text); }
.launch-card__body { color:var(--text-dim); font-size:14px; }
.launch-card__cta { color:var(--tan); font-weight:600; font-size:14px; margin-top:2px; }

/* Forms (base for later stages) */
.field { display:flex; flex-direction:column; gap:6px; margin-bottom:14px; text-align:left; }
.field > label { font-size:13px; font-weight:500; color:var(--text-dim); }
input, select, textarea {
  font:inherit; color:var(--text); background:var(--surface-2);
  border:1px solid var(--line-2); border-radius:var(--r-sm); padding:11px 13px;
}
input:focus, select:focus, textarea:focus { outline:none; border-color:var(--tan); }
input::placeholder, textarea::placeholder { color:var(--text-dim); opacity:.6; }

/* Join codes */
.code { font-weight:700; letter-spacing:.28em; color:var(--tan); }

/* Toast */
.toast {
  position:fixed; left:50%; bottom:24px; transform:translate(-50%,16px);
  max-width:min(440px,92vw); background:var(--surface); color:var(--text);
  border:1px solid var(--line-2); border-left:3px solid var(--tan);
  padding:12px 16px; border-radius:var(--r-sm); box-shadow:var(--shadow);
  opacity:0; pointer-events:none; transition:opacity .2s ease, transform .2s ease;
  z-index:50; font-size:14px;
}
.toast.is-on { opacity:1; transform:translate(-50%,0); }
.toast--error { border-left-color:var(--brick-2); }
.toast--success { border-left-color:var(--green); }

@media (prefers-reduced-motion: reduce) {
  *, ::before, ::after { animation-duration:.001ms !important; transition-duration:.001ms !important; }
}

/* === Mr. Smash: question bank (Stage 2b) === */
.iconbtn { width:36px; height:36px; flex:0 0 auto; display:grid; place-items:center; border-radius:9px; border:1px solid var(--line-2); background:var(--surface-2); color:var(--text-dim); transition:color .15s ease, border-color .15s ease, background .15s ease; }
.iconbtn:hover { color:var(--text); border-color:var(--coffee); }
.iconbtn svg { width:18px; height:18px; }
.iconbtn--danger:hover { color:var(--brick-2); border-color:var(--brick-2); }
.btn .glyph { display:inline-flex; }
.btn .glyph svg { width:16px; height:16px; }

.qb-toolbar { display:flex; justify-content:flex-end; margin-bottom:18px; }
.qb-list { display:flex; flex-direction:column; gap:10px; }
.qb-empty { color:var(--text-dim); text-align:center; padding:44px 0; }

.qb-row { display:flex; gap:14px; align-items:flex-start; justify-content:space-between; padding:16px 18px; background:var(--surface); border:1px solid var(--line); border-radius:14px; }
.qb-row__main { min-width:0; display:flex; flex-direction:column; gap:6px; }
.qb-row__prompt { color:var(--text); font-weight:600; font-size:16px; line-height:1.35; }
.qb-row__sub { color:var(--text-dim); font-size:13px; }
.qb-badges { display:flex; flex-wrap:wrap; gap:6px; margin-top:2px; }
.badge { font-size:11px; font-weight:600; letter-spacing:.03em; padding:3px 9px; border-radius:999px; background:var(--surface-2); color:var(--text-dim); border:1px solid var(--line-2); }
.badge--kind { background:rgba(227,196,157,.16); color:var(--tan); border-color:transparent; }
.badge--cat { color:var(--text); }
.qb-row__actions { display:flex; gap:8px; flex:0 0 auto; }

.qb-editor { display:flex; flex-direction:column; gap:18px; width:100%; max-width:680px; margin:0 auto; }
.qb-editor__head { display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.qb-editor__title { margin:0; font-size:20px; font-weight:600; color:var(--text); }
.qb-editor__actions { display:flex; gap:10px; }
.qb-editor__body { display:flex; flex-direction:column; gap:16px; }
.qb-grid { display:grid; gap:14px; grid-template-columns:1fr 1fr; align-items:start; }
.qb-section { background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:18px; display:flex; flex-direction:column; gap:2px; }
.qb-section__title { font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--tan); font-weight:600; margin-bottom:10px; }
.qb-hint { color:var(--text-dim); font-size:13px; margin:6px 0 0; }
.qb-editor textarea { resize:vertical; min-height:46px; }
.qb-addopt { align-self:flex-start; margin-top:6px; }

.qb-opt { display:flex; align-items:flex-start; gap:12px; padding:12px 0; border-top:1px solid var(--line); }
.qb-opt:first-of-type { border-top:none; padding-top:2px; }
.qb-opt__correct { flex:0 0 auto; padding-top:10px; display:flex; cursor:pointer; }
.qb-opt__correct input { width:18px; height:18px; accent-color:var(--green); cursor:pointer; }
.qb-opt__texts { flex:1; min-width:0; display:grid; gap:8px; grid-template-columns:1fr 1fr; }

.seg { display:inline-flex; background:var(--surface-2); border:1px solid var(--line-2); border-radius:10px; padding:3px; gap:3px; max-width:100%; flex-wrap:wrap; }
.seg__btn { border:none; background:transparent; color:var(--text-dim); font-weight:600; font-size:14px; padding:7px 14px; border-radius:7px; cursor:pointer; transition:background .15s ease, color .15s ease; }
.seg__btn.is-on { background:var(--tan); color:var(--ink); }

@media (max-width: 560px) {
  .qb-grid, .qb-opt__texts { grid-template-columns:1fr; }
}

/* === Mr. Smash: bulk import (Stage 2d) === */
.qb-import__ta { width:100%; font-family:ui-monospace, Menlo, Consolas, monospace; font-size:13px; line-height:1.55; }
.qb-import__file { color:var(--text-dim); font-size:14px; }
.qb-import__file::file-selector-button { font:inherit; font-weight:600; color:var(--ink); background:var(--tan); border:none; border-radius:8px; padding:8px 14px; margin-right:12px; cursor:pointer; }
.qb-import__help { background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:14px 18px; }
.qb-import__help summary { cursor:pointer; color:var(--tan); font-weight:600; font-size:14px; }
.qb-import__pre { margin:12px 0 0; padding:14px; background:var(--surface-2); border:1px solid var(--line-2); border-radius:10px; overflow:auto; font-family:ui-monospace, Menlo, Consolas, monospace; font-size:12px; line-height:1.55; color:var(--text-dim); max-height:340px; }
.qb-import__result { margin-top:2px; }
.qb-import__summary { background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:16px 18px; }
.qb-import__count { color:var(--text); font-weight:600; margin:0; }
.qb-import__errors { margin:10px 0 0; padding-left:18px; color:var(--brick-2); font-size:13px; display:flex; flex-direction:column; gap:4px; }
.qb-import__errors li { line-height:1.4; }

/* === Mr. Smash: import loading === */
.qb-import__loading { display:flex; align-items:center; gap:10px; color:var(--text-dim); font-size:14px; padding:14px 0; }
.qb-spin { width:18px; height:18px; border-radius:50%; border:2px solid var(--line-2); border-top-color:var(--tan); animation:qb-spin .7s linear infinite; flex:0 0 auto; }
@keyframes qb-spin { to { transform:rotate(360deg); } }

/* === Mr. Smash: game builder (Stage 2c-1) === */
.code--sm { letter-spacing:.16em; font-size:13px; }
.code--lg { font-size:26px; letter-spacing:.28em; }
.badge--status { border-color:transparent; }
.badge--draft { background:rgba(227,196,157,.16); color:var(--tan); }
.badge--lobby { background:rgba(138,111,95,.24); color:#C9B79E; }
.badge--live { background:rgba(20,156,120,.18); color:var(--green); }
.badge--finished { background:var(--surface-2); color:var(--text-dim); }
.ge-head { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.ge-head__title { font-size:22px; font-weight:600; color:var(--text); }
.qb-section.ge-meta { flex-direction:row; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap; }
.ge-meta__info { text-align:right; }
.ge-meta__row { color:var(--text-dim); font-size:14px; }
.ge-rounds { display:flex; flex-direction:column; gap:10px; }
.ge-rounds__head { display:flex; align-items:center; justify-content:space-between; gap:12px; }

/* Mr. Smash: round questions */
.ge-head__publish { margin-left: auto; }
.ge-qlist { display: flex; flex-direction: column; gap: 8px; }
.ge-actions { margin-top: 14px; }
.badge--pts { background: rgba(20, 156, 120, .16); color: #1FBF93; }

/* === Mr. Smash: lobby host === */
.lobby__grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 18px; align-items: start; padding: 18px clamp(16px,4vw,32px) 32px; }
@media (max-width: 720px) { .lobby__grid { grid-template-columns: 1fr; } }
.lobby-code { display: flex; flex-direction: column; gap: 10px; padding: 28px; }
.lobby-code__label { color: var(--text-dim); font-size: .82rem; text-transform: uppercase; letter-spacing: .12em; }
.lobby-code__value { font-size: clamp(2.6rem, 9vw, 4.6rem); font-weight: 700; letter-spacing: .18em; color: var(--tan); line-height: 1.05; }
.lobby-code__hint { color: var(--text-dim); font-size: .9rem; }
.lobby-side { display: flex; flex-direction: column; gap: 14px; padding: 22px; }
.lobby-side__head { display: flex; align-items: center; justify-content: space-between; }
.lobby-side__title { font-size: 1rem; margin: 0; }
.lobby-roster__count { background: var(--surface-2); color: var(--text); border-radius: 999px; padding: 2px 12px; font-variant-numeric: tabular-nums; font-weight: 600; }
.lobby-conn { align-self: flex-start; font-size: .8rem; padding: 3px 10px; border-radius: 999px; }
.lobby-conn--on { background: rgba(20,156,120,.18); color: var(--green); }
.lobby-conn--off { background: var(--surface-2); color: var(--text-dim); }
.lobby-roster { display: flex; flex-direction: column; gap: 8px; min-height: 60px; }
.lobby-roster__empty { color: var(--text-dim); font-size: .9rem; padding: 14px 0; }
.lobby-team { display: flex; align-items: center; gap: 10px; padding: 9px 12px; background: var(--surface-2); border-radius: var(--r-sm); }
.lobby-team__dot { width: 9px; height: 9px; border-radius: 50%; flex: 0 0 auto; }
.lobby-team__dot.is-on { background: var(--green); box-shadow: 0 0 0 3px rgba(20,156,120,.2); }
.lobby-team__dot.is-off { background: var(--coffee); opacity: .5; }
.lobby-team__name { color: var(--text); font-weight: 500; }
.lobby__start { margin-top: 6px; width: 100%; }

/* === Mr. Smash: modal dialog === */
.modal-overlay { position: fixed; inset: 0; z-index: 1000; display: flex; align-items: center; justify-content: center; padding: 20px; background: rgba(0, 0, 0, .55); opacity: 0; transition: opacity .18s ease; }
.modal-overlay.is-on { opacity: 1; }
.modal { width: 100%; max-width: 420px; background: var(--surface); border: 1px solid var(--line-2); border-radius: var(--r-card); box-shadow: var(--shadow); padding: 22px; transform: translateY(10px) scale(.98); transition: transform .18s ease; }
.modal-overlay.is-on .modal { transform: translateY(0) scale(1); }
.modal__title { font-size: 1.12rem; font-weight: 700; color: var(--text); }
.modal__msg { color: var(--text); font-size: .95rem; line-height: 1.45; margin-top: 8px; }
.modal__detail { color: var(--text-dim); font-size: .88rem; line-height: 1.45; margin-top: 8px; word-break: break-word; }
.modal__actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 22px; }
.modal__actions .btn { width: auto; min-width: 100px; }
.btn--danger { background: var(--brick-2); color: var(--white); }
.btn--danger:hover { background: var(--brick); }

/* === Mr. Smash: table (captain) === */
.table-app { min-height: 100dvh; }
.table-shell { max-width: 480px; margin: 0 auto; padding: 22px 18px 40px; display: flex; flex-direction: column; gap: 16px; }
.table-hero { text-align: center; padding: 22px 0 6px; }
.table-hero__brand { font-size: 2rem; font-weight: 700; color: var(--tan); }
.table-hero__sub { color: var(--text-dim); margin-top: 4px; }
.table-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-card); padding: 22px; display: flex; flex-direction: column; gap: 8px; }
.field-label { color: var(--text-dim); font-size: .8rem; text-transform: uppercase; letter-spacing: .1em; margin-top: 8px; }
.field { width: 100%; box-sizing: border-box; background: var(--surface-2); border: 1px solid var(--line-2); border-radius: var(--r-btn); color: var(--text); font: inherit; font-size: 1rem; padding: 13px 14px; outline: none; }
.field:focus { border-color: var(--coffee); }
.field--code { text-transform: uppercase; letter-spacing: .22em; font-weight: 700; text-align: center; }
.table__cta { margin-top: 16px; width: 100%; }
.table-topbar { display: flex; align-items: center; justify-content: space-between; }
.table-topbar__title { font-weight: 600; color: var(--text); }
.table-leave { background: transparent; border: 0; color: var(--text-dim); font: inherit; cursor: pointer; padding: 6px 8px; }
.table-card--team { align-items: center; text-align: center; }
.table-team__label { color: var(--text-dim); font-size: .78rem; text-transform: uppercase; letter-spacing: .1em; }
.table-team__name { font-size: 1.5rem; font-weight: 700; color: var(--text); }
.table-status { text-align: center; padding: 6px 0; }
.table-status__headline { font-size: 1.25rem; font-weight: 700; color: var(--tan); }
.table-status__sub { color: var(--text-dim); margin-top: 6px; }
.table-standings { display: flex; flex-direction: column; gap: 6px; }
.table-standings__title { color: var(--text-dim); font-size: .8rem; text-transform: uppercase; letter-spacing: .1em; margin-bottom: 4px; }
.table-rank { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: var(--surface-2); border-radius: var(--r-sm); }
.table-rank.is-me { background: var(--coffee); }
.table-rank__pos { color: var(--text-dim); font-variant-numeric: tabular-nums; width: 20px; text-align: center; }
.table-rank.is-me .table-rank__pos { color: var(--text); }
.table-rank__name { flex: 1; color: var(--text); font-weight: 500; }
.table-rank__score { font-variant-numeric: tabular-nums; font-weight: 700; color: var(--text); }

/* === Mr. Smash: display (venue screen) === */
.display-app { min-height: 100dvh; display: flex; }
.display-setup { margin: auto; text-align: center; padding: 40px; }
.display-setup__title { font-size: 2rem; font-weight: 700; color: var(--tan); }
.display-setup__sub { color: var(--text-dim); margin-top: 10px; }
.display-shell { flex: 1; display: flex; flex-direction: column; padding: 3vh 4vw; gap: 3vh; }
.display-head { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; }
.display-brand { font-size: 2vw; font-weight: 700; color: var(--tan); }
.display-title { font-size: 1.6vw; color: var(--text-dim); }
.display-main { flex: 1; display: grid; grid-template-columns: 1.1fr .9fr; gap: 4vw; align-items: center; }
.display-join { text-align: center; }
.display-join__label { font-size: 1.4vw; text-transform: uppercase; letter-spacing: .2em; color: var(--text-dim); }
.display-join__code { font-size: 11vw; font-weight: 800; color: var(--text); letter-spacing: .08em; line-height: 1.05; }
.display-join__hint { font-size: 1.6vw; color: var(--coffee); margin-top: 1vh; }
.display-side { display: flex; flex-direction: column; gap: 2vh; min-width: 0; }
.display-phase { font-size: 2vw; font-weight: 700; color: var(--tan); }
.display-teams { display: flex; flex-direction: column; gap: 1vh; }
.display-teams__empty { color: var(--text-dim); font-size: 1.4vw; }
.display-team { display: flex; align-items: center; gap: 1vw; font-size: 1.8vw; color: var(--text); }
.display-team.is-off { opacity: .45; }
.display-team__pos { color: var(--text-dim); font-variant-numeric: tabular-nums; min-width: 1.6em; }
.display-team__dot { width: .7vw; height: .7vw; border-radius: 50%; background: var(--green); flex: none; }
.display-team.is-off .display-team__dot { background: var(--text-dim); }
.display-team__name { flex: 1; font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.display-team__score { font-variant-numeric: tabular-nums; font-weight: 800; }

/* === Mr. Smash: regia (host play) === */
.regia__grid { display: grid; grid-template-columns: 1.7fr 1fr; gap: 18px; align-items: start; padding: 18px clamp(16px,4vw,32px) 32px; }
@media (max-width: 820px) { .regia__grid { grid-template-columns: 1fr; } }
.regia__main { display: flex; flex-direction: column; gap: 16px; }
.regia-stage { padding: 28px; display: flex; flex-direction: column; gap: 8px; }
.regia-round__tag { color: var(--text-dim); font-size: .82rem; text-transform: uppercase; letter-spacing: .12em; }
.regia-round__title { font-size: 1.8rem; font-weight: 700; color: var(--tan); }
.regia-round__sub { color: var(--text-dim); }
.regia-q { padding: 28px; display: flex; flex-direction: column; gap: 14px; }
.regia-q.is-reveal { border: 1px solid rgba(20, 156, 120, .4); }
.regia-q__meta { color: var(--text-dim); font-size: .82rem; text-transform: uppercase; letter-spacing: .1em; }
.regia-q__prompt { font-size: 1.5rem; font-weight: 700; color: var(--text); line-height: 1.25; }
.regia-q__options { display: flex; flex-direction: column; gap: 8px; }
.regia-opt { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 12px 14px; background: var(--surface-2); border-radius: var(--r-sm); border: 1px solid transparent; }
.regia-opt.is-correct { border-color: var(--green); background: rgba(20, 156, 120, .12); }
.regia-opt__text { color: var(--text); font-weight: 500; }
.regia-opt__badge { color: var(--green); font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }
.regia-q__numeric { font-size: 1.1rem; color: var(--text); background: rgba(20, 156, 120, .12); border: 1px solid var(--green); border-radius: var(--r-sm); padding: 12px 14px; }
.regia-q__explain { color: var(--text-dim); font-size: .95rem; line-height: 1.4; border-top: 1px solid var(--line); padding-top: 12px; }
.regia-bar { display: flex; align-items: center; gap: 16px; }
.regia-count { display: flex; flex-direction: column; align-items: center; min-width: 84px; padding: 10px 14px; background: var(--surface); border: 1px solid var(--line-2); border-radius: var(--r-btn); }
.regia-count__value { font-size: 1.8rem; font-weight: 800; color: var(--tan); font-variant-numeric: tabular-nums; line-height: 1; }
.regia-count__label { color: var(--text-dim); font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; }
.regia-go { flex: 1; }
.regia-side { display: flex; flex-direction: column; gap: 14px; padding: 22px; }
.regia-stop { width: 100%; margin-top: 4px; }
.lobby-team__score { margin-left: auto; font-variant-numeric: tabular-nums; font-weight: 700; color: var(--text); }

/* === Mr. Smash: table question === */
.t-q { padding: 20px; display: flex; flex-direction: column; gap: 12px; }
.t-q.is-reveal { border: 1px solid rgba(20, 156, 120, .4); }
.t-count { position: relative; align-self: center; width: 128px; height: 128px; }
.t-count__ringwrap { position: absolute; inset: 0; }
.t-count__ring { display: block; width: 100%; height: 100%; transform: rotate(-90deg); }
.t-count__track { fill: none; stroke: var(--line-2); stroke-width: 7; }
.t-count__prog { fill: none; stroke: var(--green); stroke-width: 7; stroke-linecap: round; transition: stroke-dashoffset .2s linear, stroke .4s ease; }
.t-count__value { position: absolute; inset: 0; display: grid; place-items: center; font-size: 2.6rem; font-weight: 800; color: var(--tan); font-variant-numeric: tabular-nums; line-height: 1; }
.t-count__label { position: absolute; left: 0; right: 0; top: 50%; margin-top: 1.4rem; text-align: center; color: var(--text-dim); font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; }
.t-locked { align-self: center; color: var(--text-dim); font-weight: 600; }
.t-q__meta { color: var(--text-dim); font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; }
.t-q__prompt { font-size: 1.3rem; font-weight: 700; color: var(--text); line-height: 1.3; }
.t-q__options { display: flex; flex-direction: column; gap: 8px; }
.t-opt { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 13px 14px; background: var(--surface-2); border-radius: var(--r-btn); border: 1px solid transparent; }
.t-opt.is-correct { border-color: var(--green); background: rgba(20, 156, 120, .14); }
.t-opt__text { color: var(--text); font-weight: 500; }
.t-opt__badge { color: var(--green); font-weight: 800; }
.t-q__numeric { color: var(--text); background: var(--surface-2); border-radius: var(--r-btn); padding: 13px 14px; font-weight: 500; }
.t-q__explain { color: var(--text-dim); font-size: .9rem; line-height: 1.4; border-top: 1px solid var(--line); padding-top: 10px; }

/* === Mr. Smash: display question === */
.display-round { flex: 1; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; gap: 1vh; }
.display-round__tag { font-size: 2vw; text-transform: uppercase; letter-spacing: .2em; color: var(--text-dim); }
.display-round__title { font-size: 6vw; font-weight: 800; color: var(--tan); line-height: 1.05; }
.display-round__sub { font-size: 2vw; color: var(--text-dim); }
.display-q { flex: 1; display: flex; flex-direction: column; gap: 2.5vh; min-height: 0; justify-content: center; }
.display-q__head { display: flex; align-items: center; justify-content: space-between; gap: 2vw; }
.display-q__meta { font-size: 1.8vw; text-transform: uppercase; letter-spacing: .12em; color: var(--text-dim); }
.display-count { position: relative; width: 9vw; height: 9vw; min-width: 100px; min-height: 100px; }
.display-count__ringwrap { position: absolute; inset: 0; }
.display-count__ring { display: block; width: 100%; height: 100%; transform: rotate(-90deg); }
.display-count__track { fill: none; stroke: var(--line-2); stroke-width: 7; }
.display-count__prog { fill: none; stroke: var(--green); stroke-width: 7; stroke-linecap: round; transition: stroke-dashoffset .2s linear, stroke .4s ease; }
.display-count__value { position: absolute; inset: 0; display: grid; place-items: center; font-size: 3.4vw; font-weight: 800; color: var(--tan); font-variant-numeric: tabular-nums; line-height: 1; }
.display-count__label { position: absolute; left: 0; right: 0; top: 50%; margin-top: 2vw; text-align: center; font-size: 1vw; text-transform: uppercase; letter-spacing: .1em; color: var(--text-dim); }
.display-count--locked .display-count__prog { stroke: var(--brick-2); }
.display-count--locked .display-count__value { color: var(--brick-2); }
.display-q__prompt { font-size: 4.4vw; font-weight: 800; color: var(--text); line-height: 1.15; }
.display-q__options { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5vw; }
.display-opt { font-size: 2.4vw; font-weight: 600; color: var(--text); background: var(--surface-2); border: 2px solid transparent; border-radius: var(--r-btn); padding: 2vh 2vw; }
.display-opt.is-correct { border-color: var(--green); background: rgba(20, 156, 120, .16); }
.display-q__numeric { font-size: 8vw; font-weight: 800; color: var(--tan); text-align: center; }

/* === mrsmash-m3-3b submit (table clickable + numeric, regia answered) === */
.t-opt.is-live { cursor: pointer; transition: border-color .12s ease, background .12s ease, transform .06s ease; }
@media (hover: hover) { .t-opt.is-live:hover { border-color: var(--coffee); background: var(--surface-2); } }
.t-opt.is-live:active { transform: scale(.99); }
.t-opt.is-mine { border-color: var(--tan); background: rgba(227, 196, 157, .10); }
.t-opt__badge--mine { color: var(--tan); }
.t-numeric { display: flex; gap: 10px; margin-top: 14px; }
.t-numeric__input { flex: 1; }
.t-numeric__btn { flex: 0 0 auto; }
.t-numeric__hint { margin-top: 8px; font-size: 13px; color: var(--tan); }
.regia-q__answered { margin-top: 10px; font-size: 14px; color: var(--text-dim); }

/* === mrsmash-m3-3c roster classifica + answered indicator === */
.lobby-team__rank { min-width: 18px; text-align: right; font-weight: 700; color: var(--tan); font-variant-numeric: tabular-nums; }
.lobby-team__name { flex: 1; }
.lobby-team__answer { font-size: 13px; font-weight: 700; }
.lobby-team__answer.is-yes { color: var(--green); }
.lobby-team__answer.is-wait { color: var(--text-dim); letter-spacing: 1px; }
.lobby-team.has-answered { box-shadow: inset 2px 0 0 var(--green); }

/* === mrsmash-m3-3d roster scroll for many tables === */
.lobby-roster { max-height: 62vh; overflow-y: auto; }

/* === mrsmash-remove-table host kick button === */
.lobby-team__kick { flex: 0 0 auto; width: 24px; height: 24px; padding: 0; border: none; background: transparent; color: var(--text-dim); cursor: pointer; border-radius: 6px; font-size: 13px; line-height: 1; opacity: .5; transition: opacity .12s ease, background .12s ease, color .12s ease; }
.lobby-team__kick:hover { opacity: 1; background: rgba(185, 86, 83, .18); color: var(--brick-2); }

/* === mrsmash-m3-5b finished views (winner + final standings) === */
.regia-finished, .t-finished { text-align: center; }
.regia-finished__tag, .t-finished__tag, .display-finished__tag { text-transform: uppercase; letter-spacing: 2px; font-size: 13px; color: var(--text-dim); margin-bottom: 10px; }
.regia-finished__trophy, .t-finished__trophy { font-size: 44px; line-height: 1; }
.display-finished__trophy { font-size: 88px; line-height: 1; }
.regia-finished__winner, .t-finished__winner { font-size: 26px; font-weight: 800; color: var(--tan); margin-top: 8px; }
.display-finished__winner { font-size: 6vw; font-weight: 800; color: var(--tan); margin-top: 1vh; }
.regia-finished__score, .t-finished__score { font-size: 15px; color: var(--text-dim); margin-top: 4px; }
.display-finished__score { font-size: 2.4vw; color: var(--text-dim); margin-top: .5vh; }
.regia-finstand__box, .t-finished .table-standings { margin-top: 18px; text-align: left; }
.regia-finstand { display: flex; align-items: center; gap: 10px; padding: 8px 12px; background: var(--surface-2); border-radius: var(--r-sm); margin-top: 6px; }
.regia-finstand__rank { min-width: 20px; text-align: right; font-weight: 700; color: var(--tan); font-variant-numeric: tabular-nums; }
.regia-finstand__name { flex: 1; }
.regia-finstand__score { font-variant-numeric: tabular-nums; font-weight: 700; }
.display-finished { display: flex; flex-direction: column; align-items: center; }
.display-finstand { margin-top: 3vh; width: min(60vw, 760px); }
.display-finrow { display: flex; align-items: center; gap: 2vw; padding: 1.1vh 2vw; background: rgba(255,255,255,.04); border-radius: 14px; margin-top: 1vh; font-size: 2.4vw; }
.display-finrow__rank { min-width: 3vw; text-align: right; font-weight: 800; color: var(--tan); font-variant-numeric: tabular-nums; }
.display-finrow__name { flex: 1; }
.display-finrow__score { font-weight: 800; font-variant-numeric: tabular-nums; }


/* === mrsmash-m3-5c-1 prize === */
.field textarea { width: 100%; box-sizing: border-box; background: var(--surface-2); border: 1px solid var(--line-2); border-radius: var(--r-sm); color: var(--text); padding: 10px 12px; font: inherit; resize: vertical; min-height: 44px; }
.field textarea:focus { outline: none; border-color: var(--coffee); }
.ge-prize__save { margin-top: 10px; }
/* === end mrsmash-m3-5c-1 === */


/* === mrsmash-m3-5c-2 display qr + prize === */
.display-qr { width: min(34vh, 30vw); margin: 1.2vw auto 0.4vw; }
.display-qr svg { width: 100%; height: auto; display: block; border-radius: 0.6vw; }
.display-prize { background: var(--surface-2); border: 1px solid var(--line-2); border-radius: 1vw; padding: 1.4vw 1.6vw; margin-bottom: 1.2vw; }
.display-prize__label { font-size: 1.2vw; text-transform: uppercase; letter-spacing: 0.18em; color: var(--tan); }
.display-prize__points { font-size: 2.2vw; font-weight: 800; color: var(--text); margin-top: 0.4vw; }
.display-prize__text { font-size: 1.5vw; color: var(--text-dim); margin-top: 0.3vw; line-height: 1.3; }
/* === end mrsmash-m3-5c-2 === */


/* === mrsmash-m3-5c-3b wager === */
.t-wager { display: flex; flex-direction: column; gap: 12px; padding: 24px 18px; text-align: center; }
.t-wager__title { font-size: 22px; font-weight: 800; color: var(--text); }
.t-wager__hint { font-size: 14px; color: var(--text-dim); }
.field--stake { text-align: center; font-size: 28px; font-weight: 800; letter-spacing: 0.02em; }
.t-wager__cta { margin-top: 4px; }
.t-wager__placed { font-size: 14px; color: var(--tan); font-weight: 700; }
.regia-wager .regia-round__tag { color: var(--brick-2); }
.display-wager .display-round__tag { color: var(--brick-2); }
/* === end mrsmash-m3-5c-3b === */

/* === mrsmash-m4b countdown zoom === */
@keyframes mrsmash-count-tick { 0% { transform: scale(1); } 22% { transform: scale(1.22); } 100% { transform: scale(1); } }
@keyframes mrsmash-count-urgent { 0% { transform: scale(1); } 22% { transform: scale(1.5); } 100% { transform: scale(1); } }
.display-count__value.is-tick, .t-count__value.is-tick { animation: mrsmash-count-tick .5s ease-out; }
.display-count__value.is-urgent, .t-count__value.is-urgent { animation: mrsmash-count-urgent .42s ease-out; color: var(--brick-2); }
/* === end mrsmash-m4b === */

/* === mrsmash-m4c audio hint === */
.display-audiohint { position: fixed; left: 50%; bottom: 4vh; transform: translateX(-50%); z-index: 50; background: var(--brick); color: #fff; padding: 1.1vh 2.4vw; border-radius: 999px; font-size: 1.4vw; font-weight: 600; box-shadow: 0 8px 30px rgba(0, 0, 0, .45); cursor: pointer; animation: mrsmash-hint-pulse 1.6s ease-in-out infinite; }
@keyframes mrsmash-hint-pulse { 0%, 100% { opacity: .8; } 50% { opacity: 1; } }
/* === end mrsmash-m4c === */

/* === mrsmash-a1 leaderboard === */
.display-round-wrap { display: flex; flex-direction: column; align-items: center; gap: 4vh; width: 100%; }
.display-round-wrap .lb { width: min(70vw, 900px); }
.lb { display: flex; flex-direction: column; gap: 1.1vh; }
.lb__row { position: relative; display: flex; align-items: center; gap: 1.2vw; padding: 1vh 1.4vw; border-radius: var(--r-sm); overflow: hidden; font-size: 2vw; background: var(--surface-2); }
.lb__bar { position: absolute; left: 0; top: 0; bottom: 0; width: 0; background: linear-gradient(90deg, var(--coffee), var(--tan)); opacity: .3; transition: width .9s cubic-bezier(.22, .61, .36, 1); }
.lb__row.is-leader .lb__bar { background: linear-gradient(90deg, var(--brick), var(--brick-2)); opacity: .42; }
.lb__pos { position: relative; color: var(--tan); font-weight: 800; font-variant-numeric: tabular-nums; min-width: 1.6em; }
.lb__name { position: relative; flex: 1; font-weight: 700; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lb__score { position: relative; font-weight: 800; font-variant-numeric: tabular-nums; }
/* === end mrsmash-a1 === */

/* === mrsmash-a1b finish leaderboard + winner === */
.display-finished .lb { width: min(70vw, 900px); margin-top: 3vh; }
.display-finished__trophy, .display-finished__winner { animation: mrsmash-winner-pop .6s cubic-bezier(.22, 1.2, .36, 1) both; }
.display-finished__score { animation: mrsmash-fade-up .6s ease-out .25s both; }
@keyframes mrsmash-winner-pop { 0% { transform: scale(.7); opacity: 0; } 60% { transform: scale(1.08); } 100% { transform: scale(1); opacity: 1; } }
@keyframes mrsmash-fade-up { 0% { transform: translateY(1vh); opacity: 0; } 100% { transform: translateY(0); opacity: 1; } }
/* === end mrsmash-a1b === */

/* === mrsmash-a2 screen transitions === */
.display-screen-in { animation: mrsmash-screen-in .45s cubic-bezier(.22, .61, .36, 1) both; }
@keyframes mrsmash-screen-in { 0% { opacity: 0; transform: translateY(1.6vh) scale(.99); } 100% { opacity: 1; transform: translateY(0) scale(1); } }
/* === end mrsmash-a2 === */

/* === mrsmash-hist2 results === */
.res-meta { color: var(--text-dim); font-size: .9rem; margin: 2px 0 14px; }
.res-stand { display: flex; flex-direction: column; gap: 8px; }
.res-stand__row { display: flex; align-items: center; gap: 12px; background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 10px 14px; }
.res-stand__row.is-winner { border-color: var(--brick-2); background: rgba(185, 86, 83, .12); }
.res-stand__rank { color: var(--tan); font-weight: 800; min-width: 1.6em; font-variant-numeric: tabular-nums; }
.res-stand__name { flex: 1; font-weight: 700; }
.res-stand__score { font-weight: 800; font-variant-numeric: tabular-nums; }
.res-tag { display: inline-block; margin-left: 8px; padding: 2px 8px; border-radius: 999px; background: var(--coffee); color: #fff; font-size: .7rem; text-transform: uppercase; letter-spacing: .06em; vertical-align: middle; }
.res-q { background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 12px 14px; margin-top: 10px; }
.res-q__meta { color: var(--text-dim); font-size: .78rem; text-transform: uppercase; letter-spacing: .06em; }
.res-q__prompt { font-weight: 700; margin: 4px 0 2px; }
.res-q__correct { color: var(--green); font-size: .9rem; margin-bottom: 8px; }
.res-ans { display: flex; align-items: center; gap: 10px; padding: 6px 0; border-top: 1px dashed var(--line); font-size: .92rem; }
.res-ans__team { flex: 1; font-weight: 600; }
.res-ans__given { color: var(--text-dim); }
.res-ans__flag--ok { color: var(--green); font-weight: 700; }
.res-ans__flag--ko { color: var(--brick-2); font-weight: 700; }
.res-ans__pts { font-variant-numeric: tabular-nums; font-weight: 700; min-width: 3.5em; text-align: right; }
.res-ans__stake { color: var(--tan); font-size: .78rem; }
/* === end mrsmash-hist2 === */

/* === mrsmash-bank2 ui === */
.qb-toolbar { justify-content: space-between; gap: 10px; flex-wrap: wrap; }
.qb-toolbar__group { display: flex; gap: 10px; align-items: center; }
.qb-danger { color: var(--brick-2); }
.qb-filterbar { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin: -6px 0 14px; }
.qb-filter { background: var(--surface); color: var(--text); border: 1px solid var(--line-2); border-radius: var(--r-btn); padding: 8px 12px; font: inherit; cursor: pointer; }
.qb-filterbar__total { margin-left: auto; color: var(--text-dim); font-size: .85rem; }
.qb-selbar { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 8px 12px; margin-bottom: 12px; font-size: .9rem; }
.qb-selbar__count { font-weight: 800; color: var(--tan); font-variant-numeric: tabular-nums; }
.qb-selbar__delete { margin-left: auto; }
.qb-check { width: 18px; height: 18px; accent-color: var(--brick-2); flex: none; align-self: center; }
.qb-pager { display: flex; gap: 12px; align-items: center; justify-content: center; margin-top: 16px; color: var(--text-dim); font-size: .9rem; font-variant-numeric: tabular-nums; }
.qb-pager .btn[disabled] { opacity: .4; pointer-events: none; }
/* === end mrsmash-bank2 === */

/* === mrsmash-pick1 dialog === */
.modal--pick { width: min(480px, 94vw); text-align: left; }
.modal--pick .modal__body { display: flex; flex-direction: column; gap: 12px; margin: 16px 0 4px; }
.modal--pick .qb-filter { width: 100%; }
/* === end mrsmash-pick1 === */

/* === mrsmash-pick1b mobile === */
/* Nessun modal puo' superare il viewport (l'overlay ha 20px di padding per lato). */
.modal { max-height: calc(100vh - 40px); max-height: calc(100dvh - 40px); overflow-y: auto; }
/* Il dialog Pesca scrolla nel body: titolo e azioni restano fissi. */
.modal--pick { display: flex; flex-direction: column; overflow: hidden; }
.modal--pick .modal__title, .modal--pick .modal__actions { flex: none; }
.modal--pick .modal__body { flex: 1 1 auto; min-height: 0; overflow-y: auto; padding-right: 2px; }
@media (max-width: 560px) {
  .modal--pick { padding: 16px; }
  .modal--pick .modal__body { gap: 10px; }
  .modal--pick .modal__actions { margin-top: 14px; }
}
/* === end mrsmash-pick1b === */


/* === Mr. Smash: play reveal polish === */
.appbar__title { margin: 0; font-size: 17px; font-weight: 700; color: var(--text); flex: 1; min-width: 0; text-align: center; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* reveal: correct always wins in green, player's wrong pick in red */
.t-q.is-reveal .t-opt.is-correct { border-color: var(--green); background: rgba(20, 156, 120, .2); }
.t-opt.is-wrong { border-color: var(--brick-2); background: rgba(185, 86, 83, .16); }
.t-opt__badge--wrong { color: var(--brick-2); }

/* outcome overlay on the player's screen at reveal */
.t-outcome { position: fixed; inset: 0; z-index: 200; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; background: rgba(29, 29, 27, .72); backdrop-filter: blur(3px); animation: t-outcome-in .18s ease; cursor: pointer; }
.t-outcome__emoji { font-size: 84px; line-height: 1; }
.t-outcome--ok .t-outcome__emoji { animation: t-outcome-pop .6s cubic-bezier(.2, 1.6, .4, 1); }
.t-outcome--ko .t-outcome__emoji { animation: t-outcome-shake .5s ease; }
.t-outcome__text { font-size: 28px; font-weight: 800; letter-spacing: .08em; }
.t-outcome--ok .t-outcome__text { color: var(--green); }
.t-outcome--ko .t-outcome__text { color: var(--brick-2); }
.t-outcome__bits { position: absolute; inset: 0; pointer-events: none; }
.t-outcome__bits span { position: absolute; font-size: 30px; animation: t-outcome-float 1.6s ease-out forwards; }
.t-outcome__bits span:nth-child(1) { left: 22%; top: 58%; animation-delay: .05s; }
.t-outcome__bits span:nth-child(2) { left: 50%; top: 62%; animation-delay: .15s; }
.t-outcome__bits span:nth-child(3) { left: 74%; top: 56%; animation-delay: .1s; }
@keyframes t-outcome-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes t-outcome-pop { 0% { transform: scale(.2) rotate(-12deg); } 60% { transform: scale(1.15) rotate(4deg); } 100% { transform: scale(1) rotate(0); } }
@keyframes t-outcome-shake { 0%, 100% { transform: translateX(0); } 20% { transform: translateX(-10px) rotate(-4deg); } 40% { transform: translateX(9px) rotate(3deg); } 60% { transform: translateX(-7px); } 80% { transform: translateX(5px); } }
@keyframes t-outcome-float { from { transform: translateY(0); opacity: 1; } to { transform: translateY(-38vh) rotate(24deg); opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .t-outcome, .t-outcome__emoji, .t-outcome__bits span { animation: none !important; } }
