/* ============================================================
   Humanāre — Adriana Schneider
   Earth-tone editorial system
   ============================================================ */

:root {
  /* Terracotta palette — Humanāre brand (default) */
  --bg: #F4ECE0;            /* cream-paper background */
  --paper: #EADDC9;         /* deeper cream / cards */
  --soft: #E3C7A6;          /* soft peach */
  --line: #D4B898;          /* hairlines on cream */
  --clay: #B5784A;          /* warm clay */
  --lime: #C9994C;          /* ochre — replaces lime, secondary accent */
  --lime-deep: #A8803A;
  --terracotta: #A04D2E;    /* primary brand accent — terracotta queimado */
  --terracotta-soft: #C2683E;
  --ink: #1F1815;           /* almost-black with terracotta undertone */
  --ink-soft: #5C4A3E;
  --ink-mute: #8E7763;

  /* Type system */
  --font-display: "Cormorant Garamond", "Times New Roman", serif;
  --font-body: "Manrope", -apple-system, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;

  --display-weight: 500;
  --body-weight: 400;

  /* Density */
  --space-unit: 1rem;
  --section-py: clamp(80px, 10vw, 160px);
  --container: 1400px;
  --gutter: clamp(24px, 4vw, 64px);

  /* Motion */
  --ease: cubic-bezier(.22,.61,.36,1);
}

[data-density="compact"] {
  --section-py: clamp(56px, 7vw, 110px);
  --gutter: clamp(20px, 3vw, 48px);
}
[data-density="spacious"] {
  --section-py: clamp(110px, 13vw, 200px);
  --gutter: clamp(32px, 5vw, 80px);
}

/* Dark mode — lime takes over as accent */
[data-mode="dark"] {
  --bg: #14120D;
  --paper: #1E1B14;
  --soft: #2A2519;
  --line: #3A3325;
  --clay: #8A7A5E;
  --lime: #CDE966;
  --lime-deep: #B5D04A;
  --terracotta: #CDE966;     /* lime replaces terracotta on dark theme */
  --terracotta-soft: #DCF080;
  --ink: #F1EADB;
  --ink-soft: #C5B9A4;
  --ink-mute: #807563;
}

/* Font-pair tweak */
[data-fontpair="modern"] {
  --font-display: "DM Serif Display", serif;
  --display-weight: 400;
}
[data-fontpair="sans"] {
  --font-display: "Sora", sans-serif;
  --display-weight: 300;
}

/* ============================================================
   Reset + base
   ============================================================ */
* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
html {
  scroll-behavior: smooth;
  scroll-padding-top: 80px;        /* account for the fixed nav on anchor jumps */
}
/* Hint the compositor that these elements move during scroll —
   keeps the framerate stable while smooth wheel scroll is active. */
.hero-sig-photo, .hero-sig-circle, .marquee-track, .intermission-track,
[data-parallax] { will-change: transform; }
body {
  font-family: var(--font-body);
  font-weight: var(--body-weight);
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  transition: background .35s var(--ease), color .35s var(--ease);
  overflow-x: hidden;
}
img { display: block; max-width: 100%; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
a { color: inherit; text-decoration: none; }

::selection { background: var(--lime); color: var(--ink); }

/* ============================================================
   Type
   ============================================================ */
.display {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  line-height: 1.02;
  letter-spacing: -0.02em;
}
.mono {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 400;
}
.eyebrow {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--terracotta);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.eyebrow::before {
  content: "";
  width: 24px; height: 1px;
  background: currentColor;
}
.eyebrow.center::before { display: none; }

.italic-accent { font-style: italic; font-family: var(--font-display); }

/* ============================================================
   Layout
   ============================================================ */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.section { padding: var(--section-py) 0; }

/* ============================================================
   Top nav
   ============================================================ */
.nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  /* full-width bar; inner content constrained to container */
  max-width: var(--container);
  margin: 0 auto;
  padding-top: 22px;
  padding-bottom: 22px;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
  transition: background .3s var(--ease), backdrop-filter .3s var(--ease), padding .3s var(--ease);
}
/* full-width tinted bar behind the (centered) nav, only when scrolled */
.nav.scrolled::before {
  content: '';
  position: fixed; top: 0; left: 0; right: 0;
  height: var(--nav-h, 64px);
  background: color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  z-index: -1;
}
.nav.scrolled {
  padding-top: 14px;
  padding-bottom: 14px;
}
.nav-brand {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--font-display);
  font-size: 1.4rem;
  letter-spacing: -0.01em;
}
.nav-brand .mark { width: 28px; height: 28px; }
.nav-brand small {
  font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--ink-mute);
  display: block; line-height: 1; margin-top: 2px;
}
.nav-links {
  display: flex; gap: 36px; align-items: center;
}
.nav-links a {
  font-size: 0.88rem;
  position: relative;
  padding: 4px 0;
  transition: color .2s var(--ease);
}
.nav-links a::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: -2px;
  height: 1px; background: var(--terracotta);
  transform: scaleX(0); transform-origin: left;
  transition: transform .3s var(--ease);
}
.nav-links a:hover::after, .nav-links a.active::after { transform: scaleX(1); }
.nav-links a.active { color: var(--terracotta); }

.nav-cta {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 12px 22px;
  border: 1px solid var(--ink);
  border-radius: 100px;
  transition: all .25s var(--ease);
}
.nav-cta:hover {
  background: var(--ink); color: var(--bg);
}

.nav-mobile-toggle { display: none; }

@media (max-width: 860px) {
  .nav-links, .nav-cta { display: none; }
  .nav-mobile-toggle {
    display: flex; flex-direction: column; gap: 5px;
    padding: 8px;
  }
  .nav-mobile-toggle span { width: 22px; height: 1px; background: var(--ink); }
}

/* ============================================================
   Buttons
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 16px 28px;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border-radius: 100px;
  transition: all .3s var(--ease);
  cursor: pointer;
  white-space: nowrap;
}
.btn.primary {
  background: var(--ink); color: var(--bg);
  border: 1px solid var(--ink);
}
.btn.primary:hover {
  background: var(--terracotta);
  border-color: var(--terracotta);
  color: var(--bg);
  transform: translateY(-1px);
}
.btn.terracotta {
  background: var(--terracotta); color: var(--bg);
  border: 1px solid var(--terracotta);
}
.btn.terracotta:hover {
  background: var(--ink); color: var(--bg); border-color: var(--ink); transform: translateY(-1px);
}
.btn.lime {
  background: var(--lime); color: var(--ink);
  border: 1px solid var(--lime);
}
.btn.lime:hover {
  background: var(--bg); color: var(--ink); border-color: var(--bg); transform: translateY(-1px);
}
.btn.ghost {
  border: 1px solid var(--ink);
  background: transparent;
}
.btn.ghost:hover { background: var(--ink); color: var(--bg); }

.btn .arrow {
  display: inline-block;
  transition: transform .3s var(--ease);
}
.btn:hover .arrow { transform: translateX(4px); }

.link-arrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-bottom: 1px solid currentColor;
  padding-bottom: 4px;
  transition: gap .25s var(--ease), color .2s var(--ease);
}
.link-arrow:hover { gap: 14px; color: var(--terracotta); }

/* ============================================================
   Hero — Variation A: split editorial
   ============================================================ */
.hero {
  position: relative;
  padding-top: 140px;
  padding-bottom: var(--section-py);
  overflow: hidden;
}

.hero-split {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: end;
  min-height: calc(100vh - 140px);
}
.hero-content { padding-bottom: 40px; }
.hero-eyebrow { margin-bottom: 32px; }
.hero-title {
  font-size: clamp(3.2rem, 7.5vw, 7.2rem);
  margin-bottom: 36px;
  letter-spacing: -0.035em;
  font-weight: var(--display-weight);
  font-family: var(--font-display);
  line-height: 0.98;
}
.hero-title .rotate-line {
  display: block;
  position: relative;
  min-height: 1.05em;
}
.hero-title em {
  font-style: italic;
  color: var(--terracotta);
  font-family: var(--font-display);
}
.hero-sub {
  font-size: 1.15rem;
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 480px;
  margin-bottom: 44px;
}
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; }

.hero-image {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  background: var(--paper);
}
.hero-image .photo {
  width: 100%; height: 100%;
  background-size: cover; background-position: center;
  filter: saturate(0.92) contrast(1.02);
  transition: transform 8s ease;
}
.hero-image:hover .photo { transform: scale(1.04); }

.hero-image .badge {
  position: absolute;
  bottom: 24px; left: 24px;
  background: var(--bg);
  padding: 14px 18px;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  display: flex; align-items: center; gap: 12px;
}
.hero-image .badge::before {
  content: ""; width: 6px; height: 6px; background: var(--terracotta); border-radius: 50%;
}

.hero-meta {
  position: absolute;
  bottom: 60px; right: var(--gutter);
  display: flex; flex-direction: column; align-items: flex-end; gap: 8px;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.hero-meta .yr {
  font-family: var(--font-display);
  font-size: 1rem;
  letter-spacing: 0;
  text-transform: none;
  color: var(--ink-soft);
  font-style: italic;
}

/* Hero V2 — full bleed manifesto */
.hero-manifesto {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  text-align: center;
  position: relative;
  padding: 140px var(--gutter) 80px;
}
.hero-manifesto-bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  filter: brightness(0.55) saturate(0.7);
  z-index: 0;
}
.hero-manifesto::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--ink) 30%, transparent) 0%,
    color-mix(in srgb, var(--ink) 60%, transparent) 100%);
  z-index: 1;
}
.hero-manifesto-content {
  position: relative; z-index: 2;
  color: var(--bg);
  max-width: 1100px;
}
.hero-manifesto-content .eyebrow {
  color: var(--lime); justify-content: center;
  margin-bottom: 40px;
}
.hero-manifesto-content .eyebrow::before { background: var(--lime); }
.hero-manifesto-content h1 {
  font-size: clamp(2.6rem, 7.5vw, 7rem);
  line-height: 1.05;
  letter-spacing: -0.025em;
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  margin-bottom: 40px;
}
.hero-manifesto-content h1 em {
  font-style: italic;
  color: var(--lime);
}
.hero-manifesto-content p {
  max-width: 600px;
  margin: 0 auto 44px;
  color: color-mix(in srgb, var(--bg) 80%, transparent);
  font-size: 1.1rem;
}

/* Hero V3 — asymmetric editorial */
.hero-asym {
  position: relative;
  min-height: 100vh;
  padding-top: 140px;
}
.hero-asym-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-template-rows: auto auto auto;
  gap: 24px;
  position: relative;
}
.hero-asym .eye { grid-column: 1 / 4; grid-row: 1; padding-top: 12px; }
.hero-asym .number {
  grid-column: 12 / 13; grid-row: 1;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-align: right;
  color: var(--ink-mute);
  writing-mode: vertical-rl;
}
.hero-asym h1 {
  grid-column: 1 / 11;
  grid-row: 2;
  font-size: clamp(3.5rem, 11vw, 11rem);
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  line-height: 0.92;
  letter-spacing: -0.04em;
  margin-top: 24px;
}
.hero-asym h1 .line1 { display: block; }
.hero-asym h1 .line2 { display: block; padding-left: 12vw; font-style: italic; color: var(--terracotta); }
.hero-asym h1 .line3 { display: block; }
.hero-asym .photo-block {
  grid-column: 9 / 13;
  grid-row: 3;
  aspect-ratio: 3/4;
  background-size: cover; background-position: center;
  filter: saturate(0.92);
}
.hero-asym .lead {
  grid-column: 1 / 7;
  grid-row: 3;
  align-self: end;
  padding-bottom: 8px;
}
.hero-asym .lead p {
  font-size: 1.1rem;
  color: var(--ink-soft);
  max-width: 460px;
  margin-bottom: 32px;
}

/* ============================================================
   Marquee — Empresas
   ============================================================ */
.marquee {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 30px 0;
  overflow: hidden;
  background: var(--paper);
}
.marquee-track {
  display: flex; gap: 60px;
  animation: marquee 50s linear infinite;
  width: fit-content;
}
.marquee-item {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.4rem;
  color: var(--ink-soft);
  white-space: nowrap;
  display: flex; align-items: center; gap: 60px;
  flex-shrink: 0;
}
.marquee-item::after { content: "✦"; color: var(--terracotta); font-style: normal; font-size: 0.7rem;}
@keyframes marquee {
  to { transform: translateX(calc(-50% - 30px)); }
}

