/* =============================================================
   moonpartridge — Sociedade Ornitológica
   Boletim Trimestral · Vol. III · Nº 05 · Maio MMXXVI
   -------------------------------------------------------------
   CONSTITUTION
   01 · Two colors: parchment #f1e8d3 + forest ink #15311f.
        Single accent: redbreast #c93d24 — once per section, on
        the italicised binomial name or a section's leading sign.
   02 · Type stack:
        · Instrument Serif (display, frequently italic)
        · Source Serif 4 (body)
        · IBM Plex Mono (taxonomy, figures, folio)
        No Fraunces. No Newsreader. No Karla.
   03 · Surfaces: parchment + 5% noise; plates have duck-egg
        tint #d6e1d8; 1px ink rules; corners 0–2px; NO box-shadows.
   04 · Layout: 14-col field-notebook grid with visible column
        marks at page edges. Each species is a magazine spread
        (PLATE + NOTES, alternating sides). Section heights vary
        deliberately; one full-bleed "Espécime do mês" anchor.
   05 · Signature: a ▽ partridge silhouette glyph prefixes every
        section number AND every binomial name. Binomial is
        italicised in redbreast. Used once. Used everywhere.
   ============================================================= */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --parch:    #f1e8d3;
  --parch-2:  #e7dcc1;
  --parch-3:  #ddd2b3;
  --duck:     #d6e1d8;
  --duck-2:   #c5d2c5;
  --ink:      #15311f;
  --ink-70:   #2c4836;
  --ink-50:   #5b6e60;
  --ink-30:   #97a596;
  --ink-15:   #c3cbc1;
  --red:      #c93d24;
  --red-dim:  #a02e1a;

  --display: 'Instrument Serif', 'Times New Roman', serif;
  --body:    'Source Serif 4', 'Source Serif Pro', Georgia, serif;
  --mono:    'IBM Plex Mono', ui-monospace, 'Courier New', monospace;

  --gutter:    24px;
  --pad:       28px;
  --max:       1240px;
}

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; background: var(--parch); }

body {
  background: var(--parch);
  color: var(--ink);
  font-family: var(--body);
  font-weight: 400;
  font-size: 17px;
  line-height: 1.6;
  font-feature-settings: "kern" on, "liga" on, "onum" on;
  min-height: 100vh;
  position: relative;
  overflow-x: hidden;
}

/* Paper grain */
body::before {
  content: ""; position: fixed; inset: 0;
  pointer-events: none; z-index: 1;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.92' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.55 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity: 0.06;
  mix-blend-mode: multiply;
}

/* Faint vertical column rules at page edges — visible "field notebook" grid */
body::after {
  content: ""; position: fixed; inset: 0;
  pointer-events: none; z-index: 0;
  background-image:
    linear-gradient(to right, transparent 27px, var(--ink-15) 27px, var(--ink-15) 28px, transparent 28px),
    linear-gradient(to left,  transparent 27px, var(--ink-15) 27px, var(--ink-15) 28px, transparent 28px);
  opacity: 0.55;
}

img { max-width: 100%; height: auto; display: block; }
a   { color: var(--ink); text-decoration: underline; text-decoration-thickness: 1px;
      text-underline-offset: 3px; text-decoration-color: var(--ink-50); transition: color .15s, text-decoration-color .15s; }
a:hover { color: var(--red); text-decoration-color: var(--red); }
::selection { background: var(--ink); color: var(--parch); }

/* ============================================================
   TYPE SYSTEM
   ============================================================ */
h1, h2, h3, h4 { font-family: var(--display); color: var(--ink); font-weight: 400; letter-spacing: -0.005em; }
h1 { font-size: clamp(3.6rem, 11vw, 9rem); line-height: 0.88; letter-spacing: -0.03em; font-weight: 400; }
h2 { font-size: clamp(2rem, 4vw, 3.4rem); line-height: 1.02; margin-bottom: 18px; }
h3 { font-size: 1.55rem; line-height: 1.1; margin-bottom: 6px; }
h4 { font-family: var(--mono); font-size: 0.74rem; font-weight: 500; letter-spacing: 0.18em;
     text-transform: uppercase; color: var(--ink-70); margin-bottom: 14px; }

p  { margin-bottom: 14px; color: var(--ink); }
em { font-style: italic; color: var(--red); font-family: var(--display); }
strong { font-weight: 600; }

/* The dingbat */
.partridge { display: inline-block; transform: translateY(-0.05em); color: var(--ink); }
.partridge.red { color: var(--red); }

.mono, .meta, .folio, .tax {
  font-family: var(--mono); font-feature-settings: "tnum" on;
}
.meta {
  font-size: 11.5px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-70);
}

/* Display drop-leading: oldstyle figures + slight optical raise */
.figure {
  font-family: var(--display); font-feature-settings: "tnum" on;
  font-size: clamp(3rem, 6vw, 5.6rem); line-height: 0.95; color: var(--ink);
}

/* ============================================================
   LAYOUT PRIMITIVES
   ============================================================ */
.container { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); position: relative; z-index: 2; }

