:root{color:#17202a;background:#eef1f0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:geometricPrecision}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{cursor:pointer}.selection-shell,.drill-shell{min-height:100vh;background:linear-gradient(180deg,#ffffffb8,#eef1f0d1),#eef1f0}.selection-shell{display:grid;place-items:center;padding:28px}.selection-main{width:min(720px,100%);background:#ffffffeb;border:1px solid #d7dedb;border-radius:8px;box-shadow:0 18px 50px #1c27301f;padding:34px}.app-kicker,.topbar-brand{display:flex;align-items:center;gap:10px;color:#0f766e;font-weight:800}.selection-main h1{margin:22px 0 10px;font-size:clamp(2rem,5vw,3.7rem);line-height:1.02;letter-spacing:0}.selection-main p{max-width:58ch;color:#50606b;line-height:1.55;margin:0 0 28px}.control-group{display:grid;gap:10px;margin-top:18px}.control-group label,.range-row{color:#34424d;font-weight:750}select{width:100%;min-height:48px;color:#17202a;background:#fbfcfb;border:1px solid #cdd6d2;border-radius:8px;padding:0 12px}input[type=text],input[type=url]{width:100%;min-height:44px;color:#17202a;background:#fbfcfb;border:1px solid #cdd6d2;border-radius:8px;padding:0 12px}input[type=range]{width:100%;accent-color:#0f766e}.range-row,.range-bounds,.card-label-row,.compact-status,.topbar-status,.drill-footer,.legend{display:flex;align-items:center;justify-content:space-between;gap:12px}.range-bounds{color:#6a7780;font-size:.9rem}.toggle-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:24px}.phone-layout-control,.phone-layout-toggle{display:none}.toggle,.primary-action{border:1px solid #cad4d0;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;background:#fbfcfb;color:#27343e;font-weight:800}.toggle.selected{background:#e3f3f0;border-color:#76bdb6;color:#075b55}.primary-action{width:100%;margin-top:22px;background:#17202a;border-color:#17202a;color:#fff}.phase-three-shell{min-height:100vh;display:grid;grid-template-columns:300px minmax(0,1fr);background:#eef1f0}.phase-three-shell.score-focus{height:100vh;grid-template-columns:minmax(0,1fr);overflow:hidden}.score-focus .phase-three-sidebar,.score-focus .phase-three-toolbar,.score-focus .storage-warning{display:none}.phase-three-sidebar{min-width:0;border-right:1px solid #d5ddda;background:#ffffffeb;padding:24px;display:flex;flex-direction:column;gap:20px}.phase-three-actions .primary-action{margin-top:0}.piece-list{display:grid;gap:10px;overflow:auto;padding-right:2px}.piece-row,.empty-piece{min-width:0;border:1px solid #d5ddda;border-radius:8px;background:#fbfcfb;color:#26343d;padding:12px}.piece-row{display:grid;gap:4px;text-align:left}.piece-row strong,.piece-row span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.piece-row span{color:#62707a;font-size:.9rem}.piece-row.selected{border-color:#0f766e;background:#e5f4f1}.empty-piece{min-height:92px;color:#66747d;display:grid;place-items:center;gap:8px}.phase-three-workspace{min-width:0;display:flex;flex-direction:column;padding:18px;gap:14px}.score-focus .phase-three-workspace{height:100vh;padding:0;gap:0}.phase-three-toolbar{display:grid;grid-template-columns:minmax(160px,.75fr) minmax(240px,1.35fr) auto auto auto;align-items:end;gap:12px;background:#fff;border:1px solid #d5ddda;border-radius:8px;padding:14px}.field-row{min-width:0;display:grid;gap:7px}.field-row label,.speed-row label{color:#34424d;font-weight:800}.file-button,.toolbar-button{min-height:44px;border:1px solid #cbd5d1;border-radius:8px;background:#fbfcfb;color:#27343e;display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:0 14px;font-weight:850}.toolbar-button{min-width:48px}.danger-button{color:#8a2727;border-color:#e2c4c4}.hidden-file-input{display:none}.storage-warning{border:1px solid #e0c073;background:#fff7df;color:#694b05;border-radius:8px;padding:10px 12px;font-weight:750}.practice-layout{min-height:0;flex:1;display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:14px}.score-focus .practice-layout{min-height:100vh;grid-template-columns:minmax(0,1fr);gap:0}.score-panel,.youtube-panel{min-width:0;min-height:0;background:#fff;border:1px solid #d5ddda;border-radius:8px;overflow:hidden}.score-panel{display:grid;grid-template-rows:auto minmax(0,1fr)}.score-focus .score-panel{border:0;border-radius:0;overflow:auto}.pdf-page-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:10px;padding:10px 12px;background:#f6f8f7;border-bottom:1px solid #d5ddda;color:#34424d;font-weight:850}.score-focus .pdf-page-toolbar{position:sticky;top:0;z-index:12}.pdf-page-toolbar input{width:70px;min-height:38px;border:1px solid #cbd5d1;border-radius:8px;padding:0 10px;color:#27343e;font:inherit;font-weight:850}.pdf-page-toolbar span{min-width:44px;color:#62717a}.pdf-zoom-controls{display:inline-flex;align-items:center;gap:8px;padding-left:8px;border-left:1px solid #d5ddda}.pdf-zoom-controls span{min-width:52px;text-align:center;color:#34424d}.page-turn-button{width:42px;height:38px;border:1px solid #cbd5d1;border-radius:8px;background:#fff;color:#26343d;display:inline-flex;align-items:center;justify-content:center}.page-turn-button:disabled{color:#a9b4b8;background:#eef2f0}.score-focus-button{margin-left:auto}.pdf-viewer{width:100%;height:100%;min-height:720px;border:0}.score-focus .pdf-viewer{min-height:calc(100vh - 59px);max-width:none}.score-placeholder,.youtube-placeholder{color:#66747d;display:grid;place-items:center;align-content:center;gap:10px;min-height:420px;font-weight:850}.youtube-panel{display:flex;flex-direction:column;gap:12px;padding:14px}.score-focus .youtube-panel{position:fixed;right:14px;bottom:14px;z-index:20;width:min(280px,calc(100vw - 28px));max-height:min(48vh,330px);box-shadow:0 18px 44px #141f2a38}.youtube-panel-header{display:flex;align-items:center;justify-content:space-between;color:#26343d;font-weight:900}.youtube-panel-header span,.youtube-panel-header a{color:inherit;display:inline-flex;align-items:center;gap:8px}.youtube-search-card{display:grid;gap:8px;padding:10px;border:1px solid #d5ddda;border-radius:8px;background:#f8faf9}.score-focus .youtube-search-card{display:none}.youtube-search-card label{color:#34424d;font-weight:800}.youtube-search-row{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.youtube-search-row input{min-width:0}.youtube-search-row .toolbar-button{min-height:42px}.text-action{justify-self:start;min-height:28px;border:0;background:transparent;color:#0f766e;padding:0;font-weight:850}.speed-row{display:grid;gap:7px}.speed-row select{min-height:42px}.mode-toggle{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));border:1px solid #cbd5d1;border-radius:8px;overflow:hidden}.mode-toggle button{min-height:38px;border:0;background:#fbfcfb;color:#384752;font-weight:850}.mode-toggle button.selected{background:#0f766e;color:#fff}.youtube-frame{width:100%;border:0;border-radius:8px;background:#111827}.compact-mode .youtube-frame{height:92px}.video-mode .youtube-frame{aspect-ratio:16 / 9;height:auto}.compact-mode .youtube-placeholder{min-height:92px}.drill-shell{display:flex;flex-direction:column;padding:18px}.drill-topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:58px;padding:0 8px 12px}.topbar-status{flex-wrap:wrap;justify-content:flex-end;color:#45545f;font-weight:800}.topbar-status span{display:inline-flex;align-items:center;gap:6px;min-height:32px}.end-session-button{min-height:34px;border:1px solid #c8d2ce;border-radius:8px;background:#fff;color:#34424d;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 12px;font-weight:850}.end-session-button:hover{border-color:#aebbb6;background:#f6f8f7}.phone-layout-toggle{grid-template-columns:repeat(2,minmax(0,1fr));border:1px solid #c8d2ce;border-radius:8px;overflow:hidden;background:#fff}.phone-layout-toggle button{min-height:34px;border:0;background:transparent;color:#3f4f5a;padding:0 10px;font-weight:850}.phone-layout-toggle button.selected{background:#0f766e;color:#fff}.drill-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;flex:1;align-items:stretch}.rhythm-card{min-width:0;background:#fff;border:2px solid #17202a;border-radius:8px;box-shadow:0 14px 32px #1f29331a;padding:18px;display:flex;flex-direction:column;justify-content:center}.preview-card{border-color:#7a878f}.blank-card{border-color:#c8d2ce;box-shadow:none}.blank-notation{min-height:190px}.card-label-row{color:#42515d;font-weight:850;margin-bottom:10px;text-transform:uppercase;letter-spacing:0;font-size:.84rem}.notation{min-height:190px;width:100%}.notation svg{display:block;width:100%;height:auto}.counting{display:block;color:#53626d;font-weight:850;padding:6px 48px 0 88px}.counting-bar{display:grid;gap:0}.counting-single-reminder{display:grid;gap:5px;padding-top:0}.counting span{text-align:center}.counting-reminder-label{color:#7a8790;font-size:.76rem;font-weight:800;text-transform:uppercase}.drill-footer{min-height:96px;padding:16px 8px 0}.beat-pulse{display:flex;align-items:center;gap:12px}.beat-pulse span{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:#fff;border:2px solid #c9d3d0;color:#5b6973;font-weight:900;transition:transform .12s ease,background .12s ease,border-color .12s ease,color .12s ease}.beat-pulse span.active{transform:scale(1.12);background:#0f766e;border-color:#0f766e;color:#fff}.beat-pulse span.accent.active{background:#c76b23;border-color:#c76b23}.muted-pulse span{opacity:.35}.legend{justify-content:flex-end;flex-wrap:wrap;color:#4a5964;font-weight:750}.legend span{display:inline-flex;align-items:center;gap:8px}.legend-dot{width:12px;height:12px;border-radius:50%;display:inline-block}.snare-dot{background:#17202a}.kick-dot{background:#c76b23}.hihat-dot{background:#0f766e}.tom-dot{background:#7c3aed}.count-in-shell{display:grid;place-items:center}.count-in-panel{width:min(640px,100%);padding:42px;border-radius:8px;background:#fff;border:1px solid #d7dedb;text-align:center;box-shadow:0 18px 50px #1c27301f}.compact-status{justify-content:center;color:#53626d;font-weight:850}.count-in-panel h1{margin:22px 0 34px;font-size:clamp(2.3rem,7vw,5rem);line-height:1;letter-spacing:0}.count-in-panel .beat-pulse{justify-content:center}.count-in-panel .beat-pulse span{width:72px;height:72px;font-size:1.5rem}@media(max-width:680px){.drill-grid,.toggle-grid,.phase-three-toolbar,.practice-layout{grid-template-columns:1fr}.selection-shell{display:block;min-height:100dvh;padding:14px}.selection-main{padding:20px}.selection-main h1{margin-top:16px;font-size:2rem;line-height:1.06}.selection-main p{margin-bottom:20px}.control-group{margin-top:14px}.toggle-grid{gap:10px;margin-top:18px}.toggle{min-height:44px}.phone-layout-control{display:grid;gap:9px;margin-top:18px;color:#34424d;font-weight:800}.phone-layout-toggle{display:grid}.phase-three-shell{grid-template-columns:1fr}.phase-three-sidebar{border-right:0;border-bottom:1px solid #d5ddda}.pdf-viewer{min-height:560px}.drill-shell{min-height:100dvh;padding:10px;overflow:auto}.drill-topbar,.drill-footer{align-items:flex-start;flex-direction:column}.drill-topbar{gap:8px;min-height:0;padding:0 0 8px}.topbar-status,.legend{justify-content:flex-start}.topbar-status{gap:8px;font-size:.9rem}.topbar-status span{min-height:28px}.topbar-status .phone-layout-toggle{flex:1 1 172px;max-width:230px}.end-session-button{min-height:32px}.drill-grid{gap:10px;flex:0 0 auto}.rhythm-card{min-height:0;padding:10px;justify-content:flex-start}.card-label-row{margin-bottom:6px;font-size:.76rem}.notation,.blank-notation{min-height:132px}.phone-readable .drill-grid{grid-template-rows:minmax(0,1fr) auto}.phone-readable .rhythm-card:not(.preview-card):not(.blank-card){min-height:52dvh}.phone-readable .preview-card{max-height:30dvh;overflow:auto;border-width:1px;box-shadow:none}.phone-readable .preview-card .notation{min-height:104px}.phone-readable .preview-card .counting{font-size:.75rem}.phone-readable.count-in-preview-shell .blank-card{display:none}.phone-readable.count-in-preview-shell .preview-card{max-height:none;min-height:58dvh;border-width:2px;box-shadow:0 14px 32px #1f29331a}.phone-readable.count-in-preview-shell .preview-card .notation{min-height:150px}.phone-pair .rhythm-card{min-height:38dvh}.drill-footer{min-height:0;padding:8px 0 0;gap:10px}.beat-pulse{gap:8px}.beat-pulse span{width:38px;height:38px;font-size:.92rem}.legend{gap:8px;font-size:.78rem;line-height:1.25}.counting{padding:4px 18px 0 56px;font-size:.82rem}.count-in-panel{width:100%;padding:28px 18px}.count-in-panel h1{margin:18px 0 28px;font-size:2.5rem}.count-in-panel .beat-pulse span{width:54px;height:54px;font-size:1.2rem}}@media(max-height:480px)and (max-width:900px){.phone-layout-control,.phone-layout-toggle{display:grid}.drill-shell{min-height:100dvh;padding:10px;overflow:auto}.drill-topbar,.drill-footer{align-items:flex-start;flex-direction:column}.drill-topbar{gap:8px;min-height:0;padding:0 0 8px}.topbar-status,.legend{justify-content:flex-start}.topbar-status{gap:8px;font-size:.9rem}.topbar-status .phone-layout-toggle{flex:1 1 172px;max-width:230px}.drill-grid{grid-template-columns:1fr;gap:10px;flex:0 0 auto}.rhythm-card{min-height:0;padding:10px;justify-content:flex-start}.notation,.blank-notation{min-height:132px}.phone-readable .rhythm-card:not(.preview-card):not(.blank-card){min-height:52dvh}.phone-readable .preview-card{max-height:30dvh;overflow:auto;border-width:1px;box-shadow:none}.phone-readable.count-in-preview-shell .blank-card{display:none}.phone-readable.count-in-preview-shell .preview-card{max-height:none;min-height:58dvh;border-width:2px;box-shadow:0 14px 32px #1f29331a}.phone-pair .rhythm-card{min-height:38dvh}.drill-footer{min-height:0;padding:8px 0 0;gap:10px}.beat-pulse{gap:8px}.beat-pulse span{width:38px;height:38px;font-size:.92rem}.legend{gap:8px;font-size:.78rem;line-height:1.25}}
