:root{--bg-darkest:#060610;--bg-dark:#0a0a18;--bg-base:#0e0e1a;--bg-elevated:#14142a;--bg-surface:#1a1a35;--bg-hover:#22223d;--accent-primary:#06f;--accent-hover:#38f;--accent-light:#6af;--accent-subtle:#0066ff1a;--accent-glow:#0066ff40;--accent-gradient:linear-gradient(135deg, #04c, #08f);--pro-primary:#f80;--pro-hover:orange;--pro-light:#fc3;--pro-subtle:#ff88001a;--pro-glow:#ff880040;--pro-gradient:linear-gradient(135deg, #f60, #fa0);--text-primary:#f0f0f5;--text-secondary:#8888a0;--text-muted:#55556a;--text-accent:#6af;--border-subtle:#ffffff0a;--border-default:#ffffff12;--border-hover:#ffffff20;--border-accent:#06f4;--font-family:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--fs-xs:.75rem;--fs-sm:.875rem;--fs-base:1rem;--fs-md:1.125rem;--fs-lg:1.25rem;--fs-xl:1.5rem;--fs-2xl:2rem;--fs-3xl:2.5rem;--fs-4xl:3rem;--fw-normal:400;--fw-medium:500;--fw-semibold:600;--fw-bold:700;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px var(--accent-glow);--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--transition-spring:.3s cubic-bezier(.34, 1.56, .64, 1);--sidebar-width:260px;--sidebar-collapsed:72px;--header-height:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility}body{min-height:100vh;font-family:var(--font-family);font-size:var(--fs-base);font-weight:var(--fw-normal);color:var(--text-primary);background-color:var(--bg-darkest);line-height:1.6}img,svg,video{max-width:100%;display:block}button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}input,textarea,select{font:inherit;color:inherit;background:0 0;border:none;outline:none}h1,h2,h3,h4,h5,h6{line-height:1.2;font-weight:var(--fw-bold)}#app{grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:var(--header-height) 1fr auto;grid-template-areas:"sidebar header""sidebar main""sidebar footer";width:100%;min-height:100vh;display:grid}.app-header{z-index:100;padding:0 var(--space-xl);height:var(--header-height);background-color:var(--bg-dark);border-bottom:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);grid-area:header;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.app-sidebar{width:var(--sidebar-width);height:100vh;padding:var(--space-lg);background-color:var(--bg-base);border-right:1px solid var(--border-subtle);z-index:200;transition:transform var(--transition-base);grid-area:sidebar;position:fixed;top:0;left:0;overflow-y:auto}.app-main{padding:var(--space-2xl);grid-area:main;min-height:0;overflow-y:auto}.app-footer{padding:var(--space-lg) var(--space-xl);color:var(--text-muted);font-size:var(--fs-sm);border-top:1px solid var(--border-subtle);grid-area:footer;justify-content:center;align-items:center;display:flex}.footer-link{color:var(--text-accent);transition:color var(--transition-fast);text-decoration:none}.footer-link:hover{color:var(--accent-hover);text-decoration:underline}.page-container{animation:fadeSlideIn var(--transition-slow) ease both}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.sidebar-overlay{z-index:150;opacity:0;transition:opacity var(--transition-base);background:#0009;display:none;position:fixed;inset:0}.sidebar-overlay.active{opacity:1;display:block}@media (width<=768px){#app{grid-template-columns:1fr;grid-template-areas:"header""main""footer"}.app-sidebar{transform:translate(-100%)}.app-sidebar.open{transform:translate(0)}.app-main{padding:var(--space-lg)}}.btn{align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);font-size:var(--fs-sm);font-weight:var(--fw-semibold);transition:all var(--transition-fast);white-space:nowrap;padding:.65em 1.4em;display:inline-flex}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-ghost{border:1px solid var(--border-default);color:var(--text-secondary)}.btn-ghost:hover{border-color:var(--accent-primary);color:var(--text-accent);background:var(--accent-subtle)}.tool-card{gap:var(--space-md);padding:var(--space-xl);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-base);flex-direction:column;text-decoration:none;display:flex;position:relative;overflow:hidden}.tool-card:before{content:"";border-radius:inherit;background:linear-gradient(135deg, var(--accent-subtle), transparent 60%);opacity:0;transition:opacity var(--transition-base);position:absolute;inset:0}.tool-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow);transform:translateY(-4px)}.tool-card:hover:before{opacity:1}.tool-card--pro{border-color:var(--pro-subtle)}.tool-card--pro:before{background:linear-gradient(135deg, var(--pro-subtle), transparent 60%)}.tool-card--pro:hover{border-color:var(--pro-primary);box-shadow:var(--pro-glow)}.tool-card--pro .tool-card__icon{background:var(--pro-subtle);color:var(--pro-primary)}.tool-card--pro:hover .tool-card__icon{background:var(--pro-glow)}.pro-badge{background:var(--pro-gradient);color:#fff;text-align:center;text-transform:uppercase;letter-spacing:1px;z-index:10;pointer-events:none;width:100px;padding:4px 0;font-size:10px;font-weight:800;position:absolute;top:12px;right:-32px;transform:rotate(45deg);box-shadow:0 2px 4px #0000004d}.tool-card__icon{border-radius:var(--radius-md);background:var(--accent-subtle);width:56px;height:56px;font-size:var(--fs-2xl);transition:background var(--transition-base), color var(--transition-base);justify-content:center;align-items:center;display:flex;position:relative}.tool-card:hover .tool-card__icon{background:var(--accent-glow)}.tool-card__title{font-size:var(--fs-lg);font-weight:var(--fw-semibold);color:var(--text-primary);position:relative}.tool-card__desc{font-size:var(--fs-sm);color:var(--text-secondary);line-height:1.5;position:relative}.nav-item{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--fs-sm);font-weight:var(--fw-medium);transition:all var(--transition-fast);cursor:pointer;display:flex}.nav-item:hover{color:var(--text-primary);background:var(--bg-hover)}.nav-item.active{color:var(--text-accent);background:var(--accent-subtle);border-left:3px solid var(--accent-primary)}.nav-item__icon{font-size:var(--fs-lg);text-align:center;flex-shrink:0;width:24px}.sidebar-brand{align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;margin-bottom:var(--space-xl);display:flex}.sidebar-brand__icon{border-radius:var(--radius-md);background:var(--accent-gradient);width:40px;height:40px;font-size:var(--fs-xl);justify-content:center;align-items:center;display:flex}.sidebar-brand__text{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--text-primary)}.sidebar-brand__sub{font-size:var(--fs-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.sidebar-section{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;padding:var(--space-lg) var(--space-md) var(--space-sm)}.badge{border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:var(--fw-semibold);align-items:center;padding:.2em .7em;display:inline-flex}.badge--accent{background:var(--accent-subtle);color:var(--text-accent);border:1px solid var(--border-accent)}.badge--soon{color:#fa4;background:#ff880018;border:1px solid #ff880030}.page-header{margin-bottom:var(--space-2xl)}.page-header__title{font-size:var(--fs-3xl);font-weight:var(--fw-bold);color:var(--text-primary);margin-bottom:var(--space-sm)}.page-header__desc{font-size:var(--fs-md);color:var(--text-secondary);max-width:560px}.tools-grid{gap:var(--space-xl);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.hamburger{color:var(--text-primary);cursor:pointer;transition:color var(--transition-fast);padding:0;font-size:2rem;line-height:1;display:none}.hamburger:hover{color:var(--accent-primary)}@media (width<=768px){.hamburger{display:inline-block}}.header-search{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-full);min-width:240px;transition:border-color var(--transition-fast);display:flex}.header-search:focus-within{border-color:var(--accent-primary)}.header-search input{width:100%;font-size:var(--fs-sm);color:var(--text-primary)}.header-search input::placeholder{color:var(--text-muted)}@media (width<=768px){.header-search{display:none}}.tool-placeholder{text-align:center;justify-content:center;align-items:center;gap:var(--space-lg);padding:var(--space-3xl) var(--space-xl);flex-direction:column;min-height:400px;display:flex}.tool-placeholder__icon{font-size:4rem;line-height:1;animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.tool-placeholder__title{font-size:var(--fs-2xl);font-weight:var(--fw-bold);color:var(--text-primary)}.tool-placeholder__desc{font-size:var(--fs-md);color:var(--text-secondary);max-width:420px}.chord-filters{gap:var(--space-sm);margin-bottom:var(--space-xl);flex-wrap:wrap;display:flex}.chord-tab{border-radius:var(--radius-full);font-size:var(--fs-sm);font-weight:var(--fw-medium);border:1px solid var(--border-default);color:var(--text-secondary);background:var(--bg-elevated);cursor:pointer;transition:all var(--transition-fast);padding:.45em 1.1em}.chord-tab:hover{border-color:var(--accent-primary);color:var(--text-accent);background:var(--accent-subtle)}.chord-tab.active{background:var(--accent-gradient);color:#fff;box-shadow:var(--shadow-sm);border-color:#0000}.chord-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(140px,1fr));display:grid}.chord-card{align-items:center;gap:var(--space-sm);padding:var(--space-lg) var(--space-md) var(--space-md);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-base);flex-direction:column;animation:.25s both fadeScaleIn;display:flex}.chord-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow);transform:translateY(-3px)}.chord-card--hidden{display:none!important}@keyframes fadeScaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.chord-card__diagram{width:100%;max-width:120px}.chord-svg{width:100%;height:auto;display:block}.chord-card__info{flex-direction:column;align-items:center;gap:2px;display:flex}.chord-card__name{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--text-primary);line-height:1}.chord-card__full{font-size:var(--fs-xs);color:var(--text-muted)}.lang-selector{border:1px solid var(--border-default);border-radius:var(--radius-full);background:var(--bg-elevated);align-items:center;display:flex;overflow:hidden}.lang-btn{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;letter-spacing:.04em;background:0 0;border:none;padding:.3em .75em}.lang-btn:hover{color:var(--text-accent);background:var(--accent-subtle)}.lang-btn.active{background:var(--accent-gradient);color:#fff}@media (width<=480px){.lang-btn{padding:.3em .5em}}.tuner-phase.hidden,.page-header.hidden{display:none}.tuning-presets-grid{gap:var(--space-lg);width:100%;margin-top:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.tuning-preset-card{align-items:center;gap:var(--space-sm);padding:var(--space-xl) var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);text-align:center;flex-direction:column;display:flex}.tuning-preset-card:hover{border-color:var(--border-accent);background:var(--bg-surface);box-shadow:var(--shadow-glow);transform:translateY(-4px)}.tuning-preset-card__icon{font-size:2.5rem;line-height:1}.tuning-preset-card__name{font-size:var(--fs-lg);font-weight:var(--fw-semibold);color:var(--text-primary)}.tuning-preset-card__desc{font-size:var(--fs-sm);color:var(--text-secondary);font-family:var(--font-mono)}.tuner-grid{gap:var(--space-md);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);width:100%;max-height:calc(100vh - 100px);padding:var(--space-md);grid-template:"topbar topbar topbar""left center right"1fr/260px 1fr 260px;display:grid;overflow:hidden}.tuner-grid__topbar{justify-content:space-between;align-items:center;gap:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-subtle);grid-area:topbar;display:flex}.tuner-grid__left{justify-content:space-between;gap:var(--space-md);flex-direction:column;grid-area:left;min-height:0;display:flex;overflow:hidden}.tuner-grid__center{justify-content:center;align-items:center;gap:var(--space-sm);flex-direction:column;grid-area:center;min-height:0;display:flex;overflow:hidden}.tuner-grid__right{gap:var(--space-md);flex-direction:column;grid-area:right;min-height:0;display:flex;overflow:hidden}.tuner-panel{gap:var(--space-sm);flex-direction:column;flex:1;min-height:0;display:flex}.tuner-panel__label{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.tuner-progress{align-items:center;gap:var(--space-sm);flex:1;max-width:320px;display:flex}.tuner-progress__text{font-size:var(--fs-sm);color:var(--text-secondary);font-weight:var(--fw-medium);white-space:nowrap}.tuner-progress__bar{background:var(--bg-surface);border-radius:var(--radius-full);flex:1;height:5px;overflow:hidden}.tuner-progress__fill{background:var(--accent-gradient);border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow)}.tuner-target{padding:var(--space-md);background:var(--accent-subtle);border:1px solid var(--border-accent);border-radius:var(--radius-lg);text-align:center;flex-direction:column;align-items:center;gap:2px;display:flex}.tuner-target__label{font-size:var(--fs-xs);color:var(--text-accent);text-transform:uppercase;letter-spacing:.08em;font-weight:var(--fw-semibold)}.tuner-target__note{font-size:var(--fs-2xl);font-weight:var(--fw-bold);color:var(--text-primary);font-family:var(--font-mono)}.tuner-target__string{font-size:var(--fs-xs);color:var(--text-secondary)}.tuner-gauge{flex-shrink:0;width:320px;height:180px;position:relative}.tuner-gauge__svg{width:100%;height:100%;overflow:visible}.tuner-gauge__needle{transform-origin:180px 180px;transition:transform .12s ease-out}.tuner-gauge__needle line{stroke:var(--text-primary);stroke-width:2.5px;stroke-linecap:round}.tuner-gauge__needle circle{fill:var(--text-primary)}.tuner-gauge[data-state=in-tune] .tuner-gauge__needle line{stroke:#2c6}.tuner-gauge[data-state=in-tune] .tuner-gauge__needle circle{fill:#2c6}.tuner-gauge[data-state=flat] .tuner-gauge__needle line{stroke:#f64}.tuner-gauge[data-state=flat] .tuner-gauge__needle circle{fill:#f64}.tuner-gauge[data-state=sharp] .tuner-gauge__needle line{stroke:#fa2}.tuner-gauge[data-state=sharp] .tuner-gauge__needle circle{fill:#fa2}.tuner-note{text-align:center}.tuner-note__name{font-size:4rem;font-weight:var(--fw-bold);color:var(--text-primary);transition:color var(--transition-fast);letter-spacing:-.02em;line-height:1}.tuner-note__name span{color:var(--text-secondary);vertical-align:super;font-size:2rem}.tuner-note__freq{font-size:var(--fs-base);color:var(--text-secondary);font-family:var(--font-mono);margin-top:2px}.tuner-state{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:var(--fs-sm);font-weight:var(--fw-semibold);transition:all var(--transition-base);min-height:32px;display:flex}.tuner-state i{font-size:1.2em}.tuner-state[data-state=idle]{background:var(--bg-surface);color:var(--text-muted)}.tuner-state[data-state=listening]{background:var(--accent-subtle);color:var(--text-accent);animation:2s ease-in-out infinite pulse-border}.tuner-state[data-state=in-tune]{color:#2c6;background:#22cc6620;box-shadow:0 0 20px #22cc6630}.tuner-state[data-state=flat]{color:#f64;background:#ff664420}.tuner-state[data-state=sharp]{color:#fa2;background:#ffaa2220}@keyframes pulse-border{0%,to{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 12px 4px var(--accent-glow)}}.tuner-cents{font-size:var(--fs-lg);font-weight:var(--fw-semibold);font-family:var(--font-mono);color:var(--text-secondary)}.tuner-strings-guided{gap:var(--space-xs);flex-direction:column;display:flex}.tuner-string-step{align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-elevated);transition:all var(--transition-base);display:flex}.tuner-string-step__num{border-radius:var(--radius-full);width:28px;height:28px;font-size:var(--fs-sm);font-weight:var(--fw-bold);color:var(--text-muted);background:var(--bg-surface);flex-shrink:0;justify-content:center;align-items:center;display:flex}.tuner-string-step__num i{font-size:1rem}.tuner-string-step__note{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-secondary);flex:1}.tuner-string-step__note sub{font-size:.7em}.tuner-string-step__freq{font-size:var(--fs-xs);color:var(--text-muted);font-family:var(--font-mono)}.tuner-string-step.pending{opacity:.45}.tuner-string-step.current{border-color:var(--accent-primary);background:var(--accent-subtle);opacity:1;animation:2s ease-in-out infinite pulse-string}.tuner-string-step.current .tuner-string-step__num{background:var(--accent-primary);color:#fff}.tuner-string-step.current .tuner-string-step__note{color:var(--text-accent)}@keyframes pulse-string{0%,to{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 12px 2px var(--accent-glow)}}.tuner-string-step.tuned{opacity:1;background:#22cc6610;border-color:#2c6}.tuner-string-step.tuned .tuner-string-step__num{color:#fff;background:#2c6}.tuner-string-step.tuned .tuner-string-step__note{color:#2c6}.tuner-waveform{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);flex:1;width:100%;min-height:0}.tuner-tips{gap:var(--space-xs);flex-direction:column;display:flex}.tuner-tips__item{align-items:flex-start;gap:var(--space-sm);font-size:var(--fs-xs);color:var(--text-muted);padding:var(--space-xs) var(--space-sm);background:var(--bg-surface);border-radius:var(--radius-sm);line-height:1.4;display:flex}.tuner-tips__item i{color:var(--text-accent);flex-shrink:0;font-size:1.1em}.tuner-share-btn{align-items:center;gap:var(--space-xs);border-radius:var(--radius-full);color:#fff;font-size:var(--fs-sm);font-weight:var(--fw-semibold);transition:all var(--transition-fast);white-space:nowrap;background:#25d366;flex-shrink:0;padding:.4em 1em;display:inline-flex}.tuner-share-btn:hover{background:#20bf5a;transform:translateY(-1px);box-shadow:0 4px 16px #25d3664d}.tuner-share-btn--lg{font-size:var(--fs-base);padding:.7em 1.8em}.tuner-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;justify-content:center;align-items:center;animation:.3s both modal-fade-in;display:flex;position:fixed;inset:0}.tuner-modal-overlay.hidden{display:none}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.tuner-modal{align-items:center;gap:var(--space-lg);text-align:center;padding:var(--space-3xl) var(--space-2xl);background:var(--bg-elevated);border:1px solid var(--border-accent);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg), 0 0 40px var(--accent-glow);flex-direction:column;width:90%;max-width:440px;animation:.4s cubic-bezier(.34,1.56,.64,1) both modal-slide-up;display:flex}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(40px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.tuner-modal__icon{font-size:4rem;line-height:1;animation:1s ease-in-out celebrate}@keyframes celebrate{0%{transform:scale(0)rotate(-20deg)}50%{transform:scale(1.3)rotate(10deg)}to{transform:scale(1)rotate(0)}}.tuner-modal__title{font-size:var(--fs-2xl);font-weight:var(--fw-bold);color:#2c6}.tuner-modal__desc{font-size:var(--fs-base);color:var(--text-secondary);line-height:1.5}.tuner-modal__desc strong{color:var(--text-accent)}.tuner-modal__sub{font-size:var(--fs-lg);color:var(--text-primary)}.tuner-modal__actions{align-items:center;gap:var(--space-md);margin-top:var(--space-md);flex-direction:column;width:100%;display:flex}.tuner-section-label{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;align-self:flex-start}@media (width<=900px){.tuner-grid{grid-template:"topbar topbar""center center""left right"/1fr 1fr}.tuner-gauge{width:260px;height:150px}.tuner-note__name{font-size:3rem}}@media (width<=600px){.tuner-grid{gap:var(--space-sm);background:0 0;border:none;border-radius:0;flex-direction:column;max-height:none;padding:0;display:flex;overflow:visible}.tuner-grid__topbar{gap:var(--space-xs);padding-bottom:var(--space-xs);border-bottom:1px solid var(--border-subtle);flex-wrap:wrap}.tuner-grid__topbar .btn{font-size:var(--fs-xs);padding:.3em .6em}.tuner-share-btn{font-size:var(--fs-xs);padding:.3em .8em}.tuner-progress{order:-1;width:100%;max-width:none}.tuner-grid__center{padding:var(--space-sm) 0;align-items:center;gap:2px}.tuner-gauge{width:200px;height:120px}.tuner-note__name{font-size:2.5rem}.tuner-note__name span{font-size:1.2rem}.tuner-note__freq{font-size:var(--fs-sm)}.tuner-cents{font-size:var(--fs-base)}.tuner-state{font-size:var(--fs-xs);padding:var(--space-xs) var(--space-sm)}.tuner-target{padding:var(--space-sm)}.tuner-target__note{font-size:var(--fs-xl)}.tuner-target__label{font-size:.6rem}.tuner-target__string{font-size:.65rem}.tuner-strings-guided{justify-content:center;gap:var(--space-xs);flex-flow:wrap}.tuner-string-step{width:auto;min-width:44px;padding:var(--space-xs);text-align:center;flex-direction:column;gap:2px}.tuner-string-step__num{width:22px;height:22px;font-size:var(--fs-xs)}.tuner-string-step__note{font-size:var(--fs-xs)}.tuner-string-step__freq{display:none}.tuner-grid__left{justify-content:flex-start;gap:var(--space-sm)}.tuner-waveform{min-height:60px;max-height:80px}.tuner-tips__item{padding:4px var(--space-xs);font-size:.65rem}.tuner-panel__label{font-size:.6rem}}.metro-layout{align-items:center;gap:var(--space-xl);flex-direction:column;max-width:680px;margin:0 auto;display:flex}.metro-visualizer{justify-content:center;align-items:center;gap:var(--space-md);min-height:56px;display:flex}.metro-dot{background:var(--bg-surface);border:2px solid var(--border-default);width:40px;height:40px;transition:background var(--transition-fast), border-color var(--transition-fast), transform 80ms ease, box-shadow 80ms ease;border-radius:50%}.metro-dot.accent{border-color:var(--accent-primary)}.metro-dot.active{background:var(--accent-primary);border-color:var(--accent-primary);box-shadow:0 0 18px var(--accent-glow);transform:scale(1.2)}.metro-dot.accent.active{background:var(--accent-hover);box-shadow:0 0 28px var(--accent-primary);transform:scale(1.35)}.metro-bpm-block{align-items:center;gap:var(--space-lg);display:flex}.metro-bpm-display{flex-direction:column;align-items:center;display:flex}.metro-bpm-input{text-align:center;width:140px;font-size:4.5rem;font-weight:var(--fw-bold);color:var(--text-primary);font-family:var(--font-mono);appearance:textfield;background:0 0;border:none;outline:none;line-height:1}.metro-bpm-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.metro-bpm-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.metro-bpm-label{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em}.metro-adj-btn{border:1px solid var(--border-default);background:var(--bg-elevated);width:44px;height:44px;color:var(--text-secondary);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:1.5rem;display:flex}.metro-adj-btn:hover{border-color:var(--accent-primary);color:var(--text-accent);background:var(--accent-subtle)}.metro-adj-btn:active{transform:scale(.92)}.metro-slider-wrap{align-items:center;gap:var(--space-md);width:100%;max-width:480px;display:flex}.metro-slider-label{font-size:var(--fs-xs);color:var(--text-muted);text-align:center;min-width:28px}.metro-slider{appearance:none;border-radius:var(--radius-full);background:var(--bg-surface);cursor:pointer;outline:none;flex:1;height:6px}.metro-slider::-webkit-slider-thumb{appearance:none;background:var(--accent-gradient);width:20px;height:20px;box-shadow:0 0 6px var(--accent-glow);cursor:grab;transition:box-shadow var(--transition-fast), transform var(--transition-fast);border-radius:50%}.metro-slider::-webkit-slider-thumb:active{cursor:grabbing;box-shadow:0 0 14px var(--accent-primary);transform:scale(1.2)}.metro-slider::-moz-range-thumb{background:var(--accent-gradient);cursor:grab;border:none;border-radius:50%;width:20px;height:20px}.metro-controls-row{justify-content:center;align-items:center;gap:var(--space-xl);width:100%;display:flex}.metro-play-btn{background:var(--accent-gradient);cursor:pointer;width:80px;height:80px;box-shadow:0 4px 20px var(--accent-glow);transition:transform var(--transition-spring), box-shadow var(--transition-base);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.metro-play-btn:after{content:"";border:2px solid var(--accent-primary);opacity:0;transition:opacity var(--transition-base), transform var(--transition-base);border-radius:50%;position:absolute;inset:-4px}.metro-play-btn.playing:after{opacity:1;animation:1s infinite metro-ring;transform:scale(1.1)}@keyframes metro-ring{0%,to{opacity:.7;transform:scale(1.05)}50%{opacity:.2;transform:scale(1.18)}}.metro-play-btn:hover{box-shadow:0 6px 30px var(--accent-primary);transform:scale(1.07)}.metro-play-btn:active{transform:scale(.95)}.metro-play-icon{color:#fff;width:28px;height:28px}.metro-tap-btn{border-radius:var(--radius-lg);border:2px solid var(--border-default);background:var(--bg-elevated);width:68px;height:68px;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;justify-content:center;align-items:center;gap:2px;display:flex}.metro-tap-btn span{font-size:var(--fs-md);font-weight:var(--fw-bold)}.metro-tap-btn small{font-size:var(--fs-xs);color:var(--text-muted)}.metro-tap-btn:hover{border-color:var(--accent-primary);background:var(--accent-subtle);color:var(--text-accent)}.metro-tap-btn:active{background:var(--accent-glow);transform:scale(.93)}.metro-volume-wrap{align-items:center;gap:var(--space-sm);display:flex}.metro-vol-icon{font-size:var(--fs-base)}.metro-vol-slider{flex:none;width:90px}.metro-section{width:100%}.metro-section__label{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-sm)}.metro-chip-row{gap:var(--space-sm);flex-wrap:wrap;display:flex}.metro-chip{border-radius:var(--radius-full);border:1px solid var(--border-default);background:var(--bg-elevated);color:var(--text-secondary);font-size:var(--fs-sm);font-weight:var(--fw-medium);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;padding:.4em 1em}.metro-chip:hover{border-color:var(--accent-primary);color:var(--text-accent);background:var(--accent-subtle)}.metro-chip.active{background:var(--accent-gradient);color:#fff;box-shadow:var(--shadow-sm);border-color:#0000}.metro-presets-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(120px,1fr));display:grid}.metro-preset{padding:var(--space-md) var(--space-sm);border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-elevated);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;align-items:center;gap:3px;display:flex}.metro-preset:hover{border-color:var(--border-accent);background:var(--accent-subtle);transform:translateY(-2px)}.metro-preset.active{border-color:var(--accent-primary);background:var(--accent-subtle);box-shadow:0 0 12px var(--accent-glow)}.metro-preset__name{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-primary)}.metro-preset__bpm{font-size:var(--fs-xs);color:var(--text-accent);font-family:var(--font-mono)}kbd{border:1px solid var(--border-default);border-radius:var(--radius-sm);font-size:.8em;font-family:var(--font-mono);color:var(--text-secondary);background:var(--bg-elevated);padding:.1em .45em;display:inline-block}@media (width<=560px){.metro-bpm-input{width:110px;font-size:3.5rem}.metro-play-btn{width:68px;height:68px}.metro-tap-btn{width:58px;height:58px}.metro-vol-slider{width:70px}.metro-presets-grid{grid-template-columns:repeat(auto-fill,minmax(95px,1fr))}}.scale-intro{gap:var(--space-xl);padding:var(--space-xl);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:var(--space-2xl);grid-template-columns:1fr 1fr;display:grid}@media (width<=640px){.scale-intro{grid-template-columns:1fr}}.scale-intro__title{font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--text-primary);margin-bottom:var(--space-md)}.scale-intro__text p{font-size:var(--fs-sm);color:var(--text-secondary);margin-bottom:var(--space-sm);line-height:1.7}.scale-intro__text strong{color:var(--text-accent);font-weight:var(--fw-semibold)}.scale-intro__legend{justify-content:center;gap:var(--space-md);padding-left:var(--space-xl);border-left:1px solid var(--border-subtle);flex-direction:column;display:flex}@media (width<=640px){.scale-intro__legend{border-left:none;border-top:1px solid var(--border-subtle);padding-left:0;padding-top:var(--space-lg)}}.scale-legend-item{align-items:center;gap:var(--space-md);font-size:var(--fs-sm);color:var(--text-secondary);display:flex}.scale-legend-item--tip{padding:var(--space-sm) var(--space-md);background:var(--accent-subtle);border-radius:var(--radius-md);color:var(--text-accent);font-size:var(--fs-xs)}.scale-legend-dot{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:8px;font-weight:700;display:flex}.scale-legend-dot.root{background:var(--accent-primary);border:2px solid #fff}.scale-legend-dot.note{background:var(--accent-subtle);border:2px solid var(--accent-primary)}.scale-nav{gap:var(--space-sm);margin-bottom:var(--space-2xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;display:flex}.scale-nav-link{border-radius:var(--radius-full);border:1px solid var(--border-default);background:var(--bg-elevated);color:var(--text-secondary);font-size:var(--fs-sm);font-weight:var(--fw-medium);transition:all var(--transition-fast);white-space:nowrap;padding:.4em 1em;text-decoration:none}.scale-nav-link:hover{border-color:var(--accent-primary);color:var(--text-accent);background:var(--accent-subtle)}.scale-section{margin-bottom:var(--space-3xl);scroll-margin-top:calc(var(--header-height) + var(--space-lg))}.scale-section__header{margin-bottom:var(--space-xl)}.scale-section__title{font-size:var(--fs-2xl);font-weight:var(--fw-bold);color:var(--text-primary);margin-bottom:var(--space-sm)}.scale-section__desc{font-size:var(--fs-sm);color:var(--text-secondary);max-width:640px;line-height:1.65}.scale-cards-grid{gap:var(--space-xl);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}@media (width<=480px){.scale-cards-grid{grid-template-columns:1fr}}.scale-card{gap:var(--space-md);padding:var(--space-xl);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:border-color var(--transition-base), box-shadow var(--transition-base);border-left:3px solid var(--scale-color,var(--accent-primary));flex-direction:column;display:flex}.scale-card:hover{border-color:var(--border-accent);box-shadow:0 0 20px var(--accent-glow)}.scale-card__header{justify-content:space-between;align-items:flex-start;gap:var(--space-md);display:flex}.scale-card__name{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--text-primary);margin-bottom:4px}.scale-card__intervals{font-size:var(--fs-xs);color:var(--scale-color,var(--text-accent));font-family:var(--font-mono);letter-spacing:.03em}.scale-card__tags{flex-shrink:0}.scale-tag{border-radius:var(--radius-sm);background:var(--bg-surface);border:1px solid var(--border-default);font-size:var(--fs-xs);font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap;padding:.2em .6em;display:inline-block}.scale-card__desc{font-size:var(--fs-sm);color:var(--text-secondary);line-height:1.65}.scale-card__diagram{margin-top:var(--space-sm)}.scale-diagram-label{font-size:var(--fs-xs);color:var(--text-muted);margin-bottom:var(--space-sm);font-weight:var(--fw-medium)}.scale-svg{border-radius:var(--radius-md);background:var(--bg-surface);width:100%;height:auto;padding:4px;display:block}.scale-legend{gap:var(--space-lg);margin-top:var(--space-sm);display:flex}.scale-legend__root,.scale-legend__note{font-size:var(--fs-xs);color:var(--text-muted)}.scale-legend__root{color:var(--scale-color,var(--accent-primary));font-weight:var(--fw-semibold)}.modal-backdrop{z-index:1000;opacity:0;pointer-events:none;transition:opacity var(--transition-base);padding:var(--space-lg);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-backdrop.visible{opacity:1;pointer-events:all}.modal-box{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-2xl);width:100%;max-width:400px;transition:transform var(--transition-base);transform:translateY(12px);box-shadow:0 24px 60px #00000080}.modal-backdrop.visible .modal-box{transform:translateY(0)}.modal-header{margin-bottom:var(--space-xl);justify-content:space-between;align-items:center;display:flex}.modal-brand{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--text-primary)}.modal-close{color:var(--text-muted);font-size:var(--fs-lg);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast);background:0 0;border:none;padding:4px 8px}.modal-close:hover{color:var(--text-primary)}.modal-tabs{border-bottom:1px solid var(--border-subtle);margin-bottom:var(--space-xl);gap:0;display:flex}.modal-tab{padding:var(--space-sm) 0;color:var(--text-muted);font-size:var(--fs-sm);font-weight:var(--fw-medium);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-1px}.modal-tab.active{color:var(--text-accent);border-bottom-color:var(--accent-primary)}.btn-google{justify-content:center;align-items:center;gap:var(--space-md);width:100%;padding:.7em var(--space-lg);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--fs-sm);font-weight:var(--fw-medium);cursor:pointer;transition:all var(--transition-fast);display:flex}.btn-google:hover{background:var(--bg-hover);border-color:var(--border-accent)}.modal-divider{align-items:center;gap:var(--space-md);margin:var(--space-lg) 0;color:var(--text-muted);font-size:var(--fs-xs);display:flex}.modal-divider:before,.modal-divider:after{content:"";border-top:1px solid var(--border-subtle);flex:1}.modal-error{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:#ff6b6b;font-size:var(--fs-xs);margin-bottom:var(--space-md);background:#ff3c3c1f;border:1px solid #ff3c3c4d}.modal-form{gap:var(--space-md);flex-direction:column;display:flex}.modal-field{flex-direction:column;gap:6px;display:flex}.modal-field label{font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--text-secondary)}.modal-field input{padding:.6em var(--space-md);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--fs-sm);transition:border-color var(--transition-fast)}.modal-field input:focus{border-color:var(--accent-primary);outline:none}.btn-primary-full{background:var(--accent-gradient);border-radius:var(--radius-md);color:#fff;width:100%;font-size:var(--fs-sm);font-weight:var(--fw-semibold);cursor:pointer;transition:opacity var(--transition-fast);border:none;padding:.7em}.btn-primary-full:hover{opacity:.88}.btn-primary-full:disabled{opacity:.5;cursor:not-allowed}.modal-link{color:var(--text-muted);font-size:var(--fs-xs);cursor:pointer;text-align:center;transition:color var(--transition-fast);background:0 0;border:none;text-decoration:underline}.modal-link:hover{color:var(--text-accent)}.header-avatar{background:var(--accent-gradient);cursor:pointer;width:32px;height:32px;transition:transform var(--transition-fast), box-shadow var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;text-decoration:none;display:flex;position:relative}.header-avatar:hover{box-shadow:0 0 0 2px var(--accent-primary);transform:scale(1.08)}.header-avatar__letter{font-size:var(--fs-sm);font-weight:var(--fw-bold);color:#fff;line-height:1}.header-avatar__crown{font-size:10px;position:absolute;top:-6px;right:-6px}.sidebar-divider{background:var(--border-subtle);height:1px;margin:var(--space-md) 0}.sidebar-pro-tag{font-size:9px;font-weight:var(--fw-bold);letter-spacing:.06em;border-radius:var(--radius-sm);background:var(--pro-gradient);color:#fff;margin-left:auto;padding:2px 6px}.account-loading{justify-content:center;align-items:center;height:200px;display:flex}.spinner{border:3px solid var(--border-subtle);border-top-color:var(--accent-primary);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.account-layout{gap:var(--space-2xl);flex-direction:column;max-width:640px;display:flex}.account-user-card{align-items:center;gap:var(--space-lg);padding:var(--space-xl);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);display:flex}.acct-avatar{background:var(--accent-gradient);width:56px;height:56px;font-size:var(--fs-2xl);font-weight:var(--fw-bold);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.acct-name{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--text-primary)}.acct-email{font-size:var(--fs-sm);color:var(--text-secondary)}.acct-since{font-size:var(--fs-xs);color:var(--text-muted);margin-top:2px}.plan-badge{border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:var(--fw-bold);letter-spacing:.07em;margin-left:auto;padding:.3em .8em}.plan-badge--pro{background:var(--pro-gradient);color:#fff}.plan-badge--free{background:var(--bg-surface);border:1px solid var(--border-default);color:var(--text-muted)}.account-section{gap:var(--space-lg);flex-direction:column;display:flex}.account-section__title{font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--text-primary)}.account-section__desc{font-size:var(--fs-sm);color:var(--text-secondary)}.account-pro-info{gap:var(--space-sm);padding:var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);flex-direction:column;display:flex}.pro-info-row{font-size:var(--fs-sm);color:var(--text-secondary);justify-content:space-between;align-items:center;display:flex}.pro-info-row strong{color:var(--text-primary)}.status-active{color:#22c55e}.plan-cards{gap:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}@media (width<=500px){.plan-cards{grid-template-columns:1fr}}.plan-card{gap:var(--space-md);padding:var(--space-xl);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:border-color var(--transition-base);flex-direction:column;display:flex;position:relative}.plan-card--featured{border-color:var(--pro-primary);box-shadow:0 0 24px var(--pro-glow)}.plan-offer-badge{white-space:nowrap;background:var(--pro-gradient);border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:var(--fw-bold);color:#fff;padding:.2em .9em;position:absolute;top:-12px;left:50%;transform:translate(-50%)}.plan-card__name{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em}.plan-card__price{font-size:var(--fs-3xl,2rem);font-weight:var(--fw-bold);color:var(--text-primary);line-height:1}.plan-card__price span{font-size:var(--fs-sm);color:var(--text-muted);font-weight:var(--fw-normal)}.plan-card__sub{font-size:var(--fs-xs);color:var(--text-muted)}.plan-card__features{font-size:var(--fs-xs);color:var(--text-secondary);flex-direction:column;flex:1;gap:6px;margin:0;padding:0;list-style:none;display:flex}.btn-upgrade{background:var(--bg-surface);border:1px solid var(--border-accent);border-radius:var(--radius-md);width:100%;color:var(--text-accent);font-size:var(--fs-sm);font-weight:var(--fw-semibold);cursor:pointer;transition:all var(--transition-fast);padding:.7em}.btn-upgrade:hover{background:var(--accent-subtle)}.btn-upgrade--best{background:var(--pro-gradient);color:#fff;border-color:#0000}.btn-upgrade--best:hover{background:var(--pro-primary);box-shadow:var(--pro-glow)}.btn-upgrade:disabled{opacity:.5;cursor:not-allowed}.pro-page{gap:var(--space-3xl);max-width:900px;padding:var(--space-xl) 0 var(--space-3xl);flex-direction:column;margin:0 auto;display:flex}.pro-hero{text-align:center;align-items:center;gap:var(--space-md);flex-direction:column;display:flex}.pro-hero__title{font-size:var(--fs-4xl);font-weight:var(--fw-bold);background:var(--pro-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.pro-hero__subtitle{font-size:var(--fs-lg);color:var(--text-secondary);max-width:500px}.pro-section{gap:var(--space-xl);flex-direction:column;display:flex}.pro-section__title{text-align:center;font-size:var(--fs-2xl);font-weight:var(--fw-bold);color:var(--text-primary)}.pro-benefits-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.pro-benefit-card{padding:var(--space-xl);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);text-align:center;transition:transform var(--transition-base)}.pro-benefit-card:hover{border-color:var(--pro-subtle);transform:translateY(-4px)}.pro-benefit-icon{color:var(--pro-primary);margin-bottom:var(--space-md);font-size:2.5rem}.pro-benefit-title{font-size:var(--fs-md);font-weight:var(--fw-bold);color:var(--text-primary);margin-bottom:var(--space-sm)}.pro-benefit-desc{font-size:var(--fs-sm);color:var(--text-secondary);line-height:1.5}.pro-section--pricing{padding:var(--space-3xl) var(--space-xl);background:var(--bg-darkest);border-radius:var(--radius-xl);border:1px solid var(--border-subtle)}.pro-badge--hero{width:auto;padding:4px 12px;font-size:14px;position:static;transform:none}@media (width<=600px){.pro-hero__title{font-size:var(--fs-3xl)}}.btn-portal{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--fs-sm);cursor:pointer;transition:all var(--transition-fast);align-self:flex-start;padding:.6em 1.4em}.btn-portal:hover{border-color:var(--accent-primary);color:var(--text-accent)}.btn-signout{border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-muted);font-size:var(--fs-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;align-self:flex-start;padding:.5em 1.2em}.btn-signout:hover{color:#ff6b6b;border-color:#ff6b6b}.cp-gate{text-align:center;padding:var(--space-3xl) var(--space-xl);max-width:420px;margin:0 auto}.cp-gate__icon{margin-bottom:var(--space-lg);color:var(--pro-primary);font-size:3rem}.cp-gate h2{color:var(--text-primary);margin-bottom:var(--space-sm)}.cp-gate p{color:var(--text-secondary);font-size:var(--fs-sm);margin-bottom:var(--space-xl)}.cp-layout{gap:var(--space-2xl);flex-direction:column;max-width:720px;display:flex}.cp-setup{gap:var(--space-2xl);flex-direction:column;display:flex}.cp-section{gap:var(--space-lg);flex-direction:column;display:flex}.cp-section__title{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--text-primary)}.cp-section__desc{font-size:var(--fs-sm);color:var(--text-muted)}.cp-level-group{margin-bottom:var(--space-xl)}.cp-level-title{align-items:center;gap:var(--space-sm);font-size:var(--fs-md);font-weight:var(--fw-semibold);color:var(--text-secondary);margin-bottom:var(--space-md);display:flex}.cp-level-badge{background:var(--pro-gradient);color:#fff;width:24px;height:24px;font-size:var(--fs-xs);font-weight:var(--fw-bold);border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.cp-drill-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.cp-drill-btn{padding:var(--space-md) var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;flex-direction:column;gap:4px;display:flex}.cp-drill-btn:hover{border-color:var(--pro-primary);background:var(--pro-subtle)}.cp-drill-btn__label{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-primary)}.cp-drill-btn__count{font-size:var(--fs-xs);color:var(--text-muted)}.cp-chord-picker{flex-wrap:wrap;gap:6px;display:flex}.cp-chord-pick{font-size:var(--fs-xs);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:.35em .7em}.cp-chord-pick:hover{border-color:var(--pro-primary)}.cp-chord-pick.selected{background:var(--pro-gradient);color:#fff;border-color:#0000}.cp-custom-selected{min-height:28px}.cp-selected-label{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--pro-primary)}.cp-selected-hint{font-size:var(--fs-xs);color:var(--text-muted)}.cp-speed-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(140px,1fr));display:grid}.cp-speed-card{padding:var(--space-lg) var(--space-md);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;align-items:center;gap:6px;display:flex}.cp-speed-card:hover{border-color:var(--pro-primary)}.cp-speed-card.active{background:var(--pro-gradient);border-color:#0000}.cp-speed-card__icon{font-size:1.8rem}.cp-speed-card__name{font-size:var(--fs-sm);font-weight:var(--fw-bold);color:var(--text-primary)}.cp-speed-card.active .cp-speed-card__name{color:#fff}.cp-speed-card__detail{font-size:var(--fs-xs);color:var(--text-muted)}.cp-speed-card.active .cp-speed-card__detail{color:#fffc}.cp-setting{gap:var(--space-sm);flex-direction:column;min-width:140px;display:flex}.cp-setting label{font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.cp-setting__val{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--pro-primary)}.cp-slider{accent-color:var(--pro-primary)}.cp-chip-row{gap:6px;display:flex}.cp-chip{font-size:var(--fs-xs);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:.35em .8em}.cp-chip.active{background:var(--pro-gradient);color:#fff;border-color:#0000}.cp-start-btn{font-size:var(--fs-md);font-weight:var(--fw-bold);border-radius:var(--radius-md);background:var(--bg-surface);color:var(--text-muted);cursor:not-allowed;transition:all var(--transition-fast);border:none;align-self:flex-start;padding:.7em 2.5em}.cp-start-btn.ready{background:var(--pro-gradient);color:#fff;cursor:pointer}.cp-start-btn.ready:hover{opacity:.88}.cp-countdown{justify-content:center;align-items:center;height:300px;display:flex}.cp-countdown span{font-size:6rem;font-weight:var(--fw-bold);color:var(--pro-primary);animation:.9s ease-in-out infinite cp-pulse}@keyframes cp-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}.cp-practice{align-items:center;gap:var(--space-xl);flex-direction:column;display:flex}.cp-active{align-items:center;gap:var(--space-xl);flex-direction:column;width:100%;display:flex}.cp-timer-bar{align-items:center;gap:var(--space-xl);font-size:var(--fs-lg);color:var(--text-secondary);justify-content:center;width:100%;display:flex}.cp-timer-bar strong{color:var(--pro-primary)}.cp-beat-dots{gap:var(--space-md);display:flex}.cp-dot{background:var(--border-subtle);border-radius:50%;width:16px;height:16px;transition:all .1s}.cp-dot.accent{border:2px solid var(--pro-primary)}.cp-dot.active{background:var(--pro-primary);transform:scale(1.3)}.cp-chord-display{justify-content:center;align-items:center;gap:var(--space-2xl);width:100%;display:flex}.cp-chord-current{align-items:center;gap:var(--space-sm);flex-direction:column;display:flex}.cp-chord-next{align-items:center;gap:var(--space-sm);opacity:.4;flex-direction:column;display:flex}.cp-chord-label{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--text-secondary)}.cp-chord-label--active{font-size:var(--fs-2xl);color:var(--pro-primary)}.cp-svg{width:100px;height:auto}.cp-svg--small{opacity:.5;width:60px}.cp-stop-btn{font-size:var(--fs-sm);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:.6em 2em}.cp-stop-btn:hover{color:#ff6b6b;border-color:#ff6b6b}.cp-result{align-items:center;gap:var(--space-xl);padding:var(--space-2xl);flex-direction:column;display:flex}.cp-score-num{font-size:4rem;font-weight:var(--fw-bold);background:var(--pro-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;line-height:1}.cp-score-label{font-size:var(--fs-md);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.cp-detail-row{font-size:var(--fs-sm);color:var(--text-secondary)}.cp-detail-row strong{color:var(--text-primary)}.cp-result-btns{gap:var(--space-md);display:flex}.cp-again-btn{background:var(--pro-gradient);border-radius:var(--radius-md);color:#fff;font-weight:var(--fw-semibold);cursor:pointer;border:none;padding:.6em 1.8em}.cp-again-btn:hover{opacity:.88}.cp-back-btn{border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;background:0 0;padding:.6em 1.8em}.cp-hist-section{margin-top:var(--space-xl)}.cp-hist-item{align-items:center;gap:var(--space-lg);padding:var(--space-sm) 0;font-size:var(--fs-sm);color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);display:flex}.cp-hist-item strong{color:var(--text-primary)}.cp-hist-date{font-size:var(--fs-xs);color:var(--text-muted);margin-left:auto}.cp-hist-empty{font-size:var(--fs-sm);color:var(--text-muted)}@media (width<=600px){.cp-chord-display{gap:var(--space-lg)}.cp-svg{width:80px}.cp-svg--small{width:45px}.cp-drill-grid{grid-template-columns:1fr}.cp-settings{flex-direction:column}}.prog-layout{gap:var(--space-2xl);flex-direction:column;max-width:800px;display:flex}.prog-controls{gap:var(--space-xl);padding:var(--space-xl);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);flex-wrap:wrap;display:flex}.prog-control-group{gap:var(--space-sm);flex-direction:column;display:flex}.prog-control-group label{font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.prog-key-grid{flex-wrap:wrap;gap:4px;display:flex}.prog-key-btn{width:36px;height:32px;font-size:var(--fs-xs);font-weight:var(--fw-semibold);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.prog-key-btn:hover{border-color:var(--pro-primary)}.prog-key-btn.active{background:var(--pro-gradient);color:#fff;border-color:#0000}.prog-mode-row{gap:4px;display:flex}.prog-mode-btn{font-size:var(--fs-xs);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:.4em 1em}.prog-mode-btn.active{background:var(--pro-gradient);color:#fff;border-color:#0000}.prog-style-row{flex-wrap:wrap;gap:6px;display:flex}.prog-style-tab{font-size:var(--fs-xs);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:.35em .9em}.prog-style-tab.active{background:var(--pro-subtle);color:var(--pro-primary);border-color:var(--pro-primary)}.prog-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.prog-card{gap:var(--space-md);padding:var(--space-xl);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:border-color var(--transition-fast);flex-direction:column;display:flex}.prog-card:hover{border-color:var(--pro-primary)}.prog-card__header{justify-content:space-between;align-items:baseline;gap:var(--space-sm);display:flex}.prog-card__title{font-size:var(--fs-md);font-weight:var(--fw-bold);color:var(--text-primary)}.prog-card__roman{font-size:var(--fs-xs);color:var(--text-muted);white-space:nowrap}.prog-card__desc{font-size:var(--fs-xs);color:var(--text-secondary);line-height:1.5}.prog-card__chords{flex-wrap:wrap;gap:6px;display:flex}.prog-chord-pill{font-size:var(--fs-sm);font-weight:var(--fw-semibold);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);transition:all var(--transition-fast);padding:.3em .7em}.prog-chord-pill.playing{background:var(--pro-gradient);color:#fff;border-color:#0000;transform:scale(1.08)}.prog-card__actions{gap:var(--space-md);margin-top:auto;display:flex}.prog-play-btn,.prog-practice-btn{font-size:var(--fs-xs);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:.4em .9em;text-decoration:none}.prog-play-btn:hover,.prog-practice-btn:hover{border-color:var(--pro-primary);color:var(--pro-primary)}@media (width<=500px){.prog-grid{grid-template-columns:1fr}.prog-key-grid{gap:3px}.prog-key-btn{width:30px;height:28px;font-size:10px}}.ear-layout{gap:var(--space-2xl);flex-direction:column;max-width:640px;display:flex}.ear-controls{gap:var(--space-xl);padding:var(--space-xl);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);flex-wrap:wrap;display:flex}.ear-control-group{gap:var(--space-sm);flex-direction:column;display:flex}.ear-control-group label{font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.ear-mode-row{flex-wrap:wrap;gap:6px;display:flex}.ear-mode-btn{font-size:var(--fs-xs);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:.4em .9em}.ear-mode-btn.active{background:var(--accent-gradient);color:#fff;border-color:#0000}.ear-stats{gap:var(--space-xl);justify-content:center;display:flex}.ear-stat{font-size:var(--fs-xs);color:var(--text-muted);flex-direction:column;align-items:center;gap:4px;display:flex}.ear-stat__val{font-size:var(--fs-2xl);font-weight:var(--fw-bold);color:var(--text-primary)}.ear-question{align-items:center;gap:var(--space-lg);flex-direction:column;display:flex}.ear-play-btn{font-size:var(--fs-md);font-weight:var(--fw-bold);background:var(--accent-gradient);border-radius:var(--radius-full);color:#fff;cursor:pointer;transition:all var(--transition-fast);border:none;padding:.8em 2.5em}.ear-play-btn:hover{opacity:.88;transform:scale(1.03)}.ear-feedback{text-align:center;min-height:28px}.ear-correct{color:#22c55e;font-weight:var(--fw-bold);font-size:var(--fs-md);animation:.3s ear-pop}.ear-wrong{color:#ff6b6b;font-weight:var(--fw-bold);font-size:var(--fs-md);animation:.3s ear-pop}@keyframes ear-pop{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.ear-answers{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.ear-answer-btn{font-size:var(--fs-sm);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);min-width:80px;padding:.5em 1em}.ear-answer-btn:hover{border-color:var(--accent-primary);background:var(--accent-subtle)}.ear-answer-btn.correct{color:#22c55e;background:#22c55e33;border-color:#22c55e}.ear-answer-btn.wrong{color:#ff6b6b;background:#ff6b6b33;border-color:#ff6b6b}@media (width<=500px){.ear-stats{gap:var(--space-lg)}.ear-answer-btn{min-width:60px;font-size:var(--fs-xs)}}.bt-layout{gap:var(--space-2xl);flex-direction:column;max-width:800px;display:flex}.bt-style-row{flex-wrap:wrap;gap:6px;display:flex}.bt-style-tab{font-size:var(--fs-sm);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:.4em 1em}.bt-style-tab.active{background:var(--pro-subtle);color:var(--pro-primary);border-color:var(--pro-primary)}.bt-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.bt-card{gap:var(--space-md);padding:var(--space-xl);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:border-color var(--transition-fast);flex-direction:column;display:flex}.bt-card:hover{border-color:var(--pro-primary)}.bt-card__header{justify-content:space-between;align-items:baseline;display:flex}.bt-card__header h3{font-size:var(--fs-md);font-weight:var(--fw-bold);color:var(--text-primary)}.bt-card__meta{font-size:var(--fs-xs);color:var(--text-muted);white-space:nowrap}.bt-card__prog{flex-wrap:wrap;gap:4px;display:flex}.bt-prog-pill{font-size:var(--fs-xs);font-weight:var(--fw-semibold);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);padding:.25em .6em;transition:all .15s}.bt-prog-pill.active{background:var(--pro-gradient);color:#fff;border-color:#0000;transform:scale(1.1)}.bt-card__scale{font-size:var(--fs-xs);color:var(--text-secondary)}.bt-card__scale-label{color:var(--text-muted)}.bt-card__scale-name{font-weight:var(--fw-semibold);color:var(--pro-primary)}.bt-card__controls{align-items:center;gap:var(--space-md);margin-top:auto;display:flex}.bt-play-btn{width:40px;height:40px;font-size:var(--fs-lg);background:var(--pro-gradient);color:#fff;cursor:pointer;transition:all var(--transition-fast);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.bt-play-btn:hover{opacity:.85;transform:scale(1.05)}.bt-loop-btn{font-size:var(--fs-sm);border:1px solid var(--border-default);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:all var(--transition-fast);background:0 0;padding:.3em .6em}.bt-loop-btn.active{color:var(--pro-primary);border-color:var(--pro-primary)}.bt-vol{max-width:100px;accent-color:var(--pro-primary);flex:1}@media (width<=500px){.bt-grid{grid-template-columns:1fr}}
