:root{--brand-navy:#1f3a5f;--brand-navy-d:#15293f;--brand-gold:#c9a227;--brand-gold-d:#a8861a;--bg:#f5f3ee;--surface:#fff;--surface-2:#faf8f3;--border:#e3ded3;--text:#2b2b2f;--text-muted:#6c6a73;--text-on-brand:#fff;--radius:10px;--shadow:0 1px 2px #15293f0f, 0 8px 24px -12px #15293f40;--sans:"Segoe UI", system-ui, Roboto, Helvetica, Arial, sans-serif;--serif:Georgia, "Times New Roman", serif;font:16px/1.5 var(--sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{min-height:100svh;margin:0}h1,h2,h3{font-family:var(--serif);color:var(--brand-navy);margin:0;font-weight:600}a{color:var(--brand-navy)}button{font:inherit;cursor:pointer}.app{grid-template-rows:auto 1fr;min-height:100svh;display:grid}.app-header{background:linear-gradient(180deg, var(--brand-navy) 0%, var(--brand-navy-d) 100%);color:var(--text-on-brand);box-shadow:var(--shadow);align-items:center;gap:28px;padding:10px 24px;display:flex}.brand{flex:none;align-items:center;display:flex}.brand-logo{width:auto;height:44px;display:block}.back-link{color:var(--text-on-brand);opacity:.9;flex:none;align-items:center;gap:6px;font-size:14px;text-decoration:none;display:inline-flex}.back-link:hover{color:var(--brand-gold);opacity:1}.back-link svg{display:block}.top-menu{align-items:center;gap:4px;display:flex}.menu-item{color:#ffffffd9;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:8px;padding:8px 14px;font-size:15px}.menu-item:hover{color:#fff;background:#ffffff14}.menu-item.active{color:var(--brand-gold);border-bottom-color:var(--brand-gold);border-radius:8px 8px 0 0}.header-spacer{flex:1}.logout-btn{color:var(--text-on-brand);background:0 0;border:1px solid #ffffff59;border-radius:8px;padding:6px 14px}.logout-btn:hover{border-color:var(--brand-gold);color:var(--brand-gold)}.login-btn{color:var(--text-on-brand);cursor:pointer;font:inherit;background:0 0;border:1px solid #ffffff59;border-radius:8px;padding:6px 14px}.login-btn:hover{border-color:var(--brand-gold);color:var(--brand-gold)}.main{padding:28px 32px;overflow:auto}.modal-overlay{z-index:200;background:#15293f73;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:14px;flex-direction:column;width:720px;max-width:100%;max-height:calc(100svh - 48px);display:flex;overflow:hidden;box-shadow:0 24px 60px -20px #00000073}.modal-head{background:linear-gradient(180deg, var(--brand-navy) 0%, var(--brand-navy-d) 100%);color:#fff;flex:none;justify-content:space-between;align-items:center;padding:16px 22px;display:flex}.modal-form{flex-direction:column;flex:auto;min-height:0;display:flex}.modal-head h2{color:#fff;font-size:20px}.modal-x{color:#fff;opacity:.85;background:0 0;border:none;padding:0 4px;font-size:26px;line-height:1}.modal-x:hover{opacity:1}.modal-body{flex:auto;min-height:0;padding:22px;overflow-y:auto}.field-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;display:grid}.field{flex-direction:column;gap:6px;display:flex}.field-wide{grid-column:1/-1}.field>span{color:var(--text);font-size:13px;font-weight:600}.field>span em{color:var(--brand-gold-d);font-style:normal}.field>span small{color:var(--text-muted);margin-left:4px;font-weight:400}.field input,.field textarea,.field select{font:inherit;border:1px solid var(--border);background:var(--surface);color:var(--text);resize:vertical;border-radius:8px;padding:9px 11px;font-size:14px}.field select{cursor:pointer}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--brand-navy);outline:none;box-shadow:0 0 0 3px #1f3a5f1f}.tag-pick{flex-wrap:wrap;gap:8px;display:flex}.tag-chip{font:inherit;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:999px;padding:6px 12px;font-size:13px}.tag-chip:hover{border-color:var(--brand-navy)}.tag-chip.on{background:var(--brand-navy);border-color:var(--brand-navy);color:#fff}.upload{flex-direction:column;gap:8px;display:flex}.upload-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.upload-btn{border:1px solid var(--brand-navy);color:var(--brand-navy);background:var(--surface);cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;padding:8px 14px;font-size:13px;font-weight:600;display:inline-flex}.upload-btn:hover{background:#1f3a5f0d}.upload-name{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:60%;font-size:13px;overflow:hidden}.upload-clear{color:#9a3b3b;cursor:pointer;background:0 0;border:none;padding:0;font-size:13px}.upload-clear:hover{text-decoration:underline}.thumb-preview{border:1px solid var(--border);object-fit:cover;border-radius:8px;width:auto;max-width:220px;max-height:140px}.audio-preview{width:100%;max-width:320px;height:36px}.upload-btn.busy{cursor:default;opacity:.85}.spinner{vertical-align:-2px;border:2px solid #1f3a5f40;border-top-color:var(--brand-navy);border-radius:50%;width:13px;height:13px;margin-right:7px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.upload-progress{background:var(--surface-2);border:1px solid var(--border);border-radius:999px;max-width:320px;height:6px;margin-top:8px;overflow:hidden}.upload-progress-bar{background:var(--brand-navy);height:100%;transition:width .15s}.yt-id{border:1px solid var(--border);background:var(--surface-2);color:var(--brand-navy);border-radius:8px;align-self:flex-start;padding:9px 11px;font-family:ui-monospace,Cascadia Code,Menlo,Consolas,monospace;font-size:13px;text-decoration:none}.yt-id:hover{border-color:var(--brand-navy)}.yt-id-empty{color:var(--text-muted);font-family:inherit;font-style:italic}.modal-note{color:var(--text-muted);background:var(--surface-2);border:1px dashed var(--border);border-radius:8px;margin:18px 0 0;padding:9px 12px;font-size:12px}.field-label{color:var(--text);font-size:13px;font-weight:600}.pe{flex-direction:column;gap:8px;display:flex}.pe-scroll{border:1px solid var(--border);border-radius:8px;overflow-x:auto}.pe-table{border-collapse:collapse;width:100%;font-size:13px}.pe-table th,.pe-table td{border-bottom:1px solid var(--border);border-right:1px solid var(--border);text-align:center;padding:0}.pe-table th{background:var(--surface-2);color:var(--text-muted);white-space:nowrap;padding:7px 8px;font-weight:600}.pe-table tbody tr:last-child td{border-bottom:none}.pe-table th:last-child,.pe-table td:last-child{border-right:none}.pe-rowlabel{background:var(--surface-2);width:30px;color:var(--text-muted);font-weight:600}.pe-book{text-align:left;min-width:150px}.pe-book select{width:100%;font:inherit;color:var(--text);background:0 0;border:none;padding:8px 10px}.pe-table input{width:100%;font:inherit;text-align:center;color:var(--text);-moz-appearance:textfield;background:0 0;border:none;padding:8px 6px}.pe-table input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.pe-table input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.pe-table select:focus,.pe-table input:focus{outline:2px solid var(--brand-navy);outline-offset:-2px;border-radius:4px}.pe-del{width:34px}.pe-del-btn{color:var(--text-muted);background:0 0;border:none;padding:4px 8px;font-size:18px;line-height:1}.pe-del-btn:hover{color:#9a3b3b}.pe-row-invalid td{background:#fbf1f1}.pe-row-invalid input,.pe-row-invalid select{color:#9a3b3b}.pe-summary{color:var(--text-muted);padding:2px 2px 0;font-size:13px}.pe-summary-label{color:var(--text);font-weight:600}.pe-warning{color:#9a3b3b;background:#fbf1f1;border:1px solid #d9b1b1;border-radius:8px;padding:8px 11px;font-size:13px}.modal-error{color:#8a2a2a;background:#fbf1f1;border:1px solid #d9b1b1;border-radius:8px;margin-top:16px;padding:10px 12px;font-size:13px}.modal-foot{border-top:1px solid var(--border);background:var(--surface);flex:none;justify-content:flex-end;gap:10px;padding:14px 22px;display:flex}.btn-ghost,.btn-primary{font:inherit;cursor:pointer;border-radius:8px;padding:9px 18px;font-size:14px}.btn-ghost{border:1px solid var(--border);color:var(--text);background:0 0}.btn-ghost:hover{border-color:var(--brand-navy)}.btn-primary{background:var(--brand-navy);border:1px solid var(--brand-navy);color:#fff}.btn-primary:hover:not(:disabled){background:var(--brand-navy-d)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}@media (width<=640px){.modal-overlay{padding:0}.modal{border-radius:0;width:100%;max-width:100%;height:100svh;max-height:100svh}.modal-body{padding:16px}.modal-head{padding:14px 16px}.modal-foot{padding:12px 16px}.btn-ghost,.btn-primary{flex:1;padding:11px 16px}.pe-table th{white-space:normal}.pe-book{min-width:110px}}.sermons{max-width:1180px;margin:0 auto}.page-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:20px;display:flex}.page-title{margin-bottom:2px;font-size:30px}.page-subtitle{color:var(--text-muted);margin:0}.btn-add{font:inherit;white-space:nowrap;border:1px solid var(--brand-navy);background:var(--brand-navy);color:#fff;border-radius:9px;padding:10px 18px;font-size:14px;font-weight:600}.btn-add:hover{background:var(--brand-navy-d)}.search{font:inherit;border:1px solid var(--border);background:var(--surface);width:240px;color:var(--text);border-radius:8px;padding:7px 12px;font-size:14px}.search:focus{border-color:var(--brand-navy);outline:none;box-shadow:0 0 0 3px #1f3a5f1f}.filters{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:18px;display:flex}.filters-spacer{flex:1}.result-count{color:var(--text-muted);white-space:nowrap;font-size:13px}.clear-all{border:1px solid var(--border);color:var(--brand-navy);background:0 0;border-radius:8px;padding:7px 12px;font-size:13px}.clear-all:hover{border-color:var(--brand-navy);background:#1f3a5f0d}.slicer{position:relative}.slicer-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:8px;align-items:center;gap:7px;padding:7px 12px;font-size:14px;display:inline-flex}.slicer-btn:hover{border-color:var(--brand-navy)}.slicer-btn.active{border-color:var(--brand-navy);background:#1f3a5f0d}.slicer-count{background:var(--brand-navy);color:#fff;border-radius:999px;place-items:center;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:600;display:inline-grid}.slicer-caret{color:var(--text-muted);font-size:10px}.slicer-panel{z-index:40;background:var(--surface);border:1px solid var(--border);min-width:200px;max-width:280px;box-shadow:var(--shadow);border-radius:10px;position:absolute;top:calc(100% + 6px);left:0;overflow:hidden}.slicer-panel-head{border-bottom:1px solid var(--border);letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);justify-content:space-between;align-items:center;padding:9px 12px;font-size:12px;display:flex}.slicer-clear{color:var(--brand-navy);text-transform:none;letter-spacing:0;background:0 0;border:none;padding:0;font-size:12px}.slicer-clear:hover{text-decoration:underline}.slicer-options{max-height:260px;padding:6px;overflow-y:auto}.slicer-option{cursor:pointer;border-radius:6px;align-items:center;gap:9px;padding:7px 8px;font-size:14px;display:flex}.slicer-option:hover{background:#1f3a5f0f}.slicer-option input{accent-color:var(--brand-navy);width:16px;height:16px}.slicer-empty{color:var(--text-muted);padding:10px 12px;font-size:13px}.date-range{background:var(--surface);border:1px solid var(--border);border-radius:8px;align-items:center;gap:8px;padding:5px 10px;display:inline-flex}.date-range-label{color:var(--text-muted);font-size:14px}.date-range-sep{color:var(--text-muted)}.date-input{font:inherit;color:var(--text);background:0 0;border:none;padding:2px 0;font-size:13px}.date-input:focus{outline:none}.passage-search{background:var(--surface);border:1px solid var(--border);border-radius:8px;align-items:center;gap:8px;padding:5px 10px;display:inline-flex}.passage-search:focus-within{border-color:var(--brand-navy)}.passage-search.invalid{background:#fbf4f4;border-color:#d9b1b1}.passage-search-label{color:var(--text-muted);white-space:nowrap;font-size:14px}.passage-input{font:inherit;color:var(--text);background:0 0;border:none;width:160px;padding:2px 0;font-size:13px}.passage-input:focus{outline:none}.notice{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);padding:20px}.notice.error{color:#8a2a2a;background:#fbf1f1;border-color:#d9b1b1}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto}.sermons-table{border-collapse:collapse;width:100%;font-size:14px}.sermons-table th,.sermons-table td{text-align:left;border-bottom:1px solid var(--border);vertical-align:top;padding:12px 14px}.sermons-table thead th{background:var(--surface-2);color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;font-size:12px;font-weight:600;position:sticky;top:0}.sermons-table tbody tr:last-child td{border-bottom:none}.sermons-table tbody tr:hover{background:#1f3a5f08}.nowrap{white-space:nowrap}.cell-title{min-width:240px}.cell-title .title{color:var(--brand-navy);font-weight:600}.cell-title .title-link{font:inherit;color:var(--brand-navy);cursor:pointer;text-align:left;background:0 0;border:none;padding:0;font-weight:600}.cell-title .title-link:hover{text-decoration:underline}.cell-title .title-text{color:var(--brand-navy);font-weight:600}.col-actions{white-space:nowrap;text-align:right;width:1%}.sermons-table .link-danger{color:#9a3b3b;cursor:pointer;background:0 0;border:none;padding:4px 6px;font-size:13px}.sermons-table .link-danger:hover{text-decoration:underline}.cell-title .desc{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:3px;font-size:13px;display:-webkit-box;overflow:hidden}.type-pill{background:var(--brand-navy);color:#fff;border-radius:999px;padding:2px 9px;font-size:12px;display:inline-block}.cell-tags{max-width:200px}.tag{background:var(--accent-bg,#c9a22724);color:var(--brand-gold-d);border:1px solid #c9a22759;border-radius:6px;margin:0 4px 4px 0;padding:2px 8px;font-size:12px;display:inline-block}.cell-passages{white-space:normal;min-width:150px}.passage-line{line-height:1.7;display:block}.passage-link{color:var(--brand-navy);white-space:nowrap;text-decoration:none}.passage-link:hover{text-decoration:underline}.passage-preview{z-index:100;background:var(--surface);border:1px solid var(--border);max-width:360px;max-height:320px;box-shadow:var(--shadow);text-align:left;pointer-events:none;border-radius:10px;padding:12px 14px;position:fixed;overflow:auto}.passage-preview .muted{color:var(--text-muted);font-size:13px}.passage-preview-text{color:var(--text);white-space:pre-wrap;font-size:13.5px;line-height:1.55;display:block}.col-resources{white-space:nowrap;width:1%}.resources{align-items:center;gap:10px;display:flex}.resources a{display:inline-flex}.resources img{object-fit:contain;width:26px;height:26px;transition:transform .1s}.resources a:hover img{transform:scale(1.12)}@media (width<=720px){.filters{flex-direction:column;align-items:stretch;gap:8px}.filters-spacer{display:none}.search,.slicer,.date-range,.passage-search{width:100%}.slicer-btn{justify-content:space-between;width:100%}.date-range,.passage-search{justify-content:space-between}.passage-input{flex:1;width:auto}.date-input{flex:1;min-width:0}.filters .result-count{text-align:right}.btn-add{width:100%}.table-wrap{box-shadow:none;background:0 0;border:none;overflow:visible}.sermons-table,.sermons-table tbody{display:block}.sermons-table thead{display:none}.sermons-table tr{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:10px;margin-bottom:14px;padding:4px 2px;display:block}.sermons-table td{border-bottom:1px solid var(--surface-2);white-space:normal;grid-template-columns:92px 1fr;gap:10px;width:auto;max-width:none;padding:8px 12px;display:grid}.sermons-table tr td:last-child{border-bottom:none}.sermons-table td:empty{display:none}.sermons-table td:before{content:attr(data-label);color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;padding-top:3px;font-size:11px;font-weight:600}.cell-title .title{font-size:16px}}.lookup{max-width:760px;margin:0 auto}.lookup-add{gap:10px;margin-bottom:18px;display:flex}.lookup-add input{font:inherit;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:8px;flex:1;padding:9px 12px;font-size:14px}.lookup-add input:focus{border-color:var(--brand-navy);outline:none;box-shadow:0 0 0 3px #1f3a5f1f}.lookup-add .btn-primary{font:inherit;white-space:nowrap;border:1px solid var(--brand-navy);background:var(--brand-navy);color:#fff;cursor:pointer;border-radius:8px;padding:9px 18px;font-size:14px;font-weight:600}.lookup-add .btn-primary:hover:not(:disabled){background:var(--brand-navy-d)}.lookup-add .btn-primary:disabled{opacity:.5;cursor:not-allowed}.lookup .notice{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);padding:18px}.lookup .notice.error{color:#8a2a2a;background:#fbf1f1;border-color:#d9b1b1}.lookup .table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.lookup-table{border-collapse:collapse;width:100%;font-size:14px}.lookup-table th,.lookup-table td{text-align:left;border-bottom:1px solid var(--border);padding:8px 14px}.lookup-table thead th{background:var(--surface-2);color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;font-size:12px}.lookup-table tbody tr:last-child td{border-bottom:none}.lookup-table tr.inactive{opacity:.55}.lookup .name-input{width:100%;font:inherit;color:var(--text);background:0 0;border:1px solid #0000;border-radius:6px;padding:6px 8px;font-size:14px}.lookup .name-input:hover{border-color:var(--border)}.lookup .name-input:focus{border-color:var(--brand-navy);background:var(--surface);outline:none}.lookup .col-active{width:130px}.lookup .switch{color:var(--text-muted);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:inline-flex}.lookup .switch input{accent-color:var(--brand-navy);width:16px;height:16px}.lookup .col-actions{text-align:right;width:80px}.lookup .link-danger{color:#9a3b3b;cursor:pointer;background:0 0;border:none;padding:4px 6px;font-size:13px}.lookup .link-danger:hover{text-decoration:underline}
