/* ============================================================
   TRANTOR — Wiki do Cenário
   Tema "pergaminho" inspirado no material em PDF (v1.0, 2024).
   Paleta: papel envelhecido, tinta marrom, destaque bordô,
   títulos em blackletter, caixas "Informação de Jogo".
   ============================================================ */

:root {
  /* Pergaminho */
  --parch:       #e9dcbf;
  --parch-2:     #e2d2af;   /* sombreado / faixas */
  --parch-edge:  #cdb98d;
  --leather:     #241910;   /* fundo (couro/madeira) */
  --leather-2:   #160f08;

  /* Tinta */
  --ink:         #2a1d11;
  --ink-soft:    #4a3826;
  --ink-faint:   #6b5944;

  /* Bordô (destaque) */
  --wine:        #7c2329;
  --wine-deep:   #531417;
  --wine-soft:   #9a3b40;

  /* Ouro / ornamento */
  --gold:        #b08a4e;
  --gold-deep:   #8a6a36;

  --line:        rgba(74, 56, 38, 0.30);
  --line-strong: rgba(42, 29, 17, 0.55);

  --radius:      6px;
  --sidebar-w:   288px;
  --header-h:    62px;
  --measure:     74ch;

  --serif:  'EB Garamond', Georgia, 'Times New Roman', serif;
  --black:  'MedievalSharp', 'EB Garamond', serif;   /* títulos (medieval legível) */
  --caps:   'Cinzel', Georgia, serif;                 /* caps romanas — rótulos/nav */
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: var(--serif);
  font-size: 19px;
  line-height: 1.7;
  color: var(--ink);
  background-color: var(--leather);
  /* textura de couro escura ao fundo */
  background-image:
    radial-gradient(1200px 600px at 50% -10%, rgba(120, 92, 56, .22), transparent 60%),
    radial-gradient(900px 500px at 50% 120%, rgba(80, 20, 23, .18), transparent 60%);
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}

a { color: var(--wine); text-decoration: none; }
a:hover { color: var(--wine-deep); text-decoration: underline; text-underline-offset: 2px; }
img { display: block; max-width: 100%; }

/* Folha de pergaminho reutilizável (textura de papel) */
.parchment {
  background-color: var(--parch);
  background-image:
    /* grão de papel (turbulência SVG) */
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E"),
    /* manchas de envelhecimento */
    radial-gradient(120px 90px at 12% 18%, rgba(120, 86, 40, .12), transparent 70%),
    radial-gradient(160px 120px at 88% 26%, rgba(120, 86, 40, .10), transparent 70%),
    radial-gradient(200px 160px at 70% 88%, rgba(90, 60, 28, .12), transparent 70%),
    radial-gradient(140px 110px at 24% 82%, rgba(90, 60, 28, .10), transparent 70%),
    /* vinheta das bordas */
    radial-gradient(circle at 50% 50%, transparent 62%, rgba(120, 92, 50, .18) 100%);
}

/* ============================================================
   App shell
   ============================================================ */
.app { min-height: 100vh; display: flex; flex-direction: column; padding-top: var(--header-h); }

/* ---------- Cabeçalho (fixo: nunca rola junto) ---------- */
header.topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 60;
  height: var(--header-h);
  display: flex; align-items: center; gap: 14px;
  padding: 0 18px;
  background:
    linear-gradient(180deg, #2e2013, #1c130a);
  border-bottom: 2px solid var(--gold-deep);
  box-shadow: 0 4px 18px rgba(0,0,0,.45);
}
.topbar .menu-btn {
  display: none;
  width: 42px; height: 42px; flex: 0 0 auto;
  background: rgba(255,255,255,.05); border: 1px solid rgba(176,138,78,.4);
  border-radius: 8px; cursor: pointer; color: var(--parch);
  flex-direction: column; align-items: center; justify-content: center; gap: 5px;
}
.topbar .menu-btn span { display:block; width: 20px; height: 2px; background: var(--gold); border-radius: 2px; }