section { padding: 96px 0; position: relative; }
section.thin { padding: 56px 0; }
section.deep { padding: 144px 0; }

/* Section heading mark */
.section-mark {
  display: flex; align-items: baseline; gap: 16px;
  border-top: 1px solid var(--ink);
  padding-top: 14px; margin-bottom: 56px;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-70);
}
.section-mark .num {
  color: var(--ink); font-weight: 600;
  font-feature-settings: "tnum" on;
  letter-spacing: 0.1em;
}
.section-mark .glyph { margin-left: auto; color: var(--ink); font-size: 14px; letter-spacing: 0; }

.section-head { max-width: 38em; margin-bottom: 60px; }
.section-head h2 { font-style: italic; }
.lede { font-size: 1.18rem; line-height: 1.5; color: var(--ink-70); font-family: var(--body); }

/* ============================================================
   FOLIO BAR
   ============================================================ */
.folio-bar {
  position: relative; z-index: 4;
  background: var(--parch);
  border-bottom: 1px solid var(--ink);
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-70);
}
.folio-bar .inner {
  max-width: var(--max); margin: 0 auto;
  padding: 8px var(--pad);
  display: flex; gap: 22px; align-items: center; flex-wrap: wrap;
}
.folio-bar .mark { color: var(--ink); font-weight: 600; }
.folio-bar .mark::before { content: "▽ "; color: var(--red); }
.folio-bar .sep { color: var(--ink-30); }

/* ============================================================
   NAVBAR
   ============================================================ */
.navbar {
  position: sticky; top: 0; z-index: 5;
  background: var(--parch);
  border-bottom: 1px solid var(--ink);
}
.nav-inner {
  max-width: var(--max); margin: 0 auto;
  padding: 14px var(--pad);
  display: flex; align-items: center; gap: 24px;
}
.site-logo {
  font-family: var(--display); font-size: 1.55rem; font-weight: 400;
  text-decoration: none; color: var(--ink);
  display: inline-flex; align-items: baseline; gap: 8px;
}
.site-logo .em { font-style: italic; color: var(--red); }
.site-logo .glyph { color: var(--red); font-size: 0.85em; transform: translateY(-0.1em); display:inline-block; }

.nav-links {
  list-style: none; display: flex; gap: 22px; margin-left: auto; align-items: center;
}
.nav-links a {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em;
  text-transform: uppercase; text-decoration: none; color: var(--ink-70);
}
.nav-links a:hover { color: var(--red); }
.nav-links .n {
  display: inline-block; width: 18px; color: var(--ink-30);
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.08em; margin-right: 6px;
}

.menu-toggle {
  display: none; background: none; border: 1px solid var(--ink); padding: 7px 10px;
  cursor: pointer; margin-left: auto;
}
.menu-toggle span,
.menu-toggle span::before,
.menu-toggle span::after {
  display: block; width: 20px; height: 1px; background: var(--ink); position: relative;
}
.menu-toggle span::before { content: ""; position: absolute; top: -6px; left: 0; width: 20px; height: 1px; background: var(--ink); }
.menu-toggle span::after  { content: ""; position: absolute; top:  6px; left: 0; width: 20px; height: 1px; background: var(--ink); }

@media (max-width: 880px) {
  .nav-links { display: none; }
  .nav-links.is-open {
    display: flex; flex-direction: column; gap: 14px; align-items: flex-start;
    position: absolute; top: 100%; right: 0; left: 0;
    background: var(--parch); border-bottom: 1px solid var(--ink);
    padding: 18px var(--pad);
  }
  .menu-toggle { display: inline-flex; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  padding: 64px 0 56px;
  border-bottom: 1px solid var(--ink);
}
.hero-meta {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-70);
  display: flex; flex-wrap: wrap; gap: 18px; margin-bottom: 28px;
}
.hero-meta .sep::before { content: "·"; margin-right: 18px; color: var(--ink-30); }

.wordmark {
  font-family: var(--display); font-weight: 400;
  letter-spacing: -0.045em;
  display: block;
  position: relative;
  line-height: 0.86;
}
.wordmark em { font-style: italic; color: var(--red); font-family: var(--display); }
.wordmark .pglyph {
  font-size: 0.32em; vertical-align: 0.55em; color: var(--red);
  margin-left: 0.18em; display: inline-block;
}

.hero-spread {
  display: grid; grid-template-columns: 1.4fr 1fr;
  gap: 56px; align-items: end; margin-top: 32px;
}
.hero-lede {
  font-family: var(--body); font-style: italic;
  font-size: clamp(1.2rem, 1.9vw, 1.55rem); line-height: 1.42;
  color: var(--ink); max-width: 28em;
}
.hero-lede strong { font-weight: 600; font-style: normal; }

.hero-rule { border-top: 1px solid var(--ink); margin: 36px 0 22px; }

.hero-strip {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
  background: var(--ink-15);
  border: 1px solid var(--ink);
}
.hero-strip > div {
  background: var(--parch); padding: 18px 18px 16px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--ink-70);
}
.hero-strip strong {
  display: block; font-family: var(--display); font-style: italic;
  font-weight: 400;
  font-size: clamp(2rem, 3.4vw, 3rem); line-height: 1;
  color: var(--ink); letter-spacing: -0.02em; margin-bottom: 6px;
}
.hero-strip strong em { color: var(--red); font-style: italic; }