/* ============================================================
   About slice
   ============================================================ */
.about-slice {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: clamp(40px, 7vw, 120px);
  align-items: center;
}
.about-slice .visual {
  position: relative;
  aspect-ratio: 4/5;
  background-size: cover;
  background-position: center;
}
.about-slice .visual::after {
  content: "";
  position: absolute;
  bottom: -30px; right: -30px;
  width: 60%; height: 60%;
  border: 1px solid var(--terracotta);
  z-index: -1;
}
.about-slice h2 {
  font-size: clamp(2rem, 4.5vw, 4.2rem);
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  line-height: 1.02;
  letter-spacing: -0.025em;
  margin: 20px 0 32px;
}
.about-slice h2 em { font-style: italic; color: var(--terracotta); }
.about-slice p {
  font-size: 1.08rem;
  color: var(--ink-soft);
  margin-bottom: 18px;
  max-width: 580px;
}
.about-slice .stats {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin: 44px 0;
  border-top: 1px solid var(--line);
  padding-top: 32px;
}
.about-slice .stat .num {
  font-family: var(--font-display);
  font-size: 2.6rem;
  line-height: 1;
  color: var(--terracotta);
}
.about-slice .stat .lbl {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-top: 6px;
}

/* ============================================================
   Section header
   ============================================================ */
.sec-head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  margin-bottom: 64px;
  align-items: end;
}
.sec-head h2 {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 5vw, 4.4rem);
  line-height: 1;
  letter-spacing: -0.025em;
  font-weight: var(--display-weight);
}
.sec-head h2 em { font-style: italic; color: var(--terracotta); }
.sec-head .sub { max-width: 480px; color: var(--ink-soft); font-size: 1.02rem; }
.sec-head .eyebrow { margin-bottom: 20px; }

/* ============================================================
   Palestras
   ============================================================ */
.palestras-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
}
.palestra {
  background: var(--bg);
  padding: 44px 40px;
  display: flex; flex-direction: column;
  min-height: 320px;
  position: relative;
  transition: background .3s var(--ease);
  cursor: pointer;
}
.palestra:hover { background: var(--paper); }
.palestra .num {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  color: var(--ink-mute);
  margin-bottom: 28px;
}
.palestra h3 {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 2.4vw, 2.2rem);
  font-weight: var(--display-weight);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin-bottom: 16px;
}
.palestra h3 em { font-style: italic; color: var(--terracotta); }
.palestra p {
  color: var(--ink-soft);
  font-size: 0.98rem;
  margin-bottom: auto;
}
.palestra .arrow-wrap {
  margin-top: 28px;
  display: flex; align-items: center; justify-content: space-between;
}
.palestra .tag {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.palestra .go {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid var(--ink);
  display: flex; align-items: center; justify-content: center;
  transition: all .3s var(--ease);
}
.palestra:hover .go {
  background: var(--terracotta);
  border-color: var(--terracotta);
  color: var(--bg);
  transform: rotate(-45deg);
}

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

/* ============================================================
   Quote + Livro
   ============================================================ */
.livro {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: clamp(40px, 7vw, 100px);
  align-items: center;
  padding: var(--section-py) 0;
  background: var(--paper);
}
.livro .container { display: contents; }
.livro-cover {
  aspect-ratio: 2/3;
  background: linear-gradient(135deg, var(--terracotta), var(--clay));
  position: relative;
  box-shadow: 30px 30px 0 -1px var(--line);
  overflow: hidden;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 40px 32px;
  color: var(--bg);
}
.livro-cover::before {
  content: "";
  position: absolute; inset: 16px;
  border: 1px solid color-mix(in srgb, var(--bg) 30%, transparent);
  pointer-events: none;
}
.livro-cover .top { position: relative; z-index: 1; }
.livro-cover .top small {
  font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.22em;
  text-transform: uppercase;
}
.livro-cover .ttl {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.5vw, 3rem);
  line-height: 1;
  letter-spacing: -0.02em;
  position: relative; z-index: 1;
}
.livro-cover .ttl em { font-style: italic; }
.livro-cover .auth {
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em;
  text-transform: uppercase;
  position: relative; z-index: 1;
}
.livro-cover .sun {
  position: absolute;
  right: -60px; bottom: -60px;
  width: 220px; height: 220px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--bg) 20%, transparent);
  z-index: 0;
}

.livro-info { padding: 0 0 0 0; }
.livro-info h2 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3.6rem);
  line-height: 1;
  letter-spacing: -0.02em;
  font-weight: var(--display-weight);
  margin: 24px 0 24px;
}
.livro-info h2 em { font-style: italic; color: var(--terracotta); }
.livro-info p { color: var(--ink-soft); margin-bottom: 16px; font-size: 1.04rem; max-width: 560px; }
.livro-info .quote {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.4rem;
  line-height: 1.4;
  color: var(--ink);
  padding-left: 24px;
  border-left: 2px solid var(--terracotta);
  margin: 32px 0;
  max-width: 540px;
}
.livro-info .meta {
  display: flex; gap: 32px;
  margin: 32px 0;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.livro-info .meta strong { color: var(--ink); font-weight: 500; display: block; margin-top: 4px; letter-spacing: 0; text-transform: none; font-family: var(--font-display); font-size: 1.1rem; font-style: italic; }

@media (max-width: 820px) {
  .livro { grid-template-columns: 1fr; }
  .about-slice { grid-template-columns: 1fr; }
  .hero-split { grid-template-columns: 1fr; min-height: auto; }
  .hero-image { aspect-ratio: 4/4; }
  .sec-head { grid-template-columns: 1fr; }
  .hero-asym h1 { grid-column: 1 / 13; font-size: clamp(3rem, 14vw, 6rem); }
  .hero-asym h1 .line2 { padding-left: 4vw; }
  .hero-asym .photo-block { grid-column: 1 / 13; aspect-ratio: 16/10; }
  .hero-asym .lead { grid-column: 1 / 13; }
}

/* ============================================================
   Testimonials
   ============================================================ */
.tst-wrap {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: start;
}
.tst-list { display: flex; flex-direction: column; gap: 24px; }
.tst {
  background: var(--paper);
  padding: 36px 36px 30px;
  position: relative;
  border-left: 2px solid transparent;
  transition: border-color .3s var(--ease), transform .3s var(--ease);
}
.tst:hover { border-left-color: var(--terracotta); transform: translateX(4px); }
.tst .q {
  font-family: var(--font-display);
  font-size: 1.25rem;
  line-height: 1.45;
  font-style: italic;
  margin-bottom: 24px;
}
.tst .author {
  display: flex; align-items: center; gap: 16px;
}
.tst .author .av {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--soft);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-style: italic;
  color: var(--ink-soft);
  font-size: 1.1rem;
}
.tst .author .info strong { display: block; font-family: var(--font-body); font-size: 0.92rem; font-weight: 600;}
.tst .author .info span { font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); }

@media (max-width: 820px) {
  .tst-wrap { grid-template-columns: 1fr; }
}

/* ============================================================
   Eventos
   ============================================================ */
.evt-list { display: flex; flex-direction: column; }
.evt {
  display: grid;
  grid-template-columns: 100px 1fr 200px 60px;
  align-items: center;
  gap: 32px;
  padding: 28px 0;
  border-top: 1px solid var(--line);
  transition: padding .25s var(--ease), background .25s var(--ease);
  cursor: pointer;
  margin: 0 calc(-1 * var(--gutter));
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}
.evt:hover { background: var(--paper); }
.evt:last-child { border-bottom: 1px solid var(--line); }
.evt .date {
  font-family: var(--font-display);
  font-size: 2rem;
  line-height: 1;
  font-style: italic;
}
.evt .date small {
  font-family: var(--font-mono);
  font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase;
  display: block; margin-top: 4px; color: var(--ink-mute); font-style: normal;
}
.evt h4 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: var(--display-weight);
  line-height: 1.15;
}
.evt h4 em { font-style: italic; color: var(--terracotta); }
.evt .loc { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute); }
.evt .go-mini {
  width: 38px; height: 38px;
  border-radius: 50%;
  border: 1px solid var(--ink-mute);
  display: flex; align-items: center; justify-content: center;
  transition: all .3s var(--ease);
  justify-self: end;
}
.evt:hover .go-mini { background: var(--terracotta); border-color: var(--terracotta); color: var(--bg); transform: rotate(-45deg); }
.evt.passed { opacity: 0.45; }
.evt.passed .date small::before { content: "passada · "; }

@media (max-width: 760px) {
  .evt { grid-template-columns: 80px 1fr 40px; gap: 16px; }
  .evt .loc { display: none; }
}

/* ============================================================
   Newsletter
   ============================================================ */
.newsletter {
  background: var(--ink);
  color: var(--bg);
  padding: var(--section-py) 0;
  position: relative;
  overflow: hidden;
}
.newsletter::before {
  content: "✦";
  position: absolute;
  font-size: 30rem;
  color: color-mix(in srgb, var(--lime) 14%, transparent);
  right: -60px;
  top: 50%; transform: translateY(-50%);
  font-family: var(--font-display);
  line-height: 1;
  pointer-events: none;
}
.newsletter .container { position: relative; z-index: 1; }
.newsletter-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: center;
}
.newsletter h2 {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 4.6vw, 4rem);
  line-height: 1;
  letter-spacing: -0.025em;
  font-weight: var(--display-weight);
}
.newsletter h2 em { font-style: italic; color: var(--lime); }
.newsletter p { color: color-mix(in srgb, var(--bg) 70%, transparent); margin-top: 20px; max-width: 480px; font-size: 1.04rem;}

.subscribe-form {
  display: flex;
  border: 1px solid color-mix(in srgb, var(--bg) 30%, transparent);
  border-radius: 100px;
  overflow: hidden;
  align-items: center;
  padding: 8px 8px 8px 24px;
  max-width: 500px;
}
.subscribe-form input {
  flex: 1; background: transparent; border: none; outline: none;
  color: var(--bg); padding: 14px 0;
  font-family: var(--font-body);
  font-size: 0.95rem;
}
.subscribe-form input::placeholder { color: color-mix(in srgb, var(--bg) 50%, transparent); }
.newsletter .eyebrow { color: var(--lime); }
.newsletter .eyebrow::before { background: var(--lime); }

.subscribe-form button {
  background: var(--lime);
  color: var(--ink);
  padding: 14px 26px;
  border-radius: 100px;
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase;
  transition: all .25s var(--ease);
}
.subscribe-form button:hover { background: var(--bg); color: var(--ink); }
.newsletter .stats-mini {
  margin-top: 44px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: color-mix(in srgb, var(--bg) 60%, transparent);
}
.newsletter .stats-mini > div {
  padding: 22px 24px;
  background: color-mix(in srgb, var(--bg) 5%, transparent);
  border: 1px solid color-mix(in srgb, var(--bg) 14%, transparent);
  border-radius: 14px;
}
.newsletter .stats-mini strong {
  color: var(--bg); display: block;
  font-family: var(--font-display); font-size: 2rem; font-style: italic;
  letter-spacing: -0.01em; text-transform: none; margin-bottom: 8px;
  line-height: 1;
}
@media (max-width: 540px) {
  .newsletter .stats-mini { grid-template-columns: 1fr; }
}

@media (max-width: 820px) { .newsletter-grid { grid-template-columns: 1fr; gap: 36px; } }

/* ============================================================
   Footer
   ============================================================ */
.footer {
  background: var(--bg);
  padding: 100px 0 40px;
  border-top: 1px solid var(--line);
}
.footer-top {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 64px; padding-bottom: 80px;
}
.footer-brand .display {
  font-size: 3rem;
  font-family: var(--font-display);
  letter-spacing: -0.02em;
}
.footer-brand p { color: var(--ink-soft); max-width: 320px; margin-top: 16px; }
.footer-col h5 {
  font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-mute); margin-bottom: 20px;
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 10px;}
.footer-col a { font-size: 0.95rem; transition: color .2s var(--ease);}
.footer-col a:hover { color: var(--terracotta);}
.footer-bottom {
  border-top: 1px solid var(--line);
  padding-top: 28px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
  font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-mute);
}
.footer-bottom .fb-left { justify-self: start; }
.footer-bottom .fb-center {
  justify-self: center;
  text-align: center;
  color: var(--ink-soft);
}
.footer-bottom .fb-center a {
  color: var(--terracotta);
  border-bottom: 1px solid color-mix(in srgb, var(--terracotta) 35%, transparent);
  padding-bottom: 2px;
  transition: color .2s var(--ease), border-color .2s var(--ease);
}
.footer-bottom .fb-center a:hover {
  color: var(--ink); border-bottom-color: var(--ink);
}
.footer-bottom .fb-right { justify-self: end; text-align: right; }
@media (max-width: 820px) {
  .footer-bottom { grid-template-columns: 1fr; text-align: center; gap: 12px; }
  .footer-bottom .fb-left, .footer-bottom .fb-right { justify-self: center; text-align: center; }
}