.brand { display: flex; align-items: center; gap: 12px; color: var(--parch); }
.brand img { height: 40px; width: 40px; object-fit: contain; filter: drop-shadow(0 2px 4px rgba(0,0,0,.6)); }
.brand .titles { line-height: 1; }
.brand .name { font-family: var(--caps); font-weight: 700; font-size: 1.3rem; letter-spacing: .22em; color: #f0e3c4; }
.brand .tag  { font-family: var(--caps); font-size: .62rem; letter-spacing: .34em; color: var(--gold); text-transform: uppercase; }

.topbar .spacer { flex: 1; }

/* Busca */
.search { position: relative; }
.search input {
  font-family: var(--serif); font-size: .98rem;
  width: 210px; max-width: 40vw;
  padding: 8px 12px 8px 34px;
  color: #f0e3c4; background: rgba(0,0,0,.28);
  border: 1px solid rgba(176,138,78,.45); border-radius: 999px;
  outline: none; transition: border-color .2s, width .2s, background .2s;
}
.search input::placeholder { color: rgba(240,227,196,.55); }
.search input:focus { border-color: var(--gold); background: rgba(0,0,0,.42); width: 240px; }
.search svg { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); width: 15px; height: 15px; stroke: var(--gold); fill: none; }
.search .results {
  position: absolute; top: calc(100% + 8px); right: 0; width: 340px; max-width: 80vw;
  max-height: 60vh; overflow: auto; display: none;
  background: var(--parch); border: 1px solid var(--ink-faint); border-radius: 8px;
  box-shadow: 0 18px 44px rgba(0,0,0,.5); padding: 6px;
}
.search .results.open { display: block; }
.search .results a {
  display: block; padding: 8px 10px; border-radius: 6px; color: var(--ink);
  font-size: .96rem; line-height: 1.3;
}
.search .results a small { display:block; color: var(--ink-faint); font-family: var(--caps); font-size: .62rem; letter-spacing: .12em; text-transform: uppercase; }
.search .results a:hover { background: var(--parch-2); text-decoration: none; }
.search .results .empty { padding: 10px; color: var(--ink-faint); font-style: italic; }