@media (max-width: 800px) {
  .hero-spread { grid-template-columns: 1fr; gap: 32px; }
  .hero-strip { grid-template-columns: repeat(2, 1fr); }
}

/* ============================================================
   SUMÁRIO — TOC table
   ============================================================ */
.toc-grid {
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
}
.toc-row {
  display: grid;
  grid-template-columns: 80px 1fr 180px 80px;
  gap: 18px;
  align-items: baseline;
  padding: 14px 0;
  border-bottom: 1px dotted var(--ink-30);
  font-family: var(--mono); font-size: 12px;
  letter-spacing: 0.06em;
}
.toc-row:last-child { border-bottom: none; }
.toc-row .num { color: var(--ink-50); font-weight: 500; letter-spacing: 0.16em; text-transform: uppercase; }
.toc-row .ttl {
  font-family: var(--display); font-size: 1.4rem; letter-spacing: -0.01em; line-height: 1.15;
}
.toc-row .ttl a { text-decoration: none; color: var(--ink); }
.toc-row .ttl a:hover { color: var(--red); }
.toc-row .ttl em { color: var(--red); }
.toc-row .kind { text-transform: uppercase; letter-spacing: 0.16em; color: var(--ink-50); font-size: 10.5px; }
.toc-row .page { text-align: right; color: var(--ink-50); }

@media (max-width: 720px) {
  .toc-row { grid-template-columns: 50px 1fr 70px; }
  .toc-row .kind { display: none; }
}

/* ============================================================
   SPECIMEN PLATES — § II  ESPÉCIES
   ============================================================ */
.species { display: flex; flex-direction: column; gap: 88px; }

.specimen {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: 56px;
  border-top: 1px solid var(--ink);
  padding-top: 28px;
  position: relative;
}
.specimen.flipped { grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr); }
.specimen.flipped .plate { order: 2; }
.specimen.flipped .notes { order: 1; }

.specimen::before {
  content: ""; position: absolute; top: -1px; left: 0;
  width: 96px; height: 1px; background: var(--red);
}

.spec-no {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-70);
  position: absolute; top: -32px; left: 0;
}
.spec-no strong { color: var(--ink); font-weight: 600; margin-right: 10px; }

/* Plate column */
.plate { position: relative; }
.plate-stack { display: flex; flex-direction: column; gap: 14px; }

.plate-frame {
  background: var(--duck);
  border: 1px solid var(--ink);
  padding: 18px;
  position: relative;
}
.plate-frame::before {
  content: ""; position: absolute; inset: 6px;
  border: 1px solid rgba(21,49,31,0.18);
  pointer-events: none;
}

.plate-icon-row { display: grid; grid-template-columns: 124px 1fr; gap: 16px; align-items: stretch; }
.plate-icon {
  width: 124px; height: 124px; border: 1px solid var(--ink);
  background: var(--parch);
  overflow: hidden; position: relative;
}
.plate-icon img { width: 100%; height: 100%; object-fit: cover; }

.plate-screenshot { border: 1px solid var(--ink); background: var(--ink); overflow: hidden; }
.plate-screenshot img { width: 100%; height: 100%; object-fit: cover; display: block; }
.plate-screenshot.tall { aspect-ratio: 3 / 4; }
.plate-screenshot.tall-2 { aspect-ratio: 3 / 4; }

.plate-caption {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-70);
  margin-top: 12px;
  padding-top: 10px; border-top: 1px solid var(--ink-15);
  display: flex; justify-content: space-between; gap: 18px;
}
.plate-caption .lat { font-style: italic; color: var(--red); font-family: var(--display); font-size: 14px; text-transform: none; letter-spacing: 0; }

/* Notes column */
.notes { display: flex; flex-direction: column; gap: 22px; }

.taxonomy {
  display: grid; grid-template-columns: max-content 1fr; gap: 6px 18px;
  font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--ink-50);
  padding-bottom: 14px; border-bottom: 1px dotted var(--ink-30);
}
.taxonomy dt { color: var(--ink-70); }
.taxonomy dd { color: var(--ink); }

.binomial {
  font-family: var(--display); font-style: italic; font-weight: 400;
  color: var(--red);
  font-size: clamp(2rem, 3.4vw, 2.8rem); line-height: 1.02;
  letter-spacing: -0.005em;
}
.binomial::before { content: "▽ "; color: var(--red); font-style: normal; }

.common {
  font-family: var(--display); font-style: normal; color: var(--ink);
  font-size: clamp(1.6rem, 2.6vw, 2.2rem); line-height: 1.1;
  letter-spacing: -0.01em; margin-top: 4px;
}
.common::before { content: "— "; color: var(--ink-30); }
.common::after  { content: " —"; color: var(--ink-30); }

.developer {
  font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--ink-70);
  margin-top: 4px;
}

