:root{--bg:#1a1a22;--surface:#252530;--surface2:#2f2f3c;--border:#3c3c4e;--text:#e8e8f0;--muted:#9898b0;--accent:#d9922a;--accent2:#eaa830;--accent-alt:#7a9bb5;--danger:#ef4444;--success:#22c55e;--chord:#e6a530;--radius:10px;--nav-bg:#1a1a22eb;--overlay:#000000b3;--card-title:#fff;--shadow-sm:0 1px 2px #0000004d, 0 2px 6px #00000026;--shadow-md:0 4px 16px #0006, 0 2px 6px #0003;--shadow-lg:0 8px 32px #00000080, 0 4px 12px #00000040;--chord-sheet-bg:linear-gradient(160deg, #16162200 0%, #d9922a08 100%);--ghost-bg:#ffffff0a;--accent-bg:#d9922a1a;--focus-ring:0 0 0 2px #d9922a59;--glow-accent:0 0 20px #d9922a14}:root[data-theme=light]{--bg:#eae8e3;--surface:#faf9f7;--surface2:#f0eeea;--border:#ccc8be;--text:#1a1a2e;--muted:#6b6b80;--accent:#b86a08;--accent2:#a05e06;--accent-alt:#5a7f96;--danger:#dc2626;--success:#16a34a;--chord:#b86a08;--nav-bg:#eae8e3eb;--overlay:#00000059;--card-title:#0e0e18;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 16px #00000014, 0 2px 4px #0000000d;--shadow-lg:0 8px 28px #0000001a, 0 4px 8px #0000000f;--chord-sheet-bg:linear-gradient(160deg, #fffef9 0%, #f8f5ee 100%);--ghost-bg:#00000008;--accent-bg:#b86a0814;--focus-ring:0 0 0 2px #b86a0840;--glow-accent:0 0 20px #b86a080d}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);background-image:radial-gradient(80% 60% at 50% 0,#d9922a0d 0%,#0000 60%);min-height:100vh;font-family:Outfit,sans-serif;font-size:18px;line-height:1.6}:root[data-theme=light] body{background-image:radial-gradient(80% 60% at 50% 0,#b86a0808 0%,#0000 60%)}#app{max-width:860px;margin:0 auto;padding:32px 24px}.view-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.view-title{font-family:Crimson Pro,serif;font-size:28px;font-weight:600}.divider{border:none;border-top:1px solid var(--border);margin:24px 0}.empty{text-align:center;color:var(--muted);grid-column:1/-1;padding:80px 20px}.empty-icon{opacity:.3;margin-bottom:16px;font-size:56px}.empty-text{margin-bottom:20px;font-size:17px;font-weight:400}@keyframes viewFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}#app.view-enter{animation:.22s cubic-bezier(.25,.46,.45,.94) both viewFadeIn}.demo-banner{background:var(--accent);color:#fff;text-align:center;padding:6px 16px;font-size:13px;line-height:1.4}#nav{z-index:100;background:var(--nav-bg);-webkit-backdrop-filter:blur(16px)saturate(1.2);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;height:54px;padding:0 28px;display:flex;position:sticky;top:0}.nav-brand{color:var(--accent);letter-spacing:.02em;cursor:pointer;white-space:nowrap;flex-shrink:0;align-items:center;gap:6px;font-family:Crimson Pro,serif;font-size:22px;font-weight:600;display:flex}.nav-logo{color:var(--accent);display:inline-flex}.nav-logo svg{width:24px;height:24px}.nav-links{flex-shrink:1;align-items:center;gap:4px;min-width:0;display:flex}.nav-btn{color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:6px 14px;font-family:Outfit,sans-serif;font-size:14px;font-weight:400;transition:all .15s}.nav-btn:hover{color:var(--text);background:var(--surface2)}.nav-btn.active{color:var(--accent);background:var(--accent-bg);font-weight:500}.nav-icon{padding:6px 10px;font-size:16px}.nav-username{color:var(--muted);border-right:1px solid var(--border);margin-right:4px;padding:0 8px;font-size:13px}.nav-menu-wrap{margin-left:4px;position:relative}.nav-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:200;min-width:160px;padding:6px 0;display:none;position:absolute;top:calc(100% + 8px);right:0}.nav-dropdown.open{display:block}.nav-dropdown-item{width:100%;color:var(--text);text-align:left;cursor:pointer;background:0 0;border:none;padding:10px 18px;font-family:Outfit,sans-serif;font-size:14px;transition:background .12s;display:block}.nav-dropdown-item:hover{background:var(--surface2);color:var(--accent)}.nav-dropdown-divider{border:none;border-top:1px solid var(--border);margin:4px 0}.nav-signin{color:var(--accent)!important;font-weight:500!important}.nav-dropdown-primary{color:var(--accent);font-weight:600}.field{margin-bottom:14px}.field label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;font-size:12px;font-weight:500;display:block}input[type=text],input[type=password],input[type=search],input[type=number],input[type=url],input[type=date],textarea,select{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;outline:none;padding:10px 12px;font-family:Outfit,sans-serif;font-size:14px;transition:border-color .15s}@media (prefers-color-scheme:dark){input[type=text],input[type=password],input[type=search],input[type=number],input[type=url],input[type=date],textarea,select{--lightningcss-light: ;--lightningcss-dark:initial}}input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:var(--focus-ring);outline:none}input::placeholder,textarea::placeholder{color:var(--muted)}textarea{resize:vertical;min-height:300px;font-family:JetBrains Mono,monospace;font-size:13px;line-height:1.7}.btn{background:var(--accent);color:#000;border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow-sm);border:none;align-items:center;gap:6px;padding:10px 22px;font-family:Outfit,sans-serif;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s cubic-bezier(.25,.46,.45,.94);display:inline-flex}.btn:hover{background:var(--accent2);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn:active{box-shadow:none;transition-duration:60ms;transform:translateY(0)}.btn-ghost{background:var(--ghost-bg);border:1px solid var(--border);color:var(--text);box-shadow:none}.btn-ghost:hover{background:var(--surface2);border-color:var(--muted);color:var(--text);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-danger{border:1px solid var(--danger);color:var(--danger);background:0 0}.btn-danger:hover{background:var(--danger);color:#fff}.btn-sm{padding:6px 14px;font-size:13px}.btn-full{justify-content:center;width:100%}.song-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.song-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;min-height:72px;padding:18px 22px;transition:all .22s cubic-bezier(.25,.46,.45,.94);display:flex}.song-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md), var(--glow-accent);transform:translateY(-3px)}.song-card:active{box-shadow:var(--shadow-sm);transition-duration:80ms;transform:translateY(0)}.song-card-info{flex:1;min-width:0}.song-card-title{color:var(--card-title);white-space:nowrap;text-overflow:ellipsis;letter-spacing:.01em;font-family:Crimson Pro,serif;font-size:19px;font-weight:600;overflow:hidden}.song-card-meta{color:var(--muted);letter-spacing:.02em;opacity:.8;margin-top:5px;font-size:12.5px}.song-card-actions{flex-shrink:0;align-items:center;gap:8px;margin-left:16px;display:flex}.badge{text-transform:uppercase;letter-spacing:.05em;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:500}.badge-admin{color:var(--accent);background:#f0a03026}.badge-owner{color:var(--accent2);background:#f0a03040}.badge-disabled{color:var(--danger);background:#ef444426}.badge-bpm{color:var(--accent-alt);background:#7a9bb51f}.badge-tag{color:var(--accent-alt);text-transform:lowercase;background:#7a9bb51f;font-size:10px}.badge-private{background:var(--surface-alt,#2a2a35);color:var(--muted);font-size:11px}.tag-picker{flex-wrap:wrap;gap:6px;display:flex}.tag-pill{border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;border-radius:20px;padding:4px 12px;font-size:12px;transition:all .15s}.tag-pill:hover{border-color:var(--accent)}.tag-pill.active{color:var(--accent);border-color:var(--accent);background:#f0a03026}.song-card-tags{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.song-view-bpm{margin-top:6px}.song-view-tags{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.toggle{flex-shrink:0;width:36px;height:20px;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-slider{background:var(--border);cursor:pointer;border-radius:10px;transition:all .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:var(--muted);border-radius:50%;width:14px;height:14px;transition:all .2s;position:absolute;bottom:3px;left:3px}.toggle input:checked+.toggle-slider{background:var(--accent)}.toggle input:checked+.toggle-slider:before{background:#000;transform:translate(16px)}.search-row{align-items:center;gap:10px;margin-bottom:20px;display:flex}.search-row input{flex:3;min-width:0}.search-filters{gap:10px;margin-top:-12px;margin-bottom:16px;display:flex}.search-filters .language-filter{max-width:220px}#toast{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:var(--radius);z-index:9999;pointer-events:none;visibility:hidden;opacity:0;box-shadow:var(--shadow-lg);max-width:90vw;padding:12px 24px;font-size:14px;font-weight:500;transition:transform .3s cubic-bezier(.34,1.56,.64,1),opacity .3s,visibility .3s;position:fixed;bottom:28px;left:50%;transform:translate(-50%)translateY(80px)}#toast.show{visibility:visible;opacity:1;transform:translate(-50%)translateY(0)}#toast.error{border-color:var(--danger);color:var(--danger)}#toast.success{border-color:var(--success);color:var(--success)}.badge-key{color:var(--accent);background:#d08a1826;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:600}.format-badge{border-radius:var(--radius);white-space:nowrap;flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:500}.format-badge.format-ok{color:#4caf50;background:#4caf5026;border:1px solid #4caf504d}.format-badge.format-warn{color:#ff9800;background:#ff980026;border:1px solid #ff98004d}.setlist-add-overlay{background:var(--overlay);z-index:500;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.setlist-add-content{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:90%;max-width:500px;max-height:80vh;padding:24px;overflow-y:auto}.setlist-add-content .song-grid{grid-template-columns:1fr}.ocr-row{margin-bottom:8px}.ocr-modal{background:var(--overlay);z-index:600;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.ocr-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:90%;max-width:500px;max-height:90vh;padding:24px;overflow-y:auto}.ocr-preview{border-radius:var(--radius);border:1px solid var(--border);object-fit:contain;max-width:100%;max-height:200px}.ocr-progress-bar{background:var(--surface2);border-radius:3px;height:6px;overflow:hidden}.ocr-progress-fill{background:var(--accent);border-radius:3px;width:0%;height:100%;transition:width .3s}.ocr-result{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;min-height:200px;max-height:300px;color:var(--text);resize:vertical;padding:12px;font-family:JetBrains Mono,monospace;font-size:12px;line-height:1.6}.ocr-chat-history{flex-direction:column;gap:4px;max-height:120px;margin-bottom:10px;display:flex;overflow-y:auto}.ocr-chat-bubble{border-radius:8px;max-width:85%;padding:6px 10px;font-size:12px}.ocr-chat-user{background:var(--accent-bg);color:var(--accent);align-self:flex-end}.ocr-chat-ai{background:var(--surface2);color:var(--muted);align-self:flex-start}.ocr-fix-row{gap:6px;margin-top:10px;display:flex}.ocr-fix-input{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:8px;flex:1;padding:7px 10px;font-size:13px}.ocr-fix-input:focus{border-color:var(--accent);outline:none}.language-picker{position:relative}.language-picker-trigger{background:var(--surface);border:1px solid var(--border);text-align:left;cursor:pointer;width:100%;color:var(--text);border-radius:8px;padding:8px 12px;font-size:14px}.language-picker-trigger.placeholder{color:var(--muted)}.language-picker-dropdown{z-index:50;background:var(--surface);border:1px solid var(--border);border-radius:8px;max-height:280px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #00000026}.language-picker-search{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text);background:0 0;outline:none;padding:8px 12px;font-size:14px}.language-picker-section{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:6px 12px;font-size:11px;font-weight:600}.language-picker-option{cursor:pointer;width:100%;color:var(--text);text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;padding:8px 12px;font-size:14px;display:flex}.language-picker-option:hover{background:var(--hover)}.language-picker-option.selected{color:var(--accent);font-weight:500}.language-picker-code{color:var(--muted);font-size:12px}.language-picker-divider{background:var(--border);height:1px;margin:4px 0}.badge-lang{background:var(--surface);color:var(--muted);letter-spacing:.05em;border-radius:4px;padding:2px 6px;font-size:11px;font-weight:600}.language-filter{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:8px;padding:6px 10px;font-size:14px}.hero{text-align:center;margin-bottom:8px;padding:48px 20px 36px}.hero-title{color:var(--accent);letter-spacing:.01em;margin-bottom:8px;font-family:Crimson Pro,serif;font-size:42px;font-weight:600}.hero-tagline{color:var(--text);margin-bottom:6px;font-size:18px;font-weight:400}.hero-cta{color:var(--muted);max-width:360px;margin:0 auto;font-size:14px;line-height:1.5}.about-page{max-width:600px;margin:0 auto}.about-title{color:var(--accent);text-align:center;font-family:Crimson Pro,serif;font-size:36px;font-weight:600}.about-subtitle{text-align:center;color:var(--muted);margin-bottom:32px;font-size:16px}.about-section{margin-bottom:24px}.about-section h3{color:var(--accent-alt);margin-bottom:6px;font-family:Crimson Pro,serif;font-size:20px;font-weight:600}.about-section p{color:var(--muted);font-size:14px;line-height:1.6}.auth-wrap{justify-content:center;align-items:center;min-height:calc(100vh - 56px);display:flex}.auth-card{background:var(--surface);border:1px solid var(--border);width:100%;max-width:400px;box-shadow:var(--shadow-lg), var(--glow-accent);border-radius:14px;padding:44px 40px}.auth-logo{color:var(--accent);text-align:center;margin-bottom:6px;font-family:Crimson Pro,serif;font-size:36px;font-weight:600}.auth-tagline{text-align:center;color:var(--muted);margin-bottom:28px;font-size:13px}.auth-tabs{background:var(--surface2);border-radius:8px;margin-bottom:24px;padding:3px;display:flex}.auth-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:8px;font-family:Outfit,sans-serif;font-size:14px;font-weight:500;transition:all .15s}.auth-tab.active{background:var(--surface);color:var(--text)}.setlist-tabs{background:var(--surface2);border-radius:8px;gap:2px;margin-bottom:16px;padding:3px;display:flex}.setlist-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:8px;font-family:Outfit,sans-serif;font-size:14px;font-weight:500;transition:all .15s}.setlist-tab.active{background:var(--surface);color:var(--text)}.settings-section{margin-bottom:32px}.corrections-section{border-top:1px solid var(--border);margin-top:32px;padding-top:16px}.correction-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:12px;margin-bottom:12px;padding:16px}.correction-card-header{color:var(--muted);justify-content:space-between;align-items:center;margin-bottom:12px;font-size:13px;display:flex}.correction-actions{gap:8px;display:flex}.correction-preview{border:1px solid var(--border);background:var(--bg);border-radius:8px;max-height:300px;padding:12px;overflow-y:auto}.badge-pending{color:#f0a030;background:#f0a03026}.song-view-header{border-bottom:1px solid var(--border);margin-bottom:28px;padding-bottom:20px}.song-view-nav{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.song-view-title{letter-spacing:-.01em;font-family:Crimson Pro,serif;font-size:38px;font-weight:600;line-height:1.15}.song-view-artist{color:var(--muted);margin-top:6px;font-family:Crimson Pro,serif;font-size:17px;font-style:italic}.song-view-by{color:var(--muted);font-size:12px}.song-view-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-top:8px;display:flex}.song-view-meta-bottom{border-top:1px solid var(--border);margin-top:24px;padding-top:16px}.yt-link{color:#f44;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);vertical-align:middle;margin-left:6px;padding:2px 8px;font-size:12px;font-weight:500;text-decoration:none;display:inline-block}.yt-link:hover{background:var(--border)}.edit-header{align-items:center;gap:16px;margin-bottom:28px;display:flex}.edit-header h2{flex:1;font-family:Crimson Pro,serif;font-size:24px}.edit-cols{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;display:grid}.chordpro-hint-row{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.chordpro-hint{color:var(--muted);margin-bottom:6px;font-family:Outfit,sans-serif;font-size:12px}.chordpro-hint code{background:var(--surface2);color:var(--accent);border-radius:3px;padding:1px 5px;font-family:JetBrains Mono,monospace}.admin-stats{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:28px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-top:2px solid var(--accent);border-radius:var(--radius);text-align:center;box-shadow:var(--shadow-sm);padding:22px 20px}.stat-card.stat-warn{background:#ff980014;border-color:#ff980066}.stat-card.stat-warn .stat-value{color:#ff9800}.stat-value{color:var(--accent);font-family:Crimson Pro,serif;font-size:36px;font-weight:600;line-height:1.2}.stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:4px;font-size:12px}.admin-section-title{margin-bottom:12px;font-family:Crimson Pro,serif;font-size:20px;font-weight:600}.user-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px 20px}.user-card-top{justify-content:space-between;align-items:center;gap:12px;display:flex}.user-card-info{min-width:0}.user-card-badges{flex-shrink:0;gap:6px;display:flex}.user-card-actions{border-top:1px solid var(--border);flex-wrap:wrap;gap:6px;margin-top:10px;padding-top:10px;display:flex}.setlist-card .badge{color:var(--accent);background:#f0a03026}.setlist-entries{flex-direction:column;gap:10px;display:flex}.setlist-name-row{margin-top:8px}.setlist-name-input{border-radius:var(--radius);color:var(--text);background:0 0;border:1px solid #0000;outline:none;width:100%;padding:4px 8px;font-family:Crimson Pro,serif;font-size:28px;font-weight:600;transition:border-color .15s}.setlist-name-input:focus{border-color:var(--accent);background:var(--surface)}.setlist-song-item{align-items:center;gap:12px;display:flex}.setlist-song-pos{color:var(--muted);text-align:center;flex-shrink:0;min-width:28px;font-family:JetBrains Mono,monospace;font-size:14px}.setlist-entry-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.setlist-reorder{flex-direction:column;flex-shrink:0;gap:1px;display:flex}.setlist-arrow-btn{border:1px solid var(--border);width:28px;height:20px;color:var(--muted);cursor:pointer;background:0 0;border-radius:4px;justify-content:center;align-items:center;font-size:9px;transition:all .12s;display:flex}.setlist-arrow-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-bg)}.setlist-arrow-btn.disabled{visibility:hidden}.setlist-remove-btn{border:1px solid var(--border);width:30px;height:30px;color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:all .12s;display:flex}.setlist-remove-btn:hover{color:var(--danger);border-color:var(--danger);background:#ef444414}.setlist-entry-controls{align-items:center;gap:4px;display:flex}.badge-edited{color:var(--accent);background:#f0a03026;font-size:10px}.badge-nashville{color:var(--success);background:#22c55e26;font-size:10px}.setlist-play-header{z-index:50;background:var(--nav-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:8px 0;display:flex;position:sticky;top:56px}.setlist-play-indicator{color:var(--text);text-align:center;white-space:nowrap;text-overflow:ellipsis;flex:1;font-family:Crimson Pro,serif;font-size:18px;font-weight:600;overflow:hidden}.setlist-sheet-row{align-items:stretch;gap:0;display:flex}.setlist-sheet-row .chord-sheet-wrap{flex:1;min-width:0}.setlist-side-btn{background:var(--surface2);border:1px solid var(--border);width:48px;color:var(--muted);cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0;justify-content:center;align-items:center;font-size:30px;transition:all .2s;display:flex}.setlist-side-prev{border-radius:var(--radius) 0 0 var(--radius);border-right:none}.setlist-side-next{border-radius:0 var(--radius) var(--radius) 0;border-left:none}.setlist-side-btn:hover{background:var(--accent-bg);color:var(--accent)}.setlist-side-btn:active{background:var(--accent);color:#000}.setlist-side-spacer{width:0}.setlist-play-nav{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:24px;padding:16px 0;display:flex}.setlist-play-nav .btn{min-width:44px;min-height:44px}.setlist-play-pos{color:var(--muted);font-family:JetBrains Mono,monospace;font-size:14px}.setlist-save-btn{animation:1.5s ease-in-out infinite pulse-glow}@keyframes pulse-glow{0%,to{box-shadow:0 0 #f0a0304d}50%{box-shadow:0 0 8px 2px #f0a0304d}}.setlist-editor{margin:16px 0}.setlist-edit-textarea{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;min-height:400px;color:var(--text);resize:vertical;padding:16px;font-family:JetBrains Mono,monospace;font-size:13px;line-height:1.7}.setlist-edit-textarea:focus{border-color:var(--accent);outline:none}.setlist-editor-actions{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.song-versions{flex-wrap:wrap;align-items:center;gap:8px;margin-top:12px;display:flex}.song-versions .btn.active{background:var(--accent);color:#000;border-color:var(--accent)}.setlist-meta-row{flex-wrap:wrap;align-items:center;gap:16px;margin-top:8px;display:flex}.setlist-meta-row input[type=date]{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);width:auto;color:var(--text);padding:6px 10px;font-family:Outfit,sans-serif;font-size:13px}body.perf-mode #nav{display:none}body.perf-mode #app{max-width:100%;padding:40px 60px}body.perf-mode .song-view-header,body.perf-mode .transpose-bar{display:none}body.perf-mode .chord-sheet-wrap{box-shadow:none;background:0 0;border:none;padding:0}body.perf-mode .chord-sheet .chord{font-size:18px}body.perf-mode .chord-sheet .lyrics{font-size:22px}body.perf-mode .song-view-title{font-size:48px}.perf-controls{z-index:200;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.perf-btn{background:var(--surface);border:1px solid var(--border);width:44px;height:44px;color:var(--text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:18px;transition:all .15s;display:flex}.perf-btn:hover,.perf-btn.active{background:var(--accent);color:#000;border-color:var(--accent)}@media (width<=600px){#app{padding:20px 16px;overflow-x:hidden}#nav{height:48px;padding:0 12px}.nav-brand{font-size:18px}.nav-btn{padding:5px 10px;font-size:13px}.song-grid,.edit-cols{grid-template-columns:1fr}.song-view-title{font-size:28px}.chord-sheet-wrap,body.perf-mode #app{padding:24px 20px}.admin-stats{grid-template-columns:1fr}.setlist-entry-actions{flex-direction:column;align-items:flex-end;gap:4px}.setlist-play-header{top:0}.setlist-meta-row{flex-direction:column;align-items:flex-start}.transpose-bar{flex-wrap:wrap;width:100%}.setlist-side-btn{width:36px;font-size:22px}.setlist-play-header{flex-wrap:wrap;gap:4px 8px}.setlist-play-indicator{white-space:normal;min-width:0;font-size:15px}.song-card{flex-wrap:wrap;gap:8px;padding:14px 16px}.song-card-actions{flex-wrap:wrap;gap:6px;margin-left:0}.search-row{flex-wrap:wrap}.search-row input{flex:100%}}.sl-options-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:10px;margin-bottom:12px;padding:12px 16px;display:flex}.overridden{position:relative}.overridden:after{content:"";background:var(--accent);border-radius:50%;width:6px;height:6px;position:absolute;top:1px;right:1px}.sl-options-title{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:2px;font-size:11px;font-weight:600}.sl-option{color:var(--text);cursor:pointer;justify-content:space-between;align-items:center;font-size:14px;display:flex}.sl-font-btns{gap:4px;display:flex}.sl-font-btns .btn{min-width:36px}.transpose-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:20px;padding:8px 12px;display:inline-flex}.transpose-tools{align-items:center;gap:6px;display:flex}.transpose-label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:12px}.key-current{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:600;transition:all .15s}.key-current:hover{text-decoration:underline}.key-info{color:var(--accent);padding:2px 4px;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:600}.key-current.disabled{opacity:.4;cursor:not-allowed}.key-picker{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);gap:3px;margin-bottom:16px;padding:8px 12px;display:flex}.key-pill{color:var(--muted);cursor:pointer;text-align:center;background:0 0;border:none;border-radius:4px;flex:1;padding:4px 6px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:500;transition:all .1s}.key-pill:hover{color:var(--accent);background:var(--accent-bg)}.key-pill.active{background:var(--accent);color:#000;font-weight:600}.transpose-btn{background:var(--surface2);border:1px solid var(--border);width:30px;height:30px;color:var(--text);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;font-size:18px;line-height:1;transition:all .1s;display:flex}.transpose-btn:hover{background:var(--accent);color:#000;border-color:var(--accent)}.transpose-value{color:var(--accent);text-align:center;min-width:70px;font-family:JetBrains Mono,monospace;font-size:14px}.transpose-reset{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:2px 6px;font-size:12px}.transpose-reset:hover{color:var(--text)}.number-toggle{cursor:pointer;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);-webkit-user-select:none;user-select:none;align-items:center;gap:5px;font-size:11px;display:flex}.number-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;margin:0}.number-toggle input:checked+span{color:var(--accent);font-weight:500}.number-toggle input:disabled{opacity:.35;cursor:not-allowed}.number-toggle:has(input:disabled){opacity:.35;cursor:not-allowed}.transpose-btn:disabled{opacity:.3;cursor:not-allowed}.transpose-btn:disabled:hover{background:var(--surface2);color:var(--text);border-color:var(--border)}.col-toggle{white-space:nowrap;width:auto;padding:0 6px;font-family:Outfit,sans-serif;font-size:11px;font-weight:600}.autofit-btn{width:auto;padding:0 6px;font-family:Outfit,sans-serif;font-size:11px;font-weight:600}.toolbar-divider{background:var(--border);width:1px;height:20px;margin:0 4px}.font-btn{padding:0 8px;font-family:Outfit,sans-serif;font-size:12px;font-weight:600}.font-reset{font-size:14px}.font-reset.disabled,.font-reset:disabled{opacity:.25;cursor:default}.font-reset.disabled:hover,.font-reset:disabled:hover{background:var(--surface2);color:var(--text);border-color:var(--border)}.col-toggle.active{background:var(--accent);color:#000;border-color:var(--accent)}.chord-sheet-wrap{background:var(--surface);background-image:var(--chord-sheet-bg);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:36px 40px;overflow-x:auto}.chord-sheet-wrap.two-col>#chord-output{column-count:2;column-rule:1px solid var(--border);column-gap:32px}.chord-sheet-wrap.two-col .paragraph{break-inside:avoid}.chord-sheet .paragraph{margin-bottom:2.2em}.chord-sheet .row{flex-wrap:wrap;margin-bottom:.6em;line-height:1;display:flex}.chord-sheet .column{flex-direction:column;margin-right:1px;display:inline-flex}.chord-sheet-wrap{--font-scale:1}.chord-sheet .chord{font-family:JetBrains Mono,monospace;font-size:calc(15px * var(--font-scale));color:var(--chord);white-space:pre;letter-spacing:.02em;min-height:1.2em;padding-right:6px;font-weight:600}.chord-sheet .lyrics{font-family:Outfit,sans-serif;font-size:calc(18px * var(--font-scale));color:var(--text);white-space:pre;line-height:1.4}.chord-sheet .comment,.chord-sheet .tag{color:var(--muted);font-size:calc(13px * var(--font-scale));margin:8px 0 4px;font-style:italic}.chord-sheet .section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--muted);border-bottom:1px solid var(--border);margin:16px 0 8px;padding-bottom:4px;font-size:11px;font-weight:600}.chord-sheet h3.label{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);background:var(--accent-bg);border-radius:4px;margin:0 0 8px;padding:3px 10px;font-family:Outfit,sans-serif;font-size:11px;font-weight:600;display:inline-block}.chord-sheet .paragraph.chorus{border-left:2px solid var(--accent-alt);margin-left:-16px;padding-left:16px}.chord-sheet .paragraph.prechorus{border-left:2px dotted var(--accent-alt);margin-left:-16px;padding-left:16px}.chord-sheet .paragraph.bridge{border-left:2px dashed var(--muted);margin-left:-16px;padding-left:16px}.editor-split{border:1px solid var(--border);border-radius:var(--radius);gap:0;min-height:400px;display:flex;overflow:hidden}@media (width>=768px){.editor-split{width:calc(100vw - 48px);max-width:1200px;position:relative;left:50%;transform:translate(-50%)}}.editor-split>.cm-editor-wrap{border-right:1px solid var(--border);flex:0 0 55%;max-height:70vh;overflow:auto}.editor-split>.editor-preview-wrap{background:var(--bg);flex:0 0 45%;max-height:70vh;overflow:auto}.editor-preview-wrap .chord-sheet-wrap{box-shadow:none;border-left-width:2px;padding:20px 24px}.editor-preview-wrap .chord-sheet h1{margin-bottom:8px;font-size:20px}.editor-preview-wrap .chord-sheet h2{font-size:16px}.editor-tabs{display:none}@media (width<=767px){.editor-tabs{border-bottom:1px solid var(--border);display:flex}.editor-tab{text-align:center;color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px 0;font-size:14px;font-weight:500;transition:color .15s,border-color .15s}.editor-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.editor-split{flex-direction:column;min-height:350px}.editor-split>.cm-editor-wrap{border-right:none;flex:auto;max-height:none}.editor-split>.editor-preview-wrap{flex:auto;max-height:none}.editor-hidden{display:none}}.editor-preview{padding:12px}.editor-preview-toolbar{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;padding-bottom:8px;display:flex}.editor-preview-empty{min-height:200px;color:var(--muted);justify-content:center;align-items:center;font-size:14px;font-style:italic;display:flex}.cm-editor-container .cm-editor{height:100%}.cm-editor-container .cm-scroller{padding:8px 12px;font-family:JetBrains Mono,Fira Code,SF Mono,ui-monospace,monospace;font-size:15px;line-height:1.6}.cm-editor-container .cm-placeholder{color:var(--muted);font-style:italic}
