:root{--primary:#ff6b35;--primary-dark:#e55a25;--primary-light:#fff3ef;--secondary:#1a1a2e;--accent:#00c49f;--accent-light:#e6faf7;--warning:#ffb800;--danger:#f44;--danger-light:#fff0f0;--bg:#f0f2f5;--surface:#fff;--surface-2:#f8f9fa;--border:#e8e8e8;--text:#1a1a2e;--text-secondary:#555;--text-muted:#999;--radius:16px;--radius-sm:10px;--radius-xs:6px;--shadow:0 2px 12px #0000000f;--shadow-md:0 4px 16px #0000001a;--nav-height:82px;--header-height:60px;--transition:.18s ease}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{height:100%;font-size:16px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;overflow-x:hidden}#root{background:var(--bg);max-width:500px;min-height:100dvh;margin:0 auto;position:relative}.page{padding:16px;padding-top:calc(var(--header-height) + 16px);padding-bottom:calc(var(--nav-height) + 24px);min-height:100dvh;animation:.22s pageIn}@keyframes pageIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}button{cursor:pointer;border:none;font-family:inherit}.btn{border-radius:var(--radius-sm);transition:background var(--transition), transform var(--transition), box-shadow var(--transition);white-space:nowrap;justify-content:center;align-items:center;gap:6px;padding:13px 20px;font-size:15px;font-weight:600;line-height:1;text-decoration:none;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);box-shadow:0 4px 14px #ff6b3561}.btn-primary:active{transform:scale(.97)}.btn-secondary{background:var(--surface);color:var(--text);border:1.5px solid var(--border)}.btn-secondary:hover{background:var(--surface-2)}.btn-danger{background:var(--danger-light);color:var(--danger);border:1.5px solid #0000}.btn-danger:hover{background:var(--danger);color:#fff}.btn-full{width:100%}.btn-sm{border-radius:var(--radius-xs);padding:7px 12px;font-size:13px}input,select,textarea{font-family:inherit}.form-group{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.form-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;font-size:11px;font-weight:700}.form-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);width:100%;transition:border-color var(--transition), box-shadow var(--transition);appearance:none;padding:12px 14px;font-size:15px}.form-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #ff6b351f}.form-row{gap:10px;display:flex}.form-row .form-group{flex:1}.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.section-title{color:var(--text);margin-bottom:12px;font-size:17px;font-weight:700}.auth-nudge{color:var(--text-muted);align-items:center;gap:10px;margin-bottom:16px;font-size:14px;display:flex}.auth-nudge span{flex-shrink:0;font-size:20px}.empty-state{text-align:center;color:var(--text-muted);padding:56px 24px}.empty-state-icon{margin-bottom:14px;font-size:52px;display:block}.empty-state p{font-size:15px;line-height:1.5}.app-loading{height:100dvh;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:14px;font-size:14px;display:flex}.app-loading-spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}@media (width>=500px){.page{padding:20px 24px;padding-top:calc(var(--header-height) + 20px);padding-bottom:calc(var(--nav-height) + 28px)}}@media (width>=768px){:root{--sidebar-width:220px;--nav-height:0px;--header-height:60px}#root{max-width:100%}.page{margin-left:var(--sidebar-width);max-width:calc(var(--sidebar-width) + 1080px);padding:40px 48px;padding-top:calc(var(--header-height) + 40px);padding-bottom:48px}.card{padding:20px}.section-title{font-size:18px}}.navbar{width:100%;max-width:500px;height:var(--nav-height);background:var(--surface);border-top:1px solid var(--border);z-index:100;padding-bottom:env(safe-area-inset-bottom);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -2px 12px #0000000f}.nav-brand{display:none}.nav-item{border-radius:var(--radius-sm);color:var(--text-muted);transition:color var(--transition), background var(--transition), transform var(--transition);flex-direction:column;flex:1;align-items:center;gap:4px;min-width:0;padding:10px 12px;text-decoration:none;display:flex}.nav-item:active{transform:scale(.92)}.nav-item.active{color:var(--primary)}.nav-item svg{flex-shrink:0}.nav-label{letter-spacing:.2px;white-space:nowrap;font-size:11px;font-weight:600}@media (width>=768px){.navbar{width:var(--sidebar-width);max-width:var(--sidebar-width);height:100dvh;padding:calc(var(--header-height) + 16px) 10px 24px;border-top:none;border-right:1px solid var(--border);flex-direction:column;justify-content:flex-start;align-items:stretch;gap:2px;position:fixed;inset:0 auto 0 0;overflow-y:auto;transform:none;box-shadow:2px 0 16px #0000000a}.nav-brand{height:var(--header-height);border-bottom:1px solid var(--border);background:var(--surface);align-items:center;gap:10px;padding:0 14px;display:flex;position:absolute;top:0;left:0;right:0}.nav-brand-icon{background:var(--primary);color:#fff;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.nav-brand-name{color:var(--text);letter-spacing:-.3px;font-size:17px;font-weight:800}.nav-item{border-radius:var(--radius-sm);flex-direction:row;flex:none;justify-content:flex-start;align-items:center;gap:12px;padding:11px 14px}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:var(--primary-light);color:var(--primary)}.nav-item.active:hover{background:var(--primary-light)}.nav-label{letter-spacing:0;font-size:14px;font-weight:600}}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-card{width:100%;max-width:380px;padding:24px;animation:.18s modalIn}@keyframes modalIn{0%{opacity:0;transform:scale(.96)translateY(-8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-title{color:var(--text);margin-bottom:4px;font-size:20px;font-weight:800}.modal-subtitle{color:var(--text-muted);margin-bottom:20px;font-size:13px}.modal-error{color:var(--danger);background:var(--danger-light);border-radius:var(--radius-xs);margin-bottom:12px;padding:8px 12px;font-size:13px}.modal-actions{gap:10px;margin-top:4px;display:flex}.app-header{width:100%;max-width:500px;height:var(--header-height);background:var(--surface);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;padding:0 16px;display:flex;position:fixed;top:0;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #0000000a}.header-content{align-items:center;gap:10px;display:flex}.header-logo{background:var(--primary);color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.header-title{color:var(--text);font-size:18px;font-weight:800;line-height:1}.header-subtitle{color:var(--text-muted);margin-top:2px;font-size:12px}.header-auth{flex-shrink:0}.auth-btn{border-radius:var(--radius-xs);cursor:pointer;border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);transition:background var(--transition), color var(--transition);align-items:center;gap:6px;padding:7px 12px;font-size:13px;font-weight:600;display:flex}.auth-btn:hover{background:var(--surface-2)}.auth-btn--in{color:var(--accent);border-color:var(--accent-light);background:var(--accent-light)}.auth-btn--in:hover{background:var(--accent);color:#fff;border-color:var(--accent)}@media (width>=768px){.app-header{left:var(--sidebar-width);width:auto;max-width:none;padding:0 32px;right:0;transform:none}.header-logo{display:none}.header-title{font-size:20px}.header-subtitle{font-size:13px}}.stats-card{text-align:center;flex-direction:column;align-items:center;gap:4px;padding:16px 12px;display:flex}.stats-card--accent{background:linear-gradient(135deg, var(--primary) 0%, #ff8c5a 100%);color:#fff}.stats-card--accent .stats-label,.stats-card--accent .stats-sub{color:#fffc}.stats-icon{margin-bottom:2px;font-size:22px}.stats-value{color:var(--text);font-size:22px;font-weight:800;line-height:1}.stats-card--accent .stats-value{color:#fff}.stats-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:600}.stats-sub{color:var(--text-secondary);font-size:12px}.run-list{flex-direction:column;gap:0;display:flex}.run-card{margin-bottom:10px}.run-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.run-date{color:var(--text-secondary);font-size:14px;font-weight:600}.run-distance-badge{background:var(--primary-light);color:var(--primary);border-radius:20px;padding:3px 10px;font-size:13px;font-weight:700}.run-stats{background:var(--surface-2);border-radius:var(--radius-sm);align-items:center;gap:0;margin-bottom:8px;padding:10px 0;display:flex}.run-stat{text-align:center;flex-direction:column;flex:1;gap:2px;display:flex}.run-stat-value{color:var(--text);font-size:16px;font-weight:700}.run-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:600}.run-stat-divider{background:var(--border);width:1px;height:32px}.run-notes-text{color:var(--text-secondary);margin-top:4px;margin-bottom:8px;font-size:13px;font-style:italic;line-height:1.4}.run-card-actions{justify-content:flex-end;gap:8px;margin-top:8px;display:flex}.run-year-group{margin-bottom:4px}.run-year-header{justify-content:space-between;align-items:center;margin-top:8px;padding:6px 2px 8px;display:flex}.run-year-header:first-child{margin-top:0}.run-year-label{color:var(--text);letter-spacing:-.3px;font-size:17px;font-weight:800}.run-year-count{color:var(--text-muted);font-size:12px;font-weight:600}.goal-card{margin-bottom:12px}.goal-card--done{border-left:4px solid var(--accent)}.goal-card-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:12px;display:flex}.goal-name{color:var(--text);font-size:16px;font-weight:700}.goal-dates{color:var(--text-muted);margin-top:2px;font-size:12px}.goal-done-badge{background:var(--accent-light);color:var(--accent);border-radius:20px;flex-shrink:0;padding:4px 10px;font-size:12px;font-weight:700}.goal-progress-row{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.goal-progress-label{color:var(--text-secondary);font-size:13px;font-weight:600}.goal-progress-pct{color:var(--primary);font-size:13px;font-weight:700}.goal-progress-bar{background:var(--surface-2);border-radius:4px;height:8px;margin-bottom:12px;overflow:hidden}.goal-progress-fill{background:linear-gradient(90deg, var(--primary), #ff8c5a);border-radius:4px;min-width:4px;height:100%;transition:width .6s}.goal-card--done .goal-progress-fill{background:linear-gradient(90deg, var(--accent), #00ddb5)}.goal-projections{background:var(--surface-2);border-radius:var(--radius-sm);justify-content:space-between;padding:10px 12px;display:flex}.goal-projection{flex-direction:column;align-items:center;gap:2px;display:flex}.goal-projection-value{color:var(--text);font-size:14px;font-weight:700}.goal-projection-label{color:var(--text-muted);text-align:center;font-size:11px}.dashboard-hero{border-radius:var(--radius);color:#fff;background:#e55520;justify-content:center;align-items:center;margin-bottom:16px;padding:24px 20px;display:flex;box-shadow:0 4px 20px #ff6b354d}.hero-stat{flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.hero-value{font-size:40px;font-weight:800;line-height:1}.hero-label{opacity:.85;font-size:13px;font-weight:500}.hero-divider{background:#ffffff4d;width:1px;height:50px;margin:0 8px}.stats-grid{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px;display:grid}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-link{color:var(--primary);font-size:13px;font-weight:600;text-decoration:none}.dashboard-bottom{flex-direction:column;gap:8px;display:flex}.fab{bottom:calc(var(--nav-height) + 16px);background:var(--primary);color:#fff;width:52px;height:52px;transition:transform var(--transition), box-shadow var(--transition);z-index:50;border-radius:50%;justify-content:center;align-items:center;text-decoration:none;display:flex;position:fixed;right:max(16px,50vw - 234px);box-shadow:0 4px 16px #ff6b3573}.fab:hover{transform:scale(1.08);box-shadow:0 6px 20px #ff6b3580}.fab:active{transform:scale(.95)}@media (width>=768px){.dashboard-hero{border-radius:20px;margin-bottom:20px;padding:32px 40px}.hero-value{font-size:52px}.hero-label{font-size:14px}.hero-divider{height:60px;margin:0 24px}.stats-grid{grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px}.dashboard-bottom{grid-template-columns:1fr 1fr;align-items:start;gap:24px;margin-top:4px;display:grid}.dashboard-bottom>section:only-child{grid-column:1/-1}.fab{width:56px;height:56px;bottom:32px;right:40px}}.run-form{margin-bottom:20px}.form-heading{color:var(--text);margin-bottom:16px;font-size:18px;font-weight:700}.duration-row{gap:8px;display:flex}.duration-field{flex:1;align-items:center;gap:4px;display:flex}.duration-input{text-align:center;min-width:0}.duration-unit{color:var(--text-muted);flex-shrink:0;font-size:13px;font-weight:600}.run-notes{resize:none;line-height:1.5}.run-filters{margin-bottom:12px}.filter-bar{align-items:center;gap:8px;display:flex}.filter-toggle{background:var(--surface);border:1.5px solid var(--border);color:var(--text-secondary);transition:all var(--transition);border-radius:20px;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:600;display:flex}.filter-toggle:hover{border-color:var(--primary);color:var(--primary)}.filter-toggle--active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.filter-badge{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:11px;font-weight:700;line-height:1;display:inline-flex}.filter-chevron{transition:transform var(--transition)}.filter-chevron--open{transform:rotate(180deg)}.filter-clear{border:1.5px solid var(--border);color:var(--text-muted);transition:all var(--transition);background:0 0;border-radius:20px;padding:7px 12px;font-size:12px;font-weight:600}.filter-clear:hover{border-color:var(--danger);color:var(--danger)}.filter-panel{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);margin-top:8px;padding:12px;animation:.15s filterIn}@keyframes filterIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.filter-empty{color:var(--text-muted);margin-bottom:10px;font-size:13px}.filter-rows{flex-direction:column;gap:8px;margin-bottom:10px;display:flex}.filter-row{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-xs);padding:8px 10px}.filter-row-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.filter-row-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:11px;font-weight:700}.filter-remove-btn{width:20px;height:20px;color:var(--text-muted);transition:all var(--transition);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:16px;line-height:1;display:flex}.filter-remove-btn:hover{background:var(--danger-light);color:var(--danger)}.filter-date-inputs{gap:8px;display:flex}.filter-date-field{flex-direction:column;flex:1;gap:3px;display:flex}.filter-field-label{color:var(--text-muted);font-size:11px;font-weight:600}.filter-comparison-inputs{align-items:center;gap:6px;display:flex}.filter-input,.filter-select{border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--surface);color:var(--text);padding:5px 8px;font-family:inherit;font-size:13px}.filter-input:focus,.filter-select:focus{border-color:var(--primary);outline:none}.filter-date-inputs .filter-input{width:100%}.filter-input--value{flex-shrink:0;width:70px}.filter-select--operator{flex-shrink:0;width:52px;padding-right:4px}.filter-select--unit{flex-shrink:0;width:52px}.filter-unit-label{color:var(--text-muted);white-space:nowrap;font-size:13px;font-weight:600}.filter-add-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.filter-add-label{color:var(--text-muted);font-size:12px;font-weight:600}.filter-add-btn{background:var(--surface);border:1.5px dashed var(--border);color:var(--text-secondary);transition:all var(--transition);border-radius:12px;padding:4px 10px;font-size:12px;font-weight:600}.filter-add-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light);border-style:solid}.history-header{align-items:baseline;gap:8px;margin-top:16px;margin-bottom:8px;display:flex}.history-count{color:var(--text-muted);font-size:13px;font-weight:600}.pagination{justify-content:center;align-items:center;gap:12px;margin-top:16px;padding-top:4px;display:flex}.pagination-btn{background:var(--surface);border:1.5px solid var(--border);color:var(--text-secondary);transition:all var(--transition);border-radius:20px;padding:8px 16px;font-size:13px;font-weight:600}.pagination-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.pagination-btn:disabled{opacity:.35;cursor:default}.pagination-info{color:var(--text-muted);text-align:center;min-width:50px;font-size:13px;font-weight:600}.chart-container{width:100%;padding:4px 0}.chart-placeholder{background:var(--surface-2);border-radius:var(--radius-sm);height:120px;color:var(--text-muted);text-align:center;justify-content:center;align-items:center;padding:16px;font-size:13px;display:flex}.stats-grid-2{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px;display:grid}.charts-row{flex-direction:column;gap:0;display:flex}.chart-section{margin-bottom:20px}.chart-card{padding:16px 8px 8px}@media (width>=768px){.stats-grid-2{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}.charts-row{grid-template-columns:1fr 1fr;gap:20px;display:grid}.chart-section{margin-bottom:0}.chart-card{padding:20px 12px 12px}}.goal-form{margin-bottom:20px}.form-actions{gap:10px;margin-top:4px;display:flex}.past-goals-section{opacity:.75;margin-top:24px}.race-card{margin-bottom:10px}.race-card--best{border-left:4px solid var(--warning)}.race-card-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:12px;display:flex}.race-type-badge{background:var(--primary-light);color:var(--primary);text-transform:uppercase;letter-spacing:.4px;border-radius:12px;margin-bottom:4px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.race-name{color:var(--text);font-size:15px;font-weight:700}.race-location{color:var(--text-muted);margin-top:2px;font-size:12px}.race-card-right{flex-direction:column;align-items:flex-end;gap:6px;display:flex}.race-card-actions{gap:6px;display:flex}.race-best-badge{color:var(--warning);white-space:nowrap;font-size:12px;font-weight:700}.race-stats{background:var(--surface-2);border-radius:var(--radius-sm);align-items:center;margin-bottom:8px;padding:10px 0;display:flex}.race-stat{text-align:center;flex-direction:column;flex:1;gap:2px;display:flex}.race-stat-value{color:var(--text);font-size:14px;font-weight:700}.race-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:600}.race-notes{color:var(--text-secondary);font-size:13px;font-style:italic;line-height:1.4}.goals-add-btn{margin-bottom:20px}.records-section{margin-bottom:24px}.records-section-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.records-distance{color:var(--text-muted);font-size:12px;font-weight:500}
