*,::after,::before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--bg2:#161b27;--bg3:#1e2535;--panel:#1a2030;--panel2:#222d40;--border:#2d3a52;--border2:#3a4d6a;--accent:#3d8ef0;--accent2:#5aa3ff;--green:#2ecc71;--green2:#27ae60;--yellow:#f1c40f;--orange:#e67e22;--red:#e74c3c;--purple:#9b59b6;--text:#e8eaf0;--text2:#9aa5bb;--text3:#5a6a82;--shadow:0 4px 20px rgba(0,0,0,0.5);--radius:8px;--radius2:12px;--font:'Segoe UI',system-ui,-apple-system,sans-serif}body,html{height:100%;overflow:hidden}body{font-family:var(--font);background:var(--bg);color:var(--text);display:flex;flex-direction:column;user-select:none}#topbar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg2);border-bottom:1px solid var(--border);height:52px;flex-shrink:0;z-index:10}#game-title{font-size:1.2rem;font-weight:700;color:var(--accent2);letter-spacing:1px;text-transform:uppercase;white-space:nowrap}#game-title span{color:var(--green)}#topbar-spacer{flex:1}#genesis-hud{display:flex;align-items:center;gap:7px;background:rgba(0,255,136,.07);border:1px solid #00ff8840;border-radius:6px;padding:3px 10px;animation:genesis-pulse 2s ease-in-out infinite}#genesis-hud.hidden{display:none}@keyframes genesis-pulse{0%,100%{box-shadow:0 0 6px #00ff8830}50%{box-shadow:0 0 18px #00ff8870}}#topbar-info{display:flex;gap:10px;font-size:.8rem;color:var(--text2);flex-shrink:1;min-width:0}.btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--border2);border-radius:var(--radius);background:var(--bg3);color:var(--text);font-size:.8rem;font-family:var(--font);cursor:pointer;transition:all .15s;white-space:nowrap}.btn:hover{background:var(--panel2);border-color:var(--accent);color:var(--accent2)}.btn:active{transform:scale(.97)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{background:var(--accent2)}.btn.success{background:var(--green2);border-color:var(--green2);color:#fff}.btn.danger{background:#8a2020;border-color:var(--red);color:#fff}.btn.danger:hover{background:var(--red)}.btn.small{padding:4px 10px;font-size:.75rem}#main-layout{display:flex;flex:1;overflow:hidden;gap:0}.side-panel{width:260px;flex-shrink:0;display:flex;flex-direction:column;background:var(--panel);border-right:1px solid var(--border);overflow:hidden}.side-panel.right{border-right:none;border-left:1px solid var(--border)}.panel-section{display:flex;flex-direction:column;border-bottom:1px solid var(--border);flex-shrink:0}.panel-section.grow{flex:1;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg2);font-size:.75rem;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.8px;cursor:pointer;gap:8px}.panel-header .toggle-icon{color:var(--text3);font-size:.7rem;transition:transform .2s}.panel-header.collapsed .toggle-icon{transform:rotate(-90deg)}.panel-body{padding:8px;overflow-y:auto;flex:1}.panel-body::-webkit-scrollbar{width:4px}.panel-body::-webkit-scrollbar-track{background:0 0}.panel-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}#inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(42px,1fr));gap:3px;padding:2px}.inv-slot{position:relative;aspect-ratio:1;min-width:42px;background:var(--bg3);border:1px solid var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:default;transition:border-color .15s,background .15s;overflow:hidden}.inv-slot:hover{border-color:var(--accent);background:var(--bg2)}.inv-slot.highlight{border-color:var(--green);animation:inv-pulse .5s ease}.inv-slot-icon{width:30px;height:30px;object-fit:contain;display:block;image-rendering:pixelated;pointer-events:none}.inv-slot-emoji{font-size:1.3rem;line-height:1;pointer-events:none}.inv-slot-count{position:absolute;bottom:2px;right:3px;font-size:.65rem;font-weight:700;color:#fff;text-shadow:0 0 3px #000,0 1px 2px #000;line-height:1;pointer-events:none}@keyframes inv-pulse{0%{transform:scale(1)}50%{transform:scale(1.06)}100%{transform:scale(1)}}#objectives-list{display:flex;flex-direction:column;gap:4px}.obj-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;font-size:.76rem;background:var(--bg3);border:1px solid var(--border);transition:background .3s,border-color .3s,opacity .3s}.obj-content{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.obj-text{line-height:1.3}.obj-reward-preview{font-size:.64rem;color:var(--text3)}.obj-claimed-lbl{color:var(--green2)}.obj-item.claimable{background:rgba(246,201,14,.07);border-color:rgba(246,201,14,.45)}.obj-item.claimable .obj-reward-preview{color:var(--yellow);font-weight:600}.obj-item.done.claimed{opacity:.45;background:rgba(46,204,113,.05);border-color:var(--border)}.obj-item.done.claimed .obj-text{text-decoration:line-through;color:var(--text3)}.obj-check{width:16px;height:16px;border-radius:3px;border:1.5px solid var(--border2);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px}.obj-item.claimable .obj-check{border-color:var(--yellow)}.obj-item.claimed .obj-check{background:var(--green2);border-color:var(--green2);color:#fff}.obj-claim-btn{flex-shrink:0;padding:3px 9px;background:linear-gradient(135deg,#f6c90e,#e67e22);color:#000;border:none;border-radius:4px;font-size:.64rem;font-weight:700;cursor:pointer;letter-spacing:.3px;animation:claim-btn-glow 1.4s ease-in-out infinite}.obj-claim-btn:hover{filter:brightness(1.15)}@keyframes claim-btn-glow{0%,100%{box-shadow:0 0 0 0 rgba(246,201,14,0)}50%{box-shadow:0 0 7px 2px rgba(246,201,14,.55)}}@keyframes obj-claim-flash{0%{background:rgba(246,201,14,.45);box-shadow:0 0 0 3px rgba(246,201,14,.5);transform:scale(1.04)}55%{background:rgba(246,201,14,.1)}100%{background:0 0;box-shadow:none;transform:scale(1)}}.obj-item.claiming{animation:obj-claim-flash .65s ease-out forwards}@keyframes titlebar-reward{0%{background:rgba(246,201,14,.28)}100%{background:0 0}}.win-titlebar.win-reward-flash{animation:titlebar-reward .8s ease-out forwards}@keyframes reward-fly{0%{opacity:1;transform:translate(0,0) scale(1.1)}70%{opacity:.9}100%{opacity:0;transform:translate(var(--tx),var(--ty)) scale(.5)}}.reward-particle{position:fixed;pointer-events:none;font-size:11px;font-weight:700;color:var(--yellow);text-shadow:0 0 6px rgba(246,201,14,.9),0 1px 3px rgba(0,0,0,.9);z-index:9999;white-space:nowrap;transform-origin:center;animation:reward-fly 1s ease-out forwards}.reward-star{font-size:14px;color:gold;text-shadow:0 0 8px rgba(255,215,0,.9)}#build-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.era-header{grid-column:1/-1;font-size:.64rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 6px;margin-top:4px;border-left:3px solid;background:rgba(255,255,255,.04);border-radius:0 3px 3px 0}.build-btn{display:flex;flex-direction:column;align-items:center;gap:5px;padding:8px 6px 6px;background:var(--bg3);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .15s;text-align:center;position:relative}.build-btn:hover:not(.locked):not(.no-res){background:var(--panel2);border-color:var(--accent)}.build-btn.selected{border-color:var(--green);background:rgba(46,204,113,.1)}.build-btn.locked{opacity:.4;cursor:not-allowed}.build-btn.no-res{opacity:.6;cursor:not-allowed;border-color:var(--red)}.build-icon{width:64px;height:64px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:monospace;font-weight:700;font-size:.75rem;color:#fff;overflow:hidden;flex-shrink:0}.build-icon img{width:100%;height:100%;object-fit:contain}.build-name{font-size:.7rem;color:var(--text2);line-height:1.2}.build-cost{font-size:.65rem;color:var(--text3)}.build-shortcut{position:absolute;bottom:3px;right:3px;width:14px;height:14px;background:rgba(0,0,0,.65);border:1px solid rgba(255,255,255,.15);border-radius:3px;font-size:9px;font-weight:700;color:rgba(255,255,255,.7);display:flex;align-items:center;justify-content:center;pointer-events:none;line-height:1}.build-lock-badge{position:absolute;top:3px;right:3px;background:var(--red);color:#fff;font-size:.55rem;padding:1px 4px;border-radius:3px}#tech-list{display:flex;flex-direction:column;gap:6px;width:100%;box-sizing:border-box}.tech-item{width:100%;box-sizing:border-box;padding:8px 10px;background:var(--bg3);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .2s}.tech-item:hover:not(.locked):not(.done){border-color:var(--accent);background:var(--panel2)}.tech-item.done{border-color:var(--green2);background:rgba(46,204,113,.07);cursor:default}.tech-item.locked{opacity:.45;cursor:not-allowed}.tech-item.available{border-color:var(--yellow)}.tech-item.researching{border-color:#a855f7;background:rgba(168,85,247,.08)}.tech-item.repeatable{border-style:dashed;border-color:var(--yellow)}.tech-item.repeatable:hover{background:var(--yellow) 0d}.tech-level{font-size:.68rem;padding:1px 5px;border-radius:3px;background:var(--yellow) 22;color:var(--yellow);font-weight:700}.tech-bonus{font-size:.7rem;color:var(--text3);margin:2px 0}.tech-bonus-total{font-size:.7rem;color:var(--green);margin:1px 0}.tech-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.tech-icon{width:24px;height:24px;border-radius:4px;background:var(--panel2);display:flex;align-items:center;justify-content:center;font-size:.65rem;font-family:monospace;font-weight:700;color:var(--accent2);flex-shrink:0}.tech-name{font-size:.8rem;font-weight:600;flex:1}.tech-status{font-size:.65rem;padding:2px 6px;border-radius:3px}.tech-status.done{background:var(--green2);color:#fff}.tech-status.available{background:var(--yellow);color:#000}.tech-status.locked{background:var(--border);color:var(--text3)}.tech-status.researching{background:#a855f7;color:#fff}.tech-cost{font-size:.7rem;color:var(--text3);margin-top:3px}.tech-cost span{color:var(--text2)}.tech-unlocks{font-size:.68rem;color:var(--accent);margin-top:2px}#canvas-area{position:fixed;top:52px;left:0;right:0;bottom:50px;overflow:hidden;background:#0a0e16}#gameCanvas{display:block;cursor:crosshair;width:100%;height:100%}#minimap-wrapper{position:absolute;bottom:44px;right:10px;z-index:20;display:flex;flex-direction:column;align-items:flex-end;gap:0;filter:drop-shadow(0 4px 12px rgba(0,0,0,.7))}#minimap-label{font-size:.62rem;font-family:monospace;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:2px;padding-right:2px}#minimap{display:block;border:1px solid var(--border2);border-radius:5px;background:#111;image-rendering:pixelated;cursor:default;opacity:.88;transition:opacity .2s}#minimap:hover{opacity:1}#canvas-controls-hint{display:none;position:absolute;bottom:8px;right:10px;max-width:420px;background:rgba(0,0,0,.6);border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:.7rem;color:var(--text2);pointer-events:none;line-height:1.6}#hud-bottom-left{position:absolute;bottom:8px;left:8px;display:flex;flex-direction:column;gap:4px;z-index:20;pointer-events:none}#mode-indicator{background:rgba(0,0,0,.75);border:1px solid var(--border);border-radius:6px;padding:5px 10px;font-size:.75rem;color:var(--text2);pointer-events:none;white-space:nowrap}#mode-indicator.build-mode{border-color:var(--green);color:var(--green)}#zoom-controls{display:flex;align-items:center;gap:6px;background:rgba(0,0,0,.75);border:1px solid var(--border);border-radius:6px;padding:3px 8px;pointer-events:auto}#zoom-display{font-size:.72rem;color:var(--text2);min-width:36px;text-align:center}#messages-container{position:absolute;top:0;left:0;right:0;pointer-events:none;overflow:hidden;height:100%;z-index:500}.float-msg{position:absolute;background:rgba(20,30,50,.92);border:1px solid var(--border2);border-radius:6px;padding:5px 12px;font-size:.78rem;color:var(--text);white-space:nowrap;pointer-events:none;animation:float-up 2.5s ease forwards;box-shadow:0 2px 10px rgba(0,0,0,.4)}.float-msg.success{border-color:var(--green);color:var(--green)}.float-msg.tech{border-color:var(--yellow);color:var(--yellow)}.float-msg.info{border-color:var(--accent);color:var(--accent2)}.float-msg.warning{border-color:var(--orange);color:var(--orange)}@keyframes float-up{0%{opacity:0;transform:translateY(0)}15%{opacity:1}80%{opacity:1}100%{opacity:0;transform:translateY(-50px)}}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-overlay.hidden{display:none}#victory-banner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(135deg,#1a2a1a,#0f1f0f);border:2px solid #2ecc71;border-radius:12px;padding:28px 40px;text-align:center;color:#2ecc71;font-size:1.3rem;font-weight:700;z-index:100;box-shadow:0 0 40px rgba(46,204,113,.3);pointer-events:none}#victory-banner.hidden{display:none}#mem-monitor{font:11px/1.5 monospace;color:var(--text2)}.mm-section{font-size:9px;font-weight:700;letter-spacing:.08em;color:var(--text3);text-transform:uppercase;margin:7px 0 3px;border-top:1px solid var(--border);padding-top:5px}.mm-section:first-child{margin-top:0;border-top:none;padding-top:0}.mm-row{display:flex;justify-content:space-between;gap:6px;padding:1px 0}.mm-row span:last-child{color:var(--text);font-weight:600;text-align:right}.mm-bar{font-size:9px;letter-spacing:1px;color:var(--accent);margin:1px 0 3px;overflow:hidden;white-space:nowrap}.mm-na{color:var(--text3);font-style:italic;font-size:10px}.mm-hint{color:var(--text3);font-size:9px;margin-top:8px;text-align:right}#fps-counter{position:absolute;top:6px;left:50%;transform:translateX(-50%);font-size:.7rem;color:var(--yellow);font-family:monospace;background:rgba(0,0,0,.65);padding:2px 10px;border-radius:4px;pointer-events:none;z-index:10}#fps-counter.hidden{display:none}#pause-menu{position:absolute;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:rgba(5,8,15,.78);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px)}#pause-menu.hidden{display:none}.pm-shell{display:flex;width:min(760px,96vw);height:min(530px,88vh);border-radius:16px;overflow:hidden;box-shadow:0 28px 90px rgba(0,0,0,.75),0 0 0 1px rgba(255,255,255,.07);animation:pm-in .18s ease}@keyframes pm-in{from{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.pm-sidebar{width:210px;flex-shrink:0;background:#0b0f1b;border-right:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;padding:24px 12px 16px;gap:0}.pm-logo{font-size:1.5rem;font-weight:800;color:#c0cee8;text-align:center;letter-spacing:1px;margin-bottom:2px}.pm-logo span{color:var(--accent2)}.pm-paused{font-size:.6rem;letter-spacing:4px;color:var(--text3);text-align:center;margin-bottom:22px}#pm-nav{display:flex;flex-direction:column;gap:2px;flex:1}.pm-btn{display:flex;align-items:center;gap:8px;padding:9px 13px;border-radius:8px;border:none;background:0 0;color:var(--text2);font-size:.83rem;font-weight:500;cursor:pointer;text-align:left;width:100%;transition:background .12s,color .12s}.pm-btn:hover{background:rgba(255,255,255,.07);color:var(--text)}.pm-btn.active{background:rgba(61,142,240,.18);color:var(--accent2);font-weight:700}.pm-btn-resume{color:var(--green)!important;font-weight:700}.pm-btn-resume:hover{background:rgba(46,204,113,.12)!important}.pm-btn-danger{color:var(--red)!important;margin-top:auto}.pm-btn-danger:hover{background:rgba(231,76,60,.12)!important}.pm-divider{height:1px;background:rgba(255,255,255,.07);margin:6px 4px}.pm-content{flex:1;background:#111827;overflow-y:auto;padding:28px 30px}.pm-sec-title{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid var(--border)}.pm-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.pm-info-card{background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:12px 14px}.pm-ic-label{font-size:.67rem;color:var(--text3);margin-bottom:4px}.pm-ic-val{font-size:.92rem;font-weight:700;color:var(--text)}.pm-resume-btn{display:block;width:100%;padding:13px;background:linear-gradient(135deg,#1d4ed8,#3d8ef0);border:none;border-radius:10px;color:#fff;font-size:.95rem;font-weight:700;cursor:pointer;letter-spacing:1px;transition:opacity .15s,transform .15s;margin-bottom:10px}.pm-resume-btn:hover{opacity:.9;transform:translateY(-1px)}.pm-quick-btns{display:flex;gap:8px}.pm-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:16px}.pm-tab{padding:6px 16px;border:none;border-bottom:2px solid transparent;background:0 0;color:var(--text2);font-size:.79rem;font-weight:600;cursor:pointer;transition:color .12s,border-color .12s;margin-bottom:-1px}.pm-tab.active{color:var(--accent2);border-color:var(--accent2)}.pm-tab:hover:not(.active){color:var(--text)}.pm-tab-content{display:none;flex-direction:column;gap:10px}.pm-tab-content.active{display:flex}.pm-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:var(--bg3);border-radius:8px;cursor:default}.pm-row:hover{background:var(--panel2)}.pm-row>span:first-child{font-size:.8rem;color:var(--text2);user-select:none}.pm-soon{font-size:.63rem;color:var(--text3);background:var(--bg2);padding:1px 5px;border-radius:3px;margin-left:6px}.pm-slider-wrap{display:flex;align-items:center;gap:8px}.pm-slider-wrap input[type=range]{width:100px;accent-color:var(--accent)}.pm-slider-wrap span{font-size:.78rem;color:var(--text);min-width:38px;text-align:right}.pm-toggle{width:38px;height:21px;flex-shrink:0;appearance:none;-webkit-appearance:none;background:var(--border2);border-radius:11px;cursor:pointer;transition:background .2s;position:relative}.pm-toggle::after{content:'';position:absolute;top:3px;left:3px;width:15px;height:15px;background:#fff;border-radius:50%;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.3)}.pm-toggle:checked{background:var(--accent)}.pm-toggle:checked::after{left:20px}.pm-toggle:disabled{opacity:.4;cursor:not-allowed}.pm-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.pm-stat-card{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:14px 10px;text-align:center}.pm-stat-icon{font-size:1.5rem;margin-bottom:5px}.pm-stat-val{font-size:1.05rem;font-weight:800;color:var(--text);margin-bottom:3px}.pm-stat-label{font-size:.63rem;color:var(--text3);text-transform:uppercase;letter-spacing:1px}.pm-ctrl-table{width:100%;border-collapse:collapse}.pm-ctrl-table td{padding:7px 10px;font-size:.79rem;vertical-align:middle}.pm-ctrl-table tr{border-bottom:1px solid var(--border)}.pm-ctrl-table tr:last-child{border:none}.pm-ctrl-section{font-size:.68rem;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:2px;padding:12px 10px 4px!important}kbd{background:var(--bg3);border:1px solid var(--border2);border-radius:5px;padding:2px 7px;font-size:.76rem;font-family:monospace;color:var(--accent2);box-shadow:0 2px 0 var(--border2)}.pm-save-slot{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;gap:12px}.pm-slot-info .pm-slot-title{font-size:.85rem;font-weight:700;color:var(--text)}.pm-slot-info .pm-slot-sub{font-size:.72rem;color:var(--text3);margin-top:3px}.pm-slot-actions{display:flex;gap:6px;flex-shrink:0}.pm-act-btn{padding:7px 14px;border-radius:7px;border:1px solid var(--border2);background:var(--bg2);color:var(--text2);font-size:.78rem;cursor:pointer;transition:background .12s,color .12s}.pm-act-btn:hover{background:var(--panel2);color:var(--text)}.pm-act-btn:disabled{opacity:.4;cursor:not-allowed}.pm-act-btn.primary{border-color:var(--accent);color:var(--accent2)}.pm-act-btn.primary:hover{background:rgba(61,142,240,.15)}.pm-act-btn.danger{border-color:var(--red);color:var(--red)}.pm-act-btn.danger:hover{background:rgba(231,76,60,.1)}.pm-warn-box{background:rgba(231,76,60,.08);border:1px solid rgba(231,76,60,.3);border-radius:8px;padding:12px 14px;font-size:.8rem;color:#f08080;line-height:1.5}.pm-seed-inp{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:8px;padding:10px 14px;color:var(--text);font-size:.88rem}.pm-seed-inp::placeholder{color:var(--text3)}.pm-seed-inp:focus{outline:0;border-color:var(--accent)}.pm-credits{text-align:center;padding:8px 0}.pm-credits-logo{font-size:2rem;font-weight:800;color:var(--text);letter-spacing:2px;margin-bottom:2px}.pm-credits-logo span{color:var(--accent2)}.pm-credits-ver{font-size:.7rem;color:var(--text3);margin-bottom:22px}.pm-credits-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--border);font-size:.82rem}.pm-credits-row:last-child{border:none}.pm-credits-role{color:var(--text3)}.pm-credits-name{color:var(--text);font-weight:600}.build-produces{font-size:.65rem;color:var(--accent2);margin-top:2px}#dpad{position:absolute;bottom:16px;left:16px;display:none;grid-template-columns:repeat(3,44px);grid-template-rows:repeat(3,44px);gap:4px;z-index:30}.dpad-btn{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:1.1rem;cursor:pointer;touch-action:none;user-select:none}.dpad-btn:active{background:rgba(255,255,255,.28)}.dpad-e{background:rgba(46,204,113,.2);border-color:var(--green);color:var(--green);font-weight:700}@media (hover:none) and (pointer:coarse){#dpad{display:grid}}.modal{background:var(--panel);border:1px solid var(--border2);border-radius:var(--radius2);box-shadow:var(--shadow);padding:24px;max-width:480px;width:90%;max-height:80vh;overflow-y:auto}.modal h2{font-size:1.1rem;margin-bottom:12px;color:var(--accent2)}.modal p{font-size:.85rem;color:var(--text2);line-height:1.6;margin-bottom:12px}.modal ul{padding-left:20px;font-size:.83rem;color:var(--text2);line-height:1.8;margin-bottom:16px}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.modal.scrollable{max-height:88vh;overflow-y:auto}.cfg-section{margin-bottom:18px}.cfg-label{font-size:.72rem;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px;font-weight:600}.cfg-row{display:flex;flex-wrap:wrap;gap:6px}.cfg-btn{padding:6px 11px;border-radius:6px;border:1.5px solid var(--border);background:var(--bg3);color:var(--text2);font-size:.78rem;cursor:pointer;transition:border-color .12s,background .12s,color .12s;white-space:nowrap}.cfg-btn:hover{border-color:var(--border2);color:var(--text);background:var(--panel2)}.cfg-btn.active{border-color:var(--accent);background:rgba(61,142,240,.18);color:var(--text);font-weight:600}.cfg-btn.danger-active{border-color:var(--red);background:rgba(231,76,60,.15);color:#ff8a8a;font-weight:600}.cfg-biome-btn{display:flex;align-items:center;gap:7px;padding:8px 11px}.cfg-era-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px}.cfg-divider{border:none;border-top:1px solid var(--border);margin:4px 0 18px}#tutorial-box{position:absolute;top:8px;right:8px;z-index:10;background:rgba(20,30,50,.95);border:1px solid var(--accent);border-radius:var(--radius);padding:12px 14px;max-width:220px;font-size:.76rem;color:var(--text2);z-index:5;line-height:1.5;box-shadow:var(--shadow)}#tutorial-box h4{color:var(--accent2);margin-bottom:6px;font-size:.82rem}#tutorial-close{display:block;margin-top:8px;text-align:right;font-size:.72rem;color:var(--text3);cursor:pointer;text-decoration:underline}#tutorial-close:hover{color:var(--text)}#tooltip{position:fixed;background:var(--panel);border:1px solid var(--border2);border-radius:var(--radius);padding:8px 12px;font-size:.75rem;color:var(--text2);pointer-events:none;z-index:999;max-width:200px;box-shadow:var(--shadow);display:none}#tooltip.visible{display:block}#tooltip h5{color:var(--text);font-size:.8rem;margin-bottom:4px}#tooltip .t-line{margin:2px 0}#tooltip .t-cost{color:var(--orange)}#tooltip .t-prod{color:var(--green)}#recipe-panel{padding:8px;background:var(--bg2);border-top:1px solid var(--border);flex-shrink:0;display:none}#recipe-panel.visible{display:block}#recipe-panel h4{font-size:.75rem;color:var(--text2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}#recipe-list{display:flex;flex-wrap:wrap;gap:5px}.recipe-btn{padding:4px 10px;border-radius:5px;border:1px solid var(--border2);background:var(--bg3);color:var(--text2);font-size:.72rem;cursor:pointer;transition:all .15s}.recipe-btn:hover{border-color:var(--accent);color:var(--text)}.recipe-btn.active{border-color:var(--green);color:var(--green);background:rgba(46,204,113,.1)}*{scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.admin-page{overflow:auto;height:100%;display:flex;flex-direction:column}.admin-topbar{display:flex;align-items:center;gap:12px;padding:10px 20px;background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0}.admin-topbar h1{font-size:1.1rem;color:var(--accent2);flex:1}.admin-tabs{display:flex;gap:4px;padding:12px 20px 0;background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0}.tab-btn{padding:8px 18px;border:1px solid transparent;border-bottom:none;border-radius:6px 6px 0 0;background:0 0;color:var(--text2);font-size:.85rem;cursor:pointer;transition:all .15s;font-family:var(--font)}.tab-btn:hover{color:var(--text);background:var(--bg3)}.tab-btn.active{background:var(--panel);border-color:var(--border2);color:var(--accent2);font-weight:600}.admin-content{flex:1;min-height:0;overflow-y:auto;padding:20px}.tab-content{display:none}.tab-content.active{display:block}.admin-section{margin-bottom:32px}.admin-section h2{font-size:.9rem;color:var(--text2);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid var(--border)}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.admin-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius2);padding:16px;transition:border-color .2s}.admin-card:hover{border-color:var(--border2)}.admin-card-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.admin-card-icon{width:36px;height:36px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;font-family:monospace;color:#fff;flex-shrink:0}.admin-card-title{font-weight:600;font-size:.9rem}.admin-card-id{font-size:.7rem;color:var(--text3);font-family:monospace}.form-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:.8rem}.form-row label{color:var(--text2);width:80px;flex-shrink:0}.form-row input,.form-row select,.form-row textarea{flex:1;background:var(--bg3);border:1px solid var(--border2);border-radius:5px;color:var(--text);padding:5px 8px;font-size:.8rem;font-family:var(--font);outline:0;transition:border-color .15s}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--accent)}.form-row input[type=color]{padding:2px;width:40px;height:28px;cursor:pointer}.admin-card-actions{display:flex;gap:6px;margin-top:10px;justify-content:flex-end}.add-new-card{background:var(--bg3);border:2px dashed var(--border2);border-radius:var(--radius2);display:flex;align-items:center;justify-content:center;min-height:120px;cursor:pointer;transition:all .2s;color:var(--text3);font-size:.85rem;gap:8px}.add-new-card:hover{border-color:var(--accent);color:var(--accent2);background:var(--panel)}.json-editor{width:100%;min-height:300px;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);color:var(--text);font-family:'Courier New',monospace;font-size:.8rem;padding:12px;resize:vertical;outline:0}.json-editor:focus{border-color:var(--accent)}.admin-actions-bar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.msg-bar{padding:8px 14px;border-radius:6px;font-size:.82rem;margin-bottom:12px;display:none}.msg-bar.success{background:rgba(46,204,113,.15);border:1px solid var(--green2);color:var(--green);display:block}.msg-bar.error{background:rgba(231,76,60,.15);border:1px solid var(--red);color:var(--red);display:block}@media (max-width:900px){.side-panel{width:220px}}.win{position:fixed;background:var(--panel);border:1px solid var(--border2);border-radius:var(--radius2);box-shadow:0 8px 32px rgba(0,0,0,.65),0 0 0 1px rgba(255,255,255,.04) inset;display:flex;flex-direction:column;z-index:100;overflow:hidden;min-width:180px;transition:box-shadow .15s}.win:hover{box-shadow:0 12px 44px rgba(0,0,0,.75),0 0 0 1px rgba(255,255,255,.07) inset}.win-titlebar{display:flex;align-items:center;gap:7px;padding:0 10px 0 12px;height:34px;background:linear-gradient(135deg,var(--bg2) 0,var(--panel2) 100%);border-bottom:1px solid var(--border);cursor:grab;user-select:none;flex-shrink:0}.win-titlebar:active{cursor:grabbing}.win-icon{font-size:14px;line-height:1;flex-shrink:0}.win-title{flex:1;font-size:10px;font-weight:700;color:var(--text2);letter-spacing:.8px;text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.win-btns{display:flex;gap:5px;margin-left:4px;flex-shrink:0}.win-btn{width:13px;height:13px;border-radius:50%;border:none;cursor:pointer;font-size:0;display:flex;align-items:center;justify-content:center;transition:filter .15s,font-size .1s;flex-shrink:0}.win-btn:hover{filter:brightness(1.35);font-size:7px}.win-btn span{pointer-events:none;color:rgba(0,0,0,.55);font-weight:900;line-height:1}.win-btn-min{background:#f39c12}.win-btn-max{background:#27ae60}.win-btn-close{background:#e74c3c}.win-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px;max-height:360px;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.win-body::-webkit-scrollbar{width:4px}.win-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.win-resize{position:absolute;bottom:0;right:0;width:14px;height:14px;cursor:se-resize;opacity:.2;background:linear-gradient(135deg,transparent 50%,var(--text3) 50%);border-bottom-right-radius:var(--radius2);transition:opacity .2s}.win:hover .win-resize{opacity:.45}.recipe-btn{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:.75rem;background:var(--bg3);border:1px solid var(--border2);color:var(--text2);transition:border-color .15s,background .15s}.recipe-btn:hover{border-color:var(--accent);color:var(--text)}.recipe-btn.active{border-color:var(--accent);background:var(--accent) 22;color:var(--text)}.win-view-toggle{display:flex;gap:4px;padding:6px 8px 0}.view-btn{flex:1;padding:3px 0;font-size:.72rem;border-radius:4px;cursor:pointer;background:var(--bg3);border:1px solid var(--border2);color:var(--text3);transition:all .15s}.view-btn.active{background:var(--accent) 33;border-color:var(--accent);color:var(--accent2)}.view-btn:hover:not(.active){border-color:var(--border2);color:var(--text)}.tech-node{position:absolute;padding:9px 10px;border-radius:10px;cursor:pointer;background:var(--bg3);border:1.5px solid var(--border2);transition:border-color .15s,background .15s,box-shadow .15s;user-select:none;display:flex;flex-direction:column;gap:4px}.tech-node:hover{border-color:var(--accent2);background:var(--bg2);box-shadow:0 0 10px var(--accent) 30}.tech-node.repeatable{border-style:dashed;border-color:var(--yellow) 99}.tech-node.repeatable:hover{background:rgba(241,196,15,.06);box-shadow:0 0 10px var(--yellow) 30}.tech-node.done{border-color:var(--green);border-style:solid;background:rgba(46,204,113,.07);box-shadow:0 0 8px rgba(46,204,113,.2)}.tech-node.available{border-color:var(--accent);box-shadow:0 0 8px var(--accent) 44}.tech-node.locked{opacity:.38;cursor:default;pointer-events:none}.tn-header{display:flex;align-items:center;justify-content:space-between;gap:4px}.tn-icon{font-size:1.25rem;line-height:1;flex-shrink:0;background:var(--bg2);border-radius:6px;padding:2px 4px}.tn-badge{font-size:.66rem;padding:2px 6px;border-radius:4px;font-weight:700;background:var(--bg2);color:var(--text3);white-space:nowrap}.tn-badge.done{color:var(--green);background:rgba(46,204,113,.18)}.tn-badge.available{color:var(--accent2);background:rgba(61,142,240,.18)}.tn-badge.locked{color:var(--text3)}.tn-badge.lv{color:var(--yellow);background:rgba(241,196,15,.18)}.tn-badge.lv0{color:var(--accent2);background:rgba(61,142,240,.18)}.tn-badge.researching{color:#fff;background:#a855f7}.tech-node.researching{border-color:#a855f7!important;box-shadow:0 0 10px rgba(168,85,247,.35)}.tn-name{font-size:.76rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.tn-bonus{font-size:.66rem;color:var(--accent2);background:rgba(61,142,240,.12);padding:2px 5px;border-radius:4px;align-self:flex-start;font-weight:600}.tech-node.repeatable .tn-bonus{color:var(--yellow);background:rgba(241,196,15,.12)}.tn-cost{display:flex;flex-wrap:wrap;gap:3px;margin-top:1px}.tn-cost-item{font-size:.64rem;background:var(--bg2);padding:1px 4px;border-radius:3px;border:1px solid var(--border);color:var(--red)}.tn-cost-item.ok{color:var(--green);border-color:rgba(46,204,113,.25)}.drill-res-btn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:.72rem;background:var(--bg3);border:1px solid var(--border2);color:var(--text2);min-width:52px;text-align:center;transition:border-color .15s,background .15s}.drill-res-btn:hover{border-color:var(--accent);color:var(--text)}.drill-res-btn.active{border-color:var(--accent);background:var(--accent) 22;color:var(--text)}.win-search-wrap{padding:6px 8px 0}.win-search{width:100%;padding:4px 8px 4px 26px;font-size:.75rem;background:var(--bg3);border:1px solid var(--border2);border-radius:4px;color:var(--text);outline:0;transition:border-color .15s;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23556' stroke-width='2.5'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:7px center}.win-search:focus{border-color:var(--accent)}.win-search::placeholder{color:var(--text3)}.win.win-hidden{display:none!important}.win.win-collapsed .win-body,.win.win-collapsed .win-resize{display:none}#hotbar{position:fixed;bottom:52px;left:50%;transform:translateX(-50%);display:flex;gap:4px;padding:5px 8px;background:rgba(15,17,26,.88);border:1px solid var(--border2);border-radius:10px;box-shadow:0 4px 24px rgba(0,0,0,.5);z-index:90}.hb-slot{position:relative;width:56px;height:68px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:var(--bg3);border:1px solid var(--border2);border-radius:7px;cursor:pointer;transition:border-color .12s,background .12s;overflow:hidden;padding:2px}.hb-slot img{width:100%;height:100%;object-fit:contain}.hb-slot:hover{border-color:var(--accent);background:var(--panel2)}.hb-slot.hb-empty{opacity:.7}.hb-slot.hb-empty:hover{opacity:1}.hb-slot.hb-locked{opacity:.4}.hb-num{position:absolute;top:2px;left:4px;font-size:9px;font-weight:700;color:rgba(255,255,255,.5);line-height:1}.hb-icon{width:34px;height:34px;border-radius:5px;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.hb-name{font-size:8px;color:var(--text3);text-align:center;line-height:1.2;max-width:52px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hb-plus{font-size:1.6rem;color:rgba(255,255,255,.55);line-height:1;margin-top:8px}#hotbar-picker{position:fixed;bottom:128px;left:50%;transform:translateX(-50%);width:420px;max-width:96vw;background:var(--panel);border:1px solid var(--border2);border-radius:10px;box-shadow:0 8px 40px rgba(0,0,0,.7);z-index:200;overflow:hidden}#hotbar-picker.hidden{display:none}.hbp-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg3);border-bottom:1px solid var(--border);font-size:.82rem;color:var(--text2)}.hbp-clear,.hbp-close{background:0 0;border:1px solid var(--border2);color:var(--text3);border-radius:5px;padding:2px 7px;cursor:pointer;font-size:.8rem}.hbp-clear:hover{color:var(--red);border-color:var(--red)}.hbp-close:hover{color:var(--text)}.hbp-grid{display:grid;grid-template-columns:repeat(auto-fill,56px);gap:6px;padding:10px;max-height:260px;overflow-y:auto}.hbp-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:5px 4px;border:1px solid var(--border2);border-radius:7px;cursor:pointer;transition:border-color .1s,background .1s}.hbp-item:hover{border-color:var(--accent);background:var(--panel2)}.hbp-item.hbp-selected{border-color:var(--green);background:rgba(46,204,113,.12)}.hbp-icon{width:34px;height:34px;border-radius:5px;display:flex;align-items:center;justify-content:center;overflow:hidden}.hbp-name{font-size:8px;color:var(--text3);text-align:center;line-height:1.2;max-width:52px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#taskbar{position:fixed;bottom:0;left:0;right:0;height:50px;background:rgba(8,10,18,.97);border-top:1px solid var(--border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;padding:0 10px;gap:3px;z-index:500}.task-sep{width:1px;height:28px;background:var(--border);margin:0 6px;flex-shrink:0}.task-btn{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:5px 12px;border-radius:8px;border:1px solid transparent;background:0 0;color:var(--text3);cursor:pointer;font-size:9px;font-family:var(--font);font-weight:600;min-width:56px;white-space:nowrap;transition:all .15s;letter-spacing:.3px}.task-btn .t-icon{font-size:18px;line-height:1.3}.task-btn:hover{background:var(--panel2);color:var(--text2);border-color:var(--border)}.task-btn.active{background:rgba(61,142,240,.1);border-color:rgba(61,142,240,.25);color:var(--accent2)}.task-btn.active::after{content:'';position:absolute;bottom:-1px;left:50%;transform:translateX(-50%);width:22px;height:2px;background:var(--accent2);border-radius:2px 2px 0 0}@keyframes notify-pulse{0%,100%{box-shadow:0 0 0 0 rgba(241,196,15,0)}50%{box-shadow:0 0 0 5px rgba(241,196,15,.4);border-color:rgba(241,196,15,.75)!important}}.task-btn.notify{animation:notify-pulse 1s ease-in-out infinite;border-color:rgba(241,196,15,.5)!important}.task-btn.notify::before{content:'';position:absolute;top:3px;right:3px;width:7px;height:7px;background:var(--red);border-radius:50%;border:1.5px solid var(--bg)}#victory-screen{background:rgba(0,0,0,.92);z-index:2000;animation:vs-in .6s ease}@keyframes vs-in{from{opacity:0;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}#victory-box{position:relative;background:linear-gradient(160deg,#0a1a2a 0,#0d2d1a 100%);border:2px solid #00ff8860;border-radius:16px;padding:40px 48px;max-width:520px;width:90%;text-align:center;box-shadow:0 0 80px #00ff8830,inset 0 0 60px rgba(0,191,255,.06)}#victory-glow{position:absolute;inset:-2px;border-radius:16px;background:0 0;box-shadow:0 0 40px #00ff8840;animation:vs-glow 2s ease-in-out infinite;pointer-events:none}@keyframes vs-glow{0%,100%{box-shadow:0 0 40px #00ff8840}50%{box-shadow:0 0 80px #00ff8880,0 0 120px #00bFFF30}}#victory-title{font-size:2rem;font-weight:900;letter-spacing:.15em;background:linear-gradient(90deg,#00bfff,#0f8,#00bfff);background-size:200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:vs-shimmer 3s linear infinite;margin-bottom:16px}@keyframes vs-shimmer{0%{background-position:0}100%{background-position:200%}}#victory-subtitle{color:var(--text2);font-size:.92rem;line-height:1.7;margin-bottom:24px}#victory-subtitle b{color:#0f8}#victory-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:8px}.vs-stat{background:rgba(0,255,136,.05);border:1px solid #00ff8830;border-radius:8px;padding:10px 14px;display:flex;flex-direction:column;gap:4px}.vs-label{font-size:.72rem;color:var(--text3);text-transform:uppercase;letter-spacing:.06em}.vs-val{font-size:1.1rem;font-weight:700;color:#0f8;font-family:monospace}#title-screen{position:fixed;top:0;left:0;width:100%;height:100%;z-index:99999;display:flex;align-items:center;justify-content:center;background:#080c14;transition:opacity .4s ease}#title-screen.hidden{display:none}body:has(#title-screen:not(.hidden)) #canvas-area,body:has(#title-screen:not(.hidden)) #fs-overlay,body:has(#title-screen:not(.hidden)) #hotbar-container,body:has(#title-screen:not(.hidden)) #topbar{visibility:hidden;pointer-events:none}body:has(#title-screen:not(.hidden)) .modal-overlay:not(.hidden),body:has(#title-screen:not(.hidden)) .modal-overlay:not(.hidden) *{visibility:visible;pointer-events:auto}#ts-splash{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;z-index:0;filter:saturate(1.35) brightness(.8);transition:opacity 2.2s ease}#ts-splash.loaded{opacity:1}#ts-fx{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:2}#ts-biome-badge{position:absolute;bottom:22px;right:22px;z-index:5;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.28)}#ts-bg{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse at 30% 40%,rgba(61,142,240,.16) 0,transparent 60%),radial-gradient(ellipse at 70% 60%,rgba(46,204,113,.11) 0,transparent 55%),linear-gradient(rgba(8,12,20,.38),rgba(8,12,20,.32));animation:ts-pulse 6s ease-in-out infinite alternate}@keyframes ts-pulse{0%{opacity:.6}100%{opacity:1}}#ts-content{position:relative;z-index:4;display:flex;flex-direction:column;align-items:center;gap:18px;text-align:center}#ts-logo{font-size:clamp(2.8rem, 8vw, 5.5rem);font-weight:900;letter-spacing:.04em;text-transform:uppercase;color:var(--accent2);text-shadow:0 0 60px rgba(61,142,240,.45)}#ts-logo span{color:var(--green)}#ts-tagline{font-size:clamp(.85rem, 2vw, 1.1rem);color:var(--text3);letter-spacing:.12em;text-transform:uppercase;margin-top:-10px}#ts-btns{display:flex;flex-direction:column;gap:10px;width:300px;margin-top:8px}.ts-btn{padding:14px 28px;font-size:1rem;font-weight:700;border:1.5px solid var(--border2);border-radius:10px;background:var(--bg3);color:var(--text);cursor:pointer;transition:all .15s ease;letter-spacing:.04em}.ts-btn:hover{background:var(--panel2);border-color:var(--accent);color:var(--accent2);transform:translateY(-1px)}.ts-btn-primary{background:rgba(61,142,240,.18);border-color:var(--accent);color:var(--accent2);box-shadow:0 0 20px rgba(61,142,240,.2)}.ts-btn-primary:hover{background:rgba(61,142,240,.28);box-shadow:0 0 30px rgba(61,142,240,.35)}.ts-btn-test{background:rgba(46,204,113,.1);border-color:#27ae60;color:#2ecc71;font-size:.88rem}.ts-btn-test:hover{background:rgba(46,204,113,.22);border-color:#2ecc71;color:#5effa0;box-shadow:0 0 18px rgba(46,204,113,.25)}.ts-btn-resonance{background:rgba(0,220,255,.1);border-color:#00b4d8;color:#00e5ff;font-size:.88rem}.ts-btn-resonance:hover{background:rgba(0,220,255,.22);border-color:#00e5ff;color:#80ffff;box-shadow:0 0 18px rgba(0,220,255,.3)}.ts-btn:disabled{opacity:.35;cursor:not-allowed;transform:none}#ts-hint{font-size:.72rem;color:var(--text3);letter-spacing:.06em;padding:6px 14px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:6px}#ts-version{font-size:.68rem;color:var(--text3);opacity:.5;margin-top:-6px}.lang-btn{padding:4px 10px;font-size:.8rem;font-weight:600;border-radius:6px;cursor:pointer;background:var(--bg3);color:var(--text2);border:1px solid var(--border2);transition:all .15s}.lang-btn:hover{background:var(--panel2);color:var(--text)}.lang-btn.lang-active{background:var(--accent);color:#fff;border-color:var(--accent)}#tut-overlay{position:fixed;z-index:8200;pointer-events:none;box-shadow:0 0 0 9999px rgba(0,0,0,.62);transition:left .25s ease,top .25s ease,width .25s ease,height .25s ease;animation:tut-ring 2s ease-in-out infinite}#tut-overlay.hidden{display:none}@keyframes tut-ring{0%,100%{box-shadow:0 0 0 9999px rgba(0,0,0,.62),0 0 0 3px rgba(61,142,240,.55)}50%{box-shadow:0 0 0 9999px rgba(0,0,0,.62),0 0 0 5px rgba(61,142,240,.9),0 0 18px rgba(61,142,240,.4)}}#tut-panel{position:fixed;z-index:8300;width:340px;background:var(--bg2);border:1px solid var(--border2);border-radius:14px;box-shadow:0 8px 40px rgba(0,0,0,.7),0 0 0 1px rgba(61,142,240,.15);padding:0;overflow:hidden;transition:left .25s ease,top .25s ease}#tut-panel.hidden{display:none}#tut-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 8px;background:rgba(61,142,240,.08);border-bottom:1px solid var(--border)}.tut-counter{font-size:.7rem;color:var(--accent2);font-weight:700;letter-spacing:.08em;text-transform:uppercase}.tut-skip-btn{font-size:.68rem;color:var(--text3);background:0 0;border:1px solid var(--border);border-radius:5px;padding:2px 8px;cursor:pointer;transition:color .12s,border-color .12s}.tut-skip-btn:hover{color:var(--red);border-color:var(--red)}#tut-panel h3{font-size:.95rem;font-weight:700;color:var(--text);padding:14px 16px 6px;margin:0;line-height:1.3}#tut-panel #tut-text{font-size:.8rem;color:var(--text2);line-height:1.6;padding:0 16px 12px;margin:0}#tut-panel #tut-text b{color:var(--accent2)}#tut-panel #tut-text kbd{background:var(--bg3);border:1px solid var(--border2);border-radius:4px;padding:1px 5px;font-size:.75rem;font-family:monospace;color:var(--yellow)}#tut-dots{display:flex;align-items:center;justify-content:center;gap:6px;padding:4px 16px 10px}.tut-dot{width:7px;height:7px;border-radius:50%;background:var(--border2);transition:all .2s ease}.tut-dot.done{background:var(--accent);opacity:.5}.tut-dot.active{background:var(--accent2);width:20px;border-radius:4px}#tut-nav{display:flex;gap:8px;justify-content:flex-end;padding:10px 14px 14px;border-top:1px solid var(--border)}.tut-btn{padding:7px 16px;font-size:.8rem;font-weight:600;border-radius:7px;cursor:pointer;background:var(--bg3);color:var(--text2);border:1px solid var(--border2);transition:all .12s}.tut-btn:hover:not(:disabled){background:var(--panel2);color:var(--text);border-color:var(--border2)}.tut-btn:disabled{opacity:.3;cursor:not-allowed}.tut-btn-primary{background:rgba(61,142,240,.2);color:var(--accent2);border-color:var(--accent)}.tut-btn-primary:hover{background:rgba(61,142,240,.32)}#map-view{position:fixed;inset:0;z-index:900;background:rgba(0,0,0,.88);display:flex;align-items:center;justify-content:center}#map-view.hidden{display:none}#map-view-inner{position:relative;width:94vw;height:92vh;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius2);display:flex;flex-direction:column;overflow:hidden}#map-view-header{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0}#map-view-title{font-size:1rem;font-weight:700;color:var(--accent2);flex:1}#map-view-legend{display:flex;gap:14px;font-size:.72rem;color:var(--text2)}.mv-leg{display:flex;align-items:center;gap:5px;cursor:pointer;padding:2px 6px;border-radius:5px;border:1px solid transparent;transition:background .1s,opacity .1s;user-select:none}.mv-leg:hover{background:rgba(255,255,255,.07);border-color:var(--border)}.mv-leg i{display:inline-block;width:10px;height:10px;flex-shrink:0;border:1px solid rgba(255,255,255,.2)}.mv-leg-off{opacity:.35;text-decoration:line-through}#map-res-filter{position:relative}#map-res-btn{padding:4px 10px;font-size:.75rem;font-weight:600;border-radius:6px;cursor:pointer;white-space:nowrap;background:var(--bg3);color:var(--text2);border:1px solid var(--border2);transition:background .12s,border-color .12s}#map-res-btn:hover{background:var(--panel2);color:var(--text);border-color:var(--accent)}#map-res-btn span{color:var(--accent2)}#map-res-dropdown{position:absolute;top:calc(100% + 6px);right:0;z-index:100;background:var(--panel);border:1px solid var(--border2);border-radius:var(--radius2);box-shadow:var(--shadow);min-width:200px;max-width:260px;display:flex;flex-direction:column}#map-res-dropdown.hidden{display:none}.mvrd-actions{display:flex;gap:6px;padding:8px 10px;border-bottom:1px solid var(--border)}.mvrd-actions button{flex:1;padding:4px;font-size:.72rem;font-weight:600;border-radius:5px;cursor:pointer;background:var(--bg3);color:var(--text2);border:1px solid var(--border2)}.mvrd-actions button:hover{background:var(--panel2);color:var(--text)}.mvrd-list{padding:6px 4px;max-height:260px;overflow-y:auto}.mvrd-item{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:5px;cursor:pointer;font-size:.78rem;color:var(--text2);transition:background .1s}.mvrd-item:hover{background:var(--bg3);color:var(--text)}.mvrd-item input[type=checkbox]{accent-color:var(--accent);cursor:pointer;flex-shrink:0}.mvrd-item i{display:inline-block;width:9px;height:9px;border-radius:2px;border:1px solid rgba(255,255,255,.15);flex-shrink:0}#map-close-btn{padding:5px 12px;font-size:.78rem;font-weight:600;border-radius:6px;cursor:pointer;background:rgba(231,76,60,.15);color:var(--red);border:1px solid rgba(231,76,60,.35);transition:background .12s}#map-close-btn:hover{background:rgba(231,76,60,.3)}#map-canvas-area{flex:1;position:relative;overflow:hidden}#map-canvas{display:block;width:100%;height:100%;cursor:crosshair}#map-tooltip{position:fixed;background:var(--panel);border:1px solid var(--border2);border-radius:var(--radius);padding:8px 11px;font-size:.75rem;color:var(--text);pointer-events:none;z-index:950;max-width:230px;line-height:1.6;box-shadow:var(--shadow)}#map-tooltip.hidden{display:none}.mtt-title{font-weight:700;font-size:.82rem;color:var(--accent2);margin-bottom:5px}.mtt-row{display:flex;gap:6px;align-items:baseline;color:var(--text2)}.mtt-row b{color:var(--green)}.mtt-sep{font-size:.68rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin:4px 0 2px}.mtt-hint{font-size:.68rem;color:var(--text3);font-style:italic;margin-top:5px;border-top:1px solid var(--border);padding-top:4px}#map-ann-form{position:absolute;z-index:20;background:var(--panel);border:1px solid var(--border2);border-radius:var(--radius2);padding:14px 16px;min-width:260px;max-width:320px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:9px;bottom:16px;right:16px}#map-ann-form.hidden{display:none}.ann-form-title{font-size:.88rem;font-weight:700;color:var(--accent2)}.ann-form-title span{color:var(--text2);font-weight:400}.ann-section-label{font-size:.72rem;color:var(--text2);display:block;margin-bottom:-4px}#ann-desc,#ann-label{width:100%;padding:6px 9px;font-size:.8rem;background:var(--bg3);color:var(--text);border:1px solid var(--border2);border-radius:6px;outline:0;transition:border-color .12s;font-family:var(--font)}#ann-desc:focus,#ann-label:focus{border-color:var(--accent)}#ann-desc{resize:vertical;min-height:52px}#ann-icon-grid{display:flex;flex-wrap:wrap;gap:4px;max-height:92px;overflow-y:auto}.ann-ico-btn{width:28px;height:28px;font-size:1rem;line-height:28px;text-align:center;border-radius:5px;cursor:pointer;border:1px solid transparent;background:var(--bg3);transition:border-color .1s,background .1s}.ann-ico-btn:hover{background:var(--bg2);border-color:var(--border2)}.ann-ico-btn.selected{border-color:var(--accent);background:rgba(61,142,240,.18)}.ann-color-row{display:flex;gap:8px;align-items:center}#ann-color{width:32px;height:26px;border:1px solid var(--border2);border-radius:5px;background:var(--bg3);cursor:pointer;padding:1px}.ann-form-actions{display:flex;gap:8px;justify-content:flex-end}.ann-btn{padding:6px 14px;font-size:.78rem;font-weight:600;border-radius:6px;cursor:pointer;border:1px solid var(--border2);background:var(--bg3);color:var(--text2);transition:background .12s}.ann-btn:hover{background:var(--panel2);color:var(--text)}.ann-btn.primary{background:rgba(46,204,113,.18);color:var(--green);border-color:var(--green2)}.ann-btn.primary:hover{background:rgba(46,204,113,.32)}.ann-btn.danger{background:rgba(231,76,60,.12);color:var(--red);border-color:rgba(231,76,60,.35)}.ann-btn.danger:hover{background:rgba(231,76,60,.28)}.ach-toast{position:fixed;bottom:80px;right:16px;z-index:9998;display:flex;align-items:center;gap:12px;background:#161b22;border:1.5px solid gold;border-radius:12px;padding:12px 16px;min-width:260px;max-width:320px;transform:translateX(120%);transition:transform .4s cubic-bezier(.34,1.56,.64,1);font-family:monospace}.ach-toast.show{transform:translateX(0)}.ach-icon{font-size:1.8rem}.ach-name{font-size:.85rem;font-weight:700;color:gold}.ach-desc{font-size:.72rem;color:#8b949e;margin-top:2px}#_era_trans{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0);pointer-events:none;transition:background .5s}#_era_trans.show{background:rgba(0,0,0,.7)}#_era_trans.hide{background:rgba(0,0,0,0)}.era-box{text-align:center;opacity:0;transform:scale(.5);transition:all .5s cubic-bezier(.34,1.56,.64,1)}#_era_trans.show .era-box{opacity:1;transform:scale(1)}#_era_trans.hide .era-box{opacity:0;transform:scale(1.2)}.era-icon{font-size:4rem;margin-bottom:12px}.era-name{font-size:2rem;color:gold;font-family:monospace;font-weight:700;text-shadow:0 0 30px gold}.era-sub{color:#8b949e;font-size:.9rem;margin-top:8px}#_victory{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:10000;display:flex;align-items:center;justify-content:center;font-family:monospace}.victory-box{text-align:center;padding:40px;border:2px solid gold;border-radius:16px;background:#0d1117;max-width:460px}.victory-title{font-size:3rem;color:gold;margin:0 0 8px;text-shadow:0 0 20px gold}.victory-sub{color:#8b949e;font-size:.9rem;margin-bottom:24px}.victory-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px}.victory-stat{background:#161b22;border-radius:8px;padding:12px;color:#e6edf3}.victory-stat .val{font-size:1.4rem;color:#58a6ff;font-weight:700}.victory-stat .lbl{font-size:.75rem;color:#8b949e}.victory-btns{display:flex;gap:12px;justify-content:center}.ach-toast{position:fixed;bottom:80px;right:-320px;width:280px;background:#161b22;border:1px solid gold;border-radius:10px;padding:12px 14px;display:flex;align-items:center;gap:12px;z-index:9000;transition:right .4s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 20px rgba(255,215,0,.2)}.ach-toast.show{right:16px}.ach-toast .ach-icon{font-size:1.8rem;flex-shrink:0}.ach-toast .ach-name{font-size:.85rem;font-weight:700;color:gold;font-family:monospace}.ach-toast .ach-desc{font-size:.72rem;color:#8b949e;margin-top:2px}.ach-section-label{font-size:.68rem;font-weight:700;color:#8b949e;letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}.ach-row{display:flex;align-items:flex-start;gap:10px;padding:6px 4px;border-radius:6px;margin-bottom:3px}.ach-done{background:rgba(255,215,0,.07)}.ach-todo{background:rgba(255,255,255,.03)}.ach-row-icon{font-size:1.4rem;flex-shrink:0;width:28px;text-align:center}.ach-row-name{font-size:.82rem;font-weight:700;color:#e6edf3;line-height:1.3}.ach-row-desc{font-size:.7rem;color:#8b949e;line-height:1.3}#gameCanvas{touch-action:none}body{overscroll-behavior:none}@media (hover:none) and (pointer:coarse){#game-title{display:none}#topbar{gap:3px;padding:2px 6px}#topbar-info{font-size:.68rem;gap:3px}.topbar-btn{font-size:.7rem;padding:3px 7px}#hotbar{display:none!important}#hotbar-picker{bottom:54px!important}.win:not(.win-maximized){width:50vw!important;max-width:50vw!important}.win.win-maximized{width:calc(100vw - 16px)!important;max-width:none!important}.win-body{max-height:40vh!important}.win-resize{width:28px!important;height:28px!important;opacity:.6!important;touch-action:none}#tutorial-box{display:none!important}.pm-shell{zoom:0.55;width:min(760px,98vw)!important;height:min(530px,95vh)!important}#ts-content{gap:8px!important}#ts-logo{font-size:clamp(1.6rem, 6vw, 3rem)!important}#ts-tagline{font-size:.78rem!important}#ts-hint,#ts-version{display:none!important}.ts-btn{padding:8px 20px!important;font-size:.82rem!important}.win-titlebar{font-size:.72rem;padding:4px 7px}.win-body{max-height:42vh!important;font-size:.72rem;padding:4px 6px!important}.win-btn{width:18px;height:18px;font-size:.65rem}.build-btn,.obj-row,.tech-card{font-size:.7rem!important;padding:5px 7px!important}.build-btn-img{width:36px!important;height:36px!important}.inv-row{font-size:.7rem!important;padding:2px 4px!important}.win-search{font-size:.72rem;padding:3px 6px}.task-btn{min-height:44px;font-size:.7rem;padding:4px 6px}#dpad{bottom:58px;left:10px}#mobile-actions{bottom:58px}}#mobile-actions{position:absolute;bottom:16px;right:16px;display:none;flex-direction:column;gap:6px;z-index:30}.mob-btn{width:44px;height:44px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:10px;color:#fff;font-size:.85rem;touch-action:none;user-select:none;cursor:pointer;display:flex;align-items:center;justify-content:center}.mob-btn:active{background:rgba(255,255,255,.28)}@media (hover:none) and (pointer:coarse){#mobile-actions{display:flex}}