.user-avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;font-size:.75rem;font-weight:700;color:#000;cursor:pointer;border:2px solid transparent;flex-shrink:0;transition:border-color .15s,opacity .15s;background:none;padding:0;line-height:1;letter-spacing:0}.user-avatar:hover{border-color:#fff6;opacity:.9}.user-avatar--sm{width:26px;height:26px;font-size:.65rem}.user-switcher-wrapper{position:relative}.user-switcher-panel{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:#1a1a2e;border:1px solid rgba(255,255,255,.12);border-radius:10px;box-shadow:0 8px 24px #00000080;z-index:500;overflow:hidden;animation:us-fade-in .12s ease}@keyframes us-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.user-switcher-panel-header{padding:10px 14px 8px;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:#fff6;border-bottom:1px solid rgba(255,255,255,.08)}.user-switcher-list{list-style:none;margin:0;padding:4px 0}.user-switcher-item{display:flex;align-items:center;gap:10px;padding:8px 14px;cursor:pointer;transition:background .1s}.user-switcher-item:hover{background:#ffffff0f}.user-switcher-item--active{background:#ffffff0a}.user-switcher-item-name{flex:1;font-size:.9rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-switcher-item-name--active{font-weight:600}.user-switcher-check{font-size:.85rem;color:#00d4ff;flex-shrink:0}.user-switcher-actions{display:flex;gap:2px;flex-shrink:0}.user-switcher-icon-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:6px;background:none;border:none;cursor:pointer;color:#ffffff73;transition:background .1s,color .1s;padding:0}.user-switcher-icon-btn:hover{background:#ffffff1a;color:#fff}.user-switcher-icon-btn--danger:hover{background:#ff505026;color:#ff6b6b}.user-switcher-rename-row{display:flex;align-items:center;gap:6px;padding:4px 14px}.user-switcher-name-input{flex:1;background:#ffffff14;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:.85rem;padding:5px 8px;outline:none}.user-switcher-name-input:focus{border-color:#00d4ff}.user-switcher-confirm-btn{background:#00d4ff;border:none;border-radius:6px;color:#000;font-size:.8rem;font-weight:700;padding:5px 10px;cursor:pointer;white-space:nowrap}.user-switcher-confirm-btn:hover{background:#3df}.user-switcher-cancel-btn{background:none;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff9;font-size:.8rem;padding:5px 8px;cursor:pointer}.user-switcher-cancel-btn:hover{background:#ffffff0f}.user-switcher-footer{border-top:1px solid rgba(255,255,255,.08);padding:6px 0 4px}.user-switcher-add-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 14px;background:none;border:none;color:#fff9;font-size:.85rem;cursor:pointer;text-align:left;transition:background .1s,color .1s}.user-switcher-add-btn:hover{background:#ffffff0f;color:#fff}.user-switcher-add-icon{width:26px;height:26px;border-radius:50%;border:1.5px dashed rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.user-switcher-add-form{padding:6px 14px 10px}*{box-sizing:border-box;margin:0;padding:0}:focus-visible{outline:2px solid var(--primary-blue);outline-offset:3px}.skip-link{position:absolute;top:-9999px;left:0;z-index:9999;padding:.75rem 1.25rem;background:var(--primary-blue);color:#000;font-weight:700;font-size:.95rem;border-radius:0 0 8px;text-decoration:none}.skip-link:focus-visible{top:0}:root{--font-headline: "Teko", "Arial Narrow", sans-serif;--font-body: "Ubuntu", "Segoe UI", sans-serif;--primary-blue: #00D4A6;--primary-rgb: 0, 212, 166;--dark-blue: #00A884;--light-blue: #32E5BE;--success: #00C853;--warning: #FF9800;--error: #F44336;--background: #0A1929;--surface: #132F4C;--surface-light: #1E4976;--text-primary: #FFFFFF;--text-secondary: #B2BAC2;--border: rgba(255, 255, 255, .1);--body-gradient: linear-gradient(180deg, #0A1929 0%, #001E3C 100%);--overlay-xs: rgba(255, 255, 255, .03);--overlay-sm: rgba(255, 255, 255, .05);--overlay-md: rgba(255, 255, 255, .08);--overlay-lg: rgba(255, 255, 255, .1);--overlay-xl: rgba(255, 255, 255, .2);--chip-bg: rgba(255, 255, 255, .06);--chip-border: rgba(255, 255, 255, .12);--chip-color: rgba(255, 255, 255, .7);--input-bg: rgba(255, 255, 255, .06);--input-border: rgba(255, 255, 255, .12);--input-placeholder: rgba(255, 255, 255, .35);--icon-muted: rgba(255, 255, 255, .4);--tab-inactive: rgba(255, 255, 255, .5);--tab-border: rgba(255, 255, 255, .08);--muted-45: rgba(255, 255, 255, .45);--muted-50: rgba(255, 255, 255, .5);--activity-nav-bg: rgba(15, 15, 30, .9);--conn-tabs-bg: rgba(0, 0, 0, .2);--conn-tab-color: rgba(255, 255, 255, .55);--debug-bg: rgba(0, 0, 0, .3);--card-bg: rgba(20, 20, 40, .8);--card-border: rgba(255, 255, 255, .1);--section-bg: rgba(255, 255, 255, .03);--section-border: rgba(255, 255, 255, .07);--inset-bg: rgba(0, 0, 0, .2);--modal-bg: linear-gradient(180deg, #1a1a2e 0%, #0f0f1e 100%);--page-gradient: linear-gradient(180deg, #0a0a1a 0%, #1a1a2e 100%);--modal-overlay-bg: rgba(0, 0, 0, .8);--toast-bg: rgba(20, 20, 40, .98)}body{font-family:var(--font-body);background:var(--body-gradient);color:var(--text-primary);min-height:100vh;line-height:1.6}h1,h2,h3,h4{font-family:var(--font-headline);text-transform:uppercase;letter-spacing:.5px}.logo{font-family:var(--font-headline);letter-spacing:1.5px;font-size:1.4rem}.nav-title{font-family:var(--font-headline);letter-spacing:1px}.modal-header h2{font-family:var(--font-headline)}.btn{font-family:var(--font-body)}.top-nav{background:var(--surface);border-bottom:1px solid var(--border);height:64px;display:block;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.top-nav-inner{max-width:1400px;margin:0 auto;padding:0 2rem;height:64px;display:flex;align-items:center;justify-content:space-between}.nav-left{display:flex;align-items:center;gap:2rem}.logo{width:120px;color:inherit;text-decoration:none;display:flex;align-items:center;justify-content:center;transition:background .2s ease,border-color .2s ease,transform .2s ease}.logo-image{width:100%;display:block;object-fit:contain}.nav-tabs{display:flex;gap:.5rem}.nav-tab{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;color:var(--text-secondary);text-decoration:none;transition:all .2s}.nav-tab:hover{background:var(--overlay-sm);color:var(--text-primary)}.nav-tab.active{background:var(--primary-blue);color:#000}.nav-right{display:flex;align-items:center;gap:1rem}@media(max-width:900px){.top-nav-inner{padding:0 0rem;height:56px}.top-nav{height:56px}.logo{width:110px}.nav-tabs{display:none}.nav-right{gap:.5rem}.emulator-badge-nav{padding:.3rem .55rem;font-size:.6rem}.connection-badge{padding:.35rem .6rem;font-size:.8rem}.connection-badge span{display:none}}.emulator-badge-nav{padding:.4rem .8rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;font-size:.7rem;font-weight:700;letter-spacing:.5px}.connection-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--surface-light);border:none;border-radius:8px;cursor:pointer;transition:all .2s;font-size:.9rem;color:var(--text-primary)}.connection-badge:hover{background:var(--primary-blue);color:#000;transform:translateY(-1px)}.connection-badge.connected{background:var(--success);color:#000}.top-nav--activity{display:grid;grid-template-columns:1fr auto 1fr;height:60px;background:var(--activity-nav-bg);border-bottom-color:var(--border);position:fixed;top:0;left:0;right:0;z-index:100}.top-nav--activity .nav-right{justify-self:end}.nav-center{display:flex;align-items:center;justify-content:center}.nav-back{display:flex;align-items:center;gap:.5rem;color:var(--text-primary);text-decoration:none;font-size:.9rem;opacity:.8;transition:opacity .2s}.nav-back:hover{opacity:1}.nav-title{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.main-content{max-width:1400px;margin:0 auto;padding:2rem}.hero-section{margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center}.hero-content{flex:1}.hero-section h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.hero-subtitle{color:var(--text-secondary);font-size:1.1rem}.workout-filters{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.filter-search{position:relative;display:flex;align-items:center}.filter-search-icon{position:absolute;left:.875rem;color:var(--icon-muted);pointer-events:none}.filter-search-input{width:100%;padding:.65rem 2.5rem .65rem 2.75rem;background:var(--input-bg);border:1px solid var(--input-border);border-radius:10px;color:var(--text-primary);font-size:.9rem;font-family:var(--font-body);transition:all .2s}.filter-search-input::placeholder{color:var(--input-placeholder)}.filter-search-input:focus{outline:none;border-color:var(--primary-blue);background:var(--overlay-md);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.25)}.filter-search-clear{position:absolute;right:.625rem;background:none;border:none;color:var(--icon-muted);cursor:pointer;padding:.25rem;display:flex;align-items:center;border-radius:50%;transition:all .15s}.filter-search-clear:hover{color:var(--text-primary);background:var(--overlay-lg)}.filter-section{display:flex;align-items:center;gap:.75rem}.filter-section-header{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.filter-label{font-size:.75rem;color:var(--icon-muted);text-transform:uppercase;letter-spacing:.8px;flex-shrink:0;font-weight:600}.filter-clear-link{background:none;border:none;color:var(--primary-blue);font-size:.75rem;cursor:pointer;padding:0;opacity:.8;transition:opacity .15s}.filter-clear-link:hover{opacity:1}.filter-categories-scroll{display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:2px;flex:1;min-width:0}.filter-categories-scroll::-webkit-scrollbar{display:none}.filter-category-chip{display:flex;align-items:center;gap:.5rem;padding:.4rem .85rem;background:var(--chip-bg);border:1px solid var(--chip-border);border-radius:20px;color:var(--chip-color);font-size:.8rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0}.filter-category-chip:hover{background:var(--overlay-lg);border-color:var(--overlay-xl);color:var(--text-primary)}.filter-category-chip.active{background:#0099ff26;border-color:var(--primary-blue);color:var(--text-primary)}.filter-category-name{line-height:1}.filter-category-count{font-size:.7rem;background:var(--overlay-lg);padding:.1rem .4rem;border-radius:10px;color:var(--muted-50);line-height:1.2}.filter-category-chip.active .filter-category-count{background:#0099ff4d;color:#ffffffd9}.filter-section-sub{padding-left:0;animation:filterSlideIn .2s ease-out}@keyframes filterSlideIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.filter-pills{display:flex;flex-wrap:wrap;gap:.5rem}.filter-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .85rem;border-radius:20px;font-size:.85rem;font-weight:500;border:1px solid var(--chip-border);background:var(--chip-bg);color:var(--chip-color);cursor:pointer;transition:all .15s}.filter-pill:hover{background:var(--overlay-md);color:var(--text-primary)}.filter-pill.active{background:#09f3;border-color:var(--primary-blue);color:var(--text-primary)}.filter-pill-count{font-size:.7rem;opacity:.5}.filter-pill.active .filter-pill-count{opacity:.75}.active-filters-bar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.5rem .75rem;background:#0099ff0f;border:1px solid rgba(0,153,255,.15);border-radius:8px}.active-filters-list{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.active-filter-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .6rem;background:#0099ff26;border-radius:12px;font-size:.78rem;font-weight:500;color:var(--primary-blue);cursor:pointer;transition:all .15s}.active-filter-chip:hover{background:#0099ff40}.active-filter-chip svg{opacity:.6;flex-shrink:0}.active-filter-chip:hover svg{opacity:1}.active-filters-clear{background:none;border:none;color:var(--muted-50);font-size:.78rem;cursor:pointer;white-space:nowrap;transition:color .15s;padding:.2rem 0}.active-filters-clear:hover{color:var(--text-primary)}.results-count{font-size:.85rem;color:var(--muted-45);margin-bottom:1rem;font-weight:500}.empty-state-clear{margin-top:.75rem;background:var(--overlay-md);border:1px solid var(--chip-border);border-radius:8px;color:var(--chip-color);padding:.5rem 1.25rem;font-size:.85rem;cursor:pointer;transition:all .15s}.empty-state-clear:hover{background:var(--overlay-lg);color:var(--text-primary)}.workouts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.workout-card{background:var(--surface);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s;border:1px solid var(--border);text-decoration:none;color:inherit;display:block}.workout-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #09f3;border-color:var(--primary-blue)}.workout-card-image{width:100%;height:180px;position:relative;overflow:hidden}.workout-chart{position:absolute;bottom:0;left:0;right:0;height:80px;display:flex;align-items:flex-end;padding:0 1rem .5rem;gap:3px}.workout-chart-bar{flex:1;background:#ffffff4d;border-radius:2px 2px 0 0;transition:all .2s}.workout-card:hover .workout-chart-bar{background:#ffffff80}.workout-badge{position:absolute;top:1rem;right:1rem;padding:.4rem .8rem;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;font-size:.75rem;font-weight:600;text-transform:uppercase}.workout-card-content{padding:1.25rem}.workout-type{color:var(--primary-blue);font-size:.85rem;font-weight:600;text-transform:uppercase;margin-bottom:.5rem}.workout-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;gap:1rem}.workout-title{font-size:1.1rem;font-weight:600;line-height:1.3;flex:1}.workout-duration{font-size:.9rem;color:var(--text-secondary);white-space:nowrap;font-weight:500}.workout-meta{display:flex;gap:1.5rem;color:var(--text-secondary);font-size:.9rem;margin-bottom:.75rem}.workout-meta-item{display:flex;align-items:center;gap:.4rem}.workout-description{font-size:.85rem;color:var(--text-secondary);margin-bottom:.75rem;line-height:1.4}.workout-tags{display:flex;flex-wrap:wrap;gap:.5rem}.workout-tag{padding:.25rem .6rem;background:var(--overlay-lg);border-radius:12px;font-size:.7rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.start-workout-section{text-align:center;padding:1.5rem 0;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.btn-start-workout{display:inline-flex;align-items:center;gap:.75rem;padding:1rem 3rem;font-size:1.1rem;background:linear-gradient(135deg,#ff6b00,#ff8c00);border:none;border-radius:12px;color:#fff;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 15px #ff6b004d}.btn-start-workout:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff6b0066}.start-hint{margin-top:.75rem;font-size:.85rem;color:var(--muted-50)}.modal{display:none;position:fixed;inset:0;background:var(--modal-overlay-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;animation:fadeIn .2s}.modal.active{display:flex;align-items:center;justify-content:center}.modal-content{background:linear-gradient(180deg,#0f1e2e,#0a1b28);width:90%;max-width:800px;max-height:90vh;border-radius:16px;overflow:hidden;animation:slideUp .3s}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:1.5rem 2rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}.modal-header h2{font-size:1.5rem;font-weight:700;text-transform:uppercase;letter-spacing:1px}.back-button{background:var(--overlay-lg);border:none;color:var(--text-primary);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.back-button:hover{background:var(--overlay-xl);transform:scale(1.1)}.modal-body{padding:2rem;overflow-y:auto;max-height:calc(90vh - 100px)}.device-status-bar{display:flex;gap:1rem;margin-bottom:2rem}.status-chip{background:var(--overlay-md);padding:.6rem 1rem;border-radius:8px;display:flex;align-items:center;gap:.5rem;font-size:.9rem}.status-label{color:var(--text-secondary)}.status-value{font-weight:600;text-transform:uppercase;font-size:.85rem;padding:.2rem .6rem;border-radius:4px}.status-value.connected{background:var(--success);color:#fff}.status-value.connecting{background:var(--warning);color:#fff}.status-value.disconnected,.status-value.idle{background:var(--overlay-lg);color:var(--text-secondary)}.status-value.scanning{background:#ff8500;color:#fff}.devices-found-section{background:var(--overlay-sm);border-radius:12px;padding:1.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h3{font-size:1.2rem;font-weight:600}.scan-actions{display:flex;gap:1rem}.btn-text{background:none;border:none;color:var(--text-primary);font-weight:600;cursor:pointer;text-decoration:underline;font-size:.9rem;padding:.5rem 1rem;transition:all .2s}.btn-text:hover{opacity:.8}.devices-list{min-height:200px;margin-bottom:1.5rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:var(--muted-50);text-align:center}.empty-state svg{margin-bottom:1rem;opacity:.5}.device-item{background:#fff;color:#333;padding:1.25rem;border-radius:12px;margin-bottom:.75rem;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s;border:2px solid transparent;position:relative}.device-item:hover{transform:translate(4px);box-shadow:0 4px 12px #00000026}.device-item.selected{background:#e8f5e9;border-color:var(--success)}.device-item.selected:before{content:"✓";position:absolute;left:-10px;width:24px;height:24px;background:var(--success);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.device-info{display:flex;align-items:center;gap:1rem}.device-icon{width:48px;height:48px;background:var(--primary-blue);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem}.device-details h4{font-size:1.1rem;font-weight:700;margin-bottom:.25rem}.device-type{color:#666;font-size:.9rem}.device-signal{color:#999;font-size:1.2rem}.scan-controls{display:flex;gap:1rem}.conn-type-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--conn-tabs-bg)}.conn-type-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 1rem;background:none;border:none;color:var(--conn-tab-color);font-size:.9rem;font-family:var(--font-body);font-weight:600;letter-spacing:.3px;cursor:pointer;transition:all .2s;border-bottom:2px solid transparent;margin-bottom:-1px}.conn-type-tab:hover{color:var(--text-primary);background:var(--overlay-sm)}.conn-type-tab.active{color:var(--text-primary);border-bottom-color:#ffffff40;background:#ffffff0a}.conn-type-tab.active svg{color:var(--text-primary)}.ble-hint{display:flex;align-items:flex-start;gap:.6rem;padding:.75rem 1rem;margin-bottom:1.5rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:8px;font-size:.875rem;color:var(--text-secondary);line-height:1.45}.ble-hint svg{flex-shrink:0;margin-top:1px;color:var(--text-primary)}.device-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#ffffff14;border-radius:8px;color:var(--text-primary);flex-shrink:0}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:.5px}.btn-large{padding:1rem 2rem;font-size:1rem;flex:1}.btn-primary{background:linear-gradient(135deg,#ff6b00,#ff8500);color:#fff;box-shadow:0 4px 12px #ff6b004d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #ff6b0066}.btn-secondary{background:var(--overlay-lg);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:var(--overlay-xl)}.btn-danger{background:linear-gradient(135deg,#d32f2f,#f44336);color:#fff;box-shadow:0 2px 8px #f443364d}.btn-danger:hover:not(:disabled){box-shadow:0 4px 12px #f4433673;transform:translateY(-1px)}.connected-device-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;margin-bottom:1.5rem;background:#00c8531a;border:1px solid rgba(0,200,83,.3);border-radius:10px}.connected-device-info{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-primary)}.connected-device-info svg{color:var(--success);flex-shrink:0}.offline-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1.1rem;margin:1.25rem 0 1.5rem;background:rgba(var(--primary-rgb),.12);border:1px solid rgba(var(--primary-rgb),.35);border-radius:12px}.offline-banner-content{display:flex;flex-direction:column;gap:.15rem}.offline-banner-title{font-weight:700;color:var(--text-primary)}.offline-banner-text{font-size:.9rem;color:var(--text-secondary)}@media(max-width:768px){.offline-banner{flex-direction:column;align-items:flex-start}}.btn:disabled{opacity:.5;cursor:not-allowed}.activity-detail{max-width:1000px;background:linear-gradient(180deg,var(--surface) 0%,var(--background) 100%)}.telemetry-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.telemetry-card{background:var(--surface-light);padding:1.5rem;border-radius:12px;text-align:center;border:1px solid var(--border)}.telemetry-label{color:var(--text-secondary);font-size:.85rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem}.telemetry-value{font-size:2.5rem;font-weight:700;color:var(--primary-blue);line-height:1;margin-bottom:.25rem}.telemetry-unit{color:var(--text-secondary);font-size:.9rem}.workout-controls{background:var(--surface-light);padding:1.5rem;border-radius:12px;margin-bottom:2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.control-group label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-size:.9rem;font-weight:600}.input-group{display:flex;gap:.5rem}.input-group input{flex:1;padding:.75rem;border:1px solid var(--border);border-radius:8px;background:var(--background);color:var(--text-primary);font-size:1rem}.input-group input:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.25)}.stats-row{display:flex;gap:2rem;padding:1rem;background:var(--overlay-xs);border-radius:8px;margin-bottom:1rem;flex-wrap:wrap}.stat-item{display:flex;gap:.5rem}.stat-label{color:var(--text-secondary)}.stat-value{font-weight:600;color:var(--text-primary)}.debug-section{background:var(--debug-bg);padding:1rem;border-radius:8px;margin-top:1rem}.debug-section summary{cursor:pointer;font-weight:600;-webkit-user-select:none;user-select:none}.debug-content{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border);font-family:monospace;font-size:.85rem;color:var(--text-secondary)}.debug-content div{margin-bottom:.5rem}.mobile-bottom-nav{display:none}@media(max-width:768px){.mobile-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--surface);border-top:1px solid var(--border);padding:.25rem 0 env(safe-area-inset-bottom,.25rem)}.mobile-nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;padding:.45rem .25rem;color:var(--text-secondary);text-decoration:none;font-size:.65rem;font-weight:500;transition:color .15s;-webkit-tap-highlight-color:transparent}.mobile-nav-tab.active{color:var(--primary-blue)}.mobile-nav-tab svg{flex-shrink:0}}@media(max-width:768px){.top-nav{padding:0 1rem}.nav-tabs{display:none}.main-content{padding:1rem 1rem 5.5rem}.hero-section h1{font-size:1.75rem}.workouts-grid{grid-template-columns:1fr}.modal-content{width:100%;height:100%;max-height:100vh;border-radius:0}.telemetry-grid{grid-template-columns:repeat(2,1fr)}.connection-badge span{display:none}.connection-badge{padding:.5rem}}.device-status-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.5rem 1rem;color:var(--text-primary);font-size:.875rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s}.device-status-btn:hover{background:#ffffff1a;border-color:#fff3}.device-status-btn svg{flex-shrink:0}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.connected{background:var(--success);box-shadow:0 0 8px var(--success)}.status-dot.disconnected{background:var(--text-secondary)}.device-name{font-weight:500}.history-section{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border)}.history-section--top{margin-top:1.5rem;margin-bottom:2rem;padding-top:0;padding-bottom:1.5rem;border-top:none;border-bottom:1px solid var(--border)}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.history-header h2{font-size:1.5rem;font-weight:700}.history-list{display:flex;flex-direction:column;gap:.75rem}.history-item{display:flex;justify-content:space-between;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1rem 1.25rem;transition:border-color .2s}.history-item:hover{border-color:var(--overlay-xl)}.history-item-left{flex-shrink:0;min-width:140px}.history-name{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.2rem}.history-date{font-size:.8rem;color:var(--text-secondary)}.history-stats{display:flex;gap:1.5rem;flex-wrap:wrap}.history-stat{display:flex;flex-direction:column;align-items:center;min-width:56px}.history-stat-value{font-size:1.05rem;font-weight:700;color:var(--text-primary);line-height:1.2}.history-stat-value small{font-size:.7rem;font-weight:400;color:var(--text-secondary);margin-left:1px}.history-stat-label{font-size:.65rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-top:.15rem}@media(max-width:768px){.history-item{flex-direction:column;align-items:flex-start;gap:.75rem}.history-stats{gap:1rem}}.home-tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;border-bottom:1px solid var(--tab-border);padding-bottom:0}.home-tab{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:none;border:none;border-bottom:2px solid transparent;color:var(--tab-inactive);font-size:.9rem;font-family:var(--font-body);font-weight:500;cursor:pointer;transition:all .15s ease;margin-bottom:-1px}.home-tab:hover{color:var(--text-primary)}.home-tab.active{color:var(--primary-blue);border-bottom-color:var(--primary-blue)}.home-tab-count{background:rgba(var(--primary-rgb),.15);color:var(--primary-blue);font-size:.7rem;font-weight:700;padding:.1rem .45rem;border-radius:20px;min-width:18px;text-align:center}.my-workouts-section{margin-bottom:2rem}.my-workouts-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.my-workouts-subtitle{font-size:.875rem;color:var(--muted-45);margin:0}.my-workouts-new-btn{display:flex;align-items:center;gap:.375rem;padding:.45rem .875rem;border-radius:8px;background:rgba(var(--primary-rgb),.1);border:1px solid rgba(var(--primary-rgb),.3);color:var(--primary-blue);font-size:.85rem;font-weight:600;text-decoration:none;transition:all .15s ease}.my-workouts-new-btn:hover{background:rgba(var(--primary-rgb),.18)}.my-workouts-empty{text-align:center;padding:4rem 2rem;color:var(--muted-50);display:flex;flex-direction:column;align-items:center;gap:.75rem}.my-workouts-empty p{font-size:1rem;margin:0}.my-workouts-cta{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:8px;background:linear-gradient(135deg,var(--primary-blue),var(--dark-blue));color:#000;font-size:.9rem;font-weight:600;text-decoration:none;margin-top:.5rem;transition:all .15s ease}.my-workouts-cta:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(var(--primary-rgb),.3)}.workout-card-wrapper{position:relative}.workout-card-actions{position:absolute;top:.625rem;right:.625rem;display:flex;gap:.375rem;opacity:0;transition:opacity .15s ease;z-index:2}.workout-card-wrapper:hover .workout-card-actions{opacity:1}.workout-card-rename,.workout-card-delete{width:28px;height:28px;border-radius:6px;background:#0009;border:1px solid rgba(255,255,255,.15);color:#ffffff80;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.workout-card-rename:hover{background:#00d4ff33;border-color:#00d4ff80;color:#00d4ff}.workout-card-delete:hover{background:#ff3c3c4d;border-color:#ff3c3c80;color:#ff6060}.workout-card-delete.deleting{opacity:.5;cursor:not-allowed}.workout-rename-row{margin-bottom:.25rem}.workout-rename-input{width:100%;background:var(--input-bg);border:1px solid #00d4ff;border-radius:6px;color:var(--text-primary);font-size:.95rem;font-weight:600;padding:.3rem .5rem;font-family:inherit;box-sizing:border-box}.workout-rename-input:focus{outline:none;box-shadow:0 0 0 3px rgba(var(--primary-rgb),.25)}.tp-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.tp-header-actions{display:flex;align-items:center;gap:1.25rem;flex-shrink:0}.tp-weekly-stats{display:flex;gap:1.25rem;align-items:center}.tp-stat{display:flex;flex-direction:column;align-items:center}.tp-stat-value{font-size:1.1rem;font-weight:700;color:var(--text-primary);line-height:1.2}.tp-stat-label{font-size:.65rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.tp-clear-all-btn{background:none;border:1px solid var(--chip-border);color:var(--text-secondary);font-size:.8rem;padding:.4rem .8rem;border-radius:6px;cursor:pointer;transition:all .15s}.tp-clear-all-btn:hover{color:var(--error);border-color:var(--error)}.tp-route-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;background:linear-gradient(135deg,#00d4a61a,#00a8840f);border:1px solid rgba(0,212,166,.25);border-radius:16px;padding:1.25rem 1.5rem;flex-wrap:wrap}.tp-route-card-content{display:flex;align-items:flex-start;gap:1rem;flex:1;min-width:0}.tp-route-card-icon{color:var(--primary-blue);flex-shrink:0;margin-top:.1rem}.tp-route-card-text h2{font-size:1.1rem;font-weight:700;margin-bottom:.25rem;color:var(--text-primary)}.tp-route-card-text p{font-size:.85rem;color:var(--text-secondary);line-height:1.5;margin:0;text-transform:none;letter-spacing:0}.tp-route-card-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:var(--primary-blue);color:#000;text-decoration:none;border-radius:8px;font-weight:600;font-size:.9rem;transition:all .2s;white-space:nowrap;flex-shrink:0}.tp-route-card-btn:hover{opacity:.88;transform:translateY(-1px)}@media(max-width:600px){.tp-route-card{flex-direction:column;align-items:flex-start}.tp-route-card-btn{width:100%;justify-content:center}}.tp-today-hero{margin-bottom:1.5rem;background:linear-gradient(135deg,#0099ff1f,#00d2000f);border:1px solid rgba(0,153,255,.2);border-radius:16px;padding:1.5rem;animation:fadeIn .3s ease-out}.tp-today-label{display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--primary-blue);margin-bottom:1rem}.tp-today-cards{display:flex;flex-direction:column;gap:1rem}.tp-today-card{display:flex;background:var(--surface);border-radius:12px;overflow:hidden;border:1px solid var(--border);transition:border-color .2s}.tp-today-card:hover{border-color:var(--overlay-xl)}.tp-today-chart{width:220px;min-height:140px;background:linear-gradient(135deg,var(--dark-blue) 0%,var(--primary-blue) 100%);display:flex;align-items:flex-end;padding:.75rem .5rem .5rem;gap:2px;flex-shrink:0}.tp-today-chart-bar{flex:1;border-radius:1px 1px 0 0;min-height:4px}.tp-today-info{flex:1;padding:1rem 1.25rem;display:flex;flex-direction:column;justify-content:center;gap:.5rem}.tp-today-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.tp-today-category{font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--primary-blue)}.tp-today-duration{display:flex;align-items:center;gap:.3rem;font-size:.8rem;color:var(--text-secondary)}.tp-today-tss{font-size:.8rem;color:var(--text-secondary)}.tp-today-name{font-size:1.35rem;font-weight:700;line-height:1.25}.tp-start-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:linear-gradient(135deg,#ff6b00,#ff8500);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:.9rem;transition:all .2s;box-shadow:0 3px 12px #ff6b004d;align-self:flex-start;margin-top:.25rem}.tp-start-btn:hover{transform:translateY(-1px);box-shadow:0 5px 16px #ff6b0066}.tp-day-strip{display:none;gap:.25rem;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:0 0 .75rem;margin-bottom:0}.tp-day-strip::-webkit-scrollbar{display:none}.tp-day-strip-btn{flex:1;min-width:48px;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.6rem .5rem;background:var(--overlay-xs);border:1px solid transparent;border-radius:10px;color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s}.tp-day-strip-btn:hover{background:var(--overlay-md)}.tp-day-strip-btn.today{color:var(--primary-blue);font-weight:700}.tp-day-strip-btn.selected{background:#0099ff1f;border-color:var(--primary-blue);color:var(--text-primary)}.tp-day-strip-label{font-size:.8rem}.tp-day-strip-dot{width:6px;height:6px;border-radius:50%;background:var(--primary-blue)}.tp-mobile-day-detail{display:none}.tp-mobile-day{margin-bottom:1.5rem}.tp-mobile-day-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.tp-mobile-day-header h3{font-size:1.1rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.tp-mobile-clear-btn{background:none;border:none;color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:color .15s}.tp-mobile-clear-btn:hover{color:var(--error)}.tp-mobile-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;color:var(--text-secondary);background:var(--overlay-xs);border-radius:12px;border:1px dashed var(--border);gap:.75rem}.tp-mobile-empty p{font-size:.9rem;opacity:.6}.tp-mobile-add-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:#0099ff1a;border:1px solid rgba(0,153,255,.25);border-radius:8px;color:var(--primary-blue);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s;margin-top:.5rem}.tp-mobile-add-btn:hover{background:#0099ff2e}.tp-mobile-workout-list{display:flex;flex-direction:column;gap:.5rem}.tp-mobile-workout-card{display:flex;align-items:center;gap:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.75rem;transition:border-color .2s}.tp-mobile-workout-card:hover{border-color:var(--overlay-xl)}.tp-mobile-workout-chart{width:64px;height:40px;display:flex;align-items:flex-end;gap:1px;background:#07c3;border-radius:4px;padding:4px 3px;flex-shrink:0}.tp-mobile-chart-bar{flex:1;border-radius:1px 1px 0 0;min-height:2px}.tp-mobile-workout-info{flex:1;display:flex;flex-direction:column;gap:.1rem;min-width:0}.tp-mobile-workout-category{font-size:.65rem;font-weight:600;text-transform:uppercase;color:var(--primary-blue)}.tp-mobile-workout-name{font-size:.9rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tp-mobile-workout-meta{font-size:.75rem;color:var(--text-secondary)}.tp-mobile-workout-actions{display:flex;align-items:center;gap:.25rem;flex-shrink:0}.tp-week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:2rem}.tp-day-column{background:var(--overlay-xs);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;min-height:200px;transition:all .2s}.tp-day-column.today{border-color:#0099ff4d;background:#0099ff0a}.tp-day-column.drag-over{border-color:var(--primary-blue);background:#0099ff14;box-shadow:inset 0 0 20px #0099ff1a}.tp-day-header{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem .5rem;border-bottom:1px solid var(--border)}.tp-day-name{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.tp-day-name.today{color:var(--primary-blue)}.tp-today-badge{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:.15rem .4rem;background:#09f3;color:var(--primary-blue);border-radius:4px}.tp-day-workouts{flex:1;padding:.4rem;display:flex;flex-direction:column;gap:.4rem}.tp-day-empty{flex:1;display:flex;align-items:center;justify-content:center;padding:1rem .5rem}.tp-day-empty-label{font-size:.75rem;color:var(--icon-muted);font-style:italic}.tp-workout-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;cursor:grab;transition:all .15s;position:relative}.tp-workout-card:active{cursor:grabbing}.tp-workout-card:hover{border-color:var(--overlay-xl)}.tp-workout-card:hover .tp-workout-card-actions{opacity:1}.tp-workout-chart-mini{height:28px;display:flex;align-items:flex-end;gap:1px;padding:3px 4px;background:linear-gradient(135deg,#0077cc4d,#0099ff26)}.tp-workout-chart-bar-mini{flex:1;border-radius:1px 1px 0 0;min-height:2px}.tp-workout-card-body{padding:.35rem .4rem}.tp-workout-card-name{font-size:.72rem;font-weight:600;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tp-workout-card-meta{display:flex;gap:.35rem;font-size:.62rem;color:var(--text-secondary);margin-top:.15rem}.tp-workout-card-actions{position:absolute;top:2px;right:2px;display:flex;gap:2px;opacity:0;transition:opacity .15s}.tp-workout-go-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;background:#00d200cc;color:#fff;text-decoration:none;transition:all .15s}.tp-workout-go-btn:hover{background:#00d200;transform:scale(1.1)}.tp-workout-remove-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;background:#f44336b3;border:none;color:#fff;cursor:pointer;transition:all .15s}.tp-workout-remove-btn:hover{background:#f44336;transform:scale(1.1)}.tp-add-btn{display:flex;align-items:center;justify-content:center;padding:.4rem;margin:0 .4rem .4rem;border-radius:6px;border:1px dashed var(--chip-border);background:none;color:var(--icon-muted);cursor:pointer;transition:all .15s}.tp-add-btn:hover{border-color:var(--primary-blue);color:var(--primary-blue);background:#0099ff0f}.tp-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;color:var(--text-secondary)}.tp-empty-state h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:.75rem 0 .5rem}.tp-empty-state p{font-size:.9rem;max-width:400px}.tp-route-thumb-mini{background:linear-gradient(135deg,#00d4a640,#00a88426);display:flex;align-items:center;justify-content:center;color:#00d4a6}.tp-today-route-thumb{background:linear-gradient(135deg,#00d4a640,#00a8841f);display:flex;align-items:center;justify-content:center;color:#00d4a6}.tp-workout-card--route .tp-workout-chart-mini{background:linear-gradient(135deg,#00d4a640,#00a8841f)}.tp-picker-tabs{display:flex;border-bottom:1px solid var(--border)}.tp-picker-tab{flex:1;padding:.65rem 1rem;background:none;border:none;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}.tp-picker-tab:hover{color:var(--text-primary)}.tp-picker-tab.active{color:var(--primary-blue);border-bottom-color:var(--primary-blue);font-weight:600}.tp-picker-route-thumb{background:linear-gradient(135deg,#00d4a633,#00a8841a);color:#00d4a6;display:flex;align-items:center;justify-content:center}.tp-picker-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease-out}.tp-picker-modal{width:90%;max-width:560px;max-height:80vh;background:var(--surface);border:1px solid var(--border);border-radius:16px;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .2s ease-out}.tp-picker-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.tp-picker-header h2{font-size:1.15rem;font-weight:700}.tp-picker-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--overlay-sm);border:none;color:var(--text-secondary);cursor:pointer;transition:all .15s}.tp-picker-close:hover{background:var(--overlay-lg);color:var(--text-primary)}.tp-picker-search{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-bottom:1px solid var(--border);color:var(--text-secondary)}.tp-picker-search input{flex:1;background:none;border:none;color:var(--text-primary);font-size:.95rem;outline:none}.tp-picker-search input:focus-visible{outline:2px solid var(--primary-blue);outline-offset:2px;border-radius:2px}.tp-picker-search input::placeholder{color:var(--input-placeholder)}.tp-picker-list{overflow-y:auto;flex:1;padding:.5rem 0}.tp-picker-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.7rem 1.5rem;background:none;border:none;color:var(--text-primary);cursor:pointer;text-align:left;transition:background .1s}.tp-picker-item:hover{background:var(--overlay-sm)}.tp-picker-item-chart{width:60px;height:32px;display:flex;align-items:flex-end;gap:1px;background:#07c3;border-radius:4px;padding:4px 3px;flex-shrink:0}.tp-picker-chart-bar{flex:1;border-radius:1px 1px 0 0;min-height:2px}.tp-picker-item-info{flex:1;display:flex;flex-direction:column;gap:.1rem;min-width:0}.tp-picker-item-category{font-size:.65rem;font-weight:600;text-transform:uppercase;color:var(--primary-blue)}.tp-picker-item-name{font-size:.9rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tp-picker-item-meta{font-size:.75rem;color:var(--text-secondary)}.tp-picker-item-add{flex-shrink:0;color:var(--primary-blue);opacity:.5;transition:opacity .15s}.tp-picker-item:hover .tp-picker-item-add{opacity:1}.tp-picker-empty{display:flex;align-items:center;justify-content:center;padding:3rem 1rem;color:var(--text-secondary);font-size:.9rem}@media(max-width:768px){.tp-header{flex-direction:column;align-items:flex-start;gap:.75rem}.tp-header-actions{width:100%;justify-content:space-between}.tp-week-grid{display:none}.tp-day-strip{display:flex}.tp-mobile-day-detail{display:block}.tp-today-card{flex-direction:column}.tp-today-chart{width:100%;height:110px;min-height:110px}.tp-today-name{font-size:1.15rem}.tp-picker-modal{width:100%;max-width:100%;max-height:100%;height:100%;border-radius:0}.tp-empty-state{padding:2rem 1rem}}@media(min-width:769px)and (max-width:1100px){.tp-workout-card-meta{flex-direction:column;gap:.1rem}.tp-workout-card-name{font-size:.68rem}}@media(min-width:769px){.tp-day-strip,.tp-mobile-day-detail{display:none}}body.workout-page{background:var(--page-gradient);min-height:100vh;overflow-x:hidden}.workout-error{min-height:calc(100vh - 64px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;text-align:center;padding:2rem}.workout-error h2{font-size:1.8rem;color:var(--text-primary)}.workout-error p{max-width:480px;color:var(--text-secondary)}.workout-preview{min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:center;padding:2rem}.preview-content{max-width:600px;width:100%;text-align:center}.preview-content h1{font-size:2.5rem;margin-bottom:1rem;color:var(--text-primary)}.workout-stats{display:flex;justify-content:center;gap:2rem;margin:2rem 0;padding:1.5rem;background:var(--overlay-sm);border-radius:12px}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center}.stat-label{display:block;font-size:.85rem;color:var(--muted-50);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.stat-value{display:block;font-size:1.8rem;font-weight:700;color:var(--text-primary)}.hint-text{margin-top:1rem;color:var(--muted-50);font-size:.9rem}.workout-main{margin-top:0;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;margin-left:auto;margin-right:auto;transition:margin-right .3s ease}.workout-graph-container{position:relative;height:200px;background:var(--card-bg);border-radius:12px;overflow:hidden;border:1px solid var(--card-border)}#workout-graph{width:100%;height:100%}.workout-progress-line{position:absolute;top:0;bottom:0;width:2px;background:#ff6b00;box-shadow:0 0 10px #ff6b00;left:0;transition:left .25s linear}.segment-info{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--card-bg);border-radius:12px;border:1px solid var(--card-border)}.segment-current{font-size:1.5rem;font-weight:700;color:#ff6b00}.segment-timing{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.segment-separator{color:var(--muted-45);margin:0 .25rem}.effort-adjust{display:flex;align-items:center;gap:.5rem;background:var(--overlay-sm);border-radius:8px;padding:.25rem .5rem}.effort-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;background:var(--overlay-lg);color:var(--text-secondary);cursor:pointer;transition:all .15s}.effort-btn:hover:not(:disabled){background:#ff6b004d;color:#ff6b00}.effort-btn:disabled{opacity:.3;cursor:not-allowed}.effort-display{display:flex;flex-direction:column;align-items:center;min-width:48px}.effort-label{font-size:.6rem;font-weight:600;color:var(--icon-muted);text-transform:uppercase;letter-spacing:.05em;line-height:1}.effort-value{font-size:1.1rem;font-weight:700;color:var(--text-primary);line-height:1.2}.effort-value.adjusted{color:#ff6b00}.metric-bias{color:#ff6b00;font-weight:600}.workout-metrics{display:flex;flex-direction:column;gap:1rem}.metrics-top{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:1rem}.metrics-bottom{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.metric-card{background:var(--card-bg);border-radius:12px;padding:1.25rem;border:1px solid var(--card-border);display:flex;flex-direction:column;gap:.5rem}.metric-card.gauge-card{position:relative;background:var(--card-bg);border-color:var(--card-border)}.metric-label{font-size:.75rem;font-weight:600;color:var(--muted-50);letter-spacing:.05em;text-transform:uppercase}.metric-value{font-size:2.5rem;font-weight:700;color:var(--text-primary);line-height:1}.metric-unit{font-size:.9rem;font-weight:500;color:var(--muted-50);margin-left:.25rem}.metric-target,.metric-secondary{font-size:.85rem;color:var(--muted-50)}.gauge-header{display:flex;align-items:baseline;justify-content:space-between;gap:1rem}.gauge-status{font-size:.85rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--text-primary)}.metric-card.gauge-card.status-under .gauge-status{color:#60a5fa}.metric-card.gauge-card.status-on .gauge-status{color:#22c55e}.metric-card.gauge-card.status-over .gauge-status{color:#fb7185}.metric-card.gauge-card.status-free .gauge-status{color:var(--muted-50)}.gauge-body{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem}.gauge-value{font-size:3.1rem;font-weight:800;color:var(--text-primary);line-height:1}.gauge-value span{font-size:1rem;font-weight:600;color:var(--muted-50);margin-left:.35rem}.gauge-line{position:relative;height:64px;margin-top:.85rem}.gauge-track{position:absolute;left:0;right:0;top:36px;height:6px;border-radius:999px;background:#ffffff29}.gauge-ok{position:absolute;top:32px;left:calc(50% - (var(--ok-width) / 2));width:var(--ok-width);height:14px;border-radius:999px;background:#22c55ebf;transition:left .5s ease,width .5s ease}.gauge-needle{position:absolute;width:3px;height:26px;background:#fff;top:14px;left:var(--gauge-position);transform:translate(-50%);border-radius:2px;transition:left .45s ease-out,background-color .35s ease}.gauge-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:.5rem;font-size:.85rem;color:var(--muted-50)}.workout-controls{display:flex;justify-content:center;gap:1rem;padding:1rem 0}.control-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;font-size:.95rem;font-weight:600;border:none;cursor:pointer;transition:all .2s}.control-btn.secondary{background:var(--overlay-lg);color:var(--text-primary)}.control-btn.secondary:hover{background:var(--overlay-xl)}.control-btn.danger{background:#ef44444d;color:#f87171}.control-btn.danger:hover{background:#ef444466}.upcoming-segments{position:fixed;right:0;top:60px;bottom:0;width:280px;background:var(--activity-nav-bg);border-left:1px solid var(--border);padding:1.5rem;overflow-y:auto}.upcoming-segments h3{font-size:.85rem;font-weight:600;color:var(--muted-50);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.upcoming-list{display:flex;flex-direction:column;gap:.75rem}.upcoming-item{background:var(--overlay-sm);border-radius:8px;padding:.75rem;border-left:3px solid var(--overlay-xl);transition:all .2s}.upcoming-item.zone-1{border-left-color:gray}.upcoming-item.zone-2{border-left-color:#008cff}.upcoming-item.zone-3{border-left-color:#00d200}.upcoming-item.zone-4{border-left-color:#ffe600}.upcoming-item.zone-5{border-left-color:#ff9600}.upcoming-item.zone-6{border-left-color:#ff1e1e}.upcoming-item.active.zone-1{background:#80808033}.upcoming-item.active.zone-2{background:#008cff33}.upcoming-item.active.zone-3{background:#00d20033}.upcoming-item.active.zone-4{background:#ffe60033}.upcoming-item.active.zone-5{background:#ff960033}.upcoming-item.active.zone-6{background:#ff1e1e33}.upcoming-name{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.upcoming-details{font-size:.8rem;color:var(--muted-50);display:flex;gap:1rem}@media(min-width:1024px){.workout-main{margin-right:300px}}@media(max-width:1023px){.upcoming-segments{display:none}}@media(max-width:768px){.metrics-top{grid-template-columns:1fr}.gauge-value{font-size:2.4rem}}@keyframes powerPulse{0%,to{box-shadow:0 0 #ff6b0000}50%{box-shadow:0 0 30px #ff6b0080}}.countdown-overlay{position:fixed;inset:0;background:var(--modal-overlay-bg);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000}.countdown-number{font-size:12rem;font-weight:800;color:#ff6b00;text-shadow:0 0 60px rgba(255,107,0,.5)}.countdown-text{font-size:1.5rem;color:var(--text-secondary);margin-top:1rem}.complete-overlay{position:fixed;inset:0;background:var(--modal-overlay-bg);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.complete-content{max-width:600px;width:90%;text-align:center;background:var(--modal-bg);border:1px solid var(--border);border-radius:24px;padding:2.5rem 2.75rem;box-shadow:0 24px 60px #00000059}.complete-header{margin-bottom:2rem}.complete-icon{width:80px;height:80px;background:linear-gradient(135deg,#00d200,#00a000);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:#fff;margin:0 auto 1rem;box-shadow:0 4px 20px #00d20066}.complete-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.complete-workout-name{font-size:1.1rem;color:var(--text-secondary)}.complete-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:2rem 0;background:var(--overlay-sm);border-radius:16px;padding:1.5rem}.complete-stat{text-align:center;padding:.5rem}.complete-stat.highlight{background:#00d2001a;border-radius:12px;border:1px solid rgba(0,210,0,.3)}.complete-stat-value{font-size:1.8rem;font-weight:700;color:var(--text-primary)}.complete-stat-value .stat-unit{font-size:.9rem;font-weight:400;color:var(--muted-50);margin-left:2px}.complete-stat-label{font-size:.8rem;color:var(--muted-50);margin-top:.25rem;text-transform:uppercase;letter-spacing:.5px}.complete-secondary{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem;padding:1rem;background:var(--overlay-xs);border-radius:8px}.complete-secondary-stat{display:flex;gap:.5rem}.secondary-label{color:var(--muted-50)}.secondary-value{color:var(--text-primary);font-weight:600}.complete-actions{display:flex;gap:1rem;justify-content:center}.complete-btn{padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;border:none;cursor:pointer;transition:all .2s}.complete-btn.primary{background:linear-gradient(135deg,#00d200,#00a000);color:#fff}.complete-btn.primary:hover{transform:translateY(-2px);box-shadow:0 4px 15px #00d20066}.complete-btn.secondary{background:var(--overlay-lg);color:var(--text-primary)}.complete-btn.secondary:hover{background:var(--overlay-xl)}.workout-settings-overlay{position:fixed;inset:0;z-index:900;display:flex;align-items:center;justify-content:center}.workout-settings-backdrop{position:absolute;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.workout-settings-panel{position:relative;background:var(--modal-bg);border:1px solid var(--border);border-radius:16px;width:360px;max-width:90vw;box-shadow:0 20px 60px #00000080;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.settings-panel-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.settings-panel-header h3{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.settings-panel-close{background:var(--overlay-lg);border:none;border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer;transition:all .15s}.settings-panel-close:hover{background:var(--overlay-xl);color:var(--text-primary)}.settings-panel-body{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.settings-panel-row{display:flex;justify-content:space-between;align-items:center}.settings-panel-row label{font-size:.9rem;font-weight:600;color:var(--text-primary)}.settings-panel-input{display:flex;align-items:center;gap:.5rem}.settings-panel-input input{width:80px;padding:.5rem .6rem;border:1px solid var(--input-border);border-radius:6px;background:var(--input-bg);color:var(--text-primary);font-size:.95rem;font-weight:600;text-align:right}.settings-panel-input input:focus{outline:none;border-color:#ff6b00;box-shadow:0 0 0 3px #ff6b0033}.settings-panel-input span{font-size:.8rem;color:var(--icon-muted);min-width:28px}.settings-panel-hint{font-size:.78rem;color:var(--muted-45);line-height:1.4;margin-top:.25rem}.settings-panel-actions{display:flex;gap:.75rem;padding:1rem 1.5rem 1.25rem;border-top:1px solid var(--border)}.settings-panel-actions .control-btn{flex:1;justify-content:center}.control-btn.primary{background:linear-gradient(135deg,#ff6b00,#ff8c00);color:#fff}.control-btn.primary:hover{box-shadow:0 4px 12px #ff6b0066}@media(max-width:600px){.complete-stats{grid-template-columns:repeat(2,1fr)}.complete-secondary{flex-direction:column;gap:.5rem}}.notification-toast{position:fixed;top:80px;right:20px;min-width:300px;max-width:500px;background:var(--toast-bg);border-radius:12px;padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 8px 32px #0003;border:1px solid var(--border);z-index:10000;opacity:0;transform:translate(400px);transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.notification-toast.show{opacity:1;transform:translate(0)}.notification-icon{font-size:1.5rem;line-height:1;flex-shrink:0}.notification-content{flex:1;min-width:0}.notification-message{color:var(--text-primary);font-size:.95rem;line-height:1.5;word-wrap:break-word}.notification-close{background:none;border:none;color:var(--muted-50);font-size:1.25rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;flex-shrink:0}.notification-close:hover{background:var(--overlay-lg);color:var(--text-primary)}.notification-toast.notification-error{border-left:4px solid #ef4444}.notification-toast.notification-success{border-left:4px solid #10b981}.notification-toast.notification-warning{border-left:4px solid #f59e0b}.notification-toast.notification-info{border-left:4px solid #3b82f6}.notification-modal{position:fixed;inset:0;z-index:10001;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.notification-modal.show{opacity:1}.notification-modal.show .notification-modal-content{transform:scale(1);opacity:1}.notification-modal-backdrop{position:absolute;inset:0;background:var(--modal-overlay-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.notification-modal-content{position:relative;background:var(--modal-bg);border-radius:16px;padding:2rem;max-width:400px;width:90%;box-shadow:0 20px 60px #0000004d;border:1px solid var(--border);transform:scale(.9);opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1)}.notification-modal-icon{font-size:3rem;text-align:center;margin-bottom:1rem}.notification-modal-message{color:var(--text-primary);font-size:1.1rem;line-height:1.6;text-align:center;margin-bottom:2rem}.notification-modal-actions{display:flex;gap:1rem;justify-content:center}.notification-btn{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;border:none;cursor:pointer;transition:all .2s;min-width:100px}.notification-btn-primary{background:#ff6b00;color:#fff}.notification-btn-primary:hover{background:#ff8c00;transform:translateY(-1px);box-shadow:0 4px 12px #ff6b0066}.notification-btn-secondary{background:var(--overlay-lg);color:var(--text-primary);border:1px solid var(--overlay-xl)}.notification-btn-secondary:hover{background:var(--overlay-xl);transform:translateY(-1px)}@media(max-width:600px){.notification-toast{right:10px;left:10px;min-width:auto;max-width:none;top:70px}.notification-modal-content{padding:1.5rem}.notification-modal-message{font-size:1rem}.notification-modal-actions{flex-direction:column}.notification-btn{width:100%}}.settings-wrapper{max-width:100%;padding-bottom:4rem}.settings-header{margin-bottom:2rem}.settings-header h1{font-size:2rem;font-weight:700;margin-bottom:.5rem}.settings-subtitle{color:var(--text-secondary);font-size:1rem}.settings-container{display:flex;flex-direction:column;gap:2rem}.settings-section{background:var(--section-bg);border-radius:16px;padding:1.5rem}.section-title{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.section-title svg{color:#00d4ff;flex-shrink:0}.section-title h2{font-size:1.25rem;font-weight:600;margin:0;flex-grow:1}.zone-info{font-size:.875rem;color:var(--muted-50);font-weight:400}.settings-card{display:flex;flex-direction:column;gap:1rem}.setting-row{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--inset-bg);border-radius:12px;gap:2rem}.setting-info{flex:1}.setting-info label,.setting-info .setting-label-text{display:block;font-weight:500;margin-bottom:.25rem;color:var(--text-primary)}.setting-description{font-size:.8rem;color:var(--muted-50);margin:0;line-height:1.4}.setting-input{display:flex;align-items:center;gap:.5rem}.setting-input input[type=number],.setting-input select{background:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;padding:.75rem 1rem;color:var(--text-primary);font-size:1rem;width:120px;text-align:right;transition:all .2s ease}.setting-input input[type=number]:focus,.setting-input select:focus{outline:none;border-color:#00d4ff;background:#00d4ff14;box-shadow:0 0 0 3px #00d4ff33}.setting-input select{width:auto;min-width:160px;text-align:left;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:2.5rem}.input-unit{color:var(--muted-50);font-size:.875rem;min-width:40px}.toggle{position:relative;display:inline-block;width:52px;height:28px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--overlay-xl);border-radius:28px;transition:.3s}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;border-radius:50%;transition:.3s}.toggle input:checked+.toggle-slider{background-color:#00d4ff}.toggle input:checked+.toggle-slider:before{transform:translate(24px)}.toggle input:focus+.toggle-slider{box-shadow:0 0 0 2px #00d4ff4d}.zones-card{padding:0;overflow:hidden}.zones-grid{display:flex;flex-direction:column}.zone-row{display:grid;grid-template-columns:1fr auto auto;gap:1rem;padding:.875rem 1.25rem;align-items:center;border-left:4px solid transparent}.zone-row:nth-child(odd){background:var(--overlay-md)}.zone-label{font-weight:500}.zone-range{font-family:Monaco,Menlo,monospace;font-size:.9rem;color:#00d4ff;min-width:120px;text-align:right}.zone-percent{font-size:.8rem;color:var(--muted-50);min-width:80px;text-align:right}.zone-1{border-left-color:gray}.zone-2{border-left-color:#008cff}.zone-3{border-left-color:#00d200}.zone-4{border-left-color:#ffe600}.zone-5{border-left-color:#ff9600}.zone-6{border-left-color:#ff1e1e}.settings-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1rem}.btn-primary,.btn-secondary{padding:.875rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.btn-primary{background:linear-gradient(135deg,#00d4ff,#09c);color:#000}.btn-primary:hover{background:linear-gradient(135deg,#00e5ff,#0ad);transform:translateY(-1px)}.btn-secondary{background:var(--overlay-lg);color:var(--text-primary);border:1px solid var(--overlay-xl)}.btn-secondary:hover{background:var(--overlay-xl)}.save-toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%) translateY(100px);background:#10b981;color:#fff;padding:1rem 1.5rem;border-radius:12px;display:flex;align-items:center;gap:.75rem;font-weight:500;box-shadow:0 4px 20px #10b98166;opacity:0;transition:all .3s ease;z-index:1000}.save-toast.visible{transform:translate(-50%) translateY(0);opacity:1}.ai-key-security-note{display:flex;gap:.75rem;margin-top:.75rem;padding:.875rem 1rem;background:#ffc8000f;border:1px solid rgba(255,200,0,.2);border-radius:10px;font-size:.82rem;color:var(--text-secondary);line-height:1.5}.ai-key-security-note svg{color:#ffc800b3;margin-top:.1rem}.ai-key-security-note strong{color:var(--text-primary)}.ai-key-security-note em{font-style:normal;font-family:monospace;font-size:.8rem;background:var(--overlay-md);padding:.1rem .35rem;border-radius:4px}.data-mgmt-row{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--inset-bg);border-radius:12px;gap:2rem}.data-mgmt-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.1rem;border-radius:8px;font-size:.875rem;font-weight:600;white-space:nowrap;flex-shrink:0;cursor:pointer;background:var(--overlay-md);border:1px solid var(--chip-border);color:var(--text-primary);transition:all .15s ease;text-decoration:none}.data-mgmt-btn:hover{background:var(--overlay-lg);color:var(--text-primary)}.data-mgmt-import-label{display:inline-flex}.import-result{display:flex;align-items:flex-start;gap:.625rem;padding:.75rem 1rem;border-radius:8px;font-size:.85rem;line-height:1.45}.import-result svg{flex-shrink:0;margin-top:.1rem}.import-result--success{background:#00d4641a;border:1px solid rgba(0,212,100,.25);color:var(--text-primary)}.import-result--success svg{color:#00d464}.import-result--error{background:#ff50501a;border:1px solid rgba(255,80,80,.25);color:#ff8080}.btn-danger{padding:.875rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;background:#dc262626;color:#f87171;border:1px solid rgba(220,38,38,.35)}.btn-danger:hover{background:#dc262640;border-color:#dc262699;color:#fca5a5}.data-mgmt-row--danger{border:1px solid rgba(220,38,38,.2)}.clear-data-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.clear-data-modal{background:#1a1a2e;border:1px solid rgba(220,38,38,.3);border-radius:16px;padding:2rem;max-width:440px;width:100%;box-shadow:0 8px 40px #0009}.clear-data-modal-icon{color:#f87171;margin-bottom:1rem}.clear-data-modal h3{font-size:1.25rem;font-weight:700;margin:0 0 .75rem;color:var(--text-primary)}.clear-data-modal p{font-size:.9rem;color:var(--text-secondary);margin:0 0 .75rem;line-height:1.5}.clear-data-list{margin:0 0 1rem 1.25rem;padding:0;font-size:.875rem;color:var(--text-secondary);line-height:1.8}.clear-data-warning{font-size:.85rem;color:#f87171;font-weight:500;margin-bottom:1.5rem!important}.clear-data-modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.clear-data-modal-actions .btn-secondary,.clear-data-modal-actions .btn-danger{padding:.7rem 1.5rem}@media(max-width:768px){.settings-wrapper{padding:0 1rem 4rem}.setting-row{flex-direction:column;align-items:flex-start;gap:1rem}.setting-input{width:100%}.setting-input input[type=number],.setting-input select{width:100%;text-align:left}.zone-row{grid-template-columns:1fr;gap:.25rem}.zone-range,.zone-percent{text-align:left}.settings-actions{flex-direction:column}.settings-actions button{width:100%}.data-mgmt-row{flex-direction:column;align-items:flex-start;gap:1rem}.data-mgmt-btn{width:100%;justify-content:center}}.site-footer{background:var(--surface);border-top:1px solid var(--border);padding:1.25rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.site-footer__copy{font-size:.8rem;color:var(--text-secondary)}.site-footer__links{display:flex;gap:1.5rem}.site-footer__link{font-size:.8rem;color:var(--text-secondary);text-decoration:none;transition:color .15s}.site-footer__link:hover{color:var(--primary-blue)}@media(max-width:768px){.site-footer{display:none}}.settings-legal{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:1.5rem 0 .5rem}.settings-legal-link{font-size:.8rem;color:var(--text-secondary);text-decoration:none;transition:color .15s}.settings-legal-link:hover{color:var(--primary-blue)}.settings-legal-sep{font-size:.8rem;color:var(--text-secondary);opacity:.4}@media(min-width:769px){.settings-legal{display:none}}.legal-page{min-height:100vh;background:var(--body-gradient)}.legal-content{max-width:860px;margin:0 auto;padding:3rem 2rem 4rem}.legal-content h1{font-size:2.2rem;color:var(--text-primary);margin-bottom:.4rem}.legal-meta{font-size:.85rem;color:var(--text-secondary);margin-bottom:2.5rem}.legal-intro{background:#0099ff0f;border:1px solid rgba(0,153,255,.18);border-radius:10px;padding:1.25rem 1.5rem;margin-bottom:2.5rem;font-size:.95rem;color:var(--text-secondary);line-height:1.7}.legal-section{margin-bottom:2.25rem}.legal-section h2{font-size:1.15rem;color:var(--primary-blue);margin-bottom:.75rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}.legal-section p{font-size:.92rem;color:var(--text-secondary);line-height:1.75;margin-bottom:.75rem}.legal-section p:last-child{margin-bottom:0}.legal-section ul{margin:.5rem 0 .75rem 1.5rem;padding:0}.legal-section ul li{font-size:.92rem;color:var(--text-secondary);line-height:1.75;margin-bottom:.35rem}.legal-warning{background:#f4433612;border:1px solid rgba(244,67,54,.25);border-radius:10px;padding:1.25rem 1.5rem;margin-bottom:2.25rem}.legal-warning h2{font-size:1.05rem;color:#f44336;margin-bottom:.6rem;border-bottom:1px solid rgba(244,67,54,.2);padding-bottom:.4rem}.legal-warning p{font-size:.92rem;color:var(--text-secondary);line-height:1.75;margin-bottom:.5rem}.legal-warning p:last-child{margin-bottom:0}.legal-back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--primary-blue);text-decoration:none;font-size:.9rem;margin-bottom:2rem;transition:opacity .15s}.legal-back-link:hover{opacity:.75}@media(max-width:768px){.legal-content{padding:2rem 1rem 5.5rem}.legal-content h1{font-size:1.7rem}}.ai-workout-wrapper{max-width:100%;padding-bottom:4rem}.ai-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.ai-header-icon{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#00d4ff22,#00d4ff44);border:1px solid #00d4ff44;display:flex;align-items:center;justify-content:center;color:#00d4ff;flex-shrink:0}.ai-header h1{font-size:1.75rem;font-weight:700;margin:0 0 .25rem}.ai-header-sub{color:var(--text-secondary);font-size:.95rem;margin:0}.ai-no-key-banner,.ai-error-banner{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:10px;margin-bottom:1.5rem;font-size:.9rem}.ai-no-key-banner{background:#00d4ff14;border:1px solid rgba(0,212,255,.25);color:var(--text-primary)}.ai-no-key-banner svg{color:#00d4ff;flex-shrink:0}.ai-no-key-banner a,.ai-saved-info a{color:#00d4ff;text-decoration:none}.ai-no-key-banner a:hover,.ai-saved-info a:hover{text-decoration:underline}.ai-error-banner{background:#ff50501a;border:1px solid rgba(255,80,80,.3);color:#ff8080}.ai-error-banner svg{flex-shrink:0}.ai-form{display:flex;flex-direction:column;gap:1.75rem}.ai-section{background:var(--section-bg);border-radius:14px;padding:1.25rem 1.5rem;border:1px solid var(--section-border)}.ai-section-title{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin:0 0 1rem}.ai-optional{font-weight:400;text-transform:none;letter-spacing:0;color:var(--input-placeholder)}.ai-duration-grid{display:flex;flex-wrap:wrap;gap:.5rem}.ai-duration-btn{padding:.5rem 1.25rem;border-radius:8px;border:1px solid var(--chip-border);background:var(--overlay-sm);color:var(--chip-color);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease}.ai-duration-btn:hover{border-color:#00d4ff80;color:var(--text-primary)}.ai-duration-btn.active{background:#00d4ff26;border-color:#00d4ff;color:#00d4ff}.ai-option-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.ai-option-card{padding:.875rem 1rem;border-radius:10px;border:1px solid var(--card-border);background:var(--overlay-xs);text-align:left;cursor:pointer;transition:all .15s ease}.ai-option-card:hover{border-color:#00d4ff66;background:#00d4ff0d}.ai-option-card.active{border-color:#00d4ff;background:#00d4ff1f}.ai-option-label{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.ai-option-card.active .ai-option-label{color:#00d4ff}.ai-option-desc{font-size:.78rem;color:var(--muted-50);line-height:1.35}.ai-intensity-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.625rem}.ai-intensity-btn{padding:.75rem 1rem;border-radius:10px;border:1px solid var(--card-border);background:var(--overlay-xs);text-align:left;cursor:pointer;transition:all .15s ease}.ai-intensity-btn:hover{border-color:#00d4ff66}.ai-intensity-btn.active{border-color:#00d4ff;background:#00d4ff1f}.ai-intensity-label{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:.2rem}.ai-intensity-btn.active .ai-intensity-label{color:#00d4ff}.ai-intensity-desc{font-size:.78rem;color:var(--muted-45)}.ai-fitness-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.625rem}.ai-fitness-btn{padding:.75rem 1rem;border-radius:10px;border:1px solid var(--card-border);background:var(--overlay-xs);text-align:center;cursor:pointer;transition:all .15s ease}.ai-fitness-btn:hover{border-color:#00d4ff66}.ai-fitness-btn.active{border-color:#00d4ff;background:#00d4ff1f}.ai-fitness-label{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:.2rem}.ai-fitness-btn.active .ai-fitness-label{color:#00d4ff}.ai-fitness-desc{font-size:.75rem;color:var(--muted-45)}.ai-name-input{width:100%;background:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;color:var(--text-primary);font-size:.9rem;padding:.75rem;font-family:inherit;box-sizing:border-box;transition:border-color .15s ease}.ai-name-input:focus{outline:none;border-color:#00d4ff;box-shadow:0 0 0 3px #00d4ff33}.ai-name-input::placeholder{color:var(--input-placeholder)}.ai-notes-input{width:100%;background:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;color:var(--text-primary);font-size:.9rem;padding:.75rem;resize:vertical;font-family:inherit;box-sizing:border-box;transition:border-color .15s ease}.ai-notes-input:focus{outline:none;border-color:#00d4ff;box-shadow:0 0 0 3px #00d4ff33}.ai-notes-input::placeholder{color:var(--input-placeholder)}.ai-notes-count{text-align:right;font-size:.75rem;color:var(--input-placeholder);margin-top:.375rem}.ai-generate-row{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding-top:.5rem}.ai-generate-btn{display:flex;align-items:center;gap:.625rem;padding:.875rem 2.5rem;border-radius:12px;background:linear-gradient(135deg,#00d4ff,#09c);color:#000;font-size:1rem;font-weight:700;border:none;cursor:pointer;transition:all .2s ease;letter-spacing:.01em}.ai-generate-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #00d4ff59}.ai-generate-btn:active:not(:disabled){transform:translateY(0)}.ai-generate-btn:disabled{opacity:.4;cursor:not-allowed}.ai-key-hint{font-size:.85rem;color:var(--icon-muted);margin:0}.ai-key-hint a{color:#00d4ff;text-decoration:none}.ai-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 2rem;gap:1.5rem;text-align:center}.ai-loading-spinner{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.spinner-ring{position:absolute;inset:0;border-radius:50%;border:3px solid rgba(0,212,255,.15);border-top-color:#00d4ff;animation:spin 1s linear infinite}.spinner-bike{color:#00d4ff;animation:pulse 1.8s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:.6;transform:scale(.95)}50%{opacity:1;transform:scale(1.05)}}.ai-loading-msg{font-size:1.05rem;font-weight:600;color:var(--text-primary);margin:0;transition:opacity .4s ease}.ai-loading-sub{font-size:.875rem;color:var(--muted-45);margin:0}.ai-preview{display:flex;flex-direction:column;gap:1.5rem}.ai-preview-card{background:var(--overlay-xs);border-radius:16px;border:1px solid var(--card-border);overflow:hidden}.ai-preview-chart{display:flex;align-items:flex-end;gap:2px;height:120px;padding:1rem 1rem 0;background:var(--inset-bg)}.ai-chart-bar{flex:1;border-radius:2px 2px 0 0;min-width:4px;transition:height .3s ease}.ai-preview-info{padding:1.25rem 1.5rem}.ai-preview-meta{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.ai-preview-category{font-size:.8rem;color:var(--muted-50);text-transform:uppercase;letter-spacing:.06em}.ai-saved-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.75rem;font-weight:600;color:#00d4ff;background:#00d4ff1f;padding:.2rem .6rem;border-radius:20px;border:1px solid rgba(0,212,255,.3)}.ai-preview-name{font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.ai-preview-name-editable{cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;transition:color .15s ease}.ai-preview-name-editable:hover{color:#00d4ff}.ai-edit-icon{opacity:.3;flex-shrink:0;transition:opacity .15s ease}.ai-preview-name-editable:hover .ai-edit-icon{opacity:.7}.ai-preview-name-edit{margin:0 0 .5rem}.ai-preview-name-input{width:100%;background:var(--input-bg);border:1px solid #00d4ff;border-radius:8px;color:var(--text-primary);font-size:1.35rem;font-weight:700;padding:.375rem .625rem;font-family:inherit;box-sizing:border-box}.ai-preview-name-input:focus{outline:none;box-shadow:0 0 0 3px #00d4ff33}.ai-preview-duration{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--text-secondary);margin-bottom:.75rem}.ai-preview-desc{font-size:.9rem;color:var(--text-secondary);line-height:1.5;margin:0}.ai-preview-actions{display:flex;gap:.875rem;flex-wrap:wrap}.ai-btn-secondary,.ai-btn-save,.ai-btn-start{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s ease;border:none;white-space:nowrap}.ai-btn-secondary{background:var(--overlay-md);border:1px solid var(--chip-border);color:var(--text-primary)}.ai-btn-secondary:hover{background:var(--overlay-lg);color:var(--text-primary)}.ai-btn-save{background:#00d4ff1a;border:1px solid rgba(0,212,255,.4);color:#00d4ff}.ai-btn-save:hover:not(:disabled){background:#00d4ff2e}.ai-btn-save:disabled{opacity:.5;cursor:not-allowed}.ai-btn-start{background:linear-gradient(135deg,#00d4ff,#09c);color:#000;margin-left:auto}.ai-btn-start:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #00d4ff4d}.ai-btn-start:disabled{opacity:.5;cursor:not-allowed}.ai-saved-info{background:#00d4ff12;border:1px solid rgba(0,212,255,.2);border-radius:10px;padding:.875rem 1rem;font-size:.875rem;color:var(--text-secondary);text-align:center}.ai-saved-info p{margin:0}@media(max-width:600px){.ai-option-grid,.ai-intensity-grid{grid-template-columns:1fr 1fr}.ai-fitness-grid{grid-template-columns:1fr 1fr 1fr}.ai-preview-actions{flex-direction:column}.ai-btn-start{margin-left:0}.ai-generate-btn{width:100%;justify-content:center}}.help-page{min-height:100vh;background:var(--body-gradient)}.help-content{max-width:860px;margin:0 auto;padding:3rem 2rem 4rem}.help-back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--primary-blue);text-decoration:none;font-size:.9rem;margin-bottom:2rem;transition:opacity .15s}.help-back-link:hover{opacity:.75}.help-content h1{font-size:2.2rem;color:var(--text-primary);margin-bottom:.4rem}.help-subtitle{font-size:1rem;color:var(--text-secondary);margin-bottom:2.5rem}.help-section{background:var(--section-bg);border:1px solid var(--border);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.help-section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.help-section-header svg{color:#00d4ff;flex-shrink:0}.help-section-header h2{font-size:1.15rem;color:var(--text-primary);margin:0}.help-text{font-size:.92rem;color:var(--text-secondary);line-height:1.75;margin-bottom:.75rem}.help-text:last-child{margin-bottom:0}.help-text a{color:var(--primary-blue);text-decoration:none}.help-text a:hover{text-decoration:underline}.help-list{margin:.5rem 0 .75rem 1.5rem;padding:0}.help-list li{font-size:.92rem;color:var(--text-secondary);line-height:1.75;margin-bottom:.35rem}.help-list a{color:var(--primary-blue);text-decoration:none}.help-list a:hover{text-decoration:underline}.help-list code,.help-text code{background:var(--overlay-md);padding:.15rem .45rem;border-radius:4px;font-size:.85rem;color:var(--primary-blue)}.help-steps{display:flex;flex-direction:column;gap:1rem}.help-step{display:flex;gap:1rem;align-items:flex-start}.help-step-number{width:32px;height:32px;min-width:32px;border-radius:50%;background:linear-gradient(135deg,#00d4ff,#09c);color:#000;font-weight:700;font-size:.9rem;display:flex;align-items:center;justify-content:center;margin-top:.1rem}.help-step-content h3{font-size:1rem;color:var(--text-primary);margin:0 0 .35rem}.help-step-content p{font-size:.92rem;color:var(--text-secondary);line-height:1.7;margin:0}.help-step-content a{color:var(--primary-blue);text-decoration:none}.help-step-content a:hover{text-decoration:underline}.faq-list{display:flex;flex-direction:column;gap:.5rem}.faq-item{background:var(--overlay-xs);border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:border-color .2s ease}.faq-item.open{border-color:#00d4ff4d}.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;background:none;border:none;color:var(--text-primary);font-size:.95rem;font-weight:500;text-align:left;cursor:pointer;transition:background .15s}.faq-question:hover{background:var(--overlay-sm)}.faq-chevron{flex-shrink:0;color:var(--text-secondary);transition:transform .2s ease}.faq-item.open .faq-chevron{transform:rotate(180deg)}.faq-answer{padding:0 1.25rem 1rem}.faq-answer p{font-size:.92rem;color:var(--text-secondary);line-height:1.75;margin:0}@media(max-width:768px){.help-content{padding:2rem 1rem 5.5rem}.help-content h1{font-size:1.7rem}.help-subtitle{font-size:.92rem;margin-bottom:2rem}.help-section{padding:1.25rem 1rem;border-radius:10px}.help-step{gap:.75rem}.help-step-number{width:28px;height:28px;min-width:28px;font-size:.8rem}.faq-question{padding:.875rem 1rem;font-size:.9rem}.faq-answer{padding:0 1rem .875rem}}.route-page{min-height:100vh;background:var(--bg-primary, #0a0a0a);color:var(--text-primary, #e0e0e0)}.route-main{padding:1.5rem 1.5rem 6rem;max-width:1400px;margin:0 auto}.route-layout{display:grid;grid-template-columns:280px 1fr;gap:1.5rem;align-items:start}@media(max-width:900px){.route-layout{grid-template-columns:1fr}}.route-sidebar{background:#1a1a2e;border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.route-heading{font-size:1.4rem;font-weight:700;color:#fff;margin:0}.route-upload-section{display:flex;flex-direction:row;align-items:center;gap:.5rem}.btn-library-toggle{position:relative;display:flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid rgba(0,212,255,.3);border-radius:8px;background:#00d4ff12;color:#00d4ff;cursor:pointer;transition:background .2s,border-color .2s;flex-shrink:0}.btn-library-toggle:hover,.btn-library-toggle.active{background:#00d4ff2e;border-color:#00d4ff}.library-count{position:absolute;top:-5px;right:-5px;background:#00d4ff;color:#000;font-size:.65rem;font-weight:700;border-radius:999px;min-width:16px;height:16px;display:flex;align-items:center;justify-content:center;padding:0 3px}.route-library{background:#00d4ff0a;border:1px solid rgba(0,212,255,.15);border-radius:10px;overflow:hidden}.route-library-header{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#00d4ff;padding:.6rem .85rem;border-bottom:1px solid rgba(0,212,255,.1)}.route-library-empty{font-size:.82rem;color:#666;padding:.75rem .85rem;margin:0}.route-library-list{list-style:none;margin:0;padding:0;max-height:220px;overflow-y:auto}.route-library-item{display:flex;align-items:center;gap:.5rem;padding:.55rem .85rem;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.04);transition:background .15s;min-width:0}.route-library-item:last-child{border-bottom:none}.route-library-item:hover{background:#00d4ff14}.route-library-item.active{background:#00d4ff1f}.route-library-item-info{flex:1;min-width:0;display:flex;flex-direction:column}.route-library-name{font-size:.88rem;font-weight:600;color:#e0e0e0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-library-meta{font-size:.75rem;color:#666;white-space:nowrap}.route-library-actions{display:flex;gap:.25rem;flex-shrink:0;opacity:0;transition:opacity .15s}.route-library-item:hover .route-library-actions{opacity:1}.route-library-actions button{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:4px;background:#ffffff14;color:#aaa;cursor:pointer;transition:background .15s,color .15s}.route-library-actions button:hover{background:#ffffff26;color:#fff}.route-library-actions .btn-delete-route:hover{background:#f4433640;color:#f44336}.route-library-rename-input{flex:1;background:#0000004d;border:1px solid #00d4ff;border-radius:4px;color:#fff;font-size:.88rem;padding:.2rem .4rem;outline:none;min-width:0}.route-name-row{display:flex;align-items:center;gap:.5rem;min-width:0}.btn-save-to-lib{flex-shrink:0;padding:.25rem .6rem;background:#00d4ff26;border:1px solid rgba(0,212,255,.4);border-radius:6px;color:#00d4ff;font-size:.78rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-save-to-lib:hover{background:#00d4ff47}.route-saved-badge{flex-shrink:0;font-size:.75rem;color:#4caf50;font-weight:600}.gpx-upload-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1rem;background:#00d4ff;color:#000;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;transition:background .2s;-webkit-user-select:none;user-select:none}.gpx-upload-btn:hover{background:#00b8d9}.gpx-file-input{display:none}.route-crash{padding:1rem;background:#ff44441a;border:1px solid rgba(255,68,68,.4);border-radius:8px;color:#f88;font-size:.88rem}.route-crash pre{margin:.5rem 0;white-space:pre-wrap;font-size:.8rem;color:#faa}.route-crash button{margin-top:.5rem;padding:.3rem .75rem;background:#f44;color:#fff;border:none;border-radius:6px;cursor:pointer}.route-error{color:#f44;font-size:.85rem;background:#ff44441a;border:1px solid rgba(255,68,68,.3);border-radius:6px;padding:.5rem .75rem;margin:0}.route-empty-hint{color:#666;font-size:.88rem;line-height:1.5}.route-empty-hint p{margin:0}.route-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.route-stat{background:#00d4ff0f;border:1px solid rgba(0,212,255,.15);border-radius:8px;padding:.6rem .75rem;display:flex;flex-direction:column;gap:.2rem}.route-stat-label{font-size:.75rem;color:#888;text-transform:uppercase;letter-spacing:.04em}.route-stat-value{font-size:1rem;font-weight:700;color:#fff}.ride-live-stats{display:flex;flex-direction:column;gap:.5rem;background:#ff6b3514;border:1px solid rgba(255,107,53,.3);border-radius:10px;padding:.75rem 1rem}.ride-live-stat{display:flex;justify-content:space-between;align-items:center}.ride-live-label{font-size:.8rem;color:#888;text-transform:uppercase;letter-spacing:.04em}.ride-live-value{font-size:1rem;font-weight:700;color:#fff}.grade-easy{color:#4caf50}.grade-moderate{color:#ffc107}.grade-hard{color:#f44336}.route-controls{display:flex;flex-direction:column}.ride-active-controls{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.btn-start-ride,.btn-pause-ride,.btn-resume-ride,.btn-stop-ride{width:100%;padding:.75rem;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:opacity .2s,background .2s}.btn-start-ride{background:#00d4ff;color:#000}.btn-start-ride:hover:not(:disabled){background:#00b8d9}.btn-start-ride:disabled{opacity:.45;cursor:not-allowed}.btn-pause-ride{background:#ffc107;color:#000}.btn-pause-ride:hover{background:#e6ad06}.btn-resume-ride{background:#00d4ff;color:#000}.btn-resume-ride:hover{background:#00b8d9}.btn-stop-ride{background:#f44336;color:#fff}.btn-stop-ride:hover{background:#d32f2f}.route-map-section{display:flex;flex-direction:column;gap:1rem}.map-wrapper{height:480px;border-radius:12px;overflow:hidden;background:#111;isolation:isolate}.leaflet-map{width:100%;height:100%}.map-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#444}.map-placeholder p{margin:0;font-size:.95rem}.elevation-section{background:#1a1a2e;border-radius:12px;padding:1rem}.elevation-label{font-size:.8rem;color:#888;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.elevation-canvas{width:100%;height:140px;display:block}[data-theme=light] .route-sidebar,[data-theme=light] .elevation-section{background:#f0f2f5;border:1px solid #ddd}[data-theme=light] .route-page{background:#f8f9fa;color:#1a1a1a}[data-theme=light] .route-stat{background:#0096b412;border-color:#0096b433}[data-theme=light] .route-stat-value{color:#1a1a1a}[data-theme=light] .map-placeholder{background:#e8ecf0;color:#aaa}.route-complete-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;animation:routeFadeIn .3s ease}@keyframes routeFadeIn{0%{opacity:0}to{opacity:1}}.route-complete-card{max-width:520px;width:90%;text-align:center;background:#1a1a2e;border:1px solid rgba(0,212,255,.25);border-radius:24px;padding:2.5rem 2.75rem;box-shadow:0 24px 60px #0000008c}.route-complete-header{margin-bottom:2rem}.route-complete-icon{width:80px;height:80px;background:linear-gradient(135deg,#00d4ff,#0090aa);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:#fff;margin:0 auto 1rem;box-shadow:0 4px 20px #00d4ff66}.route-complete-title{font-size:2rem;font-weight:700;color:#fff;margin-bottom:.4rem}.route-complete-name{font-size:1rem;color:#888}.route-complete-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:2rem 0;background:#ffffff0a;border-radius:16px;padding:1.5rem}.route-complete-stat{text-align:center;padding:.5rem}.route-complete-stat.highlight{background:#00d4ff1a;border-radius:12px;border:1px solid rgba(0,212,255,.3)}.route-complete-stat-value{font-size:1.8rem;font-weight:700;color:#fff}.route-stat-unit{font-size:.9rem;font-weight:400;color:#888;margin-left:2px}.route-complete-stat-label{font-size:.75rem;color:#888;margin-top:.25rem;text-transform:uppercase;letter-spacing:.05em}.route-complete-actions{display:flex;gap:1rem;justify-content:center}.route-complete-btn{padding:.9rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;border:none;cursor:pointer;transition:background .2s,transform .15s}.route-complete-btn.primary{background:#00d4ff;color:#000}.route-complete-btn.primary:hover{background:#00b8d9;transform:translateY(-2px)}.route-complete-btn.secondary{background:#ffffff14;color:#e0e0e0}.route-complete-btn.secondary:hover{background:#ffffff24}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}