.observ {
  font-family: var(--body); font-size: 1.02rem; line-height: 1.6;
  color: var(--ink); margin-top: 6px;
}
.observ::first-letter {
  font-family: var(--display); font-size: 2.6em; line-height: 0.9;
  float: left; padding: 0 6px 0 0; color: var(--ink);
}

.field-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px;
  background: var(--ink-15);
  border: 1px solid var(--ink);
}
.field-stats > div {
  background: var(--parch); padding: 14px 14px 12px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-70);
}
.field-stats strong {
  display: block; font-family: var(--display); font-weight: 400;
  font-size: 1.7rem; line-height: 1; color: var(--ink);
  letter-spacing: -0.01em; margin-bottom: 6px;
}
.field-stats strong em { color: var(--red); font-style: italic; }

.specimen-link {
  font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.18em;
  text-transform: uppercase; text-decoration: none;
  display: inline-block; padding: 12px 16px;
  border: 1px solid var(--ink); color: var(--ink);
  align-self: flex-start;
  transition: background .2s, color .2s;
}
.specimen-link::after { content: " →"; color: var(--red); }
.specimen-link:hover { background: var(--ink); color: var(--parch); text-decoration: none; }
.specimen-link:hover::after { color: var(--parch); }

@media (max-width: 880px) {
  .specimen, .specimen.flipped { grid-template-columns: 1fr; gap: 28px; }
  .specimen.flipped .plate { order: 1; }
  .specimen.flipped .notes { order: 2; }
  .spec-no { position: static; margin-bottom: 8px; }
  .plate-icon-row { grid-template-columns: 96px 1fr; }
  .plate-icon { width: 96px; height: 96px; }
  .observ::first-letter { font-size: 2.2em; }
}

/* ============================================================
   MÉTODO — three column principles
   ============================================================ */
.method {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border-top: 1px solid var(--ink);
  border-left: 1px solid var(--ink);
}
.method-col {
  border-right: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  padding: 28px 22px 24px;
  background: var(--parch);
  position: relative;
}
.method-col .num {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--red); margin-bottom: 18px;
}
.method-col h3 { font-style: italic; margin-bottom: 12px; }
.method-col p { color: var(--ink-70); font-size: 0.98rem; line-height: 1.55; margin-bottom: 0; }

@media (max-width: 800px) { .method { grid-template-columns: 1fr; } }

/* ============================================================
   DESTAQUE — full-bleed anchor
   ============================================================ */
.anchor {
  background: var(--ink); color: var(--parch);
  padding: 120px 0; margin: 56px 0;
  position: relative; overflow: hidden;
}
.anchor::before {
  content: ""; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.92' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.32 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity: 0.08; mix-blend-mode: screen;
}
.anchor .section-mark { border-color: var(--parch-3); color: var(--parch-3); }
.anchor .section-mark .num,
.anchor .section-mark .glyph { color: var(--parch); }
.anchor h2 { color: var(--parch); font-style: italic; }
.anchor h2 em { color: var(--red); }
.anchor .grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center;
}
.anchor-text { color: var(--parch-3); font-size: 1.05rem; line-height: 1.6; max-width: 50ch; }
.anchor-text strong { color: var(--parch); font-weight: 600; }
.anchor blockquote {
  font-family: var(--display); font-style: italic;
  font-size: clamp(1.4rem, 2.4vw, 2rem); line-height: 1.25;
  color: var(--parch); margin: 24px 0;
  padding-left: 18px; border-left: 1px solid var(--red);
}
.anchor blockquote cite {
  display: block; font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--parch-3); margin-top: 12px; font-style: normal;
}
.anchor .anchor-link {
  display: inline-block; padding: 12px 18px; margin-top: 24px;
  border: 1px solid var(--parch-3); color: var(--parch);
  font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.18em;
  text-transform: uppercase; text-decoration: none;
}
.anchor .anchor-link::after { content: " →"; color: var(--red); }
.anchor .anchor-link:hover { background: var(--parch); color: var(--ink); }
.anchor .anchor-link:hover::after { color: var(--red); }

.anchor-plate {
  background: var(--duck); border: 1px solid var(--parch-3); padding: 18px;
}
.anchor-plate img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 3 / 4; border: 1px solid rgba(21,49,31,0.4); }
.anchor-plate-caption {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--ink-70); margin-top: 10px;
  display: flex; justify-content: space-between;
}
.anchor-plate-caption em { font-family: var(--display); color: var(--red); font-style: italic; text-transform: none; letter-spacing: 0; font-size: 13px; }

@media (max-width: 880px) {
  .anchor { padding: 80px 0; }
  .anchor .grid { grid-template-columns: 1fr; gap: 36px; }
}

/* ============================================================
   HÁBITOS — maxims (asymmetric)
   ============================================================ */
