:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#app{max-width:800px;width:100%;margin:0 auto;padding:2rem}.landing{text-align:center}.landing h1{font-size:3em;margin-bottom:.5rem}.landing>p{color:#fff9;margin-bottom:2rem}.version{margin-top:2rem;font-size:.75em;color:#ffffff4d}.input-section{margin:2rem 0}.input-section label{display:block;text-align:left;margin-bottom:.5rem;font-weight:500}textarea{width:100%;padding:1rem;font-family:Courier New,monospace;font-size:.9em;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:8px;color:inherit;resize:vertical}textarea:focus{outline:none;border-color:#646cff}.duration-estimate{margin-top:.5rem;padding:.5rem;background:#646cff1a;border-radius:4px;color:#646cff;font-weight:500}.error{color:#ff6b6b;margin-top:1rem;padding:.75rem;background:#ff6b6b1a;border-radius:4px;display:none}.error.visible{display:block}.button-group{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:all .25s}button.primary{background-color:#646cff;color:#fff}button.primary:hover{background-color:#535bf2}button.secondary{background-color:transparent;border-color:#fff3}button.secondary:hover{border-color:#646cff}button.large{font-size:1.5em;padding:1em 2em;min-width:200px}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.player{display:flex;flex-direction:column;gap:1.5rem}.player-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.player-header h2{font-size:1.8em;margin:0}.progress-bar{width:100%;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:#646cff;transition:width .3s ease}.progress-text{text-align:center;color:#fff9;font-size:.9em}.step-content{padding:2rem;background:#ffffff0d;border-radius:12px;text-align:center;min-height:300px;display:flex;align-items:center;justify-content:center}.step{width:100%}.round-context{color:#646cff;font-size:.9em;font-weight:500;margin-bottom:1rem}.step-name{font-size:2.5em;margin-bottom:1rem}.timer{font-size:4em;font-weight:700;font-family:Courier New,monospace;color:#646cff;margin:1rem 0}.reps{font-size:3em;font-weight:700;color:#646cff;margin:1rem 0}.notes{margin-top:1.5rem;color:#ffffffb3;font-style:italic}.complete h2{font-size:3em;color:#4ade80;margin-bottom:1rem}.next-preview{padding:1rem 1.25rem;background:#ffffff0d;border-radius:8px;border-left:4px solid rgba(100,116,139,.6);text-align:left;color:#ffffffb3;margin-top:1rem}.next-preview-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#ffffff80;margin-bottom:.25rem}.next-preview-name{font-weight:600;font-size:1.1em;color:#fffffff2;margin-bottom:.25rem}.next-preview-meta{font-size:.95em;color:#ffffffb3;margin-bottom:0}.next-preview-notes{font-size:.9em;color:#fff9;margin-top:.5rem;font-style:italic}.next-preview-last{text-align:center;color:#ffffff80}.controls{display:flex;gap:1rem;justify-content:center;margin-top:1rem}.preview{max-width:560px;margin:0 auto;text-align:left}.preview-title{font-size:2em;margin-bottom:.5rem;text-align:center}.preview-description{color:#ffffffb3;text-align:center;margin-bottom:1rem;font-size:.95em}.preview-equipment{color:#fff9;text-align:center;font-size:.9em;margin-bottom:.5rem}.preview-duration{color:#646cff;font-weight:600;text-align:center;margin-bottom:1.5rem}.preview-steps{list-style:none;background:#ffffff0d;border-radius:12px;padding:1rem;margin-bottom:2rem;max-height:50vh;overflow-y:auto}.preview-step{display:grid;grid-template-columns:1fr auto;gap:.75rem;align-items:center;padding:.6rem .5rem;border-bottom:1px solid rgba(255,255,255,.06);font-size:.95em}.preview-step:last-child{border-bottom:none}.preview-step-name{font-weight:500}.preview-step-meta{color:#646cff;font-weight:600;white-space:nowrap}.preview-step-group{display:block;padding:.75rem .5rem;border-bottom:1px solid rgba(255,255,255,.08)}.preview-step-group:last-child{border-bottom:none}.preview-group-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem;font-weight:600}.preview-group-name{color:inherit}.preview-group-rounds{color:#646cff;font-weight:600;font-size:.9em;white-space:nowrap}.preview-group-steps{list-style:none;padding-left:1.25rem;border-left:2px solid rgba(100,108,255,.3);margin-left:.25rem}.preview-group-steps .preview-step{padding:.4rem .5rem;font-size:.9em}.preview-group-steps .preview-step-meta{font-size:.95em}.preview-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.countdown{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;text-align:center}.countdown-number{font-size:8em;font-weight:700;color:#646cff;line-height:1;font-variant-numeric:tabular-nums}.countdown-label{margin-top:1rem;color:#fff9;font-size:1.2em}.silent-mode-hint{margin-top:1rem;padding:.5rem 1rem;background:#ffc83226;border-radius:6px;color:#ffc832e6;font-size:.85em}.countdown-next-preview{margin-top:2.5rem;width:100%;max-width:400px}@media(max-width:600px){#app{padding:1rem}.landing h1{font-size:2em}.step-name{font-size:1.8em}.timer{font-size:3em}.reps{font-size:2em}button.large{font-size:1.2em;padding:.8em 1.5em;min-width:150px}.button-group{flex-direction:column}}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}button.primary{background-color:#646cff}button.secondary{border-color:#0003}button.secondary:hover{border-color:#646cff}}
