: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%}html,body{max-width:100%;overflow-x:hidden}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;overflow-wrap:break-word}.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;flex:1 1 160px;min-width:0}.field input{width:100%}.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}.chip.me{border-color:var(--gold);color:var(--gold)}.reveal-wrap{margin:16px 0}.hint{text-align:center;color:var(--muted);font-size:13px;margin-bottom:10px}.secret-card{max-width:330px;margin:0 auto}.card-actions{display:flex;gap:10px;margin-top:12px}.card-actions .btn{flex:1 1 0;min-width:0;padding-left:12px;padding-right:12px}.card-foot{text-align:center;margin:12px 0 0}.card-back,.card-color,.card-role{border-radius:22px;box-shadow:0 16px 46px #00000080}.card-back{width:100%;aspect-ratio:5 / 7;max-height:62vh;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#dfe3ff;border:1px solid rgba(255,255,255,.14);background:radial-gradient(120% 70% at 50% -5%,rgba(59,111,224,.5),transparent 55%),radial-gradient(120% 70% at 50% 105%,rgba(224,70,59,.5),transparent 55%),repeating-linear-gradient(45deg,#11142f,#11142f 13px,#161a3c 13px,#161a3c 26px)}.card-back-emblem{font-size:46px;filter:drop-shadow(0 6px 14px rgba(0,0,0,.5))}.card-back-title{font-weight:900;letter-spacing:2px;text-transform:uppercase;font-size:17px;line-height:1.25;text-align:center}.card-back-hint{color:var(--muted);font-size:13px}.card-color{width:100%;aspect-ratio:5 / 7;max-height:68vh;color:#fff;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;border:2px solid rgba(255,255,255,.28)}.card-color.team-blue{background:linear-gradient(170deg,#4f82ec,#2a51b4)}.card-color.team-red{background:linear-gradient(170deg,#ec5a50,#b22f26)}.card-color.team-grey{background:linear-gradient(170deg,#9097bd,#5b6189)}.card-color.team-green{background:linear-gradient(170deg,#38c47e,#1f854f)}.card-color-tag{text-transform:uppercase;letter-spacing:3px;font-size:12px;font-weight:800;opacity:.9}.card-color-disc{width:108px;height:108px;border-radius:50%;background:#ffffff29;border:5px solid rgba(255,255,255,.55);box-shadow:inset 0 8px 22px #00000040}.card-color-name{font-size:clamp(34px,12vw,44px);font-weight:900;letter-spacing:1px}.card-color-note{font-size:13px;opacity:.9}.card-role{padding:20px 20px 18px;color:#fff;border:1px solid rgba(255,255,255,.18);box-shadow:0 16px 46px #00000080,inset 0 1px #ffffff38;min-height:300px;display:flex;flex-direction:column}.card-role.compact{min-height:0;padding:14px;border-radius:14px;box-shadow:0 8px 22px #00000059}.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-role-top{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.18)}.card-team{text-transform:uppercase;letter-spacing:2px;font-size:12px;opacity:.9;font-weight:800}.card-pip{font-size:24px;line-height:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}.card-role.compact .card-pip{font-size:18px}.card-name{font-size:clamp(28px,9vw,36px);font-weight:900;margin:12px 0;line-height:1.05;overflow-wrap:anywhere}.card-role.compact .card-name{font-size:20px;margin:8px 0 6px}.card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.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:#00000047;border-radius:12px;padding:10px 12px;margin-top:auto}.card-win strong{display:block;text-transform:uppercase;letter-spacing:1px;font-size:11px;opacity:.8;margin-bottom:2px}.card-role.compact .card-win{font-size:11px;padding:6px 9px}.card-warn{background:#00000052;border-radius:10px;padding:7px 10px;font-size:12px;margin-bottom:10px}.gm-fab{position:fixed;right:18px;bottom:calc(18px + env(safe-area-inset-bottom,0px));width:60px;height:60px;border-radius:50%;z-index:40;border:1px solid #4a7cf0;background:linear-gradient(180deg,#4a7cf0,var(--blue2));color:#fff;font-size:26px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px #00000080}.gm-fab:active{transform:translateY(1px)}.gm-fab.attn{animation:fab-pulse 1.6s ease-in-out infinite}@keyframes fab-pulse{0%,to{box-shadow:0 10px 28px #00000080,0 0 #4a7cf08c}50%{box-shadow:0 10px 28px #00000080,0 0 0 12px #4a7cf000}}.gm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0608148c;display:flex;align-items:flex-end;justify-content:center;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}}.gm-sheet{width:100%;max-width:760px;max-height:86vh;overflow-y:auto;background:var(--panel);border:1px solid var(--line);border-radius:20px 20px 0 0;box-shadow:0 -12px 40px #00000080;padding:10px 16px calc(20px + env(safe-area-inset-bottom,0px));animation:sheet-up .2s ease}@keyframes sheet-up{0%{transform:translateY(18px);opacity:.6}}.gm-grab{width:40px;height:4px;border-radius:999px;background:var(--line);margin:4px auto 10px}.gm-sheet h3{margin:0}.gm-sheet .x{background:none;border:none;color:var(--muted);font-size:26px;line-height:1;cursor:pointer;padding:0 4px}.gm-sheet .controls{margin:14px 0 4px}.gm-h{margin:16px 0 0;font-size:14px;color:var(--muted)}.gm-foot{margin-top:14px}.help-btn{width:32px;height:32px;border-radius:50%;flex:0 0 auto;border:1px solid var(--line);background:var(--bg2);color:var(--ink);font-weight:800;font-size:16px;cursor:pointer;line-height:1;display:inline-flex;align-items:center;justify-content:center}.help-btn:hover{filter:brightness(1.15)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#0608149e;display:flex;align-items:center;justify-content:center;padding:14px;animation:fade-in .15s ease}.modal{width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:18px;box-shadow:0 22px 60px #0009;overflow:hidden;animation:sheet-up .2s ease}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:14px 18px;border-bottom:1px solid var(--line);flex:0 0 auto}.modal-head h2{margin:0;font-size:20px}.modal .x{background:none;border:none;color:var(--muted);font-size:26px;line-height:1;cursor:pointer;padding:0 4px}.modal-body{padding:16px 18px;overflow-y:auto}.modal-foot{padding:12px 18px calc(14px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--line);flex:0 0 auto}.htp-rules{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:10px 14px;margin-bottom:16px}.htp-rules summary{cursor:pointer;font-weight:700}.htp-rules ol{margin:10px 0 4px;padding-left:20px;color:var(--muted)}.htp-rules li{margin:6px 0}.htp-deck-h{margin:4px 0 2px}.deck-list{display:flex;flex-direction:column;gap:10px;margin-top:10px}.deck-card{background:#0d1030;border:1px solid var(--line);border-radius:12px;padding:12px}.deck-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px;flex-wrap:wrap}.deck-card-name{font-weight:800;font-size:15px}.deck-count{color:var(--gold);font-weight:800}.deck-card-team{font-size:12px;color:var(--muted);white-space:nowrap}.deck-card .card-tags{margin:8px 0 0}.deck-card .tag{background:var(--bg2);border:1px solid var(--line);color:var(--muted)}.deck-card-ability{font-size:13px;color:var(--ink);opacity:.9;margin:8px 0 0}.deck-card-win{font-size:12px;color:var(--gold);margin:6px 0 0}.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:clamp(56px,18vw,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:repeat(auto-fill,minmax(min(100%,240px),1fr));gap:10px;margin-top:10px}.char-item{background:#0d1030;border:1px solid var(--line);border-radius:12px;padding:10px;min-width:0}.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;min-width:0;overflow-wrap:anywhere}.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;flex:0 0 auto}.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:clamp(40px,12vw,56px);font-weight:900;letter-spacing:clamp(4px,2.5vw,10px);color:var(--gold)}.share-url{overflow-wrap:anywhere}.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:repeat(auto-fill,minmax(min(100%,220px),1fr));gap:12px}.reveal-item{min-width:0}.reveal-item .reveal-name{font-weight:800;margin-bottom:6px;overflow-wrap:anywhere}.gbtn{display:flex;justify-content:center;margin:18px 0;min-height:44px}@media (min-width: 600px){.screen{padding:24px 20px 72px}}