.maxims {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  border-top: 1px solid var(--ink);
}
.maxim {
  padding: 28px 22px 26px;
  border-right: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
}
.maxim:last-child { border-right: none; }
.maxim:nth-child(1) { background: var(--parch); }
.maxim:nth-child(2) { background: var(--parch-2); }
.maxim:nth-child(3) { background: var(--parch); }
.maxim:nth-child(4) { background: var(--parch-2); }
.maxim .num { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; color: var(--red); text-transform: uppercase; margin-bottom: 16px; }
.maxim h4 {
  font-family: var(--display); font-style: italic;
  font-size: 1.4rem; color: var(--ink); text-transform: none;
  letter-spacing: -0.01em; line-height: 1.1; margin-bottom: 10px;
}
.maxim p { color: var(--ink-70); font-size: 0.96rem; line-height: 1.55; margin: 0; }

@media (max-width: 880px) { .maxims { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .maxims { grid-template-columns: 1fr; } .maxim { border-right: none; } }

/* ============================================================
   CIFRAS — figures
   ============================================================ */
.cifras-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  border-top: 1px solid var(--ink); border-left: 1px solid var(--ink);
}
.cif {
  padding: 28px 22px; border-right: 1px solid var(--ink); border-bottom: 1px solid var(--ink);
  background: var(--parch);
}
.cif .figure { display: block; margin-bottom: 8px; }
.cif .figure em { font-style: italic; color: var(--red); }
.cif .label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-70); margin-bottom: 4px; }
.cif .note { font-family: var(--body); font-style: italic; font-size: 0.9rem; line-height: 1.4; color: var(--ink-50); }

@media (max-width: 880px) { .cifras-grid { grid-template-columns: repeat(2, 1fr); } }

/* ============================================================
   HUMORES — mood swatches (asymmetric)
   ============================================================ */
.moods {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 200px;
  gap: 1px;
  background: var(--ink-15);
  border: 1px solid var(--ink);
}
.mood {
  background: var(--parch); padding: 20px 18px; text-decoration: none; color: var(--ink);
  display: flex; flex-direction: column; justify-content: space-between;
  position: relative; transition: background .2s, color .2s;
}
.mood:hover { background: var(--ink); color: var(--parch); }
.mood:hover h3 { color: var(--parch); }
.mood:hover .glyph { color: var(--red); }
.mood .glyph {
  font-family: var(--display); font-style: italic; color: var(--red);
  font-size: 2.6rem; line-height: 1; align-self: flex-start;
}
.mood h3 {
  font-family: var(--display); font-style: italic; font-weight: 400;
  font-size: 1.6rem; color: var(--ink); margin: 0 0 4px;
}
.mood p { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-50); margin: 0; line-height: 1.4; }

.mood:nth-child(1) { grid-column: span 2; }
.mood:nth-child(2) { grid-column: span 2; }
.mood:nth-child(3) { grid-column: span 2; }
.mood:nth-child(4) { grid-column: span 3; }
.mood:nth-child(5) { grid-column: span 3; }
.mood:nth-child(6) { grid-column: span 6; grid-auto-rows: 160px; }

@media (max-width: 880px) {
  .moods { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 160px; }
  .mood:nth-child(n) { grid-column: span 1; }
  .mood:nth-child(6) { grid-column: span 2; }
}

/* ============================================================
   VOZES — team
   ============================================================ */
.voices {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border-top: 1px solid var(--ink);
}
.voice {
  padding: 28px 26px;
  border-right: 1px solid var(--ink); border-bottom: 1px solid var(--ink);
}
.voice:last-child { border-right: none; }
.voice .who { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-70); margin-bottom: 16px; display: flex; gap: 14px; flex-wrap: wrap; }
.voice .who strong { color: var(--ink); font-weight: 600; }
.voice .who span { color: var(--red); }
.voice blockquote {
  font-family: var(--display); font-style: italic; font-size: 1.32rem;
  line-height: 1.3; color: var(--ink); margin: 0; padding-left: 14px;
  border-left: 1px solid var(--ink-30);
}

@media (max-width: 880px) { .voices { grid-template-columns: 1fr; } }

/* ============================================================
   SAÍDOS — rejected list (table-like)
   ============================================================ */
.removed { border-top: 1px solid var(--ink); }
.removed-row {
  display: grid;
  grid-template-columns: 70px 1fr 1.4fr 90px;
  gap: 18px; align-items: baseline; padding: 12px 0;
  border-bottom: 1px dotted var(--ink-30);
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.04em;
}
.removed-row .num { color: var(--ink-50); letter-spacing: 0.18em; text-transform: uppercase; }
.removed-row .ttl { font-family: var(--display); font-style: italic; font-size: 1.18rem; letter-spacing: -0.005em; color: var(--ink); }
.removed-row .why { color: var(--ink-70); text-transform: uppercase; letter-spacing: 0.1em; font-size: 11px; }
.removed-row .date { color: var(--red); text-align: right; letter-spacing: 0.16em; text-transform: uppercase; }

@media (max-width: 720px) {
  .removed-row { grid-template-columns: 50px 1fr; }
  .removed-row .why, .removed-row .date { grid-column: 2; }
}

/* ============================================================
   CORRESPONDÊNCIA — letters
   ============================================================ */
