*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{color:#212529;background:#f8f9fa;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px}#app{height:100%}.login-wrapper{background:url(/bg-login.jpg) 50%/cover no-repeat fixed;justify-content:center;align-items:center;min-height:100%;padding:1rem;display:flex}.login-card{-webkit-backdrop-filter:blur(16px);background:#ffffffeb;border:1px solid #0000001a;border-radius:.5rem;flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:380px;padding:2rem 2rem 1.75rem;display:flex;box-shadow:0 .5rem 1.5rem #0003}.login-logo{width:64px;height:64px}.login-title{color:#212529;margin-top:-.25rem;font-size:1.25rem;font-weight:600}.login-card .input-group,.login-card .btn-primary{width:100%}.input-group{flex-direction:column;display:flex}.input-group input{color:#212529;background:#fff;border:1px solid #ced4da;outline:none;width:100%;padding:.5rem .75rem;font-size:1rem;transition:border-color .15s,box-shadow .15s}.input-group input:focus{z-index:1;border-color:#86b7fe;position:relative;box-shadow:0 0 0 .2rem #0d6efd40}.input-group input:first-child{border-bottom:none;border-radius:.375rem .375rem 0 0}.input-group input:last-child{border-radius:0 0 .375rem .375rem}.input-group input:only-child{border-bottom:1px solid #ced4da;border-radius:.375rem}.login-error{color:#dc3545;text-align:center;font-size:.875rem}:root{--nav-h:60px}.layout{height:100%;padding-bottom:var(--nav-h);flex-direction:column;display:flex;overflow:hidden}.content-panel{background:#fff;flex-direction:column;flex:1;display:flex;overflow:hidden}.tab-pane{flex-direction:column;flex:1;display:flex;overflow:hidden}.tab-pane.hidden{display:none}.pane-scroll{-webkit-overflow-scrolling:touch;flex:1;padding:.5rem;overflow-y:auto}.search-bar{background:#f8f9fa;border-bottom:1px solid #dee2e6;flex-shrink:0;padding:.625rem .75rem}.search-bar input[type=search]{color:#212529;background:#fff;border:1px solid #ced4da;border-radius:.375rem;outline:none;width:100%;padding:.5rem .75rem;font-size:1rem;transition:border-color .15s,box-shadow .15s}.search-bar input[type=search]:focus{border-color:#86b7fe;box-shadow:0 0 0 .2rem #0d6efd40}.admin-actions{flex-direction:column;gap:.5rem;padding:.25rem 0;display:flex}.admin-action-btn{color:#212529;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;background:#fff;border:1px solid #e9ecef;border-radius:.5rem;justify-content:space-between;align-items:center;width:100%;min-height:52px;padding:.875rem 1rem;font-size:.95rem;transition:background .12s;display:flex}.admin-action-btn:hover{background:#f8f9fa}.admin-action-btn--danger{color:#dc3545}.admin-action-btn--danger:hover{background:#fff1f2}.admin-action-btn:disabled{opacity:.5;cursor:not-allowed}.bottom-nav{height:var(--nav-h);z-index:200;background:#fff;border-top:1px solid #dee2e6;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 12px #00000012}.bottom-nav-btn{cursor:pointer;color:#6c757d;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.2rem;padding:.375rem .25rem;font-size:.7rem;font-weight:500;line-height:1;transition:color .15s,background .15s;display:flex}.bottom-nav-btn svg{flex-shrink:0}.bottom-nav-btn:hover{color:#495057;background:#f8f9fa}.bottom-nav-btn.active{color:#0d6efd}.bottom-nav-btn.active svg{filter:drop-shadow(0 0 #0d6efd)}.viewer{inset:0;bottom:var(--nav-h);z-index:100;background:#e9ecef;flex-direction:column;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;transform:translate(100%)}.viewer.viewer-active{transform:translate(0)}.btn-back-song{justify-content:center;align-items:center;display:inline-flex}.event-acc{border-bottom:1px solid #e9ecef}.event-acc-header{cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;align-items:center;gap:.5rem;min-height:48px;padding:.625rem .75rem;transition:background .15s;display:flex}.event-acc-header:hover{background:#f0f4ff}.event-acc.open>.event-acc-header{background:#e7f1ff}.event-acc.open>.event-acc-header:hover{background:#dbeafe}.event-acc-chevron{color:#adb5bd;flex-shrink:0;width:1.1rem;font-size:1.1rem;line-height:1}.event-acc-chevron:before{content:"▸"}.event-acc.open>.event-acc-header .event-acc-chevron:before{content:"▾";color:#0d6efd}.event-acc-info{flex-direction:column;gap:.05rem;min-width:0;display:flex}.event-date{color:#6c757d;letter-spacing:.01em;font-size:.75rem;font-weight:500}.event-acc.open>.event-acc-header .event-date{color:#084298}.event-name{color:#212529;white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;overflow:hidden}.event-acc.open>.event-acc-header .event-name{color:#084298}.event-acc-body{background:#f0f4ff;border-top:2px solid #0d6efd;border-bottom:2px solid #dee2e6;flex-direction:column;gap:.25rem;padding:.5rem;display:none}.event-acc.open>.event-acc-body{display:flex}.song-item{cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fff;border:1px solid #e9ecef;border-radius:.375rem;flex-direction:column;justify-content:center;gap:.15rem;min-height:44px;padding:.5rem .625rem;transition:background .1s;display:flex}.song-item:hover{background:#e9ecef;border-color:#dee2e6}.song-item.selected{background:#cfe2ff;border-color:#93c5fd;border-left-style:solid;border-left-width:3px;padding-left:calc(.625rem - 3px)}.song-item.selected:hover{background:#b6d4fe}.song-name{font-size:.95rem;font-weight:500;line-height:1.3}.song-source{color:#6c757d;font-variant-numeric:tabular-nums;letter-spacing:.02em;font-size:.75em;font-weight:700}.song-author{color:#6c757d;font-size:.8rem;line-height:1.2}.panel-hint{color:#6c757d;padding:.5rem;font-size:.875rem}.panel-error{color:#dc3545;padding:.5rem;font-size:.875rem}.viewer{background:#e9ecef;flex-direction:column;flex:1;height:100%;display:flex;overflow:hidden}.viewer-topbar{background:#fff;border-bottom:1px solid #dee2e6;flex-shrink:0;align-items:center;gap:.75rem;padding:.5rem .75rem;display:flex}.viewer-no-song{color:#adb5bd;font-size:.9rem}.viewer-header{background:#fff;border-bottom:1px solid #dee2e6;flex-direction:column;flex-shrink:0;display:flex}.viewer-row1{align-items:center;gap:.4rem;min-width:0;padding:.4rem .625rem;display:flex}.viewer-source-prefix{color:#6c757d;white-space:nowrap;font-variant-numeric:tabular-nums;background:#e9ecef;border-radius:.25rem;flex-shrink:0;padding:.1rem .35rem;font-size:.7rem;font-weight:700}.viewer-title{white-space:nowrap;text-overflow:ellipsis;color:#212529;flex:1;min-width:0;font-size:.9rem;font-weight:600;overflow:hidden}.viewer-ccli{color:#6c757d;white-space:nowrap;font-size:.7rem;text-decoration:none}.viewer-ccli:hover{text-decoration:underline}.toast{color:#fff;opacity:0;pointer-events:none;z-index:9999;white-space:normal;text-align:center;background:#198754;border-radius:.5rem;max-width:min(90vw,480px);padding:.6rem 1.25rem;font-size:.85rem;transition:opacity .25s,transform .25s;position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%)translateY(1rem);box-shadow:0 4px 12px #0003}.toast--error{background:#dc3545}.toast--visible{opacity:1;transform:translate(-50%)translateY(0)}.arr-meta{flex-shrink:0;align-items:flex-end;display:flex}.arr-meta-inner{flex-direction:column;align-items:flex-end;gap:.1rem;display:flex}.arr-meta-line1{color:#495057;white-space:nowrap;font-size:.7rem;font-weight:600}.arr-meta-line2{color:#6c757d;white-space:nowrap;gap:.5rem;font-size:.68rem;display:flex}.meta-label{color:#adb5bd;margin-right:.15rem;font-weight:600}.viewer-row2{background:#f8f9fa;border-top:1px solid #e9ecef;align-items:center;gap:.4rem;min-width:0;padding:.3rem .625rem;display:flex;overflow:hidden}.viewer-row2-left{flex-direction:row;flex:1;align-items:center;gap:.5rem;min-width:0;display:flex;overflow:hidden}.arr-tabs{flex-wrap:nowrap;gap:.25rem;min-width:0;display:flex;overflow:hidden}.viewer-row2-right{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.arr-media{align-items:center;gap:.4rem;display:flex}.arr-audio{flex:1;min-width:180px;max-width:320px;height:2rem}.arr-yt-audio-wrap{flex-shrink:1;align-items:center;min-width:0;display:flex}.yt-audio{background:#dc3545;border-radius:.375rem;align-items:center;gap:.4rem;min-width:0;padding:.25rem .5rem;display:flex}.yt-audio-btn{color:#fff;cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;font-size:1rem;line-height:1}.yt-audio-time{color:#fff;font-variant-numeric:tabular-nums;flex-shrink:0;font-size:.7rem}.yt-audio-seek{accent-color:#fff;cursor:pointer;flex:1;min-width:60px;max-width:200px;height:3px}.yt-external-link{color:#fffc;flex-shrink:0;align-items:center;padding-left:.2rem;display:inline-flex}.yt-external-link:hover{color:#fff}.song-multi-pdf{color:#ffc107;cursor:help;margin-left:.3rem;font-size:.85em}.arr-tab{color:#495057;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #dee2e6;border-radius:.375rem;padding:.25rem .625rem;font-size:.8rem;transition:background .1s,color .1s,border-color .1s}.arr-tab:hover{background:#e9ecef;border-color:#adb5bd}.arr-tab.active{color:#fff;background:#0d6efd;border-color:#0d6efd}.viewer-body{flex-direction:column;flex:1;display:flex;position:relative;overflow:visible}.pdf-container{background:#495057;flex:1;position:relative;overflow:hidden}.pdf-container:before{content:"";opacity:.12;pointer-events:none;z-index:0;filter:invert();background:url(/logo.svg) 50%/240px 240px no-repeat;position:absolute;inset:0}.pdf-spread{z-index:1;flex-direction:row;justify-content:center;align-items:center;gap:2px;display:flex;position:absolute;inset:0}.pdf-page{display:block;box-shadow:0 .25rem .75rem #00000080}.pdf-nav{cursor:pointer;z-index:2;background:0 0;align-items:center;width:20%;height:100%;transition:background .15s;display:flex;position:absolute;top:0}.pdf-nav-left{justify-content:flex-start;padding-left:.75rem;left:0}.pdf-nav-right{justify-content:flex-end;padding-right:.75rem;right:0}.pdf-nav-hidden{display:none}.pdf-nav:hover,.pdf-nav-active{background:#00000040}.pdf-nav-arrow{color:#ffffffd9;opacity:0;pointer-events:none;font-size:2.5rem;font-weight:300;line-height:1;transition:opacity .15s}.pdf-nav:hover .pdf-nav-arrow,.pdf-nav-active .pdf-nav-arrow{opacity:1}.pdf-loading{color:#adb5bd}.btn-fullscreen-overlay{z-index:10;cursor:pointer;opacity:0;-webkit-tap-highlight-color:transparent;background:#ffffffb3;border:none;border-radius:.375rem;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;font-size:1rem;transition:opacity .2s;display:flex;position:absolute;top:.5rem;right:.5rem}@media (hover:none){.btn-fullscreen-overlay{opacity:.7}}.viewer-body:hover .btn-fullscreen-overlay{opacity:1}body.app-fullscreen .bottom-nav,body.app-fullscreen .content-panel,body.app-fullscreen .viewer-header{display:none!important}body.app-fullscreen .viewer{background:#000;z-index:500!important;transition:none!important;position:fixed!important;inset:0!important;transform:none!important}body.app-fullscreen .viewer-topbar{display:none!important}body.app-fullscreen #viewer-body{-webkit-overflow-scrolling:touch;flex:1;overflow:auto}body.app-fullscreen .btn-fullscreen-overlay{top:max(.75rem, env(safe-area-inset-top))!important;right:max(.75rem, env(safe-area-inset-right))!important;z-index:600!important;opacity:1!important;color:#fff!important;background:#00000080!important;border-radius:50%!important;width:2.5rem!important;height:2.5rem!important;font-size:1rem!important;position:fixed!important}.btn-spread{flex-shrink:0;justify-content:center;align-items:center;padding:.25rem .4rem;display:inline-flex}.yt-wrapper{background:#212529;flex:1;justify-content:center;align-items:center;padding:1rem;display:flex}.yt-frame{aspect-ratio:16/9;border:none;border-radius:.5rem;width:100%;max-width:960px}.btn-primary{color:#fff;cursor:pointer;background:#0d6efd;border:1px solid #0d6efd;border-radius:.375rem;padding:.5rem 1rem;font-size:1rem;font-weight:500;transition:background .15s,border-color .15s}.btn-primary:hover{background:#0b5ed7;border-color:#0a58ca}.btn-icon{cursor:pointer;color:#495057;background:#fff;border:1px solid #dee2e6;border-radius:.375rem;flex-shrink:0;padding:.25rem .5rem;font-size:.875rem;line-height:1;transition:background .1s,border-color .1s}.btn-icon:hover{background:#e9ecef;border-color:#adb5bd}@media (width>=768px){.layout{grid-template-rows:1fr auto;grid-template-columns:min(340px,38vw) 1fr;padding-bottom:0;display:grid}.content-panel{border-right:1px solid #dee2e6;grid-area:1/1;width:auto;overflow:hidden}.viewer{flex:unset;grid-area:1/2/3;transition:none;position:relative;transform:none!important}.bottom-nav{width:auto;height:var(--nav-h);box-shadow:none;grid-area:2/1;position:static}.btn-back-song{display:none}}.authoring-layout{background:#f0f2f5;flex-direction:column;height:100vh;display:flex;overflow:hidden}.authoring-tabs{background:#fff;border-bottom:2px solid #dee2e6;flex-shrink:0;display:flex}.authoring-tab{color:#6c757d;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-2px;padding:.7rem;font-size:.9rem;font-weight:500;transition:color .15s,border-color .15s}.authoring-tab.active{color:#0d6efd;border-bottom-color:#0d6efd}.authoring-left,.authoring-right{flex-direction:column;flex:1;display:none;overflow:hidden}.authoring-left.panel-active,.authoring-right.panel-active{display:flex}@media (width>=768px){.authoring-layout{flex-direction:row}.authoring-tabs{display:none}.authoring-left{background:#fff;border-right:1px solid #dee2e6;flex-shrink:0;width:320px;display:flex}.authoring-right{display:flex}}.authoring-left-header{border-bottom:1px solid #dee2e6;flex-shrink:0;align-items:center;gap:.75rem;padding:1rem;display:flex}.authoring-left-header h2{margin:0;font-size:1rem;font-weight:600}.btn-back{cursor:pointer;color:#6c757d;white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:.25rem .5rem;font-size:.9rem}.btn-back:hover{background:#f0f2f5}.authoring-controls{border-bottom:1px solid #dee2e6;flex-shrink:0;padding:.75rem 1rem}.authoring-source-row{align-items:center;gap:.5rem;display:flex}.authoring-select{background:#fff;border:1px solid #ced4da;border-radius:6px;flex:1;min-width:0;padding:.4rem .6rem;font-size:.875rem}.btn-icon-sm{cursor:pointer;color:#495057;background:0 0;border:1px solid #ced4da;border-radius:6px;flex-shrink:0;padding:.35rem .6rem;font-size:1rem;line-height:1;transition:background .1s}.btn-icon-sm:hover:not(:disabled){background:#f0f2f5}.btn-icon-sm:disabled{opacity:.4;cursor:default}.authoring-song-list{flex:1;overflow-y:auto}.authoring-song-item{cursor:pointer;border-bottom:1px solid #f0f2f5;align-items:center;gap:.5rem;padding:.6rem 1rem;font-size:.875rem;transition:background .1s;display:flex}.authoring-song-item:hover{background:#f8f9fa}.authoring-song-item.active{background:#e7f3ff}.song-status{text-align:center;color:#6c757d;flex-shrink:0;width:1.1rem}.authoring-song-item.has-files .song-status{color:#28a745}.song-ref{color:#6c757d;flex-shrink:0;width:2.5rem;font-size:.8rem}.song-title{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.song-key{color:#6c757d;flex-shrink:0;font-size:.8rem}.authoring-book-bar{background:#fff;border-bottom:1px solid #dee2e6;flex-shrink:0;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.authoring-book-bar .authoring-select{flex:1}.btn-upload-book{cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #ced4da;border-radius:6px;flex-shrink:0;padding:.4rem .75rem;font-size:.85rem}.btn-upload-book:hover{background:#f8f9fa}.authoring-viewer{background:#868e96;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.75rem;padding:.75rem;display:flex;overflow:hidden}.authoring-pdf-nav{color:#fff;background:#00000080;border-radius:20px;flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem;padding:.4rem .75rem;font-size:.85rem;display:flex}.authoring-page-input{text-align:center;border:1px solid #adb5bd;border-radius:4px;width:4rem;padding:.2rem .4rem;font-size:.85rem}.authoring-canvas-wrap{cursor:pointer;flex-shrink:0;position:relative;box-shadow:0 4px 20px #0006}.authoring-canvas{display:block}.page-overlay{color:#ffffffd9;background:#00000014;justify-content:center;align-items:flex-end;padding-bottom:.75rem;font-size:.85rem;font-weight:600;transition:background .15s;display:flex;position:absolute;inset:0}.page-overlay--selected{color:#28a745;background:#28a74540}.authoring-canvas-wrap.mode-regions{cursor:crosshair}.region-draw-overlay{z-index:10;cursor:crosshair;position:absolute;inset:0}.region-preview{pointer-events:none;background:#0d6efd1f;border:2px dashed #0d6efd;position:absolute}.region-rect{z-index:5;pointer-events:none;background:#0d6efd21;border:2px solid #0d6efd;position:absolute}.region-num{color:#0d6efd;pointer-events:none;background:#ffffffe6;border-radius:3px;padding:0 3px;font-size:.68rem;font-weight:700;line-height:1.5;position:absolute;top:2px;left:4px}.region-del{color:#fff;cursor:pointer;pointer-events:all;background:#dc3545d9;border:none;border-radius:3px;justify-content:center;align-items:center;width:18px;height:18px;padding:0;font-size:.8rem;line-height:1;display:flex;position:absolute;top:2px;right:2px}.region-del:hover{background:#dc3545}.btn-mode-toggle{color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff26;border:1px solid #ffffff80;border-radius:12px;flex-shrink:0;padding:.2rem .65rem;font-size:.75rem;transition:background .15s}.btn-mode-toggle:hover{background:#ffffff40}.btn-mode-toggle.mode-regions{background:#0d6efd8c;border-color:#0d6efdcc}.nav-sep{color:#ffffff4d;-webkit-user-select:none;user-select:none}.authoring-action-bar{background:#fff;border-top:1px solid #dee2e6;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.action-bar-info{flex-direction:column;flex:1;gap:.15rem;min-width:0;display:flex}.action-bar-controls{flex-shrink:0;align-items:center;gap:.75rem;display:flex}.authoring-selected-song{text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:600;overflow:hidden}.authoring-selected-pages{color:#6c757d;font-size:.8rem}.authoring-checkbox{cursor:pointer;white-space:nowrap;align-items:center;gap:.4rem;font-size:.8rem;display:flex}.btn-primary{color:#fff;cursor:pointer;white-space:nowrap;background:#0d6efd;border:none;border-radius:8px;padding:.5rem 1.25rem;font-size:.9rem;font-weight:600;transition:background .15s}.btn-primary:hover:not(:disabled){background:#0b5ed7}.btn-primary:disabled{opacity:.5;cursor:default}.authoring-modal-backdrop{z-index:500;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.authoring-modal-backdrop[hidden]{display:none}.authoring-modal{background:#fff;border-radius:12px;flex-direction:column;gap:1rem;width:100%;max-width:440px;padding:1.5rem;display:flex;box-shadow:0 8px 32px #0003}.authoring-modal h3{margin:0;font-size:1.1rem;font-weight:600}.authoring-input{box-sizing:border-box;border:1px solid #ced4da;border-radius:6px;width:100%;padding:.5rem .75rem;font-size:.875rem}.authoring-modal-actions{justify-content:flex-end;gap:.75rem;display:flex}.authoring-modal-actions button{cursor:pointer;background:#fff;border:1px solid #ced4da;border-radius:6px;padding:.5rem 1rem;font-size:.875rem}.authoring-hint{color:#6c757d;text-align:center;margin:0;padding:2rem 1rem;font-size:.9rem}.authoring-hint.error{color:#dc3545}.authoring-toast{color:#fff;z-index:1000;white-space:nowrap;background:#28a745;border-radius:20px;padding:.6rem 1.5rem;font-size:.9rem;font-weight:600;animation:.2s fadeInUp;position:fixed;bottom:2rem;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0003}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.sync-modal-backdrop{z-index:900;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.sync-modal{background:#fff;border-radius:16px;flex-direction:column;gap:1.25rem;width:100%;max-width:400px;padding:2rem;display:flex;box-shadow:0 8px 40px #00000040}.sync-modal h3{margin:0;font-size:1.1rem;font-weight:600}.sync-progress-wrap{background:#e9ecef;border-radius:999px;height:10px;overflow:hidden}.sync-progress-bar{background:#0d6efd;border-radius:999px;width:0%;height:100%;transition:width .4s}.sync-progress-bar--indeterminate{animation:1.4s ease-in-out infinite syncIndeterminate;width:40%!important}@keyframes syncIndeterminate{0%{margin-left:-40%}to{margin-left:100%}}.sync-progress-label{color:#6c757d;text-align:center;margin:0;font-size:.875rem}.btn-sync-cancel{color:#dc3545;cursor:pointer;background:0 0;border:1px solid #dc3545;border-radius:8px;align-self:center;padding:.45rem 1.5rem;font-size:.875rem;transition:background .15s,color .15s}.btn-sync-cancel:hover:not(:disabled){color:#fff;background:#dc3545}.btn-sync-cancel:disabled{opacity:.5;cursor:default}
