@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap";:root{--bg-deep: hsl(220, 25%, 8%);--bg-main: hsl(220, 25%, 11%);--bg-card: hsla(220, 25%, 15%, .85);--bg-card-hover: hsla(220, 25%, 20%, .95);--border-color: hsla(220, 20%, 25%, .5);--border-glow: hsla(142, 72%, 45%, .2);--text-primary: hsl(220, 15%, 95%);--text-secondary: hsl(220, 10%, 75%);--text-muted: hsl(220, 10%, 55%);--accent-shade: hsl(142, 72%, 45%);--accent-shade-light: hsl(142, 72%, 90%);--accent-sun: hsl(42, 95%, 55%);--accent-sun-dark: hsl(30, 90%, 50%);--accent-primary: hsl(174, 75%, 40%);--accent-error: hsl(0, 85%, 60%);--gradient-brand: linear-gradient(135deg, hsl(142, 72%, 45%) 0%, hsl(174, 75%, 40%) 100%);--gradient-card-hover: linear-gradient(180deg, hsla(220, 25%, 18%, .85) 0%, hsla(220, 25%, 15%, .85) 100%);--font-display: "Outfit", "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .15);--shadow-md: 0 8px 24px rgba(0, 0, 0, .3);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .5);--backdrop-blur: blur(16px)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background-color:var(--bg-deep);color:var(--text-primary);height:100vh;overflow:hidden;display:flex;flex-direction:column}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#3d475c99;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#525f7acc}.app-container{display:grid;grid-template-columns:420px 1fr;height:100vh;width:100vw;position:relative}.sidebar{background-color:var(--bg-main);border-right:1px solid var(--border-color);display:flex;flex-direction:column;height:100vh;z-index:10;box-shadow:var(--shadow-lg);overflow-y:auto}.sidebar-header{padding:24px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:12px}.logo-icon{width:40px;height:40px;background:var(--gradient-brand);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;box-shadow:0 0 15px #14b8a64d}.logo-text h1{font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:-.5px;background:var(--gradient-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.logo-text p{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-top:1px}.mode-tabs{display:grid;grid-template-columns:1fr 1fr;background-color:var(--bg-deep);border:1px solid var(--border-color);border-radius:10px;padding:4px;margin-bottom:8px}.tab-btn{background:transparent;border:none;border-radius:8px;padding:10px;color:var(--text-secondary);font-family:var(--font-display);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{background-color:var(--bg-main);color:var(--text-primary);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.panel-content{padding:24px;display:flex;flex-direction:column;gap:24px;flex:1}#control-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px;position:relative}.form-label{font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--text-secondary);display:flex;justify-content:space-between;align-items:center}.form-label span.value{color:var(--accent-shade);font-weight:700}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:14px;color:var(--text-muted);font-size:16px}.form-input{width:100%;padding:14px 14px 14px 40px;background-color:var(--bg-deep);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-family:var(--font-body);font-size:14px;transition:all .2s ease}.form-input:focus{outline:none;border-color:var(--accent-shade);box-shadow:0 0 0 3px var(--border-glow)}.autocomplete-list{position:absolute;top:100%;left:0;right:0;background-color:var(--bg-main);border:1px solid var(--border-color);border-radius:10px;margin-top:5px;max-height:200px;overflow-y:auto;z-index:20;box-shadow:var(--shadow-lg)}.autocomplete-item{padding:12px 16px;font-size:13px;cursor:pointer;border-bottom:1px solid hsla(220,20%,25%,.3);transition:background-color .15s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.autocomplete-item:hover{background-color:var(--bg-card-hover);color:var(--text-primary)}.slider-container{display:flex;flex-direction:column;gap:8px}.custom-range{-webkit-appearance:none;width:100%;height:6px;border-radius:3px;background:var(--bg-deep);outline:none}.custom-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--accent-shade);cursor:pointer;box-shadow:0 0 10px #22c55e66;transition:transform .1s ease}.custom-range::-webkit-slider-thumb:hover{transform:scale(1.15)}.solar-preview{display:flex;align-items:center;justify-content:space-between;background:var(--bg-deep);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--text-muted)}.solar-preview .sun-position{display:flex;align-items:center;gap:6px;color:var(--accent-sun);font-weight:500}.fitness-group{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.fitness-btn{background-color:var(--bg-deep);border:1px solid var(--border-color);border-radius:8px;padding:10px;color:var(--text-secondary);font-family:var(--font-display);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:4px}.fitness-btn i{font-size:16px}.fitness-btn:hover{background-color:var(--bg-card-hover);color:var(--text-primary);border-color:var(--text-muted)}.fitness-btn.active{background:var(--gradient-brand);color:#fff;border-color:transparent;box-shadow:0 4px 12px #14b8a633}.submit-btn{width:100%;margin-top:12px;background:var(--gradient-brand);border:none;border-radius:10px;color:#fff;padding:14px;font-family:var(--font-display);font-size:15px;font-weight:700;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 20px #22c55e26}.submit-btn:hover{transform:translateY(-1px);box-shadow:0 6px 24px #22c55e4d}.submit-btn:active{transform:translateY(1px)}.routes-container{display:flex;flex-direction:column;gap:16px}.routes-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.route-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:16px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden}.route-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--text-muted);transition:all .25s ease}.route-card.active-route:before{background:var(--gradient-brand)}.route-card:hover{background:var(--bg-card-hover);border-color:#20c55d4d;transform:translateY(-2px);box-shadow:var(--shadow-md)}.route-card.active-route{border-color:var(--accent-shade);box-shadow:0 0 15px var(--border-glow)}.route-header{display:flex;justify-content:space-between;align-items:flex-start}.route-name{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--text-primary)}.route-stats{display:flex;gap:12px;font-size:12px;color:var(--text-secondary)}.route-stat-item{display:flex;align-items:center;gap:4px}.route-stat-item i{color:var(--accent-primary)}.shade-meter-container{display:flex;flex-direction:column;gap:4px}.shade-meter-label{display:flex;justify-content:space-between;font-size:11px;color:var(--text-secondary)}.shade-meter-bar-bg{width:100%;height:6px;background-color:var(--bg-deep);border-radius:3px;overflow:hidden}.shade-meter-bar-fill{height:100%;background:var(--gradient-brand);border-radius:3px;transition:width .5s ease-out}.shade-pill{padding:2px 8px;border-radius:12px;font-size:10px;font-weight:700;text-transform:uppercase}.shade-pill.high{background-color:#20c55d26;color:#20c55d}.shade-pill.medium{background-color:#f9b81f26;color:#f9b81f}.shade-pill.low{background-color:#f0424226;color:#f04242}.map-container{width:100%;height:100%;position:relative}#map{width:100%;height:100%;background-color:var(--bg-deep)}.leaflet-container{background-color:var(--bg-deep)!important}.leaflet-control-zoom{border:1px solid var(--border-color)!important;box-shadow:var(--shadow-md)!important}.leaflet-control-zoom-in,.leaflet-control-zoom-out{background-color:var(--bg-main)!important;color:var(--text-primary)!important;border-bottom:1px solid var(--border-color)!important}.leaflet-control-zoom-in:hover,.leaflet-control-zoom-out:hover{background-color:var(--bg-card-hover)!important;color:var(--text-primary)!important}.leaflet-control-attribution{background-color:var(--bg-main)!important;color:var(--text-muted)!important}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#090d15d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;opacity:0;pointer-events:none;transition:opacity .3s ease}.loading-overlay.active{opacity:1;pointer-events:all}.spinner{width:50px;height:50px;border:4px solid var(--border-color);border-top:4px solid var(--accent-shade);border-radius:50%;animation:spin 1s linear infinite}.loading-text{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--text-primary);text-align:center;animation:pulse 1.5s ease infinite}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 20px;color:var(--text-secondary);gap:16px;flex:1}.empty-state-icon{font-size:48px;background:var(--gradient-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:float 3s ease-in-out infinite}.empty-state h3{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--text-primary)}.empty-state p{font-size:13px;line-height:1.5;max-width:280px}.solar-widget{position:absolute;top:20px;right:20px;z-index:1000;background:var(--bg-card);-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);border:1px solid var(--border-color);padding:12px 18px;border-radius:14px;box-shadow:var(--shadow-lg);pointer-events:auto;display:flex;align-items:center;gap:14px;transition:transform .3s ease}.solar-widget-sun{width:24px;height:24px;background:radial-gradient(circle,var(--accent-sun) 30%,var(--accent-sun-dark) 100%);border-radius:50%;box-shadow:0 0 15px var(--accent-sun);animation:float 4s ease-in-out infinite}.solar-widget-info{display:flex;flex-direction:column}.solar-widget-title{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.solar-widget-value{font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--text-primary)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@media (max-width: 768px){.app-container{grid-template-columns:1fr;grid-template-rows:1fr;height:100vh;overflow:hidden}.map-container{grid-row:1;grid-column:1;height:100vh;width:100vw}.sidebar{grid-row:1;grid-column:1;position:absolute;bottom:0;left:0;right:0;height:auto;max-height:70vh;width:100vw;z-index:1001;border-right:none;border-top:1px solid var(--border-color);border-radius:20px 20px 0 0;box-shadow:0 -8px 32px #0006;background-color:var(--bg-main);overflow-y:auto;transform:translateY(0);transition:transform .3s cubic-bezier(.4,0,.2,1)}.sidebar:before{content:"";display:block;width:40px;height:4px;background-color:var(--text-muted);border-radius:2px;margin:8px auto 0;opacity:.5}.sidebar-header{padding:12px 20px}.panel-content{padding:16px 20px 24px;gap:16px}.solar-widget{top:auto;bottom:calc(70vh + 20px);right:15px;padding:8px 12px}}