.letters {
  display: grid; grid-template-columns: 1fr 1fr; gap: 36px;
}
.letter {
  background: var(--parch);
  border: 1px solid var(--ink); padding: 28px 26px;
  position: relative;
}
.letter::before {
  content: "▽"; position: absolute; top: 12px; right: 16px;
  color: var(--red); font-size: 14px;
}
.letter .label {
  display: flex; justify-content: space-between; gap: 12px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--ink-70); margin-bottom: 18px;
}
.letter .label .from { color: var(--ink); font-weight: 600; }
.letter blockquote {
  font-family: var(--display); font-style: italic; font-size: 1.3rem;
  line-height: 1.3; color: var(--ink); margin: 0 0 18px;
  padding-bottom: 14px; border-bottom: 1px solid var(--ink-15);
}
.letter .reply { color: var(--ink-70); font-size: 0.98rem; line-height: 1.55; margin: 0; }
.letter .reply::before { content: "R. "; color: var(--red); font-weight: 600; font-family: var(--mono); letter-spacing: 0.18em; }

@media (max-width: 880px) { .letters { grid-template-columns: 1fr; } }

/* ============================================================
   LÉXICO — definition list
   ============================================================ */
.lexicon { border-top: 1px solid var(--ink); }
.lex-row {
  display: grid; grid-template-columns: 220px 1fr; gap: 28px;
  padding: 18px 0; border-bottom: 1px dotted var(--ink-30);
  align-items: baseline;
}
.lex-row dt {
  font-family: var(--display); font-style: italic; font-size: 1.4rem;
  color: var(--red); letter-spacing: -0.005em;
}
.lex-row dt::before { content: "▽ "; color: var(--red); font-style: normal; }
.lex-row dd { color: var(--ink-70); font-size: 1rem; line-height: 1.55; }

@media (max-width: 720px) { .lex-row { grid-template-columns: 1fr; gap: 6px; } }

/* ============================================================
   CALENDÁRIO — three forthcoming editions
   ============================================================ */
.calendar { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--ink); border-left: 1px solid var(--ink); }
.cal-cell {
  padding: 28px 22px;
  border-right: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  background: var(--parch);
}
.cal-cell .date { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--red); margin-bottom: 18px; }
.cal-cell h3 { font-style: italic; font-size: 1.55rem; margin-bottom: 10px; }
.cal-cell p { color: var(--ink-70); font-size: 0.98rem; line-height: 1.55; margin: 0; }
.cal-cell em { color: var(--red); }

@media (max-width: 880px) { .calendar { grid-template-columns: 1fr; } }

/* ============================================================
   PERGUNTAS — accordion
   ============================================================ */
.qa { border-top: 1px solid var(--ink); }
.qa details {
  border-bottom: 1px solid var(--ink);
  padding: 16px 0;
}
.qa summary {
  list-style: none; cursor: pointer;
  display: grid; grid-template-columns: 70px 1fr 30px; gap: 14px;
  align-items: baseline;
}
.qa summary::-webkit-details-marker { display: none; }
.qa .q-mark { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--red); }
.qa .q-text { font-family: var(--display); font-style: italic; font-size: 1.32rem; line-height: 1.3; letter-spacing: -0.005em; color: var(--ink); }
.qa .q-toggle { font-family: var(--mono); font-size: 16px; color: var(--ink); text-align: right; }
.qa details[open] .q-toggle { transform: rotate(45deg); }
.qa .a {
  padding: 16px 0 4px 84px; display: grid; grid-template-columns: 1fr; gap: 0;
}
.qa .a p { color: var(--ink-70); font-size: 1rem; line-height: 1.6; margin: 0; }

@media (max-width: 720px) {
  .qa summary { grid-template-columns: 50px 1fr 30px; }
  .qa .a { padding-left: 64px; }
}

/* ============================================================
   ASSINATURA — subscription form
   ============================================================ */
.subscription {
  border: 1px solid var(--ink);
  padding: 56px 40px;
  background: var(--parch-2);
  position: relative;
}
.subscription::before {
  content: ""; position: absolute; inset: 8px; border: 1px solid var(--ink); pointer-events: none;
}
.subscription .label {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--red); margin-bottom: 18px;
}
.subscription h2 { font-style: italic; margin-bottom: 12px; }
.subscription .sub { color: var(--ink-70); font-size: 1.05rem; line-height: 1.5; max-width: 44ch; margin-bottom: 28px; }

.form-row { display: grid; grid-template-columns: 1fr 1.4fr; gap: 18px; margin-bottom: 14px; }
.form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.form-group label, .consent label {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-70);
}
.form-group input {
  background: var(--parch); border: 1px solid var(--ink); padding: 12px 14px;
  font-family: var(--body); font-size: 1rem; color: var(--ink);
  border-radius: 0;
}
.form-group input:focus { outline: 2px solid var(--red); outline-offset: -2px; }

.consent { display: flex; gap: 10px; align-items: flex-start; margin-bottom: 18px; }
.consent input { margin-top: 4px; }
.consent label { font-size: 12px; line-height: 1.5; text-transform: none; letter-spacing: 0.01em; font-family: var(--body); color: var(--ink-70); }
.consent a { color: var(--red); }

