*{margin:0;padding:0;box-sizing:border-box}:root{--accent: #8b5cf6;--accent-dim: rgba(139, 92, 246, .3);--bg-panel: rgba(5, 5, 16, .85);--bg-panel-solid: rgba(10, 10, 24, .95);--text: #e0e0e0;--text-dim: rgba(255, 255, 255, .4);--cyan: #00ffcc;--green: #00ff44;--pink: #ff44aa;--blue: #4488ff;--red: #ff2200;--font: "JetBrains Mono", "Courier New", monospace}html,body{width:100%;height:100dvh;overflow:hidden;background:#050510;font-family:var(--font);color:var(--text);overscroll-behavior:none;-webkit-overflow-scrolling:touch}canvas{display:block;touch-action:none}#app{width:100%;height:100dvh;position:relative}canvas{display:block}.ui-wrapper{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10;transition:opacity .3s ease}.ui-wrapper.hidden{opacity:0;pointer-events:none!important}.ui-wrapper.hidden *{pointer-events:none!important}.ui-hide-btn{position:absolute;top:50%;left:6px;transform:translateY(-50%);z-index:20;width:32px;height:32px;background:#05051099;border:1px solid var(--accent-dim);color:var(--accent);font-family:var(--font);font-size:11px;font-weight:600;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background .2s,opacity .3s;opacity:.5;pointer-events:auto}.ui-hide-btn:hover,.ui-hide-btn:active{background:#8b5cf640;opacity:1}.ui-hide-btn.ui-shown-indicator{opacity:.8;border-color:var(--cyan);color:var(--cyan)}.ui-panel{position:absolute;pointer-events:auto;z-index:10}.stats-panel{top:16px;left:16px;background:var(--bg-panel);border:1px solid var(--accent-dim);border-radius:8px;padding:12px 16px;min-width:200px;max-height:calc(100dvh - 100px);overflow-y:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.panel-header{font-size:13px;font-weight:600;color:var(--accent);letter-spacing:2px;margin-bottom:10px;text-transform:uppercase}.panel-header-small{font-size:11px;font-weight:500;color:var(--accent);letter-spacing:1.5px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}.stats-grid{display:flex;flex-direction:column;gap:3px}.stat-row{display:flex;justify-content:space-between;align-items:center;font-size:11px;gap:8px}.stat-row.sub{padding-left:8px;opacity:.7}.stat-label{color:var(--text-dim);white-space:nowrap}.stat-value{color:var(--text);font-weight:500;text-align:right;min-width:40px}.stat-divider{height:1px;background:var(--accent-dim);margin:4px 0}.stat-bar-wrap{flex:1;height:4px;background:#ffffff14;border-radius:2px;overflow:hidden;margin:0 6px;min-width:40px}.stat-bar{height:100%;border-radius:2px;transition:width .15s ease;will-change:width}.stat-bar.stress{background:var(--pink)}.stat-bar.hunger{background:var(--red)}.stat-bar.energy{background:var(--green)}.control-panel{top:16px;right:16px;background:var(--bg-panel);border:1px solid var(--accent-dim);border-radius:8px;min-width:220px;max-height:calc(100dvh - 100px);overflow-y:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:min-width .3s ease,opacity .3s ease}.control-panel.collapsed{min-width:40px}.control-panel.collapsed .control-content{display:none}.control-header{padding:10px 14px;display:flex;justify-content:space-between;align-items:center;cursor:default;margin-bottom:0}.toggle-btn{background:none;border:1px solid var(--accent-dim);color:var(--accent);width:32px;height:32px;border-radius:4px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;transition:background .2s}.toggle-btn:hover,.toggle-btn:active{background:var(--accent-dim)}.control-content{padding:0 14px 14px}.btn-row{display:flex;gap:6px;margin-bottom:12px}.ctrl-btn{flex:1;padding:8px 6px;min-height:36px;background:#8b5cf61a;border:1px solid var(--accent-dim);color:var(--text);border-radius:4px;font-family:var(--font);font-size:10px;letter-spacing:1px;cursor:pointer;transition:background .2s,border-color .2s}.ctrl-btn:hover,.ctrl-btn:active{background:#8b5cf640;border-color:var(--accent)}.ctrl-btn.active{background:#8b5cf64d;border-color:var(--accent);color:var(--accent)}.reset-btn:hover,.reset-btn:active{background:#f203;border-color:var(--red);color:var(--red)}.slider-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:10px}.slider-row label{color:var(--text-dim);min-width:85px;white-space:nowrap}.slider-row input[type=range]{flex:1;height:3px;-webkit-appearance:none;appearance:none;background:#ffffff1a;border-radius:2px;outline:none}.slider-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent);cursor:pointer}.slider-row input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--accent);cursor:pointer;border:none}.slider-value{color:var(--text);min-width:32px;text-align:right;font-size:10px}.toggle-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px;font-size:10px;color:var(--text-dim)}.toggle-row input[type=checkbox]{accent-color:var(--accent);width:20px;height:20px;cursor:pointer;flex-shrink:0}.graph-panel{bottom:16px;left:16px;background:var(--bg-panel);border:1px solid var(--accent-dim);border-radius:8px;padding:8px 10px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.graph-panel canvas{border-radius:4px}.inspector-panel{bottom:16px;right:16px;background:var(--bg-panel-solid);border:1px solid var(--accent-dim);border-radius:8px;padding:10px 14px;min-width:200px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.close-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:18px;padding:8px;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;line-height:1}.close-btn:hover,.close-btn:active{color:var(--red)}.inspector-content{display:flex;flex-direction:column;gap:4px}.inspector-row{display:flex;align-items:center;justify-content:space-between;font-size:11px;gap:8px}.inspector-row span:first-child{color:var(--text-dim)}.inspector-row .male{color:var(--blue)}.inspector-row .female{color:var(--pink)}.mini-bar-wrap{flex:1;height:3px;background:#ffffff14;border-radius:2px;overflow:hidden;min-width:30px}.mini-bar{height:100%;border-radius:2px}.mini-bar.hunger{background:var(--red)}.mini-bar.energy{background:var(--green)}.mini-bar.stress{background:var(--pink)}.mini-bar.dna-speed{background:var(--cyan)}.mini-bar.dna-metabolism{background:#f84}.mini-bar.dna-stress{background:var(--blue)}.mini-bar.dna-fertility{background:var(--pink)}.inspector-divider{height:1px;background:var(--accent-dim);margin:6px 0}.inspector-section-label{font-size:9px;font-weight:600;color:var(--accent);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:4px}.fps-counter{position:absolute;top:16px;left:50%;transform:translate(-50%);z-index:10;font-size:10px;color:var(--text-dim);letter-spacing:1px;pointer-events:none}.help-text{position:absolute;bottom:16px;left:50%;transform:translate(-50%);z-index:10;font-size:10px;color:var(--text-dim);letter-spacing:.5px;pointer-events:none;white-space:nowrap}#loading-screen{position:fixed;top:0;left:0;width:100%;height:100dvh;background:#050510;display:flex;align-items:center;justify-content:center;z-index:1000;transition:opacity .6s ease}#loading-screen.fade-out{opacity:0;pointer-events:none}.loading-content{text-align:center}.loading-title{font-family:var(--font);font-size:28px;font-weight:600;color:var(--accent);letter-spacing:8px;margin-bottom:6px;animation:loadingPulse 2s ease-in-out infinite}.loading-subtitle-text{font-family:var(--font);font-size:10px;color:var(--text-dim);letter-spacing:3px;margin-bottom:24px;text-transform:uppercase}#loading-video{width:300px;height:300px;object-fit:cover;border-radius:12px;border:1px solid var(--accent-dim);margin-bottom:24px;box-shadow:0 0 30px #8b5cf626}@keyframes loadingPulse{0%,to{opacity:1}50%{opacity:.7}}.loading-bar-container{width:300px;height:4px;background:#ffffff14;border-radius:2px;overflow:hidden;margin:0 auto 16px}.loading-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--accent),var(--cyan));border-radius:2px;transition:width .3s ease;box-shadow:0 0 8px #8b5cf666}.loading-phase{font-family:var(--font);font-size:11px;color:var(--text-dim);letter-spacing:1px;min-height:16px}.loading-dedication{font-family:var(--font);font-size:10px;color:var(--text-dim);letter-spacing:1px;margin-top:32px;opacity:.6}.mobile-disclaimer{display:none}.setup-screen{position:fixed;top:0;left:0;width:100%;height:100dvh;background:#050510f2;display:flex;align-items:flex-start;justify-content:center;z-index:999;transition:opacity .6s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow-y:auto;padding:40px 20px}.setup-screen.fade-out{opacity:0;pointer-events:none}.setup-content{grid-area:config;text-align:center;max-width:400px}.setup-title{font-family:var(--font);font-size:32px;font-weight:600;color:var(--accent);letter-spacing:8px;margin-bottom:8px}.setup-subtitle{font-family:var(--font);font-size:11px;color:var(--text-dim);letter-spacing:3px;margin-bottom:32px}.setup-section-label{font-family:var(--font);font-size:10px;color:var(--text-dim);letter-spacing:2px;text-transform:uppercase;margin-bottom:16px}.setup-map-grid{display:flex;gap:12px;margin-bottom:32px;justify-content:center}.setup-map-card{flex:0 0 110px;cursor:pointer;border-radius:8px;border:2px solid rgba(255,255,255,.08);padding:8px;text-align:center;transition:border-color .2s,transform .2s;background:#ffffff08}.setup-map-card:hover,.setup-map-card:active{border-color:#8b5cf666}.setup-map-card.active{border-color:var(--accent);transform:scale(1.04);background:#8b5cf614}.setup-map-thumb{width:100%;height:70px;border-radius:6px;margin-bottom:8px;object-fit:cover;display:block}.setup-map-thumb-placeholder{background:linear-gradient(135deg,#ffffff0d,#ffffff05)}.setup-map-name{font-family:var(--font);font-size:11px;font-weight:600;color:var(--text);letter-spacing:.5px}.setup-map-desc{font-family:var(--font);font-size:9px;color:var(--text-dim);margin-top:4px;letter-spacing:.3px}.map-loading-overlay{position:fixed;top:0;left:0;width:100%;height:100dvh;background:#050510f2;display:flex;align-items:center;justify-content:center;z-index:999;transition:opacity .6s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.map-loading-overlay.fade-out{opacity:0;pointer-events:none}.map-loading-content{text-align:center}.map-loading-text{font-family:var(--font);font-size:14px;color:var(--accent);letter-spacing:3px;margin-bottom:20px;text-transform:uppercase}.map-loading-bar-container{width:200px;height:4px;background:#ffffff14;border-radius:2px;overflow:hidden;margin:0 auto}.map-loading-bar-inner{height:100%;width:0%;background:linear-gradient(90deg,var(--accent),var(--cyan));border-radius:2px;transition:width .3s ease}.setup-field{margin-bottom:24px;text-align:left}.setup-field label{display:block;font-family:var(--font);font-size:11px;color:var(--text-dim);letter-spacing:1px;margin-bottom:8px;text-transform:uppercase}.setup-slider-row{display:flex;align-items:center;gap:12px}.setup-slider-row input[type=range]{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:#ffffff1a;border-radius:2px;outline:none}.setup-slider-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid rgba(255,255,255,.2)}.setup-value{font-family:var(--font);font-size:18px;font-weight:600;color:var(--accent);min-width:32px;text-align:right}.setup-start-btn{margin-top:32px;padding:14px 40px;min-height:48px;background:#8b5cf626;border:2px solid var(--accent);color:var(--accent);font-family:var(--font);font-size:14px;font-weight:600;letter-spacing:3px;cursor:pointer;border-radius:6px;transition:background .3s,transform .2s}.setup-start-btn:hover,.setup-start-btn:active{background:#8b5cf64d;transform:scale(1.02)}.setup-layout{display:grid;grid-template-columns:1fr minmax(auto,400px) 1fr;grid-template-areas:"header header header" "guide  config story";gap:24px;max-width:1200px;width:100%;margin:0 auto;align-items:start}.setup-header{grid-area:header;text-align:center}.setup-guide-card{grid-area:guide}.setup-story-card{grid-area:story}.setup-info-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);max-height:70vh;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--accent-dim) transparent}.setup-info-card::-webkit-scrollbar{width:4px}.setup-info-card::-webkit-scrollbar-track{background:transparent}.setup-info-card::-webkit-scrollbar-thumb{background:var(--accent-dim);border-radius:2px}.setup-card-header{display:flex;align-items:center;gap:10px;padding:14px 16px;background:#8b5cf614;border-bottom:1px solid var(--accent-dim);position:sticky;top:0;z-index:1;font-family:var(--font)}.setup-card-icon{font-size:16px;line-height:1}.setup-card-title{font-family:var(--font);font-size:11px;font-weight:600;color:var(--accent);letter-spacing:2px;text-transform:uppercase}.setup-card-body{padding:14px 16px}.setup-card-intro{font-family:var(--font);font-size:11px;color:var(--text);line-height:1.6;margin-bottom:14px}.setup-guide-section,.setup-story-section{margin-bottom:12px}.setup-guide-heading,.setup-story-heading{font-family:var(--font);font-size:10px;font-weight:600;color:var(--accent);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:4px}.setup-guide-text,.setup-story-text{font-family:var(--font);font-size:11px;color:var(--text-dim);line-height:1.6}.setup-guide-text strong,.setup-story-text strong{color:var(--text);font-weight:600}.setup-guide-states{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.setup-state-tag{font-family:var(--font);font-size:9px;font-weight:600;color:var(--state-color);border:1px solid var(--state-color);border-radius:4px;padding:3px 8px;letter-spacing:.5px;opacity:.85}.setup-card-expand-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;min-height:44px;background:#8b5cf60f;border:1px solid var(--accent-dim);border-radius:6px;color:var(--accent);font-family:var(--font);font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:background .2s;touch-action:manipulation;margin-top:8px}.setup-card-expand-btn:hover,.setup-card-expand-btn:active{background:#8b5cf626}.setup-card-expand-btn:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}.setup-expand-arrow{font-size:12px;transition:transform .3s ease}.setup-card-expand-btn.expanded .setup-expand-arrow{transform:rotate(180deg)}.setup-card-expanded{max-height:0;overflow:hidden;transition:max-height .4s ease,opacity .3s ease;opacity:0}.setup-card-expanded.open{max-height:2000px;opacity:1;margin-top:14px}.setup-story-callout{background:#8b5cf60f;border-left:3px solid var(--accent);border-radius:0 6px 6px 0;padding:12px 14px;margin-top:14px}.control-section-header{font-size:9px;font-weight:600;color:var(--accent);letter-spacing:1.5px;margin:10px 0 6px;padding-top:6px;border-top:1px solid var(--accent-dim);text-transform:uppercase}.final-report{position:fixed;top:0;left:0;width:100%;height:100dvh;background:#050510eb;display:flex;align-items:flex-start;justify-content:center;z-index:999;opacity:0;transition:opacity .8s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow-y:auto}.final-report.visible{opacity:1}.final-report.fade-out{opacity:0;pointer-events:none}.final-report-content{max-width:600px;width:90%;padding:60px 0 40px}.fr-section{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease;margin-bottom:28px}.fr-section.visible{opacity:1;transform:translateY(0)}.fr-header{text-align:center;margin-bottom:36px}.fr-title{font-size:28px;font-weight:600;color:var(--red);letter-spacing:6px;text-transform:uppercase;margin-bottom:8px}.fr-subtitle{font-size:12px;color:var(--text-dim);letter-spacing:2px}.fr-metrics{display:flex;justify-content:space-between;gap:12px}.fr-metric{flex:1;text-align:center;background:#8b5cf614;border:1px solid var(--accent-dim);border-radius:8px;padding:14px 8px}.fr-metric-value{font-size:24px;font-weight:600;margin-bottom:4px}.fr-metric-label{font-size:9px;color:var(--text-dim);letter-spacing:1px;text-transform:uppercase}.fr-metric-sub{font-size:9px;color:var(--text-dim);margin-top:2px}.fr-section-title{font-size:11px;font-weight:600;color:var(--accent);letter-spacing:2px;margin-bottom:12px;text-transform:uppercase}.fr-stacked-bar{display:flex;width:100%;height:12px;border-radius:6px;overflow:hidden;margin-bottom:12px}.fr-bar-segment{height:100%;transition:width .6s ease}.fr-death-legend{display:flex;gap:20px;flex-wrap:wrap}.fr-legend-item{font-size:11px;color:var(--text);display:flex;align-items:center;gap:6px}.fr-legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.fr-graph canvas{width:100%;height:150px;border-radius:6px;border:1px solid var(--accent-dim);display:block}.fr-trait-legend{display:flex;gap:16px;justify-content:center;margin-top:8px;font-size:10px;font-family:var(--font);letter-spacing:.5px}.fr-trait-legend-item{opacity:.8}.fr-analysis-text{font-size:13px;color:var(--text);line-height:1.7;padding:14px 16px;background:#8b5cf60f;border-left:3px solid var(--accent);border-radius:0 6px 6px 0}.fr-recommendations-list{display:flex;flex-direction:column;gap:8px}.fr-recommendation{font-size:12px;color:var(--text);padding:10px 14px;background:#00ffcc0f;border:1px solid rgba(0,255,204,.15);border-radius:6px}.fr-recommendation:before{content:"> ";color:var(--cyan);font-weight:600}.fr-dynasty-grid{display:flex;gap:12px;flex-wrap:wrap}.fr-dynasty-item{flex:1;min-width:120px;text-align:center;background:#8b5cf60f;border:1px solid var(--accent-dim);border-radius:8px;padding:12px 8px}.fr-dynasty-label{display:block;font-size:9px;color:var(--text-dim);letter-spacing:1px;text-transform:uppercase;margin-bottom:6px}.fr-dynasty-value{display:block;font-size:18px;font-weight:600;margin-bottom:2px}.fr-dynasty-sub{display:block;font-size:9px;color:var(--text-dim)}.inspector-parents{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.god-power-toolbar{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:8px;z-index:15;padding:8px 12px;background:var(--bg-panel);border:1px solid var(--accent-dim);border-radius:10px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:auto}.god-power-btn{position:relative;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 12px;min-width:44px;min-height:44px;background:#8b5cf614;border:1px solid rgba(139,92,246,.2);color:var(--text-dim);border-radius:8px;cursor:pointer;font-family:var(--font);font-size:8px;letter-spacing:.5px;transition:background .2s,border-color .2s,color .2s;overflow:hidden}.god-power-btn svg{transition:color .2s}.god-power-btn:hover,.god-power-btn:active{background:#8b5cf633;border-color:var(--accent);color:var(--text)}.god-power-btn.active{background:#8b5cf64d;border-color:var(--accent);color:var(--accent);box-shadow:0 0 10px #8b5cf64d}.god-power-btn.on-cooldown{opacity:.5;cursor:not-allowed}.god-power-label{font-size:8px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.god-power-cooldown-overlay{position:absolute;bottom:0;left:0;right:0;height:0%;background:#05051099;pointer-events:none;display:none;transition:height .3s ease}body.god-power-active canvas{cursor:crosshair!important}body.god-power-heal canvas{cursor:pointer!important}.fr-actions{text-align:center;margin-top:36px}.fr-try-again-btn{padding:14px 48px;min-height:48px;background:#8b5cf626;border:2px solid var(--accent);color:var(--accent);font-family:var(--font);font-size:14px;font-weight:600;letter-spacing:4px;cursor:pointer;border-radius:6px;transition:background .3s,transform .2s,box-shadow .3s}.fr-try-again-btn:hover,.fr-try-again-btn:active{background:#8b5cf64d;transform:scale(1.03);box-shadow:0 0 20px #8b5cf64d}.lg-toggle-btn{position:absolute;bottom:16px;right:16px;z-index:20;padding:10px 16px;min-height:40px;background:var(--bg-panel);border:1px solid var(--accent-dim);color:var(--accent);font-family:var(--font);font-size:10px;font-weight:600;letter-spacing:2px;cursor:pointer;border-radius:6px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background .2s,border-color .2s}.lg-toggle-btn:hover,.lg-toggle-btn:active{background:#8b5cf640;border-color:var(--accent)}.lg-panel{position:absolute;bottom:48px;right:16px;z-index:21;width:320px;max-height:0;overflow:hidden;background:var(--bg-panel-solid);border:1px solid var(--accent-dim);border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);opacity:0;transform:translateY(10px);transition:max-height .35s ease,opacity .3s ease,transform .3s ease}.lg-panel.open{max-height:70vh;opacity:1;transform:translateY(0);overflow-y:auto}.lg-panel-inner{padding:14px 16px}.lg-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.lg-panel-title{font-size:12px;font-weight:600;color:var(--accent);letter-spacing:2px;text-transform:uppercase}.lg-close-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:18px;padding:8px;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;line-height:1}.lg-close-btn:hover,.lg-close-btn:active{color:var(--red)}.lg-section{margin-bottom:14px}.lg-section:last-child{margin-bottom:0}.lg-section-title{font-size:9px;font-weight:600;color:var(--accent);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid var(--accent-dim)}.lg-entry{display:flex;gap:10px;margin-bottom:6px;font-size:10px;line-height:1.5}.lg-entry-name{color:var(--text);font-weight:500;min-width:80px;flex-shrink:0}.lg-entry-desc{color:var(--text-dim)}.lg-state-dot{width:6px;height:6px;border-radius:50%;display:inline-block;flex-shrink:0;margin-top:5px}.lg-entry-state{display:flex;gap:8px;align-items:flex-start;margin-bottom:5px;font-size:10px}.lg-entry-state .lg-entry-name{min-width:70px}.lg-panel::-webkit-scrollbar{width:4px}.lg-panel::-webkit-scrollbar-track{background:transparent}.lg-panel::-webkit-scrollbar-thumb{background:var(--accent-dim);border-radius:2px}.final-report::-webkit-scrollbar{width:6px}.final-report::-webkit-scrollbar-track{background:transparent}.final-report::-webkit-scrollbar-thumb{background:var(--accent-dim);border-radius:3px}.mobile-tab-bar,.mobile-scrim{display:none}@media(max-width:1024px){.setup-layout{grid-template-columns:1fr 1fr;grid-template-areas:"header header" "guide  story" "config config";gap:16px;max-width:700px}.setup-content{max-width:400px;margin:0 auto}.setup-info-card{max-height:50vh}}@media(max-width:768px){.mobile-tab-bar{position:fixed;bottom:0;left:0;right:0;height:calc(56px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:#050510f2;border-top:1px solid var(--accent-dim);display:flex;justify-content:space-around;align-items:center;z-index:30;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:auto}.tab-btn{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;color:var(--text-dim);font-family:var(--font);font-size:9px;letter-spacing:.5px;cursor:pointer;padding:6px 12px;transition:color .2s}.tab-btn.active{color:var(--accent)}.tab-btn svg{opacity:.6;transition:opacity .2s}.tab-btn.active svg{opacity:1;stroke:var(--accent)}.mobile-scrim{display:block;position:fixed;top:0;left:0;right:0;bottom:calc(56px + env(safe-area-inset-bottom,0px));background:#0006;z-index:24;pointer-events:auto}.stats-panel{top:calc(8px + env(safe-area-inset-top,0px));left:calc(8px + env(safe-area-inset-left,0px));right:calc(8px + env(safe-area-inset-right,0px));min-width:unset;max-height:unset;padding:6px 10px;border-radius:6px}.stats-panel .panel-header{display:none}.stats-panel .stats-grid{flex-direction:row;flex-wrap:wrap;gap:0 12px}.stats-panel .stat-row:nth-child(n+3),.stats-panel .stat-row.sub,.stats-panel .stat-divider,.stats-panel .stat-bar-wrap{display:none}.stats-panel .stat-row{font-size:10px;gap:4px}.stats-panel.mobile-sheet-open{position:fixed;top:unset;left:0;right:0;bottom:calc(56px + env(safe-area-inset-bottom,0px));max-height:50dvh;overflow-y:auto;border-radius:12px 12px 0 0;padding:12px 16px;z-index:25;background:var(--bg-panel-solid)}.stats-panel.mobile-sheet-open .panel-header{display:block}.stats-panel.mobile-sheet-open .stats-grid{flex-direction:column;flex-wrap:nowrap;gap:3px}.stats-panel.mobile-sheet-open .stat-row:nth-child(n+3),.stats-panel.mobile-sheet-open .stat-row.sub,.stats-panel.mobile-sheet-open .stat-divider,.stats-panel.mobile-sheet-open .stat-bar-wrap{display:flex}.stats-panel.mobile-sheet-open .stat-divider{display:block}.control-panel{display:none}.control-panel.mobile-sheet-open{display:block;position:fixed;top:unset;left:0;right:0;bottom:calc(56px + env(safe-area-inset-bottom,0px));max-height:50dvh;overflow-y:auto;border-radius:12px 12px 0 0;min-width:unset;z-index:25;background:var(--bg-panel-solid)}.control-panel.mobile-sheet-open .toggle-btn{display:none}.control-panel.mobile-sheet-open .control-content{display:block!important}.graph-panel{display:none}.graph-panel.mobile-sheet-open{display:block;position:fixed;top:unset;left:0;right:0;bottom:calc(56px + env(safe-area-inset-bottom,0px));max-height:50dvh;overflow-y:auto;border-radius:12px 12px 0 0;z-index:25;background:var(--bg-panel-solid)}.graph-panel.mobile-sheet-open canvas{width:100%}.inspector-panel{position:fixed;top:unset;left:0;right:0;bottom:calc(56px + env(safe-area-inset-bottom,0px));max-height:50dvh;overflow-y:auto;border-radius:12px 12px 0 0;min-width:unset;z-index:26;background:var(--bg-panel-solid)}.lg-toggle-btn{display:none}.lg-panel.mobile-sheet-open{position:fixed;top:unset;left:0;right:0;bottom:calc(56px + env(safe-area-inset-bottom,0px));width:100%;max-height:50dvh;overflow-y:auto;border-radius:12px 12px 0 0;opacity:1;transform:translateY(0);z-index:25;background:var(--bg-panel-solid)}.help-text{display:none}.fps-counter{top:4px;font-size:9px}.ui-hide-btn{top:unset;bottom:calc(64px + env(safe-area-inset-bottom,0px));left:calc(6px + env(safe-area-inset-left,0px));transform:none;min-width:36px;min-height:36px}.god-power-toolbar{bottom:calc(64px + env(safe-area-inset-bottom,0px));padding:6px 8px;gap:6px}.god-power-btn{padding:8px 10px;min-width:44px;min-height:44px}.god-power-btn svg{width:18px;height:18px}.god-power-label{font-size:7px}.slider-row input[type=range]::-webkit-slider-thumb{width:22px;height:22px}.slider-row input[type=range]::-moz-range-thumb{width:22px;height:22px}.tab-btn{min-width:44px;min-height:44px;padding:6px 8px}.loading-content{display:flex;flex-direction:column;align-items:center;text-align:center}.loading-title{font-size:20px;letter-spacing:5px}#loading-video{width:200px;height:200px}.loading-bar-container{width:200px;margin-left:auto;margin-right:auto}.mobile-disclaimer{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;font-family:var(--font);font-size:10px;color:#ffffffb3;background:#8b5cf61f;border:1px solid rgba(139,92,246,.25);border-radius:8px;padding:10px 16px;margin:0 auto 16px;max-width:240px;line-height:1.5;text-align:center;letter-spacing:.5px}.mobile-disclaimer .md-icon{font-size:14px;opacity:.6}.mobile-disclaimer .md-divider{width:40px;height:1px;background:#ffffff1a}.mobile-disclaimer #md-sound-hint{color:var(--cyan);font-size:9px;letter-spacing:1px;text-transform:uppercase;animation:loadingPulse 2s ease-in-out infinite}.mobile-disclaimer.sound-enabled #md-sound-hint{color:#34d399cc;animation:none}.setup-screen{padding:20px 12px}.setup-layout{grid-template-columns:1fr;grid-template-areas:"header" "config" "guide" "story";gap:16px}.setup-title{font-size:22px;letter-spacing:5px}.setup-content{max-width:100%}.setup-map-grid{flex-wrap:wrap;gap:8px}.setup-map-card{flex:0 0 calc(33% - 6px);padding:6px}.setup-map-thumb{height:50px}.setup-map-name{font-size:10px}.setup-map-desc{font-size:9px}.setup-info-card{max-height:none;overflow-y:visible}.setup-info-card.mobile-collapsed .setup-card-body{display:none}.setup-card-header{cursor:pointer;min-height:48px}.setup-card-header:after{content:"▼";font-size:10px;color:var(--text-dim);margin-left:auto;transition:transform .3s}.setup-info-card.mobile-collapsed .setup-card-header:after{transform:rotate(-90deg)}.slider-row{font-size:11px}.slider-row label{min-width:75px}.toggle-row{font-size:11px;min-height:36px}.god-power-label{font-size:8px}.control-section-header{font-size:10px}.inspector-row{font-size:12px}.inspector-section-label{font-size:10px}.ctrl-btn{padding:10px 8px;min-height:44px;font-size:11px}.achieve-btn{min-width:44px;min-height:44px}.overlay-radio-btn{min-height:40px;font-size:10px;padding:8px 4px}.toggle-row input[type=checkbox]{width:22px;height:22px}.fr-metrics{flex-wrap:wrap}.fr-metric{flex-basis:45%}.fr-title{font-size:20px;letter-spacing:4px}}.event-banner{position:fixed;top:60px;left:50%;transform:translate(-50%);z-index:50;background:var(--bg-panel-solid);border:1px solid var(--accent-dim);border-radius:8px;padding:10px 20px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-family:JetBrains Mono,monospace;font-size:13px;color:var(--text);display:flex;align-items:center;gap:10px;max-width:400px;pointer-events:auto;animation:bannerSlideIn .3s ease-out;transition:top .3s ease}.event-banner.dismissing{animation:bannerSlideOut .3s ease-in forwards}.event-banner-icon{font-size:20px}.event-banner-text{flex:1}.event-banner-name{font-weight:600;color:var(--cyan);font-size:12px;letter-spacing:1px;text-transform:uppercase}.event-banner-desc{font-size:10px;color:var(--text-dim);margin-top:2px}@keyframes bannerSlideIn{0%{transform:translate(-50%) translateY(-20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@keyframes bannerSlideOut{0%{transform:translate(-50%) translateY(0);opacity:1}to{transform:translate(-50%) translateY(-20px);opacity:0}}@media(max-width:768px){.event-banner{max-width:90%;font-size:11px;padding:8px 14px;top:40px}}.overlay-radio-group{display:flex;gap:4px;margin-bottom:8px}.overlay-radio-btn{flex:1;padding:6px 4px;min-height:32px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-dim);border-radius:4px;font-family:JetBrains Mono,monospace;font-size:9px;cursor:pointer;transition:background .2s,border-color .2s,color .2s;letter-spacing:.5px}.overlay-radio-btn:hover,.overlay-radio-btn:active{background:#8b5cf626;border-color:var(--accent-dim)}.overlay-radio-btn.active{background:#8b5cf640;border-color:var(--accent);color:var(--accent)}.dynasty-leaderboard{display:flex;flex-direction:column;gap:3px;padding:2px 0}.dynasty-entry{display:flex;align-items:center;gap:6px;font-size:.7rem}.dynasty-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.dynasty-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.dynasty-count{color:var(--cyan);font-weight:600;min-width:20px;text-align:right}.inspector-tree{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px}.tree-level{display:flex;flex-wrap:wrap;gap:4px;justify-content:center}.tree-arrow{color:var(--text-dim);font-size:.7rem;line-height:1}.tree-node{display:inline-flex;align-items:center;gap:3px;font-size:.65rem;padding:2px 6px;border-radius:4px;background:#ffffff0f;color:var(--text);white-space:nowrap}.tree-node.dead{opacity:.4}.tree-self-node{background:#8b5cf633;border:1px solid var(--accent-dim);color:var(--accent);font-weight:600}.tree-parent .dynasty-dot,.tree-child .dynasty-dot,.tree-self-node .dynasty-dot,.panel-header-small .dynasty-dot{width:7px;height:7px}.achievement-toast-container{position:fixed;top:16px;right:16px;z-index:60;display:flex;flex-direction:column;gap:8px;pointer-events:none}.achievement-toast{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--bg-panel-solid);border:1px solid var(--cyan);border-radius:8px;box-shadow:0 0 15px #00ffcc4d,inset 0 0 8px #00ffcc0d;transform:translate(120%);opacity:0;transition:transform .4s ease,opacity .4s ease;pointer-events:auto}.achievement-toast.show{transform:translate(0);opacity:1}.achievement-toast.hide{transform:translate(120%);opacity:0}.achievement-toast-icon{font-size:1.5rem;flex-shrink:0}.achievement-toast-label{font-size:.65rem;color:var(--cyan);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.achievement-toast-name{font-size:.8rem;color:var(--text);font-weight:600}.achievement-panel-overlay{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.achievement-panel{width:90%;max-width:600px;max-height:80vh;background:var(--bg-panel-solid);border:1px solid var(--accent-dim);border-radius:12px;overflow:hidden;display:flex;flex-direction:column}.achievement-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:#8b5cf61a;border-bottom:1px solid var(--accent-dim);font-size:.85rem;font-weight:600;color:var(--accent);letter-spacing:.05em}.achievement-close-btn{background:none;border:none;color:var(--text-dim);font-size:1.4rem;cursor:pointer;padding:8px;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;line-height:1}.achievement-close-btn:hover,.achievement-close-btn:active{color:var(--text)}.achievement-panel-body{padding:12px 18px 18px;overflow-y:auto}.achievement-category-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin:14px 0 6px;font-weight:600}.achievement-category-label:first-child{margin-top:0}.achievement-grid{display:flex;flex-direction:column;gap:6px}.achievement-card{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:6px;border:1px solid rgba(255,255,255,.06);background:#ffffff08;transition:background .2s}.achievement-card.unlocked{background:#00ffcc0f;border-color:#0fc3}.achievement-card.persistent{background:#8b5cf60f;border-color:#8b5cf626}.achievement-card.locked{opacity:.45}.achievement-card-icon{font-size:1.3rem;flex-shrink:0;width:28px;text-align:center}.achievement-card-info{flex:1;min-width:0}.achievement-card-name{font-size:.75rem;font-weight:600;color:var(--text)}.achievement-card-desc{font-size:.7rem;color:var(--text-dim);margin-top:1px}.achievement-card-check{color:var(--cyan);font-size:1rem;font-weight:700}.achievement-card-star{color:var(--accent);font-size:.9rem}.achieve-btn{font-size:.9rem;min-width:36px;min-height:36px}.fr-achievement-list{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:8px}.fr-achievement-item{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#00ffcc0f;border:1px solid rgba(0,255,204,.2);border-radius:6px}.fr-achievement-icon{font-size:1.2rem}.fr-achievement-name{font-size:.75rem;font-weight:600;color:var(--cyan)}button,input,.tab-btn,.god-power-btn,.setup-map-card,.overlay-radio-btn{touch-action:manipulation}button:focus-visible,input:focus-visible,.tab-btn:focus-visible,.god-power-btn:focus-visible,.ctrl-btn:focus-visible,.overlay-radio-btn:focus-visible,.setup-map-card:focus-visible,.setup-start-btn:focus-visible,.fr-try-again-btn:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}.stats-panel,.control-panel,.lg-panel,.final-report,.achievement-panel-body{scrollbar-width:thin;scrollbar-color:var(--accent-dim) transparent}.slider-row input[type=range]::-moz-range-track{background:#ffffff1a;border-radius:2px;height:3px}.setup-slider-row input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid rgba(255,255,255,.2)}.setup-slider-row input[type=range]::-moz-range-track{background:#ffffff1a;border-radius:2px;height:4px}@media(max-width:768px){.achievement-toast-container{right:8px;top:8px;left:8px}.achievement-toast{padding:8px 12px}.achievement-panel{width:95%;max-height:85dvh}}