@media (max-width: 820px) {
  .footer-top { grid-template-columns: 1fr 1fr; gap: 40px; }
}

/* ============================================================
   Page-level
   ============================================================ */
.page-hero {
  padding-top: 200px;
  padding-bottom: var(--section-py);
  padding-left: var(--gutter);
  padding-right: var(--gutter);
  max-width: var(--container);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: end;
}
.page-hero .ttl {
  font-family: var(--font-display);
  font-size: clamp(3rem, 7vw, 7rem);
  font-weight: var(--display-weight);
  line-height: 0.95;
  letter-spacing: -0.035em;
}
.page-hero .ttl em { font-style: italic; color: var(--terracotta); }
.page-hero .intro p { color: var(--ink-soft); font-size: 1.1rem; margin-bottom: 16px; }

@media (max-width: 820px) {
  .page-hero { grid-template-columns: 1fr; padding-top: 140px; }
}

/* ============================================================
   Contato
   ============================================================ */
.contato {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: start;
}
.contato-info h3 {
  font-family: var(--font-display); font-size: 2rem; font-weight: var(--display-weight); margin-bottom: 16px;
  font-style: italic;
}
.contato-info p { color: var(--ink-soft); margin-bottom: 32px; max-width: 480px;}
.contato-info .ci-item {
  border-top: 1px solid var(--line);
  padding: 20px 0;
  display: flex; justify-content: space-between; align-items: center;
}
.contato-info .ci-item:last-child { border-bottom: 1px solid var(--line);}
.contato-info .ci-item small {
  font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-mute);
  display: block; margin-bottom: 4px;
}
.contato-info .ci-item .v { font-family: var(--font-display); font-size: 1.1rem; font-style: italic; }

.form { display: flex; flex-direction: column; gap: 20px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.field {
  display: flex; flex-direction: column; gap: 8px;
}
.field label { font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); }
.field input, .field select, .field textarea {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--line);
  padding: 10px 0;
  font-family: var(--font-body); font-size: 1rem;
  color: var(--ink);
  outline: none;
  transition: border-color .2s var(--ease);
}
.field input:focus, .field select:focus, .field textarea:focus { border-bottom-color: var(--terracotta); }
.field textarea { resize: vertical; min-height: 120px;}

@media (max-width: 820px) {
  .contato { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
}

/* ============================================================
   Conteúdo (media gallery)
   ============================================================ */
.media-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.media-card {
  cursor: pointer;
  display: flex; flex-direction: column;
  transition: transform .35s var(--ease);
}
.media-card:hover { transform: translateY(-4px); }
.media-card .thumb {
  aspect-ratio: 4/3;
  background-size: cover; background-position: center;
  background-color: var(--paper);
  position: relative;
  overflow: hidden;
}
.media-card .thumb::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, color-mix(in srgb, var(--ink) 60%, transparent));
}
.media-card .thumb .play {
  position: absolute;
  bottom: 16px; left: 16px;
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--bg);
  display: flex; align-items: center; justify-content: center;
  z-index: 1;
  transition: transform .3s var(--ease);
}
.media-card:hover .thumb .play { transform: scale(1.1); }
.media-card .meta {
  padding: 20px 0;
}
.media-card .cat {
  font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--terracotta);
}
.media-card h4 {
  font-family: var(--font-display); font-size: 1.4rem; line-height: 1.2; font-weight: var(--display-weight);
  margin: 10px 0; letter-spacing: -0.01em;
}
.media-card h4 em { font-style: italic; color: var(--terracotta); }
.media-card .info { font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute);}

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

/* ============================================================
   RIW slice
   ============================================================ */
.riw {
  display: grid;
  grid-template-columns: 7fr 5fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: center;
  background: var(--ink);
  color: var(--bg);
  padding: var(--section-py) var(--gutter);
  margin: 0 calc(-1 * var(--gutter));
  border-radius: 0;
  position: relative;
  overflow: hidden;
}
.riw::before {
  content: "RIW";
  position: absolute;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 30rem;
  color: color-mix(in srgb, var(--bg) 4%, transparent);
  right: -60px; top: -80px;
  line-height: 0.8;
  letter-spacing: -0.06em;
  pointer-events: none;
}
.riw .content { position: relative; z-index: 1; }
.riw .eyebrow { color: var(--lime); }
.riw .eyebrow::before { background: var(--lime); }
.riw h2 {
  font-family: var(--font-display); font-size: clamp(2.2rem, 4.5vw, 4rem);
  line-height: 1; letter-spacing: -0.025em; font-weight: var(--display-weight);
  margin: 24px 0 24px;
}
.riw h2 em { font-style: italic; color: var(--lime); }
.riw p { color: color-mix(in srgb, var(--bg) 75%, transparent); max-width: 520px; font-size: 1.04rem; margin-bottom: 32px; }
.riw .riw-img {
  aspect-ratio: 4/5; background-size: cover; background-position: center;
  position: relative;
}
.riw .riw-img::after {
  content: ""; position: absolute; inset: 0;
  background: color-mix(in srgb, var(--terracotta) 30%, transparent);
  mix-blend-mode: multiply;
}

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

/* ============================================================
   Manifesto strip
   ============================================================ */
.manifesto-strip {
  padding: var(--section-py) 0;
  text-align: center;
}
.manifesto-strip blockquote {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 4.4rem);
  line-height: 1.08;
  letter-spacing: -0.02em;
  max-width: 1100px;
  margin: 24px auto 0;
  font-weight: var(--display-weight);
}
.manifesto-strip blockquote em { font-style: italic; color: var(--terracotta); }
.manifesto-strip .src {
  margin-top: 32px;
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-mute);
}

/* ============================================================
   Symbol mark — used in nav + footer + accents
   ============================================================ */
/* Brand logo (img — white-on-transparent recolored via filter) */
.brand-logo-img {
  filter: brightness(0);
  transition: filter .3s var(--ease);
}
[data-mode="dark"] .brand-logo-img {
  filter: brightness(0) invert(1);
}
.brand-mark { color: var(--terracotta); }

/* ============================================================
   Trajetória timeline (about page)
   ============================================================ */
.timeline { display: flex; flex-direction: column; }
.tl-item {
  display: grid;
  grid-template-columns: 120px 1fr 1fr;
  gap: 40px;
  padding: 36px 0;
  border-top: 1px solid var(--line);
  align-items: start;
}
.tl-item:last-child { border-bottom: 1px solid var(--line);}
.tl-year { font-family: var(--font-display); font-size: 2rem; font-style: italic; color: var(--terracotta); }
.tl-title { font-family: var(--font-display); font-size: 1.5rem; line-height: 1.2; font-weight: var(--display-weight); }
.tl-title em { font-style: italic; }
.tl-desc { color: var(--ink-soft); font-size: 0.98rem; }
@media (max-width: 820px) {
  .tl-item { grid-template-columns: 1fr; gap: 12px; }
}

/* ============================================================
   Values cards (sobre page)
   ============================================================ */
.values {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px; background: var(--line); border: 1px solid var(--line);
}
.value {
  background: var(--bg);
  padding: 40px 32px;
  min-height: 280px;
  display: flex; flex-direction: column;
}
.value .num { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em; color: var(--terracotta); margin-bottom: 24px; }
.value h4 { font-family: var(--font-display); font-size: 1.6rem; line-height: 1.1; font-weight: var(--display-weight); margin-bottom: 12px; letter-spacing: -0.015em;}
.value h4 em { font-style: italic; color: var(--terracotta);}
.value p { color: var(--ink-soft); font-size: 0.98rem; }
@media (max-width: 820px) {
  .values { grid-template-columns: 1fr; }
}

/* ============================================================
   Anim — fade in on scroll (simple)
   ============================================================ */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in { opacity: 1; transform: none; }

/* ============================================================
   View transitions (page changes)
   ============================================================ */
.page-view {
  opacity: 1;
}
@keyframes fadeup {
  0% { opacity: 0; transform: translateY(14px); }
  100% { opacity: 1; transform: translateY(0); }
}
.manifesto-roll {
  display: block;
  opacity: 1;
}

/* ============================================================
   Misc
   ============================================================ */
.lockup {
  display: flex; align-items: center; gap: 14px;
}
.placeholder-photo {
  background: linear-gradient(135deg, var(--soft), var(--clay));
  display: flex; align-items: center; justify-content: center;
  color: var(--paper);
  font-family: var(--font-display);
  font-style: italic;
  position: relative;
}
.placeholder-photo::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 30% 20%, color-mix(in srgb, var(--bg) 30%, transparent) 0%, transparent 30%),
    radial-gradient(circle at 70% 70%, color-mix(in srgb, var(--terracotta) 20%, transparent) 0%, transparent 40%);
}
.placeholder-photo span { position: relative; z-index: 1; font-size: 1rem; letter-spacing: 0.1em; opacity: 0.6;}

/* ============================================================
   HeroSignature — magazine cover, intimate
   ============================================================ */
.hero-sig {
  position: relative;
  padding: 110px var(--gutter) 0;
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(36px, 5vw, 80px);
  align-items: stretch;
  overflow: hidden;
}
.hero-sig-text {
  padding: 60px 0 80px;
  display: flex; flex-direction: column;
  position: relative;
  z-index: 2;
}
.hero-sig-corner {
  position: absolute;
  top: 22px; left: 0;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  display: flex; gap: 14px; align-items: center;
}
.hero-sig-corner::before {
  content: "✦"; color: var(--terracotta); font-family: var(--font-display);
}
.hero-sig-greeting {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.3rem, 1.6vw, 1.6rem);
  color: var(--terracotta);
  margin-bottom: 24px;
  display: flex; align-items: center; gap: 16px;
}
.hero-sig-greeting::before {
  content: ""; width: 40px; height: 1px; background: var(--terracotta);
}
.hero-sig h1 {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: clamp(3rem, 7.5vw, 7rem);
  line-height: 0.96;
  letter-spacing: -0.035em;
  margin-bottom: 36px;
  position: relative;
  min-height: 2em;
}
.hero-sig h1 em { font-style: italic; color: var(--terracotta); }
.hero-sig h1 .roll {
  display: block;
  transition: opacity .45s var(--ease), transform .45s var(--ease);
}
.hero-sig h1 .roll.out { opacity: 0; transform: translateY(-12px); }
.hero-sig-letter {
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 1.3vw, 1.32rem);
  line-height: 1.5;
  color: var(--ink-soft);
  max-width: 540px;
  margin-bottom: 36px;
}
.hero-sig-letter em { font-style: italic; color: var(--ink); }
.hero-sig-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 40px; }

/* (legacy .hero-sig-ticker rules removidos — definidos no bloco REDESIGN 2026) */

.hero-sig-photo-wrap {
  position: relative;
  display: flex; flex-direction: column;
  padding: 60px 0;
}
.hero-sig-photo {
  position: relative;
  background-size: cover;
  background-position: center;
  filter: saturate(0.92);
  flex: 1;
  min-height: 480px;
}
.hero-sig-circle {
  position: absolute;
  left: -60px; top: -20px;
  width: 280px; height: 280px;
  background: var(--terracotta);
  border-radius: 50%;
  z-index: -1;
  opacity: 0.92;
}
.hero-sig-circle::before {
  content: "";
  position: absolute;
  inset: 18px;
  border: 1px solid color-mix(in srgb, var(--bg) 35%, transparent);
  border-radius: 50%;
}
.hero-sig-numbers {
  position: absolute;
  right: 20px; bottom: 20px;
  background: var(--bg);
  padding: 16px 20px;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.hero-sig-numbers strong {
  display: block;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.5rem;
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--ink);
  margin-bottom: 4px;
}