.form-error {
  display: none; color: var(--red); font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 12px;
}
.form-error.show { display: block; }

.submit-btn {
  background: var(--ink); color: var(--parch); border: 1px solid var(--ink);
  padding: 14px 22px; cursor: pointer;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.2em;
  text-transform: uppercase;
}
.submit-btn:hover { background: var(--red); border-color: var(--red); }

.form-success {
  padding: 14px 16px; border: 1px solid var(--ink); margin-top: 18px;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink); background: var(--duck);
}
.form-success.hidden { display: none; }

@media (max-width: 720px) { .form-row { grid-template-columns: 1fr; } .subscription { padding: 36px 24px; } }

/* ============================================================
   COLOPHON
   ============================================================ */
.colophon {
  background: var(--ink); color: var(--parch-3);
  padding: 80px 0 40px; position: relative; overflow: hidden;
}
.colophon::before {
  content: ""; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.92' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.25 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity: 0.08; mix-blend-mode: screen; pointer-events: none;
}
.colophon .container { position: relative; z-index: 1; }
.colo-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 36px; margin-bottom: 48px; }
.colo-brand { font-family: var(--display); font-size: 2rem; line-height: 1; margin-bottom: 18px; color: var(--parch); }
.colo-brand em { color: var(--red); font-style: italic; }
.colo-brand::before { content: "▽ "; color: var(--red); font-style: normal; }
.colo-about p { color: var(--parch-3); font-size: 0.98rem; line-height: 1.55; }
.colo-about .addr { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-30); margin-top: 18px; line-height: 1.6; }
.colo-col h4 { color: var(--parch); border-bottom: 1px solid rgba(241,232,211,0.2); padding-bottom: 8px; margin-bottom: 14px; }
.colo-col ul { list-style: none; }
.colo-col li { margin-bottom: 8px; }
.colo-col a { color: var(--parch-3); text-decoration: none; font-family: var(--body); font-size: 0.96rem; }
.colo-col a:hover { color: var(--red); }

.colo-bottom {
  display: flex; justify-content: space-between; gap: 18px; flex-wrap: wrap;
  padding-top: 24px; border-top: 1px solid rgba(241,232,211,0.2);
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-30);
}
.colo-credits {
  margin-top: 32px; color: var(--parch-3);
  font-size: 0.92rem; line-height: 1.6; max-width: 75ch;
  border-top: 1px solid rgba(241,232,211,0.12); padding-top: 18px;
  font-family: var(--body);
}
.colo-credits em { color: var(--red); }
.colo-credits strong { color: var(--parch); font-weight: 600; }

@media (max-width: 880px) { .colo-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .colo-grid { grid-template-columns: 1fr; } }

/* ============================================================
   COOKIE BANNER
   ============================================================ */
.cookie-banner {
  position: fixed; bottom: 18px; left: 18px; right: 18px;
  background: var(--ink); color: var(--parch); padding: 0;
  z-index: 100; border: 1px solid var(--red);
  display: block;
}
.cookie-banner.hidden { display: none; }
.cookie-inner {
  display: flex; gap: 18px; align-items: center; flex-wrap: wrap;
  padding: 16px 18px;
}
.cookie-inner span { font-family: var(--body); font-size: 0.92rem; flex: 1; min-width: 220px; }
.cookie-inner a { color: var(--red); text-decoration: underline; }
.cookie-inner button {
  background: var(--red); color: var(--parch); border: 1px solid var(--red);
  padding: 9px 18px; font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase; cursor: pointer;
}
.cookie-inner button:hover { background: var(--parch); color: var(--ink); border-color: var(--parch); }

/* ============================================================
   ABOUT / CONTACT / ARTICLES / TRUST page helpers
   ============================================================ */
.page-hero { padding: 96px 0 48px; border-bottom: 1px solid var(--ink); }
.page-hero h1 { font-size: clamp(2.6rem, 6vw, 5.4rem); font-style: italic; }
.page-hero h1 em { color: var(--red); }
.page-hero .kicker { font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-70); margin-bottom: 16px; }
.page-hero .lede { margin-top: 22px; max-width: 50ch; }

.prose { max-width: 38em; }
.prose h2 { font-style: italic; margin-top: 36px; }
.prose h3 { font-style: italic; margin-top: 26px; }
.prose p { font-size: 1.05rem; line-height: 1.65; color: var(--ink); margin-bottom: 14px; }
.prose ul { margin: 0 0 18px 22px; }
.prose ul li { margin-bottom: 8px; font-size: 1.02rem; line-height: 1.55; }

/* Policy / long-form pages */
.hero-edition {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-70);
  display: flex; flex-wrap: wrap; gap: 14px;
}
.hero-edition .sep::before { content: "·"; margin-right: 14px; color: var(--ink-30); }
.page-hero .updated {
  font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--red); margin-bottom: 18px;
}
.page-hero h1 { font-style: italic; margin-bottom: 18px; }
.page-hero h1 em { color: var(--red); }
.page-hero p {
  font-family: var(--body); font-style: italic; font-size: 1.18rem;
  line-height: 1.5; color: var(--ink); max-width: 56ch;
}

