body.metronome-page{background:var(--navy);color:var(--cream);min-height:100vh}.metronome-shell{display:flex;align-items:flex-start;justify-content:center;padding:calc(var(--header-h) + 1.5rem) 1rem 3rem;font-family:var(--sans);font-size:16px;line-height:1.4}.metronome-shell .app{width:100%;max-width:620px}.metronome-shell .header{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1.5rem}.metronome-shell h1{font-family:var(--serif);font-size:2rem;font-weight:300;font-style:italic;letter-spacing:.18em;color:var(--cream);line-height:1}.metronome-shell .beat-flash{width:18px;height:18px;border-radius:50%;background:#5b8de81f;border:2px solid rgba(91,141,232,.35);transition:background .05s,box-shadow .05s,border-color .05s;flex-shrink:0}.metronome-shell .beat-flash.on-accent{background:var(--orange-lt);border-color:var(--orange-lt);box-shadow:0 0 12px #f5882a99}.metronome-shell .beat-flash.on-beat{background:var(--blue-lt);border-color:var(--blue-lt);box-shadow:0 0 12px #5b8de88c}.metronome-shell .card{background:#5b8de80a;border:1px solid rgba(91,141,232,.16);border-radius:14px;padding:1.25rem 1.5rem;margin-bottom:.875rem}.metronome-shell .section-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.25em;color:#f5f3ee73;margin-bottom:1rem}.metronome-shell .btn{background:#5b8de814;border:1px solid rgba(91,141,232,.25);color:#f5f3eeb3;border-radius:8px;padding:.45rem .9rem;cursor:pointer;font-size:.9rem;font-family:inherit;transition:background .12s,border-color .12s,color .12s,transform .08s;user-select:none}.metronome-shell .btn:hover{background:#5b8de829;border-color:#5b8de873;color:var(--cream)}.metronome-shell .btn:active{transform:scale(.95)}.metronome-shell .btn.active{background:var(--cobalt);border-color:var(--blue-lt);color:var(--cream)}.metronome-shell .bpm-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding:0 1.5rem}.metronome-shell .bpm-center{text-align:center;flex:0 0 auto}.metronome-shell .bpm-number{font-size:clamp(2.6rem,14vw,4.5rem);font-weight:700;color:var(--cream);cursor:text;display:inline-block;text-align:center;line-height:1;border-bottom:2px solid transparent;outline:none;transition:border-color .15s,color .15s;caret-color:var(--blue-lt)}.metronome-shell .bpm-number:focus{border-bottom-color:var(--blue-lt);color:var(--blue-lt)}.metronome-shell .bpm-unit{font-size:.75rem;letter-spacing:.2em;color:#f5f3ee66;text-transform:uppercase;margin-top:.2rem}.metronome-shell .bpm-step-group{display:flex;flex-direction:column;gap:.4rem}.metronome-shell .btn-step{min-width:46px;font-size:.85rem;padding:.4rem .6rem}.metronome-shell .slider-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.metronome-shell .slider-label{font-size:.75rem;color:#f5f3ee59;min-width:2.5ch;text-align:center}.metronome-shell input[type=range]{flex:1;appearance:none;height:6px;background:#5b8de82e;border-radius:3px;outline:none}.metronome-shell input[type=range]::-webkit-slider-thumb{appearance:none;width:20px;height:20px;background:var(--blue-lt);border-radius:50%;cursor:pointer;border:2px solid var(--cream);transition:background .12s}.metronome-shell input[type=range]::-webkit-slider-thumb:hover{background:var(--cream)}.metronome-shell input[type=range]::-moz-range-thumb{width:20px;height:20px;background:var(--blue-lt);border-radius:50%;cursor:pointer;border:2px solid var(--cream)}.metronome-shell .tap-row{display:flex;justify-content:center}.metronome-shell .btn-tap{min-width:140px;padding:.6rem 1.5rem;font-size:.95rem;letter-spacing:.05em}.metronome-shell .btn-tap:active{background:#5b8de840;border-color:var(--blue-lt)}.metronome-shell .time-sig-presets{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.metronome-shell .btn-sig{font-size:.9rem;padding:.35rem .75rem;font-weight:600}.metronome-shell .custom-sig{display:flex;align-items:center;gap:.5rem}.metronome-shell .custom-sig-label{font-size:.75rem;color:#f5f3ee73}.metronome-shell .custom-sig input,.metronome-shell .custom-sig select{background:#5b8de814;border:1px solid rgba(91,141,232,.3);color:var(--cream);border-radius:7px;padding:.35rem .5rem;font-size:.95rem;font-family:inherit;width:60px;text-align:center;outline:none}.metronome-shell .custom-sig select{width:70px;cursor:pointer}.metronome-shell .custom-sig select option,.metronome-shell .form-unit-select option{color:#0e0d0b;background:#f5f3ee}.metronome-shell .custom-sig-slash{font-size:1.6rem;color:#5b8de866;line-height:1}.metronome-shell .subdivision-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.metronome-shell .btn-sub{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.6rem .4rem}.metronome-shell .sub-icon{font-size:1.1rem;line-height:1}.metronome-shell .sub-label{font-size:.65rem;letter-spacing:.05em;color:#f5f3ee80}.metronome-shell .btn-sub.active .sub-label{color:var(--cream)}.metronome-shell #beat-grid{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.metronome-shell .beat-btn{width:68px;height:68px;border-radius:50%;border:3px solid rgba(91,141,232,.3);background:#5b8de80f;color:#f5f3ee99;cursor:pointer;font-family:inherit;transition:border-color .12s,background .12s,color .12s,transform .12s,box-shadow .12s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;user-select:none}.metronome-shell .beat-btn:hover{border-color:#5b8de880;background:#5b8de81f}.metronome-shell .beat-btn .beat-num{font-size:1.3rem;font-weight:700;line-height:1}.metronome-shell .beat-btn .beat-icon{font-size:.65rem;line-height:1;opacity:.7}.metronome-shell .beat-btn.state-normal{border-color:#5b8de859;background:#5b8de814;color:var(--blue-lt)}.metronome-shell .beat-btn.state-accent{border-color:#e8650a8c;background:#e8650a1a;color:var(--orange-lt)}.metronome-shell .beat-btn.state-mute{border-color:#f5f3ee12;background:#00000047;color:#f5f3ee2e}.metronome-shell .beat-btn.active.state-normal{border-color:var(--blue-lt);background:var(--cobalt);color:var(--cream);box-shadow:0 0 0 4px #5b8de840,0 0 18px #5b8de866;transform:scale(1.12)}.metronome-shell .beat-btn.active.state-accent{border-color:var(--orange-lt);background:#e8650a4d;color:var(--cream);box-shadow:0 0 0 4px #f5882a40,0 0 18px #f5882a66;transform:scale(1.12)}.metronome-shell .beat-btn.active.state-mute{border-color:#f5f3ee38;transform:scale(1.05)}.metronome-shell .sub-indicators{display:flex;justify-content:center;gap:5px;margin-top:1rem;min-height:12px}.metronome-shell .sub-dot{width:10px;height:10px;border-radius:50%;background:#5b8de81f;border:1px solid rgba(91,141,232,.28);transition:background .05s,border-color .05s}.metronome-shell .sub-dot.active{background:var(--cobalt);border-color:var(--blue-lt)}.metronome-shell .sub-dot.active-accent{background:var(--orange);border-color:var(--orange-lt)}.metronome-shell .beat-grid-hint{font-size:.65rem;color:#f5f3ee59;text-align:center;margin-top:.75rem;letter-spacing:.05em}.metronome-shell .tempo-name{font-size:.7rem;letter-spacing:.18em;color:var(--blue-lt);text-transform:uppercase;margin-top:.15rem;min-height:1em;transition:color .3s}.metronome-shell .play-row{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:.75rem}.metronome-shell .spacebar-hint{font-size:.6rem;color:#f5f3ee4d;letter-spacing:.12em;text-transform:uppercase;border:1px solid rgba(91,141,232,.22);border-radius:4px;padding:.15rem .4rem}.metronome-shell .btn-play{min-width:180px;padding:.9rem 2rem;font-size:1.15rem;font-weight:600;letter-spacing:.1em;border-radius:50px;background:var(--cobalt);border-color:var(--blue-lt);color:var(--cream)}.metronome-shell .btn-play:hover{background:var(--blue);border-color:var(--cream);color:var(--cream)}.metronome-shell .btn-play.playing{background:var(--orange);border-color:var(--orange-lt);color:var(--cream)}.metronome-shell .btn-play.playing:hover{background:var(--orange-lt);border-color:var(--cream)}.metronome-shell .adv-toggle-row{display:flex;align-items:center;justify-content:center;gap:.875rem;margin:1rem 0 .5rem;cursor:pointer}.metronome-shell .adv-toggle-label{font-size:.68rem;letter-spacing:.25em;color:#f5f3ee59;text-transform:uppercase;transition:color .2s;user-select:none}.metronome-shell .adv-toggle-row.active .adv-toggle-label{color:var(--cream)}.metronome-shell .toggle-switch{position:relative;display:inline-block;width:46px;height:26px;flex-shrink:0}.metronome-shell .toggle-switch input{opacity:0;width:0;height:0;position:absolute}.metronome-shell .toggle-track{position:absolute;inset:0;background:#5b8de81a;border:1px solid rgba(91,141,232,.28);border-radius:13px;cursor:pointer;transition:background .2s,border-color .2s}.metronome-shell .toggle-track:after{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#f5f3ee66;border-radius:50%;transition:transform .2s,background .2s}.metronome-shell .toggle-switch input:checked+.toggle-track{background:var(--cobalt);border-color:var(--blue-lt)}.metronome-shell .toggle-switch input:checked+.toggle-track:after{transform:translate(20px);background:var(--cream)}.metronome-shell .adv-panel{overflow:hidden;max-height:0;transition:max-height .35s ease}.metronome-shell .adv-panel.open{max-height:9999px}.metronome-shell .adv-feature-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.metronome-shell .adv-feature-desc{font-size:.7rem;color:#f5f3ee73;margin-top:.2rem;line-height:1.4}.metronome-shell .adv-controls{transition:opacity .2s}.metronome-shell .adv-controls.disabled{opacity:.3;pointer-events:none}.metronome-shell .adv-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.6rem}.metronome-shell .adv-label{font-size:.75rem;color:#5b8de8d9;min-width:5rem}.metronome-shell .adv-row input[type=range]{flex:1}.metronome-shell .adv-value{font-size:.9rem;font-weight:600;color:var(--cream);min-width:2rem;text-align:right}.metronome-shell .adv-unit{font-size:.7rem;color:#f5f3ee66}.metronome-shell .gap-phase-indicator{display:flex;align-items:center;gap:.6rem;margin-top:.25rem;min-height:1.6rem}.metronome-shell .phase-pill{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .65rem;border-radius:20px;font-size:.7rem;font-weight:600;letter-spacing:.04em;background:#5b8de81a;border:1px solid rgba(91,141,232,.28);color:#f5f3ee73;transition:all .15s}.metronome-shell .phase-pill.play{background:#8db82024;border-color:#8db82073;color:var(--lime)}.metronome-shell .phase-pill.silent{background:#e8650a24;border-color:#e8650a73;color:var(--orange-lt)}.metronome-shell .phase-progress{font-size:.68rem;color:#f5f3ee66}.metronome-shell .form-list{max-height:280px;overflow-y:auto;border:1px solid rgba(91,141,232,.18);border-radius:8px;margin-bottom:.6rem;padding:.3rem;display:flex;flex-direction:column;gap:2px}.metronome-shell .form-group-header{display:flex;align-items:center;gap:.45rem;padding:.42rem .6rem;background:#5b8de80f;border-radius:6px;border:1px solid rgba(91,141,232,.18);transition:background .1s,border-color .1s}.metronome-shell .form-group-header.form-active{background:var(--cobalt);border-color:var(--blue-lt)}.metronome-shell .form-group-range{font-size:.62rem;color:#f5f3ee66;min-width:3.2rem;font-variant-numeric:tabular-nums}.metronome-shell .form-group-meter{font-size:1rem;font-weight:700;color:var(--blue-lt);min-width:3rem;letter-spacing:.02em}.metronome-shell .form-group-header.form-active .form-group-meter,.metronome-shell .form-group-header.form-active .form-group-range,.metronome-shell .form-group-header.form-active .form-group-count{color:var(--cream)}.metronome-shell .form-group-count{font-size:.72rem;color:#f5f3ee66;flex:1}.metronome-shell .form-expand-btn{background:none;border:none;color:#f5f3ee73;cursor:pointer;font-size:.75rem;padding:.15rem .35rem;border-radius:3px;line-height:1;transition:color .12s,background .12s}.metronome-shell .form-expand-btn:hover{color:var(--cream);background:#5b8de82e}.metronome-shell .form-row{display:flex;align-items:center;gap:.45rem;padding:.32rem .5rem .32rem 1.6rem;border-radius:4px;background:#00000038;border:1px solid rgba(91,141,232,.1);transition:background .1s}.metronome-shell .form-row.form-active{background:#5b8de82e;border-color:var(--blue-lt)}.metronome-shell .form-row-num{font-size:.68rem;color:#f5f3ee66;min-width:1.4rem;text-align:right}.metronome-shell .form-beats-input{width:40px;background:#5b8de81a;border:1px solid rgba(91,141,232,.3);color:var(--cream);border-radius:5px;padding:.22rem .3rem;font-size:.82rem;font-family:inherit;text-align:center;outline:none}.metronome-shell .form-slash{color:#5b8de866;font-size:1rem}.metronome-shell .form-unit-select{width:60px;background:#5b8de81a;border:1px solid rgba(91,141,232,.3);color:var(--cream);border-radius:5px;padding:.22rem .2rem;font-size:.82rem;font-family:inherit;outline:none;cursor:pointer}.metronome-shell .form-delete-btn{margin-left:auto;background:none;border:none;color:#e8650a73;cursor:pointer;font-size:.85rem;padding:.15rem .4rem;border-radius:4px;line-height:1;transition:color .15s,background .15s}.metronome-shell .form-delete-btn:hover{color:var(--orange-lt);background:#e8650a26}.metronome-shell .btn-add-measure{width:100%;padding:.45rem;font-size:.82rem;border-style:dashed;margin-bottom:.5rem;color:#f5f3ee8c}.metronome-shell .form-counter{font-size:.68rem;color:#f5f3ee66;text-align:center;min-height:1rem}.metronome-shell .form-toolbar{display:flex;gap:.4rem;margin-bottom:.6rem}.metronome-shell .form-tool-btn{flex:1;font-size:.72rem;padding:.38rem .3rem;text-align:center;white-space:nowrap}.metronome-shell .form-tool-btn:disabled{opacity:.22;cursor:not-allowed}.metronome-shell .form-bulk-row{display:flex;align-items:center;gap:.4rem;margin-bottom:.6rem;flex-wrap:wrap}.metronome-shell .form-bulk-label{font-size:.75rem;color:#5b8de8d9}.metronome-shell .sound-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.metronome-shell .btn-sound{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.65rem .4rem}.metronome-shell .sound-icon{font-size:1.15rem;line-height:1}.metronome-shell .sound-label{font-size:.65rem;letter-spacing:.05em;color:#f5f3ee80}.metronome-shell .btn-sound.active .sound-label{color:var(--cream)}.metronome-shell .sound-note{font-size:.62rem;color:#f5f3ee59;text-align:center;margin-top:.5rem;font-style:italic}@media(min-width:900px){.metronome-shell{padding:calc(var(--header-h) + 1rem) 2rem 2.5rem}.metronome-shell .app{max-width:1100px}.metronome-shell .header{margin-bottom:1rem}.metronome-shell .basic-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr) minmax(0,1fr);grid-template-areas:"tempo  timesig  timesig" "tempo  subdiv   sound" "beats  beats    beats";gap:.75rem;align-items:stretch}.metronome-shell .basic-grid>.card{margin-bottom:0;padding:.9rem 1.1rem}.metronome-shell .basic-grid .card-tempo{grid-area:tempo;display:flex;flex-direction:column}.metronome-shell .basic-grid .card-timesig{grid-area:timesig}.metronome-shell .basic-grid .card-subdiv{grid-area:subdiv}.metronome-shell .basic-grid .card-sound{grid-area:sound}.metronome-shell .basic-grid .card-beats{grid-area:beats}.metronome-shell .basic-grid .section-label{margin-bottom:.55rem}.metronome-shell .basic-grid .card-tempo .bpm-row{padding:0 .5rem;margin-bottom:.4rem}.metronome-shell .basic-grid .card-tempo .bpm-number{font-size:clamp(2.6rem,6vw,3.4rem)}.metronome-shell .basic-grid .card-tempo .bpm-unit{margin-top:.1rem}.metronome-shell .basic-grid .card-tempo .tempo-name{margin-top:.05rem;letter-spacing:.16em}.metronome-shell .basic-grid .card-tempo .bpm-step-group{gap:.3rem}.metronome-shell .basic-grid .card-tempo .btn-step{min-width:38px;font-size:.78rem;padding:.3rem .5rem}.metronome-shell .basic-grid .card-tempo .slider-row{margin-top:auto;margin-bottom:.55rem;padding-top:.4rem}.metronome-shell .basic-grid .card-tempo .tap-row{margin-bottom:.5rem}.metronome-shell .basic-grid .card-tempo .btn-tap{min-width:120px;padding:.45rem 1.2rem;font-size:.85rem}.metronome-shell .basic-grid .card-tempo .play-row{display:grid;grid-template-columns:1fr auto 1fr;margin-top:0;gap:.5rem}.metronome-shell .basic-grid .card-tempo .play-row .btn-play{grid-column:2;padding:.65rem 1.6rem;font-size:1.02rem;min-width:160px}.metronome-shell .basic-grid .card-tempo .play-row .spacebar-hint{grid-column:3;justify-self:start;align-self:center}.metronome-shell .basic-grid .card-timesig .time-sig-presets{margin-bottom:.7rem;flex-wrap:nowrap;gap:.4rem}.metronome-shell .basic-grid .card-timesig .btn-sig{flex:1 1 auto;padding:.32rem .4rem}.metronome-shell .basic-grid .card-timesig .custom-sig{justify-content:center}.metronome-shell .basic-grid .card-subdiv .subdivision-grid{gap:.4rem}.metronome-shell .basic-grid .card-subdiv .btn-sub{padding:.55rem .3rem}.metronome-shell .basic-grid .card-subdiv .sub-icon{min-height:1.4rem;display:flex;align-items:center;justify-content:center}.metronome-shell .basic-grid .card-sound .sound-grid{gap:.4rem}.metronome-shell .basic-grid .card-sound .btn-sound{padding:.55rem .3rem}.metronome-shell .basic-grid .card-sound .sound-icon{min-height:1.4rem;display:flex;align-items:center;justify-content:center}.metronome-shell .basic-grid .card-beats{padding:.75rem 1.1rem}.metronome-shell .basic-grid .card-beats .section-label{text-align:center}.metronome-shell .basic-grid .card-beats .beat-grid-hint{display:none}.metronome-shell .basic-grid .card-beats .sub-indicators{margin-top:.6rem}.metronome-shell .adv-toggle-row{max-width:620px;margin-left:auto;margin-right:auto}.metronome-shell .adv-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-template-areas:"gap     form" "random  form";gap:.75rem;align-items:stretch}.metronome-shell .adv-grid>.card{margin-bottom:0;padding:.9rem 1.1rem}.metronome-shell .adv-grid .card-gap{grid-area:gap}.metronome-shell .adv-grid .card-random{grid-area:random}.metronome-shell .adv-grid .card-form{grid-area:form}.metronome-shell .adv-grid .card-form{display:flex;flex-direction:column}.metronome-shell .adv-grid .card-form .adv-controls{display:flex;flex-direction:column;flex:1;min-height:0}.metronome-shell .adv-grid .card-form .form-list{flex:1;max-height:none;min-height:120px}.metronome-shell .adv-grid .card-gap,.metronome-shell .adv-grid .card-random{display:flex;flex-direction:column}.metronome-shell .adv-grid .card-gap .adv-controls,.metronome-shell .adv-grid .card-random .adv-controls{flex:1;display:flex;flex-direction:column;justify-content:center}.metronome-shell .adv-grid .card-gap .adv-row:last-of-type,.metronome-shell .adv-grid .card-random .adv-row:last-of-type{margin-bottom:0}}