.hero-sig-continue {
  position: absolute;
  bottom: 28px; left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  display: flex; flex-direction: column; align-items: center;
  gap: 10px;
  z-index: 3;
}
.hero-sig-continue::after {
  content: "";
  width: 1px; height: 28px;
  background: var(--ink-mute);
  animation: trickle 2.4s ease-in-out infinite;
}
@keyframes trickle {
  0%, 100% { transform: scaleY(0.3); transform-origin: top; opacity: 0.5; }
  50% { transform: scaleY(1); opacity: 1; }
}

@media (max-width: 980px) {
  .hero-sig { grid-template-columns: 1fr; min-height: auto; padding-top: 120px; }
  .hero-sig-text { padding: 24px 0 40px; }
  .hero-sig-photo-wrap { padding: 0; }
  .hero-sig-photo { min-height: 380px; }
  .hero-sig-corner { position: relative; top: auto; left: auto; margin-bottom: 24px; }
  .hero-sig-continue { display: none; }
  .hero-sig-circle { width: 180px; height: 180px; left: -40px; }
}

/* ============================================================
   Conheca slice — intimate "Sobre Adriana"
   ============================================================ */
.conheca {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: start;
}
.conheca-visual { position: relative; }
.conheca-photo {
  aspect-ratio: 3/4;
  background-size: cover; background-position: center;
  filter: saturate(0.92);
  position: relative;
}
.conheca-photo::before {
  content: "";
  position: absolute;
  bottom: -32px; right: -32px;
  width: 70%; height: 60%;
  border: 1px solid var(--terracotta);
  z-index: -1;
}
.conheca-letter {
  font-family: var(--font-display);
  font-size: clamp(1.15rem, 1.6vw, 1.6rem);
  line-height: 1.45;
  color: var(--ink);
}
.conheca-letter p { margin-bottom: 16px; }
.conheca-letter em { color: var(--terracotta); font-style: italic; }
.conheca-letter .pergunta {
  font-style: italic;
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  line-height: 1.2;
  color: var(--terracotta);
  margin: 24px 0;
  letter-spacing: -0.015em;
}
.conheca-letter .sig {
  margin-top: 40px;
  display: flex; align-items: center; gap: 14px;
  font-size: 1rem;
  font-style: italic;
  color: var(--ink-soft);
  letter-spacing: 0.02em;
}
.conheca-letter .sig::before {
  content: ""; width: 32px; height: 1px; background: var(--ink-soft);
}
.conheca-letter .sig em { color: var(--ink); font-style: italic; }

/* Cinco coisas — listicle */
.cinco {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: var(--line);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.cinco-item {
  background: var(--bg);
  padding: 36px 26px;
  display: flex; flex-direction: column;
  min-height: 280px;
  transition: background .25s var(--ease);
}
.cinco-item:hover { background: var(--paper); }
.cinco-item .n {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 2.6rem;
  color: var(--terracotta);
  line-height: 1;
  margin-bottom: 24px;
}
.cinco-item h4 {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: var(--display-weight);
  line-height: 1.2;
  margin-bottom: 14px;
  letter-spacing: -0.01em;
}
.cinco-item p {
  color: var(--ink-soft);
  font-size: 0.92rem;
  margin-top: auto;
}

@media (max-width: 980px) {
  .conheca { grid-template-columns: 1fr; }
  .conheca-photo::before { right: 0; }
  .cinco { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .cinco { grid-template-columns: 1fr; }
}

/* HOJE — "right now" snapshot */
.hoje {
  display: grid;
  grid-template-columns: minmax(220px, 280px) 1fr;
  gap: 32px 60px;
  padding: 56px var(--gutter);
  background: var(--paper);
  margin: 0 calc(-1 * var(--gutter));
  align-items: baseline;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.hoje-head {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.7rem, 2.5vw, 2.4rem);
  letter-spacing: -0.02em;
  color: var(--ink);
  display: flex; flex-direction: column;
  line-height: 1;
}
.hoje-head em { color: var(--terracotta); }
.hoje-head small {
  font-family: var(--font-mono);
  font-style: normal;
  font-size: 0.65rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--terracotta);
  margin-bottom: 10px;
  display: flex; align-items: center; gap: 10px;
  font-weight: 500;
}
.hoje-head small::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--terracotta);
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 0 0 var(--terracotta); }
  50% { opacity: 0.6; box-shadow: 0 0 0 6px transparent; }
}
.hoje-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 24px 40px;
}
.hoje-row {
  display: flex; flex-direction: column;
  border-top: 1px solid var(--line);
  padding-top: 14px;
}
.hoje-row small {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 6px;
}
.hoje-row .v {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.1rem;
  line-height: 1.3;
  color: var(--ink);
}

@media (max-width: 760px) {
  .hoje { grid-template-columns: 1fr; gap: 24px; }
}

/* ============================================================
   Animation primitives (driven by animations.js)
   ============================================================ */

/* word-level reveal */
.reveal-words .wr {
  display: inline-block;
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s var(--ease), transform .7s var(--ease);
  will-change: opacity, transform;
}
.reveal-words.in .wr { opacity: 1; transform: none; }

/* block-level reveal */
.reveal-block {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .8s var(--ease), transform .8s var(--ease);
  will-change: opacity, transform;
}
.reveal-block.in { opacity: 1; transform: none; }

/* magnetic transform binding */
[data-magnetic] {
  transform: translate(var(--mx, 0), var(--my, 0));
  transition: transform .35s cubic-bezier(.2,.8,.2,1);
}

/* parallax target binding */
[data-parallax] {
  transform: translate3d(0, var(--py, 0), 0);
  will-change: transform;
}

/* ============================================================
   Intermission marquee — bold horizontal scroll
   ============================================================ */
.intermission {
  background: var(--ink);
  color: var(--bg);
  padding: clamp(28px, 3.5vw, 44px) 0;
  overflow: hidden;
  position: relative;
  /* sem borda — para que dark blocks adjacentes (caminho, dark-section) flow sem corte */
}
.intermission.light { background: var(--paper); color: var(--ink); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.intermission-track {
  display: flex;
  width: max-content;
  animation: scrollLeft 38s linear infinite;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: var(--display-weight);
  font-size: clamp(1.6rem, 3.2vw, 2.8rem);
  line-height: 1.2;
  letter-spacing: -0.02em;
  white-space: nowrap;
  gap: 48px;
}
.intermission-track span {
  display: inline-flex; align-items: center; gap: 60px;
}
.intermission-track span::after {
  content: "✦";
  color: var(--lime);
  font-style: normal;
  font-size: 0.4em;
  vertical-align: middle;
}
.intermission.light .intermission-track span::after { color: var(--terracotta); }
@keyframes scrollLeft {
  from { transform: translate3d(0, 0, 0); }
  to   { transform: translate3d(-50%, 0, 0); }
}
.intermission:hover .intermission-track { animation-play-state: paused; }

/* ============================================================
   Magazine cursor — subtle dot + ring
   ============================================================ */
.mag-cursor {
  position: fixed;
  top: 0; left: 0;
  pointer-events: none;
  z-index: 2147483645;
  width: 0; height: 0;
  opacity: 0;
  transition: opacity .25s var(--ease);
}
.mag-cursor.on { opacity: 1; }
.mag-cursor-dot,
.mag-cursor-ring {
  position: absolute;
  top: 0; left: 0;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
}
.mag-cursor-dot {
  width: 6px; height: 6px;
  background: var(--terracotta);
  transition: width .25s var(--ease), height .25s var(--ease), background .25s var(--ease);
}
.mag-cursor-ring {
  width: 28px; height: 28px;
  border: 1px solid color-mix(in srgb, var(--ink) 40%, transparent);
  transition: width .35s var(--ease), height .35s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.mag-cursor.hover .mag-cursor-dot {
  width: 0; height: 0;
}
.mag-cursor.hover .mag-cursor-ring {
  width: 48px; height: 48px;
  background: color-mix(in srgb, var(--terracotta) 14%, transparent);
  border-color: var(--terracotta);
  mix-blend-mode: normal;
}
[data-mode="dark"] .mag-cursor-ring { border-color: color-mix(in srgb, var(--bg) 40%, transparent); }
[data-mode="dark"] .mag-cursor.hover .mag-cursor-ring {
  background: color-mix(in srgb, var(--lime) 18%, transparent);
  border-color: var(--lime);
}
[data-mode="dark"] .mag-cursor-dot { background: var(--lime); }

/* hide custom cursor on touch devices */
@media (hover: none) { .mag-cursor { display: none !important; } }

/* ============================================================
   Hero — Cover Story (editorial magazine cover)
   ============================================================ */
.hero-cover {
  min-height: 100vh;
  padding: 100px var(--gutter) 60px;
  position: relative;
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 32px;
  overflow: hidden;
}
.hero-cover-mast {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-family: var(--font-display);
  font-size: clamp(2.6rem, 4.5vw, 4.8rem);
  font-style: italic;
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--terracotta);
  padding: 24px 0;
  border-right: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
}
.hero-cover-mast small {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 0.3em;
  font-style: normal;
  color: var(--ink-mute);
  writing-mode: vertical-rl;
  margin-top: 16px;
}
.hero-cover-stage {
  position: relative;
  display: flex;
  flex-direction: column;
}
.hero-cover-topbar {
  display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap;
  padding: 12px 0 28px;
  border-bottom: 1px solid var(--line);
  font-family: var(--font-mono); font-size: 0.62rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-mute);
}
.hero-cover-topbar strong {
  color: var(--ink); font-family: var(--font-display); font-style: italic;
  font-size: 1rem; letter-spacing: 0; text-transform: none; font-weight: 500;
}
.hero-cover-photo {
  flex: 1; position: relative;
  background-size: cover; background-position: center;
  margin-top: 32px;
  min-height: 540px;
  filter: saturate(0.9);
}
.hero-cover-photo::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, color-mix(in srgb, var(--ink) 14%, transparent) 0%, transparent 30%, color-mix(in srgb, var(--ink) 75%, transparent) 100%);
}
.hero-cover-title {
  position: absolute; bottom: 40px; left: 40px; right: 40px;
  z-index: 2; color: var(--bg);
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: clamp(2.6rem, 7vw, 7rem);
  line-height: 0.94;
  letter-spacing: -0.035em;
  max-width: 80%;
}
.hero-cover-title em { font-style: italic; color: var(--lime); }
.hero-cover-droplet {
  position: absolute; top: 40px; right: 40px;
  font-family: var(--font-display); font-style: italic;
  font-size: clamp(8rem, 14vw, 14rem);
  color: var(--terracotta);
  line-height: 0.7;
  z-index: 2; pointer-events: none;
}
.hero-cover-inside {
  position: absolute; top: 50px; left: 40px; z-index: 2;
  display: flex; flex-direction: column; gap: 10px;
  max-width: 280px;
}
.hero-cover-inside .label {
  font-family: var(--font-display); font-style: italic; color: var(--lime);
  font-size: 1rem; letter-spacing: 0; margin-bottom: 6px;
}
.hero-cover-badge {
  display: inline-flex; align-items: center; gap: 10px;
  background: color-mix(in srgb, var(--ink) 70%, transparent);
  backdrop-filter: blur(8px);
  padding: 8px 14px;
  border: 1px solid color-mix(in srgb, var(--bg) 20%, transparent);
  font-family: var(--font-mono); font-size: 0.6rem;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--bg);
  align-self: flex-start;
}
.hero-cover-badge::before { content: "›"; color: var(--lime); }
.hero-cover-actions {
  position: absolute; bottom: 36px; right: 40px; z-index: 3;
}
.hero-cover-barcode {
  position: absolute; bottom: 36px; left: 40px; z-index: 2;
  display: flex; gap: 2px; align-items: flex-end;
  height: 30px;
}
.hero-cover-barcode span {
  background: var(--bg); display: inline-block;
}
.hero-cover-barcode small {
  font-family: var(--font-mono); font-size: 0.55rem;
  color: var(--bg); letter-spacing: 0.2em;
  margin-left: 8px; align-self: flex-end;
}

@media (max-width: 820px) {
  .hero-cover { grid-template-columns: 1fr; padding-top: 120px; padding-left: 24px; padding-right: 24px; }
  .hero-cover-mast { display: none; }
  .hero-cover-title { font-size: clamp(1.8rem, 9vw, 3rem); left: 20px; right: 20px; bottom: 24px; max-width: 100%; }
  .hero-cover-droplet { font-size: 6rem; right: 20px; top: 24px; }
  .hero-cover-inside { left: 20px; right: 20px; top: 80px; max-width: none; }
  .hero-cover-actions { right: 20px; bottom: 90px; }
  .hero-cover-barcode { left: 20px; bottom: 90px; }
  .hero-cover-photo { min-height: 600px; }
}

