:root{--clr-brand: #fc4c02;--clr-brand-dk: #e04400;--clr-text: #333;--clr-muted: #666;--clr-subtle: #bbb;--clr-border: rgba(0, 0, 0, .07);--clr-bg: #fff;--clr-surface: #fafafa;--nav-h: 56px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 24px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 1px 4px rgba(0, 0, 0, .12);--shadow-lg: 0 4px 20px rgba(0, 0, 0, .15);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--container-max: 1400px;--container-pad: clamp(.75rem, 4vw, 2rem);--font-sm: clamp(.78rem, 1.5vw, .875rem);--font-base: clamp(.9rem, 2vw, 1rem)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--clr-bg);color:var(--clr-text);line-height:1.6;overflow-x:hidden;font-size:var(--font-base)}#root{min-height:100vh;display:flex;flex-direction:column}.navbar{position:sticky;top:0;z-index:100;height:var(--nav-h);background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.1);display:flex;align-items:center;justify-content:center;padding:0 var(--container-pad)}.navbar .logo{height:36px;display:block;position:absolute;left:var(--container-pad)}.nav-tabs{display:none}.nav-tab,.drawer-item{display:flex;align-items:center;gap:.4rem}.nav-tab{background:transparent;color:var(--clr-muted);border:none;border-bottom:3px solid transparent;border-radius:0;padding:0 clamp(.6rem,1.5vw,1.2rem);height:var(--nav-h);margin-bottom:-1px;font-size:clamp(.8rem,1.4vw,.9rem);cursor:pointer;transition:color .15s;white-space:nowrap}.nav-tab:hover:not(:disabled){background:transparent;color:#333}.nav-tab.active{color:var(--clr-brand);border-bottom-color:var(--clr-brand)}.hamburger{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;background:transparent;border:none;width:44px;height:44px;cursor:pointer;position:absolute;right:var(--container-pad)}.hamburger span{display:block;width:22px;height:2px;background:#888;border-radius:2px}.hamburger:hover:not(:disabled){background:transparent}.profile-wrap{display:none;position:absolute;right:calc(var(--container-pad) + 3rem);align-items:center}.profile-btn{background:transparent;border:none;color:#888;padding:.4rem;font-size:1rem;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .15s,background .15s}.profile-btn:hover:not(:disabled),.profile-btn.active{background:#fc4c0214;color:var(--clr-brand)}.profile-avatar{width:26px;height:26px;border-radius:50%;object-fit:cover;display:block}.profile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90}.profile-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:220px;background:var(--clr-bg);border-radius:10px;box-shadow:var(--shadow-lg);padding:.4rem 0;z-index:100}.profile-action{display:flex;align-items:center;gap:.6rem;width:100%;background:transparent;border:none;border-radius:0;color:#333;font-size:.9rem;padding:.6rem 1rem;text-align:left;cursor:pointer}.profile-action:hover:not(:disabled){background:#f5f5f5;color:#333}.profile-action:disabled{opacity:.6}.profile-signout{color:#888}.comp-past td{background:#f0fff4}.profile-divider{height:1px;background:#eee;margin:.3rem 0}.profile-login{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.75rem;align-items:flex-start}.profile-login p{margin:0;font-size:.85rem;color:#888}.profile-error{color:#d32f2f;font-size:.82rem;padding:0 1rem;margin:.25rem 0}@media(min-width:1024px){.nav-tabs,.profile-wrap{display:flex}.hamburger{display:none}}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:200;animation:fadeInOverlay .2s ease}.drawer{position:absolute;top:0;right:0;bottom:0;width:clamp(200px,60vw,280px);background:#fffffff5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;flex-direction:column;padding:1.5rem 0;box-shadow:-2px 0 12px #00000026;animation:slideInRight .25s cubic-bezier(.25,.46,.45,.94)}.drawer-item{background:transparent;color:#444;border:none;border-left:3px solid transparent;border-radius:0;padding:.85rem 1.5rem;font-size:1rem;text-align:left;cursor:pointer}.drawer-item:hover:not(:disabled){background:#f5f5f5;color:#333}.drawer-item.active{color:var(--clr-brand);border-left-color:var(--clr-brand);background:#fc4c020d}.drawer-divider{height:1px;background:#eee;margin:.5rem 0}.drawer-login{padding:1rem 1.5rem;display:flex;flex-direction:column;gap:.75rem;overflow:hidden}.drawer-login p{margin:0;font-size:.85rem;color:#888}.drawer-login iframe{max-width:100%!important}.drawer-signout{color:#888}.container{max-width:var(--container-max);width:100%;margin:clamp(.75rem,3vw,2rem) auto;padding:0 var(--container-pad);flex:1;display:flex;flex-direction:column}.tab-content{animation:fadeIn .2s ease;flex:1;display:flex;flex-direction:column}.home{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:clamp(1rem,4vw,2rem) var(--container-pad);gap:1.5rem}.home-card{display:flex;flex-direction:column;gap:.75rem;width:clamp(200px,60vw,360px)}.photo-carousel{display:grid;width:100%;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer}.home-photo{grid-area:1 / 1;width:100%;object-fit:cover;opacity:0;transition:opacity .7s ease;transform:scale(1.04)}.home-photo--active{opacity:1;animation:photoEnter .7s ease forwards}.photo-carousel:hover .home-photo--active{filter:brightness(1.04)}.logo{transition:opacity .3s ease}.home-quote{margin:0;padding:.8rem 1.4rem;background:#ffffffbf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:var(--radius-lg);box-shadow:0 1px 6px #0000001a;font-family:Oswald,sans-serif;font-style:italic}.home-quote-text{margin:0 0 .4rem;font-size:clamp(1.1rem,3vw,1.4rem);font-weight:700;color:#222;line-height:1.3;text-align:center}.home-quote-author{display:block;font-size:clamp(.82rem,2vw,.95rem);font-weight:400;color:#888;letter-spacing:.03em;text-align:right}.health-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;padding:.5rem 0}.health-empty{color:var(--clr-muted);text-align:center;padding:2rem}.metric-card--muted .metric-sub{font-size:.78rem;color:var(--clr-subtle)}.home-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:.65rem;width:clamp(200px,80vw,480px)}.metric-card{background:#fffc;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:var(--radius-md);box-shadow:0 1px 6px #00000014;padding:.6rem .75rem;display:flex;flex-direction:column;gap:.15rem;min-width:0}.metric-label{font-size:.68rem;font-weight:600;color:var(--clr-subtle);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.metric-value{font-size:1.25rem;font-weight:700;color:#222;line-height:1.1}.metric-sub{font-size:.72rem;color:var(--clr-muted)}.metric-badge{display:inline-block;font-size:.72rem;font-weight:600;padding:.15rem .45rem;border-radius:99px;text-transform:capitalize;white-space:nowrap}.metric-card--wide{grid-column:span 2}.race-predictions{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-top:.4rem}.race-item{display:flex;flex-direction:column;align-items:center;gap:.1rem}.race-dist{font-size:.65rem;font-weight:700;color:var(--clr-muted);text-transform:uppercase;letter-spacing:.04em}.race-time{font-size:1rem;font-weight:700;color:var(--clr-text)}.metric-value--mono{font-variant-numeric:tabular-nums;letter-spacing:.02em}.predictions-grid{display:flex;gap:.5rem;margin-top:.6rem;flex-wrap:wrap}.prediction-block{display:flex;flex-direction:column;align-items:center;background:#0000000a;border-radius:8px;padding:.4rem .75rem;flex:1;min-width:58px}.prediction-dist{font-size:.62rem;font-weight:700;color:var(--clr-muted);text-transform:uppercase;letter-spacing:.06em}.prediction-time{font-size:1.05rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--clr-text);margin-top:3px;white-space:nowrap}@media(max-width:767px){.home-metrics{grid-template-columns:repeat(2,1fr);width:clamp(200px,90vw,400px)}}.controls{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;margin-bottom:1.25rem;background:#ffffffd9;padding:.75rem 1rem;border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.controls label{display:flex;align-items:center;gap:.5rem;font-weight:500;font-size:var(--font-sm)}.controls input[type=date]{padding:.35rem .5rem;border:1px solid #ccc;border-radius:var(--radius-sm);font-size:var(--font-base)}.controls input[type=date]:disabled{opacity:.45;cursor:not-allowed}.all-time-label{display:flex;align-items:center;gap:.4rem;font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:var(--font-sm)}.runs-summary{color:var(--clr-muted);margin-bottom:.75rem;font-size:.95rem}button{padding:.45rem 1.1rem;background:var(--clr-brand);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-base);cursor:pointer}button:disabled{opacity:.6;cursor:not-allowed}button:hover:not(:disabled){background:var(--clr-brand-dk)}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;background:var(--clr-bg);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-md)}th,td{padding:clamp(.4rem,1.2vw,.6rem) clamp(.5rem,1.5vw,1rem);text-align:left;border-bottom:1px solid var(--clr-border);white-space:nowrap;font-size:var(--font-sm)}th{background:var(--clr-surface);font-weight:600}tbody tr:hover{background:#fc4c020f}.table-compact{width:fit-content;margin:0 auto}.table-compact table{width:auto}.mileage-controls{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.25rem}.view-toggle{display:flex;background:var(--clr-surface);border-radius:var(--radius-sm);padding:3px;gap:2px}.view-toggle button{background:transparent;color:var(--clr-muted);border:none;border-radius:calc(var(--radius-sm) - 2px);padding:.3rem .9rem;font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:background .15s,color .15s}.view-toggle button:hover:not(:disabled){background:#fc4c0214;color:var(--clr-brand)}.view-toggle button.active{background:#fff;color:var(--clr-brand);box-shadow:0 1px 4px #0000001a}.year-selector{display:flex;flex-wrap:wrap;gap:.35rem}.year-selector button{background:var(--clr-surface);color:var(--clr-muted);border:1px solid var(--clr-border);border-radius:var(--radius-sm);padding:.25rem .7rem;font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.year-selector button:hover:not(:disabled){background:#fc4c0214;color:var(--clr-brand);border-color:var(--clr-brand)}.year-selector button.active{background:var(--clr-brand);color:#fff;border-color:var(--clr-brand)}.yearly-chart-wrap{max-width:680px;margin:0 auto;width:100%}.yearly-chart{width:100%;display:block;overflow:visible}.gear-tooltip{position:fixed;z-index:300;background:var(--clr-bg);border-radius:12px;box-shadow:0 8px 32px #0000002e;padding:.6rem;display:flex;flex-direction:column;align-items:center;gap:.4rem;pointer-events:none;animation:fadeIn .15s ease}.gear-tooltip img{width:180px;height:120px;object-fit:contain;border-radius:6px}.gear-tooltip span{font-size:.78rem;color:#888;text-align:center;max-width:180px}.logo--link{cursor:pointer}.site-footer{text-align:center;padding:1.25rem 1rem;padding-bottom:calc(1.25rem + env(safe-area-inset-bottom,0px));font-size:.82rem;color:var(--clr-subtle)}.error{color:#d32f2f;margin-bottom:1rem}.loading-box{background:#ffffffd9;border-radius:var(--radius-md);padding:2rem;text-align:center;color:var(--clr-muted);box-shadow:var(--shadow-sm)}@keyframes photoEnter{0%{transform:scale(1.04)}to{transform:scale(1)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}@media(max-width:767px){.home{padding:.5rem var(--container-pad);gap:.75rem}.photo-carousel{max-height:38vh}.home-photo{max-height:38vh;object-fit:cover}.home-quote{padding:.6rem 1rem}.home-quote-text{font-size:1rem}.home-quote-author{font-size:.82rem}}@media(max-width:767px){.table-wrap table thead{display:none}.table-wrap table,.table-wrap tbody,.table-wrap tr,.table-wrap td{display:block;width:100%}.table-wrap tr{border:1px solid #eee;border-radius:var(--radius-md);margin-bottom:.75rem;box-shadow:var(--shadow-sm)}.table-wrap td{display:flex;justify-content:space-between;padding:.5rem 1rem;border-bottom:1px solid #f0f0f0;text-align:right;white-space:normal;word-break:break-word;font-size:var(--font-sm)}.table-wrap td:last-child{border-bottom:none}.table-wrap td:before{content:attr(data-label);font-weight:600;color:var(--clr-muted);text-align:left;white-space:nowrap;flex-shrink:0;margin-right:.5rem}.table-wrap td[data-label=""]{font-weight:600;font-size:1rem;background:var(--clr-surface);border-bottom:2px solid #eee;justify-content:flex-start}.table-compact{width:100%}.table-compact table thead{display:none}.table-compact table,.table-compact tbody,.table-compact tr,.table-compact td{display:block;width:100%}.table-compact tr{border:1px solid #eee;border-radius:var(--radius-md);margin-bottom:.75rem;box-shadow:var(--shadow-sm)}.table-compact td{display:flex;justify-content:space-between;padding:.5rem 1rem;border-bottom:1px solid #f0f0f0;text-align:right;white-space:normal;word-break:break-word;font-size:var(--font-sm)}.table-compact td:last-child{border-bottom:none}.table-compact td:before{content:attr(data-label);font-weight:600;color:var(--clr-muted);text-align:left;white-space:nowrap;flex-shrink:0;margin-right:.5rem}.table-compact td[data-label=""]{font-weight:600;font-size:1rem;background:var(--clr-surface);border-bottom:2px solid #eee;justify-content:flex-start}}.cal-agenda-wrap{max-width:640px;margin:0 auto;background:var(--clr-bg);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:.75rem 1rem}.cal-agenda{display:flex;flex-direction:column}.cal-row{display:grid;grid-template-columns:72px 1fr;gap:.75rem;padding:.7rem 0;border-bottom:1px solid #f0f0f0;align-items:flex-start}.cal-row:last-child{border-bottom:none}.cal-row--rest{opacity:.38}.cal-row-label{display:flex;flex-direction:column;gap:2px;padding-top:3px}.cal-row-dow{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--clr-muted)}.cal-row--today .cal-row-dow{color:var(--clr-brand)}.cal-row-date{font-size:.9rem;font-weight:600;color:var(--clr-text)}.cal-row--today .cal-row-date{color:var(--clr-brand)}.cal-row-events{display:flex;flex-direction:column;gap:.4rem}.cal-rest-label{color:var(--clr-muted);font-size:.85rem;padding-top:4px}.cal-card{border-radius:8px;padding:.5rem .7rem;display:flex;flex-direction:column;gap:.2rem}.cal-card-top{display:flex;align-items:flex-start;gap:.45rem}.cal-card-emoji{font-size:1rem;flex-shrink:0;line-height:1.35}.cal-card-name{font-size:.88rem;font-weight:600;line-height:1.35}.cal-card-meta{display:flex;gap:.5rem;font-size:.75rem;opacity:.75;margin-left:1.45rem}.cal-run{background:#e8f5e9;color:#2e7d32}.cal-bike{background:#e3f2fd;color:#1565c0}.cal-swim{background:#e0f7fa;color:#00695c}.cal-strength{background:#fce4ec;color:#c62828}.cal-other{background:#f3e5f5;color:#6a1b9a}@media(max-width:480px){.cal-row{grid-template-columns:56px 1fr;gap:.5rem}.cal-card-name{font-size:.82rem}}.goals-wrap{display:flex;flex-direction:column;gap:2rem}.goals-year{display:flex;flex-direction:column;gap:.75rem}.goals-year-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.25rem}.goals-year-label{font-size:1.1rem;font-weight:700;color:var(--clr-text);min-width:3rem}.goals-progress{flex:1;height:6px;background:#eee;border-radius:3px;overflow:hidden}.goals-progress-fill{height:100%;border-radius:3px;transition:width .4s ease}.goals-year-count{font-size:.8rem;color:var(--clr-muted);min-width:2.5rem;text-align:right}.goals-list{display:flex;flex-direction:column;gap:.5rem}.goal-card{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--clr-surface, #fafafa);border-radius:var(--radius-md);border-left:3px solid #e0e0e0;transition:border-color .2s}.goal-card--done{border-left-color:#4caf50;background:#f1f8f1}.goal-check{width:22px;height:22px;border-radius:50%;border:2px solid #ccc;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:transparent;flex-shrink:0}.goal-check--done{background:#4caf50;border-color:#4caf50;color:#fff}.goal-desc{flex:1;font-size:.95rem;color:var(--clr-text)}.goal-card--done .goal-desc{color:#2e7d32}.goal-result{font-size:.8rem;font-weight:700;background:#4caf50;color:#fff;padding:.15rem .55rem;border-radius:999px;white-space:nowrap}.goal-edit-btn{background:transparent;border:1px solid #ddd;color:var(--clr-muted);padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:.8rem;cursor:pointer;flex-shrink:0}.goal-card--editing{flex-wrap:wrap;gap:.5rem;align-items:flex-start;border-left-color:var(--clr-brand)}.goal-check-wrap{display:flex;align-items:center;padding-top:.4rem}.goal-edit-fields{display:flex;flex:1;gap:.5rem;min-width:0}@media(max-width:767px){.goal-card{padding:.6rem .75rem}.goal-edit-fields{flex-direction:column}}
