:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#10100e;color:#f6f2e8}*{box-sizing:border-box}[hidden]{display:none!important}body{min-height:100svh;margin:0;background:linear-gradient(135deg,rgba(44,148,109,.2),transparent 36%),radial-gradient(circle at 100% 0%,rgba(225,89,73,.22),transparent 30%),#10100e}button,input,select{font:inherit}button{min-height:44px;border:0;border-radius:8px;padding:0 15px;color:#151512;background:#e9e2cf;font-weight:800}button:disabled{cursor:not-allowed;opacity:.45}.primary{color:#07130e;background:#3ee07f}input,select{width:100%;min-width:0;min-height:44px;border:1px solid #45443d;border-radius:8px;padding:10px 12px;color:#f6f2e8;background:#1b1b18}code{overflow-wrap:anywhere;color:#cafbd8}.app-shell{display:grid;gap:16px;min-height:100svh;align-content:start;padding:max(18px,env(safe-area-inset-top)) max(18px,env(safe-area-inset-right)) max(18px,env(safe-area-inset-bottom)) max(18px,env(safe-area-inset-left))}.app-header{display:flex;width:min(1280px,100%);margin:0 auto;gap:16px;align-items:center;justify-content:space-between}.app-header .status-pill{flex:0 0 auto}.app-header h1{margin:0;font-size:clamp(2.2rem,6vw,4.8rem);line-height:.9;letter-spacing:0}.app-tabs,.app-panels{width:min(1280px,100%);margin:0 auto}.app-tabs{display:flex;gap:8px}.tab-button{border:1px solid #4b493f;color:#ddd5c0;background:#22221e}.tab-button.active{border-color:#3ee07fb3;color:#07130e;background:#3ee07f}.app-panel[hidden]{display:none}.workout-surface{min-width:0;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:clamp(16px,4vw,30px);background:#161612f2;box-shadow:0 22px 80px #00000059}.timer-surface{max-width:560px}.logbook-surface{max-width:980px}.timer-surface,.logbook-surface{margin:0 auto}.section-header,.phase-meta,.controls{display:flex;gap:12px;align-items:center}.section-header{justify-content:space-between}.eyebrow{margin:0 0 4px;color:#aaa596;font-size:.78rem;font-weight:900;letter-spacing:0;text-transform:uppercase}h2{margin:0;font-size:clamp(2rem,5vw,3.4rem);line-height:.9;letter-spacing:0}h3{margin:0 0 10px;color:#f1ead9;font-size:.98rem}.status-pill{display:inline-flex;flex:0 0 auto;gap:8px;align-items:center;border:1px solid #4b493f;border-radius:999px;padding:7px 10px;color:#ddd5c0;background:#22221e;font-size:.86rem;font-weight:750}.spotify-status{cursor:pointer}.spotify-status:hover{border-color:#7b7667}.status-dot{width:9px;height:9px;border-radius:999px;background:#c6594a;box-shadow:0 0 0 3px #c6594a24}.status-pill.connected{border-color:#3ee07f99;color:#3ee07f}.status-pill.connected .status-dot{background:#3ee07f;box-shadow:0 0 0 3px #3ee07f29}.app-notice{position:fixed;left:50%;bottom:calc(20px + env(safe-area-inset-bottom,0px));z-index:50;max-width:min(520px,calc(100vw - 32px));margin:0;border:1px solid #4b493f;border-radius:12px;padding:12px 16px;color:#ddd5c0;background:#26261f;box-shadow:0 14px 44px #00000080;font-size:.9rem;font-weight:650;text-align:center;opacity:0;pointer-events:none;transform:translate(-50%,12px);transition:opacity .22s ease,transform .22s ease}.app-notice.show{opacity:1;transform:translate(-50%)}.timer-face{margin:24px 0 18px}.phase-meta{justify-content:space-between;color:#bfb8a5;font-weight:750}.timer-display{margin:0;font-size:clamp(3rem,11vw,4.6rem);font-variant-numeric:tabular-nums;font-weight:900;line-height:.95;text-align:center}.timer-ring{display:grid;place-items:center;width:min(280px,78vw);aspect-ratio:1;margin:10px auto 4px}.timer-ring>*{grid-area:1 / 1}.timer-start{position:relative;z-index:1;justify-self:center;align-self:center;width:62%;aspect-ratio:1;min-height:0;border-radius:50%;color:#07130e;background:#3ee07f;font-size:clamp(1.4rem,5vw,2rem);font-weight:900;letter-spacing:.02em;touch-action:manipulation}.timer-ring-svg{width:100%;height:100%;transform:rotate(-90deg);pointer-events:none}.timer-ring-track{fill:none;stroke:#2a2924;stroke-width:10}.timer-ring-fill{fill:none;stroke:#3ee07f;stroke-width:10;stroke-linecap:round;stroke-dasharray:100;stroke-dashoffset:100;transition:stroke-dashoffset .2s linear}.routine-card{border-top:1px solid rgba(255,255,255,.09);border-bottom:1px solid rgba(255,255,255,.09);margin:18px 0;padding:16px 0}.routine-current{display:flex;gap:12px;align-items:flex-start;justify-content:space-between}.routine-current h3{margin:0;font-size:clamp(1.35rem,4vw,2rem);line-height:1.05}.routine-current .muted-line{margin-top:6px}.set-actions{display:flex;gap:10px;margin-top:14px}.set-actions .set-action{flex:1 1 0;border:1px solid #4b493f;color:#ddd5c0;background:#22221e}.set-actions .set-action.active{border-color:#3ee07f99;color:#07130e;background:#3ee07f}.reps-editor{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:end;margin-top:12px}.reps-editor label{display:grid;gap:6px;color:#c8c0ac;font-size:.84rem;font-weight:800}.planned-set-list{display:grid;gap:8px;max-height:300px;overflow:auto;margin:14px 0 0;padding:0;list-style:none}.planned-set-list li{display:grid;gap:2px;border:1px solid #38372f;border-radius:8px;padding:9px 10px;background:#171713}.planned-set-list li.current{border-color:#3ee07fb3}.planned-set-list li.completed{color:#3ee07f}.planned-set-list small{color:#aaa596}.controls{flex-wrap:wrap}.controls+.controls{margin-top:12px}.controls button{flex:1 1 150px}.import-actions{display:flex;gap:10px;align-items:center}.file-button{display:inline-grid;min-height:44px;align-items:center;border-radius:8px;padding:0 15px;color:#07130e;background:#3ee07f;font-weight:800}.file-button input{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}.muted-line,.empty-state{margin:10px 0 0;color:#aaa596;font-size:.92rem}.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:14px 0 18px}.stat-card{min-width:0;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:11px;background:#1b1b18}.stat-card span,.template-header p,.session-header p,.exercise-list small{color:#aaa596;font-size:.82rem}.stat-card strong{display:block;margin-top:2px;color:#f6f2e8;font-size:1.35rem;line-height:1.1}.manual-log{border-top:1px solid rgba(255,255,255,.09);border-bottom:1px solid rgba(255,255,255,.09);margin:18px 0;padding:16px 0}.manual-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;align-items:end}.manual-grid label:nth-of-type(1),.manual-grid label:nth-of-type(2),.manual-grid label:nth-of-type(3){grid-column:span 2}.manual-grid label:nth-of-type(6){grid-column:span 2}.manual-grid label{display:grid;min-width:0;gap:6px;color:#c8c0ac;font-size:.84rem;font-weight:800}.logbook-columns{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px}.template-list,.session-list{display:grid;max-height:560px;overflow:auto;gap:10px;padding-right:2px}.template-row,.session-row{border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:12px;background:#171713}.template-header,.session-header{display:flex;gap:10px;align-items:flex-start;justify-content:space-between}.template-header h3,.session-header h3{margin:0 0 4px}.template-header span,.session-header span{flex:0 0 auto;color:#3ee07f;font-size:.78rem;font-weight:850}.exercise-list{display:grid;gap:8px;margin:10px 0 0;padding-left:18px}.exercise-list li{color:#f6f2e8}.exercise-list small{display:block;margin-top:1px}.set-chip-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.set-chip{border:1px solid #38372f;border-radius:999px;padding:5px 8px;color:#ddd5c0;background:#22221e;font-size:.78rem}.set-chip.skipped{color:#aaa596;text-decoration:line-through}.exercise-table-wrap{margin-top:18px}table{width:100%;border-collapse:collapse;overflow:hidden;border:1px solid rgba(255,255,255,.08);border-radius:8px}th,td{border-bottom:1px solid rgba(255,255,255,.07);padding:10px;text-align:left;vertical-align:top}th{color:#aaa596;background:#171713;font-size:.78rem;text-transform:uppercase}td{color:#f6f2e8;font-size:.9rem}@media(max-width:680px){.app-header,.section-header{align-items:flex-start;flex-direction:column}.logbook-columns{grid-template-columns:1fr}.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.manual-grid{grid-template-columns:1fr 1fr}.manual-grid button{grid-column:1 / -1}.routine-current,.set-tracking{grid-template-columns:1fr}.routine-current{display:grid}}@media(max-width:420px){.summary-grid,.manual-grid{grid-template-columns:1fr}.manual-grid label{grid-column:auto}.import-actions,.controls{width:100%}.import-actions button,.file-button{flex:1 1 0}}.settings-group{margin-top:20px}.settings-heading{margin:0 0 10px;font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:#f6f2e899}.settings-field{display:block;margin-bottom:10px}.settings-field>span{display:block;margin-bottom:6px;font-weight:600}.diagnostics{border:1px solid rgba(246,242,232,.12);border-radius:12px;background:#00000040;padding:12px 14px}.diagnostics-actions{display:flex;gap:10px;margin:12px 0}.diagnostics-actions button{flex:1 1 0}.log-view{max-height:260px;overflow:auto;margin:0;padding:10px;border-radius:8px;background:#0b0b09;color:#cfe8d8;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.modal{position:fixed;inset:0;z-index:60;display:grid;place-items:center;padding:20px;background:#0009}.modal-card{width:min(360px,100%);border:1px solid rgba(246,242,232,.14);border-radius:14px;padding:20px;background:#201f1b;box-shadow:0 24px 70px #0000008c;text-align:center}.modal-title{margin:0 0 6px;font-size:1.2rem;font-weight:800}.modal-text{margin:0 0 16px;color:#bfb8a5;font-size:.9rem}.modal-actions{display:flex;gap:10px}.modal-actions button{flex:1 1 0}.reset-popup{position:fixed;left:50%;top:50%;z-index:70;transform:translate(-50%,-50%);padding:18px 26px;border-radius:14px;background:#c6594af2;color:#fff;font-size:1.15rem;font-weight:800;box-shadow:0 20px 60px #00000080}