/* ============================================================
   Hero — Stage Spotlight (cinematic dark)
   ============================================================ */
.hero-stage {
  min-height: 100vh;
  background: var(--ink);
  color: var(--bg);
  padding: 140px var(--gutter) 60px;
  position: relative;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  overflow: hidden;
  text-align: center;
}
.hero-stage::before {
  content: ""; position: absolute; inset: -10% -10% 0 -10%;
  background: radial-gradient(ellipse at 50% 30%,
    color-mix(in srgb, var(--lime) 14%, transparent) 0%,
    transparent 55%);
  pointer-events: none;
}
.hero-stage::after {
  /* light beam */
  content: ""; position: absolute; top: 0;
  left: 50%; transform: translateX(-50%);
  width: 120vw; height: 100vh;
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--lime) 8%, transparent) 0%,
    transparent 70%);
  clip-path: polygon(45% 0, 55% 0, 75% 100%, 25% 100%);
  pointer-events: none;
}
.hero-stage-overhead {
  position: absolute; top: 110px; left: 50%; transform: translateX(-50%);
  font-family: var(--font-mono); font-size: 0.65rem;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: color-mix(in srgb, var(--bg) 60%, transparent);
  display: flex; align-items: center; gap: 14px;
  z-index: 3;
}
.hero-stage-overhead::before, .hero-stage-overhead::after {
  content: ""; width: 60px; height: 1px;
  background: color-mix(in srgb, var(--bg) 40%, transparent);
}
.hero-stage-live {
  display: flex; align-items: center; gap: 8px;
  color: var(--lime);
  font-weight: 600;
}
.hero-stage-live::before {
  content: ""; width: 6px; height: 6px;
  background: var(--lime); border-radius: 50%;
  animation: pulse 1.8s ease-in-out infinite;
}
.hero-stage h1 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: var(--display-weight);
  font-size: clamp(2.6rem, 8vw, 8rem);
  line-height: 0.94;
  letter-spacing: -0.04em;
  max-width: 1100px;
  margin: 32px 0 40px;
  position: relative; z-index: 2;
}
.hero-stage h1 em {
  font-style: normal;
  color: var(--lime);
}
.hero-stage-photo {
  position: relative;
  width: clamp(180px, 22vw, 280px); aspect-ratio: 3/4;
  background-size: cover; background-position: center;
  margin: 0 auto 40px;
  filter: saturate(0.85) contrast(1.05);
  z-index: 2;
}
.hero-stage-photo::after {
  content: "";
  position: absolute; inset: -10px;
  border: 1px solid var(--lime);
  z-index: -1;
}
.hero-stage-photo::before {
  content: "Adriana Schneider";
  position: absolute;
  bottom: -30px; left: 50%; transform: translateX(-50%);
  font-family: var(--font-display); font-style: italic;
  font-size: 0.95rem; white-space: nowrap;
  color: var(--bg);
}
.hero-stage-actions {
  display: flex; gap: 14px; flex-wrap: wrap;
  justify-content: center;
  position: relative; z-index: 2;
  margin-top: 16px;
}
.hero-stage-credits {
  position: absolute; bottom: 32px; left: 0; right: 0;
  display: flex; justify-content: space-between; flex-wrap: wrap;
  padding: 0 var(--gutter);
  gap: 16px;
  font-family: var(--font-mono); font-size: 0.6rem;
  letter-spacing: 0.25em; text-transform: uppercase;
  color: color-mix(in srgb, var(--bg) 50%, transparent);
  z-index: 3;
}
.hero-stage-credits span::before {
  content: "✦"; color: var(--lime); font-family: var(--font-display);
  margin-right: 8px; font-style: normal; vertical-align: middle;
}
.hero-stage-wire {
  position: absolute; top: 50%;
  font-family: var(--font-mono); font-size: 0.55rem;
  letter-spacing: 0.32em; text-transform: uppercase;
  color: color-mix(in srgb, var(--bg) 35%, transparent);
  white-space: nowrap;
  z-index: 3;
}
.hero-stage-wire.left {
  left: var(--gutter);
  transform: translateY(-50%) rotate(-90deg);
  transform-origin: left center;
}
.hero-stage-wire.right {
  right: var(--gutter);
  transform: translateY(-50%) rotate(90deg);
  transform-origin: right center;
}

@media (max-width: 820px) {
  .hero-stage h1 { font-size: clamp(2rem, 11vw, 4rem); margin: 24px 0 32px; }
  .hero-stage-wire { display: none; }
  .hero-stage-overhead { top: 100px; font-size: 0.55rem; gap: 8px; }
  .hero-stage-overhead::before, .hero-stage-overhead::after { width: 24px; }
  .hero-stage-credits { font-size: 0.55rem; gap: 8px; }
}

/* ============================================================
   Hero — Triptych (3-panel editorial)
   ============================================================ */
.hero-tri {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1.1fr 1fr;
  margin: 0 calc(-1 * var(--gutter));
  padding-top: 90px;
  overflow: hidden;
  position: relative;
}
.hero-tri-panel {
  position: relative;
  padding: 56px 40px 80px;
  display: flex; flex-direction: column;
  min-height: calc(100vh - 90px);
}
.hero-tri-panel.cream { background: var(--paper); color: var(--ink); }
.hero-tri-panel.clay  { background: var(--terracotta); color: var(--bg); }
.hero-tri-panel.dark  { background: var(--ink); color: var(--bg); }

.hero-tri-panel .nh {
  font-family: var(--font-mono); font-size: 0.62rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  opacity: 0.65;
  margin-bottom: 24px;
  display: flex; align-items: center; gap: 12px;
}
.hero-tri-panel .nh::before { content: ""; width: 28px; height: 1px; background: currentColor; opacity: 0.4; }

.hero-tri-panel h2 {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: clamp(2rem, 4vw, 3.6rem);
  line-height: 1;
  letter-spacing: -0.025em;
  margin-bottom: 24px;
}
.hero-tri-panel h2 em { font-style: italic; }
.hero-tri-panel.cream h2 em { color: var(--terracotta); }
.hero-tri-panel.clay h2 em { color: var(--bg); }
.hero-tri-panel.dark h2 em { color: var(--lime); }

.hero-tri-panel .photo {
  flex: 1;
  background-size: cover; background-position: center;
  margin: 24px -40px 0;
  min-height: 320px;
  filter: saturate(0.9);
}
.hero-tri-panel .photo-cap {
  position: absolute;
  bottom: 36px; left: 40px; right: 40px;
  z-index: 2;
  background: var(--bg);
  color: var(--ink);
  padding: 14px 16px;
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  display: flex; flex-direction: column;
  gap: 4px;
  max-width: 240px;
}
.hero-tri-panel .photo-cap strong {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-style: italic;
  letter-spacing: 0;
  text-transform: none;
}

.hero-tri-panel.clay .massive-q {
  font-family: var(--font-display); font-style: italic;
  font-size: clamp(7rem, 14vw, 16rem);
  line-height: 0.85; letter-spacing: -0.045em;
  margin: 16px 0;
  color: var(--bg);
}
.hero-tri-panel.clay .secondline {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.4rem, 2.2vw, 2.2rem);
  line-height: 1.15;
  color: color-mix(in srgb, var(--bg) 88%, transparent);
  margin-bottom: 32px;
}

.hero-tri-panel.dark .nums {
  display: grid; grid-template-columns: 1fr 1fr; gap: 28px;
  margin-top: 28px;
  border-top: 1px solid color-mix(in srgb, var(--bg) 20%, transparent);
  padding-top: 28px;
}
.hero-tri-panel.dark .nums .num {
  display: flex; flex-direction: column;
}
.hero-tri-panel.dark .nums .v {
  font-family: var(--font-display);
  font-size: 2.6rem;
  font-style: italic;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--lime);
}
.hero-tri-panel.dark .nums small {
  font-family: var(--font-mono); font-size: 0.6rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  opacity: 0.6;
  margin-top: 8px;
}

.hero-tri-panel .panel-cta {
  margin-top: auto;
  align-self: flex-start;
}
.hero-tri-panel .panel-num {
  position: absolute;
  top: 24px; right: 32px;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 5rem;
  line-height: 1;
  letter-spacing: -0.04em;
  opacity: 0.18;
  pointer-events: none;
}

@media (max-width: 980px) {
  .hero-tri { grid-template-columns: 1fr; }
  .hero-tri-panel { min-height: auto; padding-bottom: 60px; }
  .hero-tri-panel .photo { min-height: 280px; }
  .hero-tri-panel.clay .massive-q { font-size: clamp(4rem, 16vw, 9rem); }
}

/* ============================================================
   Reduce motion safety net
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001s !important;
    transition-duration: 0.001s !important;
    animation-iteration-count: 1 !important;
  }
  .reveal-words .wr { opacity: 1 !important; transform: none !important; }
  .reveal-block { opacity: 1 !important; transform: none !important; }
  .intermission-track { animation: none !important; }
  .marquee-track { animation: none !important; }
  .mag-cursor { display: none !important; }
}

/* ============================================================
   Number block — used in stats
   ============================================================ */
.stat-counter {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: var(--display-weight);
  font-variant-numeric: tabular-nums;
}

/* ============================================================
   ── REDESIGN 2026 ─ Humanāre · Adriana Schneider ──
   ============================================================ */

/* Embroidery texture — terracotta thread pattern on cream.
   Used as a recurring brand motif (banner backgrounds, dividers). */
.embroidery {
  position: relative;
  background-color: var(--paper);
  background-image:
    radial-gradient(circle at 25% 30%, color-mix(in srgb, var(--terracotta) 22%, transparent) 0 1.4px, transparent 1.6px),
    radial-gradient(circle at 75% 60%, color-mix(in srgb, var(--terracotta) 18%, transparent) 0 1.2px, transparent 1.4px),
    radial-gradient(circle at 50% 80%, color-mix(in srgb, var(--clay) 22%, transparent) 0 1px, transparent 1.2px),
    repeating-linear-gradient(
      36deg,
      transparent 0 14px,
      color-mix(in srgb, var(--terracotta) 9%, transparent) 14px 15px,
      transparent 15px 30px
    ),
    repeating-linear-gradient(
      -36deg,
      transparent 0 14px,
      color-mix(in srgb, var(--clay) 8%, transparent) 14px 15px,
      transparent 15px 30px
    );
  background-size: 12px 12px, 12px 12px, 12px 12px, 60px 60px, 60px 60px;
}
.embroidery-divider {
  height: 84px;
  margin: 0 calc(-1 * var(--gutter));
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

/* ── Hero (Signature) — refresh ───────────────────────── */
.hero-sig {
  position: relative;
  padding-top: 150px;
  padding-bottom: 80px;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
  max-width: var(--container);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: clamp(40px, 6vw, 90px);
  min-height: calc(100vh - 80px);
  align-items: end;
}
.hero-sig-text { display: flex; flex-direction: column; gap: 28px; max-width: 780px; }
.hero-sig-corner {
  display: flex; gap: 12px; align-items: center;
  font-family: var(--font-mono); font-size: 0.65rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-mute);
}
.hero-sig-greeting {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.4rem;
  color: var(--terracotta);
  letter-spacing: -0.01em;
}
.hero-sig h1 {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 5vw, 4.6rem);
  font-weight: var(--display-weight);
  line-height: 1.02;
  letter-spacing: -0.03em;
  color: var(--ink);
  max-width: 14ch;
  /* Reserva espaço fixo p/ as 4 manifesto-lines não causarem layout shift
     quando o conteúdo trocar (mais longa = 3 linhas). */
  min-height: 3.1em;
  display: flex;
  align-items: flex-start;
}
.hero-sig h1 em {
  font-style: italic;
  color: var(--terracotta);
}
.hero-sig h1 .roll {
  display: block;
  transition: opacity .42s var(--ease), transform .42s var(--ease);
}
.hero-sig h1 .roll.out { opacity: 0; transform: translateY(14px); }

