/* ── Brasil 1600 — folha de estilo ─────────────────────────────── */
:root {
  --ink: #2b1f12;
  --ink-soft: #5a4632;
  --parchment: #efe3c8;
  --parchment-deep: #e6d6b4;
  --page: #171210;
  --page-soft: #221a14;
  --cream: #ede2cb;
  --cream-dim: #b9a888;
  --gold: #c9962e;
  --sea: #d8e0d2;
  --rust: #8c3b22;
  --line: #3a2d20;
  --serif: "EB Garamond", Georgia, "Times New Roman", serif;
  --display: "IM Fell English", "EB Garamond", Georgia, serif;
  --display-sc: "IM Fell English SC", "IM Fell English", Georgia, serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--serif);
  background: var(--page);
  color: var(--cream);
  font-size: 18px;
  line-height: 1.65;
}

a { color: var(--gold); text-decoration: none; border-bottom: 1px dotted rgba(201,150,46,.5); }
a:hover { color: #e8b84d; }

.wrap { max-width: 1180px; margin: 0 auto; padding: 0 24px; }

/* ── Hero ── */
.hero {
  padding: 96px 0 64px;
  text-align: center;
  background:
    radial-gradient(ellipse 90% 70% at 50% 0%, rgba(201,150,46,.10), transparent 60%),
    var(--page);
  border-bottom: 1px solid var(--line);
}
.hero h1 {
  font-family: var(--display);
  font-size: clamp(3rem, 8vw, 5.5rem);
  font-weight: 400;
  letter-spacing: .04em;
  color: var(--cream);
}
.hero h1 .ano { color: var(--gold); }
.hero .sub {
  max-width: 720px; margin: 20px auto 0;
  font-size: 1.25rem; color: var(--cream-dim); font-style: italic;
}
.hero .meta-nota {
  max-width: 680px; margin: 28px auto 0; font-size: .95rem;
  color: var(--cream-dim);
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  padding: 14px 10px;
}
.hero .meta-nota strong { color: var(--cream); }

/* ── Seções ── */
section { padding: 72px 0; }
section.alt { background: var(--page-soft); }
h2 {
  font-family: var(--display-sc);
  font-weight: 400;
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  letter-spacing: .06em;
  color: var(--cream);
  margin-bottom: 8px;
}
.h2-sub { color: var(--cream-dim); font-style: italic; margin-bottom: 36px; max-width: 800px; }
h2::before { content: "❧ "; color: var(--gold); }

/* ── Mapa ── */
#mapa { padding-top: 56px; }
.mapa-grid { display: grid; grid-template-columns: 1fr 340px; gap: 20px; align-items: start; }
.mapa-moldura {
  background: var(--parchment);
  border: 3px solid #5d4a2e;
  outline: 1px solid #2c2115;
  box-shadow: 0 18px 60px rgba(0,0,0,.55), inset 0 0 80px rgba(120,90,40,.25);
  border-radius: 3px;
  position: relative;
  overflow: hidden;
}
.mapa-moldura svg { display: block; width: 100%; height: auto; cursor: grab; }
.mapa-moldura svg:active { cursor: grabbing; }

.controles {
  position: absolute; top: 10px; left: 10px; z-index: 5;
  background: rgba(239,227,200,.93);
  border: 1px solid #8a6f47; border-radius: 3px;
  padding: 10px 14px; font-size: .85rem; color: var(--ink);
  box-shadow: 0 3px 12px rgba(43,31,18,.3);
}
.controles strong { font-family: var(--display-sc); font-weight: 400; letter-spacing: .05em; display: block; margin-bottom: 6px; border-bottom: 1px solid #b89d6f; padding-bottom: 4px; }
.controles label { display: flex; gap: 7px; align-items: center; cursor: pointer; padding: 2px 0; user-select: none; }
.controles input { accent-color: #8c3b22; }
.zoom-dica { position: absolute; bottom: 8px; left: 12px; z-index: 5; font-size: .75rem; color: #7a6243; font-style: italic; }

/* painel lateral */
.painel {
  background: var(--page-soft);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 24px;
  min-height: 420px;
  position: sticky; top: 16px;
}
.painel h3 { font-family: var(--display); font-weight: 400; font-size: 1.5rem; color: var(--gold); margin-bottom: 2px; }
.painel .painel-tipo { font-size: .85rem; text-transform: uppercase; letter-spacing: .12em; color: var(--cream-dim); margin-bottom: 14px; }
.painel p { font-size: 1rem; margin-bottom: 14px; }
.painel .fonte {
  font-size: .85rem; color: var(--cream-dim);
  border-left: 3px solid var(--gold); padding-left: 12px; font-style: italic;
}
.painel .fonte::before { content: "Fonte: "; font-style: normal; font-variant: small-caps; color: var(--gold); }
.badge-certeza { display: inline-block; font-size: .75rem; letter-spacing: .08em; text-transform: uppercase; padding: 2px 10px; border-radius: 2px; margin-bottom: 14px; border: 1px solid; }
.badge-certeza.documentado { color: #9dc18b; border-color: #44603a; }
.badge-certeza.estimativa { color: #d8b35e; border-color: #6e5a26; }
.badge-certeza.controverso { color: #d88f6e; border-color: #6e4226; }
.painel-vazio { color: var(--cream-dim); font-style: italic; }

/* tooltip */
#tooltip {
  position: fixed; pointer-events: none; z-index: 50; display: none;
  background: #2b1f12; color: var(--parchment);
  border: 1px solid var(--gold); border-radius: 3px;
  padding: 6px 12px; font-size: .9rem; max-width: 280px;
  box-shadow: 0 4px 16px rgba(0,0,0,.5);
}
#tooltip .tt-titulo { font-family: var(--display); color: var(--gold); }
#tooltip .tt-sub { font-size: .8rem; color: var(--cream-dim); }

/* ── Cartões de panorama ── */
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 20px; }
.card {
  background: var(--page-soft); border: 1px solid var(--line); border-radius: 4px;
  padding: 28px;
}
section.alt .card { background: var(--page); }
.card h3 { font-family: var(--display-sc); font-weight: 400; font-size: 1.3rem; letter-spacing: .05em; color: var(--gold); margin-bottom: 12px; }
.card p { font-size: .98rem; margin-bottom: 10px; }
.card .fonte-mini { font-size: .82rem; color: var(--cream-dim); font-style: italic; margin-top: 12px; border-top: 1px dashed var(--line); padding-top: 10px; }
.card .fonte-mini::before { content: "Fontes: "; font-variant: small-caps; font-style: normal; color: var(--gold); }

/* ── Tabela demografia ── */
table { width: 100%; border-collapse: collapse; font-size: .95rem; }
th, td { text-align: left; padding: 12px 14px; border-bottom: 1px solid var(--line); vertical-align: top; }
th { font-family: var(--display-sc); font-weight: 400; letter-spacing: .06em; color: var(--gold); font-size: 1rem; }
td.valor { font-family: var(--display); font-size: 1.15rem; color: var(--cream); white-space: nowrap; }
td .fonte-td { display: block; font-size: .82rem; color: var(--cream-dim); font-style: italic; margin-top: 4px; }
.aviso-estimativa {
  margin-top: 18px; font-size: .9rem; color: var(--cream-dim);
  background: var(--page-soft); border: 1px solid var(--line); border-left: 3px solid var(--gold);
  padding: 14px 18px; border-radius: 3px;
}

/* ── Cronologia ── */
.timeline { border-left: 2px solid var(--line); margin-left: 8px; padding-left: 32px; }
.evento { position: relative; padding-bottom: 26px; }
.evento::before {
  content: ""; position: absolute; left: -39px; top: 8px;
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--page); border: 2px solid var(--gold);
}
.evento .ano { font-family: var(--display); font-size: 1.35rem; color: var(--gold); }
.evento p { margin: 2px 0 4px; }
.evento .fonte-mini { font-size: .82rem; color: var(--cream-dim); font-style: italic; }
.evento .fonte-mini::before { content: "— "; }

/* ── Não existia ── */
.nao-lista { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 14px; }
.nao-item { background: var(--page); border: 1px solid var(--line); border-radius: 4px; padding: 18px 20px; }
.nao-item .quando { font-family: var(--display); color: var(--rust); font-size: 1.1rem; }
.nao-item strong { color: var(--cream); display: block; margin: 2px 0 4px; }
.nao-item p { font-size: .9rem; color: var(--cream-dim); }

/* ── Fontes ── */
.fontes-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.fontes-grid h3 { font-family: var(--display-sc); font-weight: 400; font-size: 1.35rem; letter-spacing: .05em; color: var(--gold); margin-bottom: 16px; }
.fontes-grid ul { list-style: none; }
.fontes-grid li { padding: 9px 0; border-bottom: 1px dashed var(--line); font-size: .95rem; }
.fontes-grid li em { color: var(--cream); }
.fontes-grid li .desc { color: var(--cream-dim); font-size: .88rem; }
.metodo { margin-top: 44px; background: var(--page-soft); border: 1px solid var(--line); border-radius: 4px; padding: 28px; }
.metodo h3 { font-family: var(--display-sc); font-weight: 400; color: var(--gold); font-size: 1.3rem; margin-bottom: 12px; }
.metodo p { font-size: .95rem; margin-bottom: 10px; }

footer {
  border-top: 1px solid var(--line); padding: 36px 0 48px;
  text-align: center; color: var(--cream-dim); font-size: .9rem;
}
footer .colofao { font-family: var(--display-sc); letter-spacing: .1em; color: var(--gold); margin-bottom: 6px; }

/* ── Rótulos dentro do SVG ── */
#mapa-svg text { font-family: var(--display), Georgia, serif; fill: var(--ink); }
#mapa-svg .rotulo-lugar { font-size: 11.5px; paint-order: stroke; stroke: rgba(239,227,200,.85); stroke-width: 2.5px; }
#mapa-svg .rotulo-povo {
  font-family: var(--serif); font-style: italic; font-size: 10.5px;
  letter-spacing: .18em; fill: #6e4226; text-anchor: middle;
  paint-order: stroke; stroke: rgba(239,227,200,.7); stroke-width: 2px;
}
#mapa-svg .rotulo-capitania {
  font-family: var(--display-sc); font-size: 9.5px; letter-spacing: .1em;
  fill: #7a6243; text-anchor: middle; opacity: .95;
}
#mapa-svg .rotulo-rio { font-style: italic; font-size: 10px; fill: #54707f; text-anchor: middle; letter-spacing: .08em; }
#mapa-svg .rotulo-latim { font-style: italic; font-size: 11px; fill: #8a6f47; }
#mapa-svg .rotulo-tordesilhas { font-size: 10.5px; fill: #8c3b22; text-anchor: middle; letter-spacing: .06em; }
#mapa-svg .rotulo-escala { font-size: 10px; fill: #5a4632; }
#mapa-svg .cart-titulo { font-family: var(--display-sc); font-size: 26px; letter-spacing: .35em; fill: #2b1f12; }
#mapa-svg .cart-sub { font-size: 14px; font-style: italic; fill: #5a4632; }
#mapa-svg .cart-mini { font-size: 9.5px; fill: #7a6243; }
#mapa-svg .rosa-n { font-family: var(--display-sc); font-size: 15px; fill: #2b1f12; text-anchor: middle; }
#mapa-svg .coroa { fill: #8c3b22; }

@media (max-width: 980px) {
  .mapa-grid { grid-template-columns: 1fr; }
  .painel { position: static; min-height: 0; }
  .fontes-grid { grid-template-columns: 1fr; }
}
