:root{--bg-deep: #060a12;--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-panel: rgba(17, 24, 39, .95);--bg-panel-solid: #111827;--bg-hover: #1c2940;--bg-input: #0c1220;--bg-selected: #1a3050;--border: #1e2d40;--border-bright: #2a4060;--text-primary: #d8e2ec;--text-secondary: #7b8fa3;--text-muted: #4a5c70;--accent: #4fc3f7;--accent-dim: #1a5a7a;--accent-glow: rgba(79, 195, 247, .3);--success: #66bb6a;--success-dim: rgba(102, 187, 106, .15);--warning: #ffb74d;--warning-dim: rgba(255, 183, 77, .15);--danger: #ef5350;--danger-dim: rgba(239, 83, 80, .15);--money: #ffd54f;--mars-surface: #1e1008;--mars-grid: #2a1810;--font-mono: "JetBrains Mono", "Fira Code", "SF Mono", "Consolas", monospace;--font-ui: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}body{font-family:var(--font-ui);background:var(--bg-deep);color:var(--text-primary);font-size:13px;line-height:1.4;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-bright)}.game{display:flex;flex-direction:column;height:100vh;background:var(--bg-deep)}.game-main{flex:1;position:relative;overflow:hidden;min-height:0}.top-bar{position:relative;display:flex;align-items:center;gap:2px;height:40px;padding:0 12px;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0;z-index:10}.top-bar-title{font-family:var(--font-mono);font-weight:700;font-size:14px;color:var(--accent);letter-spacing:1px;margin-right:12px;white-space:nowrap}.top-bar-divider{width:1px;height:20px;background:var(--border);margin:0 8px}.resource-pill{display:flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--radius-sm);font-size:12px;font-family:var(--font-mono);font-weight:500;background:var(--bg-primary);border:1px solid var(--border);white-space:nowrap}.resource-pill .label{color:var(--text-muted);font-size:10px}.resource-pill .value{color:var(--text-primary)}.resource-pill.money .value{color:var(--money)}.resource-pill.money .label{color:#b8962a}.top-bar-resources{display:flex;align-items:center;gap:2px}.top-bar.low-cash{animation:lowCashPulse 1.5s ease-in-out infinite}@keyframes lowCashPulse{0%,to{background:var(--bg-secondary);border-bottom-color:var(--border)}50%{background:#ef535026;border-bottom-color:var(--danger)}}.top-bar-right{margin-left:auto;display:flex;align-items:center;gap:6px}.icon-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;font-size:14px;transition:all .15s}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-bright)}.icon-btn.active{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.icon-btn.map-selector-btn{width:auto;min-width:120px;max-width:210px;padding:0 8px;font-size:11px;font-family:var(--font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.map-viewport{width:100%;height:100%;position:relative;overflow:hidden;background:var(--mars-surface)}.map-canvas{display:block;width:100%;height:100%}.map-tooltip{position:absolute;pointer-events:none;z-index:20;background:var(--bg-panel);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-bright);border-radius:var(--radius-md);padding:8px 10px;min-width:140px;max-width:220px;font-size:11px;line-height:1.5;box-shadow:0 4px 20px #00000080;animation:fadeIn .1s ease-out}.map-tooltip .tt-header{display:flex;align-items:center;gap:5px;font-weight:600;font-size:12px;margin-bottom:4px}.map-tooltip .tt-status{font-size:10px;padding:1px 6px;border-radius:3px;display:inline-block;margin-bottom:4px}.map-tooltip .tt-status.active{background:var(--success-dim);color:var(--success)}.map-tooltip .tt-status.constructing{background:var(--warning-dim);color:var(--warning)}.map-tooltip .tt-status.suspended{background:var(--danger-dim);color:var(--danger)}.map-tooltip .tt-row{display:flex;justify-content:space-between;gap:8px;color:var(--text-secondary)}.map-tooltip .tt-row .val{color:var(--text-primary);font-family:var(--font-mono)}.map-tooltip .tt-bar{height:4px;background:#1a2030;border-radius:2px;overflow:hidden;margin-top:2px}.map-tooltip .tt-bar-fill{height:100%;border-radius:2px;transition:width .3s}.build-mode-indicator{position:absolute;top:10px;left:50%;transform:translate(-50%);z-index:15;padding:6px 16px;background:var(--bg-panel);border:1px solid var(--accent);border-radius:var(--radius-md);font-size:12px;color:var(--accent);font-weight:600;box-shadow:0 0 20px var(--accent-glow);animation:fadeIn .2s ease-out;display:flex;align-items:center;gap:8px}.build-mode-label{min-width:0;white-space:normal}.build-mode-cancel{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--danger);background:var(--danger-dim);color:var(--danger);font-size:14px;cursor:pointer}.area-draw-indicator{position:absolute;top:10px;left:50%;transform:translate(-50%);z-index:15;padding:6px 16px;background:var(--bg-panel);border:1px solid var(--danger);border-radius:var(--radius-md);font-size:12px;color:var(--danger);font-weight:600;box-shadow:0 0 20px #ef53504d;animation:fadeIn .2s ease-out;display:flex;align-items:center;gap:8px}.build-toolbar{display:flex;align-items:stretch;background:var(--bg-secondary);border-top:1px solid var(--border);flex-shrink:0;z-index:10;overflow:hidden}.build-toolbar-tabs{display:flex;flex-direction:column;border-right:1px solid var(--border);min-width:100px}.build-tab{padding:4px 10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);cursor:pointer;border:none;background:transparent;text-align:left;transition:all .15s;border-left:2px solid transparent}.build-tab:hover{color:var(--text-secondary);background:var(--bg-hover)}.build-tab.active{color:var(--text-primary);background:var(--bg-primary);border-left-color:var(--accent)}.build-items{display:flex;flex-wrap:wrap;gap:4px;padding:6px 8px;flex:1;align-items:flex-start;align-content:flex-start;overflow-y:auto;max-height:110px}.build-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:4px 8px;width:92px;height:68px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-primary);cursor:pointer;transition:all .15s;position:relative}.build-card:hover:not(.disabled){border-color:var(--accent);background:var(--bg-hover)}.build-card.selected{border-color:var(--accent);background:var(--accent-dim);box-shadow:0 0 8px var(--accent-glow)}.build-card.disabled{opacity:.3;cursor:not-allowed}.build-card .bc-icon{font-size:18px;font-weight:700;line-height:1;margin-bottom:1px}.build-card .bc-name{font-size:9px;font-weight:600;color:var(--text-secondary);text-align:center;line-height:1.2;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.build-card .bc-cost{font-size:9px;font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.build-toolbar-extra{display:flex;flex-direction:column;gap:4px;padding:6px 10px;border-left:1px solid var(--border);min-width:120px;justify-content:center}.building-detail{position:absolute;bottom:8px;left:8px;z-index:20;width:320px;max-height:calc(100% - 16px);overflow-y:auto;background:var(--bg-panel);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-bright);border-radius:var(--radius-lg);padding:12px;box-shadow:0 8px 32px #00000080;animation:slideUp .2s ease-out}.building-detail .bd-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.building-detail .bd-icon{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff;flex-shrink:0}.building-detail .bd-title{font-weight:700;font-size:14px}.building-detail .bd-coords{font-size:11px;color:var(--text-muted);font-family:var(--font-mono)}.building-detail .bd-close{margin-left:auto;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:18px;padding:0 4px;line-height:1}.building-detail .bd-close:hover{color:var(--text-primary)}.bd-section{margin-top:10px;padding-top:8px;border-top:1px solid var(--border)}.bd-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:6px}.bd-status{font-size:11px;padding:2px 8px;border-radius:3px;display:inline-block}.bd-status.active{background:var(--success-dim);color:var(--success)}.bd-status.constructing{background:var(--warning-dim);color:var(--warning)}.bd-status.suspended{background:var(--danger-dim);color:var(--danger)}.bd-recipe{font-size:11px;color:var(--text-secondary);padding:4px 8px;background:var(--bg-primary);border-radius:var(--radius-sm);font-family:var(--font-mono)}.capacity-bar{height:6px;background:#1a2030;border-radius:3px;overflow:hidden;margin-top:3px}.capacity-bar-fill{height:100%;border-radius:3px;transition:width .3s}.capacity-label{font-size:11px;color:var(--text-secondary);display:flex;justify-content:space-between}.route-item{display:flex;align-items:center;gap:6px;padding:3px 0;font-size:12px}.route-item .route-res{font-family:var(--font-mono);font-weight:600}.route-item .route-arrow{color:var(--text-muted)}.route-item .route-dest{color:var(--accent)}.route-item .route-delete{margin-left:auto;background:transparent;border:1px solid transparent;color:var(--text-muted);cursor:pointer;font-size:10px;padding:1px 6px;border-radius:3px}.route-item .route-delete:hover{color:var(--danger);border-color:var(--danger)}.route-hint{font-size:11px;color:var(--text-muted);font-style:italic;padding:4px 0}.auto-sell-grid{display:flex;flex-direction:column;gap:3px}.auto-sell-row{display:flex;align-items:center;gap:4px;font-size:11px}.auto-sell-row .as-name{width:80px;color:var(--text-secondary);font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auto-sell-row .as-price{width:40px;font-family:var(--font-mono);color:var(--text-muted);font-size:10px}.auto-sell-btn{padding:1px 6px;font-size:10px;border-radius:3px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:all .1s}.auto-sell-btn:hover{border-color:var(--border-bright)}.auto-sell-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.worker-detail{position:absolute;z-index:20;width:290px;background:var(--bg-panel);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-bright);border-radius:var(--radius-lg);padding:10px;box-shadow:0 8px 32px #00000080;animation:fadeIn .15s ease-out;font-size:12px}.worker-detail .wd-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.worker-detail .wd-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;line-height:1}.resource-picker{position:absolute;z-index:30;background:var(--bg-panel);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-bright);border-radius:var(--radius-md);padding:6px;box-shadow:0 8px 32px #0009;animation:scaleIn .12s ease-out;max-height:280px;overflow-y:auto;min-width:140px}.resource-picker .rp-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:2px 6px 4px}.resource-picker .rp-item{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:var(--radius-sm);cursor:pointer;font-size:12px;color:var(--text-primary);transition:background .1s}.resource-picker .rp-item:hover{background:var(--bg-hover)}.resource-picker .rp-item .rp-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.notifications{position:fixed;top:48px;right:12px;z-index:100;display:flex;flex-direction:column;gap:6px;pointer-events:none}.toast{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius-md);background:var(--bg-panel-solid);border:1px solid var(--border-bright);box-shadow:0 4px 20px #00000080;font-size:12px;animation:slideInRight .2s ease-out;pointer-events:auto;max-width:320px}.toast.leaving{animation:slideOutRight .2s ease-in forwards}.toast .toast-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.toast.success .toast-dot{background:var(--success)}.toast.error .toast-dot{background:var(--danger)}.toast.warning .toast-dot{background:var(--warning)}.toast.info .toast-dot{background:var(--accent)}.toast .toast-text{color:var(--text-primary)}.toast .toast-dismiss{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:0 2px;margin-left:auto}.market-panel{position:absolute;top:0;right:0;bottom:0;width:300px;z-index:25;background:var(--bg-panel);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-left:1px solid var(--border-bright);padding:12px;overflow-y:auto;animation:slideInRight .2s ease-out;box-shadow:-8px 0 32px #0000004d}.market-panel .mp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.market-panel .mp-title{font-weight:700;font-size:14px}.market-section{margin-bottom:12px}.market-section .ms-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:6px}.market-row{display:flex;align-items:center;padding:3px 0;font-size:12px}.market-row .mr-name{flex:1;color:var(--text-secondary)}.market-row .mr-price{font-family:var(--font-mono);color:var(--money)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#000000b3;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease-out}.modal-content{background:var(--bg-panel-solid);border:1px solid var(--border-bright);border-radius:var(--radius-lg);padding:20px;max-width:700px;max-height:80vh;overflow-y:auto;box-shadow:0 16px 64px #0009;width:90%}.modal-content .modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.modal-content .modal-title{font-size:18px;font-weight:700}.modal-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:22px;padding:0 4px}.modal-close:hover{color:var(--text-primary)}.tech-chain{margin-bottom:14px;padding:10px;border-radius:var(--radius-md);background:var(--bg-primary);border:1px solid var(--border)}.tech-chain .tc-title{font-weight:700;font-size:13px;margin-bottom:6px}.tech-chain .tc-flow{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);margin-bottom:4px}.tech-chain .tc-desc{font-size:11px;color:var(--text-muted);line-height:1.6}.login-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:var(--bg-deep)}.login-title{font-family:var(--font-mono);font-size:28px;font-weight:700;color:var(--accent);letter-spacing:3px;margin-bottom:6px}.login-subtitle{font-size:12px;color:var(--text-muted);margin-bottom:28px}.login-box{display:flex;flex-direction:column;gap:10px;width:260px}.login-toggle{display:flex;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);margin-bottom:4px}.login-toggle button{flex:1;padding:7px;border:none;background:var(--bg-primary);color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:600;transition:all .15s}.login-toggle button.active{background:var(--accent);color:#000}.login-input{padding:10px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;font-family:var(--font-ui);outline:none;transition:border-color .15s}.login-input:focus{border-color:var(--accent)}.login-input::placeholder{color:var(--text-muted)}.login-submit{padding:10px;background:var(--accent);color:#000;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s}.login-submit:hover{opacity:.9}.login-error{color:var(--danger);font-size:12px;text-align:center;margin-top:4px}.btn{padding:4px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);cursor:pointer;font-size:12px;font-family:var(--font-ui);transition:all .15s;white-space:nowrap}.btn:hover{border-color:var(--border-bright);background:var(--bg-hover)}.btn:disabled{opacity:.3;cursor:not-allowed}.btn.btn-accent{border-color:var(--accent-dim);color:var(--accent)}.btn.btn-accent:hover{background:var(--accent-dim)}.btn.btn-danger{border-color:#ef53504d;color:var(--danger)}.btn.btn-danger:hover{background:var(--danger-dim)}.btn.btn-success{border-color:#66bb6a4d;color:var(--success)}.btn.btn-success:hover{background:var(--success-dim)}.btn-sm{padding:2px 8px;font-size:11px}.input,.select{padding:4px 8px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:12px;font-family:var(--font-ui);outline:none}.input:focus,.select:focus{border-color:var(--accent)}.filter-check{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-secondary);cursor:pointer;padding:1px 0}.filter-check input[type=checkbox]{accent-color:var(--accent)}.resource-filter-section{margin-bottom:4px}.resource-filter-groups{display:grid;grid-template-columns:1fr 1fr;gap:2px 12px}.resource-filter-group{margin-bottom:4px}.resource-filter-group-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1px;opacity:.8}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(40px)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:.4}50%{opacity:.8}}.worker-list{display:flex;flex-direction:column;gap:2px;flex:1;min-height:0;overflow-y:auto}.worker-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background .1s;font-size:12px;flex-shrink:0;white-space:nowrap;overflow:hidden}.worker-row:hover{background:var(--bg-hover)}.tile-detail{position:absolute;bottom:8px;left:8px;z-index:20;width:260px;background:var(--bg-panel);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-bright);border-radius:var(--radius-lg);padding:12px;box-shadow:0 8px 32px #00000080;animation:slideUp .2s ease-out}.tile-detail .td-header{display:flex;align-items:center;gap:8px}.tile-detail .td-dot{width:24px;height:24px;border-radius:var(--radius-sm);flex-shrink:0}.tile-detail .td-title{font-weight:700;font-size:14px}.tile-detail .td-coords{font-size:11px;color:var(--text-muted);font-family:var(--font-mono)}.tile-detail .td-close{margin-left:auto;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:18px;padding:0 4px;line-height:1}.tile-detail .td-close:hover{color:var(--text-primary)}.research-track{margin-bottom:12px}.research-track-title{font-size:11px;font-weight:700;color:var(--text-secondary);letter-spacing:.5px;margin-bottom:6px}.research-connector{text-align:center;color:var(--text-muted);font-size:10px;line-height:1;padding:1px 0}.research-node{border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 8px;font-size:11px}.research-node.completed{border-color:var(--success);background:var(--success-dim)}.research-node.available{border-color:var(--accent);background:#4fc3f714}.research-node.locked{opacity:.5}.research-node-header{display:flex;align-items:center;gap:6px;font-weight:600}.research-status-icon{font-size:12px;display:inline-flex;align-items:center;justify-content:center;line-height:1}.research-node.completed .research-status-icon{color:var(--success)}.research-node.available .research-status-icon{color:var(--accent)}.research-name{flex:1}.research-desc{color:var(--text-secondary);font-size:10px;margin-top:2px}.research-cost{display:flex;flex-wrap:wrap;gap:4px 8px;margin-top:4px;font-size:10px;font-family:var(--font-mono);color:var(--text-secondary)}.research-cost-item:before{content:"●";font-size:6px;vertical-align:middle}.research-prereq{font-size:10px;color:var(--warning);margin-top:3px}.map-selector-modal{background:var(--bg-panel-solid);border:1px solid var(--border-bright);border-radius:var(--radius-lg);padding:16px;width:96vw;height:92vh;min-width:320px;max-width:none;max-height:92vh;display:flex;flex-direction:column}.map-selector-modal .modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.map-selector-modal .modal-title{font-weight:700;font-size:14px;letter-spacing:1px}.map-selector-hint{font-size:11px;color:var(--text-secondary);margin-bottom:12px}.district-browser{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.district-browser-center{flex:1;min-width:0;text-align:center}.district-browser-label{font-size:10px;color:var(--text-muted)}.district-browser-name{font-size:12px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.district-nav-btn{width:28px;height:28px;font-size:15px;flex-shrink:0}.district-nav-btn:disabled{opacity:.35;cursor:not-allowed}.map-selector-grid{display:grid;gap:4px;overflow-y:auto;min-height:0;flex:1}.map-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);cursor:pointer;font-size:11px;font-family:var(--font-ui);color:var(--text-secondary);min-height:96px;transition:border-color .15s,background .15s;overflow:hidden}.map-cell:hover:not(:disabled){border-color:var(--accent);background:var(--bg-hover)}.map-cell.current{border-color:var(--accent);background:#4fc3f71f}.map-cell.has-outpost{border-color:var(--success)}.map-cell.locked{opacity:.35;cursor:not-allowed}.map-cell-name{width:100%;font-size:11px;font-weight:600;line-height:1.25;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.map-cell-density-pills{width:100%;margin-top:2px;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:3px;row-gap:3px}.resource-pill.map-density{padding:3px 8px;font-size:12px;min-width:0;gap:4px}.resource-pill.map-density .value{color:var(--text-secondary)}.map-cell-star{color:var(--money);font-size:14px}.map-cell-lock{font-size:10px;display:inline-flex;align-items:center;justify-content:center;line-height:1}.map-selector-legend{font-size:10px;color:var(--text-muted);margin-top:10px;text-align:center}.sector-welcome-modal{background:var(--bg-panel-solid);border:1px solid var(--border-bright);border-radius:var(--radius-lg);padding:16px;width:min(560px,94vw);box-shadow:0 16px 64px #0009}.sector-welcome-copy{font-size:13px;color:var(--text-primary);margin-bottom:4px}.sector-welcome-subcopy{font-size:11px;color:var(--text-secondary);margin-bottom:10px}.sector-scan-pending{padding:10px;border:1px dashed var(--border-bright);border-radius:var(--radius-sm);color:var(--text-muted);font-size:11px;margin-bottom:12px}.sector-resource-grid{display:grid;gap:6px;margin-bottom:12px}.sector-resource-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary)}.sector-resource-row.absent{border-color:#ef535080;background:var(--danger-dim)}.resource-pill.sector{min-width:145px;justify-content:flex-start}.resource-pill.sector.absent{border-color:#ef535080;background:#201216f2}.sector-resource-meta{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:11px}.sector-resource-absent{color:var(--danger);font-weight:600}.sector-welcome-actions{display:flex;justify-content:flex-end}.text-money{color:var(--money)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.mono{font-family:var(--font-mono)}.main-menu-popup{position:absolute;top:100%;right:0;margin-top:4px;z-index:50;background:var(--bg-panel-solid);border:1px solid var(--border-bright);border-radius:var(--radius-md);box-shadow:0 8px 32px #00000080;min-width:160px;padding:4px 0;animation:fadeIn .1s ease-out}.main-menu-item{display:block;width:100%;padding:8px 14px;min-height:36px;background:transparent;border:none;color:var(--text-primary);font-size:13px;font-family:var(--font-ui);text-align:left;cursor:pointer;transition:background .1s}.main-menu-item:hover{background:var(--bg-hover)}.main-menu-item.danger{color:var(--danger)}.main-menu-divider{height:1px;background:var(--border);margin:4px 0}.inventory-popup{position:absolute;top:100%;left:12px;margin-top:4px;z-index:50;background:var(--bg-panel-solid);border:1px solid var(--border-bright);border-radius:var(--radius-md);box-shadow:0 8px 32px #00000080;min-width:200px;max-width:280px;max-height:400px;overflow-y:auto;padding:8px;animation:fadeIn .1s ease-out}.inventory-group{margin-bottom:8px}.inventory-group:last-child{margin-bottom:0}.inventory-group-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}.inventory-row{display:flex;justify-content:space-between;align-items:center;padding:2px 4px;font-size:12px}.inventory-mat{color:var(--text-secondary)}.inventory-val{font-family:var(--font-mono);color:var(--text-primary)}.tech-building-list{display:flex;flex-direction:column;gap:6px;margin-top:6px}.tech-building-card{padding:6px 10px;border-radius:var(--radius-sm);background:var(--bg-secondary);border:1px solid var(--border)}.tech-building-card .tbc-name{font-weight:700;font-size:12px;margin-bottom:2px}.tech-building-card .tbc-recipe{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);margin-bottom:2px}.tech-building-card .tbc-desc{font-size:11px;color:var(--text-muted);margin-bottom:2px}.tech-building-card .tbc-meta{display:flex;gap:12px;font-size:10px;font-family:var(--font-mono);color:var(--text-muted)}.tutorial-checklist{position:absolute;bottom:8px;right:8px;z-index:20;width:280px;background:var(--bg-panel);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-bright);border-radius:var(--radius-md);padding:10px 12px;box-shadow:0 4px 20px #00000080;animation:slideUp .2s ease-out}.tutorial-header{font-family:var(--font-mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--accent);margin-bottom:8px}.tutorial-steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.tutorial-step{font-size:12px;color:var(--text-muted);font-family:var(--font-mono);line-height:1.4;display:flex;align-items:baseline;gap:6px}.tutorial-step.done{color:var(--success)}.tutorial-step.current{color:var(--text-primary)}.tutorial-marker{flex-shrink:0;width:14px;text-align:center;font-weight:700}.tutorial-step.done .tutorial-marker{color:var(--success)}.tutorial-step.current .tutorial-marker{color:var(--accent)}.tutorial-congrats-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:30;background:#0009;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.tutorial-congrats{background:var(--bg-panel-solid);border:1px solid var(--accent);border-radius:var(--radius-lg);padding:24px;max-width:360px;text-align:center;box-shadow:0 0 40px var(--accent-glow);animation:scaleIn .2s ease-out}.tutorial-congrats-title{font-family:var(--font-mono);font-size:20px;font-weight:700;color:var(--accent);margin-bottom:10px}.tutorial-congrats-text{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-bottom:16px}.tax-panel{width:min(400px,90vw)}.tax-rate-display{display:flex;align-items:baseline;justify-content:space-between;padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:12px}.tax-rate-label{font-size:13px;color:var(--text-secondary);font-weight:600}.tax-rate-value{font-family:var(--font-mono);font-size:22px;font-weight:700;color:var(--money)}.tax-player-table{width:100%;border-collapse:collapse;margin-bottom:12px;font-size:12px}.tax-player-table th{text-align:left;padding:6px 8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border)}.tax-player-table td{padding:6px 8px;color:var(--text-primary);border-bottom:1px solid var(--border)}.tax-player-table td:last-child,.tax-player-table th:last-child{text-align:right;font-family:var(--font-mono)}.tax-player-table td:nth-child(2),.tax-player-table th:nth-child(2){text-align:center;font-family:var(--font-mono)}.tax-no-buildings{padding:16px;text-align:center;color:var(--text-muted);font-size:12px}.tax-explanation{padding:10px 12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:11px;color:var(--text-muted);line-height:1.5}.bottom-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;background:#00000080;animation:fadeIn .15s ease-out}.bottom-sheet{position:fixed;bottom:0;left:0;right:0;z-index:41;background:var(--bg-panel-solid);border-top:1px solid var(--border-bright);border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:0 -8px 32px #00000080;animation:sheetSlideUp .25s ease-out;overflow:hidden;display:flex;flex-direction:column}.bottom-sheet.closing{animation:sheetSlideDown .2s ease-in forwards}.bottom-sheet-handle{display:flex;justify-content:center;padding:10px 0 6px;cursor:grab;flex-shrink:0}.bottom-sheet-handle-bar{width:36px;height:4px;border-radius:2px;background:var(--border-bright)}.bottom-sheet-content{overflow-y:auto;padding:0 12px 12px;-webkit-overflow-scrolling:touch}@keyframes sheetSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes sheetSlideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}.build-fab{position:fixed;bottom:20px;right:20px;z-index:30;width:56px;height:56px;border-radius:50%;border:2px solid var(--accent);background:var(--bg-panel-solid);color:var(--accent);font-size:28px;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #0006,0 0 12px var(--accent-glow);transition:transform .15s,box-shadow .15s}.build-fab:active{transform:scale(.92)}.top-bar.mobile{height:auto;min-height:44px;padding:4px 8px;gap:4px}.top-bar.mobile .top-bar-resources{flex:1;min-width:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.main-menu-popup.mobile{min-width:200px}.main-menu-popup.mobile .main-menu-item{min-height:44px;display:flex;align-items:center;font-size:14px}@media(max-width:768px){.inventory-popup{left:4px;right:4px;max-width:none;min-width:auto}}@media(max-width:768px){.icon-btn{width:44px;height:44px;font-size:16px}.icon-btn.map-selector-btn{width:auto;min-width:120px;max-width:52vw;height:44px;font-size:11px;padding:0 10px}.district-nav-btn{width:36px;height:36px;font-size:18px}.login-box{width:90%;max-width:320px}.notifications{right:auto;left:50%;transform:translate(-50%);max-width:90vw;align-items:center}.toast{max-width:90vw}.building-detail.mobile,.tile-detail.mobile,.worker-detail.mobile{position:static;width:100%;max-height:none;border:none;border-radius:0;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;animation:none}.resource-picker.mobile{position:static;width:100%;max-height:none;border:none;border-radius:0;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;animation:none;min-width:auto}.resource-picker.mobile .rp-item{padding:10px 8px;font-size:14px;min-height:44px}.build-toolbar.mobile{flex-direction:column;border:none;background:transparent}.build-toolbar.mobile .build-toolbar-tabs{flex-direction:row;border-right:none;border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;min-width:auto}.build-toolbar.mobile .build-tab{border-left:none;border-bottom:2px solid transparent;white-space:nowrap;padding:8px 12px;font-size:11px}.build-toolbar.mobile .build-tab.active{border-left-color:transparent;border-bottom-color:var(--accent)}.build-toolbar.mobile .build-items{max-height:none;gap:6px;padding:8px}.build-toolbar.mobile .build-card{width:96px;height:76px;padding:8px 10px}.build-toolbar.mobile .build-card .bc-icon{font-size:22px}.build-toolbar.mobile .build-card .bc-name{font-size:10px}.build-toolbar.mobile .build-toolbar-extra{border-left:none;border-top:1px solid var(--border);flex-direction:row;align-items:center;justify-content:space-between;min-width:auto}.market-panel{width:100%;left:0;top:0;bottom:0;right:0;border-left:none;border-radius:0}.tech-tree-overlay{align-items:stretch;justify-content:flex-start}.tech-tree-overlay .modal-content{width:100%;max-width:100%;height:100%;max-height:100%;border-radius:0;border:none;padding:12px}.worker-list-overlay{align-items:stretch;justify-content:flex-start}.worker-list-overlay .modal-content{width:100%;max-width:100%;height:100%;max-height:100%;border-radius:0;border:none;padding:12px}.build-mode-indicator,.area-draw-indicator{font-size:11px;padding:6px 12px;max-width:90vw;text-align:center}.build-mode-indicator .build-mode-label{font-size:10px;line-height:1.2;overflow-wrap:anywhere}.bd-recipe,.route-hint,.auto-sell-row .as-name,.auto-sell-row .as-price,.research-desc,.research-cost,.research-prereq{font-size:12px}.auto-sell-btn{min-height:36px;min-width:44px;padding:4px 10px;font-size:12px}.route-item .route-delete{min-width:36px;min-height:36px;font-size:14px;display:flex;align-items:center;justify-content:center}.btn{min-height:36px;padding:6px 12px}.btn-sm{min-height:32px;padding:4px 10px;font-size:12px}.filter-check{min-height:32px;font-size:12px}.filter-check input[type=checkbox]{width:18px;height:18px}}@media(max-width:768px){.tutorial-checklist{bottom:84px;right:8px;left:8px;width:auto}.tutorial-step{font-size:11px}}@media(max-width:480px){.modal-content{width:100%;max-width:100%;max-height:100vh;height:100vh;border-radius:0;border:none}.map-selector-modal{min-width:auto;max-width:100%;width:100%;height:100vh;max-height:100vh;border-radius:0;padding:12px}.sector-welcome-modal{width:100%;max-width:100%;border-radius:0;min-height:100vh}.sector-resource-row{flex-direction:column;align-items:flex-start}.login-title{font-size:22px}.login-box{width:92%}.resource-pill{padding:2px 6px;font-size:11px}}