.hero-sig-letter {
  font-family: var(--font-body);
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--ink-soft);
  max-width: 580px;
}
.hero-sig-letter em {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--terracotta);
  font-size: 1.12em;
}
.hero-sig-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 4px; }
.hero-sig-ticker {
  display: grid;
  grid-template-columns: 1fr 1fr;       /* 2 colunas alinhadas */
  column-gap: 32px;
  row-gap: 18px;
  margin-top: 16px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 0.78rem;                   /* era 0.62rem */
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.hero-sig-ticker span {
  display: flex;
  align-items: baseline;
  gap: 12px;
  line-height: 1.35;
}
.hero-sig-ticker span::before {
  content: '›';
  color: var(--terracotta);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.15rem;
  line-height: 1;
  font-weight: 600;
  flex-shrink: 0;
}
.hero-sig-ticker span::after { content: none; }
@media (max-width: 620px) {
  .hero-sig-ticker { grid-template-columns: 1fr; }
}

/* Coluna direita do hero: arch da foto + bloco de credenciais embaixo */
.hero-sig-photo-wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 36px;
  align-self: start;
  margin-top: 12px;
  width: 100%;
}
.hero-sig-photo-arch {
  position: relative;
  aspect-ratio: 3/4;
  max-height: 620px;
  width: 100%;
}
/* Soft terracotta halo behind the arched photo — keeps the photo
   visually connected to the brand color blocks of the page. */
.hero-sig-circle {
  position: absolute;
  inset: -32px -32px 12% 8%;
  background:
    radial-gradient(ellipse at 35% 30%,
      color-mix(in srgb, var(--terracotta) 88%, transparent) 0%,
      color-mix(in srgb, var(--terracotta) 60%, transparent) 55%,
      transparent 75%);
  border-radius: 999px 999px 24px 24px;
  z-index: 0;
  filter: blur(0.3px);
}
/* Photo masked into an arch — semicircle on top, slight rounding on the bottom.
   Echoes the architectural arch motif from the brand references. */
.hero-sig-photo {
  position: relative;
  width: 100%; height: 100%;
  background-size: cover;
  background-position: center 22%;
  background-repeat: no-repeat;
  z-index: 1;
  border-radius: 999px 999px 18px 18px;
  filter: saturate(0.95) contrast(1.03);
  box-shadow: 0 24px 40px -24px color-mix(in srgb, var(--ink) 35%, transparent);
}
/* Subtle texture grain on the arched photo, in brand terracotta */
.hero-sig-photo::after {
  content: '';
  position: absolute; inset: 0;
  border-radius: inherit;
  background-image: repeating-linear-gradient(
    90deg,
    transparent 0 3px,
    color-mix(in srgb, var(--terracotta) 4%, transparent) 3px 4px
  );
  pointer-events: none;
  mix-blend-mode: multiply;
}
/* Photo caption — short bio that sits over the bottom of the arched photo */
.hero-sig-bio {
  position: absolute;
  bottom: 18px;
  left: -16px;
  right: 12px;
  max-width: 400px;
  background: var(--bg);
  padding: 18px 22px;
  font-family: var(--font-body);
  font-size: 1.05rem;
  font-weight: 500;
  line-height: 1.45;
  letter-spacing: -0.005em;
  color: var(--ink);
  border-left: 3px solid var(--terracotta);
  box-shadow: 0 14px 30px -12px color-mix(in srgb, var(--ink) 32%, transparent);
  z-index: 2;
}
.hero-sig-bio em {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--terracotta);
  font-size: 1.12em;
  font-weight: 500;
}
.hero-sig-continue {
  position: absolute; bottom: 18px; right: var(--gutter);
  font-family: var(--font-mono); font-size: 0.6rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-mute);
  writing-mode: vertical-rl;
  rotate: 180deg;
}
@media (max-width: 920px) {
  .hero-sig { grid-template-columns: 1fr; gap: 40px; padding-top: 120px; }
  .hero-sig-continue { display: none; }
}

/* ── O Caminho do Protagonista (book + 3 pillars) ───── */
.caminho {
  background: var(--ink);
  color: var(--bg);
  padding: var(--section-py) 0;
  position: relative;
  overflow: hidden;
}
.caminho::before {
  content: '';
  position: absolute; inset: 0;
  /* halo sutil só no canto superior direito — não toca os edges horizontais
     onde o Caminho encontra Intermission/dark-section, evitando o "corte". */
  background:
    radial-gradient(ellipse 38% 30% at 90% 18%,
      color-mix(in srgb, var(--terracotta) 22%, transparent),
      transparent 70%);
  pointer-events: none;
}
.caminho .container { position: relative; z-index: 1; }
.caminho-head {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(36px, 5vw, 80px);
  align-items: end;
  margin-bottom: 64px;
}
.caminho-head .eyebrow { color: var(--terracotta-soft); }
.caminho-head .eyebrow::before { background: var(--terracotta-soft); }
.caminho-head h2 {
  font-family: var(--font-display);
  font-size: clamp(2.6rem, 5.6vw, 5rem);
  line-height: 1;
  letter-spacing: -0.025em;
  font-weight: var(--display-weight);
  margin-top: 20px;
}
.caminho-head h2 em {
  font-style: italic;
  color: var(--terracotta-soft);
}
.caminho-head p {
  color: color-mix(in srgb, var(--bg) 78%, transparent);
  font-size: 1.05rem;
  max-width: 520px;
  margin-bottom: 14px;
}

.caminho-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.1fr;
  gap: clamp(40px, 6vw, 90px);
  align-items: stretch;
}
.caminho-book {
  aspect-ratio: 2/3;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--ink) 30%, transparent), color-mix(in srgb, var(--ink) 60%, transparent)),
    linear-gradient(140deg, var(--terracotta) 0%, var(--clay) 60%, #6B3216 100%);
  position: relative;
  overflow: hidden;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 36px 30px;
  color: var(--bg);
  box-shadow: 28px 28px 0 -1px color-mix(in srgb, var(--terracotta) 32%, transparent),
              0 20px 60px -20px rgba(0,0,0,.5);
}
.caminho-book::before {
  content: '';
  position: absolute; inset: 14px;
  border: 1px solid color-mix(in srgb, var(--bg) 25%, transparent);
  pointer-events: none;
}
.caminho-book-top {
  position: relative; z-index: 1;
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  opacity: 0.85;
}
.caminho-book-title {
  position: relative; z-index: 1;
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  line-height: 1;
  letter-spacing: -0.02em;
  font-weight: var(--display-weight);
}
.caminho-book-title em { font-style: italic; }
.caminho-book-title small {
  display: block;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.72em;
  font-weight: 400;
  margin-top: 14px;
  opacity: 0.86;
}
.caminho-book-author {
  position: relative; z-index: 1;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}
.caminho-book-glyph {
  position: absolute;
  right: -50px; bottom: -50px;
  width: 220px; height: 220px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--bg) 18%, transparent);
  border: 1px solid color-mix(in srgb, var(--bg) 22%, transparent);
}
.caminho-book-glyph::after {
  content: '';
  position: absolute; inset: 22%;
  border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--bg) 20%, transparent);
}

.caminho-pilares { display: flex; flex-direction: column; gap: 24px; }
.pilar {
  display: grid;
  grid-template-columns: 78px 1fr;
  gap: 28px;
  padding: 28px 0;
  border-top: 1px solid color-mix(in srgb, var(--bg) 14%, transparent);
  align-items: start;
}
.pilar:last-child { border-bottom: 1px solid color-mix(in srgb, var(--bg) 14%, transparent); }
.pilar-n {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 3.2rem;
  color: var(--terracotta-soft);
  line-height: 0.9;
  letter-spacing: -0.02em;
}
.pilar-nome {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 2.2vw, 2rem);
  font-weight: var(--display-weight);
  letter-spacing: -0.02em;
  line-height: 1.1;
}
.pilar-nome em {
  font-style: italic; color: var(--terracotta-soft);
}
.pilar-sub {
  font-family: var(--font-mono);
  font-size: 0.62rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: color-mix(in srgb, var(--bg) 58%, transparent);
  margin: 6px 0 12px;
}
.pilar-desc {
  font-size: 0.98rem; line-height: 1.55;
  color: color-mix(in srgb, var(--bg) 78%, transparent);
  max-width: 520px;
}
.caminho-foot {
  margin-top: 56px;
  padding-top: 28px;
  border-top: 1px solid color-mix(in srgb, var(--bg) 12%, transparent);
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 24px;
}
.caminho-foot small {
  font-family: var(--font-mono); font-size: 0.62rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: color-mix(in srgb, var(--bg) 55%, transparent);
  max-width: 360px;
  display: block;
}
@media (max-width: 920px) {
  .caminho-grid { grid-template-columns: 1fr; }
  .caminho-head { grid-template-columns: 1fr; }
}

/* ── Humanāre · soluções para empresas ───────────────── */
.humanare-section { padding: var(--section-py) 0; }
.humanare-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
}
.humanare-card {
  background: var(--bg);
  padding: 40px 38px;
  display: flex; flex-direction: column;
  min-height: 280px;
  position: relative;
  transition: background .3s var(--ease);
}
.humanare-card:hover { background: var(--paper); }
.humanare-card .num {
  font-family: var(--font-mono);
  font-size: 0.65rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--terracotta);
  margin-bottom: 24px;
}
.humanare-card h3 {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2vw, 1.9rem);
  font-weight: var(--display-weight);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin-bottom: 16px;
}
.humanare-card h3 em { font-style: italic; color: var(--terracotta); }
.humanare-card p {
  color: var(--ink-soft);
  font-size: 0.98rem;
  line-height: 1.55;
  margin-bottom: 24px;
}
.humanare-card .tag {
  margin-top: auto;
  font-family: var(--font-mono); font-size: 0.6rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-mute);
  display: flex; justify-content: space-between; align-items: center;
}
.humanare-card .tag::after {
  content: '→';
  font-family: var(--font-display);
  font-size: 1.3rem;
  color: var(--terracotta);
  transition: transform .3s var(--ease);
}
.humanare-card:hover .tag::after { transform: translateX(6px); }

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

/* ── Impacto · números reais ─────────────────────────── */
.impacto {
  background: var(--paper);
  padding: 72px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.impacto::after {
  content: '✦';
  position: absolute;
  font-family: var(--font-display);
  font-size: 16rem;
  color: color-mix(in srgb, var(--terracotta) 8%, transparent);
  right: -30px; top: 50%; transform: translateY(-50%);
  line-height: 1;
  pointer-events: none;
}
.impacto-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: auto auto;
  column-gap: 40px;
  row-gap: 48px;
  position: relative;
  z-index: 1;
}
.impacto-lead {
  grid-column: 1 / -1;
  grid-row: 1;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.6rem, 2.4vw, 2.2rem);
  line-height: 1.15;
  letter-spacing: -0.015em;
  color: var(--ink);
  max-width: 880px;
  padding-bottom: 24px;
  border-bottom: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
}
.impacto-lead em { color: var(--terracotta); font-style: italic; }

.impacto-item {
  grid-row: 2;
  display: grid;
  grid-template-rows: minmax(60px, auto) minmax(28px, auto) auto;
  row-gap: 8px;
  align-content: start;
}
.impacto-item .v {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: var(--display-weight);
  font-size: clamp(2.4rem, 4vw, 3.6rem);
  color: var(--terracotta);
  line-height: 1;
  letter-spacing: -0.025em;
  display: block;
  align-self: end;
  font-variant-numeric: tabular-nums;
}
.impacto-item .k {
  font-family: var(--font-mono); font-size: 0.7rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink);
  display: block;
  align-self: start;
}
.impacto-item .d {
  font-size: 0.85rem;
  line-height: 1.45;
  color: var(--ink-soft);
  display: block;
  max-width: 200px;
  align-self: start;
}
@media (max-width: 920px) {
  .impacto-grid { grid-template-columns: 1fr 1fr; row-gap: 32px; }
  .impacto-item { grid-row: auto; }
}
@media (max-width: 540px) {
  .impacto-grid { grid-template-columns: 1fr; }
}

