:root{--ink:#17201f;--muted:#687675;--line:#d9e0dc;--paper:#fffdf8;--panel:#fff;--mist:#eef4f1;--jade:#0f766e;--jade-strong:#0b4f4a;--coral:#c25645;--amber:#b7791f;--blue:#2f5b8f;--shadow:0 16px 36px #1233311a}*{box-sizing:border-box}html,body{height:100%;overflow:hidden}body{background:linear-gradient(90deg, #0f766e09 1px, transparent 1px), linear-gradient(180deg, #f8faf7 0%, var(--paper) 42%, #f3f0ea 100%);color:var(--ink);letter-spacing:0;background-size:36px 36px,auto;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}a{color:inherit;text-decoration:none}.app-shell{flex-direction:column;height:100dvh;display:flex;overflow:hidden}.topbar{z-index:30;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffdf8eb;justify-content:space-between;align-items:center;gap:12px;min-height:64px;padding:10px 14px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:10px;min-width:0;display:flex}.brand-mark{object-fit:cover;border-radius:8px;width:40px;height:40px;box-shadow:0 8px 18px #12333129}.brand-title{margin:0;font-size:.92rem;font-weight:800;line-height:1.1}.brand-subtitle{color:var(--muted);margin:2px 0 0;font-size:.76rem;line-height:1.2;display:none}.topbar-actions{align-items:center;gap:8px;display:flex}.topbar .select-input,.topbar .locale-select{width:132px;min-height:40px}.icon-button,.text-button,.primary-button,.ghost-button,.chip-button,.tab-button{border:1px solid var(--line);background:var(--panel);min-height:40px;color:var(--ink);border-radius:999px;transition:background .15s,border-color .15s,color .15s,transform .15s}.icon-button{place-items:center;width:40px;padding:0;display:inline-grid}.text-button,.primary-button,.ghost-button{justify-content:center;align-items:center;gap:8px;padding:0 14px;font-size:.86rem;font-weight:750;display:inline-flex}.primary-button{border-color:var(--jade-strong);background:var(--jade-strong);color:#fff}.ghost-button{background:0 0}.icon-button:hover,.text-button:hover,.ghost-button:hover,.chip-button:hover,.tab-button:hover{border-color:var(--jade);color:var(--jade-strong)}.primary-button:hover{background:var(--jade);border-color:var(--jade)}.layout-grid{flex:1;grid-template-columns:1fr;height:calc(100dvh - 64px);min-height:0;display:grid;overflow:hidden}.desktop-sidebar{display:none}.mobile-drawer{z-index:60;background:var(--paper);grid-template-rows:auto 1fr;display:grid;position:fixed;inset:0}.mobile-drawer .side-panel{border-right:0}.drawer-head{border-bottom:1px solid var(--line);background:var(--panel);justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;display:flex}.main-pane{flex-direction:column;min-width:0;height:100%;min-height:0;display:flex;overflow:hidden}.side-panel{border-right:1px solid var(--line);background:var(--panel);flex-direction:column;width:100%;max-width:100%;height:100%;min-height:0;display:flex;overflow:hidden}.library-pane,.reader-pane,.mobile-library-step,.mobile-reader-step{width:100%;min-width:0;max-width:100%;height:100%;min-height:0;overflow:hidden}.library-pane:not(.is-active),.reader-pane:not(.is-active),.mobile-library-step:not(.is-active),.mobile-reader-step:not(.is-active){display:none}.library-pane.is-active,.mobile-library-step.is-active,.reader-pane.is-active,.mobile-reader-step.is-active{display:flex}.selector-band{border-bottom:1px solid var(--line);background:var(--panel);gap:10px;padding:14px;display:grid}.library-actions-row{align-items:center;gap:8px;display:flex}.view-mode-row{justify-content:flex-end;margin-left:auto}.language-toggle-button{border:1px solid var(--line);min-width:0;max-width:min(190px,48vw);min-height:38px;color:var(--ink);background:#fff;border-radius:8px;justify-content:center;align-items:center;gap:7px;padding:0 10px;font-size:.78rem;font-weight:800;display:inline-flex}.language-toggle-button span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.library-tools{gap:10px;padding-top:2px;display:grid}.field-label{color:var(--muted);text-transform:uppercase;align-items:center;gap:6px;font-size:.72rem;font-weight:800;display:flex}.select-input,.search-input,.form-input{border:1px solid var(--line);width:100%;min-height:44px;color:var(--ink);background:#fff;border-radius:8px;outline:none}.select-input{padding:0 36px 0 12px}.custom-select{width:100%;position:relative}.custom-select-trigger{border:1px solid var(--line);width:100%;min-height:44px;color:var(--ink);text-align:left;background:#fff;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:0 12px;display:grid;box-shadow:inset 0 -1px #0f766e0a}.custom-select-trigger span{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-weight:720;overflow:hidden}.custom-select.is-open .custom-select-trigger{border-color:var(--jade);box-shadow:0 0 0 3px #0f766e1f}.custom-select.is-disabled{opacity:.58}.custom-select-menu{z-index:80;border:1px solid var(--line);max-height:min(320px,52dvh);box-shadow:var(--shadow);background:#fffffffa;border-radius:8px;gap:3px;padding:6px;display:grid;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:auto}.custom-select-search{z-index:1;border:1px solid var(--line);min-height:38px;color:var(--muted);background:#fff;border-radius:7px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:7px;padding:0 9px;display:grid;position:sticky;top:0}.custom-select-search input{width:100%;min-width:0;color:var(--ink);background:0 0;border:0;outline:none;font-size:.86rem}.custom-select-option{min-height:38px;color:var(--ink);text-align:left;background:0 0;border:0;border-radius:7px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;padding:0 9px;display:grid}.custom-select-option span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.custom-select-option:hover,.custom-select-option.is-selected{color:var(--jade-strong);background:#eaf7f3}.custom-select-empty{color:var(--muted);padding:8px 10px}.search-input,.form-input{padding:0 12px}.select-input:focus,.search-input:focus,.form-input:focus,textarea.form-input:focus{border-color:var(--jade);box-shadow:0 0 0 3px #0f766e1f}.filter-row,.tabs-row,.toolbar-row{scrollbar-width:none;gap:8px;display:flex;overflow-x:auto}.filter-row::-webkit-scrollbar{display:none}.tabs-row::-webkit-scrollbar{display:none}.toolbar-row::-webkit-scrollbar{display:none}.chip-button,.tab-button,.font-size-button{flex:none;justify-content:center;align-items:center;gap:6px;padding:0 12px;font-size:.8rem;font-weight:750;display:inline-flex}.font-size-button{border:1px solid var(--line);background:var(--panel);min-width:44px;color:var(--ink);border-radius:999px}.chip-button.is-active,.tab-button.is-active,.icon-button.is-active{border-color:var(--jade);color:var(--jade-strong);background:#e5f2ee}.hymn-list{flex:1;width:100%;max-width:100%;min-height:0;overflow:auto}.hymn-list-grid{--grid-cell-size:66px;box-sizing:border-box;grid-template-columns:repeat(auto-fit, minmax(min(100%, var(--grid-cell-size)), 1fr));place-content:start stretch;gap:14px 8px;width:100%;padding:10px;display:grid}.hymn-list-grid .hymn-item{aspect-ratio:1;min-height:var(--grid-cell-size);border:1px solid var(--line);text-align:center;background:#fff;border-radius:8px;grid-template-columns:1fr;justify-items:center;padding:8px}.hymn-list-grid .hymn-number{background:0 0;border:0;width:100%;height:100%;font-size:1.05rem}.hymn-list-grid .hymn-meta,.hymn-list-grid .toolbar-row{display:none}.hymn-list-compact .hymn-item{grid-template-columns:36px 1fr auto;min-height:44px;padding-block:6px}.hymn-list-compact .hymn-number{width:32px;height:32px;font-size:.74rem}.hymn-list-compact .hymn-subtitle{display:none}.hymn-item{width:100%;min-height:66px;color:var(--ink);text-align:left;background:0 0;border:0;border-bottom:1px solid #edf0ed;grid-template-columns:46px 1fr auto;align-items:center;gap:10px;padding:10px 14px;display:grid}.hymn-item:hover,.hymn-item.is-active{background:#eef7f4}.hymn-number{border:1px solid var(--line);width:42px;height:42px;color:var(--jade-strong);background:#fff;border-radius:8px;place-items:center;font-size:.86rem;font-weight:850;display:grid}.hymn-meta{min-width:0}.hymn-title{text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.92rem;font-weight:780;display:block;overflow:hidden}.hymn-subtitle{text-overflow:ellipsis;white-space:nowrap;color:var(--muted);margin:3px 0 0;font-size:.76rem;overflow:hidden}.mini-pill{border:1px solid var(--line);min-height:24px;color:var(--muted);background:#fff;border-radius:999px;justify-content:center;align-items:center;padding:0 8px;font-size:.74rem;font-weight:750;display:inline-flex}.reader{background:#fffdf8ad;flex-direction:column;flex:1;height:100%;min-height:0;display:flex;overflow:hidden}.reader-header{border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#fffdf8f2;padding:12px 14px 10px;position:relative;overflow:hidden}.reader-header.is-loading:after{content:"";background:var(--jade);border-radius:0 2px 2px 0;height:2px;animation:1.1s ease-in-out infinite readerProgress;position:absolute;bottom:0;left:0}@keyframes readerProgress{0%{opacity:.7;left:0;right:100%}50%{opacity:1;left:0;right:0}to{opacity:.7;left:100%;right:0}}.reader-title-row{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.reader-title-block{flex:1;min-width:0}.reader-title{letter-spacing:-.01em;overflow-wrap:break-word;margin:0;font-size:clamp(1.2rem,6vw,2rem);line-height:1.1}.reader-overline{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;text-overflow:ellipsis;margin:0 0 3px;font-size:.72rem;font-weight:800;overflow:hidden}.reader-meta-row{flex-wrap:wrap;gap:5px}.reader-meta-row .mini-pill{max-width:100%}.reader-translations{align-items:center}.translations-label{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);align-items:center;gap:4px;font-size:.7rem;font-weight:800;display:inline-flex}.reader-content{flex:1;min-height:0;padding:22px 48px 120px;transition:opacity .15s;position:relative;overflow:auto}.reader-content.is-loading{opacity:.45;pointer-events:none}@keyframes lyricsEnter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.lyrics-enter{animation:.22s ease-out both lyricsEnter}.reader-content.is-loading .lyrics-enter{animation:none}.reader-nav-arrow{z-index:10;border:1px solid var(--line);width:36px;height:64px;color:var(--jade-strong);cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:.6;background:#fffdf8d1;border-radius:999px;justify-content:center;align-items:center;transition:background .15s,opacity .15s;display:flex;position:fixed;top:50%;transform:translateY(-50%)}.reader-nav-arrow:hover{opacity:1;background:#fffdf8fa}.reader-nav-prev{left:6px}.reader-nav-next{right:6px}.desktop-only,.desktop-meta{display:none!important}.reader-loading{align-content:center;place-items:center;gap:12px;display:grid}.lyrics{max-width:680px;margin:0 auto}.lyrics-section{text-align:center;padding:0 0 26px}.section-marker{border:1px solid var(--line);min-width:32px;height:32px;color:var(--jade-strong);background:#fff;border-radius:999px;justify-content:center;align-items:center;margin-bottom:10px;font-weight:850;display:inline-flex}.lyrics-text{white-space:pre-line;margin:0;font-family:Georgia,Times New Roman,serif;font-size:clamp(1.45rem,7vw,2.2rem);line-height:1.55}.lyrics-size-small .lyrics-text{font-size:clamp(1.08rem,4.8vw,1.65rem)}.lyrics-size-large .lyrics-text{font-size:clamp(1.72rem,8.2vw,2.65rem)}.lyrics-section.is-refrain .lyrics-text{color:#344a49;font-style:italic}.empty-state{flex:1;place-items:center;padding:28px 16px 120px;display:grid}.empty-inner{text-align:center;width:min(100%,520px)}.feature-image{border:1px solid var(--line);width:min(100%,420px);box-shadow:var(--shadow);border-radius:8px}.empty-title{margin:18px 0 8px;font-size:clamp(1.7rem,10vw,3rem);line-height:1.02}.empty-copy{max-width:440px;color:var(--muted);margin:0 auto;line-height:1.55}.audio-dock{z-index:40;border:1px solid var(--line);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffffff0;border-radius:8px;gap:8px;padding:10px;display:grid;position:fixed;bottom:12px;left:12px;right:12px}.audio-main-row{grid-template-columns:auto auto auto minmax(0,1fr);align-items:center;gap:8px;display:grid}.audio-play-button{background:var(--jade-strong);color:#fff;border:0;border-radius:999px;place-items:center;width:48px;height:48px;display:inline-grid;box-shadow:0 10px 20px #0f766e38}.audio-title-block{gap:3px;min-width:0;display:grid}.audio-title-block strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.audio-title-block span{color:var(--muted);align-items:center;gap:5px;font-size:.76rem;font-weight:720;display:inline-flex}.audio-range{appearance:none;background:linear-gradient(90deg, var(--jade) var(--audio-progress,0%), #e4ebe8 var(--audio-progress,0%));border-radius:999px;outline:none;width:100%;height:8px}.audio-range::-webkit-slider-thumb{appearance:none;background:var(--jade-strong);border:3px solid #fff;border-radius:999px;width:18px;height:18px;box-shadow:0 4px 10px #1233313d}.audio-range::-moz-range-thumb{background:var(--jade-strong);border:3px solid #fff;border-radius:999px;width:14px;height:14px;box-shadow:0 4px 10px #1233313d}.auth-page,.upload-page{align-items:center;height:100dvh;padding:18px;display:grid;overflow:auto}.auth-panel,.upload-panel{gap:18px;width:min(100%,980px);margin:0 auto;display:grid}.form-panel,.drop-zone,.queue-panel,.message-panel{border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow);border-radius:8px}.form-panel{padding:18px}.form-stack{gap:14px;display:grid}.form-row{gap:6px;display:grid}.drop-zone{text-align:center;border-style:dashed;place-items:center;min-height:220px;padding:24px;display:grid}.drop-zone.is-active{border-color:var(--jade);background:#edf7f4}.queue-panel{overflow:hidden}.queue-item{border-top:1px solid #edf0ed;grid-template-columns:1fr auto;gap:10px;padding:12px;display:grid}.progress{background:#e7ece9;border-radius:999px;height:6px;overflow:hidden}.progress span{background:var(--jade);height:100%;display:block}@keyframes slideUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes loadingPulse{0%,80%,to{opacity:.3;transform:scale(0)}40%{opacity:1;transform:scale(1)}}@keyframes livePulse{0%{box-shadow:0 0 #7dd3c780}70%{box-shadow:0 0 0 8px #7dd3c700}to{box-shadow:0 0 #7dd3c700}}@keyframes dotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}.projection-page{color:#fff;-webkit-font-smoothing:antialiased;background:#0c1110;grid-template-rows:auto auto 1fr auto;height:100dvh;min-height:0;display:grid;overflow:hidden}.projection-page.is-host{grid-template-rows:auto 1fr}.projection-bar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:10;background:#0c1110eb;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;display:flex}.client-hymn-header{justify-content:center;align-items:center;gap:12px;padding:14px 32px 0;animation:.5s fadeIn;display:flex}.client-hymn-number{color:#7dd3c7;letter-spacing:.02em;background:#7dd3c71a;border:1px solid #7dd3c74d;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;min-width:36px;height:36px;padding:0 10px;font-size:.82rem;font-weight:850;display:inline-flex}.client-hymn-title{color:#ffffff80;text-overflow:ellipsis;white-space:nowrap;letter-spacing:.01em;max-width:420px;font-size:.9rem;font-weight:500;overflow:hidden}.watcher>.projection-main{height:91vh;position:relative}.watcher>.projection-main:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(#7dd3c712 0%,#0000 65%);position:absolute;inset:0}.watcher>.projection-main>*{z-index:1;position:relative}.projection-main{text-align:center;place-items:center;min-height:0;padding:28px 18px;display:grid;position:relative;overflow:auto}.projection-slide{animation:.32s cubic-bezier(.22,1,.36,1) slideUp}.projection-idle{opacity:.38;animation:.6s fadeIn}.projection-loading{justify-content:center;align-items:center;gap:10px;display:flex}.projection-loading span{background:#7dd3c7;border-radius:50%;width:10px;height:10px;animation:1.4s ease-in-out infinite loadingPulse;display:block}.projection-loading span:first-child{animation-delay:-.32s}.projection-loading span:nth-child(2){animation-delay:-.16s}.stream-share{color:#ffffffc7;background:#ffffff14;border-top:1px solid #ffffff1f;border-bottom:1px solid #ffffff1f;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:8px 12px;font-size:.8rem;display:grid}.stream-share span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.projection-text{white-space:pre-line;letter-spacing:.01em;max-width:1000px;font-family:Georgia,Times New Roman,serif;font-size:clamp(2.4rem,10vw,6.5rem);line-height:1.22}.projection-footer{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0c1110db;border-top:1px solid #ffffff0f;gap:8px;padding:12px 16px;display:grid}.client-progress{flex-direction:column;align-items:center;gap:6px;display:flex}.client-section-label{letter-spacing:.06em;text-transform:uppercase;font-size:.72rem;font-weight:700}.dot-row{justify-content:center;gap:6px;display:flex;overflow-x:auto}.dot{background:#ffffff47;border:0;border-radius:999px;flex:none;width:8px;height:8px;transition:width .2s,background .2s;display:block}.dot.is-active{background:#7dd3c7;width:24px}.projection-settings-panel{z-index:30;width:280px;color:var(--ink);padding:12px;position:fixed;top:72px;right:12px}.host-workspace{background:linear-gradient(135deg,#7dd3c714,#0000 34%),#0408087a;grid-template-columns:minmax(0,1fr) minmax(360px,420px);gap:12px;min-height:0;padding:12px;display:grid;overflow:hidden}.host-panel-collapsed .host-workspace{grid-template-columns:minmax(0,1fr)}.host-panel-collapsed .host-panel{display:none}.host-stage{background:#ffffff08;border:1px solid #ffffff1a;border-radius:12px;grid-template-rows:auto 1fr auto;min-width:0;min-height:0;display:grid;overflow:hidden;box-shadow:inset 0 1px #ffffff0f,0 0 80px #7dd3c70a}.stage-hymn-strip{background:#0000002e;border-bottom:1px solid #ffffff12;align-items:center;gap:10px;min-width:0;padding:9px 14px;display:flex}.stage-hymn-num{color:#7dd3c7;background:#7dd3c71a;border:1px solid #7dd3c74d;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;min-width:28px;height:24px;padding:0 7px;font-size:.7rem;font-weight:850;display:inline-flex}.stage-hymn-title{text-overflow:ellipsis;white-space:nowrap;color:#ffffffb3;flex:1;min-width:0;font-size:.82rem;font-weight:600;overflow:hidden}.stage-hymn-meta{color:#ffffff52;white-space:nowrap;flex-shrink:0;font-size:.7rem}.host-stage .projection-main{position:relative;overflow:hidden}.host-stage .projection-main:after{content:"";pointer-events:none;background:radial-gradient(at 50% 60%,#7dd3c70d 0%,#0000 68%);position:absolute;inset:0}.host-stage .projection-text{font-size:clamp(2.1rem,6.4vw,5.7rem)}.host-stage-footer{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#080e0de0;border-top:1px solid #ffffff14;gap:10px;padding:12px 14px;display:grid}.host-live-title{align-items:center;gap:7px;margin:3px 0 0;font-size:1rem;line-height:1.15;display:flex}.live-dot{background:#9ca3af;border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.host-live-title.is-live .live-dot{background:#4ade80;animation:1.8s ease-in-out infinite dotPulse;box-shadow:0 0 0 3px #4ade802e}.host-status.is-live{animation:2.4s ease-in-out infinite livePulse}.progress-strip{background:#ffffff1f;border-radius:999px;height:3px;overflow:hidden}.progress-strip span{border-radius:inherit;background:#7dd3c7;height:100%;transition:width .3s;display:block}.host-panel{min-height:0;color:var(--ink);scrollbar-width:thin;align-content:start;gap:10px;display:grid;overflow:auto}.host-card{background:#fffdf8f7;border:1px solid #00000014;border-radius:12px;gap:12px;padding:16px;display:grid;box-shadow:0 2px 8px #0000001a,0 12px 32px #0000001f}.host-card-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.host-card h2{margin:3px 0 0;font-size:1rem;line-height:1.15}.host-kicker{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:.65rem;font-weight:850}.host-status,.host-count{border:1px solid var(--line);min-width:34px;min-height:28px;color:var(--muted);background:#fff;border-radius:999px;justify-content:center;align-items:center;padding:0 9px;font-size:.78rem;font-weight:850;display:inline-flex}.host-status.is-live{color:var(--jade-strong);background:#e5f6f1;border-color:#a6ded3}.host-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.host-metrics span{border:1px solid var(--line);min-width:0;min-height:36px;color:var(--muted);background:#f5f9f7;border-radius:8px;justify-content:center;align-items:center;gap:5px;padding:0 8px;font-size:.75rem;font-weight:780;display:inline-flex}.host-share-box{grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:8px;display:grid}.host-share-box>span{text-overflow:ellipsis;white-space:nowrap;border:1px solid var(--line);min-width:0;min-height:40px;color:var(--muted);background:#f5f9f7;border-radius:8px;align-items:center;padding:0 12px;font-size:.76rem;display:flex;overflow:hidden}.host-now-card p,.host-muted{color:var(--muted);margin:0;font-size:.84rem;line-height:1.42}.host-section-list,.host-hymn-list,.host-queue-list{scrollbar-width:thin;gap:7px;min-height:0;display:grid;overflow:auto}.host-section-list{max-height:34dvh}.host-hymn-list{max-height:260px}.host-queue-list{max-height:300px}.host-section-card,.host-hymn-card{border:1px solid var(--line);width:100%;color:var(--ink);text-align:left;background:#fff;border-radius:10px;gap:4px;transition:border-color .15s,background .15s;display:grid}.host-section-card{padding:10px 12px}.host-section-card:hover,.host-section-card.is-active,.host-hymn-card:hover,.host-hymn-card.is-active{background:#eef8f5;border-color:#9bd8ce}.host-section-index{color:var(--jade-strong);font-size:.72rem;font-weight:850}.host-section-card>span:last-child{color:#344a49;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.82rem;line-height:1.35;display:-webkit-box;overflow:hidden}.host-search{border:1px solid var(--line);min-height:44px;color:var(--muted);background:#fff;border-radius:10px;grid-template-columns:auto 1fr;align-items:center;gap:8px;padding:0 12px;transition:border-color .15s;display:grid}.host-search:focus-within{border-color:#7dd3c7}.host-search input{min-width:0;color:var(--ink);background:0 0;border:0;outline:0;font-size:.9rem}.host-filter-grid{grid-template-columns:1fr;gap:8px;display:grid}.host-select .custom-select-menu{max-height:min(260px,42dvh)}.host-queue-actions,.host-hymn-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;display:grid}.host-queue-item{border:1px solid var(--line);background:#fff;border-radius:10px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px;padding:8px;transition:border-color .15s,background .15s;display:grid}.host-queue-item.is-active{background:#eef8f5;border-color:#9bd8ce}.host-queue-item.is-dragging{opacity:.5;scale:.98}.host-drag-handle{width:24px;color:var(--muted);cursor:grab;place-items:center;display:grid}.host-queue-main{min-width:0;color:var(--ink);text-align:left;background:0 0;border:0;grid-template-columns:42px minmax(0,1fr);grid-template-areas:"number title""number meta";align-items:center;gap:2px 9px;display:grid}.host-queue-main>span{border:1px solid var(--line);width:34px;height:34px;color:var(--jade-strong);border-radius:8px;grid-area:number;place-items:center;font-size:.78rem;font-weight:850;display:grid}.host-queue-main strong{text-overflow:ellipsis;white-space:nowrap;grid-area:title;min-width:0;font-size:.84rem;overflow:hidden}.host-queue-main small{min-width:0;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;grid-area:meta;font-size:.72rem;overflow:hidden}.host-queue-tools{gap:4px;display:flex}.host-queue-tools .icon-button,.host-hymn-row>.icon-button{width:36px;min-width:36px;height:36px}.host-hymn-card{grid-template-columns:42px 1fr;align-items:center;min-height:50px;padding:8px 10px}.host-hymn-card span{border:1px solid var(--line);width:34px;height:34px;color:var(--jade-strong);border-radius:8px;place-items:center;font-size:.78rem;font-weight:850;display:grid}.host-hymn-card strong{text-overflow:ellipsis;white-space:nowrap;gap:2px;min-width:0;font-size:.86rem;display:grid;overflow:hidden}.host-hymn-card small{min-width:0;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:.71rem;font-weight:700;overflow:hidden}.host-controls-grid{grid-template-columns:auto 1fr auto;align-items:center;gap:8px;display:grid}.host-controls-grid span{border:1px solid var(--line);background:#f5f9f7;border-radius:8px;place-items:center;min-height:40px;font-weight:850;display:grid}.display-section{gap:8px;display:grid}.display-section-label{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);align-items:center;gap:5px;font-size:.65rem;font-weight:850;display:flex}.theme-grid{grid-template-columns:repeat(5,1fr);gap:6px;display:grid}.theme-swatch{aspect-ratio:1;cursor:pointer;border:2px solid #0000;border-radius:8px;place-items:center;font-size:.72rem;font-weight:700;transition:transform .12s,border-color .12s;display:grid}.theme-swatch:hover{transform:scale(1.08)}.theme-swatch.is-active{outline-offset:1px;border-color:#7dd3c7;outline:2px solid #7dd3c766}.display-color-row{align-items:center;gap:8px;display:flex}.display-color-pick{border:1px solid var(--line);cursor:pointer;background:#fff;border-radius:8px;flex:1;align-items:center;gap:8px;min-height:40px;padding:0 10px;transition:border-color .15s;display:flex;position:relative;overflow:hidden}.display-color-pick:hover{border-color:#7dd3c7}.display-color-pick input[type=color]{opacity:0;cursor:pointer;border:none;width:100%;height:100%;padding:0;position:absolute;inset:0}.display-color-preview{z-index:1;pointer-events:none;border:1px solid #0000001f;border-radius:5px;flex-shrink:0;width:22px;height:22px;display:block;position:relative}.display-color-hex{z-index:1;pointer-events:none;color:var(--muted);letter-spacing:.04em;font-family:Courier New,monospace;font-size:.76rem;font-weight:700;position:relative}.font-grid{grid-template-columns:repeat(5,1fr);gap:6px;display:grid}.font-btn{border:1px solid var(--line);cursor:pointer;background:#fff;border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;transition:border-color .15s,background .15s;display:flex}.font-btn:hover{background:#eef8f5;border-color:#9bd8ce}.font-btn.is-active{background:#eef8f5;border-color:#7dd3c7}.font-btn-sample{color:var(--ink);font-size:1.1rem;line-height:1}.font-btn-label{letter-spacing:.02em;color:var(--muted);text-transform:uppercase;font-family:system-ui,sans-serif;font-size:.6rem;font-weight:700}.host-theme-row{gap:8px;display:flex}.host-swatch{border:2px solid var(--line);border-radius:8px;width:44px;height:40px;font-weight:850;transition:outline .15s}.host-swatch.is-active{outline-offset:1px;outline:3px solid #0f766e38}.host-tab-bar{display:none}.spin{animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width:1100px){.host-workspace,.host-panel-collapsed .host-workspace{grid-template-rows:minmax(260px,44dvh) minmax(0,1fr);grid-template-columns:1fr}.host-panel-collapsed .host-workspace{grid-template-rows:1fr}.host-panel{grid-template-columns:repeat(2,minmax(0,1fr));align-content:start}.host-live-card,.host-now-card{grid-column:span 2}}@media (max-width:680px){.projection-bar{padding:10px 12px}.projection-bar .toolbar-row{gap:4px}.projection-page.is-host{grid-template-rows:auto 1fr}.host-workspace{grid-template-rows:auto 1fr;grid-template-columns:1fr;gap:8px;padding:8px;display:grid;overflow:hidden}.host-panel-collapsed .host-workspace{grid-template-rows:1fr}.host-stage{border-radius:10px}.host-stage .projection-main{padding:14px 12px}.host-stage .projection-text{font-size:clamp(1.5rem,8vw,3rem)}.host-stage-footer{gap:8px;padding:8px 10px}.host-tab-bar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);safe-area-inset-bottom:env(safe-area-inset-bottom);padding-bottom:env(safe-area-inset-bottom,0px);z-index:20;background:#0e1413f5;border-top:1px solid #ffffff1a;flex-shrink:0;align-items:stretch;display:flex;position:sticky;bottom:0}.host-tab{color:#ffffff6b;letter-spacing:.02em;text-transform:uppercase;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:0;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:8px 4px;font-size:.6rem;font-weight:700;transition:color .15s;display:flex}.host-tab.is-active{color:#7dd3c7}.host-tab-icon{justify-content:center;align-items:center;width:28px;height:28px;display:flex;position:relative}.host-tab-badge{color:#0c1110;background:#7dd3c7;border-radius:999px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:.6rem;font-weight:900;line-height:1;display:flex;position:absolute;top:-2px;right:-4px}.host-panel{grid-template-columns:1fr;padding-bottom:4px;overflow-y:auto}.host-panel [data-tabs]{display:none}.host-panel[data-mobile-tab=live] [data-tabs=live],.host-panel[data-mobile-tab=sections] [data-tabs=sections],.host-panel[data-mobile-tab=queue] [data-tabs=queue],.host-panel[data-mobile-tab=library] [data-tabs=library],.host-panel[data-mobile-tab=display] [data-tabs=display]{display:grid}.host-live-card,.host-now-card{grid-column:auto}.host-metrics{grid-template-columns:repeat(3,1fr);gap:6px}.host-section-list,.host-hymn-list,.host-queue-list{max-height:none}.client-hymn-header{padding:10px 16px 0}.projection-text{font-size:clamp(2rem,11vw,5rem)}}@media (min-width:580px){.brand-subtitle{display:block}.reader-header{padding:16px 22px 12px}.reader-content{padding-inline:56px}.reader-nav-prev{left:10px}.reader-nav-next{right:10px}}@media (min-width:900px){.layout-grid{grid-template-columns:360px minmax(0,1fr)}.library-pane{width:360px;max-width:360px}.desktop-sidebar,.library-pane,.library-pane:not(.is-active),.reader-pane,.reader-pane:not(.is-active){display:flex}.mobile-library-step{display:none!important}.mobile-reader-step,.mobile-reader-step:not(.is-active){display:flex}.mobile-only{display:none!important}.desktop-only{display:flex!important}.desktop-meta{display:inline-flex!important}.reader-nav-arrow{opacity:.35;width:32px;height:52px}.reader-nav-prev{left:4px}.reader-nav-next{right:4px}.reader-content{padding-bottom:110px;padding-inline:60px}.audio-dock{bottom:20px;left:386px;right:20px}.auth-panel{grid-template-columns:.95fr 1fr;align-items:stretch}.upload-panel{max-width:820px}}
