@keyframes countdown-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}*,::after,::before{box-sizing:border-box;margin:0;padding:0}#app,body{height:100vh}body{font-family:"Segoe UI",system-ui,-apple-system,sans-serif;background:#0b0e14;color:#d0d4dc;overflow:hidden}#app{display:flex;flex-direction:column}#topbar{display:flex;align-items:center;gap:20px;padding:12px 24px;background:#141820;border-bottom:1px solid #1e2636;flex-shrink:0}#topbar h1{font-size:18px;font-weight:600}#topbar h1 a{color:#8ba4c4;text-decoration:none}#btn-login,#topbar nav a{font-size:13px;transition:all .15s}#topbar nav a{color:#607090;text-decoration:none;padding:4px 8px;border-radius:4px}#topbar nav a:hover{color:#c4d0e4;background:#1a2030}.spacer,main{flex:1}.user-area{display:flex;align-items:center;gap:8px}#btn-login{background:#2a5090;border:1px solid #3a6abf;color:#e0eaff;padding:7px 18px;border-radius:5px;cursor:pointer}#btn-login:hover{background:#3060a8;border-color:#4a7acf}#user-display{display:flex;align-items:center;gap:10px;font-size:13px;color:#c4d0e4}#user-display.hidden{display:none}.user-dot{width:8px;height:8px;border-radius:50%;background:#5bc470;box-shadow:0 0 6px #5bc47055}.tier-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:3px;background:linear-gradient(135deg,#d4a020,#f0c848);color:#1a1200}.tier-badge.tier-guest{background:#2a3448;color:#607090}.join-code-group.hidden,.tier-badge.hidden{display:none}#username{font-weight:600;color:#e0eaff}#btn-logout{background:0 0;border:1px solid #2a3448;color:#607090;padding:5px 10px;border-radius:4px;font-size:11px;cursor:pointer;transition:all .15s}#btn-logout:hover{border-color:#4a2535;color:#e06c5e}main{overflow-y:auto;padding:24px;max-width:1000px;margin:0 auto;width:100%}.lobby-header{justify-content:space-between;margin-bottom:16px;flex-wrap:wrap}.join-code-group,.lobby-actions,.lobby-header{display:flex;align-items:center;gap:10px}.join-code-group{gap:4px}#join-code-input{background:#0e1218;border:1px solid #2a3448;color:#d0d4dc;padding:7px 10px;border-radius:5px;font-size:13px;font-family:"SF Mono","Consolas",monospace;letter-spacing:2px;width:100px;text-transform:uppercase;outline:0;transition:border-color .15s}#join-code-input:focus{border-color:#3a6abf}#join-code-input::placeholder{letter-spacing:0;font-family:inherit}#btn-join-code{background:#1a2030;border:1px solid #2a3448;color:#9aa8c0;padding:7px 12px;font-size:13px}#btn-join-code:hover{background:#2a5090;border-color:#3a6abf;color:#e0eaff}#lobby-section h2{font-size:16px;font-weight:600;color:#8ba4c4;text-transform:uppercase;letter-spacing:.5px}#btn-create,#btn-join-code,.filter-group summary{cursor:pointer;border-radius:5px;transition:all .15s}#btn-create{background:#2a5090;border:1px solid #3a6abf;color:#e0eaff;padding:7px 14px;font-size:13px}#btn-create:hover{background:#3060a8}#btn-create.hidden,.lobby-filters.hidden{display:none}.lobby-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start;padding:12px 14px;margin-bottom:16px;background:#141820;border:1px solid #1e2636;border-radius:6px}.filter-group{position:relative}.filter-group summary{list-style:none;padding:6px 14px;background:#0e1218;border:1px solid #2a3448;font-size:12px;color:#9aa8c0;user-select:none;white-space:nowrap}.filter-group summary::-webkit-details-marker{display:none}.filter-group summary::after{content:" ▾";margin-left:6px;opacity:.6;font-size:9px}.filter-group summary:hover{background:#1a2030;border-color:#3a4a64;color:#c4d0e4}.filter-group[open] summary{background:#2a5090;border-color:#3a6abf;color:#e0eaff}.filter-options{display:none}.filter-group[open] .filter-options{display:flex;flex-direction:column;gap:2px;position:absolute;top:calc(100% + 4px);left:0;z-index:10;background:#141820;border:1px solid #2a3448;border-radius:5px;padding:8px 4px;min-width:220px;box-shadow:0 4px 12px rgba(0,0,0,.5)}.filter-options label{display:flex;align-items:center;padding:6px 10px;font-size:13px;color:#c4d0e4;cursor:pointer;border-radius:3px;white-space:nowrap;user-select:none;transition:background .12s}.btn-filter-reset,.filter-options label:hover{background:#1a2030}.filter-options label input{margin-right:10px;cursor:pointer;accent-color:#3a6abf}.btn-filter-reset{margin-left:auto;border:1px solid #2a3448;color:#9aa8c0;padding:6px 14px;border-radius:5px;font-size:12px;cursor:pointer;transition:all .15s;align-self:center}.btn-filter-reset:hover{background:#222d42;color:#c4d0e4;border-color:#3a4a64}#game-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.game-card{background:#141820;border:1px solid #1e2636;border-radius:8px;padding:16px;transition:all .15s}.game-card:hover{border-color:#2a3448;background:#161c26}.game-top-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.game-code{font-family:"SF Mono","Consolas",monospace;font-size:12px;font-weight:700;letter-spacing:1.5px;color:#607090;background:#0e1218;padding:3px 8px;border-radius:4px;border:1px solid #1e2636}.game-map{font-size:16px;font-weight:600;color:#e0eaff;display:flex;align-items:center;gap:8px}.map-scope-tag{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 6px;border-radius:3px}.scope-global{background:#1a3050;color:#6aa0d8}.scope-user{background:#3a2a10;color:#d4a030}.game-meta{display:flex;gap:12px;font-size:12px;color:#607090;margin-bottom:8px}.game-meta .players,.hint-text strong{color:#8ba4c4}.game-meta .players.full{color:#e06c5e}.game-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.game-tag{font-size:10px;padding:2px 7px;border-radius:3px;background:#1a2030;color:#708090;border:1px solid #1e2636}.game-tag-warn{border-color:#4a3520;color:#c89040}.btn-join{width:100%;background:#1a2030;border:1px solid #2a3448;color:#9aa8c0;padding:8px;border-radius:5px;font-size:13px;cursor:pointer;transition:all .15s}.btn-join:hover{background:#2a5090;border-color:#3a6abf;color:#e0eaff}.btn-join:disabled{opacity:.5;cursor:not-allowed}.btn-rejoin{background:#1a3020;border-color:#2a5030;color:#70c478}.btn-rejoin:hover{background:#224228;border-color:#3a7040;color:#a0e8a0}.btn-abandon{background:#301a1a;border:1px solid #502a2a;color:#c47070;padding:4px 14px;border-radius:5px;font-size:12px;cursor:pointer;transition:all .15s}.btn-abandon:hover{background:#422222;border-color:#704040;color:#e0a0a0}#current-games:empty{display:none}.current-games-header{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#8ba4c4;padding:0 0 8px}.current-games-table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:20px;border:1px solid #1e2636;border-radius:8px;overflow:hidden}.current-games-table tbody tr:hover,.current-games-table thead{background:#141820}.current-games-table th,.room-players h3,.room-settings h3{font-weight:600;text-transform:uppercase;letter-spacing:.5px}.current-games-table th{padding:8px 12px;text-align:left;font-size:11px;color:#607090;border-bottom:1px solid #1e2636}.current-games-table td{padding:8px 12px;border-bottom:1px solid #111620;color:#c4d0e4}.current-games-table tbody tr{background:#0e1218;transition:background .1s}.cg-code,.room-code-display span{font-family:"SF Mono","Consolas",monospace;color:#8ba4c4;font-size:12px}.cg-status{color:#607090}.cg-status.cg-active{color:#5bc470}.current-games-table .btn-rejoin{padding:4px 14px;font-size:12px}.empty{padding:40px;text-align:center;color:#506080;font-size:14px;border:1px dashed #1e2636;border-radius:8px;grid-column:1/-1}#game-room.hidden{display:none}.room-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.room-code-display{font-size:13px;color:#607090;font-weight:600}.room-code-display span{font-size:18px;font-weight:700;letter-spacing:3px;color:#e0eaff;background:#0e1218;padding:6px 14px;border-radius:6px;border:1px solid #2a3448;margin-left:8px}.btn-back{background:#1a2030;border:1px solid #2a3448;color:#9aa8c0;padding:7px 14px;border-radius:5px;font-size:13px;cursor:pointer;transition:all .15s}.btn-back:hover{background:#222d42;color:#c4d0e4;border-color:#3a4a64}.room-layout{display:grid;grid-template-columns:1fr 1fr;gap:20px}.room-settings{background:#141820;border:1px solid #1e2636;border-radius:8px;padding:20px}.room-players h3,.room-settings h3{font-size:14px;color:#8ba4c4;margin-bottom:14px}.lobby-timer-bar{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding:8px 12px;background:#111620;border:1px solid #1e2636;border-radius:6px}.lobby-timer-label{font-size:12px;color:#607090;text-transform:uppercase;letter-spacing:.5px}.lobby-timer-value{font-size:16px;font-weight:700;color:#c4d0e4;font-variant-numeric:tabular-nums}.lobby-timer-value.timer-warn{color:#e8a820}.lobby-timer-value.timer-critical{color:#e04040}.btn-reset-timer{margin-left:auto;background:#1a2030;border:1px solid #2a3448;color:#8ba4c4;padding:4px 12px;border-radius:4px;font-size:12px;cursor:pointer;transition:all .15s}.btn-reset-timer:hover{background:#2a5090;border-color:#3a6abf;color:#e0eaff}.btn-reset-timer.hidden{display:none}.settings-grid{display:flex;flex-direction:column;gap:10px}.setting-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #1a2030}.setting-row:last-child{border-bottom:none}.setting-label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:#506080;font-weight:600}.setting-value{font-size:14px;color:#c4d0e4;font-weight:500}.room-players{background:#141820;border:1px solid #1e2636;border-radius:8px;padding:20px}.room-players h3 span{font-weight:400;color:#506080}#room-player-list{display:flex;flex-direction:column;gap:6px}.player-row{display:flex;align-items:center;padding:10px 14px;background:#0e1218;border:1px solid #1a2030;border-radius:6px;gap:0}.player-row .kick-btn{margin-left:auto}.player-name{font-size:14px;font-weight:500;color:#d0d4dc}.player-badges{display:flex;align-items:center;gap:6px}.banned-header span,.host-badge{font-weight:700;text-transform:uppercase;letter-spacing:.5px}.host-badge{font-size:10px;padding:2px 8px;border-radius:3px;background:#2a4020;color:#80c870;border:1px solid #3a5830}.kick-btn{background:0 0;border:1px solid transparent;color:#604040;font-size:18px;line-height:1;cursor:pointer;padding:2px 6px;border-radius:4px;transition:all .15s}.kick-btn:hover{color:#e06c5e;background:#2a1818;border-color:#4a2535}.player-row.empty-slot{border-style:dashed;border-color:#1a2030;background:0 0}.empty-name{color:#303848;font-style:italic;font-weight:400}.banned-section{margin-top:16px;padding:12px;background:#1a1418;border:1px solid #3a2030;border-radius:6px}.banned-section.hidden{display:none}.banned-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.banned-header span{font-size:11px;color:#c87070}.btn-clear-bans{background:#2a1820;border:1px solid #4a2535;color:#c89090;padding:4px 10px;border-radius:4px;font-size:11px;cursor:pointer;transition:all .15s}.btn-clear-bans:hover{background:#3a2030;color:#e0a0a0}.banned-row{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;margin-bottom:4px;background:#0e0a10;border:1px solid #2a1820;border-radius:4px}.banned-row:last-child{margin-bottom:0}.banned-name{font-size:13px;color:#a08080}.btn-launch,.unban-btn{cursor:pointer;transition:all .15s}.unban-btn{background:0 0;border:1px solid #2a3448;color:#708090;padding:3px 10px;border-radius:3px;font-size:11px}.unban-btn:hover{background:#1a2030;color:#c4d0e4;border-color:#3a4a64}.btn-launch{width:100%;margin-top:14px;background:linear-gradient(135deg,#2a7040,#3a9050);border:1px solid #4aa060;color:#e0ffe8;padding:11px 14px;border-radius:6px;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.btn-launch:hover:not(:disabled){background:linear-gradient(135deg,#358848,#44a860);border-color:#5ac070}.btn-launch:disabled{opacity:.5;cursor:not-allowed;background:#1a2a20;border-color:#2a3a30;color:#506060}.btn-launch.hidden,.launch-countdown.hidden,.modal.hidden{display:none}.launch-countdown{margin-top:14px;padding:20px;background:linear-gradient(135deg,#1a2a30,#2a3a50);border:1px solid #3a5070;border-radius:6px;text-align:center}.countdown-label{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:#8ba4c4;margin-bottom:8px}.countdown-number{font-size:48px;font-weight:700;color:#e0eaff;font-family:"SF Mono","Consolas",monospace;line-height:1;text-shadow:0 0 20px #3a6abf88;animation:countdown-pulse 1s ease-out infinite}.status-bar{padding:6px 16px;background:#0e1218;border-top:1px solid #1e2636;font-size:11px;flex-shrink:0}.status-disconnected{color:#e06c5e}.status-connected::before,.status-connecting::before,.status-disconnected::before{content:"●";margin-right:6px}.status-connected{color:#5bc470}.status-connecting{color:#e8a838}.modal{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:100}.modal-inner{background:#141820;border:1px solid #2a3448;border-radius:8px;padding:24px;width:400px;max-width:90vw;display:flex;flex-direction:column;gap:12px}.modal-inner.create-modal-wide{width:480px;max-height:85vh;overflow-y:auto}.modal-inner h2{font-size:18px;color:#8ba4c4}.modal-inner p{font-size:13px;color:#607090}.modal-inner label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#607090;font-weight:600;margin-top:4px}.label-hint{font-weight:400;text-transform:none;letter-spacing:0;font-size:10px;color:#506070}.hint-text{font-size:12px;color:#506070;line-height:1.5;padding:8px 10px;background:#0e1218;border-radius:4px;border:1px solid #1a2030}.modal-inner input[type=number],.modal-inner input[type=password],.modal-inner input[type=text],.modal-inner select{background:#0e1218;border:1px solid #2a3448;color:#d0d4dc;padding:9px 12px;border-radius:4px;font-size:14px;outline:0;transition:border-color .15s}.modal-inner input:focus,.modal-inner select:focus{border-color:#3a6abf}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.modal-actions button{padding:8px 18px;border-radius:5px;font-size:13px;cursor:pointer;border:1px solid #2a3448;transition:all .15s}#btn-create-cancel,#btn-login-cancel{background:#1a2030;color:#9aa8c0}#btn-create-cancel:hover,#btn-login-cancel:hover{background:#222d42}#btn-create-submit,#btn-login-submit{background:#2a5090;border-color:#3a6abf;color:#e0eaff}#btn-create-submit:hover,#btn-login-submit:hover{background:#3060a8}.btn-secondary{background:#1a2a1a;border-color:#2a5030!important;color:#70c478}.btn-secondary:hover{background:#224228!important}.create-form{display:flex;flex-direction:column;gap:0}.form-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid #1a2030;gap:16px}.form-row:last-child{border-bottom:none}.form-row>label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:#607090;font-weight:600;white-space:nowrap;flex-shrink:0;margin:0}.form-row>input[type=number],.form-row>select{background:#0e1218;border:1px solid #2a3448;color:#d0d4dc;padding:8px 12px;border-radius:4px;font-size:13px;outline:0;transition:border-color .15s;min-width:200px;text-align:right}.form-row>input:focus,.form-row>select:focus{border-color:#3a6abf}.toast{position:fixed;bottom:40px;left:50%;transform:translateX(-50%) translateY(20px);background:#1a3050;color:#c4d8f0;border:1px solid #2a4a70;padding:10px 20px;border-radius:6px;font-size:13px;opacity:0;transition:all .3s ease;z-index:200;pointer-events:none}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.toast-error{background:#3a1a1a;border-color:#5a2a2a;color:#f0a0a0}.color-swatch{width:20px;height:20px;border-radius:50%;border:2px solid rgba(255,255,255,.2);flex-shrink:0;margin-right:10px}.color-swatch.clickable{cursor:pointer;border-color:rgba(255,255,255,.5);transition:border-color .15s,transform .15s}.color-pick-btn:hover,.color-swatch.clickable:hover{border-color:#fff;transform:scale(1.15)}.color-picker-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#141820;border:1px solid #2a3448;border-radius:8px;padding:12px;display:grid;grid-template-columns:repeat(5,1fr);gap:8px;z-index:300;box-shadow:0 8px 32px rgba(0,0,0,.6)}.color-pick-btn{width:36px;height:36px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .15s}.color-pick-btn.selected{border-color:#fff;box-shadow:0 0 8px rgba(255,255,255,.4)}.color-pick-btn.taken{opacity:.2;cursor:not-allowed}#game-view{display:flex;flex-direction:column;height:100vh;position:fixed;top:0;left:0;right:0;bottom:0;z-index:100;background:#0a0d12}.game-top-bar{display:flex;align-items:center;gap:16px;padding:8px 16px;background:#141820;border-bottom:1px solid #1e2636;flex-shrink:0}.game-phase-label{font-size:14px;font-weight:600;color:#c4d0e4;padding:4px 12px;background:#1a2a40;border:1px solid #2a4060;border-radius:5px}.game-info-bar{font-size:11px;color:#607090;flex:1;text-align:center}.game-top-actions{display:flex;gap:6px;margin-left:auto}.game-btn{background:#1a2030;border:1px solid #2a3448;color:#8ba4c4;padding:4px 12px;border-radius:4px;font-size:11px;cursor:pointer;transition:all .15s}.game-btn:hover{background:#2a5090;border-color:#3a6abf;color:#e0eaff}.btn-draw{border-color:#5a4a20;color:#c8a840}.btn-draw-voted,.btn-draw:hover{background:#2a2410;border-color:#8a7030}.btn-draw-voted{color:#e8c848}.gp-abandoned{opacity:.45}.results-modal{max-width:360px;text-align:center}.results-list,.results-modal h2{margin-bottom:16px}.result-row{display:flex;align-items:center;gap:12px;padding:8px 14px;border-bottom:1px solid #1e2636}.result-place{font-size:14px;font-weight:700;color:#607090;width:36px}.result-place.result-first{color:#f0c848}.result-name{font-size:14px;color:#c4d0e4}.game-body{display:flex;flex:1;overflow:hidden}.game-map-wrap{flex:1;background:#0a0d12;overflow:hidden;position:relative}#game-svg{width:100%;height:100%}.game-sidebar{width:180px;flex-shrink:0;background:#111620;border-left:1px solid #1e2636;padding:10px;display:flex;flex-direction:column;gap:6px;overflow-y:auto}.gp-card{background:#0e1218;border:1px solid #1a2030;border-radius:6px;padding:10px}.gp-card.active-turn{border-color:#3a6abf;background:#121a28;box-shadow:0 0 8px rgba(58,106,191,.2)}.gp-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.gp-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;border:1px solid rgba(255,255,255,.2)}.gp-name{font-size:13px;font-weight:600;color:#c4d0e4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gp-stat{font-size:11px;color:#607090;padding-left:20px;line-height:1.6}.phase-hud{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);background:rgba(14,18,24,.92);border:1px solid #2a3448;border-radius:10px;padding:12px 20px;z-index:40;text-align:center;backdrop-filter:blur(8px);min-width:300px}.phase-steps{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:8px}.phase-arrow,.phase-step{color:#3a4458;font-weight:700}.phase-step{font-size:13px;text-transform:uppercase;letter-spacing:.5px;padding:4px 14px;border-radius:4px;transition:all .2s}.phase-step.active{color:#e0eaff;background:#2a5090;box-shadow:0 0 12px rgba(42,80,144,.4)}.phase-step.done{color:#5bc470}.phase-arrow{font-size:18px}.phase-detail{font-size:12px;color:#8ba4c4;margin-bottom:8px}.btn-end-phase{background:#2a5090;border:1px solid #3a6abf;color:#e0eaff;padding:6px 18px;border-radius:5px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.btn-end-phase:hover{background:#3060a8}.deploy-panel{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#141820;border:1px solid #2a3448;border-radius:8px;padding:16px 20px;z-index:50;text-align:center;box-shadow:0 8px 32px rgba(0,0,0,.6);min-width:200px}.deploy-title{font-size:13px;font-weight:600;color:#c4d0e4;margin-bottom:12px}.deploy-controls{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:12px}.deploy-btn,.deploy-input{border:1px solid #2a3448;border-radius:5px}.deploy-btn{width:32px;height:32px;background:#1a2030;color:#c4d0e4;font-size:18px;cursor:pointer;transition:all .15s}.deploy-btn:hover{background:#2a5090;border-color:#3a6abf}.deploy-input{width:60px;text-align:center;background:#0e1218;color:#e0eaff;padding:6px;font-size:16px;font-weight:600}.deploy-input:focus{border-color:#3a6abf;outline:0}.deploy-confirm{width:100%;background:#2a5090;border:1px solid #3a6abf;color:#e0eaff;padding:8px;border-radius:5px;font-size:13px;cursor:pointer;transition:all .15s}.deploy-confirm:hover{background:#3060a8}.attack-panel{position:absolute;bottom:100px;left:50%;transform:translateX(-50%);background:rgba(14,18,24,.95);border:1px solid #502a2a;border-radius:8px;padding:16px 20px;z-index:55;text-align:center;box-shadow:0 8px 32px rgba(0,0,0,.6);min-width:260px;backdrop-filter:blur(8px)}.attack-title{font-size:14px;font-weight:700;color:#f66;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}.attack-matchup{font-size:13px;color:#c4d0e4;margin-bottom:12px}.attack-mode-select{display:flex;gap:8px;margin-bottom:4px}.attack-mode-btn{flex:1;background:#1a2030;border:1px solid #2a3448;color:#c4d0e4;padding:8px 12px;border-radius:5px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.attack-mode-btn:hover{background:#2a1818;border-color:#704040;color:#f88}.attack-troop-label{font-size:11px;color:#607090;margin-bottom:8px}.attack-go{background:#802020!important;border-color:#a03030!important}.attack-go:hover{background:#a03030!important}.dice-row{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}.dice-group{display:flex;gap:6px}.dice-vs{font-size:12px;font-weight:700;color:#607090;letter-spacing:1px}.die{width:36px;height:36px;border-radius:6px;display:grid;padding:5px;box-shadow:0 2px 4px rgba(0,0,0,.4)}.die-red{background:#c0392b;border:2px solid #e74c3c}.die-blue{background:#2471a3;border:2px solid #3498db}.die[data-value="1"]{grid-template:1fr/1fr;place-items:center}.die[data-value="2"]{grid-template:1fr 1fr/1fr}.die[data-value="3"]{grid-template:1fr 1fr 1fr/1fr}.die[data-value="4"]{grid-template:1fr 1fr/1fr 1fr}.die[data-value="5"],.die[data-value="6"]{grid-template:1fr 1fr 1fr/1fr 1fr}.die-dot{width:6px;height:6px;border-radius:50%;background:#fff;justify-self:center;align-self:center}.die[data-value="2"] .die-dot:nth-child(1){justify-self:end;align-self:start}.die[data-value="2"] .die-dot:nth-child(2){justify-self:start;align-self:end}.die[data-value="3"] .die-dot:nth-child(1){justify-self:end;align-self:start}.die[data-value="3"] .die-dot:nth-child(2){justify-self:center;align-self:center}.die[data-value="3"] .die-dot:nth-child(3){justify-self:start;align-self:end}.dice-result{font-size:12px;color:#c4d0e4;margin-bottom:4px}.dice-select{display:flex;align-items:center;gap:6px;justify-content:center;margin-bottom:8px}.dice-select-label{font-size:12px;color:#607090}.dice-pick-btn{width:32px;height:32px;background:#1a2030;border:1px solid #2a3448;color:#c4d0e4;font-size:14px;font-weight:700;border-radius:5px;cursor:pointer;transition:all .15s}.dice-pick-btn:hover{background:#2a3040;border-color:#3a5060}.dice-pick-btn.active{background:#802020;border-color:#a03030;color:#fff}.dice-pick-btn:disabled{opacity:.3;cursor:not-allowed}.game-bottom-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:#141820;border-top:1px solid #1e2636;flex-shrink:0}.turn-status{font-size:13px;color:#9aa8c0}.game-actions{display:flex;gap:8px}.hidden{display:none!important}