@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Inter:wght@400;500;600&display=swap');

:root{
  --bg:#faf8f4; --panel:#ffffff; --ink:#1a1611; --muted:#6c6357;
  --line:#e6ded1; --accent:#a23b1e; --accent2:#b98a3e; --gold:#e9c98a;
  --dark:#1a1611; --max:1200px;
  --shadow:0 10px 30px rgba(40,28,14,.10); --shadow-sm:0 3px 12px rgba(40,28,14,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:"Inter",system-ui,sans-serif;line-height:1.65;font-size:16px;-webkit-font-smoothing:antialiased}
img{max-width:100%}
h1,h2,h3,h4{font-family:"Fraunces",Georgia,serif;line-height:1.1;margin:0 0 .3em;font-weight:600}
a{color:var(--accent)}

/* NAV */
header.nav{position:sticky;top:0;z-index:60;background:rgba(250,248,244,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;gap:20px;
  padding:16px 32px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:13px;margin-right:auto;text-decoration:none}
.brand-mark{flex:0 0 auto;width:52px;height:52px;display:block}
.brand-txt{font-family:"Fraunces";font-weight:600;font-size:1.12rem;color:var(--ink);line-height:1.14}
.brand small{display:block;font-family:"Inter";font-weight:500;font-size:.62rem;
  letter-spacing:.14em;color:var(--muted);text-transform:uppercase;margin-top:3px}
@media(max-width:880px){.brand-mark{width:42px;height:42px}.brand-txt{font-size:1rem}.nav-inner{padding:12px 18px}}
header.nav nav{display:flex;flex-wrap:wrap;align-items:center;gap:6px 16px}
.navtop,.navgrp-btn{font-family:inherit;font-size:.85rem;color:var(--ink);text-decoration:none;background:none;border:none;
  cursor:pointer;padding:4px 0;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:3px}
.navtop:hover,.navgrp-btn:hover{color:var(--accent)}
.navtop.active,.navgrp.active>.navgrp-btn{color:var(--accent);border-bottom-color:var(--accent)}
.navgrp-car{font-size:.7em;opacity:.7;transition:transform .2s}
.navtoggle{display:none;background:none;border:none;font-size:1.5rem;color:var(--ink);cursor:pointer;line-height:1;padding:2px 6px}
.navgrp{position:relative}
/* ponte invisível: evita a "zona morta" entre o botão e o submenu */
.navgrp::after{content:"";position:absolute;left:0;right:-6px;top:100%;height:12px}
.navgrp-panel{position:absolute;top:100%;left:-6px;margin-top:10px;background:var(--panel);border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--shadow);padding:8px;display:flex;flex-direction:column;min-width:208px;z-index:70;
  opacity:0;visibility:hidden;transform:translateY(-7px);transition:opacity .16s ease,transform .16s ease,visibility .16s}
.navgrp:hover>.navgrp-panel,.navgrp.open>.navgrp-panel{opacity:1;visibility:visible;transform:none}
.navgrp:hover>.navgrp-btn .navgrp-car,.navgrp.open>.navgrp-btn .navgrp-car{transform:rotate(180deg)}
.navgrp-panel a{font-size:.86rem;color:var(--ink);text-decoration:none;padding:8px 12px;border-radius:8px;white-space:nowrap;transition:background .12s,color .12s}
.navgrp-panel a:hover{background:var(--bg);color:var(--accent)}
.navgrp-panel a.active{color:var(--accent);font-weight:600;background:var(--bg)}
@media(max-width:880px){
  .navtoggle{display:block}
  header.nav nav{display:none;flex-basis:100%;flex-direction:column;align-items:stretch;gap:0;padding:6px 0 4px;order:3}
  header.nav nav.open{display:flex}
  .navtop{padding:13px 2px;border-bottom:1px solid var(--line);font-size:1.02rem}
  .navgrp{position:static}
  .navgrp::after{display:none}
  .navgrp-btn{width:100%;display:flex;align-items:center;padding:13px 2px;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;
    color:var(--accent2);pointer-events:auto;border-bottom:1px solid var(--line)}
  .navgrp-car{display:inline;margin-left:auto;font-size:.85em;opacity:.9}
  .navgrp-panel{position:static;flex-direction:column;box-shadow:none;border:none;padding:0;min-width:0;background:transparent;margin:0;
    opacity:1;visibility:visible;transform:none;max-height:0;overflow:hidden;transition:max-height .26s ease}
  .navgrp.open>.navgrp-panel{max-height:420px}
  .navgrp-panel a{padding:11px 2px 11px 16px;border-bottom:1px solid var(--line);border-radius:0;font-size:1rem}
  .navgrp-panel a.active{font-weight:600;background:transparent}
}

/* FAIXA DE NÚMEROS (home) */
.stats{background:var(--dark);color:#f1ece4}
.stats-in{max-width:var(--max);margin:0 auto;padding:36px 32px;display:grid;
  grid-template-columns:repeat(5,1fr);gap:18px;text-align:center}
@media(max-width:760px){.stats-in{grid-template-columns:repeat(2,1fr);gap:24px 18px}}
.stats .num{font-family:"Fraunces";font-size:clamp(1.6rem,3.4vw,2.4rem);color:#fff;line-height:1}
.stats .lab{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-top:6px}

/* HERO (home) */
.hero{position:relative;min-height:82vh;display:flex;align-items:flex-end;
  color:#fff;background:#1a1611;overflow:hidden}
.hero .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 28%}
.hero .scrim{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,15,10,.30) 0%,rgba(20,15,10,.15) 38%,rgba(20,15,10,.85) 100%)}
.hero .inner{position:relative;max-width:var(--max);margin:0 auto;width:100%;padding:0 32px 76px}
.hero .overline{font-size:.74rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.hero h1{font-size:clamp(2.3rem,5.4vw,4.4rem);font-weight:600;max-width:20ch;text-shadow:0 2px 30px rgba(0,0,0,.45)}
.hero .sub{font-size:clamp(1rem,1.6vw,1.24rem);max-width:60ch;color:#f1ece4;margin:.6em 0 0}
.hero .by{margin-top:18px;font-size:.92rem;color:#d8cdbb;font-style:italic}
.hero .scrollcue{margin-top:26px;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:#e7ded0}
.hero .credit{position:absolute;right:14px;bottom:10px;font-size:.66rem;color:rgba(255,255,255,.5)}

/* PAGE HEADER (interior, injetado) */
.pagehead{position:relative;min-height:300px;display:flex;align-items:flex-end;color:#fff;background:#1a1611;overflow:hidden}
.pagehead .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 32%}
.pagehead .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,15,10,.32),rgba(20,15,10,.80))}
.pagehead .inner{position:relative;max-width:var(--max);margin:0 auto;width:100%;padding:0 32px 32px}
.pagehead .overline{font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.pagehead h1{font-size:clamp(2rem,4vw,3.1rem);font-weight:600;text-shadow:0 2px 24px rgba(0,0,0,.4)}
.pagehead p{max-width:60ch;color:#ece6dc;margin:.4em 0 0;font-size:1rem}

/* BLOCKS */
section.block{max-width:var(--max);margin:0 auto;padding:64px 32px}
.block h2{font-size:clamp(1.6rem,3vw,2.3rem);color:var(--ink)}
.eyebrow{display:block;font-family:"Inter";font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);font-weight:600;margin-bottom:10px}
.lead{font-size:1.08rem;color:var(--muted);max-width:70ch;margin:.2em 0 2em}
.full{max-width:none}

/* HOME — HALL DE EXPERIÊNCIAS (tiles) */
.hall{max-width:var(--max);margin:0 auto;padding:64px 32px 24px}
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:18px}
.tile{position:relative;aspect-ratio:4/3;border-radius:16px;overflow:hidden;display:block;
  text-decoration:none;color:#fff;box-shadow:var(--shadow);background:#1a1611}
.tile .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 28%;transition:transform .6s ease}
.tile:hover .bg{transform:scale(1.07)}
.tile .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,15,10,.05) 28%,rgba(20,15,10,.80))}
.tile .lbl{position:absolute;left:0;right:0;bottom:0;padding:22px}
.tile .lbl .k{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.tile .lbl h3{font-size:1.5rem;margin:.12em 0 .15em;color:#fff}
.tile .lbl p{font-size:.86rem;color:#ece6dc;margin:0;max-width:34ch;line-height:1.45}
.tile .arrow{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:1.1rem;opacity:0;transform:translateY(-4px);transition:.2s}
.tile:hover .arrow{opacity:1;transform:translateY(0)}

/* STRIPS (faixas com fotos na home) */
.bandhead{display:flex;align-items:baseline;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:16px}
.bandhead a.more{font-size:.85rem;font-weight:600;text-decoration:none;white-space:nowrap}
.strip{display:flex;gap:12px;overflow-x:auto;padding:4px 2px 16px}
.strip img{height:170px;border-radius:12px;object-fit:cover;cursor:pointer;
  box-shadow:var(--shadow-sm);transition:transform .2s;flex:0 0 auto}
.strip img:hover{transform:translateY(-4px)}

/* CARDS (curiosidades, memórias) */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:20px}
.curio{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.curio:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.curio .ph{position:relative;height:170px;overflow:hidden;background:#e7ded0;cursor:pointer}
.curio .ph img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.curio:hover .ph img{transform:scale(1.05)}
.phcap{position:absolute;left:0;right:0;bottom:0;font-size:.68rem;color:#fff;line-height:1.25;
  background:linear-gradient(transparent,rgba(20,15,10,.8));padding:18px 10px 7px}

/* MEMÓRIAS — artigos */
.mem-list{display:flex;flex-direction:column;gap:30px;max-width:1000px}
.mem-article{display:grid;grid-template-columns:320px 1fr;gap:0;align-items:stretch;
  background:var(--panel);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm)}
.mem-article.mem-rev{grid-template-columns:1fr 320px}
.mem-article.mem-rev .mem-img{order:2}
.mem-img{position:relative;min-height:240px;cursor:pointer;background:#e7ded0;overflow:hidden}
.mem-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.mem-img:hover img{transform:scale(1.04)}
.mem-body{padding:26px 30px}
.mem-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.mem-emoji{font-size:1.6rem;line-height:1}
.mem-rt{font-size:.74rem;color:var(--accent2);background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:3px 10px;white-space:nowrap}
.mem-body h3{font-size:1.55rem;color:var(--accent);margin:.1em 0 .5em}
.toc{margin:22px 0 8px;padding:16px 18px;background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:10px}
.toc .toc-t{display:block;font-size:.72rem;letter-spacing:.09em;text-transform:uppercase;color:var(--accent2);margin-bottom:8px}
.toc a{display:block;color:#34291c;text-decoration:none;font-size:.95rem;padding:4px 0;border-bottom:1px dashed transparent;transition:color .15s}
.toc a:hover{color:var(--accent);border-bottom-color:var(--line)}
h2[id],h3[id]{scroll-margin-top:88px}
.about-photo{margin:0 0 22px;background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}
.about-photo img{width:100%;display:block}
.about-photo figcaption{padding:12px 16px;font-size:.85rem;color:#5d4a33;line-height:1.5}
.maptap{position:absolute;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;
  background:rgba(26,22,17,.28);cursor:pointer}
.maptap span{background:rgba(26,22,17,.82);color:#fff;font-size:.9rem;padding:9px 16px;border-radius:999px}
.leaflet-control-layers-overlays label{display:flex;align-items:center}
/* Fase 1 — ligações cruzadas */
.fam-click{cursor:pointer;transition:transform .15s,box-shadow .15s,border-color .15s}
.fam-click:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:var(--shadow)}
.fam-go{margin-top:10px;font-size:.8rem;font-weight:600;color:var(--accent)}
.fam-links{margin-top:10px;font-size:.82rem}
.mlink{color:var(--accent);text-decoration:none;font-weight:600}
.mlink:hover{text-decoration:underline}
.mh{font-family:"Fraunces";font-size:1.02rem;color:var(--accent);margin:1.1em 0 .4em}
.modal-names{display:flex;flex-wrap:wrap;gap:6px}
.modal-names span{font-size:.82rem;background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:3px 8px;color:#4f4639}
.modal-names a.mchip{font-size:.85rem;background:var(--bg);border:1px solid var(--accent);border-radius:999px;padding:4px 12px;color:var(--accent);text-decoration:none;font-weight:600}
.modal-names a.mchip:hover{background:var(--accent);color:#fff}
.mul{margin:.3em 0;padding-left:1.1em;color:#3a2e20;font-size:.92rem;line-height:1.7}
.mexc{margin:.4em 0;padding:8px 14px;border-left:3px solid var(--gold);background:var(--bg);
  font-size:.92rem;color:#4a3c2c;font-style:italic;line-height:1.6;border-radius:0 8px 8px 0}
.name{cursor:pointer}
.name:hover{color:var(--accent)}
/* Fase 3 — Lugares agrupados */
.lugar-grp{margin-bottom:30px}
.lugar-h{font-family:"Fraunces";font-size:1.5rem;color:var(--accent);margin:0 0 2px}
.lugar-sub{font-size:.9rem;color:var(--muted);margin:0 0 14px}
.lugar{overflow:hidden;padding:0}
.lugar .lugar-bd{padding:16px 18px}
.lugar-haspic{display:flex;flex-direction:column}
.lugar-img{cursor:zoom-in;background:#efe7d8;border-bottom:1px solid var(--line)}
.lugar-img img{width:100%;height:160px;object-fit:cover;display:block;transition:transform .25s}
.lugar-img:hover img{transform:scale(1.05)}
/* Fase 4 — descoberta */
.navsearch{font-size:1.05rem;text-decoration:none;margin-left:6px;padding:6px 9px;border-radius:8px;line-height:1;align-self:center}
.navsearch:hover{background:rgba(162,59,30,.10)}
.bsec{margin-bottom:30px}
.galsec{margin-bottom:34px}
.galsec .lugar-h{margin-bottom:2px}
.galsec .lugar-sub{margin-bottom:14px}
.bcount{font-size:.8rem;color:var(--muted);font-weight:400}
.kicker{display:inline-block;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;color:var(--accent2);
  border-left:3px solid var(--accent);padding:2px 0 2px 10px;margin:0 0 10px}
.kicker a{color:var(--accent)}
/* Painel do acervo */
.painel-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:680px){.painel-grid{grid-template-columns:1fr}}
.painel-card{margin:0;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px 18px;box-shadow:var(--shadow-sm)}
.painel-card figcaption{font-family:"Fraunces";font-size:1.05rem;color:var(--accent);margin-bottom:10px}
.painel-cv{position:relative;height:260px}
.painel-wide{grid-column:1 / -1}
.painel-wide .painel-cv{height:340px}
/* Comércio da colônia */
.neg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
.neg-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.neg-img{cursor:zoom-in;background:#efe7d8;border-bottom:1px solid var(--line)}
.neg-img img{width:100%;height:140px;object-fit:cover;object-position:top;display:block;transition:transform .25s}
.neg-img:hover img{transform:scale(1.05)}
.neg-bd{padding:13px 15px}
.neg-bd h3{font-size:1.05rem;color:var(--ink);margin:0 0 2px}
.neg-dono{font-size:.85rem;color:var(--accent2)}
.mem-body p{font-size:.98rem;color:#34291c;line-height:1.75;margin:.7em 0}
.mem-body p b{color:#1a1611}
.mem-src{font-size:.8rem!important;color:var(--accent2)!important;font-style:italic;margin-top:14px!important}
@media(max-width:720px){
  .mem-article,.mem-article.mem-rev{grid-template-columns:1fr}
  .mem-article.mem-rev .mem-img{order:0}
  .mem-img{min-height:200px}
  .mem-body{padding:22px 20px}
}
.curio .bd{padding:18px 20px 16px;display:flex;flex-direction:column;flex:1}
.curio .tag{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:600}
.curio h3{font-size:1.22rem;margin:6px 0}
.curio p{font-size:.92rem;color:#4f4639;margin:.2em 0 0}
.curio .share{margin-top:12px}
.curio .share a{font-size:.78rem;color:#1f8a4c;text-decoration:none;font-weight:600}

/* TIMELINE */
.tl{position:relative;max-width:860px;margin:0 auto;padding:8px 20px 0}
.tl:before{content:"";position:absolute;left:128px;top:0;bottom:0;width:2px;background:var(--line)}
.tl-item{position:relative;display:flex;gap:24px;padding:12px 0;cursor:pointer}
.tl-year{flex:0 0 104px;text-align:right;font-family:"Fraunces";font-weight:600;color:var(--accent);font-size:1.15rem;padding-top:6px}
.tl-dot{position:absolute;left:121px;top:22px;width:16px;height:16px;border-radius:50%;
  background:var(--accent);border:3px solid var(--bg);z-index:2;transition:transform .15s}
.tl-item:hover .tl-dot{transform:scale(1.3)}
.tl-body{flex:1;display:flex;gap:14px;align-items:stretch;background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:14px 16px;box-shadow:var(--shadow-sm);margin-left:28px;transition:transform .15s}
.tl-item:hover .tl-body{transform:translateX(3px)}
.tl-thumb{flex:0 0 84px;height:84px;border-radius:8px;overflow:hidden;border:1px solid var(--line);cursor:zoom-in;background:#efe7d8}
.tl-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}
.tl-thumb:hover img{transform:scale(1.08)}
.tl-txt{flex:1;min-width:0}
.tl-txt h3{font-size:1.1rem;margin:0 0 3px}
.tl-txt p{margin:0;font-size:.92rem;color:#4f4639}
.tl-src{font-size:.72rem;color:var(--accent2);margin-top:6px;font-style:italic}
.tl-era{position:relative;margin:26px 0 4px;padding-left:152px}
.tl-era span{display:block;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent2)}
.tl-era h2{font-family:"Fraunces";font-size:1.5rem;color:var(--accent);margin:2px 0 0}
@media(max-width:640px){
  .tl:before{left:18px}.tl-item{flex-direction:column;gap:6px}
  .tl-year{flex:none;text-align:left;padding-left:42px}
  .tl-dot{left:11px;top:8px}.tl-body{margin-left:42px}
  .tl-era{padding-left:42px}
}

/* MAPA */
.mapwrap{display:grid;grid-template-columns:1.4fr 1fr;gap:24px;align-items:start}
@media(max-width:760px){.mapwrap{grid-template-columns:1fr}}
.mapsvg{background:#efe6d4;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm);width:100%}
.mappt{cursor:pointer}
.mappt circle{transition:r .15s}.mappt:hover circle{r:9}
.mapinfo{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px;min-height:200px;box-shadow:var(--shadow-sm)}
.mapinfo h3{color:var(--accent);font-size:1.3rem}
.legend{font-size:.8rem;color:var(--muted);margin-top:12px}
.legend span{display:inline-flex;align-items:center;gap:6px;margin-right:14px}
.dotc{width:11px;height:11px;border-radius:50%;display:inline-block}
.histmaps{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:28px}
@media(max-width:680px){.histmaps{grid-template-columns:1fr}}
.histmaps figure{margin:0;background:var(--panel);border:1px solid var(--line);border-radius:14px;
  overflow:hidden;box-shadow:var(--shadow-sm);cursor:pointer}
.histmaps img{width:100%;display:block;transition:transform .4s}
.histmaps figure:hover img{transform:scale(1.04)}
.histmaps figcaption{padding:12px 16px;font-size:.86rem;color:#4f4639}

/* SEARCH + CHIPS */
.searchbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.searchbar input{flex:1;min-width:240px;padding:14px 18px;border:1px solid var(--line);
  border-radius:30px;font-size:1rem;background:var(--panel);font-family:inherit}
.searchbar input:focus{outline:none;border-color:var(--accent)}
.chips{margin:8px 0 22px;display:flex;gap:8px;flex-wrap:wrap}
.chip{font-size:.82rem;padding:7px 15px;border-radius:20px;border:1px solid var(--line);
  background:var(--panel);cursor:pointer;color:#4f4639;transition:.15s}
.chip:hover{border-color:var(--accent2)}
.chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* FAMÍLIAS / RUAS */
.fam-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:16px}
.fam{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:20px;box-shadow:var(--shadow-sm);transition:transform .2s}
.fam:hover{transform:translateY(-3px)}
.fam h3{font-size:1.3rem;margin:0;color:var(--accent)}
.fam .meta{font-size:.72rem;color:var(--accent2);text-transform:uppercase;letter-spacing:.08em;margin:4px 0 10px}
.fam p{font-size:.9rem;color:#4f4639;margin:.25em 0}
.fam .src{font-size:.72rem;color:var(--muted);font-style:italic;margin-top:10px}
.noresult{color:var(--muted);font-style:italic;padding:20px 0}

/* ANTEPASSADOS */
.antlist{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:8px}
.antlist .name{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:10px 15px;font-size:.92rem;color:#34291c}
.antlist .name mark{background:#f6e3b8;color:#34291c;padding:0 2px;border-radius:3px}
.facsim{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px}
.facsim img{width:100%;border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-sm);
  cursor:pointer;background:#fff;transition:transform .2s}
.facsim img:hover{transform:scale(1.03)}

/* RETRATOS / GALERIA */
.portraits{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}
.portraits img{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:12px;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .2s}
.portraits img:hover{transform:scale(1.04)}
.imig{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
@media(max-width:760px){.imig{grid-template-columns:1fr}}
.origins{list-style:none;padding:0;margin:0}
.origins li{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 18px;margin-bottom:10px;box-shadow:var(--shadow-sm)}
.origins b{color:var(--accent)}
.origins span{display:block;font-size:.88rem;color:#4f4639}
.galgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}
.galcell{position:relative;margin:0;border-radius:8px;overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);cursor:pointer;background:#e7ded0}
.galcell img{width:100%;aspect-ratio:1;object-fit:cover;display:block;transition:transform .2s}
.galcell:hover img{transform:scale(1.06)}
.galcell figcaption{position:absolute;left:0;right:0;bottom:0;font-size:.66rem;line-height:1.25;color:#fff;
  padding:14px 8px 7px;background:linear-gradient(transparent,rgba(0,0,0,.82));
  opacity:0;transform:translateY(6px);transition:opacity .18s,transform .18s;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;pointer-events:none}
.galcell:hover figcaption,.galcell:focus-within figcaption{opacity:1;transform:none}
@media(hover:none){.galcell figcaption{opacity:1;transform:none;font-size:.6rem;-webkit-line-clamp:2}}

/* BIBLIOTECA */
.storelink{display:inline-block;margin-bottom:22px;color:var(--accent);font-weight:600;text-decoration:none}
.storelink:hover{text-decoration:underline}
.books{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:22px}
.book{background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm);
  overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.book:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.book .coverwrap{background:#efe6d4;display:flex;align-items:center;justify-content:center;padding:18px;min-height:240px}
.book .coverwrap img{max-height:250px;max-width:100%;box-shadow:0 8px 22px rgba(40,25,10,.3);border-radius:2px}
.book .body{padding:18px 20px;display:flex;flex-direction:column;flex:1}
.book .yr{font-size:.72rem;color:var(--accent2);font-weight:600;letter-spacing:.08em}
.book h3{font-size:1.12rem;margin:5px 0}
.book p{font-size:.86rem;color:#4f4639;margin:.3em 0 0}
.book .serie{font-size:.72rem;color:var(--accent2);margin-top:8px;font-style:italic}
.book .price{font-size:1.15rem;color:var(--accent);font-weight:700;font-family:"Fraunces";margin-top:12px}
.buybtn{display:inline-block;text-align:center;margin-top:10px;background:var(--accent);color:#fff;
  text-decoration:none;font-size:.9rem;font-weight:500;padding:11px 16px;border-radius:30px;transition:background .15s;cursor:pointer}
.buybtn:hover{background:#86301a}

/* ANTES E DEPOIS */
.ba{position:relative;width:100%;max-width:860px;aspect-ratio:16/9;border-radius:16px;overflow:hidden;
  box-shadow:var(--shadow);border:1px solid var(--line);user-select:none;margin:0 auto}
.ba-after{position:absolute;inset:0;background:linear-gradient(160deg,#86a9c4,#b9cde0)}
.ba-after:after{content:"São João hoje (foto colorida)";position:absolute;inset:0;display:flex;
  align-items:center;justify-content:center;color:#fff;font-size:1.1rem;text-shadow:0 1px 4px rgba(0,0,0,.4)}
.ba-before{position:absolute;inset:0;width:50%;overflow:hidden;border-right:3px solid #fff;
  background:repeating-linear-gradient(45deg,#6b6256,#6b6256 8px,#5e564b 8px,#5e564b 16px)}
.ba-before:after{content:"São João antigamente (foto sépia)";position:absolute;top:0;left:0;height:100%;
  width:200%;display:flex;align-items:center;justify-content:center;color:#f0e2c8;font-size:1.1rem;
  filter:sepia(1);text-shadow:0 1px 4px rgba(0,0,0,.5)}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:40px;margin-left:-20px;cursor:ew-resize;
  display:flex;align-items:center;justify-content:center}
.ba-handle span{background:#fff;color:var(--accent);width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-weight:700;box-shadow:0 2px 10px rgba(0,0,0,.35)}
.ba-lbl{position:absolute;top:12px;font-size:.7rem;letter-spacing:.16em;background:rgba(20,15,10,.7);
  color:#fff;padding:5px 11px;border-radius:20px}
.ba-lbl-l{left:12px}.ba-lbl-r{right:12px}

/* CONTRIBUA */
.contrib{max-width:640px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:28px;box-shadow:var(--shadow-sm)}
.contrib label{display:block;font-size:.85rem;color:#4f4639;font-weight:600;margin-bottom:16px}
.contrib input,.contrib textarea{display:block;width:100%;margin-top:6px;padding:12px 15px;
  border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem;background:var(--bg)}
.contrib input:focus,.contrib textarea:focus{outline:none;border-color:var(--accent)}
.contrib-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:26px}
@media(max-width:760px){.contrib-cards{grid-template-columns:1fr}}
.contrib-card{text-align:left;cursor:pointer;font-family:inherit;background:var(--panel);border:1px solid var(--line);
  border-radius:16px;padding:20px 18px;box-shadow:var(--shadow-sm);transition:transform .15s,border-color .15s,box-shadow .15s}
.contrib-card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:var(--shadow)}
.contrib-card.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent) inset}
.contrib-card .cc-emoji{font-size:1.9rem;line-height:1}
.contrib-card h3{font-family:"Fraunces";font-size:1.18rem;margin:10px 0 6px;color:var(--ink)}
.contrib-card p{margin:0;font-size:.9rem;color:#4f4639;line-height:1.55}
.contrib-card .cc-go{display:inline-block;margin-top:12px;font-size:.85rem;font-weight:600;color:var(--accent)}

/* CITAÇÃO DE DOCUMENTO */
.docquote{margin:18px 0;padding:18px 22px;background:var(--panel);border-left:4px solid var(--accent2);
  border-radius:0 10px 10px 0;box-shadow:var(--shadow-sm);font-family:"Fraunces",Georgia,serif;
  font-size:1.08rem;line-height:1.6;color:#34291c;font-style:italic}
.docquote cite{display:block;margin-top:10px;font-family:"Inter";font-style:normal;font-size:.8rem;color:var(--accent2)}

/* FOOTER */
footer{background:var(--dark);color:#e7ded0;text-align:center;padding:48px 24px;margin-top:48px;font-size:.92rem}
footer a{color:var(--gold)}
footer .fbrand{font-family:"Fraunces";font-size:1.3rem;color:#fff;margin-bottom:6px}

/* LIGHTBOX + MODAL */
.lb{position:fixed;inset:0;background:rgba(15,11,7,.93);display:none;align-items:center;justify-content:center;z-index:200;flex-direction:column;padding:20px}
.lb.open{display:flex}
.lb img{max-width:94vw;max-height:80vh;border-radius:6px;box-shadow:0 10px 40px rgba(0,0,0,.6);cursor:zoom-in;transition:transform .18s ease}
.lb img.zoomed{transform:scale(2.6);cursor:zoom-out;border-radius:0}
.lb .cap{color:#e7ded0;font-size:.9rem;max-width:700px;text-align:center;margin-top:14px}
.lb .x{position:absolute;top:16px;right:22px;color:#fff;font-size:2rem;cursor:pointer;background:none;border:none;z-index:2}
.lb .lbnav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;
  border:none;background:rgba(255,255,255,.14);color:#fff;font-size:1.8rem;cursor:pointer;
  align-items:center;justify-content:center;transition:background .15s}
.lb .lbnav:hover{background:rgba(255,255,255,.28)}
.lb .lbprev{left:18px}.lb .lbnext{right:18px}
.lb .lbdl{margin-top:12px;color:#e7ded0;font-size:.82rem;text-decoration:none;border:1px solid rgba(255,255,255,.3);
  padding:7px 16px;border-radius:20px}
.lb .lbdl:hover{background:rgba(255,255,255,.12)}
@media(max-width:640px){.lb .lbnav{width:42px;height:42px;font-size:1.4rem}.lb .lbprev{left:6px}.lb .lbnext{right:6px}}
.modal{position:fixed;inset:0;background:rgba(20,15,10,.6);display:none;align-items:center;justify-content:center;z-index:210;padding:20px}
.modal.open{display:flex}
.modal-box{background:var(--bg);max-width:680px;width:100%;border-radius:16px;padding:32px 34px;
  box-shadow:0 20px 60px rgba(0,0,0,.4);position:relative;max-height:85vh;overflow:auto}
.modal-box h3{color:var(--accent);font-size:1.7rem;margin-top:0;font-family:"Fraunces",Georgia,serif}
#m-body{font-size:1.05rem;line-height:1.75;color:#34291c}
#m-body p{margin:.7em 0}
.modal-close{position:absolute;top:14px;right:18px;cursor:pointer;font-size:1.6rem;color:var(--muted);border:none;background:none}
.modal-src{margin-top:16px;padding-top:12px;border-top:1px solid var(--line);font-size:.82rem;color:var(--accent2);font-style:italic}

@media(max-width:640px){
  .nav-inner{padding:12px 18px}
  section.block,.hall{padding:44px 18px}
  .hero .inner{padding:0 18px 52px}
  .pagehead .inner{padding:0 18px 24px}
}

/* ---- Cruzamento legenda ↔ páginas ---- */
.lblinks{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;align-items:center;max-width:680px;margin:6px auto 0}
.lblbl{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:#d9b78a;margin-right:2px}
.lbchip{font-size:.82rem;color:#fff;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);
  padding:3px 10px;border-radius:999px;text-decoration:none;transition:background .12s}
.lbchip:hover{background:var(--accent);border-color:var(--accent)}
.mfotos{display:grid;grid-template-columns:repeat(auto-fill,minmax(76px,1fr));gap:6px;margin:.3em 0 .6em}
.mfoto{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:8px;cursor:pointer;border:1px solid var(--line);
  transition:transform .12s,box-shadow .12s}
.mfoto:hover{transform:scale(1.04);box-shadow:var(--shadow-sm)}

/* ---- Selos de família (fotos / árvore) ---- */
.fam-badges{display:flex;flex-wrap:wrap;gap:6px;margin:.4em 0 .2em}
.fbadge{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:600;color:var(--accent);
  background:#fbeee6;border:1px solid #e9d3c4;border-radius:999px;padding:2px 9px;line-height:1.4}
.fbadge.tree{color:#3f6552;background:#e9f1ec;border-color:#cfe1d6}


/* ---- Bloco "Como usar esta página" ---- */
.howto{max-width:var(--max);margin:0 auto;padding:18px 32px 0}
.howto-in{display:flex;gap:10px;align-items:flex-start;background:#fbf3ea;border:1px solid #ecdcc9;border-left:4px solid var(--accent2);border-radius:12px;padding:12px 16px;box-shadow:var(--shadow-sm)}
.howto-i{font-size:1.05rem;line-height:1.4;flex:0 0 auto}
.howto p{margin:0;font-size:.92rem;color:#5d4a33;line-height:1.5}
.howto b{color:var(--accent)}
@media(max-width:640px){.howto{padding:14px 18px 0}.howto p{font-size:.88rem}}

/* ---- Bibliografia: capas ---- */
.biblio.has-cover{display:flex;gap:14px;align-items:flex-start}
.biblio-cover{flex:0 0 72px;cursor:pointer}
.biblio-cover img{width:72px;height:98px;object-fit:cover;border-radius:6px;border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:transform .12s}
.biblio-cover img:hover{transform:scale(1.05)}
.biblio-bd{flex:1;min-width:0}

/* ---- Bibliografia: capa tipográfica gerada ---- */
.biblio-cover.gen{flex:0 0 72px;width:72px;height:98px;border-radius:6px;border:1px solid #d9cdb6;box-shadow:var(--shadow-sm);
  background:linear-gradient(135deg,#7a3b1d,#a23b1e);color:#fff7ef;display:flex;flex-direction:column;justify-content:space-between;
  padding:8px 7px;overflow:hidden;cursor:default}
.biblio-cover.gen.alt{background:linear-gradient(135deg,#3f5e4e,#5f8f85)}
.biblio-cover.gen .gt{font-family:"Fraunces",Georgia,serif;font-weight:600;font-size:.58rem;line-height:1.12;
  display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}
.biblio-cover.gen .ga{font-size:.46rem;opacity:.9;border-top:1px solid rgba(255,255,255,.35);padding-top:3px;margin-top:4px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ============================================================
   ETAPA 1 — Fundação visual (revelação, hero, botões, foco)
   ============================================================ */
:root{
  --radius:14px; --radius-lg:18px;
  --accent-d:#86301a; --ease:cubic-bezier(.22,.61,.36,1);
  --shadow-lg:0 18px 50px rgba(40,28,14,.16);
}
/* foco acessível e consistente */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2.5px solid var(--accent);outline-offset:2px;border-radius:4px}

/* botão reutilizável */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:inherit;font-size:.95rem;font-weight:600;
  padding:12px 22px;border-radius:999px;text-decoration:none;cursor:pointer;border:1.5px solid transparent;
  transition:transform .15s var(--ease),background .15s,color .15s,border-color .15s,box-shadow .15s;line-height:1}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 6px 18px rgba(162,59,30,.28)}
.btn-primary:hover{background:var(--accent-d);transform:translateY(-2px);box-shadow:0 10px 26px rgba(162,59,30,.34)}
.btn-ghost{background:rgba(255,255,255,.10);color:#fff;border-color:rgba(255,255,255,.55);backdrop-filter:blur(4px)}
.btn-ghost:hover{background:rgba(255,255,255,.20);transform:translateY(-2px)}
.btn-outline{background:#fff;color:var(--accent);border-color:var(--line)}
.btn-outline:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow)}

/* revelação ao rolar (aplicada via JS = progressive enhancement) */
@media(prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(22px);
    transition:opacity .7s var(--ease),transform .7s var(--ease)}
  .reveal.in{opacity:1;transform:none}
}

/* hero com mais vida (somente home) */
@media(prefers-reduced-motion:no-preference){
  .hero .bg{animation:kenburns 20s var(--ease) forwards;will-change:transform}
  @keyframes kenburns{from{transform:scale(1.09)}to{transform:scale(1)}}
  .hero .inner>*{opacity:0;animation:heroin .85s var(--ease) forwards}
  .hero .overline{animation-delay:.10s}
  .hero h1{animation-delay:.22s}
  .hero .sub{animation-delay:.38s}
  .hero .by{animation-delay:.52s}
  .hero .herocta{animation-delay:.64s}
  .hero .scrollcue{animation-delay:.8s}
  @keyframes heroin{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
  .hero .scrollcue{animation:heroin .85s var(--ease) .8s forwards, bob 2.4s ease-in-out 1.8s infinite}
  @keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
}
/* refinamento do scrim do hero: um respiro quente embaixo */
.hero .scrim{background:linear-gradient(180deg,rgba(20,15,10,.28) 0%,rgba(20,15,10,.10) 34%,rgba(26,16,10,.82) 100%)}
.hero .herocta{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}

/* cartões/tiles um grau mais refinados */
.tile{transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.tile .lbl h3{transition:color .2s}

/* ============================================================
   ETAPA 2 — Mapa-espinha (controle de tempo + filtros)
   ============================================================ */
.mapspine{position:relative}
#realmap{height:68vh;min-height:440px;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow)}
/* tom de mapa antigo, só nas tiles (marcadores ficam nítidos) */
.leaflet-tile{filter:sepia(.30) saturate(.82) contrast(.95) brightness(1.03)}
.timebar{margin:16px 0 6px;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius);padding:16px 20px;box-shadow:var(--shadow-sm)}
.timebar .tr{display:flex;align-items:baseline;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.timeyear{font-family:"Fraunces",Georgia,serif;font-size:1.6rem;color:var(--accent);font-weight:600;line-height:1}
.timeera{font-size:.84rem;color:var(--accent2);letter-spacing:.03em}
.timecount{font-size:.8rem;color:var(--muted);margin-left:auto}
.timebar input[type=range]{width:100%;accent-color:var(--accent);cursor:pointer;height:22px}
.timeticks{display:flex;justify-content:space-between;font-size:.68rem;color:var(--muted);margin-top:2px}
.catfilter{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 2px}
.catchip{display:inline-flex;align-items:center;gap:7px;font-size:.82rem;padding:7px 13px;border-radius:999px;
  border:1px solid var(--line);background:var(--panel);cursor:pointer;color:#4f4639;transition:.15s;user-select:none}
.catchip .sw{width:11px;height:11px;border-radius:50%;flex:0 0 auto}
.catchip .sw.line{width:16px;height:0;border-radius:0;border-top:3px dashed currentColor}
.catchip.off{opacity:.42;background:var(--bg)}
.catchip:hover{border-color:var(--accent2);transform:translateY(-1px)}
.timehint{font-size:.8rem;color:var(--muted);margin:10px 0 0}
.leaflet-popup-content b{color:var(--accent)}
.leaflet-popup-content a{color:var(--accent);font-weight:600}

/* ============================================================
   ETAPA 3 — Narrativa scrollytelling
   ============================================================ */
.scrolly{max-width:var(--max);margin:0 auto 36px;padding:0 32px;
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.scrolly-steps{display:flex;flex-direction:column}
.scrolly-step{min-height:80vh;display:flex;align-items:center}
.scrolly-step .sc-card{background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--accent);
  border-radius:var(--radius);padding:26px 28px;box-shadow:var(--shadow);
  opacity:.42;transform:translateY(10px);transition:opacity .4s var(--ease),transform .4s var(--ease)}
.scrolly-step.active .sc-card{opacity:1;transform:none;box-shadow:var(--shadow-lg)}
.scrolly-step .sc-k{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent2);font-weight:600}
.scrolly-step h3{font-size:1.5rem;color:var(--accent);margin:.2em 0 .4em}
.scrolly-step p{font-size:1rem;color:#34291c;line-height:1.7;margin:.5em 0 0}
.scrolly-media{position:sticky;top:9vh;height:82vh;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-lg);border:1px solid var(--line);background:#1a1611}
.scrolly-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0;transform:scale(1.06);transition:opacity 1s var(--ease),transform 6s var(--ease)}
.scrolly-media img.on{opacity:1;transform:scale(1)}
.scrolly-media .sc-scrim{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(20,15,10,.12),rgba(20,15,10,.66))}
.scrolly-media .sc-cap{position:absolute;left:0;right:0;bottom:0;padding:20px 24px;color:#fff;font-size:.86rem;
  line-height:1.4;text-shadow:0 1px 8px rgba(0,0,0,.5)}
.scrolly-media .sc-cap b{color:var(--gold)}
.scrolly-prog{position:absolute;top:0;left:0;height:4px;background:var(--accent);width:0;transition:width .3s var(--ease);z-index:3}
@media(max-width:820px){
  .scrolly{grid-template-columns:1fr;gap:0;padding:0 18px}
  .scrolly-media{order:-1;position:sticky;top:0;height:44vh;border-radius:0 0 var(--radius) var(--radius)}
  .scrolly-steps{margin-top:18px}
  .scrolly-step{min-height:64vh}
  .scrolly-step .sc-card{opacity:1;transform:none}
}
@media(prefers-reduced-motion:reduce){
  .scrolly-media img{transition:opacity .2s}
  .scrolly-step .sc-card{opacity:1;transform:none}
}

/* ===== Etapa 4 — busca na Home ===== */
.homesearch{display:flex;gap:10px;max-width:620px;margin:0 0 30px;flex-wrap:wrap}
.homesearch input{flex:1;min-width:220px;padding:14px 20px;border:1px solid var(--line);border-radius:999px;
  font-size:1rem;font-family:inherit;background:var(--panel);box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s}
.homesearch input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(162,59,30,.12)}
.homesearch .btn-primary{flex:0 0 auto}

/* ===== Heroes: contraste garantido (scrim mais forte) ===== */
.pagehead .scrim{background:linear-gradient(180deg,rgba(20,15,10,.30) 0%,rgba(20,15,10,.46) 46%,rgba(20,15,10,.92) 100%)}
.pagehead h1{text-shadow:0 2px 22px rgba(0,0,0,.55)}
.pagehead p{text-shadow:0 1px 10px rgba(0,0,0,.55)}
.pagehead .overline{text-shadow:0 1px 8px rgba(0,0,0,.5)}
.hero .scrim{background:linear-gradient(180deg,rgba(20,15,10,.30) 0%,rgba(20,15,10,.12) 34%,rgba(26,16,10,.88) 100%)}

/* ===== Compartilhar histórias + âncora ===== */
article[id]{scroll-margin-top:90px}
.story-anchor{font-size:.62em;color:var(--accent2);text-decoration:none;opacity:0;transition:opacity .15s;vertical-align:middle}
.mem-body h3:hover .story-anchor,.story-anchor:focus{opacity:.75}
.story-anchor:hover{opacity:1;text-decoration:underline}
.story-share{margin-top:14px;padding-top:12px;border-top:1px solid var(--line);font-size:.82rem;color:var(--muted);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.story-share a{color:#1f8a4c;font-weight:600;text-decoration:none}
.story-share a:hover{text-decoration:underline}
.story-share button{font:inherit;font-size:.82rem;background:none;border:none;color:var(--accent);font-weight:600;cursor:pointer;padding:0}
.story-share button:hover{text-decoration:underline}
.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%,14px);background:var(--ink);color:#fff;
  padding:10px 18px;border-radius:999px;font-size:.88rem;box-shadow:var(--shadow);opacity:0;
  transition:opacity .22s var(--ease),transform .22s var(--ease);z-index:300;pointer-events:none}
.toast.show{opacity:1;transform:translate(-50%,0)}

/* ===== Acessibilidade: pular para o conteúdo ===== */
.skip-link{position:fixed;left:12px;top:-60px;z-index:200;background:var(--accent);color:#fff;
  padding:10px 16px;border-radius:8px;font-weight:600;text-decoration:none;box-shadow:var(--shadow);transition:top .15s var(--ease)}
.skip-link:focus{top:12px;outline:2px solid #fff;outline-offset:2px}
#conteudo{scroll-margin-top:80px}
[tabindex="-1"]:focus{outline:none}

/* ============================================================
   Repositório: ficha de item (item.html) + Tudo sobre… (lugar.html)
   ============================================================ */
.ficha-head .ficha-cod{display:inline-block;font-family:ui-monospace,monospace;font-size:.74rem;letter-spacing:.04em;
  color:var(--accent);background:#fbeee6;border:1px solid #e9d3c4;border-radius:6px;padding:2px 9px}
.ficha-grid{display:grid;grid-template-columns:minmax(260px,380px) 1fr;gap:26px;align-items:start;margin-top:14px}
@media(max-width:760px){.ficha-grid{grid-template-columns:1fr}}
.ficha-img{margin:0;background:#efe6d4;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm);cursor:zoom-in}
.ficha-img img{width:100%;display:block}
.ficha-img figcaption{font-size:.74rem;color:var(--muted);text-align:center;padding:7px}
.ficha-tab{width:100%;border-collapse:collapse;font-size:.92rem}
.ficha-tab th{text-align:left;vertical-align:top;width:38%;color:var(--accent2);font-weight:600;padding:9px 12px 9px 0;border-bottom:1px solid var(--line)}
.ficha-tab td{vertical-align:top;color:#34291c;padding:9px 0;border-bottom:1px solid var(--line)}
.ficha-tab td.pend{color:var(--muted);font-style:italic}
.badge-conf,.badge-acc{display:inline-block;font-size:.78rem;font-weight:600;border-radius:999px;padding:2px 11px}
.badge-conf{color:#3f6552;background:#e9f1ec;border:1px solid #cfe1d6}
.badge-acc{color:var(--accent);background:#fbeee6;border:1px solid #e9d3c4}
.ficha-sec,.hub-sec{margin-top:30px}
.ficha-sec h2,.hub-sec h2{font-size:1.25rem;color:var(--ink);margin:0 0 12px}
.ficha-rel{display:flex;gap:8px;flex-wrap:wrap}
.ficha-rel a{display:block;width:92px;height:92px;border-radius:8px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.ficha-rel img{width:100%;height:100%;object-fit:cover;transition:transform .2s}
.ficha-rel a:hover img{transform:scale(1.08)}
.cite-box{font-size:.9rem;color:#4f4639;background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--accent2);
  border-radius:0 10px 10px 0;padding:14px 18px;line-height:1.6}
.hub-idx{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}
.hub-chip{display:inline-block;font-size:.9rem;padding:8px 15px;border-radius:999px;border:1px solid var(--line);
  background:var(--panel);color:var(--ink);text-decoration:none;box-shadow:var(--shadow-sm);transition:.15s}
.hub-chip:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.hub-sec h2 .bcount{font-size:.82rem;color:var(--muted);font-weight:400}

/* ===== Contribua estruturada (Doe uma memória) ===== */
.contrib-fields{display:grid;grid-template-columns:1fr 1fr;gap:0 16px;margin-bottom:0}
.contrib-fields label:first-child{grid-column:1 / -1}
@media(max-width:560px){.contrib-fields{grid-template-columns:1fr}}
.contrib-check{display:flex!important;align-items:flex-start;gap:9px;font-weight:400!important;color:#4f4639;background:var(--bg);
  border:1px solid var(--line);border-radius:10px;padding:11px 14px;margin-bottom:10px;cursor:pointer}
.contrib-check input{width:auto!important;margin:2px 0 0!important;flex:0 0 auto}
.contrib select{display:block;width:100%;margin-top:6px;padding:12px 15px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem;background:var(--bg)}
.hub-more{display:inline-flex;align-items:center;font-size:.82rem;color:var(--muted);padding:8px 4px}

/* ===== Portal: temas + andaimes ===== */
.tema-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-top:8px}
.tema-card{display:flex;gap:14px;align-items:flex-start;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius);padding:18px 20px;text-decoration:none;color:var(--ink);box-shadow:var(--shadow-sm);
  transition:transform .15s var(--ease),box-shadow .15s,border-color .15s}
.tema-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--accent2)}
.tema-emoji{font-size:1.8rem;line-height:1;flex:0 0 auto}
.tema-card h3{font-size:1.15rem;color:var(--accent);margin:0 0 .2em}
.tema-card p{font-size:.9rem;color:#4f4639;margin:0 0 .4em;line-height:1.5}
.tema-n{font-size:.78rem;color:var(--accent2);font-weight:600}
.scaffold{background:#fbf3ea;border:1px solid #ecdcc9;border-left:4px solid var(--accent2);border-radius:12px;padding:16px 20px;margin:18px 0;color:#5d4a33;font-size:.95rem}
.scaffold b{color:var(--accent)}
.src-list{list-style:none;padding:0;margin:18px 0}
.src-list li{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 18px;margin-bottom:10px;box-shadow:var(--shadow-sm)}
.src-list .st{font-size:.74rem;color:var(--accent2);font-weight:600;text-transform:uppercase;letter-spacing:.05em}

/* ===== Home: Descubra (foto misteriosa + neste dia) ===== */
.disc-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:680px){.disc-grid{grid-template-columns:1fr}}
.disc-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.disc-ph{position:relative;height:200px;overflow:hidden;background:#e7ded0;cursor:zoom-in}
.disc-ph img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.disc-ph:hover img{transform:scale(1.05)}
.disc-tag{position:absolute;left:12px;top:12px;font-size:.72rem;font-weight:600;color:#fff;background:rgba(162,59,30,.92);padding:3px 11px;border-radius:999px}
.disc-bd{padding:18px 20px;display:flex;flex-direction:column;flex:1}
.disc-bd h3{font-size:1.2rem;color:var(--accent);margin:0 0 .3em}
.disc-bd p{font-size:.92rem;color:#4f4639;margin:.1em 0}
.disc-cta{margin-top:auto;padding-top:10px}
.disc-cta a{font-weight:600;color:var(--accent);text-decoration:none}
.disc-cta a:hover{text-decoration:underline}
.disc-fact{justify-content:center}
.disc-tag2{font-size:.74rem;font-weight:600;letter-spacing:.04em;color:var(--accent2);text-transform:uppercase;margin-bottom:6px}
