*,*:before,*:after{box-sizing:border-box}html{--bg: #101216;--fg: #e6e8ec;--chord-fg: #7cc4ff;--lyric-fg: #e6e8ec;--section-verse-fg: #9ca3af;--section-chorus-fg: #f59e0b;--section-bridge-fg: #c084fc;--section-tab-fg: #94a3b8;--section-intro-fg: #34d399;--section-outro-fg: #34d399;--section-pre_chorus-fg: #fb7185;--accent: #3b82f6;--fg-rgb: 230, 232, 236;--accent-rgb: 59, 130, 246;--chord-fg-rgb: 124, 196, 255;--bg-rgb: 16, 18, 22;--font-lyrics: "Inter", "Segoe UI", system-ui, sans-serif;--font-chords: "JetBrains Mono", "Consolas", monospace;--font-weight-lyrics: 400;--font-weight-chords: 600;--column-gap: 2rem;--line-height: 1.55;--user-scale: 1;--touch-target: 44px;background-color:var(--bg);color:var(--fg);font-family:var(--font-lyrics);font-size:16px;line-height:var(--line-height)}body{margin:0;padding:0;background-color:var(--bg);color:var(--fg);min-height:100vh;padding-top:env(safe-area-inset-top);padding-right:env(safe-area-inset-right);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);touch-action:manipulation}input,textarea,select{font-size:max(16px,1em)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(var(--fg-rgb),.3);background:color-mix(in srgb,var(--fg) 30%,transparent);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:rgba(var(--fg-rgb),.5);background:color-mix(in srgb,var(--fg) 50%,transparent)}.sync-indicator.svelte-15e08h8{display:inline-flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:500;padding:.25rem .625rem;border-radius:999px}.sync-dot.svelte-15e08h8{width:7px;height:7px;border-radius:50%;flex-shrink:0}.sync-connected.svelte-15e08h8{color:#22c55e;background:#22c55e1f;background:color-mix(in srgb,#22c55e 12%,transparent)}.sync-connected.svelte-15e08h8 .sync-dot:where(.svelte-15e08h8){background:#22c55e}.sync-reconnecting.svelte-15e08h8{color:#f59e0b;background:#f59e0b1f;background:color-mix(in srgb,#f59e0b 12%,transparent)}.sync-reconnecting.svelte-15e08h8 .sync-dot:where(.svelte-15e08h8){background:#f59e0b;animation:svelte-15e08h8-pulse 1s ease-in-out infinite}.sync-queued.svelte-15e08h8{color:#3b82f6;background:#3b82f61f;background:color-mix(in srgb,#3b82f6 12%,transparent)}.sync-queued.svelte-15e08h8 .sync-dot:where(.svelte-15e08h8){background:#3b82f6;animation:svelte-15e08h8-pulse 1.4s ease-in-out infinite}.sync-offline.svelte-15e08h8{color:#ef4444;background:#ef44441f;background:color-mix(in srgb,#ef4444 12%,transparent)}.sync-offline.svelte-15e08h8 .sync-dot:where(.svelte-15e08h8){background:#ef4444}.sync-label.svelte-15e08h8{white-space:nowrap}@keyframes svelte-15e08h8-pulse{0%,to{opacity:.4}50%{opacity:1}}.overlay-backdrop.svelte-150v3v{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000080;background:color-mix(in srgb,var(--bg) 30%,rgba(0,0,0,.6));-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.overlay-sheet.svelte-150v3v{position:relative;width:85vw;max-width:1100px;max-height:90vh;overflow:auto;background:var(--bg);color:var(--fg);border-radius:12px;box-shadow:0 10px 40px #0006;padding:.5rem}.overlay-missing.svelte-150v3v{width:auto;padding:1.5rem;text-align:center}@media(max-width:640px){.overlay-sheet.svelte-150v3v{width:100vw;max-width:100vw;height:100dvh;max-height:100dvh;border-radius:0;padding:0}}.song-list.svelte-rb1kdj{display:flex;flex-direction:column;height:100%}.search-bar.svelte-rb1kdj{padding:.75rem 1rem;border-bottom:1px solid rgba(var(--fg-rgb),.1);border-bottom:1px solid color-mix(in srgb,var(--fg) 10%,transparent)}.search-input.svelte-rb1kdj{width:100%;padding:.5rem .75rem;background:rgba(var(--fg-rgb),.08);background:color-mix(in srgb,var(--fg) 8%,transparent);border:1px solid rgba(var(--fg-rgb),.15);border:1px solid color-mix(in srgb,var(--fg) 15%,transparent);border-radius:6px;color:var(--fg);font-family:inherit;font-size:.9375rem;outline:none}.search-input.svelte-rb1kdj:focus{border-color:var(--accent)}.status-message.svelte-rb1kdj{padding:2rem 1rem;text-align:center;color:rgba(var(--fg-rgb),.6);color:color-mix(in srgb,var(--fg) 60%,transparent)}.list.svelte-rb1kdj{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1}.list-item.svelte-rb1kdj{border-bottom:1px solid rgba(var(--fg-rgb),.08);border-bottom:1px solid color-mix(in srgb,var(--fg) 8%,transparent);display:flex;align-items:stretch}.song-row.svelte-rb1kdj{display:flex;align-items:center;justify-content:space-between;flex:1;padding:.75rem 1rem;background:none;border:none;color:var(--fg);text-align:left;cursor:pointer;transition:background-color .1s;min-height:44px;gap:.75rem;min-width:0}.song-row.svelte-rb1kdj:hover{background:rgba(var(--fg-rgb),.06);background:color-mix(in srgb,var(--fg) 6%,transparent)}.song-main.svelte-rb1kdj{display:flex;flex-direction:column;gap:.125rem;min-width:0}.song-title.svelte-rb1kdj{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-artist.svelte-rb1kdj{font-size:.8125rem;color:rgba(var(--fg-rgb),.65);color:color-mix(in srgb,var(--fg) 65%,transparent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-meta.svelte-rb1kdj{display:flex;flex-wrap:wrap;gap:.25rem;flex-shrink:0}.tag.svelte-rb1kdj{font-size:.75rem;padding:.125rem .5rem;border-radius:4px;background:rgba(var(--fg-rgb),.1);background:color-mix(in srgb,var(--fg) 10%,transparent);white-space:nowrap}.key-tag.svelte-rb1kdj{color:var(--chord-fg);background:rgba(var(--chord-fg-rgb),.12);background:color-mix(in srgb,var(--chord-fg) 12%,transparent)}.tempo-tag.svelte-rb1kdj{color:var(--accent);background:rgba(var(--accent-rgb),.12);background:color-mix(in srgb,var(--accent) 12%,transparent)}.modal-backdrop.svelte-1c9g7hw{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:100}.modal.svelte-1c9g7hw{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg);border:1px solid rgba(var(--fg-rgb),.15);border:1px solid color-mix(in srgb,var(--fg) 15%,transparent);border-radius:10px;width:min(600px,95vw);max-height:80vh;display:flex;flex-direction:column;z-index:101;box-shadow:0 20px 60px #00000080}.modal-header.svelte-1c9g7hw{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid rgba(var(--fg-rgb),.1);border-bottom:1px solid color-mix(in srgb,var(--fg) 10%,transparent)}.modal-title.svelte-1c9g7hw{margin:0;font-size:1.125rem;font-weight:700}.close-btn.svelte-1c9g7hw{background:none;border:none;font-size:1.25rem;color:rgba(var(--fg-rgb),.6);color:color-mix(in srgb,var(--fg) 60%,transparent);cursor:pointer;padding:.25rem;line-height:1}.close-btn.svelte-1c9g7hw:hover{color:var(--fg)}.tabs.svelte-1c9g7hw{display:flex;border-bottom:1px solid rgba(var(--fg-rgb),.1);border-bottom:1px solid color-mix(in srgb,var(--fg) 10%,transparent);padding:0 1.25rem}.tab.svelte-1c9g7hw{background:none;border:none;padding:.625rem 1rem;color:rgba(var(--fg-rgb),.65);color:color-mix(in srgb,var(--fg) 65%,transparent);font-size:.875rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.tab.active.svelte-1c9g7hw{color:var(--accent);border-bottom-color:var(--accent)}.modal-body.svelte-1c9g7hw{padding:1.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:.875rem}.hint.svelte-1c9g7hw{margin:0;font-size:.875rem;color:rgba(var(--fg-rgb),.7);color:color-mix(in srgb,var(--fg) 70%,transparent)}.paste-area.svelte-1c9g7hw{width:100%;background:rgba(var(--fg-rgb),.05);background:color-mix(in srgb,var(--fg) 5%,transparent);border:1px solid rgba(var(--fg-rgb),.15);border:1px solid color-mix(in srgb,var(--fg) 15%,transparent);border-radius:6px;color:var(--fg);font-family:var(--font-chords);font-size:.875rem;padding:.625rem .875rem;resize:vertical;outline:none;box-sizing:border-box}.paste-area.svelte-1c9g7hw:focus{border-color:var(--accent)}.file-label.svelte-1c9g7hw{display:inline-block;cursor:pointer}.file-input.svelte-1c9g7hw{display:none}.file-btn.svelte-1c9g7hw{display:inline-flex;align-items:center;padding:.5rem 1rem;background:rgba(var(--fg-rgb),.1);background:color-mix(in srgb,var(--fg) 10%,transparent);border:1px solid rgba(var(--fg-rgb),.2);border:1px solid color-mix(in srgb,var(--fg) 20%,transparent);border-radius:6px;font-size:.9375rem;font-weight:500;color:var(--fg);cursor:pointer}.file-btn.svelte-1c9g7hw:hover{background:rgba(var(--fg-rgb),.18);background:color-mix(in srgb,var(--fg) 18%,transparent)}.actions.svelte-1c9g7hw{display:flex;justify-content:flex-end}.error.svelte-1c9g7hw{margin:0;padding:.5rem .75rem;border-radius:6px;font-size:.875rem;background:color-mix(in srgb,red 15%,transparent);color:color-mix(in srgb,red 80%,var(--fg))}.library-overlay.svelte-sx1eby{display:flex;flex-direction:column;height:80vh;background:var(--bg)}.overlay-header.svelte-sx1eby{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid rgba(var(--fg-rgb),.1);border-bottom:1px solid color-mix(in srgb,var(--fg) 10%,transparent);flex-shrink:0}.overlay-title.svelte-sx1eby{margin:0;font-size:1.125rem;font-weight:700}.header-actions.svelte-sx1eby{display:flex;align-items:center;gap:.5rem}.close-btn.svelte-sx1eby{display:flex;align-items:center;justify-content:center;background:none;border:1px solid rgba(var(--fg-rgb),.18);border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);border-radius:6px;color:rgba(var(--fg-rgb),.65);color:color-mix(in srgb,var(--fg) 65%,transparent);cursor:pointer;font-size:1.2rem;line-height:1;min-height:var(--touch-target);min-width:var(--touch-target);padding:.25rem .5rem}.close-btn.svelte-sx1eby:hover{color:var(--fg);background:rgba(var(--fg-rgb),.08);background:color-mix(in srgb,var(--fg) 8%,transparent)}.list-area.svelte-sx1eby{flex:1;overflow:hidden;display:flex;flex-direction:column}.setlists-overlay.svelte-192dbr2{display:flex;flex-direction:column;height:80vh;background:var(--bg)}.overlay-header.svelte-192dbr2{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid rgba(var(--fg-rgb),.1);border-bottom:1px solid color-mix(in srgb,var(--fg) 10%,transparent);flex-shrink:0}.overlay-title.svelte-192dbr2{flex:1;margin:0;font-size:1.125rem;font-weight:700}.close-btn.svelte-192dbr2{display:flex;align-items:center;justify-content:center;background:none;border:1px solid rgba(var(--fg-rgb),.18);border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);border-radius:6px;color:rgba(var(--fg-rgb),.65);color:color-mix(in srgb,var(--fg) 65%,transparent);cursor:pointer;font-size:1.2rem;line-height:1;min-height:var(--touch-target);min-width:var(--touch-target);padding:.25rem .5rem}.close-btn.svelte-192dbr2:hover{color:var(--fg);background:rgba(var(--fg-rgb),.08);background:color-mix(in srgb,var(--fg) 8%,transparent)}.page-body.svelte-192dbr2{flex:1;overflow-y:auto;padding:1rem}.create-row.svelte-192dbr2{display:flex;gap:.5rem;margin-bottom:1rem}.name-input.svelte-192dbr2{flex:1;padding:.5rem .75rem;background:rgba(var(--fg-rgb),.08);background:color-mix(in srgb,var(--fg) 8%,transparent);border:1px solid rgba(var(--fg-rgb),.15);border:1px solid color-mix(in srgb,var(--fg) 15%,transparent);border-radius:6px;color:var(--fg);font-family:inherit;font-size:.9375rem;outline:none}.name-input.svelte-192dbr2:focus{border-color:var(--accent)}.status.svelte-192dbr2{padding:1.5rem 0;color:rgba(var(--fg-rgb),.6);color:color-mix(in srgb,var(--fg) 60%,transparent);font-size:.875rem;text-align:center}.list.svelte-192dbr2{list-style:none;margin:0;padding:0}.list-item.svelte-192dbr2{border-bottom:1px solid rgba(var(--fg-rgb),.08);border-bottom:1px solid color-mix(in srgb,var(--fg) 8%,transparent);display:flex;align-items:stretch}.sl-row.svelte-192dbr2{display:flex;align-items:center;justify-content:space-between;flex:1;padding:.75rem 1rem;background:none;border:none;color:var(--fg);text-align:left;cursor:pointer;min-height:var(--touch-target);gap:.75rem}.sl-row.svelte-192dbr2:hover{background:rgba(var(--fg-rgb),.06);background:color-mix(in srgb,var(--fg) 6%,transparent)}.sl-name.svelte-192dbr2{font-weight:500}.sl-date.svelte-192dbr2{font-size:.8125rem;color:rgba(var(--fg-rgb),.55);color:color-mix(in srgb,var(--fg) 55%,transparent)}.pin-btn.svelte-192dbr2{flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:0 .75rem;background:none;border:none;border-left:1px solid rgba(var(--fg-rgb),.08);border-left:1px solid color-mix(in srgb,var(--fg) 8%,transparent);color:rgba(var(--fg-rgb),.35);color:color-mix(in srgb,var(--fg) 35%,transparent);cursor:pointer;transition:color .1s;min-height:var(--touch-target)}.pin-btn.svelte-192dbr2:hover,.pin-btn-active.svelte-192dbr2{color:var(--accent)}.delete-btn.svelte-192dbr2{flex-shrink:0;padding:0 .875rem;background:none;border:none;border-left:1px solid rgba(var(--fg-rgb),.08);border-left:1px solid color-mix(in srgb,var(--fg) 8%,transparent);color:rgba(var(--fg-rgb),.4);color:color-mix(in srgb,var(--fg) 40%,transparent);cursor:pointer;transition:color .1s,background-color .1s;font-size:.875rem;min-height:var(--touch-target)}.delete-btn.svelte-192dbr2:hover{color:#ef4444;background:color-mix(in srgb,#ef4444 8%,transparent)}.error.svelte-192dbr2{margin:0 0 1rem;padding:.5rem .75rem;border-radius:6px;font-size:.875rem;background:color-mix(in srgb,red 15%,transparent);color:color-mix(in srgb,red 80%,var(--fg))}.editor.svelte-1purg2h{display:flex;flex-direction:column;height:min(80vh,720px);min-height:0}@media(max-width:640px){.editor.svelte-1purg2h{height:100dvh}}.editor-header.svelte-1purg2h{display:flex;align-items:center;gap:.75rem;padding:.25rem .75rem .75rem;border-bottom:1px solid color-mix(in srgb,var(--fg) 10%,transparent);flex-shrink:0}.editor-title.svelte-1purg2h{flex:1;margin:0;font-size:1.125rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status.svelte-1purg2h{padding:1.5rem 0;color:color-mix(in srgb,var(--fg) 60%,transparent);font-size:.875rem;text-align:center}.panes.svelte-1purg2h{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.35fr);gap:.75rem;flex:1;min-height:0;padding:.75rem}.master.svelte-1purg2h{display:flex;flex-direction:column;min-width:0;min-height:0;border-right:1px solid color-mix(in srgb,var(--fg) 12%,transparent);padding-right:.5rem}.master-list.svelte-1purg2h{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.15rem;flex:1;overflow-y:auto;overflow-x:hidden}.row.svelte-1purg2h{width:100%;display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:6px;background:none;border:1px solid transparent;color:var(--fg);cursor:pointer;text-align:left;min-height:var(--touch-target, 44px)}.row.svelte-1purg2h:hover{background:color-mix(in srgb,var(--fg) 6%,transparent)}.row.active.svelte-1purg2h{background:color-mix(in srgb,var(--accent) 14%,transparent);border-color:color-mix(in srgb,var(--accent) 35%,transparent)}.details-row.svelte-1purg2h{border-bottom:1px solid color-mix(in srgb,var(--fg) 10%,transparent);margin-bottom:.15rem}.row-label.svelte-1purg2h{font-weight:700}.row-pos.svelte-1purg2h{font-size:.7rem;font-weight:700;color:color-mix(in srgb,var(--fg) 45%,transparent);flex-shrink:0;width:1.25rem}.row-title.svelte-1purg2h{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.9rem}.addrow.svelte-1purg2h{position:relative;margin-top:.6rem;flex-shrink:0;min-width:0}.add-trigger.svelte-1purg2h{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;width:100%;height:var(--touch-target, 44px);padding:0 .6rem;border-radius:7px;background:var(--accent);color:#fff;border:1px solid var(--accent);font:inherit;font-size:.85rem;font-weight:600;cursor:pointer;outline:none}.add-trigger.svelte-1purg2h:hover{opacity:.9}.add-backdrop.svelte-1purg2h{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10;border:none;background:none;padding:0;cursor:default}.add-menu.svelte-1purg2h{position:absolute;bottom:calc(var(--touch-target, 44px) + .4rem);left:0;right:0;z-index:11;max-height:16rem;overflow-y:auto;display:flex;flex-direction:column;padding:.25rem;border-radius:9px;background:var(--bg);border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);box-shadow:0 6px 24px #00000040}.add-item.svelte-1purg2h{display:flex;align-items:center;min-height:var(--touch-target, 44px);padding:0 .6rem;border:none;border-radius:6px;background:none;color:var(--fg);font:inherit;font-size:.9rem;text-align:left;cursor:pointer}.add-item.svelte-1purg2h:hover{background:color-mix(in srgb,var(--accent) 12%,transparent)}.add-empty.svelte-1purg2h{padding:.6rem;font-size:.85rem;color:color-mix(in srgb,var(--fg) 55%,transparent)}.detail.svelte-1purg2h{display:flex;flex-direction:column;gap:.7rem;min-width:0;min-height:0;padding-left:.4rem}.detail-title.svelte-1purg2h{margin:0;font-size:1rem;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.field.svelte-1purg2h{display:flex;flex-direction:column;gap:.25rem;min-width:0}.lbl.svelte-1purg2h{font-size:.75rem;color:color-mix(in srgb,var(--fg) 70%,transparent);white-space:nowrap}.field.svelte-1purg2h input:where(.svelte-1purg2h),.arr-field.svelte-1purg2h select:where(.svelte-1purg2h){width:100%;min-width:0;min-height:var(--touch-target, 44px);padding:.4rem .5rem;border-radius:7px;border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);background:var(--bg);color:var(--fg);font:inherit;font-size:.9rem;outline:none;color-scheme:dark light}.field.svelte-1purg2h input:where(.svelte-1purg2h):focus,.arr-field.svelte-1purg2h select:where(.svelte-1purg2h):focus{border-color:var(--accent)}.notes-field.svelte-1purg2h{flex:1;min-height:0}.notes-input.svelte-1purg2h{flex:1;width:100%;min-height:0;box-sizing:border-box;resize:none;overflow-y:auto;padding:.6rem .5rem;border-radius:7px;border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);background:var(--bg);color:var(--fg);font:inherit;font-size:.9rem;line-height:1.5;outline:none}.notes-input.svelte-1purg2h:focus{border-color:var(--accent)}.notes-input.svelte-1purg2h::placeholder{color:color-mix(in srgb,var(--fg) 40%,transparent)}.action-buttons.svelte-1purg2h{display:flex;flex-wrap:wrap;gap:.5rem}.text-btn.svelte-1purg2h{display:inline-flex;align-items:center;gap:.35rem;min-height:var(--touch-target, 44px);padding:0 .7rem;border-radius:7px;border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);background:var(--bg);color:var(--fg);font:inherit;font-size:.85rem;cursor:pointer}.text-btn.svelte-1purg2h:hover{border-color:var(--accent);color:var(--accent)}.badge-row.svelte-1purg2h{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.6rem}.popup-anchor.svelte-1purg2h{position:relative;display:flex;flex-direction:column;gap:.25rem}.arr-field.svelte-1purg2h{min-width:8rem}.pill-btn.svelte-1purg2h{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;min-height:var(--touch-target, 44px);min-width:var(--touch-target, 44px);padding:0 .7rem;border-radius:7px;border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);background:var(--bg);color:var(--fg);font:inherit;font-size:.9rem;cursor:pointer;white-space:nowrap}.pill-btn.svelte-1purg2h:hover{border-color:var(--accent)}.pill-btn.active.svelte-1purg2h{border-color:var(--chord-fg);color:var(--chord-fg);background:color-mix(in srgb,var(--chord-fg) 10%,transparent)}.bpm-btn.active.svelte-1purg2h{border-color:var(--accent);color:var(--fg);background:color-mix(in srgb,var(--accent) 10%,transparent)}.popup.svelte-1purg2h{position:absolute;top:calc(100% + 4px);left:0;z-index:100;background:var(--bg);border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);border-radius:10px;box-shadow:0 8px 24px #00000059;padding:.75rem;min-width:240px}.bpm-popup.svelte-1purg2h{min-width:200px}.popup-title.svelte-1purg2h{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:color-mix(in srgb,var(--fg) 60%,transparent);margin-bottom:.5rem}.bpm-input.svelte-1purg2h{width:100%;box-sizing:border-box;text-align:center;min-height:var(--touch-target, 44px);padding:.4rem;border-radius:7px;border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);background:var(--bg);color:var(--fg);font:inherit;font-size:1.1rem;outline:none;margin-bottom:.5rem}.bpm-input.svelte-1purg2h:focus{border-color:var(--accent)}.bpm-input.svelte-1purg2h::-webkit-inner-spin-button,.bpm-input.svelte-1purg2h::-webkit-outer-spin-button{display:none}.bpm-input[type=number].svelte-1purg2h{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.bpm-steps.svelte-1purg2h{display:flex;gap:.35rem;margin-bottom:.5rem}.step-btn.svelte-1purg2h{flex:1;min-height:2.25rem;border-radius:6px;border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);background:var(--bg);color:var(--fg);font:inherit;cursor:pointer}.step-btn.svelte-1purg2h:hover{background:color-mix(in srgb,var(--fg) 7%,transparent)}.popup-actions.svelte-1purg2h{display:flex;gap:.5rem;justify-content:flex-end}.popup-btn.svelte-1purg2h{padding:.35rem .8rem;border-radius:6px;font:inherit;font-weight:600;cursor:pointer;border:1px solid transparent}.popup-btn.ghost.svelte-1purg2h{background:none;border-color:color-mix(in srgb,var(--fg) 20%,transparent);color:var(--fg)}.popup-btn.primary.svelte-1purg2h{background:var(--accent);color:#fff}.spacer.svelte-1purg2h{flex:1;min-height:.5rem}.confirm.svelte-1purg2h{display:flex;flex-direction:column;gap:.5rem;font-size:.8rem;color:var(--fg);padding:.6rem;border-radius:8px;background:color-mix(in srgb,#ef4444 8%,transparent);border:1px solid color-mix(in srgb,#ef4444 30%,transparent)}.confirm-btns.svelte-1purg2h{display:flex;gap:.5rem;justify-content:flex-end}.ghost.svelte-1purg2h,.danger.svelte-1purg2h{padding:.35rem .8rem;border-radius:6px;font:inherit;font-weight:600;cursor:pointer}.ghost.svelte-1purg2h{background:none;border:1px solid color-mix(in srgb,var(--fg) 20%,transparent);color:var(--fg)}.danger.svelte-1purg2h{background:#ef4444;color:#fff;border:none}.action-row.svelte-1purg2h{display:flex;gap:.5rem;justify-content:flex-end}.iconbtn.svelte-1purg2h{display:inline-flex;align-items:center;justify-content:center;width:var(--touch-target, 44px);height:var(--touch-target, 44px);flex-shrink:0;border-radius:7px;border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);background:var(--bg);color:var(--fg);cursor:pointer}.iconbtn.svelte-1purg2h:hover:not(:disabled){background:color-mix(in srgb,var(--fg) 7%,transparent)}.iconbtn.svelte-1purg2h:disabled{opacity:.35;cursor:default}.danger-icon.svelte-1purg2h{color:#ef4444;border-color:color-mix(in srgb,#ef4444 35%,transparent)}.danger-icon.armed.svelte-1purg2h{background:color-mix(in srgb,#ef4444 12%,transparent)}.empty.svelte-1purg2h{color:color-mix(in srgb,var(--fg) 50%,transparent);font-size:.85rem;margin:0}.footer.svelte-1purg2h{display:flex;gap:.5rem;justify-content:flex-end;padding:.75rem;border-top:1px solid color-mix(in srgb,var(--fg) 8%,transparent);flex-shrink:0}.btn.svelte-1purg2h{border-radius:6px;cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:600;padding:.4rem 1rem;min-height:40px;border:1px solid transparent}.btn.primary.svelte-1purg2h{background:var(--accent);color:#fff}.btn.primary.svelte-1purg2h:hover:not(:disabled){opacity:.85}.btn.primary.svelte-1purg2h:disabled{opacity:.45;cursor:default}.btn.ghost-btn.svelte-1purg2h{background:none;border-color:color-mix(in srgb,var(--fg) 20%,transparent);color:var(--fg)}.btn.ghost-btn.svelte-1purg2h:hover:not(:disabled){background:color-mix(in srgb,var(--fg) 7%,transparent)}.btn.ghost-btn.svelte-1purg2h:disabled{opacity:.45;cursor:default}.error.svelte-1purg2h{margin:.5rem .75rem 0;padding:.5rem .75rem;border-radius:6px;font-size:.875rem;background:color-mix(in srgb,red 15%,transparent);color:color-mix(in srgb,red 80%,var(--fg))}.setlist-song-bar.svelte-42xt8n{display:flex;flex-direction:column;height:80vh;background:var(--bg)}.bar-header.svelte-42xt8n{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid color-mix(in srgb,var(--fg) 10%,transparent);flex-shrink:0}.bar-title.svelte-42xt8n{font-size:1.125rem;font-weight:700;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-actions.svelte-42xt8n{display:flex;align-items:center;gap:.375rem;flex-shrink:0}.edit-btn.svelte-42xt8n{display:flex;align-items:center;justify-content:center;background:none;border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);border-radius:6px;color:color-mix(in srgb,var(--fg) 65%,transparent);cursor:pointer;min-height:var(--touch-target);min-width:var(--touch-target);padding:.25rem;transition:color .1s,background .1s}.edit-btn.svelte-42xt8n:hover{color:var(--fg);background:color-mix(in srgb,var(--fg) 8%,transparent)}.edit-btn-active.svelte-42xt8n{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,transparent);background:color-mix(in srgb,var(--accent) 8%,transparent)}.close-btn.svelte-42xt8n{display:flex;align-items:center;justify-content:center;background:none;border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);border-radius:6px;color:color-mix(in srgb,var(--fg) 65%,transparent);cursor:pointer;font-size:1.2rem;line-height:1;min-height:var(--touch-target);min-width:var(--touch-target);padding:.25rem .5rem}.close-btn.svelte-42xt8n:hover{color:var(--fg);background:color-mix(in srgb,var(--fg) 8%,transparent)}.bar-body.svelte-42xt8n{flex:1;overflow-y:auto}.status.svelte-42xt8n{padding:1.5rem 1rem;color:color-mix(in srgb,var(--fg) 55%,transparent);font-size:.875rem;text-align:center}.error.svelte-42xt8n{padding:.75rem 1rem;font-size:.875rem;color:color-mix(in srgb,red 75%,var(--fg));background:color-mix(in srgb,red 12%,transparent);margin:.75rem;border-radius:6px}.song-list.svelte-42xt8n{list-style:none;margin:0;padding:0}.song-item.svelte-42xt8n{display:flex;align-items:center;gap:.5rem;border-bottom:1px solid color-mix(in srgb,var(--fg) 7%,transparent);padding:0 .75rem;min-height:var(--touch-target)}.song-item-active.svelte-42xt8n{background:color-mix(in srgb,var(--accent) 8%,transparent)}.song-item-dragging.svelte-42xt8n{opacity:.5}.drag-handle.svelte-42xt8n{color:color-mix(in srgb,var(--fg) 40%,transparent);cursor:grab;font-size:1rem;flex-shrink:0;-webkit-user-select:none;user-select:none}.reorder-btns.svelte-42xt8n{display:flex;flex-direction:column;gap:1px;flex-shrink:0}.reorder-btn.svelte-42xt8n{background:none;border:none;color:color-mix(in srgb,var(--fg) 50%,transparent);cursor:pointer;font-size:.55rem;line-height:1;padding:1px 3px}.reorder-btn.svelte-42xt8n:hover:not(:disabled){color:var(--fg)}.reorder-btn.svelte-42xt8n:disabled{opacity:.3;cursor:default}.position-badge.svelte-42xt8n{font-size:.75rem;font-weight:600;color:color-mix(in srgb,var(--fg) 40%,transparent);min-width:1.5rem;text-align:right;flex-shrink:0}.song-btn.svelte-42xt8n{flex:1;display:flex;align-items:center;gap:.5rem;background:none;border:none;color:var(--fg);text-align:left;cursor:pointer;padding:.5rem .25rem;min-height:var(--touch-target);min-width:0}.song-btn.svelte-42xt8n:hover:not(:disabled){color:var(--accent)}.song-btn.svelte-42xt8n:disabled{cursor:default;pointer-events:none}.song-name.svelte-42xt8n{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.song-key.svelte-42xt8n{font-size:.75rem;font-weight:600;color:var(--chord-fg, var(--accent));flex-shrink:0;padding:.1rem .3rem;border:1px solid color-mix(in srgb,var(--chord-fg, var(--accent)) 35%,transparent);border-radius:4px}.edit-controls.svelte-42xt8n{display:flex;align-items:center;gap:.375rem;flex-shrink:0}.key-edit-anchor.svelte-42xt8n{position:relative}.key-edit-btn.svelte-42xt8n{background:color-mix(in srgb,var(--fg) 8%,transparent);border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);border-radius:5px;color:var(--fg);cursor:pointer;font-family:inherit;font-size:.8rem;font-weight:600;padding:.2rem .5rem;min-height:32px;min-width:2.5rem;white-space:nowrap}.key-edit-btn.svelte-42xt8n:hover{border-color:var(--accent);color:var(--accent)}.key-picker-popup.svelte-42xt8n{position:absolute;top:calc(100% + 4px);right:0;z-index:200;background:var(--bg);border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);border-radius:10px;box-shadow:0 8px 24px #00000059;padding:.5rem;min-width:220px}.arr-select.svelte-42xt8n{background:color-mix(in srgb,var(--fg) 8%,transparent);border:1px solid color-mix(in srgb,var(--fg) 18%,transparent);border-radius:5px;color:var(--fg);font-family:inherit;font-size:.8rem;padding:.2rem .375rem;min-height:32px;cursor:pointer;max-width:8rem}.arr-select.svelte-42xt8n:focus{border-color:var(--accent);outline:none}.toast.svelte-1cpok13{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;font-size:.9375rem;max-width:400px;box-shadow:0 4px 12px #0000004d}.toast-success.svelte-1cpok13{background:color-mix(in srgb,#22c55e 20%,var(--bg));border:1px solid #22c55e;color:#22c55e}.toast-error.svelte-1cpok13{background:color-mix(in srgb,#ef4444 20%,var(--bg));border:1px solid #ef4444;color:#ef4444}.toast-info.svelte-1cpok13{background:color-mix(in srgb,var(--accent) 20%,var(--bg));border:1px solid var(--accent);color:var(--accent)}.toast-message.svelte-1cpok13{flex:1;color:var(--fg)}.toast-close.svelte-1cpok13{background:none;border:none;color:rgba(var(--fg-rgb),.6);color:color-mix(in srgb,var(--fg) 60%,transparent);cursor:pointer;font-size:1rem;padding:0;line-height:1}.toast-close.svelte-1cpok13:hover{color:var(--fg)}.toast-host.svelte-53xc05{position:fixed;bottom:1rem;right:1rem;z-index:1000;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.toast-host.svelte-53xc05 .toast{pointer-events:auto}.app-shell.svelte-12qhfyh{display:flex;flex-direction:column;min-height:100vh;background:var(--bg)}.auth-loading.svelte-12qhfyh{flex:1;background:var(--bg)}.top-bar.svelte-12qhfyh{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;border-bottom:1px solid rgba(var(--fg-rgb),.1);border-bottom:1px solid color-mix(in srgb,var(--fg) 10%,transparent);flex-shrink:0;height:48px}.brand.svelte-12qhfyh{font-weight:700;font-size:1rem;color:var(--fg);text-decoration:none}.brand.svelte-12qhfyh:hover{color:var(--accent);text-decoration:none}.pinned-nav.svelte-12qhfyh{display:flex;align-items:center;gap:.25rem;flex:1;overflow:hidden;margin:0 .75rem}.pinned-link.svelte-12qhfyh{font-size:.8rem;font-weight:500;color:rgba(var(--fg-rgb),.7);color:color-mix(in srgb,var(--fg) 70%,transparent);text-decoration:none;padding:.2rem .5rem;border-radius:5px;border:1px solid rgba(var(--fg-rgb),.12);border:1px solid color-mix(in srgb,var(--fg) 12%,transparent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:10rem;transition:color .1s,background .1s}.pinned-link.svelte-12qhfyh:hover{color:var(--fg);background:rgba(var(--fg-rgb),.08);background:color-mix(in srgb,var(--fg) 8%,transparent)}.pinned-link-active.svelte-12qhfyh{color:var(--accent);border-color:rgba(var(--accent-rgb),.4);border-color:color-mix(in srgb,var(--accent) 40%,transparent);background:rgba(var(--accent-rgb),.08);background:color-mix(in srgb,var(--accent) 8%,transparent)}.top-bar-right.svelte-12qhfyh{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.settings-btn.svelte-12qhfyh{display:flex;align-items:center;justify-content:center;color:rgba(var(--fg-rgb),.65);color:color-mix(in srgb,var(--fg) 65%,transparent);border-radius:6px;padding:.25rem;background:none;border:none;cursor:pointer;transition:color .15s;min-height:var(--touch-target);min-width:var(--touch-target)}.settings-btn.svelte-12qhfyh:hover{color:var(--fg)}.main-content.svelte-12qhfyh{flex:1;display:flex;flex-direction:column}
