:root{--color-bg:#ffffff;--color-bg-secondary:#f5f5f5;--color-text:#1a1a1a;--color-text-secondary:#666666;--color-primary:#4f46e5;--color-primary-hover:#4338ca;--color-chord:#dc2626;--color-border:#e5e5e5;--color-surface:#ffffff;--font-sans:"Inter",system-ui,-apple-system,sans-serif;--font-mono:"JetBrains Mono","Fira Code","Cascadia Code",monospace;--radius:8px;--radius-sm:4px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.25rem;--font-size-xl:1.5rem}@media(prefers-color-scheme:dark){:root{--color-bg:#0a0a0a;--color-bg-secondary:#1a1a1a;--color-text:#f5f5f5;--color-text-secondary:#999999;--color-primary:#818cf8;--color-primary-hover:#6366f1;--color-chord:#f87171;--color-border:#333333;--color-surface:#111111}}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased}body{min-height:100dvh}a{text-decoration:none}a,button{color:inherit;-webkit-tap-highlight-color:rgba(0,0,0,0)}button{cursor:pointer;border:none;background:none;font:inherit}input,select,textarea{font:inherit;color:inherit}ol,ul{list-style:none}.app-layout{min-height:100dvh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border);background:var(--color-surface);position:-webkit-sticky;position:sticky;top:0;z-index:30}@media(min-width:600px){.app-header{gap:var(--space-md);padding:var(--space-md) var(--space-lg)}}.app-header__logo{display:flex;align-items:center;margin-right:auto}.app-header__user{position:relative;z-index:25;display:flex;align-items:center;gap:var(--space-sm)}.app-header__nav{display:none;gap:var(--space-md);margin-left:auto}@media(min-width:600px){.app-header__nav{display:flex}}.app-header__nav a{font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:color .15s}.app-header__nav a:hover{color:var(--color-text)}.hamburger{position:relative;z-index:25;display:flex;flex-direction:column;justify-content:center;gap:5px;width:32px;height:32px;padding:4px}@media(min-width:600px){.hamburger{display:none}}.hamburger__line{display:block;width:100%;height:2px;background:var(--color-text);border-radius:1px;transition:transform .2s,opacity .2s}.hamburger__line--open:first-child{transform:translateY(7px) rotate(45deg)}.hamburger__line--open:nth-child(2){opacity:0}.hamburger__line--open:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu{position:fixed;inset:0;z-index:20;pointer-events:none;visibility:hidden}@media(min-width:600px){.mobile-menu{display:none}}.mobile-menu--open{pointer-events:auto;visibility:visible}.mobile-menu--open .mobile-menu__backdrop{opacity:1}.mobile-menu--open .mobile-menu__panel{transform:translateX(0)}.mobile-menu__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);opacity:0;transition:opacity .25s ease}.mobile-menu__panel{position:absolute;top:0;right:0;bottom:0;width:75%;max-width:300px;background:var(--color-surface);display:flex;flex-direction:column;padding:80px 0 var(--space-xl);transform:translateX(100%);transition:transform .25s ease}.mobile-menu__panel a{padding:var(--space-md) var(--space-lg);font-size:var(--font-size-lg);color:var(--color-text-secondary);transition:background .15s,color .15s}.mobile-menu__panel a.active,.mobile-menu__panel a:hover{color:var(--color-text);background:var(--color-bg-secondary)}.mobile-menu__panel a.active{color:var(--color-primary)}.app-main{flex:1 1;display:flex;flex-direction:column;min-height:0;padding:var(--space-md);max-width:800px;width:100%;margin:0 auto}@media(min-width:600px){.app-main{padding:var(--space-lg)}}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100dvh}.empty-state,.loading{text-align:center;color:var(--color-text-secondary);padding:var(--space-xl)}.nav-badge{position:absolute;top:-12px;right:-10px;display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--color-primary);color:#fff;font-size:.65rem;font-weight:600;line-height:1;pointer-events:none;z-index:-1}.landing{min-height:100dvh}.landing,.landing__hero{display:flex;flex-direction:column}.landing__hero{align-items:center;text-align:center;padding:var(--space-xl) var(--space-md);padding-top:12vh}@media(min-width:600px){.landing__hero{padding-top:14vh;padding-bottom:var(--space-xl)}}.landing__headline{font-size:1.75rem;font-weight:800;line-height:1.15;margin-top:var(--space-lg);max-width:600px}@media(min-width:600px){.landing__headline{font-size:2.5rem}}@media(min-width:900px){.landing__headline{font-size:3rem}}.landing__subtitle{color:var(--color-text-secondary);max-width:520px;margin-top:var(--space-md);line-height:1.6}.landing__actions{display:flex;gap:var(--space-md);margin-top:var(--space-lg)}.landing__compare{display:grid;grid-gap:var(--space-lg);gap:var(--space-lg);padding:var(--space-xl) var(--space-md);max-width:900px;width:100%;margin:0 auto}@media(min-width:600px){.landing__compare{grid-template-columns:1fr 1fr;padding:var(--space-xl) var(--space-lg)}}.landing__compare-card{border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-lg);background:var(--color-surface);overflow:hidden}.landing__compare-card--problem .landing__broken-mock{font-family:var(--font-mono);font-size:.85rem;line-height:1.4;overflow-x:auto}.landing__compare-card--problem .landing__broken-mock,.landing__compare-card--solution .chord-sheet{border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-md);background:var(--color-bg)}.landing__compare-label{font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--space-md);color:var(--color-text-secondary)}.landing__compare-label--primary{color:var(--color-primary)}.landing__broken-chords{color:var(--color-chord);font-weight:700;white-space:pre;font-size:.9em}.landing__broken-text{white-space:pre}.landing__broken-text--orphan{margin-top:-2px;opacity:.6}.landing__compare-note{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-md);line-height:1.5}.landing__features{display:grid;grid-gap:var(--space-lg);gap:var(--space-lg);padding:var(--space-xl) var(--space-md);max-width:900px;width:100%;margin:0 auto}@media(min-width:600px){.landing__features{grid-template-columns:repeat(3,1fr);padding:var(--space-xl) var(--space-lg)}}.landing__feature-card{border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-lg);background:var(--color-surface)}.landing__feature-icon{width:32px;height:32px;color:var(--color-primary);margin-bottom:var(--space-md)}.landing__feature-title{font-size:var(--font-size-base);font-weight:600;margin-bottom:var(--space-sm)}.landing__feature-desc{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.5}.landing__pricing{padding:var(--space-xl) var(--space-md);max-width:900px;width:100%;margin:0 auto;text-align:center}.landing__pricing-heading{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--space-xl)}.landing__pricing-cards{display:grid;grid-gap:var(--space-lg);gap:var(--space-lg)}@media(min-width:600px){.landing__pricing-cards{grid-template-columns:1fr 1fr}}.landing__pricing-card{border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-xl) var(--space-lg);background:var(--color-surface);display:flex;flex-direction:column;align-items:center;text-align:center;position:relative}.landing__pricing-card--pro{border-color:var(--color-primary);border-width:2px}.landing__pricing-card .btn{margin-top:auto}.landing__pricing-badge{position:absolute;top:-12px;background:var(--color-primary);color:#fff;font-size:var(--font-size-sm);font-weight:600;padding:2px var(--space-md);border-radius:999px}.landing__pricing-name{font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--space-md)}.landing__pricing-price{display:flex;align-items:baseline;gap:4px;margin-bottom:var(--space-sm)}.landing__pricing-amount{font-size:2rem;font-weight:800}.landing__pricing-note,.landing__pricing-period{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.landing__pricing-note{margin-bottom:var(--space-sm)}.landing__pricing-features{list-style:none;padding:0;margin:var(--space-lg) 0;width:100%;text-align:left}.landing__pricing-features li{padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.landing__pricing-features li:before{content:"✓ ";color:var(--color-primary);font-weight:700}.landing__pricing-features li:last-child{border-bottom:none}.landing__cta{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);padding:var(--space-xl) var(--space-md);padding-bottom:12vh}.landing__cta-heading{font-size:var(--font-size-xl);font-weight:700}.landing__footer{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-xl) var(--space-md);border-top:1px solid var(--color-border);margin-top:auto}.landing__footer-links{display:flex;gap:var(--space-lg)}.landing__footer-links a{color:var(--color-text-secondary);font-size:var(--font-size-sm);text-decoration:none}.landing__footer-links a:hover{color:var(--color-text)}.landing__footer-copy{color:var(--color-text-secondary);font-size:var(--font-size-sm);opacity:.6}.btn--lg{padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-base)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-sm) var(--space-md);border-radius:var(--radius);font-weight:500;font-size:var(--font-size-sm);transition:all .15s}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover{background:var(--color-primary-hover)}.btn--secondary{background:var(--color-bg-secondary);border:1px solid var(--color-border)}.btn--secondary:hover{background:var(--color-border)}.btn--ghost{color:var(--color-text-secondary);background:var(--color-bg-secondary);border:1px solid var(--color-border)}.btn--ghost:hover{color:var(--color-primary);border-color:var(--color-primary)}.btn--sm{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm)}.btn--danger{color:#dc2626}.btn--danger:hover{background:#fef2f2}.btn--danger-fill{background:#dc2626;color:#fff}.btn--danger-fill:hover{background:#b91c1c}.btn:disabled{opacity:.5;pointer-events:none}.logo{font-family:var(--font-logo),cursive;color:var(--color-primary);line-height:1;letter-spacing:.02em;-webkit-user-select:none;-moz-user-select:none;user-select:none}.logo--sm{font-size:2rem}.logo--lg{font-size:4.5rem}.input{width:100%;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);transition:border-color .15s}.input:focus{outline:none;border-color:var(--color-primary)}.input--lg{font-size:var(--font-size-lg);font-weight:600}.input--sm{max-width:100px}.input--mono{font-family:var(--font-mono);font-size:var(--font-size-sm)}.song-list{display:flex;flex-direction:column;gap:var(--space-xs)}.song-list__item a{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius);transition:background .15s}.song-list__item a:hover{background:var(--color-bg-secondary)}.song-list__title{font-weight:500;flex:1 1}.song-list__artist{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.song-list__key{font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--color-chord);font-weight:600}.song-list__item--locked{opacity:.5}.song-list__locked-content{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);cursor:default}.song-list__lock-badge{display:flex;align-items:center;gap:4px;font-size:var(--font-size-sm);color:var(--color-primary);font-weight:600;margin-left:auto}.songs-page__filters{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.songs-page__key-filter{width:auto;min-width:100px}.songs-page__header{flex-wrap:wrap;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.songs-page__actions,.songs-page__header{display:flex;gap:var(--space-sm)}@media(max-width:599px){.songs-page__actions{width:100%}.songs-page__actions .btn{flex:1 1}}.song-view__header{margin-bottom:var(--space-lg)}.song-view__title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md)}.song-view__title{font-size:var(--font-size-xl);line-height:1.2}.song-view__artist{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-xs)}.song-view__icons{display:flex;align-items:center;gap:var(--space-xs);flex-shrink:0}.song-view__toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-top:var(--space-md)}.meta-tag{font-size:var(--font-size-sm);color:var(--color-text-secondary);border:1px solid var(--color-border);padding:var(--space-xs) var(--space-md);border-radius:999px;font-family:var(--font-mono)}.song-view__meta-tags,.transpose-controls{display:flex;align-items:center;gap:var(--space-xs)}.transpose-controls{background:var(--color-surface);border-radius:var(--radius);padding:var(--space-xxs) var(--space-xs)}.transpose-controls__value{font-family:var(--font-mono);font-weight:600;min-width:2.5em;text-align:center}.upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-xl) var(--space-lg);border:2px dashed var(--color-border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s,background .15s;text-align:center;color:var(--color-text-secondary)}.upload-area:hover{border-color:var(--color-primary);background:var(--color-bg-secondary)}.upload-area__error{margin-top:var(--space-md);padding:var(--space-md);border-radius:var(--radius);background:#fef2f2;color:#dc2626;text-align:center}.upload-area__error p{margin-bottom:var(--space-sm)}.import-page__intro{margin-bottom:var(--space-lg);color:var(--color-text-secondary)}.import-section__heading{display:block;font-size:var(--font-size-sm);font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.import-section+.import-section{margin-top:var(--space-lg)}.import-divider{display:flex;align-items:center;gap:var(--space-sm);margin:var(--space-lg) 0;color:var(--color-text-secondary);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.04em}.import-divider:after,.import-divider:before{content:"";flex:1 1;height:1px;background:var(--color-border)}.import-form{display:flex;gap:var(--space-sm);align-items:stretch}@media(max-width:599px){.import-form{flex-direction:column}}.import-form__input{flex:1 1;min-width:0;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);font-size:var(--font-size-base);color:var(--color-text);transition:border-color .15s}@media(max-width:599px){.import-form__input{font-size:16px}}.import-form__input::placeholder{color:var(--color-text-secondary)}.import-form__input:focus{outline:none;border-color:var(--color-primary)}.import-form__input:disabled{opacity:.6;cursor:not-allowed}.import-form__hint{margin-top:var(--space-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.chord-sheet{font-family:var(--font-mono);font-size:var(--font-size-base);line-height:1.4;overflow:hidden}.chord-section{margin-bottom:var(--space-xl)}.chord-section__label{font-family:var(--font-sans);font-size:var(--font-size-sm);font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-sm)}.chord-line{display:flex;flex-wrap:wrap;margin-bottom:var(--space-xs)}.chord-word{display:inline-flex;flex-wrap:nowrap}.chord-fragment{display:inline-flex;flex-direction:column;white-space:pre}.chord-fragment__chord{color:var(--color-chord);font-weight:700;font-size:.9em;line-height:1.6;min-height:1.6em}.chord-fragment__text{line-height:1.4}.chord-fragment--pad{opacity:.3}.chord-fragment--pad:hover{opacity:.6}.chord-highlight{background:var(--color-primary);color:#fff;border-radius:2px}.chord-bar-line{font-family:var(--font-mono);font-size:var(--font-size-base);line-height:1.8;white-space:pre;margin-bottom:var(--space-xs)}.chord-bar-line__bar{opacity:.4}.chord-bar-line__chord{color:var(--color-chord);font-weight:700}.chord-bar-line__dashes{opacity:.3}.song-editor{gap:var(--space-lg)}.song-editor,.song-editor__meta{display:flex;flex-direction:column}.song-editor__meta{gap:var(--space-sm)}.song-editor__meta-row{display:flex;gap:var(--space-sm)}.song-editor__meta-row>*{flex:1 1;min-width:0;max-width:none}.song-editor__sections{display:flex;flex-direction:column;gap:var(--space-lg)}.song-editor__insert-btn{align-self:center;border:1px dashed var(--color-border);border-radius:var(--radius);background:none;color:var(--color-text-secondary);font-size:1.5rem;line-height:1;padding:var(--space-xs) var(--space-xl,2rem);cursor:pointer;opacity:.4;transition:opacity .15s,background .15s}.song-editor__insert-btn:hover{opacity:1;background:var(--color-bg-secondary)}.song-editor__section{padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius);display:flex;flex-direction:column;gap:var(--space-sm);min-width:0;overflow:hidden}.song-editor__section-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.song-editor__section-header select{max-width:200px}.song-editor__footer{display:flex;justify-content:flex-end;padding-top:var(--space-md);border-top:1px solid var(--color-border)}@media(max-width:599px){.song-editor__footer{position:-webkit-sticky;position:sticky;bottom:0;background:var(--color-bg);padding:var(--space-md);margin:0 calc(-1*var(--space-md));border-top:1px solid var(--color-border);z-index:10}.song-editor__footer .btn{width:100%}}.section-editor{min-width:0}.section-editor__tabs{display:flex;border-bottom:1px solid var(--color-border);margin-bottom:var(--space-sm)}.section-editor__tab{padding:var(--space-xs) var(--space-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);border-bottom:2px solid rgba(0,0,0,0);transition:all .15s}.section-editor__tab:hover{color:var(--color-text)}.section-editor__tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.section-editor__textarea{width:100%;font-family:var(--font-mono);font-size:var(--font-size-sm);line-height:1.6;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);resize:none;overflow:hidden;min-height:4em}@media(max-width:599px){.section-editor__textarea{font-size:16px}}.section-editor__textarea:focus{outline:none;border-color:var(--color-primary)}.section-editor__chord-view{font-family:var(--font-mono);font-size:var(--font-size-sm);padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius);min-height:4em;overflow-x:hidden;max-width:100%}@media(max-width:599px){.section-editor__chord-view{overflow-x:auto;-webkit-overflow-scrolling:touch}.section-editor__chord-view .chord-line--editable{flex-wrap:nowrap}}.section-editor__chord-view .chord-line--editable .chord-fragment__chord--has-chord{cursor:pointer;border-radius:var(--radius-sm);padding:0 2px}.section-editor__chord-view .chord-line--editable .chord-fragment__chord--has-chord:hover{background:var(--color-bg-secondary)}.section-editor__chord-view .chord-line--editable .chord-fragment__text{cursor:crosshair}.section-editor__preview{font-family:var(--font-mono);font-size:var(--font-size-base);padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius);min-height:4em;min-width:0;overflow:hidden}.section-editor__preview .chord-line{max-width:100%}.section-editor__empty-line{height:1.6em}.section-editor__placeholder{color:var(--color-text-secondary);font-style:italic}.bar-editor{flex-wrap:wrap;gap:var(--space-xs)}.bar-editor,.bar-editor__bar{display:flex;align-items:center}.bar-editor__bar{font-family:var(--font-mono);font-size:var(--font-size-sm);background:var(--color-bg-secondary);border-radius:var(--radius-sm);gap:0}.bar-editor__pipe{opacity:.4;padding:0 2px;line-height:1.8}.bar-editor__beat{padding:var(--space-xs) var(--space-sm);cursor:pointer;border-radius:var(--radius-sm);transition:all .1s;line-height:1.8}@media(max-width:599px){.bar-editor__beat{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}}.bar-editor__beat--has-chord{font-weight:700;color:var(--color-chord)}.bar-editor__beat:not(.bar-editor__beat--has-chord){opacity:.3}.bar-editor__beat:hover{background:var(--color-bg-secondary);opacity:1}.bar-editor__beat--active{background:var(--color-primary);color:#fff;opacity:1}.bar-editor__remove-bar{padding:0 var(--space-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary);opacity:0;cursor:pointer;transition:opacity .15s;line-height:1.8}.bar-editor__bar:hover .bar-editor__remove-bar{opacity:.5}.bar-editor__remove-bar:hover{opacity:1!important;color:#dc2626}@media(max-width:599px){.bar-editor__remove-bar{opacity:.4;min-width:32px;min-height:44px;display:flex;align-items:center;justify-content:center}}.bar-editor__add{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary);border:1px dashed var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}@media(max-width:599px){.bar-editor__add{min-height:44px;display:flex;align-items:center}}.bar-editor__add:hover{color:var(--color-primary);border-color:var(--color-primary)}.chord-picker-backdrop{display:none}@media(max-width:599px){.chord-picker-backdrop{display:block;position:fixed;inset:0;z-index:99;background:rgba(0,0,0,.4)}}.chord-picker{position:fixed;z-index:100;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 8px 24px rgba(0,0,0,.15);padding:var(--space-sm);min-width:280px}@media(max-width:599px){.chord-picker{bottom:0;left:0;right:0;top:auto!important;min-width:unset;border-radius:var(--radius-lg,16px) var(--radius-lg,16px) 0 0;border-bottom:none;padding:var(--space-md);box-shadow:0 -4px 24px rgba(0,0,0,.2)}}.chord-picker__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.chord-picker__title{font-weight:600;font-size:var(--font-size-base)}.chord-picker__pos{display:flex;align-items:center;gap:var(--space-xs);margin-bottom:var(--space-sm);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.chord-picker__pos-arrow{flex-shrink:0;min-width:44px;min-height:44px;font-size:18px}.chord-picker__pos-bar{flex:1 1;display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.chord-picker__pos-bar::-webkit-scrollbar{display:none}.chord-picker__pos-char{font-family:var(--font-mono);display:inline-flex;flex-direction:column;align-items:center;flex-shrink:0;cursor:pointer;padding:2px 0;background:rgba(0,0,0,0);min-width:16px}.chord-picker__pos-char--pad:not(.chord-picker__pos-char--active){opacity:.35}.chord-picker__pos-chord{display:inline-block;font-size:10px;font-weight:700;line-height:1.2;color:var(--color-chord,var(--color-primary));white-space:nowrap;padding:0 2px;min-height:12px;background:rgba(0,0,0,0)}.chord-picker__pos-letter{display:inline-block;font-size:16px;line-height:1.4;text-align:center;padding:1px 4px;background:rgba(0,0,0,0);border-radius:var(--radius-sm)}.chord-picker__pos-char--active .chord-picker__pos-letter{background:var(--color-primary);color:#fff;font-weight:700}.chord-picker__input-row{display:flex;gap:var(--space-xs);margin-bottom:var(--space-sm)}.chord-picker__input{flex:1 1;padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--font-size-base);font-weight:600;background:var(--color-surface)}@media(max-width:599px){.chord-picker__input{font-size:16px}}.chord-picker__input:focus{outline:none;border-color:var(--color-primary)}.chord-picker__move{display:flex;gap:2px}.chord-picker__move-btn{padding:var(--space-xs) 6px;font-size:var(--font-size-sm);min-width:28px;line-height:1}@media(max-width:599px){.chord-picker__move-btn{min-width:44px;min-height:44px}}.chord-picker__remove{color:#dc2626}@media(max-width:599px){.chord-picker__remove{min-height:44px}}.chord-picker__insert-space{margin-bottom:var(--space-sm);width:100%;text-align:center}@media(max-width:599px){.chord-picker__insert-space{min-height:44px}}.chord-picker__grid{display:flex;flex-direction:column;gap:2px}@media(max-width:599px){.chord-picker__grid{gap:var(--space-xs)}}.chord-picker__row{display:flex;gap:2px;flex-wrap:wrap}@media(max-width:599px){.chord-picker__row{gap:var(--space-xs)}}.chord-picker__chip{padding:var(--space-xs) var(--space-sm);font-family:var(--font-mono);font-size:var(--font-size-sm);border-radius:var(--radius-sm);background:var(--color-bg-secondary);transition:all .1s;cursor:pointer}@media(max-width:599px){.chord-picker__chip{min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-base)}}.chord-picker__chip--active,.chord-picker__chip:hover{background:var(--color-primary);color:#fff}.chord-keyboard{display:flex;flex-direction:column;gap:var(--space-xs);padding-top:var(--space-sm)}.chord-keyboard__draft{min-height:44px;padding:var(--space-xs) var(--space-md);font-family:var(--font-mono);font-size:22px;font-weight:700;background:var(--color-bg-secondary);border-radius:var(--radius-sm);display:flex;align-items:center;color:var(--color-primary);letter-spacing:.01em}.chord-keyboard__placeholder{color:var(--color-text-secondary);font-weight:400;font-size:var(--font-size-base);font-family:inherit;letter-spacing:0}.chord-keyboard__row{display:flex;gap:4px}.chord-keyboard__key{flex:1 1;min-width:0;min-height:44px;padding:0 4px;font-family:var(--font-mono);font-weight:600;font-size:var(--font-size-base);background:var(--color-bg-secondary);border:1px solid rgba(0,0,0,0);border-radius:var(--radius-sm);color:var(--color-text);display:inline-flex;align-items:center;justify-content:center}.chord-keyboard__key:active{background:var(--color-primary);color:#fff}.chord-keyboard__key--root{font-size:18px}.chord-keyboard__key--bksp{flex:0 0 auto;min-width:56px;font-size:18px}.chord-keyboard__key:disabled{opacity:.4}.chord-keyboard__actions{display:flex;margin-top:var(--space-xs)}.chord-keyboard__apply{flex:1 1;min-height:48px;font-size:var(--font-size-base)}.chord-picker__header-actions{display:flex;gap:var(--space-xs);align-items:center}.chord-picker__tabs{display:flex;gap:2px;margin-bottom:var(--space-sm);padding:2px;background:var(--color-bg-secondary);border-radius:var(--radius-sm)}.chord-picker__tab{flex:1 1;min-height:36px;padding:0 var(--space-sm);font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);background:rgba(0,0,0,0);border:none;border-radius:calc(var(--radius-sm) - 2px)}.chord-picker__tab--active{background:var(--color-surface);color:var(--color-text);box-shadow:0 1px 2px rgba(0,0,0,.06)}.chord-picker__grid--mobile .chord-picker__chip{flex:1 1;min-height:44px;font-size:var(--font-size-base)}.confirm-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.4);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.confirm-dialog{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 16px 48px rgba(0,0,0,.2);padding:var(--space-lg);max-width:400px;width:calc(100% - var(--space-lg)*2)}.confirm-dialog__title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-sm)}.confirm-dialog__message{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.5;margin-bottom:var(--space-lg)}.confirm-dialog__actions{display:flex;justify-content:flex-end;gap:var(--space-sm)}.instructions-modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 16px 48px rgba(0,0,0,.2);padding:var(--space-lg);max-width:500px;width:calc(100% - var(--space-lg)*2)}.instructions-modal__title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-md)}.instructions-modal__body{max-height:60vh;overflow-y:auto;margin-bottom:var(--space-lg)}.instructions-modal__body h4{font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--space-xs)}.instructions-modal__body h4:not(:first-child){margin-top:var(--space-md)}.instructions-modal__body p{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.5;margin-bottom:var(--space-sm)}.instructions-modal__body code{background:var(--color-surface-raised);padding:1px 4px;border-radius:3px;font-size:.9em}.instructions-modal__actions{display:flex;justify-content:flex-end}.friends-page h1{margin-bottom:var(--space-lg)}.friends-add{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.friends-add .input{flex:1 1}.friends-add .btn{flex-shrink:0}.friends-message{font-size:var(--font-size-sm);margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm)}.friends-message--success{color:#16a34a;background:#f0fdf4}.friends-message--error{color:#dc2626;background:#fef2f2}@media(prefers-color-scheme:dark){.friends-message--success{background:#052e16}.friends-message--error{background:#450a0a}}.friends-section{margin-top:var(--space-xl)}.friends-section h2{font-size:var(--font-size-lg);margin-bottom:var(--space-md)}.friends-list{display:flex;flex-direction:column;gap:var(--space-xs)}.friends-list__item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius);border:1px solid var(--color-border)}.friends-list__info{display:flex;flex-direction:column;min-width:0}.friends-list__name{font-weight:500}.friends-list__email,.friends-list__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friends-list__email{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.friends-list__actions{display:flex;gap:var(--space-xs);flex-shrink:0}.friends-list__status{font-size:var(--font-size-sm);color:var(--color-text-secondary);flex-shrink:0}.setlists-page .songs-page__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.setlist-list{display:flex;flex-direction:column;gap:var(--space-xs)}.setlist-list__item{display:flex;align-items:center;gap:var(--space-md);border-radius:var(--radius);border:1px solid var(--color-border);transition:background .15s}.setlist-list__item:hover{background:var(--color-bg-secondary)}.setlist-list__link{flex:1 1;min-width:0;padding:var(--space-md);text-decoration:none;color:inherit}.setlist-list__info{display:flex;flex-direction:column;min-width:0}.setlist-list__name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.setlist-list__meta{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.setlist-list__actions{display:flex;gap:var(--space-xs);flex-shrink:0;padding-right:var(--space-sm)}.setlist-create{max-width:400px}.setlist-create h1{margin-bottom:var(--space-lg)}.setlist-create form{display:flex;flex-direction:column;gap:var(--space-md)}.setlist-detail h1{margin-bottom:var(--space-lg)}.setlist-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl)}.setlist-header .input{flex:1 1}.setlist-section{margin-bottom:var(--space-xl)}.setlist-section h2{font-size:var(--font-size-lg);margin-bottom:var(--space-md)}.setlist-songs{display:flex;flex-direction:column;gap:var(--space-xs)}.setlist-songs__item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius);border:1px solid var(--color-border)}.setlist-songs__info{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.setlist-songs__title{font-weight:500}.setlist-songs__artist{color:var(--color-text-secondary)}.setlist-songs__artist,.setlist-songs__key{font-size:var(--font-size-sm);margin-left:var(--space-sm)}.setlist-songs__key{color:var(--color-primary)}.setlist-songs__actions{display:flex;gap:var(--space-xs);flex-shrink:0}.setlist-add-row{display:flex;gap:var(--space-sm);margin-top:var(--space-md)}.setlist-add-row select{flex:1 1}.setlist-members{display:flex;flex-direction:column;gap:var(--space-xs)}.setlist-members__item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius);border:1px solid var(--color-border)}.setlist-members__name{font-weight:500}.setlist-members__email{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.setlist-invite-row{display:flex;gap:var(--space-sm);margin-top:var(--space-md)}.setlist-invite-row select{flex:1 1}.setlist-play{display:flex;flex-direction:column;flex:1 1;min-height:0;margin:calc(-1*var(--space-md))}@media(min-width:600px){.setlist-play{margin:calc(-1*var(--space-lg))}}.setlist-play__topbar{position:-webkit-sticky;position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg);border-bottom:1px solid var(--color-border);flex-shrink:0}.setlist-play__counter{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap}.setlist-play .song-view__header{margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border)}.setlist-play__body{flex:1 1;overflow-y:auto;padding:var(--space-md);-webkit-overflow-scrolling:touch}.setlist-play__nav{position:-webkit-sticky;position:sticky;bottom:0;z-index:10;display:flex;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg);border-top:1px solid var(--color-border);flex-shrink:0}.setlist-play__nav .btn{flex:1 1}.setlist-play__fs-btn{font-size:1.2rem;line-height:1;flex-shrink:0}.setlist-play--fullscreen{position:fixed;inset:0;z-index:1000;margin:0;background:var(--color-bg)}.setlist-play__overlay{position:absolute;inset:0;z-index:20;pointer-events:none;opacity:0;transition:opacity .3s ease}.setlist-play__overlay--visible{opacity:1}.setlist-play__overlay-top{top:0;align-items:center;padding:var(--space-sm) var(--space-md);background:linear-gradient(to bottom,var(--color-bg) 60%,transparent);padding-bottom:var(--space-xl)}.setlist-play__overlay-bottom,.setlist-play__overlay-top{position:absolute;left:0;right:0;display:flex;gap:var(--space-sm);pointer-events:auto}.setlist-play__overlay-bottom{bottom:0;flex-direction:column;padding:var(--space-sm) var(--space-md);background:linear-gradient(to top,var(--color-bg) 60%,transparent);padding-top:var(--space-xl)}.setlist-play__overlay-nav{display:flex;gap:var(--space-sm)}.setlist-play__overlay-nav .btn{flex:1 1}.setlist-play__autoscroll{display:flex;align-items:center;justify-content:center;gap:var(--space-md);font-size:var(--font-size-sm)}.setlist-play__autoscroll-speed{min-width:3ch;text-align:center;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.billing-page{max-width:520px;margin:0 auto}.billing-page h1{margin-bottom:var(--space-sm)}.billing-page__subtitle{color:var(--color-text-secondary);margin-bottom:var(--space-xl)}.billing-plans{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-md);gap:var(--space-md)}@media(max-width:480px){.billing-plans{grid-template-columns:1fr}}.billing-plan-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;padding:var(--space-lg) var(--space-lg) var(--space-lg);text-align:center;position:relative;display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.billing-plan-card--featured{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.billing-plan-card__badge{position:absolute;top:0;left:50%;transform:translate(-50%,-50%);background:var(--color-primary);color:#fff;font-size:.75rem;font-weight:700;padding:3px 10px;border-radius:99px;letter-spacing:.02em;white-space:nowrap}.billing-plan-card h3{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;margin:0}.billing-plan-card__price{display:flex;align-items:baseline;gap:2px}.billing-plan-card__amount{font-size:2.5rem;font-weight:800;line-height:1}.billing-plan-card__note,.billing-plan-card__period{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.billing-plan-card__note{margin:0}.billing-plan-card .btn{width:100%;margin-top:auto}.billing-active{text-align:center;padding:var(--space-xl) 0}.billing-active__badge{display:inline-block;background:var(--color-primary);color:#fff;font-weight:700;font-size:var(--font-size-lg);padding:var(--space-xs) var(--space-lg);border-radius:var(--radius);margin-bottom:var(--space-md)}.billing-active p{color:var(--color-text-secondary);margin-bottom:var(--space-lg)}.billing-result{text-align:center;padding:var(--space-xl) 0;max-width:400px;margin:0 auto}.billing-result h1{margin-bottom:var(--space-md)}.billing-result p{color:var(--color-text-secondary);margin-bottom:var(--space-lg)}.plan-badge{font-size:var(--font-size-sm);font-weight:600;padding:2px var(--space-sm);border-radius:var(--radius-sm);text-decoration:none;white-space:nowrap}.plan-badge--pro{background:var(--color-primary);color:#fff}.plan-badge--upgrade{background:var(--color-bg-secondary);color:var(--color-primary)}.plan-badge--upgrade:hover{background:var(--color-primary);color:#fff}.account-page{max-width:560px;margin:0 auto}.account-page h1{margin-bottom:var(--space-lg)}.account-section{padding:var(--space-lg) 0;border-bottom:1px solid var(--color-border)}.account-section:last-child{border-bottom:none}.account-section h2{font-size:var(--font-size-lg);margin-bottom:var(--space-md)}.account-clerk-embed{overflow:hidden;border-radius:var(--radius)}.account-subscription{text-align:center;padding:var(--space-md) 0}.account-subscription p{color:var(--color-text-secondary);margin-bottom:var(--space-md)}.account-subscription__subtitle{color:var(--color-text-secondary);margin-bottom:var(--space-lg)}.account-invoices{list-style:none;display:flex;flex-direction:column;gap:var(--space-xs)}.account-invoices__empty{color:var(--color-text-secondary)}.account-invoices__item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm)}.account-invoices__item:last-child{border-bottom:none}.account-invoices__date{min-width:90px}.account-invoices__amount{font-weight:600;min-width:80px}.account-invoices__status{color:var(--color-text-secondary);flex:1 1}.account-invoices__actions{display:flex;gap:var(--space-xs)}.user-avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;overflow:hidden;flex-shrink:0;transition:opacity .15s}.user-avatar:hover{opacity:.8}.user-avatar--placeholder{background:var(--color-bg-secondary)}.user-avatar__img{width:100%;height:100%;object-fit:cover;display:block}.user-avatar__fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-primary);color:#fff;font-weight:600;font-size:var(--font-size-sm)}.legal__header{margin-bottom:var(--space-xl)}.legal{max-width:700px;margin:0 auto;padding:var(--space-xl) var(--space-md);padding-top:8vh}.legal h1{font-size:var(--font-size-xl);font-weight:800}.legal h1,.legal h2{margin-bottom:var(--space-sm)}.legal h2{font-size:var(--font-size-base);font-weight:700;margin-top:var(--space-xl)}.legal li,.legal p{color:var(--color-text-secondary);line-height:1.7;font-size:var(--font-size-sm)}.legal ul{padding-left:var(--space-lg);margin-top:var(--space-sm)}.legal li{margin-bottom:var(--space-xs)}.legal a{color:var(--color-primary);text-decoration:underline}.legal__updated{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-lg)}@font-face{font-family:Corinthia;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/fa58a89f81ef8a55-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Corinthia;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/85167fc1663429d8-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Corinthia;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/5624cfea84e8cb8e-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Corinthia Fallback;src:local("Arial");ascent-override:132.87%;descent-override:76.92%;line-gap-override:0.00%;size-adjust:57.20%}.__className_00c7e9{font-family:Corinthia,Corinthia Fallback;font-weight:700;font-style:normal}.__variable_00c7e9{--font-logo:"Corinthia","Corinthia Fallback"}