.page-content {
  max-width: 56em;
  font-family: var(--body); font-size: 1.04rem; line-height: 1.7;
}
.page-content h2 {
  font-family: var(--display); font-style: italic; font-weight: 400;
  font-size: 1.8rem; color: var(--ink); margin: 44px 0 12px;
  border-top: 1px solid var(--ink-15); padding-top: 24px;
}
.page-content h2:first-of-type { margin-top: 24px; border-top: none; padding-top: 0; }
.page-content h2::before { content: "▽ "; color: var(--red); font-style: normal; }
.page-content h3 {
  font-family: var(--display); font-style: italic; font-weight: 400;
  font-size: 1.32rem; color: var(--ink); margin: 22px 0 8px;
}
.page-content p { font-size: 1.04rem; line-height: 1.7; margin-bottom: 14px; }
.page-content ul, .page-content ol { margin: 0 0 16px 26px; padding: 0; }
.page-content li { margin-bottom: 8px; font-size: 1.02rem; line-height: 1.6; }
.page-content strong { font-weight: 600; }
.page-content em { color: var(--red); font-style: italic; }
.page-content code {
  font-family: var(--mono); font-size: 0.92em;
  background: var(--parch-2); padding: 1px 6px; border: 1px solid var(--ink-15);
}
.page-content a { color: var(--ink); text-decoration: underline; text-decoration-color: var(--red); }
.page-content a:hover { color: var(--red); }

.page-content .toc {
  border: 1px solid var(--ink);
  padding: 22px 26px;
  margin: 24px 0 40px;
  background: var(--parch-2);
}
.page-content .toc h4 { margin-bottom: 12px; }
.page-content .toc ol { margin: 0; padding-left: 22px; }
.page-content .toc li { font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; margin-bottom: 6px; }
.page-content .toc li a { color: var(--ink); text-decoration: none; }
.page-content .toc li a:hover { color: var(--red); text-decoration: underline; }

.page-content .note {
  border-left: 2px solid var(--red);
  padding: 14px 18px;
  margin: 18px 0 24px;
  background: var(--parch-2);
  font-size: 0.98rem; line-height: 1.55;
}
.page-content .note strong { color: var(--red); }

/* Contact grid */
section.tight { padding: 56px 0; }
.contact-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border-top: 1px solid var(--ink); border-left: 1px solid var(--ink);
}
.contact-cell {
  padding: 26px 22px;
  border-right: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  background: var(--parch);
}
.contact-cell .roman {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--red); display: block; margin-bottom: 14px;
}
.contact-cell h3 { font-style: italic; font-size: 1.45rem; margin-bottom: 10px; color: var(--ink); }
.contact-cell p { color: var(--ink-70); font-size: 0.95rem; line-height: 1.55; margin: 0 0 4px; }
.contact-cell a { color: var(--ink); text-decoration: underline; text-decoration-color: var(--red); }
.contact-cell a:hover { color: var(--red); }
@media (max-width: 880px) { .contact-grid { grid-template-columns: 1fr; } }

/* Form: textarea and select */
.form-group textarea, .form-group select {
  background: var(--parch); border: 1px solid var(--ink); padding: 12px 14px;
  font-family: var(--body); font-size: 1rem; color: var(--ink);
  border-radius: 0; resize: vertical; min-height: 120px;
}
.form-group select { min-height: auto; }
.form-group textarea:focus, .form-group select:focus { outline: 2px solid var(--red); outline-offset: -2px; }

/* Articles page */
.section-mark .roman {
  color: var(--ink); font-weight: 600;
  font-feature-settings: "tnum" on;
  letter-spacing: 0.1em;
}
.articles-list { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border-top: 1px solid var(--ink); border-left: 1px solid var(--ink); }
.article-card {
  padding: 28px 26px;
  border-right: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  background: var(--parch);
  display: grid; grid-template-columns: 80px 1fr; gap: 18px;
}
.article-card .meta { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--red); }
.article-card h3 { font-style: italic; font-size: 1.45rem; line-height: 1.12; margin-bottom: 10px; color: var(--ink); }
.article-card h3 em { color: var(--red); }
.article-card p { color: var(--ink-70); font-size: 0.96rem; line-height: 1.55; margin: 0 0 12px; }
.article-card .read { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-50); }
@media (max-width: 880px) {
  .articles-list { grid-template-columns: 1fr; }
  .article-card { grid-template-columns: 1fr; gap: 8px; }
}

/* Trust page list-style sections */
.trust-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border-top: 1px solid var(--ink); border-left: 1px solid var(--ink);
}
.trust-cell {
  padding: 28px 22px;
  border-right: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  background: var(--parch);
}
.trust-cell .num { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; color: var(--red); text-transform: uppercase; margin-bottom: 16px; }
.trust-cell h3 { font-style: italic; font-size: 1.45rem; margin-bottom: 10px; }
.trust-cell p { color: var(--ink-70); font-size: 0.96rem; line-height: 1.55; margin: 0; }
@media (max-width: 880px) { .trust-grid { grid-template-columns: 1fr; } }
