/* Rye, a chunky western slab-serif, self-hosted (OFL). Headings only. */
@font-face{
  font-family:'Rye';
  font-style:normal; font-weight:400; font-display:swap;
  src:url(fonts/rye-regular.woff2) format('woff2');
}
:root{
  --bg:#0d0d10; --panel:#16161c; --ink:#f4f4f6; --muted:#9a9aa8;
  --accent:#c11522; --accent-ink:#fff; --line:#26262f; --radius:14px;
  --font-display:'Rye', Georgia, 'Times New Roman', serif;
}
/* Headings / headlines in Rye. Rye is single-weight, so pin to 400 (no faux
   bold) and ease the tracking since the face is already wide. */
h1, .step-prompt, .intro-headline, .gameover-headline, .deadlock-title,
.tut-title, .reveal-vote-name{
  font-family:var(--font-display); font-weight:400; letter-spacing:0;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:var(--bg); color:var(--ink);
  font:16px/1.4 -apple-system,system-ui,Segoe UI,Roboto,sans-serif;
  -webkit-tap-highlight-color:transparent;
  /* App-like: no double-tap zoom, no font auto-scaling, no overscroll bounce */
  touch-action:manipulation;
  -webkit-text-size-adjust:100%;
  overscroll-behavior:none;
}
#app{max-width:560px;margin:0 auto;padding:24px 18px}
h1{font-size:28px;margin:8px 0 4px;letter-spacing:.5px}
.sub{color:var(--muted);margin:0 0 24px}
.btn{
  display:block;width:100%;border:0;border-radius:var(--radius);
  padding:18px;margin:10px 0;font-size:18px;font-weight:600;cursor:pointer;
  background:var(--panel);color:var(--ink);text-align:center;
}
.btn.primary{background:var(--accent);color:var(--accent-ink)}
.btn:active{transform:scale(.99)}
.field{width:100%;padding:16px;border-radius:var(--radius);border:1px solid var(--line);
  background:var(--panel);color:var(--ink);font-size:18px}
.nav{margin-top:28px;border-top:1px solid var(--line);padding-top:14px}
.nav a{display:block;color:var(--muted);text-decoration:none;padding:12px 2px}
.err{color:var(--accent);min-height:20px;margin:8px 0}
.center{display:flex;flex-direction:column;justify-content:center;min-height:80vh}

/* Sign-in screen */
.signin-buttons{max-width:340px;width:100%;margin:14px auto 0;display:flex;
  flex-direction:column;gap:12px;align-items:center}
.google-host{display:flex;justify-content:center;width:100%;min-height:44px}
.social-btn{display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;height:44px;padding:0 16px;margin:0;font-size:16px;font-weight:600;
  border-radius:22px}
