.route-page{min-height:100vh;padding-bottom:2rem}.route-page-content{max-width:800px;margin:0 auto;padding:1rem 1.5rem}.route-breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#94a3b8;margin-bottom:1.5rem}.route-breadcrumb a{color:#3b82f6;text-decoration:none}.route-breadcrumb a:hover{text-decoration:underline}.route-breadcrumb .separator{color:#475569}.route-breadcrumb .current{color:#e2e8f0}.route-header{margin-bottom:1.5rem}.route-header h1{font-size:1.75rem;font-weight:700;color:#f8fafc;margin:0 0 .5rem}.route-subtitle{font-size:1rem;color:#94a3b8;margin:0}.route-ai-summary{background:linear-gradient(135deg,#1e3a5f,#1e293b);border:1px solid #3b82f6;border-radius:12px;padding:1rem 1.25rem;margin-bottom:1.5rem}.ai-summary-badge{display:inline-block;font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#3b82f6;background:#3b82f626;padding:.25rem .5rem;border-radius:4px;margin-bottom:.75rem}.ai-summary-text{font-size:1rem;line-height:1.6;color:#e2e8f0;margin:0}.route-selectors{display:flex;align-items:flex-end;gap:.75rem;margin-bottom:1.5rem}.selector-group{flex:1;display:flex;flex-direction:column;gap:.375rem}.route-swap-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:#1e293b;border:1px solid #334155;border-radius:8px;color:#94a3b8;cursor:pointer;transition:all .15s ease;flex-shrink:0}.route-swap-btn:hover{background:#334155;border-color:#475569;color:#f8fafc}.route-swap-btn:active{transform:scale(.95)}.route-swap-btn svg{transform:rotate(90deg)}.selector-group label{font-size:.75rem;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.route-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#1e293b;border:1px solid #334155;border-radius:8px;padding:.75rem 2.5rem .75rem 1rem;font-size:1rem;color:#f8fafc;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.25rem}.route-select:hover{border-color:#475569}.route-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.route-status{margin-bottom:1.5rem}.route-section{margin-bottom:2rem}.route-section h2{font-size:1.125rem;font-weight:600;color:#f8fafc;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid #334155}.chain-list{display:flex;flex-direction:column;gap:.75rem}.chain-item{display:flex;align-items:center;gap:1rem;background:#1e293b;border-radius:8px;padding:.875rem 1rem;border-left:4px solid #475569}.chain-item.status-r-1{border-left-color:#f59e0b}.chain-item.status-r-2{border-left-color:#ef4444}.chain-item.status-r-3{border-left-color:#dc2626}.chain-item.status-closed{border-left-color:#dc2626;background:#2d1b1b}.chain-status{font-weight:700;font-size:.875rem;color:#f8fafc;min-width:80px}.chain-location{flex:1;display:flex;flex-direction:column;gap:.125rem}.chain-route{font-size:.75rem;color:#64748b}.chain-place{font-size:.9375rem;color:#e2e8f0}.chain-direction{font-size:.75rem;color:#64748b;text-transform:uppercase}.incident-list{display:flex;flex-direction:column;gap:.75rem}.incident-item{background:#1e293b;border-radius:8px;padding:1rem;border-left:4px solid #f59e0b}.incident-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.incident-type{font-weight:600;font-size:.8125rem;padding:.25rem .5rem;border-radius:4px;background:#f59e0b26;color:#f59e0b}.incident-type-collision{background:#ef444426;color:#ef4444}.incident-type-closure{background:#dc262626;color:#dc2626}.incident-type-hazard{background:#f59e0b26;color:#f59e0b}.incident-type-weather{background:#3b82f626;color:#3b82f6}.incident-unit-status{font-size:.75rem;color:#22c55e;font-weight:500}.incident-location{font-size:.9375rem;font-weight:500;color:#f8fafc;margin-bottom:.375rem}.incident-detail{font-size:.875rem;color:#cbd5e1;line-height:1.4;margin-bottom:.375rem}.incident-time{font-size:.75rem;color:#64748b}.signs-list{display:flex;flex-direction:column;gap:.5rem}.sign-item{display:flex;align-items:baseline;gap:.75rem;background:#1e293b;border-radius:6px;padding:.625rem .875rem}.sign-location{font-size:.75rem;font-weight:500;color:#64748b;white-space:nowrap;flex-shrink:0;min-width:100px}.sign-message{font-size:.875rem;color:#fbbf24;font-weight:500}.cameras-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.see-more-link{display:inline-block;margin-top:1rem;color:#3b82f6;text-decoration:none;font-size:.875rem}.see-more-link:hover{text-decoration:underline}.route-map-cta{margin:1.5rem 0}.resort-snow-list{display:flex;flex-direction:column;gap:.5rem}.resort-snow-item{display:flex;align-items:center;gap:.75rem;background:#1e293b;border-radius:8px;padding:.625rem 1rem;text-decoration:none;transition:background .15s ease}.resort-snow-item:hover{background:#334155}.resort-snow-logo{width:36px;height:36px;border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.resort-snow-logo img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.resort-snow-initial{font-size:1rem;font-weight:600;color:#94a3b8}.resort-snow-name{flex:1;font-size:.9375rem;font-weight:500;color:#f8fafc}.resort-snow-amount{font-size:1rem;font-weight:600;color:#64748b;min-width:40px;text-align:right}.resort-snow-amount.has-snow{color:#3b82f6}.route-guide{background:linear-gradient(180deg,#1e293b,#0f172a);border-radius:12px;padding:1.5rem;margin-top:1rem}.guide-intro{color:#cbd5e1;line-height:1.7;margin:0 0 1.5rem;font-size:1rem}.guide-stats{display:flex;gap:2rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #334155}.guide-stat{display:flex;flex-direction:column;gap:.25rem}.guide-stat-value{font-size:1.5rem;font-weight:700;color:#f8fafc}.guide-stat-label{font-size:.8125rem;color:#64748b}.guide-subsection{margin-bottom:2rem}.guide-subsection:last-child{margin-bottom:0}.guide-subsection h3{font-size:1rem;font-weight:600;color:#f8fafc;margin:0 0 1rem}.chain-locations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.chain-location-item{background:#334155;border-radius:8px;padding:.75rem 1rem;display:flex;flex-direction:column;gap:.25rem}.chain-location-name{font-size:.9375rem;font-weight:500;color:#f8fafc}.chain-location-meta{font-size:.75rem;color:#94a3b8}.trouble-spots-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.5rem}.trouble-spots-list li{position:relative;padding-left:1.25rem;color:#cbd5e1;font-size:.9375rem;line-height:1.5}.trouble-spots-list li:before{content:"";position:absolute;left:0;top:.5rem;width:6px;height:6px;background:#f59e0b;border-radius:50%}.faq-list{display:flex;flex-direction:column;gap:.5rem}.faq-item{background:#334155;border-radius:8px;overflow:hidden}.faq-question{padding:1rem;font-size:.9375rem;font-weight:500;color:#f8fafc;cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:1rem}.faq-question::-webkit-details-marker{display:none}.faq-question:after{content:"+";font-size:1.25rem;font-weight:400;color:#64748b;flex-shrink:0;transition:transform .2s ease}.faq-item[open] .faq-question:after{content:"−"}.faq-question:hover{color:#3b82f6}.faq-answer{padding:0 1rem 1rem;margin:0;color:#94a3b8;font-size:.9375rem;line-height:1.6}.route-map-link{display:inline-block;padding:.75rem 1.25rem;background:#1e40af;color:#f8fafc;border-radius:8px;text-decoration:none;font-weight:500;font-size:.9375rem;transition:background .15s ease}.route-map-link:hover{background:#1d4ed8}.route-not-found{text-align:center;padding:4rem 2rem}.route-not-found h1{font-size:1.5rem;color:#f8fafc;margin-bottom:.75rem}.route-not-found p{color:#94a3b8;margin-bottom:1.5rem}.route-not-found .back-link{color:#3b82f6;text-decoration:none}.route-not-found .back-link:hover{text-decoration:underline}.winter-driving-section{margin-top:1.5rem}.winter-driving-intro{color:#94a3b8;font-size:.9375rem;line-height:1.6;margin:0 0 1.5rem}.winter-driving-sections{display:flex;flex-direction:column;gap:.5rem}.winter-driving-item{background:#334155;border-radius:8px;overflow:hidden}.winter-driving-heading{padding:1rem;font-size:.9375rem;font-weight:500;color:#f8fafc;cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:1rem}.winter-driving-heading::-webkit-details-marker{display:none}.winter-driving-heading:after{content:"+";font-size:1.25rem;font-weight:400;color:#64748b;flex-shrink:0;transition:transform .2s ease}.winter-driving-item[open] .winter-driving-heading:after{content:"−"}.winter-driving-heading:hover{color:#3b82f6}.winter-driving-content{padding:0 1rem 1rem}.winter-driving-content p{margin:0;color:#cbd5e1;font-size:.9375rem;line-height:1.6}.winter-driving-content strong{color:#f8fafc;font-weight:500}.winter-driving-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.625rem}.winter-driving-list li{position:relative;padding-left:1.25rem;color:#cbd5e1;font-size:.9375rem;line-height:1.5}.winter-driving-list li:before{content:"";position:absolute;left:0;top:.5rem;width:6px;height:6px;background:#3b82f6;border-radius:50%}.winter-driving-list strong{color:#f8fafc;font-weight:500}@media(max-width:640px){.route-page-content{padding:1rem}.route-header h1{font-size:1.5rem}.route-selectors{flex-direction:row;flex-wrap:wrap;gap:.5rem}.route-selectors .selector-group{flex:1 1 calc(50% - 1.5rem);min-width:0}.route-selectors .selector-group:first-child{order:1}.route-swap-btn{order:3;width:100%;height:36px;margin-top:.25rem}.route-swap-btn svg{transform:rotate(0)}.route-selectors .selector-group:last-child{order:2}.route-select{padding:.625rem 2.25rem .625rem .875rem;font-size:.9375rem}.chain-item{flex-wrap:wrap}.chain-direction{width:100%;margin-top:.25rem}.cameras-grid{grid-template-columns:1fr}.route-stats{gap:1rem}}
