*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0b1220;--panel:#141d31;--panel2:#1c2845;--border:#2a3a5f;--text:#e8eefc;--muted:#8fa0c4;--accent:#ffb13d;--accent2:#4da3ff;--green:#3ddc84;--red:#ff5d5d}body,html{height:100%}body{background:radial-gradient(1100px 700px at 75% -10%,#1c2c52 0,transparent 60%),radial-gradient(900px 600px at 10% 110%,#14203c 0,transparent 55%),var(--bg);background-attachment:fixed;color:var(--text);font-family:Pretendard Variable,Pretendard,Segoe UI,Apple SD Gothic Neo,Noto Sans KR,sans-serif;-webkit-font-smoothing:antialiased;letter-spacing:-.01em}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:#2a3a5f;border-radius:6px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#3d5286;background-clip:padding-box;border:2px solid transparent}::-webkit-scrollbar-track{background:transparent}button{font-family:inherit;cursor:pointer;border:none;border-radius:8px;background:var(--panel2);color:var(--text);padding:8px 14px;font-size:14px;transition:filter .12s,transform .05s}button:hover:not(:disabled){filter:brightness(1.2)}button:disabled{opacity:.45;cursor:not-allowed}button.primary{background:var(--accent);color:#1a1206;font-weight:700}button.blue{background:var(--accent2);color:#06121f;font-weight:700}button.danger{background:var(--red);color:#fff}button.small{padding:4px 10px;font-size:12px}input,select{font-family:inherit;background:#0e1626;border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 10px;font-size:14px;outline:none}input[type=range]{padding:0;accent-color:var(--accent)}input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px}.page{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:24px}.title-banner{font-size:42px;font-weight:900;letter-spacing:2px;color:var(--accent);text-shadow:0 3px 0 #7a4c12,0 6px 18px rgba(255,177,61,.35);margin:24px 0 4px}.subtitle{color:var(--muted);margin-bottom:28px}.card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:20px}.login-card{display:flex;flex-direction:column;gap:14px;align-items:stretch}.login-card .divider{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:12px}.login-card .divider:after,.login-card .divider:before{content:"";flex:1 1;height:1px;background:var(--border)}.lobby{width:100%;max-width:1100px;display:grid;grid-template-columns:1fr 320px;grid-gap:16px;gap:16px}.lobby-header{grid-column:1/-1;display:flex;align-items:center;justify-content:space-between}.lobby-header .me{display:flex;align-items:center;gap:10px}.avatar{width:34px;height:34px;border-radius:50%;background:var(--panel2);display:inline-flex;align-items:center;justify-content:center;font-weight:700;overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.room-list{display:flex;flex-direction:column;gap:8px;min-height:300px}.room-row{display:flex;align-items:center;justify-content:space-between;background:var(--panel2);border:1px solid var(--border);border-radius:10px;padding:12px 16px}.room-row .name{font-weight:700}.room-row .meta{color:var(--muted);font-size:13px}.badge{display:inline-block;font-size:11px;padding:2px 8px;border-radius:99px;background:var(--panel);border:1px solid var(--border);color:var(--muted);margin-left:8px}.badge.playing{color:var(--accent);border-color:var(--accent)}.modal-backdrop{position:fixed;inset:0;background:rgba(4,8,18,.72);display:flex;align-items:center;justify-content:center;z-index:100}.modal{width:440px;max-width:94vw;max-height:90vh;overflow-y:auto}.form-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:10px 0}.form-row label{color:var(--muted);font-size:14px}.form-row input[type=number],.form-row input[type=password],.form-row input[type=text],.form-row select{width:200px}h2.section{font-size:17px;margin-bottom:12px;color:var(--text)}.rank-row{display:flex;align-items:center;gap:10px;padding:7px 4px;border-bottom:1px solid var(--border);font-size:14px}.rank-row .pos{width:22px;color:var(--accent);font-weight:700}.rank-row .stats{margin-left:auto;color:var(--muted);font-size:12px}.room-page{min-height:100vh;display:flex;flex-direction:column;padding:16px;gap:12px;max-width:1280px;margin:0 auto;width:100%}.room-topbar{display:flex;align-items:center;gap:14px}.room-topbar .code{font-family:monospace;font-size:15px;background:var(--panel2);border:1px dashed var(--border);padding:4px 10px;border-radius:8px;letter-spacing:2px}.room-main{display:grid;grid-template-columns:1fr 300px;grid-gap:12px;gap:12px;flex:1 1;min-height:0}.player-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:10px;gap:10px}.player-slot{display:flex;align-items:center;gap:10px;background:var(--panel2);border:1px solid var(--border);border-radius:10px;padding:12px}.player-slot.empty{opacity:.35;justify-content:center;color:var(--muted);border-style:dashed}.player-slot .color-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0}.player-slot .pname{font-weight:600;display:flex;align-items:center;gap:6px}.player-slot .tag{font-size:11px;color:var(--muted)}.ready-pill{margin-left:auto;font-size:12px;padding:3px 10px;border-radius:99px;background:#233;color:var(--muted)}.ready-pill.on{background:rgba(61,220,132,.15);color:var(--green)}.settings-list{display:flex;flex-wrap:wrap;gap:8px;font-size:13px;color:var(--muted)}.settings-list span{background:var(--panel2);padding:4px 10px;border-radius:8px;border:1px solid var(--border)}.chat{display:flex;flex-direction:column;height:100%}.chat-log{flex:1 1;overflow-y:auto;display:flex;flex-direction:column;gap:5px;padding-right:4px;min-height:120px}.chat-line{font-size:13.5px;line-height:1.45;word-break:break-word}.chat-line .who{font-weight:700;margin-right:6px}.chat-line.system{color:var(--accent);font-size:12.5px}.chat-line.spectator{color:var(--muted)}.chat-line .who.me{color:var(--accent)}.chat-notice{font-size:12px;color:var(--muted);margin-top:6px}.chat-input{display:flex;gap:8px;margin-top:10px}.room-page.in-game{padding:10px 12px;gap:8px;max-width:none}.game-shell{flex:1 1;display:flex;flex-direction:column;min-height:0}.game-area{position:relative;background:#060b16;border:1px solid var(--border);border-radius:14px;overflow:hidden;min-height:480px;flex:1 1;box-shadow:0 14px 50px rgba(0,0,0,.55),inset 0 0 80px rgba(0,0,0,.25)}.game-canvas-host{position:absolute;inset:0}.hud-chip{background:rgba(7,13,28,.74);border:1px solid rgba(125,155,215,.35);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:10px;padding:5px 12px;font-size:13px;font-weight:700;color:var(--text);text-shadow:0 1px 2px #000;white-space:nowrap}.shortcut-bar{position:absolute;top:0;left:0;right:0;z-index:6;text-align:center;font-size:11.5px;color:var(--muted);background:rgba(7,13,28,.72);border-bottom:1px solid rgba(125,155,215,.18);padding:3px 8px;pointer-events:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shortcut-bar b{color:var(--text)}.hud-top{position:absolute;top:28px;left:12px;right:12px;display:flex;align-items:center;gap:8px;pointer-events:none;z-index:5}.hud-btn{pointer-events:auto;cursor:pointer;padding:5px 9px}.hud-btn:hover{border-color:var(--red);color:var(--red)}.hud-top .turn-banner{color:var(--accent);border-color:rgba(255,177,61,.55);box-shadow:0 0 12px rgba(255,177,61,.25)}.hud-timer{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.hud-timer.danger{color:var(--red);border-color:var(--red);animation:hudpulse 1s infinite}@keyframes hudpulse{50%{opacity:.5}}.players-overlay{position:absolute;top:70px;right:12px;width:232px;display:flex;flex-direction:column;gap:5px;background:rgba(7,13,28,.62);border:1px solid rgba(125,155,215,.25);border-radius:12px;padding:9px 11px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:5;pointer-events:none}.kick-mini{pointer-events:auto;width:18px;height:18px;padding:0;font-size:11px;line-height:1;border-radius:5px;background:rgba(70,25,25,.85);border:1px solid rgba(255,93,93,.45);color:#ff9d96;flex-shrink:0}.kick-mini:hover{background:var(--red);color:#fff}.hp-row{display:flex;align-items:center;gap:7px;font-size:12.5px;text-shadow:0 1px 2px #000}.hp-row .hp-name{min-width:74px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hp-row .bar{flex:1 1;height:7px;background:rgba(0,0,0,.55);border-radius:5px;overflow:hidden}.hp-row .bar.lost-red{background:#a12626}.hp-row .bars{flex:1 1;display:flex;flex-direction:column;gap:2px}.hp-row .bars .bar{flex:none}.hp-row .shield-bar{height:4px}.hp-row .bar>div{height:100%;border-radius:5px;transition:width .5s ease}.spectate-banner{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:5;pointer-events:none;background:rgba(7,13,28,.8);border:1px solid var(--red);color:var(--red);border-radius:99px;padding:6px 18px;font-weight:700;font-size:14px}.controls{display:flex;gap:10px}.controls .group{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}.controls .value{color:var(--text);font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;min-width:36px;text-align:right;text-shadow:0 1px 2px #000}.controls.disabled .deck-row{opacity:.5;pointer-events:none}.control-deck{position:absolute;left:50%;transform:translateX(-50%);top:68px;z-index:6;flex-direction:column;align-items:stretch;gap:5px;background:rgba(7,13,28,.78);border:1px solid rgba(125,155,215,.35);border-radius:14px;padding:6px 12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 8px 26px rgba(0,0,0,.5);max-width:calc(100% - 620px)}.deck-row{gap:11px;justify-content:center;flex-wrap:wrap;row-gap:5px}.deck-row,.weapon-btn{display:flex;align-items:center}.weapon-btn{gap:4px;background:rgba(28,40,69,.85);border:1px solid var(--border);border-radius:9px;padding:3px 7px;font-size:12px}.weapon-btn .wicon{font-size:15px}.weapon-btn .wname{font-size:12px}.weapon-btn .wcount{color:var(--accent2);font-weight:800;font-size:11px}.weapon-btn.selected{border-color:var(--accent);background:rgba(255,177,61,.16);box-shadow:0 0 10px rgba(255,177,61,.35)}.deck-btn{background:rgba(28,40,69,.85);border:1px solid var(--border)}.deck-stat{font-size:12.5px;color:var(--text);font-weight:700;text-shadow:0 1px 2px #000}.deck-hint{font-size:11.5px;color:var(--muted);text-align:center}.fire-btn{min-width:86px;height:40px;border-radius:12px;font-size:15px;font-weight:900;letter-spacing:1px;background:linear-gradient(180deg,#ffae3d,#e0661c);color:#2a1404;border:1px solid #ffd089;box-shadow:0 4px 0 #93420f,0 8px 22px rgba(255,140,40,.35);-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none}.fire-btn:active:not(:disabled){transform:translateY(3px);box-shadow:0 1px 0 #93420f}.fire-btn:disabled{filter:grayscale(.85) brightness(.7)}.power-gauge{width:108px;height:13px;background:rgba(0,0,0,.55);border:1px solid var(--border);border-radius:7px;overflow:hidden;position:relative}.power-mark{position:absolute;top:0;bottom:0;width:2px;transform:translateX(-50%);background:#fff;box-shadow:0 0 5px rgba(255,255,255,.9),0 0 2px #000;pointer-events:none}.power-gauge>div{height:100%;background:linear-gradient(90deg,#3ddc84,#f1c40f 60%,#ff5d5d);transition:width .03s linear}.power-gauge>div.charging{box-shadow:0 0 8px rgba(255,177,61,.9)}.chat-overlay{position:absolute;left:12px;top:70px;z-index:7;display:flex;flex-direction:column;align-items:flex-start;gap:6px}.chat-toggle{width:38px;height:38px;border-radius:50%;background:rgba(7,13,28,.8);border:1px solid rgba(125,155,215,.35);font-size:15px}.chat-overlay .chat-box,.chat-toggle{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.chat-overlay .chat-box{width:290px;height:215px;background:rgba(7,13,28,.72);border:1px solid rgba(125,155,215,.3);border-radius:12px;padding:10px;display:flex}.chat-overlay .chat-line{font-size:12.5px;text-shadow:0 1px 2px #000}.leave-btn{position:absolute;top:10px;right:12px;z-index:8;width:36px;height:36px;border-radius:10px;background:rgba(7,13,28,.74);border:1px solid rgba(125,155,215,.35);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font-size:15px}.game-modal{background:rgba(4,8,18,.45);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.game-modal .card{background:rgba(18,27,47,.93);border-color:rgba(125,155,215,.4);box-shadow:0 24px 70px rgba(0,0,0,.65)}.shop-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:10px;gap:10px;margin:12px 0}.shop-item{background:var(--panel2);border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:6px}.shop-item .iname{font-weight:700}.shop-item .idesc{font-size:12px;color:var(--muted)}.shop-item .ifoot{display:flex;align-items:center;justify-content:space-between;margin-top:4px}.shop-item .cost{color:var(--accent);font-weight:700;font-size:14px}.owned{font-size:12px;color:var(--accent2)}.standings-table{width:100%;border-collapse:collapse;margin:12px 0;font-size:14px}.standings-table td,.standings-table th{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border)}.standings-table th{color:var(--muted);font-weight:600;font-size:12px}.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--red);color:#fff;border-radius:10px;padding:10px 18px;font-size:14px;z-index:200;box-shadow:0 6px 24px rgba(0,0,0,.5)}.conn-banner{background:rgba(255,93,93,.12);border:1px solid var(--red);color:var(--red);border-radius:8px;padding:6px 12px;font-size:13px;text-align:center}.muted{color:var(--muted)}.spacer{flex:1 1}img.gi{display:inline-block;vertical-align:-.18em;object-fit:contain}.logo-img,img.gi{-webkit-user-select:none;-moz-user-select:none;user-select:none}.logo-img{width:min(440px,80vw);height:auto;filter:drop-shadow(0 6px 18px rgba(255,177,61,.25))}.logo-img.small{width:200px}.login-page{background:linear-gradient(rgba(7,12,25,.55),rgba(7,12,25,.82)),url(/assets/ui/hero-bg.jpg) 50% /cover no-repeat fixed}.hud-chip{display:inline-flex;align-items:center;gap:6px}.deck-btn,.deck-stat{display:inline-flex;align-items:center;gap:3px}.shop-item .iname{display:flex;align-items:center;gap:7px}.conn-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--red);margin-left:5px;animation:hudpulse 1.2s infinite}.player-slot .tag{display:inline-flex;align-items:center;gap:3px}button{background:linear-gradient(180deg,#243353,#1a2645);border:1px solid rgba(125,155,215,.22);box-shadow:inset 0 1px 0 rgba(255,255,255,.07),0 2px 6px rgba(0,0,0,.35);transition:filter .12s,transform .08s,box-shadow .12s,border-color .12s}button:hover:not(:disabled){filter:brightness(1.15);border-color:rgba(125,155,215,.45);transform:translateY(-1px)}button:active:not(:disabled){transform:translateY(1px)}button:focus-visible{outline:2px solid var(--accent2);outline-offset:2px}button.primary{background:linear-gradient(180deg,#ffc063,#f09a26);border-color:#ffd089;color:#221302;box-shadow:inset 0 1px 0 rgba(255,255,255,.35),0 3px 10px rgba(255,160,50,.3)}button.blue{background:linear-gradient(180deg,#6cb4ff,#2f8aee);border-color:#8ec5ff;color:#04101f;box-shadow:inset 0 1px 0 rgba(255,255,255,.35),0 3px 10px rgba(60,140,240,.3)}button.danger{background:linear-gradient(180deg,#ff7a72,#e0443c);border-color:#ff9d96;box-shadow:inset 0 1px 0 rgba(255,255,255,.25),0 3px 10px rgba(230,70,60,.3)}input,select{transition:border-color .15s,box-shadow .15s}input:focus,select:focus{border-color:var(--accent2);box-shadow:0 0 0 3px rgba(77,163,255,.18)}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;background:linear-gradient(90deg,#2a3a5f,#3d5286);border:none;border-radius:4px;box-shadow:inset 0 1px 3px rgba(0,0,0,.5)}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:17px;height:17px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#ffd89a,var(--accent) 60%);border:1px solid #ffe2ae;box-shadow:0 0 8px rgba(255,177,61,.55),0 2px 4px rgba(0,0,0,.4);cursor:-webkit-grab;cursor:grab}input[type=range]:disabled::-webkit-slider-thumb{filter:grayscale(1) brightness(.7)}.card{background:linear-gradient(180deg,rgba(26,37,64,.96),rgba(17,25,45,.96));border:1px solid rgba(125,155,215,.2);box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 14px 40px rgba(0,0,0,.45)}.room-row{background:linear-gradient(180deg,rgba(32,45,78,.7),rgba(22,32,58,.7));transition:border-color .15s,transform .12s,box-shadow .15s}.room-row:hover{border-color:rgba(255,177,61,.5);transform:translateY(-1px);box-shadow:0 6px 18px rgba(0,0,0,.35)}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:backdrop-in .18s ease-out}.modal{animation:modal-in .22s cubic-bezier(.2,1.2,.4,1)}@keyframes backdrop-in{0%{opacity:0}}@keyframes modal-in{0%{opacity:0;transform:translateY(14px) scale(.97)}}.ready-pill.on{box-shadow:0 0 10px rgba(61,220,132,.35)}.player-slot{transition:border-color .15s}.player-slot:hover:not(.empty){border-color:rgba(125,155,215,.5)}.rank-row .pos{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.rank-row:nth-child(2) .pos{color:#ffd34d;text-shadow:0 0 8px rgba(255,211,77,.5)}.rank-row:nth-child(3) .pos{color:#c8d3e8}.rank-row:nth-child(4) .pos{color:#d29a6b}.weapon-btn{transition:border-color .12s,box-shadow .12s,transform .1s}.weapon-btn:hover:not(:disabled){transform:translateY(-1px)}.shop-item{background:linear-gradient(180deg,rgba(32,45,78,.75),rgba(22,32,58,.75));transition:border-color .15s,box-shadow .15s}.shop-item:hover{border-color:rgba(255,177,61,.45);box-shadow:0 4px 14px rgba(0,0,0,.3)}.fire-btn{background:radial-gradient(circle at 50% 25%,#ffc063 0,#f2861f 55%,#d9601a 100%)}.fire-btn.charging{animation:fire-charge .5s infinite;border-color:#fff1c4}@keyframes fire-charge{50%{box-shadow:0 4px 0 #93420f,0 0 26px rgba(255,190,60,.85);filter:brightness(1.18)}}.hit-flash{position:absolute;inset:0;z-index:9;pointer-events:none;background:radial-gradient(ellipse at center,transparent 38%,rgba(255,30,20,.42) 100%);animation:hit-fade .7s ease-out forwards}@keyframes hit-fade{0%{opacity:1}to{opacity:0}}.toast{animation:toast-in .25s cubic-bezier(.2,1.2,.4,1)}@keyframes toast-in{0%{opacity:0;transform:translateX(-50%) translateY(12px)}}.chat{width:100%;min-width:0;min-height:0}.chat-card{display:flex;min-height:300px;max-height:calc(100vh - 150px);max-height:calc(100dvh - 150px);overflow:hidden;align-self:start;position:-webkit-sticky;position:sticky;top:16px}.chat-log{min-height:0}.chat-input{width:100%;min-width:0}.chat-input input{border-radius:99px;padding-left:14px;flex:1 1;min-width:0;width:0}.chat-input button{border-radius:99px;flex-shrink:0}.chat-overlay .chat-box{overflow:hidden}h2.section{letter-spacing:-.02em}body,html{overflow-x:hidden}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:30px;background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238fa0c4' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center}button{display:inline-flex;align-items:center;justify-content:center;gap:5px;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none}img.gi{flex-shrink:0}.chat-line .who{gap:3px}.chat-line .who,.settings-list span{display:inline-flex;align-items:center}.settings-list span{gap:4px}input[type=range]::-moz-range-thumb{width:17px;height:17px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#ffd89a,var(--accent) 60%);border:1px solid #ffe2ae;cursor:grab}.page,.room-page{min-height:100vh;min-height:100dvh}.room-topbar{flex-wrap:wrap;min-width:0}.room-topbar b{max-width:40vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hud-top{flex-wrap:wrap;row-gap:6px}.players-overlay{max-height:58%;overflow-y:auto;pointer-events:auto}.control-deck{width:max-content}.deck-row,.deck-row.weapons{max-width:100%}.login-card{width:360px;max-width:calc(100vw - 40px)}.game-area{min-width:0}@media (max-width:1100px){.lobby{max-width:720px}.lobby,.room-main{grid-template-columns:1fr}.players-overlay{width:188px;font-size:11.5px;padding:7px 9px}.hp-row .hp-name{min-width:56px}.chat-overlay .chat-box{width:240px;height:175px}.control-deck{left:264px;right:208px;transform:none;max-width:none;padding:5px 9px}.deck-row{gap:8px}}.tank-style-row{display:flex;align-items:center;gap:7px;flex-wrap:wrap}.tank-style-btn{flex-direction:column;gap:3px;padding:7px 9px 5px;border-radius:10px;background:rgba(28,40,69,.7);border:1px solid var(--border)}.tank-style-btn img{width:52px;height:26px;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.6))}.tank-style-btn span{font-size:10.5px;color:var(--muted)}.tank-style-btn.selected{border-color:var(--accent);background:rgba(255,177,61,.14);box-shadow:0 0 10px rgba(255,177,61,.35)}.tank-style-btn.selected span{color:var(--accent);font-weight:700}@media (max-width:760px){.player-grid,.shop-grid{grid-template-columns:1fr}.hud-chip{font-size:11.5px;padding:4px 9px}.fire-btn{min-width:78px;height:46px;font-size:14px}.game-area{min-height:380px}}.game-layout{display:flex;gap:16px;align-items:flex-start;justify-content:center;padding:16px;width:100%;max-width:1500px;margin:0 auto}.game-left{display:flex;flex-direction:column;gap:10px;align-items:center}.own-panel{display:flex;gap:12px;align-items:flex-start}.own-side{gap:10px;width:120px}.own-side,.side-box{display:flex;flex-direction:column}.side-box{background:var(--panel,#131c31);border:1px solid rgba(140,160,200,.15);border-radius:10px;padding:10px;gap:4px;align-items:center}.side-label{font-size:11px;letter-spacing:.08em;color:#8fa0c4;text-transform:uppercase}.side-stat{font-size:13px}.side-stat.big{font-size:22px;font-weight:800}.side-box.keys{font-size:11px;color:#aab8d6;align-items:flex-start}.pending-count{font-size:26px;font-weight:900;color:#9fb0d0}.pending-count.hot{color:#ff6b6b;animation:pulse-red .9s ease-in-out infinite}@keyframes pulse-red{0%,to{transform:scale(1)}50%{transform:scale(1.18)}}.own-board-wrap{position:relative;border:3px solid #4a5a7a;border-radius:14px;padding:4px;background:#0c1322;box-shadow:0 8px 30px rgba(0,0,0,.45)}.own-board{width:240px;height:480px;line-height:0}.own-board canvas{display:block}.board-overlay{position:absolute;inset:0;display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center;background:rgba(8,12,24,.66);border-radius:12px;z-index:5}.countdown{font-size:72px;font-weight:900;color:#ffd166;text-shadow:0 4px 18px rgba(0,0,0,.6)}.dead-label{font-size:28px;font-weight:900;color:#ff6b6b}.touch-row{display:flex;gap:8px;justify-content:center}.touch-row button{width:52px;height:44px;font-size:18px;border-radius:10px;touch-action:none}@media (hover:hover) and (pointer:fine){.touch-row{display:none}}.opp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(132px,1fr));grid-gap:10px;gap:10px;width:460px;max-width:40vw}.mini-board{background:#101829;border:2px solid #44506b;border-radius:10px;padding:6px;display:flex;flex-direction:column;gap:4px}.mini-board.dead{opacity:.75}.mini-head{display:flex;align-items:center;gap:6px;min-height:18px}.mini-name{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1}.mini-conn{font-size:10px;color:#ff9f43}.mini-pending{font-size:11px;font-weight:800;background:#5b2330;color:#ff8a8a;border-radius:8px;padding:1px 6px}.mini-grid{position:relative;display:grid;grid-template-columns:repeat(6,1fr);grid-gap:1px;gap:1px;aspect-ratio:1/2;background:#0b1120;border-radius:6px;padding:2px}.mini-cell{border-radius:3px;background:rgba(140,160,200,.06)}.mini-dead-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(8,12,24,.7);border-radius:6px;font-size:13px;font-weight:800}.mini-foot{display:flex;justify-content:space-between;font-size:10px;color:#8fa0c4}.next-piece{display:flex;flex-direction:column;gap:3px;align-items:center;padding:4px 0}.next-cell{border-radius:6px;box-shadow:inset -2px -3px 0 rgba(0,0,0,.25),inset 2px 3px 0 rgba(255,255,255,.25)}.game-chat{width:280px;height:540px;display:flex}.game-chat .chat{height:100%}.result-backdrop{z-index:60}.result-modal{min-width:520px}.result-winner{font-size:20px;font-weight:900;text-align:center;color:#ffd166;margin:4px 0 12px}.result-table{width:100%;border-collapse:collapse;font-size:14px}.result-table td,.result-table th{padding:7px 10px;text-align:center;border-bottom:1px solid rgba(140,160,200,.12)}.result-table th{color:#8fa0c4;font-size:12px;font-weight:600}.result-table tr.first td{color:#ffd166;font-weight:800}@media (max-width:1100px){.game-layout{flex-wrap:wrap}.opp-grid{width:100%;max-width:none;grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.game-chat{width:100%;height:220px}}.login-page{background:linear-gradient(rgba(7,12,25,.35),rgba(7,12,25,.8)),url(/assets/ui/hero-bg.jpg) 50% /cover no-repeat fixed}.chat-col{position:relative;min-height:380px;min-width:0}.chat-col .chat-card{position:absolute;inset:0;align-self:stretch;display:flex;min-height:0;max-height:none;overflow:hidden}.mini-cell{transition:background-color .13s ease}