/* ============================================================
   Leitor de Corpus — Hub Católico (História da Igreja)
   Framework compartilhado: Denzinger · Catecismo · DSI · Direito Canônico
   Cada site define --accent / --accent-deep / --hero-img no :root inline.
   ============================================================ */
:root{
  --ink:#1c1a17; --ink-soft:#6b645c; --paper:#f7f3ec; --card:#fffdfa;
  --line:#e7ddcf; --accent:#7a2e2e; --accent-deep:#4a0d18; --gold:#b8902f;
  --maxw:1240px; --serif:'Spectral',Georgia,'Times New Roman',serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit}

/* ---------- Hub bar (autorreferência) ---------- */
.hub-bar{position:sticky;top:0;z-index:50;background:rgba(28,26,23,.96);backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(255,255,255,.08);color:#f7f3ec}
.hub-bar-in{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:18px;
  padding:10px 22px;font-size:14px}
.hub-bar img{height:26px;width:auto;display:block}
.hub-bar .sep{opacity:.4}
.hub-drop{position:relative}
.hub-drop>button{background:none;border:0;color:#f7f3ec;font:inherit;cursor:pointer;display:flex;align-items:center;gap:6px;opacity:.92}
.hub-drop>button:hover{opacity:1}
.hub-menu{position:absolute;top:130%;left:0;background:#fffdfa;color:var(--ink);border-radius:12px;
  box-shadow:0 18px 50px rgba(0,0,0,.28);padding:8px;min-width:230px;display:none;border:1px solid var(--line)}
.hub-drop:hover .hub-menu,.hub-drop:focus-within .hub-menu{display:block}
.hub-menu a{display:block;padding:9px 12px;border-radius:8px;font-size:14px;text-decoration:none;color:var(--ink)}
.hub-menu a:hover{background:var(--paper)}
.hub-menu a small{display:block;color:var(--ink-soft);font-size:11.5px}
.hub-bar .spacer{margin-left:auto}
.hub-bar .home{opacity:.85;text-decoration:none;font-size:13px}

/* ---------- Hero cinematográfico ---------- */
.hero{position:relative;overflow:hidden;color:#fff;padding:74px 22px 64px;text-align:center;
  background:linear-gradient(rgba(0,0,0,.55),rgba(0,0,0,.78)),var(--accent-deep);
  background-size:cover;background-position:center 28%}
.hero::after{content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(115% 85% at 50% 26%,transparent 36%,rgba(0,0,0,.62) 100%)}
.hero>*{position:relative;z-index:1;max-width:760px;margin-left:auto;margin-right:auto}
.hero .kicker{font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;opacity:.82;margin-bottom:16px;color:var(--gold)}
.hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(34px,6vw,60px);line-height:1.04;letter-spacing:-.01em}
.hero .sub{font-family:var(--serif);font-style:italic;font-size:clamp(15px,2.2vw,20px);opacity:.9;margin-top:16px}
.hero .src{font-size:12.5px;opacity:.62;margin-top:20px}

/* ---------- Busca ---------- */
.searchwrap{position:sticky;top:46px;z-index:40;background:var(--paper);border-bottom:1px solid var(--line);
  padding:14px 22px}
.searchwrap-in{max-width:var(--maxw);margin:0 auto;display:flex;gap:12px;align-items:center;flex-wrap:wrap}
#q{flex:1;min-width:240px;font:16px var(--sans);padding:13px 16px;border:1.5px solid var(--line);border-radius:12px;
  background:var(--card);color:var(--ink)}
#q:focus{outline:none;border-color:var(--accent)}
.searchwrap .count{font-size:13px;color:var(--ink-soft);white-space:nowrap}
.jump{font:14px var(--sans);padding:13px 14px;border:1.5px solid var(--line);border-radius:12px;background:var(--card);color:var(--ink);width:130px}
.jump:focus{outline:none;border-color:var(--accent)}

