.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-content{background-color:#1a1a1af2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:3rem;width:100%;max-width:400px;box-shadow:0 8px 32px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2.5rem}.login-title{font-size:2rem;font-weight:700;color:#ffffffde;margin:0 0 .5rem}.login-subtitle{font-size:1rem;color:#fff9;margin:0}.login-body{display:flex;flex-direction:column;gap:1rem}.google-login-button{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.875rem 1.5rem;background-color:#fff;color:#213547;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0000001a}.google-login-button:hover{background-color:#f5f5f5;box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.google-login-button:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}.google-icon{flex-shrink:0}@media (prefers-color-scheme: light){.login-content{background-color:#fffffff2}.login-title{color:#213547}.login-subtitle{color:#0009}.google-login-button{background-color:#fff;color:#213547;box-shadow:0 2px 4px #0000001a}.google-login-button:hover{background-color:#f5f5f5}}.metronome-container{display:flex;flex-direction:column;align-items:center;gap:2rem;padding-bottom:.5rem}.metronome-wheel{position:relative;width:200px;height:200px;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none}.metronome-wheel.disabled{cursor:default;opacity:.6;pointer-events:none}.metronome-wheel.disabled .tempo-handle{cursor:default}.wheel-svg{width:100%;height:100%;color:#ffffffde}.tempo-handle{transition:fill .2s;filter:drop-shadow(0 2px 4px rgba(100,108,255,.4))}.tempo-handle:hover{filter:drop-shadow(0 2px 6px rgba(100,108,255,.6))}.tempo-display{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2rem;font-weight:600;color:#ffffffde;cursor:pointer;-webkit-user-select:none;user-select:none;padding:.25rem .5rem;border-radius:4px;transition:background-color .2s}.tempo-display:hover:not(.disabled){background-color:#ffffff1a}.tempo-display.disabled{cursor:default;opacity:.7}.tempo-input{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2rem;font-weight:600;color:#ffffffde;background-color:#1e1e1ee6;border:2px solid var(--accent-color, #646cff);border-radius:4px;padding:.25rem .5rem;text-align:center;width:120px;outline:none;font-family:inherit}.tempo-input:focus{background-color:#1e1e1ef2;box-shadow:0 0 8px #646cff66}.time-signature-controls{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:500px}.time-signature-buttons{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.time-signature-button{padding:.5rem 1rem;border-radius:8px;border:2px solid rgba(255,255,255,.3);background-color:transparent;color:#ffffffde;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;min-width:60px}.time-signature-button:hover{border-color:#646cff;background-color:#646cff1a}.time-signature-button.active{border-color:#646cff;background-color:#646cff;color:#fff}.time-signature-button:active{transform:scale(.95)}@media (prefers-color-scheme: light){.wheel-svg,.tempo-display{color:#213547}.tempo-display:hover:not(.disabled){background-color:#0000000d}.metronome-wheel.disabled{opacity:.6}.tempo-display.disabled{opacity:.7}.tempo-input{color:#213547;background-color:#fffffff2;border-color:#646cff}.tempo-input:focus{background-color:#fff}.time-signature-label{color:#213547}.time-signature-button{border-color:#2135474d;color:#213547}.time-signature-button:hover{border-color:#646cff;background-color:#646cff1a}.time-signature-button.active{border-color:#646cff;background-color:#646cff;color:#fff}.beat-dot{background-color:#2135474d}.beat-dot.first-beat{background-color:#ffa50066}.beat-dot.active{background-color:#646cff}.beat-dot.first-beat.active{background-color:#ff9500}}.time-signature-selector{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-bottom:2rem;position:relative}.time-signature-label{font-size:1rem;font-weight:500;color:#ffffffde}.time-signature-trigger{display:flex;align-items:center;padding:.75rem 1.25rem;border-radius:8px;border:2px solid rgba(255,255,255,.3);background-color:transparent;color:#ffffffde;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;min-width:120px;justify-content:center}.time-signature-trigger:hover{border-color:#646cff;background-color:#646cff1a}.time-signature-trigger:active:not(.disabled){transform:scale(.98)}.time-signature-trigger.disabled,.time-signature-trigger:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.time-signature-trigger.disabled:hover,.time-signature-trigger:disabled:hover{border-color:#ffffff4d;background-color:transparent}.dialog-icon{font-size:1rem;transition:transform .2s}.time-signature-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in-out}.time-signature-dialog-content{background-color:#1a1a1a;border-radius:8px;padding:0;max-width:400px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 6px #0000004d;animation:slideUp .2s ease-out}.time-signature-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.time-signature-dialog-header h2{margin:0;font-size:1.5rem;color:#ffffffde}.time-signature-dialog-close{background:none;border:none;color:#ffffffde;font-size:2rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.time-signature-dialog-close:hover{background-color:#ffffff1a}.time-signature-dialog-body{padding:1.5rem}.time-signature-options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.time-signature-option{padding:1rem;border:2px solid rgba(255,255,255,.2);border-radius:8px;background-color:transparent;color:#ffffffde;font-size:1.25rem;font-weight:500;cursor:pointer;transition:all .15s;text-align:center}.time-signature-option:hover{border-color:#646cff;background-color:#646cff33;color:#fff;transform:scale(1.02)}.time-signature-option:active{transform:scale(.98)}.time-signature-option.selected{border-color:#646cff;background-color:#646cff4d;color:#fff}@media (prefers-color-scheme: light){.time-signature-label{color:#213547}.time-signature-trigger{border-color:#2135474d;color:#213547}.time-signature-trigger:hover{border-color:#646cff;background-color:#646cff1a}.time-signature-trigger.disabled,.time-signature-trigger:disabled{opacity:.5;cursor:not-allowed}.time-signature-trigger.disabled:hover,.time-signature-trigger:disabled:hover{border-color:#2135474d;background-color:transparent}.time-signature-dialog-content{background-color:#fff}.time-signature-dialog-header h2,.time-signature-dialog-close{color:#213547}.time-signature-dialog-close:hover{background-color:#0000000d}.time-signature-option{border-color:#21354733;color:#213547}.time-signature-option:hover{border-color:#646cff;background-color:#646cff26}.time-signature-option:active{background-color:#646cff40}.time-signature-option.selected{border-color:#646cff;background-color:#646cff40;color:#213547}}.word-control-container{display:flex;flex-direction:column;width:100%;position:relative}.word-control-main{display:flex;flex-direction:column;align-items:center;width:100%;gap:1rem}.word-control-center,.word-preview-container{display:flex;justify-content:center}.word-preview{font-size:.75em;font-style:italic;opacity:.7}.associated-word-section{margin-top:1rem;width:100%;padding-top:.5rem}.associated-word-toggle{display:flex;align-items:center;gap:.5rem;background:transparent;border:none;color:inherit;cursor:pointer;font-size:.875rem;padding:.5rem;width:100%;justify-content:center;transition:opacity .2s}.associated-word-toggle:hover{opacity:.7}.associated-word-toggle:focus{outline:none}.associated-word-content{margin-top:.5rem;padding:1rem;display:flex;flex-direction:column;gap:.5rem;align-items:center}.associated-word-loading{font-size:.875rem;opacity:.7}.associated-word-error{font-size:.875rem;color:#ff6b6b}.associated-word-empty{font-size:.875rem;opacity:.7}.associated-word-list{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.associated-word-item{padding:.5rem 1rem;background:#ffffff1a;border-radius:.5rem;font-size:.875rem;border:1px solid rgba(255,255,255,.2)}.settings-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in-out}.settings-modal-content{background-color:#1a1a1a;border-radius:8px;padding:0;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 6px #0000004d;animation:slideUp .2s ease-out}.settings-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.settings-modal-header h2{margin:0;font-size:1.5rem;color:#ffffffde}.settings-modal-close{background:none;border:none;color:#ffffffde;font-size:2rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.settings-modal-close:hover{background-color:#ffffff1a}.settings-modal-body{padding:1.5rem}.settings-control{margin-bottom:2rem}.settings-control:last-child{margin-bottom:0}.settings-user-section{margin-top:2rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:1rem}.settings-user-info{display:flex;flex-direction:column;gap:.25rem}.settings-user-label{font-size:.875rem;color:#fff9}.settings-user-name{font-size:1rem;font-weight:500;color:#ffffffde}.settings-control label{display:block;margin-bottom:.5rem;color:#ffffffde;font-size:1rem;font-weight:500}.settings-control input[type=range]{width:100%;height:8px;border-radius:4px;background:#fff3;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.settings-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#646cff;cursor:pointer;transition:background-color .2s}.settings-control input[type=range]::-webkit-slider-thumb:hover{background:#535bf2}.settings-control input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#646cff;cursor:pointer;border:none;transition:background-color .2s}.settings-control input[type=range]::-moz-range-thumb:hover{background:#535bf2}.settings-control-hint{margin-top:.5rem;font-size:.875rem;color:#fff9;font-style:italic}.settings-modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.settings-button{padding:.75rem 1.5rem;border:2px solid rgba(255,255,255,.87);border-radius:4px;font-size:1rem;cursor:pointer;transition:all .2s;background-color:transparent}.settings-button-cancel{color:#ffffffde}.settings-button-cancel:hover{background-color:#ffffff1a;border-color:#ffffffde}.settings-button-save{color:#ffffffde;background-color:#646cff;border-color:#646cff}.settings-button-save:hover{background-color:#535bf2;border-color:#535bf2;transform:scale(1.05)}.settings-button-logout{color:#ffffffde;border-color:#ff4d4d80;background-color:transparent}.settings-button-logout:hover{background-color:#ff4d4d33;border-color:#ff4d4dcc}.settings-button:active{transform:scale(.95)}@media (prefers-color-scheme: light){.settings-modal-content{background-color:#fff}.settings-modal-header h2,.settings-modal-close{color:#213547}.settings-modal-close:hover{background-color:#0000000d}.settings-control label{color:#213547}.settings-control input[type=range]{background:#0000001a}.settings-control-hint{color:#0009}.settings-button-cancel{color:#213547;border-color:#213547}.settings-button-cancel:hover{background-color:#0000000d}.settings-user-section{border-top-color:#0000001a}.settings-user-label{color:#0009}.settings-user-name{color:#213547}.settings-button-logout{color:#213547;border-color:#ff4d4d80}.settings-button-logout:hover{background-color:#ff4d4d1a;border-color:#ff4d4dcc}}.beat-indicator{display:flex;gap:.75rem;align-items:center;justify-content:center;height:20px}.beat-dot{width:12px;height:12px;border-radius:50%;background-color:#ffffff4d;transition:all .2s}.beat-dot.first-beat{background-color:#ffa50080}.beat-dot.active{background-color:var(--accent-color, #646cff);transform:scale(1.3);box-shadow:0 0 8px #646cff99}.beat-dot.first-beat.active{background-color:#ff9500;box-shadow:0 0 8px #ff9500cc}@media (prefers-color-scheme: light){.beat-dot{background-color:#2135474d}.beat-dot.first-beat{background-color:#ffa50066}.beat-dot.active{background-color:#646cff}.beat-dot.first-beat.active{background-color:#ff9500}}.play-pause-button{background-color:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:100;transform:scale(2);outline:none;margin:1rem}.play-pause-button:focus{outline:none}.now-playing{padding:.5rem;width:90%;max-width:450px;background:#ffffff0d;border-radius:8px;cursor:pointer;transition:all .2s;border:1px solid rgba(255,255,255,.1);margin-bottom:8px}.now-playing:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-1px)}.now-playing:active{transform:translateY(0)}.now-playing-content{display:flex;flex-direction:column;gap:.2rem}.now-playing-label{font-size:.7rem;color:#fff9;text-transform:uppercase;letter-spacing:.5px}.now-playing-info{display:flex;flex-direction:column;gap:.25rem}.now-playing-title{font-size:.8rem;font-weight:600;color:#ffffffde}.now-playing-details{font-size:.7rem;color:#fff9}.now-playing-placeholder{font-size:.7rem;color:#fff6;font-style:italic}.beats-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in-out;padding:1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.beats-modal-content{background-color:#1a1a1a;border-radius:8px;padding:0;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;overflow-x:hidden;box-shadow:0 4px 6px #0000004d;animation:slideUp .2s ease-out;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;touch-action:pan-y;overscroll-behavior:contain}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.beats-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);position:sticky;top:0;background-color:#1a1a1a;z-index:10}.beats-modal-header h2{margin:0;font-size:1.5rem;color:#ffffffde}.beats-modal-close{background:none;border:none;color:#ffffffde;font-size:2rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.beats-modal-close:hover{background-color:#ffffff1a}.beats-modal-body{padding:1.5rem;touch-action:pan-y}.beats-loading,.beats-error,.beats-empty{text-align:center;padding:2rem;color:#fff9}.beats-error{color:#ff6b6b}.beats-list{display:flex;flex-direction:column;gap:.75rem;min-height:0;touch-action:pan-y}.beat-item{padding:1rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:all .2s;touch-action:manipulation;user-select:none;-webkit-user-select:none}.beat-item:hover{background:#ffffff1a;border-color:#fff3;transform:translate(4px)}.beat-item-active{background:#646cff33;border-color:#646cff}.beat-item-active:hover{background:#646cff4d}.beat-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.beat-item-artist{font-size:1.125rem;font-weight:600;color:#ffffffde}.beat-item-bpm{font-size:.875rem;color:#fff9;background:#ffffff1a;padding:.25rem .75rem;border-radius:12px}.beat-item-details{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#fff9;margin-bottom:.5rem;flex-wrap:wrap}.beat-item-separator{color:#ffffff4d}.beat-item-genre,.beat-item-time-signature,.beat-item-phrases,.beat-item-length{color:#fff9}.beat-item-measures{font-size:.75rem;color:#fff6;font-style:italic}@media (prefers-color-scheme: light){.now-playing{background:#0000000d;border-color:#0000001a}.now-playing:hover{background:#0000001a;border-color:#0003}.now-playing-label{color:#0009}.now-playing-title{color:#213547}.now-playing-details{color:#0009}.now-playing-placeholder{color:#0006}.beats-modal-content{background-color:#fff}.beats-modal-header{background-color:#fff;border-bottom-color:#0000001a}.beats-modal-header h2,.beats-modal-close{color:#213547}.beats-modal-close:hover{background-color:#0000000d}.beats-loading,.beats-empty{color:#0009}.beat-item{background:#0000000d;border-color:#0000001a}.beat-item:hover{background:#0000001a;border-color:#0003}.beat-item-active{background:#646cff26;border-color:#646cff}.beat-item-artist{color:#213547}.beat-item-bpm{color:#0009;background:#0000001a}.beat-item-details{color:#0009}.beat-item-separator{color:#0000004d}.beat-item-genre,.beat-item-time-signature,.beat-item-phrases,.beat-item-length{color:#0009}.beat-item-measures{color:#0006}}.app{display:flex;flex-direction:column;align-items:center;min-height:100vh;width:100vw}.app-content{width:100%;display:flex;flex-direction:column;align-items:center;padding-top:2rem}.app h1{margin-bottom:0}.app-beat-indicator{min-height:40px;margin-bottom:1rem}.beat-details{display:flex;flex-direction:column;gap:8px;align-items:center}.beat-details-word{font-size:.7rem}.beat-details-phrase{font-size:.8rem}.settings-button-icon{position:fixed;bottom:1rem;left:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:100;background-color:transparent}.settings-button-icon:hover{background-color:#ffffff1a;border-color:#646cff;transform:scale(1.05)}.settings-button-icon:active{transform:scale(.95)}@media (prefers-color-scheme: light){.play-pause-button{border-color:#213547;color:#213547}.play-pause-button:hover{background-color:#0000000d;border-color:#646cff}.settings-button-icon{border-color:#213547;color:#213547}.settings-button-icon:hover{background-color:#0000000d;border-color:#646cff}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,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}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
