:root{--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-800: #1e40af;--primary-900: #1e3a8a;--accent-50: #fff7ed;--accent-100: #ffedd5;--accent-200: #fed7aa;--accent-300: #fdba74;--accent-400: #fb923c;--accent-500: #f97316;--accent-600: #ea580c;--accent-700: #c2410c;--neutral-50: #f8fafc;--neutral-100: #f1f5f9;--neutral-200: #e2e8f0;--neutral-300: #cbd5e1;--neutral-400: #94a3b8;--neutral-500: #64748b;--neutral-600: #475569;--neutral-700: #334155;--neutral-800: #1e293b;--neutral-900: #0f172a;--success: #22c55e;--warning: #eab308;--error: #ef4444;--swim-color: #06b6d4;--bike-color: #8b5cf6;--run-color: #10b981;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display: "Inter", var(--font-sans);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:1rem;line-height:1.6;color:var(--neutral-800);background-color:var(--neutral-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.2;color:var(--neutral-900)}h1{font-size:clamp(2.5rem,5vw,4rem)}h2{font-size:clamp(2rem,4vw,3rem)}h3{font-size:clamp(1.5rem,3vw,2rem)}h4{font-size:1.25rem}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--space-6)}.modal-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-4);background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container{position:relative;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;padding:var(--space-8);background:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);animation:slideUp .3s ease}.modal-close{position:absolute;top:var(--space-4);right:var(--space-4);width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--neutral-400);background:var(--neutral-100);border-radius:var(--radius-full);transition:all var(--transition-fast)}.modal-close:hover{color:var(--neutral-700);background:var(--neutral-200)}.modal-header{text-align:center;margin-bottom:var(--space-8)}.modal-distance-badge{display:inline-block;padding:var(--space-1) var(--space-4);background:linear-gradient(135deg,var(--primary-600),var(--accent-500));color:#fff;font-weight:600;font-size:.875rem;border-radius:var(--radius-full);margin-bottom:var(--space-3)}.modal-title{font-size:1.75rem;margin-bottom:var(--space-2)}.modal-subtitle{color:var(--neutral-500);font-size:.95rem}.modal-form{display:flex;flex-direction:column;gap:var(--space-6)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-weight:600;font-size:.95rem;color:var(--neutral-700)}.form-label-sub{font-weight:400;font-size:.85rem;color:var(--neutral-500);margin-left:var(--space-2)}.form-input{width:100%;padding:var(--space-3) var(--space-4);font-size:1rem;border:2px solid var(--neutral-200);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.form-input-error{border-color:var(--error)}.form-input-error:focus{box-shadow:0 0 0 3px #ef444426}.form-error{color:var(--error);font-size:.85rem}.form-hint{color:var(--neutral-500);font-size:.85rem}.time-inputs,.time-input-group{display:flex;align-items:center;gap:var(--space-2)}.time-input{width:80px;text-align:center}.time-label{color:var(--neutral-500);font-size:.9rem}.time-separator{font-size:1.5rem;font-weight:600;color:var(--neutral-400)}.range-input-container{display:flex;align-items:center;gap:var(--space-4)}.form-range{flex:1;height:8px;-webkit-appearance:none;appearance:none;background:var(--neutral-200);border-radius:var(--radius-full);outline:none}.form-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));border-radius:var(--radius-full);cursor:pointer;box-shadow:var(--shadow-md);transition:transform var(--transition-fast)}.form-range::-webkit-slider-thumb:hover{transform:scale(1.1)}.form-range::-moz-range-thumb{width:24px;height:24px;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));border-radius:var(--radius-full);cursor:pointer;border:none}.range-value{min-width:90px;padding:var(--space-2) var(--space-3);background:var(--primary-50);color:var(--primary-700);font-weight:600;font-size:.95rem;text-align:center;border-radius:var(--radius-md)}.modal-actions{display:flex;gap:var(--space-4);margin-top:var(--space-4)}.modal-actions .btn{flex:1}@media(max-width:480px){.modal-overlay{padding:0;align-items:flex-end}.modal-container{width:100%;max-width:none;max-height:95vh;padding:var(--space-6);padding-bottom:calc(var(--space-6) + env(safe-area-inset-bottom,0));border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;animation:slideUpMobile .3s ease}@keyframes slideUpMobile{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-close{width:44px;height:44px;font-size:1.75rem}.modal-header{margin-bottom:var(--space-6)}.modal-title{font-size:1.5rem}.modal-subtitle,.form-label{font-size:.9rem}.form-input{padding:var(--space-4);font-size:1rem;min-height:50px}.time-inputs{flex-wrap:wrap;gap:var(--space-3)}.time-input{width:70px;min-height:50px;font-size:1.1rem}.range-input-container{flex-direction:column;align-items:stretch;gap:var(--space-3)}.form-range{height:12px}.form-range::-webkit-slider-thumb{width:32px;height:32px}.range-value{min-width:auto;padding:var(--space-3);font-size:1rem}.modal-actions{flex-direction:column-reverse;gap:var(--space-3)}.modal-actions .btn{min-height:52px;font-size:1rem}}.edit-modal{max-width:1000px;width:95vw;height:85vh;display:flex;flex-direction:column;padding:0;overflow:hidden;background:#f8fafc}.modal-header{background:#fff;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--neutral-200);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.modal-header h2{font-size:1.25rem;font-weight:700;color:var(--neutral-800);margin:0}.discipline-badge{margin-left:var(--space-3);padding:var(--space-1) var(--space-2);background:var(--neutral-100);border-radius:var(--radius-full);font-size:.75rem;color:var(--neutral-600);font-weight:500}.modal-header-actions{display:flex;align-items:center;gap:var(--space-2)}.maximize-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:var(--neutral-400);background:var(--neutral-100);border-radius:var(--radius-full);transition:all var(--transition-fast);cursor:pointer;border:none}.maximize-btn:hover{color:var(--neutral-700);background:var(--neutral-200)}.edit-modal.maximized{max-width:95vw;width:95vw;height:95vh}.edit-modal-body{display:grid;grid-template-columns:320px 1fr;flex:1;overflow:hidden}.library-column{background:#fff;border-right:1px solid var(--neutral-200);display:flex;flex-direction:column;overflow:hidden}.library-filters{padding:var(--space-4);border-bottom:1px solid var(--neutral-100);display:flex;gap:var(--space-2);overflow-x:auto;white-space:nowrap;scrollbar-width:none}.library-filters::-webkit-scrollbar{display:none}.category-btn{padding:var(--space-1) var(--space-3);border:1px solid var(--neutral-200);border-radius:var(--radius-full);background:#fff;cursor:pointer;font-size:.8rem;color:var(--neutral-600);transition:all .2s;flex-shrink:0}.category-btn:hover{border-color:var(--neutral-400);color:var(--neutral-800)}.category-btn.active{background:var(--neutral-900);color:#fff;border-color:var(--neutral-900)}.library-list{flex:1;overflow-y:auto;padding:var(--space-2)}.library-item{display:flex;flex-direction:column;width:100%;padding:var(--space-3);border:1px solid transparent;border-bottom:1px solid var(--neutral-100);background:#fff;cursor:pointer;text-align:left;border-radius:var(--radius-md);transition:all .2s;margin-bottom:2px}.library-item:hover{background:var(--neutral-50)}.library-item.selected{background:var(--primary-50);border-color:var(--primary-200);box-shadow:0 2px 4px #0000000d}.library-item .item-main{margin-bottom:var(--space-2)}.library-item strong{display:block;color:var(--neutral-800);font-size:.9rem;margin-bottom:4px}.library-desc{font-size:.75rem;color:var(--neutral-500);line-height:1.3;margin-top:4px;margin-bottom:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-clamp:2}.workout-mini-viz{display:flex;height:6px;width:100%;background:var(--neutral-100);border-radius:3px;overflow:hidden;margin:6px 0}.viz-segment{height:100%}.library-item .item-meta{font-size:.7rem;color:var(--neutral-400);display:flex;justify-content:space-between;text-transform:uppercase;font-weight:500}.editor-column{padding:var(--space-6);overflow-y:auto;background:#f8fafc}.editor-card{background:#fff;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000000d;border:1px solid var(--neutral-200);padding:var(--space-6);height:100%;display:flex;flex-direction:column;overflow-y:auto}.editor-section{margin-bottom:var(--space-6)}.editor-section label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;font-weight:600;color:var(--neutral-500);margin-bottom:var(--space-2)}.title-input{width:100%;font-size:1.5rem;font-weight:700;color:var(--neutral-900);border:none;border-bottom:2px solid var(--neutral-200);padding:var(--space-2) 0;background:transparent;transition:border-color .2s}.title-input:focus{outline:none;border-color:var(--primary-500)}.description-text{font-size:.95rem;color:var(--neutral-600);line-height:1.6}.variation-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.variation-tab{padding:var(--space-2) var(--space-3);border:1px solid var(--neutral-200);border-radius:var(--radius-md);background:#fff;cursor:pointer;font-size:.9rem;color:var(--neutral-600);transition:all .2s}.variation-tab:hover{border-color:var(--primary-200);color:var(--primary-600)}.variation-tab.active{background:var(--primary-50);border-color:var(--primary-500);color:var(--primary-700);font-weight:600}.steps-list{display:flex;flex-direction:column;gap:var(--space-2)}.step-row{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);background:var(--neutral-50);border-radius:var(--radius-md);border:1px solid var(--neutral-100)}.step-header{display:grid;grid-template-columns:80px 1fr auto;align-items:center;gap:var(--space-3)}.step-intensity{padding:2px 6px;border-radius:4px;font-size:.7rem;font-weight:700;text-transform:uppercase;text-align:center;color:#fff}.step-name{font-size:.9rem;font-weight:600;color:var(--neutral-800)}.step-duration{font-size:.9rem;color:var(--neutral-600);font-variant-numeric:tabular-nums;font-weight:600}.step-details{padding-left:calc(80px + var(--space-3));border-top:1px solid var(--neutral-200);padding-top:var(--space-2);margin-top:-2px}.step-instructions{margin:0 0 var(--space-2) 0;font-size:.85rem;color:var(--neutral-600);line-height:1.4}.step-metrics{display:flex;flex-wrap:wrap;gap:var(--space-2)}.metric-tag{font-size:.75rem;color:var(--neutral-500);background:#fff;border:1px solid var(--neutral-200);padding:2px 6px;border-radius:4px;display:inline-flex;align-items:center}.modal-footer{background:#fff;padding:var(--space-4) var(--space-6);border-top:1px solid var(--neutral-200);display:flex;justify-content:flex-end;gap:var(--space-3);flex-shrink:0}@media(max-width:768px){.edit-modal{width:100vw;height:100vh;max-width:none;border-radius:0;margin:0}.modal-header{padding:var(--space-3) var(--space-4);padding-top:calc(var(--space-3) + env(safe-area-inset-top,0))}.modal-header h2{font-size:1.1rem}.maximize-btn{display:none}.edit-modal-body{grid-template-columns:1fr;grid-template-rows:auto 1fr}.library-column{max-height:280px;min-height:200px;border-right:none;border-bottom:1px solid var(--neutral-200)}.library-filters{padding:var(--space-3)}.category-btn{min-height:36px;padding:var(--space-2) var(--space-3)}.library-item{padding:var(--space-4);min-height:60px}.library-item:active{background:var(--primary-100)}.editor-column,.editor-card{padding:var(--space-4)}.title-input{font-size:1.25rem;padding:var(--space-3) 0}.step-header{grid-template-columns:70px 1fr auto}.step-row{padding:var(--space-4)}.step-details{padding-left:0}.modal-footer{padding:var(--space-4);padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom,0));gap:var(--space-3)}.modal-footer .btn{flex:1;min-height:48px;font-size:1rem}}.completion-modal{max-width:480px;width:90vw;background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:0;overflow:hidden}.completion-modal .modal-header{background:#fff;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--neutral-100)}.completion-modal .modal-header h2{font-size:1.25rem;font-weight:700;color:var(--neutral-800)}.completion-modal .modal-body{padding:var(--space-6)}.workout-info-banner{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);background:var(--neutral-50);border:1px solid var(--neutral-200);border-radius:var(--radius-lg);margin-bottom:var(--space-6);box-shadow:0 1px 2px #00000005}.workout-info-banner strong{color:var(--neutral-900);font-size:.95rem}.workout-info-banner span{color:var(--neutral-500);font-size:.85rem;font-weight:500}.status-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-bottom:var(--space-6)}.status-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-2);border:1px solid var(--neutral-200);border-radius:var(--radius-lg);background:#fff;cursor:pointer;transition:all .2s ease;height:80px}.status-btn:hover{background:var(--neutral-50);border-color:var(--neutral-300);transform:translateY(-1px)}.status-btn .status-icon{font-size:1.25rem;line-height:1;margin-bottom:2px}.status-btn span:last-child{font-size:.8rem;font-weight:600;color:var(--neutral-500);transition:color .2s}.status-btn.completed.active{background:#f0fdf4;border-color:var(--success);color:var(--success);box-shadow:0 2px 4px #10b9811a}.status-btn.completed.active span:last-child{color:var(--success)}.status-btn.partial.active{background:#fefce8;border-color:var(--accent-500);color:var(--accent-600);box-shadow:0 2px 4px #eab3081a}.status-btn.partial.active span:last-child{color:var(--accent-700)}.status-btn.skipped.active{background:var(--neutral-100);border-color:var(--neutral-400);color:var(--neutral-600)}.status-btn.skipped.active span:last-child{color:var(--neutral-700)}.completion-modal .form-group{margin-bottom:var(--space-5)}.completion-modal .form-group label{display:flex;justify-content:space-between;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;font-weight:600;color:var(--neutral-500);margin-bottom:var(--space-2)}.completion-modal .form-input{width:100%;padding:var(--space-2) 0;border:none;border-bottom:2px solid var(--neutral-200);border-radius:0;font-size:1.1rem;color:var(--neutral-900);background:transparent;transition:border-color .2s}.completion-modal .form-input:focus{outline:none;border-color:var(--primary-500)}.completion-modal textarea.form-input{border:1px solid var(--neutral-200);border-radius:var(--radius-md);padding:var(--space-3);font-size:.95rem;min-height:80px;resize:vertical}.completion-modal textarea.form-input:focus{border-color:var(--primary-500)}.rpe-slider-container{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-1)}.rpe-slider{-webkit-appearance:none;width:100%;height:8px;border-radius:4px;outline:none;margin:var(--space-2) 0}.rpe-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 5px #0003;border:4px solid white;transform:scale(1);transition:transform .1s;margin-top:-8px}.rpe-slider::-webkit-slider-thumb{border:2px solid rgba(0,0,0,.1)}.rpe-slider:active::-webkit-slider-thumb{transform:scale(1.1)}.rpe-value{display:flex;justify-content:space-between;align-items:center;background:var(--neutral-50);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);margin-top:-5px}.rpe-number{font-size:1.2rem;font-weight:800}.rpe-label{font-size:.9rem;font-weight:600}.effort-feedback{margin-top:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);font-size:.85rem;line-height:1.4;display:flex;gap:var(--space-2)}.effort-feedback.warning{background:#fff7ed;color:#c2410c;border:1px solid #ffedd5}.effort-feedback.success{background:#f0fdf4;color:#15803d;border:1px solid #dcfce7}.completion-modal .modal-footer{padding:var(--space-4) var(--space-6);background:var(--neutral-50);border-top:1px solid var(--neutral-200)}.plan-view{min-height:100vh;background:var(--neutral-50)}.plan-header{position:sticky;top:0;z-index:50;padding:var(--space-4) var(--space-6);background:#fff;border-bottom:1px solid var(--neutral-200)}.back-button{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);color:var(--neutral-600);font-weight:500;border-radius:var(--radius-lg);transition:all var(--transition-fast)}.back-button:hover{color:var(--primary-600);background:var(--primary-50)}.plan-header-content{max-width:1200px;margin:var(--space-4) auto 0}.plan-title{font-size:1.75rem;margin-bottom:var(--space-2)}.plan-meta{color:var(--neutral-500);font-size:.95rem}.phase-overview{padding:var(--space-6);background:#fff;border-bottom:1px solid var(--neutral-200)}.phase-bar{max-width:1200px;margin:0 auto;display:flex;height:40px;border-radius:var(--radius-lg);overflow:hidden}.phase-segment{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-size:.75rem;min-width:60px}.phase-name{font-weight:600;text-transform:capitalize}.phase-weeks{opacity:.8}.week-selector{padding:var(--space-6);background:#fff;border-bottom:1px solid var(--neutral-200);text-align:center}.week-nav{display:flex;align-items:center;justify-content:center;gap:var(--space-6);margin-bottom:var(--space-4)}.week-nav-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:var(--neutral-600);background:var(--neutral-100);border-radius:var(--radius-full);transition:all var(--transition-fast)}.week-nav-btn:hover:not(:disabled){color:var(--primary-600);background:var(--primary-100)}.week-nav-btn:disabled{opacity:.3;cursor:not-allowed}.week-info{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.week-number{font-size:1.25rem;font-weight:700;color:var(--neutral-800)}.week-phase{padding:var(--space-1) var(--space-3);color:#fff;font-size:.75rem;font-weight:600;border-radius:var(--radius-full)}.week-focus{color:var(--neutral-600);font-size:.95rem;margin-bottom:var(--space-2)}.week-hours{color:var(--neutral-500);font-size:.9rem}.week-thumbnails{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);background:#fff;border-bottom:1px solid var(--neutral-200)}.week-thumb{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:500;color:var(--neutral-600);background:var(--neutral-100);border:2px solid transparent;border-radius:var(--radius-md);transition:all var(--transition-fast)}.week-thumb:hover{background:var(--neutral-200)}.week-thumb.active{font-weight:700;color:var(--neutral-900)}.days-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-4);padding:var(--space-6);max-width:1400px;margin:0 auto}.day-card{background:#fff;border-radius:var(--radius-xl);border:1px solid var(--neutral-200);overflow:hidden}.day-card.rest-day{background:linear-gradient(135deg,var(--neutral-50),var(--success));background-size:200% 200%;background-position:0% 100%}.day-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);background:var(--neutral-50);border-bottom:1px solid var(--neutral-200)}.day-name{font-weight:700;color:var(--neutral-800)}.day-date{color:var(--neutral-500);font-size:.9rem}.day-workouts{padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-3)}.workout-card{border-radius:var(--radius-lg);border:1px solid var(--neutral-200);overflow:hidden;display:flex;flex-direction:column}.workout-drag-handle{display:flex;align-items:center;justify-content:center;padding:var(--space-2) var(--space-1);background:var(--neutral-50);border-right:1px solid var(--neutral-200);cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast)}.workout-drag-handle:hover{background:var(--neutral-100)}.workout-drag-handle:active{cursor:grabbing;background:var(--primary-50)}.drag-handle-icon{color:var(--neutral-400);font-size:1rem;letter-spacing:-.1em}.workout-header-row{display:flex;flex-direction:row;align-items:stretch}.workout-header-row>.workout-summary{flex:1}.workout-card.dragging{opacity:.5;transform:scale(.98);background:var(--neutral-100)}.workout-ghost{background:#fff;border-radius:var(--radius-lg);border:2px solid var(--primary-400);box-shadow:0 20px 40px #00000040;transform:rotate(2deg) scale(1.02);opacity:.95}.workout-ghost .workout-header-row{display:flex;flex-direction:row;align-items:stretch}.workout-ghost .workout-summary{padding:var(--space-3) var(--space-4);display:flex;align-items:center;gap:var(--space-3)}.day-card.drag-active{background:var(--primary-50);border-color:var(--primary-300);box-shadow:0 0 0 3px #3b82f633;transition:all .15s ease}.empty-day-placeholder{display:flex;align-items:center;justify-content:center;padding:var(--space-8) var(--space-4);border:2px dashed var(--neutral-300);border-radius:var(--radius-lg);color:var(--neutral-400);font-size:.9rem;background:var(--neutral-50);transition:all .15s ease}.day-card.drag-active .empty-day-placeholder{border-color:var(--primary-400);background:var(--primary-50);color:var(--primary-500)}.empty-day-placeholder.drag-over{border-color:var(--primary-400);background:var(--primary-100);color:var(--primary-600);border-style:solid}.workout-summary{width:100%;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:#fff;text-align:left;transition:background var(--transition-fast)}.workout-summary:hover{background:var(--neutral-50)}.workout-icon{font-size:1.5rem}.workout-info{flex:1;display:flex;flex-direction:column}.workout-title{font-weight:600;color:var(--neutral-800)}.workout-duration{font-size:.85rem;color:var(--neutral-500)}.workout-expand{color:var(--neutral-400);font-size:.75rem;transition:transform var(--transition-fast)}.workout-expand.expanded{transform:rotate(180deg)}.workout-details{padding:var(--space-4);background:var(--neutral-50);border-top:1px solid var(--neutral-200);animation:slideDown .2s ease}.workout-description{color:var(--neutral-600);font-size:.95rem;margin-bottom:var(--space-4)}.workout-steps{display:flex;flex-direction:column;gap:var(--space-3)}.step-card{padding:var(--space-4);background:#fff;border-radius:var(--radius-lg);border-left:4px solid var(--neutral-300)}.step-intensity{padding:var(--space-1) var(--space-2);color:#fff;font-size:.7rem;font-weight:600;text-transform:uppercase;border-radius:var(--radius-sm)}.step-duration{color:var(--neutral-500);font-size:.85rem;font-weight:500}.step-name{font-size:1rem;font-weight:600;margin-bottom:var(--space-2)}.step-instructions{color:var(--neutral-600);font-size:.9rem;line-height:1.6}.step-targets{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-3)}.target-badge{padding:var(--space-1) var(--space-2);background:var(--neutral-100);color:var(--neutral-700);font-size:.8rem;border-radius:var(--radius-md)}.workout-tips{margin-top:var(--space-4);padding:var(--space-4);background:var(--primary-50);border-radius:var(--radius-lg)}.workout-tips h5{font-size:.9rem;margin-bottom:var(--space-2)}.workout-tips ul{list-style:none;padding:0}.workout-tips li{position:relative;padding-left:var(--space-5);color:var(--neutral-600);font-size:.85rem;margin-bottom:var(--space-1)}.workout-tips li:before{content:"•";position:absolute;left:var(--space-2);color:var(--primary-500)}@media(max-width:768px){.training-plan-container{padding:var(--space-3);padding-bottom:calc(var(--space-4) + 80px)}.week-thumbnails{max-width:100%;overflow-x:auto;flex-wrap:nowrap;justify-content:flex-start;gap:var(--space-2);padding:var(--space-2) 0;-webkit-overflow-scrolling:touch;scrollbar-width:none}.week-thumbnails::-webkit-scrollbar{display:none}.week-thumbnail{min-width:48px;height:48px;font-size:.9rem;flex-shrink:0;border-radius:var(--radius-lg)}.week-thumbnail:active{transform:scale(.95)}.phase-segment{min-width:40px;font-size:.65rem;padding:var(--space-1) var(--space-2)}.days-grid{grid-template-columns:1fr;gap:var(--space-3)}.day-card{border-radius:var(--radius-lg);padding:var(--space-3)}.day-header{padding:var(--space-2);margin-bottom:var(--space-2)}.day-name{font-size:.85rem}.day-date{font-size:.75rem}.workout-card{padding:var(--space-3);margin-bottom:var(--space-2);border-radius:var(--radius-md)}.workout-card:active{transform:scale(.98);background:var(--neutral-100)}.workout-header{margin-bottom:var(--space-2)}.workout-title{font-size:.9rem}.workout-duration{font-size:.75rem}.workout-actions{flex-wrap:wrap;gap:var(--space-2)}.action-btn{min-height:44px;padding:var(--space-2) var(--space-4);font-size:.85rem;flex:1;justify-content:center}.log-btn{min-height:44px;padding:var(--space-2) var(--space-4)}.workout-drag-handle{min-width:44px;min-height:44px;padding:var(--space-3)}.drag-handle-icon{font-size:1.2rem}.workout-card.dragging{opacity:.4;background:var(--primary-50);border-color:var(--primary-300)}.empty-day-placeholder{padding:var(--space-6) var(--space-4);min-height:60px}}.workout-actions{display:flex;gap:var(--space-2);margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--neutral-200)}.action-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:.85rem;font-weight:500;border-radius:var(--radius-md);transition:all .2s;cursor:pointer}.edit-btn{background:var(--primary-50);color:var(--primary-600);border:1px solid var(--primary-200)}.edit-btn:hover{background:var(--primary-100);border-color:var(--primary-300)}.swap-btn{background:var(--accent-50);color:var(--accent-600);border:1px solid var(--accent-200)}.swap-btn:hover{background:var(--accent-100);border-color:var(--accent-300)}.delete-btn{background:transparent;color:var(--error);border:1px solid var(--error);margin-left:auto}.delete-btn:hover{background:var(--error);color:#fff;border-color:var(--error)}.delete-modal{max-width:400px}.delete-modal .modal-body{padding:1.5rem}.delete-modal .modal-body p{margin-bottom:.75rem}.delete-modal .warning-text{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}.delete-modal .modal-actions{display:flex;gap:.75rem;padding:1rem 1.5rem 1.5rem}.btn-danger{background:var(--error);color:#fff;border:none}.btn-danger:hover{background:#dc2626}.save-btn{margin-top:var(--space-3)}.completion-indicator{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:.75rem;color:#fff;font-weight:700;margin-left:calc(-1 * var(--space-2));margin-right:var(--space-1)}.log-btn{background:var(--success);color:#fff;border:none}.log-btn:hover{background:#059669}.log-btn.completed{background:var(--primary-100);color:var(--primary-700);border:1px solid var(--primary-300)}.regen-modal{max-width:450px}.regen-modal .modal-body{padding:1.5rem}.regen-modal .modal-body p{margin-bottom:.75rem}.regen-modal .warning-text{color:var(--text-secondary);margin-bottom:1rem}.regen-modal .success-text{color:var(--success-color);display:flex;align-items:center;gap:.5rem}.regen-modal .success-icon{font-size:1.1rem}.regen-modal .modal-actions{padding:1rem 1.5rem 1.5rem;gap:.75rem}.workout-card.status-completed{border-color:var(--success);background-color:#f0fdf4}.workout-card.status-completed .workout-summary{background-color:#f0fdf4}.workout-card.status-completed .workout-icon{color:var(--success);position:relative}.status-check{position:absolute;bottom:-4px;right:-4px;background:var(--success);color:#fff;font-size:.6rem;width:14px;height:14px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:2px solid white}.workout-card.status-partial{border-color:var(--accent-500);background-color:#fefce8}.workout-card.status-partial .workout-summary{background-color:#fefce8}.workout-card.status-skipped{border-color:var(--neutral-300);background-color:var(--neutral-100);opacity:.7}.workout-card.status-skipped .workout-summary{background-color:var(--neutral-100);text-decoration:line-through;color:var(--neutral-500)}.auth-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-4);background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}.auth-container{position:relative;width:100%;max-width:420px;padding:var(--space-8);background:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-close{position:absolute;top:var(--space-4);right:var(--space-4);width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--neutral-400);background:var(--neutral-100);border-radius:var(--radius-full);transition:all var(--transition-fast)}.auth-close:hover{color:var(--neutral-700);background:var(--neutral-200)}.auth-header{text-align:center;margin-bottom:var(--space-6)}.auth-logo{font-size:2rem;margin-bottom:var(--space-2)}.auth-title{font-size:1.5rem;margin-bottom:var(--space-2)}.auth-subtitle{color:var(--neutral-500);font-size:.95rem}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-error{padding:var(--space-3) var(--space-4);background:#ef44441a;color:var(--error);border-radius:var(--radius-lg);font-size:.9rem;display:flex;align-items:center;gap:var(--space-2)}.auth-success{padding:var(--space-3) var(--space-4);background:#22c55e1a;color:var(--success);border-radius:var(--radius-lg);font-size:.9rem;display:flex;align-items:center;gap:var(--space-2)}.auth-submit{margin-top:var(--space-2);padding:var(--space-4)}.auth-submit:disabled{opacity:.7;cursor:not-allowed}.auth-loading{display:inline-flex;align-items:center;gap:var(--space-2)}.password-requirements{margin-top:var(--space-2);margin-bottom:var(--space-2);padding:var(--space-3);background:var(--neutral-100);border-radius:var(--radius-md);font-size:.85rem}.requirements-title{font-weight:600;color:var(--neutral-700);margin-bottom:var(--space-2);display:block}.requirements-list{display:flex;flex-direction:column;gap:var(--space-1);list-style:none;padding:0;margin:0}.requirement-item{display:flex;align-items:center;gap:var(--space-2);color:var(--neutral-500);transition:color .2s}.requirement-item.met{color:var(--success)}.requirement-icon{display:flex;align-items:center;justify-content:center;width:16px;height:16px}.auth-footer{margin-top:var(--space-6);text-align:center;color:var(--neutral-500);font-size:.9rem}.auth-toggle{color:var(--primary-600);font-weight:600;margin-left:var(--space-1);background:none;padding:0}.auth-toggle:hover{text-decoration:underline}.forgot-password-link{text-align:right;margin-top:calc(-1 * var(--space-2))}@media(max-width:480px){.auth-container{padding:var(--space-6)}}.wizard-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-4);background:linear-gradient(135deg,var(--primary-900) 0%,var(--neutral-900) 100%);overflow-y:auto}.wizard-container{width:100%;max-width:700px;padding:var(--space-8);background:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl)}.wizard-header{text-align:center;margin-bottom:var(--space-6)}.wizard-header h2{font-size:1.75rem;margin-bottom:var(--space-2)}.wizard-header p{color:var(--neutral-500)}.wizard-skip{margin-top:var(--space-3);color:var(--neutral-400);font-size:.9rem;background:none;padding:var(--space-2) var(--space-4);transition:color var(--transition-fast)}.wizard-skip:hover{color:var(--primary-600)}.wizard-progress{display:flex;justify-content:space-between;margin-bottom:var(--space-8);position:relative}.wizard-progress:before{content:"";position:absolute;top:15px;left:10%;right:10%;height:2px;background:var(--neutral-200);z-index:0}.progress-step{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);position:relative;z-index:1}.progress-dot{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;color:var(--neutral-400);background:var(--neutral-100);border:2px solid var(--neutral-200);border-radius:var(--radius-full);transition:all var(--transition-base)}.progress-step.active .progress-dot{color:#fff;background:var(--primary-600);border-color:var(--primary-600)}.progress-step.complete .progress-dot{color:#fff;background:var(--success);border-color:var(--success)}.progress-label{font-size:.75rem;color:var(--neutral-400);white-space:nowrap}.progress-step.active .progress-label{color:var(--primary-600);font-weight:600}.wizard-content{min-height:350px;margin-bottom:var(--space-6)}.wizard-step h3{font-size:1.25rem;margin-bottom:var(--space-2)}.wizard-step h4{font-size:1rem;margin:var(--space-6) 0 var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.optional-badge{font-size:.7rem;padding:var(--space-1) var(--space-2);background:var(--neutral-100);color:var(--neutral-500);border-radius:var(--radius-full);font-weight:400}.hint{color:var(--neutral-500);font-size:.9rem;margin-bottom:var(--space-4)}.experience-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3);margin-bottom:var(--space-4)}.experience-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4);background:var(--neutral-50);border:2px solid var(--neutral-200);border-radius:var(--radius-lg);transition:all var(--transition-fast);text-transform:capitalize}.experience-card.selected{border-color:var(--primary-600);background:var(--primary-50)}.experience-name{font-size:.85rem;font-weight:500}.metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.metric-input label{display:block;font-size:.85rem;color:var(--neutral-600);margin-bottom:var(--space-2)}.metric-input input{width:100%;padding:var(--space-3);border:1px solid var(--neutral-300);border-radius:var(--radius-lg)}.add-injury-form{display:flex;gap:var(--space-3);margin-bottom:var(--space-4)}.add-injury-form input{flex:2;padding:var(--space-3);border:1px solid var(--neutral-300);border-radius:var(--radius-lg)}.add-injury-form select{flex:1;padding:var(--space-3);border:1px solid var(--neutral-300);border-radius:var(--radius-lg)}.injuries-list{display:flex;flex-direction:column;gap:var(--space-2)}.injury-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--neutral-50);border-radius:var(--radius-lg);border-left:4px solid var(--neutral-300)}.injury-item.severity-minor{border-left-color:var(--success)}.injury-item.severity-moderate{border-left-color:var(--warning)}.injury-item.severity-severe{border-left-color:var(--error)}.injury-part{flex:1;font-weight:500}.injury-severity{font-size:.8rem;padding:var(--space-1) var(--space-2);background:var(--neutral-200);border-radius:var(--radius-sm);text-transform:capitalize}.injury-remove{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--neutral-400);font-size:1.2rem;background:none;border-radius:var(--radius-full);transition:all var(--transition-fast)}.injury-remove:hover{color:var(--error);background:#ef44441a}.no-injuries{text-align:center;padding:var(--space-8);background:var(--success);background:#22c55e1a;border-radius:var(--radius-lg)}.no-injuries span{font-size:2rem;display:block;margin-bottom:var(--space-2)}.no-injuries p{color:var(--success);margin:0}.total-time{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-4);background:var(--primary-50);border-radius:var(--radius-lg);margin-bottom:var(--space-6)}.total-time strong{font-size:1.5rem;color:var(--primary-700)}.race-breakdown{display:flex;flex-direction:column;gap:var(--space-4)}.breakdown-item{display:grid;grid-template-columns:100px 1fr 80px;align-items:center;gap:var(--space-4)}.breakdown-item.small label{color:var(--neutral-500);font-size:.9rem}.breakdown-item input[type=range]{width:100%}.breakdown-value{font-weight:600;color:var(--primary-700);text-align:right}.preference-section{margin-bottom:var(--space-6)}.preference-section h4{margin-bottom:var(--space-3)}.rest-day-btn{flex:1;padding:var(--space-3);background:var(--neutral-100);border:2px solid var(--neutral-200);border-radius:var(--radius-lg);font-size:.85rem;font-weight:500;text-transform:capitalize;transition:all var(--transition-fast)}.rest-day-btn:hover{border-color:var(--primary-300)}.rest-day-btn.selected{background:var(--primary-100);border-color:var(--primary-500);color:var(--primary-700)}.split-sliders{display:flex;flex-direction:column;gap:var(--space-4)}.split-item label{display:block;margin-bottom:var(--space-2);font-weight:500}.split-item input[type=range]{width:100%}.hr-inputs{display:grid;grid-template-columns:1fr 1fr 2fr auto;gap:var(--space-4);align-items:end;margin-bottom:var(--space-4)}.hr-input{display:flex;flex-direction:column}.hr-input label{font-size:.85rem;color:var(--neutral-600);margin-bottom:var(--space-2)}.hr-input input{width:100%;padding:var(--space-3);border:1px solid var(--neutral-300);border-radius:var(--radius-lg)}.hr-input.lthr-input .hint{font-size:.75rem;margin-top:var(--space-1)}.hr-zones-preview{display:flex;gap:var(--space-2);flex-wrap:wrap}.zone{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:.85rem;font-weight:500;color:#fff}.zone-1{background:var(--neutral-400)}.zone-2{background:var(--success)}.zone-3{background:var(--primary-500)}.zone-4{background:var(--warning)}.zone-5{background:var(--error)}.demographics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.equipment-grid{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-4)}.equipment-btn{padding:var(--space-3) var(--space-4);background:var(--neutral-100);border:2px solid var(--neutral-200);border-radius:var(--radius-lg);font-size:.9rem;transition:all var(--transition-fast)}.equipment-btn.selected{background:var(--primary-100);border-color:var(--primary-500);color:var(--primary-700)}.strength-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);margin-bottom:var(--space-4)}.strength-select label{display:block;font-size:.9rem;font-weight:500;margin-bottom:var(--space-2);color:var(--neutral-600)}.discipline-options{display:flex;gap:var(--space-2)}.discipline-btn{flex:1;padding:var(--space-3);background:var(--neutral-100);border:2px solid var(--neutral-200);border-radius:var(--radius-lg);font-size:.85rem;text-transform:capitalize;transition:all var(--transition-fast)}.discipline-btn:hover{border-color:var(--neutral-300)}.discipline-btn.selected.strongest{background:var(--success);background:#22c55e26;border-color:var(--success);color:#15803d}.discipline-btn.selected.weakest{background:#f59e0b26;border-color:var(--warning);color:#b45309}.goal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.goal-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-5);background:var(--neutral-50);border:2px solid var(--neutral-200);border-radius:var(--radius-xl);transition:all var(--transition-fast)}.goal-card:hover{border-color:var(--primary-300);background:var(--primary-50)}.goal-card.selected{border-color:var(--primary-600);background:var(--primary-50)}.goal-icon{font-size:2rem}.goal-name{font-weight:600;font-size:.95rem}.goal-desc{font-size:.75rem;color:var(--neutral-500);text-align:center}.wizard-nav{display:flex;justify-content:space-between;padding-top:var(--space-4);border-top:1px solid var(--neutral-200)}@media(max-width:640px){.wizard-container{padding:var(--space-6)}.experience-grid{grid-template-columns:repeat(2,1fr)}.metrics-grid{grid-template-columns:1fr}.add-injury-form{flex-direction:column}.breakdown-item{grid-template-columns:60px 1fr 60px}.rest-days-grid{flex-wrap:wrap}.rest-day-btn{flex:0 0 calc(25% - var(--space-2))}.progress-label{display:none}.hr-inputs{grid-template-columns:1fr 1fr}.hr-input.lthr-input,.hr-inputs .btn{grid-column:1 / -1}}.onboarding-wizard{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-4);background:linear-gradient(135deg,var(--primary-900) 0%,var(--neutral-900) 50%,var(--primary-800) 100%);overflow-y:auto}.wizard-container{width:100%;max-width:600px;background:#fff;border-radius:var(--radius-2xl);box-shadow:0 25px 50px -12px #00000040;overflow:hidden}.wizard-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--neutral-100)}.wizard-logo{display:flex;align-items:center;gap:var(--space-2)}.wizard-logo .logo-icon{font-size:1.25rem}.wizard-logo .logo-text{font-size:1.25rem;font-weight:700;color:var(--primary-600)}.skip-link{color:var(--neutral-400);font-size:.875rem;background:none;padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);transition:all var(--transition-fast)}.skip-link:hover{color:var(--neutral-600);background:var(--neutral-100)}.wizard-close-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:var(--neutral-400);background:transparent;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast)}.wizard-close-btn:hover{color:var(--neutral-600);background:var(--neutral-100)}.onboarding-progress{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:var(--neutral-50);border-bottom:1px solid var(--neutral-100)}.progress-info{display:flex;align-items:center;gap:var(--space-2);font-size:.875rem}.progress-step-text{color:var(--primary-600);font-weight:600}.progress-dot-separator{color:var(--neutral-300)}.progress-title{color:var(--neutral-600)}.progress-dots{display:flex;gap:var(--space-2)}.progress-dot{width:10px;height:10px;border-radius:50%;background:var(--neutral-200);transition:all var(--transition-fast)}.progress-dot.active{background:var(--primary-500);transform:scale(1.2)}.progress-dot.completed{background:var(--success)}.progress-time{font-size:.75rem;color:var(--neutral-400)}.wizard-content{padding:var(--space-6)}.wizard-step h2{font-size:1.5rem;font-weight:700;margin-bottom:var(--space-2);color:var(--neutral-800)}.wizard-step h4{font-size:1rem;font-weight:600;margin-top:var(--space-6);margin-bottom:var(--space-3);color:var(--neutral-700)}.step-hint{color:var(--neutral-500);margin-bottom:var(--space-6);font-size:.95rem}.distance-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3);margin-bottom:var(--space-6)}.distance-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-5);background:var(--neutral-50);border:2px solid var(--neutral-200);border-radius:var(--radius-xl);transition:all var(--transition-fast);cursor:pointer}.distance-card:hover{border-color:var(--primary-300);background:var(--primary-50);transform:translateY(-2px)}.distance-card.selected{border-color:var(--primary-500);background:var(--primary-50);box-shadow:0 0 0 4px #3b82f61a}.distance-icon{font-size:2rem}.distance-name{font-weight:600;color:var(--neutral-800)}.distance-detail{font-size:.75rem;color:var(--neutral-500);text-align:center}.race-details{animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.form-group{margin-bottom:var(--space-5)}.form-group label{display:flex;align-items:center;gap:var(--space-2);font-size:.875rem;font-weight:600;color:var(--neutral-700);margin-bottom:var(--space-2)}.form-group .required{color:var(--error)}.form-input{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--neutral-300);border-radius:var(--radius-lg);font-size:1rem;transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f61a}.form-input::placeholder{color:var(--neutral-400)}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}.form-row.three-col{grid-template-columns:repeat(3,1fr)}.form-hint{display:block;font-size:.75rem;color:var(--neutral-400);margin-top:var(--space-1)}.time-inputs{display:flex;align-items:center;gap:var(--space-2)}.time-input{width:70px!important;text-align:center}.time-separator{color:var(--neutral-500);font-weight:500}.hours-input-wrapper{display:flex;align-items:center;gap:var(--space-2)}.hours-input{width:100px!important;text-align:center}.hours-unit{color:var(--neutral-500)}.tooltip-btn{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--neutral-400);background:var(--neutral-100);border:none;border-radius:50%;cursor:help}.tooltip-btn:hover{color:var(--primary-500);background:var(--primary-50)}.smart-badge{font-size:.7rem;font-weight:500;color:var(--success);background:#22c55e1a;padding:2px 8px;border-radius:var(--radius-full);margin-left:auto}.experience-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2)}.experience-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-4) var(--space-2);background:var(--neutral-50);border:2px solid var(--neutral-200);border-radius:var(--radius-lg);transition:all var(--transition-fast);cursor:pointer}.experience-card:hover{border-color:var(--primary-300);background:var(--primary-50)}.experience-card.selected{border-color:var(--primary-500);background:var(--primary-50)}.experience-icon{font-size:1.5rem}.experience-label{font-size:.8rem;font-weight:600;color:var(--neutral-700)}.experience-desc{font-size:.65rem;color:var(--neutral-400);text-align:center}.rest-days-grid{display:flex;gap:var(--space-2)}.rest-day-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3);background:var(--neutral-50);border:2px solid var(--neutral-200);border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;color:var(--neutral-600);transition:all var(--transition-fast);cursor:pointer;min-height:48px}.rest-day-btn:hover{border-color:var(--primary-300);background:var(--primary-50)}.rest-day-btn.selected{border-color:var(--primary-500);background:var(--primary-500);color:#fff}.rest-day-btn .check{font-size:.7rem;margin-top:2px}.equipment-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2)}.equipment-btn{padding:var(--space-3) var(--space-4);background:var(--neutral-50);border:2px solid var(--neutral-200);border-radius:var(--radius-lg);font-size:.875rem;transition:all var(--transition-fast);cursor:pointer}.equipment-btn:hover{border-color:var(--primary-300);background:var(--primary-50)}.equipment-btn.selected{border-color:var(--success);background:#22c55e1a;color:var(--success)}.step-actions{display:flex;justify-content:center;gap:var(--space-3);margin-top:var(--space-8)}.step-actions.three-buttons{display:grid;grid-template-columns:auto 1fr auto}.step-actions .btn-lg{padding:var(--space-4) var(--space-8);font-size:1rem}.step-actions .btn-xl{padding:var(--space-5) var(--space-10);font-size:1.1rem}.summary-step h2{text-align:center}.summary-card{background:var(--neutral-50);border:1px solid var(--neutral-200);border-radius:var(--radius-xl);padding:var(--space-6);margin-top:var(--space-6)}.summary-section{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-4) 0;border-bottom:1px solid var(--neutral-200)}.summary-section:last-child{border-bottom:none}.summary-section.highlight{background:var(--primary-50);margin:0 calc(-1 * var(--space-6));margin-top:var(--space-4);margin-bottom:calc(-1 * var(--space-6));padding:var(--space-4) var(--space-6);border-bottom:none;border-radius:0 0 var(--radius-xl) var(--radius-xl)}.summary-icon{font-size:1.5rem;flex-shrink:0}.summary-content{display:flex;flex-direction:column;gap:var(--space-1)}.summary-content strong{font-size:1rem;color:var(--neutral-800)}.summary-content span{font-size:.875rem;color:var(--neutral-500)}.capitalize{text-transform:capitalize}.skip-confirm-overlay{position:fixed;inset:0;z-index:1100;display:flex;align-items:center;justify-content:center;background:#00000080;padding:var(--space-4)}.skip-confirm-modal{background:#fff;border-radius:var(--radius-xl);padding:var(--space-6);max-width:400px;text-align:center;box-shadow:var(--shadow-xl)}.skip-confirm-modal h3{margin-bottom:var(--space-3)}.skip-confirm-modal p{color:var(--neutral-600);margin-bottom:var(--space-6)}.skip-confirm-actions{display:flex;gap:var(--space-3);justify-content:center}@media(max-width:640px){.onboarding-wizard{padding:0}.wizard-container{max-width:none;min-height:100vh;border-radius:0}.wizard-content{padding:var(--space-4)}.experience-grid{grid-template-columns:repeat(2,1fr)}.form-row,.form-row.three-col{grid-template-columns:1fr}.rest-days-grid{flex-wrap:wrap}.rest-day-btn{flex:0 0 calc(25% - var(--space-2))}.equipment-grid{grid-template-columns:1fr}.step-actions.three-buttons{grid-template-columns:1fr;gap:var(--space-2)}.step-actions.three-buttons .btn:first-child{order:3}}@media(max-width:380px){.onboarding-progress{flex-direction:column;gap:var(--space-2)}.distance-grid{grid-template-columns:1fr}}.dashboard{min-height:100vh;background:var(--neutral-50);padding:var(--space-6)}.welcome-section{max-width:1200px;margin:0 auto var(--space-6);padding:var(--space-6);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);text-align:center}.welcome-section h1{font-size:1.75rem;margin-bottom:var(--space-2)}.race-countdown{color:var(--neutral-600);font-size:1rem}.race-countdown strong{color:var(--primary-600)}.progress-section{max-width:1200px;margin:0 auto var(--space-6);padding:var(--space-6);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.progress-section h2{font-size:1.25rem;margin-bottom:var(--space-4)}.progress-cards{display:flex;gap:var(--space-4);margin-bottom:var(--space-4)}.progress-card{flex:1;text-align:center;padding:var(--space-4);background:var(--neutral-50);border-radius:var(--radius-lg)}.progress-value{display:block;font-size:2rem;font-weight:700;color:var(--primary-600)}.progress-value-row{display:flex;justify-content:center;align-items:center;gap:var(--space-2);min-height:2.2rem}.value-tbd{font-size:2rem;font-weight:700;color:var(--neutral-400)}.confidence-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.confidence-badge.low{background:var(--neutral-200);color:var(--neutral-600);border:1px solid var(--neutral-300)}.confidence-badge.medium{background:#fef9c3;color:#854d0e;border:1px solid #fde047}.confidence-badge.high{background:#f0fdf4;color:#166534;border:1px solid #86efac}.progress-label{font-size:.85rem;color:var(--neutral-500)}.progress-bar-container{height:8px;background:var(--neutral-200);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--accent-500));border-radius:var(--radius-full);transition:width .5s ease}.today-section{max-width:1200px;margin:0 auto var(--space-6);padding:var(--space-6);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.today-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.today-header h2{font-size:1.25rem;margin:0}.today-total{color:var(--neutral-500);font-size:.9rem}.today-workouts{display:flex;flex-direction:column;gap:var(--space-4)}.rest-day-card{text-align:center;padding:var(--space-8);background:linear-gradient(135deg,var(--neutral-50),rgba(34,197,94,.1));border-radius:var(--radius-xl)}.rest-icon{font-size:3rem;display:block;margin-bottom:var(--space-3)}.rest-day-card h3{margin-bottom:var(--space-2)}.rest-day-card p{color:var(--neutral-600)}.workout-card-large{padding:var(--space-5);background:var(--neutral-50);border-radius:var(--radius-xl);border-left:4px solid var(--neutral-300)}.workout-card-large.swim{border-left-color:var(--swim-color)}.workout-card-large.bike{border-left-color:var(--bike-color)}.workout-card-large.run{border-left-color:var(--run-color)}.workout-card-large.brick{border-left-color:var(--accent-500)}.workout-card-large.strength{border-left-color:var(--neutral-600)}.workout-card-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-3)}.workout-type-icon{font-size:2.5rem}.workout-card-info h3{font-size:1.25rem;margin-bottom:var(--space-1)}.workout-duration{color:var(--neutral-500);font-size:.9rem}.workout-description{color:var(--neutral-600);line-height:1.6;margin-bottom:var(--space-4)}.workout-preview{padding:var(--space-4);background:#fff;border-radius:var(--radius-lg)}.workout-preview strong{display:block;margin-bottom:var(--space-2);font-size:.9rem}.workout-preview ul{list-style:none;padding:0;margin:0}.workout-preview li{padding:var(--space-2) 0;border-bottom:1px solid var(--neutral-100);font-size:.9rem;color:var(--neutral-600)}.workout-preview li:last-child{border-bottom:none}.more-steps{color:var(--primary-600);font-style:italic}.workout-card-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-3);width:100%;background:none;border:none;padding:0;cursor:pointer;text-align:left;font-family:inherit}.workout-card-header:hover{opacity:.9}.workout-expand-icon{font-size:.8rem;color:var(--neutral-400);transition:transform .2s ease;margin-left:auto}.workout-expand-icon.expanded{transform:rotate(180deg)}.workout-card-large.expanded{background:#fff;box-shadow:var(--shadow-sm)}.workout-details{margin-top:var(--space-4)}.workout-details .workout-description{margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--neutral-200)}.workout-steps{margin-bottom:var(--space-4)}.workout-steps h4{font-size:.95rem;margin-bottom:var(--space-3);color:var(--neutral-700)}.workout-step{background:var(--neutral-50);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-3)}.workout-step:last-child{margin-bottom:0}.step-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.step-intensity{display:inline-block;padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:.7rem;font-weight:600;text-transform:uppercase;color:#fff}.step-duration{font-size:.85rem;color:var(--neutral-500);font-weight:500}.step-content strong{display:block;margin-bottom:var(--space-1);color:var(--neutral-800)}.step-content p{font-size:.9rem;color:var(--neutral-600);line-height:1.5;margin:0}.step-targets{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-2)}.target-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:var(--neutral-100);border-radius:var(--radius-md);font-size:.75rem;color:var(--neutral-600)}.workout-tips{background:#22c55e1a;padding:var(--space-4);border-radius:var(--radius-lg)}.workout-tips h4{font-size:.9rem;margin-bottom:var(--space-2);color:var(--neutral-700)}.workout-tips ul{list-style:none;padding:0;margin:0}.workout-tips li{padding:var(--space-2) 0;font-size:.9rem;color:var(--neutral-600);border-bottom:1px solid rgba(34,197,94,.2)}.workout-tips li:last-child{border-bottom:none;padding-bottom:0}.stats-section{max-width:1200px;margin:0 auto;padding:var(--space-6);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.stats-section h2{font-size:1.25rem;margin-bottom:var(--space-4)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.stat-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--neutral-50);border-radius:var(--radius-lg)}.stat-icon{font-size:1.5rem}.stat-value{font-size:1.1rem;font-weight:600;color:var(--neutral-800)}.stat-label{font-size:.8rem;color:var(--neutral-500)}@media(max-width:768px){.dashboard{padding:var(--space-4);padding-bottom:calc(var(--space-4) + 80px)}.welcome-section{padding:var(--space-5);margin-bottom:var(--space-4);border-radius:var(--radius-xl)}.welcome-section h1{font-size:1.25rem;margin-bottom:var(--space-2)}.race-countdown{font-size:.9rem}.progress-section{margin-bottom:var(--space-4)}.progress-section h2{font-size:1rem;margin-bottom:var(--space-3)}.progress-cards{flex-direction:column;gap:var(--space-3)}.progress-card{padding:var(--space-4);border-radius:var(--radius-lg);background:var(--neutral-50);border:1px solid var(--neutral-200)}.progress-value{font-size:1.25rem}.progress-label{font-size:.8rem}.today-section{margin-bottom:var(--space-4)}.today-header{margin-bottom:var(--space-3)}.today-header h2{font-size:1rem}.workout-card-large{border-radius:var(--radius-lg)}.workout-card-header{padding:var(--space-4)}.workout-type-icon{font-size:2rem}.workout-card-info h3{font-size:1rem}.stats-section{margin-bottom:var(--space-4)}.stats-section h2{font-size:1rem;margin-bottom:var(--space-3)}.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.stat-card{padding:var(--space-3);border-radius:var(--radius-lg)}.stat-icon{font-size:1.25rem}.stat-value{font-size:.9rem}.stat-label{font-size:.7rem}.rest-day-card{padding:var(--space-6);border-radius:var(--radius-xl)}.rest-day-card h3{font-size:1.25rem}}.empty-dashboard{min-height:100%;padding:var(--space-6);background:var(--neutral-50)}.empty-dashboard-content{max-width:800px;margin:0 auto}.welcome-section{text-align:center;margin-bottom:var(--space-8)}.welcome-title{font-size:2rem;font-weight:700;color:var(--neutral-800);margin-bottom:var(--space-2)}.welcome-subtitle{font-size:1.1rem;color:var(--neutral-500)}.error-banner{display:flex;gap:var(--space-4);padding:var(--space-4);background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-lg);margin-bottom:var(--space-6)}.error-banner.error-auth{background:#fffbeb;border-color:#fde68a}.error-banner.error-network,.error-banner.error-timeout{background:#eff6ff;border-color:#bfdbfe}.error-icon{font-size:1.5rem;flex-shrink:0}.error-content{flex:1}.error-content strong{display:block;color:#991b1b;margin-bottom:var(--space-1)}.error-auth .error-content strong{color:#92400e}.error-network .error-content strong,.error-timeout .error-content strong{color:#1e40af}.error-content p{color:#7f1d1d;font-size:.9rem;margin:0 0 var(--space-2) 0}.error-auth .error-content p{color:#78350f}.error-network .error-content p,.error-timeout .error-content p{color:#1e3a8a}.error-actions{display:flex;gap:var(--space-2);margin-top:var(--space-3)}.error-actions .btn{font-size:.85rem}.empty-state-card{text-align:center;padding:var(--space-8);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);margin-bottom:var(--space-8)}.empty-state-icon{font-size:4rem;margin-bottom:var(--space-4)}.empty-state-card h2{font-size:1.5rem;font-weight:700;color:var(--neutral-800);margin-bottom:var(--space-3)}.empty-state-card p{color:var(--neutral-600);font-size:1rem;line-height:1.6;max-width:500px;margin:0 auto var(--space-6)}.create-plan-cta{padding:var(--space-4) var(--space-8)!important;font-size:1.1rem!important}.quick-links{text-align:center}.quick-links h3{font-size:1rem;font-weight:500;color:var(--neutral-500);margin-bottom:var(--space-4)}.quick-links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.quick-link-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-5);background:#fff;border-radius:var(--radius-lg);border:1px solid var(--neutral-200);text-decoration:none;transition:all var(--transition-fast)}.quick-link-card:hover{border-color:var(--primary-300);box-shadow:var(--shadow-md);transform:translateY(-2px)}.quick-link-icon{font-size:2rem}.quick-link-title{font-weight:600;color:var(--neutral-800)}.quick-link-desc{font-size:.85rem;color:var(--neutral-500);text-align:center}@media(max-width:768px){.empty-dashboard{padding:var(--space-4)}.welcome-title{font-size:1.5rem}.empty-state-card{padding:var(--space-6)}.empty-state-icon{font-size:3rem}.quick-links-grid{grid-template-columns:1fr}}.app-header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--neutral-200);box-shadow:var(--shadow-sm)}.header-container{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto;padding:var(--space-3) var(--space-6)}.header-brand{display:flex;align-items:center;gap:var(--space-3)}.header-logo{font-size:1.25rem}.header-title{font-size:1.25rem;font-weight:700;background:linear-gradient(135deg,var(--primary-600),var(--accent-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-race{font-size:.85rem;color:var(--neutral-500);padding-left:var(--space-3);border-left:1px solid var(--neutral-300)}.header-nav{display:flex;gap:var(--space-1)}.nav-tab{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:none;border:none;border-radius:var(--radius-lg);font-size:.9rem;font-weight:500;color:var(--neutral-600);cursor:pointer;transition:all var(--transition-fast)}.nav-tab:hover:not(:disabled){background:var(--neutral-100);color:var(--neutral-800)}.nav-tab.active{background:var(--primary-50);color:var(--primary-700)}.nav-tab:disabled{opacity:.5;cursor:not-allowed}.tab-icon{font-size:1.1rem}.tab-label{display:inline}.header-user{display:flex;align-items:center;gap:var(--space-3)}.user-name{font-size:.9rem;color:var(--neutral-600)}@media(max-width:768px){.app-header{position:fixed;inset:auto 0 0;border-bottom:none;border-top:1px solid var(--neutral-200);box-shadow:0 -2px 10px #0000001a;padding-bottom:env(safe-area-inset-bottom,0)}.header-container{padding:var(--space-1) var(--space-2);flex-direction:row;justify-content:space-around;gap:0}.header-brand,.header-user{display:none}.header-nav{width:100%;justify-content:space-around;gap:0;border-top:none;padding-top:0}.nav-tab{flex-direction:column;padding:var(--space-2) var(--space-3);min-width:56px;min-height:48px;gap:var(--space-1);border-radius:var(--radius-md)}.nav-tab:active{transform:scale(.95);background:var(--primary-100)}.tab-icon{font-size:1.35rem}.tab-label{display:block;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.nav-tab.active .tab-label{color:var(--primary-600)}.header-race,.user-name{display:none}}.footer-professional{background-color:var(--neutral-900);color:var(--neutral-400);padding:4rem 0 2rem;border-top:1px solid #1e293b;margin-top:auto}.footer-content{max-width:1200px;margin:0 auto;padding:0 1.5rem}.footer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3rem;margin-bottom:3rem}.footer-brand-col{grid-column:span 1}.footer-logo{display:flex;align-items:center;gap:.5rem;color:#fff;font-weight:700;font-size:1.25rem;margin-bottom:1rem}.footer-tagline{font-size:.9rem;line-height:1.6;margin-bottom:1.5rem}.footer-heading{color:#fff;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.footer-links-list{list-style:none;padding:0;margin:0}.footer-links-list li{margin-bottom:.75rem}.footer-links-list a{font-size:.9rem;color:var(--neutral-400);transition:color .2s}.footer-links-list a:hover{color:#fff}.footer-bottom{border-top:1px solid var(--neutral-800);padding-top:2rem;display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:var(--neutral-500)}.footer-meta{display:flex;align-items:center;gap:.75rem}.footer-version{padding:2px 6px;background-color:var(--neutral-800);border-radius:4px;font-size:.7rem;color:var(--neutral-400);font-family:monospace;opacity:.8;letter-spacing:0}@media(max-width:768px){.footer-professional{padding-bottom:7rem}.footer-grid{grid-template-columns:1fr;gap:2rem}.footer-bottom{flex-direction:column;gap:1rem;text-align:center}}.app-layout{min-height:100vh;display:flex;flex-direction:column;background:var(--neutral-50)}.app-main{flex:1;overflow-y:auto}.page-layout{min-height:100vh;display:flex;flex-direction:column;background-color:var(--neutral-50)}.page-hero{background:var(--neutral-900);padding-bottom:8rem;padding-top:2rem;color:#fff}.page-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem}.page-back-link{display:flex;align-items:center;gap:.5rem;color:var(--neutral-400);font-weight:500;font-size:.9rem;transition:color .2s;text-decoration:none}.page-back-link:hover{color:#fff}.page-label{color:var(--neutral-500);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.page-header-content{max-width:800px}.page-title{font-size:clamp(2rem,5vw,3rem);font-weight:700;color:#fff;margin-bottom:1rem;letter-spacing:-.02em}.page-subtitle{font-size:1.125rem;color:var(--neutral-400);max-width:600px;line-height:1.6}.page-date{margin-top:1rem;font-size:.875rem;color:var(--neutral-500);font-family:monospace}.page-main{flex-grow:1;width:100%;max-width:1000px;margin:-6rem auto 3rem;padding:0 1.5rem;position:relative;z-index:10}.page-card{background:#fff;border-radius:var(--radius-xl);padding:3rem;box-shadow:var(--shadow-xl);border:1px solid var(--neutral-200)}.page-content section{margin-bottom:2.5rem}.page-content h2{font-size:1.5rem;color:var(--neutral-900);margin-bottom:1rem;border-bottom:1px solid var(--neutral-200);padding-bottom:.5rem}.page-content p{margin-bottom:1rem;color:var(--neutral-600);line-height:1.7}.page-content ul{list-style-type:disc;padding-left:1.5rem;margin-bottom:1rem;color:var(--neutral-600)}.page-content li{margin-bottom:.5rem}.page-content a{color:var(--primary-600);text-decoration:underline}.page-content a:hover{color:var(--primary-700)}@media(max-width:640px){.page-card{padding:1.5rem}.page-hero{padding-top:1rem;padding-bottom:6rem}}.api-disclosure{background-color:#eff6ff;border:1px solid #dbeafe;border-radius:var(--radius-lg);padding:1.5rem;margin:1.5rem 0}.api-disclosure-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.api-disclosure-title{font-weight:700;color:var(--primary-900);font-size:1rem;margin:0}.api-disclosure p,.api-disclosure ul{color:var(--primary-800);font-size:.95rem}.api-disclosure-note{margin-top:1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--primary-700)}.offline-indicator{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:.875rem;font-weight:500;text-align:center;position:fixed!important;bottom:0;left:0;right:0;z-index:9999;animation:slideUp .3s ease-out;box-shadow:0 -4px 6px -1px #0000001a}@keyframes slideDown{0%{transform:translateY(0);opacity:1}to{transform:translateY(100%);opacity:0}}.offline-indicator--offline{background-color:var(--warning);color:var(--neutral-900)}.offline-indicator--online{background-color:var(--success);color:#fff;animation:slideDown .3s ease-in forwards}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-100%)}}.offline-indicator__icon{width:1rem;height:1rem;flex-shrink:0}@media(max-width:480px){.offline-indicator{font-size:.8125rem;padding:var(--space-2) var(--space-3)}.offline-indicator__icon{width:.875rem;height:.875rem}}.install-prompt{position:fixed;bottom:calc(70px + var(--space-4) + env(safe-area-inset-bottom,0px));left:var(--space-4);right:var(--space-4);max-width:400px;margin:0 auto;background:#1e293bf2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);padding:var(--space-4);box-shadow:var(--shadow-xl);z-index:1000;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.install-prompt__content{display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4)}.install-prompt__icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-600),var(--primary-500));border-radius:var(--radius-lg);color:#fff}.install-prompt__icon svg{width:24px;height:24px}.install-prompt__text{flex:1;min-width:0}.install-prompt__title{font-size:1rem;font-weight:600;color:#fff;margin:0 0 var(--space-1) 0}.install-prompt__description{font-size:.875rem;color:var(--neutral-300);margin:0;line-height:1.4}.install-prompt__actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3)}.install-prompt__dismiss{background:none;border:none;color:var(--neutral-400);font-size:.875rem;font-weight:500;padding:var(--space-2) var(--space-3);cursor:pointer;transition:color var(--transition-fast)}.install-prompt__dismiss:hover{color:var(--neutral-200)}.install-prompt__install{background:linear-gradient(135deg,var(--primary-600),var(--accent-500));border:none;color:#fff;font-size:.875rem;font-weight:600;padding:var(--space-2) var(--space-5);border-radius:var(--radius-full);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.install-prompt__install:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2563eb66}.install-prompt__install:active{transform:translateY(0)}@media(min-width:768px){.install-prompt{bottom:var(--space-6);left:auto;right:var(--space-6)}}.notification-prompt{position:fixed;bottom:calc(70px + var(--space-4) + env(safe-area-inset-bottom,0px));left:var(--space-4);right:var(--space-4);max-width:400px;margin:0 auto;background:#1e293bf2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);padding:var(--space-4);box-shadow:var(--shadow-xl);z-index:999;animation:notificationSlideUp .3s ease-out}@keyframes notificationSlideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.notification-prompt--ios-info{position:relative;padding-right:calc(var(--space-4) + 32px)}.notification-prompt__content{display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4)}.notification-prompt--ios-info .notification-prompt__content{margin-bottom:0}.notification-prompt__icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-500),var(--accent-400));border-radius:var(--radius-lg);color:#fff}.notification-prompt__icon--info{background:linear-gradient(135deg,var(--primary-500),var(--primary-400))}.notification-prompt__icon svg{width:24px;height:24px}.notification-prompt__text{flex:1;min-width:0}.notification-prompt__title{font-size:1rem;font-weight:600;color:#fff;margin:0 0 var(--space-1) 0}.notification-prompt__description{font-size:.875rem;color:var(--neutral-300);margin:0;line-height:1.4}.notification-prompt__actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3)}.notification-prompt__dismiss{background:none;border:none;color:var(--neutral-400);font-size:.875rem;font-weight:500;padding:var(--space-2) var(--space-3);cursor:pointer;transition:color var(--transition-fast)}.notification-prompt__dismiss:hover:not(:disabled){color:var(--neutral-200)}.notification-prompt__dismiss:disabled{opacity:.5;cursor:not-allowed}.notification-prompt__enable{background:linear-gradient(135deg,var(--accent-500),var(--accent-400));border:none;color:#fff;font-size:.875rem;font-weight:600;padding:var(--space-2) var(--space-5);border-radius:var(--radius-full);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast);min-width:80px}.notification-prompt__enable:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #f9731666}.notification-prompt__enable:active:not(:disabled){transform:translateY(0)}.notification-prompt__enable:disabled{opacity:.7;cursor:not-allowed}.notification-prompt__dismiss-icon{position:absolute;top:var(--space-3);right:var(--space-3);width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--neutral-400);cursor:pointer;border-radius:var(--radius-full);transition:background-color var(--transition-fast),color var(--transition-fast)}.notification-prompt__dismiss-icon:hover{background-color:#ffffff1a;color:var(--neutral-200)}.notification-prompt__dismiss-icon svg{width:16px;height:16px}@media(min-width:768px){.notification-prompt{bottom:var(--space-6);left:auto;right:var(--space-6)}}.page-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:var(--space-4)}.page-loader-spinner{width:48px;height:48px;border:4px solid var(--neutral-200);border-top:4px solid var(--primary-500);border-radius:50%;animation:page-loader-spin 1s linear infinite}@keyframes page-loader-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.page-loader-text{color:var(--neutral-500);font-size:.95rem;margin:0}.public-layout{display:flex;flex-direction:column;min-height:100vh}.public-content{flex:1;margin-top:60px}.nav-link{color:var(--neutral-600);text-decoration:none;font-weight:500;transition:color .2s ease}.nav-link:hover{color:var(--primary-600)}.testimonials-minimal{padding:var(--space-20) 0;background-color:var(--neutral-50)}.testimonials-grid-minimal{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-8);margin-top:var(--space-12)}.testimonial-card{background:#fff;padding:var(--space-8);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:var(--space-6);transition:transform var(--transition-base)}.testimonial-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.testimonial-quote{font-size:1.1rem;color:var(--neutral-700);line-height:1.6;font-style:italic}.testimonial-author{display:flex;align-items:center;gap:var(--space-4);margin-top:auto}.testimonial-avatar{width:48px;height:48px;background:var(--primary-50);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.testimonial-name{display:block;font-weight:700;color:var(--neutral-900)}.testimonial-detail{display:block;font-size:.85rem;color:var(--neutral-500)}.app{min-height:100vh;display:flex;flex-direction:column}.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:var(--space-4) 0;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--neutral-200)}.nav-container{display:flex;align-items:center;justify-content:space-between}.nav-logo{display:flex;align-items:center;gap:var(--space-2);font-weight:700;font-size:1.25rem}.logo-icon{font-size:1.5rem}.logo-text{background:linear-gradient(135deg,var(--primary-600),var(--primary-800));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-links{display:flex;align-items:center;gap:var(--space-6)}.nav-links a{color:var(--neutral-600);font-weight:500;transition:color var(--transition-fast)}.nav-links a:hover{color:var(--primary-600)}.nav-user{display:flex;align-items:center;gap:var(--space-3)}.nav-email{color:var(--neutral-600);font-weight:500;font-size:.9rem}.nav-loading{color:var(--neutral-400)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-weight:600;font-size:.95rem;border-radius:var(--radius-lg);transition:all var(--transition-base)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:.875rem}.btn-lg{padding:var(--space-4) var(--space-8);font-size:1rem}.btn-primary{background:linear-gradient(135deg,var(--primary-600),var(--primary-700));color:#fff;box-shadow:0 4px 14px #2563eb66}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2563eb80}.btn-outline{border:2px solid var(--neutral-300);color:var(--neutral-700);background:transparent}.btn-outline:hover{border-color:var(--primary-600);color:var(--primary-600)}.btn-block{width:100%}.btn-arrow{transition:transform var(--transition-fast)}.btn:hover .btn-arrow{transform:translate(4px)}.hero{position:relative;padding:calc(var(--space-24) + 60px) 0 var(--space-24);background:linear-gradient(135deg,var(--neutral-50) 0%,var(--primary-50) 100%);overflow:hidden}.hero-bg{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(59,130,246,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(249,115,22,.1) 0%,transparent 50%);pointer-events:none}.hero-container{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:var(--space-12);align-items:center}.hero-eyebrow{display:inline-block;padding:var(--space-2) var(--space-4);background:var(--primary-100);color:var(--primary-700);font-weight:600;font-size:.875rem;border-radius:var(--radius-full);margin-bottom:var(--space-4)}.hero-title{font-size:clamp(2.5rem,5vw,4rem);line-height:1.1;margin-bottom:var(--space-6)}.hero-description{font-size:1.125rem;color:var(--neutral-600);max-width:540px;margin-bottom:var(--space-8)}.hero-cta{display:flex;gap:var(--space-4);margin-bottom:var(--space-12)}.hero-stats{display:flex;gap:var(--space-10)}.stat{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:700;color:var(--neutral-900)}.stat-label{font-size:.875rem;color:var(--neutral-500)}.hero-visual{position:relative;display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-8)}.hero-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5) var(--space-6);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);transform:translate(0);transition:transform var(--transition-base),box-shadow var(--transition-base)}.hero-card:hover{transform:translate(8px);box-shadow:var(--shadow-xl)}.hero-card:nth-child(1){animation:slideIn .5s ease .1s both}.hero-card:nth-child(2){animation:slideIn .5s ease .2s both}.hero-card:nth-child(3){animation:slideIn .5s ease .3s both}@keyframes slideIn{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.card-icon{font-size:2rem}.card-label{font-weight:600;color:var(--neutral-700);flex:1}.card-stat{font-weight:700;font-size:1.125rem}.swim-card .card-stat{color:var(--swim-color)}.bike-card .card-stat{color:var(--bike-color)}.run-card .card-stat{color:var(--run-color)}.section-header{text-align:center;max-width:600px;margin:0 auto var(--space-12)}.section-eyebrow{display:inline-block;padding:var(--space-1) var(--space-3);background:var(--accent-100);color:var(--accent-700);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full);margin-bottom:var(--space-3)}.section-title{margin-bottom:var(--space-4)}.section-description{color:var(--neutral-600);font-size:1.125rem}.features{padding:var(--space-24) 0;background:#fff}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-8)}.feature-card{padding:var(--space-8);background:var(--neutral-50);border-radius:var(--radius-xl);border:1px solid var(--neutral-200);transition:all var(--transition-base)}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-200)}.feature-icon{font-size:2.5rem;margin-bottom:var(--space-4)}.feature-title{font-size:1.25rem;margin-bottom:var(--space-3)}.feature-description{color:var(--neutral-600);line-height:1.7}.plans{padding:var(--space-24) 0;background:linear-gradient(180deg,var(--neutral-50) 0%,white 100%)}.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-6)}.plan-card{position:relative;padding:var(--space-8);background:#fff;border-radius:var(--radius-xl);border:2px solid var(--neutral-200);text-align:center;transition:all var(--transition-base)}.plan-card:hover{border-color:var(--primary-300);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.plan-card.featured{border-color:var(--primary-500);background:linear-gradient(180deg,var(--primary-50) 0%,white 100%)}.plan-badge{position:absolute;top:calc(-1 * var(--space-3));left:50%;transform:translate(-50%);padding:var(--space-1) var(--space-4);background:var(--neutral-800);color:#fff;font-size:.75rem;font-weight:600;border-radius:var(--radius-full);white-space:nowrap}.plan-card.featured .plan-badge{background:linear-gradient(135deg,var(--primary-600),var(--accent-500))}.plan-name{font-size:1.75rem;margin:var(--space-4) 0 var(--space-6)}.plan-distances{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4) 0;margin-bottom:var(--space-6);border-top:1px solid var(--neutral-200);border-bottom:1px solid var(--neutral-200)}.plan-distances span{color:var(--neutral-600);font-size:.95rem}.footer{margin-top:auto;padding:var(--space-12) 0 var(--space-6);background:var(--neutral-900);color:var(--neutral-400)}.footer-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-6);text-align:center}.footer-brand{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.footer-brand .logo-text{color:#fff;background:none;-webkit-text-fill-color:white}.footer-links{display:flex;gap:var(--space-6)}.footer-links a{color:var(--neutral-400);transition:color var(--transition-fast)}.footer-links a:hover{color:#fff}.footer-copy{font-size:.875rem;color:var(--neutral-500)}@media(max-width:768px){.nav{padding:var(--space-3) 0}.nav-container{padding:0 var(--space-4)}.nav-links a:not(.btn){display:none}.nav-logo{font-size:1rem}.logo-icon{font-size:1.25rem}.hero{padding:calc(var(--space-16) + 40px) 0 var(--space-12)}.hero-container{grid-template-columns:1fr;text-align:center}.hero-container-minimal{padding:var(--space-8) 0}.hero-title-minimal{font-size:2rem;line-height:1.15;margin-bottom:var(--space-4)}.hero-description{margin-left:auto;margin-right:auto;font-size:1rem}.hero-description-minimal{font-size:1rem;margin-bottom:var(--space-6)}.btn-xl{padding:var(--space-4) var(--space-6);font-size:1rem;width:100%}.hero-cta{justify-content:center;flex-wrap:wrap}.hero-stats{justify-content:center;gap:var(--space-6)}.hero-visual{display:none}.features-grid{grid-template-columns:1fr}.features-minimal{padding:var(--space-12) 0}.features-grid-minimal{grid-template-columns:1fr;gap:var(--space-4);margin-bottom:var(--space-8)}.feature-card-minimal{padding:var(--space-5)}.feature-icon-minimal{font-size:2rem}.feature-title-minimal{font-size:1rem}.feature-description-minimal{font-size:.9rem}.coming-soon-header{font-size:1rem;margin-bottom:var(--space-4)}.plans-grid{grid-template-columns:1fr}.distance-modal{padding:var(--space-6);padding-bottom:calc(var(--space-6) + env(safe-area-inset-bottom,0))}.distance-options{gap:var(--space-3)}.distance-option{padding:var(--space-4)}.distance-option:active{transform:scale(.98);background:var(--primary-100)}.distance-name{font-size:1rem}.distance-detail{font-size:.85rem}}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--neutral-50) 0%,var(--primary-50) 100%);gap:var(--space-4)}.app-loading p{color:var(--neutral-500);font-size:1rem;font-weight:500}.loading-spinner{width:48px;height:48px;border:4px solid var(--primary-100);border-top-color:var(--primary-600);border-radius:50%;animation:spinner .8s linear infinite}@keyframes spinner{to{transform:rotate(360deg)}}.hero-container-minimal{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-16) 0}.hero-content-minimal{max-width:700px}.hero-title-minimal{font-size:clamp(2.5rem,6vw,4.5rem);line-height:1.1;margin-bottom:var(--space-6);font-weight:800}.hero-description-minimal{font-size:1.25rem;color:var(--neutral-600);margin-bottom:var(--space-8);line-height:1.6}.btn-xl{padding:var(--space-5) var(--space-10);font-size:1.125rem}.text-gradient{background:linear-gradient(135deg,var(--primary-600),var(--accent-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.features-minimal{padding:var(--space-16) 0;background:#fff}.features-grid-minimal{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);margin-bottom:var(--space-12)}.feature-card-minimal{position:relative;padding:var(--space-6);background:var(--neutral-50);border-radius:var(--radius-xl);border:1px solid var(--neutral-200);text-align:center;transition:all var(--transition-base)}.feature-card-minimal:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.feature-icon-minimal{font-size:2.5rem;margin-bottom:var(--space-3)}.feature-title-minimal{font-size:1.125rem;font-weight:600;margin-bottom:var(--space-2);color:var(--neutral-900)}.feature-description-minimal{font-size:.95rem;color:var(--neutral-600);line-height:1.6}.coming-soon-header{text-align:center;font-size:1.25rem;font-weight:600;color:var(--neutral-500);margin-bottom:var(--space-6);text-transform:uppercase;letter-spacing:.05em}.coming-soon-card{opacity:.85;background:linear-gradient(135deg,var(--neutral-100),var(--neutral-50))}.coming-soon-badge{position:absolute;top:var(--space-3);right:var(--space-3);font-size:.7rem;font-weight:600;text-transform:uppercase;padding:var(--space-1) var(--space-2);background:var(--neutral-200);color:var(--neutral-600);border-radius:var(--radius-full)}.plans-minimal{padding:var(--space-16) 0;background:linear-gradient(180deg,var(--neutral-50) 0%,white 100%)}.plans-grid-minimal{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.plan-card-minimal{position:relative;display:flex;flex-direction:column;align-items:center;padding:var(--space-6);background:#fff;border:2px solid var(--neutral-200);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-base)}.plan-card-minimal:hover{border-color:var(--primary-400);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.plan-card-minimal.featured{border-color:var(--primary-500);background:linear-gradient(180deg,var(--primary-50) 0%,white 100%)}.plan-badge-minimal{position:absolute;top:calc(-1 * var(--space-3));font-size:.7rem;font-weight:600;text-transform:uppercase;padding:var(--space-1) var(--space-3);background:linear-gradient(135deg,var(--primary-600),var(--accent-500));color:#fff;border-radius:var(--radius-full)}.plan-name-minimal{font-size:1.5rem;font-weight:700;color:var(--neutral-900);margin-bottom:var(--space-2)}.plan-detail-minimal{font-size:.875rem;color:var(--neutral-500)}@media(max-width:992px){.features-grid-minimal,.plans-grid-minimal{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.hero-title-minimal{font-size:2rem}.hero-description-minimal{font-size:1rem}.features-grid-minimal,.plans-grid-minimal{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4)}.modal-content{background:#fff;border-radius:var(--radius-2xl);max-width:560px;width:100%;max-height:90vh;overflow-y:auto;position:relative;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-close{position:absolute;top:var(--space-4);right:var(--space-4);background:var(--neutral-100);border:none;width:36px;height:36px;border-radius:50%;font-size:1.5rem;color:var(--neutral-600);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.modal-close:hover{background:var(--neutral-200);color:var(--neutral-900)}.distance-modal{padding:var(--space-8)}.modal-title{font-size:1.5rem;font-weight:700;text-align:center;margin-bottom:var(--space-2);color:var(--neutral-900)}.modal-subtitle{text-align:center;color:var(--neutral-500);margin-bottom:var(--space-6)}.distance-options{display:flex;flex-direction:column;gap:var(--space-3)}.distance-option{display:flex;flex-direction:column;align-items:flex-start;padding:var(--space-5);background:var(--neutral-50);border:2px solid var(--neutral-200);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-base);text-align:left}.distance-option:hover{border-color:var(--primary-400);background:var(--primary-50);transform:translate(4px)}.distance-option.featured{border-color:var(--primary-400);background:linear-gradient(135deg,var(--primary-50),white)}.distance-name{font-size:1.125rem;font-weight:600;color:var(--neutral-900);margin-bottom:var(--space-1)}.distance-detail{font-size:.875rem;color:var(--neutral-600);margin-bottom:var(--space-2)}.distance-badge{font-size:.7rem;font-weight:600;text-transform:uppercase;padding:var(--space-1) var(--space-2);background:var(--neutral-200);color:var(--neutral-600);border-radius:var(--radius-full)}.distance-badge.popular{background:linear-gradient(135deg,var(--primary-600),var(--accent-500));color:#fff}
