:root{--bg: #0D0D0E;--card: #18181B;--card-border: #27272A;--elev: #18181B;--panel: #18181B;--text: #FAFAFA;--muted: #A1A1AA;--border: #27272A;--ok: #10B981;--warn: #F59E0B;--bad: #EF4444;--accent: #FACC15;--accent-hover: #EAB308;--accent-dark: #CA8A04;--accent-rgb: 250, 204, 21;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--glass-bg: rgba(24, 24, 27, .85);--glass-border: rgba(250, 204, 21, .12);--glass-blur: blur(12px)}.theme-toggle-map{position:fixed;bottom:24px;left:16px;z-index:10001;width:44px;height:44px;border-radius:var(--radius-md);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s,background .2s;pointer-events:auto}.theme-toggle-map:hover{color:var(--accent);background:var(--surface-hover)}.app--results .theme-toggle-map,.theme-icon-moon,[data-map-theme=light] .theme-icon-sun{display:none}[data-map-theme=light] .theme-icon-moon{display:block}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--text);font:15px/1.5 Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#facc1533;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#facc1566}.muted{color:var(--muted)}.small{font-size:13px}.btn{background:var(--card);border:1px solid var(--border);color:var(--text);padding:10px 16px;border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s ease;display:inline-flex;align-items:center;gap:6px}.btn:hover{background:var(--accent);border-color:var(--accent);color:#0a0a0a;transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--accent-rgb),.3)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}#app{position:fixed;inset:0;width:100vw;height:100vh}#mobileContentSlot{display:none}#map{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:0;background:#000}#leaflet{position:absolute;inset:0;z-index:0}.top-bar{position:fixed;top:0;left:0;right:0;height:48px;z-index:50;display:flex;align-items:center;padding:0 16px;gap:12px;background:linear-gradient(to bottom,#0d0d0ee0,#0d0d0e00);pointer-events:none}.top-bar>*{pointer-events:auto}header.top-bar{border:none;box-shadow:none}.title{font-weight:900;font-size:18px;color:var(--accent);letter-spacing:-.5px;text-shadow:0 2px 8px rgba(0,0,0,.6);text-decoration:none;cursor:pointer;transition:opacity .15s}.title:hover{opacity:.8}.actions{margin-left:auto;display:flex;gap:8px;align-items:center}.header-nav-links{display:flex;gap:4px;align-items:center}.nav-link-btn{padding:6px 10px;font-size:12px;font-weight:500;color:#fff9;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm)}.nav-link-btn:hover{color:var(--text);background:#ffffff14;border-color:transparent;transform:none;box-shadow:none}.mobile-menu-btn{display:none;padding:7px 9px;background:#18181bb3;border:1px solid var(--border);color:var(--muted);border-radius:var(--radius-sm)}.mobile-menu-btn:hover{background:#18181bf2;border-color:#facc154d;transform:none;box-shadow:none;color:var(--accent)}@media(max-width:768px){.header-nav-links{display:none;position:absolute;top:52px;right:8px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);padding:8px;flex-direction:column;gap:2px;z-index:300;min-width:160px;box-shadow:0 8px 24px #00000080}.header-nav-links.mobile-nav-open{display:flex}.nav-link-btn{width:100%;justify-content:flex-start;padding:10px 14px;font-size:14px;color:var(--text);background:transparent;border-color:transparent}.mobile-menu-btn{display:flex;align-items:center;justify-content:center}}.control-center{position:absolute;top:60px;left:16px;width:320px;max-height:calc(100vh - 76px);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);z-index:100;overflow:hidden;box-shadow:0 8px 32px #00000080,0 1px #ffffff0a inset;display:flex;flex-direction:column;transition:all .3s cubic-bezier(.4,0,.2,1)}.cc-modify-btn{display:none!important}.cc-header{padding:14px 16px 0;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.cc-brand{font-size:13px;font-weight:800;color:var(--accent);letter-spacing:.5px;text-transform:uppercase}.cc-tabs{display:flex;gap:2px;background:#0000004d;border-radius:var(--radius-sm);padding:2px}.cc-tab{padding:5px 12px;font-size:12px;font-weight:600;border-radius:6px;border:none;background:transparent;color:var(--muted);cursor:pointer;transition:all .15s ease}.cc-tab--active,.cc-tab[aria-selected=true]{background:var(--accent);color:#0a0a0a}.cc-tab:hover:not(.cc-tab--active):not([aria-selected=true]){color:var(--text)}.cc-body{overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-y;overscroll-behavior:contain;flex:1;min-height:0;display:flex;flex-direction:column;padding:10px 0 0}.cc-pane{padding:0 12px 8px}.cc-section-header{display:flex;justify-content:space-between;align-items:center;padding:8px 4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:var(--radius-sm);transition:color .15s}.cc-section-header:hover{color:var(--accent)}.collapse-chevron{font-size:10px;transition:transform .2s;color:var(--muted)}.card-collapse-body{overflow:hidden;transition:all .25s ease}#uploadCard.collapsed .card-collapse-body{display:none}#uploadCard.collapsed .collapse-chevron{transform:rotate(180deg)}#plannerCard.collapsed .card-collapse-body{display:none}.cc-draw-btn{width:100%;margin-bottom:6px;background:#facc151a;border:1px solid rgba(250,204,21,.3);color:var(--accent);font-weight:700;border-radius:var(--radius-md);justify-content:center}.cc-draw-btn:hover{background:var(--accent);color:#0a0a0a}.cc-finish-btn{flex:1;background:var(--ok);border-color:transparent;color:#061a2b;font-weight:700;justify-content:center}.cc-gpx-btn{width:100%;background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#10b981;font-weight:700;border-radius:var(--radius-md);justify-content:center;pointer-events:none}.cc-progress-row{padding:8px 12px 4px}.progress{height:6px;width:100%;background:#ffffff0f;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;border-radius:999px;box-shadow:0 0 8px rgba(var(--accent-rgb),.5)}.progress-biker{position:absolute;top:-14px;left:0;font-size:18px;transition:left .4s ease;animation:bikerPedal .5s ease-in-out infinite;pointer-events:none;z-index:10;display:none}@keyframes bikerPedal{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.cc-actions{padding:8px 12px;display:flex;gap:8px;flex-shrink:0}.cc-run-btn{flex:1;background:#2ca48a;border-color:transparent;color:#061a2b;font-weight:800;font-size:14px;border-radius:var(--radius-md);justify-content:center}.cc-run-btn:hover{background:#25907a;color:#fff;border-color:transparent}.cc-clear-btn{border-radius:var(--radius-md)}.cc-secondary-actions{padding:0 12px 12px;display:flex;gap:8px}.cc-save-btn{flex:1;background:#10b9811a;border-color:#10b9814d;color:#10b981;font-weight:700;border-radius:var(--radius-md);justify-content:center;font-size:13px}.cc-save-btn:hover{background:#10b981;border-color:#10b981;color:#fff}.cc-export-btn{flex:1;background:#facc151a;border-color:#facc154d;color:var(--accent);font-weight:700;border-radius:var(--radius-md);justify-content:center;font-size:13px}.app--results .control-center{display:none}.app--results .cc-body{opacity:0;pointer-events:none}.app--results .cc-modify-btn{display:flex!important}.control-center.cc-expanded .cc-body{opacity:1;pointer-events:auto}.control-center.cc-expanded{max-height:calc(100vh - 76px);overflow:hidden}.control-center.cc-expanded .cc-modify-btn{background:#facc150f;border-bottom:1px solid var(--border)}.insights-panel{position:absolute;top:60px;left:16px;width:320px;max-height:calc(100vh - 76px);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);z-index:100;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-y;overscroll-behavior:contain;display:flex;flex-direction:column;visibility:hidden;opacity:0;transform:translateY(8px);transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1),visibility .3s;box-shadow:0 8px 32px #00000080,0 1px #ffffff0a inset}.insights-panel.ip-visible{visibility:visible;opacity:1;transform:translateY(0)}.ip-score-section{padding:16px 20px;background:linear-gradient(180deg,rgba(250,204,21,.04) 0%,transparent 100%);border-bottom:1px solid var(--border)}.new-analysis-btn{display:inline-flex;align-items:center;padding:8px 14px;border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border);color:var(--text);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.new-analysis-btn:hover{background:var(--surface-hover, rgba(255,255,255,.08));border-color:var(--accent)}.gauge-container{position:relative;display:flex;flex-direction:column;align-items:center;margin-bottom:8px}.score-gauge{width:200px;height:110px;overflow:visible}.gauge-track{stroke:var(--border);stroke-width:10;stroke-linecap:round}.gauge-fill{stroke:url(#gaugeGradient);stroke-width:10;stroke-linecap:round;stroke-dasharray:0 267;transition:stroke-dasharray .8s cubic-bezier(.4,0,.2,1),stroke .4s ease;filter:drop-shadow(0 0 6px rgba(250,204,21,.4))}.ip-score-value{font-size:52px;font-weight:900;letter-spacing:-3px;line-height:1;text-align:center;margin-top:-20px;color:var(--muted);font-variant-numeric:tabular-nums}.ip-score-label{text-align:center;font-size:13px;font-weight:600;color:var(--muted);line-height:1.5;margin-top:6px}.score-legend-chips{display:flex;flex-wrap:wrap;gap:4px;margin-top:10px;margin-bottom:4px;justify-content:center}.legend-chip{font-size:10px;font-weight:600;font-variant-numeric:tabular-nums;opacity:.75}.ip-section,.ip-summary-section{padding:14px 20px;border-bottom:1px solid var(--border)}.ip-section-title{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--accent);font-weight:700;margin-bottom:10px}.ip-stat-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:5px 0;font-size:13px;color:var(--muted);border-bottom:1px solid rgba(255,255,255,.04)}.ip-stat-row:last-child{border-bottom:none}.ip-stat-value{color:var(--text);font-weight:700;font-size:13px;font-variant-numeric:tabular-nums;text-align:right}.top-risks-badges{display:flex;flex-direction:column;gap:6px}.risk-item{display:flex;justify-content:space-between;align-items:center;padding:7px 10px;border-left:3px solid transparent;border-radius:var(--radius-sm);background:#ffffff08;font-size:12px;cursor:pointer;transition:all .15s ease}.risk-item:hover{background:#facc150f;border-left-color:var(--accent);transform:translate(2px)}.risk-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.risk-mile{color:var(--muted);font-weight:600}.risk-score{font-weight:800;padding:2px 8px;border-radius:4px;font-size:11px;min-width:28px;text-align:center}.segment-overlay{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.segment-overlay--hidden{display:none!important}.overlay-header{padding:12px 20px;background:#facc150a;border-bottom:1px solid var(--border);border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s;flex-shrink:0}.overlay-header:hover{background:#facc1514}.overlay-header:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.overlay-title{font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px;color:var(--accent)}.toggle-icon{font-size:12px;transition:transform .25s ease;color:var(--muted)}.segment-overlay.minimized .toggle-icon{transform:rotate(180deg)}.segment-overlay.minimized .filter-bar,.segment-overlay.minimized .segment-list{display:none}.filter-bar{padding:10px 20px;background:#0003;border-bottom:1px solid var(--border);flex-shrink:0}.filter-input{width:100%;padding:8px 12px;background:#0006;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);font-size:13px;transition:all .15s}.filter-input:focus{outline:none;border-color:#facc1566;box-shadow:0 0 0 2px #facc1514}.filter-input::placeholder{color:var(--muted)}.segment-list{overflow-y:auto;flex:1;min-height:0;max-height:40vh}.segment-item{display:flex;align-items:center;gap:10px;height:40px;padding:0 12px;border-bottom:1px solid rgba(255,255,255,.04);border-left:4px solid transparent;cursor:pointer;transition:all .15s ease;font-size:13px}.segment-item:hover,.segment-item.segment-hover-active{background:#facc150d;border-left-color:var(--accent)}.segment-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.segment-num{font-weight:700;color:var(--accent);font-size:11px;min-width:44px;font-variant-numeric:tabular-nums}.segment-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.segment-road{font-weight:600;color:var(--text);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.segment-infra{font-size:11px;color:var(--muted)}.segment-distance{font-size:11px;font-weight:600;color:var(--muted);font-variant-numeric:tabular-nums;text-align:right;min-width:40px}.segment-score{display:flex;align-items:center;gap:6px;min-width:70px}.score-badge{width:30px;height:30px;padding:0;border-radius:6px;font-weight:800;font-size:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-variant-numeric:tabular-nums}.score-bar{display:none}.segment-skeleton{display:flex;gap:10px;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.04);align-items:center}.skel-block{border-radius:4px;background:#ffffff0f;animation:skelPulse 1.4s ease-in-out infinite}@keyframes skelPulse{0%,to{opacity:.4}50%{opacity:.8}}.cc-support-link,.ip-support-link{display:flex;justify-content:center;margin-top:10px}.ip-post-actions{display:flex;gap:8px;justify-content:center;align-items:center;margin-top:12px;flex-wrap:wrap}.ip-download-btn{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#10b981;font-size:12px;font-weight:600;padding:6px 12px;border-radius:var(--radius-md)}.ip-download-btn:hover{background:#10b981;border-color:#10b981;color:#fff}.ip-footer{padding:20px 20px 16px;border-top:1px solid var(--border);flex-shrink:0;display:flex;justify-content:center;margin-top:auto}.ip-coffee-link{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--muted);text-decoration:none;padding:6px 12px;border-radius:var(--radius-md);border:1px solid var(--border);transition:all .2s ease}.ip-coffee-link:hover{color:var(--accent);border-color:#facc154d;background:#facc150d}.infra-bar-wrap{padding:0 20px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.infra-bar-track{height:8px;border-radius:4px;overflow:hidden;display:flex;background:#ffffff0f;margin-bottom:6px;gap:0}.infra-seg{height:100%;transition:width .6s cubic-bezier(.4,0,.2,1);min-width:0}.infra-seg--protected{background:#10b981}.infra-seg--painted{background:#facc15}.infra-seg--none{background:#ef4444;opacity:.7}.infra-bar-legend{display:flex;justify-content:space-between;gap:4px}.infra-leg{font-size:10px;font-weight:700;color:var(--muted)}.infra-leg--protected{color:#10b981}.infra-leg--painted{color:#facc15}.infra-leg--none{color:#ef4444}.map-toolbox{position:absolute;top:50%;transform:translateY(-50%);right:16px;z-index:100;display:flex;flex-direction:column;gap:6px;pointer-events:none;transition:right .35s cubic-bezier(.4,0,.2,1)}.app--results .map-toolbox{right:16px}.toolbox-btn{width:40px;height:40px;border-radius:var(--radius-md);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:17px;transition:all .2s ease;position:relative;pointer-events:auto;padding:0;box-shadow:0 2px 8px #00000059}.toolbox-btn:hover{background:#18181bfa;border-color:#facc1573;color:var(--accent);transform:translate(-3px)}.toolbox-btn.active{border-color:var(--accent);color:var(--accent);background:#facc1514}.toolbox-btn.loading{opacity:.6;cursor:not-allowed}.toolbox-btn:before{content:attr(data-tooltip);position:absolute;right:calc(100% + 10px);top:50%;transform:translateY(-50%);background:#0d0d0ef7;border:1px solid var(--border);border-radius:var(--radius-sm);padding:5px 10px;font-size:11px;font-weight:600;white-space:nowrap;color:var(--text);pointer-events:none;opacity:0;transition:opacity .15s ease}.toolbox-btn:hover:before{opacity:1}.legend-bar{position:absolute;bottom:16px;left:50%;transform:translate(-50%);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 14px;z-index:50;min-width:300px;max-width:400px;box-shadow:0 4px 16px #0006;transition:left .35s ease,transform .35s ease}.app--results .legend-bar{left:50%;transform:translate(-50%)}.legend-bar-gradient{height:8px;border-radius:4px;background:linear-gradient(to right,#dc2626,#ef4444,#f97316,#eab308,#84cc16,#22c55e,#10b981);margin-bottom:6px}.legend-bar-ticks{display:flex;justify-content:space-between;font-size:10px;color:var(--muted);font-weight:700;font-variant-numeric:tabular-nums}.legend-bar-labels{display:flex;justify-content:space-between;font-size:9px;color:var(--muted);margin-top:2px}.score-actions{display:flex;gap:8px;margin:12px auto 0;justify-content:center}.safer-routes-panel-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;border-radius:var(--radius-md);border:1.5px solid var(--accent);background:var(--accent);color:#0a0a0a;font-size:12px;font-weight:700;white-space:nowrap;cursor:pointer;transition:background .15s ease}.safer-routes-panel-btn:hover{background:var(--accent-hover)}input[type=number],input[type=file],input[type=text]{width:100%;background:#0006;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-md);padding:8px 12px;font-size:13px;transition:border-color .15s}input:focus{outline:none;border-color:#facc1566;box-shadow:0 0 0 2px #facc1514}input[type=number]{width:90px}input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--accent)}.row{display:grid;grid-template-columns:1fr auto;gap:12px;margin:6px 0;align-items:center;font-size:13px}.planner-input{width:100%;background:#0006;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 12px;font-size:13px;font-family:inherit;resize:vertical;min-height:80px;transition:border-color .15s;margin-bottom:8px}.planner-input:focus{outline:none;border-color:#facc1566;box-shadow:0 0 0 2px #facc1514}.planner-input::placeholder{color:var(--muted);font-size:12px}.planner-chips{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.planner-example-chip{background:#facc1514;border:1px solid rgba(250,204,21,.2);color:var(--accent);padding:4px 10px;border-radius:99px;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}.planner-example-chip:hover{background:var(--accent);color:#0a0a0a;border-color:var(--accent)}.planner-find-btn{width:100%;background:var(--accent);border-color:transparent;color:#0a0a0a;font-weight:800;border-radius:var(--radius-md);justify-content:center;margin-bottom:8px}.planner-find-btn:hover{background:var(--accent-hover);border-color:transparent;color:#0a0a0a}.planner-status{font-size:12px;color:var(--muted);padding:6px 0}.planner-results-list{display:flex;flex-direction:column;gap:6px}.planner-result-card{background:#00000059;border:1px solid var(--border);border-radius:var(--radius-md, 12px);padding:14px;margin-bottom:6px}.planner-ai-card{border-color:#6366f140}.prc-header{margin-bottom:10px}.prc-label{display:inline-block;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:700;letter-spacing:.02em}.prc-stats{display:flex;gap:16px;margin-bottom:10px}.prc-stat{display:flex;align-items:baseline;gap:3px}.prc-stat-value{font-size:18px;font-weight:800;color:var(--text)}.prc-stat-unit{font-size:11px;color:var(--muted);font-weight:500}.prc-summary{font-size:13px;line-height:1.5;color:var(--muted);margin:0 0 12px}.ai-steps-list{list-style:none;margin:0 0 12px;padding:0;display:flex;flex-direction:column;gap:0}.ai-step{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.05)}.ai-step:last-child{border-bottom:none}.ai-step-num{flex-shrink:0;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#6366f126;color:#818cf8;font-size:11px;font-weight:700;margin-top:1px}.ai-step-body{flex:1;display:flex;flex-direction:column;gap:4px}.ai-step-text{font-size:13px;line-height:1.45;color:var(--text)}.ai-step-dist{display:inline-block;font-size:11px;font-weight:600;color:var(--accent);background:#facc1514;padding:2px 7px;border-radius:4px;margin-top:2px;width:fit-content}.ai-step-note{display:block;font-size:11.5px;line-height:1.4;color:var(--muted);font-style:italic;margin-top:2px;padding-left:1px}.ai-safety-notes{list-style:none;margin:0 0 10px;padding:10px 12px;background:#ef44440f;border:1px solid rgba(239,68,68,.15);border-radius:8px;display:flex;flex-direction:column;gap:6px}.ai-safety-note{font-size:12px;line-height:1.45;color:#fca5a5}.ai-plan-review-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:8px 12px;margin-top:8px;background:#6366f11a;border:1px solid rgba(99,102,241,.25);border-radius:var(--radius-md, 12px);color:#818cf8;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.ai-plan-review-btn:hover{background:#6366f12e;border-color:#6366f166}.ai-plan-overlay{position:fixed;inset:0;background:#000000a6;z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px}.ai-plan-modal{background:#1a1d22;border:1px solid #2a2d35;border-radius:14px;padding:20px;max-width:480px;width:100%;max-height:80vh;overflow-y:auto;color:var(--text);font-family:inherit}.ai-plan-modal .modal-close-btn{width:100%;padding:10px;margin-top:12px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:var(--text);font-weight:600;font-size:13px;cursor:pointer}.ai-plan-modal .modal-close-btn:hover{background:#ffffff24}.endpoint-adjust-hint{font-size:11px;color:var(--muted);text-align:center;padding:6px 0 2px;line-height:1.4}.prc-bullets{list-style:none;margin:0 0 12px;padding:0}.prc-bullet{font-size:12.5px;line-height:1.5;color:var(--muted);padding:3px 0 3px 14px;position:relative}.prc-bullet:before{content:"•";position:absolute;left:0;color:var(--accent)}.planner-results-heading{font-size:12px;font-weight:600;color:var(--muted);margin:0 0 8px}.planner-waypoint-warning{font-size:12px;color:#f59e0b;margin:0 0 8px;line-height:1.4}.bike-verified-badge{width:100%;margin-top:8px;background:#facc150d;border:1px solid rgba(250,204,21,.18);border-radius:var(--radius-sm);padding:6px 10px;display:flex;align-items:center;gap:7px;cursor:pointer;transition:all .2s ease;text-align:left}.bike-verified-badge:hover{background:#facc151a;border-color:#facc1566;transform:none;box-shadow:none}.badge-checkmark{color:var(--accent);font-size:13px;font-weight:900;flex-shrink:0}.badge-content{flex:1;display:flex;flex-direction:column;gap:1px}.badge-eyebrow{font-size:8px;color:var(--accent);text-transform:uppercase;letter-spacing:.8px;font-weight:700;opacity:.8}.badge-title{font-size:11px;font-weight:700;color:var(--text);line-height:1.2}.badge-cta{color:var(--accent);font-size:13px;flex-shrink:0}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(80px);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 20px;font-size:14px;font-weight:600;color:var(--text);z-index:99999;box-shadow:0 8px 24px #0006;transition:transform .3s cubic-bezier(.34,1.56,.64,1),opacity .3s ease;opacity:0;pointer-events:none;white-space:nowrap}.toast.show{transform:translate(-50%) translateY(0);opacity:1}.toast.success{border-color:var(--ok);color:var(--ok)}.toast.error{border-color:var(--bad);color:var(--bad)}#overallScore{font-size:52px;font-weight:900;letter-spacing:-3px;line-height:1;text-align:center;color:var(--muted);font-variant-numeric:tabular-nums}.score-circle-container{position:relative;width:120px;height:120px;margin:8px auto;display:flex;align-items:center;justify-content:center}.score-ring{position:absolute;inset:0;width:100%;height:100%;transform:rotate(-90deg)}.score-ring-bg{fill:none;stroke:var(--border);stroke-width:8}.score-ring-fill{fill:none;stroke:var(--muted);stroke-width:8;stroke-linecap:round;stroke-dasharray:314;stroke-dashoffset:314;transition:stroke-dashoffset .8s cubic-bezier(.4,0,.2,1),stroke .4s ease}.card{background:#ffffff08;border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;margin-bottom:8px;transition:border-color .15s}.card:hover{border-color:#facc1533}.card h3{margin:0 0 10px;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--accent);font-weight:700}.card-header,.collapsible-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.improve-summary{font-size:13px;color:var(--text);line-height:1.6;margin-bottom:16px}.improve-cards-list{display:flex;flex-direction:column;gap:10px}.improve-card{background:#ffffff08;border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;transition:border-color .15s}.improve-card:hover{border-color:#facc154d}.improve-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.improve-card-label{font-size:12px;font-weight:700;padding:3px 8px;border-radius:4px;background:#facc1526;color:var(--accent);text-transform:uppercase;letter-spacing:.5px}.improve-card-est{font-size:12px}.delta-positive{color:var(--ok);font-weight:700}.delta-neutral{color:var(--muted)}.improve-card-stats{display:flex;gap:14px;margin-bottom:8px;font-size:12px;color:var(--text)}.improve-card-stats span{display:flex;flex-direction:column;gap:1px}.improve-card-stats .stat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.improve-card-stats .stat-delta{font-size:10px;color:var(--muted)}.improve-card-stats .stat-delta.positive{color:#f97316}.improve-card-stats .stat-delta.negative{color:var(--ok)}.improve-card-desc{font-size:12px;color:var(--muted);line-height:1.5;margin:0 0 8px}.improve-card-bullets{margin:0 0 10px;padding:0;list-style:none}.improve-card-bullets li{font-size:12px;color:var(--muted);line-height:1.5;padding-left:14px;position:relative;margin-bottom:3px}.improve-card-bullets li:before{content:"·";position:absolute;left:4px;color:var(--accent)}.improve-card-btn{width:100%;background:transparent;border:1px solid var(--border);color:var(--text);padding:7px 12px;border-radius:var(--radius-sm);cursor:pointer;font-size:12px;font-weight:700;transition:all .2s}.improve-card-btn:hover{background:var(--accent);border-color:var(--accent);color:#0a0a0a}.improve-loading{font-size:12px;color:var(--muted);padding:8px 0;display:flex;align-items:center;gap:8px}.improve-loading:before{content:"";display:inline-block;width:12px;height:12px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.mobile-results{display:none}.welcome-modal{display:none;position:fixed;inset:0;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}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.welcome-modal-content{background:linear-gradient(135deg,var(--card) 0%,var(--bg) 100%);border:2px solid var(--accent);border-radius:var(--radius-xl);max-width:850px;width:100%;padding:32px;margin:20px auto;box-shadow:0 20px 60px rgba(var(--accent-rgb),.2);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(var(--accent-rgb),.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:rgba(var(--accent-rgb),.07);border-left:4px solid var(--accent);border-radius:var(--radius-sm);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(--card);border:1px solid var(--border);border-radius:var(--radius-md);padding:18px;text-align:center;transition:all .3s ease}.welcome-feature:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 8px 24px rgba(var(--accent-rgb),.2)}.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(--card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;transition:all .3s ease}.welcome-sample-item:hover{border-color:var(--accent);box-shadow:0 8px 24px rgba(var(--accent-rgb),.2)}.welcome-sample-screenshot{padding:14px}.sample-map-bg{background:#0a0a0a;border-radius:var(--radius-sm);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:#0d0d0ef2;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(var(--accent-rgb),.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:var(--radius-sm);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:var(--radius-sm);border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #fc4c024d}.welcome-strava-btn:hover{background:#e84402;transform:translateY(-2px)}.welcome-analyze-btn{display:inline-block;background:var(--accent);color:#0a0a0a;font-weight:700;font-size:15px;padding:12px 24px;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px rgba(var(--accent-rgb),.4)}.welcome-analyze-btn:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 6px 16px rgba(var(--accent-rgb),.5)}.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(min-width:769px){.app--results #map{width:100%}}@media(max-width:768px){html,body{overflow-y:auto;height:auto}#app{position:relative;display:flex;flex-direction:column;min-height:100vh;width:100%}#map{position:relative;width:100%;height:40vh;min-height:40vh;flex-shrink:0;z-index:0}#leaflet{position:absolute;inset:0}.top-bar{position:absolute;height:48px;z-index:50}.control-center{position:relative;inset:auto;width:100%;max-height:none;border-radius:0;z-index:10;background:var(--card);backdrop-filter:none;-webkit-backdrop-filter:none;border:none;border-top:1px solid var(--border);box-shadow:none;padding-top:1rem}.control-center:before{display:none}.app--results .control-center{display:none}.app--results .cc-body{opacity:1;pointer-events:auto}.insights-panel{position:relative;top:auto;left:auto;width:100%;height:auto;min-height:60vh;transform:none!important;opacity:1;visibility:hidden;display:none;border:none;border-top:2px solid var(--border);border-radius:0;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;background:#18181bfa;overflow-y:auto;-webkit-overflow-scrolling:touch;max-height:none;z-index:10}.insights-panel .ip-score-section{padding-top:20px}.insights-panel.ip-visible{display:flex;visibility:visible}.segment-list{max-height:none}.segment-overlay{overflow:visible}.map-toolbox{position:absolute;top:50%;transform:translateY(-50%);right:12px}.app--results .map-toolbox{right:12px;bottom:auto;top:50%;transform:translateY(-50%);flex-direction:column}.legend-bar{min-width:240px;bottom:8px}.ip-footer{order:1;border-top:1px solid var(--border);padding:12px 20px}.bike-verified-badge{margin-top:12px}#mobileContentSlot{display:flex;flex-direction:column;width:100%;z-index:10;background:var(--bg)}.welcome-feature-grid,.welcome-sample-grid{grid-template-columns:1fr}.welcome-action-buttons{flex-direction:column;gap:10px}.welcome-analyze-btn,.welcome-coffee-btn,.welcome-strava-btn{width:100%;padding:14px 20px}.welcome-modal-content{padding:20px;margin:0;border-radius:0}.welcome-modal.active{padding:0;align-items:flex-start}#drawingControls{flex-wrap:wrap}#drawingControls .cc-finish-btn{flex:1 0 100%}body.drawing-active .control-center{display:none!important}body.drawing-active #map{height:100vh;min-height:100vh}body.drawing-active .mobile-drawing-dock{display:flex;flex-direction:column;gap:8px;position:fixed;left:0;right:0;bottom:0;padding:12px 12px calc(12px + env(safe-area-inset-bottom,0px));background:#18181bf2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border);box-shadow:0 -4px 20px #0006;z-index:200}body.drawing-active .mobile-drawing-dock #waypointCount{display:block!important;margin:0!important;text-align:center;color:var(--muted);font-size:12px}body.drawing-active .mobile-drawing-dock #drawingControls{display:flex!important;flex-wrap:wrap;gap:8px;margin:0!important}body.drawing-active .mobile-drawing-dock #drawingControls .cc-finish-btn{flex:1 0 100%;padding:12px 16px;font-size:15px}body.drawing-active .mobile-drawing-exit{align-self:center;padding:6px 12px;background:transparent;border:none;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;border-radius:var(--radius-sm)}body.drawing-active .mobile-drawing-exit:hover,body.drawing-active .mobile-drawing-exit:focus-visible{color:var(--text);background:#ffffff0f}}.mobile-drawing-dock{display:none}.empty-state-hint{text-align:center;color:var(--muted);font-size:12px;padding:8px 0 4px;line-height:1.5}.card.analyzing{border-color:rgba(var(--accent-rgb),.4);box-shadow:0 0 0 1px rgba(var(--accent-rgb),.15)}@media(max-width:768px){html{scroll-behavior:smooth}body{overscroll-behavior-y:contain;-webkit-tap-highlight-color:transparent}#map{position:sticky;top:0;z-index:5;height:42dvh;min-height:280px;box-shadow:0 6px 14px -8px #00000080}.app--results #map{height:60dvh;min-height:60dvh}#app{min-height:100dvh}#mobileContentSlot{position:relative;z-index:6;padding-bottom:max(env(safe-area-inset-bottom),24px)}.insights-panel{-webkit-overflow-scrolling:touch;overflow-y:visible;min-height:0;overscroll-behavior:contain;transform:none!important}.insights-panel.ip-visible{animation:mobileSlideUp .32s cubic-bezier(.2,.9,.3,1) both}@keyframes mobileSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.insights-panel .ip-score-section{padding:22px 18px 18px}.segment-item,#mobileSegmentList .segment-item{min-height:56px;padding:12px 14px;align-items:center;gap:10px;touch-action:manipulation}.segment-item+.segment-item{border-top:1px solid rgba(255,255,255,.04)}.segment-item:active{background:#ffdb000f}.segment-item .score-badge{min-width:36px;min-height:28px;display:inline-flex;align-items:center;justify-content:center;font-weight:700}#mobileFilterInput{height:44px;font-size:16px;padding:0 14px}.control-center button,.cc-run-btn,.cc-draw-btn,.cc-gpx-btn{min-height:44px;touch-action:manipulation}.map-toolbox button,.map-toolbox a{min-width:40px;min-height:40px}.app--results .theme-toggle-map{display:none}}@media(max-width:380px){.insights-panel .ip-score-section{flex-direction:column;align-items:stretch;gap:12px}}@media(max-width:768px){.strava-combined-modal{align-items:stretch!important;padding:0!important;overflow:hidden!important}.strava-combined-modal__card{padding:16px!important;border-radius:0!important;border:none!important;border-top:2px solid #fc4c02!important;max-width:100%!important;max-height:100dvh!important;height:100dvh!important;padding-top:max(16px,env(safe-area-inset-top))!important;padding-bottom:max(16px,env(safe-area-inset-bottom))!important}.strava-combined-modal__scroll{flex:1 1 auto!important;min-height:0!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important;overscroll-behavior:contain!important;padding-bottom:8px}.strava-combined-modal .route-item,.strava-combined-modal .activity-item{padding:14px!important;min-height:64px}.strava-combined-modal .route-item:active,.strava-combined-modal .activity-item:active{background:#fc4c021f!important}}@media(max-width:768px){body.drawing-active .mobile-drawing-dock #drawingControls .cc-finish-btn,#drawingControls .cc-finish-btn{background:var(--accent)!important;border-color:var(--accent)!important;color:#0a0a0a!important;font-weight:800}body.drawing-active .mobile-drawing-dock #drawingControls .cc-finish-btn:disabled,#drawingControls .cc-finish-btn:disabled{background:var(--accent-dark)!important;color:#0a0a0a!important;opacity:.85}}body.v2{--bg: #0D0D0E;--card: #18181B;--card-border: #27272A;--panel: #18181B;--text: #FAFAFA;--muted: #A1A1AA;--border: #27272A;--ok: #10B981;--warn: #F59E0B;--bad: #EF4444;--accent: #ffdb00;--accent-hover: #e6c500;--accent-dark: #b89e00;--accent-rgb: 255, 219, 0;--accent-glow: rgba(255, 219, 0, .12);--surface: #1C1C1F;--surface-hover: #232326;--glass-bg: rgba(24, 24, 27, .82);--glass-border: rgba(255, 219, 0, .08);--glass-blur: blur(20px);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg)}body.v2 ::-webkit-scrollbar-thumb{background:#ffdb0026}body.v2 ::-webkit-scrollbar-thumb:hover{background:#ffdb004d}.hub-overlay{position:fixed;inset:0;z-index:10000;background:var(--bg);overflow-y:auto;-webkit-overflow-scrolling:touch;animation:hubFadeIn .5s ease forwards}@keyframes hubFadeIn{0%{opacity:0}to{opacity:1}}.hub-overlay.hub-exit{animation:hubFadeOut .4s ease forwards}@keyframes hubFadeOut{0%{opacity:1}to{opacity:0;pointer-events:none}}.hub-inner{max-width:1080px;margin:0 auto;padding:60px 32px 80px}.hub-header{text-align:center;margin-bottom:56px}.hub-logo{font-size:42px;font-weight:900;color:var(--accent);letter-spacing:-1.5px;margin-bottom:12px;line-height:1}.hub-tagline{font-size:17px;color:var(--muted);font-weight:500;margin:0;letter-spacing:.2px}.hub-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:64px}.hub-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px 28px 28px;cursor:pointer;transition:all .35s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;display:flex;flex-direction:column}.hub-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);opacity:0;transition:opacity .35s ease}.hub-card:hover{border-color:#ffdb004d;transform:translateY(-6px);box-shadow:0 16px 48px #0006,0 0 0 1px #ffdb0014 inset}.hub-card:hover:before{opacity:1}.hub-card-icon{width:48px;height:48px;border-radius:var(--radius-md);background:#ffdb0014;border:1px solid rgba(255,219,0,.15);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:20px;flex-shrink:0}.hub-card-title{font-size:20px;font-weight:800;color:var(--text);margin-bottom:8px;letter-spacing:-.3px}.hub-card-desc{font-size:14px;color:var(--muted);line-height:1.6;margin:0;flex:1}.hub-card-cta{display:inline-flex;align-items:center;gap:6px;margin-top:20px;font-size:13px;font-weight:700;color:var(--accent);letter-spacing:.3px;transition:gap .2s ease}.hub-card:hover .hub-card-cta{gap:10px}.hub-story{max-width:720px;margin:0 auto 64px}.hub-story-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.hub-story-label{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:2px;color:var(--accent)}.hub-story-line{flex:1;height:1px;background:var(--border)}.hub-story-body{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px;position:relative}.hub-story-body:before{content:"";position:absolute;top:0;left:32px;right:32px;height:1px;background:linear-gradient(90deg,transparent,rgba(255,219,0,.2),transparent)}.hub-story-narrative{font-size:16px;line-height:1.8;color:var(--text);margin:0 0 16px}.hub-story-narrative strong{color:var(--accent);font-weight:700}.hub-story-mission{font-size:15px;color:var(--muted);line-height:1.7;margin:0 0 16px;padding-left:16px;border-left:3px solid var(--accent)}.hub-story-impact{font-size:14px;color:var(--muted);line-height:1.6;margin:0}.hub-story-stats{display:flex;gap:24px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.hub-stat{text-align:center}.hub-stat-value{font-size:24px;font-weight:900;color:var(--accent);letter-spacing:-1px;line-height:1}.hub-stat-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.hub-footer{text-align:center;padding-top:32px;border-top:1px solid var(--border)}.hub-support-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:#ffdb000f;border:1px solid rgba(255,219,0,.2);border-radius:var(--radius-md);color:var(--accent);font-size:14px;font-weight:700;text-decoration:none;transition:all .25s ease;cursor:pointer}.hub-support-btn:hover{background:#ffdb001f;border-color:#ffdb0066;transform:translateY(-2px);box-shadow:0 4px 16px #ffdb0026}.hub-disclaimer{font-size:12px;color:var(--muted);margin-top:16px;line-height:1.5}.hub-disclaimer a{color:var(--accent);text-decoration:underline;font-weight:600}.v2-persistent-support{position:fixed;bottom:20px;right:20px;z-index:9998;display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid rgba(255,219,0,.15);border-radius:var(--radius-md);color:var(--accent);font-size:12px;font-weight:700;text-decoration:none;transition:all .25s ease;box-shadow:0 4px 16px #0000004d}.v2-persistent-support:hover{background:#ffdb001a;border-color:#ffdb0059;transform:translateY(-2px);box-shadow:0 6px 24px #0006}.v2-persistent-support svg{fill:var(--accent);flex-shrink:0}.pillar-nav{position:fixed;top:0;left:0;right:0;height:44px;z-index:200;display:flex;align-items:center;padding:0 16px;gap:12px;background:#0d0d0eeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.pillar-nav-home{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--radius-sm);background:transparent;border:1px solid var(--border);color:var(--muted);font-size:12px;font-weight:700;cursor:pointer;transition:all .2s ease}.pillar-nav-home:hover{border-color:#ffdb004d;color:var(--accent);background:#ffdb000d}.pillar-nav-title{font-size:13px;font-weight:800;color:var(--accent);letter-spacing:.5px;text-transform:uppercase}.pillar-nav-sep{color:var(--border);font-size:14px}body.v2.v2-pillar-active .top-bar{top:44px}body.v2.v2-pillar-active .control-center,body.v2.v2-pillar-active .insights-panel{top:108px}.velo-overlay{position:fixed;inset:0;z-index:150;background:var(--bg);padding-top:44px}.velo-iframe-wrap{width:100%;height:100%}.velo-iframe{width:100%;height:100%;border:none;display:block}body.v2 .btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);font-weight:600;transition:all .25s cubic-bezier(.4,0,.2,1)}body.v2 .btn:hover{background:var(--accent);border-color:var(--accent);color:#0a0a0a;box-shadow:0 4px 20px rgba(var(--accent-rgb),.25);transform:translateY(-1px)}body.v2 .top-bar{background:linear-gradient(to bottom,var(--bg) 0%,transparent 100%);height:52px}body.v2 .title{color:var(--accent);font-size:19px;font-weight:900;letter-spacing:-.3px;text-shadow:0 0 20px rgba(var(--accent-rgb),.3)}body.v2 .nav-link-btn{color:#fafafa80;border-radius:var(--radius-sm);transition:all .2s ease}body.v2 .nav-link-btn:hover{color:var(--text);background:#ffdb000f}body.v2 .control-center{background:var(--glass-bg);backdrop-filter:var(--glass-blur) saturate(1.3);-webkit-backdrop-filter:var(--glass-blur) saturate(1.3);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:0 12px 40px #00000080,0 1px #ffffff08 inset;top:64px;transition:all .35s cubic-bezier(.4,0,.2,1)}body.v2 .cc-brand{color:var(--accent);font-size:12px;letter-spacing:1.5px}body.v2 .cc-tabs{background:#00000059;border-radius:var(--radius-sm);padding:3px}body.v2 .cc-tab{border-radius:8px;padding:5px 14px;font-size:12px;transition:all .2s ease}body.v2 .cc-tab--active,body.v2 .cc-tab[aria-selected=true]{background:var(--accent);color:#0a0a0a;box-shadow:0 2px 8px rgba(var(--accent-rgb),.25)}body.v2 .cc-draw-btn{background:#ffdb000f;border:1px solid rgba(255,219,0,.2);color:var(--accent);border-radius:var(--radius-md);transition:all .25s ease}body.v2 .cc-draw-btn:hover{background:var(--accent);color:#0a0a0a;box-shadow:0 4px 16px rgba(var(--accent-rgb),.25)}body.v2 .cc-gpx-btn{background:#10b98114;border:1px solid rgba(16,185,129,.25);color:var(--ok);border-radius:var(--radius-md)}body.v2 .cc-run-btn{background:var(--accent);border:none;color:#0a0a0a;font-weight:800;border-radius:var(--radius-md);box-shadow:0 4px 16px rgba(var(--accent-rgb),.25);transition:all .25s ease}body.v2 .cc-run-btn:hover{background:var(--accent-hover);box-shadow:0 6px 24px rgba(var(--accent-rgb),.35);transform:translateY(-2px);color:#0a0a0a}body.v2 .cc-save-btn{background:#10b98114;border-color:#10b98140;color:var(--ok)}body.v2 .cc-save-btn:hover{background:var(--ok);color:#fff}body.v2 .cc-export-btn{background:#ffdb000f;border-color:#ffdb0033;color:var(--accent)}body.v2 .bar{background:var(--accent);box-shadow:0 0 12px rgba(var(--accent-rgb),.4)}body.v2 .cc-section-header:hover{color:var(--accent)}body.v2 .insights-panel{background:var(--glass-bg);backdrop-filter:var(--glass-blur) saturate(1.3);-webkit-backdrop-filter:var(--glass-blur) saturate(1.3);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:0 12px 40px #00000080,0 1px #ffffff08 inset;top:64px;transition:opacity .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1),visibility .35s}body.v2 .insights-panel.ip-visible{animation:v2SlideIn .4s cubic-bezier(.16,1,.3,1) forwards}@keyframes v2SlideIn{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}body.v2 .ip-score-section{background:linear-gradient(180deg,rgba(255,219,0,.04) 0%,transparent 100%);border-bottom:1px solid var(--border);padding:20px 20px 16px}body.v2 .gauge-fill{filter:drop-shadow(0 0 6px rgba(var(--accent-rgb),.35));transition:stroke-dasharray 1s cubic-bezier(.4,0,.2,1),stroke .5s ease}body.v2 .gauge-track{stroke:var(--border)}body.v2 .ip-score-value,body.v2 #overallScore{font-weight:900;letter-spacing:-3px}body.v2 .ip-section-title{color:var(--accent);font-size:11px;letter-spacing:1.5px}body.v2 .ip-stat-row{border-bottom:1px solid rgba(255,255,255,.03);padding:6px 0}body.v2 .legend-chip{opacity:.85}body.v2 .safer-routes-panel-btn{background:var(--accent);border-color:var(--accent);color:#0a0a0a;border-radius:var(--radius-md);box-shadow:0 4px 12px rgba(var(--accent-rgb),.2);transition:all .25s ease}body.v2 .safer-routes-panel-btn:hover{background:var(--accent-hover);box-shadow:0 6px 20px rgba(var(--accent-rgb),.35)}body.v2 .new-analysis-btn{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-md)}body.v2 .new-analysis-btn:hover{border-color:var(--accent);background:#ffdb000f}body.v2 .risk-item{background:#ffffff05;border-radius:var(--radius-sm);transition:all .2s ease}body.v2 .risk-item:hover{background:#ffdb000a;border-left-color:var(--accent)}body.v2 .overlay-header{background:#ffdb0008;border-bottom-color:var(--border)}body.v2 .overlay-header:hover{background:#ffdb000f}body.v2 .overlay-title{color:var(--accent)}body.v2 .segment-item:hover,body.v2 .segment-item.segment-hover-active{background:#ffdb000a;border-left-color:var(--accent)}body.v2 .segment-num{color:var(--accent)}body.v2 .filter-input:focus{border-color:#ffdb0059;box-shadow:0 0 0 3px #ffdb000f}body.v2 .ip-download-btn{background:#10b98114;border-color:#10b98140;color:var(--ok);border-radius:var(--radius-md)}body.v2 .ip-download-btn:hover{background:var(--ok);color:#fff}body.v2 .ip-coffee-link:hover{color:var(--accent);border-color:#ffdb0040;background:#ffdb000a}body.v2 .toolbox-btn{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 4px 12px #0006;transition:all .25s ease}body.v2 .toolbox-btn:hover{border-color:#ffdb0059;color:var(--accent)}body.v2 .toolbox-btn.active{border-color:var(--accent);color:var(--accent);background:#ffdb000f}body.v2 .legend-bar{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:0 8px 24px #0006}body.v2 .planner-input{background:#0000004d;border:1px solid var(--border);border-radius:var(--radius-md)}body.v2 .planner-input:focus{border-color:#ffdb0059;box-shadow:0 0 0 3px #ffdb000f}body.v2 .planner-example-chip{background:#ffdb000f;border-color:#ffdb0026;color:var(--accent)}body.v2 .planner-example-chip:hover{background:var(--accent);color:#0a0a0a;border-color:var(--accent)}body.v2 .planner-find-btn{background:var(--accent);color:#0a0a0a;border:none;box-shadow:0 4px 16px rgba(var(--accent-rgb),.2)}body.v2 .planner-find-btn:hover{background:var(--accent-hover);color:#0a0a0a;box-shadow:0 6px 24px rgba(var(--accent-rgb),.35)}body.v2 .planner-result-card{background:var(--glass-bg);border-color:var(--glass-border);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur)}body.v2 .planner-ai-card{border-color:#6366f133}body.v2 .ai-step{border-bottom-color:#ffffff0a}body.v2 .ai-step-num{background:#6366f11f}body.v2 .ai-safety-notes{background:#ef44440d;border-color:#ef44441f}body.v2 .ai-plan-review-btn{background:#6366f114;border-color:#6366f133}body.v2 .ai-plan-review-btn:hover{background:#6366f126;border-color:#6366f159}body.v2 .ai-plan-modal{background:var(--card);border-color:var(--card-border)}body.v2 .bike-verified-badge{background:#ffdb000a;border-color:#ffdb0026}body.v2 .bike-verified-badge:hover{background:#ffdb0014;border-color:#ffdb0059}body.v2 .badge-checkmark,body.v2 .badge-eyebrow,body.v2 .badge-cta{color:var(--accent)}body.v2 .improve-card{background:#ffffff05;border:1px solid var(--border);border-radius:var(--radius-md)}body.v2 .improve-card:hover{border-color:#ffdb0040}body.v2 .improve-card-label{background:#ffdb001f;color:var(--accent)}body.v2 .improve-card-btn:hover{background:var(--accent);border-color:var(--accent);color:#0a0a0a}body.v2 .improve-loading:before{border-top-color:var(--accent)}body.v2 .toast{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 12px 32px #00000080}body.v2 .toast.success{border-color:var(--ok);color:var(--ok)}body.v2 .toast.error{border-color:var(--bad);color:var(--bad)}body.v2 input:focus{border-color:#ffdb0059;box-shadow:0 0 0 3px #ffdb000f}body.v2 input[type=checkbox]{accent-color:var(--accent)}body.v2 .card{border-radius:var(--radius-md)}body.v2 .card:hover{border-color:#ffdb0026}body.v2 .card h3{color:var(--accent)}body.v2 .card.analyzing{border-color:rgba(var(--accent-rgb),.35);box-shadow:0 0 0 1px rgba(var(--accent-rgb),.12)}body.v2 .skel-block{background:#ffdb000a}body.v2 .strava-login-btn,body.v2 .rwgps-login-btn{border-radius:var(--radius-md)!important}body.v2 .welcome-modal{display:none!important}@media(max-width:768px){.hub-cards{grid-template-columns:1fr;gap:14px}.hub-inner{padding:40px 20px 80px}.hub-logo{font-size:32px}.hub-story-stats{flex-wrap:wrap;gap:16px}body.v2 .control-center{background:var(--card);border-top:1px solid var(--border)}body.v2 .insights-panel,body.v2.v2-pillar-active .insights-panel{background:#18181bfa;border-top:2px solid rgba(255,219,0,.1);top:auto}body.v2 .control-center,body.v2.v2-pillar-active .control-center{top:auto}body.v2 .header-nav-links{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 8px 32px #0009}body.v2 .mobile-menu-btn:hover{border-color:#ffdb0040;color:var(--accent)}.v2-persistent-support{bottom:12px;right:12px;padding:8px 12px;font-size:11px}.pillar-nav{height:40px;padding:0 12px}body.v2.v2-pillar-active .top-bar{top:40px}body.v2.v2-pillar-active .control-center{top:auto}}body.v2 .hub-user-bar{display:flex;align-items:center;gap:10px;margin-left:auto;padding:0 4px;flex-shrink:0}body.v2 .hub-user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid var(--accent);flex-shrink:0}body.v2 .hub-user-name{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;max-width:140px;overflow:hidden;text-overflow:ellipsis}body.v2 .hub-strava-connect{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:#fc4c02;color:#fff;font-size:12px;font-weight:600;border-radius:var(--radius-sm);text-decoration:none;transition:opacity .2s;white-space:nowrap}body.v2 .hub-strava-connect:hover{opacity:.85}body.v2 .hub-signout{display:inline-flex;align-items:center;padding:5px 10px;background:transparent;border:1px solid var(--border);color:var(--muted);font-size:12px;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:border-color .2s,color .2s;white-space:nowrap}body.v2 .hub-signout:hover{border-color:var(--bad);color:var(--bad)}body.v2 .google-signin-gate{position:fixed;inset:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;gap:24px}body.v2 .google-signin-gate .gate-logo{font-size:28px;font-weight:700;letter-spacing:-.5px;color:var(--text)}body.v2 .google-signin-gate .gate-logo span{color:var(--accent)}body.v2 .google-signin-gate .gate-tagline{font-size:15px;color:var(--muted);text-align:center;max-width:320px;line-height:1.5}body.v2 .google-signin-gate .gate-btn{display:inline-flex;align-items:center;gap:12px;padding:12px 24px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);font-size:15px;font-weight:500;cursor:pointer;transition:background .2s,border-color .2s}body.v2 .google-signin-gate .gate-btn:hover{background:var(--surface-hover);border-color:var(--accent)}body.v2 .google-signin-gate .gate-btn img{width:20px;height:20px}body.v2 .google-signin-gate .gate-error{font-size:13px;color:var(--bad);text-align:center;max-width:300px}@media(max-width:768px){body.v2 .hub-user-name{display:none}body.v2 .hub-user-bar{gap:6px}body.v2 .hub-strava-connect,body.v2 .hub-signout{font-size:11px;padding:4px 8px}}
