:root{
  --bg:#0d0d10; --panel:#16161c; --ink:#f4f4f6; --muted:#9a9aa8;
  --accent:#c0392b; --accent-ink:#fff; --line:#26262f; --radius:14px;
}
*{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{max-width:560px;margin:0 auto;padding:24px 18px env(safe-area-inset-bottom)}
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}

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

.picklist{display:flex;flex-direction:column;gap:2px;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}

.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{
  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;
  min-height:64px;
}
.target-btn:active{background:var(--accent);color:var(--accent-ink);transform:scale(.98)}
.sheriff-result{
  border-radius:var(--radius);padding:28px 20px;
  font-size:22px;font-weight:700;text-align:center;
  margin-bottom:20px;
}
.sheriff-result.mafia{background:var(--accent);color:var(--accent-ink)}
.sheriff-result.town{background:#1a2e1a;color:#6fcf6f;border:1px solid #2d5c2d}
.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-row{
  display:flex;align-items:center;gap:12px;margin-bottom:10px;
}
.vote-row .target-btn{flex:1;margin:0}
.vote-count{
  min-width:36px;text-align:center;font-size:22px;font-weight:800;
  color:var(--accent);flex-shrink:0;
}
.abstain-row .target-btn{background:var(--bg);border-color:var(--line);color:var(--muted)}

/* Reveal */
.reveal-outcome{
  font-size:20px;font-weight:700;margin:0 0 16px;
  padding:20px;border-radius:var(--radius);text-align:center;
}
.reveal-outcome.banished{background:var(--accent);color:var(--accent-ink)}
.reveal-outcome.no-banish{background:var(--panel);border:1px solid var(--line)}

/* 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:12px 14px;border-radius:var(--radius);
  background:var(--panel);border:1px solid var(--line);
  flex-wrap:wrap;
}
.manage-row-retired{opacity:.45}
.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-retired-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;
}

/* 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;justify-content:space-between;
  margin-bottom:12px;padding:0 0 10px;
  border-bottom:1px solid var(--line);
}
.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);
  overflow:hidden;margin-bottom:24px;
}
.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;max-width:110px;word-break:break-word}
.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;
}

/* 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}
}
