:root{--bg-primary: #f5f5f0;--bg-card: #ffffff;--bg-sidebar: #fafaf7;--bg-hover: #f0efea;--text-primary: #1a1a1a;--text-secondary: #6b6b6b;--text-muted: #9a9a9a;--accent: #2d6a4f;--accent-light: #d8f3dc;--accent-hover: #1b4332;--fill-low: #40916c;--fill-med: #e9a820;--fill-high: #e36149;--fill-critical: #c1292e;--border: #e0dfda;--border-strong: #cccbc5;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .1);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;font-family:Satoshi,-apple-system,sans-serif;font-size:15px;line-height:1.5;color:var(--text-primary)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;overflow:hidden}body{background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes slideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.fade-in{animation:fadeIn .35s ease-out both}.app{display:flex;height:100vh;width:100vw;overflow:hidden}.icon-rail{width:64px;min-width:64px;height:100%;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding:20px 0;z-index:20}.rail-top{display:flex;flex-direction:column;align-items:center;gap:8px}.rail-logo{margin-bottom:16px}.rail-btn{width:40px;height:40px;border-radius:var(--radius-md);border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.rail-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.rail-btn.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px #2d6a4f4d}.panel{width:400px;min-width:400px;height:100%;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;z-index:10}.panel-header{padding:24px 24px 16px}.panel-title{font-size:1.35rem;font-weight:900;letter-spacing:-.03em;color:var(--text-primary);margin-bottom:2px}.panel-subtitle{font-size:.78rem;color:var(--text-muted);font-weight:500}.stats-row{display:flex;gap:8px;padding:0 24px 16px}.stat-pill{display:flex;align-items:baseline;gap:5px;padding:8px 14px;background:var(--bg-primary);border-radius:20px;border:1px solid var(--border)}.stat-value{font-size:1.05rem;font-weight:900;letter-spacing:-.02em}.stat-value.critical{color:var(--fill-critical)}.stat-value.warning{color:var(--fill-med)}.stat-value.good{color:var(--fill-low)}.stat-label{font-size:.7rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em}.route-planner-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.route-planner{flex:1;padding:16px 24px;border-top:1px solid var(--border);background:var(--bg-sidebar);overflow-y:auto;display:flex;flex-direction:column;gap:16px}.route-planner-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:12px}.route-endpoints{display:flex;flex-direction:column;gap:0;margin-bottom:12px;position:relative}.route-endpoint{display:flex;align-items:center;gap:12px;padding:6px 0}.endpoint-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.endpoint-dot.start{background:var(--accent)}.endpoint-dot.end{background:transparent;border:2.5px solid var(--text-muted)}.endpoint-line{width:2px;height:14px;background:var(--border-strong);margin-left:5px}.endpoint-field{flex:1;display:flex;flex-direction:column;gap:2px}.endpoint-field label{font-size:.65rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.endpoint-field select{font-family:Satoshi,sans-serif;font-size:.85rem;font-weight:600;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text-primary);cursor:pointer;outline:none;transition:border-color .15s}.endpoint-field select:focus{border-color:var(--accent)}.route-actions{display:flex;gap:8px}.btn-route{flex:1;font-family:Satoshi,sans-serif;font-size:.8rem;font-weight:700;padding:10px 16px;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;text-transform:uppercase;letter-spacing:.04em}.btn-route.primary{background:var(--accent);color:#fff}.btn-route.primary:hover{background:var(--accent-hover)}.btn-route.primary:disabled{background:var(--border);color:var(--text-muted);cursor:not-allowed}.btn-route.secondary{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border)}.btn-route.secondary:hover{background:var(--bg-hover)}.route-info{padding:12px;background:var(--accent-light);border-radius:var(--radius-sm);font-size:.8rem;color:var(--accent-hover);font-weight:500;flex:1;overflow-y:auto}.route-info-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.route-info-header span{font-size:.7rem;color:var(--accent)}.route-stop-list{list-style:none}.route-stop-list li{padding:4px 0;display:flex;align-items:center;gap:8px}.route-stop-number{width:20px;height:20px;border-radius:50%;background:var(--accent);color:#fff;font-size:.6rem;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0}.route-stop-name{flex:1;font-weight:600}.route-stop-fill{font-weight:700;font-size:.75rem}.panel-section-title{padding:12px 24px 6px;font-size:.9rem;font-weight:800;color:var(--text-primary)}.bin-list{flex:1;overflow-y:auto;padding:4px 16px 16px;display:flex;flex-direction:column;gap:8px}.bin-card{display:flex;flex-shrink:0;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);cursor:pointer;transition:all .15s;overflow:hidden;animation:slideIn .3s ease-out both}.bin-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.bin-card.selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.bin-card.route-stop{border-color:var(--accent)}.bin-card-edge{width:4px;flex-shrink:0}.bin-card-edge.low{background:var(--fill-low)}.bin-card-edge.med{background:var(--fill-med)}.bin-card-edge.high{background:var(--fill-high)}.bin-card-edge.critical{background:var(--fill-critical);animation:pulse 1.5s ease-in-out infinite}.bin-card-body{flex:1;padding:12px 14px;min-width:0}.bin-card-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.bin-card-name-row{display:flex;align-items:center;gap:8px}.route-badge{width:20px;height:20px;border-radius:50%;background:var(--accent);color:#fff;font-size:.6rem;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0}.bin-card-name{font-size:.92rem;font-weight:700;color:var(--text-primary)}.bin-card-id{font-size:.7rem;color:var(--text-muted);font-weight:500;font-family:monospace}.bin-card-bottom{display:flex;align-items:center;gap:10px}.fill-bar-track{flex:1;height:6px;background:var(--bg-primary);border-radius:3px;overflow:hidden}.fill-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}.fill-bar-fill.low{background:var(--fill-low)}.fill-bar-fill.med{background:var(--fill-med)}.fill-bar-fill.high{background:var(--fill-high)}.fill-bar-fill.critical{background:var(--fill-critical)}.bin-card-pct{font-size:.85rem;font-weight:900;min-width:36px;text-align:right}.bin-card-detail{margin-top:8px;display:flex;gap:16px;font-size:.72rem;color:var(--text-muted);font-weight:500}.map-container{flex:1;position:relative;height:100%;min-width:0;overflow:hidden}.map-container>.map-overlay,.map-container>.map-legend{height:auto;width:auto}.map-marker{position:absolute;cursor:pointer;transition:transform .2s ease;left:-18px;top:-44px}.map-marker:hover{transform:scale(1.1);z-index:100!important}.marker-pin{width:36px;height:44px;position:relative;display:flex;align-items:flex-start;justify-content:center}.marker-pin-bg{width:36px;height:36px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);position:absolute;top:0;box-shadow:0 2px 8px #00000040;border:2.5px solid white}.marker-pin-bg.low{background:var(--fill-low)}.marker-pin-bg.med{background:var(--fill-med)}.marker-pin-bg.high{background:var(--fill-high)}.marker-pin-bg.critical{background:var(--fill-critical);animation:pulse 1.5s ease-in-out infinite}.marker-label{position:absolute;top:6px;font-size:.6rem;font-weight:900;color:#fff;z-index:2;text-shadow:0 1px 2px rgba(0,0,0,.3)}.marker-route-badge{position:absolute;top:-8px;right:-8px;width:20px;height:20px;border-radius:50%;background:var(--accent);color:#fff;font-size:.6rem;font-weight:900;display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 1px 4px #0003;z-index:3}.map-overlay{position:absolute;top:16px;right:16px;background:var(--bg-card);border-radius:var(--radius-md);padding:14px 18px;box-shadow:var(--shadow-lg);z-index:5;min-width:200px}.map-overlay-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:4px}.map-overlay-name{font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:2px}.map-overlay-fill{font-size:1.6rem;font-weight:900;letter-spacing:-.03em}.map-overlay-meta{font-size:.75rem;color:var(--text-muted);margin-top:4px}.loading{display:flex;align-items:center;justify-content:center;height:100%;width:100%;font-size:.9rem;color:var(--text-muted);font-weight:500}.map-legend{position:absolute;bottom:24px;right:16px;width:fit-content;background:var(--bg-card);border-radius:var(--radius-md);padding:8px 12px;box-shadow:var(--shadow-md);z-index:999;display:flex;gap:10px;align-items:center;font-size:.7rem;pointer-events:none}.legend-item{display:flex;align-items:center;gap:5px;font-size:.68rem;font-weight:600;color:var(--text-secondary)}.legend-dot{width:8px;height:8px;border-radius:50%}.legend-dot.low{background:var(--fill-low)}.legend-dot.med{background:var(--fill-med)}.legend-dot.high{background:var(--fill-high)}.legend-dot.critical{background:var(--fill-critical)}@media(max-width:768px){.app{flex-direction:column}.icon-rail{display:none}.panel{width:100%;min-width:unset;height:45vh}.map-container{height:55vh}}.landing-page{min-height:100vh;background:var(--bg-primary);display:flex;flex-direction:column}.landing-header{display:flex;justify-content:space-between;align-items:center;padding:24px 60px;animation:fadeIn .5s ease-out}.landing-logo{display:flex;align-items:center;gap:12px}.logo-image{width:64px;height:64px}.logo-text{font-size:24px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.landing-hero{display:grid;grid-template-columns:1fr 1fr;gap:80px;max-width:1200px;margin:0 auto;padding:120px 60px;align-items:center;flex:1}.hero-content{display:flex;flex-direction:column}.hero-headline{font-size:56px;letter-spacing:-.04em;line-height:1.1;color:var(--text-primary);margin:0 0 24px;animation:fadeIn .6s ease-out .1s both}.headline-bold{font-weight:900}.headline-light{font-weight:500}.hero-subheading{font-size:18px;font-weight:500;line-height:1.6;color:var(--text-secondary);margin:0 0 32px;max-width:500px;animation:fadeIn .6s ease-out .2s both}.cta-primary{display:inline-flex;align-items:center;gap:8px;padding:16px 32px;background:var(--accent);color:#fff;font-size:16px;font-weight:700;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;box-shadow:0 4px 16px #2d6a4f4d;animation:fadeIn .6s ease-out .3s both;align-self:flex-start}.cta-primary:hover{background:#246050;transform:translateY(-2px);box-shadow:0 6px 24px #2d6a4f66}.cta-primary:active{transform:translateY(0)}.cta-arrow{transition:transform .2s}.cta-primary:hover .cta-arrow{transform:translate(4px)}.hero-visual{animation:fadeIn .7s ease-out .4s both;display:flex;justify-content:center;align-items:center}.dashboard-mockup{width:480px;height:360px;background:#fff;border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000014;display:grid;grid-template-columns:120px 1fr;overflow:hidden;transform:scale(.9);animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:scale(.9) translateY(0)}50%{transform:scale(.9) translateY(-8px)}}.mockup-sidebar{background:var(--bg-primary);padding:24px 16px;display:flex;flex-direction:column;gap:16px;border-right:1px solid var(--border)}.mockup-bin{height:60px;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.mockup-bin:after{content:"";position:absolute;bottom:0;left:0;right:0;height:40%;border-radius:0 0 var(--radius-md) var(--radius-md)}.mockup-bin.critical{background:#ffe5e5}.mockup-bin.critical:after{background:var(--fill-critical)}.mockup-bin.medium{background:#fff3e0}.mockup-bin.medium:after{background:var(--fill-med)}.mockup-bin.low{background:#e8f5e9}.mockup-bin.low:after{background:var(--fill-low)}.mockup-map{background:linear-gradient(135deg,#f5f5f0,#fff);position:relative;padding:32px}.mockup-marker{position:absolute;width:24px;height:24px;border-radius:50%;box-shadow:0 2px 8px #0003;animation:pulse 2s ease-in-out infinite}.marker-1{background:var(--fill-critical);top:20%;left:25%;animation-delay:0s}.marker-2{background:var(--fill-med);top:55%;left:60%;animation-delay:.3s}.marker-3{background:var(--fill-low);top:75%;left:35%;animation-delay:.6s}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}@media(max-width:1024px){.landing-header{padding:20px 40px}.landing-hero{gap:40px;padding:80px 40px}.hero-headline{font-size:48px}.hero-subheading{font-size:16px}.dashboard-mockup{width:400px;height:300px;transform:scale(.85)}@keyframes float{0%,to{transform:scale(.85) translateY(0)}50%{transform:scale(.85) translateY(-8px)}}}@media(max-width:768px){.landing-header{padding:16px 24px}.logo-image{width:48px;height:48px}.logo-text{font-size:20px}.landing-hero{grid-template-columns:1fr;gap:48px;padding:60px 24px}.hero-headline{font-size:36px}.hero-subheading{font-size:16px;max-width:100%}.cta-primary{width:100%;justify-content:center;padding:14px 24px}.hero-visual{order:-1}.dashboard-mockup{width:100%;max-width:360px;height:270px;transform:scale(1)}@keyframes float{0%,to{transform:scale(1) translateY(0)}50%{transform:scale(1) translateY(-6px)}}}@media(max-width:480px){.hero-headline{font-size:32px}.hero-subheading{font-size:15px}.dashboard-mockup{height:240px}}
