.driver-popover{background:var(--bg-secondary)!important;border:1px solid var(--accent-violet)!important;border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-xl),0 0 30px #8b5cf633!important;max-width:320px!important}.driver-popover-title{color:var(--text-primary)!important;font-family:var(--font-display,"Outfit",sans-serif)!important;font-size:1rem!important;font-weight:600!important}.driver-popover-description{color:var(--text-secondary)!important;font-size:.875rem!important;line-height:1.5!important}.driver-popover-progress-text{color:var(--text-muted)!important;font-size:.75rem!important}.driver-popover-footer{border-top:1px solid #ffffff0f!important}.driver-popover-next-btn{background:var(--accent-violet)!important;border-radius:var(--radius-sm)!important;color:#fff!important;border:none!important;padding:7px 16px!important;font-size:.825rem!important;font-weight:600!important}.driver-popover-next-btn:hover{opacity:.9!important}.driver-popover-prev-btn{border-radius:var(--radius-sm)!important;color:var(--text-secondary)!important;background:0 0!important;border:1px solid #a78bfa4d!important;padding:7px 16px!important;font-size:.825rem!important;font-weight:500!important}.driver-popover-close-btn{color:var(--text-muted)!important;font-size:1rem!important}.driver-popover-close-btn:hover{color:var(--text-primary)!important}.driver-overlay{opacity:.65!important}.driver-popover-arrow-side-left.driver-popover-arrow{border-left-color:var(--accent-violet)!important}.driver-popover-arrow-side-right.driver-popover-arrow{border-right-color:var(--accent-violet)!important}.driver-popover-arrow-side-top.driver-popover-arrow{border-top-color:var(--accent-violet)!important}.driver-popover-arrow-side-bottom.driver-popover-arrow{border-bottom-color:var(--accent-violet)!important}:root{--bg-primary:#0a0a1a;--bg-secondary:#12122a;--bg-tertiary:#1a1a3a;--bg-card:#190f3c80;--bg-card-hover:#231950cc;--bg-glass:#140f3266;--bg-input:#191437b3;--text-primary:#fff;--text-secondary:#ffffffd9;--text-muted:#fff9;--text-heading:#fff;--accent-violet:#a78bfa;--accent-indigo:#6366f1;--accent-pink:#f472b6;--accent-emerald:#34d399;--accent-amber:#fbbf24;--accent-cyan:#22d3ee;--accent-rose:#fb7185;--gradient-primary:linear-gradient(135deg,#6366f1,#a78bfa);--gradient-warm:linear-gradient(135deg,#f472b6,#a78bfa);--gradient-cool:linear-gradient(135deg,#22d3ee,#6366f1);--gradient-surface:linear-gradient(180deg,#190f3ccc,#0a0a1ae6);--gradient-hero:linear-gradient(135deg,#0a0a1a 0%,#1a0a3a 50%,#0a0a2a 100%);--border-subtle:#6366f126;--border-active:#a78bfa80;--border-glow:#a78bfae6;--glow-violet:0 0 35px #a78bfa66;--glow-indigo:0 0 35px #6366f166;--glow-pink:0 0 35px #f472b666;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-xl:0 16px 64px #0009;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--space-4xl:96px;--radius-sm:6px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-display:"Outfit","Inter",sans-serif;--transition-fast:.15s cubic-bezier(.4,0,.2,1);--transition-normal:.25s cubic-bezier(.4,0,.2,1);--transition-slow:.4s cubic-bezier(.4,0,.2,1);--max-width:1200px;--nav-height:60px;--sidebar-width:280px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:18px}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-size:1.0625rem;line-height:1.6;overflow-x:hidden}::selection{background-color:var(--accent-pink);color:#000}a{color:var(--accent-violet);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-pink)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--text-heading);font-weight:700;line-height:1.2}button{font-family:var(--font-sans);cursor:pointer;border:none;outline:none}.container{width:100%;max-width:var(--max-width);padding:0 var(--space-lg);margin:0 auto}.glass{background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-subtle)}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-normal)}.card:hover{background:var(--bg-card-hover);border-color:var(--border-active);box-shadow:var(--glow-violet);transform:translateY(-2px)}.badge{padding:var(--space-xs)var(--space-md);border-radius:var(--radius-full);letter-spacing:.05em;text-transform:uppercase;align-items:center;font-size:.75rem;font-weight:600;display:inline-flex}.badge-violet{color:var(--accent-violet);background:#a78bfa26;border:1px solid #a78bfa4d}.badge-pink{color:var(--accent-pink);background:#f472b626;border:1px solid #f472b64d}.badge-emerald{color:var(--accent-emerald);background:#34d39926;border:1px solid #34d3994d}.btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm)var(--space-lg);border-radius:var(--radius-full);transition:all var(--transition-normal);font-size:.875rem;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 0 35px #6366f166}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 0 35px #6366f1b3}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-subtle);box-shadow:0 0 35px #a78bfa33}.btn-secondary:hover{border-color:var(--border-active);box-shadow:var(--glow-violet)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{color:var(--text-primary);background:#a78bfa1a}.note-c{--note-color:#fb7185}.note-cs,.note-db{--note-color:#f472b6}.note-d{--note-color:#e879f9}.note-ds,.note-eb{--note-color:#c084fc}.note-e{--note-color:#a78bfa}.note-f{--note-color:#818cf8}.note-fs,.note-gb{--note-color:#6366f1}.note-g{--note-color:#22d3ee}.note-gs,.note-ab{--note-color:#34d399}.note-a{--note-color:#fbbf24}.note-as,.note-bb{--note-color:#f97316}.note-b{--note-color:#ef4444}.nav{height:var(--nav-height);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle);z-index:1000;padding:0 var(--space-lg);background:#0a0a1ad9;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.nav-brand{font-family:var(--font-display);color:var(--text-heading);align-items:center;gap:5px;font-size:1.25rem;font-weight:800;display:flex}.nav-brand-icon{border-radius:var(--radius-md);background:var(--gradient-primary);justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;display:flex}.nav-content{justify-content:space-between;align-items:center;width:100%;max-width:100%;margin:0 auto;display:flex;position:relative}.nav-search{flex:0 320px;position:relative}.nav-search-input{width:100%;padding:var(--space-sm)var(--space-md);background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-full);color:var(--text-primary);font-size:.875rem;font-family:var(--font-sans);transition:all var(--transition-normal);padding-left:36px}.nav-search-input:focus{border-color:var(--border-active);box-shadow:var(--glow-violet);outline:none}.nav-search-input::placeholder{color:var(--text-muted)}.nav-search-icon{color:var(--text-muted);font-size:.875rem;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.nav-search-shortcut{color:var(--text-muted);background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:4px;padding:2px 6px;font-size:.7rem;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.nav-actions{align-items:center;gap:var(--space-md);display:none}.nav-menu-btn{border-radius:var(--radius-md);width:40px;height:40px;color:var(--text-secondary);transition:all var(--transition-fast);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;font-size:1.25rem;display:flex}.nav-menu-btn:hover{color:var(--text-primary);border-color:var(--border-subtle);background:#a78bfa1a}.nav-center-pill{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-full);box-shadow:var(--shadow-sm),0 0 20px #a78bfa40;align-items:center;gap:6px;padding:6px 8px;display:flex;position:absolute;left:50%;transform:translate(-50%)}.nav-section-item{position:relative}.nav-pill-link{border-radius:var(--radius-full);color:var(--text-primary);cursor:pointer;transition:all var(--transition-normal);font-size:.95rem;font-weight:600;font-family:var(--font-sans);white-space:nowrap;letter-spacing:.02em;background:0 0;border:1px solid #0000;align-items:center;gap:6px;padding:8px 20px;text-decoration:none;display:inline-flex}.nav-pill-link:hover{color:#fff;background:#a78bfa33;border-color:#a78bfa66;transform:translateY(-1px);box-shadow:0 0 15px #a78bfa59}.nav-pill-link.active{color:#fff;background:var(--gradient-primary);box-shadow:var(--glow-indigo);text-shadow:0 1px 2px #0000004d;border-color:#0000}.nav-chevron{opacity:.6;transition:transform var(--transition-normal);margin-left:2px}.nav-pill-link:hover .nav-chevron{opacity:1}.nav-pill-link.active .nav-chevron{opacity:1;transform:rotate(180deg)}.nav-right-actions{align-items:center;gap:var(--space-sm);display:flex}.nav-text-link{color:var(--text-muted);border-radius:var(--radius-full);transition:all var(--transition-fast);padding:7px 12px;font-size:.85rem;font-weight:500;text-decoration:none}.nav-text-link:hover,.nav-text-link.active{color:var(--text-primary);background:#ffffff0f}.nav-upgrade-btn{border-radius:var(--radius-full);color:var(--accent-amber);transition:all var(--transition-fast);background:linear-gradient(135deg,#fbbf241f,#fbbf240f);border:1px solid #fbbf2440;align-items:center;gap:5px;padding:7px 16px;font-size:.85rem;font-weight:600;text-decoration:none;display:inline-flex}.nav-upgrade-btn:hover{color:var(--accent-amber);background:linear-gradient(135deg,#fbbf2440,#fbbf2426);border-color:#fbbf248c;transform:translateY(-1px);box-shadow:0 4px 24px #fbbf2440}.nav-login-btn{border-radius:var(--radius-full);color:#fff;background:var(--gradient-primary);transition:all var(--transition-fast);align-items:center;padding:7px 18px;font-size:.85rem;font-weight:600;text-decoration:none;display:inline-flex;box-shadow:0 0 35px #6366f166}.nav-login-btn:hover{color:#fff;transform:translateY(-1px);box-shadow:0 4px 28px #6366f1a6}.nav-dropdown{border-radius:var(--radius-lg);z-index:1100;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#120c2af2;border:1px solid #ffffff1a;animation:.18s ease-out dropdownIn;position:absolute;top:calc(100% + 12px);left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 16px 48px #00000080,0 0 0 1px #ffffff0d}.nav-dropdown-header{border-bottom:1px solid #ffffff0f;padding:12px 16px 8px}.nav-dropdown-title{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-size:.7rem;font-weight:700}.nav-dropdown-grid{padding:8px}.nav-grid-4{grid-template-columns:repeat(4,1fr);gap:2px;min-width:540px;display:grid}.nav-grid-3{grid-template-columns:repeat(3,1fr);gap:2px;min-width:420px;display:grid}@keyframes dropdownIn{0%{opacity:0;transform:translate(-50%)translateY(-8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.nav-dropdown-item{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);align-items:center;gap:10px;padding:10px 12px;text-decoration:none;display:flex}.nav-dropdown-item:hover{color:var(--text-primary);background:#a78bfa1a}.nav-dropdown-icon{border-radius:var(--radius-sm);background:#ffffff0a;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.2rem;display:flex}.nav-dropdown-text{flex-direction:column;gap:1px;min-width:0;display:flex}.nav-dropdown-label{color:var(--text-primary);white-space:nowrap;font-size:.82rem;font-weight:600;line-height:1.3}.nav-dropdown-desc{color:var(--text-muted);white-space:nowrap;font-size:.7rem;line-height:1.3}.nav-dropdown-item:hover .nav-dropdown-label{color:#fff}.sidebar-group{margin-bottom:var(--space-lg)}.sidebar-group-title{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:var(--space-sm);padding-left:var(--space-md);font-size:.7rem;font-weight:700}.sidebar-footer-links{padding-top:var(--space-lg);border-top:1px solid var(--border-subtle);gap:var(--space-xs);flex-direction:column;margin-top:auto;display:flex}.sidebar-login-btn{padding:var(--space-sm)var(--space-md);border-radius:var(--radius-full);background:var(--gradient-primary);color:#fff;box-shadow:var(--glow-indigo);transition:all var(--transition-normal);margin-top:var(--space-sm);justify-content:center;align-items:center;font-size:.9rem;font-weight:600;text-decoration:none;display:flex}.sidebar-login-btn:hover{transform:translateY(-1px);box-shadow:0 0 28px #6366f1a6}.home-section{margin-bottom:var(--space-3xl)}.home-section-header{margin-bottom:var(--space-lg)}.home-section-title{font-family:var(--font-display);color:var(--text-heading);margin-bottom:var(--space-xs);font-size:1.5rem}.home-section-desc{color:var(--text-muted);font-size:.9rem}.learn-card{max-width:400px}.tool-grid-4col{grid-template-columns:repeat(4,1fr)!important}.tool-grid-3col{grid-template-columns:repeat(3,1fr)!important}@media (max-width:900px){.nav-center-pill,.nav-right-actions{display:none}.nav-actions{display:flex}.tool-grid-4col,.tool-grid-3col{grid-template-columns:repeat(2,1fr)!important}}@media (max-width:540px){.tool-grid-4col,.tool-grid-3col{grid-template-columns:1fr!important}}.pricing-page{padding:0 var(--space-lg)var(--space-2xl)}.pricing-container{max-width:920px;margin:0 auto}.pricing-header{text-align:center;margin-bottom:var(--space-2xl)}.pricing-title{font-family:var(--font-display);color:var(--text-heading);margin-bottom:var(--space-xs);font-size:2.4rem;font-weight:800}.pricing-subtitle{color:var(--text-muted);margin-bottom:var(--space-lg);font-size:1rem}.billing-toggle{border-radius:var(--radius-full);background:#ffffff0a;border:1px solid #ffffff14;align-items:center;gap:2px;padding:3px;display:inline-flex}.billing-tab{border-radius:var(--radius-full);cursor:pointer;color:var(--text-muted);font-size:.88rem;font-weight:500;font-family:var(--font-sans);transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:6px;padding:8px 22px;display:inline-flex}.billing-tab:hover{color:var(--text-primary)}.billing-tab.active{color:#fff;background:#a78bfa33;font-weight:600}.billing-badge{border-radius:var(--radius-full);color:var(--accent-emerald);text-transform:uppercase;letter-spacing:.03em;background:#34d39926;padding:2px 8px;font-size:.65rem;font-weight:700}.pricing-grid{gap:var(--space-lg);grid-template-columns:repeat(2,1fr);align-items:stretch;display:grid}.pricing-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);flex-direction:column;transition:all .3s;display:flex;position:relative;overflow:hidden}.pricing-card:hover{border-color:#fff3;box-shadow:0 0 35px #a78bfa99}.pricing-card-pro{border:2px solid var(--accent-violet);background:linear-gradient(135deg,#6366f11a,#a78bfa0d)}.pricing-card-pro:hover{border-color:var(--accent-violet);box-shadow:0 0 35px #a78bfa99}.pro-badge{background:var(--gradient-primary);color:#fff;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.06em;padding:4px 14px;font-size:.68rem;font-weight:700;position:absolute;top:16px;right:16px}.pricing-card-top{padding:32px 28px 20px}.pricing-card-body{flex:1;padding:0 28px}.pricing-card-bottom{margin-top:auto;padding:20px 28px 32px}.plan-name{color:var(--text-heading);margin-bottom:12px;font-size:1.25rem;font-weight:700}.plan-price-row{align-items:baseline;gap:4px;margin-bottom:8px;display:flex}.plan-price{color:var(--text-heading);font-size:2.8rem;font-weight:800;font-family:var(--font-display);line-height:1}.plan-price-gradient{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.plan-price-sub{color:var(--text-muted);font-size:.95rem}.plan-savings{color:var(--accent-emerald);margin-bottom:4px;font-size:.8rem;font-weight:600}.plan-tagline{color:var(--text-muted);margin-top:8px;font-size:.85rem;line-height:1.5}.feature-list{flex-direction:column;gap:11px;padding:0;list-style:none;display:flex}.feature-item{color:var(--text-primary);align-items:flex-start;gap:10px;font-size:.88rem;line-height:1.45;display:flex}.feature-item.disabled{color:var(--text-muted);opacity:.45}.feature-check{color:var(--accent-emerald);flex-shrink:0;font-size:.95rem;line-height:1.45}.feature-cross{flex-shrink:0;font-size:.95rem;line-height:1.45}.pricing-btn{border-radius:var(--radius-lg);cursor:pointer;width:100%;transition:all var(--transition-normal);font-size:.95rem;font-weight:600;font-family:var(--font-sans);border:none;justify-content:center;align-items:center;padding:14px;text-decoration:none;display:flex}.pricing-btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--glow-indigo)}.pricing-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 32px #6366f1a6}.pricing-btn-secondary{color:var(--text-primary);border:1px solid var(--border-subtle);background:#ffffff0f}.pricing-btn-secondary:hover{background:#ffffff1a;border-color:#ffffff26;transform:translateY(-2px)}.pricing-footer-note{text-align:center;margin-top:var(--space-2xl);color:var(--text-muted);font-size:.85rem}.pricing-footer-note p+p{margin-top:6px}.pricing-footer-note a{color:var(--accent-violet);text-decoration:none}.pricing-footer-note a:hover{text-decoration:underline}@media (max-width:700px){.pricing-grid{grid-template-columns:1fr}.pricing-title{font-size:1.8rem}}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1100;opacity:0;visibility:hidden;transition:all var(--transition-normal);background:#0009;position:fixed;inset:0}.sidebar-overlay.open{opacity:1;visibility:visible}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-left:1px solid var(--border-subtle);z-index:1200;transition:transform var(--transition-normal);padding:var(--space-lg);position:fixed;top:0;bottom:0;right:0;overflow-y:auto;transform:translate(100%)}.sidebar.open{transform:translate(0)}.sidebar-close{border-radius:var(--radius-md);background:var(--bg-card);width:36px;height:36px;color:var(--text-secondary);margin-bottom:var(--space-lg);border:1px solid var(--border-subtle);transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:1rem;display:flex}.sidebar-close:hover{color:var(--text-primary);border-color:var(--border-active)}.sidebar-nav{gap:var(--space-xs);flex-direction:column;list-style:none;display:flex}.sidebar-link{align-items:center;gap:var(--space-sm);padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);font-size:.9rem;font-weight:500;display:flex}.sidebar-link:hover{color:var(--text-primary);background:#a78bfa1a}.sidebar-link.active{color:var(--accent-violet);background:#a78bfa26}.main{padding-top:calc(var(--nav-height) + var(--space-xl));min-height:100vh}.footer{margin-top:var(--space-4xl);padding:var(--space-2xl)var(--space-lg);border-top:1px solid var(--border-subtle);text-align:center}.footer-content{max-width:var(--max-width);margin:0 auto}.footer-brand{font-family:var(--font-display);color:var(--text-heading);margin-bottom:var(--space-sm);justify-content:center;align-items:center;gap:5px;font-size:1.125rem;font-weight:700;display:flex}.footer-logo{object-fit:contain}.footer-text{color:var(--text-muted);font-size:.8rem}.footer-links{justify-content:center;gap:var(--space-lg);margin-top:var(--space-md);flex-wrap:wrap;display:flex}.footer-link{color:var(--text-secondary);transition:color var(--transition-fast);font-size:.8rem}.footer-link:hover{color:var(--accent-violet)}.footer-actions{justify-content:center;align-items:center;gap:var(--space-sm);margin-top:var(--space-md);flex-wrap:wrap;display:flex}.footer-action-btn{border:1px solid var(--border-subtle);cursor:pointer;border-radius:100px;align-items:center;gap:6px;padding:7px 16px;font-size:.8rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.feedback-btn{color:var(--text-secondary);background:0 0}.feedback-btn:hover{color:var(--accent-violet);border-color:var(--accent-violet);background:#8b5cf614}.coffee-btn{color:#92400e;background:#fbbf241f;border-color:#fbbf244d}.coffee-btn:hover{color:#78350f;background:#fbbf2438;border-color:#fbbf2499}.page-header{text-align:center;padding:calc(var(--space-xl)*.2)0 calc(var(--space-xl)*1.2)}.page-title{background:var(--gradient-primary);-webkit-text-fill-color:transparent;margin-bottom:var(--space-sm);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:800}.page-subtitle{color:var(--text-secondary);max-width:600px;margin:0 auto var(--space-sm);font-size:1rem}.note-selector{gap:var(--space-xs);flex-wrap:wrap;justify-content:center;display:flex}.note-btn{border-radius:var(--radius-md);background:var(--bg-card);width:48px;height:48px;color:var(--text-primary);border:1px solid var(--border-subtle);transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:.9rem;font-weight:600;display:flex}.note-btn:hover{border-color:var(--border-active);box-shadow:var(--glow-violet);transform:translateY(-1px)}.note-btn.active{background:var(--gradient-primary);color:#fff;box-shadow:var(--glow-indigo);border-color:#0000}.toggle-group{background:var(--bg-card);border-radius:var(--radius-full);border:1px solid var(--border-subtle);padding:3px;display:inline-flex}.toggle-option{padding:var(--space-xs)var(--space-md);border-radius:var(--radius-full);color:var(--text-secondary);transition:all var(--transition-fast);background:0 0;font-size:.85rem;font-weight:500}.toggle-option:hover{color:var(--text-primary)}.toggle-option.active{background:var(--gradient-primary);color:#fff;box-shadow:var(--glow-indigo)}.tool-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-auto-rows:1fr;max-width:1100px;margin:0 auto;display:grid}.tool-card{text-align:center;padding:var(--space-lg)var(--space-md);border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-subtle);transition:all var(--transition-normal);cursor:pointer;flex-direction:column;align-items:center;text-decoration:none;display:flex}.tool-card:hover{background:var(--bg-card-hover);border-color:var(--border-active);box-shadow:var(--glow-violet);transform:translateY(-4px)scale(1.02)}.tool-card-icon{background:var(--gradient-primary);width:56px;height:56px;margin-bottom:var(--space-sm);box-shadow:var(--glow-indigo);transition:box-shadow var(--transition-normal);border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;display:flex}.tool-card:hover .tool-card-icon{box-shadow:0 0 30px #6366f180}.tool-card-name{color:var(--text-primary);font-size:.8rem;font-weight:600;line-height:1.3}.tools-page{max-width:800px}.tools-section{margin-bottom:var(--space-2xl)}.tools-section-title{font-family:var(--font-display);color:var(--text-heading);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-subtle);font-size:1.3rem}.tools-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.tools-link{padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.9rem;transition:all .15s;display:block}.tools-link:hover{color:var(--accent-violet);background:#a78bfa14}.nav-brand-logo{border-radius:var(--radius-sm)}.piano-controls{justify-content:center;gap:var(--space-xl);margin-bottom:var(--space-xl);flex-wrap:wrap;display:flex}.fx-panel{margin-bottom:var(--space-xl);border-radius:var(--radius-xl);background:var(--bg-card);border:1px solid var(--border-subtle);transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.fx-panel-header{padding:var(--space-md)var(--space-lg);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;transition:background .2s;display:flex}.fx-panel-header:hover{background:#8b5cf60a}.fx-panel-title{align-items:center;gap:var(--space-sm);text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);font-size:.8rem;font-weight:600;display:flex}.fx-panel-title svg{transition:transform .3s}.fx-panel-title svg.open{transform:rotate(180deg)}.fx-panel-badge{color:var(--accent-violet);background:#8b5cf626;border-radius:100px;padding:2px 8px;font-size:.65rem;font-weight:700}.fx-panel-body{padding:0 var(--space-lg)var(--space-lg)}.fx-panel-body.collapsed{display:none}.fx-volume-strip{align-items:center;gap:var(--space-md);padding:var(--space-md)var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-lg);background:#8b5cf60a;display:flex}.fx-volume-icon{flex-shrink:0;font-size:1.4rem}.fx-volume-slider{flex:1}.fx-volume-value{color:var(--accent-violet);text-align:right;font-variant-numeric:tabular-nums;min-width:48px;font-size:.8rem;font-weight:600}.fx-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.fx-card{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);padding:var(--space-md);background:var(--surface-2);transition:all .25s;position:relative;overflow:hidden}.fx-card:before{content:"";opacity:0;background:linear-gradient(135deg,#8b5cf60f,#0000);transition:opacity .3s;position:absolute;inset:0}.fx-card:hover:before,.fx-card.active:before{opacity:1}.fx-card.active{border-color:#8b5cf666;box-shadow:0 0 20px #8b5cf614}.fx-card-header{margin-bottom:var(--space-sm);z-index:1;justify-content:space-between;align-items:center;display:flex;position:relative}.fx-card-label{color:var(--text-primary);align-items:center;gap:6px;font-size:.8rem;font-weight:600;display:flex}.fx-card-label .fx-icon{font-size:1rem}.fx-card-value{color:var(--accent-violet);font-variant-numeric:tabular-nums;background:#8b5cf61a;border-radius:100px;padding:2px 8px;font-size:.7rem;font-weight:600}.fx-card-slider{z-index:1;position:relative}.fx-range{appearance:none;background:var(--border);cursor:pointer;border-radius:3px;outline:none;width:100%;height:6px;position:relative}.fx-range::-webkit-slider-thumb{appearance:none;background:var(--accent-violet);cursor:pointer;border-radius:50%;width:16px;height:16px;transition:box-shadow .2s,transform .15s;box-shadow:0 0 8px #8b5cf666}.fx-range::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 0 14px #8b5cf699}.fx-range::-moz-range-thumb{background:var(--accent-violet);cursor:pointer;border:none;border-radius:50%;width:16px;height:16px;box-shadow:0 0 8px #8b5cf666}.fx-eq-bands{gap:var(--space-sm);z-index:1;display:flex;position:relative}.fx-eq-band{flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.fx-eq-band label{color:var(--text-muted);text-transform:uppercase;font-size:.65rem;font-weight:600}.fx-eq-band input[type=range]{appearance:none;writing-mode:vertical-lr;background:var(--border);cursor:pointer;direction:rtl;border-radius:3px;outline:none;width:6px;height:60px}.fx-eq-band input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--accent-violet);cursor:pointer;border-radius:50%;width:14px;height:14px;box-shadow:0 0 6px #8b5cf666}.fx-eq-band input[type=range]::-moz-range-thumb{background:var(--accent-violet);cursor:pointer;border:none;border-radius:50%;width:14px;height:14px}.fx-eq-value{font-variant-numeric:tabular-nums;color:var(--text-muted);font-size:.6rem}.fx-reset-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:100px;padding:4px 12px;font-size:.7rem;transition:all .2s}.fx-reset-btn:hover{border-color:var(--accent-violet);color:var(--accent-violet)}.rotary-knob{cursor:grab;-webkit-user-select:none;user-select:none;border-radius:var(--radius-lg);border:1px solid #0000;flex-direction:column;align-items:center;gap:4px;min-width:80px;padding:8px 6px;transition:all .25s;display:flex;position:relative}.rotary-knob:hover{border-color:var(--border-subtle);background:#8b5cf60a}.rotary-knob.active{border-color:#8b5cf640}.rotary-knob.dragging{cursor:grabbing;background:#8b5cf60f;border-color:#8b5cf680}.rotary-knob.midi-mapped{border-color:#22c55e66}.rotary-knob.midi-learning{border-color:#fbbf2499;animation:1s ease-in-out infinite midi-learn-pulse}@keyframes midi-learn-pulse{0%,to{box-shadow:0 0 #fbbf244d}50%{box-shadow:0 0 16px 4px #fbbf2433}}.rotary-knob-svg-wrap{justify-content:center;align-items:center;width:64px;height:64px;display:flex;position:relative}.rotary-knob-svg{position:absolute;inset:0}.rotary-knob-value{z-index:1;color:var(--text-primary);font-variant-numeric:tabular-nums;pointer-events:none;font-size:.65rem;font-weight:700;position:relative}.rotary-knob-icon{font-size:.9rem;line-height:1}.rotary-knob-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;text-align:center;font-size:.6rem;font-weight:600;line-height:1.2}.rotary-knob-midi-dot{background:#22c55e;border-radius:50%;width:6px;height:6px;position:absolute;top:2px;right:2px;box-shadow:0 0 6px #22c55e}.rotary-knob-learn-pulse{background:#fbbf24;border-radius:50%;width:8px;height:8px;animation:.6s ease-in-out infinite alternate midi-dot-blink;position:absolute;top:2px;right:2px}@keyframes midi-dot-blink{0%{opacity:.4;transform:scale(.8)}to{opacity:1;transform:scale(1.2)}}.fx-knobs-row{padding:var(--space-sm)0;flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:4px;display:flex}.fx-pan-strip{align-items:center;gap:var(--space-md);padding:var(--space-sm)var(--space-lg);border-radius:var(--radius-lg);margin-top:var(--space-sm);margin-bottom:var(--space-sm);background:#8b5cf60a;display:flex}.fx-pan-strip .fx-pan-label{color:var(--text-secondary);align-items:center;gap:4px;min-width:36px;font-size:.75rem;font-weight:600;display:flex}.fx-pan-strip .fx-pan-slider{flex:1}.fx-pan-strip .fx-pan-value{color:var(--accent-violet);text-align:right;font-variant-numeric:tabular-nums;min-width:48px;font-size:.75rem;font-weight:600}.eq8-section{border-radius:var(--radius-xl);padding:var(--space-md)var(--space-lg);border:1px solid var(--border-subtle);margin-top:var(--space-sm);background:#8b5cf608}.eq8-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.eq8-title{color:var(--text-primary);align-items:center;gap:6px;font-size:.8rem;font-weight:600;display:flex}.eq8-reset-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:100px;padding:2px 10px;font-size:.65rem;transition:all .2s}.eq8-reset-btn:hover{border-color:var(--accent-violet);color:var(--accent-violet)}.eq8-bands{gap:var(--space-sm);justify-content:center;align-items:flex-end;display:flex}.eq8-band{flex-direction:column;align-items:center;gap:4px;min-width:40px;display:flex}.eq8-band-label{color:var(--text-muted);text-transform:uppercase;font-size:.55rem;font-weight:600}.eq8-band-freq{color:var(--text-muted);opacity:.7;font-size:.5rem}.eq8-band-value{color:var(--accent-violet);font-variant-numeric:tabular-nums;min-height:14px;font-size:.55rem;font-weight:600}.eq8-band input[type=range]{appearance:none;writing-mode:vertical-lr;background:var(--border);cursor:pointer;direction:rtl;border-radius:3px;outline:none;width:6px;height:80px}.eq8-band input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--accent-violet);cursor:pointer;border-radius:50%;width:14px;height:14px;transition:box-shadow .2s,transform .15s;box-shadow:0 0 6px #8b5cf666}.eq8-band input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 0 10px #8b5cf699}.eq8-band input[type=range]::-moz-range-thumb{background:var(--accent-violet);cursor:pointer;border:none;border-radius:50%;width:14px;height:14px}.loop-section{border-radius:var(--radius-xl);padding:var(--space-md)var(--space-lg);border:1px solid var(--border-subtle);margin-top:var(--space-md);background:#8b5cf608}.loop-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.loop-title{color:var(--text-primary);align-items:center;gap:6px;font-size:.8rem;font-weight:600;display:flex}.loop-global-controls{align-items:center;gap:6px;display:flex}.loop-config{align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);padding:var(--space-sm)var(--space-md);border-radius:var(--radius-lg);background:#00000026;flex-wrap:wrap;display:flex}.loop-config-label{color:var(--text-muted);align-items:center;gap:4px;font-size:.7rem;font-weight:600;display:flex}.loop-config select,.loop-config input{background:var(--surface-2);color:var(--text-primary);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:4px 8px;font-size:.75rem}.loop-bpm-input{text-align:center;width:60px}.loop-rows{flex-direction:column;gap:6px;display:flex}.loop-row{align-items:center;gap:var(--space-sm);background:var(--surface-2);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);padding:8px 12px;transition:all .2s;display:flex}.loop-row:hover{border-color:var(--border)}.loop-row.recording{border-color:#ef4444;box-shadow:0 0 12px #ef444426}.loop-row.playing{border-color:#8b5cf680}.loop-row.muted{opacity:.4}.loop-row-name{color:var(--text-primary);min-width:80px;font-size:.75rem;font-weight:600}.loop-row-duration{color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:40px;font-size:.65rem}.loop-row-controls{gap:4px;margin-left:auto;display:flex}.loop-btn{border:1px solid var(--border);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;font-size:.75rem;transition:all .2s;display:flex}.loop-btn:hover{border-color:var(--accent-violet);color:var(--accent-violet);background:#8b5cf60f}.loop-btn.active{border-color:var(--accent-violet);color:var(--accent-violet);background:#8b5cf626}.loop-btn.record{color:#ef4444;border-color:#ef44444d}.loop-btn.record:hover{background:#ef44441a;border-color:#ef4444}.loop-btn.record.active{color:#fff;background:#ef4444;animation:1.5s ease-in-out infinite record-pulse}@keyframes record-pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 12px 3px #ef444433}}.loop-btn.delete{color:#ef4444;opacity:.5}.loop-btn.delete:hover{opacity:1;background:#ef44441a;border-color:#ef4444}.loop-waveform{background:#00000026;border-radius:4px;flex:1;min-width:80px;height:24px;overflow:hidden}.loop-progress{background:linear-gradient(90deg,#8b5cf64d,#8b5cf61a);border-radius:4px;height:100%;transition:width .1s linear}.loop-empty{text-align:center;padding:var(--space-lg);color:var(--text-muted);font-size:.8rem}.loop-download-row{margin-top:var(--space-sm);justify-content:flex-end;gap:6px;display:flex}.loop-download-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:100px;align-items:center;gap:4px;padding:4px 12px;font-size:.7rem;transition:all .2s;display:flex}.loop-download-btn:hover{border-color:var(--accent-violet);color:var(--accent-violet)}.loop-download-btn:disabled{opacity:.3;cursor:not-allowed}.midi-learn-banner{border-radius:var(--radius-lg);margin-bottom:var(--space-sm);color:#fbbf24;background:#fbbf241a;border:1px solid #fbbf244d;justify-content:space-between;align-items:center;padding:8px 16px;font-size:.75rem;animation:1.5s ease-in-out infinite midi-learn-pulse;display:flex}.midi-learn-banner button{color:#fbbf24;cursor:pointer;background:0 0;border:1px solid #fbbf2480;border-radius:100px;padding:2px 10px;font-size:.65rem}@media (max-width:600px){.fx-grid{grid-template-columns:1fr 1fr}.fx-panel-body{padding:0 var(--space-sm)var(--space-md)}.fx-volume-strip{padding:var(--space-sm)var(--space-md)}}.control-group{align-items:center;gap:var(--space-sm);flex-direction:column;display:flex}.control-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:.75rem;font-weight:600}.piano-wrapper{width:100%;padding:var(--space-lg)0;display:flex;overflow-x:auto}.piano-keyboard{border-radius:var(--radius-lg);min-width:fit-content;box-shadow:var(--shadow-xl);background:var(--bg-primary);margin:0 auto;display:flex;overflow:hidden}.piano-octave{flex-shrink:0;width:308px;display:flex;position:relative}.piano-key{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast);justify-content:center;align-items:flex-end;display:flex}.white-key{z-index:1;background:linear-gradient(#f0f0f5,#fff);border:1px solid #0000001f;border-radius:0 0 6px 6px;width:14.2857%;height:242px}.white-key:hover{background:linear-gradient(#e8e0ff,#f0eaff)}.white-key.active{box-shadow:inset 0 -4px 8px #0000001a,var(--glow-violet);background:linear-gradient(180deg,var(--accent-violet),#c4b5fd)!important}.black-key{z-index:2;background:linear-gradient(#1a1a2e,#2d2d44);border-radius:0 0 5px 5px;width:8%;height:154px;position:absolute;box-shadow:0 4px 8px #0006}.black-key:hover{background:linear-gradient(#2a2a4e,#3d3d64)}.black-key.active{box-shadow:0 2px 4px #0006,var(--glow-indigo);height:152px;background:linear-gradient(180deg,var(--accent-indigo),var(--accent-violet))!important}.key-label{pointer-events:none;padding-bottom:8px;font-size:.65rem;font-weight:600}.white-key .key-label{color:#666}.white-key.active .key-label{color:#fff}.black-key .key-label{color:#999;padding-bottom:6px;font-size:.55rem}.black-key.active .key-label{color:#fff}.piano-sticky{z-index:100;padding-top:var(--space-sm);padding-bottom:var(--space-sm);background:0 0;position:sticky;bottom:0}.white-key.scale-highlight{background:linear-gradient(#fce7f3,#fdf2f8)}.white-key.scale-highlight .key-label{color:var(--accent-pink);font-weight:800}.black-key.scale-highlight{background:linear-gradient(#4b1a3d,#6b2d54);box-shadow:0 4px 8px #0006,0 0 6px #f472b64d}.black-key.scale-highlight .key-label{color:var(--accent-pink);font-weight:800}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.chord-type-selector{max-width:700px;margin:0 auto var(--space-xl)}.chord-category{margin-bottom:var(--space-md)}.chord-cat-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:var(--space-xs);font-size:.75rem;font-weight:600}.chord-cat-buttons{gap:var(--space-xs);flex-wrap:wrap;display:flex}.chord-type-btn{padding:var(--space-xs)var(--space-md);border-radius:var(--radius-full);background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-subtle);cursor:pointer;transition:all var(--transition-fast);font-size:.8rem;font-weight:500;font-family:var(--font-sans)}.chord-type-btn:hover{color:var(--text-primary);border-color:var(--border-active)}.chord-type-btn.active{background:var(--gradient-primary);color:#fff;border-color:#0000}.chord-display{max-width:600px;padding:var(--space-xl);border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-subtle);text-align:center;margin:0 auto}.chord-display-name{font-family:var(--font-display);background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:900}.play-chord-btn{padding:var(--space-sm)var(--space-xl);border-radius:var(--radius-full);background:var(--gradient-primary);color:#fff;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-normal);margin-bottom:var(--space-lg);box-shadow:var(--glow-indigo)}.play-chord-btn:hover{transform:scale(1.05);box-shadow:0 0 30px #6366f180}.chord-notes-display{justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-md);display:flex}.chord-note-pill{padding:var(--space-sm)var(--space-md);border-radius:var(--radius-full);color:var(--accent-violet);background:#a78bfa26;font-size:1rem;font-weight:700}.chord-formula-display{margin-bottom:var(--space-xl);font-size:.85rem}.formula-label{color:var(--text-muted);margin-right:var(--space-sm);font-size:.8rem;font-weight:600}.formula-val{color:var(--accent-violet);font-weight:600}.mini-piano{margin-top:var(--space-md)}.mini-piano-keys{max-width:350px;height:120px;margin:0 auto;display:flex;position:relative}.mini-white-key{transition:all var(--transition-fast);cursor:pointer;background:linear-gradient(#f0f0f5,#fff);border:1px solid #0000001f;border-radius:0 0 6px 6px;flex:1;justify-content:center;align-items:flex-end;display:flex}.mini-white-key:hover{background:linear-gradient(#e8e0ff,#f0eaff)}.mini-white-key.highlighted{background:linear-gradient(180deg,var(--accent-violet),#c4b5fd);box-shadow:var(--glow-violet)}.mini-white-key.highlighted:hover{background:linear-gradient(#b99bff,#d4c5ff)}.mini-black-key{z-index:2;width:7%;height:75px;transition:all var(--transition-fast);cursor:pointer;background:linear-gradient(#1a1a2e,#2d2d44);border-radius:0 0 4px 4px;justify-content:center;align-items:flex-end;display:flex;position:absolute}.mini-black-key:hover{background:linear-gradient(#2a2a4e,#3d3d64)}.mini-black-key.highlighted{background:linear-gradient(180deg,var(--accent-indigo),var(--accent-violet));box-shadow:var(--glow-indigo)}.mini-black-key.highlighted:hover{background:linear-gradient(#7375ff,#b99bff)}.mini-key-label{pointer-events:none;padding-bottom:4px;font-size:.55rem;font-weight:600}.mini-white-key .mini-key-label{color:#888}.mini-white-key.highlighted .mini-key-label{color:#fff}.mini-black-key .mini-key-label{color:#999;font-size:.45rem}.mini-black-key.highlighted .mini-key-label{color:#fff}.scale-selector{justify-content:center;gap:var(--space-xs);margin-bottom:var(--space-xl);flex-wrap:wrap;max-width:800px;margin-left:auto;margin-right:auto;display:flex}.scale-btn{padding:var(--space-xs)var(--space-md);border-radius:var(--radius-full);background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-subtle);cursor:pointer;transition:all var(--transition-fast);font-size:.8rem;font-weight:500;font-family:var(--font-sans)}.scale-btn:hover{color:var(--text-primary);border-color:var(--border-active)}.scale-btn.active{background:var(--gradient-primary);color:#fff;border-color:#0000}.scale-display{max-width:700px;padding:var(--space-xl);border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-subtle);text-align:center;margin:0 auto}.scale-header{margin-bottom:var(--space-lg)}.scale-title{font-family:var(--font-display);background:var(--gradient-primary);-webkit-text-fill-color:transparent;margin-bottom:var(--space-xs);-webkit-background-clip:text;background-clip:text;font-size:1.8rem;font-weight:800}.scale-desc{color:var(--text-secondary);font-size:.9rem}.play-btn{align-items:center;gap:var(--space-sm);padding:var(--space-md)var(--space-xl);border-radius:var(--radius-full);background:var(--gradient-primary);color:#fff;font-size:1rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-normal);margin-bottom:var(--space-xl);box-shadow:var(--glow-indigo);display:inline-flex}.play-btn.playing{animation:1s ease-in-out infinite pulse-glow}.scale-notes-row{justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-xl);flex-wrap:wrap;display:flex}.scale-note-item{align-items:center;gap:var(--space-xs);flex-direction:column;display:flex;position:relative}.scale-note-circle{background:var(--bg-tertiary);border:2px solid var(--accent-violet);width:52px;height:52px;color:var(--text-heading);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.scale-note-circle:hover{background:var(--accent-violet);color:#fff;box-shadow:var(--glow-violet);transform:scale(1.1)}.scale-note-circle.playing-note{background:var(--accent-violet);color:#fff;transform:scale(1.15);box-shadow:0 0 25px #a78bfa99}.scale-note-degree{color:var(--text-muted);font-size:.7rem}.scale-interval-bridge{color:var(--accent-pink);font-size:.65rem;font-weight:600;position:absolute;top:18px;right:-16px}.scale-formula,.scale-intervals{justify-content:center;align-items:center;gap:var(--space-sm);margin-top:var(--space-md);flex-wrap:wrap;display:flex}.formula-value{color:var(--accent-violet);font-size:.9rem;font-weight:600}.interval-chips{gap:var(--space-xs);display:flex}.interval-chip{border-radius:var(--radius-full);color:var(--accent-violet);background:#a78bfa26;padding:2px 10px;font-size:.8rem;font-weight:600}.cof-layout{gap:var(--space-xl);flex-wrap:wrap;justify-content:center;align-items:flex-start;max-width:900px;margin:0 auto;display:flex}.cof-circle-wrapper{flex:0 0 400px;justify-content:center;display:flex}.cof-panel{min-width:280px;padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-subtle);flex:1}.cof-panel h3{font-family:var(--font-display);margin-bottom:var(--space-md);text-align:center;font-size:1.3rem}.cof-chord-list{gap:var(--space-sm);flex-direction:column;display:flex}.cof-chord-item{align-items:center;gap:var(--space-md);padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);background:var(--bg-tertiary);cursor:pointer;transition:all var(--transition-fast);display:flex}.cof-chord-item:hover{background:var(--bg-card-hover);box-shadow:var(--glow-violet)}.cof-chord-roman{min-width:50px;color:var(--text-heading);font-size:1rem;font-weight:700}.cof-chord-name{color:var(--text-secondary);font-size:.9rem}.cof-chord-fn{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;margin-left:auto;padding:2px 8px;font-size:.7rem;font-weight:600}.fn-tonic{color:var(--accent-emerald);background:#34d39926}.fn-subdominant{color:var(--accent-amber);background:#fbbf2426}.fn-dominant{color:var(--accent-pink);background:#f472b626}.chord-cards-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));max-width:800px;margin:0 auto;display:grid}.chord-card{padding:var(--space-lg)var(--space-md);border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-subtle);text-align:center;cursor:pointer;transition:all var(--transition-normal)}.chord-card-roman{color:var(--text-heading);font-size:1.3rem;font-weight:800;font-family:var(--font-display);margin-bottom:var(--space-xs)}.chord-card-name{color:var(--accent-violet);margin-bottom:var(--space-sm);font-size:.9rem;font-weight:600}.chord-card-notes{color:var(--text-muted);margin-bottom:var(--space-sm);font-size:.75rem}.chord-card-function{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;font-size:.65rem;font-weight:600;display:inline-block}.cheat-sections{gap:var(--space-xl);max-width:800px;margin:0 auto;display:grid}.cheat-section{padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-subtle)}.cheat-section h3{font-family:var(--font-display);color:var(--text-heading);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-subtle);font-size:1.1rem}.cheat-row{gap:var(--space-sm);flex-wrap:wrap;justify-content:center;display:flex}.cheat-pill{padding:var(--space-sm)var(--space-md);border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-primary);font-size:.85rem;font-weight:600}.cheat-info-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.cheat-info-item{padding:var(--space-md);border-radius:var(--radius-md);background:var(--bg-tertiary);text-align:center}.cheat-info-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:var(--space-xs);font-size:.7rem}.cheat-info-value{color:var(--accent-violet);font-size:1rem;font-weight:700}.cheat-chord-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(100px,1fr));display:grid}.cheat-chord{padding:var(--space-sm);border-radius:var(--radius-md);background:var(--bg-tertiary);text-align:center}.cheat-chord-name{color:var(--text-secondary);font-size:.75rem}.cheat-degree-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(140px,1fr));display:grid}.cheat-degree{padding:var(--space-sm);border-radius:var(--radius-md);background:var(--bg-tertiary);text-align:center}.cheat-degree-num{color:var(--accent-violet);font-weight:700}.cheat-degree-name{color:var(--text-secondary);font-size:.8rem}.cheat-mode-grid{gap:var(--space-sm);flex-direction:column;display:flex}.cheat-mode-item{align-items:center;gap:var(--space-md);padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);background:var(--bg-tertiary);display:flex}.cheat-mode-name{min-width:100px;color:var(--text-heading);font-weight:700}.cheat-mode-notes{color:var(--text-secondary);font-size:.85rem}.scales-table{gap:var(--space-sm);flex-direction:column;max-width:800px;margin:0 auto;display:flex}.scale-row{padding:var(--space-md)var(--space-lg);border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-subtle);cursor:pointer;transition:all var(--transition-fast)}.scale-row:hover{border-color:var(--border-active);box-shadow:var(--glow-violet)}.scale-row.expanded{border-color:var(--accent-violet)}.scale-row-header{justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.scale-row-key{font-family:var(--font-display);color:var(--text-heading);min-width:80px;font-size:1.3rem;font-weight:800}.scale-row-notes{color:var(--text-secondary);flex:1;font-size:.85rem}.scale-row-buttons{gap:var(--space-sm);align-items:center;display:flex}.scale-play-btn{padding:var(--space-xs)var(--space-md);border-radius:var(--radius-full);background:var(--gradient-primary);color:#fff;cursor:pointer;transition:all var(--transition-fast);font-size:.8rem;font-weight:600;font-family:var(--font-sans)}.scale-play-btn:hover{transform:scale(1.05)}.expand-arrow{color:var(--text-muted);transition:transform var(--transition-fast);font-size:1.2rem}.expanded .expand-arrow{transform:rotate(180deg)}.scale-detail{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-subtle);gap:var(--space-md);flex-direction:column;display:flex}.scale-detail-section{gap:var(--space-md);flex-wrap:wrap;align-items:center;display:flex}.scale-detail-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);min-width:100px;font-size:.75rem;font-weight:600}.scale-detail-value{color:var(--text-secondary);font-size:.85rem}.diatonic-chords{gap:var(--space-xs);flex-wrap:wrap;display:flex}.diatonic-chip{border-radius:var(--radius-full);color:var(--accent-violet);background:#a78bfa26;padding:4px 12px;font-size:.8rem;font-weight:600}.progressions-list{gap:var(--space-md);flex-direction:column;max-width:700px;margin:0 auto;display:flex}.progression-card{padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-subtle);transition:all var(--transition-fast)}.progression-card:hover{border-color:var(--border-active)}.progression-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.progression-name{font-family:var(--font-display);color:var(--text-heading);font-size:1.2rem;font-weight:700}.progression-genre{border-radius:var(--radius-full);color:var(--accent-violet);text-transform:uppercase;letter-spacing:.05em;background:#a78bfa26;padding:2px 10px;font-size:.7rem;font-weight:600}.progression-numerals{gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap;display:flex}.prog-numeral{padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border-subtle);text-align:center;min-width:60px}.prog-numeral-roman{color:var(--text-heading);font-size:1rem;font-weight:700}.prog-numeral-name{color:var(--text-secondary);font-size:.7rem}.progression-desc{color:var(--text-secondary);margin-bottom:var(--space-md);font-size:.85rem}.prog-play-btn{padding:var(--space-sm)var(--space-lg);border-radius:var(--radius-full);background:var(--gradient-primary);color:#fff;cursor:pointer;transition:all var(--transition-fast);font-size:.85rem;font-weight:600;font-family:var(--font-sans);box-shadow:var(--glow-indigo)}.prog-play-btn:hover{transform:scale(1.05);box-shadow:0 0 30px #6366f180}.intervals-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));max-width:800px;margin:0 auto;display:grid}.interval-card{padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-subtle);text-align:center;transition:all var(--transition-fast)}.interval-card:hover{border-color:var(--border-active);box-shadow:var(--glow-violet)}.interval-short{font-family:var(--font-display);background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:800}.interval-semitones{color:var(--text-muted);margin-bottom:var(--space-sm);font-size:.75rem}.interval-name{color:var(--text-heading);margin-bottom:var(--space-xs);font-size:.85rem;font-weight:600}.interval-example{color:var(--accent-violet);font-size:.8rem}.interval-quality{color:var(--text-muted);margin-top:var(--space-xs);font-size:.65rem}.interval-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.interval-example{justify-content:center;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);display:flex}.interval-from,.interval-to{border-radius:var(--radius-full);padding:4px 12px;font-size:.9rem;font-weight:700}.interval-from{color:var(--accent-violet);background:#a78bfa26}.interval-to{color:var(--accent-pink);background:#f472b626}.interval-arrow{color:var(--text-muted);font-size:1.2rem}.circle-layout{align-items:flex-start;gap:var(--space-2xl);flex-wrap:wrap;justify-content:center;display:flex}.circle-wrapper{flex-shrink:0;width:100%;max-width:400px}.circle-svg{filter:drop-shadow(0 0 30px #6366f126);width:100%;height:auto}.chord-panel{flex:1;min-width:280px;max-width:400px}.chord-panel-title{font-family:var(--font-display);color:var(--text-heading);margin-bottom:var(--space-lg);font-size:1.2rem}.key-highlight{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.chord-pills{gap:var(--space-sm);flex-direction:column;display:flex}.chord-pill{align-items:center;gap:var(--space-md);padding:var(--space-md)var(--space-lg);border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-subtle);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-sans);text-align:left;width:100%;display:flex}.chord-pill:hover{border-color:var(--border-active);box-shadow:var(--glow-violet);transform:translate(4px)}.chord-pill.fn-tonic{border-left:3px solid var(--accent-violet)}.chord-pill.fn-subdominant{border-left:3px solid var(--accent-pink)}.chord-pill.fn-dominant{border-left:3px solid var(--accent-emerald)}.chord-roman{min-width:42px;color:var(--accent-violet);font-size:1.1rem;font-weight:700}.chord-name{min-width:60px;font-size:.95rem;font-weight:600}.chord-notes{color:var(--text-secondary);font-size:.8rem}.chord-legend{gap:var(--space-lg);margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--border-subtle);display:flex}.legend-item{align-items:center;gap:var(--space-xs);color:var(--text-secondary);font-size:.8rem;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px}.legend-dot.tonic{background:var(--accent-violet)}.legend-dot.subdominant{background:var(--accent-pink)}.legend-dot.dominant{background:var(--accent-emerald)}.scales-table-wrapper{max-width:900px;margin:0 auto;overflow-x:auto}table.scales-table{border-collapse:separate;border-spacing:0 4px;width:100%;max-width:none;display:table}table.scales-table th{text-align:left;padding:var(--space-sm)var(--space-md);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);border-bottom:1px solid var(--border-subtle);font-size:.75rem;font-weight:600}tr.scale-row{cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:0;padding:0}tr.scale-row td{padding:var(--space-md);background:var(--bg-card);border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle)}tr.scale-row td:first-child{border-left:1px solid var(--border-subtle);border-radius:var(--radius-md)0 0 var(--radius-md)}tr.scale-row td:last-child{border-right:1px solid var(--border-subtle);border-radius:0 var(--radius-md)var(--radius-md)0}tr.scale-row:hover td{border-color:var(--border-active);background:var(--bg-card-hover)}tr.scale-row.expanded td{border-color:var(--accent-violet);background:var(--bg-card-hover)}td.scale-key{color:var(--accent-violet);white-space:nowrap;min-width:100px;font-weight:700}td.scale-notes{flex-wrap:wrap;gap:4px;display:flex}.scale-note-chip{border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-primary);padding:2px 8px;font-size:.8rem;font-weight:600}.scale-note-chip.minor{color:var(--accent-pink);background:#f472b626}td.scale-formula{color:var(--text-secondary);white-space:nowrap;font-size:.8rem}td.scale-relative{color:var(--accent-pink);white-space:nowrap;font-weight:600}.play-sm-btn{background:var(--bg-tertiary);width:32px;height:32px;color:var(--accent-violet);border:1px solid var(--border-subtle);cursor:pointer;transition:all var(--transition-fast);font-size:.8rem;font-family:var(--font-sans);border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.play-sm-btn:hover{background:var(--gradient-primary);color:#fff;border-color:#0000}.scale-detail-row td{padding:var(--space-lg);border:1px solid var(--accent-violet);border-radius:0 0 var(--radius-md)var(--radius-md);background:#190f3c66;border-top:none}.scale-detail{gap:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}.detail-section h4{color:var(--text-heading);margin-bottom:var(--space-sm);font-size:.85rem}.detail-notes{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.detail-chords{gap:var(--space-xs);flex-wrap:wrap;display:flex}.detail-chord-pill{border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-subtle);padding:4px 10px;font-size:.8rem;font-weight:600}.chords-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));max-width:900px;margin:0 auto;display:grid}.chord-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-top:3px solid var(--fn-color,var(--accent-violet));border-radius:var(--radius-lg);padding:var(--space-lg);cursor:pointer;transition:all var(--transition-normal);text-align:center}.chord-card:hover{border-color:var(--border-active);box-shadow:var(--glow-violet);transform:translateY(-4px)}.chord-card-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.chord-degree{font-family:var(--font-display);color:var(--fn-color,var(--accent-violet));font-size:1.5rem;font-weight:800}.chord-fn-badge{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-radius:var(--radius-full);background:#6366f11a;padding:2px 8px;font-size:.65rem;font-weight:600}.chord-card-name{font-family:var(--font-display);color:var(--text-heading);margin-bottom:var(--space-md);font-size:1.3rem;font-weight:700}.chord-card-notes{justify-content:center;gap:var(--space-xs);margin-bottom:var(--space-sm);flex-wrap:wrap;display:flex}.chord-note-chip{border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-primary);padding:4px 10px;font-size:.8rem;font-weight:600}.chord-play-hint{color:var(--text-muted);margin-top:var(--space-sm);opacity:0;transition:opacity var(--transition-fast);font-size:.7rem}.chord-card:hover .chord-play-hint{opacity:1}.cheat-grid{gap:var(--space-md);grid-template-columns:repeat(2,1fr);max-width:900px;margin:0 auto;display:grid}.cheat-section{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg)}.cheat-section.wide{grid-column:1/-1}.cheat-section-title{font-family:var(--font-display);color:var(--text-heading);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-subtle);font-size:1rem}.cheat-notes-row{gap:var(--space-sm);flex-wrap:wrap;display:flex}.cheat-note{text-align:center}.cheat-note-name{background:var(--bg-tertiary);border:2px solid var(--accent-violet);width:44px;height:44px;color:var(--text-heading);border-radius:50%;justify-content:center;align-items:center;margin-bottom:4px;font-size:.85rem;font-weight:700;display:flex}.cheat-note-degree{color:var(--text-muted);font-size:.65rem}.cheat-formula{margin-top:var(--space-md);color:var(--text-secondary);font-size:.85rem}.cheat-info-grid{gap:var(--space-sm);display:grid}.info-item{padding:var(--space-sm)0;border-bottom:1px solid #6366f114;justify-content:space-between;display:flex}.info-label{color:var(--text-muted);font-size:.85rem}.info-value{color:var(--text-heading);font-size:.85rem;font-weight:600}.cheat-chords-row{gap:var(--space-sm);flex-wrap:wrap;display:flex}.cheat-chord{text-align:center;min-width:80px;padding:var(--space-sm);border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border-subtle);flex:1}.cheat-chord.fn-tonic{border-top:2px solid var(--accent-violet)}.cheat-chord.fn-subdominant{border-top:2px solid var(--accent-pink)}.cheat-chord.fn-dominant{border-top:2px solid var(--accent-emerald)}.cheat-chord-roman{color:var(--accent-violet);font-size:1rem;font-weight:700}.cheat-chord-name{color:var(--text-heading);font-size:.85rem;font-weight:600}.cheat-chord-notes{color:var(--text-muted);margin-top:2px;font-size:.7rem}.fn-groups{gap:var(--space-sm);grid-template-columns:repeat(3,1fr);display:grid}.fn-group{text-align:center;padding:var(--space-md);border-radius:var(--radius-md);background:var(--bg-tertiary)}.fn-group.fn-tonic{border:1px solid #a78bfa4d}.fn-group.fn-subdominant{border:1px solid #f472b64d}.fn-group.fn-dominant{border:1px solid #34d3994d}.fn-group-title{text-transform:capitalize;color:var(--text-heading);margin-bottom:var(--space-sm);font-size:.85rem;font-weight:700}.fn-group-chords{justify-content:center;gap:var(--space-xs);flex-wrap:wrap;display:flex}.fn-chord-pill{border-radius:var(--radius-full);color:var(--accent-violet);background:#a78bfa26;padding:2px 8px;font-size:.8rem;font-weight:600}.degrees-table{gap:2px;display:grid}.degree-row{gap:var(--space-sm);padding:var(--space-xs)var(--space-sm);border-radius:var(--radius-sm);grid-template-columns:30px 50px 1fr;align-items:center;display:grid}.degree-row:nth-child(odd){background:#6366f10d}.degree-num{color:var(--accent-violet);font-size:.85rem;font-weight:700}.degree-note{color:var(--text-heading);font-size:.85rem;font-weight:600}.degree-name{color:var(--text-secondary);font-size:.8rem}.modes-grid{gap:var(--space-sm);display:grid}.mode-item{gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-sm);grid-template-columns:160px 40px 1fr;align-items:center;display:grid}.mode-item:nth-child(odd){background:#6366f10d}.mode-name{color:var(--text-heading);font-size:.85rem;font-weight:600}.mode-root{color:var(--accent-violet);font-size:.85rem;font-weight:700}.mode-notes{color:var(--text-secondary);font-size:.8rem}.hero{text-align:center;padding:calc(var(--space-xl)*.2)0 calc(var(--space-xl)*1.2)}.hero-title{font-family:var(--font-display);color:var(--text-heading);margin-bottom:var(--space-md);font-size:2.5rem;font-weight:900;line-height:1.1}.hero-highlight{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:var(--text-secondary);max-width:550px;margin:0 auto;font-size:1.2rem;line-height:1.6}.home-search-wrapper{margin-bottom:var(--space-xl);justify-content:center;display:flex}.home-search{width:100%;max-width:480px;position:relative}.home-search-icon{font-size:1rem;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.home-search-input{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-full);width:100%;color:var(--text-primary);font-size:1rem;font-family:var(--font-sans);transition:all var(--transition-normal);padding:14px 20px 14px 44px}.home-search-input:focus{border-color:var(--border-active);box-shadow:var(--glow-violet);outline:none}.home-search-input::placeholder{color:var(--text-muted)}.category-filter{justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-xl);flex-wrap:wrap;display:flex}.category-btn{padding:var(--space-sm)var(--space-md);border-radius:var(--radius-full);background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-subtle);transition:all var(--transition-fast);font-size:.85rem;font-weight:500;font-family:var(--font-sans);cursor:pointer}.category-btn:hover{color:var(--text-primary);border-color:var(--border-active)}.category-btn.active{background:var(--gradient-primary);color:#fff;box-shadow:var(--glow-indigo);border-color:#0000}.empty-state{text-align:center;padding:var(--space-3xl);color:var(--text-muted);font-size:1.1rem}.featured-section{margin-top:var(--space-4xl)}.section-title{font-family:var(--font-display);color:var(--text-heading);margin-bottom:var(--space-lg);text-align:center;font-size:1.5rem}.featured-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));grid-auto-rows:1fr;display:grid}.featured-card{padding:var(--space-xl);border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-subtle);transition:all var(--transition-normal);flex-direction:column;text-decoration:none;display:flex;position:relative;overflow:hidden}.featured-card:before{content:"";background:var(--card-accent,var(--accent-violet));height:3px;position:absolute;top:0;left:0;right:0}.featured-card:hover{border-color:color-mix(in srgb,var(--card-accent,var(--border-active))50%,transparent);box-shadow:0 0 35px color-mix(in srgb,var(--card-accent,var(--accent-violet))60%,transparent);transform:translateY(-4px)}.featured-icon{margin-bottom:var(--space-md);align-items:center;height:60px;font-size:2rem;display:flex}.featured-icon img{object-fit:contain}.featured-card h3{color:var(--text-heading);margin-bottom:var(--space-xs);font-size:1.1rem}.featured-card p{color:var(--text-secondary);font-size:.85rem;line-height:1.5}@media (max-width:768px){.chords-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.chord-degree{font-size:1.2rem}.chord-card-name{font-size:1rem}.cheat-grid,.fn-groups{grid-template-columns:1fr}.mode-item{grid-template-columns:1fr;gap:2px}.hero-title{font-size:1.8rem}.hero-subtitle{font-size:.85rem}.scale-detail{grid-template-columns:1fr}.circle-wrapper{max-width:320px}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6366f14d}@media (max-width:768px){.nav-search{display:none}.page-title{font-size:1.75rem}.tool-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.container{padding:0 var(--space-md)}}@media (max-width:480px){.tool-grid{grid-template-columns:repeat(2,1fr)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #a78bfa4d}50%{box-shadow:0 0 40px #a78bfa80}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes spin{to{transform:rotate(360deg)}}.animate-in{animation:.5s ease-out forwards fadeInUp}.pulse-glow{animation:2s ease-in-out infinite pulse-glow}.fb-instrument-tabs{margin-bottom:var(--space-md);border-radius:var(--radius-xl);border:1px solid var(--border-subtle);background:var(--bg-card);gap:0;display:flex;overflow:hidden}.fb-instrument-tab{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px 20px;font-size:.95rem;font-weight:700;transition:all .25s;display:flex;position:relative}.fb-instrument-tab:not(:last-child){border-right:1px solid var(--border-subtle)}.fb-instrument-tab.active{color:var(--accent-violet,#8b5cf6);box-shadow:inset 0 -3px 0 var(--accent-violet,#8b5cf6);background:linear-gradient(135deg,#8b5cf626,#6366f11a)}.fb-instrument-tab:hover:not(.active){color:var(--text-primary);background:#8b5cf60f}.fb-instrument-icon{font-size:1.2rem}.fb-view-toggle-wrapper{margin-bottom:var(--space-md);justify-content:center;display:flex;position:relative}.ss-info-tooltip:after{content:attr(data-tooltip);background:var(--bg-secondary);border-radius:var(--radius-md);color:var(--text-secondary);white-space:normal;text-align:center;width:max-content;max-width:220px;box-shadow:var(--shadow-md);pointer-events:none;z-index:200;opacity:0;border:1px solid #8b5cf64d;padding:5px 9px;font-size:.72rem;line-height:1.4;transition:opacity .1s;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}.ss-info-tooltip:hover:after{opacity:1}.fb-chords-disabled-tooltip{background:var(--bg-secondary);border-radius:var(--radius-md);color:var(--text-secondary);white-space:normal;text-align:center;width:max-content;max-width:240px;box-shadow:var(--shadow-md);pointer-events:none;z-index:100;border:1px solid #8b5cf64d;padding:6px 10px;font-size:.75rem;line-height:1.4;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.fb-view-toggle{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:var(--bg-card);display:inline-flex;overflow:hidden}.fb-view-toggle-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;padding:10px 28px;font-size:.9rem;font-weight:600;transition:all .2s}.fb-view-toggle-btn:first-child{border-right:1px solid var(--border-subtle)}.fb-view-toggle-btn.active{background:var(--accent-violet,#8b5cf6);color:#fff;box-shadow:0 2px 8px #8b5cf64d}.fb-view-toggle-btn:hover:not(.active){color:var(--text-primary);background:#8b5cf614}.fb-dropdown{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%236b7280' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;min-width:150px;padding:8px 32px 8px 14px;font-size:.85rem;font-weight:500;transition:all .2s}.fb-dropdown:focus{border-color:var(--accent-violet,#8b5cf6);outline:none;box-shadow:0 0 0 2px #8b5cf633}.fb-dropdown:hover{border-color:var(--accent-violet,#8b5cf6)}.fb-dropdown option{background:var(--bg-card);color:var(--text-primary)}.fb-dropdowns-row{gap:var(--space-md);flex-wrap:wrap;align-items:flex-end;display:flex}.fb-dropdowns-row .fb-control-group{flex:1;min-width:140px}.fb-dropdowns-row .fb-dropdown{width:100%}.fret-12-info{cursor:help;z-index:2;position:absolute;top:-4px;left:50%;transform:translate(-50%)}.fret-marker-cell{position:relative}.fret-12-tooltip{align-items:center;gap:var(--space-sm);margin-top:var(--space-md);padding:var(--space-sm)var(--space-md);background:var(--accent-primary-alpha);border:1px solid var(--accent-primary);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.82rem;line-height:1.4;display:flex}.chord-diagrams-section{margin-bottom:var(--space-xl)}.chord-diagrams-title{text-align:center;color:var(--text-primary);margin-bottom:var(--space-sm);font-size:1.3rem;font-weight:700}.chord-finger-legend{justify-content:center;gap:var(--space-lg);margin-bottom:var(--space-lg);flex-wrap:wrap;display:flex}.finger-legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:.82rem;display:flex}.finger-dot{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;font-weight:700;display:inline-flex}.chord-diagrams-grid{justify-content:center;gap:var(--space-lg);flex-wrap:wrap;display:flex}.chord-diagram-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-md)var(--space-md)var(--space-sm);flex-direction:column;align-items:center;transition:border-color .2s,box-shadow .2s;display:flex}.chord-diagram-card:hover{border-color:var(--accent-primary);box-shadow:0 0 20px #8b5cf626}.chord-diagram-svg{display:block}.chord-diagram-label{color:var(--text-muted);text-transform:none;letter-spacing:.5px;margin-top:4px;font-size:.75rem;font-weight:600}.chord-diagrams-empty{text-align:center;padding:var(--space-xl);color:var(--text-muted);background:var(--bg-card);border:1px dashed var(--border-subtle);border-radius:var(--radius-lg)}.chord-notes-info{justify-content:center;align-items:center;gap:var(--space-md);margin-top:var(--space-lg);padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);flex-wrap:wrap;display:flex}.chord-notes-label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.chord-notes-pills{gap:var(--space-xs);flex-wrap:wrap;display:flex}.fretboard-controls{gap:var(--space-md);margin-bottom:var(--space-lg);padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);flex-direction:column;display:flex}.fb-control-group{gap:var(--space-xs);flex-direction:column;display:flex}.fb-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.75rem;font-weight:600}.fb-note-selector{flex-wrap:wrap;gap:4px;display:flex}.fb-note-btn{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:6px 10px;font-size:.8rem;font-weight:600}.fb-note-btn:hover{border-color:var(--accent-violet);color:var(--text-heading)}.fb-note-btn.active{background:var(--accent-violet);color:#fff;border-color:var(--accent-violet)}.fb-note-btn.highlighted{border-color:var(--accent-violet);color:var(--accent-violet);background:#8b5cf633}.fb-note-btn-sm{padding:4px 8px;font-size:.7rem}.fb-scale-selector{flex-wrap:wrap;gap:4px;display:flex}.fb-scale-btn{border:1px solid var(--border-subtle);border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:6px 12px;font-size:.78rem;font-weight:500}.fb-scale-btn:hover{border-color:var(--accent-pink);color:var(--text-heading)}.fb-scale-btn.active{background:var(--accent-pink);color:#fff;border-color:var(--accent-pink)}.fb-toggles{gap:var(--space-sm);flex-wrap:wrap;flex-direction:row!important}.fb-toggle{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);padding:6px 14px;font-size:.8rem;font-weight:500}.fb-toggle.active{border-color:var(--accent-violet);color:var(--accent-violet);background:#8b5cf626}.fretboard-wrapper{width:100%;padding:var(--space-md)0;margin-bottom:var(--space-lg);overflow-x:auto}.fretboard{border-radius:var(--radius-xl);min-width:fit-content;padding:var(--space-sm);border:1px solid var(--border-subtle);background:linear-gradient(160deg,#1a1520,#2a1f30);flex-direction:column;display:flex}.fret-markers-row,.fret-numbers-row{align-items:center;display:flex}.string-label-spacer{flex-shrink:0;width:42px}.fret-marker-cell,.fret-number{text-align:center;width:68px;color:var(--text-muted);flex-shrink:0;padding:2px 0;font-size:.7rem}.fret-marker-cell.nut,.fret-number.nut{width:46px}.fret-marker-dot{color:#ffffff40;font-size:.55rem}.fret-marker-dot.double{letter-spacing:3px}.fretboard-string-row{align-items:center;display:flex;position:relative}.fretboard-string-row:after{content:"";z-index:0;background:#c0a88c66;height:1px;position:absolute;top:50%;left:42px;right:0}.fretboard-string-row:first-of-type:after{height:1px}.fretboard-string-row:last-of-type:after{background:#c0a88c99;height:2px}.string-label{width:42px;color:var(--text-heading);text-align:center;z-index:1;flex-shrink:0;font-size:.8rem;font-weight:700}.fret-cell{z-index:1;flex-shrink:0;justify-content:center;align-items:center;width:68px;height:46px;display:flex;position:relative}.fret-cell.nut{border-right:3px solid #ffffff80;width:46px}.fret-wire{background:#c0a88c26;width:1px;position:absolute;top:0;bottom:0;right:0}.fret-cell.nut .fret-wire{display:none}.fret-note{cursor:pointer;background:var(--accent-violet);color:#fff;z-index:2;width:34px;height:34px;transition:all var(--transition-fast);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex;box-shadow:0 2px 8px #8b5cf64d}.fret-note:hover{transform:scale(1.2);box-shadow:0 3px 12px #8b5cf680}.fret-note.root{background:var(--accent-pink);box-shadow:0 2px 8px #ec489966}.fret-note.playing{transform:scale(1.3);box-shadow:0 0 20px #8b5cf6b3}.fb-scale-info{padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:var(--space-lg);text-align:center}.fb-scale-info h3{font-family:var(--font-display);color:var(--text-heading);margin-bottom:var(--space-sm);font-size:1.4rem}.fb-scale-notes{margin-bottom:var(--space-sm);flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.fb-scale-note-pill{border-radius:var(--radius-full);color:var(--accent-violet);background:#8b5cf626;padding:4px 12px;font-size:.85rem;font-weight:600}.fb-scale-note-pill.root{background:var(--accent-pink);color:#fff}.fb-scale-desc{color:var(--text-muted);font-size:.9rem}.chord-display-section{text-align:center;margin-bottom:var(--space-xl)}.chord-display-header{margin-bottom:var(--space-lg)}.chord-display-name{font-family:var(--font-display);color:var(--text-heading);margin-bottom:4px;font-size:3rem;font-weight:900}.chord-display-full{color:var(--text-muted);margin-bottom:var(--space-md);font-size:1rem}.play-btn{border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-violet),var(--accent-pink));color:#fff;cursor:pointer;transition:all var(--transition-fast);border:none;padding:10px 24px;font-size:.9rem;font-weight:600}.chord-display-notes{gap:var(--space-sm);margin-bottom:var(--space-lg);justify-content:center;display:flex}.chord-note-circle{border:2px solid var(--accent-violet);width:48px;height:48px;color:var(--accent-violet);cursor:pointer;transition:all var(--transition-fast);background:#8b5cf61a;border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.chord-note-circle:hover{background:var(--accent-violet);color:#fff;transform:scale(1.1)}.chord-diagrams-grid{gap:var(--space-lg);flex-wrap:wrap;justify-content:center;display:flex}.chord-diagram{padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;align-items:center;display:flex}.chord-diagram:hover{border-color:var(--accent-violet);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.chord-diagram-label{color:var(--text-heading);margin-top:var(--space-xs);font-size:.9rem;font-weight:700}.chord-diagram-play{color:var(--text-muted);margin-top:2px;font-size:.7rem}.chord-diagram-placeholder{padding:var(--space-xl);background:var(--bg-card);border:1px dashed var(--border-subtle);border-radius:var(--radius-lg);text-align:center;min-width:200px}.chord-diagram-icon{margin-bottom:var(--space-sm);font-size:3rem}.chord-note-info{color:var(--text-muted);margin-bottom:var(--space-md);font-size:.85rem}.tuner-presets{gap:var(--space-sm);margin-bottom:var(--space-xl);justify-content:center;display:flex}.tuner-preset-btn{border:1px solid var(--border-subtle);border-radius:var(--radius-full);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:6px;padding:10px 20px;font-size:.9rem;font-weight:600;display:flex}.tuner-preset-btn.active{background:var(--accent-violet);color:#fff;border-color:var(--accent-violet)}.tuner-preset-icon{font-size:1.1rem}.tuner-display{align-items:center;gap:var(--space-lg);margin-bottom:var(--space-xl);flex-direction:column;display:flex}.tuner-gauge{background:var(--bg-card);border:2px solid var(--border-subtle);border-radius:var(--radius-xl);flex-direction:column;justify-content:center;align-items:center;width:300px;height:240px;transition:border-color .3s;display:flex;position:relative;overflow:hidden}.tuner-gauge.in-tune{border-color:var(--accent-emerald);box-shadow:0 0 30px #10b98133}.tuner-needle-wrap{transform-origin:bottom;width:4px;height:80px;transition:transform .15s ease-out;position:absolute;top:30px}.tuner-needle{background:linear-gradient(180deg,var(--accent-pink),transparent);border-radius:2px;width:3px;height:70px;margin:0 auto}.tuner-cents-labels{width:80%;color:var(--text-muted);justify-content:space-between;font-size:.65rem;display:flex;position:absolute;top:100px}.tuner-center-mark{color:var(--accent-emerald);font-weight:700}.tuner-note-display{align-items:baseline;gap:4px;margin-top:40px;display:flex}.tuner-note-name{font-family:var(--font-display);color:var(--text-heading);font-size:3.5rem;font-weight:900;transition:color .3s}.tuner-note-name.in-tune{color:var(--accent-emerald)}.tuner-octave{color:var(--text-muted);font-size:1.5rem}.tuner-freq{color:var(--text-muted);margin-top:4px;font-size:.85rem}.tuner-cents-display{margin-top:4px;font-size:.9rem;font-weight:600}.tuner-cents-display.in-tune{color:var(--accent-emerald)}.tuner-cents-display.sharp{color:var(--accent-pink)}.tuner-cents-display.flat{color:var(--accent-amber)}.tuner-start-btn{border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-violet),var(--accent-pink));color:#fff;cursor:pointer;transition:all var(--transition-fast);border:none;padding:14px 32px;font-size:1rem;font-weight:700}.tuner-start-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px #8b5cf666}.tuner-start-btn.stop{background:linear-gradient(135deg,#ef4444,#dc2626)}.tuner-strings{text-align:center}.tuner-strings-title{font-family:var(--font-display);color:var(--text-heading);margin-bottom:var(--space-md)}.tuner-string-buttons{gap:var(--space-sm);flex-wrap:wrap;justify-content:center;display:flex}.tuner-string-btn{border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:var(--bg-card);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;align-items:center;min-width:60px;padding:12px 16px;display:flex}.tuner-string-btn.active{border-color:var(--accent-emerald);background:#10b9811a}.tuner-string-btn.selected{border-color:var(--accent-violet);background:#8b5cf61a}.tuner-string-num{color:var(--text-muted);font-size:.65rem}.tuner-string-note{color:var(--text-heading);font-size:1rem;font-weight:700}.vocal-ranges-chart{margin-bottom:var(--space-xl);padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl)}.vocal-piano-ref{margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-subtle);align-items:center;display:flex}.vocal-piano-label{width:160px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;flex-shrink:0;font-size:.75rem}.vocal-piano-keys{flex:1;display:flex}.vocal-piano-key-marker{color:var(--text-muted);text-align:left;flex:1;font-size:.65rem}.vocal-range-row{border-radius:var(--radius-md);align-items:center;padding:8px 0;transition:background .2s;display:flex}.vocal-range-row:hover,.vocal-range-row.active{background:#8b5cf60d}.vocal-range-label{flex-direction:column;flex-shrink:0;width:160px;display:flex}.vocal-range-name{color:var(--text-heading);font-size:.9rem;font-weight:700}.vocal-range-notes{color:var(--text-muted);font-size:.7rem}.vocal-range-track{border-radius:var(--radius-full);background:#ffffff08;flex:1;height:32px;position:relative}.vocal-range-bar{border-radius:var(--radius-full);opacity:.7;justify-content:space-between;align-items:center;height:100%;padding:0 4px;transition:opacity .2s;display:flex;position:absolute;top:0}.vocal-range-row:hover .vocal-range-bar,.vocal-range-row.active .vocal-range-bar{opacity:1}.vocal-range-endpoint{color:#fff;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:#0000004d;border:none;padding:2px 8px;font-size:.65rem;font-weight:700}.vocal-range-endpoint:hover{background:#0009;transform:scale(1.1)}.vocal-range-endpoint.playing{color:#1a1a2e;background:#fff}.vocal-cards-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.voice-analysis-section{align-items:center;gap:var(--space-md);padding:var(--space-xl);background:var(--surface-2);border-radius:var(--radius-xl);margin-bottom:var(--space-xl);margin-top:var(--space-xl);text-align:center;border:1px solid var(--border-subtle);flex-direction:column;display:flex;position:relative;overflow:hidden}.voice-record-btn{align-items:center;gap:var(--space-sm);padding:var(--space-md)var(--space-xl);background:var(--accent-violet);color:#fff;cursor:pointer;z-index:2;border:none;border-radius:100px;font-size:1rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 4px 12px #8b5cf64d}.voice-record-btn:not(:disabled):hover{background:var(--accent-violet-hover);transform:translateY(-2px);box-shadow:0 6px 16px #8b5cf666}.voice-record-btn:disabled{opacity:.7;cursor:not-allowed}.voice-record-btn.recording{background:var(--accent-red);animation:1.5s infinite pulse-red;box-shadow:0 0 12px #ef444466}@keyframes pulse-red{0%{box-shadow:0 0 #ef444466}70%{box-shadow:0 0 0 10px #ef444400}to{box-shadow:0 0 #ef444400}}.voice-status{color:var(--text-secondary);min-height:1.5em;font-size:.9rem;font-weight:500}.voice-visualizer{justify-content:center;align-items:center;width:100%;min-height:0;display:flex}.freq-dot{background:var(--accent-violet);border-radius:50%;width:20px;height:20px;transition:transform .1s}.voice-result-card{background:var(--bg-card);border:1px solid var(--accent-violet);border-radius:var(--radius-lg);padding:var(--space-lg);margin-top:var(--space-md);width:100%;max-width:500px;animation:.4s ease-out fadeInUp;box-shadow:0 10px 30px -10px #8b5cf626}.voice-result-title{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:var(--space-xs);font-size:.75rem;font-weight:600}.voice-type-highlight{color:var(--accent-violet);margin-bottom:var(--space-xs);background:linear-gradient(135deg,var(--accent-violet),#c4b5fd);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:800}.voice-range-highlight{color:var(--text-primary);margin-bottom:var(--space-sm);font-size:1.1rem;font-weight:600}.voice-note-display{color:var(--accent-violet);font-family:var(--font-mono);background:#8b5cf61a;border-radius:4px;padding:2px 8px;display:inline-block}.voice-desc{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.vocal-card{padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-fast);border-left:3px solid}.vocal-card:hover,.vocal-card.active{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.vocal-card-dot{width:10px;height:10px;margin-bottom:var(--space-xs);border-radius:50%}.vocal-card-title{font-family:var(--font-display);color:var(--text-heading);margin-bottom:4px;font-size:1rem}.vocal-card-desc{color:var(--text-muted);margin-bottom:var(--space-sm);font-size:.8rem}.vocal-card-range{align-items:center;gap:var(--space-xs);display:flex}.vocal-card-note{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-heading);cursor:pointer;transition:all var(--transition-fast);padding:4px 10px;font-size:.8rem;font-weight:700}.vocal-card-note:hover{background:var(--accent-violet);color:#fff;border-color:var(--accent-violet)}.vocal-card-dash{color:var(--text-muted)}@media (max-width:768px){.fret-cell{width:38px;height:32px}.fret-cell.nut{width:32px}.fret-marker-cell,.fret-number{width:38px}.fret-marker-cell.nut,.fret-number.nut{width:32px}.fret-note{width:24px;height:24px;font-size:.55rem}.string-label,.string-label-spacer{width:28px;font-size:.7rem}.vocal-range-label{width:100px}.vocal-range-name{font-size:.78rem}.tuner-gauge{width:260px;height:220px}}.section-heading{font-family:var(--font-display);color:var(--text-heading);text-align:center;margin:var(--space-2xl)0 var(--space-lg);font-size:1.5rem;font-weight:700}.section-description{color:var(--text-secondary);text-align:center;max-width:600px;margin:0 auto var(--space-lg);font-size:.9rem}.ref-info-section{gap:var(--space-md);margin-top:var(--space-2xl);padding-bottom:var(--space-2xl);grid-template-columns:repeat(auto-fit,minmax(260px,1fr));display:grid}.ref-info-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg)}.ref-info-card h3{margin-bottom:var(--space-sm);color:var(--text-heading);font-size:1rem}.ref-info-card p{color:var(--text-secondary);font-size:.875rem;line-height:1.6}.play-btn{align-items:center;gap:var(--space-sm);padding:var(--space-sm)var(--space-xl);border-radius:var(--radius-full);background:var(--gradient-primary);color:#fff;box-shadow:var(--glow-indigo);transition:all var(--transition-normal);cursor:pointer;border:none;font-size:.95rem;font-weight:600;display:inline-flex}.play-btn:hover{transform:translateY(-2px);box-shadow:0 0 30px #6366f180}.play-btn.playing{background:linear-gradient(135deg,var(--accent-emerald),var(--accent-cyan));box-shadow:0 0 20px #34d39966}.play-icon{font-size:1rem}.freq-table-wrapper{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-lg);margin-bottom:var(--space-2xl);overflow-x:auto}.freq-table{border-collapse:collapse;width:100%;font-size:.82rem}.freq-th-note,.freq-th-oct{padding:var(--space-sm)var(--space-md);background:var(--bg-tertiary);color:var(--text-heading);text-align:center;z-index:2;border-bottom:2px solid var(--border-active);font-weight:700;position:sticky;top:0}.freq-th-note{z-index:3;min-width:50px;position:sticky;left:0}.freq-note-cell{padding:var(--space-sm)var(--space-md);background:var(--bg-tertiary);color:var(--accent-violet);text-align:center;z-index:1;transition:background var(--transition-fast);font-weight:700;position:sticky;left:0}.freq-note-cell.highlighted{background:#a78bfa26}.freq-cell{padding:var(--space-sm)var(--space-md);text-align:center;background:var(--bg-card);cursor:pointer;transition:all var(--transition-fast);border-bottom:1px solid #6366f114}.freq-cell:hover{background:#a78bfa1f;transform:scale(1.02)}.freq-cell.playing{background:#6366f140;box-shadow:inset 0 0 12px #6366f14d}.freq-cell.reference{border:2px solid var(--accent-amber);background:#fbbf2414}.freq-cell.out-of-range{opacity:.3;cursor:default}.freq-value{color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:500}.freq-hz{color:var(--text-muted);margin-left:2px;font-size:.7rem}.freq-info-section{gap:var(--space-md);margin-bottom:var(--space-2xl);grid-template-columns:repeat(auto-fit,minmax(260px,1fr));display:grid}.freq-info-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg)}.freq-info-card h3{margin-bottom:var(--space-sm);font-size:1rem}.freq-info-card p{color:var(--text-secondary);font-size:.875rem;line-height:1.6}.chromatic-grid{gap:var(--space-xs);padding:var(--space-md)0 var(--space-xl);flex-wrap:wrap;justify-content:center;display:flex;overflow-x:auto}.chromatic-note-card{padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;min-width:80px;transition:all var(--transition-fast);flex-direction:column;align-items:center;display:flex;position:relative}.chromatic-note-card:hover{border-color:var(--border-active);box-shadow:var(--glow-violet);transform:translateY(-4px)}.chromatic-note-card.playing{box-shadow:var(--glow-indigo);background:#6366f133}.chromatic-note-card.root{border-color:var(--accent-violet);background:#a78bfa1a}.chromatic-note-name{color:var(--text-heading);font-size:1.3rem;font-weight:700}.chromatic-semitone{color:var(--accent-violet);margin-top:var(--space-xs);font-size:.75rem;font-weight:600}.chromatic-interval{color:var(--text-muted);text-align:center;margin-top:var(--space-xs);font-size:.65rem}.chromatic-step-bridge{color:var(--accent-pink);background:var(--bg-secondary);z-index:1;border-radius:4px;padding:2px 4px;font-size:.6rem;font-weight:700;position:absolute;top:50%;right:-14px;transform:translateY(-50%)}.alphabet-natural-row{justify-content:center;align-items:center;gap:var(--space-lg);padding:var(--space-xl)0;flex-wrap:wrap;display:flex}.alphabet-note-group{flex-direction:column;align-items:center;display:flex;position:relative}.alphabet-note-circle{background:var(--bg-card);border:2px solid var(--border-subtle);width:72px;height:72px;font-size:1.5rem;font-weight:800;font-family:var(--font-display);color:var(--text-heading);cursor:pointer;transition:all var(--transition-normal);border-radius:50%;justify-content:center;align-items:center;display:flex}.alphabet-note-circle:hover{border-color:var(--accent-violet);box-shadow:var(--glow-violet);transform:scale(1.1)}.alphabet-note-circle.playing{background:var(--gradient-primary);color:#fff;border-color:#0000;box-shadow:0 0 30px #6366f180}.alphabet-solfege{color:var(--text-muted);margin-top:var(--space-xs);font-size:.75rem;font-weight:500}.alphabet-step-badge{border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.7rem;font-weight:700;display:flex;position:absolute;top:25px;right:-28px}.alphabet-step-badge.whole{color:var(--accent-indigo);background:#6366f126;border:1px solid #6366f14d}.alphabet-step-badge.half{color:var(--accent-pink);background:#f472b626;border:1px solid #f472b64d}.alphabet-description{text-align:center;color:var(--text-secondary);max-width:600px;margin:0 auto var(--space-2xl);font-size:.9rem}.alphabet-chromatic-row{gap:var(--space-sm);padding-bottom:var(--space-xl);flex-wrap:wrap;justify-content:center;display:flex}.alphabet-pitch-card{padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border-subtle);cursor:pointer;min-width:68px;transition:all var(--transition-fast);flex-direction:column;align-items:center;display:flex}.alphabet-pitch-card.natural{background:var(--bg-card)}.alphabet-pitch-card.accidental{background:#a78bfa14;border-color:#a78bfa33}.alphabet-pitch-card:hover{box-shadow:var(--glow-violet);border-color:var(--border-active);transform:translateY(-3px)}.alphabet-pitch-card.playing{background:var(--gradient-primary);border-color:#0000}.alphabet-pitch-name{color:var(--text-heading);font-size:1.1rem;font-weight:700}.alphabet-pitch-card.playing .alphabet-pitch-name{color:#fff}.alphabet-enharmonic{color:var(--text-muted);margin-top:2px;font-size:.7rem}.solfege-grid{justify-content:center;gap:var(--space-md);padding-bottom:var(--space-xl);flex-wrap:wrap;display:flex}.solfege-card{padding:var(--space-lg)var(--space-md);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;min-width:100px;transition:all var(--transition-normal);flex-direction:column;align-items:center;display:flex}.solfege-card:hover{border-color:var(--border-active);box-shadow:var(--glow-violet);transform:translateY(-4px)}.solfege-card.playing{border-color:var(--accent-indigo);background:#6366f133}.solfege-syllable{font-size:1.8rem;font-weight:800;font-family:var(--font-display);background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.solfege-degree{color:var(--text-muted);margin:var(--space-xs)0;font-size:.75rem}.solfege-note{color:var(--text-heading);background:var(--bg-tertiary);border-radius:var(--radius-full);padding:2px 12px;font-size:1rem;font-weight:600}.solfege-chromatic-grid{gap:var(--space-sm);padding-bottom:var(--space-xl);flex-wrap:wrap;justify-content:center;display:flex}.solfege-chromatic-card{padding:var(--space-sm)var(--space-md);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);flex-direction:column;align-items:center;min-width:60px;display:flex}.solfege-chromatic-note{color:var(--text-muted);font-size:.75rem;font-weight:600}.solfege-chromatic-syllable{color:var(--text-heading);font-size:1rem;font-weight:700}.solfege-chromatic-alt{color:var(--accent-pink);font-size:.65rem}.degrees-display{gap:var(--space-md);padding-bottom:var(--space-2xl);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.degree-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-normal)}.degree-card:hover{border-color:var(--border-active);box-shadow:var(--glow-violet);transform:translateY(-2px)}.degree-card-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.degree-number{background:var(--gradient-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;font-weight:700;display:flex}.degree-roman{font-family:var(--font-display);color:var(--accent-violet);font-size:1.1rem;font-weight:700}.degree-card-note{font-size:2rem;font-weight:800;font-family:var(--font-display);color:var(--text-heading);margin-bottom:var(--space-xs)}.degree-card-name{color:var(--accent-emerald);margin-bottom:var(--space-sm);font-size:.85rem;font-weight:600}.degree-card-role{color:var(--text-secondary);margin-bottom:var(--space-sm);font-size:.8rem;line-height:1.5}.degree-card-movement{color:var(--text-muted);padding-top:var(--space-sm);border-top:1px solid var(--border-subtle);font-size:.75rem}.movement-label{color:var(--accent-pink);font-weight:600}.keysig-orders{gap:var(--space-lg);margin-bottom:var(--space-2xl);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));display:grid}.keysig-order-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center}.keysig-order-card h3{margin-bottom:var(--space-md);color:var(--text-heading);font-size:1.2rem}.keysig-order-notes{gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap;justify-content:center;display:flex}.keysig-order-note{padding:var(--space-xs)var(--space-md);border-radius:var(--radius-full);font-size:.9rem;font-weight:700}.keysig-order-note.sharp{color:var(--accent-indigo);background:#6366f126;border:1px solid #6366f14d}.keysig-order-note.flat{color:var(--accent-pink);background:#f472b626;border:1px solid #f472b64d}.keysig-mnemonic{color:var(--text-secondary);font-size:.85rem;font-style:italic}.keysig-grid{gap:var(--space-md);padding-bottom:var(--space-2xl);grid-template-columns:repeat(auto-fill,minmax(160px,1fr));display:grid}.keysig-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;cursor:pointer;transition:all var(--transition-normal)}.keysig-card:hover{border-color:var(--border-active);box-shadow:var(--glow-violet);transform:translateY(-2px)}.keysig-card.active{border-color:var(--accent-violet);box-shadow:var(--glow-violet)}.keysig-card-key{font-size:2rem;font-weight:800;font-family:var(--font-display);color:var(--text-heading)}.keysig-card-mode{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:.7rem}.keysig-card-count{margin:var(--space-xs)0;font-size:1rem;font-weight:600}.sharp-key .keysig-card-count{color:var(--accent-indigo)}.flat-key .keysig-card-count{color:var(--accent-pink)}.natural-key .keysig-card-count{color:var(--accent-emerald)}.keysig-card-relative{color:var(--text-secondary);font-size:.8rem}.keysig-detail{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-subtle);text-align:left}.keysig-detail-row{margin-bottom:var(--space-xs);justify-content:space-between;font-size:.8rem;display:flex}.keysig-detail-label{color:var(--text-muted)}.keysig-detail-value{color:var(--text-primary);font-weight:600}.sharps-flats-layout{gap:var(--space-xl);padding-bottom:var(--space-2xl);grid-template-columns:repeat(auto-fit,minmax(340px,1fr));display:grid}.sf-section{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-xl)}.sf-section-title{font-family:var(--font-display);text-align:center;margin-bottom:var(--space-lg);font-size:1.4rem}.sf-section-title.sharp{color:var(--accent-indigo)}.sf-section-title.flat{color:var(--accent-pink)}.sf-mnemonic-main{text-align:center;color:var(--text-secondary);margin-bottom:var(--space-lg);font-size:.95rem;line-height:1.6}.sf-mnemonic-main strong{color:var(--text-heading);font-size:1.1rem}.sf-notes-display{justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-xl);flex-wrap:wrap;display:flex}.sf-note-item{flex-direction:column;align-items:center;gap:4px;display:flex}.sf-note-number{background:var(--bg-tertiary);width:24px;height:24px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:.7rem;font-weight:600;display:flex}.sf-note-name{padding:var(--space-xs)var(--space-md);border-radius:var(--radius-full);font-size:1.2rem;font-weight:700}.sf-note-name.sharp{color:var(--accent-indigo);background:#6366f11f}.sf-note-name.flat{color:var(--accent-pink);background:#f472b61f}.sf-sub-heading{color:var(--text-heading);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-subtle);font-size:1rem}.sf-keys-list{gap:var(--space-xs);flex-direction:column;display:flex}.sf-key-row{padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);align-items:center;gap:var(--space-md);background:#ffffff05;font-size:.85rem;display:flex}.sf-key-row:hover{background:#a78bfa0f}.sf-key-name{color:var(--text-heading);min-width:80px;font-weight:600}.sf-key-count{color:var(--accent-violet);text-align:center;min-width:30px;font-weight:700}.sf-key-notes{color:var(--text-secondary);font-family:monospace;font-size:.8rem}.intervals-chart-grid{gap:var(--space-md);padding-bottom:var(--space-2xl);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.interval-chart-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-normal)}.interval-chart-card:hover{border-color:var(--border-active);box-shadow:var(--glow-violet);transform:translateY(-2px)}.interval-chart-card.playing{border-color:var(--accent-emerald);box-shadow:0 0 20px #34d3994d}.interval-chart-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.interval-chart-short{font-size:1.4rem;font-weight:800;font-family:var(--font-display);background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.interval-chart-st{color:var(--accent-violet);border-radius:var(--radius-full);background:#a78bfa1f;padding:2px 8px;font-size:.75rem;font-weight:600}.interval-chart-name{color:var(--text-heading);margin-bottom:2px;font-size:.95rem;font-weight:600}.interval-chart-quality{color:var(--text-muted);margin-bottom:var(--space-sm);font-size:.75rem}.interval-chart-notes{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);font-size:1.1rem;font-weight:700;display:flex}.interval-chart-from{color:var(--accent-indigo);border-radius:var(--radius-md);background:#6366f11f;padding:2px 10px}.interval-chart-arrow{color:var(--text-muted)}.interval-chart-to{color:var(--accent-pink);border-radius:var(--radius-md);background:#f472b61f;padding:2px 10px}.interval-chart-actions{gap:var(--space-sm);display:flex}.interval-play-btn{padding:var(--space-xs)var(--space-sm);border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-subtle);cursor:pointer;transition:all var(--transition-fast);flex:1;font-size:.75rem;font-weight:500}.interval-play-btn:hover{color:var(--text-primary);border-color:var(--border-active);background:#6366f126}.interval-play-btn.harmonic:hover{background:#f472b626}.enharmonic-piano-wrapper{padding:var(--space-xl)0;justify-content:center;display:flex;overflow-x:auto}.enharmonic-piano{gap:4px;display:flex}.enharmonic-key{padding:var(--space-md)var(--space-sm);border-radius:var(--radius-md);min-width:60px;transition:all var(--transition-fast);flex-direction:column;justify-content:flex-end;align-items:center;display:flex}.enharmonic-key.white{background:#ffffffe6;height:120px}.enharmonic-key.black{background:var(--bg-tertiary);border:1px solid var(--border-subtle);height:100px}.enharmonic-key-label{flex-direction:column;align-items:center;font-size:.85rem;font-weight:700;display:flex}.enharmonic-key.white .enharmonic-key-label{color:#1a1a3a}.enharmonic-key.black .enharmonic-key-label{color:var(--text-primary)}.enharmonic-alt{opacity:.7;font-size:.65rem;font-weight:500}.enharmonic-pairs-grid{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.enharmonic-pair-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;transition:all var(--transition-normal)}.enharmonic-pair-card:hover{border-color:var(--border-active);box-shadow:var(--glow-violet);transform:translateY(-2px)}.enharmonic-pair-card.theoretical{opacity:.8;border-style:dashed}.enharmonic-pair-notes{justify-content:center;align-items:center;gap:var(--space-md);margin-bottom:var(--space-sm);display:flex}.enharmonic-sharp{color:var(--accent-indigo);font-size:1.4rem;font-weight:800}.enharmonic-equals{color:var(--text-muted);font-size:1.2rem}.enharmonic-flat{color:var(--accent-pink);font-size:1.4rem;font-weight:800}.enharmonic-pair-desc{color:var(--text-secondary);font-size:.8rem}.bpm-display-wrapper{align-items:center;gap:var(--space-lg);padding:var(--space-xl)0;flex-direction:column;display:flex}.bpm-display{padding:var(--space-2xl);background:var(--bg-card);border:2px solid var(--border-subtle);width:220px;height:220px;transition:all var(--transition-normal);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;display:flex;box-shadow:0 0 40px #6366f126}.bpm-number{font-size:4rem;font-weight:900;font-family:var(--font-display);color:var(--bpm-color,var(--accent-violet));line-height:1}.bpm-label{color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;font-size:.9rem;font-weight:600}.bpm-tempo-marking{color:var(--text-secondary);margin-top:var(--space-xs);font-size:.85rem;font-style:italic}.bpm-tap-btn{background:var(--gradient-primary);color:#fff;justify-content:center;align-items:center;gap:var(--space-xs);cursor:pointer;width:140px;height:140px;box-shadow:var(--glow-indigo);transition:all var(--transition-normal);-webkit-user-select:none;user-select:none;border:none;border-radius:50%;flex-direction:column;display:flex}.bpm-tap-btn:hover{transform:scale(1.05);box-shadow:0 0 40px #6366f180}.bpm-tap-btn:active,.bpm-tap-btn.active{background:linear-gradient(135deg,var(--accent-emerald),var(--accent-cyan));transform:scale(.95)}.bpm-tap-icon{font-size:2rem}.bpm-tap-text{letter-spacing:.15em;font-size:1.2rem;font-weight:800}.bpm-tap-hint{opacity:.7;font-size:.65rem}.bpm-tap-count{color:var(--text-muted);height:20px;font-size:.85rem}.bpm-info-grid{justify-content:center;gap:var(--space-md);margin-top:var(--space-lg);flex-wrap:wrap;display:flex}.bpm-info-item{padding:var(--space-md)var(--space-lg);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);flex-direction:column;align-items:center;min-width:120px;display:flex}.bpm-info-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:600}.bpm-info-value{color:var(--text-heading);font-size:1.4rem;font-weight:700;font-family:var(--font-display)}.bpm-ms-input-section{align-items:center;gap:var(--space-lg);margin-bottom:var(--space-2xl);flex-direction:column;display:flex}.bpm-ms-input-group{align-items:center;gap:var(--space-sm);flex-direction:column;display:flex}.bpm-ms-input-row{align-items:center;gap:var(--space-sm);display:flex}.bpm-ms-adj-btn{background:var(--bg-card);border:1px solid var(--border-subtle);width:44px;height:44px;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;font-size:1.3rem;display:flex}.bpm-ms-adj-btn:hover{border-color:var(--border-active);box-shadow:var(--glow-violet)}.bpm-ms-input{text-align:center;width:120px;height:64px;font-size:2rem;font-weight:800;font-family:var(--font-display);background:var(--bg-card);border:2px solid var(--border-subtle);border-radius:var(--radius-lg);color:var(--text-heading);appearance:textfield}.bpm-ms-input::-webkit-outer-spin-button{appearance:none}.bpm-ms-input::-webkit-inner-spin-button{appearance:none}.bpm-ms-input:focus{border-color:var(--accent-violet);box-shadow:var(--glow-violet);outline:none}.bpm-ms-presets{gap:var(--space-xs);flex-wrap:wrap;justify-content:center;display:flex}.bpm-ms-preset{padding:var(--space-xs)var(--space-md);border-radius:var(--radius-full);background:var(--bg-card);border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:.8rem;font-weight:600}.bpm-ms-preset:hover{border-color:var(--border-active);color:var(--text-primary)}.bpm-ms-preset.active{background:var(--gradient-primary);color:#fff;border-color:#0000}.bpm-ms-results-grid{gap:var(--space-md);padding-bottom:var(--space-xl);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.bpm-ms-result-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;transition:all var(--transition-normal)}.bpm-ms-result-card:hover{border-color:var(--border-active);box-shadow:var(--glow-violet)}.bpm-ms-result-card.highlight{border-color:var(--accent-violet);background:#a78bfa14}.bpm-ms-result-header{margin-bottom:var(--space-sm);flex-direction:column;align-items:center;display:flex}.bpm-ms-symbol{font-size:1.5rem}.bpm-ms-note-name{color:var(--text-muted);font-size:.75rem;font-weight:600}.bpm-ms-result-ms{color:var(--text-heading);font-size:1.3rem;font-weight:700;font-family:var(--font-display)}.bpm-ms-result-ms span,.bpm-ms-result-sec span,.bpm-ms-result-freq span{color:var(--text-muted);font-size:.7rem;font-weight:500}.bpm-ms-result-sec{color:var(--text-secondary);margin-top:2px;font-size:.85rem}.bpm-ms-result-freq{color:var(--accent-violet);margin-top:2px;font-size:.8rem}.transposer-layout{gap:var(--space-xl);max-width:700px;padding-bottom:var(--space-2xl);flex-direction:column;margin:0 auto;display:flex}.transposer-section{gap:var(--space-sm);flex-direction:column;display:flex}.transposer-input{width:100%;padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);color:var(--text-primary);resize:vertical;transition:border-color var(--transition-fast);font-family:monospace;font-size:1.1rem}.transposer-input:focus{border-color:var(--accent-violet);box-shadow:var(--glow-violet);outline:none}.transposer-input::placeholder{color:var(--text-muted)}.transposer-controls{align-items:center;gap:var(--space-lg);flex-direction:column;display:flex}.transposer-semitone-selector{gap:var(--space-sm);grid-template-columns:repeat(6,1fr);width:100%;display:grid}.transposer-st-btn{padding:var(--space-sm);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;align-items:center;display:flex}.transposer-st-btn:hover{border-color:var(--border-active);box-shadow:var(--glow-violet)}.transposer-st-btn.active{background:var(--gradient-primary);color:#fff;border-color:#0000}.transposer-st-num{color:var(--text-heading);font-size:1.1rem;font-weight:700}.transposer-st-btn.active .transposer-st-num{color:#fff}.transposer-st-label{color:var(--text-muted);text-transform:uppercase;font-size:.6rem}.transposer-st-btn.active .transposer-st-label{color:#fffc}.transposer-output{width:100%;padding:var(--space-lg);border:2px solid var(--accent-indigo);border-radius:var(--radius-lg);color:var(--accent-violet);word-spacing:8px;background:#6366f10f;align-items:center;min-height:80px;font-family:monospace;font-size:1.3rem;font-weight:700;line-height:2;display:flex}.transposer-examples{gap:var(--space-sm);flex-direction:column;align-items:center;display:flex}.transposer-example-btns{gap:var(--space-sm);flex-wrap:wrap;justify-content:center;display:flex}@media (max-width:768px){.alphabet-natural-row{gap:var(--space-md)}.alphabet-note-circle{width:56px;height:56px;font-size:1.2rem}.alphabet-step-badge{display:none}.solfege-card{min-width:80px;padding:var(--space-md)var(--space-sm)}.solfege-syllable{font-size:1.3rem}.bpm-display{width:180px;height:180px}.bpm-number{font-size:3rem}.bpm-tap-btn{width:120px;height:120px}.transposer-semitone-selector{grid-template-columns:repeat(4,1fr)}.intervals-chart-grid{grid-template-columns:1fr}.keysig-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.chromatic-step-bridge{display:none}}.piano-key.white-key{position:relative}.piano-key.highlighted:before{content:"";background-color:var(--accent-violet);width:12px;height:12px;box-shadow:0 0 8px var(--glow-violet);z-index:10;pointer-events:none;border-radius:50%;position:absolute;bottom:40px;left:50%;transform:translate(-50%)}.piano-key.black-key.highlighted:before{background-color:var(--accent-pink);box-shadow:0 0 8px var(--glow-pink);bottom:25px}.video-bg-wrapper{z-index:-100;pointer-events:none;background-color:#000;width:100vw;height:100vh;position:fixed;top:0;left:0;overflow:hidden}.video-bg{object-fit:contain;opacity:.15;filter:blur(1.8px)contrast(9);width:100%;height:100%;transform:scale(1.2)}