/* Idioma */
.lang { display: inline-flex; gap: 2px; padding: 3px; background: rgba(0,0,0,.28); border: 1px solid rgba(176,138,78,.4); border-radius: 999px; }
.lang button { border: 0; background: transparent; color: rgba(240,227,196,.6); font-family: var(--caps); font-weight: 600; font-size: .68rem; letter-spacing: .08em; padding: 4px 9px; border-radius: 999px; cursor: pointer; }
.lang button:hover { color: #f0e3c4; }
.lang button.active { color: #1c130a; background: var(--gold); }

/* ---------- Corpo: sidebar + conteúdo ---------- */
.body-wrap { flex: 1; display: flex; align-items: stretch; max-width: 1300px; width: 100%; margin: 0 auto; min-height: calc(100vh - var(--header-h)); }

/* Sidebar (índice): a COLUNA estica (preenche o fundo); o miolo é que gruda */
aside.sidebar {
  flex: 0 0 var(--sidebar-w); width: var(--sidebar-w);
  background-color: #d8c69e;
  border-right: 2px solid var(--gold-deep);
}
.sidebar-inner {
  position: sticky; top: var(--header-h);
  max-height: calc(100vh - var(--header-h));
  overflow-y: auto;
  padding: 22px 14px 40px;
}
.sidebar-inner::-webkit-scrollbar { width: 9px; }
.sidebar-inner::-webkit-scrollbar-thumb { background: rgba(74,56,38,.32); border-radius: 9px; }
.sidebar-inner::-webkit-scrollbar-track { background: transparent; }
.sidebar .nav-group { margin-bottom: 18px; }
.sidebar .nav-group > .cat {
  display: flex; align-items: center; gap: 9px;
  font-family: var(--caps); font-weight: 700; font-size: .82rem; letter-spacing: .12em;
  text-transform: uppercase; color: var(--wine-deep);
  padding: 6px 8px; border-bottom: 1px solid var(--line); margin-bottom: 4px; cursor: pointer;
}
.sidebar .nav-group > .cat .ico { font-size: 1rem; filter: saturate(.7); }
.sidebar .nav-group ul { list-style: none; }
.sidebar .nav-group li a {
  display: block; padding: 5px 10px 5px 26px; border-radius: 5px;
  color: var(--ink-soft); font-size: 1rem; line-height: 1.35;
  border-left: 2px solid transparent;
}
.sidebar .nav-group li a:hover { background: rgba(124,35,41,.08); color: var(--ink); text-decoration: none; }
.sidebar .nav-group li a.active { background: rgba(124,35,41,.12); color: var(--wine-deep); border-left-color: var(--wine); font-weight: 600; }
.sidebar .nav-group .cat.home-link { color: var(--ink); }

/* Conteúdo */
main.content {
  flex: 1 1 auto; min-width: 0;
  padding: 0;
  background-color: var(--parch);
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E"),
    radial-gradient(220px 160px at 92% 8%, rgba(120, 86, 40, .10), transparent 70%),
    radial-gradient(260px 200px at 6% 92%, rgba(90, 60, 28, .10), transparent 70%);
  box-shadow: inset 0 0 80px rgba(120, 92, 50, .14);
}
.article { max-width: 900px; margin: 0 auto; padding: 40px 46px 80px; }

/* Breadcrumb */
.crumbs { font-family: var(--caps); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 14px; }
.crumbs a { color: var(--ink-faint); }
.crumbs a:hover { color: var(--wine); }
.crumbs span { margin: 0 7px; }

/* ============================================================
   Tipografia de artigo
   ============================================================ */
.article h1 {
  font-family: var(--black); font-weight: 700;
  font-size: clamp(2.4rem, 6vw, 3.6rem); line-height: 1.04;
  color: var(--ink); letter-spacing: .01em;
  margin-bottom: 6px; padding-bottom: 12px;
  position: relative;
}
/* sublinhado duplo do PDF */
.article h1::after {
  content: ""; position: absolute; left: 0; bottom: 0; width: min(100%, 520px); height: 0;
  border-bottom: 3px solid var(--ink);
  box-shadow: 0 5px 0 -1px var(--ink);
}
.article .subtitle { font-family: var(--caps); font-size: .98rem; letter-spacing: .06em; color: var(--wine); font-weight: 600; margin: 14px 0 24px; }

.article h2 {
  font-family: var(--black); font-weight: 700;
  font-size: clamp(1.7rem, 4vw, 2.3rem); color: var(--ink);
  margin: 38px 0 4px; padding-bottom: 8px;
  border-bottom: 2px solid var(--ink); box-shadow: 0 4px 0 -2px var(--ink);
  width: fit-content; max-width: 100%;
}
.article h3 {
  font-family: var(--caps); font-weight: 700; font-size: 1.18rem; letter-spacing: .04em;
  color: var(--wine-deep); margin: 26px 0 6px;
}
.article p { margin: 0 0 1.05em; max-width: var(--measure); text-align: justify; hyphens: auto; }
.article p:first-of-type::first-letter,
.article .lead::first-letter {
  /* capitular discreta no parágrafo de abertura */
}
.article .lead { font-size: 1.08rem; color: var(--ink); }
.article ul, .article ol { margin: 0 0 1.1em 1.4em; max-width: var(--measure); }
.article li { margin: 0 0 .4em; }
.article ul li::marker { color: var(--wine); }
.article strong { color: var(--ink); font-weight: 700; }
.article em { font-style: italic; }
.article u { text-decoration-color: var(--wine); text-underline-offset: 3px; }
.article a { font-weight: 600; }
.article hr { border: 0; margin: 30px auto; }

/* Imagem dentro do artigo */
.article figure { margin: 22px 0; }
.article figure img { border-radius: var(--radius); border: 1px solid var(--ink-faint); box-shadow: 0 8px 22px rgba(0,0,0,.28); }
.article figure figcaption { font-family: var(--caps); font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-faint); margin-top: 8px; text-align: center; }

/* ---------- Caixa "Informação de Jogo" ---------- */
.gamebox {
  border: 1px solid var(--ink-soft); border-radius: var(--radius);
  background: rgba(255,255,255,.28);
  padding: 16px 20px; margin: 22px 0;
  box-shadow: 0 2px 0 rgba(255,255,255,.4) inset, 0 6px 16px rgba(80,55,25,.10);
}
.gamebox .gb-title {
  font-family: var(--caps); font-weight: 700; font-size: .82rem; letter-spacing: .1em;
  text-transform: uppercase; color: var(--wine-deep);
  display: flex; align-items: center; gap: 8px; margin-bottom: 8px;
}
.gamebox .gb-title::before { content: "⚙"; font-size: 1rem; }
.gamebox p:last-child, .gamebox ul:last-child { margin-bottom: 0; }
.gamebox ul { margin-left: 1.2em; }

/* Bloco de destaque "lore" / citação */
.lorequote {
  border-left: 4px solid var(--wine); padding: 6px 0 6px 18px; margin: 22px 0;
  font-style: italic; color: var(--ink-soft); font-size: 1.1rem;
}

/* ---------- Infobox lateral (ficha) ---------- */
.infocard {
  float: right; width: 280px; margin: 6px 0 22px 28px;
  background: rgba(255,255,255,.34); border: 1px solid var(--ink-soft); border-radius: var(--radius);
  box-shadow: 0 8px 22px rgba(80,55,25,.18); overflow: hidden;
}
.infocard .ic-head { font-family: var(--caps); font-weight: 700; letter-spacing: .08em; text-transform: uppercase; font-size: .82rem; text-align: center; color: #f0e3c4; background: linear-gradient(180deg, var(--wine), var(--wine-deep)); padding: 9px 12px; }
.infocard img { width: 100%; }
.infocard .medallion { width: 170px; height: 170px; margin: 16px auto 6px; border-radius: 50%; border: 4px solid var(--ink); box-shadow: 0 6px 16px rgba(0,0,0,.4); object-fit: cover; background: #000; }
.infocard dl { margin: 8px 0 4px; padding: 0 14px 12px; }
.infocard dt { font-family: var(--caps); font-size: .64rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-faint); margin-top: 8px; }
.infocard dd { font-size: .98rem; color: var(--ink); }

/* ============================================================
   Cartões (índice de categoria / home)
   ============================================================ */
.cardgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 18px; margin: 8px 0 10px; }
.card {
  display: flex; flex-direction: column; overflow: hidden;
  background: rgba(255,255,255,.26); border: 1px solid var(--ink-soft); border-radius: var(--radius);
  box-shadow: 0 4px 14px rgba(80,55,25,.14); transition: transform .15s, box-shadow .15s, border-color .15s;
}
.card:hover { transform: translateY(-3px); box-shadow: 0 14px 30px rgba(80,55,25,.28); border-color: var(--wine); text-decoration: none; }
.card .thumb { aspect-ratio: 16/10; background: #2a1d11 center/cover no-repeat; border-bottom: 1px solid var(--ink-faint); }
.card .card-body { padding: 12px 15px 16px; }
.card .card-title { font-family: var(--caps); font-weight: 700; font-size: 1.05rem; color: var(--ink); letter-spacing: .02em; }
.card .card-desc { font-size: .95rem; color: var(--ink-soft); margin-top: 4px; line-height: 1.45; }

/* Lista compacta (ex.: lugares) */
.dl-entries { margin: 16px 0; }
.dl-entries .entry { padding: 12px 2px; border-bottom: 1px solid var(--line); }
.dl-entries .entry:last-child { border-bottom: 0; }
.dl-entries .entry .e-name { font-family: var(--caps); font-weight: 700; color: var(--wine-deep); letter-spacing: .03em; }
.dl-entries .entry .e-desc { color: var(--ink-soft); }

/* ============================================================
   Divisor ornamental (número de página do PDF)
   ============================================================ */
.divider { display: flex; align-items: center; gap: 14px; margin: 46px auto; color: var(--wine); max-width: var(--measure); }
.divider::before, .divider::after { content: ""; flex: 1; height: 2px; background: linear-gradient(90deg, transparent, var(--wine) 40%, var(--wine) 60%, transparent); }
.divider .node { width: 14px; height: 14px; border: 2px solid var(--wine); border-radius: 50%; flex: 0 0 auto; }
.divider .lozenge { width: 26px; height: 26px; border: 2px solid var(--wine); transform: rotate(45deg); display: grid; place-items: center; flex: 0 0 auto; }
.divider .lozenge span { transform: rotate(-45deg); font-family: var(--caps); font-weight: 700; font-size: .8rem; }

/* ============================================================
   Home / hero
   ============================================================ */
.hero {
  /* filha direta de <main> na home: mesma largura do main, sem estourar p/ a sidebar */
  position: relative; margin: 0 0 28px; padding: 64px 46px 54px;
  color: #f3e8cf; text-align: center;
  /* imagem de fundo escurecida ~40% (camada preta a 40%).
     Caminho relativo ao PRÓPRIO wiki.css (css/ -> ../img/), resolução confiável em todos os navegadores. */
  background: linear-gradient(rgba(0,0,0,.40), rgba(0,0,0,.40)), url('../img/fundo1.png') center/cover no-repeat;
  background-color: #2a1d11;
  border-bottom: 3px solid var(--gold-deep);
}
.hero img.crest { width: 132px; height: 132px; margin: 0 auto 14px; filter: drop-shadow(0 6px 16px rgba(0,0,0,.7)); }
.hero h1 { font-family: var(--black); font-size: clamp(3rem, 9vw, 5rem); line-height: 1; color: #f3e8cf; text-shadow: 0 3px 14px rgba(0,0,0,.7); border: 0; box-shadow: none; padding: 0; }
.hero h1::after { display: none; }
.hero .lede { font-size: 1.15rem; max-width: 640px; margin: 14px auto 0; color: #ecdcbb; text-shadow: 0 2px 8px rgba(0,0,0,.6); }

/* ============================================================
   Rodapé
   ============================================================ */
footer.site { background: linear-gradient(180deg, #1c130a, #0f0a05); border-top: 2px solid var(--gold-deep); color: rgba(240,227,196,.7); }
footer.site .inner { max-width: 1300px; margin: 0 auto; padding: 22px 24px; display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap; font-size: .9rem; }
footer.site a { color: var(--gold); }

/* ============================================================
   Atualizações recentes (home)
   ============================================================ */
.recent {
  margin: 4px 0 26px; border: 1px solid var(--ink-soft); border-radius: var(--radius);
  background: rgba(255,255,255,.28); padding: 14px 18px 6px;
  box-shadow: 0 2px 0 rgba(255,255,255,.4) inset, 0 6px 16px rgba(80,55,25,.10);
}
.recent-title {
  font-family: var(--caps); font-weight: 700; font-size: .82rem; letter-spacing: .12em;
  text-transform: uppercase; color: var(--wine-deep);
  display: flex; align-items: center; gap: 8px; margin-bottom: 6px;
}
.recent-title::before { content: "🪶"; }
.recent-list { list-style: none; margin: 0; }
.recent-list li { border-bottom: 1px dashed var(--line); }
.recent-list li:last-child { border-bottom: 0; }
.recent-list a { display: flex; align-items: baseline; gap: 12px; padding: 9px 4px; color: var(--ink); }
.recent-list a:hover { text-decoration: none; background: rgba(124,35,41,.06); }
.recent-list .r-cat { font-family: var(--caps); font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; color: var(--wine); flex: 0 0 auto; width: 140px; }
.recent-list .r-title { flex: 1 1 auto; font-weight: 600; }
.recent-list time { font-family: var(--caps); font-size: .7rem; color: var(--ink-faint); flex: 0 0 auto; white-space: nowrap; }
@media (max-width: 560px) {
  .recent-list a { flex-wrap: wrap; gap: 2px 10px; }
  .recent-list .r-cat { width: auto; order: 1; }
  .recent-list time { order: 2; margin-left: auto; }
  .recent-list .r-title { order: 3; flex-basis: 100%; }
}

/* ============================================================
   Estado vazio / 404
   ============================================================ */
.notice { text-align: center; padding: 60px 20px; color: var(--ink-soft); }
.notice .big { font-family: var(--black); font-size: 3rem; color: var(--wine); }

/* ============================================================
   Responsivo
   ============================================================ */
.backdrop { display: none; }

@media (max-width: 900px) {
  body { font-size: 18px; }
  .topbar .menu-btn { display: flex; }
  aside.sidebar {
    position: fixed; top: var(--header-h); bottom: 0; left: 0; z-index: 55; width: var(--sidebar-w);
    transform: translateX(-100%); transition: transform .25s ease;
    box-shadow: 6px 0 26px rgba(0,0,0,.4);
  }
  aside.sidebar.open { transform: none; }
  .sidebar-inner { position: static; max-height: none; height: 100%; }
  .backdrop.show { display: block; position: fixed; inset: var(--header-h) 0 0 0; background: rgba(0,0,0,.45); z-index: 54; }
  .article { padding: 28px 22px 70px; }
  .hero { margin: 0 0 24px; padding: 48px 22px 40px; }
  .infocard { float: none; width: 100%; margin: 18px 0; }
  .brand .tag { display: none; }
  .search input { width: 150px; }
}

@media (max-width: 540px) {
  .brand .name { font-size: 1.05rem; letter-spacing: .14em; }
  .search { display: none; }   /* a busca também vive dentro da sidebar no mobile, se necessário */
  .article h1 { font-size: 2.1rem; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition: none !important; }
}
