:root{--ink-black: #010b13;--teal: #008080;--tropical-mint: #50ffb1;--almond-silk: #d0b8ac;--seashell: #fdede4;--bg-dark: #000408;--bg-panel: var(--ink-black);--bg-panel-hover: #081420;--border-light: hsla(20, 28%, 75%, .12);--border-active: hsla(180, 100%, 25%, .5);--accent-blue: var(--teal);--accent-green: var(--tropical-mint);--accent-yellow: var(--almond-silk);--accent-red: hsl(355, 80%, 58%);--accent-purple: var(--almond-silk);--text-primary: var(--seashell);--text-secondary: var(--almond-silk);--text-muted: hsla(20, 28%, 75%, .55);--panel-radius: 16px;--transition-speed: .25s}*{box-sizing:border-box;margin:0;padding:0;font-family:Inter,sans-serif;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.25)}::-webkit-scrollbar-thumb:active{background:rgba(255,255,255,.4)}*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.12) transparent}body,html{width:100%;height:100%;overflow:hidden;background-color:var(--bg-dark);color:var(--text-primary)}#renderCanvas{width:100%;height:100%;display:block;outline:none}.glass{background:var(--bg-panel);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border:1px solid var(--border-light);border-radius:var(--panel-radius);box-shadow:0 8px 32px #0006;transition:border-color var(--transition-speed),transform var(--transition-speed)}.glass:hover{border-color:#ffffff26}.hidden{display:none!important}.game-ui{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1000;pointer-events:none;display:grid;grid-template-rows:60px 1fr 80px;grid-template-columns:280px 1fr 340px;padding:0 20px 20px;gap:20px}.game-ui.hidden{opacity:0;pointer-events:none;transform:scale(.98);transition:opacity .5s ease,transform .5s ease}.top-bar,.left-panel,.right-panel,.bottom-bar{pointer-events:auto}@keyframes pulse{0%,to{opacity:.9;transform:scale(1);filter:drop-shadow(0 0 4px hsla(210,100%,60%,.3))}50%{opacity:1;transform:scale(1.05);filter:drop-shadow(0 0 10px hsla(210,100%,60%,.6))}}@keyframes floatUp{0%{transform:translateY(0);opacity:0}20%{opacity:1}80%{opacity:1}to{transform:translateY(-10px);opacity:0}}.floating-cost{position:fixed;z-index:9999;pointer-events:none;font-family:Outfit,sans-serif;font-weight:700;font-size:1rem;color:#ef6c77;text-shadow:0 1px 4px rgba(0,0,0,.8),0 0 12px hsla(355,80%,58%,.5);white-space:nowrap;transform:translateY(0);opacity:1;transition:transform 1s cubic-bezier(.2,.8,.3,1),opacity .9s ease;transform-origin:center bottom;translate:-50% 0}.placement-warning-tooltip{position:fixed;background:hsla(220,25%,8%,.85);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--accent-red);border-radius:8px;padding:8px 12px;color:var(--text-primary);font-family:Inter,sans-serif;font-size:.8rem;font-weight:500;box-shadow:0 4px 16px #00000080;pointer-events:none;z-index:10000;display:flex;flex-direction:column;gap:4px;max-width:260px;transition:opacity .1s ease;opacity:0}.placement-warning-tooltip.show{opacity:1}.placement-warning-tooltip .tooltip-title{color:var(--accent-red);font-family:Outfit,sans-serif;font-weight:700;font-size:.85rem;margin-bottom:2px;text-transform:uppercase;letter-spacing:.5px}.placement-warning-tooltip .reason-item{display:flex;align-items:flex-start;gap:6px;line-height:1.3}.placement-warning-tooltip .reason-bullet{color:var(--accent-red);flex-shrink:0;font-weight:700}.fps-counter{position:fixed;bottom:20px;left:20px;z-index:10000;padding:8px 14px;font-size:.8rem;font-weight:600;color:var(--text-primary);border-radius:8px;letter-spacing:.05em;font-family:Inter,sans-serif;pointer-events:none}.margin-top-0{margin-top:0!important}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-dark);display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1007;transition:opacity .6s ease}.loading-overlay.fade-out{opacity:0;pointer-events:none}.loader{width:48px;height:48px;border:4px solid var(--border-light);border-top-color:var(--accent-blue);border-radius:50%;animation:spin 1s infinite linear;margin-bottom:24px}.loading-overlay h1{font-family:Outfit,sans-serif;font-weight:800;font-size:2.5rem;letter-spacing:2px;background:linear-gradient(135deg,#fff 0%,var(--accent-blue) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:8px}.loading-overlay p{color:var(--text-secondary);font-size:.95rem;letter-spacing:.5px}.progress-bar-container{width:280px;height:6px;background:rgba(255,255,255,.08);border-radius:10px;overflow:hidden;margin-top:20px;border:1px solid rgba(255,255,255,.04)}.progress-bar-fill{width:0%;height:100%;background:linear-gradient(to right,var(--accent-blue),var(--accent-purple));border-radius:10px;transition:width .15s ease-out;box-shadow:0 0 10px #39f6}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.title-screen{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1005;display:flex;justify-content:center;align-items:center;background:radial-gradient(circle at center,rgba(15,23,42,.4) 0%,rgba(15,23,42,.95) 100%);transition:opacity .5s ease,visibility .5s}.title-screen.hidden{opacity:0;visibility:hidden;pointer-events:none}.title-card{width:440px;padding:40px;text-align:center;display:flex;flex-direction:column;gap:24px}.title-logo{font-family:Outfit,sans-serif;font-size:3.2rem;font-weight:800;letter-spacing:1.5px;background:linear-gradient(135deg,#fff 0%,var(--accent-blue) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 4px 20px rgba(0,0,0,.5)}.title-subtitle{font-size:.9rem;color:var(--text-secondary);letter-spacing:3px;text-transform:uppercase;margin-top:-12px}.menu-actions{display:flex;flex-direction:column;gap:12px;transition:all .3s ease}.menu-actions.hidden{display:none!important}.btn-title-action{background:rgba(255,255,255,.03);border:1px solid var(--border-light);color:var(--text-primary);padding:14px 20px;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%;outline:none}.btn-title-action:hover{background:rgba(255,255,255,.08);border-color:#fff3;transform:translateY(-2px)}.btn-title-action.primary{background:var(--accent-blue);border-color:var(--accent-blue);box-shadow:0 4px 14px #39f6}.btn-title-action.primary:hover{background:hsl(210,100%,65%)}.btn-title-action.secondary{background:transparent;color:var(--text-secondary)}.input-group{display:flex;flex-direction:column;gap:8px;text-align:left}.input-group label{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.input-group input{background:rgba(0,0,0,.3);border:1px solid var(--border-light);border-radius:8px;padding:12px;color:#fff;font-size:.95rem;outline:none;transition:border-color .2s}.input-group input:focus{border-color:var(--accent-blue)}.button-row{display:flex;gap:12px;margin-top:10px}.saves-list{max-height:240px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding-right:6px}.empty-saves{color:var(--text-muted);font-size:.9rem;padding:20px}.save-item{background:rgba(255,255,255,.02);border:1px solid var(--border-light);border-radius:8px;padding:12px 16px;text-align:left;cursor:pointer;transition:all .2s;display:flex;justify-content:space-between;align-items:center}.save-item:hover{background:rgba(255,255,255,.06);border-color:#ffffff26;transform:translate(4px)}.save-item-info{display:flex;flex-direction:column;gap:4px}.save-name{font-size:.95rem;font-weight:600;color:var(--text-primary)}.save-meta{font-size:.75rem;color:var(--text-muted)}.save-stats{text-align:right;display:flex;flex-direction:column;gap:4px}.save-level{font-size:.8rem;font-weight:600;color:var(--accent-blue)}.save-pop{font-size:.75rem;color:var(--text-secondary)}.save-difficulty{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 6px;border-radius:4px;display:inline-block;align-self:flex-end;margin-top:2px}.save-difficulty.easy{color:var(--accent-green);background:rgba(74,222,128,.12)}.save-difficulty.normal{color:var(--text-secondary);background:rgba(255,255,255,.06)}.save-difficulty.hard{color:var(--accent-red);background:rgba(248,113,113,.15)}.btn-delete-save{background:none;border:none;color:#ff4d4d;font-size:1.1rem;padding:8px;cursor:pointer;border-radius:4px;transition:background-color .2s,transform .1s;display:flex;align-items:center;justify-content:center}.btn-delete-save:hover{background:rgba(255,77,77,.15);transform:scale(1.1)}.btn-delete-save:active{transform:scale(.95)}.save-actions{display:flex;gap:4px;align-items:center}.btn-export-save-slot{background:none;border:none;color:#4d94ff;font-size:1.1rem;padding:8px;cursor:pointer;border-radius:4px;transition:background-color .2s,transform .1s;display:flex;align-items:center;justify-content:center}.btn-export-save-slot:hover{background:rgba(77,148,255,.15);transform:scale(1.1)}.btn-export-save-slot:active{transform:scale(.95)}.difficulty-group{margin:14px 0 4px;display:flex;flex-direction:column;gap:8px}.difficulty-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted)}.difficulty-options{display:flex;gap:8px}.difficulty-card{flex:1;position:relative;cursor:pointer;border-radius:10px;border:1.5px solid rgba(255,255,255,.07);background:rgba(255,255,255,.03);transition:all .2s ease;overflow:hidden}.difficulty-card input[type=radio]{position:absolute;opacity:0;width:0;height:0}.diff-card-content{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;text-align:center}.diff-icon{font-size:1.5rem;line-height:1}.diff-name{font-family:Outfit,sans-serif;font-weight:700;font-size:.85rem;color:var(--text-secondary);transition:color .2s}.diff-desc{font-size:.68rem;color:var(--text-muted);line-height:1.3;transition:color .2s}.difficulty-card:hover{border-color:#fff3;background:rgba(255,255,255,.06)}.difficulty-card:hover .diff-name{color:var(--text-primary)}.difficulty-card.selected{border-color:var(--accent-blue);background:hsla(210,100%,60%,.12);box-shadow:0 0 16px #39f3}.difficulty-card.selected .diff-name{color:var(--accent-blue)}.difficulty-card.selected .diff-desc{color:var(--text-secondary)}.level-select-group{margin:16px 0;text-align:left;border-top:1px solid var(--border-light);padding-top:14px}.level-select-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.level-select-label{font-family:Outfit,sans-serif;font-weight:600;font-size:.82rem;color:var(--text-secondary)}#starting-level-val{color:var(--accent-blue);font-weight:700;font-size:.95rem}.btn-small-action{background:rgba(59,130,246,.15);border:1px solid rgba(59,130,246,.3);color:var(--accent-blue);padding:4px 10px;border-radius:4px;font-size:.68rem;font-family:Outfit,sans-serif;font-weight:700;cursor:pointer;transition:all .2s ease}.btn-small-action:hover{background:var(--accent-blue);color:#fff;box-shadow:0 0 10px #3b82f666}.level-select-controls{margin-bottom:10px}.level-unlocks-container{display:block;margin-top:12px}.level-unlocks-container summary.unlocks-label{font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;cursor:pointer;-webkit-user-select:none;user-select:none;outline:none;transition:color .2s ease;margin-bottom:6px}.level-unlocks-container summary.unlocks-label:hover{color:var(--accent-blue)}.level-unlocks-list{max-height:120px;overflow-y:auto;font-size:.72rem;color:var(--text-secondary);background:rgba(0,0,0,.35);border:1px solid var(--border-light);padding:8px 12px 8px 26px;border-radius:6px;line-height:1.5;margin:4px 0 0}.level-unlocks-list li{margin-bottom:4px}.level-unlocks-list li:last-child{margin-bottom:0}.sandbox-settings-group{margin:16px 0;text-align:left;border-top:1px solid var(--border-light);padding-top:14px}.sandbox-group-label{font-family:Outfit,sans-serif;font-weight:600;font-size:.82rem;color:var(--text-secondary);display:block;margin-bottom:10px}.sandbox-options{display:flex;flex-direction:column;gap:8px}.sandbox-option-card{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.03);border:1px solid var(--border-light);border-radius:8px;padding:8px 12px;cursor:pointer;transition:all .2s ease}.sandbox-option-card:hover{background:rgba(255,255,255,.06);border-color:#ffffff26}.sandbox-option-card input[type=checkbox]{cursor:pointer;accent-color:var(--accent-blue);width:16px;height:16px}.sandbox-card-content{display:flex;align-items:center;gap:10px}.sandbox-icon{font-size:1.25rem}.sandbox-text{display:flex;flex-direction:column}.sandbox-name{font-size:.78rem;font-weight:600;color:var(--text-primary)}.sandbox-desc{font-size:.65rem;color:var(--text-muted)}.game-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1010;display:flex;justify-content:center;align-items:center;background:rgba(15,23,42,.7);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:opacity .3s ease,visibility .3s}.game-menu-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}.game-menu-card{width:320px;padding:30px;text-align:center;display:flex;flex-direction:column;gap:20px;border-radius:16px;border:1px solid var(--border-light)}.game-menu-title{font-family:Outfit,sans-serif;font-size:1.8rem;font-weight:700;color:var(--text-primary);margin-bottom:10px}.menu-button-list{display:flex;flex-direction:column;gap:12px}.btn-menu-action{background:rgba(255,255,255,.05);border:1px solid var(--border-light);color:var(--text-primary);padding:12px;font-size:.95rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s}.btn-menu-action:hover{background:rgba(255,255,255,.1);border-color:var(--accent-blue);transform:translateY(-2px)}.btn-menu-action.danger{color:#ff4d4d}.btn-menu-action.danger:hover{border-color:#ff4d4d;background:rgba(255,77,77,.1)}.water-paint-vignette{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;box-shadow:inset 0 0 45px #3b82f673;border:4px solid rgba(59,130,246,.5);z-index:9999;animation:vignette-pulse 2s infinite ease-in-out;transition:opacity .3s ease;opacity:0}.water-paint-vignette.active{opacity:1}@keyframes vignette-pulse{0%,to{box-shadow:inset 0 0 35px #3b82f659;border-color:#3b82f666}50%{box-shadow:inset 0 0 55px #3b82f699;border-color:#3b82f6bf}}.fire-paint-vignette{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;box-shadow:inset 0 0 45px #ef444473;border:4px solid rgba(239,68,68,.5);z-index:9999;animation:fire-vignette-pulse 2s infinite ease-in-out;transition:opacity .3s ease;opacity:0}.fire-paint-vignette.active{opacity:1}@keyframes fire-vignette-pulse{0%,to{box-shadow:inset 0 0 35px #ef444459;border-color:#ef444466}50%{box-shadow:inset 0 0 55px #ef444499;border-color:#ef4444bf}}.crime-paint-vignette{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;box-shadow:inset 0 0 45px #a855f773;border:4px solid rgba(168,85,247,.5);z-index:9999;animation:crime-vignette-pulse 2s infinite ease-in-out;transition:opacity .3s ease;opacity:0}.crime-paint-vignette.active{opacity:1}@keyframes crime-vignette-pulse{0%,to{box-shadow:inset 0 0 35px #a855f759;border-color:#a855f766}50%{box-shadow:inset 0 0 55px #a855f799;border-color:#a855f7bf}}.medical-paint-vignette{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;box-shadow:inset 0 0 45px #10b98173;border:4px solid rgba(16,185,129,.5);z-index:9999;animation:medical-vignette-pulse 2s infinite ease-in-out;transition:opacity .3s ease;opacity:0}.medical-paint-vignette.active{opacity:1}@keyframes medical-vignette-pulse{0%,to{box-shadow:inset 0 0 35px #10b98159;border-color:#10b98166}50%{box-shadow:inset 0 0 55px #10b98199;border-color:#10b981bf}}.starvation-paint-vignette{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;box-shadow:inset 0 0 45px #f9731673;border:4px solid rgba(249,115,22,.5);z-index:9999;animation:starvation-vignette-pulse 2s infinite ease-in-out;transition:opacity .3s ease;opacity:0}.starvation-paint-vignette.active{opacity:1}@keyframes starvation-vignette-pulse{0%,to{box-shadow:inset 0 0 35px #f9731659;border-color:#f9731666}50%{box-shadow:inset 0 0 55px #f9731699;border-color:#f97316bf}}.trash-paint-vignette{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;box-shadow:inset 0 0 45px #78716c73;border:4px solid rgba(120,113,108,.5);z-index:9999;animation:trash-vignette-pulse 2s infinite ease-in-out;transition:opacity .3s ease;opacity:0}.trash-paint-vignette.active{opacity:1}@keyframes trash-vignette-pulse{0%,to{box-shadow:inset 0 0 35px #78716c59;border-color:#78716c66}50%{box-shadow:inset 0 0 55px #78716c99;border-color:#78716cbf}}.maintenance-paint-vignette{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;box-shadow:inset 0 0 45px #eab30873;border:4px solid rgba(234,179,8,.5);z-index:9999;animation:maintenance-vignette-pulse 2s infinite ease-in-out;transition:opacity .3s ease;opacity:0}.maintenance-paint-vignette.active{opacity:1}@keyframes maintenance-vignette-pulse{0%,to{box-shadow:inset 0 0 35px #eab30859;border-color:#eab30866}50%{box-shadow:inset 0 0 55px #eab30899;border-color:#eab308bf}}.crash-paint-vignette{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;box-shadow:inset 0 0 45px #f43f5e73;border:4px solid rgba(244,63,94,.5);z-index:9999;animation:crash-vignette-pulse 2s infinite ease-in-out;transition:opacity .3s ease;opacity:0}.crash-paint-vignette.active{opacity:1}@keyframes crash-vignette-pulse{0%,to{box-shadow:inset 0 0 35px #f43f5e59;border-color:#f43f5e66}50%{box-shadow:inset 0 0 55px #f43f5e99;border-color:#f43f5ebf}}.starting-tier-slider{width:100%;cursor:pointer}.top-bar{position:absolute;top:0;left:0;width:100%;height:60px;border-radius:0;border-top:none;border-left:none;border-right:none;display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:1001}.brand{display:flex;align-items:center;gap:10px}.brand .logo{font-size:1.6rem;color:var(--accent-blue);text-shadow:0 0 10px hsla(210,100%,60%,.5);animation:pulse 2s infinite ease-in-out}.brand h1{font-family:Outfit,sans-serif;font-weight:700;font-size:1.35rem;letter-spacing:.5px;background:linear-gradient(to right,#fff,var(--text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.stats-container{display:flex;gap:16px}.stat-box{background:rgba(0,0,0,.2);border-radius:10px;padding:8px 14px;display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:500;position:relative;min-width:60px;border:1px solid rgba(255,255,255,.03)}.stat-box .icon{font-size:1.1rem}.stat-box .val{color:var(--text-primary);font-family:Outfit,sans-serif;font-weight:600}.stat-box .delta{position:absolute;bottom:-15px;right:10px;font-size:.75rem;font-weight:600;opacity:0;pointer-events:none}.stat-box .delta.animate{animation:floatUp 1.5s ease-out forwards}.delta.positive{color:var(--accent-green)}.delta.negative{color:var(--accent-red)}.progress-bar{width:50px;height:4px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden;margin-left:4px}.progress-bar .fill{height:100%;background:var(--accent-blue);border-radius:2px;transition:width .5s ease}#stat-power .progress-bar .fill{background:var(--accent-yellow)}#stat-water .progress-bar .fill{background:var(--accent-blue)}#stat-sewage .progress-bar .fill{background:var(--accent-purple)}.rci-indicator{display:flex;align-items:flex-end;gap:4px;height:36px;background:rgba(0,0,0,.3);padding:4px 6px;border-radius:6px;width:50px;border:1px solid rgba(255,255,255,.03);flex-shrink:0;position:relative}.rci-bar{width:10px;border-radius:2px 2px 0 0;transition:height .5s ease;position:relative;min-height:2px}.rci-bar.res{background:var(--accent-green)}.rci-bar.com{background:var(--accent-blue)}.rci-bar.ind{background:var(--accent-yellow)}.rci-bar .label{display:none}.time-controls{display:flex;align-items:center;gap:16px}.date-display{font-family:Outfit,sans-serif;font-weight:600;font-size:.95rem;color:var(--text-primary);min-width:90px;text-align:right;letter-spacing:.5px}.btn-group{background:rgba(0,0,0,.25);border-radius:8px;padding:3px;display:flex;gap:2px}.btn-speed{background:transparent;border:none;color:var(--text-muted);width:28px;height:28px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:all .2s ease}.btn-speed:hover{color:var(--text-primary);background:rgba(255,255,255,.05)}.btn-speed.active{color:var(--text-primary);background:var(--accent-blue);box-shadow:0 2px 8px #3399ff4d}#stat-level{min-width:140px;display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:6px 12px}#stat-level .icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:1.2rem;opacity:.3}.level-info{display:flex;flex-direction:column;line-height:1.1}.level-info .val{font-size:.9rem;font-weight:700;color:var(--accent-yellow)}.level-info .sub{font-size:.72rem;color:var(--text-secondary);font-weight:500}#level-progress-bar{width:100%;height:3px;background:rgba(255,255,255,.1);border-radius:1.5px;overflow:hidden;margin-left:0}#level-progress-fill{background:var(--accent-yellow);height:100%}.header-dropdown{position:absolute;top:52px;left:50%;transform:translate(-50%) translateY(-10px);background:rgba(15,23,42,.85);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 16px;min-width:210px;box-shadow:0 12px 30px #0009;z-index:1002;opacity:0;visibility:hidden;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;gap:8px;pointer-events:none;text-align:left}.stat-box:hover .header-dropdown,.rci-indicator:hover .header-dropdown{opacity:1;visibility:visible;transform:translate(-50%) translateY(0);pointer-events:auto}.dropdown-title{font-family:Outfit,sans-serif;font-size:.75rem;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:4px;margin-bottom:2px}.header-dropdown .dropdown-row{display:flex;justify-content:space-between;align-items:center;font-size:.78rem;line-height:1.4;color:var(--text-secondary)}.header-dropdown .dropdown-row.divider-row{border-top:1px solid rgba(255,255,255,.08);margin:3px 0;height:0}.header-dropdown .detail-label{color:var(--text-secondary)}.header-dropdown .detail-value{font-weight:600;color:var(--text-primary);font-family:Outfit,sans-serif}.header-dropdown .detail-value.positive{color:var(--accent-green)}.header-dropdown .detail-value.negative{color:var(--accent-red)}.dropdown-row-vertical{flex-direction:column;align-items:flex-start;gap:4px}.dropdown-label-bold{font-weight:700}.dropdown-value-highlight{font-size:.72rem;color:var(--accent-yellow);font-weight:500;white-space:normal;max-width:170px}.happiness-stat-val{font-size:2em;line-height:1}.header-dropdown-rci{min-width:220px!important}.brand-pointer{cursor:pointer}.left-panel{position:absolute;top:68px;left:0;width:280px;max-height:calc(100vh - 148px);display:flex;flex-direction:column;padding:20px 10px 20px 20px;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s ease;z-index:1000;pointer-events:auto}.left-panel-content{flex:1;overflow-y:auto;padding-right:10px;display:flex;flex-direction:column;gap:16px}.overlay-buttons{display:flex;flex-direction:column;gap:6px}.btn-overlay,.btn-grid-toggle{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);border-radius:6px;padding:8px 12px;color:var(--text-secondary);font-size:.82rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;text-align:left;transition:all .2s ease;width:100%}.btn-overlay:hover,.btn-grid-toggle:hover{background:rgba(255,255,255,.08);color:var(--text-primary);transform:translate(2px)}.btn-overlay.active,.btn-grid-toggle.active{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff;box-shadow:0 4px 12px #3399ff40}.left-panel.collapsed{transform:translate(calc(-100% - 4px));pointer-events:none}#left-panel-buttons{display:flex;flex-direction:row;gap:6px;align-items:center}#left-panel-buttons button{height:36px;padding:0 12px;background:rgba(255,255,255,.03);border:1px solid var(--border-light);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;flex-direction:row;align-items:center;gap:6px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s ease}#left-panel-buttons button span:first-child{font-size:1.1rem!important}#left-panel-buttons button span:last-child{font-size:.65rem!important;font-weight:700;letter-spacing:.5px}#left-panel-buttons button:hover{color:var(--text-primary);background:rgba(255,255,255,.08);border-color:#ffffff26}#left-panel-buttons button.active{color:var(--text-primary);background:var(--accent-blue);border-color:var(--accent-blue);box-shadow:0 2px 8px #3399ff59}.left-panel h3{font-family:Outfit,sans-serif;font-weight:600;font-size:.95rem;letter-spacing:.5px;color:var(--text-secondary);text-transform:uppercase}#citizens-panel{width:385px!important}#buildings-panel{width:auto!important;min-width:480px;max-width:90vw}.right-panel{grid-column:3;grid-row:2;display:flex;flex-direction:column;height:fit-content;overflow:hidden;max-height:calc(100vh - 180px);transition:transform .25s cubic-bezier(.4,0,.2,1),opacity .25s ease}.right-panel.hover-hidden{opacity:0!important;pointer-events:none!important;transform:translate(40px)!important;transition:opacity .2s ease,transform .2s ease!important}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border-light)}.panel-header h3{font-family:Outfit,sans-serif;font-weight:600;font-size:.9rem;letter-spacing:.5px}.btn-close{background:transparent;border:none;color:var(--text-muted);font-size:1.2rem;line-height:1;cursor:pointer;transition:color .2s}.btn-close:hover{color:var(--text-primary)}.panel-content{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:10px}.empty-state{display:flex;justify-content:center;align-items:center;height:100%;color:var(--text-muted);font-size:.8rem;text-align:center;padding:20px 10px}.info-section{display:flex;flex-direction:column;gap:6px}.info-section h4{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:2px}.info-grid{display:grid;grid-template-columns:auto 1fr;gap:4px 10px;font-size:.78rem}.info-grid .label{color:var(--text-secondary)}.info-grid .value{text-align:right;font-weight:500;color:var(--text-primary)}.citizen-list{display:flex;flex-direction:column;gap:4px}.citizen-item{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.04);border-radius:6px;padding:4px 8px;display:flex;align-items:center;justify-content:space-between;font-size:.72rem;cursor:pointer;transition:all .2s ease}.citizen-item:hover{background:rgba(255,255,255,.06);border-color:#ffffff1a;transform:translateY(-1px)}.citizen-status{font-size:.7rem;color:var(--text-muted)}.btn-submenu-item.locked,.btn-tool.locked,.btn-category.locked{display:none!important}.badge{padding:2px 6px;border-radius:4px;font-size:.75rem;font-weight:600}.badge.success{background:hsla(140,70%,48%,.15);color:var(--accent-green)}.badge.warning{background:hsla(45,90%,55%,.15);color:var(--accent-yellow)}.badge.danger{background:hsla(355,80%,58%,.15);color:var(--accent-red)}.badge.info{background:hsla(210,100%,60%,.15);color:var(--accent-blue)}.panel-divider{border:none;border-top:1px solid var(--border-light);margin:16px 0;width:100%}.city-stats-content{display:flex;flex-direction:column;gap:14px}.stats-section-group{display:flex;flex-direction:column;gap:8px}.stats-section-group h4{font-family:Outfit,sans-serif;font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px;display:flex;align-items:center;gap:6px}.stat-card{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.04);border-radius:8px;padding:10px 12px;display:flex;flex-direction:column;gap:6px;transition:all .2s ease}.stat-card:hover{background:rgba(255,255,255,.05);border-color:#ffffff1f;box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.stat-card.clickable{cursor:pointer}.stat-card-row{display:flex;justify-content:space-between;align-items:center;width:100%}.stat-label{font-size:.8rem;color:var(--text-secondary);font-weight:500}.stat-value{font-size:.82rem;color:var(--text-primary);font-weight:600;font-family:Outfit,sans-serif}.stat-progress-bar{width:100%;height:6px;background:rgba(255,255,255,.05);border-radius:3px;overflow:hidden}.stat-progress-bar .fill{height:100%;border-radius:3px;transition:width .5s ease}.stat-progress-bar .fill.power{background:linear-gradient(90deg,var(--accent-yellow) 0%,#ffdf5d 100%)}.stat-progress-bar .fill.water{background:linear-gradient(90deg,var(--accent-blue) 0%,#4facfe 100%)}.stat-progress-bar .fill.sewage{background:linear-gradient(90deg,var(--accent-purple) 0%,var(--accent-red) 100%)}.stat-dropdown-details{display:flex;flex-direction:column;gap:6px;background:rgba(0,0,0,.25);border-radius:6px;padding:8px 10px;margin-top:4px;border:1px solid rgba(255,255,255,.03);transition:all .25s ease}.stat-dropdown-details.hidden{display:none!important}.dropdown-row{display:flex;justify-content:space-between;font-size:.76rem;color:var(--text-muted)}.detail-label{color:var(--text-secondary)}.detail-value{font-weight:600;color:var(--text-primary)}.sound-toggle-container{margin-top:10px;border-top:1px solid var(--border-light);padding-top:16px}.btn-sound{background:rgba(255,255,255,.03);border:1px solid var(--border-light);color:var(--text-secondary);width:28px;height:28px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:all .2s ease}.btn-sound:hover{background:rgba(255,255,255,.08);color:var(--text-primary);border-color:#ffffff26}.bottom-bar{grid-column:1 / -1;grid-row:3;display:flex;justify-content:center;align-items:center;height:100%}.tool-belt{display:flex;align-items:center;gap:16px;background:var(--bg-panel);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--border-light);padding:8px 20px;border-radius:20px;box-shadow:0 12px 40px #00000080;pointer-events:auto}.tool-group{display:flex;flex-direction:column;align-items:center;gap:4px}.group-label{font-family:Outfit,sans-serif;font-size:.65rem;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:1px}.group-buttons{display:flex;gap:6px}.tool-group-separator{width:1px;height:48px;background:var(--border-light)}.btn-tool{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);border-radius:10px;height:52px;width:68px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;transition:all .25s cubic-bezier(.4,0,.2,1);color:var(--text-secondary)}.btn-tool:hover{background:rgba(255,255,255,.08);color:var(--text-primary);transform:translateY(-2px);border-color:#ffffff1f}.btn-tool.active{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue);box-shadow:0 4px 16px #3399ff73}.btn-tool .tool-icon{font-size:1.15rem}.btn-tool .tool-name{font-size:.65rem;font-weight:600;letter-spacing:.2px}.menu-category{position:relative;display:flex;flex-direction:column;align-items:center}.btn-category{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);border-radius:10px;height:52px;width:76px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;transition:all .25s cubic-bezier(.4,0,.2,1);color:var(--text-secondary)}.btn-category:hover{background:rgba(255,255,255,.08);color:var(--text-primary);transform:translateY(-2px);border-color:#ffffff1f}.btn-category .tool-icon{font-size:1.15rem}.btn-category .tool-name{font-size:.65rem;font-weight:600;letter-spacing:.2px}.submenu{position:absolute;bottom:68px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:4px;padding:8px;min-width:200px;z-index:1000;border:1px solid var(--border-light);box-shadow:0 10px 30px #00000080}.submenu.hidden{display:none!important}.btn-submenu-item{background:transparent;border:none;color:var(--text-secondary);padding:8px 12px;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:.8rem;font-weight:500;text-align:left;transition:all .2s;width:100%}.btn-submenu-item:hover{background:rgba(255,255,255,.08);color:var(--text-primary)}.btn-submenu-item.active{background:var(--accent-blue);color:#fff;box-shadow:0 2px 8px #3399ff59}.btn-submenu-item .tool-icon{font-size:1rem}.btn-submenu-item .tool-name{flex-grow:1}.btn-submenu-item .tool-cost{margin-left:auto;font-size:.72rem;color:var(--text-muted);font-family:Outfit,sans-serif;font-weight:600}.btn-submenu-item.active .tool-cost{color:#fffc}.rci-card{background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.03)}.rci-title{font-family:Outfit,sans-serif;font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:4px;margin-bottom:4px}.rci-progress-group{display:flex;flex-direction:column;gap:8px;margin-top:4px}.rci-progress-item{display:grid;grid-template-columns:36px 1fr 36px;align-items:center;gap:8px}.rci-label{font-size:.72rem;font-weight:700;text-transform:uppercase;text-align:left}.rci-label.res{color:var(--accent-green)}.rci-label.com{color:var(--accent-blue)}.rci-label.ind{color:var(--accent-yellow)}.rci-progress-track{height:6px;background:rgba(255,255,255,.05);border-radius:3px;overflow:hidden;position:relative}.rci-progress-fill{height:100%;border-radius:3px;transition:width .5s ease}.rci-progress-fill.res{background:var(--accent-green)}.rci-progress-fill.com{background:var(--accent-blue)}.rci-progress-fill.ind{background:var(--accent-yellow)}.rci-val{font-size:.72rem;font-weight:600;color:var(--text-primary);text-align:right}.elevation-control{display:flex;align-items:center;gap:8px;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.05);border-radius:10px;padding:4px 8px;height:52px}.btn-elevation{background:rgba(255,255,255,.03);border:1px solid var(--border-light);color:var(--text-secondary);width:28px;height:36px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.95rem;transition:all .2s ease}.btn-elevation:hover{background:rgba(255,255,255,.1);color:var(--text-primary);border-color:#ffffff26}.elevation-display{display:flex;flex-direction:column;align-items:center;min-width:44px}.elevation-label{font-size:.55rem;font-weight:700;color:var(--text-muted);letter-spacing:.5px}.elevation-val{font-family:Outfit,sans-serif;font-size:1rem;font-weight:700;color:var(--accent-blue);line-height:1.1}.elevation-control.hidden,.elevation-control-separator.hidden{display:none!important}.submenu-large-width{min-width:200px!important}.context-menu-container{position:absolute;z-index:999999;min-width:200px;padding:12px;box-shadow:0 8px 32px #00000080;border:1px solid var(--border-light);display:flex;flex-direction:column;gap:8px;pointer-events:auto}.context-menu-title-label{font-weight:700;font-size:.85rem;color:var(--text-primary)}.context-menu-status-label{font-size:.75rem;color:var(--text-muted)}.context-menu-button-item{width:100%;text-align:left;padding:6px 10px;font-size:.8rem;border-radius:6px;display:flex;align-items:center;gap:6px;cursor:pointer;background:rgba(255,255,255,.05);border:1px solid var(--border-light);color:var(--text-primary)}.context-menu-button-item:hover{background:rgba(255,255,255,.1);border-color:#fff3}.context-menu-button-item.build-sewage{background:rgba(0,255,200,.1);border:1px solid rgba(0,255,200,.25);color:var(--text-primary)}.context-menu-button-item.build-sewage:hover{background:rgba(0,255,200,.2)}.context-menu-button-item.build-water{background:rgba(0,180,255,.1);border:1px solid rgba(0,180,255,.25);color:var(--text-primary)}.context-menu-button-item.build-water:hover{background:rgba(0,180,255,.2)}.context-menu-button-item.build-power{background:rgba(255,220,0,.1);border:1px solid rgba(255,220,0,.25);color:var(--text-primary)}.context-menu-button-item.build-power:hover{background:rgba(255,220,0,.2)}.context-menu-button-item.demolish{background:rgba(255,77,77,.1);border:1px solid rgba(255,77,77,.2);color:#ff4d4d}.context-menu-button-item.demolish:hover{background:rgba(255,77,77,.2)}.context-menu-divider-item{height:1px;background:var(--border-light);margin:2px 0}.district-overlay-label{position:absolute;transform:translate(-50%,-50%);background:rgba(45,55,72,.85);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:8px 14px;color:#fff;font-family:Outfit,sans-serif;text-align:center;box-shadow:0 8px 24px #00000059;pointer-events:auto;cursor:pointer;-webkit-user-select:none;user-select:none;transition:opacity .25s ease,transform .22s ease,background-color .2s ease;white-space:nowrap;z-index:950}.district-overlay-label:hover{background:rgba(60,72,92,.95);border-color:#ffffff4d;transform:translate(-50%,-50%) scale(1.05)}body:has(#gameMenuModal:not(.hidden)) .district-overlay-label,body:has(#titleScreen:not(.hidden)) .district-overlay-label{display:none!important}.btn-sort{background:rgba(255,255,255,.05);border:1px solid var(--border-light);color:var(--text-secondary);padding:6px 12px;border-radius:6px;cursor:pointer;font-family:Inter,sans-serif;font-size:.75rem;font-weight:500;transition:all .15s ease}.btn-sort:hover{background:var(--bg-panel-hover);color:var(--text-primary)}.btn-sort.active{background:var(--accent);color:#fff;border-color:var(--accent)}.citizen-row{display:flex;flex-direction:column;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:10px 12px;cursor:pointer;transition:all .15s ease}.citizen-row:hover{background:rgba(255,255,255,.12);border-color:var(--accent);box-shadow:0 4px 12px #0003}.citizen-row-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.citizen-name{font-family:Outfit,sans-serif;font-weight:600;font-size:.88rem;color:var(--text-primary)}.citizen-age{font-size:.75rem;color:var(--text-muted)}.citizen-detail-row{display:flex;justify-content:space-between;font-size:.78rem;color:var(--text-secondary);margin-top:2px}.citizen-action{font-style:italic;color:var(--text-muted)}.citizen-location{font-weight:500;color:var(--accent)}#autosave-indicator{position:fixed;bottom:50px;right:50px;z-index:100000;display:flex;align-items:center;justify-content:center;width:88px;height:88px;background:rgba(15,15,20,.88);border:1px solid rgba(129,199,132,.25);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:50%;pointer-events:none;box-shadow:0 4px 18px #0009,0 0 24px #81c78426;opacity:0;transform:scale(.7) translateY(8px);transition:opacity .35s ease,transform .35s cubic-bezier(.34,1.56,.64,1)}#autosave-indicator.show{opacity:1!important;transform:scale(1) translateY(0)!important}.autosave-rings{position:relative;width:56px;height:56px}.autosave-ring{position:absolute;border-radius:50%;border-style:solid;border-color:transparent;top:50%;left:50%;transform-origin:center center}.autosave-ring-outer{width:56px;height:56px;margin-top:-28px;margin-left:-28px;border-width:3px;border-top-color:#81c784;border-right-color:#81c7844d;animation:autosave-spin-cw 1.1s linear infinite}.autosave-ring-mid{width:36px;height:36px;margin-top:-18px;margin-left:-18px;border-width:3px;border-bottom-color:#4fc3f7;border-left-color:#4fc3f74d;animation:autosave-spin-ccw .85s linear infinite}.autosave-ring-inner{width:16px;height:16px;margin-top:-8px;margin-left:-8px;border-width:2.5px;border-top-color:#ce93d8;border-right-color:#ce93d866;animation:autosave-spin-cw .65s linear infinite}.autosave-dot{position:absolute;width:6px;height:6px;border-radius:50%;background:#81c784;top:50%;left:50%;margin-top:-3px;margin-left:-3px;box-shadow:0 0 10px #81c784}@keyframes autosave-spin-cw{to{transform:rotate(360deg)}}@keyframes autosave-spin-ccw{to{transform:rotate(-360deg)}}.citizens-panel-content{display:flex;flex-direction:column;height:100%;box-sizing:border-box;overflow:hidden;padding-bottom:20px}.citizens-sorting-container{margin-bottom:12px;display:flex;gap:8px;font-size:.8rem;align-items:center;justify-content:center}.citizens-filters-container{margin-bottom:12px;display:flex;gap:8px;font-size:.8rem;align-items:center;justify-content:space-between}.filter-group{display:flex;flex-direction:column;flex:1;gap:4px;min-width:0}.filter-label{font-size:.65rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-select{width:100%;box-sizing:border-box;background:rgba(0,0,0,.4);border:1px solid var(--border-light);color:var(--text-secondary);padding:5px 8px;border-radius:6px;outline:none;cursor:pointer;text-overflow:ellipsis}.filter-select option{background:#1a1a20;color:#fff}.citizens-list-wrapper{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding-right:4px}.buildings-table{width:100%;border-collapse:collapse;font-size:.72rem;color:var(--text-primary);background:rgba(0,0,0,.25);border-radius:8px;overflow:hidden;border:1px solid var(--border-light)}.buildings-table th,.buildings-table td{padding:8px 10px;text-align:left;border-bottom:1px solid rgba(255,255,255,.05);white-space:nowrap}.buildings-table td:last-child{white-space:normal;word-break:break-word}.buildings-table th{background:rgba(0,0,0,.4);font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px}.buildings-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s ease,color .15s ease}.buildings-table th.sortable:hover{background:rgba(255,255,255,.1);color:var(--text-primary)}.buildings-table tr{cursor:pointer;transition:background .15s ease}.buildings-table tr:hover{background:rgba(255,255,255,.04)}.buildings-table tr:last-child td{border-bottom:none}.buildings-panel-content{display:flex;flex-direction:column;height:100%;box-sizing:border-box;overflow:hidden;padding-bottom:20px}.buildings-list-wrapper{flex:1;overflow:auto;padding-right:4px}#stats-panel{width:600px}.news-list-container{flex:1;overflow-y:auto;border-radius:8px;background:rgba(0,0,0,.25);border:1px solid var(--border-light);max-height:calc(100vh - 200px)}.news-table{width:100%;border-collapse:collapse;font-size:.72rem;color:var(--text-primary);text-align:left}.news-table th,.news-table td{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.05)}.news-table th{background:rgba(0,0,0,.4);font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;position:sticky;top:0;z-index:10;-webkit-user-select:none;user-select:none}.news-table th.sortable{cursor:pointer;transition:background .15s ease,color .15s ease}.news-table th.sortable:hover{background:rgba(255,255,255,.1);color:var(--text-primary)}.news-row{transition:background .15s ease}.news-row:hover{background:rgba(255,255,255,.03)}.news-table tr:last-child td{border-bottom:none}.news-table td.location{color:var(--text-muted);font-family:monospace;white-space:nowrap}.news-table td.location.clickable{color:var(--accent-green);cursor:pointer;font-weight:600;text-decoration:underline;text-decoration-style:dotted;transition:color .15s ease,background-color .15s ease,transform .1s ease}.news-table td.location.clickable:hover{color:#fff;background:rgba(80,255,177,.15);border-radius:4px}.news-table td.location.clickable:active{transform:scale(.95)}.counselor-card{width:380px!important;padding:24px!important}.counselor-header{display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border-light);padding-bottom:12px;margin-bottom:16px;position:relative}.counselor-avatar{font-size:2.2rem;background:rgba(255,255,255,.08);border-radius:50%;width:50px;height:50px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-light);box-shadow:0 4px 10px #0003}.counselor-meta{text-align:left}.counselor-meta h3{font-family:Outfit,sans-serif;margin:0;font-size:1.1rem;color:var(--text-primary)}.counselor-meta span{font-size:.72rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.counselor-body{position:relative;margin:10px 0}.counselor-bubble{background:rgba(255,255,255,.03);border:1px solid var(--border-light);border-radius:12px;padding:5px;font-size:.88rem;line-height:1.5;color:var(--text-secondary);position:relative;max-height:240px;overflow-y:auto;text-align:left}.counselor-bubble strong{color:var(--text-primary)}.btn-close-x{position:absolute;right:0;top:0;background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:4px;transition:color .15s ease}.btn-close-x:hover{color:var(--accent-red)}.budget-card{background:rgba(0,0,0,.2);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:12px;border:1px solid rgba(255,255,255,.03)}.tax-control-group{display:flex;flex-direction:column;gap:6px}.tax-slider-header{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;font-weight:500;color:var(--text-secondary)}.tax-value-label{font-weight:600;color:var(--accent-blue);font-family:Outfit,sans-serif}.tax-slider{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;border-radius:3px;background:rgba(255,255,255,.08);outline:none;cursor:pointer;transition:background .2s}.tax-slider:hover{background:rgba(255,255,255,.15)}.tax-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent-blue);box-shadow:0 0 8px #3399ff80;transition:transform .1s ease,background-color .1s ease}.tax-slider::-webkit-slider-thumb:hover{transform:scale(1.2);background:#a7ffeb}.tax-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent-blue);border:none;box-shadow:0 0 8px #3399ff80;transition:transform .1s ease,background-color .1s ease}.tax-slider::-moz-range-thumb:hover{transform:scale(1.2);background:#a7ffeb}.tax-effect-label{font-size:.72rem;margin-top:6px;padding:6px 10px;border-radius:6px;font-weight:500;line-height:1.4;text-align:left;transition:all .2s ease;min-height:32px;display:flex;align-items:center}.tax-effect-label.low{background:hsla(140,60%,50%,.12);border:1px solid hsla(140,60%,50%,.25);color:#8cf2ae}.tax-effect-label.neutral{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:var(--text-secondary)}.tax-effect-label.high{background:hsla(45,80%,50%,.12);border:1px solid hsla(45,80%,50%,.25);color:#f8d877}.tax-effect-label.extreme{background:hsla(355,80%,50%,.12);border:1px solid hsla(355,80%,50%,.25);color:#f9868f;animation:pulse-border 2s infinite}@keyframes pulse-border{0%{border-color:#e6192a40}50%{border-color:#e6192a99}to{border-color:#e6192a40}}.counselor-header-flex{border:none!important;padding-bottom:0!important;margin-bottom:12px!important;display:flex!important;align-items:center!important;gap:12px!important}.counselor-meta-align{text-align:left!important}.counselor-title-header{margin:0!important}.panel-divider-counselor{margin-top:4px!important;margin-bottom:12px!important}.budget-card-counselor{margin-bottom:16px!important}.counselor-bubble-advice{max-height:none!important;background:transparent!important;border:none!important}.settings-content{display:flex;flex-direction:column;gap:16px;width:100%;text-align:left}.settings-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.settings-row label{font-size:.9rem;font-weight:600;color:var(--text-secondary)}.settings-select{background:rgba(0,0,0,.4);color:#fff;border:1px solid var(--border-light);padding:8px 12px;border-radius:6px;font-family:inherit;font-size:.9rem;cursor:pointer;outline:none;width:150px;transition:border-color .2s}.settings-select:focus,.settings-select:hover{border-color:var(--accent-blue)}.settings-select option{background:var(--bg-dark);color:#fff}.settings-description{font-size:.78rem;color:var(--text-muted);line-height:1.45;background:rgba(0,0,0,.25);padding:12px;border-radius:8px;border:1px solid rgba(255,255,255,.03)}.settings-description strong{color:var(--text-secondary)}#districts-panel{width:auto!important;min-width:580px;max-width:90vw}.districts-table{width:100%;border-collapse:collapse;font-size:.72rem;color:var(--text-primary);background:rgba(0,0,0,.25);border-radius:8px;overflow:hidden;border:1px solid var(--border-light)}.districts-table th,.districts-table td{padding:8px 10px;text-align:left;border-bottom:1px solid rgba(255,255,255,.05);white-space:nowrap}.districts-table td:last-child{white-space:normal;word-break:break-word}.districts-table th{background:rgba(0,0,0,.4);font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px}.districts-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s ease,color .15s ease}.districts-table th.sortable:hover{background:rgba(255,255,255,.1);color:var(--text-primary)}.districts-row{cursor:pointer;transition:background .15s ease}.districts-row:hover{background:rgba(255,255,255,.04)}.districts-row.active-edit-row{background:rgba(0,128,128,.12)!important;border-left:4px solid var(--tropical-mint)!important}.districts-row:last-child td{border-bottom:none}.districts-panel-content{display:flex;flex-direction:column;height:100%;box-sizing:border-box;overflow:hidden;padding-bottom:20px}.districts-list-wrapper{flex:1;overflow:auto;padding-right:4px}.districts-table .btn-action{transition:background-color .15s ease,transform .1s ease}.districts-table .btn-action:hover{background-color:#ffffff1a!important;transform:scale(1.1);border-radius:4px}.districts-table .btn-action:active{transform:scale(.9)}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(4,8,16,.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:99999;display:flex;align-items:center;justify-content:center;transition:opacity .3s ease;pointer-events:auto}.tier-up-card{max-width:800px;width:90%;padding:30px;background:var(--bg-panel);border:1px solid var(--border-light);border-radius:20px;box-shadow:0 20px 50px #0009,0 0 40px #50ffb112;animation:modalScaleIn .4s cubic-bezier(.16,1,.3,1) forwards;display:flex;flex-direction:column;gap:24px}@keyframes modalScaleIn{0%{opacity:0;transform:scale(.94) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.tier-up-header{text-align:center}.tier-up-badge{display:inline-block;padding:4px 12px;background:linear-gradient(135deg,rgba(80,255,177,.2),rgba(0,128,128,.3));border:1px solid var(--accent-green);color:var(--accent-green);border-radius:20px;font-family:Outfit,sans-serif;font-weight:700;font-size:.75rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:12px;box-shadow:0 0 10px #50ffb126}.tier-up-header h1{font-family:Outfit,sans-serif;font-size:2.2rem;font-weight:800;margin-bottom:6px;background:linear-gradient(135deg,var(--seashell) 30%,var(--tropical-mint));-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.5px}.tier-up-header p{color:var(--text-secondary);font-size:1rem;font-weight:400}.tier-up-content{display:flex;flex-direction:row;gap:20px;align-items:stretch;min-height:250px}.tier-up-panel{flex:1;background:rgba(255,255,255,.015);border:1px solid rgba(255,255,255,.03);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:15px}.tier-up-panel h2{font-family:Outfit,sans-serif;font-size:1.15rem;font-weight:600;color:var(--text-primary);border-bottom:1px solid rgba(255,255,255,.06);padding-bottom:10px;margin-bottom:5px;display:flex;align-items:center;gap:8px}.tier-up-divider{width:1px;background:linear-gradient(to bottom,rgba(255,255,255,.01),rgba(255,255,255,.12),rgba(255,255,255,.01))}.unlocks-grid{display:grid;grid-template-columns:1fr;gap:10px;overflow-y:auto;max-height:220px;padding-right:5px}.unlock-item{display:flex;align-items:center;gap:12px;padding:8px 12px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.04);border-radius:10px;transition:background .2s,border-color .2s}.unlock-item:hover{background:rgba(80,255,177,.04);border-color:#50ffb126}.unlock-item .icon{font-size:1.35rem;background:rgba(255,255,255,.04);border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.unlock-info{display:flex;flex-direction:column}.unlock-name{font-weight:600;font-size:.85rem;color:var(--text-primary)}.unlock-desc{font-size:.72rem;color:var(--text-muted);line-height:1.2}.rules-list{display:flex;flex-direction:column;gap:10px;overflow-y:auto;max-height:220px;padding-right:5px}.rule-item{padding:10px 14px;background:rgba(80,255,177,.01);border:1px solid rgba(255,255,255,.03);border-left:3px solid var(--accent-blue);border-radius:8px;font-size:.82rem;line-height:1.45;color:var(--text-secondary)}.rule-item strong{color:var(--text-primary)}.rule-item.danger-rule{border-left-color:var(--accent-red);background:rgba(239,68,68,.01)}.rule-item.success-rule{border-left-color:var(--accent-green);background:rgba(80,255,177,.01)}.tier-up-footer{text-align:center;margin-top:10px}.btn-tier-up-action{padding:12px 35px;font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:700;background:linear-gradient(135deg,var(--teal),#50ffb1);color:var(--ink-black);border:none;border-radius:30px;cursor:pointer;box-shadow:0 4px 15px #50ffb140;transition:transform .2s,box-shadow .2s;outline:none}.btn-tier-up-action:hover{transform:translateY(-2px);box-shadow:0 6px 20px #50ffb166}.btn-tier-up-action:active{transform:translateY(0)}.boss-health-container{position:fixed;top:75px;left:50%;transform:translate(-50%);width:900px;max-width:90%;z-index:1000;display:flex;flex-direction:column;align-items:center;gap:8px;animation:bossFadeIn .8s cubic-bezier(.19,1,.22,1) forwards;pointer-events:none}.boss-health-container.hidden{display:none!important}.boss-title{font-family:Outfit,Cinzel,serif,sans-serif;font-size:2rem;font-weight:700;color:#f33;text-transform:uppercase;letter-spacing:.35em;text-shadow:0 0 15px rgba(255,51,51,.8),0 2px 4px rgba(0,0,0,.9);text-align:center;margin-bottom:4px;animation:bossTextGlow 2s ease-in-out infinite alternate}.boss-health-bar-track{width:100%;height:18px;background:rgba(10,10,12,.9);border:1px solid rgba(255,51,51,.4);box-shadow:0 0 20px #000000e6,inset 0 2px 4px #0009;border-radius:0;position:relative;overflow:hidden}.boss-health-bar-fill{height:100%;width:100%;background:linear-gradient(90deg,#800000 0%,#ff3333 50%,#800000 100%);box-shadow:0 0 16px #ff3333e6;transition:width .3s cubic-bezier(.1,.8,.1,1);position:relative}@keyframes bossFadeIn{0%{opacity:0;transform:translate(-50%,-20px)}to{opacity:1;transform:translate(-50%)}}@keyframes bossTextGlow{0%{text-shadow:0 0 10px rgba(255,51,51,.5),0 2px 4px rgba(0,0,0,.8)}to{text-shadow:0 0 22px rgba(255,51,51,.9),0 2px 6px rgba(0,0,0,.9)}}
