@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%}body{color:#0a0a0a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;font-family:Inter,system-ui,-apple-system,sans-serif}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:#f5f5f5}::-webkit-scrollbar-thumb{background:#d0d0d0;border-radius:2px}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes verse-in{0%{opacity:0;transform:translateY(18px)scale(.985)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes dot-pulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}@keyframes mic-pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-in{animation:.35s forwards fade-up}.animate-verse{animation:.5s cubic-bezier(.22,1,.36,1) forwards verse-in}.dots{align-items:center;gap:3px;display:inline-flex}.dots span{background:#0a0a0a;border-radius:50%;width:4px;height:4px;animation:1.2s ease-in-out infinite dot-pulse}.dots span:nth-child(2){animation-delay:.15s}.dots span:nth-child(3){animation-delay:.3s}:root{--app-bg:#131218;--app-bg-alt:#1a1821;--panel-bg:#201e29f5;--panel-bg-soft:#252332;--panel-border:#ffffff14;--panel-border-strong:#ff914d61;--text-main:#f5f6fb;--text-muted:#a6a9b9;--text-faint:#72778a;--accent:#ff8b3d;--accent-soft:#ff8b3d26;--success:#39d98a;--warn:#ffc857;--danger:#ff6b6b;--shadow-panel:0 18px 48px #00000047}*{box-sizing:border-box}body{background:var(--app-bg);color:var(--text-main);margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input{font:inherit}.scripture-shell{min-height:100dvh;color:var(--text-main);background:radial-gradient(circle at 0 0,#ff8b3d17,#0000 24%),radial-gradient(circle at 100% 0,#6856ff14,#0000 30%),linear-gradient(#111015 0%,#17151d 100%);padding:16px}.scripture-topbar{border:1px solid var(--panel-border);box-shadow:var(--shadow-panel);background:#18161feb;border-radius:18px;justify-content:space-between;align-items:center;gap:16px;padding:12px 16px;display:flex}.topbar-brand{min-width:0}.brand-mark{letter-spacing:-.03em;font-size:24px;font-weight:800}.brand-subtitle{color:var(--text-muted);font-size:12px}.topbar-pills,.topbar-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.topbar-pill{border:1px solid var(--panel-border);min-height:36px;color:var(--text-muted);background:#ffffff0a;border-radius:999px;align-items:center;gap:8px;padding:0 12px;font-size:12px;font-weight:700;display:inline-flex}.session-pill{color:#ddd2c8}.pill-dot{background:var(--text-faint);border-radius:50%;width:8px;height:8px}.pill-dot.success{background:var(--success)}.pill-dot.warn{background:var(--warn)}.pill-dot.muted{background:var(--text-faint)}.topbar-button,.panel-button,.mic-toggle,.search-tab,.live-chip,.queue-item,.search-result,.context-candidate,.history-card,.clear-link,.version-btn{transition:background .18s,border-color .18s,color .18s,transform .18s}.topbar-button,.panel-button,.mic-toggle,.live-chip{border:1px solid var(--panel-border);color:var(--text-main);cursor:pointer;background:#ffffff0a;border-radius:12px}.topbar-button{min-height:38px;padding:0 14px;font-size:13px;font-weight:700}.topbar-button.primary,.panel-button.primary,.mic-toggle.live{color:#170f08;background:linear-gradient(135deg,#ff8b3d 0%,#ff6f2d 100%);border-color:#ff8b3d8c}.topbar-button:hover,.panel-button:hover,.mic-toggle:hover,.live-chip:hover,.search-tab:hover,.queue-item:hover,.search-result:hover,.context-candidate:hover,.history-card:hover{transform:translateY(-1px)}.app-banner{color:#ffd0d0;background:#ff6b6b14;border:1px solid #ff6b6b47;border-radius:14px;margin-top:16px;padding:14px 16px;font-size:14px}.scripture-grid{grid-template-columns:.95fr 1.45fr 1.45fr 1fr;grid-template-areas:"transcript preview live queue""custom search search recent""songs songs songs recent";gap:16px;margin-top:16px;display:grid}.app-panel{border:1px solid var(--panel-border);background:var(--panel-bg);min-height:0;box-shadow:var(--shadow-panel);border-radius:20px;flex-direction:column;display:flex;overflow:hidden}.transcript-panel{grid-area:transcript;height:480px}.preview-panel{grid-area:preview;height:480px}.live-panel{grid-area:live;height:480px}.queue-panel{grid-area:queue;height:480px}.custom-panel{grid-area:custom;height:400px}.songs-panel{grid-area:songs;height:400px}.search-panel{grid-area:search;height:400px}.recent-panel{grid-area:recent;height:816px}.panel-header{border-bottom:1px solid var(--panel-border);justify-content:space-between;align-items:flex-start;gap:12px;padding:16px 18px;display:flex}.panel-title{color:#f8f4ef;font-size:14px;font-weight:800}.panel-subtitle,.panel-header-meta{color:var(--text-muted);font-size:12px}.output-screen-status{color:#c4cad8;align-items:center;gap:7px;margin-top:6px;font-size:12px;font-weight:700;display:inline-flex}.panel-header-actions{align-items:center;gap:10px;display:flex}.result-badge{color:#ffcaa6;text-transform:uppercase;letter-spacing:.08em;background:#ff8b3d29;border-radius:999px;justify-content:center;align-items:center;min-width:64px;padding:6px 10px;font-size:11px;font-weight:800;display:inline-flex}.result-badge.subtle{min-width:0;color:var(--text-muted);background:#ffffff0f}.transcript-content{color:#efedf6;white-space:pre-line;flex:1;padding:18px;font-size:14px;line-height:1.75;overflow-y:auto}.transcript-interim-text{color:#8d93a7}.empty-copy,.search-empty,.stage-empty{color:var(--text-muted);font-size:13px;line-height:1.7}.transcript-footer{flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:12px;padding:16px 18px 18px;display:flex}.mic-toggle{min-height:40px;padding:0 14px;font-size:13px;font-weight:800}.mic-toggle.secondary{color:var(--text-main);border-color:var(--panel-border-strong);background:#ffffff13}.save-transcript-toggle.saving{color:#10130d;background:linear-gradient(135deg,#39d98a 0%,#20c671 100%);border-color:#39d98a73}.verse-stage-card,.live-display-card{background:radial-gradient(circle at 80% 20%,#437dff52,#0000 20%),radial-gradient(circle at 70% 70%,#20b9ff33,#0000 24%),linear-gradient(135deg,#0f1220 0%,#14192b 100%);border:1px solid #ffffff14;border-radius:18px;flex-direction:column;flex:1;justify-content:center;gap:14px;margin:16px 18px;padding:22px;display:flex;overflow-y:auto}.preview-panel .verse-stage-card{gap:10px;margin:10px 14px;padding:14px}.preview-panel .stage-reference{font-size:11px}.preview-panel .stage-text{font-size:clamp(17px,1.55vw,23px);line-height:1.42}.live-panel-body{flex-direction:column;flex:1;gap:12px;min-height:0;padding:14px 18px 18px;display:flex}.live-panel-body .live-display-card{margin:0}.live-display-card.compact{flex:0 0 150px;min-height:150px;padding:18px}.stage-reference,.live-reference{color:#f0c287;text-align:center;font-size:12px;font-weight:800}.stage-text,.live-text{color:#fff;text-align:center;line-height:1.6}.stage-text{white-space:pre-line;font-size:clamp(20px,2vw,28px);font-weight:700}.live-text{white-space:pre-line;font-size:clamp(18px,1.65vw,24px);font-weight:700}.stage-note,.live-version{color:#9ea6bd;text-align:center;font-size:12px}.custom-live-preview{overflow-wrap:anywhere;width:100%;max-height:none;font-size:clamp(22px,2vw,34px);font-weight:650;line-height:1.45;overflow:visible}.custom-stage-preview{max-height:100%;font-size:clamp(18px,1.75vw,28px);font-weight:650;line-height:1.36;overflow-y:auto}.custom-stage-preview p,.custom-live-preview p,.custom-stage-preview div,.custom-live-preview div{margin:.24em 0}.custom-stage-preview p,.custom-stage-preview div{margin:.14em 0}.custom-stage-preview strong,.custom-stage-preview b,.custom-live-preview strong,.custom-live-preview b{color:#fff;text-shadow:0 0 18px #ffffff24;font-weight:950}.custom-stage-preview em,.custom-stage-preview i,.custom-live-preview em,.custom-live-preview i{font-style:italic}.custom-stage-preview u,.custom-live-preview u{text-underline-offset:.12em;text-decoration-thickness:.08em}.custom-stage-preview ul,.custom-stage-preview ol,.custom-live-preview ul,.custom-live-preview ol{text-align:left;margin:.2em auto;padding-left:1.35em;display:inline-block}.custom-stage-preview ul,.custom-stage-preview ol{margin:.12em auto}.custom-stage-preview li,.custom-live-preview li{margin:.1em 0;padding-left:.12em}.custom-panel-body{flex:1;min-height:0;padding:14px 16px 18px;display:flex}.songs-panel-body{flex-direction:column;flex:1;gap:12px;min-height:0;padding:14px 16px 18px;display:flex}.song-search-row{display:flex}.song-search-input,.song-field input,.song-section-editor-top select,.song-section-editor textarea{border:1px solid var(--panel-border);color:var(--text-main);background:#ffffff0a;outline:none}.song-search-input{border-radius:12px;width:100%;min-width:0;min-height:38px;padding:0 12px;font-size:14px}.song-search-input::placeholder{color:#777d93}.song-section-editor-top option{color:#f4ede3;background:#201e29}.song-tool-button,.song-icon-button{border:1px solid var(--panel-border);color:var(--text-main);cursor:pointer;background:#ffffff0a}.song-tool-button{border-radius:12px;min-height:38px;padding:0 10px;font-size:12px;font-weight:800}.song-tool-button:hover,.song-icon-button:hover,.song-section-card:hover{border-color:var(--panel-border-strong);background:#ff8b3d1a}.song-tool-button.danger{color:#ffb19b}.song-browser{flex:1;grid-template-columns:minmax(180px,.8fr) minmax(0,1.2fr);gap:12px;min-height:0;display:grid}.song-list,.song-section-list{flex:1;min-height:0;overflow-y:auto}.song-list{border:1px solid var(--panel-border);background:#ffffff06;border-radius:14px;padding:8px}.song-list-item{width:100%;color:inherit;cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:12px;flex-direction:column;gap:4px;margin-bottom:6px;padding:10px;display:flex}.song-list-item:hover,.song-list-item.active{border-color:var(--panel-border-strong);background:#ff8b3d1a}.song-list-title{color:#f4ede3;font-size:13px;font-weight:800}.song-list-meta{color:var(--text-muted);font-size:11px;line-height:1.35}.song-detail{flex-direction:column;gap:10px;min-height:0;display:flex}.song-detail-header{border:1px solid var(--panel-border);background:#ffffff09;border-radius:14px;justify-content:space-between;align-items:flex-start;gap:10px;padding:10px 12px;display:flex}.song-detail-title{color:#f4ede3;font-size:14px;font-weight:900}.song-detail-meta{color:var(--text-muted);margin-top:3px;font-size:11px}.song-detail-actions{flex-shrink:0;gap:6px;display:flex}.song-section-card{border:1px solid var(--panel-border);width:100%;color:inherit;cursor:pointer;text-align:left;background:#ffffff0a;border-radius:14px;margin-bottom:10px;padding:12px}.song-section-card.active{border-color:var(--panel-border-strong);background:#ff8b3d1f}.song-section-top{color:#f4ede3;justify-content:space-between;align-items:center;gap:10px;font-size:13px;font-weight:800;display:flex}.song-section-copy{color:var(--text-muted);white-space:pre-line;margin-top:7px;font-size:12px;line-height:1.5}.song-stage-preview,.song-live-preview{white-space:pre-line}.song-modal-backdrop{z-index:300;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#00000094;justify-content:center;align-items:flex-start;padding:44px 16px;display:flex;position:fixed;inset:0;overflow-y:auto}.song-modal{border:1px solid var(--panel-border);width:min(680px,100%);max-height:calc(100dvh - 88px);box-shadow:var(--shadow-panel);background:#201e29;border-radius:20px;flex-direction:column;display:flex;overflow:hidden}.song-modal-header,.song-modal-actions{border-bottom:1px solid var(--panel-border);justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;display:flex}.song-modal-actions{border-top:1px solid var(--panel-border);border-bottom:none;justify-content:flex-end}.song-modal-body{flex-direction:column;gap:14px;min-height:0;padding:16px 18px;display:flex;overflow-y:auto}.song-field{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.song-field span,.song-section-header{color:var(--text-muted);font-size:12px;font-weight:800}.song-field input{border-radius:12px;min-height:40px;padding:0 12px}.song-field-row{gap:10px;display:flex}.song-key-field{flex:0 0 120px}.song-section-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.panel-button.compact{flex:none;min-height:32px;padding:0 10px;font-size:12px}.song-section-editor-list{flex-direction:column;gap:12px;display:flex}.song-section-editor{border:1px solid var(--panel-border);border-radius:14px;overflow:hidden}.song-section-editor-top{border-bottom:1px solid var(--panel-border);background:#ffffff09;align-items:center;gap:8px;padding:8px;display:flex}.song-section-editor-top select{border-radius:10px;flex:1;min-height:34px;padding:0 10px}.song-icon-button{border-radius:10px;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:900;display:inline-flex}.song-section-editor textarea{resize:vertical;width:100%;min-height:104px;font:inherit;border:none;border-radius:0;padding:12px;line-height:1.5}.custom-text-composer{border:1px solid var(--panel-border);background:#ffffff09;border-radius:16px;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.custom-text-toolbar{border-bottom:1px solid var(--panel-border);align-items:center;gap:6px;padding:8px;display:flex}.format-btn{border:1px solid var(--panel-border);color:#f4ede3;cursor:pointer;background:#ffffff0a;border-radius:8px;justify-content:center;align-items:center;width:32px;height:30px;font-size:13px;font-weight:800;display:inline-flex}.format-btn:hover{border-color:var(--panel-border-strong);background:#ff8b3d1f}.format-btn.italic{font-style:italic}.format-btn.underline{text-decoration:underline}.format-divider{background:var(--panel-border);width:1px;height:22px;margin:0 2px}.custom-text-editor{min-height:104px;max-height:160px;color:var(--text-main);outline:none;flex:1;padding:12px 14px;font-size:14px;line-height:1.55;overflow-y:auto}.custom-text-editor:focus{box-shadow:inset 0 0 0 2px #ffffff24}.custom-text-editor:empty:before{content:attr(data-placeholder);color:var(--text-faint);pointer-events:none}.custom-text-editor ul,.custom-text-editor ol{margin:6px 0;padding-left:1.4em}.custom-text-actions{border-top:1px solid var(--panel-border);gap:10px;padding:10px;display:flex}.custom-text-actions .panel-button:disabled{cursor:not-allowed;opacity:.45;transform:none}.timer-track{background:#ffffff14;border-radius:999px;height:6px;margin:0 18px;overflow:hidden}.timer-fill{background:linear-gradient(90deg,#ff8b3d 0%,#ffd166 100%);height:100%;transition:width 1s linear}.timer-fill.paused{background:#7f879b}.panel-actions{gap:10px;padding:16px 18px 18px;display:flex}.panel-button{flex:1;min-height:40px;padding:0 14px;font-size:13px;font-weight:800}.live-chip{min-height:34px;color:var(--text-muted);border-color:var(--panel-border);background:#ffffff0a;padding:0 12px;font-size:12px;font-weight:800}.live-chip.active{color:#0f150d;background:linear-gradient(135deg,#39d98a 0%,#20c671 100%);border-color:#39d98a73}.queue-list,.history-feed,.search-results,.context-candidate-list{flex:1;padding:14px 16px 18px;overflow-y:auto}.queue-item,.search-result,.context-candidate,.history-card{border:1px solid var(--panel-border);width:100%;color:inherit;text-align:left;cursor:pointer;background:#ffffff0a;border-radius:16px}.queue-item{margin-bottom:10px;padding:14px}.queue-item-top,.history-card-top{justify-content:space-between;align-items:center;gap:10px;display:flex}.queue-ref,.history-ref{color:#f4ede3;font-size:14px;font-weight:800}.queue-text,.history-copy,.search-result-preview,.context-candidate-text{color:var(--text-muted);margin-top:8px;font-size:13px;line-height:1.55}.clear-link{color:var(--text-faint);cursor:pointer;background:0 0;border:none;padding:0;font-size:12px;font-weight:700}.clear-link:hover{color:#fff}.search-panel-header{align-items:center}.search-tabs{align-items:center;gap:8px;display:inline-flex}.search-tab{border:1px solid var(--panel-border);min-height:36px;color:var(--text-muted);cursor:pointer;background:#ffffff0a;border-radius:12px;padding:0 14px;font-size:12px;font-weight:800}.search-tab.active{border-color:var(--panel-border-strong);color:#ffd9bf;background:#ff8b3d29}.search-version-select{border:1px solid var(--panel-border);color:#f4ede3;cursor:pointer;appearance:none;background-color:#ffffff0a;background-image:linear-gradient(45deg,#0000 50%,#f4ede3 50%),linear-gradient(135deg,#f4ede3 50%,#0000 50%);background-position:calc(100% - 18px) 16px,calc(100% - 12px) 16px;background-repeat:no-repeat;background-size:6px 6px,6px 6px;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;border-radius:12px;outline:none;min-width:170px;min-height:38px;padding:0 38px 0 12px;font-size:12px;font-weight:800}.search-version-select:focus{border-color:var(--panel-border-strong);box-shadow:0 0 0 3px #ff8b3d14}.search-version-select option{color:#f4ede3;background:#201e29}.search-panel-body,.context-panel-body{flex-direction:column;flex:1;min-height:0;display:flex}.search-input-shell{align-items:center;gap:12px;padding:16px 16px 0;display:flex}.search-input{border:1px solid var(--panel-border);width:100%;min-height:46px;color:var(--text-main);background:#ffffff0a;border-radius:14px;outline:none;padding:0 14px}.search-input::placeholder{color:#777d93}.search-input:focus{border-color:var(--panel-border-strong);box-shadow:0 0 0 3px #ff8b3d14}.search-status{color:var(--text-muted);font-size:12px;font-weight:700}.search-result{margin-bottom:10px;padding:14px}.search-result.active{border-color:var(--panel-border-strong);background:#ff8b3d1f}.search-result-title,.context-candidate-ref{color:#f5f0e8;font-size:14px;font-weight:800}.context-panel-body{gap:14px;padding:16px}.context-candidate{border:1px solid var(--panel-border);background:#ffffff0a;border-radius:16px}.context-candidate-list{padding:0}.context-candidate,.history-card{margin-bottom:10px;padding:14px}.history-card.active{border-color:var(--panel-border-strong);background:#ff8b3d1f}.history-actions{justify-content:space-between;align-items:center;gap:10px;margin-top:10px;display:flex}.history-time{color:var(--text-faint);font-size:11px;font-weight:700}.history-action-pill{background:var(--accent-soft);color:#ffc69d;border-radius:999px;align-items:center;height:26px;padding:0 10px;font-size:11px;font-weight:800;display:inline-flex}@media (width<=1280px){.scripture-grid{grid-template-columns:1fr 1fr;grid-template-areas:"transcript preview""live queue""custom search""recent recent""songs songs"}.recent-panel{height:400px}}@media (width<=900px){.scripture-shell{padding:12px}.scripture-topbar{flex-direction:column;align-items:stretch}.topbar-pills,.topbar-actions{justify-content:flex-start}.scripture-grid{grid-template-columns:1fr;grid-template-areas:"transcript""preview""live""custom""search""queue""songs""recent"}.transcript-footer,.panel-actions,.search-input-shell{flex-direction:column;align-items:stretch}.panel-actions,.topbar-actions,.topbar-pills,.topbar-button,.panel-button,.mic-toggle{width:100%}.song-browser,.song-field-row{flex-direction:column;grid-template-columns:1fr}.song-key-field{flex-basis:auto}}.display-root{color:#f6f7fb;background:radial-gradient(circle at top,#ff93381f,#0000 30%),linear-gradient(#0a0a11 0%,#111320 42%,#0f121b 100%);justify-content:center;align-items:center;padding:48px;display:flex;position:fixed;inset:0;overflow:hidden}.display-bg{pointer-events:none;background:radial-gradient(circle at 20% 20%,#437dff1a,#0000 28%),radial-gradient(circle at 80% 18%,#ff8b3d1f,#0000 18%),linear-gradient(#ffffff05,#fff0);position:absolute;inset:0}.display-stage-shell{z-index:1;justify-content:center;align-items:center;width:min(1080px,100%);display:flex;position:relative}.display-stage-card{background:radial-gradient(circle at 80% 20%,#437dff52,#0000 20%),radial-gradient(circle at 70% 70%,#20b9ff33,#0000 24%),linear-gradient(135deg,#0f1220 0%,#14192b 100%);border:1px solid #ffffff14;border-radius:28px;flex-direction:column;justify-content:center;gap:20px;width:100%;min-height:min(62vh,720px);padding:clamp(34px,4vw,52px);animation:.45s forwards verse-in;display:flex;position:relative;overflow:hidden;box-shadow:0 32px 80px #00000073,inset 0 1px #ffffff0f}.display-stage-title{color:#f0c287;text-align:center;font-size:clamp(16px,1.2vw,20px);font-weight:800}.display-stage-text{color:#fff;text-align:center;white-space:pre-line;font-size:clamp(34px,4vw,56px);font-weight:700;line-height:1.6}.custom-display-text{overflow-wrap:anywhere;font-size:clamp(44px,5.2vw,82px);font-weight:650;line-height:1.38}.custom-display-text p,.custom-display-text div{margin:.24em 0}.custom-display-text strong,.custom-display-text b{color:#fff;text-shadow:0 0 22px #ffffff29;font-weight:950}.custom-display-text em,.custom-display-text i{font-style:italic}.custom-display-text u{text-underline-offset:.12em;text-decoration-thickness:.08em}.custom-display-text ul,.custom-display-text ol{text-align:left;margin:.2em auto;padding-left:1.35em;display:inline-block}.custom-display-text li{margin:.08em 0;padding-left:.12em}.song-display-card{padding-right:clamp(34px,4vw,52px)}.song-intro-card{align-items:center}.song-intro-title{color:#fff;text-align:center;max-width:12ch;font-size:clamp(48px,6vw,92px);font-weight:800;line-height:1.12}.song-intro-author{color:#d9deef;text-align:center;font-size:clamp(20px,2vw,32px);font-weight:700}.song-intro-qr{background:#fff;border:1px solid #ffffffb8;border-radius:12px;margin-top:16px;padding:12px;display:flex;box-shadow:0 12px 32px #00000047}.song-intro-qr img{width:clamp(132px,11vw,190px);height:clamp(132px,11vw,190px);image-rendering:pixelated;background:#fff;border-radius:4px}.pdf-download-card{align-items:center}.pdf-download-title{color:#fff;text-align:center;max-width:16ch;font-size:clamp(38px,4.8vw,72px);font-weight:850;line-height:1.15}.pdf-download-copy{color:#d9deef;text-align:center;font-size:clamp(18px,1.8vw,28px);font-weight:700}.pdf-download-qr{background:#fff;border:1px solid #ffffffb8;border-radius:14px;margin-top:18px;padding:14px;display:flex;box-shadow:0 12px 32px #00000047}.pdf-download-qr img{width:clamp(170px,15vw,260px);height:clamp(170px,15vw,260px);image-rendering:pixelated;background:#fff;border-radius:4px}.display-stage-empty{color:#d6dcec;text-align:center;align-self:center;max-width:28ch;font-size:clamp(22px,2.2vw,32px);font-weight:700;line-height:1.7}.display-stage-meta,.display-stage-note{color:#9ea6bd;text-align:center;font-size:clamp(14px,1.1vw,18px)}.display-stage-note{align-self:center;max-width:48ch}.display-word{transition:opacity .25s,color .25s}.display-word.unread{color:#ffffffb8}.display-word.read{color:#fff}.display-stage-timer{background:#ffffff14;border-radius:999px;height:8px;margin-top:8px;overflow:hidden}.display-stage-timer-fill{background:linear-gradient(90deg,#ff8b3d 0%,#ffd166 100%);height:100%;transition:width 1s linear}.display-stage-timer-fill.paused{background:#7f879b}.display-controls{opacity:0;z-index:100;background:#0f1220e6;border:1px solid #ffffff14;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;transition:opacity .2s;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 12px 32px #00000047}.display-root:hover .display-controls{opacity:1}.display-controls-label{color:#9ea6bd;font-size:12px}.display-ctrl-btn{color:#d6dcec;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:6px 12px;font-size:13px}.display-ctrl-btn:hover{color:#fff;background:#ffffff14}.display-ctrl-divider{background:#ffffff14;width:1px;height:16px}.display-ctrl-btn.danger{color:#ffb19b}.display-ctrl-btn.danger:hover{color:#ffd5c7}.kbd{color:#c3c9db;background:#ffffff14;border-radius:5px;justify-content:center;align-items:center;min-width:20px;height:18px;margin-left:6px;padding:0 5px;font-size:10px;font-weight:700;display:inline-flex}.custom-logo{object-fit:contain;max-width:80%;max-height:40vh;margin-bottom:24px}.idle-anim-breathe{animation:6s ease-in-out infinite idleBreathe}.idle-anim-float{animation:6s ease-in-out infinite idleFloat}.idle-anim-pulse{animation:4s ease-in-out infinite idlePulse}@keyframes idleBreathe{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes idleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}@keyframes idlePulse{0%,to{opacity:1;filter:drop-shadow(0 0 #0000)}50%{opacity:.8;filter:drop-shadow(0 0 20px #0000001a)}}.display-announcement-banner{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100;background:#000000d9;border-top:1px solid #ffffff1a;justify-content:center;align-items:center;width:100%;padding:24px 48px;display:flex;position:absolute;bottom:0;left:0;box-shadow:0 -10px 40px #00000080}.announcement-content{color:#fff;letter-spacing:.5px;text-align:center;max-width:90%;font-size:42px;font-weight:700}.animate-slide-up{animation:.6s cubic-bezier(.16,1,.3,1) forwards slideUpFade}@keyframes slideUpFade{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@media (width<=900px){.display-root{padding:24px}.display-stage-card{min-height:min(58vh,560px)}.display-controls{bottom:16px}}:root{--bg:var(--bg-main,#fafafa);--text:var(--text-main,#000);--card-bg:var(--bg-card,#fff);--hover-bg:var(--primary-light,#f5f5f5);--font:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--border:#e6e6e6;--text-muted:#666}.hymns-layout{background:var(--bg);min-height:100vh;color:var(--text);font-family:var(--font);flex-direction:column;display:flex}.hymns-header{border-bottom:1px solid var(--border);background:var(--card-bg);z-index:10;justify-content:space-between;align-items:center;padding:16px 32px;display:flex;position:sticky;top:0}.hymns-header-brand{align-items:center;gap:16px;display:flex}.hymns-back-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;padding:6px 12px;font-size:13px;transition:all .15s}.hymns-back-btn:hover{background:var(--hover-bg);color:var(--text)}.hymns-title{letter-spacing:-.3px;font-size:18px;font-weight:700}.hymns-subtitle{color:var(--text-muted);font-size:12px}.hymns-body{flex:1;width:100%;max-width:880px;margin:0 auto;padding:32px 24px}.hymns-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:24px;display:grid}.hymn-card{background:var(--card-bg);border:1px solid var(--border);cursor:pointer;border-radius:10px;flex-direction:column;gap:6px;padding:18px;transition:all .15s;display:flex}.hymn-card:hover{border-color:#000;box-shadow:0 4px 16px #0000000f}.hymn-card-title{letter-spacing:-.2px;font-size:15px;font-weight:700}.hymn-card-meta{color:var(--text-muted);font-size:12px}.hymn-card-actions{border-top:1px solid var(--border);gap:6px;margin-top:10px;padding-top:10px;display:flex}.hymn-card-verse-count{color:var(--text-muted);background:var(--hover-bg);border-radius:20px;margin-top:4px;padding:2px 8px;font-size:11px;display:inline-block}.hymn-editor-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;background:#0006;justify-content:center;align-items:flex-start;padding:48px 16px;display:flex;position:fixed;inset:0;overflow-y:auto}.hymn-editor{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:0;width:100%;max-width:640px;animation:.25s cubic-bezier(.16,1,.3,1) forwards fade-up;display:flex;box-shadow:0 24px 64px #00000026}.hymn-editor-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.hymn-editor-header h2{margin:0;font-size:17px;font-weight:700}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:20px;transition:all .15s;display:flex}.modal-close:hover{background:var(--hover-bg);color:var(--text)}.hymn-editor-body{flex-direction:column;gap:16px;padding:24px;display:flex}.hymn-form-row{gap:12px;display:flex}.hymn-form-group{flex-direction:column;flex:1;gap:6px;display:flex}.hymn-form-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.hymn-form-group input,.hymn-form-group select{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:7px;padding:8px 12px;font-size:14px;transition:all .15s}.hymn-form-group input:focus,.hymn-form-group select:focus{background:var(--card-bg);border-color:#000;outline:none;box-shadow:0 0 0 2px #0000000d}.verse-list{flex-direction:column;gap:12px;display:flex}.verse-item{border:1px solid var(--border);border-radius:8px;transition:all .15s;overflow:hidden}.verse-item:focus-within{border-color:#000;box-shadow:0 4px 12px #0000000d}.verse-item-header{background:var(--hover-bg);border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:8px 12px;display:flex}.verse-item-header select{border:1px solid var(--border);background:var(--card-bg);color:var(--text);border-radius:5px;flex:1;padding:4px 8px;font-size:13px}.verse-remove-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:14px;transition:all .15s;display:flex}.verse-remove-btn:hover{color:#d32f2f;background:#ff000014}.verse-item textarea{resize:vertical;width:100%;min-height:80px;font-size:14px;font-family:var(--font);background:var(--card-bg);color:var(--text);box-sizing:border-box;border:none;padding:10px 12px;display:block}.verse-item textarea:focus{background:var(--card-bg);outline:none}.hymn-editor-footer{border-top:1px solid var(--border);background:var(--bg);border-bottom-right-radius:14px;border-bottom-left-radius:14px;justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.hymns-layout .action-btn,.hymn-editor .action-btn{border:1px solid var(--border);background:var(--card-bg);color:var(--text);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.hymns-layout .action-btn:hover,.hymn-editor .action-btn:hover{background:var(--hover-bg);border-color:var(--text-muted)}.hymns-layout .action-btn.primary,.hymn-editor .action-btn.primary{color:#fff;background:#000;border-color:#000;font-weight:600}.hymns-layout .action-btn.primary:hover,.hymn-editor .action-btn.primary:hover{background:#222;border-color:#222}.hymn-follow-root{color:#fff;background:#0a0a0a;flex-direction:column;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Inter,sans-serif;display:flex}.hymn-follow-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;background:#0a0a0af2;border-bottom:1px solid #ffffff14;padding:20px 20px 12px;position:sticky;top:0}.hymn-follow-title{letter-spacing:-.5px;font-size:20px;font-weight:800}.hymn-follow-meta{color:#fff6;margin-top:3px;font-size:13px}.hymn-follow-body{flex-direction:column;gap:20px;padding:20px;display:flex}.hymn-follow-verse{background:#ffffff0a;border:1px solid #ffffff12;border-radius:12px;padding:18px;scroll-margin-top:90px;transition:all .4s}.hymn-follow-verse.active{background:#ffffff17;border-color:#ffffff4d}.hymn-follow-verse-label{text-transform:uppercase;letter-spacing:1.5px;color:#fff6;margin-bottom:10px;font-size:11px;font-weight:700}.hymn-follow-verse.active .hymn-follow-verse-label{color:#ffffffb3}.hymn-follow-verse-text{color:#ffffffb3;white-space:pre-wrap;font-size:18px;line-height:1.8}.hymn-follow-verse.active .hymn-follow-verse-text{color:#fff;font-size:20px}.hymn-follow-empty{color:#ffffff4d;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:70vh;font-size:14px;display:flex}.hymn-follow-note{color:#ffffff40;text-align:center;padding:20px;font-size:12px}.hymn-verse-chips{flex-wrap:wrap;gap:6px;padding:10px 0 4px;display:flex}.hymn-verse-chip{border:1px solid var(--border);cursor:pointer;background:var(--bg);color:var(--text);border-radius:20px;padding:5px 12px;font-size:12px;font-weight:500;transition:all .15s}.hymn-verse-chip:hover{background:var(--hover-bg);border-color:#000}.hymn-verse-chip.active{color:#fff;background:#000;border-color:#000}.qr-modal-body{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:24px;display:flex}.qr-canvas{border:6px solid #fff;border-radius:12px;box-shadow:0 4px 24px #0000001a}.qr-instruction{color:var(--text-muted);max-width:260px;font-size:14px;line-height:1.5}.qr-url{color:var(--text-muted);word-break:break-all;background:var(--hover-bg);border-radius:6px;max-width:280px;padding:6px 10px;font-size:11px}.tp-layout{background:#f8f8f8;flex-direction:column;height:100vh;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,sans-serif;display:flex}.tp-header{background:#fff;border-bottom:1px solid #e8e8e8;flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:14px 24px;display:flex}.tp-header-left{align-items:center;gap:14px;display:flex}.tp-back-btn{cursor:pointer;color:#444;background:#fff;border:1px solid #e0e0e0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,border-color .15s;display:flex}.tp-back-btn:hover{background:#f5f5f5;border-color:#ccc}.tp-title-group{flex-direction:column;gap:1px;display:flex}.tp-title{color:#111;letter-spacing:-.3px;font-size:17px;font-weight:600}.tp-subtitle{color:#888;font-size:12px}.tp-header-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.tp-btn{cursor:pointer;color:#333;white-space:nowrap;background:#fff;border:1px solid #ddd;border-radius:6px;align-items:center;padding:7px 14px;font-size:13px;font-weight:500;transition:background .15s,opacity .15s;display:inline-flex}.tp-btn:hover{background:#f5f5f5}.tp-btn.primary{color:#fff;background:#111;border-color:#111}.tp-btn.primary:hover{opacity:.85}.tp-btn.primary.dimmed,.tp-btn.primary:disabled{opacity:.4;cursor:default}.tp-btn.secondary{color:#555;background:#f0f0f0;border-color:#ddd}.tp-btn.secondary:hover{background:#e8e8e8}.tp-body{flex:1;display:flex;overflow:hidden}.tp-sidebar{background:#fff;border-right:1px solid #e8e8e8;flex-direction:column;flex-shrink:0;width:300px;display:flex;overflow-y:auto}.tp-list-item{cursor:pointer;border-bottom:1px solid #f0f0f0;padding:14px 16px;transition:background .12s;position:relative}.tp-list-item:hover{background:#f9f9f9}.tp-list-item.active{background:#f0f0f0;border-left:3px solid #111;padding-left:13px}.tp-item-label{color:#111;text-overflow:ellipsis;white-space:nowrap;margin-bottom:3px;padding-right:56px;font-size:13.5px;font-weight:600;overflow:hidden}.tp-item-meta{color:#999;align-items:center;gap:6px;margin-bottom:5px;font-size:11px;display:flex}.tp-item-preview{color:#666;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;line-height:1.4;display:-webkit-box;overflow:hidden}.tp-item-actions{opacity:0;gap:4px;transition:opacity .15s;display:flex;position:absolute;top:14px;right:12px}.tp-list-item:hover .tp-item-actions,.tp-list-item.active .tp-item-actions{opacity:1}.tp-icon-btn{cursor:pointer;color:#555;background:#fff;border:1px solid #e0e0e0;border-radius:5px;justify-content:center;align-items:center;width:26px;height:26px;transition:background .12s,color .12s;display:flex}.tp-icon-btn:hover{background:#f0f0f0}.tp-icon-btn.danger:hover{color:#c00;background:#fff0f0;border-color:#fcc}.tp-editor{background:#fff;flex-direction:column;flex:1;display:flex;overflow:hidden}.tp-editor-titlebar{flex-shrink:0;align-items:center;gap:12px;padding:14px 24px 0;display:flex}.tp-label-input{color:#111;letter-spacing:-.3px;background:0 0;border:none;border-bottom:2px solid #0000;outline:none;flex:1;padding-bottom:4px;font-size:20px;font-weight:600;transition:border-color .2s}.tp-label-input:focus{border-bottom-color:#111}.tp-saved-badge{color:#2a7d4f;white-space:nowrap;background:#eaf6ef;border:1px solid #b6e3cc;border-radius:4px;padding:3px 8px;font-size:12px;animation:.3s fadeIn}.tp-unsaved-badge{color:#b05000;white-space:nowrap;background:#fff8f0;border:1px solid #ffdcb0;border-radius:4px;padding:3px 8px;font-size:12px}.tp-editor-toolbar{border-bottom:1px solid #f0f0f0;flex-shrink:0;align-items:center;gap:12px;padding:8px 24px 10px;display:flex}.tp-stat{color:#888;font-size:12px}.tp-divider{background:#ddd;width:1px;height:14px}.tp-tool-btn{color:#222;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #d8d8d8;border-radius:6px;align-items:center;gap:6px;height:28px;padding:0 10px;font-size:12px;font-weight:600;transition:background .15s,border-color .15s,opacity .15s;display:inline-flex}.tp-tool-btn:hover{background:#f5f5f5;border-color:#c6c6c6}.tp-tool-btn:disabled{opacity:.55;cursor:default}.tp-hint{color:#aaa;margin-left:auto;font-size:12px}.tp-hint kbd{color:#555;background:#f0f0f0;border:1px solid #ddd;border-radius:3px;padding:1px 5px;font-family:inherit;font-size:11px;display:inline-block}.tp-format-toolbar{background:#fbfbfb;border-bottom:1px solid #eee;flex-wrap:wrap;align-items:center;gap:6px;padding:8px 24px 10px;display:flex}.tp-format-group{border-right:1px solid #e3e3e3;align-items:center;gap:3px;margin-right:1px;padding-right:7px;display:inline-flex}.tp-format-group:last-child{border-right:none}.tp-format-btn{color:#242424;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff;border:1px solid #d8d8d8;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;font-size:12px;font-weight:700;line-height:1;display:inline-flex}.tp-format-btn.wide{width:auto;min-width:34px;padding:0 8px}.tp-format-btn.strong{font-weight:800}.tp-format-btn.italic{font-family:Georgia,Times New Roman,serif;font-style:italic}.tp-format-btn.underline{text-decoration:underline}.tp-format-btn.strike{text-decoration:line-through}.tp-format-btn.clear{font-weight:600}.tp-format-btn:hover:not(:disabled){background:#f2f2f2;border-color:#c7c7c7}.tp-format-btn:disabled{opacity:.45;cursor:default}.tp-textarea-shell{flex:1;min-height:0;position:relative}.tp-textarea{color:#1a1a1a;resize:none;box-sizing:border-box;background:#fff;border:none;outline:none;width:100%;height:100%;padding:20px 24px;font-family:Georgia,Times New Roman,serif;font-size:15px;line-height:1.75}.tp-rich-editor{white-space:normal;-webkit-user-select:text;user-select:text;cursor:text;overflow-y:auto}.tp-rich-editor:empty:before{content:attr(data-placeholder);color:#ccc;font-style:italic}.tp-rich-editor p,.tp-rich-editor div{margin:0 0 .9em}.tp-rich-editor p:last-child,.tp-rich-editor div:last-child,.tp-rich-editor h1:last-child,.tp-rich-editor h2:last-child,.tp-rich-editor h3:last-child,.tp-rich-editor blockquote:last-child,.tp-rich-editor ul:last-child,.tp-rich-editor ol:last-child{margin-bottom:0}.tp-rich-editor h1,.tp-rich-editor h2,.tp-rich-editor h3{margin:0 0 .55em;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:750;line-height:1.25}.tp-rich-editor h1{font-size:30px}.tp-rich-editor h2{font-size:24px}.tp-rich-editor h3{font-size:19px}.tp-rich-editor blockquote{color:#4a4a4a;border-left:3px solid #d0d0d0;margin:0 0 1em;padding:.25em 0 .25em 1em}.tp-rich-editor ul,.tp-rich-editor ol{margin:0 0 1em;padding-left:1.6em}.tp-rich-editor li{margin:.2em 0}.tp-textarea.is-correcting{color:#1a1a1a29;background:#fbfbfb}.tp-textarea::placeholder{color:#ccc;font-style:italic}.tp-correction-layer{z-index:2;pointer-events:none;background:#ffffffdb;flex-direction:column;padding:20px 24px;display:flex;position:absolute;inset:0}.tp-correction-status{color:#555;margin-bottom:10px;font-size:12px;font-weight:600}.tp-correction-stream{flex-wrap:wrap;align-content:flex-start;gap:4px 7px;max-height:100%;display:flex;position:relative;overflow:hidden}.tp-correction-indicator{z-index:0;opacity:0;will-change:transform, width;background:#111;border-radius:99px;height:3px;transition:transform .22s cubic-bezier(.22,1,.36,1),width .22s cubic-bezier(.22,1,.36,1),opacity .14s;position:absolute;top:0;left:0}.tp-correction-indicator.visible{opacity:1}.tp-correction-word{z-index:1;color:#555;align-items:center;min-height:24px;padding:0 1px 4px;font-family:Georgia,Times New Roman,serif;font-size:15px;line-height:1.45;transition:color .15s;display:inline-flex;position:relative}.tp-correction-word.active,.tp-correction-word.applied{color:#111}.tp-inline-error{color:#9d1c1c;background:#fff7f7;border-bottom:1px solid #f4d7d7;padding:8px 24px;font-size:12px;line-height:1.4}.tp-inline-success{color:#1d6b42;background:#f5fbf7;border-bottom:1px solid #d7eadf;padding:8px 24px;font-size:12px;line-height:1.4}.tp-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:48px 24px;display:flex}.tp-empty-icon{opacity:.5;margin-bottom:16px;font-size:48px}.tp-empty-title{color:#333;margin-bottom:8px;font-size:16px;font-weight:600}.tp-empty-desc{color:#888;max-width:240px;font-size:13px;line-height:1.5}.tp-no-selection{text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:32px;display:flex}.tp-no-sel-icon{color:#ccc;margin-bottom:16px;font-size:36px}.tp-no-sel-title{color:#555;margin-bottom:8px;font-size:16px;font-weight:600}.tp-no-sel-desc{color:#999;max-width:260px;font-size:13px;line-height:1.5}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (width<=700px){.tp-body{flex-direction:column}.tp-sidebar{border-bottom:1px solid #e8e8e8;border-right:none;width:100%;max-height:40vh}.tp-editor{flex:1}.tp-header{padding:12px 16px}.tp-editor-titlebar{padding:12px 16px 0}.tp-editor-toolbar{flex-wrap:wrap;padding:6px 16px 8px}.tp-textarea{padding:14px 16px;font-size:14px}.tp-correction-layer{padding:12px 16px}.tp-correction-stream{gap:6px}.tp-correction-word{min-height:22px;padding-bottom:4px;font-size:13px}.tp-inline-error,.tp-inline-success{padding:8px 16px}.tp-hint{display:none}}