.social-btn .apple-mark{flex-shrink:0;margin-top:-2px}
.apple-btn{background:#000;color:#fff;border:1px solid #000}
.google-btn{background:#fff;color:#1f1f1f;border:1px solid #dadce0}
.social-btn .google-mark{flex-shrink:0}
.settings-signout{width:auto;margin:0;padding:8px 16px;font-size:15px}
.settings-pro-btn{width:auto;margin:0;padding:8px 16px;font-size:14px;white-space:nowrap}
.settings-pro-active{color:#6fcf6f;font-weight:700;font-size:14px}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}
.settings-sub{display:block;color:var(--muted);font-size:13px;font-weight:400;margin-top:2px}

/* Wizard */
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}

.pick-bulk{display:flex;gap:10px;margin-bottom:12px}
.pick-bulk .btn{flex:1;margin:0}
.pick-groups-label{margin:14px 0 8px}
.pick-groups{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.group-chip{
  display:flex;align-items:stretch;overflow:hidden;
  border:1px solid var(--line);border-radius:999px;background:var(--panel);
}
.group-apply{
  background:none;border:0;color:var(--ink);font-size:14px;font-weight:700;
  padding:8px 14px;cursor:pointer;
}
.group-apply:active{background:var(--accent);color:var(--accent-ink)}
.group-del{
  background:none;border:0;border-left:1px solid var(--line);
  color:var(--muted);font-size:18px;line-height:1;padding:0 12px;cursor:pointer;
}
.group-del:active{color:var(--accent)}
.picklist{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}

.pick{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;border-radius:var(--radius);
  background:var(--panel);cursor:pointer;
  border:1px solid var(--line);
}
.pick input[type=checkbox]{
  width:20px;height:20px;accent-color:var(--accent);flex-shrink:0;cursor:pointer;
}
.pick span{font-size:17px}

.scenariocard{
  padding:16px;border-radius:var(--radius);
  background:var(--panel);border:1px solid var(--line);
  cursor:pointer;display:flex;flex-direction:column;gap:4px;
}
.scenariocard:active{transform:scale(.99)}
.scenariocard strong{font-size:17px}
.scenariocard .sub{font-size:14px;margin:0}
.scenariocard.custom{border:1px dashed var(--accent);background:rgba(192,57,43,.08);margin-bottom:6px}
.scenariocard.custom strong{color:var(--accent)}

/* Custom Game config form */
.custom-form{display:flex;flex-direction:column;margin-bottom:16px}
.cf-label{font-size:13px;color:var(--muted);margin:14px 0 6px;font-weight:600}
.cf-row2{display:flex;gap:12px}
.cf-col{flex:1;display:flex;flex-direction:column}
.cf-col .cf-label{margin-top:0}

/* Manual role assignment */
.assign-list{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.assign-row{display:flex;align-items:center;gap:12px}
.assign-name{flex:1;font-size:18px;font-weight:700}
.assign-row .assign-role{flex:0 0 150px}
.assign-row .sel{flex:0 0 150px}
.assign-status{min-height:20px;margin:0 0 16px;font-size:14px;line-height:1.4}
.assign-status.bad{color:var(--accent)}
.assign-status.ok{color:var(--muted)}

/* Set the Scene + dramatic intro */
.setup-story{
  width:100%;min-height:220px;padding:14px 16px;
  border-radius:var(--radius);border:1px solid var(--line);
  background:var(--panel);color:var(--ink);
  font-size:16px;font-family:inherit;line-height:1.45;resize:vertical;margin-bottom:8px;
}
.ai-note{min-height:18px;margin:4px 0 8px;font-size:13px;color:var(--muted);line-height:1.4}
.intro-screen{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;min-height:68vh;gap:18px;
}
.intro-headline{font-size:34px;font-weight:900;color:var(--accent);letter-spacing:.5px;margin:0}
.intro-story{font-size:18px;line-height:1.55;max-width:440px;color:var(--ink);margin:0}
.intro-count{font-size:72px;font-weight:900;color:var(--ink);margin:8px 0;line-height:1}
.intro-count.danger{color:var(--accent)}

/* Deadlock tie-break event */
.deadlock-screen{gap:14px}
.deadlock-title{font-size:40px;font-weight:900;color:var(--accent);
  letter-spacing:2px;text-transform:uppercase;margin:0}
.deadlock-names{font-size:24px;font-weight:800;color:var(--ink);
  letter-spacing:1px;margin:2px 0}
.dl-nightfall{font-size:20px;color:var(--muted);font-style:italic;letter-spacing:.5px}

/* Per-speaker final-statement list */
.dl-list{display:flex;flex-direction:column;gap:8px;width:100%;max-width:360px;margin:4px auto}
.dl-row{display:flex;align-items:center;justify-content:space-between;
  padding:12px 18px;border-radius:var(--radius);border:1px solid var(--line);
  background:var(--panel);opacity:.5;min-height:56px;transition:opacity .15s,border-color .15s}
.dl-row.active{opacity:1;border-color:var(--accent);background:rgba(192,21,34,.10)}
.dl-row.done{opacity:.8}
.dl-row-name{font-size:18px;font-weight:700;color:var(--ink)}
.dl-state{font-size:15px;color:var(--muted);display:flex;align-items:center}
.dl-state.dl-waiting{font-style:italic}
.dl-state.dl-count-inline{font-size:28px;font-weight:900;color:var(--accent);line-height:1}
.dl-state.dl-count-inline.danger{color:#fff}
.dl-row.done .dl-state{color:#6fcf6f}

.review-table{display:flex;flex-direction:column;gap:0;margin-bottom:24px;
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.review-row{display:flex;justify-content:space-between;align-items:center;
  padding:12px 16px;border-bottom:1px solid var(--line)}
.review-row:last-child{border-bottom:0}
.review-label{color:var(--muted);font-size:14px}
.review-val{font-size:15px;font-weight:600;text-align:right}

.reveal-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:12px;margin-bottom:24px;
}
.reveal-card{
  position:relative;height:100px;cursor:pointer;
  perspective:600px;
}
.reveal-front,.reveal-back{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  border-radius:var(--radius);border:1px solid var(--line);
  backface-visibility:hidden;transition:transform .35s ease;
  padding:8px;text-align:center;
}
.reveal-front{
  background:var(--panel);font-size:15px;font-weight:600;
  transform:rotateY(0deg);
}
.reveal-back{
  background:var(--accent);color:var(--accent-ink);
  transform:rotateY(180deg);
}
.reveal-card.flipped .reveal-front{transform:rotateY(-180deg)}
.reveal-card.flipped .reveal-back{transform:rotateY(0deg)}
.reveal-role{font-size:17px;font-weight:700}
.reveal-alignment{font-size:12px;opacity:.8;margin-top:4px;text-transform:uppercase;letter-spacing:.5px}

/* Night flow */
.night-step{display:flex;flex-direction:column;gap:0}
.step-prompt{
  font-size:22px;font-weight:700;margin:12px 0 20px;color:var(--ink);
}
.target-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.target-btn{
  position:relative;
  display:block;width:100%;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 18px;font-size:20px;font-weight:700;cursor:pointer;
  background:var(--panel);color:var(--ink);text-align:center;
  transition:background .15s,transform .1s,opacity .15s;
  min-height:64px;
}
.target-btn:active{background:var(--accent);color:var(--accent-ink);transform:scale(.98)}
/* Tap confirmation: the chosen tile fills accent with a circled check; the rest fade. */
.target-btn:disabled{cursor:default}
.target-btn:disabled:not(.selected){opacity:.4}
.target-btn.selected{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.target-check{
  position:absolute;right:16px;top:50%;transform:translateY(-50%);
  display:flex;align-items:center;color:var(--accent-ink);
}
/* Night target tiles with a role badge for the narrator. */
.target-btn.has-tag{display:flex;align-items:center;justify-content:space-between;gap:12px;text-align:left}
.target-btn .target-name{flex:1;min-width:0}
.target-btn.selected .role-tag{visibility:hidden}
.role-tag{
  flex-shrink:0;font-size:12px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;
  padding:4px 10px;border-radius:999px;
}
.role-mafia{background:rgba(193,21,34,.24);color:#ef8a8a}
.role-doctor{background:rgba(46,160,90,.18);color:#6fce93}
.role-sheriff{background:rgba(70,120,200,.22);color:#8fb4e8}
.role-town{background:var(--bg);color:var(--muted)}
.role-note{font-size:13px;color:var(--muted);font-weight:600;margin:-4px 0 16px;letter-spacing:.2px}
.role-note.dead{color:var(--accent)}

/* Roster sections: In The Game / Murdered / Banished */
.roster-head{
  display:flex;align-items:center;gap:8px;
  font-size:13px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;
  color:var(--muted);margin:20px 0 10px;
}
.roster-count{
  background:var(--panel);border:1px solid var(--line);border-radius:999px;
  color:var(--muted);font-size:12px;padding:1px 9px;
}
.dead-list{display:flex;flex-direction:column;gap:8px}
.dead-row{
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;border-radius:var(--radius);
  background:var(--bg);border:1px solid var(--line);opacity:.72;
}
.dead-row.alive-row{opacity:1;background:var(--panel)}
.dead-row .target-name{flex:1;min-width:0}
.death-round{flex-shrink:0;font-size:12px;font-weight:700;color:var(--muted)}
.gameover-roster{width:100%}
.timeline{display:flex;flex-direction:column;gap:8px;width:100%}
.tl-item{
  display:flex;gap:12px;align-items:baseline;
  padding:12px 16px;border-radius:var(--radius);
  background:var(--bg);border:1px solid var(--line);
}
.tl-when{
  flex-shrink:0;width:60px;font-size:12px;font-weight:800;
  text-transform:uppercase;letter-spacing:.4px;color:var(--muted);
}
.tl-night .tl-when{color:#8fb4e8}
.tl-day .tl-when{color:var(--accent)}
.tl-line{flex:1;font-size:15px;color:var(--ink);line-height:1.4;text-align:left}
/* Result cards: information, never a button. Tinted by outcome and shared by the
   sheriff investigation result and the reveal verdict. good = green (Town / Not
   Mafia), bad = red (Mafia), neutral = no disclosure or no banishment. */
.result-card{
  border-radius:var(--radius);padding:28px 20px;
  font-size:22px;font-weight:700;text-align:center;margin:8px 0 24px;
}
.result-card.good{background:#15241a;color:#6fcf6f;border:1px solid #2d5c2d}
.result-card.bad{background:#2a1614;color:#e8736a;border:1px solid #5c2f2d}
.result-card.neutral{background:var(--panel);color:var(--ink);border:1px solid var(--line)}
.recruit-toggle{
  display:flex;align-items:center;margin-bottom:16px;
  padding:14px 16px;border-radius:var(--radius);
  background:var(--panel);border:1px solid var(--line);
}
.recruit-toggle label{
  display:flex;align-items:center;gap:12px;
  font-size:16px;font-weight:600;cursor:pointer;
  width:100%;
}
.recruit-toggle input[type=checkbox]{
  width:20px;height:20px;accent-color:var(--accent);flex-shrink:0;cursor:pointer;
}

/* Morning / narration */
.outcome-line{font-size:20px;font-weight:700;margin:0 0 12px}
.narration{font-style:italic;color:var(--muted);margin:0 0 24px;line-height:1.6}

/* Discussion timer */
.timer{
  font-size:72px;font-weight:800;letter-spacing:2px;text-align:center;
  color:#4caf50;margin:12px 0 8px;font-variant-numeric:tabular-nums;
  transition:color .3s;
}
.timer.warn{color:#f0a500}
.timer.danger{color:var(--accent)}
.timer-flash{
  display:none;
  text-align:center;font-size:18px;font-weight:700;color:var(--accent);
  margin-bottom:8px;animation:flash 1s step-start infinite;
}
.timer-flash.show{display:block}
@keyframes flash{0%,100%{opacity:1}50%{opacity:0}}
.timer-controls{display:flex;gap:8px;margin-bottom:12px}
.timer-controls .btn{flex:1;padding:14px 8px;font-size:16px;margin:0}

/* Voting */
.vote-status{
  font-size:15px;color:var(--muted);text-align:center;
  margin:0 0 16px;font-weight:600;
}
.vote-candidate{
  display:flex;align-items:center;gap:12px;
}
.vote-candidate .vote-name{flex:1;text-align:center}
.vote-count{
  min-width:32px;text-align:center;font-size:20px;font-weight:800;
  color:var(--accent);flex-shrink:0;
}
.vote-row{display:flex;align-items:stretch;gap:10px}
.vote-row .vote-candidate{flex:1;margin:0}
.vote-minus{
  flex-shrink:0;width:52px;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--panel);color:var(--muted);font-size:26px;font-weight:700;line-height:1;cursor:pointer;
}
.vote-minus:active{background:var(--accent);color:var(--accent-ink)}

/* Reveal */

/* Game over */
.gameover{display:flex;flex-direction:column;align-items:center;padding-top:24px}
.gameover-headline{
  font-size:48px;font-weight:900;color:var(--accent);
  text-align:center;margin-bottom:12px;letter-spacing:1px;
}
.gameover .narration{text-align:center;max-width:400px}
.gameover .player-list{width:100%;margin-top:20px}

/* Management screens */
.manage-back{margin-top:12px}

.manage-add-row{
  display:flex;gap:10px;align-items:stretch;margin-bottom:18px;
}
.manage-add-field{flex:1;margin:0}
.manage-add-btn{
  flex-shrink:0;width:auto;padding:0 22px;margin:0;font-size:16px;
}

.manage-list{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.manage-empty{margin:0 0 12px}

.manage-row{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 16px;border-radius:var(--radius);
  background:var(--panel);border:1px solid var(--line);
  flex-wrap:wrap;cursor:pointer;
}
.manage-row:active{background:var(--bg)}
.manage-row-retired,.manage-row-archived{opacity:.5}
.manage-name{font-size:16px;font-weight:600;flex:1;min-width:0;word-break:break-word}

.manage-actions{
  display:flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:wrap;
}

.manage-toggle-wrap{
  display:flex;align-items:center;gap:6px;cursor:pointer;
  padding:6px 10px;border-radius:var(--radius);
  border:1px solid var(--line);background:var(--bg);
  white-space:nowrap;
}
.manage-toggle-wrap input[type=checkbox]{
  width:18px;height:18px;accent-color:var(--accent);flex-shrink:0;cursor:pointer;margin:0;
}
.manage-toggle-label{font-size:13px;font-weight:600;color:var(--muted)}

.manage-rename-btn,.manage-retire-btn{
  width:auto;padding:6px 14px;margin:0;font-size:13px;font-weight:600;
}
.manage-retire-btn{color:var(--accent)}

.manage-section-label{
  font-size:12px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;
  color:var(--muted);margin:18px 0 6px;
}
.manage-remove-btn{color:var(--accent)}
.manage-retired-badge,.manage-archived-badge{
  font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  color:var(--muted);flex-shrink:0;
}

/* Shared form control height (forms rule: select = input height) */
.fld,
select.fld{
  height:54px;padding:0 16px;line-height:54px;
  border-radius:var(--radius);border:1px solid var(--line);
  background:var(--panel);color:var(--ink);font-size:16px;
  width:100%;appearance:none;-webkit-appearance:none;
}

/* Themed dropdown (replaces the gray OS option menu) */
.sel{position:relative}
.sel.open{z-index:20}
.sel select.fld{display:none}
.sel-btn{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  text-align:left;cursor:pointer;font-family:inherit;
}
.sel-btn .sel-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sel-chev{flex-shrink:0;color:var(--muted);transition:transform .15s ease}
.sel.open .sel-chev{transform:rotate(180deg)}
.sel-menu{
  position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:60;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:none;box-shadow:0 14px 34px rgba(0,0,0,.55);
}
.sel.open .sel-menu{display:block}
.sel-item{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  width:100%;padding:14px 16px;background:none;border:0;border-bottom:1px solid var(--line);
  color:var(--ink);font-size:16px;font-family:inherit;text-align:left;cursor:pointer;
}
.sel-item:last-child{border-bottom:0}
.sel-item.on{color:var(--accent);font-weight:700}
.sel-item:active{background:var(--bg)}
.sel-check{flex-shrink:0;color:var(--accent)}

/* Scenario / Ruleset form layout */
.manage-form-label{
  display:block;font-size:13px;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;color:var(--muted);margin:14px 0 4px;
}
.manage-form-input{display:block}
.manage-form-row2{
  display:flex;gap:12px;
}
.manage-form-col{flex:1;min-width:0}

.manage-scenario-info{
  display:flex;flex-direction:column;gap:2px;flex:1;min-width:0;
}
.manage-scenario-desc{
  font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.manage-edit-btn,.manage-delete-btn{
  width:auto;padding:6px 14px;margin:0;font-size:13px;font-weight:600;
}
.manage-delete-btn{color:var(--accent)}

/* Ruleset form toggles */
.ruleset-toggle-row{
  display:flex;align-items:center;gap:10px;
  padding:14px 16px;border-radius:var(--radius);
  border:1px solid var(--line);background:var(--panel);
  margin:8px 0;cursor:pointer;width:100%;
}
.ruleset-toggle-row input[type=checkbox]{
  width:20px;height:20px;accent-color:var(--accent);flex-shrink:0;cursor:pointer;margin:0;
}
.ruleset-toggle-row .manage-toggle-label{
  font-size:15px;font-weight:600;color:var(--ink);letter-spacing:0;text-transform:none;
}

/* In-game persistent header */
.game-header{
  display:flex;align-items:center;gap:10px;
  margin-bottom:12px;padding:10px 0;
  /* The global topbar is hidden in-game, so clear the status bar here */
  padding-top:calc(env(safe-area-inset-top) + 10px);
  border-bottom:1px solid var(--line);
}
.game-back{
  background:transparent;border:0;color:var(--muted);
  padding:4px 6px 4px 0;cursor:pointer;display:flex;align-items:center;flex-shrink:0;
}
.game-back:active{opacity:.6;transform:scale(.92)}
.game-town{font-size:13px;color:var(--muted);font-weight:600;letter-spacing:.3px}
.morning-intro{
  font-size:16px;line-height:1.5;color:var(--muted);font-style:italic;
  margin:0 0 16px;max-width:480px;
}
.home-btn{
  background:var(--panel);color:var(--muted);
  border:1px solid var(--line);border-radius:var(--radius);
  padding:7px 16px;font-size:14px;font-weight:600;cursor:pointer;
  flex-shrink:0;
}
.home-btn:active{opacity:.7;transform:scale(.97)}

/* Dashboard */
.dash{display:flex;flex-direction:column}
.phase-pill{
  display:inline-block;align-self:flex-start;
  background:var(--accent);color:var(--accent-ink);
  font-size:13px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;
  padding:5px 14px;border-radius:20px;margin-bottom:6px;
}
.alive-count{margin-bottom:16px}
.win-line{
  font-size:20px;font-weight:700;color:var(--accent);
  margin-bottom:16px;
}
.player-list{
  display:flex;flex-direction:column;gap:4px;margin-bottom:20px;
}
.player-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 16px;border-radius:var(--radius);
  background:var(--panel);border:1px solid var(--line);
}
.player-row.dead{opacity:.4}
.player-name{font-size:16px;font-weight:600}
.player-status{font-size:13px;color:var(--muted);text-align:right;max-width:60%}

/* Settings screen */
.settings-list{
  display:flex;flex-direction:column;gap:0;
  border:1px solid var(--line);border-radius:var(--radius);
  margin-bottom:24px;
}
/* The themed dropdown matches the old native select width and can open without
   being clipped (the list intentionally does not hide overflow). */
.settings-row .sel{width:130px;flex-shrink:0}
.settings-row{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 16px;border-bottom:1px solid var(--line);
}
.settings-row:last-child{border-bottom:0}
.settings-label{font-size:15px;font-weight:600;flex:1;min-width:0}

/* Toggle pill */
.settings-toggle-wrap{
  display:inline-flex;align-items:center;cursor:pointer;flex-shrink:0;
}
.settings-toggle-wrap .settings-cb{
  position:absolute;opacity:0;width:0;height:0;pointer-events:none;
}
.settings-toggle-track{
  position:relative;display:inline-block;
  width:48px;height:28px;border-radius:14px;
  background:var(--line);transition:background .2s;flex-shrink:0;
}
.settings-toggle-thumb{
  position:absolute;top:3px;left:3px;
  width:22px;height:22px;border-radius:50%;
  background:var(--muted);transition:transform .2s,background .2s;
}
.settings-cb:checked + .settings-toggle-track{background:var(--accent)}
.settings-cb:checked + .settings-toggle-track .settings-toggle-thumb{
  transform:translateX(20px);background:#fff;
}

/* Statistics screen */
.stats-totals{
  display:flex;flex-direction:column;gap:4px;
  padding:16px;border-radius:var(--radius);
  background:var(--panel);border:1px solid var(--line);
  margin-bottom:20px;
}
.stats-total-games{font-size:20px;font-weight:700}
.stats-win-split{font-size:14px;color:var(--muted);font-weight:600}

.stats-empty{
  padding:40px 0 24px;text-align:center;
}
.stats-empty-title{
  font-size:20px;font-weight:700;margin:0 0 8px;
}

.stats-scroll-wrap{
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  margin-bottom:12px;
  border:1px solid var(--line);border-radius:var(--radius);
}
.stats-table{
  width:100%;border-collapse:collapse;
  font-size:14px;
}
.stats-th{
  padding:10px 10px;font-size:11px;font-weight:700;
  letter-spacing:.6px;text-transform:uppercase;color:var(--muted);
  background:var(--bg);border-bottom:1px solid var(--line);
  white-space:nowrap;
}
.stats-td{
  padding:11px 10px;border-bottom:1px solid var(--line);vertical-align:middle;
}
.stats-table tbody tr:last-child .stats-td{border-bottom:0}
.stats-name-col{text-align:left;font-weight:600;white-space:nowrap}

/* Statistics as player cards */
.stat-cards{display:flex;flex-direction:column;gap:14px}
.stat-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.stat-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:14px}
.stat-card-name{font-size:18px;font-weight:800}
.stat-card-record{font-size:13px;font-weight:700;color:var(--muted);flex-shrink:0}
.stat-card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.stat-cell{text-align:center}
.stat-cell-num{font-size:18px;font-weight:800;color:var(--ink)}
.stat-cell-label{font-size:10px;color:var(--muted);margin-top:3px;text-transform:uppercase;letter-spacing:.3px}
.stats-num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}

/* Settings number + select controls: same height as .fld */
.fld.settings-number{
  width:90px;flex-shrink:0;text-align:right;
}
.fld.settings-select{
  width:130px;flex-shrink:0;
}

/* Info icon button */
.info-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;padding:2px;
  background:transparent;border:0;border-radius:50%;
  color:var(--muted);cursor:pointer;
  vertical-align:middle;margin-left:5px;flex-shrink:0;
  -webkit-tap-highlight-color:transparent;
  transition:color .15s;
}
.info-btn:hover,.info-btn:focus{color:var(--accent);outline:none}
.info-btn:active{opacity:.7}
.info-btn svg{display:block}

/* Info overlay */
.info-overlay{
  position:fixed;inset:0;z-index:500;
  background:rgba(0,0,0,.65);
  display:flex;align-items:center;justify-content:center;
  padding:24px;
}
.info-card{
  background:var(--panel);border-radius:var(--radius);
  padding:28px 24px 20px;
  max-width:340px;width:100%;
  border:1px solid var(--line);
}
.info-card-title{
  font-size:20px;font-weight:700;margin:0 0 12px;
}
.info-card-body{
  font-size:15px;color:var(--muted);line-height:1.55;
  margin:0 0 12px;
}
.info-line{
  font-size:15px;color:var(--ink);line-height:1.5;
  margin:0 0 6px;padding-left:2px;
}
.info-line:last-of-type{margin-bottom:20px}
.info-got-it{
  margin:0;
}

/* ── Companion narrator monitor ─────────────────────────────────────────── */
.game-room-btn{margin-left:auto;background:transparent;border:1px solid var(--accent);color:var(--accent);
  border-radius:999px;padding:5px 14px;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap}
.room-overlay-card{max-width:360px;max-height:86vh;overflow-y:auto;text-align:center}
.room-overlay-card .room-join{margin-top:0}
.device-vote-row{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:14px 0}
.room-join{display:flex;flex-direction:column;align-items:center;gap:2px;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;margin:6px 0 4px}
.room-qr{background:#fff;padding:10px;border-radius:10px;line-height:0;margin-bottom:10px}
.room-qr img,.room-qr canvas{display:block}
.room-join-label{font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.room-code{font-size:44px;font-weight:900;letter-spacing:8px;color:var(--accent);line-height:1.1}
.room-url{font-size:14px;color:var(--muted)}
.room-hint{font-size:13px;color:var(--muted);text-align:center;margin:0 0 12px}
.room-voter-list{display:flex;flex-direction:column;gap:6px;margin:6px 0 16px}
.room-voter-row{display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel)}
.room-voter-name{font-size:16px;font-weight:600;color:var(--ink)}
.room-voter-done{font-size:14px;font-weight:700;color:#6fcf6f}
.room-voter-wait{font-size:13px;color:var(--muted);font-style:italic}
.room-cast-btn{background:var(--bg);border:1px solid var(--line);color:var(--ink);
  border-radius:10px;padding:6px 14px;font-size:14px;font-weight:600;cursor:pointer}

/* ── Companion player page (/play) ──────────────────────────────────────── */
.play-logo-wrap{display:flex;justify-content:center;padding:24px 0 6px}
.play-pad{padding:8px 4px 24px}
.play-center{display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:50vh;text-align:center;gap:6px}
.play-seat{font-size:20px;color:var(--ink);margin:0}
.play-hint{font-size:13px;color:var(--muted);margin:0 0 14px}
.play-code{text-align:center;font-size:34px;font-weight:800;letter-spacing:10px;
  text-transform:uppercase;padding:18px}
.play-claim-list{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.play-claim{position:relative;display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:700}
.play-claim.taken{opacity:.45}
.play-taken-tag{position:absolute;right:16px;font-size:12px;font-weight:600;
  color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.play-tiles{margin-top:6px}
.play-tile{justify-content:center;font-size:18px;font-weight:700;min-height:60px}

/* Locked phone-as-whiteboard */
.cover-card{position:fixed;inset:0;background:var(--bg);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:14px;text-align:center;cursor:pointer;padding:24px}
.cover-logo{width:140px;max-width:50%;height:auto;opacity:.95}
.cover-text{font-size:24px;font-weight:800;color:var(--ink);margin:0;letter-spacing:1px}
.cover-tap{font-size:15px;color:var(--muted);margin:0}
.reveal-vote-card{position:fixed;inset:0;background:var(--accent);color:var(--accent-ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  text-align:center;cursor:pointer;padding:24px}
.reveal-vote-label{font-size:16px;font-weight:600;opacity:.9;margin:0;text-transform:uppercase;letter-spacing:1px}
.reveal-vote-name{font-size:52px;font-weight:900;margin:0;line-height:1.05}
.reveal-vote-tap{font-size:14px;opacity:.85;margin:0}

/* Subtle Home footer link to re-open the tutorial */
.home-help-link{display:block;margin:30px auto 10px;background:none;border:0;
  color:var(--muted);font-size:14px;font-weight:600;letter-spacing:.3px;
  text-decoration:underline;text-underline-offset:3px;cursor:pointer;padding:8px}

/* How to Play tutorial carousel */
.tut-overlay{position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.78);
  display:flex;align-items:center;justify-content:center;padding:24px}
.tut-card{position:relative;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius);max-width:360px;width:100%;padding:30px 24px 22px;text-align:center}
.tut-close{position:absolute;top:10px;right:10px;background:transparent;border:0;
  color:var(--muted);cursor:pointer;padding:8px;line-height:0}
.tut-icon{color:var(--accent);display:flex;justify-content:center;margin:4px 0 14px}
.tut-title{font-size:22px;font-weight:800;margin:0 0 10px;color:var(--ink)}
.tut-body{font-size:15px;line-height:1.6;color:var(--muted);margin:0 0 18px;min-height:80px}
.tut-dots{display:flex;justify-content:center;gap:7px;margin:0 0 18px}
.tut-dot{width:7px;height:7px;border-radius:50%;background:var(--line)}
.tut-dot.on{background:var(--accent)}
.tut-nav{display:flex;gap:10px}
.tut-nav .btn{margin:0;flex:1}
.tut-back{background:transparent;border:1px solid var(--line);color:var(--ink)}
.tut-spacer{flex:1}

/* Screen fade: plays once on full-screen render; timer ticks on nested elements do not re-trigger */
@keyframes screen-fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion: no-preference){
  #app > *{animation:screen-fade 160ms ease both}
}

/* ── Logo ──────────────────────────────────────────────────────────────── */
.logo-sm{
  display:block;height:34px;width:auto;object-fit:contain;
}
.logo-lg{
  display:block;width:300px;max-width:84%;height:auto;object-fit:contain;
  margin:0 auto 8px;
}
.home-logo-wrap{
  display:flex;justify-content:center;padding:20px 0 4px;
}
.home-section-label{
  font-size:12px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;
  color:var(--muted);margin:26px 0 10px;
}
.home-stat-grid{display:flex;gap:10px}
.home-stat{
  flex:1;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 10px;text-align:center;
}
.home-stat-num{font-size:26px;font-weight:800;color:var(--ink)}
.home-stat-label{font-size:12px;color:var(--muted);margin-top:4px}
.home-recent-list{display:flex;flex-direction:column;gap:8px}
.home-recent-row{
  display:flex;align-items:center;gap:12px;padding:14px 16px;
  border-radius:var(--radius);background:var(--panel);border:1px solid var(--line);
}
.rg-when{font-weight:700;color:var(--ink);flex-shrink:0}
.rg-players{flex:1;color:var(--muted);font-size:14px}
.rg-result{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;flex-shrink:0}
.rg-town{color:#6fce93}
.rg-mafia{color:var(--accent)}

/* ── Top bar ────────────────────────────────────────────────────────────── */
#topbar{
  position:sticky;top:0;z-index:100;
  width:100%;background:var(--panel);
  border-bottom:1px solid var(--line);
  padding-top:env(safe-area-inset-top);
}
.topbar-inner{
  max-width:560px;margin:0 auto;
  height:52px;display:flex;align-items:center;justify-content:space-between;
  padding:0 8px;
}
.topbar-side{
  width:44px;flex-shrink:0;
}
.topbar-back{
  width:44px;height:44px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:transparent;border:0;color:var(--ink);cursor:pointer;
  border-radius:var(--radius);
  -webkit-tap-highlight-color:transparent;
}
.topbar-back:active{opacity:.6}

/* ── Tab bar ────────────────────────────────────────────────────────────── */
#tabbar{
  position:fixed;bottom:0;left:0;right:0;z-index:100;
  background:var(--panel);border-top:1px solid var(--line);
  padding-bottom:env(safe-area-inset-bottom);
  display:flex;
}
.tab-btn{
  flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:3px;
  padding:8px 4px;border:0;background:transparent;
  color:var(--muted);cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  min-height:56px;
}
.tab-btn.active{color:var(--accent)}
.tab-btn:active{opacity:.7}
.tab-icon{
  display:flex;align-items:center;justify-content:center;
  width:24px;height:24px;
}
.tab-label{
  font-size:11px;font-weight:600;letter-spacing:.2px;
  line-height:1;
}

/* ── Chrome-aware #app padding ─────────────────────────────────────────── */
/* Top bar present: push content below it; absent: start at the top. */
body.has-topbar #app{ padding-top:calc(52px + env(safe-area-inset-top)); }
body:not(.has-topbar) #app{ padding-top:0; }
/* Bottom nav present: leave room above it; absent: just the safe-area inset. */
body.has-tabbar #app{ padding-bottom:calc(56px + env(safe-area-inset-bottom)); }
body:not(.has-tabbar) #app{ padding-bottom:env(safe-area-inset-bottom); }
/* Hide each bar when its class is absent. */
body:not(.has-topbar) #topbar{ display:none; }
body:not(.has-tabbar) #tabbar{ display:none; }

/* ── Tier UX: paywall overlay, Home upsell, locked Pro affordances ─────────── */
.paywall-card{text-align:center;max-width:340px}
.paywall-title{font-family:var(--font-display);font-weight:400;font-size:30px;color:var(--accent);margin:0 0 2px}
.paywall-sub{color:var(--muted);margin:0 0 16px;font-size:14px}
.paywall-feats{list-style:none;margin:0 0 18px;padding:0;text-align:left;display:grid;gap:11px}
.paywall-feats li{display:flex;align-items:center;gap:10px;font-size:15px}
.paywall-feats li svg{color:#6fcf6f;flex-shrink:0}
.paywall-card .btn{margin-top:8px}
.pw-web-note{color:var(--muted);font-size:14px;margin:4px 0 4px}
.home-upsell{display:block;width:100%;margin:14px 0 0;padding:14px 16px;text-align:left;
  background:rgba(192,21,34,.10);border:1px solid var(--accent);border-radius:var(--radius);cursor:pointer}
.home-upsell:active{background:rgba(192,21,34,.18)}
.home-upsell-title{display:block;font-weight:800;color:var(--ink);font-size:15px}
.home-upsell-sub{display:block;color:var(--muted);font-size:13px;margin-top:2px}
.btn.pro-locked{opacity:.85}
.pro-lock-ic{vertical-align:-2px;opacity:.85}
.pro-pill{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:999px;
  background:rgba(192,21,34,.12);border:1px solid var(--accent);color:var(--accent);
  font-weight:700;font-size:13px;cursor:pointer;white-space:nowrap}
.pro-pill:active{background:rgba(192,21,34,.22)}
