:root{--void: #0e1320;--void-2: #161d2e;--panel: rgba(16, 22, 35, .72);--panel-solid: #121826;--line: rgba(110, 231, 216, .22);--line-strong: rgba(110, 231, 216, .55);--holo: #6ee7d8;--holo-dim: #3f8c83;--signal: #ffc24b;--alert: #ff5d6c;--coral: #ff7a6b;--mineral: #9be0ff;--energy: #ffc24b;--ink: #e8eef6;--ink-dim: #8b96a8;--font-display: "Chakra Petch", system-ui, sans-serif;--font-body: "IBM Plex Sans", system-ui, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, monospace}*{box-sizing:border-box}html,body{margin:0;height:100%;overflow:hidden;background:var(--void)}body{font-family:var(--font-body);color:var(--ink);user-select:none;-webkit-user-select:none}canvas{display:block}#app{position:fixed;inset:0;cursor:crosshair;touch-action:none}#app canvas{touch-action:none}#hud{position:fixed;inset:0;pointer-events:none;z-index:10}#hud>*{pointer-events:auto}.bracket{position:fixed;width:56px;height:56px;border:2px solid var(--line-strong);pointer-events:none;opacity:.8}.bracket.tl{top:14px;left:14px;border-right:none;border-bottom:none}.bracket.tr{top:14px;right:14px;border-left:none;border-bottom:none}.bracket.bl{bottom:14px;left:14px;border-right:none;border-top:none}.bracket.br{bottom:14px;right:14px;border-left:none;border-top:none}.bracket:after{content:"";position:absolute;width:6px;height:6px;background:var(--holo);box-shadow:0 0 8px var(--holo)}.bracket.tl:after{top:-2px;left:-2px}.bracket.tr:after{top:-2px;right:-2px}.bracket.bl:after{bottom:-2px;left:-2px}.bracket.br:after{bottom:-2px;right:-2px}.topbar{position:fixed;top:22px;left:50%;transform:translate(-50%);display:flex;align-items:stretch;gap:10px}.panel{background:var(--panel);border:1px solid var(--line);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.colony-id{display:flex;flex-direction:column;justify-content:center;padding:8px 16px;clip-path:polygon(0 0,100% 0,100% 100%,12px 100%,0 calc(100% - 12px))}.colony-id .name{font-family:var(--font-display);font-weight:700;letter-spacing:.18em;font-size:15px;color:var(--ink)}.colony-id .sub{font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;color:var(--holo-dim);text-transform:uppercase}.resbar{display:flex;align-items:center;gap:4px;padding:6px 10px}.res{display:flex;align-items:center;gap:8px;padding:4px 14px 4px 10px;min-width:116px}.res .dot{width:10px;height:10px;transform:rotate(45deg);flex:none}.res.mineral .dot{background:var(--mineral);box-shadow:0 0 10px var(--mineral)}.res.energy .dot{background:var(--energy);box-shadow:0 0 10px var(--energy)}.res.supply .dot{background:var(--holo);box-shadow:0 0 10px var(--holo)}.res .meta{display:flex;flex-direction:column;line-height:1.1}.res .label{font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;color:var(--ink-dim);text-transform:uppercase}.res .val-row{display:flex;align-items:baseline;gap:6px}.res .val{font-family:var(--font-mono);font-weight:600;font-size:17px;color:var(--ink);font-variant-numeric:tabular-nums}.res .rate{font-family:var(--font-mono);font-size:10px;color:var(--holo-dim);font-variant-numeric:tabular-nums}.res .val.delta{animation:tick .3s ease}@keyframes tick{0%{color:var(--holo);transform:translateY(-1px)}to{color:var(--ink);transform:none}}.raidclock{display:flex;align-items:center;gap:10px;padding:8px 16px;clip-path:polygon(0 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%)}.raidclock .label{font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;color:var(--ink-dim);text-transform:uppercase}.raidclock .time{font-family:var(--font-mono);font-weight:600;font-size:17px;color:var(--holo);font-variant-numeric:tabular-nums}.raidclock.imminent .time{color:var(--alert);animation:blink .7s steps(2,start) infinite}@keyframes blink{50%{opacity:.35}}.dock{position:fixed;bottom:22px;left:50%;transform:translate(-50%);display:flex;gap:10px;align-items:flex-end}.menu{display:flex;gap:6px;padding:10px}.menu-title{position:absolute;top:-9px;left:12px;font-family:var(--font-mono);font-size:9px;letter-spacing:.24em;color:var(--holo-dim);text-transform:uppercase;background:var(--panel-solid);padding:0 6px}.card{position:relative;width:92px;padding:10px 8px 8px;background:#ffffff05;border:1px solid var(--line);cursor:pointer;transition:border-color .15s,background .15s,transform .1s;text-align:left;color:var(--ink)}.card:hover{border-color:var(--line-strong);background:#6ee7d80f}.card:active{transform:translateY(1px)}.card:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.6)}.card .glyph{width:26px;height:26px;margin-bottom:6px}.card .cname{font-family:var(--font-display);font-weight:600;font-size:12px;letter-spacing:.04em}.card .key{position:absolute;top:6px;right:6px;font-family:var(--font-mono);font-size:9px;color:var(--ink-dim);border:1px solid var(--line);padding:0 4px;line-height:14px}.card .cost{display:flex;gap:8px;margin-top:5px}.card .cost span{font-family:var(--font-mono);font-size:10px;display:flex;align-items:center;gap:3px;color:var(--ink-dim)}.card .cost i{width:6px;height:6px;transform:rotate(45deg);display:inline-block}.card .cost .m i{background:var(--mineral)}.card .cost .e i{background:var(--energy)}.card.unaffordable .cost{color:var(--alert)}.selection{position:fixed;left:22px;bottom:22px;width:232px;padding:12px 14px 14px;min-height:76px}.sel-head{font-family:var(--font-display);font-weight:700;font-size:13px;letter-spacing:.12em;color:var(--holo);display:flex;justify-content:space-between;align-items:baseline}.sel-head .count{font-family:var(--font-mono);color:var(--ink-dim);font-size:11px;font-weight:400}.sel-body{margin-top:8px;font-family:var(--font-mono);font-size:11px;color:var(--ink-dim);line-height:1.7}.sel-empty{color:var(--ink-dim);font-style:normal;opacity:.7}.statline{display:flex;justify-content:space-between}.statline b{color:var(--ink);font-weight:500}.hpbar{height:4px;background:#ffffff1a;margin-top:6px;overflow:hidden}.hpbar>i{display:block;height:100%;background:var(--holo);transition:width .2s}.train-row{display:flex;gap:6px;margin-top:10px}.train-btn{flex:1;padding:8px 6px;cursor:pointer;background:#6ee7d814;border:1px solid var(--line-strong);color:var(--holo);font-family:var(--font-display);font-weight:600;font-size:12px;letter-spacing:.04em;transition:background .15s}.train-btn:hover{background:#6ee7d82e}.train-btn:disabled{opacity:.4;cursor:not-allowed}.queue{margin-top:8px;display:flex;align-items:center;gap:8px}.queue .q-track{flex:1;height:5px;background:#ffffff1a}.queue .q-track>i{display:block;height:100%;background:var(--signal);width:0}.queue .q-num{font-family:var(--font-mono);font-size:11px;color:var(--signal)}.research-title{margin-top:12px;margin-bottom:6px;font-family:var(--font-mono);font-size:9px;letter-spacing:.24em;color:var(--holo-dim);text-transform:uppercase}.research-btn{width:100%;display:flex;justify-content:space-between;align-items:center;padding:7px 10px;margin-top:5px;cursor:pointer;background:#ffc24b12;border:1px solid rgba(255,194,75,.3);color:var(--ink);transition:background .15s}.research-btn:hover:not(:disabled){background:#ffc24b29}.research-btn:disabled{opacity:.4;cursor:not-allowed}.research-btn .r-name{font-family:var(--font-display);font-weight:600;font-size:12px}.research-btn .r-name b{color:var(--signal);font-weight:600}.research-btn .r-cost{font-family:var(--font-mono);font-size:10px;color:var(--signal)}.minimap{position:fixed;right:22px;bottom:22px;width:180px;height:180px;padding:8px}.minimap canvas{width:164px;height:164px;image-rendering:pixelated}.minimap .mm-label{position:absolute;top:-9px;left:12px;font-family:var(--font-mono);font-size:9px;letter-spacing:.24em;color:var(--holo-dim);text-transform:uppercase;background:var(--panel-solid);padding:0 6px}.notices{position:fixed;left:50%;top:96px;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:5px;pointer-events:none}.notice{font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;padding:5px 14px;border-left:2px solid var(--holo);background:var(--panel);color:var(--ink);animation:slidein .25s ease}.notice.ok{border-color:var(--holo)}.notice.info{border-color:var(--signal)}.notice.alert{border-color:var(--alert);color:#ffd2d6}@keyframes slidein{0%{opacity:0;transform:translateY(-6px)}}#marquee{position:fixed;display:none;z-index:20;border:1px solid var(--holo);background:#6ee7d81a;pointer-events:none}.hint{position:fixed;bottom:22px;right:214px;display:none}@media (min-width: 1100px){.hint{display:block;font-family:var(--font-mono);font-size:10px;color:var(--ink-dim);text-align:right;line-height:1.9;opacity:.7}}.hint b{color:var(--holo-dim)}.tutorial{position:fixed;left:22px;top:92px;width:268px;padding:12px 14px 14px;border-left:2px solid var(--holo);animation:slidein .3s ease;transition:opacity .4s,transform .4s}.tutorial.tut-out{opacity:0;transform:translate(-12px)}.tut-head{display:flex;justify-content:space-between;align-items:center}.tut-tag{font-family:var(--font-mono);font-size:9px;letter-spacing:.22em;color:var(--holo-dim);text-transform:uppercase}.tut-skip{font-family:var(--font-mono);font-size:10px;color:var(--ink-dim);background:none;border:1px solid var(--line);padding:2px 8px;cursor:pointer}.tut-skip:hover{color:var(--ink);border-color:var(--line-strong)}.tut-step{margin-top:9px;font-family:var(--font-body);font-size:13px;line-height:1.5;color:var(--ink);min-height:38px}.tut-num{margin-top:8px;font-family:var(--font-mono);font-size:10px;color:var(--signal);letter-spacing:.1em}.tutorial.tut-tick{border-left-color:var(--signal)}.tutorial.tut-tick .tut-step{color:var(--holo)}.tutorial.tut-tick .tut-step:after{content:" ✓";color:var(--holo);font-weight:700}.pause-overlay{position:fixed;inset:0;z-index:60;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px;background:#0a0e1857;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);pointer-events:none}.pause-overlay .pause-mark{font-family:var(--font-display);font-weight:700;font-size:40px;letter-spacing:.2em;color:var(--holo);text-shadow:0 0 28px rgba(110,231,216,.5)}.pause-overlay .pause-sub{font-family:var(--font-mono);font-size:12px;letter-spacing:.24em;color:var(--ink-dim)}.idle-chip{position:fixed;left:22px;bottom:112px;display:flex;align-items:center;gap:8px;padding:7px 12px;cursor:pointer;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;color:var(--ink);border:1px solid var(--signal);animation:idlepulse 1.6s ease-in-out infinite}.idle-chip:hover{background:#ffc24b1f}.idle-chip .idle-dot{width:8px;height:8px;transform:rotate(45deg);background:var(--signal);box-shadow:0 0 8px var(--signal)}.idle-chip b{color:var(--signal);font-weight:600}.idle-chip .idle-key{margin-left:2px;padding:0 5px;line-height:15px;border:1px solid var(--line);color:var(--ink-dim);font-size:10px}@keyframes idlepulse{50%{border-color:#ffc24b59}}.sound-toggle{position:fixed;top:90px;right:22px;padding:6px 12px;font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;color:var(--holo);cursor:pointer;background:var(--panel);border:1px solid var(--line)}.sound-toggle:hover{border-color:var(--line-strong)}.save-cluster{position:fixed;top:122px;right:22px;display:flex;gap:6px}.sys-btn{padding:6px 12px;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;color:var(--ink-dim);cursor:pointer;background:var(--panel);border:1px solid var(--line)}.sys-btn:hover{color:var(--holo);border-color:var(--line-strong)}#boot{position:fixed;inset:0;z-index:100;background:radial-gradient(120% 90% at 70% 10%,#2a1d3a 0%,var(--void) 60%);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:28px;transition:opacity .8s ease}#boot.done{opacity:0;pointer-events:none}.boot-mark{text-align:center}.boot-mark .tag{font-family:var(--font-mono);font-size:11px;letter-spacing:.5em;color:var(--coral);text-transform:uppercase}.boot-mark h1{font-family:var(--font-display);font-weight:700;font-size:clamp(34px,7vw,76px);letter-spacing:.14em;margin:8px 0 0;background:linear-gradient(100deg,var(--coral),var(--holo) 70%);-webkit-background-clip:text;background-clip:text;color:transparent}.boot-mark .by{font-family:var(--font-mono);font-size:11px;letter-spacing:.3em;color:var(--ink-dim);margin-top:6px}.boot-log{width:min(440px,78vw);font-family:var(--font-mono);font-size:12px;color:var(--holo-dim)}.boot-log .ln{display:flex;justify-content:space-between;opacity:0;animation:bootln .3s forwards;padding:3px 0;border-bottom:1px dashed rgba(110,231,216,.12)}.boot-log .ln .ok{color:var(--holo)}@keyframes bootln{to{opacity:1}}.diff-row{display:flex;gap:10px}.diff-chip{display:flex;flex-direction:column;align-items:center;gap:2px;width:120px;padding:10px 8px;cursor:pointer;background:#ffffff05;border:1px solid var(--line);color:var(--ink);transition:border-color .15s,background .15s,transform .1s}.diff-chip:hover{border-color:var(--line-strong);background:#6ee7d80f}.diff-chip.sel{border-color:var(--holo);background:#6ee7d81f;box-shadow:0 0 18px #6ee7d840}.diff-chip .d-label{font-family:var(--font-display);font-weight:700;font-size:16px;letter-spacing:.1em}.diff-chip .d-sub{font-family:var(--font-mono);font-size:9px;letter-spacing:.24em;color:var(--holo-dim)}.diff-chip .d-meta{font-family:var(--font-mono);font-size:9px;color:var(--ink-dim);margin-top:3px}.diff-chip .d-rec{font-family:var(--font-mono);font-size:9px;color:var(--signal);margin-top:4px;padding-top:4px;border-top:1px solid var(--line);width:100%;text-align:center}.diff-chip .d-rec-empty{color:var(--ink-dim);opacity:.6}.boot-start{font-family:var(--font-display);font-weight:700;font-size:15px;letter-spacing:.18em;color:var(--void);background:var(--holo);border:none;padding:14px 40px;cursor:pointer;text-transform:uppercase;clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);opacity:0;transition:opacity .4s,transform .1s,box-shadow .2s;box-shadow:0 0 #6ee7d800}.boot-start.ready{opacity:1}.boot-start:hover{box-shadow:0 0 28px #6ee7d880}.boot-start:active{transform:translateY(2px)}.boot-actions{display:flex;gap:12px;align-items:center}.boot-continue{font-family:var(--font-display);font-weight:700;font-size:14px;letter-spacing:.16em;color:var(--holo);background:transparent;border:1px solid var(--holo);padding:13px 28px;cursor:pointer;text-transform:uppercase;clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);opacity:0;transition:opacity .4s,background .2s}.boot-continue.ready{opacity:1}.boot-continue:hover{background:#6ee7d81f}#endcard{position:fixed;inset:0;z-index:120;display:none;background:#080a12db;backdrop-filter:blur(6px);flex-direction:column;justify-content:center;align-items:center;gap:18px}#endcard.show{display:flex}#endcard h2{font-family:var(--font-display);font-weight:700;font-size:44px;letter-spacing:.12em;margin:0}#endcard.lose h2{color:var(--alert)}#endcard.win h2{color:var(--holo)}#endcard p{font-family:var(--font-mono);color:var(--ink-dim);margin:0}.end-diff{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;color:var(--holo-dim);text-transform:uppercase;margin-top:4px}.end-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:6px;min-width:360px}.end-stats .es{display:flex;flex-direction:column;align-items:center;gap:3px;padding:12px 14px;background:var(--panel-solid)}.end-stats .ek{font-family:var(--font-mono);font-size:9px;letter-spacing:.16em;color:var(--ink-dim)}.end-stats .ev{font-family:var(--font-mono);font-weight:600;font-size:20px;color:var(--ink);font-variant-numeric:tabular-nums}.end-rec{display:flex;gap:20px;margin-top:4px;font-family:var(--font-mono);font-size:12px;color:var(--ink-dim)}.end-rec .rec-new{margin-left:6px;padding:1px 5px;font-size:9px;font-weight:600;letter-spacing:.1em;color:var(--void);background:var(--signal);vertical-align:middle}@media (prefers-reduced-motion: reduce){*{animation-duration:.001ms!important;transition-duration:.001ms!important}}button:focus-visible,.card:focus-visible{outline:2px solid var(--holo);outline-offset:2px}@media (max-width: 720px){.res{min-width:84px;padding:4px 8px}.res .val{font-size:14px}.selection{width:180px}.minimap{width:130px;height:130px}.minimap canvas{width:114px;height:114px}.card{width:74px}}
