:root,[data-theme=dark]{--bg-primary:#0d1117;--bg-secondary:#111922;--bg-elevated:#16213e;--bg-sidebar:#0a0e17;--border-primary:#1e2a3a;--border-secondary:#2a2a4a;--border-hover:#3a3a5a;--text-primary:#e0e0e0;--text-secondary:#9ba8b5;--text-dim:#6a7a8a;--text-muted:#4a5a6a;--accent-green:#91cf60;--accent-green-bright:#66bb6a;--accent-orange:#ffa726;--accent-blue:#4fc3f7;--accent-red:#ef5350;--shadow-sm:0 2px 6px #0000004d;--shadow-md:0 6px 20px #00000040;--shadow-lg:0 8px 24px #0000004d;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--font-body:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, "Cascadia Code", "Fira Code", monospace;--shimmer-highlight:#1a2535}[data-theme=light]{--bg-primary:#f5f7fa;--bg-secondary:#fff;--bg-elevated:#e8ecf1;--bg-sidebar:#edf0f5;--border-primary:#d0d7de;--border-secondary:#c0c8d0;--border-hover:#a0a8b0;--text-primary:#1f2937;--text-secondary:#4b5563;--text-dim:#6b7280;--text-muted:#9ca3af;--accent-green:#22c55e;--accent-green-bright:#16a34a;--accent-orange:#f59e0b;--accent-blue:#3b82f6;--accent-red:#ef4444;--shadow-sm:0 1px 3px #0000001a;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 6px 16px #0000001a;--shimmer-highlight:#e0e5ea}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased}#root{flex-direction:column;width:100%;min-height:100vh;display:flex}.skip-to-content{background:var(--accent-blue);color:#fff;z-index:10000;border-radius:0 0 var(--radius-sm) 0;padding:.5rem 1rem;font-size:.85rem;text-decoration:none;transition:top .2s;position:absolute;top:-40px;left:0}.skip-to-content:focus{top:0}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{background:linear-gradient(90deg, var(--bg-secondary) 25%, var(--shimmer-highlight) 50%, var(--bg-secondary) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}@media (width<=768px){.app-header{padding:.5rem 1rem!important}.app-header h1{font-size:.9rem!important}.header-breadcrumb-sep,.header-breadcrumb-page,.subtitle{display:none}}.illustrated-map-container{-webkit-user-select:none;user-select:none;background:#ede8db;width:100%;height:100%;position:absolute;inset:0;overflow:hidden}.illustrated-map{transform-origin:50%;object-fit:cover;width:100%;height:100%;transition:transform 80ms ease-out}.sand-block{fill:url(#sand-grad);stroke:#d9b754;stroke-width:.6px;filter:url(#tile-shadow)}.sand-ripple{fill:none;stroke:#c8a240;stroke-width:.7px;stroke-linecap:round;opacity:.3}.sand-dot{fill:#c8a240;opacity:.2}.steppe-block{fill:#b8c9a0;stroke:#a3b58a;stroke-width:.4px}.steppe-grass{stroke:#6b8f4e;stroke-width:1.2px;stroke-linecap:round;opacity:.5}.tree-tile-anim{transform-origin:50% 100%;animation:5s ease-in-out infinite sway}@keyframes sway{0%,to{transform:rotate(-.6deg)}50%{transform:rotate(.6deg)}}.tree-ground{fill:#c5e1a5;stroke:#9ccc65;stroke-width:.6px;filter:url(#tile-shadow)}.water-block{fill:url(#water-grad);stroke:#1976d2;stroke-width:.6px;filter:url(#tile-shadow)}.water-flow-1{fill:none;stroke:#ffffff80;stroke-width:1.2px;stroke-linecap:round;stroke-dasharray:6 4;animation:2s linear infinite water-flow}.water-flow-2{fill:none;stroke:#ffffff4d;stroke-width:1px;stroke-linecap:round;stroke-dasharray:4 6;animation:2.5s linear infinite reverse water-flow}@keyframes water-flow{0%{stroke-dashoffset:0}to{stroke-dashoffset:-20px}}.water-sparkle{fill:#fffc;animation:3s ease-in-out infinite sparkle}@keyframes sparkle{0%,to{opacity:0;r:.5}50%{opacity:.8;r:1.5}}.rock-block{fill:url(#rock-grad);stroke:#6d4c41;stroke-width:.6px;filter:url(#tile-shadow)}.rock-peak{fill:#5d4037;stroke:#4e342e;stroke-width:.5px;stroke-linejoin:round}.rock-snow{fill:#fafafa;stroke:#e0e0e0;stroke-width:.4px}.hw-block{fill:#b0bec5;stroke:#90a4ae;stroke-width:.6px;filter:url(#tile-shadow)}.hw-stripe{stroke:#fafafa;stroke-width:1.5px;stroke-linecap:round;stroke-dasharray:3 3}.city-marker{cursor:pointer}.city-marker:hover{filter:url(#glow)}.city-glow{fill:#5c6bc01f}.city-shadow{fill:#00000014}.bld-body{stroke:#0000001a;stroke-width:.5px}.bld-window{fill:#ffffff47}.city-name-label{text-anchor:middle;fill:#263238;paint-order:stroke;stroke:#ffffffb3;stroke-width:3px;stroke-linejoin:round;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;font-weight:700}.feat-marker{cursor:pointer}.feat-marker:hover{filter:url(#glow)}.feat-ring{fill:none;stroke-width:2px;opacity:.25}.feat-ring-veg{stroke:#2e7d32}.feat-ring-water{stroke:#0d47a1}.feat-ring-sand{stroke:#a67c00}.feat-bg{stroke-width:0}.feat-bg-veg{fill:#43a047}.feat-bg-proj{fill:#fb8c00}.feat-bg-water{fill:#1e88e5}.feat-bg-sand{fill:#d4a843}.feat-label{text-anchor:middle;paint-order:stroke;stroke:#ffffffbf;stroke-width:2.5px;stroke-linejoin:round;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:9px;font-weight:700}.feat-label-veg{fill:#1b5e20}.feat-label-proj{fill:#bf360c}.feat-label-water{fill:#0d47a1}.feat-label-sand{fill:#6d4c00}.progress-ring-arc{transition:stroke-dashoffset .6s}.desert-label-main{fill:#a67c00;text-anchor:middle;letter-spacing:10px;opacity:.35;font-family:Georgia,Times New Roman,serif;font-size:20px;font-weight:800}.desert-label-sub{fill:#a67c00;text-anchor:middle;letter-spacing:2px;opacity:.28;font-family:Georgia,Times New Roman,serif;font-size:10px;font-style:italic}.label-pill{opacity:.85}.mtn-pill{fill:#5d40371f}.river-pill,.lake-pill{fill:#1565c01a}.label-text{text-anchor:middle;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:700}.mtn-text{fill:#4e342e;letter-spacing:3px;font-size:11px}.river-text{fill:#1565c0;font-size:9.5px;font-style:italic}.lake-text{fill:#1565c0;font-size:9px;font-style:italic}.compass-bg{fill:#ffffffeb;stroke:#bdbdbd;stroke-width:1px}.compass-n{fill:#e53935;text-anchor:middle;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:11px;font-weight:800}.scale-text{fill:#757575;text-anchor:middle;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:10px;font-weight:600}.map-zoom-controls{z-index:10;flex-direction:column;gap:2px;display:flex;position:absolute;bottom:80px;right:20px}.map-zoom-controls button{color:#555;cursor:pointer;background:#fffffff5;border:1px solid #ccc;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;font-family:-apple-system,BlinkMacSystemFont,sans-serif;font-size:20px;font-weight:400;transition:all .15s;display:flex;box-shadow:0 1px 4px #00000014}.map-zoom-controls button:hover{color:#43a047;background:#fff;border-color:#43a047;box-shadow:0 2px 8px #0000001f}.map-zoom-controls button:first-child{border-radius:10px 10px 2px 2px}.map-zoom-controls button:last-child{border-radius:2px 2px 10px 10px}.map-zoom-controls button.grid-active{color:#fff;background:#4fc3f7;border-color:#4fc3f7}.map-tooltip{z-index:20;pointer-events:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0a0e14eb;border:1px solid #4fc3f733;border-radius:8px;min-width:160px;padding:8px 12px;font-family:-apple-system,BlinkMacSystemFont,sans-serif;position:absolute}.map-tooltip-coords{color:#4fc3f7;margin-bottom:4px;font-family:monospace;font-size:11px;font-weight:600}.map-tooltip-ndvi{color:#c0d0e0;font-size:12px}.map-tooltip-ndvi strong{color:#91cf60}.map-tooltip-src{color:#5a6a7a;margin-left:6px;font-size:9px}.map-tooltip-terrain{color:#6a7a8a;margin-top:2px;font-size:10px}.map-pinned-card{z-index:25;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a0e14f2;border:1px solid #4fc3f74d;border-radius:10px;min-width:180px;padding:12px 14px;font-family:-apple-system,BlinkMacSystemFont,sans-serif;position:absolute;box-shadow:0 4px 20px #0006}.map-pin-close{color:#5a6a7a;cursor:pointer;background:0 0;border:none;padding:2px 6px;font-size:16px;position:absolute;top:4px;right:6px}.map-pin-close:hover{color:#ef5350}.map-pin-coords{color:#4fc3f7;margin-bottom:6px;font-family:monospace;font-size:12px;font-weight:600}.map-pin-ndvi{color:#c0d0e0;margin-bottom:4px;font-size:14px}.map-pin-class{color:#8a9aaa;font-size:11px}.map-pin-terrain{color:#5a6a7a;margin-top:2px;font-size:10px}.click-ripple .ripple-highlight{fill:#ffffff59;animation:.6s ease-out forwards ripple-bright}.click-ripple .ripple-ring{fill:none;stroke:#4fc3f799;stroke-width:2px;animation:.6s ease-out forwards ripple-expand}@keyframes ripple-bright{0%{fill:#ffffff80}to{fill:#fff0}}@keyframes ripple-expand{0%{stroke-width:3px;stroke-opacity:.8;transform:scale(1)}to{stroke-width:.5px;stroke-opacity:0;transform:scale(1.8)}}.coord-grid-line{stroke:#64647833;stroke-width:.8px;stroke-dasharray:6 4}.coord-grid-label{fill:#64647880;font-family:monospace;font-size:9px}.tile-count-badge{z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#8a9aaa;background:#00000073;border-radius:4px;padding:2px 8px;font-family:monospace;font-size:9px;position:absolute;bottom:8px;left:8px}.ndvi-loading-badge{z-index:15;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#8a9aaa;background:#0a0e14d9;border:1px solid #4fc3f733;border-radius:20px;align-items:center;gap:8px;padding:6px 16px;font-size:11px;animation:.3s fadeInDown;display:flex;position:absolute;top:50px;left:50%;transform:translate(-50%)}.ndvi-loading-dot{background:#4fc3f7;border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite pulse-dot}@keyframes fadeInDown{0%{opacity:0;transform:translate(-50%)translateY(-8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.sat-photo{background:#0d1117;border-radius:8px;position:relative;overflow:hidden}.sat-photo-skeleton{color:#5a6a7a;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:40px 20px;font-size:12px;display:flex}.sat-photo-pulse{border:3px solid #1e2a3a;border-top-color:#4fc3f7;border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.sat-photo-placeholder{color:#3a4a5a;background:#111922;border-radius:8px;justify-content:center;align-items:center;padding:40px 20px;font-size:12px;display:flex}.sat-photo-img{opacity:0;border-radius:8px;width:100%;transition:opacity .4s;display:block}.sat-photo-img.loaded{opacity:1}.sat-photo-label{align-items:center;gap:8px;display:flex;position:absolute;bottom:8px;left:8px}.sat-photo-label span{color:#ccc;background:#000000b3;border-radius:3px;padding:2px 8px;font-size:11px;font-weight:600}.sat-photo-src{color:#4fc3f7!important}.feature-sat-photo{border-radius:8px;min-height:80px;margin-bottom:10px}.sat-ba-container{background:#0d1117;border-radius:10px;overflow:hidden}.sat-ba-loading{color:#5a6a7a;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:60px 20px;font-size:13px;display:flex}.sat-ba-pulse{border:3px solid #1e2a3a;border-top-color:#91cf60;border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}.sat-ba-fallback{color:#3a4a5a;background:#111922;border-radius:10px;justify-content:center;align-items:center;padding:60px 20px;font-size:13px;display:flex}.sat-ba-slider{cursor:ew-resize;border-radius:10px;line-height:0;position:relative;overflow:hidden}.sat-ba-img{pointer-events:none;width:100%;display:block}.sat-ba-before{position:absolute;inset:0;overflow:hidden}.sat-ba-line{z-index:5;background:#fff;width:3px;position:absolute;top:0;bottom:0;transform:translate(-50%);box-shadow:0 0 8px #00000080}.sat-ba-handle{color:#333;white-space:nowrap;background:#fff;border-radius:20px;padding:4px 6px;font-size:12px;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 2px 8px #0000004d}.sat-ba-label-left{color:#fff;z-index:4;background:#000000b3;border-radius:4px;padding:4px 12px;font-size:14px;font-weight:700;position:absolute;top:12px;left:12px}.sat-ba-label-right{color:#91cf60;z-index:4;background:#000000b3;border-radius:4px;padding:4px 12px;font-size:14px;font-weight:700;position:absolute;top:12px;right:12px}.theme-toggle{border-radius:var(--radius-sm);border:1px solid var(--border-primary);background:var(--bg-secondary);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;transition:all .2s;display:flex}.theme-toggle:hover{border-color:var(--accent-orange);color:var(--accent-orange)}.alert-bell-wrapper{position:relative}.alert-bell{border-radius:var(--radius-sm);border:1px solid var(--border-primary);background:var(--bg-secondary);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;display:flex;position:relative}.alert-bell:hover{border-color:var(--accent-orange);color:var(--accent-orange)}.alert-badge{background:var(--accent-red);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:.6rem;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.alert-dropdown{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);width:280px;max-height:320px;box-shadow:var(--shadow-lg);z-index:100;padding:.75rem;position:absolute;top:40px;right:0;overflow-y:auto}.alert-dropdown h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.8rem}.alert-empty{color:var(--text-dim);text-align:center;padding:1rem 0;font-size:.8rem}.alert-item{border-radius:var(--radius-sm);border-left:3px solid #0000;justify-content:space-between;align-items:center;margin-bottom:.25rem;padding:.5rem;display:flex}.alert-item.severity-info{border-left-color:var(--accent-blue)}.alert-item.severity-warning{border-left-color:var(--accent-orange)}.alert-item.severity-critical{border-left-color:var(--accent-red)}.alert-title{color:var(--text-primary);font-size:.8rem}.alert-dismiss{border:1px solid var(--border-primary);border-radius:var(--radius-sm);color:var(--text-dim);cursor:pointer;background:0 0;padding:.15rem .4rem;font-size:.65rem}.auth-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-modal{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);width:360px;max-width:90vw;padding:2rem}.auth-modal h2{color:var(--text-primary);margin-bottom:1.5rem;font-size:1.2rem}.auth-modal form{flex-direction:column;gap:.75rem;display:flex}.auth-modal input{border-radius:var(--radius-sm);border:1px solid var(--border-primary);background:var(--bg-primary);color:var(--text-primary);padding:.6rem .8rem;font-size:.9rem}.auth-modal input:focus{border-color:var(--accent-blue);outline:none}.auth-submit{border-radius:var(--radius-sm);background:var(--accent-green);color:#0d1117;cursor:pointer;border:none;margin-top:.5rem;padding:.6rem;font-size:.9rem;font-weight:600}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-error{color:var(--accent-red);font-size:.8rem}.auth-switch{color:var(--text-secondary);text-align:center;margin-top:1rem;font-size:.8rem}.auth-switch-btn{color:var(--accent-blue);cursor:pointer;background:0 0;border:none;font-size:.8rem;text-decoration:underline}.onboarding-overlay{z-index:2000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.onboarding-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);text-align:center;width:90vw;max-width:420px;padding:2rem}.onboarding-card h3{color:var(--accent-green);margin-bottom:1rem;font-size:1.1rem}.onboarding-text{color:var(--text-primary);margin-bottom:1.5rem;font-size:.95rem;line-height:1.6}.onboarding-progress{justify-content:center;gap:6px;margin-bottom:1.5rem;display:flex}.onboarding-dot{background:var(--border-primary);border-radius:50%;width:8px;height:8px}.onboarding-dot.active{background:var(--accent-green);transform:scale(1.3)}.onboarding-dot.done{background:var(--accent-green);opacity:.5}.onboarding-actions{justify-content:space-between;display:flex}.onboarding-skip{color:var(--text-dim);cursor:pointer;background:0 0;border:none;font-size:.85rem}.onboarding-next{border-radius:var(--radius-sm);background:var(--accent-green);color:#0d1117;cursor:pointer;border:none;padding:.5rem 1.5rem;font-size:.85rem;font-weight:600}.sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border-secondary);z-index:100;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;width:50px;padding:12px 0;display:flex}.sidebar-brand{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--accent-green);background:#91cf601f;flex-shrink:0;justify-content:center;align-items:center;margin-bottom:4px;display:flex}.sidebar-label{letter-spacing:.8px;color:#4a4a6a;text-transform:uppercase;-webkit-user-select:none;user-select:none;flex-shrink:0;margin:8px 0 2px;font-size:9px;font-weight:600}.sidebar-icon{color:#6a6a8a;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;transition:all .2s;display:flex;position:relative}.sidebar-icon:hover{background:var(--bg-elevated);color:#ccc}.sidebar-icon.active{color:var(--accent-green);background:#91cf602e}.sidebar-icon.active:before{content:"";background:var(--accent-green);border-radius:0 4px 4px 0;width:4px;position:absolute;top:8px;bottom:8px;left:0}.sidebar-icon .sidebar-tooltip{background:var(--bg-elevated);color:var(--text-primary);white-space:nowrap;pointer-events:none;opacity:0;border:1px solid var(--border-secondary);box-shadow:var(--shadow-md);z-index:200;border-radius:4px;padding:4px 10px;font-size:12px;transition:opacity .18s,transform .18s;position:absolute;top:50%;left:52px;transform:translateY(-50%)translate(-4px)}.sidebar-icon:hover .sidebar-tooltip{opacity:1;transform:translateY(-50%)translate(0)}.sidebar-spacer{flex:1}@media (width<=768px){.sidebar{border-right:none;border-top:1px solid var(--border-secondary);z-index:1200;background:var(--bg-sidebar);-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-direction:row;gap:0;width:100%;height:56px;padding:0 4px;position:fixed;bottom:0;left:0;right:0;overflow:auto hidden}.sidebar::-webkit-scrollbar{display:none}.sidebar-brand,.sidebar-label,.sidebar-spacer{display:none}.sidebar-icon{border-radius:10px;flex-shrink:0;width:44px;height:44px;margin:6px 2px}.sidebar-icon.active:before{border-radius:3px 3px 0 0;width:auto;height:3px;inset:auto 8px 0}.sidebar-icon .sidebar-tooltip{display:none}}.app{background:var(--bg-primary);min-height:100vh;color:var(--text-primary);flex-direction:column;display:flex}.app.fullscreen .app-header,.app.fullscreen .status-bar,.app.fullscreen .sidebar{display:none}.app.fullscreen .app-shell{z-index:9999;position:fixed;inset:0}.app-shell{flex:1;display:flex;overflow:hidden}.app-main-content{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.view-panel{flex-direction:column;flex:1;animation:.3s viewFadeIn;display:none;overflow:hidden}.view-panel.active{display:flex}@keyframes viewFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.app-header{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);border-bottom:1px solid #2a2a4a;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 24px;display:flex}.header-title-row{align-items:baseline;gap:8px;display:flex}.header-left h1{color:#91cf60;margin:0;font-size:20px;font-weight:700}.header-breadcrumb-sep{color:#3a3a5a;font-size:16px;font-weight:300}.header-breadcrumb-page{color:var(--text-secondary);font-size:15px;font-weight:500}.subtitle{color:var(--text-secondary);margin:2px 0 0;font-size:12px}.header-right{align-items:center;gap:12px;display:flex}.header-source-badge{letter-spacing:.5px;text-transform:uppercase;border-radius:12px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:600;display:flex}.header-source-badge.live{color:#1a9850;background:#1a985026}.header-source-badge.demo{color:#fc8d59;background:#fc8d5926}.header-source-dot{border-radius:50%;width:6px;height:6px;animation:2s infinite pulse-dot}.header-source-badge.live .header-source-dot{background:#1a9850;box-shadow:0 0 4px #1a9850}.header-source-badge.demo .header-source-dot{background:#fc8d59;box-shadow:0 0 4px #fc8d59}.lang-toggle{background:#ffffff0f;border-radius:8px;align-items:center;gap:0;padding:2px;display:flex}.lang-toggle button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 12px;font-size:12px;font-weight:500;transition:all .2s}.lang-toggle button.active{color:#91cf60;background:#91cf6026;font-weight:600}.lang-toggle button:hover:not(.active){color:#ccc}.error-banner{color:#fff;background:#d73027;justify-content:space-between;align-items:center;padding:8px 24px;font-size:13px;display:flex}.error-dismiss{color:#fff;cursor:pointer;opacity:.8;background:0 0;border:none;padding:0 4px;font-size:16px}.error-dismiss:hover{opacity:1}.dashboard-bar{background:#1a1a2e;border-bottom:1px solid #2a2a4a;flex-shrink:0;gap:16px;padding:10px 24px;display:flex;overflow-x:auto}.dashboard-card{background:#16213e;border-radius:8px;flex:1;min-width:140px;padding:10px 18px}.dashboard-value{font-size:20px;font-weight:700}.dashboard-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;margin-top:2px;font-size:11px}.search-filter-bar{background:#16213e;border-bottom:1px solid #2a2a4a;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:16px;padding:8px 24px;display:flex}.search-input-wrapper{flex:0 0 220px;position:relative}.search-icon{color:#666;font-size:14px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-input{color:#e0e0e0;background:#0d1117;border:1px solid #3a3a5a;border-radius:6px;outline:none;width:100%;padding:6px 10px 6px 32px;font-size:13px;transition:border-color .2s}.search-input:focus{border-color:#91cf60}.filter-chips{flex-wrap:wrap;gap:6px;display:flex}.filter-chip{color:#ccc;cursor:pointer;white-space:nowrap;background:0 0;border:1.5px solid;border-radius:16px;align-items:center;gap:5px;padding:4px 12px;font-size:12px;transition:all .2s;display:flex}.filter-chip.active{color:#fff}.filter-chip:hover{opacity:.85}.chip-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.fullscreen-btn{z-index:1000;color:#ccc;cursor:pointer;background:#1a1a2e;border:1px solid #3a3a5a;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex;position:absolute;top:12px;right:12px}.fullscreen-btn:hover{color:#91cf60;background:#2a2a4a;border-color:#91cf60}.spinner-wrapper{justify-content:center;padding:24px;display:flex}.spinner{border:3px solid #2a2a4a;border-top-color:#91cf60;border-radius:50%;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.skeleton-card{background:linear-gradient(90deg,#1a1a2e 25%,#2a2a4a 50%,#1a1a2e 75%) 0 0/200% 100%;border-radius:8px;animation:1.5s infinite shimmer}.status-bar{color:#6a6a8a;background:#0a0e17;border-top:1px solid #2a2a4a;flex-shrink:0;align-items:center;gap:16px;padding:6px 24px;font-size:11px;display:flex}.status-item{white-space:nowrap;align-items:center;gap:6px;display:flex}.status-dot{border-radius:50%;width:6px;height:6px}.status-dot.demo{background:#fc8d59;box-shadow:0 0 4px #fc8d5980}.status-dot.live{background:#1a9850;box-shadow:0 0 4px #1a985080}.status-spacer{flex:1}.status-highlight{color:#91cf60;font-weight:600}.status-updated{color:#555}.dashboard-view{flex:1;padding:24px;overflow-y:auto}.dash-metrics-row{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.dash-metric-card{background:#16213e;border:1px solid #2a2a4a;border-radius:10px;padding:18px}.dash-metric-value{font-size:28px;font-weight:700}.dash-metric-label{color:var(--text-secondary);margin-top:4px;font-size:12px}.dash-metric-trend{align-items:center;gap:4px;margin-top:6px;font-size:12px;font-weight:600;display:flex}.dash-metric-trend.up{color:#1a9850}.dash-metric-trend.down{color:#d73027}.dash-chart-card{background:#16213e;border:1px solid #2a2a4a;border-radius:10px;margin-bottom:24px;padding:20px}.dash-chart-card h3{color:#ccc;margin:0 0 12px;font-size:14px}.dash-regional-row{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.dash-regional-card{background:#16213e;border:1px solid #2a2a4a;border-radius:10px;padding:14px}.dash-regional-card h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 8px;font-size:12px}.dash-projects-section{background:#16213e;border:1px solid #2a2a4a;border-radius:10px;padding:20px}.dash-projects-section h3{color:#ccc;margin:0 0 16px;font-size:14px}.dash-projects-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.dash-project-card{background:#0d1117;border-radius:8px;justify-content:space-between;align-items:center;padding:14px;display:flex}.dash-project-top{align-items:center;gap:12px;display:flex}.dash-project-info{flex-direction:column;gap:4px;display:flex}.dash-project-name{color:#e0e0e0;font-size:13px;font-weight:600}.dash-project-status{font-size:11px;font-weight:600}.dash-project-status.green{color:#1a9850}.dash-project-status.yellow{color:#e0a030}.dash-project-status.red{color:#d73027}.dash-project-pct{color:#91cf60;font-size:18px;font-weight:700}.mini-progress-ring{flex-shrink:0}@media (width<=768px){.app-header{padding:8px 16px}.header-left h1{font-size:16px}.subtitle{display:none}.header-breadcrumb-sep,.header-breadcrumb-page{font-size:13px}.app-shell{flex-direction:column;padding-bottom:56px}.status-bar{display:none}.dashboard-bar{gap:8px;padding:8px 12px}.dashboard-card{min-width:110px;padding:8px 12px}.search-filter-bar{flex-direction:column;gap:8px;padding:8px 12px}.search-input-wrapper{flex:100%}.dash-metrics-row,.dash-regional-row{grid-template-columns:repeat(2,1fr)}.dash-projects-grid{grid-template-columns:1fr}}.ws-status{align-items:center;display:flex}.ws-dot{border-radius:50%;width:6px;height:6px}.ws-status.connected .ws-dot{background:var(--accent-green);box-shadow:0 0 4px var(--accent-green)}.ws-status.disconnected .ws-dot{background:var(--text-dim)}.header-login{border-radius:var(--radius-sm);border:1px solid var(--border-primary);background:var(--bg-secondary);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;display:flex}.header-login:hover{border-color:var(--accent-blue);color:var(--accent-blue)}.header-user{align-items:center;gap:6px;display:flex}.header-user-name{color:var(--text-secondary);font-size:12px;font-weight:500}.header-logout{border-radius:var(--radius-sm);border:1px solid var(--border-primary);width:28px;height:28px;color:var(--text-dim);cursor:pointer;background:0 0;justify-content:center;align-items:center;display:flex}.header-logout:hover{color:var(--accent-red);border-color:var(--accent-red)}.simulated-badge{color:var(--accent-orange);letter-spacing:.5px;text-transform:uppercase;background:#ffa72626;border-radius:4px;align-items:center;gap:4px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-flex}.map-area{flex:1;min-height:400px;position:relative}.map-fullbleed{flex:1;min-height:0}.map-overlay-top{z-index:100;position:absolute;top:0;left:0;right:0}.map-overlay-top .search-filter-bar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:.4;background:#16213ed9;border-bottom:1px solid #2a2a4a80;padding:6px 16px;transition:opacity .3s}.map-overlay-top:hover .search-filter-bar,.map-overlay-top .search-filter-bar:focus-within{opacity:1}.custom-marker{background:0 0!important;border:none!important}.marker-icon{width:32px;height:32px;box-shadow:var(--shadow-sm);border-radius:50% 50% 50% 0;justify-content:center;align-items:center;display:flex;transform:rotate(-45deg)}.marker-icon svg{width:18px;height:18px;transform:rotate(45deg)}.slide-panel{z-index:1001;background:#1a1a2e;border-left:1px solid #2a2a4a;width:400px;height:100%;transition:transform .3s;position:absolute;top:0;right:0;overflow-y:auto;transform:translate(100%);box-shadow:-4px 0 20px #00000040}.slide-panel.open{transform:translate(0)}.panel-close-btn{float:right;color:#ccc;cursor:pointer;z-index:10;background:#0d1117;border:1px solid #3a3a5a;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;margin:10px;transition:all .2s;display:flex;position:sticky;top:0}.panel-close-btn:hover{color:#fff;background:#d73027;border-color:#d73027}.panel-content{flex-direction:column;gap:12px;padding:12px 16px;display:flex}.feature-details{background:#16213e;border-radius:8px;padding:14px}.feature-header{margin-bottom:10px}.category-badge{color:#fff;border-radius:10px;margin-bottom:6px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-block}.feature-name{color:#e0e0e0;margin:4px 0 0;font-size:18px;font-weight:700}.feature-description{color:#aaa;margin:8px 0;font-size:13px;line-height:1.5}.feature-stats-grid{grid-template-columns:1fr 1fr;gap:6px;margin-top:10px;display:grid}.feature-stat{background:#0d1117;border-radius:6px;padding:8px 10px}.feature-stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;font-size:10px;display:block}.feature-stat-value{color:#e0e0e0;margin-top:2px;font-size:14px;font-weight:600;display:block}.timeline{background:#16213e;border-radius:8px;flex-wrap:wrap;align-items:center;gap:16px;padding:12px 14px;display:flex}.timeline-section{align-items:center;gap:8px;display:flex}.timeline-section label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;font-size:11px}.timeline-section input[type=range]{accent-color:#1a9850;width:120px}.timeline-section select{color:#e0e0e0;background:#0d1117;border:1px solid #3a3a5a;border-radius:4px;padding:3px 6px;font-size:12px}.year-display{color:#91cf60;text-align:center;min-width:40px;font-size:16px;font-weight:700}.year-arrow{color:var(--text-secondary);font-size:16px}.btn-compare{color:#fff;cursor:pointer;background:#4a90d9;border:none;border-radius:6px;padding:4px 12px;font-size:12px;font-weight:600;transition:background .2s}.btn-compare:hover{background:#357abd}.legend{background:#16213e;border-radius:8px;padding:12px}.legend h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 8px;font-size:12px}.legend-item{align-items:center;gap:8px;padding:2px 0;font-size:12px;display:flex}.legend-color{border-radius:3px;flex-shrink:0;width:16px;height:12px}.legend-label{color:#ccc;flex:1}.legend-range{color:var(--text-secondary);font-size:11px;font-family:var(--font-mono)}.chart-container{background:#16213e;border-radius:8px;padding:12px}.chart-container h3{color:#ccc;margin:0 0 10px;font-size:13px}.compare-slider-container{background:#16213e;border-radius:8px;padding:12px}.compare-slider-container h3{color:#ccc;margin:0 0 10px;font-size:13px}.compare-labels{color:#91cf60;justify-content:space-between;margin-top:6px;font-size:13px;font-weight:600;display:flex}.compare-year-label{color:#91cf60;background:#0009;border-radius:4px;padding:2px 8px;font-size:12px;font-weight:700;position:absolute;bottom:8px;left:8px}.stats-container{background:#16213e;border-radius:8px;padding:12px}.stats-container h3{color:#ccc;margin:0 0 10px;font-size:13px}.stats-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.stat-card{background:#0d1117;border-left:3px solid #333;border-radius:6px;padding:10px}.stat-value{margin-bottom:2px;font-size:18px;font-weight:700}.stat-label{color:var(--text-secondary);font-size:10px}.export-buttons{gap:8px;padding-top:4px;display:flex}.export-btn{color:#ccc;cursor:pointer;background:#0d1117;border:1px solid #3a3a5a;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:6px;padding:8px 12px;font-size:12px;transition:all .2s;display:flex}.export-btn:hover{color:#91cf60;background:#2a2a4a;border-color:#91cf60}.year-slider-toggle{z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#91cf60;cursor:pointer;width:40px;height:40px;box-shadow:var(--shadow-sm);background:#0d1117d9;border:1px solid #2a2a4a;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.year-slider-toggle:hover{background:#0d1117f2;border-color:#91cf60;transform:translate(-50%)scale(1.1)}.map-year-slider{z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0d1117d9;border:1px solid #2a2a4a;border-radius:12px;align-items:center;gap:12px;padding:10px 16px;animation:.25s slideUp;display:flex;position:absolute;bottom:16px;left:80px;right:80px}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.year-close-btn{color:#6a6a8a;cursor:pointer;background:0 0;border:1px solid #3a3a5a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:all .15s;display:flex}.year-close-btn:hover{color:#ef5350;border-color:#ef5350}.year-play-btn{color:#91cf60;cursor:pointer;background:#1a1a2e;border:1px solid #3a3a5a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.year-play-btn:hover{background:#2a2a4a;border-color:#91cf60}.year-big{color:#91cf60;text-align:center;flex-shrink:0;min-width:50px;font-size:22px;font-weight:700}.slider-track-wrapper{flex:1;align-items:center;height:24px;display:flex;position:relative}.year-range-input{appearance:none;z-index:2;background:#2a2a4a;border-radius:2px;outline:none;width:100%;height:4px;position:relative}.year-range-input::-webkit-slider-thumb{-webkit-appearance:none;cursor:pointer;background:#91cf60;border-radius:50%;width:16px;height:16px;box-shadow:0 0 6px #91cf6080}.year-range-input::-moz-range-thumb{cursor:pointer;background:#91cf60;border:none;border-radius:50%;width:16px;height:16px}.slider-fill{pointer-events:none;z-index:1;background:linear-gradient(90deg,#91cf60,#1a9850);border-radius:2px;height:4px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.milestone-tick{z-index:3;pointer-events:none;position:absolute;top:-2px;transform:translate(-50%)}.milestone-dot{background:#4a90d9;border:2px solid #0d1117;border-radius:50%;width:8px;height:8px;margin:0 auto}.milestone-label{color:#6a6a8a;text-align:center;white-space:nowrap;margin-top:2px;font-size:9px;display:block}.dash-hero{background:#16213e;border:1px solid #2a2a4a;border-radius:10px;margin-bottom:24px;padding:20px}.dash-hero-text{margin-bottom:14px}.dash-hero-text h3{color:#e0e0e0;margin:0 0 4px;font-size:16px}.dash-hero-text p{color:var(--text-secondary);margin:0;font-size:12px}.map-sat-toggle{z-index:1000;color:#666;cursor:pointer;background:#ffffffe6;border:1px solid #c4b89a;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex;position:absolute;top:12px;left:12px;box-shadow:0 2px 4px #00000026}.map-sat-toggle:hover{color:#4fc3f7;border-color:#4fc3f7}.map-sat-toggle.active{color:#fff;background:#4fc3f7;border-color:#4fc3f7}.map-sat-bg{z-index:1;position:absolute;inset:0}.map-sat-bg .sat-photo-img{object-fit:cover;border-radius:0;width:100%;height:100%}.map-sat-bg .sat-photo-skeleton,.map-sat-bg .sat-photo-placeholder{min-height:100%}.map-area:has(.map-sat-bg) .illustrated-map-container{opacity:.35;z-index:2}@media (width<=768px){.slide-panel{border-top:1px solid #2a2a4a;border-left:none;border-radius:16px 16px 0 0;width:100%;height:60vh;top:auto;bottom:0;transform:translateY(100%)}.slide-panel.open{transform:translateY(0)}.slide-panel:before{content:"";background:#3a3a5a;border-radius:2px;width:36px;height:4px;margin:8px auto 4px;display:block}.map-area{min-height:300px}.map-year-slider{left:10px;right:10px}.fullscreen-btn{width:40px;height:40px;top:8px;right:8px}}
