:root{--bg:#0a0d10;--panel:#0f1215;--elev:#14181c;--text:#e9eef3;--muted:#8b95a5;--border:#1e252d;--ok:#44d07a;--warn:#ffd166;--bad:#ff6b6b;--accent:#ffdb00;--accent-hover:#e6c500;--accent-dark:#cca800}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font:15px/1.5 ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial}header{display:flex;gap:16px;align-items:center;padding:16px 24px;background:linear-gradient(135deg,#14181c,#0f1215);border-bottom:2px solid var(--accent);box-shadow:0 4px 12px #0000004d}.title{font-weight:800;font-size:20px;color:var(--accent);letter-spacing:-.5px}.muted{color:var(--muted)}.small{font-size:13px}.actions{margin-left:auto;display:flex;gap:12px}.btn{background:var(--elev);border:1px solid var(--border);color:var(--text);padding:10px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s ease}.btn:hover{background:var(--accent);border-color:var(--accent);color:#0a0d10;transform:translateY(-1px);box-shadow:0 4px 12px #36cccf4d}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn:focus-visible{outline:3px solid var(--accent);outline-offset:2px}#app{display:grid;grid-template-columns:380px 1fr;height:calc(100vh - 70px)}aside{background:var(--panel);border-right:1px solid var(--border);padding:16px;overflow:auto}.card{background:var(--elev);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:16px;transition:border-color .2s}.card:hover{border-color:#36cccf4d}.card h3{margin:0 0 12px;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--accent);font-weight:700}.row{display:grid;grid-template-columns:1fr auto;gap:12px;margin:8px 0;align-items:center}label.row{display:grid;grid-template-columns:1fr auto;gap:12px;margin:8px 0}label.checkbox{display:flex;gap:10px;align-items:center;margin:8px 0}#map{position:relative;background:#000}#leaflet{position:absolute;inset:0}.legend{position:absolute;right:16px;bottom:16px;background:#14181cf2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:12px;padding:14px 16px;z-index:999;box-shadow:0 8px 24px #0006}.risk-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid rgba(30,37,45,.5);font-size:12px;cursor:pointer;transition:all .2s ease}.risk-item:last-child{border-bottom:none}.risk-item:hover{color:var(--accent);transform:translate(2px)}.risk-mile{color:var(--muted);font-weight:600}.risk-score{font-weight:800;padding:2px 6px;border-radius:4px;font-size:11px;min-width:28px;text-align:center}.legend h4{margin:0 0 10px;font-size:12px;color:var(--accent);text-transform:uppercase;letter-spacing:1px;font-weight:700}.legend .line{display:flex;justify-content:space-between;gap:12px;margin:8px 0;font-size:13px}.swatch{width:70px;height:12px;border-radius:6px;border:1px solid rgba(0,0,0,.3)}.progress{height:8px;width:140px;background:#0a0d10;border:1px solid var(--border);border-radius:999px;overflow:visible;display:inline-block;position:relative}.bar{height:100%;width:0;background:var(--accent);display:block;transition:width .4s ease;box-shadow:0 0 8px #36cccf80}.progress-biker{position:absolute;top:-16px;left:0;font-size:20px;transition:left .4s ease;animation:bikerPedal .5s ease-in-out infinite;transform-origin:center;pointer-events:none;z-index:10;display:none}@keyframes bikerPedal{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-2px) rotate(-2deg)}50%{transform:translateY(0) rotate(0)}75%{transform:translateY(-2px) rotate(2deg)}}input[type=number],input[type=file]{width:100%;background:#0a0d10;color:var(--text);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:14px;transition:border-color .2s}input[type=number]:focus,input[type=file]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #36cccf1a}input[type=number]{width:100px}input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--accent)}input[type=checkbox]:focus-visible{outline:3px solid var(--accent);outline-offset:2px}.segment-overlay{position:absolute;bottom:0;left:0;right:0;max-height:50vh;background:#0f1215f7;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:0;overflow:hidden;z-index:1000;box-shadow:0 12px 48px #00000080;max-width:100vw}.segment-overlay.minimized{max-height:56px}.overlay-header{padding:16px 20px;background:linear-gradient(135deg,#36cccf26,#36cccf14);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s}.overlay-header:hover{background:linear-gradient(135deg,#36cccf40,#36cccf26)}.overlay-title{font-size:15px;font-weight:700;display:flex;align-items:center;gap:10px;color:var(--accent)}.toggle-icon{font-size:14px;transition:transform .3s ease;color:var(--accent)}.segment-overlay.minimized .toggle-icon{transform:rotate(180deg)}.filter-bar{padding:14px 20px;background:#0a0d10b3;border-bottom:1px solid var(--border)}.filter-input{width:100%;padding:10px 14px;background:#0a0d10e6;border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;transition:all .2s}.filter-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #36cccf1a}.filter-input::placeholder{color:var(--muted)}.overlay-header:focus-visible{outline:3px solid var(--accent);outline-offset:-3px}.risk-item:focus-visible{outline:3px solid var(--accent);outline-offset:-2px;background:#36cccf1a}.segment-list{overflow-y:auto;overflow-x:hidden;max-height:calc(50vh - 140px)}.segment-item{padding:14px 16px;border-bottom:1px solid rgba(30,37,45,.6);display:grid;grid-template-columns:60px 1fr 90px 110px;gap:12px;align-items:center;font-size:14px;cursor:pointer;transition:all .2s ease}.segment-item:hover{background:#36cccf14;border-left:3px solid var(--accent);padding-left:13px}.segment-item:focus-visible{outline:3px solid var(--accent);outline-offset:-3px;background:#36cccf1f}.segment-num{font-weight:700;color:var(--accent);font-size:13px}.segment-details{display:flex;flex-direction:column;gap:4px}.segment-road{font-weight:600;color:var(--text);font-size:14px}.segment-infra{font-size:12px;color:var(--muted);text-transform:capitalize}.segment-distance{color:var(--muted);font-size:13px}.segment-score{display:flex;align-items:center;gap:10px}.score-badge{padding:8px 14px;border-radius:8px;font-weight:800;font-size:15px;min-width:55px;text-align:center;box-shadow:0 2px 8px #0003}.score-bar{flex:1;height:8px;background:#0a0d1099;border-radius:4px;overflow:hidden}.score-fill{height:100%;transition:width .4s ease}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#0a0d1099}::-webkit-scrollbar-thumb{background:#36cccf4d;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#36cccf80}.mobile-results{display:none}@media(max-width:1024px)and (min-width:769px){#app{grid-template-columns:320px 1fr}aside{padding:12px}.card{padding:14px;margin-bottom:12px}.legend{right:12px;bottom:12px;padding:12px}.segment-overlay{max-height:45vh}.segment-item{grid-template-columns:50px 1fr 80px 100px;gap:10px;padding:12px 14px}}@media(max-width:768px){header{flex-wrap:wrap;padding:14px 16px;gap:12px}.title{font-size:17px;width:100%}header .muted{display:none}.actions{width:100%;gap:8px;flex-wrap:wrap}.btn{padding:12px 18px;font-size:15px;min-height:44px}#app{display:flex;flex-direction:column;height:calc(100vh - 86px)}aside{display:none;width:100%;flex:1;overflow-y:auto;border-right:none;border-bottom:2px solid var(--border)}aside:not(.mobile-hidden){display:block}aside.mobile-hidden{display:none!important}#map{flex:1;min-height:300px;position:relative}#leaflet{height:100%}.legend{display:none}.segment-overlay{display:none!important}.card{padding:16px;margin-bottom:14px;border-radius:10px}input[type=file],input[type=number]{padding:12px;font-size:16px}.progress{width:100%;height:10px}.progress-biker{font-size:24px;top:-18px}#drawRouteBtn{min-height:50px;font-size:16px;font-weight:700}#drawingControls{gap:10px!important}#drawingControls .btn{flex:1;min-height:48px;font-size:15px;font-weight:600}#waypointCount{font-size:14px;padding:8px;background:var(--elev);border-radius:8px}.waypoint-marker{transform:scale(1.2)}.mobile-results{height:60vh;overflow-y:auto;background:var(--bg);display:flex;flex-direction:column}.mobile-back-btn{position:sticky;top:0;left:0;right:0;z-index:100;background:var(--accent);color:#0a0d10;border:none;padding:14px;font-size:15px;font-weight:700;cursor:pointer;border-bottom:1px solid var(--border)}.mobile-back-btn:active{background:var(--accent-hover)}.mobile-score-card{background:var(--panel);padding:24px;border-bottom:2px solid var(--border);text-align:center;position:sticky;top:52px;z-index:10}.mobile-score-label{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent);margin-bottom:10px;font-weight:700}.mobile-score{font-size:72px;font-weight:900;line-height:1;margin-bottom:10px}.mobile-score-text{font-size:15px;font-weight:600;margin-bottom:18px}.mobile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}.mobile-stat{display:flex;flex-direction:column;gap:6px}.stat-value{font-size:20px;font-weight:700;color:var(--text)}.stat-label{font-size:10px;color:var(--accent);text-transform:uppercase;letter-spacing:.8px;font-weight:600}.mobile-segment-header{background:var(--panel);padding:14px;border-bottom:1px solid var(--border);position:sticky;top:52px;z-index:9}.mobile-segment-title{display:flex;justify-content:space-between;align-items:center;font-size:15px;font-weight:700;margin-bottom:10px;color:var(--accent)}.mobile-count{font-size:12px;color:var(--muted);font-weight:400}.mobile-filter{width:100%;padding:10px 14px;background:var(--elev);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px}.mobile-segment-list{flex:1;overflow-y:auto}.mobile-segment-list .segment-item{padding:14px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:10px;background:var(--panel);grid-template-columns:none}.mobile-segment-list .segment-item:active{background:#36cccf1a}.mobile-segment-list .segment-num{font-size:12px;font-weight:700;color:var(--accent)}.mobile-segment-list .segment-details{flex:1}.mobile-segment-list .segment-road{font-size:15px;font-weight:600;margin-bottom:4px}.mobile-segment-list .segment-infra{font-size:13px;color:var(--muted)}.mobile-segment-list .segment-score{display:flex;align-items:center;gap:14px}.mobile-segment-list .score-badge{padding:8px 14px;border-radius:8px;font-weight:800;font-size:17px}.mobile-segment-list .score-bar{flex:1;height:10px;background:#0a0d1099;border-radius:5px;overflow:hidden}.mobile-segment-list .segment-distance{font-size:13px;font-weight:600}}@media(max-width:480px){.title{font-size:15px}.btn{padding:10px 14px;font-size:14px}header .actions .btn{flex:1;min-width:0}.card h3{font-size:12px}#overallScore{font-size:42px!important}.mobile-score{font-size:56px}.mobile-stats{grid-template-columns:1fr;gap:10px}.mobile-stat{flex-direction:row;justify-content:space-between;align-items:center;padding:10px;background:var(--elev);border-radius:8px}.stat-value{font-size:18px}.stat-label{font-size:11px}.segment-item{padding:12px}}@media(max-width:768px)and (orientation:landscape){header{padding:8px 16px}.title{font-size:16px}.btn{padding:8px 12px;font-size:13px}#app{height:calc(100vh - 60px)}#map{min-height:200px}.card{padding:12px;margin-bottom:10px}}.welcome-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000000f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10000;overflow-y:auto;animation:fadeIn .3s ease}.welcome-modal.active{display:flex;align-items:flex-start;justify-content:center;padding:20px}.welcome-modal-content{background:linear-gradient(135deg,var(--panel) 0%,var(--bg) 100%);border:2px solid var(--accent);border-radius:16px;max-width:850px;width:100%;padding:32px;margin:20px auto;position:relative;box-shadow:0 20px 60px #36cccf4d;animation:slideUp .4s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.welcome-header{text-align:center;margin-bottom:24px;padding-bottom:20px;border-bottom:2px solid rgba(54,204,207,.3)}.welcome-title{font-size:36px;font-weight:900;color:var(--accent);margin:0 0 10px;letter-spacing:-1px}.welcome-subtitle{font-size:17px;color:var(--muted);margin:0;font-weight:600}.welcome-story{background:#36cccf14;border-left:4px solid var(--accent);border-radius:8px;padding:20px 24px;margin:24px 0}.welcome-story-text{font-size:16px;line-height:1.7;color:var(--text);margin:0;font-style:italic}.welcome-story-text strong{color:var(--accent);font-style:normal;font-weight:800}.welcome-section-title{font-size:24px;font-weight:800;color:var(--accent);margin:32px 0 20px;text-align:center;text-transform:uppercase;letter-spacing:1px}.welcome-feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:32px}.welcome-feature{background:var(--elev);border:1px solid var(--border);border-radius:10px;padding:18px;text-align:center;transition:all .3s ease}.welcome-feature:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 8px 24px #36cccf33}.welcome-feature-icon{font-size:40px;margin-bottom:12px}.welcome-feature h3{font-size:16px;font-weight:700;color:var(--text);margin:0 0 6px}.welcome-feature p{font-size:13px;color:var(--muted);margin:0;line-height:1.5}.welcome-sample-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:32px}.welcome-sample-item{background:var(--elev);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:all .3s ease}.welcome-sample-item:hover{border-color:var(--accent);box-shadow:0 8px 24px #36cccf33}.welcome-sample-screenshot{padding:14px}.sample-map-bg{background:#0a0d10;border-radius:8px;padding:16px;position:relative;height:160px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.sample-score-circle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#0f1215f2;border:2px solid #84cc16;border-radius:50%;width:90px;height:90px;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2}.sample-score-circle.dangerous{border-color:#ef4444}.sample-score-label{font-size:8px;color:var(--accent);letter-spacing:.5px;font-weight:700;text-transform:uppercase}.sample-score-value{font-size:32px;font-weight:900;color:#84cc16;line-height:1;margin:2px 0}.sample-score-value.safe{color:#10b981}.sample-score-circle.dangerous .sample-score-value{color:#ef4444}.sample-score-distance{font-size:10px;color:var(--muted);font-weight:600}.sample-route-path{position:absolute;inset:0;z-index:1}.route-svg{width:100%;height:100%;opacity:.8}.welcome-sample-caption{font-size:12px;color:var(--text);text-align:center;margin:0;line-height:1.5}.welcome-sample-caption strong{color:var(--accent);font-size:13px;display:block;margin-bottom:4px}.welcome-footer{text-align:center;padding-top:24px;border-top:2px solid rgba(54,204,207,.3);margin-top:32px}.welcome-action-buttons{display:flex;gap:12px;justify-content:center;align-items:center;margin-bottom:20px}.welcome-coffee-btn{display:inline-block;background:#fd0;color:#000;font-weight:700;font-size:15px;padding:12px 24px;border-radius:8px;text-decoration:none;transition:all .2s ease;box-shadow:0 4px 12px #ffdd004d}.welcome-coffee-btn:hover{background:#ffe84d;transform:translateY(-2px);box-shadow:0 6px 16px #fd06}.welcome-strava-btn{display:inline-block;background:#fc4c02;color:#fff;font-weight:700;font-size:15px;padding:12px 24px;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #fc4c024d}.welcome-strava-btn:hover{background:#e84402;transform:translateY(-2px);box-shadow:0 6px 16px #fc4c0266}.welcome-analyze-btn{display:inline-block;background:var(--accent);color:#0a0d10;font-weight:700;font-size:15px;padding:12px 24px;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #36cccf66}.welcome-analyze-btn:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 6px 16px #36cccf80}.welcome-disclaimer{font-size:12px;color:var(--muted);line-height:1.6;margin:0}.welcome-disclaimer-link{color:#eab308;text-decoration:underline;font-weight:600}.welcome-disclaimer-link:hover{color:#fbbf24}@media(max-width:768px){.welcome-modal.active{padding:0;align-items:flex-start}.welcome-modal-content{padding:20px;margin:0;border-radius:0;max-height:100vh;overflow-y:auto}.welcome-title{font-size:28px;margin-top:16px}.welcome-subtitle,.welcome-story-text{font-size:15px}.welcome-feature-grid,.welcome-sample-grid{grid-template-columns:1fr;gap:12px}.welcome-section-title{font-size:20px}.welcome-action-buttons{flex-direction:column;gap:10px}.welcome-analyze-btn,.welcome-coffee-btn,.welcome-strava-btn{width:100%;padding:14px 20px}}@media(max-width:480px){.welcome-title{font-size:24px}.welcome-story{padding:14px 16px}.welcome-story-text{font-size:14px}.welcome-analyze-btn,.welcome-coffee-btn,.welcome-strava-btn{font-size:14px;padding:12px 20px}.sample-map-bg{height:140px}.sample-score-circle{width:80px;height:80px}.sample-score-value{font-size:28px}}
