:root{--bg: #0f1226;--bg2: #171a36;--panel: #1d2142;--ink: #eef0ff;--muted: #9aa0c7;--blue: #3b6fe0;--blue2: #1b3a86;--red: #e0463b;--red2: #8a221b;--grey: #8b90b5;--green: #2fae6a;--gold: #f4c542;--line: #2c3162;--radius: 16px;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:radial-gradient(1200px 600px at 50% -10%,#20254d 0%,var(--bg) 60%);color:var(--ink);font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased}.screen{max-width:760px;margin:0 auto;padding:20px 18px 64px;min-height:100%}.screen.narrow{max-width:460px}h1,h2,h3{line-height:1.15}.muted{color:var(--muted)}.small{font-size:13px}.row{display:flex;align-items:center;gap:10px}.row.between{justify-content:space-between}.row.gap{gap:16px}.wrap{flex-wrap:wrap}.center{text-align:center;justify-content:center}.stack{display:flex;flex-direction:column;gap:10px}.home{text-align:center;padding-top:8vh}.logo{display:flex;flex-direction:column;gap:2px;margin:8px 0 18px}.logo-two{font-weight:900;font-size:40px;letter-spacing:2px;color:var(--blue)}.logo-and{font-style:italic;color:var(--muted)}.logo-boom{font-weight:900;font-size:44px;letter-spacing:2px;color:var(--red)}.logo-sm{font-weight:800;letter-spacing:1px}.tagline{color:var(--muted);margin:0 auto 24px;max-width:36ch}.home-actions{display:flex;flex-direction:column;gap:12px;max-width:320px;margin:0 auto}.how{margin:28px auto 0;max-width:40ch;text-align:left;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:12px 16px}.how summary{cursor:pointer;font-weight:700}.how ol{margin:10px 0 0;padding-left:20px;color:var(--muted)}.how li{margin:6px 0}.foot{margin-top:28px;font-size:12px}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--line);background:var(--bg2);color:var(--ink);padding:12px 18px;border-radius:999px;font-weight:700;cursor:pointer;transition:transform .05s ease,filter .15s ease}.btn:hover{filter:brightness(1.12)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:linear-gradient(180deg,#4a7cf0,var(--blue2));border-color:#4a7cf0}.btn.danger{background:linear-gradient(180deg,#ef5b50,var(--red2));border-color:#ef5b50}.btn.warn{background:linear-gradient(180deg,#f0a93b,#8a5b15);border-color:#f0a93b}.btn.ghost{background:transparent}.btn.big{padding:16px 22px;font-size:17px;width:100%}.btn.sm{padding:7px 12px;font-size:13px}.link{background:none;border:none;color:var(--blue);cursor:pointer;padding:6px 0;font:inherit}.link.inline{padding:0}.link.back{color:var(--muted)}.link.danger-link{color:var(--red);display:block;margin:22px auto 0}input,.big-input{background:#0d1030;border:1px solid var(--line);color:var(--ink);border-radius:12px;padding:12px 14px;font:inherit;width:100%}.big-input{font-size:18px}.code-input{letter-spacing:8px;text-align:center;font-weight:800;font-size:28px;text-transform:uppercase}label{font-weight:600;font-size:14px;color:var(--muted)}.field{display:flex;flex-direction:column;gap:6px;font-size:13px}.field input{width:160px}.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;margin:14px 0}.panel h3{margin:0 0 10px}.banner{border-radius:12px;padding:10px 14px;margin:10px 0;font-size:14px}.banner.error{background:#3a1620;border:1px solid var(--red);color:#ffd7d2}.banner.info{background:#122b3a;border:1px solid #2b6f8a;color:#cdeeff}.pill{background:var(--bg2);border:1px solid var(--line);border-radius:999px;padding:4px 12px;font-size:13px;font-weight:700}.pill.green{color:var(--green);border-color:var(--green)}.chips{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-wrap:wrap;gap:8px}.chip{background:var(--bg2);border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-weight:600;font-size:14px}.reveal-wrap{margin:16px 0}.hint{text-align:center;color:var(--muted);font-size:13px;margin-bottom:8px}.tap-hide{margin-top:8px}.card-hidden{width:100%;aspect-ratio:3/4;max-height:60vh;border-radius:20px;cursor:pointer;border:2px dashed var(--line);background:repeating-linear-gradient(45deg,#14183a,#14183a 12px,#171c44 12px,#171c44 24px);color:var(--muted);font-weight:700;font-size:18px}.card-role{border-radius:20px;padding:22px;color:#fff;box-shadow:0 12px 40px #0006;border:2px solid rgba(255,255,255,.18);min-height:280px;display:flex;flex-direction:column}.card-role.compact{min-height:0;padding:14px;border-radius:14px}.team-blue{background:linear-gradient(160deg,#2c5fd0,#15275e)}.team-red{background:linear-gradient(160deg,#d33d33,#5e1712)}.team-grey{background:linear-gradient(160deg,#6a6f96,#2c2f50)}.team-green{background:linear-gradient(160deg,#2aa564,#114a2c)}.card-team{text-transform:uppercase;letter-spacing:2px;font-size:12px;opacity:.85;font-weight:700}.card-name{font-size:34px;font-weight:900;margin:4px 0 10px}.card-role.compact .card-name{font-size:20px;margin:2px 0 6px}.card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.tag{background:#00000047;border-radius:999px;padding:3px 10px;font-size:11px;font-weight:700;letter-spacing:.5px}.card-ability{font-size:15px;opacity:.96;margin:4px 0}.card-role.compact .card-ability{font-size:12px}.card-win{font-size:14px;background:#00000040;border-radius:10px;padding:8px 12px;margin-top:auto}.card-role.compact .card-win{font-size:11px;padding:5px 8px}.card-warn{background:#0000004d;border-radius:8px;padding:6px 10px;font-size:12px;margin-bottom:8px}.timer-panel,.timer-host{text-align:center}.round-label{font-weight:800;font-size:18px;margin-bottom:6px}.countdown{font-variant-numeric:tabular-nums;font-weight:900;font-size:44px;letter-spacing:2px}.countdown.big{font-size:76px;display:block;margin:6px 0}.countdown.danger{color:var(--red);animation:pulse 1s infinite}@keyframes pulse{50%{opacity:.55}}.round-meta{color:var(--muted)}.hostage-ref{margin-top:10px;color:var(--ink)}.controls{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:16px 0}.controls .btn{flex:1 1 auto;min-width:120px}.round-strip{display:flex;gap:8px;justify-content:center;margin-top:12px;flex-wrap:wrap}.round-dot{background:var(--bg2);border:1px solid var(--line);border-radius:8px;padding:4px 10px;font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}.round-dot.on{border-color:var(--gold);color:var(--gold);font-weight:800}.round-dot.done{opacity:.5;text-decoration:line-through}.center-block{text-align:center;padding:30px 0}.spinner{width:36px;height:36px;border:4px solid var(--line);border-top-color:var(--blue);border-radius:50%;margin:0 auto 14px;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.rounds-edit{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.round-edit{display:flex;align-items:center;gap:6px;background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:6px 10px}.round-edit input{width:58px;padding:6px;text-align:center}.round-edit .r-i{font-weight:800;color:var(--muted)}.round-edit .x{background:none;border:none;color:var(--red);font-size:18px;cursor:pointer}.charset{margin:10px 0;border:1px solid var(--line);border-radius:12px;padding:8px 12px}.charset summary{cursor:pointer;font-weight:800}.char-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}.char-item{background:#0d1030;border:1px solid var(--line);border-radius:12px;padding:10px}.char-item.on{border-color:var(--gold)}.char-head{display:flex;justify-content:space-between;align-items:center;gap:6px}.char-name{font-weight:800;font-size:14px}.char-ability{font-size:11px;color:var(--muted);margin:6px 0 0}.char-win{font-size:11px;color:var(--gold);margin:4px 0 0}.stepper{display:flex;align-items:center;gap:8px}.stepper button{width:26px;height:26px;border-radius:8px;border:1px solid var(--line);background:var(--bg2);color:var(--ink);font-size:16px;cursor:pointer}.stepper span{min-width:14px;text-align:center;font-weight:800}.sticky-foot{position:sticky;bottom:0;background:linear-gradient(180deg,transparent,var(--bg) 30%);padding:12px 0 6px;margin-top:14px}.preview-line{font-size:14px;margin-bottom:8px}.preview-line.center{text-align:center}.dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin:0 4px -1px 8px}.dot.team-blue{background:var(--blue)}.dot.team-red{background:var(--red)}.dot.team-grey{background:var(--grey)}.dot.team-green{background:var(--green)}.code-hero{text-align:center;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;margin:12px 0}.code-big{font-size:56px;font-weight:900;letter-spacing:10px;color:var(--gold)}.qr-box{display:inline-flex;padding:12px;background:#fff;border-radius:14px;margin:10px auto 6px;box-shadow:0 6px 20px #00000059;line-height:0}.qr-box svg{display:block}.reveal-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.reveal-item .reveal-name{font-weight:800;margin-bottom:6px}.gbtn{display:flex;justify-content:center;margin:18px 0;min-height:44px}@media (max-width: 420px){.char-grid,.reveal-grid{grid-template-columns:1fr}.countdown.big{font-size:64px}}
