:root{--bg: #0e1117;--bg-elev: #1a1f2b;--bg-elev-2: #232a39;--border: #2c3344;--text: #e6e9ef;--text-dim: #8a93a6;--primary: #4f8cff;--primary-hi: #6ea1ff;--success: #2bd47d;--success-hi: #44e591;--warning: #ffb84d;--danger: #ff5e6c;--paused: #b08cff;--shadow: 0 8px 24px rgba(0, 0, 0, .35);--radius: 14px;--gap: .75rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,system-ui,sans-serif;color-scheme:dark}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent}button,input,select{font:inherit;color:inherit}.page{min-height:100dvh;padding:calc(1.25rem + env(safe-area-inset-top)) calc(1.25rem + env(safe-area-inset-right)) calc(1.25rem + env(safe-area-inset-bottom)) calc(1.25rem + env(safe-area-inset-left));display:flex;flex-direction:column;gap:1.25rem;max-width:28rem;margin:0 auto}.page--centered{justify-content:center;align-items:stretch;text-align:center}.page--lobby h2,.page--gameover h2,.page--home h1{margin:0}.muted{color:var(--text-dim)}.error{background:#ff5e6c26;border:1px solid var(--danger);color:var(--danger);padding:.6rem .8rem;border-radius:10px;font-size:.9rem}.home-header h1{margin:0;font-size:1.7rem;letter-spacing:.02em}.home-subtitle{margin:.25rem 0 0;color:var(--text-dim)}.home-warning{margin-top:.5rem;color:var(--warning);font-size:.85rem}.mode-tabs{display:grid;grid-template-columns:1fr 1fr;background:var(--bg-elev);border-radius:var(--radius);padding:4px;gap:4px}.mode-tab{background:transparent;border:0;padding:.75rem;border-radius:10px;font-weight:600;cursor:pointer;color:var(--text-dim)}.mode-tab--active{background:var(--bg-elev-2);color:var(--text)}.form{display:flex;flex-direction:column;gap:1rem}.field{display:flex;flex-direction:column;gap:.4rem}.field>span{font-size:.8rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em}.field input,.field select{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:.85rem .9rem;font-size:1rem;min-height:48px}.field input:focus,.field select:focus{outline:2px solid var(--primary);outline-offset:0;border-color:var(--primary)}.hint{color:var(--text-dim);font-size:.8rem}.segmented{display:grid;grid-template-columns:1fr 1fr;background:var(--bg-elev);border-radius:10px;padding:4px;gap:4px}.segmented__btn{background:transparent;border:0;padding:.65rem;border-radius:8px;color:var(--text-dim);cursor:pointer;font-weight:600;min-height:44px}.segmented__btn--on{background:var(--bg-elev-2);color:var(--text)}.btn{border:0;cursor:pointer;border-radius:12px;padding:.85rem 1.2rem;font-weight:600;min-height:48px;background:var(--bg-elev);color:var(--text);transition:transform .05s ease,background .2s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.btn:active{transform:scale(.98)}.btn[disabled]{opacity:.55;cursor:not-allowed}.btn--primary{background:var(--primary);color:#fff}.btn--primary:hover{background:var(--primary-hi)}.btn--ghost{background:transparent;border:1px solid var(--border)}.btn--danger{background:var(--danger);color:#fff}.btn--lg{font-size:1.05rem;padding:1rem 1.4rem}.lobby-header h2{font-size:1.4rem;letter-spacing:.04em}.join-share{display:flex;gap:.5rem}.join-share>.btn{flex:1 1 0;min-width:0}.qr-dialog{border:1px solid var(--border);border-radius:16px;background:var(--bg-elev);color:var(--text);padding:0;max-width:92vw}.qr-dialog::backdrop{background:#0009}.qr-dialog__body{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1.5rem}.qr-dialog__body h3{margin:0}.qr-dialog__body svg{background:#fff;padding:.75rem;border-radius:12px}.qr-dialog__code{margin:0;letter-spacing:.08em}.qr-scan-dialog{width:min(92vw,420px)}.scan-row{display:flex;gap:.5rem;align-items:stretch}.scan-row input{flex:1 1 auto;min-width:0}.scan-row .btn{flex:0 0 auto}.qr-scan__frame{position:relative;width:100%;aspect-ratio:1 / 1}.qr-scan__video{width:100%;height:100%;object-fit:cover;border-radius:12px;background:#000}.qr-scan__reticle{position:absolute;inset:15%;border:3px solid rgba(255,255,255,.85);border-radius:12px;pointer-events:none}.player-list{list-style:none;margin:.5rem 0 0;padding:0;display:flex;flex-direction:column;gap:.5rem}.pregame-row{display:grid;grid-template-columns:2.5rem 1fr auto;align-items:center;background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;padding:.75rem .9rem;gap:.5rem}.pregame-row--me{border-color:var(--primary)}.pregame-row--empty{opacity:.6;border-style:dashed}.pregame-row__slot{font-variant-numeric:tabular-nums;color:var(--text-dim);font-weight:600}.pregame-row__name{font-weight:600}.pregame-row__badges{display:flex;gap:.4rem}.pregame-actions{display:flex;flex-direction:column;gap:.5rem}.badge{font-size:.7rem;font-weight:700;letter-spacing:.06em;padding:.15rem .45rem;border-radius:999px;background:var(--bg-elev-2);color:var(--text-dim)}.badge--host{background:#4f8cff2e;color:var(--primary-hi)}.badge--me{background:#2bd47d2e;color:var(--success-hi)}.badge--out{background:#ff5e6c33;color:var(--danger)}.badge--paused{background:#b08cff2e;color:var(--paused)}.badge--ready{background:#2bd47d2e;color:var(--success-hi)}.pregame-row--draggable{cursor:grab}.pregame-row--draggable:active{cursor:grabbing}.pregame-row--drag-over{border-color:var(--primary);background:var(--bg-elev-2)}.pregame-row__handle{color:var(--text-dim);font-size:1.1rem;-webkit-user-select:none;user-select:none}.ready-actions{display:flex;gap:.5rem;margin-bottom:.5rem}.game{height:100dvh;display:grid;grid-template-rows:1fr auto;gap:0}.game__top{padding:.9rem 1rem .5rem;display:flex;flex-direction:column;gap:.6rem;overflow-y:auto;min-height:0}.game__header{display:flex;align-items:center;justify-content:space-between}.game__code{font-size:.85rem;letter-spacing:.1em;color:var(--text-dim)}.player-grid{display:flex;flex-direction:column;gap:.5rem}.player-card{background:var(--player-strips, var(--bg-elev));border:1px solid var(--border);border-radius:12px;padding:.45rem .7rem;display:flex;flex-direction:column;gap:.1rem}.player-card--me{border-color:var(--primary)}.player-card--active{border-color:var(--success);box-shadow:0 0 0 2px var(--success)}.player-card--eliminated{opacity:.55}.player-card__row1{display:flex;align-items:center;gap:.5rem}.player-card__row1 .player-card__name{font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:.05rem .45rem;border-radius:999px;background:#0e11178c}.player-card__row1 .player-card__badges{display:flex;gap:.3rem;flex:0 0 auto}.player-card__row1 .player-card__time{margin-left:auto;font-size:1.1rem;padding:.05rem .45rem;border-radius:999px;background:#0e11178c}.player-card__row2{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.player-card__life{font-weight:600;font-variant-numeric:tabular-nums;flex:0 0 auto;padding:.05rem .5rem;border-radius:999px;background:#0e11178c}.player-card__pills{display:flex;gap:.3rem;flex-wrap:wrap;flex:1 1 auto;min-width:0}.player-card__active-dot{width:.6rem;height:.6rem;border-radius:50%;background:var(--success);box-shadow:0 0 8px var(--success);animation:dot-pulse 1.2s ease-in-out infinite;flex:0 0 auto}@keyframes dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.85)}}.time-display{font-variant-numeric:tabular-nums;font-weight:700;font-size:1.3rem;letter-spacing:.02em}.time-display--warning{color:var(--danger)}.game__bottom{padding:.5rem;background:var(--bg-elev);border-top:1px solid var(--border)}.my-controls{display:flex;flex-direction:column;gap:.5rem;border-radius:14px;padding:.5rem;transition:background .25s ease,box-shadow .25s ease}.my-controls--your-turn{background:#2bd47d1f;box-shadow:inset 0 0 0 2px var(--success),0 0 28px #2bd47d40;animation:my-pulse 1.6s ease-in-out infinite}.my-controls--paused{background:#b08cff14;box-shadow:inset 0 0 0 1px var(--paused)}@keyframes my-pulse{0%,to{box-shadow:inset 0 0 0 2px var(--success),0 0 24px #2bd47d33}50%{box-shadow:inset 0 0 0 2px var(--success-hi),0 0 36px #2bd47d73}}.my-controls__header{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.my-controls__time{font-size:2rem;margin-right:auto}.icon-row{display:flex;gap:.4rem;align-items:center}.icon-btn{background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text);width:2.6rem;height:2.6rem;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:background .1s ease,transform .06s ease}.icon-btn:active{transform:scale(.94)}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.icon-btn--danger{color:var(--danger)}.icon-btn--primary{background:var(--primary);border-color:var(--primary);color:#fff}.icon-btn--confirm{background:var(--danger);border-color:var(--danger);color:#fff}.big-pass-btn{border:0;width:100%;min-height:4.5rem;border-radius:16px;background:var(--bg-elev-2);color:var(--text-dim);font-size:1.3rem;font-weight:800;letter-spacing:.08em;cursor:pointer;transition:transform .06s ease,background .2s ease}.big-pass-btn[disabled]{cursor:not-allowed}.big-pass-btn--ready{background:var(--success);color:#04150a}.big-pass-btn--ready:active{transform:scale(.985)}.big-pass-btn--paused{background:var(--paused);color:#fff}.winner-line{font-size:1.2rem}.results-list{list-style:none;padding:0;margin:1rem 0;display:flex;flex-direction:column;gap:.4rem}.results-row{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:.7rem .85rem;display:flex;align-items:center;gap:.5rem}.results-row--me{border-color:var(--primary)}.results-row__name{font-weight:600;flex:1}.results-row__time{font-variant-numeric:tabular-nums;color:var(--text-dim)}.stepper{position:relative;display:grid;grid-template-columns:1fr 1fr;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.stepper__half{background:transparent;border:0;color:var(--text-dim);cursor:pointer;display:flex;align-items:center;padding:0 .9rem;transition:background .1s ease}.stepper__half--down{justify-content:flex-start}.stepper__half--up{justify-content:flex-end}.stepper__half:active:not(:disabled){background:#ffffff12}.stepper__half:disabled{cursor:default;color:var(--border)}.stepper__glyph{font-size:1.4rem;line-height:1}.stepper__value{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:.4rem;font-variant-numeric:tabular-nums;pointer-events:none}.stepper--life{min-height:3.5rem;border-radius:var(--radius)}.life-heart{color:var(--danger);font-size:1.2rem}.life-heart--warning{color:var(--warning)}.life-num{font-size:2rem;font-weight:700}.life-num--warning{color:var(--warning)}.stepper--cmd{min-height:2.1rem;border-radius:8px}.stepper--cmd .stepper__half{padding:0 .5rem;touch-action:manipulation;user-select:none;-webkit-user-select:none}.stepper--cmd .stepper__glyph{font-size:1rem}.cmd-num{font-size:1.05rem;font-weight:600}.cmd-num--warning{color:var(--danger)}.cmd-damage-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(7.5rem,1fr));gap:.4rem}.cmd-damage-cell{background:var(--source-strips, var(--bg-elev-2));border:1px solid var(--border);border-radius:10px;padding:.3rem;display:flex;flex-direction:column;gap:.2rem}.cmd-damage-cell--warning{border-color:var(--danger);box-shadow:0 0 0 2px var(--danger)}.cmd-damage-cell__name{font-size:.75rem;color:var(--text);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;align-self:center;max-width:100%;padding:1px 8px;border-radius:999px;background:#0e111799}.player-card__life{display:inline-flex;align-items:center;gap:.25rem;color:var(--text)}.player-card__life--warning{color:var(--warning)}.player-card__cmd-chip{display:inline-flex;align-items:center;font-size:.75rem;padding:2px 6px;border-radius:999px;background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text-dim);font-variant-numeric:tabular-nums}.player-card__cmd-chip--warning{background:#ff5e6c26;border-color:var(--danger);color:var(--danger)}.badge--cmd-count{background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text-dim)}.life-stepper-wrap{position:relative}.stepper--life .stepper__half{touch-action:manipulation;user-select:none;-webkit-user-select:none}.life-num--tappable{display:inline-flex;align-items:center;gap:.25rem;background:transparent;border:0;color:inherit;font:inherit;font-size:2rem;font-weight:700;padding:.1rem .5rem;border-radius:10px;cursor:pointer;pointer-events:auto;touch-action:manipulation;-webkit-user-select:none;user-select:none}.life-num--tappable .life-heart{font-size:1.2rem}.life-num--tappable:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.life-num--tappable:active{background:#ffffff14}.life-stepper__badge{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:.25rem;font-size:.85rem;font-weight:700;font-variant-numeric:tabular-nums;padding:.1rem .55rem;border-radius:999px;background:#000000a6;border:1px solid var(--border);pointer-events:none;white-space:nowrap;opacity:1;transition:opacity .35s ease-out;z-index:2}.life-stepper__badge[data-visible=false]{opacity:0}.life-stepper__badge--down{color:var(--danger)}.life-stepper__badge--up{color:var(--success)}.life-calc-dialog{border:2px solid var(--border);border-radius:16px;background:var(--bg-elev);color:var(--text);padding:0;width:min(92vw,360px);transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}.life-calc-dialog::backdrop{background:#0009}.life-calc-dialog[data-sign=sub]{border-color:var(--danger);background:linear-gradient(180deg,rgba(255,94,108,.18),var(--bg-elev) 65%);box-shadow:0 0 0 1px #ff5e6c59,0 12px 32px #ff5e6c2e}.life-calc-dialog[data-sign=add]{border-color:var(--success);background:linear-gradient(180deg,rgba(43,212,125,.18),var(--bg-elev) 65%);box-shadow:0 0 0 1px #2bd47d59,0 12px 32px #2bd47d2e}.life-calc__body{display:flex;flex-direction:column;gap:1rem;padding:1.25rem}.life-calc__display{display:grid;grid-template-columns:auto auto 1fr auto auto;align-items:baseline;column-gap:.5rem;font-variant-numeric:tabular-nums;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:12px;padding:.65rem .9rem}.life-calc__current{color:var(--text-dim);font-size:1.1rem}.life-calc__op{font-size:1.4rem;font-weight:700;transition:color .16s ease}.life-calc-dialog[data-sign=sub] .life-calc__op,.life-calc-dialog[data-sign=sub] .life-calc__preview{color:var(--danger)}.life-calc-dialog[data-sign=add] .life-calc__op,.life-calc-dialog[data-sign=add] .life-calc__preview{color:var(--success)}.life-calc__amount{font-size:1.6rem;font-weight:700;text-align:right}.life-calc__eq{color:var(--text-dim)}.life-calc__preview{font-size:1.4rem;font-weight:700;transition:color .16s ease}.life-calc__keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.life-calc__key{background:var(--bg-elev-2);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:.85rem 0;font-size:1.25rem;font-weight:600;cursor:pointer;touch-action:manipulation;-webkit-user-select:none;user-select:none}.life-calc__key:active{background:#ffffff12}.life-calc__key--toggle[data-sign="-1"]{color:var(--danger)}.life-calc__key--toggle[data-sign="1"]{color:var(--success)}.life-calc__submit{background:var(--primary);color:#fff;border:0;border-radius:10px;padding:.9rem 0;font-size:1.05rem;font-weight:700;cursor:pointer;font-variant-numeric:tabular-nums;transition:background .16s ease}.life-calc-dialog[data-sign=sub] .life-calc__submit{background:var(--danger)}.life-calc-dialog[data-sign=add] .life-calc__submit{background:var(--success);color:#0c1018}.life-calc__submit:disabled{opacity:.4;cursor:default}.icon-btn--swatch{position:relative;overflow:hidden;padding:0}.icon-btn--swatch:before{content:"";position:absolute;inset:0;background:var(--player-strips, var(--border));opacity:.85;z-index:0}.icon-btn--swatch>svg{position:relative;z-index:1;filter:drop-shadow(0 0 2px rgba(0,0,0,.6));color:#fff}.color-picker-dialog{background:var(--bg-elev);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:0;box-shadow:var(--shadow);max-width:22rem;width:90vw}.color-picker-dialog::backdrop{background:#0000008c}.color-picker__body{display:flex;flex-direction:column;gap:.75rem;padding:.9rem}.color-picker__preview{height:2.2rem;border-radius:8px;border:1px solid var(--border)}.color-picker__swatches{display:grid;grid-template-columns:repeat(6,1fr);gap:.4rem}.color-picker__swatch{position:relative;aspect-ratio:1 / 1;border:2px solid var(--border);border-radius:10px;cursor:pointer;padding:0;transition:transform .06s ease,border-color .1s ease}.color-picker__swatch:hover{transform:translateY(-1px)}.color-picker__swatch--selected{border-color:var(--text);box-shadow:0 0 0 2px #ffffff26}.color-picker__order{position:absolute;top:2px;right:2px;background:#000000a6;color:#fff;font-size:.7rem;font-weight:700;line-height:1;width:1.1rem;height:1.1rem;display:flex;align-items:center;justify-content:center;border-radius:50%}.color-picker__submit{appearance:none;border:none;background:var(--primary);color:#fff;font-size:1rem;font-weight:600;padding:.7rem;border-radius:10px;cursor:pointer}.color-picker__submit:disabled{opacity:.4;cursor:default}
