/* Os Milagres Eucarísticos do Mundo — Hub Católico
   Paleta eucarística: vinho/bordô, ouro, creme. */
:root{
  --wine:#7a5e2a; --wine-deep:#4a3818; --gold:#b8902f; --gold-soft:#c9a227;
  --cream:#faf6ec; --cream-2:#f3ecdb; --ink:#241a16; --ink-soft:#5b4d44; --line:#e3d9c4;
  --serif:'Cormorant Garamond', Georgia, serif; --sans:'Inter', system-ui, sans-serif;
  --shadow:0 10px 40px rgba(74,13,24,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.12}

/* top */
.site-top{display:flex;align-items:center;justify-content:space-between;padding:18px 30px;position:sticky;top:0;z-index:30;
  background:rgba(250,246,236,.86);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.brand-line{font-family:var(--serif);font-size:20px;font-weight:600;letter-spacing:.5px;color:var(--wine)}
.top-nav{display:flex;gap:24px;font-size:14px;font-weight:500}
.top-nav a{color:var(--ink-soft);text-decoration:none;transition:color .2s}
.top-nav a:hover{color:var(--wine)}

/* hero */
.hero{position:relative;text-align:center;padding:84px 24px 72px;color:var(--cream);
  background:radial-gradient(120% 120% at 50% -10%, var(--wine) 0%, var(--wine-deep) 70%)}
.hero-monstrance{color:var(--gold-soft);width:120px;margin:0 auto 14px;opacity:.95}
.hero-monstrance svg{width:100%;height:auto;filter:drop-shadow(0 0 22px rgba(201,162,39,.45))}
.hero-eyebrow{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--gold-soft);letter-spacing:.5px}
.hero-title{font-size:clamp(34px,6vw,62px);margin:8px auto 16px;max-width:14ch;text-wrap:balance}
.hero-sub{max-width:60ch;margin:0 auto 28px;font-size:17px;color:rgba(250,246,236,.86);text-wrap:pretty}
.hero-cta{display:inline-block;background:var(--gold-soft);color:var(--wine-deep);font-weight:600;text-decoration:none;
  padding:13px 30px;border-radius:30px;font-size:15px;transition:transform .15s, box-shadow .2s;box-shadow:0 8px 24px rgba(0,0,0,.25)}
.hero-cta:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.3)}

/* acutis band */
.acutis-band{background:var(--cream-2);border-bottom:1px solid var(--line)}
.acutis-inner{max-width:880px;margin:0 auto;padding:36px 24px;display:flex;gap:22px;align-items:flex-start}
.acutis-mark{font-size:34px;color:var(--gold);line-height:1;flex-shrink:0;margin-top:4px}
.acutis-band h2{font-size:26px;color:var(--wine);margin-bottom:8px}
.acutis-band p{font-size:15.5px;color:var(--ink-soft);text-wrap:pretty}

