:root{--bg:#0b0c10;--panel-bg:#161a26bf;--panel-border:#ffffff12;--text:#f1f3f9;--text-muted:#9aa2b5;--primary:#38bdf8;--primary-glow:#38bdf826;--accent:#fbbf24;--accent-glow:#fbbf2433;--danger:#ef4444;--success:#10b981;--font-sans:"Outfit", "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;--shadow:0 8px 32px #0000005e;--fast:.18s cubic-bezier(.4,0,.2,1);--normal:.3s cubic-bezier(.4,0,.2,1);--song-font-size:18px;--song-line-spacing:1.8;--header-h:56px;--sidebar-w:220px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;touch-action:manipulation;min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff40}.app-container{flex-direction:column;min-height:100vh;display:flex}.glass-header{height:var(--header-h);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--panel-border);z-index:200;background:#0b0c10eb;justify-content:space-between;align-items:center;gap:.5rem;padding:0 1rem;display:flex;position:sticky;top:0}.brand{letter-spacing:-.5px;background:linear-gradient(135deg, var(--primary) 0%, #a5f3fc 100%);-webkit-text-fill-color:transparent;cursor:pointer;-webkit-background-clip:text;background-clip:text;flex-shrink:0;align-items:center;gap:.4rem;font-size:1.25rem;font-weight:800;display:flex}.header-actions{flex-wrap:nowrap;align-items:center;gap:.5rem;display:flex}.header-user-info{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:180px;font-size:.78rem;overflow:hidden}.main-content{flex:1;width:100%;max-width:1320px;margin:0 auto;padding:1rem}.btn{font-family:var(--font-sans);cursor:pointer;transition:var(--fast);white-space:nowrap;-webkit-tap-highlight-color:transparent;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background:linear-gradient(135deg, #0284c7 0%, var(--primary) 100%);color:#040815;box-shadow:0 4px 12px #38bdf833}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 18px #38bdf859}.btn-primary:active{transform:translateY(0)}.btn-secondary{border:1px solid var(--panel-border);color:var(--text);background:#ffffff0f}.btn-secondary:hover{background:#ffffff1f}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{opacity:.88}.btn-ghost{color:var(--text-muted);background:0 0;border:1px solid #0000;border-radius:6px;padding:.4rem}.btn-ghost:hover{color:var(--text);background:#ffffff14}.btn-danger-ghost{color:var(--danger);opacity:.7;background:0 0;border:1px solid #0000;border-radius:6px;padding:.4rem}.btn-danger-ghost:hover{opacity:1;background:#ef44441a}.btn-icon{width:34px;height:34px;padding:.45rem}.btn-lg{padding:.65rem 1.5rem;font-size:1rem}.btn-google{color:#333;cursor:pointer;transition:var(--fast);white-space:nowrap;background:#fff;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.45rem 1rem;font-size:.875rem;font-weight:600;display:inline-flex}.btn-google:hover{background:#f1f3f4;box-shadow:0 2px 8px #0003}.btn-section{color:var(--primary);cursor:pointer;transition:var(--fast);font-size:.75rem;font-weight:700;font-family:var(--font-sans);letter-spacing:.5px;background:#38bdf814;border:1px solid #38bdf833;border-radius:6px;padding:.3rem .6rem}.btn-section:hover{background:#38bdf82e}.key-badge{background:var(--accent-glow);color:var(--accent);border:1px solid #fbbf2433;border-radius:6px;padding:.18rem .5rem;font-size:.75rem;font-weight:700}.church-badge{color:var(--primary);text-overflow:ellipsis;white-space:nowrap;background:#38bdf81a;border:1px solid #38bdf840;border-radius:6px;max-width:120px;padding:.18rem .45rem;font-size:.72rem;font-weight:700;overflow:hidden}.global-badge{color:var(--success);background:#10b98114;border:1px solid #10b98133;border-radius:6px;padding:.18rem .45rem;font-size:.72rem;font-weight:700}.role-badge{letter-spacing:.3px;white-space:nowrap;border-radius:6px;padding:.15rem .5rem;font-size:.7rem;font-weight:700}.role-badge.super{color:var(--accent);background:#fbbf241f;border:1px solid #fbbf244d}.role-badge.admin{color:var(--primary);background:#38bdf81a;border:1px solid #38bdf840}.role-badge.user{color:var(--success);background:#10b98114;border:1px solid #10b98133}.glass-panel{background:var(--panel-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--panel-border);box-shadow:var(--shadow);border-radius:16px;margin-bottom:1.25rem;padding:1.25rem}.search-wrapper{flex-wrap:wrap;gap:.75rem;margin-bottom:1.25rem;display:flex}.search-input{border:1px solid var(--panel-border);min-width:0;color:var(--text);font-family:var(--font-sans);transition:var(--fast);background:#ffffff0a;border-radius:10px;flex:1;padding:.65rem .9rem;font-size:.95rem}.search-input:focus{border-color:var(--primary);background:#ffffff14;outline:none}.search-input::placeholder{color:var(--text-muted)}.select-dropdown{color:var(--text);border:1px solid var(--panel-border);font-family:var(--font-sans);cursor:pointer;background:#ffffff0d;border-radius:8px;height:38px;padding:.4rem .75rem;font-size:.875rem;font-weight:600}.select-dropdown:focus{border-color:var(--primary);outline:none}.song-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;margin-top:1rem;display:grid}.song-card{cursor:pointer;transition:var(--normal);-webkit-tap-highlight-color:transparent;background:#ffffff06;border:1px solid #ffffff0f;border-radius:12px;flex-direction:column;justify-content:space-between;min-height:105px;padding:1.1rem;display:flex}.song-card:hover{background:#ffffff0d;border-color:#38bdf84d;transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.song-card h3{color:var(--text);font-size:1rem;font-weight:600;line-height:1.3}.song-viewer-container{max-width:800px;transition:max-width var(--normal);margin:0 auto;overflow-x:hidden}.song-viewer-container.widescreen{max-width:100%}.song-viewer{font-size:var(--song-font-size);line-height:var(--song-line-spacing);-webkit-user-select:text;user-select:text;word-break:break-word;overflow-x:hidden}.song-sections-wrapper.multi-col{column-rule:1px solid var(--panel-border);column-gap:3rem}.song-section-container{break-inside:avoid-column;-webkit-column-break-inside:avoid;width:100%;margin-bottom:1.5rem;display:inline-block}.song-section-header{color:var(--primary);letter-spacing:1px;text-transform:uppercase;border-bottom:1px solid #38bdf826;margin-top:1.8em;margin-bottom:.5em;padding-bottom:.2rem;font-size:.8em;font-weight:700;display:block}.song-line{clear:both;margin-bottom:.4em;display:block}.chord-segment{white-space:pre;margin-top:1.1em;display:inline-block;position:relative}.chord{font-family:var(--font-mono);color:var(--accent);-webkit-user-select:none;user-select:none;pointer-events:none;background:var(--bg);text-shadow:0 0 5px var(--bg);white-space:nowrap;border-radius:3px;padding:0 1px;font-size:.82em;font-weight:800;position:absolute;top:-1.25em;left:0}.lyrics-text{font-family:var(--font-sans);color:var(--text)}.song-meta-line{color:var(--text-muted);margin-bottom:.5em;font-size:.88em;font-style:italic}.youtube-link{color:var(--primary);word-break:break-all;border-bottom:1px dotted #38bdf880;text-decoration:none}.youtube-link:hover{color:#a5f3fc}.controls-bar{-webkit-backdrop-filter:blur(14px);border:1px solid var(--panel-border);top:var(--header-h);z-index:90;-webkit-overflow-scrolling:touch;scrollbar-width:none;background:#0e111ceb;border-radius:12px;flex-wrap:nowrap;align-items:center;gap:.4rem;margin-bottom:1.25rem;padding:.55rem .85rem;display:flex;position:sticky;overflow-x:auto;box-shadow:0 4px 20px #0000004d}.controls-bar::-webkit-scrollbar{display:none}.controls-divider{background:var(--panel-border);flex-shrink:0;width:1px;height:22px}.control-group{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.control-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;font-size:.75rem;font-weight:600}.transpose-box{border:1px solid var(--panel-border);background:#ffffff0d;border-radius:8px;align-items:center;height:34px;display:flex;overflow:hidden}.transpose-btn{color:var(--text);cursor:pointer;width:32px;height:34px;transition:var(--fast);-webkit-tap-highlight-color:transparent;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.transpose-btn:hover{background:#ffffff1a}.transpose-value{text-align:center;min-width:36px;color:var(--primary);padding:0 4px;font-size:.9rem;font-weight:700}.slider-container{background:#ffffff05;border:1px solid #ffffff0a;border-radius:8px;align-items:center;gap:.4rem;height:34px;padding:.28rem .55rem;display:flex}.slider-container input[type=range]{-webkit-appearance:none;background:#ffffff1a;border-radius:2px;outline:none;width:80px;height:4px}.slider-container input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--primary);cursor:pointer;border-radius:50%;width:15px;height:15px}.fullscreen-active{background:var(--bg);z-index:1000!important;padding:1.5rem!important}.fullscreen-active .glass-header{display:none!important}.admin-layout{grid-template-columns:var(--sidebar-w) 1fr;min-height:calc(100vh - var(--header-h) - 2rem);align-items:start;gap:1.5rem;display:grid}.admin-sidebar{top:calc(var(--header-h) + 1rem);-webkit-backdrop-filter:blur(12px);border:1px solid var(--panel-border);background:#101420b3;border-radius:14px;flex-direction:column;gap:.25rem;padding:1rem .75rem;display:flex;position:sticky}.sidebar-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-top:.25rem;padding:.25rem .5rem;font-size:.68rem;font-weight:700}.sidebar-nav{flex-direction:column;gap:.2rem;display:flex}.sidebar-nav-item{color:var(--text-muted);font-family:var(--font-sans);cursor:pointer;transition:var(--fast);text-align:left;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:8px;align-items:center;gap:.6rem;width:100%;padding:.6rem .75rem;font-size:.875rem;font-weight:500;display:flex}.sidebar-nav-item:hover{color:var(--text);background:#ffffff12}.sidebar-nav-item.active{background:var(--primary-glow);color:var(--primary);font-weight:600}.sidebar-nav-item.cta{color:var(--primary);background:linear-gradient(135deg,#0284c740 0%,#38bdf826 100%);border:1px solid #38bdf840;margin:.25rem 0;font-weight:700}.sidebar-nav-item.cta:hover{background:linear-gradient(135deg,#0284c766 0%,#38bdf84d 100%)}.sidebar-nav-item.cta.active{background:linear-gradient(135deg, #0284c7, var(--primary));color:#040815}.sidebar-divider{background:var(--panel-border);height:1px;margin:.4rem 0}.sidebar-user-card{border:1px solid var(--panel-border);background:#ffffff08;border-radius:8px;margin-top:auto;padding:.75rem}.admin-main{min-width:0}.admin-page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.admin-page-title{font-size:1.5rem;font-weight:800;line-height:1.1}.admin-page-subtitle{color:var(--text-muted);margin-top:.25rem;font-size:.85rem}.songs-list{flex-direction:column;gap:.5rem;display:flex}.song-list-item{transition:var(--fast);background:#ffffff06;border:1px solid #ffffff0d;border-radius:10px;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem 1rem;display:flex}.song-list-item:hover{background:#ffffff0d;border-color:#38bdf833}.song-list-info{flex:1;min-width:0}.song-list-title{white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;overflow:hidden}.song-list-meta{flex-wrap:wrap;align-items:center;gap:.4rem;margin-top:.3rem;display:flex}.song-list-actions{flex-shrink:0;align-items:center;gap:.3rem;display:flex}.empty-state{text-align:center;color:var(--text-muted);padding:4rem 2rem}.empty-state svg{opacity:.4;margin-bottom:1rem}.empty-state h3{color:var(--text);margin-bottom:.4rem;font-size:1.2rem}.list-container{border:1px solid var(--panel-border);border-radius:12px;overflow:hidden}.list-item{background:#ffffff03;border-bottom:1px solid #ffffff08;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:.85rem 1rem;display:flex}.list-item:last-child{border-bottom:none}.wizard-steps{border:1px solid var(--panel-border);background:#ffffff05;border-radius:12px;align-items:center;margin-bottom:1.5rem;padding:1rem 1.5rem;display:flex;overflow-x:auto}.wizard-step{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.wizard-step-dot{border:2px solid var(--panel-border);width:28px;height:28px;color:var(--text-muted);transition:var(--fast);background:#ffffff12;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.82rem;font-weight:700;display:flex}.wizard-step.active .wizard-step-dot{background:var(--primary-glow);border-color:var(--primary);color:var(--primary)}.wizard-step.done .wizard-step-dot{border-color:var(--success);color:var(--success);background:#10b98126}.wizard-step-label{color:var(--text-muted);white-space:nowrap;font-size:.82rem;font-weight:600}.wizard-step.active .wizard-step-label{color:var(--primary)}.wizard-step.done .wizard-step-label{color:var(--success)}.wizard-step-line{background:var(--panel-border);flex-shrink:0;width:40px;height:2px;margin:0 .5rem}.editor-step-card{background:var(--panel-bg);border:1px solid var(--panel-border);box-shadow:var(--shadow);border-radius:16px;padding:1.5rem}.step-card-title{flex-wrap:wrap;align-items:center;gap:.6rem;margin-bottom:1.25rem;font-size:1.1rem;font-weight:700;display:flex}.step-number{background:var(--primary-glow);border:2px solid var(--primary);width:26px;height:26px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:800;display:inline-flex}.step-subtitle{color:var(--text-muted);font-size:.85rem;font-weight:400}.form-group{flex-direction:column;gap:.35rem;margin-bottom:.75rem;display:flex}.form-group label,.form-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.78rem;font-weight:600}.form-input{border:1px solid var(--panel-border);color:var(--text);font-family:var(--font-sans);transition:var(--fast);background:#ffffff0a;border-radius:9px;width:100%;padding:.65rem .85rem;font-size:.95rem}.form-input:focus{border-color:var(--primary);background:#ffffff12;outline:none}.form-input::placeholder{color:var(--text-muted)}.form-select{border:1px solid var(--panel-border);color:var(--text);font-family:var(--font-sans);cursor:pointer;background:#ffffff0d;border-radius:9px;width:100%;height:42px;padding:.6rem .85rem;font-size:.9rem;font-weight:600}.form-select:focus{border-color:var(--primary);outline:none}.form-row-3{grid-template-columns:2fr 1fr 1fr;gap:.75rem;margin-bottom:1rem;display:grid}.dropzone{text-align:center;cursor:pointer;transition:var(--normal);-webkit-tap-highlight-color:transparent;background:#ffffff03;border:2px dashed #ffffff24;border-radius:12px;flex-direction:column;align-items:center;gap:.6rem;padding:2rem 1.25rem;display:flex}.dropzone:hover{border-color:var(--primary);background:#38bdf808}.dropzone p{color:var(--text-muted);font-size:.88rem}.dropzone-icon{color:var(--text-muted);transition:var(--fast)}.dropzone:hover .dropzone-icon{color:var(--primary);transform:translateY(-3px)}.file-selected{color:var(--success);font-size:.85rem;font-weight:600}.info-tip{color:var(--text-muted);background:#38bdf80f;border:1px solid #38bdf82e;border-radius:9px;align-items:flex-start;gap:.6rem;margin-bottom:1.25rem;padding:.75rem .9rem;font-size:.85rem;line-height:1.5;display:flex}.info-tip svg{color:var(--primary);flex-shrink:0;margin-top:2px}.info-tip code{color:var(--accent);font-family:var(--font-mono);background:#fbbf241f;border-radius:4px;padding:0 4px;font-size:.82em}.error-banner{color:var(--danger);background:#ef44441a;border:1px solid #ef444440;border-radius:9px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem;display:flex}.chord-inserter{border:1px solid var(--panel-border);background:#0000004d;border-radius:12px;margin-bottom:.9rem;padding:.9rem}.chord-inserter-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.chord-inserter-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:700}.chord-custom-input{align-items:center;gap:.35rem;display:flex}.chord-custom-input input{border:1px solid var(--panel-border);color:var(--text);font-family:var(--font-sans);background:#ffffff0d;border-radius:6px;width:110px;padding:.3rem .6rem;font-size:.82rem}.chord-custom-input input:focus{border-color:var(--primary);outline:none}.chord-buttons-grid{flex-wrap:wrap;gap:.4rem;display:flex}.chord-insert-btn{font-family:var(--font-mono);color:var(--accent);cursor:pointer;transition:var(--fast);-webkit-tap-highlight-color:transparent;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:6px;padding:.3rem .65rem;font-size:.82rem;font-weight:700}.chord-insert-btn:hover{background:#fbbf2426;border-color:#fbbf2466;transform:translateY(-1px)}.chord-insert-btn.selected{border-color:var(--accent);background:#fbbf2433;box-shadow:0 0 8px #fbbf244d}.editor-split{grid-template-columns:1fr 1fr;gap:1rem;height:420px;display:grid}.editor-pane{border:1px solid var(--panel-border);border-radius:12px;flex-direction:column;display:flex;overflow:hidden}.editor-pane-header{border-bottom:1px solid var(--panel-border);color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;background:#ffffff08;flex-shrink:0;align-items:center;gap:.4rem;padding:.45rem .9rem;font-size:.75rem;font-weight:700;display:flex}.chord-textarea{color:var(--text);font-family:var(--font-mono);resize:none;tab-size:2;background:#06070a;border:none;outline:none;flex:1;width:100%;padding:1rem;font-size:.9rem;line-height:1.6}.chord-textarea::placeholder{color:var(--text-muted);opacity:.6}.preview-pane{background:#0d0f14;flex:1;padding:1rem;overflow-y:auto}.review-summary{border:1px solid var(--panel-border);background:#ffffff05;border-radius:12px;overflow:hidden}.review-row{border-bottom:1px solid #ffffff0a;align-items:center;gap:1rem;padding:.8rem 1rem;display:flex}.review-row:last-child{border-bottom:none}.review-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;width:70px;font-size:.78rem;font-weight:600}.review-value{font-size:.9rem;font-weight:600}.login-card{width:100%;max-width:420px;margin:4rem auto}.hide-mobile{display:none}@media (width>=640px){.hide-mobile{display:flex}.show-mobile-only{display:none}}@media (width<=639px){.main-content{padding:.75rem}h1{font-size:1.6rem!important}.song-grid{grid-template-columns:1fr;gap:.65rem}.song-sections-wrapper{column-count:1!important}.song-viewer-container{padding:1rem!important}.admin-layout{grid-template-columns:1fr;gap:.75rem}.admin-sidebar{border-radius:12px;flex-flow:wrap;gap:.35rem;padding:.6rem;position:static}.admin-sidebar .sidebar-section-label,.admin-sidebar .sidebar-divider,.admin-sidebar .sidebar-user-card{display:none}.sidebar-nav{flex-flow:wrap;gap:.3rem}.sidebar-nav-item{border-radius:8px;width:auto;padding:.4rem .7rem;font-size:.8rem}.sidebar-nav-item span{display:inline}.wizard-steps{gap:0;padding:.75rem}.wizard-step-line{width:20px}.editor-split{grid-template-columns:1fr;height:auto}.editor-pane{height:260px}.form-row-3{grid-template-columns:1fr}.controls-bar{top:var(--header-h);gap:.35rem;padding:.5rem .65rem}.login-card{margin:2rem auto}}@media (width>=640px) and (width<=1023px){.admin-layout{grid-template-columns:180px 1fr;gap:1rem}.form-row-3{grid-template-columns:1fr 1fr}.editor-split{height:360px}.song-sections-wrapper{column-count:1!important}}@media (width>=1024px){.main-content{padding:1.5rem}.glass-header{padding:0 1.5rem}}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:1s linear infinite spin}@keyframes fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.25s both fade-in}.step-pills{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.step-pill{border:1px solid var(--panel-border);color:var(--text-muted);font-family:var(--font-sans);cursor:pointer;transition:var(--fast);background:#ffffff08;border-radius:20px;align-items:center;gap:.4rem;padding:.4rem .9rem;font-size:.82rem;font-weight:600;display:flex}.step-pill.active{background:var(--primary-glow);border-color:var(--primary);color:var(--primary)}.step-pill.done{border-color:var(--success);color:var(--success);background:#10b9811a}.step-pill-dot{background:#ffffff14;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.72rem;font-weight:800;display:flex}.step-pill.active .step-pill-dot{background:var(--primary);color:#040815}.step-pill.done .step-pill-dot{background:var(--success);color:#040815}.wysiwyg-root{flex-direction:column;gap:.75rem;display:flex}.wysiwyg-toolbar{border:1px solid var(--panel-border);background:#ffffff05;border-radius:10px;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.55rem .85rem;display:flex}.wysiwyg-toolbar-left{flex-wrap:wrap;flex:1;align-items:center;gap:.4rem;display:flex}.wysiwyg-main{grid-template-columns:1fr;gap:1rem;display:grid}.wysiwyg-main.with-preview{grid-template-columns:1fr 1fr}.wysiwyg-sheet-wrap{overflow-x:auto}.wysiwyg-sheet{border:1px solid var(--panel-border);background:#ffffff05;border-radius:12px;min-height:280px;padding:1rem 1rem .75rem}.wysiwyg-blank-line{cursor:pointer;height:.7rem;transition:var(--fast);border-radius:4px}.wysiwyg-blank-line:hover{background:#ffffff08}.wysiwyg-header-row{align-items:center;gap:.5rem;margin:1rem 0 .35rem;padding:.2rem 0;display:flex}.wysiwyg-lyric-row{min-height:52px;margin-bottom:.15rem}.wysiwyg-edit-row{flex-wrap:wrap;align-items:center;gap:.4rem;padding:.35rem 0;display:flex}.wysiwyg-line-input{flex:1;min-width:180px;padding:.45rem .75rem!important;font-size:.95rem!important}.wysiwyg-chars-outer{align-items:flex-start;gap:.4rem;padding:.25rem 0;display:flex}.wysiwyg-chars-inner{flex-wrap:wrap;flex:1;align-items:flex-end;gap:0;padding-top:1.8em;display:flex}.wysiwyg-side-btns{flex-direction:column;flex-shrink:0;gap:.15rem;padding-top:1.5em;display:flex}.wysiwyg-edit-btn{border:1px solid var(--panel-border);color:var(--text-muted);cursor:pointer;width:24px;height:24px;transition:var(--fast);background:#ffffff0f;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;font-size:.82rem;display:flex}.wysiwyg-edit-btn:hover{color:var(--primary);background:#38bdf826}.wysiwyg-del-btn{color:var(--text-muted);cursor:pointer;width:24px;height:24px;transition:var(--fast);opacity:.5;background:0 0;border:1px solid #0000;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;display:flex}.wysiwyg-del-btn:hover{color:var(--danger);opacity:1;background:#ef44441f}.wysiwyg-empty-hint{color:var(--text-muted);cursor:pointer;border:1px dashed #ffffff1a;border-radius:4px;padding:.2rem .4rem;font-size:.82rem;font-style:italic}.wysiwyg-empty-hint:hover{border-color:var(--primary);color:var(--primary)}.wysiwyg-char-unit{cursor:pointer;-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:flex-start;min-width:12px;padding-top:0;display:inline-flex;position:relative}.wysiwyg-char-unit.has-chord .wysiwyg-char-glyph{color:var(--accent);-webkit-text-decoration:underline #fbbf244d;text-decoration:underline #fbbf244d}.wysiwyg-char-unit:hover .wysiwyg-char-glyph{color:var(--primary)}.wysiwyg-chord-pill{color:var(--accent);font-family:var(--font-mono);white-space:nowrap;cursor:pointer;z-index:10;transition:var(--fast);background:#fbbf2426;border:1px solid #fbbf2480;border-radius:5px;align-items:center;gap:2px;padding:0 5px;font-size:.72rem;font-weight:800;line-height:1.5;display:flex;position:absolute;bottom:calc(100% + 2px);left:0}.wysiwyg-chord-pill:hover{border-color:var(--danger);color:var(--danger);background:#ef444426}.chord-pill-x{opacity:.6;margin-left:1px;font-size:.65rem;line-height:1}.wysiwyg-char-glyph{font-family:var(--font-sans);-webkit-user-select:none;user-select:none;color:var(--text);transition:color var(--fast);font-size:1.05rem;line-height:1.4}.wysiwyg-add-line-btn{color:var(--text-muted);font-family:var(--font-sans);cursor:pointer;transition:var(--fast);background:0 0;border:1px dashed #ffffff1a;border-radius:6px;justify-content:center;align-items:center;gap:.35rem;width:100%;margin-top:.75rem;padding:.35rem .75rem;font-size:.8rem;display:flex}.wysiwyg-add-line-btn:hover{border-color:var(--primary);color:var(--primary)}.wysiwyg-preview-panel{flex-direction:column;display:flex}.chord-palette-dock{border:1px solid var(--panel-border);z-index:80;background:#0c0f16eb;border-radius:12px;position:sticky;bottom:.5rem;overflow:hidden;box-shadow:0 -4px 24px #0006}.palette-toggle{border:none;border-bottom:1px solid var(--panel-border);width:100%;color:var(--text);font-family:var(--font-sans);cursor:pointer;transition:var(--fast);background:#ffffff08;justify-content:space-between;align-items:center;padding:.6rem 1rem;font-size:.82rem;display:flex}.palette-toggle:hover{background:#ffffff0f}.palette-body{flex-direction:column;gap:.65rem;padding:.75rem;animation:.15s fade-in;display:flex}.palette-selected-label{color:var(--text-muted);padding:.2rem 0;font-size:.8rem}.palette-active-name{color:var(--accent);font-family:var(--font-mono);font-size:.95rem}.palette-grid{flex-wrap:wrap;gap:.4rem;display:flex}.palette-btn{font-family:var(--font-mono);min-width:46px;color:var(--accent);cursor:pointer;transition:var(--fast);text-align:center;-webkit-tap-highlight-color:transparent;background:#ffffff0d;border:1px solid #ffffff14;border-radius:7px;padding:.35rem .7rem;font-size:.82rem;font-weight:700}.palette-btn:hover{background:#fbbf241a;border-color:#fbbf2466;transform:translateY(-1px)}.palette-btn.active{background:var(--accent);color:#040815;border-color:var(--accent);transform:scale(1.05);box-shadow:0 0 12px #fbbf2466}.palette-custom-row{border-top:1px solid var(--panel-border);padding-top:.35rem}.custom-chord-inp{border:1px solid var(--panel-border);color:var(--text);font-family:var(--font-mono);background:#ffffff0d;border-radius:6px;outline:none;width:100px;padding:.3rem .6rem;font-size:.9rem}.custom-chord-inp:focus{border-color:var(--primary)}.mobile-fab{z-index:300;background:linear-gradient(135deg, #0284c7, var(--primary));color:#040815;cursor:pointer;width:60px;height:60px;transition:var(--fast);-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;justify-content:center;align-items:center;animation:.3s cubic-bezier(.175,.885,.32,1.275) fab-pop;display:flex;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 6px 24px #38bdf873,0 2px 8px #0006}.mobile-fab:hover,.mobile-fab:active{transform:scale(1.1);box-shadow:0 8px 32px #38bdf899}@keyframes fab-pop{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@media (width<=639px){.wysiwyg-char-unit{min-width:16px}.wysiwyg-char-glyph{align-items:center;min-width:12px;min-height:36px;font-size:1.15rem;display:flex}.chord-palette-dock{z-index:200;border-bottom:none;border-left:none;border-right:none;border-radius:16px 16px 0 0;max-height:55vh;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}.wysiwyg-root{padding-bottom:50vh}.wysiwyg-main.with-preview{grid-template-columns:1fr}.wysiwyg-toolbar{padding:.45rem}.palette-btn{min-width:52px;padding:.5rem .9rem;font-size:.9rem}.form-row-3{grid-template-columns:1fr}.admin-layout{grid-template-columns:1fr;gap:.75rem}.admin-sidebar{border-radius:10px;flex-flow:wrap;gap:.3rem;padding:.5rem;position:static}.admin-sidebar .sidebar-section-label,.admin-sidebar .sidebar-divider,.admin-sidebar .sidebar-user-card{display:none}.sidebar-nav{flex-flow:wrap;gap:.3rem}.sidebar-nav-item{border-radius:7px;width:auto;padding:.4rem .65rem;font-size:.78rem}}.song-viewer-content{line-height:var(--song-line-spacing,1.85);word-break:break-word;-webkit-overflow-scrolling:touch;overflow-x:hidden}.field-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:.35rem;font-size:.75rem;font-weight:600;display:block}.setlist-live{padding-bottom:calc(1.25rem + env(safe-area-inset-bottom))}body,.app-container{min-height:100dvh}.glass-header{height:calc(var(--header-h) + env(safe-area-inset-top));padding-top:env(safe-area-inset-top)}.controls-bar{top:calc(var(--header-h) + env(safe-area-inset-top))}.mobile-fab{bottom:calc(1.5rem + env(safe-area-inset-bottom))}*{-webkit-tap-highlight-color:transparent}.btn:active,.song-card:active,.sidebar-nav-item:active,.transpose-btn:active,.key-badge:active,.step-pill:active{transform:scale(.97)}.song-card,.preview-pane,.admin-main,.list-container,.controls-bar{-webkit-overflow-scrolling:touch}@media (pointer:coarse){.form-input,.search-input,.select-dropdown,textarea,input[type=text],input[type=email],input[type=url],input[type=date]{font-size:16px}.btn-icon{width:44px;height:44px}.transpose-btn{min-width:44px;height:44px}.transpose-box{height:44px}.select-dropdown{min-height:44px}.wysiwyg-edit-btn,.wysiwyg-del-btn{min-width:40px;min-height:40px}input[type=range]::-webkit-slider-thumb{width:24px;height:24px}input[type=range]::-moz-range-thumb{width:24px;height:24px}}@media (height<=480px) and (orientation:landscape){:root{--header-h:46px}.controls-bar{padding-top:.3rem;padding-bottom:.3rem}}.show-mobile-only{display:none}@media (width<=639px){.show-mobile-only{display:flex}}.chords-emphasized .chord{filter:brightness(1.15);font-size:1.18em;font-weight:800}.chords-hidden .chord-segment{margin-top:0}.song-section-container.is-current{box-shadow:inset 3px 0 0 var(--primary);background:#22d3ee14;border-radius:6px;transition:background .25s}
