:root{--bg-base: #0d1117;--bg-surface: #161b22;--bg-elevated:#1c2230;--bg-hover: #21283a;--border: #2d3748;--border-light: #3d4f6b;--text-primary: #e8edf5;--text-secondary: #8b98b0;--text-muted: #4a5568;--gold: #d4a843;--gold-dim: #a07830;--blue: #4a90d9;--blue-dim: #2d5f99;--green: #4caf7d;--red: #e05555;--red-dim: #8b2e2e;--sidebar-w: 220px;--right-w: 300px;--radius: 8px;--radius-sm: 5px;--radius-lg: 12px;--font-ui: "Inter", -apple-system, sans-serif;--font-display: "Cinzel", Georgia, serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-ui);background:var(--bg-base);color:var(--text-primary);font-size:14px;line-height:1.5;overflow:hidden;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,.hero-content h1{text-wrap:balance}button{cursor:pointer;border:none;background:none;color:inherit;font:inherit}input,select,textarea{font:inherit;color:var(--text-primary);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;width:100%;outline:none;transition:border-color .15s ease-out,box-shadow .15s ease-out}input:focus,select:focus,textarea:focus{border-color:var(--blue)}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--blue);outline-offset:1px;box-shadow:0 0 0 4px #4a90d91a}textarea{resize:vertical}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr var(--right-w);height:100vh;overflow:hidden;transition:grid-template-columns .3s ease}.app-shell.sidebar-hidden{grid-template-columns:0 1fr var(--right-w)}@media(max-width:1200px){.app-shell{grid-template-columns:var(--sidebar-w) 1fr 240px}}@media(max-width:1024px){.app-shell{grid-template-columns:1fr var(--right-w)}.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:100;width:var(--sidebar-w);box-shadow:10px 0 30px #00000080;background:var(--bg-surface);transform:translate(-100%)}.app-shell:not(.sidebar-hidden) .sidebar{transform:translate(0);width:var(--sidebar-w);padding:16px 12px}}@media(max-width:768px){.app-shell{display:flex;flex-direction:column}.right-panel{height:40vh;border-left:none;border-top:1px solid var(--border)}.main-content{flex:1;min-height:0}}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:16px 12px;gap:4px;overflow:hidden;transition:transform .3s ease,width .3s ease}.app-shell.sidebar-hidden .sidebar{transform:translate(-100%);width:0;padding:0;border:none}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:8px 8px 16px;font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--gold);letter-spacing:.5px}.sidebar-church{font-size:11px;color:var(--text-muted);padding:0 8px 12px;text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border);margin-bottom:4px}.btn-new-song{display:flex;align-items:center;gap:8px;background:var(--gold);color:#0d1117;font-weight:600;font-size:13px;padding:9px 14px;border-radius:var(--radius);margin-bottom:8px;transition:opacity .15s}.btn-new-song:hover{opacity:.88}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;transition:background-color .12s ease-out,color .12s ease-out}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--bg-hover);color:var(--gold)}.sidebar-footer{border-top:1px solid var(--border);padding-top:12px}.sidebar-sync-status{padding:0 8px;margin-bottom:8px}.sync-indicator{display:flex;align-items:center;gap:6px;font-size:12px;padding:6px 8px;border-radius:6px}.sync-indicator.synced{color:var(--gold);background:#d4af371a}.sync-login-btn{display:flex;align-items:center;gap:6px;font-size:12px;padding:6px 8px;border-radius:6px;width:100%;background:#ffffff08;border:1px dashed var(--border);color:var(--text-muted);cursor:pointer;transition:background-color .15s ease-out,color .15s ease-out,border-color .15s ease-out}.sync-login-btn:hover{background:#ffffff0f;border-color:var(--gold-dim);color:var(--gold)}.btn-projection{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border-light);color:var(--blue);font-size:13px;font-weight:500;transition:background-color .15s ease-out,color .15s ease-out,border-color .15s ease-out}.btn-projection:hover{background:var(--bg-hover);border-color:var(--blue-dim)}.main-content{overflow:hidden;display:flex;flex-direction:column;flex:1;min-height:0}.right-panel{background:var(--bg-surface);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}.view-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.view-header h1{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--text-primary)}.header-actions{display:flex;gap:8px;align-items:center}.song-count{font-size:12px;color:var(--text-muted);margin-left:10px}.auth-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;margin-bottom:16px}.auth-card.success{border-color:var(--gold-dim);padding:12px 16px;border-radius:var(--radius-md);background:#ffd7000d}.btn-primary{display:inline-flex;align-items:center;gap:6px;background:var(--blue);color:#fff;font-size:13px;font-weight:500;padding:8px 14px;border-radius:var(--radius-sm);transition:opacity .15s;white-space:nowrap}.btn-primary:hover{opacity:.88}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-primary.large{padding:12px 24px;font-size:15px}.btn-ghost{display:inline-flex;align-items:center;gap:6px;background:transparent;color:var(--text-secondary);font-size:13px;padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);transition:all .15s;white-space:nowrap}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;border-radius:var(--radius-sm);color:var(--text-secondary);transition:background-color .12s ease-out,color .12s ease-out,transform .12s ease-out}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary);transform:translateY(-1px)}.btn-icon.danger:hover{background:var(--red-dim);color:var(--red)}.btn-icon:focus-visible,.btn-icon-xs:focus-visible,.btn-nav:focus-visible,.btn-special:focus-visible,.nav-item:focus-visible,.btn-ghost:focus-visible,.btn-primary:focus-visible,.btn-projection:focus-visible,.btn-new-song:focus-visible,.slide-item:focus-visible,.song-card-compact:focus-visible,.verse-item:focus-visible,.book-item:focus-visible,.testament-tab:focus-visible,.preview-slide-btn:focus-visible,.live-slide-card:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.library-view{display:flex;flex-direction:column;height:100%}.library-filters{display:flex;gap:8px;align-items:center;padding:12px 24px;border-bottom:1px solid var(--border);flex-shrink:0}.search-box{display:flex;align-items:center;gap:8px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 12px;flex:1}.search-box input{background:none;border:none;padding:0;flex:1}.search-box input:focus{border:none}.filter-select{width:auto;flex-shrink:0;font-size:13px;padding:6px 8px}.library-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted)}.library-empty p{font-size:16px}.song-list{flex:1;overflow-y:auto;padding:8px 16px 16px;display:flex;flex-direction:column;gap:4px}.song-card{display:flex;align-items:center;justify-content:space-between;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;cursor:pointer;transition:all .12s}.song-card:hover{background:var(--bg-hover);border-color:var(--border-light)}.song-card-info{flex:1;min-width:0}.song-card-title{font-weight:500;font-size:14px;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-card-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:12px;color:var(--text-secondary)}.song-key{background:var(--gold-dim);color:var(--gold);padding:1px 7px;border-radius:99px;font-size:11px;font-weight:600}.tag{background:var(--bg-base);color:var(--text-secondary);padding:1px 8px;border-radius:99px;font-size:11px;border:1px solid var(--border)}.tag.removable{cursor:pointer}.tag.removable:hover{background:var(--red-dim);color:var(--red);border-color:var(--red-dim)}.usage-count{font-size:11px;color:var(--text-muted);margin-top:3px}.song-card-actions{display:flex;gap:2px;flex-shrink:0}.control-panel{border-bottom:1px solid var(--border);padding:16px;display:flex;flex-direction:column;gap:10px}.control-panel.empty{flex:1;align-items:center;justify-content:center;min-height:300px}.control-empty-msg{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-muted);text-align:center}.control-empty-msg p{font-size:14px}.control-empty-msg span{font-size:12px}.control-song-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.control-song-title{font-weight:600;font-size:15px;line-height:1.3}.control-song-progress{font-size:12px;color:var(--text-muted);margin-top:3px}.progress-bar{height:3px;background:var(--border);border-radius:99px;overflow:hidden}.progress-fill{height:100%;background:var(--gold);transition:width .3s}.slides-list{display:flex;flex-direction:column;gap:2px;max-height:240px;overflow-y:auto}.slide-item{display:flex;flex-direction:column;gap:2px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;border:1px solid transparent;transition:all .12s;text-align:left}.slide-preview{font-size:var(--slide-preview-size, 13px);color:var(--text-primary);line-height:1.5}.slides-size-control{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-muted)}.slides-size-control input[type=range]{flex:1;padding:0;border:none;background:none;height:4px}.slide-item:hover{background:var(--bg-hover)}.slide-item.active{background:var(--bg-hover);border-color:var(--gold)}.slide-label{font-size:10px;color:var(--gold);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.slide-preview{font-size:12px;color:var(--text-primary);line-height:1.4}.slide-preview.dim{color:var(--text-muted)}.control-nav{display:grid;grid-template-columns:1fr 1fr;gap:6px}.btn-nav{display:flex;align-items:center;justify-content:center;gap:5px;padding:9px;border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border);font-size:13px;font-weight:500;transition:all .12s}.btn-nav:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-light)}.btn-nav.primary{background:var(--blue);border-color:var(--blue);color:#fff}.btn-nav.primary:hover:not(:disabled){opacity:.88}.btn-nav:disabled{opacity:.3;cursor:not-allowed}.control-special{display:grid;grid-template-columns:1fr 1fr;gap:6px}.btn-special{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border);font-size:12px;font-weight:500;color:var(--text-secondary);transition:background-color .15s ease-out,color .15s ease-out,border-color .15s ease-out}.btn-special:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-special.active-black{background:#000;border-color:#555;color:#fff}.btn-special.active-logo{background:var(--gold-dim);border-color:var(--gold);color:var(--gold)}.recognition-panel{padding:16px;display:flex;flex-direction:column;gap:10px}.recognition-header{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.recognition-warning{display:flex;align-items:center;gap:6px;background:#3d2a00;border:1px solid #6b4a00;color:#f0a030;border-radius:var(--radius-sm);padding:8px 10px;font-size:12px}.device-select{font-size:12px;padding:6px 8px}.btn-recognition{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border);font-size:13px;font-weight:500;color:var(--text-secondary);transition:background-color .15s ease-out,color .15s ease-out,border-color .15s ease-out}.btn-recognition:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn-recognition.active{background:var(--red-dim);border-color:var(--red);color:var(--red)}.btn-recognition:disabled{opacity:.3;cursor:not-allowed}.recognition-status{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);font-size:12px;background:var(--bg-elevated)}.recognition-status.status-listening{color:var(--blue)}.recognition-status.status-detecting{color:var(--gold)}.recognition-status.status-found{color:var(--green)}.recognition-status.status-not_found{color:var(--text-muted)}.recognition-status.status-error{color:var(--red)}.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);animation:pulse 1.5s ease-in-out infinite}.spin-dot{width:8px;height:8px;border-radius:50%;border:2px solid var(--gold);border-top-color:transparent;animation:spin .8s linear infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .8s linear infinite}.detected-song{background:var(--bg-elevated);border:1px solid var(--green);border-radius:var(--radius-sm);padding:12px;display:flex;flex-direction:column;gap:4px}.detected-title{font-weight:600;font-size:14px}.detected-artist{font-size:12px;color:var(--text-secondary)}.detected-confidence{font-size:11px;color:var(--text-muted)}.detected-actions{display:flex;gap:6px;margin-top:8px}.btn-confirm{display:flex;align-items:center;gap:5px;flex:1;justify-content:center;padding:7px;background:var(--green);color:#fff;border-radius:var(--radius-sm);font-size:12px;font-weight:600}.btn-dismiss{display:flex;align-items:center;gap:5px;padding:7px 10px;background:var(--bg-base);color:var(--text-muted);border-radius:var(--radius-sm);border:1px solid var(--border);font-size:12px}.song-editor{display:flex;flex-direction:column;height:100%}.editor-body{display:grid;grid-template-columns:1fr 340px;flex:1;overflow:hidden;gap:0}@media(max-width:1000px){.editor-body{grid-template-columns:1fr}.editor-preview{display:none}}.editor-form{padding:16px 24px;overflow-y:auto;display:flex;flex-direction:column;gap:14px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:12px;font-weight:500;color:var(--text-secondary);display:flex;align-items:center;gap:5px}.tag-input-row{display:flex;gap:6px}.tag-input-row input{flex:1}.tags-row{display:flex;flex-wrap:wrap;gap:4px}.lyrics-group{flex:1}.lyrics-toolbar{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}.btn-label{padding:4px 10px;font-size:11px;font-weight:500;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);transition:all .12s}.btn-label:hover{background:var(--bg-hover);color:var(--gold);border-color:var(--gold-dim)}.lyrics-textarea{flex:1;font-family:Lora,Georgia,serif;font-size:14px;line-height:1.8;min-height:300px}.editor-preview{background:var(--bg-surface);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.preview-header{display:flex;align-items:center;gap:6px;padding:12px 16px;font-size:12px;color:var(--text-secondary);font-weight:500;border-bottom:1px solid var(--border);flex-shrink:0}.mini-projection{background:#060810;flex-shrink:0;padding:24px 20px;text-align:center;min-height:160px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.mini-label{font-size:10px;color:#fff6;text-transform:uppercase;letter-spacing:1px}.mini-line{font-family:Lora,Georgia,serif;color:#fff;font-size:16px;line-height:1.5}.mini-empty{color:#fff3;font-size:13px;font-style:italic}.preview-slides{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px;padding:8px}.preview-slide-btn{text-align:left;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:all .12s;display:flex;flex-direction:column;gap:2px;border:1px solid transparent}.preview-slide-btn:hover{background:var(--bg-hover)}.preview-slide-btn.active{background:var(--bg-hover);border-color:var(--gold)}.slide-label-mini{font-size:10px;color:var(--gold);font-weight:600}.preview-slide-btn span:not(.slide-label-mini){font-size:12px;color:var(--text-secondary)}.setlists-view{display:flex;flex-direction:column;height:100%}.new-setlist-form{display:flex;gap:8px;padding:12px 24px;border-bottom:1px solid var(--border)}.new-setlist-form input{flex:1}.setlists-body{display:grid;grid-template-columns:280px 1fr;flex:1;overflow:hidden}@media(max-width:900px){.setlists-body{grid-template-columns:1fr;grid-template-rows:1fr 1.5fr}.setlists-list{border-right:none;border-bottom:1px solid var(--border)}}.setlists-list{overflow-y:auto;border-right:1px solid var(--border);padding:8px;display:flex;flex-direction:column;gap:4px}.setlist-card{display:flex;align-items:center;justify-content:space-between;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:12px;cursor:pointer;transition:all .12s}.setlist-card:hover{background:var(--bg-hover)}.setlist-card.selected{border-color:var(--gold)}.setlist-card-info{flex:1;min-width:0}.setlist-name{font-weight:500;font-size:13px;margin-bottom:4px}.setlist-meta{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted)}.setlist-editor{padding:16px 24px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.setlist-editor h3{font-family:var(--font-display);font-size:18px}.setlist-editor h4{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.setlist-songs-section,.setlist-add-section{display:flex;flex-direction:column;gap:4px}.setlist-song-item{display:flex;align-items:center;gap:8px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px;cursor:pointer;transition:all .12s}.setlist-song-item:hover{background:var(--bg-hover);border-color:var(--border-light)}.setlist-song-item.active{border-color:var(--gold);box-shadow:0 0 10px var(--gold-glow)}.drag-handle{color:var(--text-muted);cursor:grab;flex-shrink:0;padding:4px}.drag-handle:active{cursor:grabbing}.setlist-song-info{flex:1;min-width:0;display:flex;flex-direction:column}.setlist-song-name{font-size:13px;font-weight:500;color:var(--text-primary)}.setlist-song-artist{font-size:11px;color:var(--text-muted)}.empty-hint{font-size:12px;color:var(--text-muted);font-style:italic}.add-songs-list{display:flex;flex-direction:column;gap:2px;max-height:300px;overflow-y:auto}.add-song-btn{display:flex;align-items:center;gap:6px;text-align:left;padding:8px 10px;border-radius:var(--radius-sm);font-size:12px;color:var(--text-secondary);border:1px solid transparent;transition:all .12s}.add-song-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border)}.add-song-btn .dim{color:var(--text-muted)}.loading-hint{font-size:13px;color:var(--text-muted);padding:12px;font-style:italic}.badge{background:var(--gold-dim);color:var(--gold);padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600;text-transform:uppercase;vertical-align:middle;margin-left:8px;border:1px solid var(--gold)}.editor-header-row,.section-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.setlist-editor h3,.setlist-editor h4{margin:0}.search-box.sm{background:var(--bg-base);border-color:var(--border);padding:4px 10px;flex:0 1 200px}.search-box.sm input{font-size:12px}.clear-search{color:var(--text-muted);font-size:10px;padding:2px}.clear-search:hover{color:var(--text-primary)}.add-section-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.filters-row-compact{display:flex;gap:6px;margin-bottom:8px}.filter-select-sm{flex:1;font-size:11px;padding:4px 8px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary)}.add-songs-list.highlight{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-base);padding:4px}.add-song-btn-large{display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid transparent;transition:all .12s;background:transparent;margin-bottom:2px}.add-song-btn-large:hover{background:var(--bg-hover);border-color:var(--border-light)}.add-song-btn-main{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.add-song-btn-main .add-icon{color:var(--blue);opacity:.6}.add-song-btn-large:hover .add-icon{opacity:1}.song-info{display:flex;flex-direction:column;min-width:0}.song-info .title{font-size:13px;font-weight:500;color:var(--text-primary)}.song-info .artist{font-size:11px;color:var(--text-muted)}.song-key-sm{font-size:10px;font-weight:600;color:var(--gold);background:var(--gold-dim);padding:1px 6px;border-radius:99px}.settings-view{display:flex;flex-direction:column;height:100%}.settings-body{flex:1;overflow-y:auto;padding:16px 24px;display:flex;flex-direction:column;gap:24px}.settings-section{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:14px}.settings-section h2{font-size:15px;font-weight:600;display:flex;align-items:center;gap:10px;padding-bottom:12px;border-bottom:1px solid var(--border)}.settings-link{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:400;margin-left:auto}.settings-info{font-size:12px;color:var(--text-muted);background:var(--bg-base);border-radius:var(--radius-sm);padding:8px 12px;border-left:3px solid var(--blue)}.input-with-icon{display:flex;gap:6px;align-items:center}.input-with-icon input{flex:1}.color-input-row{display:flex;gap:8px;align-items:center}.color-input-row input[type=color]{width:40px;height:36px;padding:2px;cursor:pointer;flex-shrink:0}.color-input-row input[type=text]{flex:1}.checkboxes{justify-content:center}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;width:auto}.checkbox-label input[type=checkbox]{width:auto}.theme-preview{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);min-height:140px;display:flex;align-items:center;justify-content:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:600px;max-width:95vw;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 80px #0009}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:16px;font-weight:600;display:flex;align-items:center;gap:8px}.modal-body{padding:16px 20px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.search-error{font-size:13px;color:var(--red);padding:8px 0}.search-results{display:flex;flex-direction:column;gap:4px}.search-result-item{display:flex;align-items:center;gap:12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;transition:all .12s}.search-result-item:hover{background:var(--bg-hover)}.result-thumb{width:40px;height:40px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}.result-thumb-placeholder{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--bg-base);display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0}.result-info{flex:1;min-width:0}.result-title{font-weight:500;font-size:14px}.result-artist{font-size:12px;color:var(--text-secondary);display:flex;align-items:center;gap:6px}.result-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;background:var(--gold-dim);color:var(--gold);padding:1px 7px;border-radius:99px}.search-mode-toggle{display:flex;gap:4px;margin-bottom:4px}.mode-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 12px;font-size:12px;font-weight:500;border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);transition:all .15s;flex:1;justify-content:center}.mode-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.mode-btn.active{background:var(--gold-dim);border-color:var(--gold);color:var(--gold);font-weight:600}.lyrics-preview{display:flex;flex-direction:column;gap:8px}.lyrics-preview h3{font-size:16px;font-weight:600}.lyrics-preview .dim{font-size:13px;color:var(--text-muted)}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}.projection-root{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.projection-black{position:absolute;top:0;right:0;bottom:0;left:0;background:#000;opacity:0;pointer-events:none;transition:opacity .4s ease}.projection-black.visible{opacity:1}.projection-logo{display:flex;align-items:center;justify-content:center}.logo-placeholder{font-size:10rem;color:#ffffff26;animation:breathe 4s ease-in-out infinite}@keyframes breathe{0%,to{opacity:.15}50%{opacity:.3}}.projection-content{text-align:center;padding:60px;display:flex;flex-direction:column;align-items:center;gap:16px;animation:fadeIn .4s ease;max-width:1400px;margin:0 auto;width:100%}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.projection-song-title{font-size:1.4rem;text-transform:uppercase;letter-spacing:3px;font-weight:800;margin-bottom:12px}.projection-verse-label{font-size:1rem;text-transform:uppercase;letter-spacing:2px;font-weight:700}.projection-lines{display:flex;flex-direction:column;gap:.2em}.projection-line{white-space:pre-wrap}.projection-waiting{display:flex;align-items:center;justify-content:center}.projection-counter{position:absolute;bottom:20px;right:24px;font-size:.85rem;opacity:.25;font-family:monospace}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-surface)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:99px;border:2px solid var(--bg-surface)}::-webkit-scrollbar-thumb:hover{background:var(--gold-dim)}.dim{color:var(--text-muted)}.bible-view{display:flex;flex-direction:column;height:100%}.bible-body{display:grid;grid-template-columns:200px 1fr 260px;flex:1;overflow:hidden}@media(max-width:1100px){.bible-body{grid-template-columns:180px 1fr}.bible-preview{display:none}}@media(max-width:850px){.bible-body{display:flex;flex-direction:column}.bible-sidebar{height:180px;border-right:none;border-bottom:1px solid var(--border)}}.bible-sidebar{border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.book-search{padding:8px 12px;border-bottom:1px solid var(--border);flex-shrink:0;display:flex;flex-direction:column;gap:4px}.book-search-input{width:100%;padding:6px 8px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-primary);border-radius:var(--radius-sm);font-size:12px}.book-search-input:focus{outline:none;border-color:var(--gold)}.book-suggestion{display:flex;flex-direction:column;gap:2px}.suggestion-button{text-align:left;padding:6px 8px;border-radius:var(--radius-sm);font-size:12px;color:var(--gold);background:var(--bg-hover);border:1px solid var(--gold-dim);transition:all .1s}.suggestion-button:hover{background:var(--gold-dim)}.testament-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}.testament-tab{flex:1;padding:8px 4px;font-size:12px;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;transition:all .12s}.testament-tab.active{color:var(--gold);border-bottom-color:var(--gold)}.testament-tab:hover{color:var(--text-primary)}.books-list{flex:1;overflow-y:auto;padding:4px;display:flex;flex-direction:column;gap:1px}.book-item{text-align:left;padding:7px 10px;border-radius:var(--radius-sm);font-size:12px;color:var(--text-secondary);transition:all .1s;border:1px solid transparent}.book-item:hover{background:var(--bg-hover);color:var(--text-primary)}.book-item.active{background:var(--bg-hover);color:var(--gold);border-color:var(--gold-dim)}.bible-main{display:flex;flex-direction:column;overflow:hidden;border-right:1px solid var(--border)}.chapter-nav{display:flex;align-items:center;gap:8px;justify-content:center;padding:10px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.chapter-title{font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px}.chapter-select{width:auto;padding:4px 6px;font-size:14px;font-weight:600;background:var(--bg-elevated);border-color:var(--border)}.bible-search{display:flex;gap:6px;padding:8px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.bible-search .search-box{flex:1}.bible-loading{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.verses-list{flex:1;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:2px}.verse-item{display:flex;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;border-left:3px solid transparent;transition:all .1s}.verse-item:hover{background:var(--bg-hover)}.verse-item.projected{background:#ffd70014;border-left-color:var(--gold)}.verse-number{font-size:11px;font-weight:700;color:var(--gold);min-width:20px;padding-top:2px;flex-shrink:0}.verse-text-body{flex:1;font-size:13px;line-height:1.6;color:var(--text-primary)}.search-results-bible{border-bottom:1px solid var(--border);max-height:250px;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:6px;flex-shrink:0}.search-results-header{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--text-muted);font-weight:500}.search-results-scroll{display:flex;flex-direction:column;gap:6px}.verse-result{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px;display:flex;flex-direction:column;gap:4px;border-left:3px solid transparent;transition:all .1s;cursor:pointer}.verse-result:hover{border-color:var(--gold-dim);background:var(--bg-hover)}.verse-result.projected{background:#ffd70014;border-left-color:var(--gold);border-color:var(--gold-dim)}.verse-reference{font-size:11px;font-weight:700;color:var(--gold)}.verse-text{font-size:12px;color:var(--text-primary);line-height:1.5}.btn-ghost.small{padding:4px 8px;font-size:11px;align-self:flex-start}.bible-preview{display:flex;flex-direction:column;gap:0;overflow:hidden}.bible-projection-preview{flex:1;padding:20px 16px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;min-height:180px}.bible-preview-reference{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;font-weight:800}.bible-preview-text{font-size:15px;line-height:1.6}.bible-preview-empty{font-size:12px;color:#ffffff26;font-style:italic}.bible-hint{padding:10px 14px;font-size:11px;color:var(--text-muted);line-height:1.6;border-top:1px solid var(--border)}.library-grid{display:grid;grid-template-columns:320px 1fr;flex:1;overflow:hidden}@media(max-width:900px){.library-grid{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.library-sidebar-list{border-right:none;border-bottom:1px solid var(--border)}}.library-sidebar-list{border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--bg-base)}.library-filters-compact{padding:12px;border-bottom:1px solid var(--border)}.song-list-scroll{flex:1;overflow-y:auto;padding:6px}.song-card-compact{padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:all .1s;border:1px solid transparent;margin-bottom:2px}.song-card-compact:hover{background:var(--bg-hover)}.song-card-compact.active{background:var(--bg-hover);border-color:var(--gold-dim)}.song-card-title{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-card-artist{font-size:11px;color:var(--text-muted)}.library-preview-pane{background:var(--bg-surface);display:flex;flex-direction:column;overflow:hidden}.live-selection-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-muted)}.live-selection{display:flex;flex-direction:column;height:100%}.live-selection-header{padding:16px 24px;border-bottom:1px solid var(--border);background:var(--bg-base);display:flex;justify-content:space-between;align-items:center}.live-selection-header h2{font-family:var(--font-display);font-size:20px;color:var(--gold)}.live-meta{font-size:11px;color:var(--text-muted)}.live-slides-grid{display:flex;flex-direction:column;gap:8px;padding:16px;overflow-y:auto;background:#090c12;flex:1}.live-slide-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:24px 20px 16px;text-align:left;position:relative;min-height:60px;height:auto;flex-shrink:0;display:flex;flex-direction:column;transition:all .1s ease-out;cursor:pointer}.live-slide-card:hover{border-color:var(--gold-dim);background:var(--bg-hover)}.live-slide-card.active{background:#1a1f2e;border-color:var(--gold);border-left:4px solid var(--gold)}.live-slide-number{position:absolute;top:6px;left:8px;font-size:9px;color:var(--text-muted);font-weight:700}.live-slide-label{position:absolute;top:6px;right:10px;font-size:9px;text-transform:uppercase;color:var(--gold);font-weight:700;letter-spacing:1px}.live-slide-line{font-family:Lora,serif;font-size:15px;line-height:1.4;color:var(--text-primary)}.live-slide-card.active .live-slide-line{color:#fff;font-weight:500}.live-controls-footer{padding:12px 24px;background:var(--bg-base);border-top:1px solid var(--border);display:flex;gap:8px}.control-panel.compact-sidebar{padding:12px;gap:12px}.control-panel.compact-sidebar .control-nav{grid-template-columns:1fr}.control-panel.compact-sidebar .btn-nav{padding:12px;font-size:14px}.btn-icon-xs{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.btn-icon-xs:hover{background:var(--bg-hover);color:var(--text-primary)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}.mockup-container,.floating-card,.pulse-dot,.spin-dot,.spin{animation:none}}.privacy-selector-group{margin-top:10px;background:#ffffff08;padding:12px;border-radius:var(--radius);border:1px solid var(--border)}.privacy-label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.privacy-buttons{display:flex;gap:8px}.privacy-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.privacy-btn:hover{background:var(--bg-elevated);border-color:#fff3}.privacy-btn.active.public{background:#3b82f61a;border-color:#3b82f6;color:#60a5fa;box-shadow:0 0 15px #3b82f626}.privacy-btn.active.private{background:#8b5cf61a;border-color:#8b5cf6;color:#a78bfa;box-shadow:0 0 15px #8b5cf626}.privacy-hint{font-size:11px;color:var(--text-muted);margin-top:8px;font-style:italic}.song-card-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.status-icon-verified{color:#60a5fa;filter:drop-shadow(0 0 4px rgba(59,130,246,.3))}.status-icon-pending{color:#fbbf24;filter:drop-shadow(0 0 4px rgba(245,158,11,.3))}.status-icon-private{color:var(--text-muted);opacity:.6}.moderation-tab-selector{display:flex;margin:10px 12px;padding:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);gap:4px}.tab-btn{flex:1;padding:8px;border:none;background:transparent;color:var(--text-muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-radius:4px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px}.tab-btn:hover{background:#ffffff08}.tab-btn.active{background:var(--bg-elevated);box-shadow:var(--shadow-sm);color:var(--text-primary);border:1px solid var(--border)}.btn-icon-xs.danger:hover{background:#e055551a;color:var(--red);border-color:var(--red-dim)}.notifier{width:6px;height:6px;background:#f59e0b;border-radius:50%;display:inline-block;box-shadow:0 0 8px #f59e0b}.notes-view{display:flex;flex-direction:column;height:100%}.notes-body{flex:1;overflow-y:auto;padding:16px 24px;display:flex;flex-direction:column;gap:16px}.notes-section{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:12px}.notes-section-header{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.attendance-row{display:flex;gap:8px;align-items:flex-start;flex-wrap:wrap}.attendance-row input{flex:1;min-width:120px}.attendance-service-row{display:flex;flex-direction:column;gap:4px}.attendance-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}@media(max-width:600px){.attendance-grid{grid-template-columns:repeat(2,1fr)}}.attendance-field{display:flex;flex-direction:column;gap:4px}.attendance-field-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.attendance-total-row{display:flex;align-items:center;gap:10px;padding-top:8px;border-top:1px solid var(--border)}.attendance-total-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.attendance-total-value{font-size:20px;font-weight:700;color:var(--gold);font-variant-numeric:tabular-nums}.attendance-chart{display:flex;flex-direction:column;gap:16px}.chart-bars-row{display:flex;align-items:flex-end;gap:8px;height:140px;overflow-x:auto;padding-bottom:2px}.chart-col{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;width:44px;height:100%}.chart-value{font-size:10px;color:var(--text-muted);font-variant-numeric:tabular-nums;flex-shrink:0}.chart-bar-wrap{flex:1;width:100%;display:flex;align-items:flex-end}.chart-bar{width:100%;display:flex;flex-direction:column;border-radius:3px 3px 0 0;overflow:hidden;min-height:4px;transition:height .3s ease}.chart-bar-segment{width:100%;flex-shrink:0}.chart-label{font-size:9px;color:var(--text-muted);text-align:center;white-space:nowrap;flex-shrink:0}.chart-legend{display:flex;gap:12px;flex-wrap:wrap;font-size:11px;color:var(--text-secondary)}.chart-legend span{display:flex;align-items:center;gap:4px}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.chart-table{display:flex;flex-direction:column;gap:2px;font-size:12px}.chart-table-header{display:grid;grid-template-columns:1fr repeat(5,52px);gap:4px;padding:6px 8px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--border)}.chart-table-row{display:grid;grid-template-columns:1fr repeat(5,52px);gap:4px;padding:6px 8px;border-radius:var(--radius-sm);transition:background .1s}.chart-table-row:hover{background:var(--bg-hover)}.chart-table-header span,.chart-table-row span{text-align:right}.chart-table-header span:first-child,.chart-table-row span:first-child{text-align:left;color:var(--text-secondary)}.chart-table-total{font-weight:700;color:var(--gold)!important}.notice-list{display:flex;flex-direction:column;gap:4px;list-style:none;padding:0;margin:0}.notice-item{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color .15s}.notice-item--projected{border-color:var(--gold);background:#d4a8430f}.notice-project-active{color:var(--gold)!important}.notice-text{flex:1;font-size:13px;line-height:1.5;margin:0;word-break:break-word}.notice-actions{display:flex;gap:2px;flex-shrink:0}.notice-form{display:flex;flex-direction:column;gap:8px;padding:10px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm)}.notice-form-actions{display:flex;gap:6px;justify-content:flex-end}.field-error{font-size:12px;color:var(--red);margin-top:2px}.date-today-badge{font-size:10px;font-weight:600;color:var(--gold);background:#d4a8431f;padding:2px 8px;border-radius:99px;border:1px solid rgba(212,168,67,.3)}.sync-error-toast{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#ef44441a;border:1px solid var(--red);border-radius:var(--radius-sm);font-size:12px;color:var(--red);margin:0 24px 16px}.sync-ok-toast{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#4caf7d1f;border:1px solid var(--green);border-radius:var(--radius-sm);font-size:12px;color:var(--green);margin:0 24px 16px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.feedback-modal{width:480px}.feedback-success{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 0;text-align:center}.feedback-success p{font-size:18px;font-weight:600;color:var(--text-primary)}.feedback-success span{font-size:13px;color:var(--text-secondary)}.btn-feedback-trigger{display:flex;align-items:center;gap:6px;padding:7px 12px;border-radius:var(--radius-sm);background:#d4a84314;border:1px solid rgba(212,168,67,.2);color:var(--gold);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;width:100%}.btn-feedback-trigger:hover{background:#d4a84326;border-color:var(--gold)}
