:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:var(--text-primary);background-color:var(--background-base);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:color .2s ease,background-color .2s ease}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:inherit;color:inherit}#root{min-height:100vh}a{color:inherit}button,input,select,textarea{font:inherit;color:inherit}textarea{resize:vertical}::selection{background-color:#3b82f633}:root{--text-primary: #0f172a;--text: #0f172a;--text-muted: #475569;--surface: #ffffff;--glass: hsla(0, 0%, 100%, .8);--border: #e2e8f0;--muted: #64748b;--muted-surface: #f1f5f9;--nav-icon-color: var(--text);--accent: #2563eb;--accent-soft: rgba(149, 181, 252, .99);--danger: #dc2626;--shadow: 0 12px 32px rgba(15, 23, 42, .08);--nav-width: 320px;--background-base: #f8fafc;--background: hsl(218, 37%, 92%);--surface-elevated: #ffffff;--panel-border: rgba(148, 163, 184, .24);--textarea-bg: rgba(241, 245, 249, .6);--textarea-border: #d0d7e3;--nav-overlay-background: rgba(255, 255, 255, .98);--chord-diagram-title: #e2e8f0;--chord-diagram-label: #cbd5e1;--chord-diagram-grid: rgba(241, 245, 249, .85);--chord-diagram-dot: #2563eb;--chord-diagram-dot-text: #0f172a;--chord-diagram-barre: #2563eb;--chord-diagram-open: rgba(241, 245, 249, .95);--chord-diagram-muted: #ef4444;--chord-diagram-surface: #ffffff;--chord-diagram-border: #e2e8f0;--chord-diagram-popover-surface: rgba(15, 23, 42, .98);--chord-diagram-popover-border: rgba(15, 23, 42, .3);--chord-diagram-popover-text: #f8fafc;--chord-diagram-card-surface: rgba(15, 23, 42, .98);--chord-diagram-card-border: rgba(15, 23, 42, .3);--chord-diagram-card-text: #f8fafc;--chord-diagram-container: #0f172a;--chord-diagram-container-border: rgba(15, 23, 42, .4);--edit-chord-modal-preview-background: hsla(0, 0%, 100%, .3);--header-height: 72px;--header-stack-height: 150px;--song-font-scale: .6;--meter-gap: 4px;--preview-header-text: var(--accent);--control-shell: #f4f7fb;--control-surface: #e9eef5;--control-inner: #e1e8f4;--control-button: #dfe6f3;--control-text: #1f2937;--control-muted-text: #6b7280;--control-meter-track: rgba(15, 23, 42, .18);--control-meter-fill: var(--accent)}[data-theme=dark]{--text-primary: #e2e8f0;--text: #e2e8f0;--text-muted: #94a3b8;--surface: #111c2f;--glass: hsl(218, 47%, 13%, .95);--border: #1e293b;--muted: #94a3b8;--muted-surface: rgba(15, 23, 42, .8);--nav-icon-color: #f8fafc;--accent: #60a5fa;--accent-soft: rgba(149, 181, 252, .99);--danger: #f87171;--shadow: 0 12px 32px rgba(2, 6, 23, .45);--background-base: #0b1120;--background: #111c2f;--surface-elevated: #152338;--panel-border: rgba(148, 163, 184, .32);--textarea-bg: rgba(12, 21, 38, .92);--textarea-border: rgba(148, 163, 184, .3);--nav-overlay-background: rgba(11, 17, 32, .96);--chord-diagram-title: #0f172a;--chord-diagram-label: #334155;--chord-diagram-grid: rgba(15, 23, 42, .75);--chord-diagram-dot: #60a5fa;--chord-diagram-dot-text: #0b1120;--chord-diagram-barre: #60a5fa;--chord-diagram-open: rgba(15, 23, 42, .9);--chord-diagram-muted: #ef4444;--chord-diagram-surface: #ffffff;--chord-diagram-border: #e2e8f0;--chord-diagram-popover-surface: rgba(255, 255, 255, .98);--chord-diagram-popover-border: rgba(226, 232, 240, .9);--chord-diagram-popover-text: #0f172a;--chord-diagram-card-surface: var(--chord-diagram-surface);--chord-diagram-card-border: var(--chord-diagram-border);--chord-diagram-card-text: var(--text-primary);--chord-diagram-container: #e2e8f0;--chord-diagram-container-border: rgba(148, 163, 184, .45);--edit-chord-modal-preview-background: hsla(218, 47%, 13%, .6);--header-height: 72px;--header-stack-height: 150px;--song-font-scale: .6;--control-shell: #111c2f;--control-surface: #0f172a;--control-inner: #0b1629;--control-button: #0f1b2f;--control-text: #e2e8f0;--control-muted-text: #94a3b8;--control-meter-track: rgba(148, 163, 184, .35);--control-meter-fill: var(--accent);--preview-header-text: var(--accent)}.app{display:flex;flex-direction:column;min-height:100vh;background:var(--background);overflow-x:hidden}.app__header{position:fixed;top:0;left:0;right:0;z-index:16;display:grid;padding:.75rem clamp(.9rem,4vw,2rem) .9rem;background:var(--glass);border-bottom:1px solid var(--border);border-radius:0 0 20px 20px;box-shadow:0 0 6px 8px #0f172a57;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.app__header.has-controls{gap:.65rem}.app__main{padding:calc(var(--header-stack-height, 180px) + 1rem) clamp(0rem,4vw,.85rem) 2rem;display:flex;flex-direction:column;gap:0rem;flex:1}.app__controls{display:flex;flex-direction:column;gap:.75rem;width:100%;border:none;border-radius:22px}.app__controls-header{display:flex;align-items:center;justify-content:center;background:var(--control-shell);border-radius:20px;box-shadow:inset 0 0 10px #00000078;cursor:pointer}.app__controls-title{margin:0;font-weight:800;letter-spacing:.02em;text-transform:uppercase;font-size:.85rem;color:var(--control-muted-text);line-height:1}.app__controls-caret{border-radius:12px;background:transparent;color:var(--control-muted-text);font-weight:800;letter-spacing:.08em;font-size:1.3rem;box-shadow:none;display:inline-flex;align-items:center;justify-content:center;pointer-events:none;padding-bottom:5px;padding-left:5px}.app__toolbar{opacity:80%;display:flex;flex-wrap:wrap;align-items:stretch;justify-content:center;gap:.5rem;row-gap:.25rem;background:var(--chord-diagram-card-surface);border:none;border-radius:18px;padding:.75rem .9rem;width:100%;margin:0;box-shadow:inset 0 0 8px 3px #000000b8}.toolbar-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-template-areas:"trans auto text";gap:.5rem;width:100%;align-items:start;justify-items:stretch;max-width:100%;margin:0}.toolbar-group{display:flex;flex-direction:column;gap:.05rem;align-items:flex-start;min-width:0;width:100%;justify-content:flex-start}.toolbar-group--trans{grid-area:trans}.toolbar-group--auto{grid-area:auto}.toolbar-group--text{grid-area:text}.toolbar-group__label{margin:0 0 2px;font-size:.64rem;letter-spacing:.05em;text-transform:uppercase;color:var(--chord-diagram-title);line-height:1.2;padding-left:2px;font-weight:700}.toolbar-group .transposer,.toolbar-group .app__autoscroll-control,.toolbar-group .app__textsize-control{width:100%}.toolbar-row{display:flex;align-items:stretch;justify-content:center;gap:.5rem;width:100%}.toolbar-row--split{display:grid;grid-template-columns:1fr;gap:.25rem;width:100%}.toolbar-row--split .toolbar-row-inner{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}.app__autoscroll{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.app__autoscroll-control,.app__textsize-control{display:flex;flex-direction:column;gap:.08rem;align-items:stretch;padding:.12rem .35rem 0;min-height:56px;box-shadow:inset 0 1px #ffffff08;position:relative}.toolbar-group.app__autoscroll{flex-direction:column;align-items:flex-start;gap:.05rem}@media (max-width: 639px){.toolbar-grid{grid-template-columns:repeat(2,minmax(0,1fr));grid-template-areas:"trans trans" "auto text"}}@media (max-width: 340px){.toolbar-grid{grid-template-columns:1fr;grid-template-areas:"trans" "auto" "text";gap:.35rem}.toolbar-group{max-width:none}}.app__autoscroll-stepper{display:inline-flex;align-items:center;gap:.18rem;justify-content:space-between;width:100%;background:transparent;border:none;border-radius:10px;padding:0;position:relative;overflow:visible;height:28px}.app__autoscroll-stepper button{width:28px;height:28px;border-radius:9px;border:none;background:var(--control-button);color:var(--control-text);font-size:.85rem;font-weight:700;line-height:1;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease}.app__autoscroll-stepper button:hover{background:var(--accent);color:#fff}.app__autoscroll-toggle{padding:.35rem .45rem;min-width:68px;border-radius:9px;border:none;background:linear-gradient(180deg,#94a3b81f,#94a3b80a);color:var(--control-text);opacity:.9;font-size:.88rem;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease;font-weight:800;flex:1 1 0}.app__autoscroll-toggle:hover{background:var(--accent);color:#fff}.app__autoscroll-stepper button:active,.app__autoscroll-toggle:active{background:color-mix(in srgb,var(--accent) 100%,black 10%);color:#fff}.app__autoscroll-toggle.is-active{border-color:var(--accent);background:var(--accent);color:#fff;opacity:1}.app__autoscroll-meter{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:var(--meter-gap);align-items:center;padding:0;position:absolute;pointer-events:none;left:.35rem;right:.35rem;bottom:4px;margin:0}@media (max-width: 639px){.app__toolbar{padding:.4rem .55rem;gap:.25rem;align-items:center}.transposer__control,.app__autoscroll-stepper,.app__textsize{height:32px;padding-top:.08rem;padding-bottom:.08rem}.app__autoscroll-meter,.app__textsize-meter{bottom:3px}}.app__autoscroll-dot{width:100%;height:4px;border-radius:999px;background:var(--control-meter-track);transition:background .15s ease,transform .15s ease;margin:0;box-shadow:inset 0 0 0 1px #0000000f}.app__autoscroll-dot.is-filled{background:var(--control-meter-fill);transform:none}.app__textsize{display:inline-flex;align-items:center;gap:.35rem;justify-content:space-between;width:100%;border:none;border-radius:10px;padding:0;background:transparent;position:relative;overflow:visible;height:28px}.app__textsize-btn{width:30px;height:28px;border-radius:9px;border:none;background:var(--control-button);color:var(--control-text);font-weight:700;font-size:.92rem;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease}.app__textsize-btn--small{font-size:.74rem;font-weight:600;transform:translateY(1px)}.app__textsize-btn--large{font-size:1rem}.app__textsize-btn:hover{background:var(--accent);color:#fff}.app__textsize-control{align-items:center}.app__textsize-value{border-radius:9px;border:none;background:var(--control-button);color:var(--control-text);font-size:.88rem;font-weight:800;padding:.25rem .45rem;min-width:68px;text-align:center;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease;flex:1 1 0}.app__textsize-value:hover{background:var(--accent);color:#fff}.app__textsize-btn:active,.app__textsize-value:active{background:color-mix(in srgb,var(--accent) 100%,black 10%);color:#fff}.app__textsize-meter{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:var(--meter-gap);align-items:center;padding:0;position:absolute;pointer-events:none;left:.35rem;right:.35rem;bottom:4px;margin:0}.app__textsize span{min-width:48px;text-align:center;color:var(--muted);font-weight:600;font-variant-numeric:tabular-nums}.app__toolbar-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.app__edit{padding:.5rem .9rem;border-radius:12px;border:1px solid rgba(37,99,235,.35);background:#2563eb14;color:var(--accent);cursor:pointer}.app__edit:hover{background:#2563eb29}.app__remove{padding:.5rem .9rem;border-radius:12px;border:1px solid rgba(220,38,38,.2);background:#dc262614;color:var(--danger);cursor:pointer}.app__remove:hover{background:#dc26261f}.app__empty{margin:auto;font-size:1rem;color:var(--muted);width:min(720px,80%)}.app__empty-card{padding:clamp(2.5rem,4vw,2.5rem);border-radius:24px;background:linear-gradient(75deg,#1418ffa4,#8b21e88b,#ca8effa0);border:0px solid rgba(148,163,184,.25);box-shadow:0 18px 44px #0f172a1f;color:var(--text);display:flex;flex-direction:column;gap:1.5rem;text-align:left}.app__empty-header{display:inline-flex;align-items:center;gap:.75rem}.app__empty-icon{width:76px;height:76px;flex-shrink:0}.app__empty-card h2{margin:0 0 .5rem;font-size:clamp(.5rem,4vw,2rem)}.app__empty-card p{margin:0;color:var(--text-muted)}.song-nav{display:flex;flex-direction:column;gap:.5rem;position:relative;width:100%}.song-nav__header{display:flex;align-items:center;gap:.65rem;flex-wrap:nowrap;min-width:0;width:100%}.song-nav__title{display:flex;flex-direction:row;margin-left:auto;min-width:0;text-align:right;align-items:center;flex:0 0 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:.2rem}.song-nav__title-text{display:flex;flex-direction:column;gap:.15rem;align-items:flex-end;min-width:0}.song-nav__header h2{margin:0;font-size:clamp(.8rem,2.5vw,1rem);white-space:nowrap;line-height:1}.song-nav__favicon{height:2.5dvh;width:auto;flex-shrink:0;display:block;margin-left:.2rem}.song-nav__version{margin:0;font-size:clamp(.8rem,.8vw,1rem);color:var(--muted);white-space:nowrap;line-height:1.2}.song-nav__actions{display:flex;align-items:flex-start;gap:.4rem;flex-wrap:nowrap;flex-shrink:0}.song-nav__toggle,.song-nav__controls,.song-nav__add,.song-nav__more{display:inline-flex;align-items:center;justify-content:center;border-radius:12px;font-weight:600;cursor:pointer;white-space:nowrap;width:2.75rem;height:2.75rem;padding:0;min-width:2.75rem;flex-shrink:0;color:var(--nav-icon-color)}.song-nav__toggle{gap:.4rem;border:1px solid var(--border);background:#94a3b81f;font-size:1.25rem}.song-nav__controls,.song-nav__add,.song-nav__more{border:1px solid var(--border);background:#94a3b81f}.song-nav__toggle:hover,.song-nav__controls:hover,.song-nav__add:hover,.song-nav__more:hover{background:#94a3b82e;color:var(--nav-icon-color)}.song-nav__toggle.is-active,.song-nav__controls.is-active,.song-nav__add.is-active,.song-nav__more.is-active{border-color:var(--accent);background:var(--accent);color:#fff}.song-nav__actions .song-nav__more{font-size:1.35rem}.song-nav__menu{position:relative}.song-nav__menu-panel{position:absolute;top:110%;right:auto;left:0;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);display:flex;flex-direction:column;min-width:200px;z-index:30}.song-nav__menu-panel--item{right:0;left:auto;z-index:30}.song-nav__menu-panel button{border:none;background:transparent;padding:.7rem .9rem;text-align:left;cursor:pointer;color:var(--text);transition:background-color .12s ease,color .12s ease;display:grid;grid-template-columns:auto 1fr;gap:.6rem;align-items:center}.song-nav__menu-icon{width:1.8rem;height:1.8rem;display:inline-flex;align-items:center;justify-content:center;color:var(--text)}.song-nav__menu-panel button:hover:not(.song-nav__menu-hint){background:var(--muted-surface);color:var(--accent)}.song-nav__menu-panel button.song-nav__danger{color:var(--danger);font-weight:700}.song-nav__icon,.song-nav__menu-icon{display:inline-flex;align-items:center;justify-content:center;background-color:currentColor;mask-repeat:no-repeat;mask-position:center;mask-size:70% 70%;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center;-webkit-mask-size:70% 70%;color:inherit}.song-nav__icon{width:1.6rem;height:1.6rem}.song-nav__menu-icon{width:2rem;height:2rem;color:var(--nav-icon-color)}.song-nav__icon--note{mask-image:url(/icons/queue-music.svg);-webkit-mask-image:url(/icons/queue-music.svg)}.song-nav__icon--panel{mask-image:url(/icons/panel.svg);-webkit-mask-image:url(/icons/panel.svg)}.song-nav__icon--plus{mask-image:url(/icons/plus.svg);-webkit-mask-image:url(/icons/plus.svg)}.song-nav__icon--gear{mask-image:url(/icons/gear.svg);-webkit-mask-image:url(/icons/gear.svg)}.song-nav__icon--search{mask-image:url(/icons/search.svg);-webkit-mask-image:url(/icons/search.svg)}.song-nav__icon--link{mask-image:url(/icons/link.svg);-webkit-mask-image:url(/icons/link.svg)}.song-nav__icon--import{mask-image:url(/icons/import.svg);-webkit-mask-image:url(/icons/import.svg)}.song-nav__icon--export{mask-image:url(/icons/export.svg);-webkit-mask-image:url(/icons/export.svg)}.song-nav__icon--save{mask-image:url(/icons/save.svg);-webkit-mask-image:url(/icons/save.svg)}.song-nav__icon--library{mask-image:url(/icons/library.svg);-webkit-mask-image:url(/icons/library.svg)}.song-nav__icon--dots{mask-image:url(/icons/dots.svg);-webkit-mask-image:url(/icons/dots.svg)}.song-nav__menu-panel button.song-nav__danger:hover{background:#dc26261a;color:var(--danger);border-radius:10px}.song-nav__menu-hint{color:var(--muted);cursor:default}.song-nav__overlay{position:absolute;top:calc(100% + .65rem);left:0;width:min(760px,calc(100vw - 2rem));z-index:24}.song-nav__overlay--mobile{position:fixed;inset:0;background:var(--nav-overlay-background);padding:0;display:flex;justify-content:center;align-items:stretch;width:100%;max-width:none;height:100vh;overflow:hidden;overscroll-behavior:contain;z-index:28}.song-nav__panel{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem;max-height:70vh;min-width:min(420px,100%);width:100%}.song-nav__overlay--mobile .song-nav__panel{width:100%;max-height:100vh;height:100vh;padding:1.25rem 1.25rem 1.5rem;border-radius:0;min-width:100%;overflow:auto;box-shadow:none;overscroll-behavior:contain}.song-nav__panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.song-nav__panel-header h3{margin:0;letter-spacing:.08em;text-transform:uppercase;font-size:.85rem;color:var(--muted)}.song-nav__panel-subtitle{margin:.1rem 0 0;color:var(--muted);font-size:.9rem}.song-nav__close{border:1px solid var(--danger);background:var(--danger);border-radius:10px;padding:.35rem .7rem;font-size:1.2rem;cursor:pointer;color:#fff}.song-nav__scroll{flex:1;overflow-y:auto;padding-right:.5rem;display:flex;flex-direction:column;gap:1.25rem;min-height:0}.song-nav__letter-group h3{margin:0 0 .5rem;font-size:.9rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.song-nav__artist{margin-bottom:1rem}.song-nav__artist p{margin:0 0 .4rem;font-weight:600}.song-nav__artist ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.35rem}.song-nav__item{display:flex;align-items:center;justify-content:space-between;gap:.4rem}.song-nav__item-main{display:flex;align-items:center;gap:.4rem;width:100%;min-width:0}.song-nav__artist button{width:100%;min-width:0;text-align:left;padding:.45rem .7rem;border-radius:10px;border:1px solid transparent;background:transparent;color:inherit;cursor:pointer;overflow:hidden;text-overflow:ellipsis;display:inline-flex;align-items:center;gap:.45rem}.song-nav__artist button:hover{border-color:#94a3b899;background:#94a3b80f}.song-nav__artist button.is-active{border-color:var(--accent);background:var(--accent-soft);color:#fff}.song-nav__item .song-nav__menu{margin-left:auto}.song-nav__item-type{display:inline-flex;align-items:center;padding:.08rem .4rem;border-radius:999px;border:1px solid var(--border);background:#94a3b826;color:var(--muted);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.song-nav__artist button.is-active .song-nav__item-type,.song-nav__artist button.is-active .song-type-pill--inline{background:#ffffff26;color:#fff;border-color:#ffffff59}.song-nav__item-actions{display:flex;align-items:center;gap:.3rem;flex-shrink:0;position:relative}.song-nav__item-actions button{border:1px solid var(--border);background:var(--muted-surface);color:var(--text);padding:.35rem .5rem;border-radius:8px;cursor:pointer;font-size:.85rem}.song-nav__item-actions button:hover{background:#94a3b833}button:disabled{opacity:.5;cursor:not-allowed}.transposer{display:inline-flex;align-items:center;height:auto;width:100%;margin:0}.transposer__control{display:inline-flex;align-items:center;gap:.18rem;justify-content:space-between;padding:.12rem .32rem 0;min-height:56px;width:100%;box-shadow:inset 0 1px #ffffff08}.transposer__control button{width:26px;height:26px;border-radius:9px;border:none;background:var(--control-button);color:var(--control-text);font-size:.82rem;font-weight:700;line-height:1;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease;flex-shrink:0}.transposer__control button:hover{background:var(--accent);color:#fff}.transposer__control button:active{background:color-mix(in srgb,var(--accent) 100%,black 10%);color:#fff}.transposer__control button:disabled{opacity:.45;cursor:not-allowed}.transposer__display{display:inline-flex;align-items:center;gap:.35rem;padding:0 .36rem;border-radius:9px;background:var(--control-button);color:var(--control-text);min-width:68px;justify-content:center;border:none;font-size:.88rem;font-weight:800;cursor:pointer;transition:background .12s ease,border-color .12s ease;line-height:1;height:26px;flex:1 1 0}.transposer__display:hover{border-color:#00000014;background:#00000014}.transposer__display-step{font-size:.96rem;font-weight:800;color:var(--control-text)}.transposer__display-key{font-weight:700;font-size:.86rem;color:var(--control-muted-text)}.song-sheet{background:transparent;padding:clamp(.5rem,2vw,2.5rem);box-shadow:none;display:flex;flex-direction:column;gap:2rem;font-size:.85rem;line-height:1.55;width:100%;box-sizing:border-box;overflow:visible}.song-sheet__layout{display:grid;grid-template-columns:1fr;grid-template-areas:"right" "left";gap:1.5rem}.song-sheet__left{grid-area:left;min-width:0;order:2}.song-sheet__right{grid-area:right;display:block;gap:1rem;min-width:0;order:1;width:100%;max-width:100%;position:static;top:auto;align-self:stretch}.song-sheet__right-inner{display:grid;gap:1rem;width:100%;max-width:100%;min-width:0;box-sizing:border-box}.song-sheet__right>*{width:100%;max-width:100%;min-width:0;box-sizing:border-box}.song-sheet__notes-panel .notes-panel{margin:0}.song-sheet__header{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;width:100%;min-width:0}.song-sheet__title-stack{display:flex;align-items:center;gap:.75rem;min-width:0;flex:0 1 auto;width:auto;max-width:100%;align-self:center;justify-content:center}.song-sheet__title-row{display:flex;flex-direction:column;gap:.35rem;position:relative;width:100%;max-width:100%;min-width:0;align-items:flex-start;text-align:left}.song-sheet__artist-row{display:flex;align-items:center;gap:.35rem;width:100%;min-width:0;flex-wrap:nowrap}.song-sheet__header h2{margin:0rem 0;display:inline-flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:clamp(1.4rem,4vw,2.7rem);line-height:1.15;white-space:normal;word-break:break-word;text-align:left;justify-content:flex-start;text-overflow:clip;overflow:visible;min-width:0;flex:1 1 auto;width:100%}.song-sheet__title-text{display:inline-flex;min-width:0;overflow:visible;text-overflow:clip;white-space:normal;word-break:break-word;flex:1 1 auto;text-align:left}.song-type-pill--inline{display:inline-flex;align-items:center;padding:.2rem 1.5rem;border-radius:999px;border:1px solid var(--border);background:#94a3b826;color:var(--muted);font-size:clamp(.6rem,2vw,.72rem);font-weight:800;text-transform:uppercase;letter-spacing:.06em;flex:0 1 auto;min-width:0;max-width:40%;padding-inline:.7rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-sheet__artist{margin:0;color:var(--muted);font-weight:500;flex:0 0 auto;white-space:nowrap}.song-sheet__meta{display:flex;gap:1.5rem;margin:0;width:100%;min-width:0;justify-content:center;text-align:center}.song-sheet__meta div{margin:0;display:grid;gap:.2rem}.song-sheet__meta dt{margin:0;font-size:.65rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}.song-sheet__meta dd{margin:0;font-weight:600}.song-sheet__edit{border:1px solid var(--border);background:var(--control-button);color:var(--control-text);border-radius:10px;padding:.35rem;width:38px;height:38px;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.song-sheet__edit:hover{background:var(--accent);color:#fff}.song-sheet__edit-icon{width:1.1rem;height:1.1rem;display:inline-block;background-color:currentColor;mask:url(/icons/edit.svg) center / 80% 80% no-repeat;-webkit-mask:url(/icons/edit.svg) center / 80% 80% no-repeat}.song-sheet__meta a{color:var(--accent);text-decoration:none;font-weight:700}.song-sheet__meta a:hover{text-decoration:underline}.chord-lib__backdrop{position:fixed;inset:0;background:#0f172a8c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:1.5rem;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom,0px));min-height:100dvh;z-index:34}.chord-lib{width:min(1100px,100%);max-height:min(90vh,calc(100dvh - env(safe-area-inset-bottom,0px) - 1rem));background:var(--surface);border-radius:18px;border:1px solid var(--border);box-shadow:0 30px 90px #00000059;display:flex;flex-direction:column;gap:1rem;padding:1.25rem;padding-bottom:calc(2.5rem + env(safe-area-inset-bottom,0px));overflow:hidden}.chord-lib__header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.chord-lib__header h2{margin:0}.chord-lib__close{border:1px solid var(--danger);background:var(--danger);color:#fff;font-size:1.2rem;cursor:pointer;border-radius:10px;width:2.5rem;height:2.5rem}.chord-lib__form{display:grid;gap:.75rem;background:var(--muted-surface);border-radius:14px;padding:.9rem}.chord-lib__row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.5rem}.chord-lib__row label{display:grid;gap:.25rem;font-size:.9rem;color:var(--muted)}.chord-lib__row input{border-radius:10px;border:1px solid var(--border);background:var(--surface);padding:.5rem .6rem;color:var(--text)}.chord-lib__row--grid{grid-template-columns:repeat(auto-fit,minmax(110px,1fr))}.chord-lib__strings{display:grid;gap:.45rem;flex:1 1 auto;grid-template-columns:repeat(2,minmax(0,1fr))}@media (max-height: 774px) and (min-width: 900px){.chord-lib__strings{grid-template-columns:repeat(3,minmax(0,1fr))}}.chord-lib__string-group{background:var(--surface);border-radius:12px;border:1px solid var(--border);padding:.35rem .45rem .3rem;display:grid;gap:.15rem}.chord-lib__string-label{margin:0;font-weight:700;color:var(--text);font-size:.85rem}.chord-lib__string-group label{display:grid;gap:.2rem;font-size:.8rem;color:var(--muted)}.chord-lib__string-group input,.chord-lib__string-group select,.chord-lib__barre select{border-radius:10px;border:1px solid var(--border);background:var(--surface);padding:.4rem .5rem;color:var(--text);min-width:0}.chord-lib__form-section{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:.75rem;display:grid;gap:.5rem;width:100%}.chord-lib__form-section h4,.chord-lib__form-section--preview h4{margin:0;font-size:.95rem;letter-spacing:.05em;text-transform:uppercase}.chord-lib__editor-grid{display:grid;gap:1.3rem;grid-template-columns:1fr}.chord-lib__form-section--info{order:1}.chord-lib__form-section--barre{order:2}.chord-lib__form-section--strings{order:3;display:flex;flex-direction:column}.chord-lib__form-section--preview{order:4;position:sticky;bottom:0;background:var(--surface);z-index:2}.chord-lib__shift-control{display:grid;gap:.35rem;width:min(100%,260px);align-self:flex-start}.chord-lib__shift-label{margin:0;font-size:.85rem;color:var(--muted);font-weight:700;letter-spacing:.02em}.chord-lib__shift{display:inline-flex;align-items:center;gap:.35rem;justify-content:space-between;width:100%;border:none;border-radius:10px;padding:0;background:transparent;position:relative;overflow:visible;height:28px}.chord-lib__shift-btn{width:30px;height:28px;border-radius:9px;border:none;background:var(--control-button);color:var(--control-text);font-weight:700;font-size:.92rem;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease}.chord-lib__shift-btn--small{font-size:.78rem;font-weight:600;transform:translateY(1px)}.chord-lib__shift-btn--large{font-size:1.02rem}.chord-lib__shift-btn:hover{background:var(--accent);color:#fff}.chord-lib__shift-btn:disabled{background:var(--muted-surface);color:var(--muted);cursor:not-allowed;opacity:.6}.chord-lib__shift-value{border-radius:9px;border:none;background:var(--control-button);color:var(--control-text);font-size:.88rem;font-weight:800;padding:.25rem .45rem;min-width:68px;text-align:center;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease;flex:1 1 0}.chord-lib__shift-value:hover{background:var(--accent);color:#fff}.chord-lib__shift-btn:active,.chord-lib__shift-value:active{background:color-mix(in srgb,var(--accent) 100%,black 10%);color:#fff}@media (min-width: 900px){.chord-lib__editor-grid{grid-template-columns:3fr 1.5fr;grid-template-rows:auto 1fr auto;grid-template-areas:"barre preview" "strings preview" "strings info"}.chord-lib__form-section--barre{grid-area:barre;align-self:start}.chord-lib__form-section--preview{grid-area:preview;align-self:start}.chord-lib__form-section--strings{grid-area:strings}.chord-lib__form-section--info{grid-area:info}}.chord-lib__barre-grid{display:flex;flex-wrap:wrap;gap:.75rem}.chord-lib__barre-pair{flex:1 1 260px;min-width:220px;background:var(--surface);border-radius:12px;border:1px solid var(--border);padding:.65rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:.5rem}.chord-lib__barre-pair label{display:grid;gap:.2rem;font-size:.85rem;color:var(--muted)}.chord-lib__preview{display:grid;gap:.35rem;margin-top:.5rem}.chord-lib__preview p{margin:0;font-weight:700;color:var(--text)}.chord-lib__diagram{background:var(--chord-diagram-container);border:1px solid var(--chord-diagram-container-border);border-radius:12px;padding:0rem;display:flex;justify-content:center}.chord-diagram-picker{position:relative;display:grid;grid-template-columns:repeat(2,auto);grid-template-areas:"diag diag" "prev next" "count count" "label label";justify-items:center;align-content:start;padding:.5rem;row-gap:0}.chord-diagram-picker__diagram{grid-area:diag;display:flex;justify-content:center;transform:none;transform-origin:center;margin-bottom:-1.6rem;pointer-events:none}.chord-diagram-picker__diagram svg{display:block;transform:scale(.78);transform-origin:top center}.chord-diagram-picker__arrow{position:static;transform:none;margin-bottom:.29rem;border:1px solid var(--border);background:var(--muted-surface);color:var(--text);border-radius:10px;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:.95rem;pointer-events:auto;z-index:1}.chord-diagram-picker__arrow--prev{grid-area:prev}.chord-diagram-picker__arrow--next{grid-area:next}.chord-diagram-picker__count{grid-area:count;padding-top:.5rem;font-size:.59rem;color:var(--muted);line-height:1.1}.chord-diagram-picker__label{grid-area:label;margin:0;font-size:.65rem;color:var(--muted);font-weight:600;line-height:1.1}.chord-diagram-picker p{margin:0}.chord-lib__actions{display:flex;gap:.5rem;flex-wrap:wrap;padding:1.25rem;border-top:1px solid var(--border);background:var(--surface);box-shadow:0 -8px 20px #0f172a14;position:sticky;bottom:0}.chord-lib__save{border:1px solid var(--accent);background:var(--accent);color:#fff;border-radius:10px;padding:.55rem 1rem;cursor:pointer}.chord-lib__secondary{border:1px solid var(--border);background:transparent;color:var(--text);border-radius:10px;padding:.55rem 1rem;cursor:pointer}.chord-lib__hint{margin:0;font-size:.85rem;color:var(--muted)}.chord-lib__list{overflow:auto;display:grid;gap:1rem;padding-right:.25rem;padding-bottom:calc(2.5rem + env(safe-area-inset-bottom,0px));scroll-padding-bottom:calc(2.5rem + env(safe-area-inset-bottom,0px));-webkit-overflow-scrolling:touch}.chord-lib__toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem}.chord-lib__filters{display:flex;flex-wrap:wrap;gap:.4rem}.chord-lib__filter{border-radius:999px;border:1px solid var(--border);background:transparent;padding:.35rem .65rem;cursor:pointer;font-weight:600;color:var(--muted)}.chord-lib__filter.is-active{background:var(--accent);border-color:var(--accent);color:#fff}.chord-lib__add{border-radius:10px;border:1px solid var(--border);background:var(--muted-surface);padding:.5rem .85rem;cursor:pointer;font-weight:600;color:var(--text)}.chord-lib__section{display:grid;gap:.5rem;background:var(--muted-surface);border-radius:12px;padding:.75rem}.chord-lib__section-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.chord-lib__section h3{margin:0}.chord-lib__badge{font-size:.85rem;color:var(--muted)}.chord-lib__cards{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(135px,1.2fr))}.chord-lib__card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:.5rem .75rem .75rem;display:grid;gap:.5rem;align-items:start}.chord-lib__card--custom{border-color:#2563eb33}.chord-lib__card--preferred{border-color:var(--accent);box-shadow:0 0 0 1px #2563eb66}.chord-lib__card-actions{display:flex;justify-content:flex-end}.chord-lib__card-menu{position:relative}.chord-lib__card-menu-btn{border:1px solid var(--border);background:var(--muted-surface);border-radius:999px;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;font-size:1.2rem;line-height:1;cursor:pointer;color:var(--text)}.chord-lib__card-menu-panel{position:absolute;top:calc(100% + .35rem);right:0;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:.35rem;display:grid;gap:.15rem;min-width:140px;box-shadow:0 10px 25px #0f172a40;z-index:6}.chord-lib__card-menu-panel button{border:none;background:transparent;padding:.45rem .6rem;border-radius:8px;text-align:left;font-size:.9rem;color:var(--text);cursor:pointer}.chord-lib__card-menu-panel button:hover{background:var(--muted-surface)}.chord-lib__card-menu-panel button:disabled{opacity:.6;cursor:default}.chord-lib__card-menu-item--danger{color:var(--danger)}.chord-lib__flag{display:inline-flex;align-items:center;gap:.2rem;font-size:.75rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}.chord-lib__label{margin:0;font-size:.85rem;color:var(--muted)}.chord-lib__editor-backdrop{position:fixed;inset:0;background:#020617e6;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:36}.chord-lib__editor-backdrop--modal{padding:0}.chord-lib__form--floating{width:min(980px,calc(100vw - 1rem));max-height:min(90vh,calc(100dvh - env(safe-area-inset-bottom,0px) - 1rem));border-radius:30px;border:1px solid var(--border);background:var(--surface);box-shadow:0 20px 80px #0f172a59;display:flex;flex-direction:column;overflow:hidden;position:relative;align-self:center;padding-bottom:calc(4.5rem + env(safe-area-inset-bottom,0px))}.chord-lib__form-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem;border-radius:20px;box-shadow:0 4px 8px 2px #00000026;background:var(--glass);z-index:4}.chord-lib__form-header h3{margin:0}.chord-lib__form-header button{border:1px solid var(--border);background:var(--danger);border-radius:8px;width:2rem;color:#fff;height:2rem;cursor:pointer}.chord-lib__editor-scroll{overflow-y:auto;flex:1 1 auto;display:grid;gap:1rem;position:relative;z-index:1;background:var(--surface);padding-bottom:calc(5.5rem + env(safe-area-inset-bottom,0px));scroll-padding-bottom:calc(5.5rem + env(safe-area-inset-bottom,0px));max-height:calc(100dvh - 9rem - env(safe-area-inset-bottom,0px));-webkit-overflow-scrolling:touch}.chord-lib__row--compact{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.45rem}.chord-lib__row--compact label{min-width:0;display:flex;flex-direction:column}.chord-lib__row--compact input{width:100%}@media (max-width: 400px){.chord-lib__row--compact{grid-template-columns:1fr}}.song-sheet__body{display:flex;flex-direction:column;gap:.75rem;font-size:calc(1rem * var(--song-font-scale, 1));line-height:1.55;min-width:60dvw;align-self:center;max-width:95dvw;box-sizing:border-box;overflow:visible}.song-sheet__section{margin:1.5rem 0 .5rem;font-size:1rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}.song-sheet__spacer{height:.75rem}.song-sheet--plain .song-sheet__body{font-family:JetBrains Mono,Fira Code,monospace;font-size:.85rem;gap:0rem}.song-sheet__plain-line{font-family:inherit}.chord-palette{display:flex;flex-direction:column;gap:.6rem;align-items:stretch;width:100%}.chord-palette__header{display:flex;align-items:center;justify-content:center;gap:.6rem;width:100%;max-width:100%;margin:0 auto;padding:.6rem .4rem;border-radius:20px;background:var(--control-shell);box-shadow:inset 0 0 10px #000000de;cursor:pointer;flex-wrap:nowrap;min-width:0}.chord-palette h3{margin:0;font-size:clamp(.72rem,2vw,.82rem);letter-spacing:0em;text-transform:uppercase;color:var(--control-muted-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chord-palette__caret{font-size:1.3rem;font-weight:800;padding-bottom:3px;color:var(--control-muted-text);line-height:1}.chord-palette__panel{background:var(--control-surface);border-radius:18px;padding:.35rem .6rem .5rem;box-shadow:inset 0 0 10px #000000de;width:100%;max-width:100%}.chord-palette__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.5rem;padding:1rem}.chord-palette__grid figure{margin:0;background:var(--chord-diagram-card-surface);border:1px solid var(--chord-diagram-card-border);color:var(--chord-diagram-card-text);border-radius:18px;padding:.05rem .2rem;box-shadow:0 18px 44px #0f172a14;display:flex;justify-content:center;align-items:flex-start}.chord-palette__figure--missing{background:transparent!important;border-color:transparent!important;color:var(--text);box-shadow:none;padding:0}.chord-palette__missing{display:grid;gap:.4rem;padding:.5rem .6rem .6rem;width:100%;color:var(--text);background:#ef44441f;border:1px solid var(--danger);border-radius:16px;box-sizing:border-box}.chord-palette__missing-title{margin:0;font-weight:800}.chord-palette__missing-text,.chord-palette__missing-hint{margin:0;font-size:.92rem;color:var(--text)}.chord-palette__missing-actions{display:grid;gap:.35rem;margin-top:.4rem}.chord-palette__missing-actions button{border:1px solid var(--danger);background:#fff;color:var(--text);border-radius:10px;padding:.45rem .6rem;cursor:pointer;font-weight:800}.chord-palette__missing-actions button:hover{background:#ef44441f}.chord-line{position:relative;display:block;font-family:JetBrains Mono,Fira Code,monospace;width:100%;line-height:1.55;padding-top:2.4rem;overflow:hidden;box-sizing:border-box}.chord-line__lyrics{white-space:pre-wrap;word-break:keep-all;overflow-wrap:break-word;-webkit-hyphens:none;hyphens:none;font-size:inherit;max-width:100%}.chord-line__chords{position:absolute;top:0;left:0;right:0;height:2.2rem;pointer-events:none;overflow:hidden}.chord-line__chord{position:absolute;top:0;display:flex;align-items:flex-end;font-size:inherit}.chord-line__chord>*{pointer-events:auto}.chord-token{position:relative}.chord-token__label{padding:.2rem .5rem;border-radius:8px;border:1px solid rgba(37,99,235,.3);background:#2563eb14;color:var(--accent);cursor:pointer;font-size:inherit}.chord-token__label--missing{border-color:#dc262640;background:#dc262614;color:var(--danger)}.chord-token__diagram{position:fixed;top:0;left:0;transform:none;background:var(--chord-diagram-popover-surface);border:1px solid var(--chord-diagram-popover-border);color:var(--chord-diagram-popover-text);backdrop-filter:blur(1px);-webkit-backdrop-filter:blur(12px);box-shadow:0 24px 48px #0f172a40;border-radius:18px;padding:1rem 1.25rem;z-index:5;width:max-content;max-width:min(90vw,540px);inset-inline:12px}.chord-token__close{position:absolute;top:8px;right:8px;border:1px solid var(--danger);background:var(--danger);color:#fff;font-size:1rem;cursor:pointer;border-radius:8px;width:1.8rem;height:1.8rem}.chord-token__missing{max-width:220px;font-size:.9rem;color:var(--muted)}.chord-token__missing p{margin:.4rem 0}.chord-token__hint{font-size:.8rem}.chord-token__actions{display:flex;gap:.4rem;margin-top:.5rem}.chord-token__actions button{border:1px solid var(--border);background:var(--control-button);color:var(--control-text);border-radius:8px;padding:.3rem .6rem;cursor:pointer;font-weight:700}.chord-token__actions button:hover{background:var(--accent);color:#fff}.notes-panel{background:transparent;border-radius:20px;box-shadow:var(--shadow);padding:.5rem;display:flex;flex-direction:column;gap:.75rem;transition:background-color .2s ease,border-color .2s ease}.notes-panel textarea{width:100%;border-radius:12px;border:none;padding:.75rem;background:transparent;color:var(--text-primary);transition:background-color .2s ease,border-color .2s ease;flex:1 1 auto;min-height:180px;resize:vertical}.notes-panel textarea::placeholder{color:var(--muted);opacity:.9}.song-form__backdrop{position:fixed;inset:0;background:#0f172aa6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:2rem;z-index:32}.song-form{width:min(640px,100%);background:var(--surface);border-radius:24px;padding:1.5rem 1.75rem;display:flex;flex-direction:column;gap:1.25rem;max-height:90vh;overflow:hidden;box-shadow:0 30px 90px #0009}.song-form header{display:flex;align-items:center;justify-content:space-between}.song-form header h2{margin:0}.song-form header button{border:1px solid var(--danger);background:var(--danger);font-size:1.5rem;cursor:pointer;color:#fff;border-radius:10px;width:2.5rem;height:2.5rem}.song-form__field{display:grid;gap:.4rem}.song-form__row{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.song-form__field input,.song-form__field textarea{border-radius:12px;border:1px solid var(--textarea-border);padding:.6rem .75rem;background:var(--textarea-bg);color:var(--text-primary);transition:background-color .2s ease,border-color .2s ease;width:100%}.song-form__field select{border-radius:12px;border:1px solid var(--textarea-border);padding:.6rem .75rem;background:var(--textarea-bg);color:var(--text-primary);transition:background-color .2s ease,border-color .2s ease;width:100%;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:right .8rem center,right .55rem center;background-size:8px 8px,8px 8px;background-repeat:no-repeat}.song-form__field select:focus{outline:none;border-color:var(--accent)}.song-form__body{display:grid;gap:1.25rem;flex:1;min-height:0;overflow-y:auto;padding-right:.25rem;margin-right:-.25rem}.song-form__hint{margin:0;font-size:.85rem;color:var(--muted)}.song-form__error{margin:0;padding:.75rem 1rem;border-radius:12px;background:#dc26261a;color:#991b1b}.song-form footer{display:flex;justify-content:flex-end;gap:.75rem}.song-form__secondary{border-radius:12px;border:1px solid var(--border);background:transparent;padding:.6rem 1.1rem;cursor:pointer}.song-form__primary{border-radius:12px;border:none;background:var(--accent);color:#fff;padding:.6rem 1.3rem;cursor:pointer}.ug-search__backdrop{position:fixed;inset:0;background:#0f172aa6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:32}.ug-search{width:min(960px,100%);background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:0 30px 90px #0009;display:flex;flex-direction:column;gap:1rem;padding:1.25rem}.ug-search__header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.ug-search__close{border:1px solid var(--danger);background:var(--danger);color:#fff;font-size:1.2rem;cursor:pointer;border-radius:10px;width:2.5rem;height:2.5rem}.ug-search__controls{display:grid;gap:.75rem}.ug-search__row{display:flex;gap:.75rem;flex-wrap:wrap}.ug-search__row input{flex:1;min-width:240px;border-radius:10px;border:1px solid var(--border);padding:.65rem .75rem;background:var(--muted-surface);color:var(--text)}.ug-search__row button{padding:.65rem 1rem;border-radius:10px;border:1px solid rgba(37,99,235,.35);background:#2563eb14;color:var(--accent);cursor:pointer}.ug-search__error{color:var(--danger);margin:0}.ug-search__results{max-height:60vh;overflow:auto;border:1px solid var(--border);border-radius:12px;padding:.5rem;background:var(--muted-surface)}.ug-search__hint{margin:.25rem 0 .5rem;color:var(--text-muted)}.ug-search__results ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.ug-search__result{display:flex;justify-content:space-between;gap:1rem;padding:.75rem;border-radius:10px;background:var(--surface);border:1px solid var(--border)}.ug-search__title{margin:0 0 .2rem;font-weight:600}.ug-search__artist{margin:0;color:var(--text-muted)}.ug-search__badges{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.35rem}.ug-search__badge{padding:.2rem .5rem;border-radius:10px;background:var(--muted-surface);border:1px solid var(--border);font-size:.85rem;color:var(--muted)}.ug-search__actions{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;min-width:120px}.ug-search__actions button{padding:.5rem .8rem;border-radius:10px;border:1px solid rgba(37,99,235,.35);background:#2563eb14;color:var(--accent);cursor:pointer}.ug-search__link{color:var(--text-muted);font-size:.9rem}.theme-toggle-floating{position:fixed;right:1rem;bottom:1rem;width:52px;height:52px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--text);box-shadow:0 12px 32px #000e;cursor:pointer;z-index:40}body.modal-open{overflow:hidden}@media (max-width: 640px){.song-form__row{grid-template-columns:1fr}}@media (max-width: 899px){.app__header{padding:.75rem 1rem .85rem}.song-nav__header{gap:.6rem;flex-wrap:nowrap}.song-nav__actions{width:auto}.song-nav__overlay{width:100%}.song-nav__overlay--mobile .song-nav__scroll{max-height:none}}@media (max-width: 639px){.app__toolbar{padding:1rem}.chord-token__diagram{left:0;transform:none}}@media (max-width: 899px){.song-nav__title{max-width:70vw}.chord-lib__editor-backdrop,.chord-lib__backdrop{padding:0;align-items:stretch;justify-content:stretch}.chord-lib{width:100vw;height:100vh;max-height:100vh;border-radius:0;border:none;box-shadow:none;padding:1.1rem}.song-form__backdrop{padding:0;align-items:stretch;justify-content:stretch}.song-form{width:100vw;height:100vh;max-height:100vh;border-radius:0;box-shadow:none;padding:1.25rem 1.1rem 1.5rem}.chord-lib__editor-backdrop .chord-lib__form--floating{width:100vw;height:100vh;max-height:100vh;border-radius:0;border:none;box-shadow:none;background:var(--surface);align-self:stretch}.chord-lib__editor-backdrop .chord-lib__form{padding:0;background:var(--surface);border-radius:0;gap:0}.chord-lib__editor-backdrop .chord-lib__form-header{position:sticky;top:0;padding:1rem;border-bottom:1px solid rgba(148,163,184,.3);background:var(--surface);z-index:4}.chord-lib__editor-backdrop .chord-lib__editor-scroll{padding:0;gap:1rem}.chord-lib__editor-backdrop .chord-lib__form-section{border:none;border-radius:0;margin:0;background:transparent}.chord-lib__editor-backdrop .chord-lib__form-section--strings{margin-bottom:6rem}.chord-lib__editor-backdrop .chord-lib__strings{grid-template-columns:repeat(4,minmax(0,1fr))}@media (max-width: 639px){.chord-lib__editor-backdrop .chord-lib__strings{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 401px){.chord-lib__editor-backdrop .chord-lib__strings{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 280px){.chord-lib__editor-backdrop .chord-lib__strings{grid-template-columns:1fr}}.chord-lib__editor-backdrop .chord-lib__form-section--preview{box-shadow:0 0 30px 3px #000c;margin:0;padding:1.7rem;width:100%;border-radius:30px 30px 0 0;background:var(--glass);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.chord-lib__editor-backdrop .chord-lib__form-section--preview h4{color:var(--preview-header-text)}.chord-lib__editor-backdrop .chord-lib__actions{margin:0;padding:1rem;width:100%;border-radius:0;box-shadow:0 -12px 35px #0006;position:sticky;bottom:calc(env(safe-area-inset-bottom,0px) + 1rem);background:var(--surface);padding-bottom:0}.song-sheet__header{flex-direction:column;align-items:center;justify-content:center;text-align:left}.song-sheet__title-stack{justify-content:center;align-items:center;align-self:center}.song-sheet__title-row{align-items:flex-start;text-align:left;width:100%}.song-sheet__meta{justify-content:center;align-items:flex-start;align-self:center;text-align:left}}@media (min-width: 900px){.app__main{display:flex;flex-direction:column;margin-top:var(--header-stack-height, 150px);padding:1rem clamp(.6rem,4vw,1.5rem) 1.25rem;box-sizing:border-box;min-height:calc(100vh - var(--header-stack-height, 150px));gap:1rem}.song-sheet{overflow:hidden;flex:1 1 auto;min-height:0;height:auto;max-height:calc(100vh - var(--header-stack-height, 150px) - 2.5rem)}.song-sheet__layout{display:grid;grid-template-columns:minmax(0,.7fr) minmax(0,.3fr);grid-template-areas:"left right";align-items:stretch;gap:2rem;height:100%;min-height:0}.song-sheet__left{grid-area:left;order:1;align-self:stretch;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.song-sheet__right{grid-area:right;order:2;align-self:stretch;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.song-sheet__left,.song-sheet__right{scrollbar-width:none}.song-sheet__left::-webkit-scrollbar,.song-sheet__right::-webkit-scrollbar{display:none}.song-sheet__right-inner{position:static;align-self:start;height:auto;max-height:none;overflow:visible;align-content:start;display:grid;gap:1rem}.song-sheet__header{width:100%;position:sticky;top:0;z-index:2;padding:.35rem 0;background:var(--background);box-shadow:0 -12px 3px 14px #0006;border-bottom:1px solid var(--border)}.song-sheet__header h2{font-size:clamp(1rem,1.6vw,1.7rem)}.song-sheet__meta{justify-content:center;flex-wrap:wrap}.song-sheet__right .chord-palette,.song-sheet__right .chord-palette__header,.song-sheet__right .chord-palette__panel{width:100%}}@media (max-width: 370px){.song-nav__title-text{display:none}.song-nav__title{gap:.25rem;max-width:none}}.chord-lib__string-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.2rem}.chord-lib__string-grid select{width:100%}
