*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}[hidden]{display:none!important}*{scrollbar-width:none}*::-webkit-scrollbar{display:none}:root{--bg: #ffffff;--bg-card: #f8fafc;--bg-input: #ffffff;--border: #e2e8f0;--text: #0f172a;--text-muted: #64748b;--primary: #0d9488;--primary-dark: #0f766e;--primary-faint:rgba(13,148,136,.1);--success: #16a34a;--error: #dc2626;--warning: #d97706;--radius: 10px;--shadow: 0 4px 24px rgba(0,0,0,.08);--nav-bg: #ffffff;--nav-h: calc(env(safe-area-inset-top, 0px) + 3.25rem) }@media(prefers-color-scheme:dark){:root{--bg: #111111;--bg-card: #1c1c1c;--bg-input: #1c1c1c;--border: #2e2e2e;--text: #f0f0f0;--text-muted: #9e9e9e;--primary: #14b8a6;--primary-dark: #0d9488;--primary-faint:rgba(20,184,166,.15);--success: #22c55e;--error: #ef4444;--warning: #f59e0b;--shadow: 0 4px 24px rgba(0,0,0,.5);--nav-bg: #1c1c1c}}[data-theme=dark]{--bg: #111111;--bg-card: #1c1c1c;--bg-input: #1c1c1c;--border: #2e2e2e;--text: #f0f0f0;--text-muted: #9e9e9e;--primary: #14b8a6;--primary-dark: #0d9488;--primary-faint:rgba(20,184,166,.15);--success: #22c55e;--error: #ef4444;--warning: #f59e0b;--shadow: 0 4px 24px rgba(0,0,0,.5);--nav-bg: #1c1c1c}[data-theme=light]{--bg: #ffffff;--bg-card: #f8fafc;--bg-input: #ffffff;--border: #e2e8f0;--text: #0f172a;--text-muted: #64748b;--primary: #0d9488;--primary-dark: #0f766e;--primary-faint:rgba(13,148,136,.1);--success: #16a34a;--error: #dc2626;--warning: #d97706;--shadow: 0 4px 24px rgba(0,0,0,.08);--nav-bg: #ffffff}body{font-family:system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;transition:background .2s,color .2s}html{background:var(--nav-bg)}a{color:var(--primary);text-decoration:none}.nav{display:flex;align-items:center;justify-content:space-between;padding:calc(env(safe-area-inset-top,0px) + .75rem) 1.5rem .75rem;background:var(--nav-bg);border-bottom:1px solid var(--border);position:fixed;top:0;left:0;right:0;z-index:100;box-shadow:0 1px 4px #0000000f}.nav__brand{display:flex;align-items:center;gap:.45rem;font-weight:700;font-size:1.1rem;color:var(--primary);flex-shrink:0}.nav__logo{width:28px;height:28px;border-radius:6px;display:block}.nav__logo--dark,[data-theme=dark] .nav__logo--light{display:none}[data-theme=dark] .nav__logo--dark{display:block}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .nav__logo--light{display:none}:root:not([data-theme=light]) .nav__logo--dark{display:block}}.nav__links{display:flex;align-items:center;gap:1rem}.nav__link{color:var(--text-muted);font-size:.9rem;transition:color .15s}.nav__link.active,.nav__link:hover{color:var(--primary)}.nav__logout{background:none;border:1px solid var(--border);color:var(--text-muted);padding:.3rem .75rem;border-radius:6px;cursor:pointer;font-size:.85rem;transition:border-color .15s,color .15s}.nav__logout:hover{border-color:var(--error);color:var(--error)}.nav__theme-toggle{background:none;border:1px solid var(--border);color:var(--text-muted);padding:.3rem .6rem;border-radius:6px;cursor:pointer;font-size:.9rem;line-height:1;transition:border-color .15s,color .15s}.nav__theme-toggle:hover{border-color:var(--primary);color:var(--primary)}.nav__backdrop{display:none}.nav__hamburger{display:none;background:none;border:1px solid var(--border);color:var(--text-muted);border-radius:6px;padding:.35rem .5rem;cursor:pointer;transition:border-color .15s,color .15s;flex-shrink:0}.nav__hamburger:hover{border-color:var(--primary);color:var(--primary)}.hamburger-icon{display:block}@media(max-width:768px){.nav__hamburger{display:flex;align-items:center}.nav{flex-wrap:nowrap}.nav__brand{position:absolute;left:50%;transform:translate(-50%);max-width:calc(100% - 6rem)}.nav__backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:149;-webkit-tap-highlight-color:transparent}.nav--open .nav__backdrop{display:block}.nav__links{position:fixed;top:0;right:0;bottom:0;width:min(280px,85vw);display:flex;flex-direction:column;align-items:stretch;background:var(--nav-bg);border-left:1px solid var(--border);padding:calc(env(safe-area-inset-top,0px) + 3.5rem) 1.25rem calc(env(safe-area-inset-bottom,0px) + 1.5rem);gap:0;box-shadow:-6px 0 32px #0000002e;z-index:150;overflow-y:auto;transform:translate(110%);transition:transform .28s cubic-bezier(.4,0,.2,1)}.nav--open .nav__links{transform:translate(0)}.nav__link{padding:.85rem 0;font-size:1rem;border-bottom:1px solid var(--border)}.nav__link:last-of-type{border-bottom:none}.nav__links .nav__theme-toggle{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border);width:100%;justify-content:center;text-align:center}.nav__links .nav__logout{margin-top:.5rem;width:100%;justify-content:center;text-align:center}}.page{max-width:900px;margin:0 auto;padding:calc(var(--nav-h) + 1rem) 1.5rem calc(env(safe-area-inset-bottom,0px) + 1.5rem)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1.4rem;border-radius:var(--radius);font-size:.95rem;font-weight:500;cursor:pointer;border:none;transition:opacity .15s,transform .1s,background .15s}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--primary);color:#fff}.btn--primary:hover{background:var(--primary-dark)}.btn--secondary{background:var(--bg-card);color:var(--text);border:1px solid var(--border)}.btn--secondary:hover{border-color:var(--primary);color:var(--primary)}.btn--ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn--ghost:hover{border-color:var(--primary);color:var(--primary)}.btn--full{width:100%}.btn--sm{padding:.35rem .9rem;font-size:.82rem}.form-label{display:flex;flex-direction:column;gap:.4rem;font-size:.875rem;color:var(--text-muted);font-weight:500}.form-label+.form-label{margin-top:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem}input,select,textarea{background:var(--bg-input);border:1px solid var(--border);color:var(--text);border-radius:var(--radius);padding:.55rem .8rem;font-size:.95rem;width:100%;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-faint)}input[type=range]{padding:0;accent-color:var(--primary)}.form-actions{display:flex;gap:.75rem;margin-top:1.5rem}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:var(--bg)}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:2rem;width:100%;max-width:400px;box-shadow:var(--shadow)}.auth-logo{display:flex;justify-content:center;margin-bottom:.75rem}.auth-logo__img{width:72px;height:72px;border-radius:16px}.auth-logo__img--dark,[data-theme=dark] .auth-logo__img--light{display:none}[data-theme=dark] .auth-logo__img--dark{display:block}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .auth-logo__img--light{display:none}:root:not([data-theme=light]) .auth-logo__img--dark{display:block}}.auth-title{font-size:1.5rem;margin-bottom:.25rem;text-align:center}.auth-subtitle{font-size:.875rem;color:var(--text-muted);text-align:center;margin-bottom:1.25rem}.auth-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.auth-tab{flex:1;padding:.6rem;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}.auth-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.auth-form .btn--primary{margin-top:1.25rem}.auth-error{margin-top:.75rem;padding:.6rem .8rem;border-radius:6px;background:#dc262614;border:1px solid var(--error);color:var(--error);font-size:.875rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;display:flex;flex-direction:column;align-items:center;gap:.4rem;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 28px #0000001a}.stat-value{font-size:2rem;font-weight:700;color:var(--primary)}.stat-label{font-size:.8rem;color:var(--text-muted);text-align:center}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1.5rem;box-shadow:var(--shadow)}.chart-title{font-size:.9rem;color:var(--text-muted);margin-bottom:1rem}.km-chart{width:100%;height:220px;display:block}.cta-row{display:flex;gap:1rem;flex-wrap:wrap}.offline-note{color:var(--warning);font-size:.85rem;margin:.5rem 0}.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:1rem}.section-title{font-size:1rem;font-weight:600}.section-subtitle{font-size:.8rem;color:var(--text-muted)}.insights-row{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1.25rem}.insight-card{display:flex;align-items:flex-start;gap:.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:.65rem .9rem;font-size:.85rem;color:var(--text);flex:1;min-width:200px}.insight-icon{font-size:1rem;flex-shrink:0;margin-top:1px}.insight-msg{line-height:1.4}.week-progress-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:1.25rem 1.5rem;margin-bottom:1.25rem;box-shadow:var(--shadow)}.week-progress-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden;margin-bottom:.4rem}.week-progress-fill{height:100%;background:var(--primary);border-radius:4px;transition:width .4s ease}.week-progress-labels{display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-muted);margin-bottom:1.25rem}.week-no-plan{font-size:.875rem;color:var(--text-muted);margin-bottom:1rem}.week-days-row{display:grid;grid-template-columns:repeat(7,1fr);gap:.4rem}.day-cell-wrap{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.5rem .25rem;border-radius:8px;border:1px solid var(--border);font-size:.72rem;min-width:0;transition:background .15s}.day-cell-name{font-weight:600;color:var(--text-muted);font-size:.7rem}.day-cell-icon{font-size:.95rem;line-height:1}.day-cell-sub{color:var(--text-muted);font-size:.68rem;text-align:center}.day-cell--done{background:#16a34a1a;border-color:#16a34a}.day-cell--done .day-cell-icon{color:#16a34a;font-size:1rem}.day-cell--missed{background:#dc262614;border-color:#dc2626}.day-cell--today{background:var(--primary-faint);border-color:var(--primary)}.day-cell--today .day-cell-name{color:var(--primary)}.day-cell--rest{opacity:.45}.day-cell--upcoming{background:var(--bg-card)}.last-run-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:1.25rem 1.5rem;margin-bottom:1.25rem;box-shadow:var(--shadow)}.last-run-stats{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.last-run-stat{text-align:center}.last-run-val{display:block;font-size:1.4rem;font-weight:700;color:var(--text);line-height:1.1}.last-run-unit{display:block;font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.last-run-divider{width:1px;height:2.5rem;background:var(--border);flex-shrink:0}.last-run-notes{font-size:.85rem;color:var(--text-muted);font-style:italic;margin:.5rem 0}.last-run-edit{margin-top:.75rem}.effort-row{margin:.4rem 0}.effort-dots{font-size:.7rem;color:var(--primary);letter-spacing:1px}.effort-label{font-size:.72rem;color:var(--text-muted);margin-left:.4rem}.empty-hint{font-size:.875rem;color:var(--text-muted)}.plan-header{margin-bottom:1.5rem}.plan-header h1{font-size:1.5rem}.plan-meta{color:var(--text-muted);margin:.3rem 0 .75rem}.plan-weeks{display:flex;flex-direction:column;gap:1rem}.week-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.week-header{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding:.75rem 1rem;border-bottom:1px solid var(--border);background:var(--bg)}.week-num{font-weight:700}.week-date{color:var(--text-muted);font-size:.85rem}.week-km{margin-left:auto;font-weight:600;color:var(--primary)}.badge{font-size:.72rem;padding:.2rem .5rem;border-radius:20px;font-weight:600}.badge--cutback{background:#d977061f;color:var(--warning)}.badge--taper{background:#8b5cf61f;color:#7c3aed}.week-days{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border)}.day-cell{background:var(--bg-card);padding:.6rem .5rem;display:flex;flex-direction:column;align-items:center;gap:.2rem;cursor:pointer;transition:background .12s}.day-cell:not(.day-cell--rest):hover,.day-cell:not(.day-cell--rest):focus-visible{background:var(--primary-faint);outline:none}.day-cell--selected{background:var(--primary-faint)!important}.day-cell--rest{opacity:.45;cursor:default}.day-name{font-size:.7rem;color:var(--text-muted);font-weight:600;text-transform:uppercase}.day-icon{font-size:1rem}.day-label{font-size:.68rem;color:var(--text-muted);text-align:center;line-height:1.3}.day-detail-popup{margin:0;padding:.75rem 1rem;background:var(--bg-card);border-top:2px solid var(--primary);display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;animation:fadeInDown .15s ease}.day-detail-popup__type{font-size:.8rem;font-weight:700;color:var(--primary);text-transform:capitalize}.day-detail-popup__day{font-size:.8rem;color:var(--text-muted)}.day-detail-popup__label{width:100%;font-size:.9rem;color:var(--text);margin-top:.1rem}.day-detail-popup__km{background:var(--primary-faint);color:var(--primary);border-radius:6px;padding:.2rem .6rem;font-size:.8rem;font-weight:700}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.plan-summary{font-size:.9rem;color:var(--text-muted);line-height:1.6;margin:.5rem 0 1rem;font-style:italic}.week-coaching-note{font-size:.82rem;color:var(--primary);padding:.4rem .75rem;margin:.5rem 0 0;border-left:2px solid var(--primary);line-height:1.5;font-style:italic}.setup-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:2rem;max-width:480px;margin:0 auto;box-shadow:var(--shadow)}.setup-card h1{font-size:1.4rem;margin-bottom:1.5rem}.plan-form .btn--primary{margin-top:1.5rem}.fitness-banner{display:flex;align-items:flex-start;gap:.5rem;background:var(--primary-faint);border:1px solid var(--primary);border-radius:8px;padding:.65rem .85rem;margin-bottom:1.25rem;font-size:.875rem;color:var(--text)}.fitness-banner__icon{font-size:1rem;flex-shrink:0;margin-top:1px}.no-data-banner{border-radius:8px;padding:.65rem .85rem;margin-bottom:1.25rem;font-size:.875rem}.no-data-banner--warn{background:#d977061a;border:1px solid var(--warning);color:var(--text)}.no-data-banner a.link{color:var(--primary);text-decoration:underline}.form-hint{display:block;font-size:.78rem;color:var(--text-muted);margin-top:.2rem}.log-page{max-width:540px}.log-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:2rem;box-shadow:var(--shadow)}.log-card h1{font-size:1.4rem;margin-bottom:1.5rem}.pace-display{font-size:.9rem;color:var(--primary);font-weight:600;background:var(--primary-faint);padding:.4rem .75rem;border-radius:6px;margin-top:.5rem}#effort-label{font-weight:700;color:var(--primary);font-size:.9rem;margin-top:.25rem}#toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.5rem;z-index:9999}.toast{padding:.75rem 1.25rem;border-radius:var(--radius);font-size:.9rem;font-weight:500;max-width:320px;opacity:0;transform:translateY(10px);transition:opacity .25s,transform .25s;box-shadow:var(--shadow)}.toast--visible{opacity:1;transform:translateY(0)}.toast--success{background:var(--success);color:#fff}.toast--error{background:var(--error);color:#fff}.toast--info{background:var(--bg-card);color:var(--text);border:1px solid var(--border)}.runs-page{max-width:720px}.runs-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.runs-header h1{font-size:1.5rem}.runs-list{display:flex;flex-direction:column;gap:.75rem}.run-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;box-shadow:var(--shadow);transition:transform .1s,box-shadow .1s}.run-card:hover{transform:translateY(-1px);box-shadow:0 6px 24px #0000001a}.run-card__top{display:flex;align-items:center;gap:.6rem;margin-bottom:.5rem}.run-card__date{font-weight:600;font-size:.9rem;color:var(--text)}.run-card__badges{display:flex;gap:.4rem;margin-left:auto}.run-card__stats{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;margin-bottom:.4rem}.run-stat{font-size:1rem;font-weight:600;color:var(--text)}.run-stat--dist{font-size:1.15rem;color:var(--primary)}.run-stat--pace,.run-stat--dur{color:var(--text-muted);font-weight:500;font-size:.9rem}.run-card__effort{margin-bottom:.4rem}.effort-dots{font-size:.65rem;letter-spacing:.05em;color:var(--primary);opacity:.85}.run-card__notes{font-size:.85rem;color:var(--text-muted);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;max-width:100%;margin-bottom:.75rem}.run-card__actions{display:flex;align-items:center;gap:.5rem}.btn--danger{color:var(--error);border-color:var(--border)}.btn--danger:hover{border-color:var(--error);background:#dc26260f}.badge--strava{background:#fc4c021a;color:#fc4c02;font-size:.68rem;font-weight:700;padding:.15rem .45rem;border-radius:20px;border:1px solid rgba(252,76,2,.25)}.runs-load-more{text-align:center;margin-top:1.25rem}.runs-empty{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem 1rem;text-align:center;color:var(--text-muted)}.runs-empty__icon{font-size:2.5rem}.runs-empty p{font-size:1rem}.settings-page{max-width:600px}.settings-title{font-size:1.5rem;margin-bottom:1.5rem}.settings-section{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow)}.settings-section__header{display:flex;align-items:center;gap:.6rem;margin-bottom:1.25rem}.settings-section__header h2{font-size:1.1rem}.strava-logo{font-size:1.2rem}.settings-desc{color:var(--text-muted);font-size:.9rem;margin-bottom:1rem;line-height:1.6}.btn--strava{background:#fc4c02;color:#fff;border:none;display:inline-flex;align-items:center;gap:.5rem}.btn--strava:hover{background:#e04000}.btn--strava:disabled{opacity:.6}.strava-connected__info{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.strava-connected__badge{background:#16a34a1f;color:var(--success);font-size:.8rem;font-weight:600;padding:.2rem .6rem;border-radius:20px}.strava-connected__name{font-weight:600;font-size:1rem}.strava-connected__sync-note{color:var(--text-muted);font-size:.875rem;margin-bottom:1rem}.strava-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.strava-sync-wrap{display:flex;align-items:center;gap:.5rem}.sync-days-select{width:auto;padding:.3rem .6rem;font-size:.85rem;border-radius:6px}.strava-sync-result{margin-top:.75rem;font-size:.875rem;color:var(--success)}.loading,.page-loading{color:var(--text-muted);padding:2rem;text-align:center}.error,.page-error{color:var(--error);padding:2rem;text-align:center}@media(max-width:600px){.form-row{grid-template-columns:1fr}.stat-value{font-size:1.6rem}.nav{padding:.75rem 1rem;position:relative}.run-card__stats{gap:.75rem}.week-days{display:flex;flex-direction:column;background:transparent;gap:0}.day-cell{flex-direction:row;align-items:center;padding:.65rem 1rem;gap:.75rem;border-bottom:1px solid var(--border);border-radius:0;cursor:default}.day-cell:last-child{border-bottom:none}.day-name{min-width:2.5rem;font-size:.72rem;text-transform:uppercase;font-weight:700;color:var(--text-muted)}.day-icon{min-width:1.4rem;text-align:center;font-size:1rem}.day-label{display:block!important;flex:1;font-size:.85rem;text-align:left;color:var(--text);line-height:1.35}.day-cell--rest .day-label{display:none!important}.day-cell--rest{opacity:.45}}
