:root{--bg: #241c17;--bg2: #2f2620;--bg3: #3d2f26;--fg: #f7efe2;--fg2: #c9b8a3;--p1: #d2603a;--p2: #3e8fa3;--p1-light: rgba(210, 96, 58, .25);--p2-light: rgba(62, 143, 163, .25);--accent: #f2c14e;--green: #6aa84f;--on-accent: #2e1f12;--font-display: "Baloo 2", ui-rounded, "Hiragino Maru Gothic ProN", system-ui, sans-serif;--shadow-soft: 0 6px 18px rgba(30, 18, 10, .35);--stat-hp: #e74c3c;--stat-damage: #f4d35e;--stat-range: #5dade2;--stat-heal: #ffffff;--stat-move: #2ecc71;--green-light: rgba(39, 174, 96, .35);--red-light: rgba(231, 76, 60, .45);--cell: 8vmin;--radius: 12px;--border: 1px solid rgba(247 239 226 / .1);--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;color:var(--fg);font-family:system-ui,-apple-system,sans-serif;-webkit-tap-highlight-color:transparent;overscroll-behavior:none;overflow:hidden}body{background-color:var(--bg);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='w'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.6' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23w)' opacity='0.06'/%3E%3C/svg%3E"),repeating-linear-gradient(0deg,transparent 0,transparent 126px,rgba(0,0,0,.34) 127px,rgba(255,231,194,.05) 128px,rgba(0,0,0,.16) 129px,transparent 131px),repeating-linear-gradient(0deg,#ffe7c206 0,#ffe7c206 128px,#120b070f 128px,#120b070f 256px),radial-gradient(120% 110% at 50% 38%,#0000 50%,#0006),radial-gradient(135% 100% at 50% -5%,#3a2c20 0%,#28201a 38%,var(--bg) 70%,#140f0a 100%);background-size:180px 180px,auto,auto,auto,auto;background-attachment:fixed}h1,h2,h3,.menu-title,.overlay-title{font-family:var(--font-display);letter-spacing:.01em}button{min-height:44px;min-width:44px;cursor:pointer;font:inherit;border:none;border-radius:var(--radius);transition:opacity .15s,transform .1s}button:active:not(:disabled){transform:scale(.96)}button:disabled{opacity:.4;cursor:default}.menu-btn,.overlay-panel,.draft-confirm-btn,.mm-header-btn--primary{box-shadow:var(--shadow-soft)}img{display:block;max-width:100%}#root{display:flex;flex-direction:column;padding-top:var(--safe-top);padding-bottom:var(--safe-bottom);padding-left:var(--safe-left);padding-right:var(--safe-right)}.screen-menu{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;padding:24px;position:relative}.menu-corner-actions{position:absolute;right:16px;bottom:16px;display:flex;flex-direction:column;gap:8px;align-items:stretch;z-index:2}.menu-corner-btn{padding:10px 14px;font-size:.85rem;font-weight:600;background:var(--bg2);color:var(--fg);border:var(--border);border-radius:var(--radius);min-height:40px;white-space:nowrap;cursor:pointer}.menu-corner-btn--icon{width:44px;min-width:44px;height:44px;min-height:44px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:1.25rem;line-height:1}.menu-corner-btn:hover{background:var(--bg3)}.menu-hero{text-align:center}.menu-title{font-size:clamp(2.5rem,10vw,5rem);font-weight:900;letter-spacing:-.02em;color:var(--p1);text-shadow:0 2px 0 rgba(74,53,38,.15)}.menu-subtitle{color:var(--fg2);margin-top:4px;font-size:.95rem;letter-spacing:.08em;text-transform:uppercase}.menu-nav{display:flex;flex-direction:column;gap:12px;width:100%;max-width:320px}.menu-btn{padding:14px 24px;font-size:1.05rem;font-weight:600;background:var(--bg2);color:var(--fg);border:var(--border);border-radius:var(--radius);position:relative;text-align:left}.menu-btn--primary{background:var(--accent);color:var(--on-accent);border-color:transparent}.menu-btn--disabled,.menu-corner-btn--disabled{opacity:.5;cursor:not-allowed}.menu-btn--disabled:hover,.menu-corner-btn--disabled:hover{background:var(--bg2)}.menu-soon{float:right;font-size:.7rem;font-weight:400;color:var(--fg2);text-transform:uppercase;letter-spacing:.05em;padding-top:2px}.screen-draft{flex:1;display:flex;flex-direction:column;overflow:hidden}.draft-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg2);border-bottom:var(--border);flex-shrink:0}.draft-back-btn{background:transparent;color:var(--fg);font-size:1.3rem;min-width:44px;min-height:44px;border-radius:var(--radius)}.draft-player-label{font-size:1rem;font-weight:700;color:var(--accent);flex:1}.draft-phase-label{font-size:.8rem;color:var(--fg2)}.draft-picked-row{display:flex;gap:8px;padding:12px 16px;background:var(--bg2);border-bottom:var(--border);overflow-x:auto;flex-shrink:0;min-height:90px;align-items:center}.picked-slot{display:flex;flex-direction:column;align-items:center;gap:2px;position:relative;flex-shrink:0}.picked-slot__sprite{width:52px;height:52px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;background:transparent}.picked-slot__sprite--empty{background:#ffffff0d;border:2px dashed rgba(255 255 255 / .15);cursor:default}.picked-slot__img{width:100%;height:100%;object-fit:contain}.picked-slot__initial{font-size:1.4rem;font-weight:700;color:#ffffffe6}.picked-slot__outfit-badge{position:absolute;bottom:2px;right:2px;background:#0009;color:#f7efe2;font-size:.55rem;padding:1px 3px;border-radius:3px}.picked-slot__name{font-size:.6rem;color:var(--fg2);text-align:center;max-width:52px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.picked-slot__remove{position:absolute;top:-6px;right:-6px;width:18px;height:18px;min-width:18px;min-height:18px;background:var(--p1);color:#fff;font-size:.75rem;border-radius:50%;display:flex;align-items:center;justify-content:center;line-height:1}.draft-pool{padding:12px 16px;display:grid;grid-template-columns:repeat(auto-fit,minmax(88px,96px));justify-content:center;gap:8px;align-content:start}.char-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;border-radius:var(--radius);background:var(--bg2);border:var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;transition:border-color .15s,transform .1s;position:relative}.char-card:active{transform:scale(.95)}.char-card--picked{border-color:var(--accent);background:#f4d35e1a}.draft-pool--p1 .char-card--picked{border-color:var(--p1);background:var(--p1-light)}.draft-pool--p2 .char-card--picked{border-color:var(--p2);background:var(--p2-light)}.char-card__sprite{width:56px;height:56px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;position:relative;background:transparent}.char-card__img{width:100%;height:100%;object-fit:contain}.char-card__initial{font-size:1.6rem;font-weight:700;color:#ffffffe6}.char-card__name{font-size:.7rem;font-weight:600;color:var(--fg);text-align:center;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.char-card__badge{font-size:.55rem;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}.char-card__outfit{font-size:.55rem;color:var(--fg2)}.draft-footer{padding:12px 16px;background:var(--bg2);border-top:var(--border);display:flex;align-items:center;gap:12px;flex-shrink:0}.draft-hint{font-size:.7rem;color:var(--fg2);flex:1}.draft-confirm-btn{padding:12px 24px;background:var(--accent);color:var(--on-accent);font-weight:700;font-size:.95rem;flex-shrink:0}.draft-confirm-btn:disabled{background:var(--bg3);color:var(--fg2)}.team-panel__cpu-btn{padding:4px 10px;font-size:.72rem;font-weight:700;background:var(--bg2);color:var(--fg);border:var(--border);border-radius:var(--radius);min-height:28px;white-space:nowrap;cursor:pointer}.team-panel__cpu-btn[aria-pressed=true]{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.screen-draft--combined{overflow-y:auto}.draft-teams{display:flex;flex-direction:column;gap:8px;padding:8px 12px;background:var(--bg2);border-bottom:var(--border);flex-shrink:0}@media (min-width: 720px){.draft-teams{flex-direction:row}}.team-panel{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px;padding:8px;background:var(--bg3);border:2px solid transparent;border-radius:var(--radius);cursor:pointer}.team-panel--p1{border-left:3px solid var(--p1);background:var(--p1-light)}.team-panel--p2{border-left:3px solid var(--p2);background:var(--p2-light)}.team-panel--p1.team-panel--active{border-color:var(--p1);box-shadow:0 0 0 1px var(--p1);background:var(--p1-light)}.team-panel--p2.team-panel--active{border-color:var(--p2);box-shadow:0 0 0 1px var(--p2);background:var(--p2-light)}.team-panel__header{display:flex;justify-content:space-between;align-items:baseline;font-size:.85rem}.team-panel__title{font-weight:700;color:var(--fg)}.team-panel__status{font-size:.7rem;color:var(--fg2);text-transform:uppercase;letter-spacing:.05em}.team-panel__random-btn{margin-left:auto;padding:4px 10px;font-size:.72rem;font-weight:700;background:var(--bg2);color:var(--fg);border:var(--border);border-radius:var(--radius);min-height:28px;min-width:0;white-space:nowrap}.team-panel__random-btn:hover{background:var(--accent);color:var(--on-accent)}.team-panel__row{display:flex;gap:4px;align-items:center;overflow-x:auto;overflow-y:hidden;touch-action:pan-x;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;padding-bottom:4px}.team-panel__leader-label,.team-panel__roster-label{font-size:.65rem;color:var(--fg2);text-transform:uppercase;letter-spacing:.06em;flex-shrink:0;padding:0 4px}.draft-active-banner{padding:6px 12px;text-align:center;font-size:.8rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;background:var(--bg2)}.draft-active-banner[data-active="1"]{color:var(--p1)}.draft-active-banner[data-active="2"]{color:var(--p2)}.draft-pool-section{display:flex;flex-direction:column;gap:6px;padding:8px 12px}.draft-pool-section__title{font-size:.7rem;font-weight:700;color:var(--fg2);text-transform:uppercase;letter-spacing:.06em;padding:4px 0;text-align:center}.draft-pool--leaders{padding-bottom:4px}.screen-game{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.game-top-bar{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg2);border-bottom:var(--border);flex-shrink:0}.game-top-bar__options-btn{background:transparent;color:var(--fg2);font-size:1.2rem;min-width:36px;min-height:36px;flex-shrink:0;border-radius:var(--radius)}.game-top-bar__turn{flex:1;text-align:center;font-size:.95rem;font-weight:700}.game-top-bar__turn[data-player="1"]{color:var(--p1)}.game-top-bar__turn[data-player="2"]{color:var(--p2)}.game-top-bar__actions{display:flex;align-items:center;gap:3px;padding:4px 8px;background:#ffffff0a;border-radius:var(--radius);flex-shrink:0}.game-top-bar__actions-label{font-size:.7rem;color:var(--fg2);font-weight:600;letter-spacing:.04em}.game-top-bar__actions-count{font-size:1rem;font-weight:700;min-width:1ch;text-align:center}.game-top-bar__actions-count[data-player="1"]{color:var(--p1)}.game-top-bar__actions-count[data-player="2"]{color:var(--p2)}.game-top-bar__score{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#ffffff0a;border-radius:var(--radius);font-size:.85rem;font-weight:700;flex-shrink:0}.game-top-bar__score-side--p1{color:var(--p1)}.game-top-bar__score-side--p2{color:var(--p2)}.game-top-bar__score-divider{color:var(--fg2);font-weight:400;font-size:.75rem}.game-body{flex:1;display:grid;grid-template-areas:"board board" "info  controls";grid-template-columns:1fr 144px;grid-template-rows:1fr 32vh;overflow:hidden;min-height:0;--cell: min(calc((100vw - 16px) / 12), calc((68vh - 52px - 16px) / 12))}.game-board-area{grid-area:board;display:flex;align-items:center;justify-content:center;padding:4px;min-height:0;min-width:0;overflow:hidden}.game-board-area>*{max-width:100%;max-height:100%}.game-info-panel{grid-area:info;background:var(--bg2);border-top:var(--border);overflow:hidden;min-width:0;padding:6px}.game-controls-panel{grid-area:controls;background:var(--bg2);border-top:var(--border);display:flex;flex-direction:column;gap:6px;padding:6px;overflow-y:auto}@media (orientation: landscape) and (max-width: 899px){.game-body{grid-template-rows:1fr 18vh;--cell: min(calc((100vw - 16px) / 12), calc((82vh - 52px - 12px) / 12))}.game-info-panel{padding:4px}.unit-info-panel{padding:6px 8px;gap:4px;font-size:.78rem}.unit-info-panel__portrait{width:36px;height:36px}.unit-info-panel__name{font-size:.88rem}.unit-info-panel__owner{font-size:.7rem}.unit-info-panel__stats{padding:4px 6px;gap:6px}.unit-info-panel__stat{font-size:.72rem}.unit-info-panel__abilities{gap:3px}.unit-info-panel__abilities-header{font-size:.65rem;padding-bottom:2px}.unit-info-panel__ability{padding:4px 6px}.unit-info-panel__ability-name{font-size:.8rem}.unit-info-panel__ability-kind{font-size:.62rem}.unit-info-panel__ability-stats{margin-top:2px;font-size:.66rem}.unit-info-panel__ability-desc{font-size:.7rem;line-height:1.25}}@media (min-width: 900px){.game-body{grid-template-areas:"info board controls";grid-template-columns:280px 1fr 160px;grid-template-rows:1fr;--cell: min(calc((100vw - 280px - 160px - 32px) / 12), calc((100vh - 52px - 32px) / 12))}.game-info-panel{border-top:none;border-right:var(--border);padding:8px;overflow-y:auto}.game-controls-panel{border-top:none;border-left:var(--border);padding:8px}}.board-viewport{width:calc(var(--board-w, 12) * var(--cell));height:calc(var(--board-h, 12) * var(--cell));max-width:100%;max-height:100%;overflow:hidden;position:relative;background:var(--bg);cursor:crosshair}.board-grid{position:relative;display:grid;grid-template-columns:repeat(var(--board-w, 12),var(--cell));grid-template-rows:repeat(var(--board-h, 12),var(--cell));width:calc(var(--board-w, 12) * var(--cell));height:calc(var(--board-h, 12) * var(--cell));will-change:transform}.board-cell{position:relative;display:flex;align-items:center;justify-content:center;border:1px solid rgba(74 53 38 / .07);transition:background-color .1s}.board-cell--even{background:#2c231b}.board-cell--odd{background:#241c15}.board-grid[data-active-player="1"]{--hl-base: 210, 96, 58;--hl-action-base: 232, 124, 84}.board-grid[data-active-player="2"]{--hl-base: 62, 143, 163;--hl-action-base: 86, 173, 194}.board-cell--reachable{background:rgba(var(--hl-base),.18)!important;border-color:rgba(var(--hl-base),.5)}.board-cell--reachable:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:50%;background:rgba(var(--hl-base),.28);pointer-events:none}.board-cell--action{background:rgba(var(--hl-action-base),.32)!important;border-color:rgba(var(--hl-action-base),.7)}.board-cell--action:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:50%;background:rgba(var(--hl-action-base),.4);pointer-events:none}.board-cell--path{background:rgba(var(--hl-base),.45)!important;border-color:rgba(var(--hl-base),.85)}.board-cell--path:after{content:"";position:absolute;top:25%;right:25%;bottom:25%;left:25%;border-radius:50%;background:rgba(var(--hl-base),.6);pointer-events:none}.board-cell--path-end{background:rgba(var(--hl-base),.78)!important}.board-cell--path-end:after{top:12%;right:12%;bottom:12%;left:12%;border:2px solid rgba(var(--hl-base),1);background:rgba(var(--hl-base),.55)}.board-cell--selected{border-color:var(--accent)!important;border-width:2px}.unit-view{position:absolute;top:1px;right:1px;bottom:1px;left:1px;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.unit-view--selected .unit-sprite{outline:2px solid var(--accent);outline-offset:1px}.unit-view--spent .unit-sprite{opacity:.45;filter:grayscale(1) brightness(.7)}.unit-view--selected.unit-view--spent .unit-sprite{opacity:1;filter:none}.unit-sprite{width:calc(var(--cell) * .92);height:calc(var(--cell) * .92);background:transparent;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}.unit-sprite__img{width:100%;height:100%;object-fit:contain}.unit-sprite__initial{font-size:calc(var(--cell) * .4);font-weight:900;color:#fffffff2;line-height:1}.unit-status-icon{position:absolute;top:0;right:0;font-size:calc(var(--cell) * .22);line-height:1}.unit-hp-bar{width:calc(var(--cell) * .76);height:3px;background:#ffffff26;border-radius:2px;overflow:hidden;flex-shrink:0;margin-top:1px}.unit-hp-bar__fill{height:100%;border-radius:2px;transition:width .2s}.unit-owner-dot{width:4px;height:4px;border-radius:50%;flex-shrink:0;margin-top:1px}.unit-owner-dot--p1{background:var(--p1)}.unit-owner-dot--p2{background:var(--p2)}.side-panel{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.side-panel__actions-row{display:flex;gap:6px}.side-panel__btn{flex:1;padding:10px 12px;font-size:.8rem;font-weight:600;background:var(--bg3);color:var(--fg);border-radius:var(--radius)}.side-panel__btn--end-turn{background:var(--accent);color:var(--on-accent)}.side-panel__btn--skip{background:#ffffff14}.side-panel__btn--undo{width:100%;background:#ffffff0f;color:var(--fg2);font-size:.78rem;border:1px solid rgba(255 255 255 / .08)}.side-panel__btn--undo:not(:disabled):hover{background:#ffffff1f;color:var(--fg)}.side-panel__btn--replay{width:100%;background:var(--bg3);color:var(--accent);border:1px solid var(--accent);margin-top:8px}.side-panel__btn--save-replay{width:100%;background:var(--accent);color:var(--on-accent);border:1px solid transparent}.side-panel__btn--save-replay:disabled{opacity:.6;background:var(--bg3);color:var(--green);border-color:var(--green)}.replay-save__input{width:100%}.replay-rename__input{width:100%;padding:6px 8px;font-size:.95rem}.side-panel__game-over{text-align:center;padding:8px;display:flex;flex-direction:column;gap:8px}.side-panel__game-over-text{font-size:1rem;font-weight:700;color:var(--accent)}.replay-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 16px;background:var(--bg3);color:var(--fg);border-bottom:var(--border);flex-shrink:0}.replay-banner__label{font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);font-size:.85rem}.replay-banner__progress{font-size:.8rem;color:var(--fg2)}.replay-controls{display:flex;gap:6px;padding:8px 12px;align-items:center;flex-wrap:wrap}.replay-controls__btn{flex:1;min-width:40px;padding:8px 10px;font-size:.95rem;background:var(--bg3);color:var(--fg);border-radius:var(--radius)}.replay-controls__btn--primary{background:var(--accent);color:var(--on-accent);flex:1.4}.replay-controls__btn--speed{font-size:.85rem;font-weight:700;background:#ffffff14}.replay-controls__btn:disabled{opacity:.35}.replay-progress{margin:0 12px 8px;height:4px;background:#ffffff14;border-radius:2px;overflow:hidden}.replay-progress__bar{height:100%;background:var(--accent);transition:width .18s linear}.replay-controls__exit{margin:8px 12px;width:calc(100% - 24px);background:var(--bg3);color:var(--fg);border:1px solid rgba(255 255 255 / .12)}.combat-log__toggle{padding:6px 10px;font-size:.72rem;font-weight:600;background:var(--bg3);color:var(--fg);border-radius:var(--radius);flex-shrink:0;text-align:center;min-height:32px}.combat-log__toggle[aria-expanded=true]{background:var(--bg2)}.combat-log{flex:1;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:2px;font-size:.72rem;line-height:1.4}.log-entry{padding:2px 4px;border-radius:3px}.log-sys{color:var(--fg2)}.log-dmg{color:var(--stat-damage)}.log-heal{color:var(--stat-heal)}.log-def{color:#3498db}.log-cvt{color:#9b59b6}.log-mv{color:var(--stat-move);font-style:italic}.stat--hp{color:var(--stat-hp)}.stat--damage{color:var(--stat-damage)}.stat--range{color:var(--stat-range)}.stat--heal{color:var(--stat-heal)}.stat--move{color:var(--stat-move)}.stat--hp strong,.stat--damage strong,.stat--range strong,.stat--heal strong,.stat--move strong{color:inherit}.log-info{color:var(--fg)}.log-dg{color:var(--accent)}.turn-banner{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:50;animation:banner-in .25s ease-out,banner-out .4s ease-in 1.3s forwards}.turn-banner--p1{background:#d2603a40}.turn-banner--p2{background:#3e8fa340}.turn-banner__text{font-size:clamp(1.5rem,6vw,2.5rem);font-weight:900;color:#f7efe2;padding:16px 32px;background:#000000b3;border-radius:12px;letter-spacing:.02em}@keyframes banner-in{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes banner-out{0%{opacity:1}to{opacity:0}}.victory-banner{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:auto;cursor:pointer;z-index:200;overflow:hidden;background:#0000008c;animation:victory-fade-in .45s ease-out}.victory-banner--p1{background:radial-gradient(circle at center,#c23a2f8c,#000000b3)}.victory-banner--p2{background:radial-gradient(circle at center,#3f7fb88c,#000000b3)}.victory-banner--tie{background:radial-gradient(circle at center,#7878788c,#000000b3)}.victory-banner__text{position:relative;font-size:clamp(2.5rem,12vw,6rem);font-weight:900;color:#fff;text-shadow:0 0 22px rgba(255,255,255,.55),0 0 60px currentColor;padding:24px 48px;letter-spacing:.06em;text-align:center;animation:victory-text-pop 1.1s cubic-bezier(.34,1.56,.64,1) both,victory-text-pulse 1.6s ease-in-out 1.1s infinite}.victory-banner--p1 .victory-banner__text{color:#ffb3a8}.victory-banner--p2 .victory-banner__text{color:#a8d4ff}.victory-banner__hint{margin-top:16px;font-size:.95rem;color:#ffffffbf;letter-spacing:.04em;animation:victory-fade-in .6s ease-out 1.4s both}.victory-banner__rays{position:absolute;top:-50%;right:-50%;bottom:-50%;left:-50%;background:conic-gradient(from 0deg,rgba(255,255,255,.08) 0deg,transparent 12deg,rgba(255,255,255,.08) 24deg,transparent 36deg,rgba(255,255,255,.08) 48deg,transparent 60deg,rgba(255,255,255,.08) 72deg,transparent 84deg);animation:victory-rays-spin 8s linear infinite;pointer-events:none}.victory-banner__fireworks{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.firework{position:absolute;width:0;height:0;animation:firework-shell var(--firework-duration, 1.2s) ease-out both infinite;--firework-color: #fff}.firework__particle{position:absolute;left:0;top:0;width:6px;height:6px;border-radius:50%;transform:translateZ(0);box-shadow:0 0 8px 1px currentColor,0 0 16px 2px var(--firework-color);animation:firework-particle var(--firework-duration, 1.2s) ease-out both infinite;animation-delay:inherit;will-change:transform,opacity}@keyframes victory-fade-in{0%{opacity:0}to{opacity:1}}@keyframes victory-text-pop{0%{opacity:0;transform:scale(.4) rotate(-6deg)}60%{opacity:1;transform:scale(1.15) rotate(2deg)}to{opacity:1;transform:scale(1) rotate(0)}}@keyframes victory-text-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}@keyframes victory-rays-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes firework-shell{0%,to{opacity:0}6%{opacity:1}60%{opacity:1}}@keyframes firework-particle{0%{transform:translateZ(0) scale(.8);opacity:1}20%{transform:translate3d(calc(var(--dx) * .4),calc(var(--dy) * .4),0) scale(1);opacity:1}to{transform:translate3d(var(--dx),calc(var(--dy) + 60px),0) scale(.4);opacity:0}}.overlay-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.overlay-panel{background:var(--bg2);border:var(--border);border-radius:12px;padding:24px;display:flex;flex-direction:column;gap:12px;width:min(320px,90vw);max-height:90vh;overflow-y:auto}.overlay-panel--wide{width:min(480px,92vw)}.overlay-text{font-size:.85rem;color:var(--fg);line-height:1.4}.overlay-title{text-align:center;font-size:1.2rem;font-weight:700;color:var(--accent);margin-bottom:4px}.overlay-btn{padding:14px;font-size:.95rem;font-weight:600;background:var(--bg3);color:var(--fg);text-align:center;border-radius:var(--radius)}.overlay-btn--primary{background:var(--accent);color:var(--on-accent)}.overlay-btn--danger{background:#d2603a4d;color:#e74c3c}.overlay-section{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--bg3);border-radius:var(--radius);border:var(--border)}.overlay-section__title{font-size:.7rem;font-weight:700;color:var(--fg2);text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px}.overlay-btn--toggle{background:var(--bg2);color:var(--fg);font-size:.85rem;padding:10px 14px}.overlay-btn--toggle[aria-pressed=true]{background:var(--p1);color:var(--fg)}.overlay-slider{display:flex;align-items:center;gap:8px}.overlay-slider__label{font-size:.75rem;color:var(--fg2);width:50px;flex-shrink:0}.overlay-slider input[type=range]{flex:1;accent-color:var(--accent)}.overlay-select{display:flex;align-items:center;gap:8px}.overlay-select select{flex:1;background:var(--bg2);color:var(--fg);border:var(--border);border-radius:var(--radius);padding:8px 10px;font:inherit}.how-to-play-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.how-to-play-list__item{background:var(--bg3);border:var(--border);border-radius:var(--radius);font-size:1rem;color:var(--fg);line-height:1.35;position:relative;padding:14px 16px 14px 40px}.how-to-play-list__item:before{content:counter(item);counter-increment:item;position:absolute;left:12px;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:50%;background:var(--accent);color:var(--on-accent);font-weight:700;font-size:.85rem;display:flex;align-items:center;justify-content:center}.how-to-play-list{counter-reset:item}.turn-timer{position:absolute;top:56px;right:12px;z-index:90;display:flex;align-items:baseline;gap:6px;padding:6px 10px;background:#0000008c;color:#fff;border-radius:var(--radius);border:1px solid rgba(255,255,255,.12);font-size:.85rem;pointer-events:none;font-variant-numeric:tabular-nums}.turn-timer__label{font-size:.7rem;color:#ffffffb3;text-transform:uppercase;letter-spacing:.06em}.turn-timer__value{font-size:1.05rem;font-weight:700}.turn-timer--warning{background:#d2603aa6;color:#fff;animation:turn-timer-pulse 1s ease-in-out infinite}@keyframes turn-timer-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}.screen-missions{flex:1;display:flex;flex-direction:column;overflow:hidden}.missions-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg2);border-bottom:var(--border);flex-shrink:0}.missions-back-btn{background:transparent;color:var(--fg);font-size:1.5rem;min-width:44px;min-height:44px;border-radius:var(--radius)}.missions-title{font-size:1.1rem;font-weight:700;color:var(--fg);flex:1}.missions-tabs{display:flex;background:var(--bg2);border-bottom:var(--border);flex-shrink:0}.missions-tab{flex:1;padding:12px 8px;font-size:.85rem;font-weight:600;color:var(--fg2);background:transparent;border-radius:0;border-bottom:2px solid transparent;text-transform:uppercase;letter-spacing:.06em}.missions-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.missions-list{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.missions-empty{color:var(--fg2);font-size:.9rem;text-align:center;padding:24px 0}.mission-card{display:flex;align-items:center;gap:12px;background:var(--bg2);border:var(--border);border-radius:var(--radius);padding:14px 16px}.mission-card__bubble{flex-shrink:0;width:52px;height:52px;border-radius:50%;background:var(--bg3);border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;overflow:hidden}.mission-card__bubble-img{width:100%;height:100%;object-fit:cover}.mission-card__bubble-initial{font-size:1.4rem;font-weight:700;color:var(--fg);text-transform:uppercase}.mission-card__info{flex:1;display:flex;flex-direction:column;gap:4px}.mission-card__name{font-size:1rem;font-weight:700;color:var(--fg);display:flex;align-items:center;gap:8px}.mission-card__desc{font-size:.8rem;color:var(--fg2)}.mission-card__turns{font-size:.72rem;color:var(--fg2);text-transform:uppercase;letter-spacing:.06em}.mission-card__play-btn{padding:10px 20px;background:var(--accent);color:var(--on-accent);font-weight:700;font-size:.9rem;flex-shrink:0}.mission-badge{font-size:.62rem;font-weight:700;padding:2px 6px;border-radius:10px;text-transform:uppercase;letter-spacing:.05em;vertical-align:middle}.mission-badge--new{background:var(--bg3);color:var(--fg2)}.mission-badge--win{background:var(--green);color:#fff}.mission-badge--loss{background:var(--p1);color:#fff}.mission-badge--locked{background:#ffffff1a;color:var(--fg2)}.mission-card--locked{opacity:.45;cursor:not-allowed;filter:grayscale(.6)}.ai-thinking-bar{position:absolute;top:0;left:0;right:0;z-index:20;padding:6px 16px;background:#3e8fa3d9;color:#fff;font-size:.78rem;font-weight:600;letter-spacing:.06em;text-align:center;pointer-events:none}.screen-online{flex:1;display:flex;flex-direction:column;overflow:hidden}.online-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg2);border-bottom:var(--border);flex-shrink:0}.online-back-btn{background:transparent;color:var(--fg);font-size:1.5rem;min-width:44px;min-height:44px;border-radius:var(--radius)}.online-title{font-size:1.1rem;font-weight:700;color:var(--accent);flex:1}.online-conn{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:4px 8px;border-radius:10px}.online-conn--on{background:#27ae6040;color:var(--green)}.online-conn--off{background:#e74c3c40;color:#e74c3c}.online-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}.online-body:has(.online-status){justify-content:center}.online-actions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:320px}.online-join{display:flex;gap:8px;align-items:stretch;margin-top:8px}.online-join__input{flex:1;font-size:1.1rem;font-weight:700;letter-spacing:.2em;text-align:center;text-transform:uppercase;padding:12px;background:var(--bg2);color:var(--fg);border:var(--border);border-radius:var(--radius)}.online-join__input:focus{outline:2px solid var(--accent);outline-offset:1px}.online-status{text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px;max-width:360px}.online-status p{color:var(--fg);font-size:1rem}.online-status__hint{color:var(--fg2)!important;font-size:.85rem!important}.online-code{font-size:2rem;font-weight:900;letter-spacing:.2em;background:var(--bg3);color:var(--accent);padding:16px 24px;border-radius:var(--radius);-webkit-user-select:all;user-select:all}.online-error{color:#e74c3c;font-size:.85rem;margin-top:16px;text-align:center}.online-code-actions{display:flex;gap:8px;justify-content:center}.menu-btn--small{font-size:.85rem;padding:8px 14px;min-height:36px}.reconnecting-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:100;pointer-events:none}.reconnecting-overlay__panel{background:var(--bg2);border:var(--border);border-radius:var(--radius);padding:24px 32px;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:0 8px 32px #0006}.reconnecting-overlay__text{color:var(--fg);font-weight:600;letter-spacing:.04em}.reconnecting-overlay__spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--accent);border-radius:50%;animation:reconnecting-spin .9s linear infinite}@keyframes reconnecting-spin{to{transform:rotate(360deg)}}.toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%);padding:10px 16px;border-radius:var(--radius);font-size:.9rem;font-weight:600;background:var(--bg2);border:var(--border);color:var(--fg);box-shadow:0 4px 16px #0000004d;z-index:110;max-width:90vw;text-align:center;pointer-events:none;animation:toast-in .18s ease-out}.toast--error{background:#e74c3ceb;color:#fff;border-color:transparent}@keyframes toast-in{0%{transform:translate(-50%,8px);opacity:0}to{transform:translate(-50%);opacity:1}}.board-anim-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:5}.ability-anim{position:absolute;pointer-events:none;z-index:6;image-rendering:auto;image-rendering:-webkit-optimize-contrast;image-rendering:high-quality;filter:contrast(1.05) saturate(1.03);will-change:background-position}.unit-info-panel{display:flex;flex-direction:column;gap:8px;padding:10px 12px;background:var(--bg3);border:var(--border);border-radius:var(--radius);height:100%;overflow-y:auto;color:var(--fg);font-size:.95rem}.unit-info-panel--empty{align-items:center;justify-content:center}.unit-info-panel__hint{color:var(--fg2);font-size:1rem;text-align:center}.unit-info-panel__header{display:flex;align-items:center;gap:10px}.unit-info-panel__portrait{width:48px;height:48px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:transparent}.unit-info-panel__portrait img{width:100%;height:100%;object-fit:contain}.unit-info-panel__title{display:flex;flex-direction:column;gap:2px;min-width:0}.unit-info-panel__name{font-size:1.05rem;font-weight:700}.unit-info-panel__owner{font-size:.8rem;color:var(--fg2)}.unit-info-panel[data-pn="1"] .unit-info-panel__owner{color:var(--p1)}.unit-info-panel[data-pn="2"] .unit-info-panel__owner{color:var(--p2)}.unit-info-panel__stats{display:flex;flex-direction:row;flex-wrap:wrap;gap:10px;padding:6px 8px;background:#ffffff08;border-radius:var(--radius)}.unit-info-panel__stat{display:flex;gap:4px;font-size:.85rem;align-items:baseline}.unit-info-panel__stat-label{color:var(--fg2)}.unit-info-panel__stat-value{font-weight:600}.unit-info-panel__abilities{display:flex;flex-direction:column;gap:6px}.unit-info-panel__abilities-header{font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--fg2);border-bottom:var(--border);padding-bottom:4px}.unit-info-panel__ability{padding:6px 8px;background:#ffffff08;border-radius:var(--radius)}.unit-info-panel__ability-row{display:flex;justify-content:space-between;align-items:baseline;gap:6px}.unit-info-panel__ability-name{font-size:.92rem;font-weight:600}.unit-info-panel__ability-kind{font-size:.7rem;color:var(--fg2);text-transform:uppercase;letter-spacing:.05em}.unit-info-panel__ability-stats{display:flex;gap:6px;margin-top:4px;font-size:.75rem;color:var(--fg2)}.unit-info-panel__ability-stat{display:inline-flex;align-items:baseline;gap:3px;padding:2px 6px;border-radius:3px;background:#ffffff0d;text-transform:uppercase;letter-spacing:.05em}.unit-info-panel__ability-stat strong{color:var(--accent);font-weight:700;font-size:.85rem}.unit-info-panel__ability-desc{margin-top:4px;font-size:.82rem;color:var(--fg2);line-height:1.35}.unit-info-panel__ability-empty{font-size:.9rem;color:var(--fg2);font-style:italic}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:200}.confirm-dialog{background:var(--bg2);border:var(--border);border-radius:var(--radius);padding:18px 20px;max-width:320px;width:calc(100vw - 32px);display:flex;flex-direction:column;gap:14px;box-shadow:0 10px 30px #00000080}.confirm-dialog__msg{font-size:1rem;line-height:1.4}.confirm-dialog__checkbox{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--fg2);cursor:pointer}.confirm-dialog__buttons{display:flex;gap:8px;justify-content:flex-end}.confirm-dialog__btn{padding:8px 16px;border-radius:var(--radius);border:var(--border);font-weight:600;background:var(--bg3);color:var(--fg)}.confirm-dialog__btn--yes{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.movement-sprite{position:absolute;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:6}.movement-sprite__inner{width:calc(var(--cell) * .92);height:calc(var(--cell) * .92);background:transparent;display:flex;align-items:center;justify-content:center}.movement-sprite__inner img{width:100%;height:100%;object-fit:contain}.missions-view{flex:1;display:flex;flex-direction:column;min-height:0}.missions-view--easy{--mission-color: #2ecc71;--mission-tint: rgba(46, 204, 113, .18);--mission-border: rgba(46, 204, 113, .55)}.missions-view--medium{--mission-color: #f4d35e;--mission-tint: rgba(244, 211, 94, .18);--mission-border: rgba(244, 211, 94, .55)}.missions-view--hard{--mission-color: #e74c3c;--mission-tint: rgba(231, 76, 60, .18);--mission-border: rgba(231, 76, 60, .55)}.missions-view .missions-tab--active{color:var(--mission-color);border-bottom-color:var(--mission-color)}.missions-view button.mission-card{border-color:var(--mission-border)}.missions-view button.mission-card:hover,.missions-view .mission-card__bubble{border-color:var(--mission-color)}.missions-view .mission-card__turns{color:var(--mission-color)}button.mission-card{width:100%;text-align:left;background:var(--bg2);border:var(--border);border-radius:var(--radius);color:var(--fg);padding:10px 12px;cursor:pointer;display:flex;flex-direction:row;align-items:center;gap:12px;transition:background .1s,transform .05s}button.mission-card:hover{background:var(--bg3)}button.mission-card:active{transform:scale(.99)}.mission-intro-backdrop{cursor:pointer}.mission-intro{background:var(--bg2);border:var(--border);border-radius:var(--radius);padding:24px 20px;max-width:420px;width:90%;cursor:default;display:flex;flex-direction:column;gap:16px}.mission-intro__title{font-size:.8rem;color:var(--fg2);text-transform:uppercase;letter-spacing:.08em}.mission-intro__speaker{font-size:1.2rem;font-weight:700}.mission-intro__line{font-size:1rem;line-height:1.4;min-height:3em}.mission-intro__progress{display:flex;gap:6px;justify-content:center}.mission-intro__dot{width:8px;height:8px;border-radius:50%;background:var(--bg3)}.mission-intro__dot--on{background:var(--fg)}.mission-intro__actions{display:flex;gap:8px;justify-content:flex-end}.screen-shop{display:flex;flex-direction:column;height:100%;background:var(--bg);color:var(--fg)}.shop-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg2);border-bottom:var(--border)}.shop-back{background:transparent;color:var(--fg);padding:6px 10px;border-radius:var(--radius)}.shop-title{flex:1;text-align:center;font-size:1.1rem;font-weight:700;margin:0}.shop-credits{background:#ffffff14;padding:4px 10px;border-radius:var(--radius);font-size:.85rem;font-weight:600}.shop-tabs{display:flex;gap:4px;padding:8px 14px;background:var(--bg2);border-bottom:var(--border)}.shop-tab{flex:1;padding:8px 12px;background:transparent;border-bottom:2px solid transparent;color:var(--fg2);font-weight:600;border-radius:0}.shop-tab--active{color:var(--fg);border-bottom-color:var(--fg)}.shop-body{flex:1;overflow-y:auto;padding:16px 14px;display:flex;flex-direction:column;gap:12px}.shop-list{display:flex;flex-direction:column;gap:12px;list-style:none;padding:0;margin:0}.shop-card{background:var(--bg2);border:var(--border);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:8px}.shop-card--featured{border-color:var(--fg)}.shop-card__title{font-size:1.05rem;font-weight:700}.shop-card__desc{font-size:.9rem;color:var(--fg2)}.shop-card__meta{font-size:.8rem;color:var(--fg2)}.shop-card__buy{align-self:flex-start;background:var(--fg);color:var(--bg);font-weight:700;padding:8px 18px;border-radius:var(--radius)}.shop-card__buy:disabled{opacity:.6}.shop-card__owned{align-self:flex-start;background:var(--bg3);color:var(--fg);padding:4px 10px;border-radius:var(--radius);font-weight:600;font-size:.85rem}.shop-pack-roster{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:10px;margin:6px 0 4px}.shop-pack-char{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px}.shop-pack-char__sprite{width:56px;height:56px;border-radius:50%;background:var(--bg3);border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;overflow:hidden}.shop-pack-char__img{width:100%;height:100%;object-fit:cover}.shop-pack-char__initial{font-size:1.4rem;font-weight:700;color:var(--fg);text-transform:uppercase}.shop-pack-char__name{background:transparent;border:none;padding:2px 6px;border-radius:6px;font-size:.75rem;color:var(--fg);font-weight:600;cursor:pointer;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shop-pack-char__name:hover,.shop-pack-char__name--active{background:var(--bg3);color:var(--accent)}.shop-pack-char__popover{position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%);z-index:50;min-width:180px;max-width:240px;padding:8px 10px;background:var(--bg);color:var(--fg);border:1px solid var(--accent);border-radius:var(--radius);font-size:.78rem;line-height:1.35;text-align:center;box-shadow:0 6px 16px #00000059;pointer-events:auto;display:flex;flex-direction:column;gap:4px}.shop-pack-char__popover-stats{font-weight:700;color:var(--accent);font-size:.72rem;letter-spacing:.04em}.shop-pack-char__popover-desc{color:var(--fg)}.shop-footer{padding:8px 14px;background:var(--bg2);border-top:var(--border)}.shop-restore{display:block;margin:0 auto 6px;background:transparent;color:var(--fg2);font-size:.8rem;font-weight:600;text-decoration:underline;padding:6px 10px}.shop-restore:hover{color:var(--fg)}.shop-footer__notice{font-size:.75rem;color:var(--fg2);text-align:center}.outfit-shop__intro{font-size:.85rem;color:var(--fg2);padding:4px 0 8px}.outfit-shop__grid{display:flex;flex-direction:column;gap:6px;list-style:none;padding:0;margin:0}.outfit-row{background:var(--bg2);border:var(--border);border-radius:var(--radius);overflow:hidden}.outfit-row__head{width:100%;text-align:left;background:transparent;color:var(--fg);padding:10px 12px;border-left:4px solid var(--bg3);border-radius:0;display:flex;justify-content:space-between;align-items:center}.outfit-row__name{font-weight:700}.outfit-row__counts{font-size:.8rem;color:var(--fg2)}.outfit-row__slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px;padding:8px 12px 12px}.outfit-slot{background:var(--bg);border:var(--border);border-radius:var(--radius);padding:8px;display:flex;flex-direction:column;gap:4px;align-items:stretch}.outfit-slot--owned{border-color:var(--fg)}.outfit-slot__label{font-size:.8rem;color:var(--fg2)}.outfit-slot__badge{background:var(--bg3);color:var(--fg);text-align:center;padding:4px;border-radius:var(--radius);font-size:.8rem;font-weight:600}.outfit-slot__buy{background:var(--fg);color:var(--bg);font-weight:600;font-size:.8rem;padding:6px 4px;border-radius:var(--radius)}.outfit-slot__buy:disabled{opacity:.6}.overlay-text{font-size:.9rem;color:var(--fg2);line-height:1.4}.overlay-text--error{color:#e74c3c}.overlay-input{width:100%;background:var(--bg);border:var(--border);border-radius:var(--radius);padding:8px 10px;color:var(--fg);font-size:.95rem}.menu-account{background:transparent;color:var(--fg2);font-size:.85rem;padding:8px;margin-top:16px;border-radius:var(--radius)}.menu-account:hover{color:var(--fg)}.menu-top-right-actions{position:absolute;right:16px;top:16px;display:flex;gap:8px;z-index:2}.menu-corner-btn--shop{background:var(--accent);color:var(--on-accent);border-color:transparent;font-weight:700}.menu-corner-btn--shop:hover{filter:brightness(1.1);background:var(--accent)}.menu-corner-btn--shop.menu-corner-btn--disabled:hover{filter:none}.missions-scroll{flex:1;overflow-y:auto;display:flex;flex-direction:column}.my-missions{padding:12px;display:flex;flex-direction:column;gap:8px;border-bottom:var(--border)}.my-missions__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.my-missions__title{flex:1;margin:0;text-align:left;padding:6px 10px}.my-missions__create{background:var(--accent);color:var(--on-accent);font-weight:700;padding:8px 14px;border-radius:var(--radius);border:none;cursor:pointer;font-size:.85rem}.my-missions__create:hover{filter:brightness(1.1)}.my-missions__list{display:grid;grid-template-columns:1fr;gap:8px}@media (min-width: 720px){.my-missions__list{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}}.mission-card--custom{display:flex;flex-direction:column;gap:8px;padding:10px 12px}.mission-card__main{background:transparent;border:none;padding:0;text-align:left;color:inherit;cursor:pointer;display:flex;flex-direction:column;gap:4px}.mission-card__actions{display:flex;gap:6px;justify-content:flex-end}.mission-card__action-btn{background:var(--bg3);color:var(--fg);border:var(--border);border-radius:var(--radius);padding:6px 12px;font-size:.8rem;cursor:pointer}.mission-card__action-btn:hover{background:var(--bg)}.mission-card__action-btn--danger{background:#d2603a26;border-color:#d2603a80;color:#f5b7b1}.mission-card__action-btn--danger:hover{background:#d2603a4d}.screen-mission-maker{flex:1;display:flex;flex-direction:column;overflow:hidden}.mm-header{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg2);border-bottom:var(--border);flex-shrink:0}.mm-name-input{flex:1;background:var(--bg);border:var(--border);border-radius:var(--radius);padding:8px 12px;color:var(--fg);font-size:1rem;min-width:0}.mm-header-btn{background:var(--bg3);color:var(--fg);border:var(--border);border-radius:var(--radius);padding:8px 14px;font-weight:600;cursor:pointer;font-size:.9rem}.mm-header-btn:hover{background:var(--bg)}.mm-header-btn--primary{background:var(--accent);color:var(--on-accent);border-color:transparent}.mm-header-btn--primary:hover{filter:brightness(1.1);background:var(--accent)}.mm-header-btn:disabled{opacity:.4;cursor:not-allowed}.mm-body{flex:1;display:flex;flex-direction:column;overflow:hidden}@media (min-width: 900px){.mm-body{flex-direction:row}}.mm-board-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:12px;overflow-y:auto;gap:8px}.mm-board{flex-shrink:0;display:grid;background:var(--bg2);border:var(--border);border-radius:var(--radius);overflow:hidden;gap:1px;padding:1px}.mm-cell{background:var(--bg);border:none;padding:0;position:relative;cursor:pointer;display:flex;align-items:center;justify-content:center;min-width:0;min-height:0}.mm-cell--light{background:#ffffff08}.mm-cell--dark{background:#00000026}.mm-cell--p1{background:var(--p1-light);box-shadow:inset 0 0 0 2px var(--p1)}.mm-cell--p2{background:var(--p2-light);box-shadow:inset 0 0 0 2px var(--p2)}.mm-cell--selected{outline:2px solid var(--accent);outline-offset:-2px;z-index:1}.mm-cell__img{width:80%;height:80%;object-fit:contain;pointer-events:none}.mm-board-footer{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:min(100%,560px);font-size:.8rem;color:var(--fg2)}.mm-link-btn{background:transparent;color:var(--fg2);border:none;cursor:pointer;text-decoration:underline;font-size:.8rem;padding:4px 6px}.mm-link-btn:hover{color:var(--fg)}.mm-tools{background:var(--bg2);border-top:var(--border);padding:12px;display:flex;flex-direction:column;gap:12px;overflow-y:auto;flex-shrink:0;max-height:45vh}@media (min-width: 900px){.mm-tools{border-top:none;border-left:var(--border);width:340px;max-height:none}}.mm-section{display:flex;flex-direction:column;gap:6px}.mm-section--compact{gap:3px}.mm-section--compact .mm-section__title{font-size:.68rem;text-transform:uppercase;letter-spacing:.05em}.mm-section--compact .mm-toggle__btn{min-height:30px;padding:3px 8px;font-size:.72rem;font-weight:600}.mm-section__title{font-size:.85rem;letter-spacing:.01em;color:var(--fg2);font-weight:700;font-family:var(--font-display)}.mm-section__title--sub{margin-top:10px}.mm-outfit-btn{align-self:flex-start;padding:8px 14px;border-radius:var(--radius);background:var(--bg3);color:var(--fg);font-weight:700;font-size:.85rem}.mm-share-code{width:100%;resize:vertical;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.8rem;line-height:1.4;padding:10px;border-radius:var(--radius);border:var(--border);background:var(--bg);color:var(--fg);word-break:break-all}.mm-share-error{color:var(--p1);font-size:.8rem;margin:0}.mm-help{font-size:.75rem;color:var(--fg2);line-height:1.3}.mm-toggle{display:flex;gap:6px}.mm-toggle__btn{flex:1;background:var(--bg);color:var(--fg);border:var(--border);border-radius:var(--radius);padding:8px 10px;font-size:.85rem;font-weight:600;cursor:pointer}.mm-toggle__btn--active{background:var(--accent);color:var(--on-accent);border-color:transparent}.mm-toggle__btn--p1.mm-toggle__btn--active{background:var(--p1);color:#fff}.mm-toggle__btn--p2.mm-toggle__btn--active{background:var(--p2);color:#fff}.mm-behavior-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.mm-behavior-btn{background:var(--bg);color:var(--fg);border:var(--border);border-radius:var(--radius);padding:8px;font-size:.85rem;font-weight:600;cursor:pointer}.mm-behavior-btn--active{background:var(--accent);color:var(--on-accent);border-color:transparent}.mm-stepper{display:flex;align-items:center;gap:8px}.mm-stepper__btn{background:var(--bg);color:var(--fg);border:var(--border);border-radius:var(--radius);min-width:40px;min-height:40px;font-size:1.1rem;font-weight:700;cursor:pointer}.mm-stepper__btn:hover{background:var(--bg3)}.mm-stepper__btn:disabled{opacity:.4;cursor:not-allowed}.mm-stepper__value{flex:1;text-align:center;font-size:1.1rem;font-weight:700;font-variant-numeric:tabular-nums}.mm-size-grid{display:grid;grid-template-columns:auto 1fr;gap:6px 10px;align-items:center}.mm-size-grid__label{font-size:.78rem;color:var(--fg2);text-transform:uppercase;letter-spacing:.05em}.mm-char-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:6px;max-height:280px;overflow-y:auto;padding-right:4px}.mm-char-card{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px;background:var(--bg);border:var(--border);border-radius:var(--radius);cursor:pointer;min-height:70px}.mm-char-card:hover{background:var(--bg3)}.mm-char-card--active{border-color:var(--accent);background:#f4d35e1a}.mm-char-card__img{width:44px;height:44px;object-fit:contain;pointer-events:none}.mm-char-card__name{font-size:.65rem;color:var(--fg);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.mm-toast{position:fixed;left:50%;bottom:32px;transform:translate(-50%);background:var(--accent);color:var(--on-accent);padding:10px 20px;border-radius:var(--radius);font-weight:700;font-size:.9rem;box-shadow:0 4px 12px #0006;z-index:100;pointer-events:none}.screen-local-play{display:flex;flex-direction:column;height:100%;background:var(--bg);color:var(--fg)}.local-play__body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:20px;overflow-y:auto}.local-play__choose,.local-play__panel{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:360px}.local-play__hint{text-align:center;color:var(--fg2);font-size:.95rem;line-height:1.4;margin:0}.local-play__hint--sub{font-size:.85rem}.local-play__hint--error{color:var(--p1)}.qr-display{width:280px;height:280px;max-width:80vw;max-height:80vw;background:#fff;border-radius:var(--radius);object-fit:contain;image-rendering:pixelated}.qr-display--loading{background:var(--bg2)}.qr-display--error{display:flex;align-items:center;justify-content:center;color:var(--p1);background:var(--bg2)}.qr-scanner{width:280px;height:280px;max-width:80vw;max-height:80vw;border-radius:var(--radius);overflow:hidden;background:#000;border:var(--border)}.qr-scanner__video{width:100%;height:100%;object-fit:cover}.screen-online-choice{display:flex;flex-direction:column;height:100%;background:var(--bg);color:var(--fg)}.online-choice__body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:20px}.online-choice__btn{display:flex;flex-direction:column;align-items:flex-start;gap:2px;width:100%;max-width:360px}.online-choice__label{font-size:1.05rem;font-weight:600}.online-choice__sub{font-size:.78rem;font-weight:400;opacity:.8}.home-shell{flex:1;display:flex;flex-direction:column;min-height:0}.home-shell__content{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.tab-bar{display:flex;background:var(--bg2);border-top:var(--border);flex-shrink:0;box-shadow:0 -6px 18px #1e120a59}.tab-bar__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px 10px;background:transparent;border:none;border-radius:0;color:var(--fg2);min-height:56px}.tab-bar__item--active{color:var(--accent);background:linear-gradient(to top,rgba(242,193,78,.14),transparent);box-shadow:inset 0 2px 0 var(--accent)}.tab-bar__icon{font-size:1.3rem;line-height:1;filter:saturate(1.1)}.tab-bar__item--active .tab-bar__icon{transform:translateY(-1px) scale(1.08)}.tab-bar__label{font-size:.62rem;font-weight:700;letter-spacing:.02em;white-space:nowrap;text-transform:uppercase}.home-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:var(--bg2);border-bottom:var(--border);flex-shrink:0}.home-topbar__title{font-size:1.15rem;font-weight:800;color:var(--fg)}.home-topbar__options{width:40px;height:40px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;font-size:1.25rem;line-height:1;background:var(--bg3);color:var(--fg);border:var(--border);border-radius:var(--radius)}.home-topbar__options:hover{background:var(--bg)}.home-tab{flex:1;display:flex;flex-direction:column;min-height:0}.home-tab__scroll{flex:1;min-height:0;overflow-y:auto}.sub-nav{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--bg2);border-bottom:var(--border);flex-shrink:0}.sub-nav__back{background:transparent;color:var(--fg);font-size:1.4rem;min-width:40px;min-height:40px;border-radius:var(--radius)}.sub-nav__title{font-size:1rem;font-weight:700;color:var(--fg)}.menu-stack{display:flex;flex-direction:column;gap:10px;padding:12px}.choice-btn{display:flex;align-items:center;gap:14px;width:100%;text-align:left;padding:14px 16px;background:var(--bg2);color:var(--fg);border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow-soft)}.choice-btn:hover{background:var(--bg3)}.choice-btn:active{transform:scale(.99)}.choice-btn--primary{border-color:var(--accent);background:linear-gradient(135deg,rgba(242,193,78,.18),var(--bg2))}.choice-btn__icon{font-size:1.7rem;line-height:1;flex-shrink:0}.choice-btn__text{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.choice-btn__label{font-size:1.05rem;font-weight:700}.choice-btn__sub{font-size:.78rem;color:var(--fg2)}.choice-btn__chevron{font-size:1.5rem;color:var(--fg2);flex-shrink:0}.online-conn-row{display:flex;justify-content:flex-end;padding:6px 12px 0;flex-shrink:0}.mm-menu__scroll{flex:1;min-height:0}.shop-tabs--embedded{align-items:center}.shop-credits--embedded{margin-left:auto;margin-right:12px}.credits-tagline{text-align:center;color:var(--fg2);font-size:.85rem;margin-top:-4px}.credits-list{display:flex;flex-direction:column;gap:10px;margin:4px 0}.credits-row{display:flex;flex-direction:column;gap:1px;text-align:center}.credits-role{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--fg2)}.credits-name{font-size:.95rem;font-weight:700;color:var(--fg)}.credits-thanks{text-align:center;font-weight:700;color:var(--accent);margin:4px 0}.missions-header--actions{justify-content:space-between}.missions-header--actions .missions-title{flex:1}.mm-menu__intro{padding:12px 16px 0;color:var(--fg2);font-size:.85rem}.mm-menu__empty{padding:32px 24px;text-align:center}.mm-menu__list{display:flex;flex-direction:column;gap:10px;padding:12px 16px 24px}.mm-menu__card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg2);border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow-soft)}.mm-menu__info{flex:1;min-width:0}.mm-menu__name{font-weight:700;font-size:1rem;color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mm-menu__meta{font-size:.78rem;color:var(--fg2);margin-top:2px}.mm-menu__actions{display:flex;gap:6px;flex-shrink:0}.mm-menu__delete{min-width:44px;padding:8px 10px;font-size:1rem}.screen-extras{display:flex;flex-direction:column;height:100%;background:var(--bg);color:var(--fg);overflow-y:auto}.extras-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:12px}.extras-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 12px;background:var(--bg2);border:var(--border);border-radius:var(--radius);color:var(--fg);box-shadow:var(--shadow-soft);position:relative;min-height:92px}.extras-tile__icon{font-size:2rem;line-height:1}.extras-tile__label{font-size:.9rem;font-weight:700}.extras-tile--disabled{opacity:.5;cursor:not-allowed}.extras-tile .menu-soon{position:absolute;top:6px;right:8px;float:none}.extras-account{margin:4px 16px 24px;align-self:stretch}.glossary-list{margin:0;display:flex;flex-direction:column;gap:14px;text-align:left;max-height:60vh;overflow-y:auto}.glossary-list__item{display:flex;flex-direction:column;gap:2px}.glossary-list__term{font-weight:800;color:var(--accent);font-size:.95rem}.glossary-list__def{margin:0;color:var(--fg2);font-size:.85rem;line-height:1.4}.team-builder__name{flex:1;min-width:0;padding:10px 12px;font-size:1rem;font-weight:600;color:var(--fg);background:var(--bg);border:var(--border);border-radius:var(--radius)}.team-builder__name::placeholder{color:var(--fg2);font-weight:400}.team-builder__selection{background:var(--bg2);border-bottom:var(--border);padding:8px 12px;flex-shrink:0;overflow-x:auto}.mm-menu__bar{display:flex;align-items:center;gap:12px;padding:12px 16px 0}.mm-menu__bar .mm-menu__intro{flex:1;padding:0}.team-picker{-moz-appearance:none;appearance:none;-webkit-appearance:none;min-height:36px;max-width:160px;padding:6px 10px;font-size:.8rem;font-weight:600;color:var(--fg);background:var(--bg3);border:var(--border);border-radius:var(--radius);cursor:pointer}.team-picker option{color:var(--fg);background:var(--bg2)}.team-panel__load{max-width:140px}