/* controls */
.controls{position:sticky;top:61px;z-index:20;background:rgba(250,246,236,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.controls-inner{max-width:1100px;margin:0 auto;padding:14px 24px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.ctl-search{flex:1;min-width:200px;height:42px;padding:0 16px;border:1px solid var(--line);border-radius:22px;background:#fff;font-family:var(--sans);font-size:14px;color:var(--ink);outline:none}
.ctl-search:focus{border-color:var(--gold)}
.ctl-sel{height:42px;padding:0 14px;border:1px solid var(--line);border-radius:22px;background:#fff;font-family:var(--sans);font-size:13.5px;color:var(--ink);cursor:pointer;outline:none}
.ctl-count{margin-left:auto;font-size:13px;color:var(--ink-soft)}

/* grid */
.grid{max-width:1100px;margin:0 auto;padding:30px 24px 10px;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.card{position:relative;background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px 22px 20px;cursor:pointer;
  transition:transform .15s, box-shadow .2s, border-color .2s;overflow:hidden}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--gold)}
.card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(var(--gold-soft),var(--wine))}
.card-host{position:absolute;right:16px;top:14px;width:30px;height:30px;border-radius:50%;border:2px solid var(--gold-soft);opacity:.5}
.card-year{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--wine)}
.card-name{font-family:var(--serif);font-size:23px;font-weight:600;line-height:1.15;margin:2px 0 6px;color:var(--ink);padding-right:30px}
.card-place{font-size:13px;color:var(--ink-soft);margin-bottom:12px}
.card-place b{color:var(--wine);font-weight:600}
.card-resumo{font-size:14px;color:var(--ink-soft);line-height:1.5}
.badge{display:inline-block;margin-top:14px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;padding:3px 10px;border-radius:20px}
.badge.aprovado{background:rgba(184,144,47,.16);color:#8a6a18}
.badge.reconhecido{background:rgba(110,20,35,.12);color:var(--wine)}
.badge.venerado{background:rgba(91,77,68,.12);color:var(--ink-soft)}

/* councils */
.councils{background:var(--wine-deep);color:var(--cream);margin-top:40px}
.councils-inner{max-width:1000px;margin:0 auto;padding:54px 24px}
.councils h2{font-size:32px;color:var(--gold-soft);text-align:center}
.councils-sub{text-align:center;color:rgba(250,246,236,.8);max-width:60ch;margin:10px auto 30px;font-size:15px}
.council-list{display:grid;gap:1px;background:rgba(201,162,39,.18);border-radius:14px;overflow:hidden}
.council{display:grid;grid-template-columns:64px 1fr;gap:16px;padding:16px 20px;background:var(--wine-deep);align-items:baseline}
.council:hover{background:#3a0a13}
.council-year{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--gold-soft)}
.council-name{font-family:var(--serif);font-size:20px;font-weight:600}
.council-resumo{font-size:13.5px;color:rgba(250,246,236,.78);margin-top:2px}

/* footer */
.site-foot{text-align:center;padding:40px 24px 56px;background:var(--cream-2);border-top:1px solid var(--line)}
.site-foot a{color:var(--wine);font-weight:600;text-decoration:none}
.foot-credit{max-width:64ch;margin:10px auto 0;font-size:13px;color:var(--ink-soft)}

/* sheet (detalhe) */
.sheet-back{position:fixed;inset:0;z-index:50;background:rgba(40,10,18,.5);backdrop-filter:blur(3px);
  display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto}
.sheet-back.open{display:flex}
.sheet{background:var(--cream);max-width:680px;width:100%;border-radius:20px;box-shadow:0 30px 80px rgba(0,0,0,.4);overflow:hidden;animation:rise .25s ease}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.sheet-head{background:radial-gradient(120% 120% at 50% -20%, var(--wine) 0%, var(--wine-deep) 75%);color:var(--cream);padding:30px 32px 26px;position:relative}
.sheet-close{position:absolute;right:16px;top:16px;width:36px;height:36px;border-radius:50%;border:none;background:rgba(255,255,255,.14);color:#fff;font-size:18px;cursor:pointer;line-height:1}
.sheet-close:hover{background:rgba(255,255,255,.26)}
.sheet-year{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--gold-soft)}
.sheet-name{font-size:32px;margin:2px 0 6px;text-wrap:balance}
.sheet-place{font-size:14px;color:rgba(250,246,236,.85)}
.sheet-body{padding:26px 32px 32px}
.sheet-body p{margin-bottom:14px;font-size:15.5px;color:var(--ink-soft);text-wrap:pretty}
.sheet-section{font-family:var(--serif);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--gold);margin:20px 0 8px}
.sheet-ev{background:#fff;border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:10px;padding:14px 16px;font-size:14.5px;color:var(--ink)}
.sheet-fontes{display:flex;flex-direction:column;gap:6px}
.sheet-fontes a{font-size:13px;color:var(--wine);word-break:break-all}

@media(max-width:640px){
  .site-top{padding:14px 18px}.top-nav{gap:16px;font-size:13px}
  .acutis-inner{flex-direction:column;gap:12px;padding:28px 20px}
  .council{grid-template-columns:54px 1fr;gap:12px;padding:14px 16px}
  .sheet-back{padding:0}.sheet{border-radius:0;min-height:100%}
}

/* ── Header unificado do Hub ── */
.hub-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 28px;position:sticky;top:0;z-index:40;
  background:rgba(250,246,236,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.hub-brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.hub-brand img{height:30px;width:auto;display:block}
.hub-brand span{font-family:var(--serif);font-size:19px;font-weight:600;color:var(--wine)}
.hub-nav{display:flex;align-items:center;gap:6px}
.hub-nav>a,.hub-drop-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 13px;border-radius:20px;border:none;background:transparent;
  font-family:var(--sans);font-size:14px;font-weight:500;color:var(--ink-soft);text-decoration:none;cursor:pointer;transition:background .2s,color .2s}
.hub-nav>a:hover,.hub-drop-btn:hover{background:var(--cream-2);color:var(--wine)}
.hub-drop{position:relative}
.hub-menu{position:absolute;right:0;top:calc(100% + 6px);min-width:210px;background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow);padding:6px;display:none;flex-direction:column}
.hub-drop:hover .hub-menu{display:flex}
.hub-menu a{padding:10px 14px;border-radius:9px;font-size:14px;color:var(--ink);text-decoration:none}
.hub-menu a:hover{background:var(--cream-2)}
.hub-menu a.active{color:var(--wine);font-weight:600}
@media(max-width:680px){ .hub-brand span{display:none} .hub-nav{gap:2px} .hub-nav>a,.hub-drop-btn{padding:8px 9px;font-size:13px} }

/* ── Mapa ── */
.map-section{background:var(--cream-2);border-top:1px solid var(--line);padding:48px 0 0}
.map-head{text-align:center;max-width:60ch;margin:0 auto 24px;padding:0 24px}
.map-head h2{font-size:32px;color:var(--wine)}
.map-head p{color:var(--ink-soft);font-size:15px;margin-top:6px}
#map{height:520px;width:100%;background:var(--cream)}
.leaflet-container{font-family:var(--sans)}
.leaflet-tooltip{font-size:12.5px;border-radius:8px;border:none;box-shadow:0 2px 8px rgba(0,0,0,.2)}

.badge.santo{background:rgba(184,144,47,.2);color:#8a6a18}
.badge.beato{background:rgba(122,94,42,.16);color:#7a5e2a}
.badge.veneravel,.badge.servo_de_deus{background:rgba(91,77,68,.12);color:var(--ink-soft)}
.pope-n{position:absolute;right:14px;top:12px;font-family:var(--serif);font-size:26px;font-style:italic;color:var(--cream-2)}
.dec-list{list-style:none;display:flex;flex-direction:column;gap:7px}
.dec-list li{position:relative;padding-left:20px;font-size:14.5px;color:var(--ink-soft);line-height:1.5}
.dec-list li::before{content:'';position:absolute;left:2px;top:8px;width:7px;height:7px;border-radius:50%;background:var(--gold)}

.santo-link{display:flex;align-items:baseline;gap:8px;padding:11px 14px;background:#fff;border:1px solid var(--line);border-radius:10px;text-decoration:none;transition:border-color .2s,background .2s}
.santo-link:hover{border-color:var(--gold);background:var(--cream-2)}
.santo-link b{font-family:var(--serif);font-size:16px;color:var(--wine)}
.santo-link small{color:var(--ink-soft);font-size:12.5px}
.santo-link .arr{margin-left:auto;color:var(--gold);font-weight:700}
.set-rows{margin-top:6px;border-top:1px solid var(--line)}
.set-row2{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:10px 2px;border-bottom:1px solid var(--line);font-size:14px}
.set-row2 span{color:var(--ink-soft);font-size:13px}
.set-row2 b{color:var(--ink);font-weight:600;text-align:right}
.card{padding-top:26px}

/* Hero cinematográfico: vinheta + escurecimento (LUT) sobre a arte/gradiente */
.hero{position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(115% 85% at 50% 28%, transparent 38%, rgba(0,0,0,.58) 100%);}
.hero>*{position:relative;z-index:1}
