:root{--bg:#f4f6f4;--surface:#fff;--surface-soft:#f8faf9;--ink:#1f2430;--muted:#647084;--line:#dce3e8;--accent:#8f2434;--accent-strong:#741b29;--accent-soft:#f8e9ec;--green:#2f7d6d;--green-soft:#e8f4f1;--gold:#c79b3b;--gold-soft:#fff8e8;--blue:#286fae;--danger:#b42318;--shadow:0 18px 40px #1f243014;color:var(--ink);background:var(--bg);font-family:Inter,Segoe UI,Roboto,Arial,sans-serif}*{box-sizing:border-box}html{min-height:100%}body{background:linear-gradient(180deg, #8f243414, transparent 300px), linear-gradient(90deg, #2f7d6d0f, transparent 42%), var(--bg);min-height:100vh;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}textarea{resize:vertical;min-height:112px}.app-shell{width:min(1540px,100% - 32px);margin:0 auto;padding:18px 0 28px}.topbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.brand{align-items:center;gap:12px;min-width:230px;display:flex}.brand-mark{filter:drop-shadow(0 10px 20px #8f243433);flex:none;width:54px;height:54px}.brand-saint{background:#fff;border:3px solid #ffffffeb;border-radius:50%;flex:none;width:44px;height:44px;margin-left:-18px;box-shadow:0 10px 24px #1f24301f}.brand strong{margin-top:2px;font-size:1.55rem;line-height:1.05;display:block}.eyebrow{color:var(--muted);letter-spacing:0;text-transform:uppercase;font-size:.72rem;font-weight:850;display:block}.tabs,.topbar-actions,.inline-actions,.preview-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.tab-button,.button,.icon-button{border:1px solid var(--line);background:var(--surface);min-height:42px;color:var(--ink);border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:800;display:inline-flex;box-shadow:0 1px #1f24300a}.button,.tab-button{padding:0 13px}.icon-button{width:42px;padding:0}.tab-button.active,.button.primary{border-color:var(--accent);background:var(--accent);color:#fff}.button.success{border-color:var(--green);background:var(--green);color:#fff}.button.danger{color:var(--danger)}.button:disabled,.tab-button:disabled{cursor:not-allowed;opacity:.58}.button.ghost{background:0 0}.button:hover,.button:focus-visible,.tab-button:hover,.tab-button:focus-visible,.icon-button:hover,.icon-button:focus-visible{border-color:#8f243473;outline:none}.button svg,.tab-button svg,.icon-button svg,.field-icon{flex:none;width:18px;height:18px}.workspace,.admin-workspace{align-items:start;gap:16px;display:grid}.workspace{grid-template-columns:minmax(300px,.82fr) minmax(0,1.55fr)}.admin-workspace{grid-template-columns:minmax(280px,.78fr) minmax(0,1.45fr)}.panel{border:1px solid var(--line);min-width:0;box-shadow:var(--shadow);background:#fffffff0;border-radius:8px}.panel-heading{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:12px;min-height:72px;padding:16px;display:flex}.panel-heading h1,.panel-heading h2,.panel-heading h3{margin:2px 0 0;font-size:1.08rem;line-height:1.2}.panel-body{padding:16px}.side-panel{position:sticky;top:16px}.hero-panel{overflow:hidden}.hero-strip{border-bottom:1px solid var(--line);color:#fff;background:linear-gradient(135deg,#8f2434e6,#2f7d6dd6),url(/assets/church-mark.svg) right 22px center/190px no-repeat;grid-template-columns:1.15fr .85fr;min-height:240px;display:grid}.hero-copy{align-content:end;gap:10px;padding:28px;display:grid}.hero-copy h1{max-width:680px;margin:0;font-size:clamp(2rem,4vw,4rem);line-height:.98}.hero-meta{flex-wrap:wrap;gap:8px;display:flex}.pill,.status-pill{background:var(--surface-soft);min-height:30px;color:var(--muted);border-radius:999px;align-items:center;gap:7px;padding:0 10px;font-size:.82rem;font-weight:850;display:inline-flex}.hero-meta .pill{color:#fff;background:#ffffff24}.status-pill.published{background:var(--green-soft);color:var(--green)}.status-pill.draft{background:var(--gold-soft);color:#775512}.status-pill.archived{background:var(--surface-soft);color:var(--muted)}.content-grid{flex-direction:column;gap:14px;display:flex}.reading-block{border:1px solid var(--line);background:var(--surface);border-radius:8px;gap:14px;width:100%;min-width:0;padding:18px;display:grid}.content-grid>.reading-block:last-child{gap:8px}.reading-block h3,.reading-block h4{color:var(--accent);margin:0;font-size:.95rem}.reading-block.full-content{white-space:pre-line;grid-column:1/-1}.reading-block p{white-space:pre-line;margin:0;line-height:1.7}.reading-block .reading-section p{margin:0;padding-bottom:.85rem}.reading-block .reading-section{gap:8px;display:grid}.reading-block .reading-section strong{color:var(--accent);text-transform:uppercase;letter-spacing:.02em;font-size:1rem;font-weight:700;display:block}.booklet-layout{grid-template-columns:minmax(280px,.62fr) minmax(0,1.6fr);align-items:start;gap:16px;display:grid}.booklet-stage{gap:12px;min-width:0;display:grid}.booklet-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.booklet-sheet{color:#201b19;background:#fffdf7;border:1px solid #cfc7b8;border-radius:8px;min-width:0;overflow:hidden;box-shadow:0 24px 50px #1f24301f}.booklet-masthead{color:#fff;background:#b3262f;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.booklet-brandline{align-items:center;gap:10px;min-width:0;display:flex}.booklet-brandline img{background:#ffffff29;border-radius:8px;flex:none;width:46px;height:46px;padding:5px}.booklet-brandline strong{font-size:clamp(1.45rem,3vw,2.35rem);line-height:.95;display:block}.booklet-brandline span,.booklet-date span{letter-spacing:0;text-transform:uppercase;font-size:.72rem;font-weight:850;display:block}.booklet-date{text-align:right;border-left:1px solid #ffffff5c;flex:none;min-width:116px;padding-left:12px}.booklet-date strong{margin-top:3px;font-size:1.1rem;display:block}.booklet-cover{background:linear-gradient(90deg,#fffaf0 0%,#fffdf7 58%,#eef8f4 100%);border-bottom:1px solid #ded3c0;grid-template-columns:minmax(0,1fr) 132px;align-items:center;gap:16px;padding:18px;display:grid}.booklet-cover h1{color:var(--accent);margin:4px 0 8px;font-size:clamp(1.8rem,4vw,3.4rem);line-height:.98}.booklet-cover p{color:var(--muted);margin:0;font-weight:750;line-height:1.45}.booklet-cover-mark{aspect-ratio:1;background:#ffffffb8;border:2px solid #8f243438;border-radius:50%;place-items:center;width:132px;margin:0;display:grid}.booklet-cover-mark img{width:106px;height:106px}.booklet-flow{column-count:3;column-rule:1px solid #ded3c0;column-gap:18px;padding:18px;font-family:Georgia,Times New Roman,serif}.booklet-item{break-inside:avoid;border-bottom:1px solid #ded3c0;margin:0 0 18px;padding-bottom:12px}.booklet-item h2,.booklet-reading h3{color:var(--accent);margin:0 0 8px;font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;font-size:.96rem;line-height:1.2}.booklet-item h2 span{font-weight:950}.booklet-reading{break-inside:avoid;margin-bottom:12px}.booklet-reading h3{text-transform:uppercase}.booklet-item p,.booklet-imported{white-space:pre-line;margin:0 0 10px;font-size:.94rem;line-height:1.48}.booklet-imported *{max-width:100%}.history-list,.prayer-list,.admin-list{gap:8px;display:grid}.list-button,.chapter-button{border:1px solid var(--line);background:var(--surface);width:100%;min-width:0;color:var(--ink);text-align:left;border-radius:8px}.list-button{gap:5px;padding:12px;display:grid}.list-button strong{overflow-wrap:anywhere}.list-button span{color:var(--muted);font-size:.84rem}.list-button.active{border-color:var(--accent);background:var(--accent-soft)}.form-grid,.selector-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.mass-form{gap:14px;display:grid}label{gap:6px;min-width:0;display:grid}label span{color:var(--muted);font-size:.82rem;font-weight:800}input,select,textarea{border:1px solid var(--line);background:var(--surface-soft);width:100%;min-width:0;color:var(--ink);border-radius:8px;outline:0}input,select{min-height:42px;padding:0 11px}textarea{padding:10px 11px;line-height:1.45}input:focus,select:focus,textarea:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px #286fae24}.book-layout,.prayer-layout{grid-template-columns:minmax(260px,.72fr) minmax(0,1.28fr);gap:16px;display:grid}.chapter-grid{grid-template-columns:repeat(auto-fit,minmax(52px,1fr));gap:8px;margin-top:12px;display:grid}.chapter-button{text-align:center;min-height:40px;padding:0 6px;font-weight:850}.chapter-button.active{border-color:var(--green);background:var(--green-soft);color:var(--green)}.verse-list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.verse-list li{grid-template-columns:36px minmax(0,1fr);gap:10px;line-height:1.62;display:grid}.verse-number{color:var(--accent);text-align:right;font-weight:900}.empty-state,.notice{border:1px dashed var(--line);background:var(--surface-soft);color:var(--muted);border-radius:8px;padding:14px;line-height:1.5}.prayer-text{font-size:1.08rem;line-height:1.68}.step-list{gap:8px;margin:0;padding-left:20px;line-height:1.5;display:grid}.login-shell{width:min(480px,100% - 32px);margin:48px auto}.admin-header{margin-bottom:16px}.admin-form{gap:12px;display:grid}.admin-list{max-height:calc(100vh - 212px);overflow:auto}.admin-preview{gap:10px;display:grid}.error-text{color:var(--danger);font-weight:800}.success-text{color:var(--green);font-weight:800}@media (max-width:1180px){.workspace,.admin-workspace,.booklet-layout,.book-layout,.prayer-layout,.install-hero,.install-grid{grid-template-columns:1fr}.side-panel{position:static}}@media (max-width:760px){.app-shell{width:min(100% - 20px,720px);padding-top:12px}.topbar{flex-direction:column;align-items:stretch}.tabs,.topbar-actions,.inline-actions{grid-template-columns:1fr 1fr;display:grid}.button,.tab-button{width:100%}.hero-strip,.content-grid,.booklet-cover,.form-grid,.selector-grid{grid-template-columns:1fr}.hero-strip{background:linear-gradient(135deg,#8f2434eb,#2f7d6de0),url(/assets/church-mark.svg) right -22px bottom -28px/150px no-repeat;min-height:220px}.hero-copy{padding:22px}.panel-heading{flex-direction:column;align-items:stretch}}@media (max-width:480px){.tabs,.topbar-actions,.inline-actions{grid-template-columns:1fr}.brand{min-width:0}.brand-mark{width:48px;height:48px}.brand-saint{width:38px;height:38px;margin-left:-16px}.panel-heading,.panel-body{padding:12px}.install-shell{width:min(100% - 20px,720px)}.install-hero{padding:18px}.phone-screen{width:min(220px,100%)}}@media print{body{background:#fff}.topbar,.side-panel,.tabs,.preview-actions,.booklet-actions,.admin-header,.admin-list-panel{display:none!important}.app-shell{width:100%;padding:0}.workspace,.admin-workspace,.booklet-layout{display:block}.panel{box-shadow:none;border:0}.booklet-sheet{box-shadow:none;border:0;border-radius:0}.booklet-flow{column-count:3}}.list-field{gap:12px;display:grid}.list-input-group{grid-template-columns:1fr auto;gap:8px;display:grid}.list-items{gap:6px;margin:0;padding:0;list-style:none;display:grid}.list-item{border:1px solid var(--line);background:var(--surface-soft);border-radius:6px;grid-template-columns:1fr auto;align-items:center;gap:8px;padding:8px 12px;display:grid}.list-item button{border-radius:4px;padding:4px}.button.small{padding:6px 10px;font-size:.8rem}.install-shell{width:min(1120px,100% - 32px)}.install-store{gap:16px;display:grid}.install-hero{border:1px solid var(--line);background:linear-gradient(135deg, #fffffff5, #e8f4f1f5), var(--surface);min-height:360px;box-shadow:var(--shadow);border-radius:8px;grid-template-columns:minmax(0,1.15fr) minmax(260px,.85fr);align-items:stretch;gap:18px;padding:28px;display:grid;overflow:hidden}.install-copy{align-content:center;gap:18px;display:grid}.install-copy h1{max-width:620px;color:var(--accent-strong);margin:0;font-size:clamp(2.1rem,5vw,4.4rem);line-height:.98}.install-copy p{max-width:620px;color:var(--muted);margin:0;font-size:1.05rem;line-height:1.58}.install-phone{place-items:center;min-height:300px;display:grid}.phone-screen{aspect-ratio:9/16;background:linear-gradient(#fff,#f8faf9 62%,#e8f4f1);border:10px solid #1f2430;border-radius:28px;place-items:center;gap:12px;width:min(250px,100%);padding:24px;display:grid;box-shadow:0 24px 48px #1f243029}.phone-screen img{width:min(136px,70%);height:auto}.phone-screen strong{color:var(--accent-strong);text-align:center;font-size:1.35rem}.phone-screen span{color:var(--muted);text-align:center;font-size:.84rem;font-weight:800}.install-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.install-card{border:1px solid var(--line);min-width:0;box-shadow:var(--shadow);background:#fffffff2;border-radius:8px;grid-template-rows:auto auto 1fr auto;gap:14px;padding:18px;display:grid}.install-card h2{margin:2px 0 0;font-size:1.25rem}.install-card-icon{background:var(--green-soft);width:48px;height:48px;color:var(--green);border-radius:8px;place-items:center;display:grid}.install-card-icon svg{width:24px;height:24px}.install-steps{color:var(--ink);gap:10px;margin:0;padding-left:20px;line-height:1.5;display:grid}.install-steps li svg{vertical-align:-3px;width:18px;height:18px;margin:0 4px}.install-tip{border:1px solid var(--line);background:var(--surface-soft);min-height:42px;color:var(--muted);border-radius:8px;align-items:center;gap:8px;padding:0 12px;font-weight:800;display:flex}.install-tip svg{width:18px;height:18px;color:var(--accent);flex:none}.rosary-layout{grid-template-columns:minmax(260px,.72fr) minmax(0,1.28fr);align-items:start;gap:16px;display:grid}.rosary-list{gap:8px;display:grid}.rosary-panel{overflow:hidden}.rosary-body{gap:16px;display:grid}.rosary-progress{background:var(--surface-soft);border-radius:999px;height:10px;overflow:hidden}.rosary-progress span{border-radius:inherit;background:linear-gradient(90deg, var(--accent), var(--green));height:100%;display:block}.rosary-visual-card{border:1px solid var(--line);background:linear-gradient(180deg, #fffffff5, #e8f4f1e0), var(--surface);border-radius:8px;grid-template-columns:minmax(220px,.72fr) minmax(0,.28fr);align-items:center;gap:14px;min-width:0;padding:16px;display:grid}.rosary-visual{width:min(100%,420px);height:auto;margin:0 auto;display:block}.rosary-string{fill:none;stroke:#6470845c;stroke-linecap:round;stroke-width:3px}.rosary-cross{fill:none;stroke:var(--accent);stroke-linecap:round;stroke-width:8px}.rosary-visual-bead{fill:#fff;stroke:#8f243457;stroke-width:2.4px;transition:fill .16s,stroke .16s,r .16s}.rosary-visual-bead.large{stroke:#c79b3bb3}.rosary-visual-bead.done{fill:var(--green-soft);stroke:var(--green)}.rosary-visual-bead.active{fill:var(--accent);stroke:var(--accent-strong);stroke-width:3.2px}.rosary-visual-bead-hit{cursor:pointer;outline:none}.rosary-visual-bead-hit:focus-visible .rosary-visual-bead{stroke-width:4px}.rosary-visual-caption{gap:6px;min-width:0;display:grid}.rosary-visual-caption strong{color:var(--accent-strong);font-size:1.25rem}.rosary-current,.rosary-bead-panel{border:1px solid var(--line);background:var(--surface);border-radius:8px;gap:12px;padding:18px;display:grid}.rosary-current h2{color:var(--accent-strong);margin:0;font-size:clamp(1.4rem,3vw,2.2rem);line-height:1.1}.rosary-current p{margin:0;font-size:1.05rem;line-height:1.7}.rosary-decade-heading{gap:4px;display:grid}.rosary-decade-heading strong{line-height:1.3}.rosary-beads{grid-template-columns:repeat(11,minmax(18px,1fr));align-items:center;gap:8px;display:grid}.rosary-bead{aspect-ratio:1;background:var(--surface-soft);width:100%;max-width:30px;color:var(--muted);border:2px solid #8f243447;border-radius:50%;justify-self:center;place-items:center;padding:0;font-size:.68rem;font-weight:900;display:grid}.rosary-bead.large{color:#775512;border-color:#c79b3bb8;max-width:34px}.rosary-bead.done{border-color:var(--green);background:var(--green-soft);color:var(--green)}.rosary-bead.active{border-color:var(--accent);background:var(--accent);color:#fff;box-shadow:0 0 0 5px var(--accent-soft)}.rosary-controls{grid-template-columns:minmax(0,1fr) minmax(0,1fr) 42px;gap:8px;display:grid}@media (max-width:1180px){.rosary-layout,.install-hero,.install-grid{grid-template-columns:1fr}.install-hero{min-height:auto}}@media (max-width:760px){html,body{max-width:100%;overflow-x:hidden}.app-shell,.install-shell{width:min(100% - 20px,720px);padding-top:max(12px, env(safe-area-inset-top));padding-bottom:max(24px, env(safe-area-inset-bottom))}.brand{width:100%}.brand strong{font-size:1.35rem}.topbar-actions{grid-template-columns:1fr 1fr;width:100%;display:grid}.topbar-actions .tabs{grid-column:1/-1}.tabs{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.tab-button,.button{min-width:0;min-height:44px;padding:0 10px}.tab-button span,.button span{overflow-wrap:anywhere;min-width:0}.hero-copy h1{font-size:clamp(2rem,12vw,3.2rem)}.reading-block{padding:14px}.booklet-actions{grid-template-columns:1fr;display:grid}.booklet-flow{column-count:1;padding:14px}.booklet-masthead{flex-direction:column;align-items:stretch}.booklet-date{text-align:left;border-top:1px solid #ffffff5c;border-left:0;min-width:0;padding:10px 0 0}.booklet-cover-mark{justify-self:center;width:min(132px,48vw)}.install-hero{flex-direction:column;gap:18px;padding:18px;display:flex}.install-copy{order:1}.install-copy h1{font-size:clamp(2.2rem,13vw,3.4rem)}.install-phone{order:2;min-height:auto}.phone-screen{border-width:8px;border-radius:24px;width:min(220px,72vw);padding:18px}.install-grid{grid-template-columns:1fr}.install-card{padding:16px}.install-steps{padding-left:18px}.rosary-controls{grid-template-columns:1fr}.rosary-controls .icon-button{width:100%}.rosary-visual-card{grid-template-columns:1fr}.rosary-visual-caption{text-align:center}}@media (max-width:480px){.topbar-actions,.tabs{grid-template-columns:1fr}.brand-mark{width:46px;height:46px}.brand-saint{width:36px;height:36px}.panel-heading,.panel-body{padding:12px}.phone-screen{width:min(190px,68vw)}.booklet-masthead,.booklet-cover{padding:12px}.booklet-brandline img{width:40px;height:40px}.booklet-brandline strong{font-size:1.45rem}.booklet-item p,.booklet-imported{font-size:.9rem}.install-copy p,.rosary-current p{font-size:1rem}.rosary-beads{grid-template-columns:repeat(5,minmax(24px,1fr))}.rosary-visual-card{padding:12px}.rosary-visual{width:min(100%,300px)}}
