:root{color:#1d1d1f;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f7;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Segoe UI,ui-sans-serif,system-ui,sans-serif}*{box-sizing:border-box}body{min-width:320px;margin:0}#root{min-height:100svh}.app-shell{color:#1d1d1f;background:#f5f5f7;flex-direction:column;align-items:center;gap:42px;min-height:100svh;padding:0 28px 42px;display:flex}.site-header{z-index:100;-webkit-backdrop-filter:saturate(180%)blur(20px);backdrop-filter:saturate(180%)blur(20px);background:#ffffffe0;border-bottom:1px solid #0000000a;justify-content:space-between;align-items:center;gap:24px;width:calc(100% + 56px);min-height:96px;padding:16px max(32px,50% - 630px);display:flex;position:relative}.brand-block{min-width:0}.brand-name{color:#1d1d1f;font-size:30px;font-weight:650;line-height:1.1}.language-switch{z-index:20;flex:none;position:relative}.language-button{color:#1d1d1f;white-space:nowrap;background:#ffffffe6;border:1px solid #d2d2d7;border-radius:14px;justify-content:space-between;align-items:center;gap:18px;min-width:132px;min-height:52px;padding:0 18px;font-size:16px;font-weight:500;transition:background .16s,border-color .16s,box-shadow .16s;display:inline-flex}.language-button:hover,.language-button[aria-expanded=true]{background:#fff;border-color:#b8b8bd;box-shadow:0 5px 18px #00000014}.language-chevron{width:16px;height:16px;transition:transform .18s}.language-chevron.open{transform:rotate(180deg)}.language-menu{-webkit-backdrop-filter:saturate(180%)blur(20px);backdrop-filter:saturate(180%)blur(20px);transform-origin:100% 0;background:#fffffff5;border:1px solid #00000014;border-radius:14px;width:190px;padding:6px;animation:.16s ease-out menu-in;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 18px 48px #00000024}.language-menu button{color:#1d1d1f;text-align:left;background:0 0;border:0;border-radius:9px;width:100%;min-height:42px;padding:0 12px;font-size:15px;font-weight:500}.language-menu button:hover{background:#f2f2f7}.language-menu button.selected{color:#fff;background:#007aff}@keyframes menu-in{0%{opacity:0;transform:scale(.96)translateY(-4px)}}.metronome-panel{z-index:1;background:#fffffff0;border:1px solid #0000001a;border-radius:24px;width:min(1320px,100%);padding:26px 42px 34px;position:relative;box-shadow:0 12px 38px #0000001a}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}button,input{font:inherit}button{cursor:pointer}.tempo-control{grid-template-columns:96px minmax(360px,1fr) 96px;align-items:center;gap:52px;width:min(720px,100%);margin:0 auto;display:grid}.step-button{color:#1d1d1f;background:linear-gradient(#fff,#fbfbfd);border:1px solid #d2d2d7;border-radius:50%;place-items:center;width:96px;height:96px;transition:transform .14s,background .14s,box-shadow .14s;display:grid;box-shadow:0 6px 14px #0000001a}.step-button svg{stroke-width:1.8px;width:39px;height:39px}.step-button:hover{background:#f5f5f7;transform:translateY(-1px);box-shadow:0 8px 18px #0000001f}.step-button:active,.play-button:active,.tap-button:active,.segmented button:active{transform:scale(.97)}.tempo-display{text-align:center;place-items:center;gap:12px;min-width:0;display:grid}.bpm-kicker{color:#1d1d1f;font-size:22px;font-weight:500;line-height:1}.bpm-button,.bpm-form{color:#1d1d1f;background:linear-gradient(#fff,#fcfcfd);border:1px solid #d2d2d7;border-radius:28px;flex-direction:column;justify-content:center;align-items:center;gap:2px;width:360px;height:196px;padding:8px 18px 12px;transition:border-color .16s,box-shadow .16s,transform .16s;display:flex;box-shadow:0 8px 18px #0000001c}.bpm-button:hover{border-color:#b8b8bd;transform:translateY(-1px);box-shadow:0 12px 24px #00000021}.bpm-form{border-color:#007aff;box-shadow:0 0 0 4px #007aff1f,0 10px 24px #0000001f}.bpm-value-surface{background:0 0;border-radius:20px;place-items:center;width:100%;height:132px;display:grid;position:relative}.bpm-value-surface.editing{background:#f2f2f7}.bpm-value-surface strong,.bpm-value-surface input{font-size:108px;font-weight:580;line-height:1}.bpm-edit-icon{color:#6e6e73;stroke-width:1.8px;width:23px;height:23px;position:absolute;top:12px;right:8px}.bpm-edit-hint{color:#6e6e73;min-height:24px;font-size:17px;font-weight:400;line-height:1.2}.bpm-form input{color:#1d1d1f;caret-color:#007aff;text-align:center;background:0 0;border:0;outline:0;width:100%;height:1em;padding:0}.bpm-form input:focus-visible{outline:0}.slider-row{color:#1d1d1f;grid-template-columns:48px minmax(0,1fr) 48px;align-items:center;gap:16px;width:min(1190px,100%);margin:38px auto 0;font-size:19px;font-weight:500;display:grid}.slider-row input[type=range]{appearance:none;border-radius:999px;outline:none;width:100%;height:5px}.slider-row input[type=range]::-webkit-slider-thumb{appearance:none;cursor:grab;background:#fff;border:1px solid #d2d2d7;border-radius:50%;width:32px;height:32px;box-shadow:0 3px 8px #00000029}.slider-row input[type=range]::-moz-range-thumb{cursor:grab;background:#fff;border:1px solid #d2d2d7;border-radius:50%;width:30px;height:30px;box-shadow:0 3px 8px #00000029}.audio-note{color:#bf5b00;text-align:center;margin:14px 0 0;font-size:13px;font-weight:500}.beat-status-row{justify-content:center;align-items:center;min-height:22px;margin-top:22px;display:flex}.beat-dots{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.beat{background:#c7c7cc;border-radius:50%;width:8px;height:8px;transition:width .12s,background .12s,transform .12s}.beat:first-child{width:10px;height:10px}.beat.active{background:#007aff;transform:scale(1.08);box-shadow:0 0 0 5px #007aff21}.primary-actions{grid-template-columns:minmax(320px,1.2fr) minmax(260px,1fr);gap:24px;width:min(700px,100%);margin:18px auto 0;display:grid}.play-button,.tap-button{border-radius:999px;min-height:72px;transition:transform .14s,box-shadow .14s,filter .14s}.play-button{color:#fff;background:linear-gradient(#2f86ff,#0a6ff2);border:0;justify-content:center;align-items:center;gap:16px;font-size:28px;font-weight:500;display:flex;box-shadow:0 8px 18px #007aff3d}.play-button:hover{filter:brightness(1.04);box-shadow:0 10px 24px #007aff47}.play-button svg{color:#007aff;background:#fff;border-radius:50%;width:42px;height:42px;padding:10px}.tap-button{color:#1d1d1f;background:#fff;border:1px solid #d2d2d7;grid-template-columns:auto auto;place-content:center;align-items:center;column-gap:14px;display:grid;box-shadow:0 5px 14px #00000014}.tap-button:hover{background:#f9f9fb;box-shadow:0 7px 18px #0000001a}.tap-button>svg{stroke-width:1.6px;grid-row:1/3;width:32px;height:32px}.tap-button strong{text-align:left;font-size:20px;font-weight:500;line-height:1.1}.tap-button small{color:#86868b;text-align:left;font-size:11px;font-weight:500;line-height:1.1}.control-grid{grid-template-columns:minmax(330px,.72fr) minmax(0,1.28fr);gap:28px 22px;min-width:0;margin-top:34px;display:grid}.control-group{min-width:0}.control-group p{color:#86868b;margin:5px 0 0;font-size:14px;line-height:1.35}.label{color:#1d1d1f;font-size:19px;font-weight:500}.time-signature-group{grid-column:1/-1;padding:0 14px}.segmented{grid-template-columns:repeat(8,minmax(64px,1fr)) minmax(150px,1.55fr);gap:20px;width:100%;min-width:0;margin-top:14px;padding:2px 0 8px;display:grid;overflow-x:auto}.segmented button,.custom-signature-control{color:#1d1d1f;min-width:0;height:66px;box-shadow:none;background:#fff;border:1px solid #d2d2d7;border-radius:14px;font-size:22px;font-weight:500;transition:color .15s,background .15s,border-color .15s,transform .15s,box-shadow .15s}.segmented button:hover,.custom-signature-control:hover{background:#f5f5f7}.segmented button.selected,.custom-signature-control.selected{color:#fff;box-shadow:none;background:linear-gradient(#3489ff,#0a71f5);border-color:#007aff}.custom-signature-control{justify-content:center;align-items:center;gap:10px;padding:0 14px;display:flex;overflow:hidden}.custom-signature-control svg{stroke-width:1.6px;flex:none;width:22px;height:22px}.custom-signature-control.selected svg{width:16px;height:16px}.custom-signature-control.editing{background:#fff;border-color:#007aff;animation:.18s ease-out custom-edit-in;box-shadow:0 0 0 4px #007aff1f}@keyframes custom-edit-in{0%{transform:scale(.96)}}.custom-signature-control input{color:#1d1d1f;caret-color:#007aff;text-align:center;background:0 0;border:0;outline:0;width:100%;min-width:0;height:64px;padding:0 8px;font-size:22px;font-weight:500}.custom-signature-control input::placeholder{color:#86868b;opacity:1}.accent-control,.countdown{background:#fff;border:1px solid #d2d2d7;border-radius:16px;min-height:128px;box-shadow:0 3px 10px #0000000d}.control-group-heading{min-width:0}.accent-control{justify-content:space-between;align-items:center;gap:20px;padding:24px 30px;display:flex}.switch{flex:none;width:64px;height:38px;display:inline-flex;position:relative}.switch input{opacity:0;position:absolute}.switch span{background:#e9e9eb;border-radius:999px;width:100%;transition:background .18s;box-shadow:inset 0 0 0 1px #0000000f}.switch span:before{content:"";background:#fff;border-radius:50%;width:32px;height:32px;transition:transform .18s;position:absolute;top:3px;left:3px;box-shadow:0 2px 7px #00000038}.switch input:checked+span{background:#007aff}.switch input:checked+span:before{transform:translate(26px)}.countdown{grid-template-columns:150px minmax(0,1fr);align-items:center;gap:14px 26px;padding:20px 28px 16px;display:grid}.countdown .control-group-heading{border-right:1px solid #e5e5ea;padding-right:24px}.countdown-time{font-variant-numeric:tabular-nums;margin-top:4px;font-size:42px;font-weight:400;line-height:1;display:block}.countdown-time.expired{color:#ff3b30}.countdown-row{grid-template-columns:minmax(112px,.8fr) minmax(160px,1.25fr) minmax(92px,.65fr);align-items:center;gap:14px;min-width:0;display:grid}.countdown-input-wrap{background:#fff;border:1px solid #d2d2d7;border-radius:12px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:5px;min-width:0;height:52px;padding-right:12px;display:grid}.countdown-input-wrap input{color:#1d1d1f;background:0 0;border:0;outline:0;width:100%;min-width:0;height:50px;padding:0 10px;font-size:16px;font-weight:500}.countdown-input-wrap span{color:#6e6e73;font-size:13px;font-weight:500}.countdown-row button{white-space:nowrap;border-radius:12px;justify-content:center;align-items:center;gap:7px;min-height:52px;font-size:15px;font-weight:500;display:inline-flex}.countdown-start{color:#007aff;background:#fff;border:1px solid #007aff}.countdown-start:hover{background:#007aff0f}.countdown-row button.quiet{color:#6e6e73;background:#fff;border:1px solid #d2d2d7}.countdown-hint{text-align:right;grid-column:1/-1;color:#86868b!important;margin:0!important;font-size:12px!important}:is(button:focus-visible,input:focus-visible,.switch:has(input:focus-visible) span){outline-offset:2px;outline:4px solid #007aff3d}@media (width<=1350px) and (width>=901px){.countdown{grid-template-columns:132px minmax(0,1fr);gap:12px 18px;padding-inline:22px}.countdown .control-group-heading{padding-right:18px}.countdown-row{grid-template-columns:minmax(88px,.8fr) minmax(128px,1.25fr) 52px;gap:10px}.countdown-row button{min-width:0;padding-inline:10px}.countdown-row button.quiet span{display:none}}@media (width<=900px){.app-shell{gap:20px;padding:0 14px 20px}.site-header{width:calc(100% + 28px);min-height:72px;padding:10px 18px}.brand-name{font-size:22px}.language-button{min-width:0;min-height:44px;padding:0 13px}.metronome-panel{padding:24px 20px}.tempo-control{grid-template-columns:72px minmax(250px,1fr) 72px;gap:24px}.step-button{width:72px;height:72px}.bpm-button,.bpm-form{width:290px;height:176px}.bpm-value-surface strong,.bpm-value-surface input{font-size:88px}.segmented{grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;padding-bottom:2px;overflow-x:visible}.custom-signature-control{grid-column:span 2}.control-grid{grid-template-columns:1fr;gap:16px}.accent-control,.countdown{grid-column:1}.countdown-row button.quiet span{display:inline}}@media (width<=620px){.app-shell{padding-inline:10px}.site-header{width:calc(100% + 20px)}.brand-name{font-size:19px}.language-button span{text-overflow:ellipsis;max-width:62px;overflow:hidden}.metronome-panel{border-radius:18px;padding:20px 12px}.tempo-control{grid-template-columns:48px minmax(0,1fr) 48px;gap:8px}.step-button{width:48px;height:48px}.step-button svg{width:25px;height:25px}.tempo-display{gap:8px}.bpm-kicker{font-size:17px}.bpm-button,.bpm-form{border-radius:22px;width:min(210px,100%);height:142px;padding-inline:10px}.bpm-value-surface{height:94px}.bpm-value-surface strong,.bpm-value-surface input{font-size:66px}.bpm-edit-icon{width:17px;height:17px;top:8px;right:5px}.bpm-edit-hint{text-overflow:ellipsis;white-space:nowrap;max-width:185px;font-size:13px;overflow:hidden}.slider-row{grid-template-columns:34px minmax(0,1fr) 34px;gap:8px;margin-top:28px;font-size:14px}.slider-row input[type=range]::-webkit-slider-thumb{width:27px;height:27px}.beat-status-row{margin-top:18px}.primary-actions{grid-template-columns:1.15fr .85fr;gap:10px;margin-top:12px}.play-button,.tap-button{min-height:58px}.play-button{gap:8px;font-size:20px}.play-button svg{width:34px;height:34px;padding:8px}.tap-button{justify-content:center;align-items:center;column-gap:7px;display:flex}.tap-button>svg{width:25px;height:25px}.tap-button strong{font-size:15px}.tap-button small{display:none}.control-grid{margin-top:26px}.time-signature-group{padding:0 2px}.label{font-size:17px}.segmented{grid-template-columns:repeat(5,minmax(0,1fr));gap:9px}.segmented button,.custom-signature-control{border-radius:12px;height:56px;font-size:18px}.custom-signature-control input{height:54px;font-size:18px}.accent-control{min-height:104px;padding:20px}.countdown{grid-template-columns:1fr;padding:20px}.countdown .control-group-heading{border-bottom:1px solid #e5e5ea;border-right:0;padding:0 0 16px}.countdown-time{font-size:38px}.countdown-row{grid-template-columns:1fr 1.2fr}.countdown-row button.quiet{grid-column:1/-1}.countdown-hint{text-align:left}}@media (width<=390px){.brand-name{font-size:17px}.language-button{padding-inline:10px}.tempo-control{grid-template-columns:42px minmax(0,1fr) 42px;gap:5px}.step-button{width:42px;height:42px}.bpm-button,.bpm-form{width:min(190px,100%)}.bpm-value-surface strong,.bpm-value-surface input{font-size:60px}.primary-actions,.countdown-row{grid-template-columns:1fr}.countdown-row button.quiet{grid-column:auto}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