/* ── Curadorias (eventos curados) ────────────────────── */
.curadorias {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
}
.curadoria {
  background: var(--bg);
  padding: 36px 28px;
  display: flex; flex-direction: column; gap: 12px;
  min-height: 240px;
  transition: background .3s var(--ease);
}
.curadoria:hover { background: var(--paper); }
.curadoria .sigla {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: var(--display-weight);
  font-size: 3rem;
  line-height: 0.9;
  letter-spacing: -0.03em;
  color: var(--terracotta);
}
.curadoria .nome {
  font-family: var(--font-display);
  font-size: 1.3rem;
  line-height: 1.15;
  font-weight: var(--display-weight);
  letter-spacing: -0.015em;
}
.curadoria .loc {
  font-family: var(--font-mono); font-size: 0.6rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-mute);
}
.curadoria .desc {
  font-size: 0.92rem;
  color: var(--ink-soft);
  margin-top: auto;
  line-height: 1.5;
}
.curadoria .desde {
  font-family: var(--font-mono); font-size: 0.6rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--terracotta);
  align-self: flex-end;
}
@media (max-width: 920px) {
  .curadorias { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .curadorias { grid-template-columns: 1fr; }
}

/* ── Conheça / Carta — refresh ───────────────────────── */
.conheca {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: start;
}
.conheca-visual {
  position: relative;
  display: flex;
  flex-direction: column;
}
.conheca-photo-frame {
  position: relative;
  aspect-ratio: 3/4.5;
  min-height: 920px;
}
/* Backdrop terracota sólido — fica na ESQUERDA (oposto à linha de contorno
   que vive no canto inferior direito da foto, vinda de .conheca-photo::before). */
.conheca-photo-frame::before {
  content: '';
  position: absolute;
  inset: 18px 18px -18px -18px;
  background: var(--terracotta);
  z-index: -1;
}
.conheca-photo {
  position: relative;
  width: 100%; height: 100%;
  background-size: cover;
  background-position: center top;
  filter: saturate(0.95) contrast(1.02);
}

/* Tarja branca — sobe bem mais pra ficar à altura da linha de contorno
   (.conheca-photo::before fica na bottom-right ~40% acima da base). */
.conheca-stamp {
  position: relative;
  margin-top: -420px;           /* sobe ~420px pra sentar perto da linha de contorno */
  margin-left: -28px;
  width: min(88%, 440px);
  background: var(--bg);
  padding: 32px 32px 30px;
  border-left: 3px solid var(--terracotta);
  box-shadow: 0 22px 48px -20px color-mix(in srgb, var(--ink) 35%, transparent);
  z-index: 2;
  display: flex; flex-direction: column; gap: 20px;
}
.conheca-stamp-head {
  display: flex; flex-direction: column; gap: 2px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.conheca-stamp-head strong {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 2rem;
  color: var(--terracotta);
  font-weight: var(--display-weight);
  line-height: 1;
  letter-spacing: -0.015em;
}
.conheca-stamp-head span {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.conheca-stamp-claim {
  font-family: var(--font-display);
  font-size: clamp(1.7rem, 2.2vw, 2.1rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-weight: var(--display-weight);
  color: var(--ink);
}
.conheca-stamp-claim em {
  font-style: italic;
  color: var(--terracotta);
}
/* Body text in the stamp — standardized to read at the same comfort
   level as the body copy elsewhere on the page. */
.conheca-stamp p {
  font-family: var(--font-body);
  font-size: 1.05rem;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0;
  font-weight: 400;
}
.conheca-stamp p em {
  font-style: italic;
  color: var(--terracotta);
  font-family: var(--font-display);
  font-size: 1.12em;
  font-weight: 500;
}
@media (max-width: 920px) {
  .conheca-stamp {
    position: relative;
    left: 0; bottom: 0;
    width: 100%;
    margin-top: 24px;
  }
  .conheca-photo-frame { min-height: auto; }
}

.conheca-letter {
  font-size: 1.08rem;
  line-height: 1.65;
  color: var(--ink-soft);
}
.conheca-letter p { margin-bottom: 18px; }
.conheca-letter p.pergunta {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.6rem, 2.6vw, 2.4rem);
  line-height: 1.15;
  color: var(--terracotta);
  margin: 20px 0 28px;
  letter-spacing: -0.015em;
}
.conheca-letter .sig {
  margin-top: 28px;
  font-family: var(--font-mono); font-size: 0.65rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-mute);
}
.conheca-letter .sig em {
  font-family: var(--font-display); font-style: italic;
  font-size: 1.4rem; color: var(--terracotta);
  letter-spacing: 0; text-transform: none;
}
@media (max-width: 920px) { .conheca { grid-template-columns: 1fr; } }

/* ── Hoje widget — refresh ───────────────────────────── */
.hoje {
  background: var(--paper);
  padding: 56px clamp(28px, 4vw, 60px);
  border-left: 4px solid var(--terracotta);
  display: grid; grid-template-columns: 1fr 2fr;
  gap: clamp(28px, 5vw, 80px);
  align-items: start;
}
.hoje-head small {
  font-family: var(--font-mono); font-size: 0.6rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-mute);
  display: block; margin-bottom: 12px;
}
.hoje-head span {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 2.4vw, 2.2rem);
  line-height: 1.1; font-weight: var(--display-weight);
  letter-spacing: -0.02em;
}
.hoje-head span em { font-style: italic; color: var(--terracotta); }
.hoje-list { display: flex; flex-direction: column; }
.hoje-row {
  display: grid; grid-template-columns: 140px 1fr;
  gap: 24px;
  padding: 14px 0;
  border-top: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  align-items: baseline;
}
.hoje-row:last-child { border-bottom: 1px solid color-mix(in srgb, var(--ink) 8%, transparent); }
.hoje-row small {
  font-family: var(--font-mono); font-size: 0.62rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-mute);
}
.hoje-row .v {
  font-family: var(--font-display); font-style: italic;
  font-size: 1.15rem; color: var(--ink);
  letter-spacing: -0.01em;
}
@media (max-width: 760px) {
  .hoje { grid-template-columns: 1fr; }
  .hoje-row { grid-template-columns: 1fr; gap: 4px; }
}

