.App,.App *{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.App{background-color:#000;box-sizing:border-box;color:#0f0;font-family:Courier New,monospace;margin:0;min-height:100dvh;overflow:hidden;padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0);position:relative;width:100vw}:root{--menu-surface-bg:linear-gradient(140deg,#081420f0,#060e18f5 45%,#040a12fa);--menu-surface-highlight:#4ecdc429;--menu-border:#4ecdc48c;--menu-border-strong:#4ecdc4d9;--menu-shadow:0 22px 45px #0000008c;--menu-text-primary:#ebfff8;--menu-text-secondary:#dbfff4c7;--menu-muted:#aed0caa6;--menu-accent:#4ecdc4;--menu-danger:#ff6b6b;--menu-warning:#ffd166}.game-header{flex-shrink:0;padding:10px;text-align:center}.game-header h1{color:#0ff;font-size:1.5em;margin:5px 0;text-shadow:0 0 10px #0ff}.game-header p{color:#ff0;font-size:.9em;margin:2px 0}.game-main{bottom:env(safe-area-inset-bottom,0);left:env(safe-area-inset-left,0);padding:10px;position:absolute;right:env(safe-area-inset-right,0);top:env(safe-area-inset-top,0)}.game-container,.game-main{align-items:center;display:flex;justify-content:center;overflow:hidden}.game-container{height:100%;width:100%}.game-board{align-items:center;background-color:#1a1a1a;border:2px solid #0f0;border-radius:5px;box-shadow:0 0 20px #00ff004d;display:flex;flex-direction:column;font-family:Courier New,monospace;font-size:12px;isolation:isolate;justify-content:center;line-height:1;padding:0;white-space:pre}.game-board,.three-renderer{max-height:calc(100dvh - 20px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));max-width:calc(100vw - 20px - env(safe-area-inset-left, 0px) - env(safe-area-inset-right, 0px));overflow:hidden;position:relative}.three-renderer{background:radial-gradient(circle at 20% 20%,#00bcd424,#0000 55%),#050608f2;border:2px solid #00bcd4;border-radius:6px;box-shadow:0 0 28px #00bcd459;height:100%;width:100%}.three-renderer canvas{display:block;height:100%!important;width:100%!important}.three-renderer__stats{height:60px!important;left:12px!important;mix-blend-mode:screen;opacity:.9;overflow:hidden;pointer-events:none;position:absolute!important;top:12px!important;width:60px!important}.three-renderer__status{align-items:center;background:#080c10d9;border:1px solid #00bcd459;border-radius:6px;color:#e0fbfc;display:flex;flex-direction:column;font-family:Courier New,monospace;font-size:.85rem;gap:6px;left:50%;letter-spacing:.03em;overflow:hidden;padding:8px 14px;pointer-events:none;position:absolute;text-align:center;top:12px;transform:translateX(-50%)}.three-renderer__status--loading{background:linear-gradient(145deg,#080c10f2,#0e1820e0 60%,#04080ce6),#080c10e6;box-shadow:0 14px 40px #00bcd447;padding:14px 18px 18px;width:min(320px,80vw)}.three-renderer__status--ready{background:linear-gradient(145deg,#081018f2,#0c1820e6 55%,#060e16f2),#0a1018eb;box-shadow:0 14px 42px #00bcd452;padding:18px 22px;width:min(320px,80vw)}.three-renderer__status--interactive{pointer-events:auto}.three-renderer__poster-wrapper{aspect-ratio:2/3;border:1px solid #00bcd44d;border-radius:6px;box-shadow:0 8px 24px #00bcd438;overflow:hidden;width:min(260px,70vw)}.three-renderer__poster{display:block;height:auto;width:100%}.three-renderer__status-text{align-items:center;display:flex;flex-direction:column;gap:6px}.three-renderer__status--error{border-color:#ff6b6b80;color:#ff6b6b}.three-renderer__status-line{overflow-wrap:anywhere;white-space:normal}.three-renderer__status-line--sub{color:#e0fbfccc;font-size:.75rem}.three-renderer__progress{background:#081c2499;border:1px solid #00bcd440;border-radius:999px;box-shadow:inset 0 0 6px #00bcd459;height:6px;max-width:220px;overflow:hidden;width:100%}.three-renderer__progress-bar{background:linear-gradient(90deg,#00bcd4,#4dd0e1);height:100%;transition:width .25s ease-out}.three-renderer__start-button{background:linear-gradient(135deg,#00bcd4e6,#4dd0e1e6);border:1px solid #00bcd499;border-radius:6px;box-shadow:0 8px 24px #00bcd440;color:#011627;cursor:pointer;font-family:Courier New,monospace;font-size:.9rem;letter-spacing:.04em;margin-top:6px;padding:8px 18px;transition:transform .15s ease,box-shadow .15s ease}.three-renderer__start-button:focus,.three-renderer__start-button:hover{box-shadow:0 12px 30px #00bcd461;outline:none;transform:translateY(-1px)}.three-renderer__start-button:active{box-shadow:0 6px 18px #00bcd433;transform:translateY(0)}.three-renderer__hint{background:#080c1099;border-radius:4px;bottom:14px;color:#e0fbfcd9;font-family:Courier New,monospace;font-size:.75rem;letter-spacing:.02em;padding:6px 10px;pointer-events:none;position:absolute;right:16px}.game-board.build-mode{border-color:#ff6b35;box-shadow:0 0 20px #ff6b3580;cursor:crosshair}.game-board.small-world{background-color:#0a0a0a}.viewport-content{align-items:center;display:flex;flex-direction:column;justify-content:center}.padding-cell{background-color:#0a0a0a;border-color:#4040400d}.padding-cell .empty{background-color:initial;color:#0000}.build-cursor{pointer-events:none;z-index:100}.build-preview{position:relative;text-align:center}.build-character{color:#ff6b35;display:block;font-size:20px;font-weight:700;text-shadow:0 0 8px #ff6b35}.tile-layer{align-items:center;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0}.terrain-layer{z-index:1}.entity-layer{z-index:4}.entity-layer.animal{filter:drop-shadow(0 0 3px rgba(0,0,0,.35));font-size:16px;transition:transform .35s ease,opacity .35s ease}.entity-layer.animal-rabbit{font-size:18px}.entity-layer.animal-rabbit.is-alert{transform:scale(1.12)}.entity-layer.animal-worm{font-size:15px}.entity-layer.animal-worm.is-hidden{opacity:.45;transform:translateY(2px)}.building-layer{z-index:5}.belt-item-layer{color:gold;font-size:12px;font-weight:700;text-shadow:0 0 4px gold;z-index:6}.belt-item-stack-count{color:#fff;font-size:9px;margin-left:2px}.rejected-item-layer{color:#f44;font-size:16px;font-weight:700;opacity:.9;text-shadow:0 0 6px #f44;z-index:7}.power-alert-overlay{animation:power-alert-flash 1s ease-in-out;color:#ffd86b;font-size:18px;font-weight:700;text-shadow:0 0 10px #ffd86bcc;z-index:7.3}@keyframes power-alert-flash{0%,to{opacity:.2;transform:scale(.9)}50%{opacity:1;transform:scale(1)}}.crafting-progress-indicator{font-size:10px;pointer-events:none;z-index:7.5}.crafting-spinner{align-items:center;animation:pulse 1.5s ease-in-out infinite;border:1px solid #4ecdc499;border-radius:50%;color:#fff;display:flex;font-size:8px;font-weight:700;height:20px;justify-content:center;text-shadow:0 0 2px #000;width:20px}@keyframes pulse{0%,to{box-shadow:0 0 4px #4ecdc466}50%{box-shadow:0 0 8px #4ecdc4cc}}.player-layer{font-size:20px;z-index:8}.player{color:#0f0;text-shadow:0 0 8px #0f0;transition:opacity .3s ease-in-out}.player-faded{opacity:.3}.preview-layer{opacity:.8;z-index:12}.belt-preview-layer{animation:belt-preview-flash .6s ease-in-out infinite alternate;color:#ff6b35;font-size:16px;opacity:1;text-shadow:0 0 8px #ff6b35;z-index:15}@keyframes belt-preview-flash{0%{color:#ff8c35;opacity:.8;text-shadow:0 0 8px #ff8c35}to{color:#fff;opacity:1;text-shadow:0 0 15px #fff,0 0 25px #ffaa35}}.belt-preview-cell{position:relative}.belt-preview-char{align-items:center;animation:belt-preview-flash .6s ease-in-out infinite alternate;bottom:0;color:#ff6b35;display:flex;font-size:16px;justify-content:center;left:0;opacity:1;pointer-events:none;position:absolute;right:0;text-shadow:0 0 8px #ff6b35;top:0;z-index:15}.quick-belt-preview-cell{box-shadow:inset 0 0 0 2px #4ecdc473}.quick-belt-preview-cell.quick-belt-preview-invalid{box-shadow:inset 0 0 0 2px #ff6b6b99}.quick-belt-preview-char{color:#4ecdc4;text-shadow:0 0 8px #4ecdc4b3}.quick-belt-preview-char.quick-belt-preview-char-invalid{color:#ff6b6b;text-shadow:0 0 8px #ff6b6bbf}.build-tooltip{background-color:#000000e6;border:1px solid #ff6b35;border-radius:4px;box-shadow:0 2px 8px #00000080;color:#fff;font-size:11px;left:50%;padding:6px 10px;position:absolute;top:25px;transform:translateX(-50%);white-space:nowrap}.target-highlight{background-color:#ff6b3580!important;border-color:#ff6b35cc!important;box-shadow:inset 0 0 8px #ff6b3599,0 0 4px #ff6b3566;z-index:5}.facing-tint{background-color:#00ffff26!important;border-color:#00ffff4d!important;box-shadow:inset 0 0 4px #0ff3;z-index:3}.game-row{align-items:center;display:flex;line-height:1;margin:0;padding:0}.game-cell{align-items:center;background-clip:padding-box;border:.5px solid #80808014;box-sizing:border-box;display:inline-flex;height:1em;justify-content:center;line-height:1em;overflow:hidden;position:relative;vertical-align:top;width:1ch}.game-cell:hover{background-color:#ffffff05;border-color:#80808033}.player{color:#0ff;text-shadow:0 0 5px #0ff;z-index:10}.player,.wall{font-weight:700}.wall{background-color:#6666;color:#666}.tree{background-color:#32cd3226;color:#32cd32;text-shadow:0 0 2px #228b22}.rock,.tree{font-weight:700}.rock{background-color:#8b735533;color:#a0a0a0;text-shadow:0 0 1px #8b7355}.resource{color:gold;text-shadow:0 0 3px gold}.empty{background-color:#8080800d;color:#8080804d}.water{background-color:#4169e14d;color:#4169e1;text-shadow:0 0 3px #4169e1}.sand{background-color:#f4a46026;color:#f4a460}.grass{background-color:#1a4a1a14;color:#1a4a1a}.mountain{background-color:#6969694d;color:grey;font-weight:700;text-shadow:0 0 2px #696969}.iron-node{background-color:#c0c0c066;color:#e0e0e0;font-weight:700;text-shadow:0 0 4px silver}.copper-node{background-color:#b8733366;color:peru;font-weight:700;text-shadow:0 0 4px #b87333}.bridge{background-color:#8b451399;border:1px solid #8b4513cc;color:tan;text-shadow:0 0 3px #8b4513}.bridge,.miner{font-weight:700}.miner{background-color:#ff6b3566!important;border-color:#ff6b3599!important;color:#ff6b35;text-shadow:0 0 4px #ff6b35,0 0 8px #ff6b35}.save-menu-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#040c14b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:1900}.save-menu{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:linear-gradient(140deg,#081420f0,#060e18f5 45%,#040a12fa);background:var(--menu-surface-bg);border:1px solid #4ecdc48c;border:1px solid var(--menu-border);border-radius:18px;box-shadow:0 22px 45px #0000008c,0 28px 60px #0009;box-shadow:var(--menu-shadow),0 28px 60px #0009;color:#ebfff8;color:var(--menu-text-primary);gap:20px;isolation:isolate;left:50%;max-height:min(84vh,720px);overflow:hidden;padding:24px 28px;position:fixed;top:50%;transform:translate(-50%,-50%);width:min(760px,92vw);z-index:2000}.save-menu,.save-menu-content{display:flex;flex-direction:column}.save-menu-content{flex:1 1;gap:18px;margin-right:-6px;overflow-y:auto;padding-right:6px;scrollbar-width:thin}.save-menu-content::-webkit-scrollbar{width:8px}.save-menu-content::-webkit-scrollbar-track{background:#06121c99;border-radius:999px}.save-menu-content::-webkit-scrollbar-thumb{background:#4ecdc459;border-radius:999px}.auto-save-section,.load-section,.save-section{background:linear-gradient(150deg,#0c222ce6,#0a1c26eb 55%,#08141ef0);border:1px solid #4ecdc447;border-radius:14px;box-shadow:inset 0 0 0 1px #4ecdc414;color:#dbfff4c7;color:var(--menu-text-secondary);padding:18px 20px}.auto-save-section h3,.load-section h3,.save-section h3{color:#4ecdc4;color:var(--menu-accent);font-size:1.1rem;letter-spacing:.06em;margin:0 0 14px;text-transform:uppercase}.auto-save-slot{cursor:default}.auto-save-note{color:#c8e6deb3;font-size:.82em;margin-top:8px}.save-menu-header{align-items:flex-start;border-bottom:1px solid #4ecdc440;display:flex;gap:16px;justify-content:space-between;padding-bottom:16px}.save-menu-header h3{color:#ebfff8;color:var(--menu-text-primary);font-size:1.45rem;letter-spacing:.08em;margin:0;text-shadow:0 0 12px #4ecdc440;text-transform:uppercase}.save-menu-header .close-button{font-size:.85em;padding:6px 12px}.close-button-header{background:none;border:none;border-radius:4px;color:#f44;cursor:pointer;font-size:20px;padding:5px}.close-button-header:hover{background-color:#f443}.load-section,.save-section{margin-bottom:0}.save-controls{display:flex;flex-direction:column;gap:15px}.clipboard-controls{display:flex;flex-wrap:wrap;gap:10px}.save-name-input{align-items:center;display:flex;gap:10px}.save-name-input label{color:#aed0caa6;color:var(--menu-muted);letter-spacing:.04em;min-width:100px}.save-name-input input{background:#081820d9;border:1px solid #4ecdc440;border-radius:10px;color:#ebfff8;color:var(--menu-text-primary);flex:1 1;font-family:Courier New,monospace;padding:10px 12px;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.save-name-input input:focus{background:#0c202af2;border-color:#4ecdc48c;box-shadow:0 0 0 3px #4ecdc42e;outline:none}.slot-selector{align-items:center;display:flex;gap:10px}.slot-selector label{color:#0f0;min-width:100px}.slot-buttons{display:flex;gap:8px}.slot-button{background:#0a1c24d1;border:1px solid #4ecdc447;border-radius:999px;color:#dbfff4c7;color:var(--menu-text-secondary);cursor:pointer;font-family:Courier New,monospace;letter-spacing:.05em;padding:7px 14px;transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease}.slot-button:hover{background:#102a34e6;border-color:#4ecdc480;box-shadow:0 6px 14px #00000059;transform:translateY(-1px)}.slot-button.selected{background:linear-gradient(135deg,#6eecdceb,#4ecdc4e6 55%,#3cb0a8eb);border-color:#4ecdc4a6;box-shadow:inset 0 1px 0 #fff6,0 10px 20px #4ecdc461;color:#0f1b1d}.slot-button.occupied{border-color:#ffd166a6;color:#ffd166e6}.clipboard-button,.close-button,.copy-button,.delete-button,.load-button,.new-game-button,.save-button{border:1px solid #0000;border-radius:10px;cursor:pointer;font-family:Courier New,monospace;font-size:.8em;font-weight:600;letter-spacing:.08em;padding:8px 16px;text-transform:uppercase;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,filter .16s ease}.save-button{background:linear-gradient(135deg,#7eece0f5,#4ecdc4e6 55%,#40b2a8f0);border-color:#4ecdc4a6;box-shadow:0 10px 24px #4ecdc44d;color:#062021}.save-button:hover{box-shadow:0 14px 32px #4ecdc461;transform:translateY(-1px)}.load-button{background:linear-gradient(135deg,#74d4fff2,#48a6dceb 55%,#3084c4f0);border-color:#48a6dc99;box-shadow:0 10px 24px #48a6dc47;color:#061c24}.load-button:hover{box-shadow:0 14px 32px #48a6dc5c;transform:translateY(-1px)}.clipboard-button,.copy-button{background:linear-gradient(135deg,#b484fff0,#8a60ece6 45%,#704ad2eb);border-color:#8a60ec8c;box-shadow:0 10px 22px #8a60ec52;color:#f3ecff}.clipboard-button.secondary{background:linear-gradient(135deg,#7ed0ffeb,#60a8ece6 45%,#4880d2eb);border-color:#60a8ec80;color:#061e2a}.clipboard-button.secondary:hover,.clipboard-button:hover,.copy-button:hover{box-shadow:0 14px 28px #8a60ec59;filter:brightness(1.05);transform:translateY(-1px)}.clipboard-button:disabled,.copy-button:disabled{background:#142028cc;border-color:#4ecdc42e;box-shadow:none;color:#b4d2cc73;cursor:not-allowed;transform:none}.save-slots-list{display:flex;flex-direction:column;gap:14px}.save-slot{align-items:stretch;background:linear-gradient(150deg,#0e2630e6,#0a1a24eb 52%,#08141ef2);border:1px solid #4ecdc442;border-radius:14px;box-shadow:inset 0 0 0 1px #4ecdc40f;display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;padding:16px 18px;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease}.save-slot:hover{border-color:#4ecdc480;box-shadow:inset 0 0 0 1px #4ecdc41f,0 16px 30px #0006;transform:translateY(-2px)}.save-slot.filled{border-color:#4ecdc466}.save-slot.empty{background:linear-gradient(150deg,#0a1c24b8,#08141cc7 60%,#060e16d1);border-color:#4ecdc440;border-style:dashed}.save-slot.demo-slot{background:linear-gradient(150deg,#202c54eb,#182046f0 55%,#12183af5);border-color:#7ca0ff80}.slot-info{display:flex;flex:1 1 240px;flex-direction:column;gap:8px;min-width:0}.slot-name{color:#ebfff8;color:var(--menu-text-primary);font-size:1.05rem;font-weight:700;letter-spacing:.04em}.slot-details{color:#aed0caa6;color:var(--menu-muted);display:flex;flex-direction:column;font-size:.86em;gap:4px}.slot-timestamp{color:#c0e1dcbf}.demo-slot-notice{background:#405aa02e;border:1px solid #7ca0ff59;border-radius:10px;color:#c3d2ffd9;font-size:.8em;letter-spacing:.04em;padding:10px 12px}.slot-actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.delete-button{background:linear-gradient(135deg,#ff7c7cf5,#dc3e4ef0 55%,#a82030f5);border-color:#dc3e4e8c;box-shadow:0 10px 24px #dc3e4e59;color:#ffecec}.delete-button:hover{box-shadow:0 14px 30px #dc3e4e6b;transform:translateY(-1px)}.empty-slot-text{color:#b4d2cc80;font-style:italic}.menu-actions{border-top:1px solid #4ecdc438;display:flex;gap:12px;justify-content:space-between;margin-top:24px;padding-top:18px}.new-game-button{background:linear-gradient(135deg,#ffbc78f5,#ff8e44eb 55%,#e05e20f5);border-color:#ff8e4499;box-shadow:0 14px 32px #ff8e4452;color:#330b00}.new-game-button.danger{background:linear-gradient(135deg,#ff7878f2,#e84444f0 55%,#b01c1cf5);border-color:#e844448c;box-shadow:0 14px 34px #e8444461;color:#fff1f1}.new-game-button.danger:hover,.new-game-button:hover{box-shadow:0 18px 36px #ff8e445c;transform:translateY(-1px)}.close-button{background:linear-gradient(135deg,#1a2c34e6,#122028eb 55%,#0c141cf0);border-color:#4ecdc433;box-shadow:0 10px 24px #00000059;color:#dbfff4c7;color:var(--menu-text-secondary)}.close-button:hover{box-shadow:0 14px 30px #0006;filter:brightness(1.1);transform:translateY(-1px)}.build-menu{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:linear-gradient(140deg,#081420f0,#060e18f5 45%,#040a12fa);background:var(--menu-surface-bg);border:1px solid #4ecdc48c;border:1px solid var(--menu-border);border-radius:18px;box-shadow:0 22px 45px #0000008c,0 24px 60px #0000008c;box-shadow:var(--menu-shadow),0 24px 60px #0000008c;color:#ebfff8;color:var(--menu-text-primary);display:flex;flex-direction:column;gap:18px;left:50%;margin-right:-6px;max-height:min(78vh,660px);overflow-y:auto;padding:22px 6px 22px 26px;position:fixed;scrollbar-width:thin;top:50%;transform:translate(-50%,-50%);width:min(640px,90vw);z-index:1600}.build-menu::-webkit-scrollbar{width:8px}.build-menu::-webkit-scrollbar-track{background:#06121c99;border-radius:999px}.build-menu::-webkit-scrollbar-thumb{background:#4ecdc452;border-radius:999px}.build-menu-header{border-bottom:1px solid #4ecdc440;color:#dbfff4c7;color:var(--menu-text-secondary);margin-bottom:0;padding-bottom:12px;text-align:center}.build-menu-header h3{color:#ebfff8;color:var(--menu-text-primary);letter-spacing:.08em;margin:0 0 10px;text-transform:uppercase}.build-menu-header p{color:#aed0caa6;color:var(--menu-muted);font-size:.82em;margin:0}.category-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.category-item{background:linear-gradient(145deg,#0c202aeb,#0a1c26f0 55%,#08141ef5);border:1px solid #4ecdc438;border-radius:14px;cursor:pointer;padding:16px 18px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.category-item:hover{border-color:#4ecdc473;box-shadow:0 16px 28px #0006;transform:translateY(-2px)}.category-header{align-items:center;color:#ebfff8;color:var(--menu-text-primary);display:flex;justify-content:space-between;margin-bottom:10px}.category-header h4{font-size:1.05em;letter-spacing:.05em;margin:0;text-transform:uppercase}.category-header kbd{background:#4ecdc426;border:1px solid #4ecdc466;border-radius:6px;color:#4ecdc4;color:var(--menu-accent);font-size:.75em;padding:2px 6px}.building-preview{display:flex;gap:5px}.preview-char{color:#ccc;font-family:Courier New,monospace;font-size:1.2em}.building-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr}.building-item{background:linear-gradient(145deg,#0c202ae6,#0a1a24eb 55%,#08121cf2);border:1px solid #4ecdc43d;border-radius:14px;cursor:pointer;display:flex;gap:14px;padding:14px 16px;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.building-item:hover{border-color:#4ecdc480;box-shadow:0 16px 28px #00000073;transform:translateY(-2px)}.building-item.affordable{border-color:#6eece0a6}.building-item.expensive{border-color:#ff63848c;cursor:not-allowed;opacity:.6}.building-item.selected{background:linear-gradient(145deg,#ffd1662e,#ffaa002e 55%,#ff960038)!important;border-color:#ffd166bf!important;box-shadow:0 16px 30px #ffaa0059;transform:translateY(-2px) scale(1.02)}.building-icon{align-items:center;background:#06121acc;border-radius:12px;color:#4ecdc4;color:var(--menu-accent);display:flex;font-family:Courier New,monospace;font-size:2em;height:56px;justify-content:center;width:56px}.building-info{display:flex;flex:1 1;flex-direction:column;gap:6px}.building-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.building-name{color:#ebfff8;color:var(--menu-text-primary);font-weight:700;letter-spacing:.04em}.building-cost{color:#ffd166;color:var(--menu-warning);font-size:.82em}.building-description{color:#aed0caa6;color:var(--menu-muted);font-size:.82em;line-height:1.5}kbd{background:#4ecdc426;border:1px solid #4ecdc459;border-radius:6px;color:#4ecdc4;color:var(--menu-accent);font-family:Courier New,monospace;font-size:.82em;letter-spacing:.05em;padding:2px 6px}.game-stats{background-color:#111;border:1px solid #0f0;border-radius:5px;flex-shrink:0;margin:10px auto;max-width:400px;padding:10px;text-align:center}.game-stats.build-mode-active{background-color:#ff6b351a;border-color:#ff6b35;box-shadow:0 0 15px #ff6b354d}.game-stats p{color:#0f0;font-size:.9em;margin:3px 0}.build-mode-indicator{color:#ff6b35!important;font-size:1em!important;font-weight:700;text-shadow:0 0 8px #ff6b35}.build-instructions{color:#ff0!important;font-size:.8em!important;font-style:italic;margin-top:5px!important}.building-status-menu-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#040c14b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:2500}.building-status-menu{background:linear-gradient(140deg,#081420f0,#060e18f5 45%,#040a12fa);background:var(--menu-surface-bg);border:1px solid #4ecdc48c;border:1px solid var(--menu-border);border-radius:18px;box-shadow:0 22px 45px #0000008c,0 26px 60px #0000008c;box-shadow:var(--menu-shadow),0 26px 60px #0000008c;color:#ebfff8;color:var(--menu-text-primary);display:flex;flex-direction:column;gap:18px;max-height:min(82vh,720px);overflow-y:auto;padding:24px 28px;scrollbar-width:thin;width:min(720px,92vw)}.building-status-menu::-webkit-scrollbar{width:8px}.building-status-menu::-webkit-scrollbar-track{background:#06121c99;border-radius:999px}.building-status-menu::-webkit-scrollbar-thumb{background:#4ecdc452;border-radius:999px}.building-status-menu-header{align-items:flex-start;border-bottom:1px solid #4ecdc440;display:flex;gap:14px;justify-content:space-between;padding-bottom:16px}.building-status-menu-header h3{color:#ebfff8;color:var(--menu-text-primary);font-size:1.35rem;letter-spacing:.06em;margin:0;text-shadow:0 0 12px #4ecdc440;text-transform:uppercase}.building-position{color:#aed0caa6;color:var(--menu-muted);font-size:.85em}.building-status-menu-content{display:flex;flex-direction:column;gap:16px}.mobile-action-menu-overlay{background-color:#00000073;inset:0;position:fixed;z-index:2600}.mobile-action-menu{background-color:#0a0a0af2;border:2px solid #4ecdc4;border-radius:12px;box-shadow:0 0 20px #4ecdc459;color:#0f0;padding:16px 18px;position:absolute;width:220px}.mobile-action-menu__header{align-items:baseline;display:flex;gap:8px;justify-content:space-between;margin-bottom:8px}.mobile-action-menu__title{color:#4ecdc4;font-size:1.05rem;margin:0}.mobile-action-menu__coordinates{color:#8fd;font-size:.8rem}.mobile-action-menu__subtitle{color:#b8fff6;font-size:.85rem;letter-spacing:.04em;margin:0 0 12px}.mobile-action-menu__options{display:flex;flex-direction:column;gap:10px}.mobile-action-menu__button{background-color:#002020d9;border:1px solid #4ecdc4;border-radius:6px;color:#0f9;cursor:pointer;font-size:.95rem;letter-spacing:.08em;padding:10px 12px;text-transform:uppercase;transition:background-color .15s ease,transform .1s ease,box-shadow .15s ease}.mobile-action-menu__button:focus-visible:not(:disabled),.mobile-action-menu__button:hover:not(:disabled){background-color:#004040f2;box-shadow:0 0 12px #4ecdc459;outline:none}.mobile-action-menu__button:active:not(:disabled){transform:translateY(1px)}.mobile-action-menu__button:disabled{border-color:#4ecdc466;color:#88ffdd73;cursor:not-allowed;opacity:.35}.stored-inventory-section{background-color:#4ecdc414;border:1px solid #4ecdc459;border-radius:8px;display:flex;flex-direction:column;gap:10px;padding:12px}.stored-inventory-section h4{color:#4ecdc4;font-size:1em;margin:0}.stored-inventory-list{display:flex;flex-direction:column;gap:8px}.inventory-item-row{align-items:center;background-color:#00000059;border:1px solid #4ecdc440;border-radius:6px;display:flex;gap:12px;justify-content:space-between;padding:8px 12px}.collect-item-button{background-color:#4ecdc4;border:none;border-radius:6px;color:#0b1c1c;cursor:pointer;font-size:.85em;font-weight:600;padding:6px 12px;transition:background-color .15s ease,box-shadow .15s ease}.collect-item-button:focus-visible,.collect-item-button:hover{background-color:#3cb7ac;box-shadow:0 0 10px #4ecdc473;outline:none}.inventory-actions{display:flex;gap:10px;justify-content:flex-end}.collect-all-button{background:linear-gradient(90deg,#45b7d1,#4ecdc4);border:none;border-radius:6px;color:#0b1c1c;cursor:pointer;font-weight:700;padding:8px 16px;transition:transform .15s ease,box-shadow .15s ease}.collect-all-button:focus-visible,.collect-all-button:hover{box-shadow:0 0 14px #4ecdc473;outline:none;transform:translateY(-1px)}.resource-node-menu{background-color:#0a1414f2;border:2px solid #4ecdc4;border-radius:10px;bottom:40px;box-shadow:0 0 25px #4ecdc459;color:#0f0;display:flex;flex-direction:column;gap:16px;left:50%;padding:18px 22px;position:fixed;transform:translateX(-50%);width:min(320px,calc(100vw - 40px));z-index:2600}.resource-node-menu__header{align-items:center;display:flex;justify-content:space-between}.resource-node-menu__header h3{color:#4ecdc4;font-size:1.1em;margin:0}.resource-node-menu__content{display:flex;flex-direction:column;gap:12px}.resource-node-menu__title{color:#00ffb3;font-size:1.05em;font-weight:600;margin:0;text-align:center}.resource-node-menu__mine-button{background:linear-gradient(135deg,#0b3d3e,#132e32);border:none;border-radius:6px;color:#d7fff6;cursor:pointer;font-weight:700;overflow:hidden;padding:10px 14px;position:relative;transition:transform .15s ease,box-shadow .15s ease,background .2s ease,color .2s ease}.resource-node-menu__mine-button:after{background:radial-gradient(circle at center,#00f5d48c 0,#00f5d426 35%,#f15bb559 65%,#f15bb500 90%);border:2px solid #00f5d480;border-radius:8px;content:"";filter:drop-shadow(0 0 12px rgba(0,245,212,.45));inset:-4px;opacity:0;pointer-events:none;position:absolute;transform:scale(.9)}.resource-node-menu__mine-button--flashing:after{animation:manual-mine-flash .55s ease-out}.resource-node-menu__mine-button--flashing{background:linear-gradient(135deg,#00f5d4,#00bbf9 45%,#f15bb5 90%);box-shadow:0 0 22px #f15bb58c,0 0 16px #00f5d48c;color:#042727}.resource-node-menu__mine-button:focus-visible,.resource-node-menu__mine-button:hover{box-shadow:0 0 14px #00f5d466;outline:none;transform:translateY(-1px)}@keyframes manual-mine-flash{0%{border-color:#00f5d4e6;filter:drop-shadow(0 0 20px rgba(0,245,212,.65));opacity:1;transform:scale(.75)}50%{border-color:#f15bb5bf;filter:drop-shadow(0 0 28px rgba(241,91,181,.65));opacity:.75;transform:scale(1.18)}to{border-color:#f15bb500;filter:drop-shadow(0 0 32px rgba(241,91,181,0));opacity:0;transform:scale(1.45)}}.resource-node-menu__hint{color:#ffffffa6;font-size:.85em;margin:0;text-align:center}.launch-rocket-section{background-color:#111;border:1px solid #4ecdc4;border-radius:8px;display:flex;flex-direction:column;gap:12px;padding:16px}.launch-rocket-warning{color:#ff6b6b;font-size:.95em;margin:0}.launch-rocket-progress{color:#ccc;font-size:.9em;margin:0}.launch-rocket-button{align-self:flex-start;background-color:#4ecdc4;border:none;border-radius:6px;color:#0b1c1c;cursor:pointer;font-weight:700;padding:10px 18px;transition:background-color .2s ease,transform .1s ease}.launch-rocket-button:hover{background-color:#76f7dc;transform:translateY(-1px)}.launch-rocket-button:active{transform:translateY(0)}.recipe-list{display:flex;flex-direction:column;gap:10px}.recipe-item{background-color:#333;border:1px solid #555;border-radius:8px;cursor:pointer;padding:15px;transition:all .2s ease}.recipe-item:hover{border-color:#4ecdc4;box-shadow:0 0 10px #4ecdc433}.recipe-item.selected{background-color:#4ecdc41a;border-color:#4ecdc4;box-shadow:0 0 15px #4ecdc44d}.recipe-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.recipe-header h4{color:#0ff;font-size:1.1em;margin:0}.crafting-time{background-color:#444;border-radius:4px;color:#ff0;font-size:.9em;padding:2px 6px}.recipe-details{align-items:center;display:flex;flex-wrap:wrap;gap:15px}.recipe-inputs,.recipe-outputs{display:flex;flex-direction:column;gap:5px}.recipe-inputs .label,.recipe-outputs .label{color:#888;font-size:.8em;font-weight:700;text-transform:uppercase}.ingredient{align-items:center;background-color:#444;border-radius:4px;color:#fff;display:flex;font-size:.9em;gap:6px;padding:4px 8px}.ingredient-count{color:#ff0;font-size:.8em;font-weight:700}.recipe-arrow{align-items:center;color:#4ecdc4;display:flex;flex-direction:column;font-size:1.2em;font-weight:700;gap:4px}.selected-recipe-info{background-color:#4ecdc41a;border:1px solid #4ecdc4;border-radius:8px;margin-top:10px;padding:15px}.selected-recipe-info h4{color:#4ecdc4;margin:0 0 10px}.selected-recipe-info p{color:#ccc;font-size:.9em;margin:0}.selected-recipe-view{display:flex;flex-direction:column;gap:20px}.selected-recipe-details{align-items:center;background-color:#333;border:1px solid #4ecdc4;border-radius:8px;display:flex;gap:15px;padding:15px}.recipe-actions{display:flex;justify-content:center;margin-top:10px}.assembler-upgrade-section{align-items:center;display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.upgrade-factory-button{background-color:#4ecdc4;border:none;border-radius:6px;color:#0d1b2a;cursor:pointer;font-weight:700;padding:10px 20px;transition:transform .15s ease,box-shadow .15s ease}.upgrade-factory-button:hover{box-shadow:0 0 10px #4ecdc466;transform:translateY(-1px)}.upgrade-factory-note{color:#ccc;display:flex;flex-direction:column;font-size:.85em;gap:2px;text-align:center}.change-recipe-button{background-color:#ff6b35;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1em;font-weight:700;padding:10px 20px;transition:all .2s ease}.change-recipe-button:hover{background-color:#e55a2b;box-shadow:0 0 10px #ff6b354d}.recipe-list h4{color:#4ecdc4;margin:0 0 15px;text-align:center}.crafting-progress-section{background-color:#2a2a2a;border:1px solid #444;border-radius:8px;margin:20px 0;padding:15px}.crafting-duration{color:#ff0;font-size:.9em;font-weight:400}.crafting-status{display:flex;flex-direction:column;gap:8px}.crafting-label{color:#4ecdc4;font-size:.95em;font-weight:700}.progress-bar-container{align-items:center;display:flex;gap:10px}.progress-bar{background-color:#1a1a1a;border:2px solid #666;border-radius:10px;flex-grow:1;height:20px;overflow:hidden;position:relative}.progress-fill{background:linear-gradient(90deg,#45b7d1,#4ecdc4);border-radius:8px;box-shadow:0 0 10px #4ecdc466;height:100%}.progress-text{color:#fff;font-size:.9em;font-weight:700;min-width:45px;text-align:right}.crafting-time-info{display:flex;justify-content:center;margin-top:5px}.time-remaining{color:#ff0;font-size:.9em;font-style:italic}.crafting-complete{color:#0f0;font-size:.95em;font-weight:700;text-shadow:0 0 8px #0f0}.idle-status{align-items:center;display:flex;justify-content:center;padding:10px}.idle-label{color:#aaa;font-weight:700}.ready-status{color:#0f0;font-weight:700;text-shadow:0 0 6px #0f0}.waiting-status{color:#ff6b35;font-weight:700;text-shadow:0 0 6px #ff6b35}.loading-screen{background-color:#000}.loading-screen h1{color:#0ff;margin-bottom:40px;text-shadow:0 0 10px #0ff}.loading-message{text-align:center}.loading-message p{color:#ff0;font-size:1.2em;margin-bottom:20px}.loading-spinner{font-size:3em}.debug-menu{background-color:#1a1a1a;border:3px solid #f60;border-radius:12px;box-shadow:0 0 40px #f606;color:#fff;left:50%;max-height:85vh;max-width:700px;overflow-y:auto;padding:25px;position:fixed;top:50%;transform:translate(-50%,-50%);z-index:3000}.debug-menu-header{border-bottom:2px solid #f60;margin-bottom:25px;padding-bottom:15px;text-align:center}.debug-menu-header h3{color:#f60;font-size:1.4em;margin:0 0 10px;text-shadow:0 0 10px #f60}.debug-menu-header p{color:#aaa;font-size:.9em;font-style:italic;margin:0}.debug-section{background-color:#2a2a2a;border:1px solid #444;border-radius:8px;margin-bottom:25px;padding:20px}.debug-section h4{border-bottom:1px solid #444;color:#f90;font-size:1.1em;margin:0 0 15px;padding-bottom:8px}.debug-controls{display:flex;flex-direction:column;gap:15px}.debug-research-controls{gap:20px}.debug-research-list{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.tick-info{background-color:#1a1a1a;border:1px solid #333;border-radius:6px;margin-bottom:15px;padding:12px}.tick-info p{color:#ccc;margin:5px 0}.tick-info strong{color:#0f0}.step-controls{display:flex;flex-wrap:wrap;gap:10px}.debug-button.active{background-color:#f90;color:#000}.debug-button.active:hover{background-color:#fa3}.resource-controls{align-items:center;display:flex;flex-wrap:wrap;gap:15px}.resource-controls label{color:#fff;font-weight:700;min-width:120px}.resource-input{background-color:#333;border:2px solid #666;border-radius:6px;box-sizing:border-box;color:#fff;display:flex;flex-direction:column;font-family:Courier New,monospace;gap:8px;padding:12px;width:100%}.resource-input:focus-within{border-color:#f60;box-shadow:0 0 8px #ff66004d}.resource-input label{color:#fff;font-weight:700;text-align:left}.resource-input input,.resource-input select{background-color:#1e1e1e;border:1px solid #555;border-radius:4px;box-sizing:border-box;color:#fff;font-family:Courier New,monospace;padding:8px 10px;width:100%}.resource-input input:focus,.resource-input select:focus{border-color:#f60;box-shadow:0 0 8px #ff66004d;outline:none}.sound-volume-control{align-items:center;display:flex;gap:12px;width:100%}.sound-volume-control input[type=range]{-webkit-appearance:none;appearance:none;background-color:#555;border-radius:4px;flex:1 1;height:6px;min-width:0}.sound-volume-control input[type=range]::-webkit-slider-runnable-track{background:linear-gradient(90deg,#f60,#fa3);border-radius:4px;height:6px}.sound-volume-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background-color:#fc6;border:2px solid #f90;border-radius:50%;height:16px;margin-top:-5px;width:16px}.sound-volume-control input[type=range]::-moz-range-track{background:#555;border-radius:4px;height:6px}.sound-volume-control input[type=range]::-moz-range-progress{background:linear-gradient(90deg,#f60,#fa3);border-radius:4px;height:6px}.sound-volume-control input[type=range]::-moz-range-thumb{background-color:#fc6;border:2px solid #f90;border-radius:50%;height:16px;width:16px}.sound-volume-value{font-feature-settings:"tnum";color:#fc6;font-variant-numeric:tabular-nums;font-weight:700;min-width:48px;text-align:right}.current-resources{color:#ff0;font-weight:700;margin-top:10px}.resource-count{color:#0f0;font-size:1.2em;text-shadow:0 0 5px #0f0}.cheat-toggle{align-items:center;background-color:#333;border:1px solid #555;border-radius:6px;display:flex;gap:15px;padding:10px}.cheat-description{color:#ccc;font-size:.9em;font-style:italic}.debug-button{border:none;border-radius:6px;cursor:pointer;font-family:Courier New,monospace;font-size:.9em;font-weight:700;padding:10px 20px;transition:all .2s}.debug-button.add-resources{background-color:#0a0;color:#fff}.debug-button.add-resources:hover{background-color:#0c0;box-shadow:0 0 10px #0c06}.debug-button.toggle-button{background-color:#666;color:#fff;min-width:160px}.debug-button.toggle-button:hover{background-color:#777}.debug-button.toggle-button.active{background-color:#f60;border:2px solid #f90;box-shadow:0 0 15px #ff660080;color:#000;text-shadow:none}.logger-controls{margin-bottom:20px}.logger-controls h5{color:#f60;font-size:1.1em;margin:0 0 10px}.logger-checkboxes{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr;margin-bottom:15px}.logger-checkboxes .debug-checkbox{font-size:.9em;margin:0}.log-level-controls{margin-bottom:20px}.log-level-controls h5{color:#f60;font-size:1.1em;margin:0 0 10px}.debug-select{background-color:#333;border:1px solid #555;border-radius:4px;color:#fff;font-size:.9em;padding:8px 12px;width:100%}.debug-select:focus{border-color:#f60;box-shadow:0 0 5px #ff66004d;outline:none}.log-actions{display:flex;flex-wrap:wrap;gap:10px}.log-actions .debug-button{flex:1 1;min-width:120px}.debug-info{grid-gap:10px;background-color:#333;border:1px solid #555;border-radius:6px;display:grid;gap:10px;grid-template-columns:1fr 1fr;padding:15px}.info-row{display:flex;justify-content:space-between;padding:5px 0}.info-row span:first-child{color:#f90;font-weight:700}.info-row span:last-child{color:#0ff;font-family:Courier New,monospace}.debug-actions{border-top:2px solid #f60;display:flex;gap:15px;justify-content:space-between;margin-top:25px;padding-top:20px}.debug-button.reset-button{background-color:#c30;color:#fff;flex:1 1}.debug-button.reset-button:hover{background-color:#f40;box-shadow:0 0 10px #f406}.debug-button.close-button{background-color:#666;color:#fff;flex:1 1}.debug-button.close-button:hover{background-color:#888}.top-menu{align-items:stretch;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(140deg,#081420f0,#060e18f5 45%,#040a12fa);background:var(--menu-surface-bg);border:1px solid #4ecdc48c;border:1px solid var(--menu-border);border-radius:14px;box-shadow:0 22px 45px #0000008c;box-shadow:var(--menu-shadow);color:#ebfff8;color:var(--menu-text-primary);display:flex;flex-direction:column;gap:18px;isolation:isolate;max-width:min(320px,calc(100vw - 48px));min-width:240px;overflow:hidden;padding:18px 22px 20px;position:fixed;right:24px;top:24px;transition:transform .2s ease,box-shadow .2s ease;z-index:1200}.top-menu:before{background:radial-gradient(120% 120% at 10% 12%,#4ecdc442 0,#4ecdc414 24%,#0000 56%),linear-gradient(140deg,#4ecdc41f,#4ecdc400 55%);border-radius:inherit;content:"";inset:1px;mix-blend-mode:screen;opacity:.85;pointer-events:none;position:absolute}.mobile-build-mode-controls{display:none}.mobile-build-mode-label{font-size:.85em;letter-spacing:.08em;text-transform:uppercase}.mobile-build-mode-exit-button{align-items:center;background:#4ecdc41f;border:1px solid #4ecdc4a6;border-radius:999px;color:#4ecdc4;display:inline-flex;font-size:.8em;font-weight:600;justify-content:center;letter-spacing:.1em;padding:6px 12px;text-transform:uppercase;transition:background-color .2s ease,color .2s ease}.mobile-build-mode-exit-button:focus-visible,.mobile-build-mode-exit-button:hover{background:#4ecdc440;color:#fff}.quick-belt-confirmation{background:linear-gradient(145deg,#102e38e0,#0c2028e6 50%,#08161eeb),#4ecdc414;border:1px solid #4ecdc466;border-radius:12px;box-shadow:inset 0 0 0 1px #4ecdc41f;color:#dbfff4c7;color:var(--menu-text-secondary);display:flex;flex-direction:column;gap:8px;padding:12px 14px}.quick-belt-confirmation-invalid{background:linear-gradient(145deg,#3a1014e6,#2a0a0ee6 55%,#1a060aeb);border-color:#ff6b6b99;box-shadow:inset 0 0 0 1px #ff6b6b2e;color:#ffd2d2d9}.quick-belt-summary{display:flex;flex-direction:column;font-size:.84em;gap:4px}.quick-belt-title{color:#4ecdc4;color:var(--menu-accent);font-weight:600;letter-spacing:.08em;text-transform:uppercase}.quick-belt-cost,.quick-belt-count{color:#aed0caa6;color:var(--menu-muted)}.quick-belt-error-message{color:#ff6b6b;color:var(--menu-danger);font-size:.8em}.quick-belt-actions{display:flex;gap:10px;justify-content:flex-end}.quick-belt-button{background:#0c2830c2;border:1px solid #4ecdc466;border-radius:10px;box-shadow:inset 0 1px 0 #ffffff0d;color:#dbfff4c7;color:var(--menu-text-secondary);cursor:pointer;font-size:.8em;letter-spacing:.08em;padding:7px 14px;text-transform:uppercase;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.quick-belt-button:hover:not(:disabled){border-color:#4ecdc4a6;box-shadow:inset 0 1px 0 #ffffff14,0 8px 18px #0006;transform:translateY(-1px)}.quick-belt-button.confirm{background:linear-gradient(140deg,#7eece0f2,#4ecdc4e6 55%,#40b2a8f2);border-color:#4ecdc4b3;color:#072223;font-weight:600}.quick-belt-button.confirm:hover:not(:disabled){box-shadow:inset 0 1px 0 #ffffff59,0 10px 24px #4ecdc473}.quick-belt-button.cancel{background:linear-gradient(140deg,#701820e6,#561018eb 55%,#3a0c12f2);border-color:#ff6b6b8c;box-shadow:inset 0 1px 0 #ffffff0d;color:#ffcbcbe0}.quick-belt-button.cancel:hover:not(:disabled){box-shadow:inset 0 1px 0 #ffffff14,0 10px 20px #ff6b6b4d}.quick-belt-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.55}.game-info{color:#dbfff4c7;color:var(--menu-text-secondary);display:flex;flex-direction:column;font-size:.88em;gap:6px;width:100%}.prestige-info{color:#ffd166;color:var(--menu-warning);font-weight:600;letter-spacing:.04em;text-transform:uppercase}.inventory-window{background:#000000eb;border:2px solid #00ff0073;border-radius:10px;box-shadow:0 16px 30px #0000008c;display:flex;flex-direction:column;gap:12px;max-height:70vh;overflow-y:auto;padding:16px;position:fixed;right:24px;top:120px;width:min(400px,calc(100vw - 48px))}.inventory-window-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between}.inventory-window-title-group{display:flex;flex-direction:column;gap:4px}.inventory-window-title{color:#4ecdc4;font-size:1.05em;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.inventory-window-hotkey{color:#ffffff8c;font-size:.7em;letter-spacing:.12em;text-transform:uppercase}.hand-crafting-menu{background:#4ecdc414;border:1px solid #4ecdc473;border-radius:8px;display:flex;flex-direction:column;gap:10px;padding:12px}.hand-crafting-menu-header{display:flex;flex-direction:column;gap:4px}.hand-crafting-menu-title{color:#4ecdc4;font-size:.8em;letter-spacing:.1em;text-transform:uppercase}.hand-crafting-menu-description{color:#fff9;font-size:.72em;line-height:1.4}.hand-crafting-list{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.hand-crafting-button{align-items:flex-start;background:#00000073;border:1px solid #4ecdc473;border-radius:8px;color:#e7fffb;cursor:pointer;display:flex;flex-direction:column;font-size:.8em;gap:6px;padding:8px;text-align:left;transition:border-color .2s ease,background-color .2s ease,transform .2s ease}.hand-crafting-button:hover:not(:disabled){background:#00ffb71f;border-color:#00ffb7bf;transform:translateY(-1px)}.hand-crafting-button:focus-visible{border-color:#00ffb7e6;box-shadow:0 0 0 2px #00ffb759;outline:none}.hand-crafting-button--disabled,.hand-crafting-button:disabled{background:#ffffff0a;border-color:#ffffff1f;color:#ffffff80;cursor:not-allowed;transform:none}.hand-crafting-item-header{align-items:center;display:flex;gap:6px;justify-content:space-between;width:100%}.hand-crafting-item-icon{color:#4ecdc4;font-size:1.1em}.hand-crafting-item-name{color:#f0fffb;flex:1 1;font-weight:600}.hand-crafting-item-output{color:#ffffffa6;font-size:.72em}.hand-crafting-item-inputs{color:#fff9;font-size:.72em}.hand-crafting-item-status{color:#00ffb7;font-size:.74em;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.hand-crafting-item-status--missing{color:#ff7878d9}.inventory-close-button{background:#4ecdc41a;border:1px solid #4ecdc480;border-radius:6px;color:#4ecdc4;cursor:pointer;font-size:1.1em;height:28px;line-height:1;transition:border-color .2s ease,color .2s ease,background-color .2s ease;width:32px}.inventory-close-button:focus-visible,.inventory-close-button:hover{background:#00ffb71f;border-color:#00ffb7bf;color:#00ffb7;outline:none}.player-inventory{display:flex;flex-direction:column;gap:10px}.held-stack{align-self:flex-start;background:#ffd7001f;border:1px solid #ffd70066;border-radius:6px;color:gold;font-size:.85em;letter-spacing:.04em;padding:6px 10px}.held-stack.empty{background:#ffffff14;border-color:#ffffff40;color:#ffffff80}.inventory-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(72px,1fr))}.inventory-slot{align-items:center;background:#0c0c0cf2;border:1px solid #00ff0059;border-radius:6px;color:#00ffb7;cursor:pointer;display:flex;flex-direction:column;gap:3px;min-height:90px;padding:6px 4px 14px;position:relative;transition:border-color .2s ease,box-shadow .2s ease,transform .12s ease}.inventory-slot:focus-visible,.inventory-slot:hover{border-color:#4ecdc4;box-shadow:0 0 12px #4ecdc473;outline:none;transform:translateY(-1px)}.inventory-slot.empty{background:#080808d9;border-color:#0f03;color:#00ff0059}.inventory-slot.full{border-color:gold;box-shadow:0 0 10px #ffd70059}.inventory-slot.compatible{border-color:#4ecdc499}.inventory-slot.active{box-shadow:0 0 14px #0f09}.inventory-slot-index{color:#ffffff59;font-size:.7em;left:8px;position:absolute;top:6px}.inventory-slot-icon{font-size:1.35em;text-shadow:0 0 6px currentColor}.inventory-slot-stack-indicator{display:flex;flex-wrap:wrap;gap:2px;justify-content:center;max-width:100%}.inventory-slot-stack-square{background:#ffd70026;border:1px solid #ffd70080;border-radius:2px;box-shadow:0 0 6px #ffd70040;height:10px;width:10px}.inventory-slot-name{color:#4ecdc4;font-size:.78em;text-align:center}.inventory-slot-count{color:gold;font-size:.78em}.inventory-slot-capacity{color:#ffffff73;font-size:.65em}.inventory-slot-type{color:#ffffff59;font-size:.6em;letter-spacing:.05em;text-transform:uppercase}.inventory-slot-progress-track{background:#4ecdc433;border-bottom-left-radius:6px;border-bottom-right-radius:6px;bottom:0;height:4px;left:0;overflow:hidden;position:absolute;right:0}.inventory-slot-progress-fill{background:linear-gradient(90deg,#4ecdc480,#0f09);height:100%;transition:width .2s ease}.chest-inventory-grid{margin-top:12px}.chest-slot{display:flex;flex-direction:column;gap:6px}.chest-slot .inventory-slot{width:100%}.chest-inventory-slot{cursor:pointer}.chest-collect-button{width:100%}.chest-inventory-actions{display:flex;flex-direction:column;gap:8px;margin-top:12px}.chest-inventory-actions .collect-all-button{align-self:flex-start}.hand-crafting-status{background:#000c;border:1px solid #00ff0059;border-radius:8px;bottom:20px;box-shadow:0 0 12px #00ff001f;color:#f0fff0d9;font-size:.78rem;left:20px;padding:12px;pointer-events:none;position:absolute;width:220px}.hand-crafting-status h4{color:#0f9;font-size:.82rem;letter-spacing:.08em;margin:0 0 8px;text-transform:uppercase}.hand-crafting-status__current{display:flex;flex-direction:column;gap:6px}.hand-crafting-status__title{color:#fff;font-weight:600}.hand-crafting-status__progress-bar{background:#00ff9926;border-radius:4px;height:6px;overflow:hidden;position:relative}.hand-crafting-status__progress-fill{background:linear-gradient(90deg,#0f9,#0cf);bottom:0;left:0;position:absolute;top:0;transition:width .2s ease}.hand-crafting-status__details{color:#ffffffb3;display:flex;font-size:.74rem;justify-content:space-between}.hand-crafting-status__queue{color:#fff9;font-size:.72rem;margin-top:8px}.hand-crafting-status__idle{color:#ffffff8c;font-size:.74rem;margin:0}.inventory-help-text{color:#ffffff80;font-size:.72em;line-height:1.4;margin:0}.resource-info{color:gold;font-weight:700}.biome-info{color:#0ff}.position-info{color:#888}.menu-buttons{align-items:center;border-bottom:1px solid #4ecdc438;display:flex;flex-wrap:wrap;gap:10px 12px;margin-bottom:4px;padding-bottom:6px}.menu-button,.menu-button-wrapper{align-items:center;display:flex;justify-content:center;position:relative}.menu-button{background:linear-gradient(150deg,#0c222cf0,#0a1c26f5 45%,#06101afa);border:1px solid #4ecdc459;border-radius:12px;box-shadow:inset 0 1px 0 #ffffff0d,0 6px 18px #00000073;color:#ebfff8;color:var(--menu-text-primary);cursor:pointer;font-size:18px;height:44px;overflow:hidden;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease,color .18s ease;width:44px}.menu-button.inventory-pulsing{box-shadow:inset 0 1px 0 #ffffff14,0 0 20px #4ecdc48c,0 6px 18px #00000073}.menu-button:hover{background:linear-gradient(150deg,#1a4850f2,#123840fa 60%,#0c2028fa);border-color:#4ecdc4bf;box-shadow:inset 0 1px 0 #ffffff1f,0 10px 26px #0000008c;transform:translateY(-1px) scale(1.04)}.menu-button.active{background:linear-gradient(148deg,#6cebdcf2,#4ecdc4e6 50%,#3eb0a8f2);border-color:#4ecdc4d9;border-color:var(--menu-border-strong);box-shadow:inset 0 1px 0 #fff6,0 10px 26px #4ecdc466;color:#0f1b1d}.menu-button:focus-visible{border-color:#4ecdc4d9;box-shadow:inset 0 0 0 1px #4ecdc4a6,0 0 0 3px #4ecdc44d,0 8px 24px #00000080;outline:none}.menu-button-icon{position:relative;z-index:1}.inventory-pulse-indicator{animation:inventory-pulse .9s ease-out forwards;background:radial-gradient(circle at center,#4ecdc440 0,#4ecdc400 70%);border:1px solid #4ecdc4a6;border-radius:12px;inset:0;pointer-events:none;position:absolute;z-index:0}.menu-button-badge{background:#4ecdc426;border:1px solid #4ecdc473;border-radius:999px;bottom:4px;color:#dbfff4c7;color:var(--menu-text-secondary);font-size:11px;font-weight:700;letter-spacing:.04em;padding:2px 6px;position:absolute;right:4px;text-shadow:none;z-index:1}.menu-button.active .menu-button-badge,.menu-button:hover .menu-button-badge{background:#4ecdc459;border-color:#4ecdc499;color:#0f1b1d}.menu-button-progress-track{background:#4ecdc41f;border:1px solid #4ecdc473;border-radius:6px 6px 4px 4px;bottom:0;box-sizing:border-box;height:10px;left:0;overflow:hidden;pointer-events:none;position:absolute;width:100%;z-index:0}@keyframes inventory-pulse{0%{opacity:.9;transform:scale(.95)}60%{opacity:.45;transform:scale(1.2)}to{opacity:0;transform:scale(1.35)}}.menu-button-progress-fill{background:linear-gradient(90deg,#45b7d1e6,#4ecdc4);box-shadow:0 0 8px #4ecdc473;display:block;height:100%;left:0;position:absolute;top:0;transition:width .2s ease}.help-menu{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#040c14b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:2000}.help-menu-content{background:linear-gradient(140deg,#081420f0,#060e18f5 45%,#040a12fa);background:var(--menu-surface-bg);border:1px solid #4ecdc48c;border:1px solid var(--menu-border);border-radius:18px;box-shadow:0 22px 45px #0000008c,0 24px 56px #0000008c;box-shadow:var(--menu-shadow),0 24px 56px #0000008c;color:#ebfff8;color:var(--menu-text-primary);display:flex;flex-direction:column;gap:20px;max-height:min(82vh,720px);overflow-y:auto;padding:26px 30px;scrollbar-width:thin;width:min(820px,92vw)}.help-menu-content::-webkit-scrollbar{width:8px}.help-menu-content::-webkit-scrollbar-track{background:#06121c99;border-radius:999px}.help-menu-content::-webkit-scrollbar-thumb{background:#4ecdc452;border-radius:999px}.help-header{align-items:flex-start;border-bottom:1px solid #4ecdc438;display:flex;gap:16px;justify-content:space-between;margin-bottom:16px;padding-bottom:16px}.help-header h3{color:#ebfff8;color:var(--menu-text-primary);font-size:1.4rem;letter-spacing:.06em;margin:0;text-transform:uppercase}.help-header .close-button{font-size:.85em;padding:6px 10px}.help-sections{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(2,minmax(0,1fr))}.help-section{background:linear-gradient(150deg,#0c202ae6,#0a1a24eb 55%,#08121cf2);border:1px solid #4ecdc43d;border-radius:14px;color:#dbfff4c7;color:var(--menu-text-secondary);display:flex;flex-direction:column;gap:10px;padding:18px 20px}.help-section h4{border-bottom:1px solid #4ecdc433;color:#ebfff8;color:var(--menu-text-primary);font-size:1rem;letter-spacing:.05em;margin:0;padding-bottom:6px;text-transform:uppercase}.help-section p{line-height:1.5;margin:6px 0}.help-footer,.help-section p{color:#aed0caa6;color:var(--menu-muted)}.help-footer{border-top:1px solid #4ecdc438;font-size:.85em;margin-top:12px;padding-top:14px;text-align:center}.left-panel{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#000000e6;border:2px solid #0f0;border-radius:8px;left:20px;max-height:calc(100vh - 40px);overflow-y:auto;position:fixed;top:20px;width:300px;z-index:1400}.panel-header{align-items:center;background-color:#333;border-bottom:1px solid #555;border-radius:6px 6px 0 0;display:flex;justify-content:space-between;padding:15px}.panel-header h3{color:#0ff;font-size:1.1em;margin:0}.panel-content{padding:15px}.info-section{background-color:#333;border:1px solid #555;border-radius:6px;margin-bottom:20px;padding:15px}.info-section h4{border-bottom:1px solid #555;color:#0ff;font-size:1em;margin:0 0 10px;padding-bottom:5px}.info-section p{font-size:.9em;margin:5px 0}.build-info{background-color:#ff6b351a!important;border-color:#ff6b35!important}.build-info h4{color:#ff6b35!important}.build-hint{color:#ff0!important;font-style:italic;font-weight:700}.panel-debug{border-top:1px solid #555;padding:15px}.debug-toggle{background-color:#f60;border:none;border-radius:6px;color:#fff;cursor:pointer;font-family:Courier New,monospace;font-weight:700;padding:10px;transition:all .2s;width:100%}.debug-toggle:hover{background-color:#f80}.debug-panel-content{margin-top:15px}.debug-panel-content .debug-menu{background-color:initial;border:none;box-shadow:none;left:auto;max-height:none;max-width:none;padding:0;position:relative;top:auto;transform:none;z-index:auto}.debug-panel-content .debug-menu-header{display:none}.App{outline:none}body{margin:0;overflow:hidden;padding:0}.toast-container{bottom:calc(env(safe-area-inset-bottom, 0px) + 20px);display:flex;flex-direction:column;gap:10px;left:50%;max-width:90vw;pointer-events:none;position:fixed;transform:translateX(-50%);z-index:10000}.toast{align-items:center;animation:toast-slide-up .3s ease-out;background-color:#333;border:2px solid;border-radius:8px;box-shadow:0 4px 12px #0000004d;cursor:pointer;display:flex;font-family:Courier New,monospace;font-size:.9em;justify-content:space-between;max-width:500px;min-width:clamp(220px,60vw,300px);padding:12px 16px;pointer-events:auto;width:min(500px,calc(100vw - 32px))}.toast-error{background-color:#ff44441a;border-color:#f44;color:#f66}.toast-warning{background-color:#ffaa001a;border-color:#fa0;color:#fc4}.toast-success{background-color:#44ff441a;border-color:#4f4;color:#6f6}.toast-info{background-color:#4444ff1a;border-color:#44f;color:#66f}.toast-content{align-items:center;display:flex;flex:1 1;gap:10px}.toast-icon{flex-shrink:0;font-size:1.2em}.toast-message{flex:1 1;word-break:break-word}.toast-close{background:none;border:none;border-radius:4px;color:inherit;cursor:pointer;font-size:1.1em;margin-left:10px;opacity:.7;padding:4px;transition:opacity .2s ease}.toast-close:hover{background-color:#ffffff1a;opacity:1}@media (max-width:600px){.App{--mobile-safe-top:env(safe-area-inset-top,0px);--mobile-top-menu-height:clamp(120px,28vh,184px);--mobile-top-offset:calc(var(--mobile-safe-top) + var(--mobile-top-menu-height))}.top-menu{border-left:none;border-radius:0;border-right:none;box-sizing:border-box;flex-direction:column;gap:10px;left:0;margin:0;min-height:var(--mobile-top-menu-height);padding:12px 16px 10px;right:0;row-gap:8px;top:var(--mobile-safe-top);width:100vw}.mobile-build-mode-controls,.top-menu{display:flex;justify-content:space-between}.mobile-build-mode-controls{align-items:center;background:#4ecdc414;border:1px solid #4ecdc473;border-radius:10px;gap:12px;padding:10px 12px}.mobile-build-mode-label{color:#ffffffbf;font-size:.75em}.menu-buttons{flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:6px}.menu-button-wrapper{flex:1 1 64px;max-width:82px}.menu-button{font-size:18px;height:48px;width:48px}.game-info{flex-direction:row;flex-wrap:wrap;font-size:.85em;gap:6px 12px;justify-content:center;text-align:center}.game-main{padding:6px;top:var(--mobile-top-offset)}.game-board{border-radius:0;font-size:9px;height:100%;max-height:none;max-width:none;width:100%}.left-panel{left:50%;max-height:calc(100vh - var(--mobile-top-offset) - 24px);right:auto;top:calc(var(--mobile-top-offset) + 12px);transform:translateX(-50%);width:calc(100vw - 32px)}.inventory-window{border-left:none;border-radius:0;border-right:none;box-sizing:border-box;height:calc(100vh - var(--mobile-top-offset));left:0;max-height:calc(100vh - var(--mobile-top-offset));max-width:none;padding:20px 16px;right:0;top:var(--mobile-top-offset);width:100vw}.help-menu{align-items:stretch;bottom:0;justify-content:flex-start;padding:16px 0 0;top:var(--mobile-top-offset)}.help-menu-content{border-radius:0;box-sizing:border-box;height:100%;max-height:none;max-width:none;padding:24px 16px;width:100vw}.help-sections{grid-template-columns:1fr}.save-menu{border-radius:0;box-sizing:border-box;height:calc(100vh - var(--mobile-top-offset));left:0;max-height:none;max-width:none;padding:20px 16px;right:0;top:var(--mobile-top-offset);transform:none;width:100vw}}.power-network-summary{margin-top:8px}.power-network-table{border-collapse:collapse;margin-top:4px;width:100%}.power-network-table th{font-weight:400;padding:2px 8px 2px 0;text-align:left}.power-demand-breakdown{margin-top:16px}.power-demand-list{display:flex;flex-direction:column;gap:12px;margin-top:8px}.power-demand-row{border-top:1px solid #ffffff0f;display:flex;flex-direction:column;gap:6px;padding:8px 0}.power-demand-row:first-child{border-top:none;padding-top:0}.power-demand-row-header{align-items:baseline;display:flex;gap:8px;justify-content:space-between}.power-demand-name{font-weight:600}.power-demand-value{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;opacity:.85}.power-demand-sparkline-wrapper{display:flex;flex-direction:column;gap:4px}.power-demand-sparkline{display:block;height:40px;width:100%}.power-demand-sparkline-scale{display:flex;font-size:.75rem;justify-content:space-between;opacity:.7}.power-demand-empty{font-size:.9rem;margin-top:8px;opacity:.75}.power-stat-divider{text-align:center;width:12px}.power-stat-value{text-align:right;white-space:nowrap}.power-history{margin-top:16px}.power-history-graph{margin-top:12px}.power-history-svg{display:block;height:160px;width:100%}.power-history-gridline{stroke:#ffffff14;stroke-width:1}.power-history-axis{stroke:#ffffff26;stroke-width:1.5}.power-history-line{fill:none;stroke-width:2.25;stroke-linecap:round;stroke-linejoin:round}.power-history-line.production{stroke:#6ae6ff}.power-history-line.demand{stroke:#ff6a7a}.power-history-line.satisfaction{stroke:#ffb347}.power-history-point.production{fill:#6ae6ff}.power-history-point.demand{fill:#ff6a7a}.power-history-point.satisfaction{fill:#ffb347}.power-history-legend{display:flex;flex-wrap:wrap;font-size:.85rem;gap:12px;margin-top:10px;opacity:.85}.legend-item{align-items:center;display:inline-flex;gap:6px}.legend-swatch{border-radius:999px;height:12px;width:12px}.legend-swatch.production{background:#6ae6ff;box-shadow:0 0 6px #6ae6ff99}.legend-swatch.demand{background:#ff6a7a;box-shadow:0 0 6px #ff6a7a99}.legend-swatch.satisfaction{background:#ffb347;box-shadow:0 0 6px #ffb3478c}.power-history-axis-labels{display:flex;font-size:.75rem;justify-content:space-between;margin-top:8px;opacity:.7}.power-history-summary{display:flex;flex-wrap:wrap;font-size:.8rem;gap:12px;margin-top:6px}@keyframes toast-slide-up{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.space-mode{background:radial-gradient(circle at 20% 20%,#4169e12e,#0000),radial-gradient(circle at 80% 0,#00ced11f,#0000);box-sizing:border-box;color:#e5f1ff;gap:1.5rem;height:100vh;overflow-y:auto;padding:1.75rem}.space-mode,.space-mode__header{display:flex;flex-direction:column}.space-mode__header{background:#09101cd1;border:1px solid #5082c859;border-radius:12px;box-shadow:0 0 22px #194d9140;gap:1rem;padding:1.25rem}.space-mode__header h1{color:#66d1ff;font-size:1.75rem;letter-spacing:.05em;margin-bottom:.25rem}.space-mode__summary-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.space-mode__summary-label{color:#bfd7ffb3;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase}.space-mode__primary-button{align-items:center;background:linear-gradient(135deg,#2e8bffcc,#10348ae6);border:1px solid #66d1ff80;border-radius:999px;color:#e9f7ff;cursor:pointer;display:inline-flex;font-weight:600;justify-content:center;padding:.6rem 1.1rem;transition:transform .15s ease,box-shadow .15s ease}.space-mode__primary-button:hover{box-shadow:0 8px 18px #2e8bff66;transform:translateY(-1px)}.space-mode__primary-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.4}.space-mode__section{background:#060c18d1;border:1px solid #5082c840;border-radius:12px;box-shadow:inset 0 0 32px #0c1d3a66;padding:1.25rem}.space-mode__section h2{color:#88e0ff;letter-spacing:.06em;margin-bottom:1rem;margin-top:0}.space-mode__stockpile{display:flex;flex-wrap:wrap;font-size:.95rem;gap:.75rem 1.5rem}.space-mode__stockpile span{background:#142542bf;border:1px solid #70a8ff40;border-radius:8px;padding:.35rem .75rem}.space-mode__colonies{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.space-mode__colony-card{background:#08111fd9;border:1px solid #4a78c059;border-radius:14px;box-shadow:0 0 24px #12346859;display:flex;flex-direction:column;gap:.85rem;padding:1.1rem}.space-mode__colony-card header h3{color:#7bf5ff;letter-spacing:.04em;margin:0}.space-mode__colony-card header p{color:#cfe0ffd9;font-size:.9rem;margin:.15rem 0}.space-mode__colony-production,.space-mode__colony-trade{background:#0c1a2dcc;border:1px solid #5a8cd240;border-radius:10px;font-size:.9rem;padding:.75rem}.space-mode__building-list{display:flex;flex-direction:column;gap:.85rem}.space-mode__building-row{grid-gap:1rem;background:#0a1526bf;border:1px solid #446eb259;border-radius:10px;display:grid;gap:1rem;grid-template-columns:minmax(0,1fr) minmax(160px,auto);padding:.9rem}.space-mode__building-summary strong{color:#9ae8ff;font-size:1rem}.space-mode__building-meta{color:#a2ceff99;display:block;font-size:.75rem;letter-spacing:.08em;margin:.25rem 0;text-transform:uppercase}.space-mode__building-summary p{color:#c8dcffd1;font-size:.85rem;margin:0}.space-mode__building-actions{align-items:flex-start;display:flex;flex-direction:column;gap:.5rem}.space-mode__building-cost{color:#add2ffbf;font-size:.8rem}.space-mode__action-button{background:#184480b3;border:1px solid #70c8ff66;border-radius:8px;color:#e0f3ff;cursor:pointer;font-weight:600;padding:.4rem .8rem;transition:background .15s ease,transform .15s ease}.space-mode__action-button:hover:not(:disabled){background:#306ec8d9;transform:translateY(-1px)}.space-mode__action-button:disabled{cursor:not-allowed;opacity:.35}.space-mode__upgrades{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.space-mode__upgrade-card{background:#0a1628cc;border:1px solid #5a8cd252;border-radius:12px;box-shadow:0 0 18px #123a804d;display:flex;flex-direction:column;gap:.6rem;padding:1rem}.space-mode__upgrade-card h3{color:#7dd9ff;margin:0}.space-mode__upgrade-card p{color:#cddeffd9;font-size:.88rem;margin:0}.space-mode__upgrade-cost{color:#b9d2ffb3;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase}.space-mode__trade-form{background:#0a1528b3;border:1px solid #4c7cc64d;border-radius:10px;display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem;padding:1rem}.space-mode__trade-fields{grid-gap:.85rem;display:grid;gap:.85rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.space-mode__trade-fields label{color:#b1caf5a6;display:flex;flex-direction:column;font-size:.8rem;gap:.35rem;letter-spacing:.08em;text-transform:uppercase}.space-mode__trade-fields input,.space-mode__trade-fields select{background:#0c1e3cd9;border:1px solid #5284d266;border-radius:8px;color:#e5f1ff;padding:.45rem .6rem}.space-mode__trade-routes{display:flex;flex-direction:column;gap:.75rem}.space-mode__trade-row{align-items:center;background:#091221c7;border:1px solid #4a78c04d;border-radius:10px;display:flex;justify-content:space-between;padding:.75rem 1rem}.space-mode__trade-row strong{color:#8de2ff}.space-mode__trade-row p{color:#cddeffcc;font-size:.85rem;margin:.25rem 0 0}.space-mode__trade-actions{display:flex;gap:.4rem}.space-mode__trade-actions button{background:#102646d9;border:1px solid #64a0e659;border-radius:6px;color:#dff3ff;cursor:pointer;padding:.35rem .6rem;transition:background .15s ease}.space-mode__trade-actions button:hover{background:#285aa0cc}.space-mode__log{display:flex;flex-direction:column;gap:.5rem;max-height:280px;overflow-y:auto;padding-right:.5rem}.space-mode__log p{color:#c4d6f0d9;font-size:.86rem;line-height:1.4;margin:0}@media (max-width:900px){.space-mode{padding:1.25rem}.space-mode__building-row,.space-mode__colonies{grid-template-columns:1fr}}.achievement-menu-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#040c14b3;box-sizing:border-box;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:1900}.achievement-menu{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:var(--menu-surface-bg);border:1px solid var(--menu-border);border-radius:18px;box-shadow:var(--menu-shadow),0 28px 60px #0009;color:var(--menu-text-primary);display:flex;flex-direction:column;gap:0;max-height:min(82vh,720px);overflow:hidden;width:min(680px,92vw)}.achievement-menu__header{align-items:flex-start;background:var(--menu-surface-highlight);border-bottom:1px solid #4ecdc447;display:flex;gap:16px;justify-content:space-between;padding:20px 24px 18px}.achievement-menu__title-group{display:flex;flex-direction:column;gap:6px}.achievement-menu__title-group h3{font-size:1.45rem;letter-spacing:.08em;margin:0;text-shadow:0 0 12px #4ecdc440;text-transform:uppercase}.achievement-menu__progress{color:var(--menu-muted);font-size:.85rem;letter-spacing:.06em;margin:0;text-transform:uppercase}.achievement-menu__close{align-self:flex-start}.achievement-menu__body{display:flex;flex-direction:column;gap:18px;overflow-y:auto;padding:22px 24px 26px;scrollbar-width:thin}.achievement-menu__body::-webkit-scrollbar{width:8px}.achievement-menu__body::-webkit-scrollbar-track{background:#06121c99;border-radius:999px}.achievement-menu__body::-webkit-scrollbar-thumb{background:#4ecdc452;border-radius:999px}.achievement-menu__list{display:flex;flex-direction:column;gap:14px}.achievement-menu__card{align-items:flex-start;background:linear-gradient(150deg,#0c222ce6,#0a1c26eb 55%,#08141ef0);border:1px solid #4ecdc43d;border-radius:14px;box-shadow:inset 0 0 0 1px #4ecdc414;color:var(--menu-text-secondary);display:flex;gap:16px;padding:16px 18px;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.achievement-menu__card--unlocked{border-color:#4ecdc48c;box-shadow:inset 0 0 0 1px #4ecdc42e,0 12px 24px #4ecdc42e;color:var(--menu-text-primary)}.achievement-menu__card--locked{opacity:.85}.achievement-menu__icon{color:var(--menu-accent);font-size:2.4rem;min-width:52px;position:relative;text-align:center}.achievement-menu__lock{bottom:-6px;font-size:1rem;opacity:.75;position:absolute;right:-4px}.achievement-menu__info{display:flex;flex:1 1;flex-direction:column;gap:6px}.achievement-menu__name{color:var(--menu-text-primary);font-size:1rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.achievement-menu__card--locked .achievement-menu__name{color:#c4e0ec99}.achievement-menu__description{color:#c4e0ecc7;font-size:.9rem;line-height:1.5}.achievement-menu__card--locked .achievement-menu__description{color:#c4e0ec8c}.achievement-menu__progress-detail{color:#4ecdc4db;font-size:.85rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.achievement-menu__card--locked .achievement-menu__progress-detail{color:#c4e0ec99}.achievement-menu__timestamp{color:#ffd78cd9;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase}.achievement-menu__empty{background:#08141eb3;border:1px dashed #4ecdc440;border-radius:14px;color:#b7e2f1b3;padding:48px 18px;text-align:center}@media (max-width:640px){.achievement-menu-overlay{align-items:flex-start;padding:var(--mobile-top-offset) 16px 16px}.achievement-menu{border-left:none;border-radius:0;border-right:none;height:calc(100vh - var(--mobile-top-offset));max-height:none;width:100vw}.achievement-menu__header{padding:18px 20px 16px}.achievement-menu__body{padding:18px 20px 22px}}.loading-screen{align-items:center;background-color:#0a0a0a;color:#0f0;display:flex;flex-direction:column;font-family:Courier New,monospace;height:100vh;justify-content:center;padding:2rem;text-align:center}.loading-screen h1{animation:glow 2s ease-in-out infinite alternate;font-size:3rem;margin-bottom:2rem;text-shadow:0 0 10px #0f0}.loading-poster-placeholder{aspect-ratio:2/3;border:1px solid #00ff004d;border-radius:6px;box-shadow:0 10px 32px #0f03;margin-bottom:2rem;overflow:hidden;width:min(260px,70vw)}.loading-poster-skeleton{animation:posterPulse 6s ease-in-out infinite;background:linear-gradient(135deg,#00ff0014,#00ff0005 40%,#00ff001a);background-size:200% 200%;height:100%;opacity:.8;width:100%}.loading-message{margin-bottom:2rem}.loading-message p{font-size:1.5rem;margin-bottom:1rem}.loading-spinner{animation:spin 2s linear infinite;font-size:4rem;margin:1rem 0}.loading-details{margin-top:2rem;opacity:.7}.loading-details p{animation:fadeInOut 3s ease-in-out infinite;font-size:1rem;margin:.5rem 0}.loading-details p:nth-child(2){animation-delay:1s}.loading-details p:nth-child(3){animation-delay:2s}@keyframes glow{0%{text-shadow:0 0 10px #0f0}to{text-shadow:0 0 20px #0f0,0 0 30px #0f0}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes fadeInOut{0%,to{opacity:.3}50%{opacity:.8}}@keyframes posterPulse{0%,to{background-position:0 50%}50%{background-position:100% 50%}}@media (max-width:768px){.loading-screen h1{font-size:2rem}.loading-message p{font-size:1.2rem}.loading-spinner{font-size:3rem}.loading-details p{font-size:.9rem}}.start-menu-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:radial-gradient(circle at top,#00bcd42e 0,#0000 55%),#03080ceb;display:flex;inset:0;justify-content:center;padding:clamp(16px,4vw,48px);pointer-events:auto;position:fixed;z-index:2000}.start-menu{background:linear-gradient(145deg,#061018eb,#08141edb 55%,#02080ee6),#040a10d9;border:1px solid #00bcd459;border-radius:16px;box-shadow:0 30px 90px #00bcd447;color:#e6f9ff;display:flex;flex-direction:column;gap:clamp(20px,4vw,32px);padding:clamp(24px,4vw,36px);text-align:left;width:min(880px,100%)}.start-menu__layout{align-items:flex-start;display:flex;flex-wrap:wrap;gap:clamp(20px,4vw,40px)}.start-menu__title{color:#7efeff;font-size:clamp(2.1rem,4.5vw,3rem);letter-spacing:.08em;margin:0;text-shadow:0 0 24px #00bcd499;text-transform:uppercase}.start-menu__hero-poster{border:1px solid #7efeff59;border-radius:12px;box-shadow:0 20px 60px #00bcd459,0 0 40px #7efeff59;flex:0 0 auto;height:390px;object-fit:cover;width:260px}.start-menu__content{display:flex;flex:1 1;flex-direction:column;gap:clamp(16px,3vw,24px);min-width:0}.start-menu__subtitle{color:#e0fbfcd1;font-size:clamp(1rem,2vw,1.25rem);letter-spacing:.04em;margin:0}.start-menu__posters{grid-gap:clamp(14px,2.5vw,22px);display:grid;gap:clamp(14px,2.5vw,22px);grid-template-columns:1fr}.start-menu__poster{background:linear-gradient(160deg,#06121cf5,#040e16db 60%,#02080eeb);border:1px solid #00bcd447;border-radius:14px;box-shadow:0 16px 40px #00bcd440;color:inherit;cursor:pointer;display:flex;flex-direction:column;gap:12px;overflow:hidden;padding:clamp(16px,2.8vw,24px);position:relative;text-align:left;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.start-menu__poster:focus-visible,.start-menu__poster:hover{border-color:#7efeffb3;box-shadow:0 24px 60px #00bcd459;outline:none;transform:translateY(-8px) rotate(-.7deg)}.start-menu__poster:active{transform:translateY(-2px)}.start-menu__poster--primary{background:linear-gradient(150deg,#0c2234f5,#0a1e2ee6 55%,#081622eb)}.start-menu__poster--secondary{background:linear-gradient(150deg,#081824f5,#06141ee6 60%,#040e16eb)}.start-menu__poster-tag{align-self:flex-start;background:#00bcd42e;border:1px solid #00bcd46b;border-radius:999px;color:#7efeff;font-size:.7rem;letter-spacing:.18em;padding:4px 10px;text-transform:uppercase}.start-menu__poster-title{font-size:clamp(1.2rem,2.2vw,1.5rem);letter-spacing:.06em;margin:0}.start-menu__poster-description{color:#e0fbfcdb;font-size:clamp(.9rem,1.8vw,1rem);line-height:1.5;margin:0}.start-menu__poster-meta{color:#7efeffd1;font-size:.8rem;letter-spacing:.04em}.start-menu__actions{align-items:flex-start;display:flex;flex-direction:column;gap:12px}.start-menu__action-button{background:#0000;border:1px solid #7efeff73;border-radius:999px;color:#7efeff;cursor:pointer;font-size:.9rem;letter-spacing:.08em;padding:10px 18px;text-transform:uppercase;transition:background .2s ease,color .2s ease,border-color .2s ease}.start-menu__action-button:focus-visible,.start-menu__action-button:hover{background:#7efeff1a;border-color:#7efeffbf;outline:none}.start-menu__hint{color:#e0fbfcb3;font-size:.8rem;letter-spacing:.08em}@media (max-width:640px){.start-menu__layout{align-items:center;flex-direction:column;text-align:center}.start-menu__content{align-items:center}.start-menu__posters{grid-template-columns:1fr}.start-menu{padding:clamp(20px,6vw,32px)}.start-menu__actions{align-items:center}}.production-menu-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#050c18b3;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:1200}.production-menu{background:#0a111f;border:2px solid #4ecdc4a6;border-radius:14px;box-shadow:0 18px 48px #0000008c;color:#f4f6f8;display:flex;flex-direction:column;font-family:Inter,Fira Code,monospace;max-height:82vh;overflow:hidden;width:min(760px,95vw)}.production-menu__header{align-items:flex-start;background:#4ecdc41a;border-bottom:1px solid #4ecdc459;display:flex;justify-content:space-between;padding:20px 24px 16px}.production-menu__header h3{font-size:1.35rem;letter-spacing:.05em;margin:0}.production-menu__header p{color:#9fbdd1;font-size:.9rem;margin:6px 0 0}.production-menu__close{background:#0000;border:none;color:#d7e3f0;cursor:pointer;font-size:1.4rem;line-height:1;transition:color .2s ease}.production-menu__close:hover{color:#4ecdc4}.production-menu__controls{align-items:center;color:#b5ccdc;display:flex;flex-wrap:wrap;font-size:.85rem;gap:10px;padding:14px 24px 0}.production-menu__controls-label{color:#b7e2f1cc;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase}.production-menu__hotkey{color:#b7e2f1b3;font-size:.8rem;margin-left:auto}.production-menu__window-button{background:#4ecdc429;border:1px solid #4ecdc459;border-radius:999px;color:#e4f1f9;cursor:pointer;padding:6px 14px;transition:background .2s ease,border-color .2s ease,color .2s ease}.production-menu__window-button.active{background:#4ecdc4;border-color:#4ecdc4;color:#05101b}.production-menu__window-button:not(.active):hover{border-color:#4ecdc4}.production-menu__body{display:flex;flex-direction:column;gap:18px;overflow-y:auto;padding:18px 24px 24px;scrollbar-width:thin}.production-menu__body::-webkit-scrollbar{width:8px}.production-menu__body::-webkit-scrollbar-track{background:#040c16a6}.production-menu__body::-webkit-scrollbar-thumb{background:#4ecdc459;border-radius:999px}.production-menu__row{background:#061220d1;border:1px solid #4ecdc440;border-radius:12px;box-shadow:inset 0 0 0 1px #4ecdc41a;display:flex;flex-direction:column;gap:12px;padding:14px 18px 16px}.production-menu__row-header{align-items:baseline;display:flex;gap:12px;justify-content:space-between}.production-menu__item-name{font-size:1rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.production-menu__item-rate{color:#9fbdd1;font-size:.9rem}.production-menu__sparkline-wrapper{display:flex;flex-direction:column;gap:6px}.production-menu__sparkline{height:36px;width:100%}.production-menu__sparkline-scale{color:#93b9d1a6;display:flex;font-size:.75rem;justify-content:space-between}.production-menu__details{color:#9fbdd1d9;font-size:.82rem}@media (max-width:640px){.production-menu__controls{justify-content:flex-start}.production-menu__hotkey{margin-left:0;width:100%}}.research-menu-overlay{align-items:center;background:#0006;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:1000}.research-menu{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0a0f1a;border:2px solid #4ecdc4;border-radius:12px;box-shadow:0 12px 40px #00000080;color:#f4f6f8;display:flex;flex-direction:column;font-family:Inter,Fira Code,monospace;font-size:.95rem;line-height:1.5;max-height:80vh;overflow:hidden;width:min(720px,90vw)}.research-menu__header{align-items:center;background:#4ecdc41a;border-bottom:1px solid #4ecdc44d;display:flex;justify-content:space-between;padding:16px 20px}.research-menu__header h3{font-size:1.4rem;letter-spacing:.05em;margin:0}.research-menu__close{background:#0000;border:none;color:inherit;cursor:pointer;font-size:1.2rem;transition:color .2s ease}.research-menu__close:hover{color:#4ecdc4}.research-menu__body{display:flex;flex-direction:column;gap:12px;overflow-y:auto;padding:16px 20px;scrollbar-width:thin}.research-menu__body::-webkit-scrollbar{width:8px}.research-menu__body::-webkit-scrollbar-track{background:#040c1699}.research-menu__body::-webkit-scrollbar-thumb{background:#4ecdc459;border-radius:999px}.research-menu__queue{background:#08162499;border:1px solid #4ecdc440;border-radius:10px;display:flex;flex-direction:column;gap:10px;padding:12px 14px}.research-menu__queue-header{align-items:center;display:flex;gap:8px;justify-content:space-between}.research-menu__queue-header h4{font-size:.95rem;letter-spacing:.08em;margin:0;text-transform:uppercase}.research-menu__queue-clear{background:#4ecdc426;border:1px solid #4ecdc466;border-radius:8px;color:#f4f6f8;cursor:pointer;padding:6px 10px;transition:all .15s ease}.research-menu__queue-clear:hover:not(:disabled){background:#4ecdc440;transform:translateY(-1px)}.research-menu__queue-clear:disabled{cursor:not-allowed;opacity:.5}.research-menu__queue-empty{color:#9fbdd1;font-size:.9rem;margin:0}.research-menu__queue-list{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.research-menu__queue-item{align-items:center;background:#04121ea6;border:1px dashed #4ecdc44d;border-radius:8px;display:flex;gap:10px;padding:8px 10px}.research-menu__queue-item--active{border-color:#4ecdc4b3;box-shadow:0 0 12px #4ecdc433}.research-menu__queue-rank{color:#4ecdc4;font-weight:700;letter-spacing:.06em;min-width:92px;text-transform:uppercase}.research-menu__queue-name{color:#f4f6f8}.research-tree{background:#081624b3;border:1px solid #4ecdc440;border-radius:10px;display:flex;flex-direction:column;gap:16px;padding:16px}.research-tree__header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between}.research-tree__header h4{font-size:1rem;letter-spacing:.08em;margin:0;text-transform:uppercase}.research-tree__header p{color:#9fbdd1;font-size:.85rem;margin:4px 0 0}.research-tree__selected-card{background:#04121ed9;border:1px solid #4ecdc459;border-radius:10px;box-shadow:inset 0 0 0 1px #4ecdc41a;display:flex;flex-direction:column;gap:12px;min-width:240px;padding:14px 16px}.research-tree__selected-card--empty{background:#04121e99;border-color:#4ecdc440;border-style:dashed;color:#9fbdd1}.research-tree__selected-card-header{align-items:baseline;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.research-tree__selected-card-title-group{display:flex;flex-direction:column;gap:2px}.research-tree__selected-card-title{color:#b7e2f1bf;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase}.research-tree__selected-card-name{color:#f4f6f8;font-size:1rem;font-weight:600}.research-tree__selected-card-status{background:#4ecdc426;border:1px solid #4ecdc466;border-radius:999px;color:#4ecdc4;font-size:.75rem;letter-spacing:.08em;padding:4px 10px;text-transform:uppercase;white-space:nowrap}.research-tree__selected-card-status--available{background:#4ecdc433;border-color:#4ecdc473;color:#4ecdc4}.research-tree__selected-card-status--unlocked{background:#7cd85833;border-color:#7cd85866;color:#7cd858}.research-tree__selected-card-status--locked{background:#ff63842e;border-color:#ff638459;color:#ff6384}.research-tree__selected-progress{display:flex;flex-direction:column;font-size:.85rem;gap:8px}.research-tree__selected-progress .crafting-progress-section{background:#4ecdc414;border-color:#4ecdc433;margin:0;padding:10px 12px}.research-tree__selected-progress-summary{color:#b9d7e8}.research-tree__selected-requirements{grid-gap:4px;color:#d7ecff;display:grid;gap:4px;margin:0;padding-left:18px}.research-tree__selected-progress-placeholder{color:#b9d7e8;font-size:.85rem}.research-tree__graph{background:#020c18bf;border:1px solid #4ecdc433;border-radius:10px;overflow-x:auto;overflow-y:hidden;padding:12px;position:relative;scrollbar-width:thin}.research-tree__graph::-webkit-scrollbar{height:8px}.research-tree__graph::-webkit-scrollbar-track{background:#040c1699;border-radius:999px}.research-tree__graph::-webkit-scrollbar-thumb{background:#4ecdc459;border-radius:999px}.research-tree__connections{stroke-linecap:round;stroke-width:2;inset:0;pointer-events:none;position:absolute}.research-tree__connection{fill:none}.research-tree__connection--complete{stroke:#4ecdc4}.research-tree__connection--active{stroke:#4ecdc4a6;stroke-dasharray:6 6}.research-tree__connection--locked{stroke:#8ca3b859}.research-tree__columns{grid-gap:16px;display:grid;gap:16px;position:relative}.research-tree__column{display:flex;flex-direction:column;gap:12px}@media (max-width:600px){.research-menu-overlay{align-items:stretch;height:calc(100vh - var(--mobile-top-offset));justify-content:flex-start;left:0;padding:0;top:var(--mobile-top-offset);width:100vw}.research-menu{border-radius:0;box-sizing:border-box;height:100%;max-height:none;width:100%}.research-menu__header{padding:14px 16px}.research-menu__body{flex:1 1;padding:14px 16px}}.research-tree__node{background:#0c2030d1;border:1px solid #4ecdc426;border-radius:8px;display:flex;flex-direction:column;gap:8px;min-width:0;padding:12px 14px;position:relative;transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease}.research-tree__node--locked{border-color:#e770554d}.research-tree__node--available{border-color:#4ecdc480;box-shadow:0 0 0 1px #4ecdc426}.research-tree__node--unlocked{background:#16364ed9;border-color:#4ecdc4bf}.research-tree__node--selected{border-color:#4ecdc4;box-shadow:0 0 12px #4ecdc459}.research-tree__node--interactive{cursor:pointer}.research-tree__node--interactive:hover{border-color:#4ecdc4e6;transform:translateY(-2px)}.research-tree__node--repeatable{background:#24123fd1;border-color:#b784ff73}.research-tree__node--repeatable.research-tree__node--locked{border-color:#b784ff59}.research-tree__node--repeatable.research-tree__node--available{border-color:#cea7ffa6;box-shadow:0 0 0 1px #cea7ff33}.research-tree__node--repeatable.research-tree__node--unlocked{background:#361b5cd9;border-color:#cea7ffd9}.research-tree__node--repeatable.research-tree__node--selected{border-color:#cea7ff;box-shadow:0 0 14px #cea7ff73}.research-tree__node--repeatable.research-tree__node--interactive:hover{border-color:#cea7fff2}.research-tree__node--repeatable .research-tree__node-status{color:#cea7ff}.research-tree__node-title{font-size:.95rem}.research-tree__node-status{color:#4ecdc4;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase}.research-tree__node--locked .research-tree__node-status{color:#ff8b6a}.research-tree__node-prerequisites{color:#a9c6d9;display:flex;flex-direction:column;font-size:.78rem;gap:4px}.research-tree__node-prerequisites span{font-weight:600;letter-spacing:.04em;text-transform:uppercase}.research-tree__node-prerequisites ul{grid-gap:2px;display:grid;gap:2px;margin:0;padding-left:16px}.research-tree__node-prereq--met{color:#9be7c4}.research-tree__node-prereq--unmet{color:#f5b971}.research-tree__node-prerequisites--none{color:#9fbdd1}.research-tree__node-progress{display:flex;flex-direction:column;gap:6px}.research-tree__node-progress .crafting-progress-section{background:#4ecdc41a;border-color:#4ecdc433;margin:0;padding:8px}.research-tree__node-progress .progress-bar{height:12px}.research-tree__node-progress-list{grid-gap:4px;color:#d7ecff;display:grid;font-size:.76rem;gap:4px;margin:0;padding-left:16px}.research-tree__node-debug{display:flex;justify-content:flex-end}.research-tree__force-unlock{align-self:flex-end;background:#e770551f;border:1px solid #e7705566;border-radius:4px;color:#ffb49f;cursor:pointer;font-size:.72rem;letter-spacing:.06em;padding:4px 8px;text-transform:uppercase;transition:background .2s ease,border-color .2s ease,color .2s ease}.research-tree__force-unlock:hover:not(:disabled){background:#e7705538;border-color:#e77055b3;color:#ffe3d9}.research-tree__force-unlock:disabled{cursor:not-allowed;opacity:.5}@media (max-width:640px){.research-tree__header{flex-direction:column}.research-tree__selected-progress{width:100%}.research-tree__graph{padding:8px}}.research-card{background:linear-gradient(145deg,#020c18d1,#091a28e6);border:1px solid #4ecdc433;border-radius:10px;display:flex;flex-direction:column;gap:12px;padding:14px 16px;transition:border-color .2s ease,background .2s ease,transform .2s ease}.research-card--available{background:#122f4ccc;border-color:#4ecdc499}.research-card--unlocked{background:#224a66d9;border-color:#4ecdc4cc}.research-card:hover{transform:translateY(-1px)}.research-card__header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.research-card__header-content{grid-gap:6px;display:grid;flex:1 1 260px;gap:6px;min-width:0}.research-card__header h4{font-size:1.05rem;font-weight:600;letter-spacing:.02em;margin:0}.research-card__description{color:#c4d7e0;font-size:.92rem;line-height:1.5;margin:0;overflow-wrap:anywhere}.research-card__status{color:#4ecdc4;flex:0 0 auto;font-size:.8rem;letter-spacing:.12em;line-height:1.4;max-width:180px;overflow-wrap:anywhere;text-align:right;text-transform:uppercase}.research-card--locked .research-card__status{color:#e17055}.research-card__content{grid-gap:10px;display:grid;gap:10px}.research-card__content li,.research-card__content span{overflow-wrap:anywhere}.research-card__repeatable-info{color:#9fbdd1;font-size:.82rem;letter-spacing:.03em;margin:0;text-transform:uppercase}.research-card__progress{margin-top:4px}.research-card__progress .crafting-progress-section{background:#4ecdc414;border-color:#4ecdc433;margin:0;padding:10px 12px}.research-card__progress .crafting-status{gap:6px}.research-card__progress .progress-bar-container{width:100%}.research-card__progress .progress-bar{height:14px}.research-card__progress .progress-text{font-size:.85rem}.research-card__progress .crafting-time-info{color:#a0c4d4;font-size:.8rem}.research-card__prerequisites,.research-card__unlocks{font-size:.9rem}.research-card__prerequisites span,.research-card__unlocks span{display:block;font-weight:600;margin-bottom:4px}.research-card__prerequisites ul,.research-card__unlocks ul{grid-gap:4px;display:grid;gap:4px;line-height:1.45;margin:0;padding-left:18px}.research-card__prerequisites li.met{color:#aee1cd}.research-card__prerequisites li.unmet{color:#f39c12}.research-card__actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.research-card__set-active{background:#091a2899;border:1px solid #9fbdd166;border-radius:6px;color:#f4f6f8;cursor:pointer;font-size:.9rem;padding:8px 14px;transition:background .2s ease,transform .1s ease,border-color .2s ease}.research-card__set-active:hover:not(:disabled){background:#9fbdd133;border-color:#9fbdd1a6;transform:translateY(-1px)}.research-card__set-active:disabled{cursor:not-allowed;opacity:.5}.research-card__unlock{background:#4ecdc426;border:1px solid #4ecdc499;border-radius:6px;color:#f4f6f8;cursor:pointer;font-size:.95rem;padding:8px 14px;transition:background .2s ease,transform .1s ease}.research-card__unlock:hover:not(:disabled){background:#4ecdc440;transform:translateY(-1px)}.research-card__unlock:disabled{cursor:not-allowed;opacity:.5}.research-tree__header,.research-tree__node,.research-tree__node-prerequisites,.research-tree__node-progress-list,.research-tree__selected-progress{font-family:inherit}.research-tree__header p,.research-tree__node-prerequisites,.research-tree__node-progress-list,.research-tree__node-status,.research-tree__node-title{overflow-wrap:anywhere}.research-tree__node-title{font-weight:600;letter-spacing:.02em}@media (max-width:640px){.research-menu{width:95vw}}.research-menu--prestige{background:linear-gradient(135deg,#ffeb3b1a,#fff0);border-color:#ffd54f}.research-menu__header--prestige{background:linear-gradient(90deg,#fbc02d,#ffe082);border-bottom:1px solid #ffd74099;color:#3e2723}.research-menu__body--prestige{border-top:none}.prestige-summary{align-items:center;background:#ffe0821a;border:1px solid #ffe08266;border-radius:8px;color:#ffecb3;display:flex;font-weight:600;justify-content:space-between;margin-bottom:16px;padding:12px 16px}.research-card--prestige{background:#ffeb3b0d;border-color:#ffd74066;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.research-card--prestige:hover{border-color:#ffeb3bcc;box-shadow:0 0 12px #ffeb3b40}.research-card--prestige.selected{border-color:#ffeb3be6;box-shadow:0 0 16px #ffeb3b59}.research-card--prestige-owned{background:#ffffff0d;opacity:.9}.research-card__header--prestige{color:#ffe082}.research-card__effect{color:#ffe082;font-style:italic;margin:8px 0}.research-card__cost{color:#ffecb3;font-weight:600;margin-top:8px}.research-card__unlock--prestige{background:linear-gradient(90deg,#fdd835,#fbc02d);border:none;color:#3e2723}.research-card__unlock--prestige:disabled{background:#ffeb3b33;color:#3e272399}
/*# sourceMappingURL=main.4199689a.css.map*/