@font-face{font-family:Avengeance;src:url(../fonts/avengeance-mightiest.otf) format("opentype"),url(../fonts/avengeance-mightiest.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}:root{--bg: #1b1f2a;--panel: #252b3a;--panel-2: #2e3548;--text: #eef1f7;--muted: #98a0b3;--primary: #e23636;--primary-dark: #b02525;--secondary: #2c6fb3;--danger: #c0392b;--ok: #27893f;--radius: 12px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}button,input,select,textarea{font-family:inherit}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:Barlow Semi Condensed,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:16px}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:url(../background.jpg) center center / cover no-repeat;opacity:.07;pointer-events:none;transition:opacity .7s ease}body.celebrate:before{opacity:.5}.screen{min-height:100%;display:flex;flex-direction:column;max-width:560px;margin:0 auto;padding:env(safe-area-inset-top) 16px 24px}.screen.center{justify-content:center;align-items:center}.content{flex:1;display:flex;flex-direction:column;gap:16px;padding-top:8px}.content.center{justify-content:center;align-items:center}.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--panel-2)}.title{font-family:Avengeance,system-ui,sans-serif;font-size:1.6rem;letter-spacing:.03em;margin:0}.subtitle{font-size:1.1rem;margin:0 0 4px}.muted{color:var(--muted);font-size:.9rem}.label{font-size:.85rem;color:var(--muted);margin-top:8px}.center{text-align:center}.card-panel{background:var(--panel);border-radius:var(--radius);padding:24px;width:100%;max-width:360px;text-align:center}.form{display:flex;flex-direction:column;gap:10px}.stack{display:flex;flex-direction:column;gap:12px}.input{width:100%;padding:14px 16px;font-size:1rem;border-radius:10px;border:1px solid var(--panel-2);background:var(--panel-2);color:var(--text)}.input:focus{outline:2px solid var(--primary)}.input-code{text-transform:uppercase;letter-spacing:.3em;text-align:center;font-size:1.6rem;font-weight:700}.btn{padding:14px 18px;font-size:1rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;color:#fff;transition:filter .15s,opacity .15s}.btn:active{filter:brightness(.9)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-lg{padding:18px;font-size:1.1rem}.btn-sm{padding:8px 12px;font-size:.85rem}.btn-primary{background:var(--primary)}.btn-secondary{background:var(--secondary)}.btn-danger{background:var(--danger)}.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--panel-2)}.error{color:#ff8b8b;font-size:.9rem;margin:4px 0}.notice{background:var(--panel-2);padding:12px;border-radius:10px;font-size:.9rem}.room-code-box{background:var(--panel);border-radius:var(--radius);padding:16px;text-align:center;display:flex;flex-direction:column;gap:4px}.room-code{font-size:2.6rem;font-weight:800;letter-spacing:.2em;color:var(--primary)}.player-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.player-item{display:flex;align-items:center;gap:10px;background:var(--panel);padding:12px 14px;border-radius:10px}.player-name{font-weight:600;flex:1}.dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.dot-on{background:var(--ok)}.dot-off{background:var(--muted)}.badge{font-size:.7rem;padding:3px 8px;border-radius:999px;background:var(--panel-2);color:var(--muted)}.badge-you{background:var(--primary);color:#fff}.rooms-active{margin-top:18px;border-top:1px solid var(--panel-2);padding-top:14px}.rooms-active .subtitle{margin-bottom:10px}.rooms-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.rooms-item{background:var(--panel);border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:4px}.rooms-item-head{display:flex;align-items:center;justify-content:space-between}.rooms-item-players{font-size:.9rem;color:var(--muted)}.rooms-item-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:2px}.admin-toggle{margin-top:12px;width:100%}.admin-login{margin-top:12px;display:flex;flex-direction:column;gap:8px}.admin-login-btns{display:flex;gap:8px}.admin-login-btns .btn{flex:1}.admin-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.admin-room{background:var(--panel);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:8px}.admin-room-head{display:flex;align-items:center;justify-content:space-between}.room-code-sm{font-size:1.4rem;font-weight:800;letter-spacing:.15em}.admin-room-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:.85rem}.admin-room-players{font-size:.9rem}.tag{font-size:.75rem;padding:3px 10px;border-radius:999px;font-weight:600}.tag-waiting{background:#3a4a2e;color:#b5e89a}.tag-playing{background:#2e3a4a;color:#9ac6e8}.tag-finished{background:#4a2e3a;color:#e89ab5}.card{position:relative;display:flex;align-items:center;justify-content:center;text-align:center;aspect-ratio:3 / 4;border-radius:8px;color:#fff;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.5);padding:4px;overflow:hidden;-webkit-user-select:none;user-select:none}.card-sm{width:56px}.card-md{width:84px}.card-lg{width:110px}.card-name{font-size:.72rem;line-height:1.1}.card-img{width:100%;height:100%;object-fit:cover}.card-selectable{cursor:pointer;box-shadow:0 0 0 2px transparent}.card-selectable:active{transform:scale(.97)}.card-selected{box-shadow:0 0 0 3px var(--primary)}.board{max-width:640px;padding:0 8px 8px;height:100dvh;overflow:hidden}.board-top{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:8px 4px;border-bottom:1px solid var(--panel-2)}.turn-indicator{font-weight:700}.your-turn{color:var(--ok)}.board-counts{display:flex;align-items:center;gap:12px;font-size:.9rem}.opponents-scroll{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;justify-content:flex-end;gap:8px;padding:8px 0}.my-zone-fixed{flex-shrink:0;padding-top:4px}.player-zone{position:relative;background:#252b3a8c;border-radius:10px;padding:4px 6px;border:2px solid transparent;display:flex;align-items:stretch;gap:6px;overflow:hidden}.zone-discard{position:absolute;top:0;right:0;bottom:0;width:70%;display:flex;align-items:center;justify-content:center;color:#fff;font-family:Avengeance,system-ui,sans-serif;font-size:clamp(1.6rem,7vw,3rem);letter-spacing:.04em;text-transform:uppercase;text-shadow:0 2px 8px rgba(0,0,0,.7);z-index:6;pointer-events:none;animation:zone-discard-in .25s ease}@keyframes zone-discard-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.zone-count{flex-shrink:0;align-self:stretch;display:flex;align-items:center;justify-content:flex-end;min-width:34px;padding-right:28px;font-family:Avengeance,system-ui,sans-serif;font-size:6rem;font-weight:800;line-height:.82;color:#ffffff1a;transform:translateY(10px)}.zone-side{flex-shrink:0;width:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px}.zone-name-vert{writing-mode:vertical-rl;transform:rotate(180deg);font-weight:700;font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-height:88px}.zone-meta-v{display:flex;flex-direction:column;align-items:center;font-size:.6rem;color:var(--muted);line-height:1.15}.zone-meta-v .prepared-win{color:var(--ok);font-weight:700}.zone-current{background:#43306b}.zone-selectable{border-color:var(--primary);cursor:pointer}.zone-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.zone-name{font-weight:700;display:flex;align-items:center;gap:6px}.zone-meta{display:flex;gap:10px;font-size:.8rem;align-items:center}.prepared{background:var(--panel-2);padding:2px 8px;border-radius:999px}.prepared-win{background:var(--ok);color:#fff}.zone-heroes{flex:1;min-width:0;display:flex;flex-wrap:nowrap;align-items:flex-end;gap:5px;min-height:20px}.zone-heroes>.hero-slot{flex:1 1 0;min-width:0;max-width:96px}.hero-slot{position:relative;display:flex}.hero-pips{position:absolute;top:4px;right:4px;z-index:2;display:flex;gap:2px}.hero-flash{position:fixed;z-index:120;color:#fff;font-family:Avengeance,system-ui,sans-serif;font-weight:800;font-size:2.8rem;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap;text-shadow:0 2px 10px rgba(0,0,0,.85);pointer-events:none;animation:hero-flash 1.3s ease forwards}.hero-dying{position:fixed;z-index:110;pointer-events:none;transform-origin:center;animation:hero-die .5s ease forwards}@keyframes hero-die{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.08)}}.hand-card.dealt{animation:deal-in .38s ease}@keyframes deal-in{0%{opacity:0;transform:translate(-34px) scale(.82)}to{opacity:1;transform:none}}@keyframes hero-flash{0%{opacity:0;transform:translate(-50%,-50%) scale(.6)}20%{opacity:1;transform:translate(-50%,-50%) scale(1)}60%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}to{opacity:0;transform:translate(-50%,-50%) scale(1.45)}}.pip{width:11px;height:11px;border-radius:3px;text-align:center;color:#fff;border:1.5px solid #fff;box-shadow:0 0 0 1px #0000004d}.pip-red{background:#c0392b}.pip-yellow{background:#caa12a}.pip-green{background:#27893f}.pip-blue{background:#2c6fb3}.pip-gray{background:#7f8c8d}.pip-villain{background:#111}.pip-ally{background:#d4af37;color:#111}.hand-row{display:flex;align-items:flex-end;gap:8px;border-top:1px solid var(--panel-2)}.hand{flex:1;min-width:0;display:flex;gap:8px;overflow-x:auto;padding:10px 4px calc(10px + env(safe-area-inset-bottom));min-height:130px;align-items:flex-end;justify-content:center}.hand-card{flex:1 1 0;min-width:0;max-width:96px}.deck-pile{flex-shrink:0;padding:10px 6px calc(10px + env(safe-area-inset-bottom)) 2px;align-self:flex-end}.deck{position:relative;width:96px;height:96px}.deck:before,.deck:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:10px;background:#6e1f1f;border:1px solid rgba(255,255,255,.25)}.deck:before{transform:translate(5px,5px)}.deck:after{transform:translate(2.5px,2.5px)}.deck-card{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;border-radius:10px;background:repeating-linear-gradient(135deg,#b02525 0,#b02525 10px,#9c1f1f 10px,#9c1f1f 20px);border:2px solid rgba(255,255,255,.6);box-shadow:0 1px 4px #00000073;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:#fff}.deck-mark{font-size:1.6rem;line-height:1;text-shadow:0 1px 2px rgba(0,0,0,.5)}.deck-label{font-size:.6rem;font-weight:800;letter-spacing:.15em;opacity:.9}.deck-count{font-size:1.1rem;font-weight:800;background:#00000059;border-radius:999px;padding:0 8px}.deck--discard:before,.deck--discard:after{background:#4b4f57}.deck--discard .deck-card{background:repeating-linear-gradient(135deg,#7f8590 0,#7f8590 10px,#6b7079 10px,#6b7079 20px)}.deck--drop .deck-card{outline:3px solid var(--primary);outline-offset:1px}.deck-staged{position:absolute;top:4px;right:4px;background:var(--primary);color:#fff;font-size:.85rem;font-weight:800;padding:0 7px;border-radius:999px}.turn-line{font-family:Avengeance,system-ui,sans-serif;letter-spacing:.04em;text-align:center;line-height:1;padding:6px 0 2px;text-shadow:0 2px 6px rgba(0,0,0,.5);animation:turn-line-in .45s ease}@keyframes turn-line-in{0%{opacity:0;transform:translateY(-8px) scale(.94)}to{opacity:1;transform:none}}.turn-line.mine{color:#9b7ce8;font-size:4.4rem}.turn-line.other{color:#ffffff8c;font-size:1.8rem}.turn-line{display:flex;align-items:baseline;justify-content:center;gap:.7rem}.turn-timer{font-family:Avengeance,system-ui,sans-serif;font-size:1.4rem;color:#ffffffb3;letter-spacing:.05em;padding:.05rem .5rem;border:1px solid rgba(255,255,255,.25);border-radius:999px;background:#00000040}.turn-timer.urgent{color:#ff6b6b;border-color:#ff6b6b8c;background:#780c0c59;animation:turn-timer-pulse .6s ease-in-out infinite alternate}@keyframes turn-timer-pulse{0%{transform:scale(1)}to{transform:scale(1.08)}}.card-tip{position:fixed;z-index:300;max-width:220px;background:#14161f;color:#fff;border:1px solid var(--panel-2);border-radius:8px;padding:8px 10px;font-size:.72rem;line-height:1.3;box-shadow:0 8px 18px #0000008c;pointer-events:none}.drag-ghost{position:fixed;width:86px;transform:translate(-50%,-62%);pointer-events:none;z-index:200;opacity:.95;filter:drop-shadow(0 8px 12px rgba(0,0,0,.55))}.play-fx{position:fixed;transform:translate(-50%,-50%);z-index:130;pointer-events:none}.play-fx-card{display:block;width:100%;animation:play-fx-card .95s cubic-bezier(.2,.7,.3,1) forwards;filter:drop-shadow(0 6px 14px rgba(0,0,0,.5))}@keyframes play-fx-card{0%{opacity:0;transform:scale(2.1) translateY(-26px) rotate(-6deg)}22%{opacity:1;transform:scale(1.55) translateY(0) rotate(0)}68%{opacity:1;transform:scale(1.5)}to{opacity:0;transform:scale(1.35)}}.play-fx-burst{position:absolute;left:50%;top:50%;width:78%;height:78%;transform:translate(-50%,-50%);border-radius:16px;opacity:0;animation:play-fx-burst .95s ease forwards}@keyframes play-fx-burst{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}30%{opacity:.95}to{opacity:0;transform:translate(-50%,-50%) scale(2.2)}}.play-fx--hero .play-fx-burst{box-shadow:0 0 30px 14px #3c96e6e6}.play-fx--villain .play-fx-burst{box-shadow:0 0 30px 14px #e14b4ae6}.play-fx--power .play-fx-burst{box-shadow:0 0 30px 14px #4fae4fd9}.play-fx--ally .play-fx-burst{box-shadow:0 0 30px 14px #d4af37e6}.play-fx--action .play-fx-burst{box-shadow:0 0 30px 14px #9663dde6}.snap-fx{position:fixed;top:0;right:0;bottom:0;left:0;z-index:140;display:flex;align-items:center;justify-content:center;pointer-events:none;animation:snap-fx-bg 1.5s ease forwards}@keyframes snap-fx-bg{0%{background:radial-gradient(circle,#6c3aa600,#0000)}22%{background:radial-gradient(circle,#6c3aa699,#0000008c 75%)}to{background:radial-gradient(circle,#6c3aa600,#0000)}}.snap-fx-card{width:min(76vw,60vh);animation:snap-fx-card 1.5s cubic-bezier(.18,.7,.28,1) forwards;filter:drop-shadow(0 0 50px rgba(150,99,221,.95))}@keyframes snap-fx-card{0%{opacity:0;transform:scale(.25) rotate(-14deg)}20%{opacity:1;transform:scale(1.12) rotate(0)}34%{transform:scale(.98)}42%{transform:scale(1.05)}to{opacity:0;transform:scale(1.18)}}.action-bar{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--panel);border-radius:10px;padding:8px 12px;margin:4px 0;min-height:44px;font-size:.85rem}.action-bar-btns{display:flex;gap:8px;flex-shrink:0}.action-bar .btn{padding-top:3px;padding-bottom:3px;font-size:.8rem}.board-error{margin:2px 4px}.small{font-size:.75rem}.banner{position:fixed;left:50%;bottom:150px;transform:translate(-50%);background:var(--panel-2);border:1px solid var(--primary);border-radius:10px;padding:10px 14px;display:flex;gap:10px;align-items:center;font-size:.85rem;max-width:92vw;z-index:40}.game-log{background:var(--panel);border-radius:8px;margin:2px 0}.log-toggle{width:100%;background:none;border:none;color:var(--text);display:flex;justify-content:space-between;gap:8px;padding:8px 12px;font-size:.8rem;cursor:pointer;align-items:center}.log-last{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.log-list{list-style:none;margin:0;padding:4px 12px 10px;max-height:140px;overflow-y:auto;font-size:.78rem;color:var(--muted);display:flex;flex-direction:column;gap:3px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;padding:16px;z-index:50}.modal{background:var(--panel);border-radius:14px;padding:20px;width:100%;max-width:380px;max-height:88vh;overflow-y:auto;text-align:center}.modal h3,.modal h2{margin:0 0 8px}.modal-btns{display:flex;flex-direction:column;gap:8px;margin-top:12px}.modal-heroes,.spy-hand{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:8px 0}.counter-card{width:120px;margin:12px auto}.howto-link{margin-top:14px;width:100%}.howto{text-align:left;max-width:460px}.howto h2{text-align:center}.howto h3{margin:16px 0 4px;font-size:1rem;color:var(--primary)}.howto p{margin:0 0 6px;font-size:.9rem;line-height:1.45}.howto-goal{background:var(--panel-2);padding:10px 12px;border-radius:8px;text-align:center}.howto-list{margin:0;padding-left:18px;font-size:.9rem;line-height:1.45;display:flex;flex-direction:column;gap:7px}.howto-list ul{margin:5px 0 0;padding-left:16px;display:flex;flex-direction:column;gap:4px}.howto .modal-btns{position:sticky;bottom:-20px;background:var(--panel);padding-top:10px}.end-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:24px;background:#08061066}.end-content{text-align:center;width:100%;max-width:340px}.end-sub{font-family:Avengeance,system-ui,sans-serif;color:#fff9;font-size:1.4rem;letter-spacing:.12em;margin:0 0 4px}.end-title{font-family:Avengeance,system-ui,sans-serif;font-size:3.2rem;line-height:1;color:#fff;text-shadow:0 4px 16px rgba(0,0,0,.65);margin:0 0 20px}.end-title.win{color:#b49bf0}.end-overlay .btn-ghost{background:#b49bf0;color:#1b1f2a;border-color:#b49bf0}.series-score{display:flex;align-items:center;justify-content:center;gap:14px;margin:4px 0 18px}.series-player{display:inline-flex;flex-direction:column;align-items:center;gap:2px;min-width:84px}.series-name{font-size:.9rem;color:#ffffffb3;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.series-player.me .series-name{color:#b49bf0;font-weight:700}.series-wins{font-family:Avengeance,system-ui,sans-serif;font-size:2.4rem;line-height:1;color:#fff}.series-player.me .series-wins{color:#b49bf0}.series-sep{font-size:1.6rem;color:#fff6}.end-series-result{font-family:Avengeance,system-ui,sans-serif;font-size:1.4rem;margin:0 0 6px;color:#fff}.end-series-result.win{color:#b49bf0}.end-returning{display:flex;flex-direction:column;align-items:center;gap:8px}.end-countdown{font-family:Avengeance,system-ui,sans-serif;color:#b49bf0;font-size:1.2em}@media (min-width: 768px){body{font-size:17px}.screen{max-width:720px;padding-left:24px;padding-right:24px}.card-panel{max-width:420px;padding:32px}.title{font-size:2rem}.room-code{font-size:3.2rem}.admin-list{display:grid;grid-template-columns:repeat(2,1fr);align-items:start}.modal{max-width:480px}.board{max-width:880px}.zone-heroes>.hero-slot{max-width:116px}.hand{min-height:152px}.hand-card{max-width:116px}.deck{width:116px;height:116px}.zone-count{font-size:7rem}}@media (min-width: 1200px){.screen{max-width:820px}.admin-list{grid-template-columns:repeat(3,1fr)}.modal{max-width:560px}.board{max-width:1180px;padding:0 24px 12px}.zone-heroes>.hero-slot{max-width:132px}.hand{min-height:172px}.hand-card{max-width:132px}.deck{width:132px;height:132px}.zone-count{font-size:8rem}.turn-line.mine{font-size:5.2rem}}@media (max-width: 767px){.board>.game-log{display:none}.board-top{border-bottom:none;padding:0;min-height:0}.board-counts{display:none}.board-leave{position:fixed;top:calc(env(safe-area-inset-top) + 6px);right:8px;z-index:30;background:#252b3ad9;border:1px solid var(--panel-2);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.deck{width:60px;height:60px}.deck-pile{padding-left:0;padding-right:2px}.deck-label{font-size:.5rem}.deck-count{font-size:.85rem;padding:0 6px}}@media (min-width: 768px) and (max-height: 620px){.hand{min-height:120px}.hand-card,.zone-heroes>.hero-slot{max-width:96px}.deck{width:96px;height:96px}}
