*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #070b14;--bg2: #0d1526;--bg3: #111d33;--border: #1e3a5f;--accent: #00d4ff;--accent2: #ff6b35;--alert: #e0556a;--alert-deep: #3a2026;--gold: #f0c040;--text: #c8d8f0;--text-dim: #5a7090;--fed-color: #2a6dd9;--zeon-color:#d92a2a;--green: #2a9d4e;--hp-green: #4caf50;--font-hud: "Orbitron", sans-serif;--font-body: "Rajdhani", sans-serif;--board-w: max(1200px, calc(100vh * 6 / 7));--card-w: min(10.35vh, calc((var(--board-w) - 100px) / 8.9));--card-h: calc(var(--card-w) * 176 / 126);--card-w-sm: 60px;--card-h-sm: 85px;--slot-w: 120px;--slot-h: 160px;--radius: 6px;--unit-w: var(--card-w);--unit-h: var(--card-h);--log-w: 220px}html,body,#root{height:100%;font-family:var(--font-body);background:var(--bg);color:var(--text);overflow:hidden}.app{height:100vh;display:flex;flex-direction:column;overflow:auto}.error-toast{position:fixed;top:16px;left:50%;transform:translate(-50%);background:#7b1111;border:1px solid #f44336;color:#fff;padding:10px 24px;border-radius:6px;font-family:var(--font-hud);font-size:12px;z-index:9999;animation:slideDown .2s ease;max-width:400px;text-align:center}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.lobby{flex:1;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 20% 20%,rgba(42,109,217,.15) 0%,transparent 60%),radial-gradient(ellipse at 80% 80%,rgba(217,42,42,.1) 0%,transparent 60%),var(--bg);overflow-y:auto}.lobby-content{width:100%;max-width:520px;display:flex;flex-direction:column;gap:28px;padding:32px 20px}.lobby-logo{text-align:center}.logo-main{font-family:var(--font-hud);font-size:42px;font-weight:900;letter-spacing:6px;background:linear-gradient(135deg,var(--accent),#fff 50%,var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none}.logo-sub{font-family:var(--font-hud);font-size:11px;letter-spacing:4px;color:var(--text-dim);margin-top:4px}.lobby-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;overflow:hidden}.auth-strip{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;color:var(--text)}.auth-loading{color:var(--text-dim);justify-content:center}.auth-out{justify-content:center}.patreon-btn{display:inline-flex;align-items:center;gap:8px;background:#ff424d;color:#fff;text-decoration:none;font-weight:700;padding:8px 16px;border-radius:8px;font-size:13px;transition:filter .15s}.patreon-btn:hover{filter:brightness(1.08)}.auth-hint{color:var(--text-dim);font-size:11px}.auth-in{justify-content:flex-start}.auth-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:1px solid var(--border);flex:none}.auth-avatar-fallback{display:inline-flex;align-items:center;justify-content:center;background:#ff424d;color:#fff;font-weight:700;text-transform:uppercase}.auth-name{flex:1}.auth-logout{background:transparent;border:1px solid var(--border);color:var(--text-dim);border-radius:6px;padding:4px 10px;font-size:12px;cursor:pointer}.auth-logout:hover{color:var(--text);border-color:var(--text-dim)}.form-input[readonly]{opacity:.85;cursor:default}.nick-panel{padding:14px 16px;border-bottom:1px solid var(--border)}.nick-label{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim);margin-bottom:8px}.nick-row{display:flex;align-items:center;gap:8px}.nick-input{flex:1;margin:0}.nick-save{width:auto;padding:0 16px;height:40px;white-space:nowrap}.nick-value{font-size:18px;font-weight:700;color:var(--text);flex:1}.nick-pill{font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px}.nick-reserved{color:#2fd07a;border:1px solid rgba(47,208,122,.5);background:#2fd07a1a}.nick-change,.nick-cancel{background:transparent;border:1px solid var(--border);color:var(--text-dim);border-radius:6px;padding:5px 12px;font-size:12px;cursor:pointer}.nick-change:hover,.nick-cancel:hover{color:var(--text);border-color:var(--text-dim)}.nick-cancel{margin-top:10px}.nick-status{margin-top:7px;font-size:12px;min-height:16px}.nick-good{color:#2fd07a}.nick-err{color:#ff6b6b}.nick-dim{color:var(--text-dim)}.nick-warn{margin-top:10px;padding:8px 10px;border-radius:6px;font-size:12px;color:#ffce6b;background:#ffce6b14;border:1px solid rgba(255,206,107,.3);line-height:1.4}.nick-warn b{color:#ffce6b}.history-bar{padding:10px 16px;border-bottom:1px solid var(--border)}.history-toggle{background:transparent;border:none;color:var(--text-dim);font-size:12px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;padding:2px 0}.history-toggle:hover{color:var(--text)}.history-empty{color:var(--text-dim);font-size:12px;padding:8px 2px}.history-list{list-style:none;margin:8px 0 2px;padding:0;max-height:220px;overflow-y:auto}.history-row{display:flex;align-items:center;gap:10px;padding:6px 2px;border-top:1px solid rgba(255,255,255,.05);font-size:13px}.history-badge{font-family:var(--font-hud);font-size:11px;font-weight:700;width:42px;text-align:center;padding:2px 0;border-radius:4px}.history-badge.is-win{color:#2fd07a;background:#2fd07a1f;border:1px solid rgba(47,208,122,.4)}.history-badge.is-loss{color:#ff6b6b;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.35)}.history-opp{flex:1;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-when{color:var(--text-dim);font-size:12px}.history-replay{flex:none;background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text-dim);font-size:11px;padding:2px 8px;cursor:pointer;transition:all .15s;white-space:nowrap}.history-replay:hover{color:#fff;border-color:var(--fed-color);background:#2a6dd92e}.lobby-footer{margin-top:16px;padding:0 6px 8px;text-align:center;color:var(--text-dim);font-size:11px;line-height:1.5;max-width:520px}.lobby-footer b{color:var(--text)}.unit .unit-foot,.unit .unit-top,.unit .unit-kw-row,.unit .unit-status,.hc-foot,.hc-lv,.hc-cost{display:none!important}.unit-img,.hand-img{opacity:1}.fly-cardback{background:linear-gradient(150deg,#16335c,#0c1b33 60%,#0a1428);border:1px solid #2a4d80}.fly-cardback:after{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:5px;border:1px solid rgba(120,160,220,.35)}.turn-flash{position:absolute;top:0;right:0;bottom:0;left:0;z-index:200;pointer-events:none;overflow:hidden;border-radius:6px;--flash: 150, 225, 255;animation:turn-glow .86s ease-out forwards}.turn-flash-mine{--flash: 110, 220, 255}.turn-flash-opp{--flash: 255, 140, 140}.turn-flash:before{content:"";position:absolute;top:-25%;bottom:-25%;left:-45%;width:34%;background:linear-gradient(100deg,rgba(var(--flash),0),rgba(var(--flash),.18) 38%,#fffffff2,rgba(var(--flash),.18) 62%,rgba(var(--flash),0));transform:skew(-16deg);filter:blur(1px);animation:turn-sweep .86s cubic-bezier(.35,0,.15,1) forwards}@keyframes turn-sweep{0%{left:-45%;opacity:0}12%{opacity:1}86%{opacity:1}to{left:128%;opacity:0}}@keyframes turn-glow{0%{background:rgba(var(--flash),0);box-shadow:inset 0 0 rgba(var(--flash),0)}22%{background:rgba(var(--flash),.07);box-shadow:inset 0 0 70px rgba(var(--flash),.42)}to{background:rgba(var(--flash),0);box-shadow:inset 0 0 rgba(var(--flash),0)}}.deck-select-wrap{position:relative}.deck-select-wrap:after{content:"";position:absolute;right:15px;top:50%;transform:translateY(-50%);width:0;height:0;pointer-events:none;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid #8fa3bf}.deck-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;width:100%;padding-right:34px}.deck-select option{background:var(--bg2);color:var(--text)}.deck-select optgroup{background:var(--bg2);color:var(--text-dim);font-style:normal}.deck-select-placeholder{color:var(--text-dim)}.deck-builder-bar{display:flex;gap:10px;margin:6px 0 2px}.deck-build-btn,.deck-edit-btn{background:transparent;border:1px dashed var(--border);color:var(--text-dim);border-radius:7px;padding:5px 10px;font-size:12px;cursor:pointer;transition:all .15s}.deck-build-btn:hover,.deck-edit-btn:hover{color:var(--accent);border-color:var(--accent)}.deck-builder-modal{position:relative;max-width:560px;width:100%;background:linear-gradient(180deg,#182231,#10161f);border:1px solid var(--border);border-radius:14px;padding:22px 24px;box-shadow:0 18px 50px #000000b3;display:flex;flex-direction:column;gap:8px;max-height:90vh;overflow-y:auto}.deck-textarea{font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:13px;line-height:1.5;resize:vertical;white-space:pre;overflow-wrap:normal;overflow-x:auto}.deck-builder-status{min-height:22px;display:flex;flex-direction:column;gap:4px;font-size:12px}.deck-count{font-family:var(--font-hud)}.deck-count.ok{color:var(--hp-green)}.deck-count.bad{color:#ffb454}.deck-ok{color:var(--hp-green)}.deck-err,.deck-errors{color:#ff7b7b}.deck-errors{margin:0;padding-left:16px;list-style:disc}.deck-errors li{margin:1px 0}.deck-builder-actions{display:flex;align-items:center;gap:10px;margin-top:6px}.deck-builder-spacer{flex:1}.deck-delete{background:#3a2026;border:1px solid #e0556a;color:#ffd9df;border-radius:7px;padding:7px 12px;cursor:pointer;font-size:13px}.deck-delete:hover{background:#4d2a32}.deck-record-row{display:flex;align-items:center;gap:10px;margin-top:4px;font-size:12px}.deck-record-label{color:var(--text-dim)}.deck-reset{margin-left:auto;background:transparent;border:1px solid var(--border);color:var(--text-dim);border-radius:7px;padding:5px 10px;cursor:pointer;font-size:12px}.deck-reset:hover{color:var(--gold);border-color:var(--gold)}.deck-reset.confirm{color:#ffd9df;border-color:#e0556a;background:#3a2026}.disclaimer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9600;display:flex;align-items:center;justify-content:center;padding:16px;background:#04080eb3;animation:preview-in .15s ease-out}.disclaimer-modal{position:relative;max-width:560px;width:100%;background:linear-gradient(180deg,#182231,#10161f);border:1px solid var(--border);border-radius:14px;padding:24px 26px;box-shadow:0 18px 50px #000000b3}.disclaimer-close{position:absolute;top:12px;right:14px;background:transparent;border:none;color:var(--text-dim);font-size:22px;line-height:1;cursor:pointer}.disclaimer-close:hover{color:var(--text)}.disclaimer-title{font-family:var(--font-hud);font-size:20px;font-weight:700;color:#eaf6ff;margin-bottom:14px}.disclaimer-body p{color:var(--text);font-size:14px;line-height:1.55;margin:0 0 12px}.disclaimer-body b{color:#eaf6ff}.disclaimer-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px;flex-wrap:wrap}.disclaimer-wait,.disclaimer-accept{font-family:var(--font-hud);cursor:pointer;border-radius:8px;padding:10px 18px;font-size:14px;border:1px solid var(--border)}.disclaimer-wait{background:transparent;color:var(--text-dim)}.disclaimer-wait:hover{color:var(--text);border-color:var(--text-dim)}.disclaimer-accept{background:#c43d3d;border-color:#c43d3d;color:#fff;font-weight:700}.disclaimer-accept:hover{filter:brightness(1.08)}.lobby-gate{padding:18px 16px;text-align:center;color:var(--text-dim);font-size:13px}.play-as{font-size:13px;color:var(--text);padding:4px 0 10px}.play-as b{color:var(--accent)}.tab-bar{display:flex;border-bottom:1px solid var(--border)}.tab-btn{flex:1;padding:12px;background:transparent;border:none;color:var(--text-dim);font-family:var(--font-hud);font-size:11px;letter-spacing:2px;cursor:pointer;transition:all .2s}.tab-btn.active{color:var(--accent);background:#00d4ff0f;border-bottom:2px solid var(--accent)}.tab-btn:hover:not(.active){background:#ffffff0a}.lobby-form{display:flex;flex-direction:column;gap:12px;padding:24px}.form-label{font-family:var(--font-hud);font-size:10px;letter-spacing:2px;color:var(--text-dim)}.form-input{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-body);font-size:15px;padding:10px 14px;outline:none;transition:border-color .2s}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--text-dim)}.code-input{font-family:var(--font-hud);letter-spacing:4px;text-transform:uppercase}.btn-primary{background:linear-gradient(135deg,#1a4a8a,#2a6dd9);border:1px solid var(--fed-color);border-radius:var(--radius);color:#fff;font-family:var(--font-hud);font-size:12px;letter-spacing:2px;padding:12px;cursor:pointer;transition:all .2s;margin-top:4px}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#2a5aaa,#3a7de9);box-shadow:0 0 16px #2a6dd966}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{background:linear-gradient(135deg,#2a2f3a,#3a4250);border:1px solid var(--border);border-radius:var(--radius);color:#cdd6e4;font-family:var(--font-hud);font-size:12px;letter-spacing:2px;padding:12px;cursor:pointer;transition:all .2s;margin-top:8px;width:100%}.btn-secondary:hover:not(:disabled){background:linear-gradient(135deg,#353b48,#465061);box-shadow:0 0 12px #788cb440}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.lobby-rules{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:20px 24px}.rules-title{font-family:var(--font-hud);font-size:10px;letter-spacing:3px;color:var(--text-dim);margin-bottom:14px}.rules-grid{display:flex;flex-direction:column;gap:10px}.rule-item{display:flex;gap:12px;align-items:flex-start;font-size:13px;color:var(--text);line-height:1.4}.rule-icon{font-size:16px;flex-shrink:0}.waiting-screen{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg)}.waiting-content{text-align:center;display:flex;flex-direction:column;gap:20px;align-items:center}.logo-text{font-family:var(--font-hud);font-size:28px;font-weight:900;letter-spacing:6px;color:var(--accent)}.waiting-room-code{font-family:var(--font-body);font-size:16px;color:var(--text-dim)}.room-code{font-family:var(--font-hud);font-size:32px;font-weight:700;color:var(--gold);letter-spacing:8px;display:block;margin-top:8px;text-shadow:0 0 20px rgba(240,192,64,.4)}.waiting-hint{color:var(--text-dim);font-size:14px}.waiting-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.replay-bar{position:fixed;bottom:10px;left:50%;transform:translate(-50%);z-index:9000;display:flex;align-items:center;gap:14px;padding:7px 16px;background:#0d1526eb;border:1px solid var(--border);border-radius:10px;box-shadow:0 6px 20px #00000080;font-family:var(--font-hud);font-size:12px}.replay-tag{color:var(--accent);letter-spacing:2px}.replay-result{color:var(--text-dim)}.replay-exit{background:transparent;border:1px solid var(--border);color:var(--text-dim);border-radius:7px;padding:5px 12px;cursor:pointer;font-size:12px}.replay-exit:hover{color:var(--accent);border-color:var(--accent)}.waiting-cancel{margin-top:22px;background:transparent;border:1px solid var(--border);color:var(--text-dim);border-radius:8px;padding:9px 22px;font-size:14px;cursor:pointer;font-family:var(--font-hud);letter-spacing:1px;transition:all .15s}.waiting-cancel:hover{color:#ff9aa6;border-color:#e0556a;background:#e0556a14}.over-screen{flex:1;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,rgba(42,109,217,.2) 0%,transparent 70%),var(--bg)}.over-content{text-align:center;display:flex;flex-direction:column;gap:20px;align-items:center}.over-title{font-family:var(--font-hud);font-size:52px;font-weight:900;letter-spacing:4px;background:linear-gradient(135deg,var(--gold),#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.over-detail{font-size:18px;color:var(--text-dim)}.over-abandon{margin-top:-10px;font-family:var(--font-hud);font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);opacity:.85}.board{display:flex;flex:none}.board-loading{display:flex;align-items:center;justify-content:center;height:100%;font-family:var(--font-hud);color:var(--text-dim)}.panel-log{width:var(--log-w);flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.panel-title{font-family:var(--font-hud);font-size:9px;letter-spacing:3px;color:var(--text-dim);padding:10px 12px;border-bottom:1px solid var(--border);background:var(--bg3)}.log-entries{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:3px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.log-entry{font-size:11px;color:var(--text);line-height:1.5;padding:3px 6px;border-radius:3px;word-break:break-word}.log-entry:nth-child(odd){background:#ffffff05}.board-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;background:radial-gradient(ellipse at 50% 0%,rgba(42,109,217,.08) 0%,transparent 50%),radial-gradient(ellipse at 50% 100%,rgba(217,42,42,.06) 0%,transparent 50%),var(--bg)}.player-bar{display:flex;align-items:center;justify-content:space-between;padding:6px 16px;background:var(--bg2);border-bottom:1px solid var(--border);gap:12px;flex-shrink:0;transition:border-color .3s}.player-bar-mine{border-top:1px solid var(--border);border-bottom:none}.player-bar-active{border-color:var(--accent);box-shadow:0 0 8px #00d4ff26}.player-name{font-family:var(--font-hud);font-size:11px;letter-spacing:1px;color:var(--text);white-space:nowrap}.player-stats{display:flex;align-items:center;gap:16px}.stat-pill{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-dim)}.shields-display{display:flex;gap:4px;align-items:center}.shield-pip{width:14px;height:18px;border-radius:3px;transition:all .3s}.shield-pip-active{background:linear-gradient(135deg,#1a5fa8,var(--accent));box-shadow:0 0 6px #00d4ff80}.shield-pip-broken{background:#1a1a2a;border:1px solid #333;opacity:.4}.energy-display{display:flex;flex-direction:column;align-items:center;gap:1px}.energy-label{font-family:var(--font-hud);font-size:7px;letter-spacing:1px;color:var(--text-dim)}.energy-value{font-family:var(--font-hud);font-size:13px;color:var(--text-dim)}.energy-mine{color:var(--gold)}.hand-area{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 12px;flex-shrink:0;overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent;min-height:calc(var(--card-h-sm) + 12px)}.hand-area-opp{border-bottom:1px solid var(--border);min-height:calc(var(--card-h-sm) + 12px)}.hand-area-mine{border-top:1px solid var(--border);min-height:calc(var(--card-h) + 16px)}.empty-hand-msg{font-size:12px;color:var(--text-dim);font-style:italic}.field-area{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden}.field-section{display:flex;flex-direction:column;gap:8px;align-items:center}.field-area-opp .field-section{flex-direction:column-reverse}.field-row{display:flex;gap:10px;align-items:center;justify-content:center}.battle-zone{display:flex;align-items:center;gap:12px;padding:4px 16px;flex-shrink:0}.battle-zone-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent)}.phase-badge{font-family:var(--font-hud);font-size:9px;letter-spacing:2px;color:var(--accent);white-space:nowrap;padding:3px 10px;border:1px solid rgba(0,212,255,.3);border-radius:20px;background:#00d4ff0d}.unit-slot{width:var(--slot-w);height:var(--slot-h);border-radius:8px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;position:relative;overflow:hidden;flex-shrink:0}.unit-slot-empty{background:#ffffff05;border-style:dashed}.unit-slot-empty:hover{border-color:#00d4ff66;background:#00d4ff0a}.slot-empty-label{font-family:var(--font-hud);font-size:8px;letter-spacing:2px;color:var(--text-dim);opacity:.5}.unit-slot-filled{background:linear-gradient(160deg,#0d1f3c,#091428);border-color:var(--fed-color)}.unit-slot-opp.unit-slot-filled{border-color:var(--zeon-color);background:linear-gradient(160deg,#2a0d0d,#1a0808)}.unit-slot-selected{border-color:var(--gold)!important;box-shadow:0 0 14px #f0c04080}.unit-slot-valid-target{border-color:var(--accent2)!important;box-shadow:0 0 12px #ff6b3580;animation:pulse-target 1s ease-in-out infinite}@keyframes pulse-target{0%,to{box-shadow:0 0 12px #ff6b3580}50%{box-shadow:0 0 22px #ff6b35cc}}.unit-slot-tapped{opacity:.6}.unit-card-inner{width:100%;height:100%;padding:6px;display:flex;flex-direction:column;gap:3px}.unit-pilot-badge{position:absolute;top:4px;right:4px;background:var(--gold);color:#000;font-family:var(--font-hud);font-size:8px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}.unit-shield-badge{position:absolute;top:4px;left:4px;background:#00d4ff33;border:1px solid var(--accent);color:var(--accent);font-family:var(--font-hud);font-size:7px;padding:1px 3px;border-radius:2px}.unit-name{font-size:10px;font-weight:600;color:var(--text);line-height:1.2;margin-top:18px;text-align:center}.unit-stats-row{display:flex;justify-content:center;margin:2px 0}.unit-power{font-family:var(--font-hud);font-size:13px;color:var(--accent);font-weight:700}.unit-hp-bar-wrap{height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden;margin:2px 0}.unit-hp-bar{height:100%;border-radius:2px;transition:width .4s ease,background .4s ease}.unit-hp-text{font-family:var(--font-hud);font-size:9px;color:var(--text-dim);text-align:center}.unit-tapped-label{font-family:var(--font-hud);font-size:8px;letter-spacing:1px;color:var(--accent2);text-align:center;margin-top:auto}.card{width:var(--card-w);height:var(--card-h);border-radius:8px;border:1.5px solid var(--card-border, var(--border));background:var(--card-bg, var(--bg3));box-shadow:0 0 8px #00000080;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;padding:7px;position:relative;flex-shrink:0;-webkit-user-select:none;user-select:none}.card:hover{transform:translateY(-4px);box-shadow:0 0 16px var(--card-glow, rgba(0,212,255,.3))}.card-selected{border-color:var(--gold)!important;box-shadow:0 0 18px #f0c04099!important;transform:translateY(-8px)!important}.card-playable{border-color:var(--accent)}.card-playable:not(.card-selected):hover{box-shadow:0 0 14px #00d4ff66}.card-sm{width:var(--card-w-sm);height:var(--card-h-sm);padding:4px}.card-hidden{background:linear-gradient(135deg,#0d1a2d,#1a2a40);border-color:var(--border);cursor:default}.card-hidden:hover{transform:none;box-shadow:none}.card-back-pattern{width:100%;height:100%;border-radius:4px;background:repeating-linear-gradient(45deg,rgba(0,212,255,.05) 0px,rgba(0,212,255,.05) 1px,transparent 1px,transparent 8px),repeating-linear-gradient(-45deg,rgba(0,212,255,.05) 0px,rgba(0,212,255,.05) 1px,transparent 1px,transparent 8px);display:flex;align-items:center;justify-content:center;color:var(--text-dim);font-family:var(--font-hud);font-size:7px;letter-spacing:1px}.card-back-pattern:after{content:"GUNDAM"}.card-series{position:absolute;top:4px;right:4px;font-family:var(--font-hud);font-size:7px;letter-spacing:1px;color:var(--card-border, var(--text-dim));opacity:.8}.card-name{font-size:10px;font-weight:600;color:var(--text);line-height:1.2;margin-top:2px;padding-left:26px;min-height:26px;word-break:break-word;flex-shrink:0}.card-sm .card-name{padding-left:18px;min-height:0}.card-sm .card-name{font-size:8px}.card-cost{position:absolute;top:4px;left:4px;width:20px;height:20px;border-radius:50%;background:#0009;border:1px solid var(--card-border, var(--border));display:flex;align-items:center;justify-content:center;font-family:var(--font-hud);font-size:10px;font-weight:700;color:var(--gold)}.card-sm .card-cost{width:15px;height:15px;font-size:8px}.card-type-tag{font-family:var(--font-hud);font-size:7px;letter-spacing:1.5px;color:var(--card-border, var(--text-dim));margin-top:2px;padding-left:26px;opacity:.9}.card-sm .card-type-tag{padding-left:18px}.card-stats{flex:1;display:flex;flex-direction:column;justify-content:flex-end;gap:4px}.stat-block{display:flex;align-items:baseline;gap:3px}.stat-label{font-family:var(--font-hud);font-size:7px;letter-spacing:1px;color:var(--text-dim)}.stat-value{font-family:var(--font-hud);font-size:13px;font-weight:700;color:var(--text)}.stat-sep{width:1px;height:14px;background:var(--border);align-self:flex-end}.shield-badge{font-family:var(--font-hud);font-size:7px;color:var(--accent);border:1px solid var(--accent);border-radius:2px;padding:1px 3px;margin-top:2px;align-self:flex-start}.card-desc{font-size:10px;color:var(--text-dim);line-height:1.3;flex:1;display:flex;align-items:flex-end}.card-desc.small{font-size:8px}.card-trait{font-size:9px;color:var(--text-dim);font-style:italic;margin-top:auto;padding-top:3px;border-top:1px solid rgba(255,255,255,.06)}.action-bar{padding:8px 16px;background:var(--bg2);border-top:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-shrink:0;flex-wrap:wrap}.action-hint{flex:1;font-size:12px;color:var(--text-dim);font-style:italic;min-width:0}.action-buttons{display:flex;gap:8px;flex-shrink:0}.waiting-turn{justify-content:center;color:var(--text-dim);font-size:13px;font-style:italic}.btn-phase,.btn-end-turn,.btn-direct{font-family:var(--font-hud);font-size:10px;letter-spacing:1px;padding:8px 16px;border-radius:var(--radius);border:1px solid;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-phase{background:linear-gradient(135deg,#0d2a4a,#1a4a7a);border-color:var(--fed-color);color:var(--accent)}.btn-phase:hover{background:linear-gradient(135deg,#1a3a5a,#2a5a8a);box-shadow:0 0 12px #2a6dd966}.btn-end-turn{background:linear-gradient(135deg,#1a0d0d,#3a1a1a);border-color:#555;color:var(--text-dim)}.btn-end-turn:hover{border-color:#888;color:var(--text)}.btn-direct{background:linear-gradient(135deg,#3a1a00,#7a3a00);border-color:var(--accent2);color:var(--accent2);animation:pulse-direct 1.5s ease-in-out infinite}@keyframes pulse-direct{0%,to{box-shadow:0 0 6px #ff6b3566}50%{box-shadow:0 0 16px #ff6b35b3}}.btn-direct:hover{background:linear-gradient(135deg,#5a2a00,#9a5a00)}.card-art{padding:0;overflow:hidden;position:relative}.card-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}.card-art .card-ov-top,.card-art .card-ov-bot{position:absolute;left:0;right:0;z-index:2;padding:4px 5px}.card-art .card-ov-top{top:0;display:flex;justify-content:space-between;background:linear-gradient(to bottom,rgba(0,0,0,.75),transparent)}.card-art .card-ov-bot{bottom:0;background:linear-gradient(to top,rgba(0,0,0,.88) 60%,transparent)}.ov-lv,.ov-cost{font-family:var(--font-hud);font-size:10px;font-weight:700;padding:1px 4px;border-radius:3px;background:#0009}.ov-lv{color:var(--accent)}.ov-cost{color:var(--gold)}.ov-name{font-size:9.5px;font-weight:600;color:#fff;line-height:1.15;text-shadow:0 1px 3px #000;margin-bottom:2px}.ov-stats{display:flex;gap:4px}.ov-ap,.ov-hp{font-family:var(--font-hud);font-size:9px;font-weight:700;padding:0 3px;border-radius:2px}.ov-ap{background:#ff6b35d9;color:#fff}.ov-hp{background:#4caf50d9;color:#fff}.ov-type{font-family:var(--font-hud);font-size:7px;letter-spacing:1.5px;color:var(--accent)}.card-sm .ov-name,.card-sm .ov-lv,.card-sm .ov-cost{font-size:8px}.card-sm .ov-ap,.card-sm .ov-hp{font-size:7.5px}.card.art-failed{background:var(--bg3)}.unit-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:top;z-index:0;opacity:.92;border-radius:6px}.unit>*:not(.unit-img){position:relative;z-index:1}.unit-top,.unit-name2,.unit-kw-row,.unit-bottom{text-shadow:0 1px 3px #000}.unit .unit-foot{position:absolute;left:0;right:0;bottom:0;z-index:1;background:linear-gradient(to top,rgba(0,0,0,.93) 82%,rgba(0,0,0,.72) 96%,transparent);border-radius:0 0 6px 6px;padding:6px 6px 5px}.unit-name2{background:none;padding:0}.unit-bottom{background:none;padding:0;margin-top:2px}.card-lv{position:absolute;top:4px;left:4px;font-family:var(--font-hud);font-size:8px;font-weight:700;color:var(--accent);background:#00000080;border:1px solid var(--card-border, var(--border));border-radius:3px;padding:1px 3px}.card-cost{top:22px;left:4px;background:#0009;color:var(--gold)}.card-sm .card-cost{top:18px}.card-apnhp{display:flex;gap:4px;margin-top:auto}.ap-chip,.hp-chip{font-family:var(--font-hud);font-size:9px;font-weight:700;padding:1px 4px;border-radius:3px}.ap-chip{background:#ff6b352e;color:var(--accent2);border:1px solid rgba(255,107,53,.4)}.hp-chip{background:#4caf502e;color:var(--hp-green);border:1px solid rgba(76,175,80,.4)}.card-keywords{display:flex;flex-wrap:wrap;gap:3px;margin-top:4px}.kw-badge{font-family:var(--font-hud);font-size:6.5px;letter-spacing:.5px;color:var(--accent);border:1px solid rgba(0,212,255,.4);border-radius:2px;padding:1px 3px}.card-text{font-size:8.5px;color:var(--text-dim);line-height:1.25;margin-top:4px;overflow:hidden}.battle-area{flex:1;display:flex;align-items:center;justify-content:center;gap:10px;padding:8px 16px;overflow-x:auto;min-height:150px}.battle-area-opp{align-items:flex-start}.battle-area-mine{align-items:flex-end}.area-attackable{cursor:crosshair;background:#ff6b350d;border:1px dashed rgba(255,107,53,.3);border-radius:8px}.empty-field{font-size:13px;color:var(--text-dim);font-style:italic;opacity:.7}.unit{width:var(--unit-w);height:var(--unit-h);flex-shrink:0;border-radius:8px;border:2px solid var(--unit-border, var(--border));background:var(--unit-bg, #0d1f3c);padding:7px;display:flex;flex-direction:column;cursor:pointer;position:relative;transition:all .15s}.unit-blue{--unit-bg: linear-gradient(160deg,#0d1f3c,#091428);--unit-border: #2a6dd9}.unit-red{--unit-bg: linear-gradient(160deg,#2a0d0d,#1a0808);--unit-border: #d9402a}.unit-green{--unit-bg: linear-gradient(160deg,#0d2d1a,#081a10);--unit-border: #2a9d4e}.unit-white{--unit-bg: linear-gradient(160deg,#23262d,#15171b);--unit-border: #b8c4d8}.unit-purple{--unit-bg: linear-gradient(160deg,#1f0d2d,#120818);--unit-border: #9d2ad9}.unit:hover{transform:translateY(-3px);box-shadow:0 0 14px #00000080}.unit-rested{transform:rotate(8deg) scale(.94)}.unit-rested:hover{transform:rotate(8deg) scale(.96) translateY(-2px)}.unit-can-attack{border-color:#3ddc84;box-shadow:0 0 8px #3ddc848c}.unit-attacker{border-color:var(--gold)!important;box-shadow:0 0 16px #f0c04099!important;transform:translateY(-6px)!important}.unit-target{border-color:var(--gold)!important;animation:pulse-target-gold 1s ease-in-out infinite}@keyframes pulse-target-gold{0%,to{box-shadow:0 0 12px #f0c0408c}50%{box-shadow:0 0 22px #f0c040d9}}.unit-top{display:flex;gap:4px;align-items:center;min-height:14px;flex-wrap:wrap}.unit-pilot{font-size:8px;color:var(--gold);background:#f0c0401f;border-radius:3px;padding:0 3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:90px}.unit-link-badge{font-family:var(--font-hud);font-size:7px;font-weight:700;color:#000;background:var(--gold);border-radius:2px;padding:0 3px}.unit-name2{font-size:11px;font-weight:600;color:var(--text);line-height:1.15;margin-top:3px;flex:none;align-self:flex-start}.unit-kw-row{display:flex;gap:3px;flex-wrap:wrap;margin:2px 0}.unit-kw{font-family:var(--font-hud);font-size:6.5px;color:var(--accent);border:1px solid rgba(0,212,255,.4);border-radius:2px;padding:0 2px}.unit-bottom{display:flex;align-items:center;gap:6px;margin-top:4px}.unit-ap{font-family:var(--font-hud);font-size:13px;font-weight:700;color:var(--accent2)}.unit-hp-wrap{flex:1;height:5px;background:#ffffff1a;border-radius:3px;overflow:hidden}.unit-hp-fill{height:100%;border-radius:3px;transition:width .4s}.unit-hp-num{font-family:var(--font-hud);font-size:10px;color:var(--text)}.unit-status{position:absolute;bottom:4px;right:6px;display:flex;gap:3px;font-size:11px}.status-rested{color:var(--accent2)}.resource-display{display:flex;align-items:center;gap:5px}.res-label{font-family:var(--font-hud);font-size:7px;color:var(--text-dim);letter-spacing:1px}.res-pips{display:flex;gap:2px;flex-wrap:wrap;max-width:120px}.res-pip{width:8px;height:12px;border-radius:2px}.res-active{background:linear-gradient(135deg,#caa028,var(--gold));box-shadow:0 0 4px #f0c04080}.res-rested{background:#333;border:1px solid #555;transform:rotate(20deg)}.res-count{font-family:var(--font-hud);font-size:12px;color:var(--text-dim)}.res-mine{color:var(--gold)}.ex-res{color:var(--accent);font-size:9px}.base-card{border:1px solid var(--accent);border-radius:4px;padding:3px 8px;background:#00d4ff14;text-align:center;min-width:70px}.base-name{font-size:9px;color:var(--accent);font-weight:600;white-space:nowrap}.base-hp{font-family:var(--font-hud);font-size:9px;color:var(--hp-green)}.base-empty{border-color:#333;background:transparent;color:var(--text-dim);opacity:.5}.base-empty .base-name{color:var(--text-dim)}.block-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:5000;animation:slideDown .2s ease}.block-modal{background:var(--bg2);border:1px solid var(--accent);border-radius:12px;padding:28px 32px;max-width:480px;box-shadow:0 0 40px #00d4ff4d;text-align:center}.block-title{font-family:var(--font-hud);font-size:20px;color:var(--accent);letter-spacing:2px;margin-bottom:8px}.block-sub{font-size:13px;color:var(--text-dim);margin-bottom:18px}.block-options{display:flex;flex-direction:column;gap:8px}.block-choice,.block-pass{font-family:var(--font-hud);font-size:12px;padding:11px 18px;border-radius:6px;cursor:pointer;transition:all .15s}.block-choice{background:linear-gradient(135deg,#0d2a4a,#1a4a7a);border:1px solid var(--accent);color:var(--accent)}.block-choice:hover{box-shadow:0 0 14px #00d4ff66}.block-pass{background:transparent;border:1px solid #555;color:var(--text-dim)}.block-pass:hover{border-color:#888;color:var(--text)}.card-preview{position:fixed;z-index:9500;pointer-events:none;border:2px solid var(--accent);border-radius:12px;background:var(--bg2);box-shadow:0 12px 48px #000000bf,0 0 24px #00d4ff40;overflow:hidden;animation:preview-in .12s ease-out}.card-preview img{width:100%;height:100%;object-fit:contain;display:block}@keyframes preview-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}:root{--c-blue: #2a6dd9;--c-red: #d9402a;--c-green: #2a9d4e;--c-white: #b8c4d8;--c-purple: #9d2ad9;--zcol: calc(var(--card-w) + 12px);--shield-col: calc(var(--card-h) + 8px);--battle-col: calc(var(--card-w) * 6 + 56px)}.board-mat{flex-direction:column;height:100vh;width:var(--board-w);margin:0 auto;overflow:hidden;gap:4px;padding:4px 8px;background:radial-gradient(ellipse at 50% 0%,rgba(217,64,42,.06),transparent 45%),radial-gradient(ellipse at 50% 100%,rgba(42,109,217,.07),transparent 45%),var(--bg)}.mat{flex:1;min-height:0;position:relative;display:grid;grid-template-columns:var(--zcol) 1fr var(--zcol);grid-template-rows:auto minmax(0,1fr) auto;gap:4px}.mat-mine{grid-template-columns:minmax(var(--shield-col),1fr) var(--battle-col) minmax(var(--shield-col),1fr);grid-template-rows:minmax(0,.95fr) minmax(0,.05fr) minmax(0,.5fr) minmax(0,.5fr) auto;grid-template-areas:"base    battle deck" "shields battle deck" "shields battle trash" "shields battle trash" "shields resource endturn"}.mat-opp{grid-template-columns:minmax(var(--shield-col),1fr) var(--battle-col) minmax(var(--shield-col),1fr);grid-template-rows:auto minmax(0,.5fr) minmax(0,.5fr) minmax(0,.05fr) minmax(0,.95fr);grid-template-areas:"resource resource shields" "trash    battle   shields" "trash    battle   shields" "deck     battle   shields" "deck     battle   base"}.zone-base{grid-area:base}.zone-shields{grid-area:shields}.zone-battle{grid-area:battle}.zone-deck{grid-area:deck}.zone-trash{grid-area:trash}.zone-resdeck{grid-area:resdeck}.zone-resource{grid-area:resource}.zone-endturn{grid-area:endturn;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--alert);border-radius:5px;background:radial-gradient(ellipse at center,#14080bd9,#14080b59 62%,#14080b00),repeating-linear-gradient(45deg,var(--alert) 0 12px,var(--alert-deep) 12px 24px);color:#fff;font-family:var(--font-hud);font-weight:800;font-size:12px;letter-spacing:3px;text-transform:uppercase;text-shadow:0 1px 2px #000,0 0 8px rgba(0,0,0,.9);cursor:pointer;transition:border-color .15s,box-shadow .15s,filter .15s;box-shadow:0 2px 6px #00000080}.zone-endturn .endturn-label{position:relative}.zone-endturn:hover:not(:disabled){border-color:#ffd9df;box-shadow:0 0 14px 1px #e0556aa6,0 2px 6px #00000080;filter:brightness(1.12)}.zone-endturn:disabled{opacity:.4;cursor:default;filter:grayscale(.55) brightness(.8)}.zone-endturn.enemy-turn,.zone-endturn.enemy-turn:disabled{background:linear-gradient(160deg,#14171d,#0d0f13);border-color:#2a2f38;color:#6a7180;text-shadow:none;filter:none;opacity:1;box-shadow:inset 0 1px #ffffff05,0 2px 6px #00000080}.zone-endturn.highlight{animation:endturn-pulse 1.15s ease-in-out infinite}@keyframes endturn-pulse{0%,to{box-shadow:0 0 #e0556a00;border-color:var(--alert)}50%{box-shadow:0 0 16px 2px #e0556ad9;border-color:#ffd9df}}.zone{position:relative;border:1px solid var(--border);border-radius:5px;background:#ffffff04;min-height:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.zone-label{position:absolute;top:3px;left:6px;font-family:var(--font-hud);font-size:7.5px;letter-spacing:1.5px;color:var(--text-dim);z-index:3;pointer-events:none;display:flex;align-items:center;gap:4px}.zone-hint{font-size:10px;color:var(--text-dim);font-style:italic;opacity:.6}.zone-battle{grid-area:battle;background:#00d4ff06;border-color:#244a6e;overflow:visible}.battle-units{width:100%;height:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 8px 22px;overflow:visible}.unit .unit-pilot-card{position:absolute;left:3%;right:3%;bottom:calc(var(--card-h) * var(--pilot-peek, -.26));height:var(--card-h);z-index:0;overflow:hidden;border-radius:5px;border:2px solid var(--unit-border, var(--border));box-shadow:0 4px 8px #0009}.unit-pilot-card img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.zone-attackable{cursor:crosshair;border-color:var(--accent2);box-shadow:inset 0 0 14px #ff6b3540;animation:pulse-target 1.1s ease-in-out infinite}.mini-card{width:var(--card-w);height:var(--card-h);border-radius:4px;border:1px solid var(--accent);background:#00d4ff14;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:3px;text-align:center}.base-mini{border-color:var(--accent);position:relative;overflow:hidden;padding:0;gap:0;justify-content:flex-end}.mini-empty{border-style:dashed;border-color:#2a3a50;color:var(--text-dim);background:transparent}.mini-art{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}.mini-art-ex{display:flex;align-items:center;justify-content:center;font-family:var(--font-hud);font-weight:700;font-size:16px;letter-spacing:1px;color:var(--accent);background:#00d4ff1a}.dmg-die{position:absolute;top:6px;right:6px;z-index:3;width:35.7%;aspect-ratio:1;padding:9%;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:6%;background:linear-gradient(150deg,rgba(var(--die-rgb, 244,244,247),.7),rgba(var(--die-rgb, 244,244,247),.5));border:1px solid rgba(0,0,0,.25);border-radius:16%;box-shadow:0 3px 6px #00000073,inset 0 1px 2px #ffffff8c;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.unit .dmg-die{position:absolute}.die-one{grid-column:1 / 4;grid-row:1 / 4;width:100%;height:100%;object-fit:contain;opacity:.82;transform:scale(1.22);filter:var(--die-one-filter, none)}.die-cell{border-radius:50%}.die-cell.pip{background:radial-gradient(circle at 35% 30%,rgba(var(--die-ink, 18,18,22),.92),rgba(var(--die-ink, 18,18,22),.78) 75%);box-shadow:inset 0 0 1px #0006}.die-num{grid-column:1 / 4;grid-row:1 / 4;display:flex;align-items:center;justify-content:center;font-family:var(--font-hud);font-weight:800;color:rgba(var(--die-ink, 18,18,22),.95);font-size:calc(var(--card-w) * .22)}.die-swatches{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}.die-swatch{width:26px;height:26px;border-radius:6px;cursor:pointer;border:1px solid rgba(255,255,255,.25);padding:0;box-shadow:inset 0 1px 2px #ffffff4d}.die-swatch.sel{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}.mini-name{font-size:8px;color:var(--accent);font-weight:600;line-height:1.1;text-shadow:0 1px 2px #000}.mini-hp{font-family:var(--font-hud);font-size:10px;font-weight:700;color:var(--hp-green);text-shadow:0 1px 3px #000,0 0 2px #000}.shield-stack{position:relative;height:100%;width:var(--card-h);--sh: var(--card-w);--pad: 14px;--pad-b: 10px}.shield-card{position:absolute;left:0;right:0;height:var(--sh);top:calc(var(--pad) + (100% - var(--pad) - var(--pad-b) - var(--sh)) * var(--i, 0));border-radius:5px;box-shadow:0 -2px 6px #0009}.stack-count{position:absolute;bottom:-2px;right:-2px;font-family:var(--font-hud);font-size:10px;font-weight:700;color:#fff;background:#000000b3;border-radius:8px;padding:0 5px;z-index:4}.pile{position:relative;display:flex;align-items:center;justify-content:center}.pile-card{width:var(--card-w);height:var(--card-h);border-radius:4px;background:repeating-linear-gradient(45deg,#0d1a2d,#0d1a2d 4px,#122440 4px,#122440 8px);border:1px solid var(--border)}.trash-card{background:repeating-linear-gradient(45deg,#2a1010,#2a1010 4px,#401818 4px,#401818 8px);border-color:#5a2a2a}.trash-pile{min-width:var(--card-w);min-height:var(--card-h);border:1px dashed #3a2020;border-radius:4px}.trash-top{object-fit:cover;border:1px solid var(--border);background:#0d1526}.trash-top-token{display:flex;align-items:center;justify-content:center;text-align:center;font-size:10px;color:var(--text);padding:4px}.res-card-back{width:44px;height:62px;background:repeating-linear-gradient(45deg,#2a2410,#2a2410 4px,#403818 4px,#403818 8px);border-color:#5a4f2a}.resource-row{width:100%;height:100%;display:flex;align-items:center;gap:3px;padding:18px 10px 12px;flex-wrap:wrap;position:relative}.res-token{width:14px;height:20px;border-radius:2px;flex-shrink:0}.res-token-active{background:linear-gradient(135deg,#caa028,var(--gold));box-shadow:0 0 4px #f0c04080}.res-token-rested{background:#2a2a1a;border:1px solid #5a5030;transform:rotate(18deg)}.res-token-ex{background:linear-gradient(135deg,#0a8fb0,var(--accent));border:1px solid var(--accent);box-shadow:0 0 6px #00d4ffa6}.res-summary{position:absolute;top:3px;right:16px;font-family:var(--font-hud);font-size:9px;color:var(--gold)}.reconnect-banner{position:fixed;top:0;left:0;right:0;z-index:6000;text-align:center;padding:6px;background:#d9402aeb;color:#fff;font-family:var(--font-hud);font-size:11px;letter-spacing:1px}.opp-topbar{flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center;min-height:34px;overflow:visible}.opp-topbar .mat-header-opp{position:absolute;left:46px;top:50%;transform:translateY(-50%);z-index:6;padding:0}.opp-hand{flex:1;min-width:0;display:flex;align-items:flex-start;justify-content:center;gap:5px;height:26px;padding:0 8px;position:relative;overflow:visible;z-index:5}.opp-hand-card{width:var(--card-w);height:var(--card-h);margin-top:calc(26px - var(--card-h));border-radius:0 0 7px 7px;border:1.5px solid var(--border);border-top:none;background:repeating-linear-gradient(45deg,#0d1a2d,#0d1a2d 4px,#122440 4px,#122440 8px);box-shadow:0 3px 8px #0009;flex-shrink:0}.topbar-right{position:fixed;top:8px;right:8px;z-index:7000;display:flex;align-items:center;gap:10px}.opp-hand-count{font-family:var(--font-hud);font-size:10px;color:var(--text-dim);white-space:nowrap}.mat-header{display:flex;align-items:center;gap:10px;padding:2px 6px;flex-shrink:0;font-size:12px}.turn-dot{width:8px;height:8px;border-radius:50%;background:#2a3a50}.turn-dot.on{background:var(--accent);box-shadow:0 0 8px var(--accent)}.mat-player{font-family:var(--font-hud);font-size:11px;color:var(--text);letter-spacing:1px}.mat-meta{font-size:11px;color:var(--text-dim)}.mat-actions{margin-left:auto;display:flex;gap:6px}.chess-clock{font-family:var(--font-hud);font-size:12px;font-weight:700;color:var(--text-dim);padding:1px 7px;border-radius:10px;border:1px solid var(--border)}.chess-clock.clock-running{color:var(--text);border-color:var(--accent);box-shadow:0 0 6px #00d4ff66}.chess-clock.clock-low{color:#ff7a5e;border-color:var(--zeon-color)}.chess-clock.clock-running.clock-low{box-shadow:0 0 8px #d9402a99;animation:clock-pulse 1s ease-in-out infinite}@keyframes clock-pulse{0%,to{opacity:1}50%{opacity:.55}}.setup-timer{font-family:var(--font-hud);font-size:13px;color:var(--text-dim);margin-bottom:12px}.setup-countdown{font-family:var(--font-hud);font-size:56px;font-weight:700;color:var(--zeon-color);line-height:1;margin-bottom:14px;text-shadow:0 0 18px rgba(217,64,42,.6);animation:countdown-pop 1s ease-in-out infinite}@keyframes countdown-pop{0%,to{transform:scale(1)}50%{transform:scale(1.18)}}.centerline{flex-shrink:0;height:1px;background:linear-gradient(90deg,transparent,var(--alert),transparent);display:flex;align-items:center;justify-content:center;margin:2px 0;position:relative}.centerline-badge{position:absolute;z-index:1;font-family:var(--font-hud);font-size:8.5px;letter-spacing:2px;color:var(--alert);background:var(--bg);padding:1px 12px;border:1px solid rgba(224,85,106,.4);border-radius:12px}.centerline-progress{position:absolute;left:0;right:0;height:3px;display:none;background:linear-gradient(90deg,transparent,var(--alert) 16%,var(--alert) 84%,transparent);transform-origin:center;box-shadow:0 0 6px #e0556a8c;pointer-events:none}.centerline-progress.centerline-flash{animation:centerline-flash .5s ease-in-out infinite}@keyframes centerline-flash{0%,to{opacity:1;box-shadow:0 0 6px #e0556a99}50%{opacity:.2;box-shadow:0 0 14px #e0556a}}.aim-overlay{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:8500;overflow:visible}.aim-line{fill:none;stroke:var(--accent);stroke-width:2.5;stroke-dasharray:9 7;stroke-linecap:round;filter:url(#aimGlow);opacity:.92;animation:aim-dash .55s linear infinite}@keyframes aim-dash{to{stroke-dashoffset:-16}}.aim-reticle{fill:none;stroke:var(--accent);stroke-width:2;filter:url(#aimGlow)}.aim-ring{opacity:.9}.aim-ring-inner{opacity:.5}.aim-tick{stroke:var(--accent);stroke-width:2}.aim-dot{fill:var(--accent);stroke:none;filter:none}.aim-sweep line{stroke:var(--accent);stroke-width:2;opacity:.75}.aim-locked .aim-line,.aim-locked .aim-reticle,.aim-locked .aim-tick,.aim-locked .aim-sweep line{stroke:var(--accent2)}.aim-locked .aim-dot{fill:var(--accent2)}.hint-strip{flex-shrink:0;text-align:center;font-size:11px;color:var(--text-dim);font-style:italic;padding:1px 0}.hand-strip{flex-shrink:0;display:flex;align-items:flex-end;justify-content:center;gap:5px;padding:4px 8px;min-height:calc(var(--card-h) + 8px);overflow-x:auto}.hand-strip-setup{position:relative;z-index:5001}.hand-card{position:relative;width:var(--card-w);height:var(--card-h);border-radius:7px;border:1.5px solid var(--clr, var(--border));background:var(--bg3);overflow:hidden;flex-shrink:0;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 2px 6px #00000080;touch-action:none;user-select:none;-webkit-user-select:none}.hand-card:hover{transform:translateY(-6px);box-shadow:0 0 14px color-mix(in srgb,var(--clr) 50%,transparent)}.hand-sel{border-color:var(--gold)!important;box-shadow:0 0 16px #f0c04099!important;transform:translateY(-10px)!important}.hand-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}.hc-lv,.hc-cost{position:absolute;top:3px;z-index:2;font-family:var(--font-hud);font-size:11px;font-weight:700;padding:1px 4px;border-radius:3px;background:#000000b3}.hc-lv{left:3px;color:var(--accent)}.hc-cost{right:3px;color:var(--gold)}.hc-foot{position:absolute;left:0;right:0;bottom:0;z-index:2;background:linear-gradient(to top,rgba(0,0,0,.92) 75%,transparent);border-radius:0 0 7px 7px;padding:4px 5px 5px}.hc-name{font-size:11px;font-weight:600;color:#fff;text-align:left;line-height:1.15;text-shadow:0 1px 3px #000}.hc-stats{display:flex;justify-content:flex-start;gap:4px;margin-top:2px}.hc-ap,.hc-hp{font-family:var(--font-hud);font-size:11px;font-weight:700;font-style:normal;padding:0 4px;border-radius:2px;color:#fff}.hc-ap{background:#ff6b35e6}.hc-hp{background:#4caf50e6}.setup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:5000;pointer-events:none;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(ellipse at 50% 42%,#04080e57,#04080e99);animation:preview-in .18s ease-out}.setup-panel{pointer-events:auto;background:linear-gradient(180deg,#141c28f7,#0e141ef7);border:1px solid var(--accent);border-radius:14px;padding:26px 32px;max-width:540px;width:100%;text-align:center;box-shadow:0 0 50px #00d4ff38,0 18px 50px #0009}.setup-title{font-family:var(--font-hud);font-size:22px;letter-spacing:3px;color:var(--accent);margin-bottom:14px}.setup-text{font-size:15px;color:var(--text);margin-bottom:18px}.setup-text b{color:var(--gold)}.setup-hint{font-size:12px;color:var(--text-dim);margin-top:14px}.setup-hint-decided{color:var(--accent);font-weight:600}.opp-mull-toast{position:fixed;top:16px;left:50%;transform:translate(-50%);background:linear-gradient(180deg,#141c28f7,#0e141ef7);border:1px solid var(--accent);color:var(--accent);padding:9px 22px;border-radius:8px;font-family:var(--font-hud);font-size:12px;letter-spacing:1px;z-index:9999;box-shadow:0 0 18px #00d4ff40;animation:slideDown .2s ease}.setup-actions{display:flex;gap:12px;justify-content:center}.setup-btn{font-family:var(--font-hud);font-size:13px;letter-spacing:1px;padding:12px 26px;border-radius:8px;cursor:pointer;background:transparent;border:1px solid var(--border);color:var(--text);transition:all .15s}.setup-btn:hover{border-color:var(--accent);color:var(--accent)}.setup-btn.primary{background:linear-gradient(135deg,#0d2a4a,#1a4a7a);border-color:var(--accent);color:#fff}.setup-btn.primary:hover{box-shadow:0 0 16px #00d4ff80;color:#fff}.gear-btn{position:fixed;top:8px;left:8px;z-index:7000;width:30px;height:30px;border-radius:6px;background:#0d1526d9;border:1px solid var(--border);color:var(--text-dim);font-size:16px;line-height:1;cursor:pointer;transition:all .15s}.gear-btn:hover{color:var(--accent);border-color:var(--accent);transform:rotate(45deg)}.mock-wrench-btn{position:fixed;bottom:8px;left:8px;z-index:7000;width:30px;height:30px;border-radius:6px;background:#0d1526d9;border:1px dashed var(--accent);color:var(--accent);font-size:15px;line-height:1;cursor:pointer;transition:all .15s}.mock-wrench-btn:hover{background:#00d4ff24}.mock-tools-panel{position:fixed;bottom:44px;left:8px;z-index:7000;display:flex;flex-direction:column;gap:8px;padding:12px;width:160px;background:#0d1526f2;border:1px solid var(--border);border-radius:8px;box-shadow:0 6px 20px #00000080}.mock-flash-btn{height:30px;padding:0 12px;border-radius:6px;background:#0d1526d9;border:1px dashed var(--accent);color:var(--accent);font-family:var(--font-hud);font-size:11px;letter-spacing:1px;cursor:pointer;transition:all .15s}.mock-flash-btn:hover{background:#00d4ff24}.settings-panel{position:fixed;top:44px;left:8px;z-index:7000;width:230px;padding:14px;background:var(--bg2);border:1px solid var(--accent);border-radius:8px;box-shadow:0 6px 24px #00000080}.settings-title{font-family:var(--font-hud);font-size:12px;letter-spacing:2px;color:var(--accent);margin-bottom:12px}.settings-row{display:flex;justify-content:space-between;align-items:baseline;font-size:12px;color:var(--text);margin-bottom:6px}.settings-val{font-family:var(--font-hud);color:var(--gold)}.settings-slider{width:100%;accent-color:var(--accent);cursor:pointer}.settings-hint{font-size:10px;color:var(--text-dim);margin-top:6px}.settings-concede{width:100%;margin-top:14px;font-family:var(--font-hud);font-size:11px;letter-spacing:1px;padding:9px;border-radius:6px;cursor:pointer;background:#d9402a1f;border:1px solid var(--zeon-color);color:#ff7a5e;transition:all .15s}.settings-concede:hover{background:#d9402a40;color:#fff}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:8000;display:flex;align-items:center;justify-content:center;background:#000000b8}.confirm-modal{background:var(--bg2);border:1px solid var(--zeon-color);border-radius:12px;padding:26px 30px;max-width:380px;text-align:center;box-shadow:0 0 40px #d9402a4d}.confirm-title{font-family:var(--font-hud);font-size:18px;letter-spacing:1px;color:#ff7a5e;margin-bottom:10px}.confirm-text{font-size:13px;color:var(--text-dim);margin-bottom:20px}.confirm-actions{display:flex;gap:10px;justify-content:center}.confirm-yes,.confirm-no{font-family:var(--font-hud);font-size:12px;letter-spacing:1px;padding:10px 22px;border-radius:7px;cursor:pointer;transition:all .15s}.confirm-yes{background:linear-gradient(135deg,#7a1f12,#d9402a);border:1px solid var(--zeon-color);color:#fff}.confirm-yes:hover{box-shadow:0 0 16px #d9402a99}.confirm-no{background:transparent;border:1px solid var(--border);color:var(--text)}.confirm-no:hover{border-color:var(--text-dim)}.is-dragging{cursor:grabbing}.is-dragging *{cursor:grabbing!important}.hand-dragging{opacity:.25}.drag-ghost{position:fixed;z-index:9000;pointer-events:none;transform:translate(-50%,-55%) rotate(-4deg) scale(1.12);filter:drop-shadow(0 12px 18px rgba(0,0,0,.7))}.drag-ghost .hand-card{box-shadow:0 0 22px color-mix(in srgb,var(--clr) 60%,transparent);border-color:var(--gold)}.zone-drop-glow{border-color:var(--gold)!important;box-shadow:inset 0 0 20px #f0c04038;animation:drop-glow 1.2s ease-in-out infinite}.zone-drop-active{border-color:var(--gold)!important;background:#f0c0401f!important;box-shadow:inset 0 0 28px #f0c04073;animation:none}@keyframes drop-glow{0%,to{box-shadow:inset 0 0 14px #f0c0402e}50%{box-shadow:inset 0 0 26px #f0c04066}}.unit-drop-glow{outline:2px dashed var(--gold);outline-offset:-3px}.unit-drop-active{outline:2px solid var(--gold);outline-offset:-2px;box-shadow:0 0 16px #f0c040b3!important}.log-toggle{height:30px;padding:0 12px;border-radius:6px;background:#0d1526d9;border:1px solid var(--border);color:var(--text-dim);font-family:var(--font-hud);font-size:11px;letter-spacing:1px;cursor:pointer;transition:all .15s}.log-toggle:hover{color:var(--accent);border-color:var(--accent)}.log-drawer{position:fixed;top:0;right:0;z-index:6900;width:300px;max-width:80vw;height:100vh;overflow-y:auto;background:var(--bg2);border-left:1px solid var(--border);box-shadow:-8px 0 24px #00000080;padding:48px 14px 14px;transform:translate(100%);transition:transform .25s ease}.log-drawer.open{transform:translate(0)}.log-drawer .log-entry{font-size:12px;line-height:1.5;padding:2px 0;border-bottom:1px solid rgba(255,255,255,.04)}.player-stats{flex-wrap:wrap;justify-content:flex-end;row-gap:4px}.battle-area{flex-wrap:wrap}@media (max-width: 560px){.battle-units{gap:4px;flex-wrap:nowrap}.mat-header{font-size:10px;gap:6px}.mat-player{font-size:9px}.hint-strip{font-size:10px}.btn-direct,.btn-end-turn{font-size:9px;padding:6px 9px}.block-modal{margin:12px;padding:20px;max-width:calc(100vw - 24px)}.block-title{font-size:16px}.logo-main{font-size:30px;letter-spacing:3px}.lobby-content{padding:20px 14px;gap:18px}}@media (hover: none){.card:hover,.unit:hover{transform:none}.unit-rested:hover{transform:rotate(8deg) scale(.94)}}.choice-banner{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9200;display:flex;flex-direction:column;align-items:center;gap:6px;background:linear-gradient(180deg,#141c28f7,#0e141ef7);border:2px solid var(--accent);border-radius:12px;padding:9px 16px;box-shadow:0 6px 22px #0009,0 0 14px #00d4ff59;font-family:var(--font-hud);max-width:92vw;pointer-events:none;animation:preview-in .14s ease-out}.choice-banner .choice-skip{pointer-events:auto}.choice-prompt{color:#eaf6ff;font-weight:600;font-size:14px}.choice-hint{color:var(--text-dim);font-size:12px}.choice-skip,.choice-opt-item,.choice-card-item{font-family:var(--font-hud);cursor:pointer;border-radius:8px;border:1px solid var(--border);background:#1b2433;color:var(--text)}.choice-skip{padding:5px 12px}.choice-skip:hover{background:#26344a}.board.is-choosing .hand-strip{opacity:.85}.unit-choice-target{cursor:pointer}.unit-choice-target{animation:pulse-target-gold 1s ease-in-out infinite}.hand-choice{outline:2px solid var(--accent);outline-offset:1px;cursor:pointer;box-shadow:0 0 12px #00d4ff99;animation:pulse-target-gold 1.1s ease-in-out infinite}.choice-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9300;display:flex;align-items:center;justify-content:center;background:#04080e8c}.choice-modal{background:linear-gradient(180deg,#182231,#10161f);border:2px solid var(--accent);border-radius:14px;padding:18px 20px;box-shadow:0 14px 40px #000000b3,0 0 18px #00d4ff4d;max-width:90vw;max-height:84vh;overflow:auto;text-align:center}.choice-title{font-family:var(--font-hud);color:#eaf6ff;font-weight:600;margin-bottom:14px;font-size:15px}.choice-items{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.choice-opt-item{padding:10px 16px;font-size:14px}.choice-opt-item:hover{background:#26344a;border-color:var(--accent)}.choice-card-item{display:flex;flex-direction:column;align-items:center;gap:4px;width:104px;padding:8px;position:relative}.choice-card-item img{width:88px;border-radius:6px;display:block}.choice-card-item:hover{border-color:var(--accent);box-shadow:0 0 10px #00d4ff80}.choice-card-name{font-size:11px;line-height:1.15;color:var(--text)}.choice-card-stats{font-size:11px;color:var(--gold)}.choice-empty{color:var(--text-dim);padding:8px}.choice-modal .choice-skip{margin-top:14px}.zone-trash-clickable{cursor:pointer}.trash-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9300;display:flex;align-items:center;justify-content:center;padding:20px;background:#04080e9e;animation:preview-in .14s ease-out}.trash-modal{display:flex;flex-direction:column;max-width:92vw;max-height:88vh;padding:14px 16px;background:linear-gradient(180deg,#182231,#10161f);border:1px solid var(--border);border-radius:12px;box-shadow:0 16px 44px #000000b3}.trash-modal-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px;flex:none}.trash-modal-title{font-family:var(--font-hud);font-size:14px;color:#eaf6ff;letter-spacing:1px}.trash-close{background:transparent;border:none;color:var(--text-dim);font-size:22px;line-height:1;cursor:pointer}.trash-close:hover{color:var(--text)}.trash-grid{display:grid;grid-template-columns:repeat(5,var(--card-w));gap:10px;overflow-y:auto;min-height:0;padding:2px 4px 2px 2px}.trash-card-item{width:var(--card-w);height:var(--card-h);border-radius:6px;overflow:hidden;border:1px solid var(--border);background:#0d1526;cursor:pointer;display:flex;align-items:center;justify-content:center}.trash-card-item img{width:100%;height:100%;object-fit:cover;display:block}.trash-card-name{font-size:11px;color:var(--text);text-align:center;padding:4px}.trash-empty{grid-column:1 / -1;color:var(--text-dim);padding:24px;text-align:center}.opp-hand-card,.deck-pile .pile-card,.fly-cardback{background-image:url(/cardback.png)!important;background-size:cover!important;background-position:center!important;background-repeat:no-repeat!important;background-color:#0d1a2d}.fly-cardback:after{display:none}.shield-card{background:#0d1a2d!important;overflow:hidden}.shield-card:before{content:"";position:absolute;top:50%;left:50%;width:var(--card-w);height:var(--card-h);transform:translate(-50%,-50%) rotate(90deg);background:url(/cardback.png) center / cover no-repeat}.unit-abilities{position:absolute;left:2px;right:2px;top:50%;transform:translateY(-50%);z-index:6;display:flex;flex-direction:column;gap:3px;align-items:stretch;pointer-events:none}.unit-ability-btn{pointer-events:auto;font-family:var(--font-hud);font-size:9px;line-height:1.1;padding:3px 4px;border-radius:5px;cursor:pointer;background:linear-gradient(180deg,#0a8fb0,#066b86);color:#eaf6ff;border:1px solid var(--accent);box-shadow:0 1px 4px #00000080;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unit-ability-btn:hover:not(:disabled){background:linear-gradient(180deg,#11a8c8,#0a8fb0)}.unit-ability-btn:disabled{background:linear-gradient(180deg,#2a3340,#20262f);color:#6f7d8c;border-color:#3a4654;cursor:not-allowed;box-shadow:none}.base-abilities{display:flex;flex-direction:column;gap:2px;margin-top:3px}.base-abilities .unit-ability-btn{font-size:8px;padding:2px 3px}.base-mini .base-abilities{position:absolute;top:2px;left:2px;right:2px;z-index:2;margin-top:0}.base-mini.base-rested{opacity:.7}.base-activatable{cursor:pointer;border-color:var(--gold);animation:pulse-target-gold 1.3s ease-in-out infinite}.base-activatable:hover{box-shadow:0 0 14px #ffc83ca6}.response-bar{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9200;display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center;max-width:94vw;background:linear-gradient(180deg,#28181cf7,#1c1014f7);border:2px solid #e0556a;border-radius:12px;padding:8px 16px;box-shadow:0 6px 22px #0009,0 0 14px #e0556a66;font-family:var(--font-hud)}.response-title{color:#ffd9df;font-weight:600;font-size:14px}.response-bar-waiting{animation:resp-wait-pulse 1.3s ease-in-out infinite}.response-bar-waiting .response-title:before{content:"⏳";margin-right:7px;font-weight:400}@keyframes resp-wait-pulse{0%,to{opacity:.8}50%{opacity:1}}.response-hint{color:var(--text-dim);font-size:11px;flex-basis:100%;text-align:center}.response-block,.response-pass{font-family:var(--font-hud);cursor:pointer;border-radius:8px;padding:6px 13px;font-size:13px;border:1px solid #e0556a;background:#3a2026;color:#ffd9df}.response-block:hover{background:#4d2a32}.response-pass{background:#1b2433;border-color:var(--border);color:var(--text)}.response-pass:hover{background:#26344a}.hand-action{outline:2px solid #e0556a;outline-offset:1px;cursor:pointer;box-shadow:0 0 12px #e0556a99}.unit-token .unit-token-art{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-hud);font-size:12px;letter-spacing:2px;color:#ffffff59;background:repeating-linear-gradient(45deg,rgba(255,255,255,.04) 0 8px,transparent 8px 16px)}.unit-token{--unit-border: var(--border)}
