:root{--gbc-bg: #0b1a12;--gbc-dark: #14241a;--gbc-panel: #1d3527;--gbc-panel-2: #24422f;--gbc-line: #3a6b4b;--gbc-ink: #d9f5c8;--gbc-ink-dim: #8fc79a;--gbc-accent: #e8d24a;--gbc-accent-2: #6fd08c;--gbc-danger: #e0553b;--gbc-blue: #5aa9e6;--safe-t: env(safe-area-inset-top, 0px);--safe-b: env(safe-area-inset-bottom, 0px);--safe-l: env(safe-area-inset-left, 0px);--safe-r: env(safe-area-inset-right, 0px)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}html,body{margin:0;padding:0;height:100%;overflow:hidden;background:var(--gbc-bg);color:var(--gbc-ink);font-family:Courier New,ui-monospace,monospace;overscroll-behavior:none;touch-action:none}#app{position:fixed;inset:0;width:100%;height:100%;touch-action:none}#game{position:absolute;inset:0;width:100%;height:100%;display:block;image-rendering:pixelated;image-rendering:crisp-edges;touch-action:none}#ui{position:absolute;inset:0;pointer-events:none;overflow:hidden}#ui>*{pointer-events:auto}.aeon-font{font-family:Courier New,ui-monospace,monospace;font-weight:700;letter-spacing:.02em}.hud-top{position:absolute;top:0;left:0;right:0;padding:calc(var(--safe-t) + 6px) calc(var(--safe-r) + 50px) 6px calc(var(--safe-l) + 8px);display:flex;gap:6px;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;background:linear-gradient(to bottom,#0b1a12f5,#0b1a12b8 80%,#0b1a1200);z-index:20;touch-action:pan-x}.hud-top::-webkit-scrollbar{display:none}.res{flex:none}.res{display:flex;align-items:center;gap:3px;background:var(--gbc-panel);border:2px solid var(--gbc-line);border-radius:6px;padding:3px 7px;min-width:62px;font-size:13px;line-height:1}.res .ic{font-size:13px}.res .val{color:var(--gbc-ink);font-weight:700;font-variant-numeric:tabular-nums}.res .cap{color:var(--gbc-ink-dim);font-size:10px}.res.full .val{color:var(--gbc-accent)}.res.low .val{color:var(--gbc-danger)}.res.pop .ic{color:var(--gbc-accent-2)}.tutorial{position:absolute;left:50%;transform:translate(-50%);bottom:calc(var(--safe-b) + 92px);max-width:min(92vw,460px);background:var(--gbc-panel-2);border:2px solid var(--gbc-accent);border-radius:10px;padding:9px 14px;font-size:14px;line-height:1.35;color:var(--gbc-ink);text-align:center;box-shadow:0 4px #00000059;z-index:25;animation:tut-in .25s ease}.tutorial .arrow{color:var(--gbc-accent);margin-right:4px}@keyframes tut-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.hud-bottom{position:absolute;left:0;right:0;bottom:0;padding:8px calc(var(--safe-r) + 10px) calc(var(--safe-b) + 10px) calc(var(--safe-l) + 10px);display:flex;justify-content:center;gap:10px;z-index:22;pointer-events:none}.hud-bottom>*{pointer-events:auto}.btn{background:var(--gbc-panel);border:2px solid var(--gbc-line);border-radius:10px;color:var(--gbc-ink);font-family:inherit;font-weight:700;font-size:14px;padding:12px 18px;cursor:pointer;box-shadow:0 3px #0006;transition:transform .05s}.btn:active{transform:translateY(2px);box-shadow:0 1px #0006}.btn.primary{background:var(--gbc-accent);color:#2a2410;border-color:#b8a52e}.btn.big{font-size:16px;padding:14px 22px}.sheet-scrim{position:absolute;inset:0;background:#00000073;z-index:30;pointer-events:auto}.sheet{position:absolute;left:0;right:0;bottom:0;max-height:70vh;background:var(--gbc-panel);border-top:3px solid var(--gbc-line);border-radius:16px 16px 0 0;padding:10px calc(var(--safe-r) + 12px) calc(var(--safe-b) + 14px) calc(var(--safe-l) + 12px);z-index:31;overflow-y:auto;-webkit-overflow-scrolling:touch;animation:sheet-in .22s ease}@keyframes sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-handle{width:44px;height:5px;border-radius:3px;background:var(--gbc-line);margin:2px auto 8px;cursor:grab;touch-action:none;flex:none}.sheet-handle:active{cursor:grabbing;background:var(--gbc-ink-dim)}.sheet h2{margin:0 0 10px;font-size:17px;color:var(--gbc-accent);text-align:center}.sheet .grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px}.card{background:var(--gbc-panel-2);border:2px solid var(--gbc-line);border-radius:10px;padding:8px 6px;text-align:center;cursor:pointer;transition:transform .05s}.card:active{transform:scale(.96)}.card.disabled{opacity:.45;cursor:not-allowed}.card.selected{border-color:var(--gbc-accent);background:#33502f}.card .cg{font-size:26px;line-height:1.1}.card .cn{font-size:12px;font-weight:700;margin-top:2px}.card .cc{font-size:10px;color:var(--gbc-ink-dim);margin-top:3px;line-height:1.3}.card .cc .ok{color:var(--gbc-ink-dim)}.card .cc .bad{color:var(--gbc-danger)}.sheet .desc{font-size:11px;color:var(--gbc-ink-dim);margin-top:2px;min-height:26px;line-height:1.3}.sheet .close{margin-top:10px;width:100%}.place-banner{position:absolute;left:50%;transform:translate(-50%);top:calc(var(--safe-t) + 52px);background:var(--gbc-accent);color:#2a2410;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:700;z-index:26;box-shadow:0 3px #0000004d;display:flex;gap:10px;align-items:center}.place-banner .cancel{background:#0003;border:none;color:#2a2410;border-radius:6px;padding:4px 8px;font-weight:700;cursor:pointer;font-family:inherit}.toasts{position:absolute;left:50%;transform:translate(-50%);top:calc(var(--safe-t) + 96px);display:flex;flex-direction:column;gap:5px;align-items:center;z-index:24;pointer-events:none}.toast{background:#14241af2;border:2px solid var(--gbc-line);border-radius:8px;padding:5px 12px;font-size:13px;color:var(--gbc-ink);animation:toast-life 1.6s ease forwards}.toast.good{border-color:var(--gbc-accent-2)}.toast.bad{border-color:var(--gbc-danger);color:#ffd9cf}@keyframes toast-life{0%{opacity:0;transform:translateY(6px)}15%{opacity:1;transform:translateY(0)}80%{opacity:1}to{opacity:0;transform:translateY(-8px)}}.overlay{position:absolute;inset:0;background:radial-gradient(circle at 50% 40%,#163726,#0b1a12 80%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;z-index:40;text-align:center;padding:24px}.overlay h1{font-size:clamp(44px,16vw,84px);letter-spacing:.12em;margin:0;color:var(--gbc-accent);text-shadow:0 4px 0 #7a6a1e,0 5px 0 rgba(0,0,0,.4)}.overlay .sub{color:var(--gbc-ink-dim);font-size:15px;max-width:320px;line-height:1.4}.overlay .menu{display:flex;flex-direction:column;gap:12px;width:min(88vw,300px)}.agechip{position:absolute;top:calc(var(--safe-t) + 44px);left:calc(var(--safe-l) + 8px);display:flex;align-items:center;gap:6px;background:var(--gbc-panel);border:2px solid var(--gbc-line);border-radius:6px;padding:3px 8px;font-size:12px;color:var(--gbc-ink);z-index:19;box-shadow:0 2px #0000004d}.agechip .ac-age{color:var(--gbc-accent);font-weight:700}.agechip .ac-sep,.agechip .ac-season{color:var(--gbc-ink-dim)}.agechip .ac-season.winter{color:#a7d4ff}.agechip.winter{border-color:#5aa0e0;box-shadow:0 0 8px #5aa0e080,0 2px #0000004d}.joblist{display:flex;flex-direction:column;gap:8px;margin-top:8px}.jobrow{display:flex;align-items:center;gap:8px;background:var(--gbc-panel-2);border:2px solid var(--gbc-line);border-radius:10px;padding:8px 10px}.jobrow .jr-ic{font-size:24px;width:30px;text-align:center}.jobrow .jr-mid{flex:1;min-width:0}.jobrow .jr-name{font-size:13px;font-weight:700;color:var(--gbc-ink)}.jobrow .jr-out{font-size:10px;color:var(--gbc-ink-dim);margin-top:1px}.jobrow .jr-ctrl{display:flex;align-items:center;gap:6px}.jobrow .step{width:34px;height:34px;border-radius:8px;border:2px solid var(--gbc-line);background:var(--gbc-panel);color:var(--gbc-ink);font-family:inherit;font-size:20px;font-weight:700;cursor:pointer;line-height:1;padding:0}.jobrow .step:active{transform:translateY(1px)}.jobrow .jr-count{min-width:40px;text-align:center;font-size:14px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--gbc-ink)}.jobrow .jr-auto{border:2px solid var(--gbc-accent);background:transparent;color:var(--gbc-accent);border-radius:8px;font-family:inherit;font-size:11px;font-weight:700;padding:4px 8px;cursor:pointer}.techlist{display:flex;flex-direction:column;gap:10px;margin-top:8px}.techcard{background:var(--gbc-panel-2);border:2px solid var(--gbc-line);border-radius:12px;padding:10px 12px}.techcard.available{border-color:var(--gbc-accent-2)}.techcard.active{border-color:var(--gbc-accent);box-shadow:0 0 8px #e8d24a59}.techcard.locked{opacity:.62}.techcard.done{opacity:.8;border-color:#3f8a44}.techcard .tc-top{display:flex;align-items:center;gap:8px}.techcard .tc-g{font-size:22px}.techcard .tc-name{flex:1;font-size:14px;font-weight:700;color:var(--gbc-ink)}.techcard .tc-cost{font-size:12px;color:var(--gbc-accent);font-weight:700}.techcard .tc-desc{font-size:11px;color:var(--gbc-ink-dim);margin-top:5px;line-height:1.35}.techcard .tc-unlocks{font-size:11px;color:var(--gbc-ink);margin-top:5px;line-height:1.3}.techcard .tc-unlocks.age{color:var(--gbc-accent);font-weight:700}.techcard .tc-bar{height:8px;background:#00000059;border-radius:5px;margin-top:8px;overflow:hidden}.techcard .tc-fill{height:100%;background:var(--gbc-accent);transition:width .2s}.techcard .tc-status{font-size:10px;color:var(--gbc-accent);margin-top:4px}.techcard .tc-done{font-size:12px;color:#6fd06f;font-weight:700;margin-top:6px}.techcard .tc-lock{font-size:11px;color:var(--gbc-danger);margin-top:6px}.techcard .btn{margin-top:8px;width:100%}.event-scrim{position:absolute;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:45;padding:24px;animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.event-card{background:var(--gbc-panel);border:3px solid var(--gbc-accent);border-radius:14px;padding:20px 20px 16px;max-width:min(90vw,380px);text-align:center;box-shadow:0 6px #0006;animation:pop-in .25s ease}@keyframes pop-in{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.event-card h2{margin:0 0 10px;font-size:20px;color:var(--gbc-accent)}.event-card p{margin:0 0 16px;font-size:14px;line-height:1.45;color:var(--gbc-ink)}.event-card .btn{width:100%}.btn.ico{padding:8px 10px;display:flex;flex-direction:column;align-items:center;gap:2px;min-width:52px}.btn.ico .bi{font-size:18px;line-height:1}.btn.ico .bl{font-size:10px;font-weight:700;line-height:1}.btn.ico.big .bi{font-size:22px}.hud-bottom{flex-wrap:wrap;gap:6px}.btn.small{font-size:12px;padding:7px 10px;border-radius:8px;box-shadow:0 2px #0006}.btn.danger{background:var(--gbc-danger);color:#2a1410;border-color:#b8402e}.threatchip{position:absolute;top:calc(var(--safe-t) + 44px);right:calc(var(--safe-r) + 8px);display:flex;align-items:center;gap:5px;background:var(--gbc-panel);border:2px solid var(--gbc-danger);border-radius:6px;padding:3px 8px;font-size:12px;color:var(--gbc-ink);z-index:19;box-shadow:0 2px #0000004d;cursor:pointer}.threatchip .tch-g{font-size:14px}.threatchip .tch-l{font-weight:700;color:#ffd9cf}.threatchip .tch-t{color:var(--gbc-ink-dim);font-variant-numeric:tabular-nums}.threatchip.raid{animation:threat-pulse 1s ease-in-out infinite}@keyframes threat-pulse{0%,to{box-shadow:0 0 4px #e0553b80,0 2px #0000004d}50%{box-shadow:0 0 12px #e0553be6,0 2px #0000004d}}.threatchip.menace{border-color:#b452c9;animation:menace-pulse .9s ease-in-out infinite}@keyframes menace-pulse{0%,to{box-shadow:0 0 5px #b452c98c,0 2px #0000004d}50%{box-shadow:0 0 14px #b452c9f2,0 2px #0000004d}}.needstrip{position:absolute;top:calc(var(--safe-t) + 74px);left:calc(var(--safe-l) + 8px);display:flex;gap:4px;z-index:18}.needpip{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;font-size:13px;background:var(--gbc-panel);border:2px solid var(--gbc-line);box-shadow:0 1px #0000004d}.needpip.ok{border-color:var(--gbc-accent-2)}.needpip.warn{border-color:var(--gbc-accent)}.needpip.bad{border-color:var(--gbc-danger);animation:threat-pulse 1.4s ease-in-out infinite}.sheet .dim{color:var(--gbc-ink-dim)}.sheet .warn-ok{color:var(--gbc-accent-2);font-weight:700}.sheet .warn-bad{color:var(--gbc-danger);font-weight:700}.morelist{display:flex;flex-direction:column;gap:10px;margin-top:8px}.trainbox{background:var(--gbc-panel-2);border:2px solid var(--gbc-accent);border-radius:10px;padding:8px 10px;margin-top:8px;display:flex;flex-direction:column;gap:6px}.trainbox .tb-label{font-size:12px;color:var(--gbc-ink)}.trainbox .tb-track{height:8px;background:#00000059;border-radius:5px;overflow:hidden}.trainbox .tb-fill{height:100%;background:var(--gbc-accent);transition:width .2s}.trainbox .btn{align-self:flex-end}.unitlist{display:flex;flex-direction:column;gap:8px;margin-top:10px}.unitrow{display:flex;align-items:center;gap:10px;background:var(--gbc-panel-2);border:2px solid var(--gbc-line);border-radius:10px;padding:8px 10px}.unitrow.locked{opacity:.55}.unitrow .ur-ic{font-size:24px;width:30px;text-align:center}.unitrow .ur-mid{flex:1;min-width:0}.unitrow .ur-name{font-size:13px;font-weight:700;color:var(--gbc-ink)}.unitrow .ur-have{color:var(--gbc-accent);font-size:12px}.unitrow .ur-sub{font-size:10px;color:var(--gbc-ink-dim);margin-top:2px;line-height:1.3}.unitrow .ur-ctrl{display:flex;gap:6px}.tradelist{display:flex;flex-direction:column;gap:8px;margin-top:8px}.traderow{display:flex;align-items:center;gap:10px;background:var(--gbc-panel-2);border:2px solid var(--gbc-line);border-radius:10px;padding:7px 10px}.traderow .tr-ic{font-size:22px;width:28px;text-align:center}.traderow .tr-mid{flex:1;min-width:0}.traderow .tr-name{font-size:13px;font-weight:700;color:var(--gbc-ink)}.traderow .tr-px{font-size:10px;color:var(--gbc-ink-dim);margin-top:1px}.traderow .tr-ctrl{display:flex;gap:6px}.caravanwrap{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.threatbox{background:#e0553b1f;border:2px solid var(--gbc-danger);border-radius:10px;padding:8px 10px;font-size:12px;color:var(--gbc-ink);margin-top:6px;line-height:1.35}.menacebox{background:#781e782e;border:2px solid #b452c9;border-radius:10px;padding:8px 10px;font-size:12px;color:var(--gbc-ink);margin-top:6px;line-height:1.35;box-shadow:0 0 0 1px #b452c940 inset}.menacebox.broken{background:#6fd08c24;border-color:var(--gbc-good, #6fd08c);box-shadow:none}.worldactions{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.sitelist{display:flex;flex-direction:column;gap:10px;margin-top:8px}.sitecard{background:var(--gbc-panel-2);border:2px solid var(--gbc-line);border-radius:12px;padding:10px 12px}.sitecard.rival{border-color:#a8562e}.sitecard.resource{border-color:var(--gbc-accent-2)}.sitecard.ruin{border-color:#6a4a8a}.sitecard .sc-top{display:flex;align-items:center;gap:8px}.sitecard .sc-g{font-size:22px}.sitecard .sc-name{flex:1;font-size:14px;font-weight:700;color:var(--gbc-ink)}.sitecard .sc-stance{font-size:11px;font-weight:700;padding:2px 7px;border-radius:6px;border:1px solid var(--gbc-line)}.sitecard .sc-stance.neutral{color:var(--gbc-ink-dim)}.sitecard .sc-stance.trade{color:var(--gbc-accent);border-color:var(--gbc-accent)}.sitecard .sc-stance.ally{color:var(--gbc-accent-2);border-color:var(--gbc-accent-2)}.sitecard .sc-stance.hostile,.sitecard .sc-stance.war{color:#ffd9cf;border-color:var(--gbc-danger);background:#e0553b33}.sitecard .sc-sub{font-size:11px;margin-top:5px;line-height:1.3;color:var(--gbc-ink)}.sitecard .sc-btns{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.sitecard .btn{margin-top:8px}.sitecard .sc-btns .btn{margin-top:0}.settingsbtn{position:absolute;top:calc(var(--safe-t) + 6px);right:calc(var(--safe-r) + 8px);width:34px;height:34px;border-radius:8px;background:var(--gbc-panel);border:2px solid var(--gbc-line);color:var(--gbc-ink);font-size:18px;line-height:1;cursor:pointer;z-index:23;box-shadow:0 2px #0006;display:flex;align-items:center;justify-content:center;padding:0}.settingsbtn:active{transform:translateY(1px)}.setrow{text-align:left;display:flex;align-items:center;gap:8px}.btn.ico{min-height:46px}.btn.big{min-height:48px}@media (orientation: landscape){.sheet{max-height:88vh;max-width:640px;left:50%;right:auto;transform:translate(-50%);border-radius:16px 16px 0 0}@keyframes sheet-in{0%{transform:translate(-50%) translateY(100%)}to{transform:translate(-50%) translateY(0)}}.tutorial{bottom:calc(var(--safe-b) + 78px);max-width:min(80vw,460px)}}@media (max-width: 360px){.sheet .grid{grid-template-columns:repeat(auto-fill,minmax(84px,1fr))}.btn.ico{padding:7px;min-width:46px}}.event-card.grand{border-color:var(--gbc-accent);box-shadow:0 0 22px #e8d24a8c,0 6px #0006;animation:grand-pop .5s ease}@keyframes grand-pop{0%{transform:scale(.85);opacity:0}60%{transform:scale(1.04)}to{transform:scale(1);opacity:1}}.perf{position:absolute;left:calc(var(--safe-l) + 6px);bottom:calc(var(--safe-b) + 74px);font-size:10px;color:var(--gbc-ink-dim);background:#00000059;padding:2px 5px;border-radius:4px;z-index:15;pointer-events:none}