/* ---------- Layout índice + corpo ---------- */
.shell{max-width:var(--maxw);margin:0 auto;padding:26px 22px 80px;display:grid;grid-template-columns:280px 1fr;gap:38px}
.toc{position:sticky;top:118px;align-self:start;max-height:calc(100vh - 146px);overflow:auto;
  padding:4px 12px 30px 0;mask-image:linear-gradient(transparent,#000 14px,#000 calc(100% - 22px),transparent)}
.toc::-webkit-scrollbar{width:6px}.toc::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.toc h3{font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);
  margin:0 0 14px;padding-bottom:10px;border-bottom:1px solid var(--line)}
.toc a{display:flex;gap:8px;align-items:baseline;padding:4px 9px;border-radius:7px;text-decoration:none;
  color:var(--ink-soft);line-height:1.3;transition:background .12s,color .12s}
.toc a span{flex:1}
.toc a:hover{background:var(--card);color:var(--accent)}
.toc a b{color:var(--accent);font-variant-numeric:tabular-nums;font-size:11px;font-weight:600;
  min-width:42px;opacity:.85;font-family:var(--sans)}
/* níveis do índice */
.toc-lvl0{margin-top:18px;padding-top:10px!important;border-top:1px solid var(--line);
  font-family:var(--serif);font-weight:600;font-size:15px;color:var(--accent-deep)!important;
  text-transform:uppercase;letter-spacing:.04em}
.toc-lvl0 b{font-size:11px;color:var(--ink-soft)}
.toc-lvl0:first-child{margin-top:0;border-top:0;padding-top:0!important}
.toc-lvl1{font-weight:600;font-size:13.5px;color:var(--ink)!important;margin-top:6px}
.toc-lvl2{font-size:13px;padding-left:18px!important}
.toc-lvl3{font-size:12.5px;padding-left:30px!important;color:var(--ink-soft)!important}
.toc-lvl4{font-size:13px}

.entries{min-width:0}
/* cabeçalhos de seção diferenciados por nível */
.sec-head{font-family:var(--serif);color:var(--accent-deep);scroll-margin-top:118px;font-weight:600}
.sec-head.lvl0{font-size:clamp(26px,3.4vw,34px);text-transform:uppercase;letter-spacing:.02em;
  margin:52px 0 6px;padding-bottom:14px;border-bottom:2px solid var(--accent);line-height:1.1}
.sec-head.lvl1{font-size:25px;margin:42px 0 4px;padding-left:14px;border-left:4px solid var(--gold)}
.sec-head.lvl2{font-size:22px;margin:36px 0 4px;color:var(--accent)}
.sec-head.lvl3{font-size:18.5px;margin:30px 0 4px;font-style:italic;font-weight:500;color:var(--ink)}
.sec-head.lvl4{font-size:21px;margin:34px 0 4px}
.sec-head:first-child{margin-top:0}
.sec-sub{font-size:13px;color:var(--ink-soft);margin-bottom:14px}
/* links de autorreferência no corpo do texto */
.xr{color:var(--accent);text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--accent) 32%,transparent);
  transition:border-color .12s,background .12s;padding:0 1px;border-radius:2px}
.xr:hover{border-bottom-color:var(--accent);background:color-mix(in srgb,var(--accent) 9%,transparent)}
.xr-s{color:var(--accent-deep);border-bottom-style:dotted;border-bottom-color:var(--gold)}
.xr-s:hover{background:color-mix(in srgb,var(--gold) 16%,transparent)}
.entry.flash{box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 30%,transparent)!important;transition:box-shadow .25s}

.entry{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin:12px 0;
  scroll-margin-top:120px}
.entry:target{border-color:var(--accent);box-shadow:0 0 0 3px rgba(122,46,46,.12)}
.entry .e-head{display:flex;align-items:baseline;gap:12px;margin-bottom:8px}
.entry .e-num{font-family:var(--serif);font-weight:700;font-size:18px;color:var(--accent);
  font-variant-numeric:tabular-nums;white-space:nowrap}
.entry .e-anchor{margin-left:auto;font-size:12px;color:var(--ink-soft);text-decoration:none;opacity:0;transition:opacity .15s}
.entry:hover .e-anchor{opacity:1}
.entry .e-title{font-family:var(--serif);font-weight:600;font-size:16px;color:var(--ink)}
.entry .e-text{font-size:15.5px;line-height:1.68;color:#26221d}
.entry .e-text p{margin:0 0 9px}
.entry .e-text p:last-child{margin-bottom:0}
.entry .e-src{margin-top:10px;font-size:12px;color:var(--ink-soft)}
.entry .e-src a{color:var(--accent);text-decoration:none}
.entry .e-xref{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}
.entry .e-xref a{font-size:12px;text-decoration:none;background:var(--paper);border:1px solid var(--line);
  border-radius:999px;padding:4px 11px;color:var(--accent)}
.entry .e-xref a:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

mark{background:rgba(184,144,47,.34);color:inherit;border-radius:3px;padding:0 1px}
.empty{text-align:center;color:var(--ink-soft);padding:60px 20px;font-size:15px}

/* nota de fonte / honestidade editorial */
.note{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.note .inner{background:#fff8ee;border:1px solid var(--line);border-left:3px solid var(--gold);
  border-radius:10px;padding:14px 18px;font-size:13px;color:var(--ink-soft);margin-top:6px}

footer{background:#1c1a17;color:#cfc7bd;text-align:center;padding:36px 22px;font-size:13px}
footer a{color:var(--gold);text-decoration:none}

@media(max-width:860px){
  .shell{grid-template-columns:1fr;gap:18px}
  .toc{position:static;max-height:none;order:2;border-top:1px solid var(--line);padding-top:18px}
  .searchwrap{top:0}
}

/* toggle "ver latim" */
.lat-toggle{margin-top:9px;font-family:var(--sans);font-size:12.5px;background:none;border:1px solid var(--line);
  color:var(--accent);border-radius:999px;padding:4px 13px;cursor:pointer;transition:all .15s}
.lat-toggle:hover,.lat-toggle.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.e-latim{margin-top:10px;padding:12px 15px;background:rgba(0,0,0,.028);border-left:3px solid var(--gold);
  border-radius:8px;font-family:var(--serif);font-style:italic;font-size:15px;line-height:1.62;color:#403a32}
.e-latim p{margin:0 0 8px}.e-latim p:last-child{margin:0}
