.homepage{min-height:100vh;background:var(--bg-primary);padding-bottom:2rem}.homepage-content{max-width:600px;margin:0 auto;padding:0 1rem}.route-selector-card{background:#1a1f2ef2;border:1px solid rgba(59,130,246,.3);border-radius:16px;padding:1rem;margin-bottom:1rem}.region-switcher{display:flex;gap:0;margin-bottom:1rem;background:var(--bg-primary);border-radius:8px;padding:4px;border:1px solid rgba(59,130,246,.2)}.region-pill{flex:1;padding:8px 12px;font-size:.8125rem;font-weight:500;border:none;border-radius:6px;cursor:pointer;transition:all .15s ease}.region-pill-active{background:var(--primary-blue);color:#fff}.region-pill-inactive{background:transparent;color:var(--text-tertiary)}.region-pill-inactive:hover{background:#3b82f61a;color:var(--text-secondary)}.route-inputs{display:flex;align-items:center;gap:12px}.route-dropdowns{flex:1;display:flex;flex-direction:column;gap:8px}.route-field{display:flex;align-items:center;gap:8px}.route-label{width:36px;font-size:.6875rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase}.route-dropdown{flex:1;padding:10px 12px;font-size:.875rem;font-weight:500;background:var(--bg-primary);border:1px solid rgba(59,130,246,.3);border-radius:8px;color:var(--text-primary);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.route-dropdown:focus{outline:none;border-color:var(--primary-blue)}.swap-btn{width:44px;height:44px;background:var(--surface);border:1px solid rgba(59,130,246,.3);border-radius:50%;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all .2s;flex-shrink:0}.swap-btn:hover{color:var(--primary-blue);border-color:var(--primary-blue);background:#3b82f61a}.status-card{border-radius:16px;padding:16px;margin-bottom:1rem}.status-card.good{background:linear-gradient(135deg,#22c55e26,#22c55e0d);border:2px solid rgba(34,197,94,.4)}.status-card.caution{background:linear-gradient(135deg,#eab30826,#eab3080d);border:2px solid rgba(234,179,8,.4)}.status-card.warning{background:linear-gradient(135deg,#ef444426,#ef44440d);border:2px solid rgba(239,68,68,.4)}.status-card.loading{background:var(--surface);border:2px solid var(--border)}.status-card.r1{background:linear-gradient(135deg,#3b82f626,#3b82f60d);border:2px solid rgba(59,130,246,.4)}.status-card.closed{background:linear-gradient(135deg,#ef444459,#ef444433);border:2px solid rgba(239,68,68,.7)}.status-header{margin-bottom:12px}.status-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.status-badge.good{background:#22c55e33;color:#22c55e}.status-badge.caution{background:#eab30833;color:#eab308}.status-badge.warning{background:#ef444433;color:#ef4444}.status-headline{font-size:1.125rem;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.status-detail{font-size:.8125rem;color:var(--text-secondary);margin-bottom:0}.status-detail+.chain-summary,.status-detail+.status-metrics{margin-top:16px}.chain-summary{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.chain-summary-item{background:#00000040;border-radius:8px;padding:10px 12px;border-left:3px solid}.chain-summary-item.r1{border-left-color:#60a5fa}.chain-summary-item.r2{border-left-color:#fbbf24}.chain-summary-item.r3{border-left-color:#f87171}.chain-summary-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.chain-status-badge{display:inline-block;font-size:.6875rem;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase;margin-right:8px;white-space:nowrap}.chain-summary-item.r1 .chain-status-badge{background:#3b82f64d;color:#60a5fa}.chain-summary-item.r2 .chain-status-badge{background:#eab3084d;color:#fbbf24}.chain-summary-item.r3 .chain-status-badge{background:#ef44444d;color:#f87171}.chain-status-label{font-size:.8125rem;font-weight:500;color:var(--text-primary)}.chain-locations{font-size:.75rem;color:var(--text-secondary)}.lane-closure-warnings{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.lane-closure-warning{display:flex;align-items:center;gap:6px}.lane-closure-warning .warning-icon{font-size:.75rem;color:#eab308}.lane-closure-warning .warning-text{font-size:.8125rem;color:var(--text-secondary)}.incident-warnings{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;padding:10px;background:#0003;border-radius:8px}.incident-warning{display:flex;align-items:flex-start;gap:8px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.08)}.incident-warning:last-child{border-bottom:none;padding-bottom:0}.incident-warning .incident-icon{font-size:1rem;flex-shrink:0;margin-top:1px}.incident-warning.weather .incident-icon{color:#60a5fa}.incident-warning.closure .incident-icon{color:#ef4444}.incident-warning.crash .incident-icon{color:#f97316}.incident-warning.minor .incident-icon,.incident-warning.major .incident-icon{color:#eab308}.incident-warning .incident-text{font-size:.8125rem;color:var(--text-secondary);line-height:1.4}.incident-warning .incident-text strong{color:var(--text-primary);font-weight:600}.incident-warning .incident-detail{color:var(--text-tertiary);font-size:.75rem}.incident-more{font-size:.75rem;color:var(--text-tertiary);text-align:center;padding-top:4px}.closure-details{margin-top:12px;display:flex;flex-direction:column;gap:12px}.closure-entry{display:flex;flex-direction:column;gap:2px}.closure-entry+.closure-entry{padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.closure-item{display:flex;align-items:center;gap:8px}.closure-label{font-size:.75rem;color:var(--text-tertiary);min-width:60px}.closure-value{font-size:.875rem;color:var(--text-primary)}.status-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.metric{text-align:center;padding:8px 4px;background:#0003;border-radius:8px}.metric-value{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.metric-value.delay{color:#eab308}.metric-value.severe-delay{color:#ef4444}.metric-value.no-delay{color:#22c55e}.metric-value.snow{color:var(--primary-blue)}.metric-label{font-size:.625rem;color:var(--text-tertiary);margin-top:2px;text-transform:uppercase;letter-spacing:.3px}.content-card{background:#1a1f2ef2;border:1px solid rgba(59,130,246,.3);border-radius:16px;margin-bottom:1rem;overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid rgba(255,255,255,.05)}.card-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.card-link{font-size:.8125rem;color:#14b8a6;text-decoration:none;transition:color .2s}.card-link:hover{color:#2dd4bf}.card-link-btn{background:none;border:none;font-size:.8125rem;color:#14b8a6;cursor:pointer;padding:0;transition:color .2s}.card-link-btn:hover{color:#2dd4bf}.card-body{padding:1rem}.map-container{background:#1a1f2ef2;border:1px solid rgba(59,130,246,.3);border-radius:16px;overflow:hidden;margin-bottom:1rem}.map-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.05)}.map-title{font-size:.875rem;font-weight:600;color:var(--text-primary)}.map-link{font-size:.75rem;color:#14b8a6;text-decoration:none}.map-display{height:280px;position:relative;background:linear-gradient(135deg,#1a2332,#243447)}.map-legend{position:absolute;bottom:12px;right:12px;display:flex;gap:12px;background:#0f1419e6;padding:8px 12px;border-radius:8px;font-size:.6875rem;z-index:10}.legend-item{display:flex;align-items:center;gap:4px;color:var(--text-secondary)}.legend-dot{width:8px;height:8px;border-radius:50%}.legend-dot.green{background:#22c55e}.legend-dot.yellow{background:#eab308}.legend-dot.red{background:#ef4444}.show-traffic-btn{position:absolute;bottom:12px;right:12px;display:flex;align-items:center;gap:6px;background:#0f1419e6;color:var(--text-secondary);border:1px solid rgba(255,255,255,.15);padding:8px 14px;border-radius:8px;font-size:.75rem;font-weight:500;cursor:pointer;z-index:10;transition:background .15s,color .15s,border-color .15s}.show-traffic-btn:hover{background:#1e2832f2;color:var(--text-primary);border-color:#ffffff40}.show-traffic-btn:disabled{opacity:.7;cursor:default}.show-traffic-btn .loading-spinner{width:12px;height:12px;border:2px solid rgba(255,255,255,.2);border-top-color:var(--text-secondary);border-radius:50%;animation:spin .8s linear infinite}.map-corridor-overlay{position:absolute;top:12px;left:12px;display:flex;align-items:center;gap:8px;background:#0f1419e6;padding:8px 12px;border-radius:8px;font-size:.8125rem;z-index:10}.map-corridor-overlay .legend-dot{width:10px;height:10px;flex-shrink:0}.map-corridor-overlay .corridor-text{color:var(--text-primary);font-weight:500}.map-corridor-overlay .corridor-delay{color:var(--text-tertiary);font-weight:400}.chain-zone-badge{display:flex;flex-direction:column;align-items:center;gap:2px;pointer-events:none}.chain-zone-badge .chain-status{background:#f97316;color:#fff;font-size:.5rem;font-weight:700;padding:1px 4px;border-radius:2px;box-shadow:0 1px 3px #0006}.chain-zone-badge.r3 .chain-status{background:#ef4444}.chain-zone-badge.closed .chain-status{background:#dc2626;font-size:.4375rem}.chain-zone-badge .chain-location{background:#0f1419e6;color:var(--text-primary);font-size:.5625rem;font-weight:500;padding:2px 5px;border-radius:3px;white-space:nowrap;margin-top:2px}.work-zone-badge{display:flex;align-items:center;justify-content:center;pointer-events:none}.work-zone-badge .work-icon{font-size:1rem;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.weather-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:8px;margin:0 -1rem;padding-left:1rem;padding-right:1rem;-webkit-overflow-scrolling:touch;scrollbar-width:none}.weather-scroll::-webkit-scrollbar{display:none}.weather-day-card{flex:0 0 72px;text-align:center;padding:12px 8px;background:#ffffff08;border-radius:12px;min-height:120px}.weather-day-card.today{background:#3b82f626;border:1px solid rgba(59,130,246,.3)}.weather-date{font-size:.75rem;font-weight:500;color:var(--text-tertiary);margin-bottom:8px}.weather-icon{display:flex;justify-content:center;align-items:center;margin-bottom:8px}.weather-temp{font-size:1rem;font-weight:600;color:var(--text-primary)}.weather-precip{font-size:.6875rem;color:#60a5fa;margin-top:4px}.weather-snow{font-size:.75rem;font-weight:600;color:var(--primary-blue);margin-top:4px;background:#3b82f626;padding:2px 6px;border-radius:4px;display:inline-block}.camera-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;margin:0 -1rem;padding-left:1rem;padding-right:1rem;-webkit-overflow-scrolling:touch;scrollbar-width:none}.camera-scroll::-webkit-scrollbar{display:none}.camera-thumb-large{flex:0 0 200px;border-radius:12px;overflow:hidden;background:var(--surface);transition:transform .2s,box-shadow .2s}.camera-thumb-large:hover{transform:scale(1.02);box-shadow:0 4px 12px #0000004d}.camera-container{position:relative;width:100%;height:120px;background:#000}.camera-img-large{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;background:linear-gradient(135deg,#1e293b,#334155);display:block}.camera-video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.camera-name-large{padding:10px 12px;font-size:.8125rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.camera-play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.camera-play-button{font-size:3rem;color:#fff;opacity:.8;text-shadow:0 2px 8px rgba(0,0,0,.5)}.camera-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#374151,#4b5563);display:flex;align-items:center;justify-content:center}.resort-list{display:flex;flex-direction:column;gap:12px}.resort-row{display:flex;align-items:center;gap:12px;padding:12px;background:#ffffff08;border-radius:12px}.resort-logo{width:40px;height:40px;background:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;color:#333;overflow:hidden}.resort-logo img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.resort-info{flex:1;min-width:0}.resort-name{font-size:.9375rem;font-weight:600;margin-bottom:2px;color:var(--text-primary)}.resort-base{font-size:.75rem;color:var(--text-tertiary)}.resort-snow-badge{text-align:right}.snow-amount{font-size:1.25rem;font-weight:700;color:var(--primary-blue)}.snow-label{font-size:.625rem;color:var(--text-tertiary);text-transform:uppercase}.skeleton{background:linear-gradient(90deg,#2a2a2a,#3a3a3a,#2a2a2a);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:4px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.homepage-map-marker{display:flex;flex-direction:column;align-items:center;pointer-events:none}.homepage-map-marker .marker-dot{width:12px;height:12px;border-radius:50%;border:2px solid white;box-shadow:0 2px 6px #0006}.homepage-map-marker.origin .marker-dot{background:#22c55e}.homepage-map-marker.dest .marker-dot{background:#ef4444}.homepage-map-marker .marker-label{font-size:.6875rem;color:var(--text-secondary);background:#0f1419e6;padding:2px 8px;border-radius:4px;margin-top:4px;white-space:nowrap}.homepage-marker{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;border:2px solid white;box-shadow:0 2px 6px #0000004d;transition:transform .15s ease}.homepage-marker:hover{transform:scale(1.15)}.homepage-marker.closure-marker.lane{background:#f97316}.homepage-marker.closure-marker.full{background:#991b1b}.homepage-marker.incident-marker{background:#dc2626}.homepage-map-popup .mapboxgl-popup-content{background:#1e293b;border-radius:12px;padding:0;min-width:220px;max-width:320px;box-shadow:0 4px 20px #0006;overflow:hidden}.homepage-map-popup .mapboxgl-popup-close-button{color:var(--text-tertiary);font-size:20px;padding:4px 8px;right:4px;top:4px}.homepage-map-popup .mapboxgl-popup-close-button:hover{color:var(--text-primary);background:#ffffff1a;border-radius:4px}.homepage-map-popup .mapboxgl-popup-tip{border-top-color:#1e293b}.popup-content{padding:0}.popup-header{padding:10px 12px;border-bottom:3px solid;background:#0003}.popup-status{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.popup-body{padding:10px 12px}.popup-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:6px}.popup-row:last-child{margin-bottom:0}.popup-label{font-size:.6875rem;color:var(--text-tertiary);text-transform:uppercase;flex-shrink:0}.popup-value{font-size:.8125rem;color:var(--text-primary);text-align:right}.popup-description{text-align:left;line-height:1.4;color:var(--text-secondary)}.popup-schedule{font-size:.6875rem;color:var(--text-secondary);text-align:right}@media(max-width:480px){.homepage-content{padding:0 .75rem}.status-metrics{grid-template-columns:repeat(2,1fr)}.weather-grid{grid-template-columns:repeat(5,1fr);gap:4px}.weather-day{padding:8px 2px}.weather-icon img{width:32px;height:32px}.weather-temp{font-size:.75rem}}
