*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}:root{--gold: #F0C040;--gold-bright: #FFD966;--gold-dim: #9A8030;--gold-pale: rgba(240, 192, 64, .1);--bg: #0F0F0F;--surface: #161616;--surface2: #1E1E1E;--surface3: #272727;--surface4: #313131;--text: #FFFFFF;--text-muted: #AAAAAA;--text-dim: #777770;--border: rgba(240, 192, 64, .25);--border-bright: rgba(240, 192, 64, .55);--green: #4AE080;--red: #FF5555;--nav-h: 64px;--header-h: 60px;--lyric-font-size: 20px}[data-theme=light]{--bg: #FAFAF7;--surface: #F2EFE8;--surface2: #EAE6DA;--surface3: #DDD8C8;--surface4: #D0C9B5;--text: #1A1A1A;--text-muted: #6B6450;--text-dim: #9C9280;--border: rgba(160, 120, 10, .15);--border-bright: rgba(160, 120, 10, .4);--gold: #C8960A;--gold-bright: #E0A820;--gold-dim: #8A6E20;--gold-pale: rgba(200, 150, 10, .1);--green: #1A9040;--red: #CC2020}html,body,#root{height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:DM Sans,sans-serif}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.screen{position:fixed;top:0;right:0;bottom:0;left:0;bottom:var(--nav-h);overflow-y:auto;-webkit-overflow-scrolling:touch;display:none;animation:fadeIn .2s ease;background:var(--bg)}.screen.active{display:block}.screen-song-view{bottom:0!important;display:none;flex-direction:column;background:var(--bg)}.screen-song-view.active{display:flex!important}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-h);background:var(--surface);border-top:1px solid var(--border);display:flex;z-index:100}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;transition:all .15s;padding-bottom:env(safe-area-inset-bottom);background:none;border:none}.nav-icon{font-size:20px;color:var(--text-dim);transition:color .15s}.nav-label{font-size:9px;color:var(--text-dim);letter-spacing:.3px;transition:color .15s}.nav-item.active .nav-icon,.nav-item.active .nav-label{color:var(--gold)}.nav-item:active{background:#ffffff08}.app-header{position:sticky;top:0;z-index:50;background:var(--surface);border-bottom:1px solid var(--border);padding:0 20px;height:var(--header-h);display:flex;align-items:center;justify-content:space-between}.header-logo{font-family:Playfair Display,serif;font-size:22px;color:var(--gold)}.header-logo sup{font-size:10px;color:var(--text-muted);font-family:DM Sans,sans-serif;vertical-align:super}.header-title{font-family:Playfair Display,serif;font-size:20px;color:var(--text)}.header-btn{background:var(--gold);color:#000;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:700;font-family:DM Sans,sans-serif;cursor:pointer;white-space:nowrap}.header-btn-outline{background:transparent;color:var(--gold);border:1px solid var(--border-bright);border-radius:8px;padding:7px 14px;font-size:13px;font-weight:500;font-family:DM Sans,sans-serif;cursor:pointer}.back-btn{font-size:13px;color:var(--text-muted);cursor:pointer;padding:8px 0;display:flex;align-items:center;gap:6px;background:none;border:none;font-family:DM Sans,sans-serif}.back-btn:hover{color:var(--gold)}.home-hero{padding:28px 20px 20px}.home-greeting{font-size:12px;color:var(--gold);text-transform:uppercase;letter-spacing:2.5px;margin-bottom:6px}.home-title{font-family:Playfair Display,serif;font-size:32px;font-weight:700;margin-bottom:4px;line-height:1.1}.home-sub{font-size:14px;color:var(--text-muted)}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:0 20px;margin-bottom:28px}.stat-card{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:16px 12px;text-align:center}.stat-num{font-family:Playfair Display,serif;font-size:32px;color:var(--gold);line-height:1}.stat-label{font-size:11px;color:var(--text-muted);margin-top:4px;text-transform:uppercase;letter-spacing:1px}.section-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;margin-bottom:12px}.section-title{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--gold-dim);font-weight:500}.section-action{font-size:13px;color:var(--gold);cursor:pointer;background:none;border:none;font-family:DM Sans,sans-serif}.home-section{margin-bottom:28px}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 20px;margin-bottom:28px}.quick-btn{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;flex-direction:column;align-items:flex-start;gap:8px;cursor:pointer;transition:all .15s;text-align:left;font-family:DM Sans,sans-serif}.quick-btn:active,.quick-btn:hover{border-color:var(--border-bright);background:var(--surface3)}.quick-btn-icon{font-size:24px}.quick-btn-label{font-size:13px;font-weight:500;color:var(--text)}.quick-btn-sub{font-size:11px;color:var(--text-muted)}.setlist-card{background:var(--surface2);border:1px solid var(--border);border-left:3px solid var(--gold);border-radius:14px;padding:16px 18px;margin:0 20px 10px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .15s;position:relative;overflow:hidden;text-align:left;width:calc(100% - 40px);font-family:DM Sans,sans-serif}.setlist-card:active,.setlist-card:hover{border-color:var(--border-bright);background:var(--surface3)}.setlist-info{flex:1}.setlist-name{font-size:18px;font-weight:600;color:var(--text);margin-bottom:4px}.setlist-meta{font-size:13px;color:var(--text-muted)}.setlist-arrow{font-size:18px;color:var(--text-dim);margin-left:12px}.setlist-badge{font-size:11px;padding:4px 10px;border-radius:20px;border:1px solid var(--border-bright);color:var(--gold);background:var(--gold-pale);margin-left:10px;white-space:nowrap}.empty-state{text-align:center;padding:40px 20px}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.4}.empty-title{font-size:18px;font-weight:500;margin-bottom:8px;color:var(--text-muted)}.empty-sub{font-size:14px;color:var(--text-dim);margin-bottom:24px}.gig-tonight{background:#4ae0801a;border:1px solid rgba(74,224,128,.3);border-radius:10px;padding:14px 16px;margin:0 20px 20px;display:flex;align-items:center;gap:12px}.gig-dot{width:10px;height:10px;border-radius:50%;background:var(--green);animation:pulse 1.5s infinite;flex-shrink:0}.gig-text{font-size:13px;color:var(--green)}.gig-name{font-size:15px;font-weight:600;color:var(--text)}.search-wrap{padding:12px 20px}.search-bar{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:10px 16px;width:100%;font-size:15px;color:var(--text);font-family:DM Sans,sans-serif;outline:none}.search-bar:focus{border-color:var(--border-bright)}.search-bar::placeholder{color:var(--text-dim)}.song-item{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin:0 20px 8px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .15s;font-family:DM Sans,sans-serif;text-align:left;width:calc(100% - 40px)}.song-item:active,.song-item:hover{border-color:var(--border-bright);background:var(--surface3)}.song-num{font-size:13px;color:var(--text-dim);min-width:24px;text-align:center}.song-info{flex:1}.song-title{font-size:15px;font-weight:500;margin-bottom:2px}.song-artist{font-size:12px;color:var(--text-muted)}.song-item.dragging{border-color:var(--gold)!important;background:#2e2a14!important;box-shadow:0 6px 24px #f0c04040;z-index:10;position:relative;cursor:grabbing}.song-item.drag-over{border-color:#f0c04066;background:#272520}.drag-handle{color:var(--text-dim);font-size:18px;padding:4px 2px 4px 6px;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;line-height:1;flex-shrink:0}.drag-handle:active{cursor:grabbing;color:var(--gold)}.song-key{background:var(--gold-pale);border:1px solid var(--border-bright);border-radius:6px;padding:3px 8px;font-size:12px;color:var(--gold);font-weight:600}.setlist-detail-header{padding:20px 20px 16px}.setlist-detail-name{font-family:Playfair Display,serif;font-size:28px;margin-bottom:4px}.setlist-detail-meta{font-size:13px;color:var(--text-muted)}.setlist-actions{display:flex;gap:8px;padding:0 20px;margin-bottom:16px;flex-wrap:wrap}.action-btn{background:var(--surface3);border:1px solid var(--border);border-radius:8px;padding:8px 14px;font-size:13px;color:var(--text-muted);cursor:pointer;font-family:DM Sans,sans-serif;display:flex;align-items:center;gap:6px;transition:all .15s}.action-btn:hover{border-color:var(--border-bright);color:var(--text)}.action-btn.gold{color:var(--gold);border-color:var(--border-bright)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;z-index:200;display:none;align-items:flex-end;animation:fadeIn .15s ease}.modal-overlay.open{display:flex}.modal{background:var(--surface2);border-radius:20px 20px 0 0;border-top:1px solid var(--border);padding:24px 20px;padding-bottom:calc(var(--nav-h) + 48px + env(safe-area-inset-bottom));width:100%;max-height:85vh;overflow-y:auto}.modal-compact{padding-bottom:calc(24px + env(safe-area-inset-bottom))}.modal-title{font-family:Playfair Display,serif;font-size:22px;margin-bottom:20px}.modal-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.modal-input{background:var(--surface3);border:1px solid var(--border);border-radius:10px;padding:12px 16px;width:100%;font-size:16px;color:var(--text);font-family:DM Sans,sans-serif;outline:none;margin-bottom:16px}.modal-input:focus{border-color:var(--border-bright)}.modal-input::placeholder{color:var(--text-dim)}.modal-textarea{background:var(--surface3);border:1px solid var(--border);border-radius:10px;padding:12px 16px;width:100%;font-size:14px;color:var(--text);font-family:DM Sans,sans-serif;outline:none;margin-bottom:16px;min-height:80px;resize:none}.modal-textarea:focus{border-color:var(--border-bright)}.modal-btn-row{display:flex;gap:10px;margin-top:8px}.btn-primary{background:var(--gold);color:#000;border:none;border-radius:10px;padding:14px;font-size:15px;font-weight:700;font-family:DM Sans,sans-serif;cursor:pointer;flex:1}.btn-secondary{background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:10px;padding:14px;font-size:15px;font-family:DM Sans,sans-serif;cursor:pointer;flex:1}.btn-danger{background:transparent;color:var(--red);border:1px solid rgba(255,85,85,.3);border-radius:10px;padding:14px;font-size:15px;font-family:DM Sans,sans-serif;cursor:pointer;width:100%;margin-top:10px}.color-picker{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.color-swatch{width:32px;height:32px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all .15s}.color-swatch.selected{border-color:var(--text);transform:scale(1.15)}.toast{position:fixed;bottom:calc(var(--nav-h) + 16px);left:50%;transform:translate(-50%);background:#4ae08026;border:1px solid rgba(74,224,128,.4);color:var(--green);font-size:13px;padding:10px 20px;border-radius:20px;opacity:0;transition:opacity .3s;pointer-events:none;white-space:nowrap;z-index:300}.toast.error{background:#ff555526;border-color:#f556;color:var(--red)}.toast.show{opacity:1}.req-qr-card{background:var(--surface2);border:1px solid var(--border-bright);border-radius:16px;padding:20px;margin:16px 20px;text-align:center}.req-qr-title{font-family:Playfair Display,serif;font-size:18px;margin-bottom:6px}.req-qr-sub{font-size:12px;color:var(--text-muted);margin-bottom:16px}.req-qr-box{background:#fff;border-radius:12px;padding:12px;display:inline-block;margin-bottom:14px}.req-qr-url{font-size:11px;color:var(--gold);word-break:break-all;background:#f0c04014;border:1px solid var(--border-bright);border-radius:8px;padding:8px 12px;margin-bottom:14px}.req-status-row{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:4px}.req-live-dot{width:8px;height:8px;border-radius:50%;background:var(--green);animation:blink 1.2s infinite}.req-live-text{font-size:13px;color:var(--green);font-weight:600}.req-count{font-size:12px;color:var(--text-muted)}.req-card{background:var(--surface2);border:1px solid var(--border);border-radius:14px;padding:14px 16px;margin:0 20px 10px;display:flex;align-items:flex-start;gap:12px;transition:all .15s}.req-card.new{border-color:var(--gold);background:#f0c0400f}.req-card.played{opacity:.4}.req-vote-block{background:#f0c0401a;border:1px solid var(--border-bright);border-radius:10px;padding:6px 10px;text-align:center;flex-shrink:0;min-width:44px}.req-vote-num{font-family:Playfair Display,serif;font-size:20px;color:var(--gold);line-height:1}.req-vote-label{font-size:10px;color:var(--gold-dim)}.req-info{flex:1}.req-song-title{font-size:15px;font-weight:600;margin-bottom:2px}.req-artist{font-size:12px;color:var(--text-muted);margin-bottom:4px}.req-from{font-size:12px;color:var(--text-dim)}.req-btns{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.req-play-btn{background:var(--gold);color:#000;border:none;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:700;cursor:pointer;font-family:DM Sans,sans-serif;white-space:nowrap}.req-dismiss-btn{background:transparent;color:var(--text-dim);border:1px solid var(--border);border-radius:8px;padding:5px 12px;font-size:12px;cursor:pointer;font-family:DM Sans,sans-serif}.req-section-title{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--gold-dim);padding:12px 20px 6px;font-weight:500}.req-empty{text-align:center;padding:32px 20px;color:var(--text-muted);font-size:14px}.req-share-btn{background:var(--surface3);border:1px solid var(--border-bright);color:var(--gold);border-radius:8px;padding:8px 16px;font-size:13px;font-weight:500;cursor:pointer;font-family:DM Sans,sans-serif;display:flex;align-items:center;gap:6px}.cal-month-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.cal-month-title{font-family:Playfair Display,serif;font-size:22px}.cal-nav-btn{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:6px 14px;font-size:16px;color:var(--text-muted);cursor:pointer;font-family:DM Sans,sans-serif;transition:all .15s}.cal-nav-btn:hover{border-color:var(--border-bright);color:var(--gold)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:20px}.cal-day-label{font-size:11px;color:var(--text-dim);text-align:center;padding:4px 0;text-transform:uppercase;letter-spacing:1px}.cal-day{min-height:42px;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:6px 2px 4px;cursor:default;position:relative}.cal-day.has-gig{background:#f0c0401a;border:1px solid var(--border-bright);cursor:pointer}.cal-day.has-gig:hover{background:#f0c0402e}.cal-day.today .cal-day-num{background:var(--gold);color:#000;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-weight:700}.cal-day.other-month .cal-day-num{color:var(--text-dim)}.cal-day-num{font-size:14px;color:var(--text)}.cal-gig-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);margin-top:3px}.gig-card{background:var(--surface2);border:1px solid var(--border);border-radius:14px;padding:16px 18px;margin:8px 20px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:14px;font-family:DM Sans,sans-serif;width:calc(100% - 40px);text-align:left}.gig-card:hover{border-color:var(--border-bright);background:var(--surface3)}.gig-date-block{background:#f0c0401a;border:1px solid var(--border-bright);border-radius:10px;padding:8px 12px;text-align:center;flex-shrink:0;min-width:52px}.gig-date-day{font-family:Playfair Display,serif;font-size:22px;color:var(--gold);line-height:1}.gig-date-month{font-size:11px;color:var(--gold-dim);text-transform:uppercase;letter-spacing:1px}.gig-info{flex:1}.gig-card .gig-name{font-size:15px;font-weight:500;margin-bottom:3px}.gig-venue{font-size:12px;color:var(--text-muted)}.gig-setlist-badge{font-size:11px;color:var(--gold);background:var(--gold-pale);border:1px solid var(--border-bright);border-radius:20px;padding:3px 10px;margin-top:5px;display:inline-block}.gig-past{opacity:.5}.gigs-section-title{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--gold-dim);padding:16px 20px 8px;font-weight:500}.sv-header{position:sticky;top:0;z-index:50;background:var(--surface);border-bottom:1px solid var(--border);padding:10px 16px 8px;flex-shrink:0}.sv-top-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.sv-song-tabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none;margin-bottom:10px}.sv-song-tabs::-webkit-scrollbar{display:none}.sv-tab{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:5px 14px;font-size:12px;color:var(--text-muted);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .15s;font-family:DM Sans,sans-serif}.sv-tab.active{border-color:var(--gold);color:var(--gold);background:#f0c04014}.sv-controls{display:flex;align-items:center;justify-content:space-between;gap:6px}.sv-ctrl-left{display:flex;align-items:center;gap:6px}.sv-ctrl-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.sv-key-badge{background:#f0c0401f;border:1px solid var(--border-bright);border-radius:7px;padding:5px 11px;font-size:13px;color:var(--gold);font-weight:600;flex-shrink:0}.sv-mode-btn{background:transparent;border:1px solid var(--border-bright);border-radius:7px;padding:5px 11px;font-size:12px;color:var(--text-muted);cursor:pointer;font-family:DM Sans,sans-serif;white-space:nowrap;transition:all .15s;flex-shrink:0}.sv-mode-btn.active{border-color:var(--gold);color:var(--gold)}.sv-lw-ind{font-size:11px;color:var(--text-muted);background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:4px 7px;white-space:nowrap;flex-shrink:0}.sv-lw-ind span{color:var(--gold);font-weight:600}.sv-edit-toolbar{display:none;align-items:center;gap:8px;margin-top:8px;background:#1c1800;border:1px solid var(--gold-dim);border-radius:10px;padding:7px 12px;flex-wrap:wrap}.sv-edit-toolbar.visible{display:flex}.sv-et-label{font-size:12px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.sv-et-val{font-size:13px;font-weight:700;color:#000;background:var(--gold);border-radius:6px;padding:4px 10px;min-width:52px;text-align:center;flex-shrink:0}.sv-key-dd-wrap{position:relative;flex-shrink:0}.sv-key-dd-btn{background:#f0c04014;border:1px solid var(--border-bright);border-radius:7px;padding:5px 9px;font-size:12px;font-weight:600;color:var(--gold);cursor:pointer;display:flex;align-items:center;gap:4px;font-family:DM Sans,sans-serif;white-space:nowrap}.sv-key-dd-menu{position:absolute;top:calc(100% + 6px);right:0;background:#252525;border:1px solid var(--gold);border-radius:10px;padding:8px;z-index:300;display:none;width:210px}.sv-key-dd-menu.open{display:block}.sv-kdm-title{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--gold-dim);margin-bottom:8px;padding:0 4px}.sv-kdm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:5px}.sv-kdm-key{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:6px 4px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;text-align:center;transition:all .12s;font-family:DM Sans,sans-serif}.sv-kdm-key:hover{border-color:var(--gold);color:var(--gold)}.sv-kdm-key.cur{border-color:var(--gold);color:#000;background:var(--gold)}.sv-sheet{padding:16px 18px;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--bg);flex:1}.sv-sheet-inner{min-width:100%;position:relative}.sv-section{font-size:11px;text-transform:uppercase;letter-spacing:2.5px;color:var(--gold-dim);margin:18px 0 8px;font-weight:500}.sv-section:first-child{margin-top:0}.sv-pair{margin-bottom:20px}.sv-chord-row{position:relative;height:34px;margin-bottom:2px}body.sv-edit .sv-chord-row{min-height:28px}.sv-lyric-pause-ind{font-size:12px;color:var(--gold);font-weight:700;opacity:.75;margin-right:2px}.sv-lyric{font-size:var(--lyric-font-size, 20px);color:var(--text);line-height:1.4}.sv-chord{position:absolute;font-size:22px;font-weight:600;color:var(--gold-bright);font-family:DM Sans,sans-serif;padding:0 3px;border-radius:4px;white-space:nowrap;line-height:32px;transition:background .1s;-webkit-user-select:none;user-select:none}body.sv-edit .sv-chord{cursor:grab;border:1px dashed rgba(240,192,64,.4);touch-action:none}body.sv-edit .sv-chord:hover{border-color:var(--gold);background:#f0c0401f}body.sv-edit .sv-chord.dragging{cursor:grabbing;background:#f0c04038;border:1px solid var(--gold);z-index:100}.sv-edit-hint{font-size:12px;color:var(--text-muted);text-align:center;padding:7px 16px;background:#f0c0400a;border-top:1px solid var(--border);display:none;flex-shrink:0}.sv-edit-hint.visible{display:block}.sv-popover{position:absolute;background:var(--surface2);border:1px solid var(--gold);border-radius:10px;padding:10px;z-index:400;display:none;min-width:210px}.sv-popover.open{display:block}.sv-pop-title{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--gold-dim);margin-bottom:8px}.sv-pop-input{background:var(--surface3);border:1px solid var(--border-bright);border-radius:7px;padding:8px 12px;font-size:18px;font-weight:600;color:var(--gold-bright);font-family:DM Sans,sans-serif;width:100%;outline:none;margin-bottom:10px}.sv-pop-input:focus{border-color:var(--gold)}.sv-qc-grid{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}.sv-qc{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-size:13px;color:var(--text-muted);cursor:pointer;transition:all .12s;font-family:DM Sans,sans-serif}.sv-qc:hover{border-color:var(--gold);color:var(--gold)}.sv-pop-btns{display:flex;gap:6px}.sv-pop-save{background:var(--gold);color:#000;border:none;border-radius:7px;padding:7px 14px;font-size:13px;font-weight:600;font-family:DM Sans,sans-serif;cursor:pointer;flex:1}.sv-pop-del{background:transparent;color:#ff6b6b;border:1px solid rgba(255,107,107,.3);border-radius:7px;padding:7px 10px;font-size:13px;font-family:DM Sans,sans-serif;cursor:pointer}.sv-pop-cancel{background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:7px;padding:7px 10px;font-size:13px;font-family:DM Sans,sans-serif;cursor:pointer}.sv-lyric-editable{cursor:text;border-radius:4px;transition:background .15s}.sv-lyric-editable:hover{background:#f0c04014;outline:1px dashed var(--gold-dim)}.sv-lyric-edit-row{display:flex;align-items:center;gap:6px;padding:2px 0 4px}.sv-lyric-input{flex:1;background:var(--surface3);border:1px solid var(--gold-dim);border-radius:7px;color:var(--text);font-size:15px;font-family:DM Sans,sans-serif;padding:5px 10px;outline:none}.sv-lyric-input:focus{border-color:var(--gold)}.sv-add-chord-btn{display:inline-block;margin-left:10px;padding:2px 8px;border-radius:10px;background:transparent;border:1px dashed var(--gold-dim);color:var(--gold-dim);font-size:11px;font-family:DM Sans,sans-serif;cursor:pointer;vertical-align:middle;white-space:nowrap}.sv-add-chord-btn:hover{border-color:var(--gold);color:var(--gold)}.sv-add-chord-btn.active{border-style:solid;border-color:var(--gold-dim);color:var(--gold);background:var(--gold-pale)}.sv-add-chord-btn.active:hover{border-color:var(--gold)}.sv-progress-track{position:fixed;right:0;top:0;bottom:0;width:4px;background:#f0c04014;z-index:45;pointer-events:none}.sv-progress-fill{width:100%;background:linear-gradient(to bottom,var(--gold),rgba(240,192,64,.6));min-height:4px;border-radius:0 0 2px 2px}.sv-countdown-badge{position:fixed;bottom:90px;right:18px;z-index:60;width:38px;height:38px;border-radius:50%;background:#f0c0401f;border:2px solid var(--gold);color:var(--gold);font-family:Playfair Display,serif;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;pointer-events:none;animation:sv-cd-pop .25s ease}@keyframes sv-cd-pop{0%{transform:scale(1.4);opacity:.4}to{transform:scale(1);opacity:1}}.sv-autoscroll-bar{display:flex;align-items:center;gap:8px;padding:6px 16px 8px;border-top:1px solid var(--border);background:var(--surface)}.sv-as-btn{flex:1;background:transparent;border:1px solid var(--border-bright);color:var(--gold);border-radius:8px;padding:7px 12px;font-size:12px;font-weight:600;font-family:DM Sans,sans-serif;cursor:pointer;text-align:left;transition:background .15s,border-color .15s}.sv-as-btn.active{background:var(--gold-pale);border-color:var(--gold);animation:sv-as-pulse 1.5s ease-in-out infinite}@keyframes sv-as-pulse{0%,to{border-color:#f0c04080}50%{border-color:#f0c040}}.sv-as-speeds{display:flex;gap:4px}.sv-as-speed{background:transparent;border:1px solid var(--border);color:var(--text-muted);border-radius:6px;padding:6px 11px;font-size:12px;font-family:DM Sans,sans-serif;cursor:pointer;transition:all .12s}.sv-as-speed.active{background:var(--gold-pale);border-color:var(--border-bright);color:var(--gold);font-weight:700}.sv-nav-bar{background:var(--surface);border-top:1px solid var(--border);display:flex;gap:10px;padding:10px 16px;padding-bottom:calc(10px + env(safe-area-inset-bottom));flex-shrink:0}.sv-nav-btn{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:11px;font-size:14px;font-weight:500;color:var(--text-muted);cursor:pointer;font-family:DM Sans,sans-serif;text-align:center;transition:all .15s}.sv-nav-btn:hover{border-color:var(--border-bright);color:var(--text)}.sv-nav-btn.primary{background:var(--gold);color:#000;border-color:var(--gold);font-weight:700}.aud-wrap{min-height:100vh;background:#0f0f0f;color:#fff;font-family:DM Sans,sans-serif;padding:0 0 40px}.aud-header{background:#161616;border-bottom:1px solid rgba(240,192,64,.25);padding:20px;text-align:center}.aud-logo{font-family:Playfair Display,serif;font-size:26px;color:#f0c040}.aud-logo sup{font-size:11px;color:#aaa;font-family:DM Sans,sans-serif}.aud-sub{font-size:13px;color:#aaa;margin-top:4px}.aud-musician{font-size:15px;color:#fff;font-weight:500;margin-top:6px}.aud-body{padding:20px}.aud-label{font-size:12px;color:#aaa;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.aud-search{background:#1e1e1e;border:1px solid rgba(240,192,64,.25);border-radius:12px;padding:14px 16px;width:100%;font-size:16px;color:#fff;font-family:DM Sans,sans-serif;outline:none;margin-bottom:12px}.aud-search:focus{border-color:#f0c0408c}.aud-search::placeholder{color:#777}.aud-result{background:#1e1e1e;border:1px solid rgba(240,192,64,.25);border-radius:12px;padding:14px 16px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .15s;width:100%;text-align:left;font-family:DM Sans,sans-serif}.aud-result:hover,.aud-result.selected{border-color:#f0c0408c;background:#f0c04012}.aud-result-title{font-size:15px;font-weight:500;margin-bottom:2px}.aud-result-artist{font-size:12px;color:#aaa}.aud-result-key{font-size:12px;color:#f0c040;background:#f0c0401a;border:1px solid rgba(240,192,64,.3);border-radius:6px;padding:3px 8px}.aud-name-input{background:#1e1e1e;border:1px solid rgba(240,192,64,.25);border-radius:12px;padding:14px 16px;width:100%;font-size:16px;color:#fff;font-family:DM Sans,sans-serif;outline:none;margin-bottom:12px}.aud-name-input:focus{border-color:#f0c04080}.aud-submit{background:#f0c040;color:#000;border:none;border-radius:12px;padding:16px;width:100%;font-size:16px;font-weight:700;cursor:pointer;font-family:DM Sans,sans-serif;margin-top:4px}.aud-submit:disabled{background:#3a3000;color:#666;cursor:not-allowed}.aud-success{text-align:center;padding:40px 20px}.aud-success-icon{font-size:64px;margin-bottom:16px}.aud-success-title{font-family:Playfair Display,serif;font-size:28px;color:#f0c040;margin-bottom:8px}.aud-success-sub{font-size:15px;color:#aaa;margin-bottom:24px}.aud-another{background:transparent;color:#f0c040;border:1px solid rgba(240,192,64,.4);border-radius:12px;padding:14px 24px;font-size:15px;cursor:pointer;font-family:DM Sans,sans-serif}.aud-no-results{text-align:center;padding:24px;color:#aaa;font-size:14px}.divider{height:1px;background:var(--border);margin:0 20px 20px}.scroll-pad{height:20px}.scan-btn{background:#f0c04014;border:1px dashed var(--border-bright);border-radius:10px;padding:16px;width:100%;display:flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;font-family:DM Sans,sans-serif;font-size:14px;color:var(--gold);margin-bottom:16px;transition:all .15s}.scan-btn:hover{background:#f0c04024}.scan-divider{display:flex;align-items:center;gap:12px;margin-bottom:16px;color:var(--text-dim);font-size:12px}.scan-divider:before,.scan-divider:after{content:"";flex:1;height:1px;background:var(--border)}.scan-preview-wrap{position:relative;width:100%;border-radius:10px;overflow:hidden;margin-bottom:12px;border:1px solid var(--border);background:var(--surface3);max-height:200px;display:flex;align-items:center;justify-content:center}.scan-preview-img{width:100%;max-height:200px;object-fit:contain;display:block}.scan-preview-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;gap:10px;color:var(--gold);font-size:15px;font-weight:600}.scan-success-banner{background:#4ae0801a;border:1px solid rgba(74,224,128,.3);border-radius:8px;padding:10px 14px;margin-bottom:14px;font-size:13px;color:var(--green);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.scan-rescan-btn{background:none;border:1px solid rgba(74,224,128,.4);border-radius:6px;padding:4px 10px;font-size:12px;color:var(--green);cursor:pointer;white-space:nowrap;font-family:DM Sans,sans-serif}.scan-rescan-btn:hover{background:#4ae0801a}.scan-raw-details{margin-bottom:14px;font-size:12px;color:var(--text-muted)}.scan-raw-details summary{cursor:pointer;padding:4px 0;color:var(--text-dim);-webkit-user-select:none;user-select:none}.scan-raw-text{margin-top:8px;background:var(--surface3);border:1px solid var(--border);border-radius:6px;padding:10px;font-size:11px;font-family:monospace;white-space:pre-wrap;word-break:break-all;max-height:180px;overflow-y:auto;color:var(--text-muted)}.pdf-progress{margin-bottom:14px}.pdf-progress-label{font-size:13px;color:var(--gold);margin-bottom:8px;text-align:center}.pdf-progress-bar{width:100%;height:6px;background:var(--surface3);border-radius:3px;overflow:hidden}.pdf-progress-fill{height:100%;background:var(--gold);border-radius:3px;transition:width .3s ease}.pdf-multi-choice{background:#f0c04014;border:1px solid rgba(240,192,64,.3);border-radius:10px;padding:14px 16px;margin-bottom:14px}.pdf-multi-title{font-size:14px;color:var(--text);margin-bottom:12px;text-align:center}.pdf-multi-btns{display:flex;gap:10px;justify-content:center}.pdf-multi-btns .btn-secondary,.pdf-multi-btns .btn-primary{flex:1;max-width:180px}.library-card{margin:0 20px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:12px;overflow:hidden}.library-card-row{display:flex;align-items:center;padding:14px 16px;gap:12px;cursor:pointer;transition:all .15s;border-bottom:1px solid var(--border)}.library-card-row:hover{background:var(--surface3)}.library-card-actions{display:flex}.library-card-action{flex:1;padding:9px 14px;font-size:12px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;gap:5px;background:none;border:none;font-family:DM Sans,sans-serif;transition:color .15s}.library-card-action:hover{color:var(--text)}.library-card-action+.library-card-action{border-left:1px solid var(--border)}.auth-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;overflow-y:auto}.auth-logo{font-family:Playfair Display,serif;font-size:42px;color:var(--gold);margin-bottom:4px;text-align:center}.auth-tagline{font-size:14px;color:var(--text-muted);text-align:center;margin-bottom:48px}.auth-form{width:100%;max-width:400px}.auth-title{font-family:Playfair Display,serif;font-size:24px;margin-bottom:24px;text-align:center}.auth-input{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;width:100%;font-size:16px;color:var(--text);font-family:DM Sans,sans-serif;outline:none;margin-bottom:12px}.auth-input:focus{border-color:var(--border-bright)}.auth-input::placeholder{color:var(--text-dim)}.auth-btn{background:var(--gold);color:#000;border:none;border-radius:12px;padding:16px;width:100%;font-size:16px;font-weight:700;font-family:DM Sans,sans-serif;cursor:pointer;margin-top:8px;margin-bottom:16px}.auth-btn:disabled{background:#3a3000;color:#666;cursor:not-allowed}.auth-toggle{text-align:center;font-size:14px;color:var(--text-muted)}.auth-toggle button{color:var(--gold);background:none;border:none;cursor:pointer;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600}.auth-error{background:#ff55551a;border:1px solid rgba(255,85,85,.3);border-radius:10px;padding:12px 16px;font-size:13px;color:var(--red);margin-bottom:16px;text-align:center}.setlist-picker-list{max-height:320px;overflow-y:auto;border-radius:10px}.setlist-picker-item{display:flex;align-items:center;padding:13px 14px;gap:12px;cursor:pointer;background:var(--surface2);border:none;border-bottom:1px solid var(--border);width:100%;text-align:left;font-family:DM Sans,sans-serif;transition:background .12s}.setlist-picker-item:last-child{border-bottom:none}.setlist-picker-item:hover{background:var(--surface3)}.spi-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.spi-info{flex:1;min-width:0}.spi-name{font-size:16px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spi-count{font-size:13px;color:var(--text-muted);margin-top:2px}.spi-add{flex-shrink:0;background:var(--gold);color:#000;font-size:13px;font-weight:700;font-family:DM Sans,sans-serif;border-radius:8px;padding:5px 12px;white-space:nowrap}.spi-check{flex-shrink:0;font-size:18px;font-weight:700;color:var(--green);width:36px;text-align:center}.spinner{width:20px;height:20px;border:2px solid rgba(240,192,64,.2);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}.sv-profile-wrap{position:relative;flex-shrink:0;display:flex;align-items:center;gap:6px}.sv-profile-btn{display:flex;align-items:center;gap:5px;background:var(--surface3);border:1px solid var(--border);border-radius:8px;padding:5px 10px;cursor:pointer;font-family:DM Sans,sans-serif;transition:border-color .15s;max-width:130px}.sv-profile-btn.open,.sv-profile-btn:hover{border-color:var(--border-bright)}.sv-profile-name{font-size:12px;font-weight:600;color:var(--gold);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:90px}.sv-profile-chevron{font-size:10px;color:var(--gold-dim);flex-shrink:0}.sv-profile-saved{font-size:11px;font-weight:700;color:var(--green);white-space:nowrap;animation:fadeIn .15s ease}.sv-profile-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:170px;background:var(--surface2);border:1px solid var(--border-bright);border-radius:10px;z-index:200;overflow:hidden;box-shadow:0 8px 24px #00000080;animation:fadeIn .15s ease}.sv-pd-item{display:flex;align-items:center;gap:6px;padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .12s}.sv-pd-item:hover{background:var(--surface3)}.sv-pd-item.active{background:var(--gold-pale)}.sv-pd-name{flex:1;font-size:13px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sv-pd-item.active .sv-pd-name{color:var(--gold);font-weight:700}.sv-pd-check{font-size:12px;color:var(--gold);flex-shrink:0}.sv-pd-del{background:none;border:none;color:var(--text-dim);font-size:12px;cursor:pointer;padding:2px 4px;border-radius:4px;flex-shrink:0;font-family:DM Sans,sans-serif;transition:color .12s}.sv-pd-del:hover{color:var(--red)}.sv-pd-new{padding:10px 14px;font-size:13px;font-weight:600;color:var(--gold);cursor:pointer;text-align:center;transition:background .12s}.sv-pd-new:hover{background:var(--gold-pale)}.sv-section{display:flex;align-items:center;gap:8px}.sv-pause-clock{background:none;border:1px solid var(--border);color:var(--text-muted);border-radius:6px;padding:1px 6px;font-size:13px;cursor:pointer;font-family:DM Sans,sans-serif;transition:all .12s;flex-shrink:0}.sv-pause-clock:hover{border-color:var(--gold);color:var(--gold)}.sv-pause-badge{display:inline-block;background:#f0c04026;border:1px solid rgba(240,192,64,.4);color:var(--gold);border-radius:10px;padding:1px 7px;font-size:11px;font-weight:700;flex-shrink:0}.sv-pause-picker{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:var(--surface2);border:1px solid var(--border-bright);border-radius:14px;padding:16px 18px;z-index:180;min-width:280px;box-shadow:0 8px 32px #0009;animation:fadeIn .15s ease}.sv-pp-title{font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:12px;text-align:center}.sv-pp-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.sv-pp-opt{background:var(--surface3);border:1px solid var(--border);color:var(--text-muted);border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600;font-family:DM Sans,sans-serif;cursor:pointer;transition:all .12s;min-width:52px;text-align:center}.sv-pp-opt:hover{border-color:var(--border-bright);color:var(--text)}.sv-pp-opt.active{background:var(--gold-pale);border-color:var(--gold);color:var(--gold)}.sv-as-btn.scrolling{background:var(--gold-pale);border-color:var(--gold);color:var(--gold);animation:sv-as-pulse 1.5s ease-in-out infinite}.sv-as-btn.paused{background:#4ae08014;border-color:var(--green);color:var(--green);animation:sv-pause-pulse 1s ease-in-out infinite}@keyframes sv-pause-pulse{0%,to{border-color:#4ae08080}50%{border-color:#4ae080}}.sv-autoscroll-bar.warning{background:#f0c0400f;border-top-color:#f0c04066;animation:sv-warn-flash .4s ease-in-out infinite alternate}@keyframes sv-warn-flash{0%{background:#f0c0400a}to{background:#f0c0401f}}.settings-body{padding:16px 16px 0}.settings-section-label{font-size:11px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:1.2px;padding:20px 4px 8px}.settings-section-label:first-child{padding-top:8px}.settings-card{background:var(--surface2);border:1px solid var(--border);border-radius:14px;overflow:hidden}.settings-divider{height:1px;background:var(--border);margin:0}.settings-profile-row{display:flex;align-items:center;gap:14px;padding:16px 16px 14px}.settings-avatar{width:52px;height:52px;border-radius:50%;background:var(--gold);color:#000;font-size:20px;font-weight:800;font-family:Playfair Display,serif;display:flex;align-items:center;justify-content:center;flex-shrink:0}.settings-profile-info{flex:1;min-width:0}.settings-profile-name{font-size:17px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.settings-profile-email{font-size:13px;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.settings-profile-sub{font-size:12px;color:var(--gold);margin-top:2px}.settings-row{display:flex;align-items:center;gap:10px;padding:14px 16px;width:100%;background:none;border:none;text-align:left;font-family:DM Sans,sans-serif;cursor:pointer;text-decoration:none;transition:background .12s}.settings-row:hover{background:var(--surface3)}.settings-row-icon{font-size:18px;flex-shrink:0}.settings-row-label{flex:1;font-size:15px;color:var(--text)}.settings-row-chevron{font-size:20px;color:var(--text-dim)}.settings-row-value{font-size:14px;color:var(--text-muted)}.settings-row-danger .settings-row-label{color:var(--red)}.settings-row-info{cursor:default}.settings-row-info:hover{background:none}.settings-pref-row{padding:12px 16px;display:flex;flex-direction:column;gap:10px}.settings-pref-label{font-size:13px;font-weight:600;color:var(--text-muted)}.settings-chip-group{display:flex;flex-wrap:wrap;gap:8px}.settings-chip{background:var(--surface3);border:1px solid var(--border);border-radius:20px;padding:6px 14px;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;font-family:DM Sans,sans-serif;transition:all .12s}.settings-chip:hover{border-color:var(--border-bright);color:var(--text)}.settings-chip.active{background:var(--gold-pale);border-color:var(--gold);color:var(--gold);font-weight:700}.settings-chip-sm{padding:6px 10px;min-width:38px;text-align:center}.settings-plan-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px}.settings-plan-badge{background:var(--surface3);border:1px solid var(--border);border-radius:20px;padding:4px 14px;font-size:13px;font-weight:700;color:var(--text-muted)}.settings-upgrade-block{padding:16px}.settings-upgrade-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:10px}.settings-upgrade-list{list-style:none;padding:0;margin:0 0 14px;display:flex;flex-direction:column;gap:6px}.settings-upgrade-list li{font-size:13px;color:var(--text-muted);padding-left:14px;position:relative}.settings-upgrade-list li:before{content:"✓";position:absolute;left:0;color:var(--gold);font-weight:700}.settings-coming-soon{font-size:11px;color:var(--text-dim);background:var(--surface3);border-radius:8px;padding:1px 6px;margin-left:4px}.settings-upgrade-btn{width:100%;background:var(--gold);color:#000;border:none;border-radius:10px;padding:13px;font-size:15px;font-weight:700;font-family:DM Sans,sans-serif;cursor:pointer}.settings-upgrade-btn:disabled{background:var(--surface3);color:var(--text-dim);cursor:not-allowed}.settings-instrument-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}[data-theme=light] .screen-song-view,[data-theme=light] .sv-sheet{background:#fafaf7}[data-theme=light] .sv-header{background:#fff;border-bottom:1px solid rgba(0,0,0,.08)}[data-theme=light] .sv-chord{color:#c8960a}[data-theme=light] .sv-section{color:#8a6e20}[data-theme=light] .sv-autoscroll-bar,[data-theme=light] .sv-nav-bar{background:#fff;border-top:1px solid rgba(0,0,0,.08)}[data-theme=light] .sv-as-btn{border-color:#c8960a66;color:#c8960a}[data-theme=light] .sv-as-btn.scrolling{background:#c8960a14;border-color:#c8960a}[data-theme=light] .sv-as-btn.paused{background:#1a904014;border-color:#1a9040;color:#1a9040}[data-theme=light] .sv-as-speed{border-color:#0000001f;color:#6b6450}[data-theme=light] .sv-as-speed.active{background:#c8960a1a;border-color:#c8960a;color:#c8960a}[data-theme=light] .sv-edit-toolbar{background:#fff;border-bottom:1px solid rgba(0,0,0,.08)}[data-theme=light] .sv-popover{background:#fff;border-color:#c8960a;box-shadow:0 4px 20px #0000001f}[data-theme=light] .sv-pop-input{background:#f2efe8;color:#c8960a;border-color:#c8960a59}[data-theme=light] .sv-qc{background:#f2efe8;border-color:#0000001a;color:#6b6450}[data-theme=light] .sv-mode-btn{border-color:#00000026;color:#6b6450}[data-theme=light] .sv-mode-btn.active{border-color:#c8960a;color:#c8960a}[data-theme=light] .sv-key-dd-btn{background:#f2efe8;border-color:#0000001f}[data-theme=light] .sv-key-dd-menu{background:#fff;border-color:#c8960a;box-shadow:0 4px 16px #0000001a}[data-theme=light] .sv-kdm-key{background:#f2efe8;border-color:#0000001a;color:#6b6450}[data-theme=light] .sv-kdm-key.cur{background:#c8960a;color:#fff;border-color:#c8960a}[data-theme=light] .sv-lyric-editable:hover{background:#c8960a0f}[data-theme=light] .sv-lyric-input{background:#f2efe8;border-color:#c8960a59;color:#1a1a1a}[data-theme=light] .sv-tab{background:#f2efe8;border-color:#0000001a;color:#6b6450}[data-theme=light] .sv-tab.active{background:#c8960a1a;border-color:#c8960a;color:#c8960a}[data-theme=light] .sv-profile-btn{background:#f2efe8;border-color:#0000001f}[data-theme=light] .sv-profile-dropdown{background:#fff;border-color:#c8960a66;box-shadow:0 6px 20px #0000001a}[data-theme=light] .sv-pd-item{border-bottom-color:#0000000f}[data-theme=light] .sv-pd-item:hover{background:#f2efe8}[data-theme=light] .sv-pd-item.active{background:#c8960a14}[data-theme=light] .sv-pause-picker{background:#fff;border-color:#c8960a66;box-shadow:0 6px 24px #0000001f}[data-theme=light] .sv-pp-opt{background:#f2efe8;border-color:#0000001a;color:#6b6450}[data-theme=light] .sv-pp-opt.active{background:#c8960a1a;border-color:#c8960a;color:#c8960a}[data-theme=light] .sv-edit-hint{background:#c8960a0d;border-top-color:#00000014}.guest-mode .screen:not(.screen-song-view){top:40px}.guest-banner{position:fixed;top:0;left:0;right:0;height:40px;z-index:100;display:flex;align-items:center;gap:10px;padding:0 14px;background:#1a1200;border-bottom:1px solid rgba(240,192,64,.25)}.guest-banner-text{flex:1;font-size:12px;color:#a89040;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.guest-banner-btn{background:var(--gold);color:#000;border:none;border-radius:7px;padding:5px 12px;font-size:12px;font-weight:700;cursor:pointer;flex-shrink:0;font-family:DM Sans,sans-serif}.upsell-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;z-index:300;display:flex;align-items:flex-end;padding:20px 16px calc(20px + env(safe-area-inset-bottom))}.upsell-modal{background:var(--surface2);border-radius:20px 20px 16px 16px;padding:28px 24px 24px;width:100%;max-width:420px;margin:0 auto;text-align:center;border:1px solid var(--border-bright)}.upsell-icon{font-size:44px;margin-bottom:10px}.upsell-title{font-family:Playfair Display,serif;font-size:26px;color:var(--text);margin-bottom:8px}.upsell-sub{font-size:14px;color:var(--text-muted);line-height:1.55;margin-bottom:22px}.upsell-signup-btn{display:block;width:100%;background:var(--gold);color:#000;border:none;border-radius:12px;padding:14px;font-size:16px;font-weight:700;cursor:pointer;font-family:DM Sans,sans-serif;margin-bottom:10px}.upsell-dismiss-btn{background:none;border:none;color:var(--text-muted);font-size:14px;cursor:pointer;padding:8px;font-family:DM Sans,sans-serif;width:100%}.upsell-dismiss-btn:hover{color:var(--text-dim)}.auth-divider{text-align:center;color:var(--text-dim);font-size:12px;margin:16px 0 12px;position:relative}.auth-divider:before,.auth-divider:after{content:"";position:absolute;top:50%;width:calc(50% - 20px);height:1px;background:#ffffff14}.auth-divider:before{left:0}.auth-divider:after{right:0}.auth-guest-btn{display:block;width:100%;background:transparent;border:1px solid rgba(240,192,64,.35);border-radius:12px;padding:14px;color:#d4a820;font-size:15px;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif;transition:background .15s,border-color .15s}.auth-guest-btn:hover{background:#f0c04014;border-color:#f0c04099}.lang-switcher{display:flex;gap:6px}.lang-btn{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:2px solid transparent;border-radius:10px;padding:6px 10px;cursor:pointer;opacity:.45;transition:opacity .15s,border-color .15s}.lang-btn.active{opacity:1;border-color:var(--gold)}.lang-btn:not(.active):hover{opacity:.75}.lang-flag{font-size:26px;line-height:1}.lang-label{font-size:10px;font-weight:600;color:var(--text, #fff);font-family:DM Sans,sans-serif;white-space:nowrap}.auth-screen{position:relative}.auth-lang-wrap{position:absolute;top:20px;right:20px;z-index:10}.batch-body{padding:16px 20px 40px}.batch-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:100%;min-height:160px;background:var(--surface2);border:2px dashed var(--border-bright);border-radius:16px;padding:28px 20px;cursor:pointer;text-align:center;margin-bottom:20px;transition:background .15s,border-color .15s;box-sizing:border-box}.batch-dropzone:hover,.batch-dropzone.drag-active{background:var(--surface3);border-color:var(--gold)}.batch-dz-icon{font-size:36px}.batch-dz-title{font-size:15px;font-weight:600;color:var(--gold)}.batch-dz-sub{font-size:12px;color:var(--text-muted)}.batch-grid-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.batch-grid-count{font-size:13px;color:var(--text-muted)}.batch-clear-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:4px 10px;font-size:12px;color:var(--text-muted);cursor:pointer;font-family:DM Sans,sans-serif}.batch-clear-btn:hover{color:var(--red);border-color:#f556}.batch-thumb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:10px;margin-bottom:20px}.batch-thumb{position:relative;background:var(--surface2);border:1px solid var(--border);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;align-items:center}.batch-thumb-img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.batch-thumb-pdf{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:#f0c04014;font-size:18px;font-weight:700;color:var(--gold);letter-spacing:1px}.batch-thumb-name{font-size:10px;color:var(--text-muted);padding:4px 6px;width:100%;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-sizing:border-box}.batch-thumb-remove{position:absolute;top:4px;right:4px;width:18px;height:18px;border-radius:50%;background:#0000008c;border:none;color:#fff;font-size:13px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.batch-thumb-remove:hover{background:var(--red)}.batch-thumb-add{cursor:pointer;justify-content:center;min-height:88px;border-style:dashed;border-color:var(--border-bright);gap:4px;padding:12px 0}.batch-thumb-add:hover{background:var(--surface3);border-color:var(--gold)}.batch-thumb-plus{font-size:22px;color:var(--gold);font-weight:300}.batch-run-btn{width:100%;margin-top:4px;margin-bottom:16px}.batch-progress-wrap{margin-bottom:16px}.batch-progress-bar{height:6px;background:var(--surface3);border-radius:3px;overflow:hidden;margin-bottom:8px}.batch-progress-fill{height:100%;background:var(--gold);border-radius:3px;transition:width .3s ease}.batch-progress-label{font-size:12px;color:var(--text-muted)}.batch-progress-label em{color:var(--text);font-style:normal}.batch-summary{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.batch-stat{font-size:13px;font-weight:600;padding:6px 12px;border-radius:8px;background:var(--surface2)}.batch-stat.ok{color:var(--green)}.batch-stat.review{color:var(--gold)}.batch-stat.fail{color:var(--red)}.batch-stat.skip{color:var(--text-muted)}.batch-list{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.batch-item{background:var(--surface2);border:1px solid var(--border);border-radius:12px;overflow:hidden}.batch-item.ok{border-color:#4ae0804d}.batch-item.review{border-color:#f0c04066}.batch-item.fail{border-color:#ff55554d}.batch-item.active{border-color:#f0c0408c}.batch-item-row{display:flex;align-items:center;gap:12px;padding:13px 14px}.batch-item-icon{font-size:15px;font-weight:700;flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.batch-item-icon.ok{color:var(--green)}.batch-item-icon.review{color:var(--gold)}.batch-item-icon.fail{color:var(--red)}.batch-item-icon.skip{color:var(--text-muted)}.batch-item-icon.active{color:var(--gold)}.batch-item-dots{letter-spacing:-1px;color:var(--text-muted)}.batch-item-info{flex:1;min-width:0}.batch-item-name{font-size:14px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.batch-item-sub{font-size:12px;color:var(--text-muted);margin-top:2px}.batch-item-error{font-size:11px;color:var(--red);margin-top:2px;white-space:normal}.batch-item-review{padding:0 14px 14px;display:flex;flex-direction:column;gap:8px}.batch-review-row{display:flex;gap:8px}.batch-raw-details{font-size:12px;color:var(--text-muted)}.batch-raw-details summary{cursor:pointer;padding:2px 0;color:var(--text-muted);-webkit-user-select:none;user-select:none}.batch-raw-text{margin-top:6px;background:var(--surface3);border-radius:6px;padding:8px 10px;font-size:10px;font-family:monospace;white-space:pre-wrap;word-break:break-all;max-height:150px;overflow-y:auto;color:var(--text-muted)}.batch-item-actions{padding:0 14px 13px}.batch-item-btn-row{display:flex;gap:8px}
