.game-page{display:flex;flex-direction:column;height:100dvh;min-height:100dvh;overflow:hidden}.game-loading-screen{background:#0a0e1a;color:#fff;display:grid;min-height:100dvh;place-items:center}.game-topbar{align-items:center;background:#0d1225;border-bottom:1px solid #2a3560;display:flex;flex-shrink:0;gap:10px;justify-content:space-between;padding:6px 12px}.game-topbar-left,.game-topbar-right{align-items:center;display:flex;gap:8px}.game-topbar-center{color:#8a94b8;font-size:10px;white-space:nowrap}.game-conn-badge,.game-phase-pill,.game-round-pill{border-radius:12px;font-size:10px;font-weight:700}.game-round-pill{color:#ff9b30;font-size:12px}.game-phase-pill{background:#243055;border:1px solid #3a4a78;padding:2px 10px}.game-conn-badge{border:1px solid #2a3560;padding:2px 8px}.game-conn-badge.ok{background:#22dd771f;color:#2d7}.game-conn-badge.retry{background:#ffaa221f;color:#fa2}.game-conn-badge.off{background:#ff66771f;color:#f67}.game-turn-indicator{font-size:12px;font-weight:700}.game-turn-indicator.mine{color:#2d7}.game-turn-indicator.theirs{color:#f35}.game-reconnect-banner{background:#ffaa221f;border-bottom:1px solid #ffaa2259;color:#ffcf7a;flex-shrink:0;font-size:11px;font-weight:700;padding:6px 12px}.game-battle{-webkit-overflow-scrolling:touch;flex:1 1;gap:6px;min-height:0;overflow-x:hidden;overflow-y:auto;padding:4px 8px}.game-battle,.game-board-scale{display:flex;flex-direction:column}.game-board-scale{gap:4px;transform-origin:top center}.game-midline{align-items:center;display:flex;flex-shrink:0;gap:6px;padding:1px 0}.game-midline-bar{background:linear-gradient(90deg,#0000,#3a4a78,#0000);flex:1 1;height:1px}.game-midline-dots{display:flex;flex-direction:column;gap:3px}.game-midline-dot{background:#2a3560;border:2px solid #3a4a78;border-radius:50%;height:8px;width:8px}.game-midline-dot.active{background:#fff}.game-midline-dot.red{background:#f35;opacity:.3}.game-midline-dot.blue{background:#4af;opacity:.3}.game-bottom-panel{background:#0d1225;border-top:1px solid #2a3560;flex-shrink:0}.game-context-stack{background:linear-gradient(180deg,#121a34f2,#0d1225fa);border-bottom:1px solid #1a2342;padding:8px 10px 6px}.game-context-panel,.game-context-stack{display:flex;flex-direction:column;gap:8px}.game-context-panel{background:#0a1022e0;border:1px solid #26345f;border-radius:10px;box-shadow:inset 0 0 0 1px #ffffff05;padding:8px 10px}.game-context-head{align-items:center;display:flex;gap:8px;justify-content:space-between}.game-context-head-wrap{align-items:flex-start;flex-direction:column}.game-context-actions{align-items:center;display:flex;gap:6px}.game-context-actions-wrap{flex-wrap:wrap}.game-context-subtext{color:#ffcf7a;font-size:10px;line-height:1.35}.game-toolbar-title{color:#fa2;font-size:11px;font-weight:700}.mercy-panel{background:linear-gradient(180deg,#0d1830f2,#0a1022fa);border-color:#78cfff61}.mercy-choice-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(92px,1fr))}.mercy-choice-card{align-items:flex-start;background:linear-gradient(180deg,#172447,#10182f);border:1px solid #35508c;border-radius:10px;color:#e8ecf8;cursor:pointer;display:flex;flex-direction:column;gap:6px;padding:10px 10px 9px;text-align:left}.mercy-choice-card:hover{border-color:#78cfff;box-shadow:0 0 0 1px #78cfff40}.mercy-choice-card.tank{border-color:#49c4ff73}.mercy-choice-card.dealer{border-color:#ff709a73}.mercy-choice-card.healer{border-color:#ffcc5273}.mercy-choice-name{font-size:12px;font-weight:800;line-height:1.15}.mercy-choice-role{background:#ffffff0a;border:1px solid #3a4a78;border-radius:999px;font-size:10px;font-weight:800;padding:3px 8px}.mercy-choice-role.tank{border-color:#5fd1ff66;color:#5fd1ff}.mercy-choice-role.dealer{border-color:#f7a6;color:#f7a}.mercy-choice-role.healer{border-color:#ffcf5266;color:#ffcf52}.game-hand-row{-webkit-overflow-scrolling:touch;display:flex;gap:5px;justify-content:center;overflow-x:auto;padding:6px 12px}.game-bottombar{align-items:center;border-top:1px solid #1a2342;display:flex;gap:8px;justify-content:space-between;padding:4px 12px 6px}.game-bottombar-meta{color:#8a94b8;font-size:9px}.game-bottombar-actions{align-items:center;display:flex;gap:6px}.game-placement-meta{color:#fa2;font-size:10px}.game-endturn{background:#ff9b30;border:none;border-radius:6px;box-shadow:0 0 14px #ff9b304d;color:#0a0e1a;cursor:pointer;font-size:13px;font-weight:900;padding:7px 18px}.game-log{-webkit-overflow-scrolling:touch;background:#0a0e1a;color:#8a94b8;font-size:9px;max-height:76px;overflow-y:auto;padding:4px 12px}.game-log-line{border-bottom:1px solid #111832;padding:1px 0}@media (max-width:860px){.game-board-scale{zoom:.9}.game-hand-row{justify-content:flex-start}}@media (max-width:768px){.game-topbar{flex-wrap:wrap;justify-content:space-between;padding:5px 8px}.game-topbar-center{font-size:9px;order:3;width:100%}.game-battle{gap:4px;padding:4px 6px 2px}.game-board-scale{zoom:.82}.game-context-stack{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:linear-gradient(180deg,#0d1225db,#0d1225fa);bottom:0;gap:6px;padding:6px 8px 5px;position:sticky;z-index:3}.game-context-panel{border-radius:9px;gap:6px;padding:7px 8px}.game-toolbar-title{font-size:10px}.game-bottombar-meta,.game-context-subtext,.game-placement-meta{font-size:9px}.mercy-choice-grid{gap:6px;grid-template-columns:repeat(2,minmax(0,1fr))}.mercy-choice-card{gap:5px;padding:8px}.mercy-choice-name{font-size:11px}.mercy-choice-role{font-size:9px;padding:2px 7px}.game-hand-row{zoom:.92;gap:4px;justify-content:flex-start;padding:4px 6px}.game-bottombar{align-items:center;flex-wrap:wrap;padding:4px 8px 6px}.game-endturn{font-size:12px;padding:6px 14px}.game-log{font-size:8px;max-height:56px;padding:4px 8px}}@media (max-width:480px){.game-page{overflow-y:auto}.game-board-scale{zoom:.74}.game-context-stack{gap:5px;padding:5px 6px 4px}.game-context-panel{gap:5px;padding:6px 7px}.game-context-actions{flex-wrap:wrap}.game-hand-row{zoom:.84}.game-conn-badge,.game-phase-pill,.game-reconnect-banner,.game-round-pill,.game-toolbar-title,.game-turn-indicator{font-size:9px}.game-context-subtext{font-size:8px}.mercy-choice-grid{grid-template-columns:1fr 1fr}.game-endturn{font-size:11px;padding:6px 12px}}@supports not (zoom:1){@media (max-width:768px){.game-board-scale{margin-bottom:-18%;transform:scale(.82);width:121.9512%}.game-hand-row{margin-bottom:-8%;transform:scale(.92);transform-origin:left top;width:108.6957%}}@media (max-width:480px){.game-board-scale{margin-bottom:-26%;transform:scale(.74);width:135.1352%}.game-hand-row{margin-bottom:-14%;transform:scale(.84);width:119.0477%}}}.game-passive-banner{background:#78cfff1f;border-bottom:1px solid #78cfff59;color:#9fdfff;flex-shrink:0;font-size:11px;font-weight:800;padding:6px 12px}.field-move-badge{border:1px solid #0000;border-radius:999px;font-size:7px;font-weight:900;left:50%;letter-spacing:.2px;padding:1px 5px;pointer-events:none;position:absolute;top:1px;transform:translateX(-50%);white-space:nowrap;z-index:2}.field-move-badge.airborne{background:#44aaff2e;border-color:#44aaff73;color:#9fe3ff}.field-move-badge.burrowed{background:#78552838;border-color:#b4824666;color:#e6c79b}.field-move-badge.stealth{background:#5a46aa38;border-color:#8c6eff61;color:#c6b8ff}.field-move-badge.exposed{background:#a0283c33;border-color:#ff5a7866;color:#ff9baa}.field-move-badge.pulled{background:#7d329633;border-color:#d278ff61;color:#f0b7ff}.field-move-badge.hooked{background:#8c19193d;border-color:#ff505073;color:#ffb0b0}.deck-builder-page{background:linear-gradient(180deg,#0a0e1a,#111832);box-sizing:border-box;color:#e8ecf8;min-height:100vh;min-height:100dvh;padding:8px}.deck-builder-shell{display:flex;flex-direction:column;gap:6px;margin:0 auto;max-width:1280px}.deck-builder-header{align-items:center;background:#111832;border:1px solid #2a3560;border-radius:10px;display:flex;flex-wrap:wrap;gap:6px;justify-content:space-between;padding:10px 12px}.deck-builder-header h1{font-size:clamp(16px,4.5vw,28px);font-weight:900;margin:0}.deck-builder-header p{color:#8a94b8;font-size:clamp(9px,2.2vw,13px);margin:2px 0 0}.deck-builder-actions{display:flex;flex-wrap:wrap;gap:5px}.ghost-btn,.primary-btn{border-radius:6px;cursor:pointer;font-size:clamp(10px,2.2vw,13px);font-weight:800;padding:6px 10px}.primary-btn{background:#ff9b30;border:none;color:#0a0e1a}.ghost-btn{background:#243055;border:1px solid #3a4a78;color:#e8ecf8}.deck-builder-topbar{grid-gap:5px;display:grid;gap:5px;grid-template-columns:1fr 1fr}.deck-input{background:#0d1225;border:1px solid #33406b;border-radius:6px;box-sizing:border-box;color:#e8ecf8;font-size:clamp(10px,2.2vw,13px);outline:none;padding:7px 10px;width:100%}.deck-builder-grid{display:flex;flex-direction:column;gap:6px}.deck-panel{background:#111832;border:1px solid #2a3560;border-radius:10px;padding:8px 10px}.panel-title{align-items:center;display:flex;font-size:clamp(13px,3vw,17px);font-weight:900;justify-content:space-between;margin-bottom:6px}.hero-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(auto-fill,minmax(62px,1fr))}.hero-tile{background:#0d1225;border:1px solid #243055;border-radius:8px;color:#e8ecf8;cursor:pointer;padding:4px;transition:transform .15s,border-color .15s}.hero-tile:hover{border-color:#ff9b30;transform:translateY(-1px)}.hero-tile-image{aspect-ratio:1/1;background:#1a2342;border-radius:6px;margin-bottom:3px;overflow:hidden;width:100%}.hero-tile-image img{height:100%;object-fit:cover;width:100%}.hero-tile-name{font-size:clamp(8px,1.8vw,11px);font-weight:700;text-align:center}.hero-tile-role{color:#8a94b8;font-size:clamp(7px,1.6vw,10px);margin-top:1px;text-align:center}.hero-tile-controls{gap:3px;margin-top:3px}.hero-tile-controls,.hero-tile-controls button{align-items:center;display:flex;justify-content:center}.hero-tile-controls button{border-radius:4px;cursor:pointer;font-size:11px;font-weight:900;height:20px;padding:0;width:20px}.hero-tile-controls .qty{font-size:10px;font-weight:800;min-width:16px;text-align:center}.deck-icon-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(auto-fill,minmax(46px,1fr))}.deck-icon-item{background:#0d1225;border:1px solid #243055;border-radius:6px;cursor:pointer;padding:3px;position:relative;text-align:center;transition:border-color .15s}.deck-icon-item:hover{border-color:#ff9b30}.deck-icon-img{aspect-ratio:1/1;background:#1a2342;border-radius:5px;overflow:hidden;width:100%}.deck-icon-img img{height:100%;object-fit:cover;width:100%}.deck-icon-name{font-size:clamp(6px,1.4vw,9px);font-weight:700;margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.deck-icon-qty{align-items:center;background:#ff9b30;border-radius:50%;color:#0a0e1a;font-size:8px;font-weight:900;height:14px;position:absolute;right:1px;top:1px;width:14px}.deck-icon-controls,.deck-icon-qty{display:flex;justify-content:center}.deck-icon-controls{gap:2px;margin-top:2px}.deck-icon-controls button{align-items:center;border-radius:3px;cursor:pointer;display:flex;font-size:9px;font-weight:900;height:16px;justify-content:center;padding:0;width:16px}.scroll-area{overflow-x:hidden;overflow-y:auto;padding-right:3px}.card-list-scroll{max-height:38vh}.deck-list-scroll{max-height:25vh}.scroll-area::-webkit-scrollbar{width:5px}.scroll-area::-webkit-scrollbar-track{background:#0d1225;border-radius:99px}.scroll-area::-webkit-scrollbar-thumb{background:#2f4170;border-radius:99px}@media (min-width:768px){.deck-builder-page{padding:16px}.deck-builder-shell{gap:10px}.deck-builder-header{padding:16px 20px}.deck-builder-grid{flex-direction:row}.deck-builder-grid>.deck-panel:first-child{flex:1.4 1}.deck-builder-grid>.deck-panel:last-child{flex:0.8 1}.deck-panel{padding:14px 16px}.hero-grid{gap:10px;grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}.deck-icon-grid{gap:6px;grid-template-columns:repeat(auto-fill,minmax(56px,1fr))}.card-list-scroll,.deck-list-scroll{max-height:62vh}}*{box-sizing:border-box;margin:0;padding:0}#root,body,html{background:#0a0e1a;color:#e8ecf8;font-family:Noto Sans KR,sans-serif;height:100%;overflow:hidden}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:#111832}::-webkit-scrollbar-thumb{background:#3a4a78;border-radius:2px}button{font-family:Noto Sans KR,sans-serif}button:active{transform:scale(.97)}
/*# sourceMappingURL=main.a30a80fe.css.map*/