:root{--ink-deep: #1A1410;--ink-medium: #4A3F2E;--ink-light: #8A7B5E;--paper-cream: #F4EBD6;--paper-aged: #E8DDC4;--brass: #B89968;--brass-bright: #D4B57E;--moss: #5C6B3F;--amber-warn: #D89841;--crimson-alert: #8B2C2C}*{box-sizing:border-box}#root{width:100%;height:100%;position:relative;background:var(--ink-deep)}.scene-canvas{position:absolute;inset:0;width:100%;height:100%;touch-action:none}.hud{position:absolute;top:0;left:0;right:0;padding:20px 28px;display:flex;justify-content:space-between;align-items:flex-start;font-family:Fraunces,Georgia,serif;pointer-events:none;z-index:10;color:var(--paper-cream);text-shadow:0 2px 8px rgba(0,0,0,.7)}.hud-title{font-size:28px;font-weight:500;letter-spacing:-.3px;margin:0}.hud-species{font-style:italic;color:var(--brass-bright)}.hud-sub{font-family:Recursive,ui-monospace,monospace;font-size:13px;color:var(--ink-light);margin-top:4px;letter-spacing:.3px}.hud-meta{font-family:Recursive,ui-monospace,monospace;font-size:13px;color:var(--paper-aged);text-align:right;font-variant-numeric:tabular-nums}.hud-right{display:flex;flex-direction:column;align-items:flex-end;gap:12px}.speed-control{display:flex;align-items:center;gap:4px;pointer-events:auto;background:#1a1108b8;border:1px solid var(--brass);border-radius:6px;padding:4px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.speed-btn{background:transparent;color:var(--paper-aged);border:none;font-family:Recursive,ui-monospace,monospace;font-size:14px;font-weight:500;padding:6px 10px;cursor:pointer;border-radius:4px;min-width:32px;transition:background 80ms ease,color 80ms ease}.speed-btn:hover{background:#b8996840}.speed-btn-active{background:var(--brass);color:var(--ink-deep)}.speed-sep{width:1px;align-self:stretch;background:#b8996880;margin:0 2px}.speed-btn-mute{font-size:16px}.speed-btn-reset{font-size:18px;color:var(--amber-warn)}.speed-btn-reset:hover{background:#d8984140;color:var(--paper-cream)}.view-toggle{pointer-events:auto;background:#1a1108b8;border:1px solid var(--brass);border-radius:6px;padding:8px 14px;font-family:Fraunces,Georgia,serif;font-size:14px;font-weight:500;color:var(--paper-aged);cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:background 80ms ease,color 80ms ease}.view-toggle:hover{background:#b8996859;color:var(--paper-cream)}.hud-toggle-row{display:flex;gap:8px}.pause-overlay{position:absolute;top:110px;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:center;pointer-events:auto;cursor:pointer;z-index:50}.pause-content{background:#1a1108c7;border:1px solid var(--brass);border-radius:8px;padding:14px 24px;text-align:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 8px 24px #0000008c;transition:transform .1s ease,background .1s ease}.pause-overlay:hover .pause-content{transform:translateY(-1px);background:#1a1108e6}.pause-icon{font-size:28px;color:var(--brass-bright);line-height:1;margin-bottom:4px}.pause-title{font-family:Fraunces,Georgia,serif;font-size:18px;color:var(--paper-cream);font-weight:500;margin-bottom:2px}.pause-sub{font-family:Recursive,ui-monospace,monospace;font-size:12px;color:var(--paper-aged);opacity:.8}.founding-hint{position:absolute;top:130px;left:24px;max-width:360px;background:#e8ddc4f0;color:var(--ink-deep);border:1.5px solid var(--brass);border-radius:8px;padding:16px 18px;font-family:Newsreader,Georgia,serif;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 8px 24px #0006;z-index:15}.founding-title{font-family:Fraunces,Georgia,serif;font-size:18px;font-weight:500;margin-bottom:6px}.founding-sub{font-size:13px;line-height:1.45;color:var(--ink-medium);margin-bottom:12px}.founding-pipeline{display:flex;align-items:center;justify-content:space-between;gap:4px;margin:12px 0}.pipe-step{flex:1;text-align:center;padding:6px 4px;border:1px dashed rgba(74,63,46,.3);border-radius:4px;opacity:.45;transition:opacity .2s ease,border-color .2s ease,background .2s ease}.pipe-step-active{opacity:1;border-color:var(--brass);background:#b899682e}.pipe-step-highlight{border-style:solid;border-color:var(--moss);background:#5c6b3f2e}.pipe-count{font-family:Recursive,ui-monospace,monospace;font-size:18px;font-weight:600;color:var(--ink-deep)}.pipe-label{font-family:Caveat,cursive;font-size:14px;color:var(--ink-medium)}.pipe-arrow{color:var(--ink-light);font-size:16px;font-weight:600;padding:0 2px}.founding-cta{font-size:12px;font-family:Recursive,ui-monospace,monospace;color:var(--ink-medium);line-height:1.5;border-top:1px dashed rgba(74,63,46,.3);padding-top:10px;margin-top:8px}.founding-cta strong{color:var(--moss)}.colony-timer{position:absolute;top:160px;right:24px;width:280px;background:#1a1108c7;color:var(--paper-aged);border:1px solid var(--brass);border-radius:8px;padding:12px 14px;font-family:Recursive,ui-monospace,monospace;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 6px 22px #00000080;z-index:15;pointer-events:auto}.timer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding-bottom:8px;border-bottom:1px dashed rgba(184,153,104,.35)}.timer-title{font-family:Fraunces,Georgia,serif;font-weight:500;font-size:14px;color:var(--paper-cream)}.timer-collapse-btn{background:transparent;border:1px solid rgba(184,153,104,.45);color:var(--paper-aged);font-size:14px;line-height:1;width:22px;height:22px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center}.timer-collapse-btn:hover{background:#b899682e;color:var(--paper-cream)}.timer-body{display:flex;flex-direction:column;gap:4px}.timer-row{display:grid;grid-template-columns:18px 1fr auto;align-items:center;gap:8px;padding:3px 0;font-size:12px}.timer-row-highlight{color:var(--brass-bright)}.timer-icon{color:var(--brass);font-size:12px;text-align:center}.timer-label{color:var(--paper-aged)}.timer-eta{font-variant-numeric:tabular-nums;color:var(--paper-cream);font-weight:500;letter-spacing:.3px}.timer-paused-note{margin-top:8px;padding-top:8px;border-top:1px dashed rgba(184,153,104,.25);font-size:11px;color:var(--amber-warn);text-align:center;opacity:.9}.timer-speed-note{color:var(--brass-bright);opacity:.7;font-size:10px}.timer-collapsed{position:absolute;top:160px;right:24px;width:40px;height:40px;border-radius:50%;background:#1a1108cc;border:1px solid var(--brass);color:var(--paper-cream);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 6px 22px #00000080;z-index:15;pointer-events:auto}.timer-collapsed:hover{background:#b8996859}.joystick{position:absolute;bottom:24px;width:140px;height:140px;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:auto;touch-action:none;-webkit-user-select:none;user-select:none;z-index:30}.joystick-left{left:24px}.joystick-right{right:24px}.joystick-base{width:120px;height:120px;border-radius:50%;background:#1a110873;border:2px solid rgba(184,153,104,.55);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px #0006}.joystick-knob{width:56px;height:56px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--brass-bright),var(--brass) 60%,#6e5232);border:1.5px solid rgba(232,221,196,.6);box-shadow:inset 0 -3px 6px #00000059,0 2px 6px #00000080;transition:transform 50ms ease-out}.joystick-label{margin-top:6px;font-family:Recursive,ui-monospace,monospace;font-size:10px;color:var(--paper-aged);text-transform:lowercase;letter-spacing:.4px;opacity:.7;text-shadow:0 1px 4px rgba(0,0,0,.6)}.fps-exit-btn{position:absolute;top:24px;left:24px;z-index:30;pointer-events:auto;background:#1a1108c7;border:1px solid var(--brass);border-radius:6px;padding:10px 16px;font-family:Fraunces,Georgia,serif;font-size:14px;color:var(--paper-cream);cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 4px 14px #00000080}.fps-exit-btn:active{transform:translateY(1px)}.event-banner-stack{position:absolute;top:80px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:60;pointer-events:none;max-width:480px;width:90vw}.event-banner{pointer-events:auto;display:grid;grid-template-columns:36px 1fr 24px;align-items:center;gap:12px;background:#1a1108e0;border-left:4px solid var(--crimson-alert);border-radius:6px;padding:10px 14px;text-align:left;font-family:Newsreader,Georgia,serif;color:var(--paper-cream);cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 6px 20px #0000008c;animation:event-slide-in .28s ease-out}.event-banner:hover{background:#1a1108f2}@keyframes event-slide-in{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.event-spider-attack{border-left-color:var(--crimson-alert)}.event-mold-infestation{border-left-color:var(--moss)}.event-mating-flight{border-left-color:var(--brass-bright)}.event-icon{font-size:26px;text-align:center;line-height:1}.event-text{min-width:0}.event-title{font-family:Fraunces,Georgia,serif;font-weight:500;font-size:15px;margin-bottom:2px}.event-body{font-size:12px;line-height:1.45;color:var(--paper-aged);opacity:.9}.event-close{font-size:18px;color:var(--paper-aged);opacity:.6;text-align:center}.edu-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#1a110873;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:80;cursor:pointer}.edu-card{position:relative;max-width:460px;background:var(--paper-cream);color:var(--ink-deep);border:1.5px solid var(--brass);border-radius:6px;padding:28px 32px 24px;font-family:Newsreader,Georgia,serif;box-shadow:0 12px 48px #0009;cursor:default}.edu-close{position:absolute;top:8px;right:12px;background:none;border:none;font-size:26px;color:var(--ink-light);cursor:pointer;line-height:1}.edu-close:hover{color:var(--ink-deep)}.edu-margin{font-family:Caveat,cursive;font-size:18px;color:var(--ink-light);margin-bottom:6px;transform:rotate(-1.5deg)}.edu-title{font-family:Fraunces,Georgia,serif;font-size:26px;font-weight:500;margin:0 0 14px;color:var(--ink-deep)}.edu-body{font-size:15px;line-height:1.55;margin:0 0 16px}.edu-dismiss{font-family:Recursive,ui-monospace,monospace;font-size:11px;color:var(--ink-light);text-align:center}.panel{position:absolute;background:#e8ddc4eb;color:var(--ink-deep);border:1.5px solid var(--brass);border-radius:6px;padding:14px 16px;font-family:Newsreader,Georgia,serif;font-size:14px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 6px 24px #0006;pointer-events:auto;z-index:10}.panel-climate{bottom:24px;left:24px;min-width:240px}.panel-climate h3{margin:0 0 6px;font-family:Fraunces,Georgia,serif;font-weight:500;font-size:17px;color:var(--ink-deep)}.panel-climate h3+h3{margin-top:0}.panel-divider{height:1px;background:#4a3f2e47;margin:10px 0 8px}.panel-climate .stat{display:flex;justify-content:space-between;font-family:Recursive,ui-monospace,monospace;font-size:13px;padding:3px 0}.panel-climate .stat-good{color:var(--moss)}.panel-climate .stat-warn{color:var(--amber-warn)}.panel-climate .stat-bad{color:var(--crimson-alert)}.action-btn{position:absolute;bottom:24px;right:24px;padding:14px 22px;background:var(--brass);color:var(--ink-deep);border:none;border-radius:8px;font-family:Fraunces,Georgia,serif;font-size:16px;font-weight:500;cursor:pointer;pointer-events:auto;box-shadow:0 4px 12px #0006;z-index:10;transition:transform 80ms ease,background 80ms ease}.action-btn:hover{background:var(--brass-bright)}.action-btn:active{transform:translateY(1px)}.actions-bar{position:absolute;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:10;pointer-events:none}.action-btn-stacked{display:flex;align-items:center;gap:12px;min-width:200px;padding:12px 16px;background:#b89968eb;color:var(--ink-deep);border:1px solid rgba(74,63,46,.4);border-radius:6px;font-family:Fraunces,Georgia,serif;font-size:15px;font-weight:500;cursor:pointer;pointer-events:auto;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 4px 12px #00000080;transition:transform 80ms ease,background 80ms ease;text-align:left}.action-btn-stacked:hover{background:var(--brass-bright)}.action-btn-stacked:active{transform:translateY(1px)}.action-icon{font-size:20px;width:28px;text-align:center}.action-label{flex:1}.crosshair{position:absolute;top:50%;left:50%;width:12px;height:12px;margin-left:-6px;margin-top:-6px;border:1.5px solid var(--paper-cream);border-radius:50%;opacity:.7;pointer-events:none;z-index:10}.fps-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,calc(-50% + 40px));font-family:Caveat,cursive;font-size:22px;color:var(--paper-aged);text-shadow:0 2px 8px rgba(0,0,0,.7);pointer-events:none;z-index:10;opacity:.7}.orbit-hint{position:absolute;bottom:100px;left:50%;transform:translate(-50%);font-family:Caveat,cursive;font-size:18px;color:var(--paper-aged);text-shadow:0 2px 8px rgba(0,0,0,.7);pointer-events:none;z-index:5;opacity:.5}.enter-fps-btn{position:absolute;bottom:140px;left:50%;transform:translate(-50%);z-index:12;pointer-events:auto;background:#b89968e0;border:1px solid var(--brass-bright);border-radius:6px;padding:10px 18px;font-family:Fraunces,Georgia,serif;font-size:14px;color:var(--ink-deep);font-weight:500;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 4px 14px #00000080;transition:background 80ms ease,transform 80ms ease}.enter-fps-btn:hover{background:var(--brass-bright)}.enter-fps-btn:active{transform:translate(-50%) translateY(1px)}@media (max-width: 767px){.enter-fps-btn{display:none}}.modal-backdrop{position:absolute;inset:0;background:#1a141099;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--paper-cream);color:var(--ink-deep);border:1.5px solid var(--brass);border-radius:8px;padding:28px 32px;max-width:420px;text-align:center;font-family:Newsreader,Georgia,serif;box-shadow:0 12px 48px #0009}.modal h2{font-family:Caveat,cursive;font-size:36px;margin:0 0 12px;font-weight:500}.modal p{margin:8px 0;font-size:16px;line-height:1.5}.modal-dismiss{margin-top:12px;font-family:Recursive,ui-monospace,monospace;font-size:12px;color:var(--ink-light)}.offline-toast{position:absolute;top:80px;left:50%;transform:translate(-50%);background:var(--paper-cream);color:var(--ink-deep);border:1.5px solid var(--brass);border-radius:8px;padding:16px 22px;max-width:360px;min-width:240px;font-family:Newsreader,Georgia,serif;box-shadow:0 8px 32px #00000080;cursor:pointer;z-index:90;animation:offline-toast-in .42s ease-out}@keyframes offline-toast-in{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}.offline-toast-title{font-family:Caveat,cursive;font-size:22px;font-weight:500;margin-bottom:6px;color:var(--brass)}.offline-toast-body{font-size:14px;line-height:1.45}.offline-toast-body ul{margin:4px 0 0;padding-left:18px}.offline-toast-body li{margin:2px 0}.offline-toast-capped{margin-top:8px;font-size:12px;color:var(--ink-light);font-style:italic}.offline-toast-dismiss{margin-top:8px;font-family:Recursive,ui-monospace,monospace;font-size:11px;color:var(--ink-light);text-align:center}@media (max-width: 767px){.offline-toast{top:64px;max-width:80vw;min-width:200px;padding:12px 16px}.offline-toast-title{font-size:18px}.offline-toast-body{font-size:13px}}.save-heartbeat{position:absolute;top:64px;right:16px;display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-family:Recursive,ui-monospace,monospace;font-size:11px;border:1px solid transparent;background:#1a1410b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:80;pointer-events:none;-webkit-user-select:none;user-select:none}.save-heartbeat-ok{color:#9cb388;border-color:#9cb3884d}.save-heartbeat-pending{color:#b89968;border-color:#b899684d}.save-heartbeat-failing{color:#d88a6b;border-color:#d88a6b80;background:#501e14b3}.save-heartbeat-icon{font-size:12px}@media (max-width: 767px){.save-heartbeat{top:56px;right:12px;padding:3px 8px;font-size:10px}}.save-failure-modal h2{color:#c04a30}.save-failure-details{font-family:Recursive,ui-monospace,monospace;font-size:12px;background:#1a141014;border-radius:4px;padding:8px 10px;margin:10px 0;word-break:break-word}.save-failure-label{font-weight:600;color:var(--ink-light);margin-right:4px}.save-failure-dismiss{margin-top:16px;background:var(--brass);color:var(--paper-cream);border:1.5px solid var(--brass);border-radius:6px;padding:8px 24px;font-family:Newsreader,Georgia,serif;font-size:15px;cursor:pointer;min-height:44px}.save-failure-dismiss:hover{background:#8a6f4a}.read-only-banner{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;background:#c04a30;color:#f8e8c0;font-family:Newsreader,Georgia,serif;font-size:13px;text-align:center;z-index:200;box-shadow:0 2px 8px #0006}.read-only-icon{font-size:16px;flex-shrink:0}.read-only-text{max-width:720px;line-height:1.4}@media (max-width: 767px){.read-only-banner{padding:6px 10px;font-size:11px}.read-only-icon{font-size:14px}}@media (max-width: 767px){.hud{padding:12px 14px}.hud-title{font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:55vw}.hud-sub{font-size:11px;max-width:55vw;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hud-meta{font-size:11px}.hud-right{gap:6px}.speed-control{padding:2px;gap:2px}.speed-btn{padding:4px 7px;font-size:12px;min-width:26px}.speed-btn-mute,.speed-btn-reset{font-size:14px}.view-toggle{padding:6px 10px;font-size:12px}.panel-climate{bottom:68px;left:12px;min-width:0;max-width:56vw;padding:10px 12px;font-size:12px;max-height:48vh;overflow-y:auto}.panel-climate h3{font-size:13px;margin:0 0 3px}.panel-climate .stat{padding:1px 0;font-size:11px}.panel-divider{margin:5px 0 3px}.actions-bar{inset:auto 12px 12px auto;flex-direction:row;gap:6px}.action-btn-stacked{min-width:0;width:44px;height:44px;padding:0;font-size:13px;gap:0;justify-content:center}.action-label{display:none}.action-icon{font-size:22px;width:auto;text-align:center}.founding-hint{display:none}.colony-timer{top:60px;right:60px;width:180px;padding:6px 8px;font-size:11px}.timer-row{font-size:10px;padding:1px 0}.timer-icon{font-size:9px}.colony-timer .timer-title{font-size:11px}.timer-collapsed{top:60px;right:12px;width:32px;height:32px;font-size:15px}.pause-overlay{top:70px;max-width:60vw}.pause-content{padding:8px 14px}.pause-icon{font-size:18px;margin-bottom:2px}.pause-title{font-size:13px}.pause-sub{font-size:10px}.event-banner-stack{top:64px;max-width:92vw}.event-banner{grid-template-columns:28px 1fr 18px;padding:8px 10px;gap:8px}.event-title{font-size:13px}.event-body{font-size:11px}.joystick{width:110px;height:110px;bottom:14px}.joystick-left{left:14px}.joystick-right{right:14px}.joystick-base{width:92px;height:92px}.joystick-knob{width:44px;height:44px}.fps-exit-btn{top:14px;left:14px;padding:8px 12px;font-size:12px}.orbit-hint{font-size:13px;bottom:60px;padding:0 12px;text-align:center}.fps-hint{font-size:13px;padding:0 12px;text-align:center}.enter-fps-btn{display:none}}@media (max-width: 379px){.hud-title{font-size:15px;max-width:50vw}.colony-timer{width:160px}.panel-climate{max-width:52vw;padding:8px 10px}}.version-footer{position:absolute;bottom:6px;right:8px;background:transparent;border:none;color:var(--ink-light);opacity:.4;font-family:Recursive,ui-monospace,monospace;font-size:10px;letter-spacing:.04em;padding:2px 4px;cursor:pointer;z-index:70;transition:opacity .16s ease}.version-footer:hover{opacity:.85}.version-footer:focus-visible{opacity:.95;outline:1px solid var(--brass);outline-offset:2px;border-radius:2px}@media (max-width: 767px){.version-footer{font-size:9px;bottom:4px;right:6px}}.update-toast{position:absolute;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:16px;background:var(--paper-cream);color:var(--ink-deep);border:1.5px solid var(--brass);border-radius:8px;padding:12px 18px;max-width:480px;font-family:Newsreader,Georgia,serif;box-shadow:0 8px 32px #00000080;z-index:95;animation:update-toast-in .32s ease-out}@keyframes update-toast-in{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.update-toast-body{flex:1;min-width:0}.update-toast-body strong{display:block;font-family:Caveat,cursive;font-size:20px;font-weight:500;color:var(--brass)}.update-toast-detail{font-size:13px;line-height:1.4;margin-top:2px}.update-toast-actions{display:flex;gap:8px;flex-shrink:0}.update-toast-reload,.update-toast-later{font-family:Newsreader,Georgia,serif;font-size:13px;padding:6px 14px;border-radius:6px;cursor:pointer;min-height:36px;border:1.5px solid var(--brass)}.update-toast-reload{background:var(--brass);color:var(--paper-cream)}.update-toast-reload:hover{background:#8a6f4a}.update-toast-later{background:transparent;color:var(--ink-deep)}.update-toast-later:hover{background:#b899681f}@media (max-width: 767px){.update-toast{flex-direction:column;align-items:stretch;gap:10px;bottom:12px;max-width:84vw;padding:10px 14px}.update-toast-actions{justify-content:stretch}.update-toast-reload,.update-toast-later{flex:1;min-height:40px}}