/* ── Cinco coisas — sidebar editorial ────────────────── */
.cinco {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  background: var(--line);
  gap: 1px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.cinco-item {
  background: var(--bg);
  padding: 36px 28px;
  display: flex; flex-direction: column; gap: 12px;
  min-height: 260px;
  transition: background .3s var(--ease);
}
.cinco-item:hover { background: var(--paper); }
.cinco-item .n {
  font-family: var(--font-display); font-style: italic;
  font-size: 2.2rem; color: var(--terracotta);
  line-height: 1; font-weight: var(--display-weight);
  letter-spacing: -0.02em;
}
.cinco-item h4 {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: var(--display-weight);
  line-height: 1.2;
  letter-spacing: -0.015em;
}
.cinco-item p {
  font-size: 0.92rem;
  color: var(--ink-soft);
  line-height: 1.55;
  margin-top: auto;
}
@media (max-width: 980px) { .cinco { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .cinco { grid-template-columns: 1fr; } }

/* ── Brand logo / nav — ensure terracotta works ──────── */
.brand-logo-img {
  filter: brightness(0);
  transition: filter .3s var(--ease);
  /* keep ink-colored on cream backgrounds */
}
.nav.scrolled .brand-logo-img {
  filter: brightness(0);
}
[data-mode="dark"] .brand-logo-img { filter: brightness(0) invert(1); }
.footer .brand-logo-img { filter: brightness(0); }

/* ── Intermission with terracotta background variant ─── */
.intermission.terra {
  background: var(--terracotta);
  color: var(--bg);
}
.intermission.terra .intermission-track span::after {
  color: color-mix(in srgb, var(--bg) 50%, transparent);
}

/* ── Newsletter — terracotta accent on dark ──────────── */
.newsletter h2 em { color: var(--lime); }     /* lime = ochre on Humanāre palette */
.newsletter .eyebrow { color: var(--lime); }
.newsletter .eyebrow::before { background: var(--lime); }
.newsletter ::selection { background: var(--lime); color: var(--ink); }

/* ── Values (6) — refresh ────────────────────────────── */
.values {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px; background: var(--line);
  border: 1px solid var(--line);
}
.value {
  background: var(--bg);
  padding: 36px 30px;
  min-height: 240px;
  display: flex; flex-direction: column; gap: 12px;
  transition: background .3s var(--ease);
}
.value:hover { background: var(--paper); }
.value .num {
  font-family: var(--font-mono); font-size: 0.62rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--terracotta);
}
.value h4 {
  font-family: var(--font-display);
  font-size: 1.4rem; font-weight: var(--display-weight);
  letter-spacing: -0.015em; line-height: 1.15;
}
.value h4 em { font-style: italic; color: var(--terracotta); }
.value p {
  font-size: 0.95rem; color: var(--ink-soft);
  line-height: 1.55;
  margin-top: auto;
}
@media (max-width: 920px) { .values { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .values { grid-template-columns: 1fr; } }

/* ── Subtle paper texture (cheap, scoped to bg sections) ── */
.embroidery, .humanare-section, .impacto {
  position: relative;
}
.embroidery::before {
  content: '';
  position: absolute; inset: 0;
  pointer-events: none;
  background-image: repeating-linear-gradient(
    90deg,
    transparent 0 4px,
    color-mix(in srgb, var(--terracotta) 5%, transparent) 4px 5px
  );
  opacity: 0.5;
}

/* ──────────────────────────────────────────────────────────
   Dark section recipe — same dark ink palette as .caminho.
   Adds a glow halo and rewires nested colors for legibility.
   Apply by adding `dark-section` to any section/wrapper.
   ────────────────────────────────────────────────────────── */
.dark-section {
  background: var(--ink);
  color: var(--bg);
  position: relative;
  overflow: hidden;
}
/* Flat ink — sem halo radial — para que dark blocks adjacentes
   (.caminho, .intermission, outras .dark-section) flow sem corte de gradiente. */
.dark-section > * { position: relative; z-index: 1; }

/* Eyebrows on dark — terracotta soft */
.dark-section .eyebrow { color: var(--terracotta-soft); }
.dark-section .eyebrow::before { background: var(--terracotta-soft); }

/* Section header headlines */
.dark-section .sec-head h2 { color: var(--bg); }
.dark-section .sec-head h2 em { color: var(--terracotta-soft); }
.dark-section .sec-head .sub { color: color-mix(in srgb, var(--bg) 75%, transparent); }
.dark-section .link-arrow { color: color-mix(in srgb, var(--bg) 80%, transparent); }
.dark-section .link-arrow:hover { color: var(--terracotta-soft); }

/* Card grids inside dark sections (humanare, curadorias) —
   linhas divisórias SÓLIDAS em cream + hover-cream que inverte o card
   inteiro pra o tom claro do site, com texto dark pra contraste máximo. */
.dark-section .humanare-grid,
.dark-section .curadorias {
  background: var(--bg);                       /* linhas SÓLIDAS bright cream */
  border: 1px solid var(--bg);                 /* moldura também em cream */
  gap: 2px;
}
.dark-section .humanare-card,
.dark-section .curadoria {
  background: var(--ink);
  color: var(--bg);
  position: relative;
  outline: 1px solid color-mix(in srgb, var(--bg) 18%, transparent);
  outline-offset: -1px;
  transition: background .3s var(--ease), color .3s var(--ease), outline-color .3s var(--ease);
}
/* Acento terracota no topo — sólido no estado normal pra reforçar distinção */
.dark-section .humanare-card::before,
.dark-section .curadoria::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: color-mix(in srgb, var(--terracotta) 60%, transparent);
  transition: background .3s var(--ease), height .3s var(--ease);
}
/* HOVER — card vira cream cheio, texto inverte pra dark */
.dark-section .humanare-card:hover,
.dark-section .curadoria:hover {
  background: var(--bg);
  color: var(--ink);
  outline-color: var(--terracotta);
}
.dark-section .humanare-card:hover::before,
.dark-section .curadoria:hover::before {
  background: var(--terracotta);
  height: 5px;
}

/* Cores de texto — animadas para o hover virar contraste alto sobre cream */
.dark-section .humanare-card h3,
.dark-section .curadoria .nome {
  color: var(--bg);
  transition: color .3s var(--ease);
}
.dark-section .humanare-card:hover h3,
.dark-section .curadoria:hover .nome {
  color: var(--ink);
}
.dark-section .humanare-card h3 em,
.dark-section .curadoria .sigla,
.dark-section .curadoria .desde {
  color: var(--terracotta-soft);
  transition: color .3s var(--ease);
}
.dark-section .humanare-card:hover h3 em,
.dark-section .curadoria:hover .sigla,
.dark-section .curadoria:hover .desde {
  color: var(--terracotta);
}
.dark-section .humanare-card p,
.dark-section .curadoria .desc {
  color: color-mix(in srgb, var(--bg) 80%, transparent);
  transition: color .3s var(--ease);
}
.dark-section .humanare-card:hover p,
.dark-section .curadoria:hover .desc {
  color: var(--ink-soft);
}
.dark-section .humanare-card .num,
.dark-section .curadoria .loc {
  color: color-mix(in srgb, var(--bg) 60%, transparent);
  transition: color .3s var(--ease);
}
.dark-section .humanare-card:hover .num,
.dark-section .curadoria:hover .loc {
  color: var(--terracotta);
}
.dark-section .humanare-card .tag {
  color: color-mix(in srgb, var(--bg) 65%, transparent);
  transition: color .3s var(--ease);
}
.dark-section .humanare-card:hover .tag {
  color: var(--ink-mute);
}
.dark-section .humanare-card .tag::after {
  color: var(--terracotta-soft);
  transition: color .3s var(--ease);
}
.dark-section .humanare-card:hover .tag::after {
  color: var(--terracotta);
}

/* Testimonials on dark */
.dark-section .tst-wrap h2 { color: var(--bg); }
.dark-section .tst-wrap h2 em { color: var(--terracotta-soft) !important; }
.dark-section .tst-wrap p { color: color-mix(in srgb, var(--bg) 70%, transparent); }
.dark-section .tst {
  background: color-mix(in srgb, var(--bg) 5%, transparent);
  border-left-color: transparent;
}
.dark-section .tst:hover { border-left-color: var(--terracotta-soft); }
.dark-section .tst .q { color: var(--bg); }
.dark-section .tst .author .av {
  background: color-mix(in srgb, var(--bg) 14%, transparent);
  color: var(--bg);
}
.dark-section .tst .author .info strong { color: var(--bg); }
.dark-section .tst .author .info span {
  color: color-mix(in srgb, var(--bg) 60%, transparent);
}

/* ============================================================
   ─────────────── MOBILE OPTIMIZATION PASS ──────────────────
   Sangrias e blocos ajustados para telas <= 960 / 720 / 480.
   ============================================================ */

/* Tablet e mobile: sangrias e tipografia base mais compactas */
@media (max-width: 960px) {
  :root {
    --section-py: clamp(56px, 8vw, 96px);
    --gutter: clamp(20px, 5vw, 36px);
  }
}
@media (max-width: 600px) {
  :root {
    --section-py: 56px;
    --gutter: 18px;
  }
}

/* ── Nav mobile ──────────────────────────────────────────── */
@media (max-width: 860px) {
  .nav { padding-top: 16px; padding-bottom: 16px; }
  .nav-brand img { width: 140px !important; height: auto !important; }
  .nav.scrolled { padding-top: 12px; padding-bottom: 12px; }
}

/* ── Hero (Signature) — stack vertical, foto reduzida ────── */
@media (max-width: 960px) {
  .hero-sig {
    grid-template-columns: 1fr;
    gap: 40px;
    padding-top: 110px;
    padding-bottom: 56px;
    min-height: auto;
    align-items: start;
  }
  .hero-sig-text { max-width: 100%; gap: 22px; }
  .hero-sig h1 { font-size: clamp(2rem, 7.4vw, 3.2rem); min-height: 0; }
  .hero-sig-letter { font-size: 1rem; line-height: 1.6; max-width: 100%; }
  .hero-sig-corner { flex-wrap: wrap; row-gap: 6px; }
  .hero-sig-actions .btn { flex: 1; justify-content: center; }
  .hero-sig-photo-wrap { gap: 28px; margin-top: 0; }
  .hero-sig-photo-arch { aspect-ratio: 4/5; max-height: 480px; }
  .hero-sig-circle { inset: -18px -18px 12% 6%; }
  .hero-sig-bio {
    position: relative;
    bottom: auto; left: 0; right: 0;
    max-width: 100%;
    margin: -28px auto 0;
    width: calc(100% - 32px);
    font-size: 0.98rem;
  }
}
@media (max-width: 560px) {
  .hero-sig-ticker {
    grid-template-columns: 1fr;
    font-size: 0.72rem;
    row-gap: 14px;
  }
  .hero-sig h1 { font-size: clamp(1.9rem, 8vw, 2.6rem); }
}

/* ── ConhecaAdriana — stack vertical + stamp in-flow ────── */
@media (max-width: 920px) {
  .conheca { grid-template-columns: 1fr; gap: 32px; }
  .conheca-photo-frame {
    min-height: 0;
    aspect-ratio: 3/4;
    max-height: 560px;
  }
  .conheca-photo-frame::before { inset: 12px -12px -12px 12px; }
  .conheca-stamp {
    margin-top: -64px;
    margin-left: 0;
    width: calc(100% - 24px);
    margin-inline: auto;
    padding: 24px 22px;
    gap: 16px;
  }
  .conheca-stamp-head strong { font-size: 1.6rem; }
  .conheca-stamp-claim { font-size: clamp(1.35rem, 5vw, 1.7rem); }
  .conheca-stamp p { font-size: 0.96rem; }
  .conheca-letter { font-size: 1.05rem; }
  .conheca-letter .pergunta { font-size: clamp(1.4rem, 5.5vw, 1.8rem); }
}

/* ── Caminho do Protagonista — stack vertical ────────────── */
@media (max-width: 920px) {
  .caminho-head { grid-template-columns: 1fr; gap: 18px; margin-bottom: 40px; }
  .caminho-head h2 { font-size: clamp(2rem, 7vw, 3rem); }
  .caminho-grid { grid-template-columns: 1fr; gap: 36px; }
  .caminho-book {
    max-width: 320px;
    margin: 0 auto;
    padding: 28px 24px;
  }
  .pilar { grid-template-columns: 56px 1fr; gap: 18px; padding: 22px 0; }
  .pilar-n { font-size: 2.4rem; }
  .pilar-nome { font-size: 1.4rem; }
  .caminho-foot { gap: 16px; }
}

/* ── Section header padrão ───────────────────────────────── */
@media (max-width: 760px) {
  .sec-head {
    grid-template-columns: 1fr;
    gap: 14px;
    margin-bottom: 36px;
  }
  .sec-head h2 { font-size: clamp(1.9rem, 7vw, 2.6rem); }
  .sec-head .sub { font-size: 0.96rem; max-width: 100%; }
}

/* ── Palestras (3 Territórios) — stack ───────────────────── */
@media (max-width: 760px) {
  .palestras-grid { grid-template-columns: 1fr !important; }
  .palestra { padding: 28px 24px; min-height: 260px; }
  .palestra h3 { font-size: clamp(1.4rem, 5vw, 1.7rem); }
}

/* ── Humanāre Soluções (dark) — stack ────────────────────── */
@media (max-width: 760px) {
  .humanare-grid { grid-template-columns: 1fr; }
  .humanare-card { padding: 28px 24px; min-height: 220px; }
}

/* ── Impacto — stack vertical ────────────────────────────── */
@media (max-width: 760px) {
  .impacto { padding: 48px 0; }
  .impacto-grid {
    grid-template-columns: 1fr 1fr;
    column-gap: 24px;
    row-gap: 30px;
  }
  .impacto-lead {
    grid-column: 1 / -1;
    font-size: clamp(1.3rem, 5.5vw, 1.7rem);
    padding-bottom: 18px;
    margin-bottom: 6px;
  }
  .impacto-item .v { font-size: clamp(1.9rem, 8vw, 2.4rem); }
  .impacto-item .d { font-size: 0.78rem; }
}

/* ── Curadorias — 2-col tablet, 1-col mobile ────────────── */
@media (max-width: 760px) {
  .curadorias { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .curadorias { grid-template-columns: 1fr; }
  .curadoria { padding: 28px 22px; min-height: 200px; }
}

/* ── Manifesto strip ─────────────────────────────────────── */
@media (max-width: 760px) {
  .manifesto-strip blockquote {
    font-size: clamp(1.6rem, 7vw, 2.4rem);
    line-height: 1.15;
  }
}

/* ── Depoimentos (dark) — stack ──────────────────────────── */
@media (max-width: 820px) {
  .tst-wrap { grid-template-columns: 1fr; gap: 28px; }
  .tst { padding: 28px 24px 22px; }
  .tst .q { font-size: 1.1rem; }
}

/* ── HOJE widget — stack ─────────────────────────────────── */
@media (max-width: 760px) {
  .hoje {
    grid-template-columns: 1fr;
    padding: 32px 24px;
    gap: 22px;
  }
  .hoje-row {
    grid-template-columns: 1fr;
    gap: 4px;
    padding: 12px 0;
  }
}

/* ── Cinco coisas ────────────────────────────────────────── */
@media (max-width: 760px) {
  .cinco { grid-template-columns: 1fr 1fr; }
  .cinco-item { padding: 26px 22px; min-height: 220px; }
}
@media (max-width: 480px) {
  .cinco { grid-template-columns: 1fr; }
  .cinco-item { min-height: 180px; padding: 24px 22px; }
}

/* ── Eventos ─────────────────────────────────────────────── */
@media (max-width: 720px) {
  .evt {
    grid-template-columns: 64px 1fr 32px;
    gap: 14px;
    padding: 20px 0;
  }
  .evt .date { font-size: 1.4rem; }
  .evt .date small { font-size: 0.55rem; }
  .evt h4 { font-size: 1.1rem; }
  .evt .loc { display: none; }
}

/* ── Newsletter ──────────────────────────────────────────── */
@media (max-width: 820px) {
  .newsletter-grid { grid-template-columns: 1fr; gap: 28px; }
  .newsletter h2 { font-size: clamp(1.9rem, 7vw, 2.6rem); }
}
@media (max-width: 540px) {
  .subscribe-form {
    flex-direction: column;
    border-radius: 16px;
    padding: 14px;
    align-items: stretch;
  }
  .subscribe-form input { padding: 10px 6px; }
  .subscribe-form button { width: 100%; margin-top: 8px; }
  .newsletter .stats-mini { grid-template-columns: 1fr; gap: 12px; }
  .newsletter .stats-mini > div { padding: 18px 20px; }
  .newsletter .stats-mini strong { font-size: 1.7rem; }
}

/* ── Intermission — fonte um pouco menor em mobile ───────── */
@media (max-width: 600px) {
  .intermission-track { font-size: clamp(1.3rem, 6vw, 1.9rem); gap: 32px; }
  .intermission { padding: 22px 0; }
}

/* ── Marquee de empresas ─────────────────────────────────── */
@media (max-width: 600px) {
  .marquee-item { font-size: 1rem; gap: 36px; }
  .marquee-track { gap: 36px; }
  .marquee { padding: 20px 0; }
}

/* ── Footer ──────────────────────────────────────────────── */
@media (max-width: 820px) {
  .footer { padding: 64px 0 32px; }
  .footer-top {
    grid-template-columns: 1fr;
    gap: 32px;
    padding-bottom: 48px;
  }
  .footer-brand p { max-width: 100%; }
}
@media (max-width: 600px) {
  .footer-bottom {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 14px;
  }
  .footer-bottom .fb-left,
  .footer-bottom .fb-right,
  .footer-bottom .fb-center {
    justify-self: center;
    text-align: center;
  }
}

/* ── Page heros (Sobre, Palestras, etc) ──────────────────── */
@media (max-width: 820px) {
  .page-hero {
    grid-template-columns: 1fr;
    padding-top: 110px;
    gap: 24px;
  }
  .page-hero .ttl { font-size: clamp(2.2rem, 8vw, 3.4rem); }
  .page-hero .intro p { font-size: 1rem; }
}

/* ── Contato form ────────────────────────────────────────── */
@media (max-width: 820px) {
  .contato { grid-template-columns: 1fr; gap: 32px; }
  .form-row { grid-template-columns: 1fr; gap: 14px; }
}

/* ── Trajetória timeline ─────────────────────────────────── */
@media (max-width: 720px) {
  .timeline .tl-item {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 24px 0;
  }
}

/* ── Valores (Sobre) ─────────────────────────────────────── */
@media (max-width: 720px) {
  .values { grid-template-columns: 1fr !important; }
  .value { min-height: 180px; padding: 28px 22px; }
}

/* ── Mídia (Conteúdo) ────────────────────────────────────── */
@media (max-width: 760px) {
  .media-grid { grid-template-columns: 1fr 1fr; gap: 18px; }
}
@media (max-width: 480px) {
  .media-grid { grid-template-columns: 1fr; }
}

/* ── Buttons mais confortáveis em mobile ─────────────────── */
@media (max-width: 600px) {
  .btn { padding: 14px 22px; font-size: 0.7rem; }
}

/* ── Evitar overflow horizontal global ───────────────────── */
@media (max-width: 960px) {
  html, body { overflow-x: hidden; }
  .embroidery-divider { margin: 0; }
}
