.notif-panel{background-color:var(--bg-secondary);border:1px solid var(--border-color);z-index:100;opacity:0;visibility:hidden;pointer-events:none;border-radius:10px;width:300px;transition:opacity .15s,transform .15s,visibility 0s .15s;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden;transform:translateY(-6px)scale(.97);box-shadow:0 4px 24px #00000026}.notif-panel--open{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .15s,transform .15s;transform:translateY(0)scale(1)}.notif-panel__header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1rem;display:flex}.notif-panel__title{color:var(--text-primary);font-size:13px;font-weight:600}.notif-panel__mark-all{all:unset;color:var(--accent);cursor:pointer;font-size:12px}.notif-panel__mark-all:hover{text-decoration:underline}.notif-panel__empty{color:var(--text-muted);text-align:center;padding:24px 14px;font-size:13px}.notif-panel__list{max-height:320px;margin:0;padding:0;list-style:none;overflow-y:auto}.notif-panel__item{cursor:pointer;border-bottom:1px solid var(--border-color);align-items:flex-start;gap:12px;padding:1rem 1.5rem;display:flex}.notif-panel__item:last-child{border-bottom:none}.notif-panel__item:hover{background-color:var(--bg-hovered)}.notif-panel__item--unread{background-color:var(--bg-secondary)}.notif-panel__item--unread:hover{background-color:var(--bg-hovered)}.notif-panel__item--unread .notif-panel__item-title:before{content:"";background-color:var(--accent);vertical-align:middle;border-radius:50%;flex-shrink:0;width:6px;height:6px;margin-right:6px;display:inline-block}.notif-panel__item-content{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.notif-panel__item-title{color:var(--text-primary);align-items:center;font-size:13px;font-weight:600;display:flex}.notif-panel__item-body{color:var(--text-secondary);font-size:12px;line-height:1.4}.notif-panel__item-time{color:var(--text-muted);margin-top:2px;font-size:11px}.notif-panel__dismiss{all:unset;cursor:pointer;color:var(--text-muted);border-radius:4px;flex-shrink:0;align-items:center;padding:2px;display:flex}.notif-panel__dismiss:hover{color:var(--text-primary);background-color:var(--bg-hovered)}.mobile-menu-overlay{display:none}@media (width<=850px){.mobile-menu-overlay{display:block}}.mobile-menu-overlay{z-index:250;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#0006;animation:.2s fadeIn;position:fixed;inset:0}.mobile-menu-overlay--closing{animation:.28s forwards fadeOut}.mobile-menu{display:none}@media (width<=850px){.mobile-menu{flex-direction:column;display:flex}}.mobile-menu{z-index:260;background-color:var(--bg-secondary);border-top:1px solid var(--border-color);border-radius:20px 20px 0 0;max-height:75vh;padding:0 1.25rem 6rem;animation:.28s cubic-bezier(.32,.72,0,1) slideUp;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;box-shadow:0 -4px 32px #0003}.mobile-menu--closing{animation:.28s cubic-bezier(.32,.72,0,1) forwards slideDown}.mobile-menu__handle{background-color:var(--border-color);border-radius:2px;flex-shrink:0;width:36px;height:4px;margin:12px auto 16px}.mobile-menu__tabs{background-color:var(--bg-elevated);border-radius:12px;gap:6px;margin-bottom:16px;padding:4px;display:flex}.mobile-menu__tab{all:unset;text-align:center;color:var(--text-muted);cursor:pointer;border-radius:9px;flex:1;padding:7px 0;font-size:13px;font-weight:500;transition:background-color .15s,color .15s}.mobile-menu__tab--active{background-color:var(--bg-secondary);color:var(--text-primary);box-shadow:0 1px 4px #0000001f}.mobile-menu ul{flex-direction:column;gap:.15rem;display:flex}.mobile-menu ul li a,.mobile-menu ul li button{cursor:pointer;width:100%;color:var(--text-primary);text-align:left;letter-spacing:.01em;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;padding:.9rem .5rem;font-size:15px;font-weight:500;text-decoration:none;transition:background-color .15s;display:flex}.mobile-menu ul li a:hover,.mobile-menu ul li button:hover{background-color:var(--bg-elevated)}.mobile-menu ul li a svg,.mobile-menu ul li button svg{color:var(--text-secondary);flex-shrink:0}.mobile-menu ul li:last-child a,.mobile-menu ul li:last-child button{color:var(--text-secondary);border-top:1px solid var(--border-color);border-radius:0;margin-top:.25rem;padding-top:1rem;font-weight:400}.mobile-menu__controls{flex-direction:column;gap:12px;display:flex}.mobile-menu__controls-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-top:4px;font-size:11px;font-weight:600}.mobile-menu__keys{grid-template-columns:repeat(6,1fr);gap:6px;display:grid}.mobile-menu__key-btn{all:unset;text-align:center;color:var(--text-secondary);background-color:var(--bg-elevated);border:1px solid var(--border-color);cursor:pointer;border-radius:8px;padding:8px 4px;font-size:13px;font-weight:500;transition:background-color .12s,color .12s,border-color .12s}.mobile-menu__key-btn--active{background-color:var(--accent);border-color:var(--accent);color:#fff}.mobile-menu__scales{flex-direction:column;gap:4px;display:flex}.mobile-menu__scale-btn{all:unset;color:var(--text-secondary);cursor:pointer;border:1px solid #0000;border-radius:9px;padding:9px 12px;font-size:14px;font-weight:400;transition:background-color .12s,color .12s,border-color .12s}.mobile-menu__scale-btn--active{background-color:color-mix(in srgb, var(--accent) 12%, transparent);border-color:color-mix(in srgb, var(--accent) 30%, transparent);color:var(--accent);font-weight:500}.mobile-menu__scale-btn:not(.mobile-menu__scale-btn--active):hover{background-color:var(--bg-elevated)}.mobile-menu__overlays{grid-template-columns:repeat(2,1fr);gap:6px;display:grid}.mobile-menu__overlay-btn{all:unset;text-align:center;color:var(--text-secondary);background-color:var(--bg-elevated);border:1px solid var(--border-color);cursor:pointer;border-radius:8px;padding:9px 8px;font-size:13px;font-weight:500;transition:background-color .12s,color .12s,border-color .12s}.mobile-menu__overlay-btn--active{background-color:color-mix(in srgb, var(--accent) 12%, transparent);border-color:color-mix(in srgb, var(--accent) 30%, transparent);color:var(--accent)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.playback-sheet-overlay{display:none}@media (width<=850px){.playback-sheet-overlay{display:block}}.playback-sheet-overlay{z-index:250;background-color:#0006;animation:.2s pbFadeIn;position:fixed;inset:0}.playback-sheet-overlay--closing{animation:.28s forwards pbFadeOut}.playback-sheet{display:none}@media (width<=850px){.playback-sheet{flex-direction:column;display:flex}}.playback-sheet{z-index:260;background-color:var(--bg-secondary);border-top:1px solid var(--border-color);border-radius:20px 20px 0 0;padding:0 1.5rem 6rem;animation:.28s cubic-bezier(.32,.72,0,1) pbSlideUp;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 32px #0003}.playback-sheet--closing{animation:.28s cubic-bezier(.32,.72,0,1) forwards pbSlideDown}.playback-sheet__handle{background-color:var(--border-color);border-radius:2px;flex-shrink:0;width:36px;height:4px;margin:12px auto 24px}.playback-sheet__play-row{align-items:center;gap:10px;margin-bottom:20px;display:flex}.playback-sheet__play-btn{all:unset;background-color:var(--bg-elevated);border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;gap:8px;padding:13px 20px;font-size:14px;font-weight:600;transition:background-color .15s,border-color .15s,color .15s;display:flex}.playback-sheet__play-btn--active{background-color:color-mix(in srgb, var(--accent) 15%, transparent);border-color:color-mix(in srgb, var(--accent) 40%, transparent);color:var(--accent)}.playback-sheet__directions{flex:1;gap:6px;display:flex}.playback-sheet__dir-btn{all:unset;text-align:center;color:var(--text-secondary);background-color:var(--bg-elevated);border:1px solid var(--border-color);cursor:pointer;border-radius:10px;flex:1;padding:13px 0;font-size:13px;font-weight:500;transition:background-color .12s,color .12s,border-color .12s}.playback-sheet__dir-btn--active{background-color:color-mix(in srgb, var(--accent) 12%, transparent);border-color:color-mix(in srgb, var(--accent) 30%, transparent);color:var(--accent);font-weight:600}.playback-sheet__bpm-section{flex-direction:column;align-items:center;gap:8px;margin-bottom:20px;display:flex}.playback-sheet__bpm-row{align-items:center;gap:12px;width:100%;display:flex}.playback-sheet__bpm-step{all:unset;background-color:var(--bg-elevated);border:1px solid var(--border-color);width:36px;height:36px;color:var(--text-primary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;transition:background-color .12s;display:flex}.playback-sheet__bpm-step:active{background-color:var(--bg-elevated-hovered)}.playback-sheet__slider{accent-color:var(--accent);flex:1;height:4px}.playback-sheet__bpm-val{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:13px}.playback-sheet__actions{grid-template-columns:1fr 1fr;gap:10px;display:grid}.playback-sheet__action-btn{all:unset;background-color:var(--bg-elevated);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:18px 12px;font-size:13px;font-weight:500;transition:background-color .15s,border-color .15s,color .15s;display:flex}.playback-sheet__action-btn--active{background-color:color-mix(in srgb, var(--accent) 12%, transparent);border-color:color-mix(in srgb, var(--accent) 30%, transparent);color:var(--accent)}@keyframes pbSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes pbSlideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}@keyframes pbFadeIn{0%{opacity:0}to{opacity:1}}@keyframes pbFadeOut{0%{opacity:1}to{opacity:0}}.bt-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.bt-modal{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;width:100%;max-width:480px;max-height:80vh;display:flex;overflow:hidden;box-shadow:0 8px 32px #00000040}.bt-modal__header{border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.bt-modal__title{color:var(--text-primary);font-size:15px;font-weight:600}.bt-modal__close{all:unset;cursor:pointer;color:var(--text-muted);border-radius:4px;align-items:center;padding:4px;display:flex}.bt-modal__close:hover{color:var(--text-primary);background-color:var(--bg-hovered)}.bt-modal__add{border-bottom:1px solid var(--border-color);flex-shrink:0;padding:16px 20px}.bt-modal__hint{color:var(--text-primary);margin:4px 0 10px;font-size:12px;line-height:1.5}.bt-modal__input-row{flex-direction:column;gap:8px;display:flex}.bt-modal__textarea{background-color:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-primary);resize:none;border-radius:6px;flex:1;padding:8px 10px;font-family:monospace;font-size:12px;line-height:1.5}.bt-modal__textarea:focus{border-color:var(--accent);outline:none}.bt-modal__textarea::placeholder{color:var(--text-muted)}.bt-modal__add-btn{all:unset;cursor:pointer;background-color:var(--accent);color:#fff;white-space:nowrap;text-align:center;border-radius:6px;height:20px;padding:8px 16px;font-size:13px;font-weight:500}.bt-modal__add-btn:disabled{opacity:.4;cursor:default}.bt-modal__add-btn:not(:disabled):hover{opacity:.9}.bt-modal__error{color:var(--red);margin-top:6px;font-size:12px;display:block}.bt-modal__list{flex-direction:column;gap:4px;padding:12px 20px 20px;display:flex;overflow-y:auto}.bt-modal__section-label{color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;margin:8px 0 6px;font-size:11px;font-weight:600;display:block}.bt-track{border:1px solid #0000;border-radius:6px;align-items:center;gap:10px;padding:8px 10px;display:flex}.bt-track:hover{background-color:var(--bg-hovered)}.bt-track--active{border-color:var(--accent);background-color:var(--bg-primary)}.bt-track__play{all:unset;cursor:pointer;background-color:var(--bg-elevated);width:28px;height:28px;color:var(--text-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:transform .1s;display:flex}.bt-track__play:hover{background-color:var(--accent);color:#fff}.bt-track__play:active{transform:scale(.9)}.bt-track__title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;overflow:hidden}.bt-track__edit-input{background:var(--bg-primary);border:1px solid var(--accent);color:var(--text-primary);border-radius:4px;outline:none;flex:1;padding:2px 6px;font-size:13px}.bt-track__edit{all:unset;cursor:pointer;color:var(--text-muted);border-radius:4px;flex-shrink:0;align-items:center;padding:4px;display:flex}.bt-track__edit:hover{color:var(--text-primary)}.bt-track__delete{all:unset;cursor:pointer;color:var(--text-muted);border-radius:4px;flex-shrink:0;align-items:center;padding:4px;display:flex}.bt-track__delete:hover{color:var(--red)}.floating-player{background-color:var(--bg-secondary);border:1px solid var(--border-color);z-index:150;border-radius:10px;width:320px;position:fixed;bottom:24px;right:24px;box-shadow:0 8px 32px #0000004d}.floating-player--dragging{-webkit-user-select:none;user-select:none}.floating-player--dragging .floating-player__header{cursor:grabbing}.floating-player__header{border-bottom:1px solid var(--border-color);cursor:grab;border-radius:10px 10px 0 0;align-items:center;gap:8px;padding:10px 12px;display:flex}.floating-player__title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:12px;font-weight:500;overflow:hidden}.floating-player__close{all:unset;cursor:pointer;color:var(--text-muted);border-radius:4px;flex-shrink:0;align-items:center;padding:2px;transition:transform .1s;display:flex}.floating-player__close:hover{color:var(--text-primary)}.floating-player__close:active{transform:scale(.88)}.floating-player__embed{aspect-ratio:16/9;width:100%;position:relative;overflow:hidden}.floating-player__embed iframe{border:none;width:100%;height:100%;position:absolute;inset:0}.floating-player__yt-target{position:absolute;inset:0}.floating-player__drag-shield{z-index:1;position:absolute;inset:0}.floating-player__controls{border-top:1px solid var(--border-color);border-radius:0 0 10px 10px;flex-direction:column;gap:8px;padding:10px 12px;display:flex}.floating-player__volume{align-items:center;gap:8px;display:flex}.floating-player__volume input[type=range]{height:3px;accent-color:var(--accent);flex:1}.floating-player__vol-icon{color:var(--text-muted);flex-shrink:0}.floating-player__speed{gap:4px;display:flex}.floating-player__speed-btn{all:unset;cursor:pointer;color:var(--text-muted);border:1px solid var(--border-color);border-radius:4px;padding:3px 7px;font-size:11px;font-weight:500;transition:transform .1s}.floating-player__speed-btn:hover{color:var(--text-primary);background-color:var(--bg-hovered)}.floating-player__speed-btn:active{transform:scale(.9)}.floating-player__speed-btn--active{color:var(--accent);border-color:var(--accent);background-color:#0000}.bottom-nav{display:none}@media (width<=850px){.bottom-nav{display:flex}}.bottom-nav{z-index:300;background-color:var(--bg-secondary);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);white-space:nowrap;border-radius:50px;align-items:center;gap:8px;padding:6px;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 24px #0003}.bottom-nav__play-btn{all:unset;color:var(--text-muted);cursor:pointer;border-radius:50px;align-items:center;gap:7px;padding:8px 16px;font-size:13px;font-weight:500;transition:color .15s,background-color .15s;display:flex}.bottom-nav__play-btn--active{color:var(--accent)}.bottom-nav__menu-btn{all:unset;cursor:pointer;background-color:var(--bg-elevated);width:36px;height:36px;color:var(--text-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:transform .1s,background-color .15s;display:flex}.bottom-nav__menu-btn:hover{background-color:var(--bg-elevated-hovered)}.bottom-nav__menu-btn:active{transform:scale(.88)}.bottom-nav__menu-btn--open{background-color:var(--accent);color:#fff}.bottom-nav__menu-btn--open:hover{background-color:var(--accent);opacity:.9}.navbar{color:var(--text-primary);background-color:var(--bg-primary);align-items:center;width:100%;height:65px;margin:0 auto;padding:0 1rem;display:flex;position:relative}.navbar .nav-content{align-items:center;width:100%;max-width:1268px;margin:0 auto;display:flex}.navbar .logo{justify-content:center;align-items:center;display:flex}.navbar .logo p{text-transform:uppercase;letter-spacing:.5px;font-family:Anton,sans-serif;font-size:24px;font-weight:400}.navbar .links{justify-content:center;align-items:center;margin-left:auto;display:flex}@media (width<=850px){.navbar .links{display:none}}.navbar .links li{text-align:center;cursor:pointer;font-size:14px;font-weight:500}.navbar .links li a{color:var(--text-primary);text-transform:uppercase;padding:10px;text-decoration:none}.navbar .links li a:hover,.navbar .links li:hover{background-color:var(--bg-hovered);border-radius:6px}.navbar .links li .auth-btn{all:unset;cursor:pointer}.navbar .links li .auth-btn:hover{color:var(--accent)}.navbar .hamburger{display:none}.navbar .nav-settings{justify-content:center;align-items:center;gap:5px;display:flex}@media (width<=850px){.navbar .nav-settings{display:none}}.navbar .nav-settings .user-email{color:#888;font-size:13px}.navbar .nav-settings .notifications-wrapper{position:relative}.navbar .nav-settings .sign-in-btn{all:unset;cursor:pointer;color:var(--text-primary);text-transform:uppercase;border-radius:6px;padding:10px;font-size:14px;font-weight:500}.navbar .nav-settings .sign-in-btn:hover{background-color:var(--bg-hovered)}.navbar .nav-settings .theme-toggle,.navbar .nav-settings .bell{cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;height:40px;padding:10px;font-size:16px;line-height:1;transition:transform .1s;display:flex;position:relative}.navbar .nav-settings .theme-toggle:focus,.navbar .nav-settings .bell:focus{outline:none}.navbar .nav-settings .theme-toggle:hover,.navbar .nav-settings .bell:hover{background-color:var(--bg-hovered)}.navbar .nav-settings .theme-toggle:active,.navbar .nav-settings .bell:active{transform:scale(.88)}.navbar .nav-settings .bell__badge{background-color:var(--red);color:#fff;pointer-events:none;border-radius:7px;justify-content:center;align-items:center;min-width:14px;height:14px;padding:0 3px;font-size:9px;font-weight:700;display:flex;position:absolute;top:4px;right:4px}.navbar .nav-settings .user-menu-wrapper{position:relative}.navbar .nav-settings .user-menu-wrapper .user-icon-btn{cursor:pointer;color:var(--text-primary);background:0 0;border:none;border-radius:6px;align-items:center;padding:10px;font-size:18px;line-height:1;transition:transform .1s;display:flex}.navbar .nav-settings .user-menu-wrapper .user-icon-btn:focus{outline:none}.navbar .nav-settings .user-menu-wrapper .user-icon-btn:hover{background-color:var(--bg-hovered);color:var(--accent)}.navbar .nav-settings .user-menu-wrapper .user-icon-btn:active{transform:scale(.88)}.navbar .nav-settings .user-menu-wrapper .user-menu{background-color:var(--bg-secondary);border:1px solid var(--border-color);z-index:100;opacity:0;visibility:hidden;pointer-events:none;border-radius:8px;flex-direction:column;gap:.25rem;transition:opacity .15s,transform .15s,visibility 0s .15s;display:flex;position:absolute;top:calc(100% + 10px);right:0;transform:translateY(-6px)scale(.97)}.navbar .nav-settings .user-menu-wrapper .user-menu--open{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .15s,transform .15s;transform:translateY(0)scale(1)}.navbar .nav-settings .user-menu-wrapper .user-menu .user-menu-email{color:var(--text-secondary);border-bottom:1px solid var(--border-color);white-space:nowrap;text-overflow:ellipsis;margin-bottom:.25rem;padding:1rem;font-size:12px;overflow:hidden}.navbar .nav-settings .user-menu-wrapper .user-menu ul li button,.navbar .nav-settings .user-menu-wrapper .user-menu ul li a{cursor:pointer;color:var(--text-primary);text-align:left;background:0 0;border:none;border-radius:4px;align-items:center;gap:10px;width:100%;padding:1rem;font-size:13px;text-decoration:none;display:flex}.navbar .nav-settings .user-menu-wrapper .user-menu ul li button:hover,.navbar .nav-settings .user-menu-wrapper .user-menu ul li a:hover{background-color:var(--bg-hovered)}.footer{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);margin-top:2rem;padding:3rem 1rem 0}.footer .footer-inner{gap:4rem;width:100%;max-width:1268px;margin:0 auto;padding-bottom:2.5rem;display:flex}@media (width<=850px){.footer .footer-inner{flex-direction:column}}.footer .footer-brand{flex:1}.footer .footer-brand .footer-logo{text-transform:uppercase;letter-spacing:.5px;color:var(--text-primary);margin-bottom:.5rem;font-family:Anton,sans-serif;font-size:22px;font-weight:400}.footer .footer-brand .footer-tagline{color:var(--text-secondary);font-size:13px}.footer .footer-col{min-width:120px}.footer .footer-col .footer-col__title{text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:1rem;font-size:11px;font-weight:600}.footer .footer-col ul{flex-direction:column;gap:.6rem;display:flex}.footer .footer-col ul li a{color:var(--text-primary);opacity:.75;font-size:13px;text-decoration:none;transition:opacity .15s}.footer .footer-col ul li a:hover{opacity:1}.footer .footer-bottom{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;width:100%;max-width:1268px;margin:0 auto;padding:1.25rem 0;display:flex}@media (width<=850px){.footer .footer-bottom{flex-direction:column;gap:10px;padding-top:1rem}}.footer .footer-bottom p{color:var(--text-secondary);opacity:.6;font-size:12px}.footer .footer-bottom__links{align-items:center;gap:1.5rem;display:flex}.footer .footer-bottom__links a{color:var(--text-secondary);opacity:.6;font-size:12px;text-decoration:none;transition:opacity .15s}.footer .footer-bottom__links a:hover{opacity:1}.auth-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-modal{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;flex-direction:column;width:100%;max-width:380px;padding:2rem;display:flex}@media (width<=850px){.auth-modal{border-radius:0;justify-content:center;min-width:100vw;height:100vh}}.auth-modal .auth-close{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:4px;align-items:center;padding:.25rem;display:flex;position:absolute;top:1rem;right:1rem}.auth-modal .auth-close:hover{color:var(--text-primary)}.auth-modal .title{text-transform:uppercase;letter-spacing:.5px;justify-content:center;align-items:center;padding-bottom:1rem;font-family:Anton,sans-serif;font-size:24px;font-weight:400;display:flex}.auth-modal .auth-tabs{border-bottom:1px solid var(--border-color);display:flex}.auth-modal .auth-tabs button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;flex:1;padding:.5rem .5rem .75rem;font-size:14px;transition:all .2s ease-in-out}.auth-modal .auth-tabs button.active{color:var(--text-primary);border-bottom:2px solid var(--accent)}.auth-modal .auth-divider{align-items:center;gap:.75rem;margin:1rem 0 .75rem;display:flex}.auth-modal .auth-divider:before,.auth-modal .auth-divider:after{content:"";background-color:var(--border-color);flex:1;height:1px}.auth-modal .auth-divider span{color:var(--text-secondary);font-size:12px}.auth-modal .google-btn{border:1px solid var(--border-color);background-color:var(--bg-primary);width:100%;color:var(--text-primary);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;gap:.6rem;padding:.65rem;font-size:14px;transition:all .2s ease-in-out;display:flex}.auth-modal .google-btn:hover{border-color:var(--text-secondary)}.auth-modal .auth-switch{color:var(--text-secondary);text-align:center;justify-content:center;align-items:center;gap:.35rem;margin-top:1rem;font-size:13px;display:flex}.auth-modal .auth-switch button{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px}.auth-modal .auth-switch button:hover{text-decoration:underline}.auth-modal .auth-confirm{flex-direction:column;gap:.75rem;margin-top:.5rem;display:flex}.auth-modal .auth-confirm__heading{color:var(--text-primary);font-size:16px;font-weight:600}.auth-modal .auth-confirm__body{color:var(--text-secondary);font-size:13px;line-height:1.5}.auth-modal .auth-confirm__body strong{color:var(--text-primary)}.auth-modal .auth-hint-text{color:var(--text-secondary);margin-bottom:.25rem;font-size:13px}.auth-modal .forgot-link{color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;margin-top:-.25rem;padding:0;font-size:12px}.auth-modal .forgot-link:hover{color:var(--text-primary)}.auth-modal .password-field{align-items:center;display:flex;position:relative}.auth-modal .password-field input{width:100%;padding-right:2.5rem}.auth-modal .password-field .password-toggle{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;padding:0;display:flex;position:absolute;right:.75rem}.auth-modal .password-field .password-toggle:hover{color:var(--text-primary)}.auth-modal .password-hints{flex-direction:column;gap:.3rem;margin:0;padding:0;list-style:none;display:flex}.auth-modal .password-hints li{color:var(--text-secondary);align-items:center;gap:.4rem;font-size:12px;transition:color .15s;display:flex}.auth-modal .password-hints li.met{color:#22c55e}.auth-modal form{flex-direction:column;gap:.75rem;display:flex}.auth-modal form input{background-color:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-color);border-radius:6px;outline:none;padding:.65rem .75rem;font-size:14px;transition:all .2s ease-in-out}.auth-modal form input:focus{border-color:var(--accent)}.auth-modal form input::placeholder{color:var(--text-secondary)}.auth-modal form .auth-error{color:#ff4d4d;font-size:13px}.auth-modal form .auth-submit{background-color:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;margin-top:.25rem;padding:.65rem;font-size:14px;transition:all .2s ease-in-out}.auth-modal form .auth-submit:hover{opacity:.85}.auth-modal form .auth-submit:disabled{opacity:.5;cursor:not-allowed}.fretboard-wrapper{width:100%;padding:0 0 1rem;overflow-x:auto}.fretboard-wrapper:hover::-webkit-scrollbar-thumb{background:var(--text-muted);background-clip:padding-box}.fretboard-wrapper:hover::-webkit-scrollbar-thumb:hover{background:var(--text-secondary);background-clip:padding-box}.fretboard,.fretboardFlipped{background-color:var(--bg-fretboard);border-left:0;border-right:0;border-radius:4px;flex-direction:column;width:1856px;margin:0 auto;display:flex;box-shadow:0 3px 20px #0000003d}.fretboard .string,.fretboard .stringsFlipped,.fretboardFlipped .string,.fretboardFlipped .stringsFlipped{width:100%;height:100%;display:flex;position:relative}.fretboard .string:before,.fretboard .stringsFlipped:before,.fretboardFlipped .string:before,.fretboardFlipped .stringsFlipped:before{content:"";z-index:1;width:100%;height:1px;position:absolute;top:15px}.fretboard .string:first-of-type:before,.fretboard .stringsFlipped:first-of-type:before,.fretboardFlipped .string:first-of-type:before,.fretboardFlipped .stringsFlipped:first-of-type:before{background-color:var(--high-string-color);height:1.5px}.fretboard .string:nth-of-type(2):before,.fretboard .stringsFlipped:nth-of-type(2):before,.fretboardFlipped .string:nth-of-type(2):before,.fretboardFlipped .stringsFlipped:nth-of-type(2):before{background-color:var(--high-string-color);height:2.4px}.fretboard .string:nth-of-type(3):before,.fretboard .stringsFlipped:nth-of-type(3):before,.fretboardFlipped .string:nth-of-type(3):before,.fretboardFlipped .stringsFlipped:nth-of-type(3):before{background-color:var(--high-string-color);height:2.5px}.fretboard .string:nth-of-type(4):before,.fretboard .stringsFlipped:nth-of-type(4):before,.fretboardFlipped .string:nth-of-type(4):before,.fretboardFlipped .stringsFlipped:nth-of-type(4):before{background-color:var(--low-string-color);height:2.75px}.fretboard .string:nth-of-type(5):before,.fretboard .stringsFlipped:nth-of-type(5):before,.fretboardFlipped .string:nth-of-type(5):before,.fretboardFlipped .stringsFlipped:nth-of-type(5):before{background-color:var(--low-string-color);height:3px}.fretboard .string:nth-of-type(6):before,.fretboard .stringsFlipped:nth-of-type(6):before,.fretboardFlipped .string:nth-of-type(6):before,.fretboardFlipped .stringsFlipped:nth-of-type(6):before{background-color:var(--low-string-color);height:3.25px}.fretboard .string .fret,.fretboard .stringsFlipped .fret,.fretboardFlipped .string .fret,.fretboardFlipped .stringsFlipped .fret{z-index:1;border-right:3px solid var(--high-string-color);flex:1;justify-content:center;align-items:center;height:35px;display:flex;position:relative}.fretboard .string .fret:first-child,.fretboard .stringsFlipped .fret:first-child,.fretboardFlipped .string .fret:first-child,.fretboardFlipped .stringsFlipped .fret:first-child{background-color:var(--bg-primary);min-width:75px;max-width:75px}.fretboard .string .fret:first-child .ghost-note,.fretboard .stringsFlipped .fret:first-child .ghost-note,.fretboardFlipped .string .fret:first-child .ghost-note,.fretboardFlipped .stringsFlipped .fret:first-child .ghost-note{background-color:var(--bg-primary)!important}.fretboard .string .fret:last-child,.fretboard .stringsFlipped .fret:last-child,.fretboardFlipped .string .fret:last-child,.fretboardFlipped .stringsFlipped .fret:last-child{border-right:none}.fretboard .string .fret .NoteBackground,.fretboard .stringsFlipped .fret .NoteBackground,.fretboardFlipped .string .fret .NoteBackground,.fretboardFlipped .stringsFlipped .fret .NoteBackground{padding:0 5px}.fretboard .string .fret .note,.fretboard .stringsFlipped .fret .note,.fretboardFlipped .string .fret .note,.fretboardFlipped .stringsFlipped .fret .note{z-index:3;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:25px;height:25px;font-size:12px;font-weight:600;display:flex;position:relative;bottom:1px}.fretboard .string .fret .note:hover,.fretboard .stringsFlipped .fret .note:hover,.fretboardFlipped .string .fret .note:hover,.fretboardFlipped .stringsFlipped .fret .note:hover{transform:scale(1.1)}.fretboard .string .fret .note,.fretboard .stringsFlipped .fret .note,.fretboardFlipped .string .fret .note,.fretboardFlipped .stringsFlipped .fret .note{color:#fff;background-color:#2f89fc}.fretboard .string .fret .note:hover,.fretboard .stringsFlipped .fret .note:hover,.fretboardFlipped .string .fret .note:hover,.fretboardFlipped .stringsFlipped .fret .note:hover{z-index:999999}.fretboard .string .fret .rootNote,.fretboard .stringsFlipped .fret .rootNote,.fretboardFlipped .string .fret .rootNote,.fretboardFlipped .stringsFlipped .fret .rootNote{z-index:3;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:25px;height:25px;font-size:12px;font-weight:600;display:flex;position:relative;bottom:1px}.fretboard .string .fret .rootNote:hover,.fretboard .stringsFlipped .fret .rootNote:hover,.fretboardFlipped .string .fret .rootNote:hover,.fretboardFlipped .stringsFlipped .fret .rootNote:hover{transform:scale(1.1)}.fretboard .string .fret .triadNote,.fretboard .stringsFlipped .fret .triadNote,.fretboardFlipped .string .fret .triadNote,.fretboardFlipped .stringsFlipped .fret .triadNote{z-index:3;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:25px;height:25px;font-size:12px;font-weight:600;display:flex;position:relative;bottom:1px}.fretboard .string .fret .triadNote:hover,.fretboard .stringsFlipped .fret .triadNote:hover,.fretboardFlipped .string .fret .triadNote:hover,.fretboardFlipped .stringsFlipped .fret .triadNote:hover{transform:scale(1.1)}.fretboard .string .fret .triadNote,.fretboard .stringsFlipped .fret .triadNote,.fretboardFlipped .string .fret .triadNote,.fretboardFlipped .stringsFlipped .fret .triadNote{color:#fff;background-color:#e94e3d}.fretboard .string .fret .powerchordNote,.fretboard .stringsFlipped .fret .powerchordNote,.fretboardFlipped .string .fret .powerchordNote,.fretboardFlipped .stringsFlipped .fret .powerchordNote{z-index:3;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:25px;height:25px;font-size:12px;font-weight:600;display:flex;position:relative;bottom:1px}.fretboard .string .fret .powerchordNote:hover,.fretboard .stringsFlipped .fret .powerchordNote:hover,.fretboardFlipped .string .fret .powerchordNote:hover,.fretboardFlipped .stringsFlipped .fret .powerchordNote:hover{transform:scale(1.1)}.fretboard .string .fret .powerchordNote,.fretboard .stringsFlipped .fret .powerchordNote,.fretboardFlipped .string .fret .powerchordNote,.fretboardFlipped .stringsFlipped .fret .powerchordNote{color:#fff;background-color:#25862a}.fretboard .string .fret .activeNote,.fretboard .stringsFlipped .fret .activeNote,.fretboardFlipped .string .fret .activeNote,.fretboardFlipped .stringsFlipped .fret .activeNote{z-index:3;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:25px;height:25px;font-size:12px;font-weight:600;display:flex;position:relative;bottom:1px}.fretboard .string .fret .activeNote:hover,.fretboard .stringsFlipped .fret .activeNote:hover,.fretboardFlipped .string .fret .activeNote:hover,.fretboardFlipped .stringsFlipped .fret .activeNote:hover{transform:scale(1.1)}.fretboard .string .fret .activeNote,.fretboard .stringsFlipped .fret .activeNote,.fretboardFlipped .string .fret .activeNote,.fretboardFlipped .stringsFlipped .fret .activeNote{background-color:#2f89fc}.fretboard .string .fret .ghost-note,.fretboard .stringsFlipped .fret .ghost-note,.fretboardFlipped .string .fret .ghost-note,.fretboardFlipped .stringsFlipped .fret .ghost-note{z-index:3;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:25px;height:25px;font-size:12px;font-weight:600;display:flex;position:relative;bottom:1px}.fretboard .string .fret .ghost-note:hover,.fretboard .stringsFlipped .fret .ghost-note:hover,.fretboardFlipped .string .fret .ghost-note:hover,.fretboardFlipped .stringsFlipped .fret .ghost-note:hover{transform:scale(1.1)}.fretboard .string .fret .ghost-note,.fretboard .stringsFlipped .fret .ghost-note,.fretboardFlipped .string .fret .ghost-note,.fretboardFlipped .stringsFlipped .fret .ghost-note{color:var(--text-secondary);background:var(--bg-fretboard);border-radius:none!important}.fretboard .string .fret .ghost-note:hover,.fretboard .stringsFlipped .fret .ghost-note:hover,.fretboardFlipped .string .fret .ghost-note:hover,.fretboardFlipped .stringsFlipped .fret .ghost-note:hover{cursor:default;transform:none}.fretboardFlipped{flex-direction:column-reverse}.stringsFlipped,.fretNumbersFlipped{flex-direction:row-reverse}.fretNumbers{align-items:center;width:1856px;height:50px;margin:0 auto;display:flex;position:relative}.fretNumbers .fretNumber{color:var(--text-secondary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:5px;font-size:14px;font-weight:600;display:flex;position:relative}.fretNumbers .fretNumber:first-of-type{min-width:75px;max-width:75px;position:relative}.fretNumbers .fretNumber .doubleDot{gap:2px;display:flex}.fretNumbers .fretNumber .dot{width:5px;height:5px;color:var(--text-secondary);border-radius:50%}.chord-grid{cursor:pointer;background-color:var(--bg-fretboard);border:1px solid var(--low-string-color);border-radius:12px;flex-direction:column;padding:1rem;display:flex}.title{justify-content:space-between;align-items:center;margin-bottom:10px;font-size:14px;display:flex}.title .start-fret{font-size:12px}.fret-row{grid-template-columns:1fr repeat(6,32px);align-items:center;display:grid}.fret-number{max-width:24px;padding-right:10px;font-size:12px;position:relative;left:-4px}.cell{border:1px solid var(--high-string-color);justify-content:center;align-items:center;width:32px;height:32px;display:flex;position:relative}.dot,.open{z-index:2;background:var(--text-primary);border-radius:50%;width:20px;height:20px;position:relative;left:-16px}.chords{width:100%;color:var(--text-primary);flex-direction:column;gap:1.5rem;width:100%;max-width:1268px;margin:2rem auto 0;display:flex}@media (width<=968px){.chords{margin-top:2rem}}@media (width<=850px){.chords{margin-top:1.5rem}}@media (width<=1270px){.chord-row-scroll{overflow-x:auto}}.chord-row-scroll.scrollbar-visible::-webkit-scrollbar-thumb{background:var(--text-muted);background-clip:padding-box}.chord-row-scroll.scrollbar-visible::-webkit-scrollbar-thumb:hover{background:var(--text-secondary);background-clip:padding-box}.section-label{font-size:16px;font-weight:500}.chord-row{justify-content:space-between;gap:.5rem;width:100%;display:flex}.show-all-btn{all:unset}.chords-header{justify-content:space-between;align-items:center;display:flex}.quality-toggle{background:var(--bg-secondary);border-radius:8px;gap:2px;padding:3px;display:flex}.quality-toggle button{all:unset;cursor:pointer;color:var(--text-secondary);border-radius:6px;padding:4px 12px;font-size:12px;font-weight:500}.quality-toggle button:hover{color:var(--text-primary)}.quality-toggle button.active{background:var(--bg-primary);color:var(--text-primary)}.chords-hint{color:var(--text-muted);margin-top:-1rem;font-size:11px}.play-chord-btn{color:#fff;cursor:pointer;background:#1a1a1a;border:1px solid #333;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;transition:background .15s;display:flex}.play-chord-btn:hover{background:#252525}.key-control{background-color:var(--bg-secondary);border-radius:6px;align-items:center;gap:4px;width:100%;height:100%;min-height:50px;padding:8px;display:flex}.key-btn{all:unset;cursor:pointer;color:var(--text-primary);background-color:var(--bg-elevated);border-radius:5px;flex:1;justify-content:center;align-items:center;height:40px;font-size:13px;font-weight:500;display:flex}.key-btn:hover{background-color:var(--bg-elevated-hovered);color:var(--text-primary)}.key-btn--active{background-color:var(--accent)!important;color:#fff!important}.scale-control{flex:1;align-items:center;width:100%;height:100%;display:flex;position:relative}.scale-control__trigger{all:unset;background-color:var(--bg-secondary);width:100%;height:38px;color:var(--text-primary);cursor:pointer;box-sizing:border-box;border-radius:6px;justify-content:space-between;align-items:center;gap:8px;height:50px;padding:0 12px;font-size:13px;font-weight:500;display:flex}.scale-control__chevron{color:#888;flex-shrink:0;transition:transform .2s}.scale-control__chevron--open{transform:rotate(180deg)}.scale-control__menu{background-color:var(--bg-secondary);z-index:10;border-radius:6px;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden;box-shadow:0 4px 16px #0006}.scale-control__section{flex-direction:column;display:flex}.scale-control__section+.scale-control__section{border-top:1px solid var(--border-color)}.scale-control__section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);padding:12px 12px 8px;font-size:11px;font-weight:600;display:block}.scale-control__option{all:unset;width:100%;color:var(--text-primary);cursor:pointer;box-sizing:border-box;height:50px;padding:10px 12px;font-size:13px;display:block}.scale-control__option:hover{background-color:var(--bg-elevated-hovered)}.scale-control__option--active{color:#fff;background-color:var(--accent)!important}.overlay-controls{background-color:var(--bg-secondary);border-radius:6px;flex:2;gap:5px;width:100%;height:50px;min-height:50px;padding:5px 10px;display:flex}.overlay-controls button{all:unset;background-color:var(--bg-elevated);cursor:pointer;color:var(--text-primary);text-align:center;border-radius:6px;flex:1;justify-content:center;align-items:center;font-size:13px;font-weight:500;display:flex}.overlay-controls button:hover{background-color:var(--bg-elevated-hovered);color:var(--text-primary)}.overlay-controls button.activeBtn{background-color:var(--accent)!important;color:#fff!important}.overlay-controls button .label-short{display:none}@media (width<=1270px){.overlay-controls button .label-full{display:none}.overlay-controls button .label-short{display:inline}}.instrument-picker-overlay{z-index:200;background-color:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.instrument-picker{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;flex-direction:column;gap:1.25rem;width:100%;max-width:480px;max-height:80vh;padding:1.5rem;display:flex;overflow-y:auto}.instrument-picker__header{justify-content:space-between;align-items:center;display:flex}.instrument-picker__header h2{color:var(--text-primary);margin:0;font-size:16px;font-weight:600}.instrument-picker__close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.25rem .5rem;font-size:14px;transition:all .2s ease-in-out}.instrument-picker__close:hover{color:var(--text-primary);background-color:var(--bg-primary)}.instrument-picker__group{flex-direction:column;gap:.5rem;display:flex}.instrument-picker__group-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);font-size:11px;font-weight:600}.instrument-picker__list{flex-direction:column;gap:.35rem;display:flex}.instrument-card{border:1px solid var(--border-color);background-color:var(--bg-primary);border-radius:6px;justify-content:space-between;align-items:center;padding:.6rem .75rem;transition:all .2s ease-in-out;display:flex}.instrument-card--active{border-color:var(--accent);background-color:rgba(var(--accent-rgb,99, 102, 241), .06)}.instrument-card__label{color:var(--text-primary);font-size:13px}.instrument-card__actions{align-items:center;gap:.5rem;display:flex}.instrument-card__preview{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;align-items:center;gap:.35rem;padding:.3rem .65rem;font-size:12px;transition:all .2s ease-in-out;display:flex}.instrument-card__preview:hover{color:var(--text-primary);border-color:var(--text-secondary)}.instrument-card__preview--playing{color:var(--accent);border-color:var(--accent)}.instrument-card__select{background-color:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:4px;padding:.3rem .75rem;font-size:12px;transition:all .2s ease-in-out}.instrument-card__select:hover:not(:disabled){opacity:.85}.instrument-card__select--current{border:1px solid var(--accent);color:var(--accent);cursor:default;background-color:#0000}.instrument-card__select:disabled{cursor:default}.play-scale{background-color:var(--bg-secondary);color:#fff;scrollbar-width:none;border-radius:6px;align-items:center;gap:7px;width:100%;min-height:50px;padding:0 10px;display:flex;overflow-x:auto}.play-scale::-webkit-scrollbar{display:none}.play-scale__btn{all:unset;cursor:pointer;color:var(--text-secondary);background-color:var(--bg-elevated);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:transform .1s,background-color .1s;display:flex}.play-scale__btn:active{transform:scale(.88)}.play-scale__btn--active{color:var(--accent,#9b59b6)}.play-scale__btn--active-blue{color:#3b82f6}.play-scale__btn:hover{background-color:var(--bg-elevated-hovered);color:var(--text-primary)}.play-scale__btn--active:hover{color:var(--accent,#9b59b6)}.play-scale__btn--active-blue:hover{color:#3b82f6}.play-scale__bpm{color:var(--text-primary);flex:1;align-items:center;gap:8px;min-width:0;font-size:12px;font-weight:500;display:flex}.play-scale__bpm input[type=range]{appearance:none;background-color:var(--bg-elevated);cursor:pointer;border-radius:999px;flex:1;min-width:0;height:4px}.play-scale__bpm input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--accent);border-radius:50%;width:14px;height:14px}.play-scale__bpm span{white-space:nowrap;flex-shrink:0}@media (width<=1270px){.play-scale__bpm{display:none}}.play-scale__bpm-dropdown{display:none}@media (width<=1270px){.play-scale__bpm-dropdown{display:block}}.play-scale__bpm-btn{all:unset;cursor:pointer;color:var(--text-primary);background-color:var(--bg-elevated);white-space:nowrap;border-radius:6px;flex-shrink:0;align-items:center;height:32px;padding:0 10px;font-size:12px;font-weight:500;display:flex}.play-scale__bpm-btn:hover{background-color:var(--bg-elevated-hovered)}.play-scale__menu--bpm{min-width:200px}.play-scale__menu--bpm span{width:30px}.play-scale__settings-wrapper{flex-shrink:0;position:relative}.play-scale__settings-btn{all:unset;cursor:pointer;color:var(--text-secondary);background-color:var(--bg-elevated);border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:transform .1s,background-color .1s;display:flex}.play-scale__settings-btn:active{transform:scale(.88)}.play-scale__settings-btn:hover{color:var(--text-primary)}.play-scale__menu{background-color:var(--bg-secondary);border:1px solid var(--border-color);z-index:100;border-radius:8px;min-width:150px;padding:8px;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 4px 16px #0003}.play-scale__menu-instrument-row{all:unset;box-sizing:border-box;cursor:pointer;width:100%;color:var(--text-primary);border-bottom:1px solid var(--border-color);border-radius:5px;align-items:center;gap:6px;margin-bottom:4px;padding:7px 8px;display:flex}.play-scale__menu-instrument-row:hover{background-color:var(--bg-elevated)}.play-scale__menu-instrument-name{color:var(--text-primary);flex:1;font-size:13px}.play-scale__menu-instrument-change{color:var(--accent);font-size:11px}.play-scale__menu-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;padding:2px 8px 6px;font-size:11px;font-weight:600;display:block}.play-scale__menu-volume{align-items:center;gap:8px;padding:4px 8px 6px;display:flex}.play-scale__menu-volume input[type=range]{appearance:none;background-color:var(--bg-elevated);cursor:pointer;border-radius:999px;flex:1;height:4px}.play-scale__menu-volume input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--text-primary);border-radius:50%;width:12px;height:12px}.play-scale__menu-volume span{color:var(--text-secondary);text-align:right;width:32px;font-size:12px}.play-scale__menu ul{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.play-scale__menu ul li button{all:unset;width:100%;color:var(--text-primary);cursor:pointer;box-sizing:border-box;border-radius:5px;padding:7px 8px;font-size:13px;display:block}.play-scale__menu ul li button:hover{background-color:var(--bg-elevated)}.play-scale__menu ul li button.active{color:var(--accent,#9b59b6);background-color:var(--bg-elevated);font-weight:600}.controls{flex-direction:column;gap:2rem;width:100%;max-width:1268px;margin:2rem auto 1.5rem;display:flex}@media (width<=968px){.controls{gap:2rem;width:100%}}@media (width<=850px){.controls{display:none}}.controls .keys,.controls .flex{border:var(--border-color);background-color:var(--bg-primary);border-radius:6px;align-items:center;gap:1rem;display:flex;position:relative}@media (width<=968px){.controls .keys,.controls .flex{height:fit-content}}.controls .keys,.controls .group,.controls .group-2{flex-direction:column;align-items:flex-start;gap:10px}.controls .keys .label,.controls .group .label,.controls .group-2 .label{color:var(--text-secondary);font-size:13px;font-weight:500}.controls .group{flex:1;min-width:0}.controls .group-2{flex:2}.controls .flex{background-color:#0000;border:none;flex-wrap:wrap;align-items:flex-start;height:fit-content;padding:0;display:flex}.controls .flex .group,.controls .flex .group-2{gap:10px;display:flex}:root{--bg-primary:#fff;--bg-secondary:#f0f4f9;--bg-elevated:#fff;--bg-elevated-hovered:#e7e8eb;--bg-hovered:#f0f0f0;--bg-fretboard:#fcfbfb;--high-string-color:#bebfc7;--low-string-color:#a9aab3;--border-color:#e2e0e0;--text-primary:#18181b;--text-secondary:#555;--text-muted:#999;--accent:#06f;--red:#ff4d6a}[data-theme=dark]{--bg-primary:#0a0a0a;--bg-secondary:#171717;--bg-elevated:#252525;--bg-elevated-hovered:#2e2e2e;--bg-hovered:#1e1e1e;--bg-fretboard:#000;--high-string-color:#333232;--low-string-color:#3a3a3a;--border-color:#1f1f1f;--text-primary:#fff;--text-secondary:#888;--text-muted:#555;--accent:#06f;--red:#ff4d6a}*{box-sizing:border-box;margin:0;padding:0;font-family:Inter,sans-serif}html,body{overflow-x:hidden}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:padding-box padding-box;border:4px solid #0000;border-radius:999px}ul{list-style-type:none}.page{background-color:var(--bg-primary);width:100%;min-height:100vh;color:var(--text-primary);flex-direction:column;display:flex}.page .layout{flex-direction:column;flex:1;width:100%;display:flex}.page .page-content{flex-direction:column;width:100%;display:flex}@media (width<=1649px){.page .page-content{padding:0 1rem}}
