/* ==========================================================================
   site.css — landing "página de HQ" de librenzagarcia.science (versão V2)
   Estilo "splash irregular": a grade inteira inclina como um bloco, com
   sarjetas brancas diagonais uniformes; o quadro recorta as bordas num
   retângulo limpo. Troca de idioma PT/EN/ES em assets/site.js.
   Fontes: self-hospedadas via assets/fonts.css (Outfit, Source Serif 4, Bangers).
   ========================================================================== */

:root {
  --ink: #15161a;
  --paper: #ffffff;
  --text: #16161a;
  --muted: #6b6b76;
  --c-atlas: #2E7FD6;   /* azul    */
  --c-cere:  #7A5CE0;   /* roxo    */
  --c-indc:  #16A06B;   /* verde   */
  --c-ensa:  #E8531F;   /* laranja */
  --c-sobre: #F2B500;   /* amarelo */
  --c-conx:  #DA2E7D;   /* magenta */
  --font-display: 'Outfit', system-ui, sans-serif;
  --font-comic: 'Bangers', 'Outfit', system-ui, sans-serif;
  --font-serif: 'Source Serif 4', Georgia, serif;
}

* { box-sizing: border-box; }
body {
  margin: 0; background: var(--paper); color: var(--text);
  font-family: var(--font-serif); font-size: 16px; line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

/* ---------- topo ---------- */
.topbar { max-width: 1180px; margin: 0 auto; padding: 20px 24px 6px; display: flex; align-items: center; gap: 14px; }
.brand { font-family: var(--font-display); font-weight: 600; font-size: 15px; color: var(--ink); text-decoration: none; letter-spacing: -.01em; }
.brand .dot { color: var(--c-atlas); }
.tagline { font-family: var(--font-display); font-size: 12px; color: var(--muted); }
.lang-switch { margin-left: auto; display: flex; gap: 4px; }
.lang-switch button { font-family: var(--font-display); font-size: 12px; font-weight: 600; padding: 5px 9px; border: 2px solid var(--ink); background: #fff; color: var(--ink); border-radius: 6px; cursor: pointer; line-height: 1; }
.lang-switch button[aria-pressed="true"] { background: var(--ink); color: #fff; }

.cover-head { max-width: 1180px; margin: 0 auto; padding: 6px 24px 14px; }
.cover-head h1 { font-family: var(--font-display); font-weight: 600; font-size: clamp(24px, 4vw, 40px); line-height: 1.05; letter-spacing: -0.02em; margin: 4px 0 8px; color: var(--ink); max-width: 22ch; }
.cover-head p { margin: 0; font-size: 14.5px; color: var(--muted); max-width: 64ch; font-family: var(--font-display); }

/* ---------- rodapé compartilhado ---------- */
.strip { max-width: 1180px; margin: 16px auto 0; padding: 0 24px; }
.disclaimer { font-family: var(--font-display); font-size: 12.5px; line-height: 1.5; color: var(--muted); background: #f4f4f7; border: 2px solid var(--ink); border-radius: 10px; padding: 12px 16px; margin: 0; }
.ecosystem { max-width: 1180px; margin: 14px auto 0; padding: 0 24px; display: flex; flex-wrap: wrap; gap: 10px 14px; align-items: center; }
.ecosystem .lbl { font-family: var(--font-display); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
.ecosystem a { font-family: var(--font-display); font-size: 13px; font-weight: 500; text-decoration: none; color: var(--ink); }
.ecosystem a b { border-bottom: 3px solid var(--c-atlas); padding-bottom: 1px; }
.ecosystem a:hover { color: var(--c-atlas); }
footer.credit { max-width: 1180px; margin: 20px auto; padding: 14px 24px 0; border-top: 1px solid rgba(0,0,0,.12); font-family: var(--font-display); font-size: 12px; color: var(--muted); }

/* ==========================================================================
   utilitários de HQ
   ========================================================================== */
/* trama de meio-tom (halftone) sobre cor chapada */
.u-halftone::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image: radial-gradient(circle, rgba(0,0,0,0.30) 2.0px, transparent 2.6px);
  background-size: 11px 11px; mix-blend-mode: multiply; opacity: .42;
}
/* explosão de raios (sunburst) */
.u-sunburst::after {
  content: ""; position: absolute; inset: -20%; z-index: 0; pointer-events: none;
  background: repeating-conic-gradient(from 0deg at 50% 42%,
    rgba(255,255,255,0.20) 0deg 5deg, rgba(255,255,255,0) 5deg 11deg);
  mix-blend-mode: screen; opacity: .9;
}

/* legenda = caixa de quadrinho */
.cap {
  position: relative; z-index: 3; display: inline-block;
  background: #fff; border: 3px solid var(--ink); padding: 6px 12px 10px;
  box-shadow: 4px 4px 0 rgba(0,0,0,.30);
}
.kicker { font-family: var(--font-display); font-weight: 600; font-size: 9.5px; letter-spacing: 0.16em; text-transform: uppercase; color: #5a5a63; display: block; }
.title { font-family: var(--font-comic); font-weight: 400; font-size: 28px; line-height: 1.0; letter-spacing: 0.03em; color: var(--ink); text-transform: uppercase; margin: 3px 0 0; display: block; text-wrap: balance; }
.cap .title { margin-bottom: 1px; }

/* selo "em breve" */
.soon { font-family: var(--font-comic); font-size: 15px; letter-spacing: .03em; background: #fff; border: 3px solid var(--ink); padding: 1px 9px 2px; box-shadow: 3px 3px 0 rgba(0,0,0,.28); display: inline-block; }

/* ==========================================================================
   V2 — SPLASH IRREGULAR: a GRADE inteira é inclinada como um bloco
   (skew no container, não em cada painel) — sarjetas diagonais uniformes,
   sem overlap. O quadro (overflow:hidden) recorta as bordas num retângulo.
   ========================================================================== */
.comic-page { max-width: 1180px; margin: 12px auto 0; padding: 0 30px; }
.comic-frame { border: 5px solid var(--ink); background: #fff; box-shadow: 11px 11px 0 rgba(0,0,0,.2); overflow: hidden; }
.comic-grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr 1fr;
  grid-template-rows: 1fr 1fr 1fr;
  grid-template-areas:
    "atlas atlas cere"
    "atlas atlas indc"
    "sobre ensa  conx";
  gap: 11px;
  aspect-ratio: 1240 / 700;
  background: #fff;
  padding: 11px;
  /* o bloco inteiro inclina; overscan horizontal p/ cobrir o quadro */
  transform: skewX(-6deg); transform-origin: center;
  margin: 0 -46px; width: calc(100% + 92px);
}
.panel {
  position: relative; overflow: hidden;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 15px;
  text-decoration: none; color: var(--ink);
  background: var(--c);
  transition: filter .2s, outline-color .2s;
  will-change: filter;
}
/* conteúdo volta ao prumo (contra-skew) */
.panel > .ico { position: absolute; left: 50%; top: 40%; transform: translate(-50%,-50%) skewX(6deg); width: var(--iw, 120px); height: var(--iw, 120px); z-index: 1; opacity: .96; }
.panel > .ico svg { width: 100%; height: 100%; }
.panel > .cap { align-self: flex-start; max-width: 90%; display: table; transform: skewX(6deg) rotate(var(--rot, -1.4deg)); transform-origin: left bottom; margin-left: 4px; }
.panel .soon { position: absolute; right: 12px; top: 10px; z-index: 5; transform: skewX(6deg) rotate(7deg); }

/* desenho do quadro (placeholder SVG; troque por <img class="art">) */
.panel .art { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }

/* texturas mais fortes p/ energia de splash */
.comic-grid .u-halftone::before { opacity: .5; }
.comic-grid .u-sunburst::after { opacity: 1; }

.p-atlas { grid-area: atlas; --c: var(--c-atlas); padding: 20px 20px 20px 66px; --rot: -2deg; }
.p-cere  { grid-area: cere;  --c: var(--c-cere);  --iw: 90px; --rot: 1.4deg; }
.p-indc  { grid-area: indc;  --c: var(--c-indc);  --iw: 82px; --rot: -1.2deg; }
.p-ensa  { grid-area: ensa;  --c: var(--c-ensa);  --iw: 80px; --rot: 1.6deg; }
.p-sobre { grid-area: sobre; --c: var(--c-sobre); --iw: 82px; --rot: -1.6deg; padding-left: 66px; }
.p-conx  { grid-area: conx;  --c: var(--c-conx);  --iw: 86px; --rot: 1.2deg; }
/* selos das colunas das pontas recuados p/ não entrar na zona recortada */
.p-indc .soon, .p-cere .soon { right: 58px; }
.p-atlas > .ico { --iw: 182px; top: 34%; }
.p-atlas > .cap { margin-left: 4px; }
.p-atlas .title { font-size: 36px; }
.p-indc .title { font-size: 24px; }
.p-sobre .title { font-size: 22px; letter-spacing: .01em; }

/* hover: o quadro acende; vizinhos em p&b */
.comic-grid:hover .panel,
.comic-grid:focus-within .panel { filter: grayscale(100%) contrast(1.05) brightness(1.02); }
.comic-grid .panel:hover,
.comic-grid .panel:focus-visible { filter: none; z-index: 30; outline: 4px solid var(--ink); outline-offset: -4px; }
.panel.is-soon { cursor: default; }

/* ==========================================================================
   responsivo: empilha em coluna (sem skew)
   ========================================================================== */
@media (max-width: 720px) {
  .comic-grid { grid-template-columns: 1fr; grid-template-areas: "atlas" "cere" "indc" "ensa" "sobre" "conx"; aspect-ratio: auto; margin: 0; width: 100%; transform: none; }
  .panel { min-height: 132px; }
  .panel > .ico, .panel > .cap, .panel .soon { transform: none !important; }
  .panel > .cap { transform: rotate(-1.4deg) !important; }
  .comic-grid:hover .panel { filter: none; }
}

/* ==========================================================================
   ECOSSISTEMA — "outros mundos": página de HQ irmã da capa.
   Formatação levemente diferente: skew INVERTIDO (+6°), Kafka em destaque
   à direita, razão de aspecto mais baixa. Reusa .panel/.cap/.u-halftone.
   ========================================================================== */
:root { --c-clin: #1F8A70; --c-lite: #6B4FC2; --c-kafka: #E0356B; }

.eco-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1.06fr;
  grid-template-areas:
    "clin kafka kafka"
    "lite kafka kafka";
  gap: 11px; aspect-ratio: 1240 / 560; background: #fff; padding: 11px;
  transform: skewX(6deg); transform-origin: center;
  margin: 0 -46px; width: calc(100% + 92px);
}
/* contra-skew invertido (a grade inclina p/ +6°, conteúdo volta com -6°) */
.eco-grid .panel > .ico { transform: translate(-50%,-50%) skewX(-6deg); }
.eco-grid .panel > .cap { transform: skewX(-6deg) rotate(var(--rot, 1.4deg)); }
.eco-grid .u-halftone::before { opacity: .5; }
.eco-grid .u-sunburst::after  { opacity: 1; }

.p-clin  { grid-area: clin;  --c: var(--c-clin);  --iw: 86px;  --rot: 1.6deg; padding-left: 62px; }
.p-lite  { grid-area: lite;  --c: var(--c-lite);  --iw: 86px;  --rot: -1.4deg; padding-left: 62px; }
.p-kafka { grid-area: kafka; --c: var(--c-kafka); --iw: 150px; --rot: -2deg; padding: 20px 20px 20px 28px; }
.p-kafka .title { font-size: 34px; }
.eco-subs { font-family: var(--font-display); font-weight: 600; font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: #5a5a63; display: block; margin-top: 5px; }

/* "virar a página" de quadrinhos */
.page-nav { max-width: 1180px; margin: 14px auto 0; padding: 0 24px; }
.page-nav a { font-family: var(--font-comic); font-size: 18px; letter-spacing: .03em; color: var(--ink); text-decoration: none; border: 3px solid var(--ink); background: #fff; padding: 2px 13px; box-shadow: 3px 3px 0 rgba(0,0,0,.28); display: inline-block; }
.page-nav a:hover { background: var(--ink); color: #fff; }

@media (max-width: 720px) {
  .eco-grid { grid-template-columns: 1fr; grid-template-areas: "kafka" "clin" "lite"; aspect-ratio: auto; transform: none; margin: 0; width: 100%; }
  .eco-grid .panel { min-height: 140px; }
  .eco-grid .panel > .ico, .eco-grid .panel > .cap { transform: none !important; }
  .eco-grid .panel > .cap { transform: rotate(-1.4deg) !important; }
}
