: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{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none}button,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}@media(min-width:600px){.app-header__logo{margin-right:0}}.app-header__user{position:relative;z-index:25}.app-header__nav{display:none;gap:var(--space-md);flex:1 1}@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;padding:var(--space-md);max-width:800px;width:100%;margin:0 auto}@media(min-width:600px){.app-main{padding:var(--space-lg)}}.landing{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;text-align:center;gap:var(--space-md)}.landing h1{font-size:3rem;font-weight:800;color:var(--color-primary)}.landing__actions{display:flex;gap:var(--space-md);margin-top: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)}.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)}.btn--ghost:hover{color:var(--color-text);background:var(--color-bg-secondary)}.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}.songs-page__header{display:flex;align-items:center;justify-content:space-between}.song-view__header,.songs-page__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;gap:var(--space-sm);margin-top:var(--space-md)}.transpose-controls{display:flex;align-items:center;gap:var(--space-xs)}.transpose-controls__value{font-family:var(--font-mono);font-size:var(--font-size-sm);min-width:2em;text-align:center}.chord-sheet{font-family:var(--font-mono);font-size:var(--font-size-base);line-height:1.4}.chord-section{margin-bottom:var(--space-lg)}.chord-section__label{font-family:var(--font-sans);font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-sm)}.chord-line{display:flex;flex-wrap:wrap;margin-bottom:var(--space-xs)}.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}.song-editor{gap:var(--space-lg)}.song-editor,.song-editor__meta{display:flex;flex-direction:column}.song-editor__meta{gap:var(--space-sm)}@media(min-width:600px){.song-editor__meta{display:grid;grid-template-columns:1fr 1fr auto}}.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)}.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)}.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}.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}.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__empty-line{height:1.6em}.section-editor__placeholder{color:var(--color-text-secondary);font-style:italic}.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}.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)}.chord-picker__input:focus{outline:none;border-color:var(--color-primary)}.chord-picker__remove{color:#dc2626}.chord-picker__grid{flex-direction:column}.chord-picker__grid,.chord-picker__row{display:flex;gap:2px}.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}.chord-picker__chip--active,.chord-picker__chip:hover{background:var(--color-primary);color:#fff}.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)}@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"}