/* ==========================================================================
   Dra. Camila Reis — Saúde mental perinatal & quarto trimestre
   Direção: "Diário Íntimo" — quarto trimestre dessaturado com âncora de
   saturação (terracota-poente) + respiração somática.
   Assinatura: o diferencial vem do TRATAMENTO — coluna estreita + line-height
   de caderno — não da fonte. Paleta que NÃO desmaia em cinza-lama.
   No Mapa by Cajueiro.tech
   ========================================================================== */

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

:root {
  /* --- Paleta dessaturada terapêutica (ficha exata) --- */
  --primary: #9A93A8;          /* lavanda acinzentada */
  --secondary: #9FA89A;        /* verde-névoa de apoio */
  --accent: #C56A4E;           /* terracota-poente queimado — ÚNICO âncora de saturação */
  --bg: #EDE8E4;               /* bruma de fundo */
  --text: #4A4540;             /* tinta suave — passa AA sobre a bruma */

  /* --- Variações derivadas (mesma família, p/ contraste/textura) --- */
  --primary-deep: #6F6880;     /* lavanda mais funda p/ títulos grandes */
  --secondary-deep: #6E7869;   /* verde-névoa mais fundo */
  --accent-deep: #A9542F;      /* terracota hover (AA em links pequenos) */
  --blush: #D8C5C2;            /* blush poeira — fios, fundos, nunca corpo */
  --bg-deep: #E4DDD7;          /* página de diário levemente mais escura */
  --bg-cartao: #F3EFEB;        /* cartão/papel que respira sobre a bruma */
  --text-suave: #6B645D;       /* secundário, ainda legível */
  --text-tenue: #8C857D;       /* legendas, metadados, labels */
  --linha: #D6CCC4;            /* fios quase imperceptíveis */
  --whatsapp: #7E7A56;         /* não-verde-gritante: oliva dessaturado coerente */

  /* --- Tipografia (ficha) --- */
  --serif: 'Lora', Georgia, 'Times New Roman', serif;
  --sans: 'Karla', system-ui, -apple-system, sans-serif;

  /* --- Medida estreita (caderno) — o diferencial é o tratamento --- */
  --medida: 34rem;             /* coluna de diário, propositalmente estreita */
  --medida-larga: 58rem;       /* títulos/imagens podem respirar um pouco mais */

  /* --- Espaçamento fluido, generoso (ritmo desacelerado) --- */
  --s-2xs: clamp(0.5rem, 0.4rem + 0.4vw, 0.7rem);
  --s-xs:  clamp(0.85rem, 0.7rem + 0.7vw, 1.2rem);
  --s-sm:  clamp(1.2rem, 1rem + 1vw, 1.8rem);
  --s-md:  clamp(2rem, 1.5rem + 2.2vw, 3rem);
  --s-lg:  clamp(3.5rem, 2.6rem + 4vw, 6rem);
  --s-xl:  clamp(6rem, 4rem + 8vw, 10rem);
  --s-2xl: clamp(8rem, 5rem + 12vw, 15rem);   /* respiro enorme entre tempos */

  /* line-height de CADERNO — generoso de propósito */
  --lh-caderno: 2;
  --lh-titulo: 1.12;

  /* ease longo, respiração */
  --ease-resp: cubic-bezier(0.33, 0, 0.16, 1);

  --grain-op: 0.05;
}

/* ---------- Base ---------- */
html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--sans);
  font-weight: 400;
  font-size: clamp(1.02rem, 0.98rem + 0.25vw, 1.18rem);
  line-height: var(--lh-caderno);
  color: var(--text);
  background-color: var(--bg);
  background-image:
    radial-gradient(120% 80% at 80% -10%, rgba(154, 147, 168, 0.10), transparent 60%),
    radial-gradient(100% 70% at 0% 110%, rgba(159, 168, 154, 0.10), transparent 55%);
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img { display: block; max-width: 100%; height: auto; }

::selection { background: rgba(197, 106, 78, 0.22); color: var(--text); }

:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 2px;
}

/* ---------- Grão / textura do diário ---------- */
.grain {
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: var(--grain-op);
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

main { position: relative; z-index: 2; }

/* =========================================================================
   RESPIRAÇÃO SOMÁTICA — 4s inspira / 6s expira (10s total).
   Aplicada a elementos-âncora. Sincroniza o corpo de quem lê.
   ========================================================================= */
@keyframes respira {
  0%   { transform: scale(1);     opacity: 0.78; }   /* fim da expiração */
  40%  { transform: scale(1.045); opacity: 1; }      /* topo da inspiração (4s) */
  100% { transform: scale(1);     opacity: 0.78; }   /* expira de volta (6s) */
}
.breathe {
  animation: respira 10s var(--ease-resp) infinite;
  transform-origin: center;
  will-change: transform, opacity;
}
/* Quando .breathe e .reveal coexistem (ex.: linha-âncora do hero), o keyframe
   de opacidade engoliria o fade-in do reveal. Só liberamos a respiração depois
   que o reveal terminou de aparecer (.visible), preservando a entrada gentil. */
.breathe.reveal:not(.visible) { animation: none; }
/* respiração no ESPAÇAMENTO (letter-spacing) — uma variante somática */
@keyframes respira-spacing {
  0%   { letter-spacing: 0.01em; opacity: 0.82; }
  40%  { letter-spacing: 0.06em; opacity: 1; }
  100% { letter-spacing: 0.01em; opacity: 0.82; }
}
.breathe-spacing {
  display: inline-block;
  animation: respira-spacing 10s var(--ease-resp) infinite;
  will-change: letter-spacing, opacity;
}

/* =========================================================================
   NAV — minimalista. Um diário não precisa de menu de clínica.
   ========================================================================= */
.diary-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-sm);
  padding: var(--s-xs) clamp(1.1rem, 4vw, 3rem);
  background: linear-gradient(to bottom, rgba(237, 232, 228, 0.92), rgba(237, 232, 228, 0));
  backdrop-filter: blur(2px);
}
.diary-nav__name {
  font-family: var(--serif);
  font-size: clamp(1rem, 0.95rem + 0.3vw, 1.15rem);
  font-weight: 500;
  color: var(--primary-deep);
  text-decoration: none;
  letter-spacing: 0.01em;
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
}
.diary-nav__breath {
  width: 0.5em; height: 0.5em;
  border-radius: 50%;
  background: var(--accent);
  animation: respira 10s var(--ease-resp) infinite;
  flex: none;
}
.diary-nav__meta {
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-tenue);
}
@media (max-width: 600px) {
  .diary-nav__meta { display: none; }
}

/* =========================================================================
   1. ABERTURA — "Como você está?"
   ========================================================================= */
.abertura {
  min-height: 100svh;
  display: grid;
  align-content: center;
  padding: clamp(6rem, 14vh, 9rem) clamp(1.4rem, 6vw, 4rem) var(--s-xl);
  max-width: 78rem;
  margin: 0 auto;
  position: relative;
}
.abertura__data {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--text-suave);
  margin-bottom: var(--s-sm);
  letter-spacing: 0.01em;
}
.abertura__titulo {
  font-family: var(--serif);
  font-weight: 500;
  line-height: var(--lh-titulo);
  letter-spacing: -0.015em;
  color: var(--primary-deep);
  margin-bottom: var(--s-md);
}
.abertura__titulo .line {
  display: block;
  font-size: clamp(2.4rem, 1.4rem + 6.2vw, 5.6rem);
}
.line--whisper {
  font-style: italic;
  font-weight: 400;
  color: var(--text-suave);
  font-size: clamp(1.7rem, 1.1rem + 3.2vw, 3.2rem) !important;
  margin-top: 0.3em;
}
.line--accent {
  color: var(--accent);          /* o âncora de saturação no momento de cuidado */
  font-style: italic;
  font-weight: 500;
  margin-top: 0.1em;
}
.abertura__corpo {
  font-family: var(--sans);
  max-width: var(--medida);
  color: var(--text);
  margin-bottom: var(--s-md);
  font-size: clamp(1.05rem, 1rem + 0.3vw, 1.22rem);
}
.abertura__seguir {
  display: inline-flex;
  align-items: center;
  gap: 0.7em;
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--text-suave);
  text-decoration: none;
  width: max-content;
  padding: 0.5rem 0;
  min-height: 44px;
}
.abertura__seguir svg {
  width: 0.85em; height: 1.4em;
  color: var(--accent);
  animation: descer-suave 3.2s var(--ease-resp) infinite;
}
@keyframes descer-suave {
  0%, 100% { transform: translateY(0); opacity: 0.55; }
  50%      { transform: translateY(5px); opacity: 1; }
}
.abertura__foto {
  margin-top: var(--s-lg);
  /* imagens são retrato 2:3 — largura mais contida para um enquadramento
     editorial elegante, sem corte e sem ocupar a tela inteira */
  max-width: 40rem;
  margin-inline: auto;
  position: relative;
}
.abertura__foto img {
  width: 100%;
  display: block;
  border-radius: 2px;
  filter: saturate(0.72) contrast(0.96);
  box-shadow: 0 30px 70px -40px rgba(74, 69, 64, 0.5);
}
/* wrapper que contém o overlay apenas sobre a imagem, nunca sobre a legenda */
.ph-media {
  display: block;
  position: relative;
  line-height: 0;
}
.abertura__foto .ph-media::after {  /* overlay bruma/blush para amarrar à grade cromática */
  content: "";
  position: absolute; inset: 0;
  border-radius: 2px;
  background: linear-gradient(160deg, rgba(154, 147, 168, 0.22), rgba(216, 197, 194, 0.20));
  mix-blend-mode: multiply;
  pointer-events: none;
}
.abertura__legenda,
.quarto__foto figcaption {
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.92rem;
  color: var(--text-tenue);
  margin-top: var(--s-xs);
  line-height: 1.5;
}

/* ---------- Índice dos quatro tempos ---------- */
.tempos-indice {
  max-width: 78rem;
  margin: 0 auto;
  padding: 0 clamp(1.4rem, 6vw, 4rem) var(--s-xl);
}
.tempos-indice ol {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--s-sm);
  border-top: 1px solid var(--linha);
  border-bottom: 1px solid var(--linha);
  padding: var(--s-md) 0;
}
.tempos-indice a {
  font-family: var(--serif);
  font-size: clamp(1.1rem, 1rem + 0.5vw, 1.4rem);
  color: var(--text);
  text-decoration: none;
  display: flex;
  align-items: baseline;
  gap: 0.5em;
  min-height: 44px;
  transition: color 0.6s var(--ease-resp), letter-spacing 0.6s var(--ease-resp);
}
.tempos-indice a span {
  font-style: italic;
  font-size: 0.85em;
  color: var(--accent);
  opacity: 0.8;
}
.tempos-indice a:hover {
  color: var(--accent-deep);
  letter-spacing: 0.02em;
}

/* =========================================================================
   2–4. TEMPOS (gestação, reta final, parto) — páginas de diário
   ========================================================================= */
.tempo {
  padding: var(--s-2xl) clamp(1.4rem, 6vw, 4rem);
}
.tempo__pagina {
  max-width: var(--medida-larga);
  margin: 0 auto;
}
.tempo__cabecalho {
  position: relative;
  margin-bottom: var(--s-lg);
}
.tempo__numero {
  position: absolute;
  top: -0.35em; left: -0.1em;
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(6rem, 4rem + 14vw, 13rem);
  line-height: 1;
  color: var(--blush);
  opacity: 0.5;
  z-index: -1;
  user-select: none;
  pointer-events: none;
}
.tempo__numero--accent { color: var(--accent); opacity: 0.32; }
.tempo__rotulo,
.quarto__rotulo,
.autoteste__rotulo {
  font-family: var(--sans);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-tenue);
  margin-bottom: var(--s-2xs);
}
.tempo__titulo {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(2.6rem, 1.8rem + 5vw, 5rem);
  line-height: var(--lh-titulo);
  letter-spacing: -0.02em;
  color: var(--primary-deep);
}

/* corpo do diário — coluna estreita, line-height de caderno */
.tempo__diario { max-width: var(--medida); }
.tempo__abre {
  font-family: var(--serif);
  font-size: clamp(1.3rem, 1.1rem + 1vw, 1.7rem);
  font-style: italic;
  font-weight: 400;
  line-height: 1.55;
  color: var(--primary-deep);
  margin-bottom: var(--s-md);
}
.tempo__corpo {
  margin-bottom: var(--s-md);
  color: var(--text);
}
.tempo__corpo strong { color: var(--accent-deep); font-weight: 600; }

/* "tempos vividos" no lugar de serviços */
.tempo__sentires {
  list-style: none;
  margin-top: var(--s-md);
  display: grid;
  gap: var(--s-md);
}
.tempo__sentires li {
  padding-left: var(--s-sm);
  border-left: 2px solid var(--blush);
}
.tempo__sentires em {
  display: block;
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.18rem;
  color: var(--accent-deep);
  line-height: 1.4;
  margin-bottom: var(--s-2xs);
}
.tempo__sentires span {
  display: block;
  font-size: 0.98rem;
  line-height: 1.85;
  color: var(--text-suave);
}

/* foto solta dentro de um tempo */
.tempo__foto--solta {
  max-width: 26rem;
  margin: 0 0 var(--s-lg) auto;
  position: relative;
}
.tempo__foto--solta img {
  width: 100%;
  display: block;
  border-radius: 2px;
  filter: saturate(0.7) contrast(0.95);
  box-shadow: 0 26px 60px -42px rgba(74, 69, 64, 0.5);
}
.tempo__foto--solta::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(150deg, rgba(159, 168, 154, 0.22), rgba(216, 197, 194, 0.18));
  mix-blend-mode: multiply;
  pointer-events: none;
}

/* sussurro — Lora italic, frase em 1ª pessoa */
.sussurro {
  margin: var(--s-lg) 0;
  padding-left: var(--s-md);
  border-left: 2px solid var(--accent);
}
.sussurro p {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(1.4rem, 1.1rem + 1.4vw, 2rem);
  line-height: 1.5;
  color: var(--primary-deep);
}
.sussurro--centro {
  border-left: none;
  padding: var(--s-md) 0;
  text-align: center;
  border-top: 1px solid var(--linha);
  border-bottom: 1px solid var(--linha);
  max-width: var(--medida);
  margin-inline: auto;
}
.sussurro--centro p { color: var(--accent-deep); }

/* nuances por tempo (sutilíssimas — alternância de papel) */
.tempo--reta { background:
  linear-gradient(180deg, transparent, rgba(228, 221, 215, 0.5) 12%, rgba(228, 221, 215, 0.5) 88%, transparent); }

/* =========================================================================
   5. QUARTO TRIMESTRE — coração do site. O âncora narrativo.
   ========================================================================= */
.quarto {
  padding: var(--s-2xl) clamp(1.4rem, 6vw, 4rem);
  background:
    radial-gradient(140% 90% at 50% 0%, rgba(197, 106, 78, 0.07), transparent 55%),
    var(--bg-deep);
  position: relative;
}
.quarto__pagina {
  max-width: var(--medida-larga);
  margin: 0 auto;
}
.quarto__cabecalho {
  position: relative;
  margin-bottom: var(--s-lg);
  text-align: center;
}
.quarto__cabecalho .tempo__numero {
  left: 50%; transform: translateX(-50%);
}
.quarto__titulo {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(2.8rem, 1.9rem + 5.5vw, 5.6rem);
  line-height: var(--lh-titulo);
  letter-spacing: -0.02em;
  color: var(--accent);      /* o coração recebe o âncora de saturação */
}
.quarto__manifesto {
  font-family: var(--serif);
  font-size: clamp(1.5rem, 1.2rem + 1.6vw, 2.3rem);
  line-height: 1.5;
  text-align: center;
  max-width: 40rem;
  margin: 0 auto var(--s-lg);
  color: var(--primary-deep);
}
.quarto__giro {
  display: block;
  margin-top: 0.5em;
  font-style: italic;
  color: var(--accent-deep);
}
.quarto__foto {
  /* retrato 2:3 — largura contida para enquadramento editorial sem corte */
  max-width: 40rem;
  margin: 0 auto var(--s-lg);
  position: relative;
}
.quarto__foto img {
  width: 100%;
  display: block;
  border-radius: 2px;
  filter: saturate(0.74) contrast(0.96);
  box-shadow: 0 34px 80px -46px rgba(74, 69, 64, 0.55);
}
.quarto__foto .ph-media::after {
  content: "";
  position: absolute; inset: 0;
  border-radius: 2px;
  background: linear-gradient(160deg, rgba(197, 106, 78, 0.14), rgba(154, 147, 168, 0.18));
  mix-blend-mode: multiply;
  pointer-events: none;
}
.quarto__foto figcaption { text-align: center; }

.quarto__desarma {
  max-width: var(--medida);
  margin: 0 auto;
}
.quarto__intro {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.3rem;
  color: var(--accent-deep);
  margin-bottom: var(--s-md);
}
.culpas {
  list-style: none;
  display: grid;
  gap: var(--s-sm);
}
.culpa {
  padding: var(--s-sm) 0;
  border-bottom: 1px solid var(--linha);
  line-height: 1.55;
}
.culpa:last-child { border-bottom: none; }
.culpa__nao {
  display: inline;
  font-family: var(--serif);
  font-weight: 600;
  font-size: 1.2rem;
  color: var(--primary-deep);
}
.culpa__sim {
  display: inline;
  font-size: 1.1rem;
  color: var(--text);
}
.quarto__fico {
  max-width: var(--medida);
  margin: var(--s-lg) auto 0;
  padding-top: var(--s-md);
  border-top: 2px solid var(--accent);
}
.quarto__fico p { color: var(--text); }

/* =========================================================================
   6. AUTOTESTE GENTIL — flow LINEAR, uma pergunta por tela
   ========================================================================= */
.autoteste {
  padding: var(--s-2xl) clamp(1.4rem, 6vw, 4rem);
}
.autoteste__cabecalho {
  max-width: var(--medida);
  margin: 0 auto var(--s-lg);
  text-align: center;
}
.autoteste__titulo {
  font-family: var(--serif);
  font-weight: 500;
  font-style: italic;
  font-size: clamp(2rem, 1.4rem + 3vw, 3.4rem);
  line-height: 1.2;
  color: var(--primary-deep);
  margin-bottom: var(--s-sm);
}
.autoteste__sub {
  color: var(--text-suave);
  font-size: 1.02rem;
  line-height: 1.85;
}

.quiz {
  max-width: 40rem;
  margin: 0 auto;
  background: var(--bg-cartao);
  border: 1px solid var(--linha);
  border-radius: 4px;
  padding: clamp(1.6rem, 4vw, 3rem);
  box-shadow: 0 30px 70px -50px rgba(74, 69, 64, 0.4);
  position: relative;
  overflow: hidden;
}
.quiz__progresso {
  height: 2px;
  background: var(--linha);
  border-radius: 2px;
  margin-bottom: var(--s-lg);
  overflow: hidden;
}
.quiz__progresso-fill {
  display: block;
  height: 100%;
  width: 0%;
  background: var(--accent);
  border-radius: 2px;
  transition: width 0.9s var(--ease-resp);
}

.quiz__flow { position: relative; min-height: 18rem; display: grid; }
.quiz__tela {
  border: none;
  grid-area: 1 / 1;          /* todas empilhadas no mesmo lugar */
  display: none;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.7s var(--ease-resp), transform 0.7s var(--ease-resp);
  align-content: center;
}
.quiz__tela.is-active { display: grid; }
.quiz__tela.is-shown { opacity: 1; transform: translateY(0); }

.quiz__convite,
.quiz__pergunta {
  font-family: var(--serif);
  font-size: clamp(1.3rem, 1.1rem + 1vw, 1.75rem);
  line-height: 1.5;
  color: var(--primary-deep);
  text-align: center;
  margin-bottom: var(--s-md);
}
.quiz__pergunta { font-style: normal; }
.quiz__convite { font-style: italic; }

.quiz__opcoes {
  display: grid;
  gap: var(--s-xs);
}
.quiz__opcao {
  font-family: var(--sans);
  font-size: 1.02rem;
  color: var(--text);
  background: var(--bg);
  border: 1px solid var(--linha);
  border-radius: 3px;
  padding: 0.95rem 1.2rem;
  min-height: 48px;
  text-align: left;
  cursor: pointer;
  transition: border-color 0.5s var(--ease-resp), background 0.5s var(--ease-resp),
              transform 0.5s var(--ease-resp), color 0.5s var(--ease-resp);
}
.quiz__opcao:hover {
  border-color: var(--accent);
  background: var(--bg-cartao);
  transform: translateY(-1px);
  color: var(--accent-deep);
}
.quiz__opcao.is-picked {
  border-color: var(--accent);
  background: rgba(197, 106, 78, 0.07);
  color: var(--accent-deep);
}

.quiz__btn {
  font-family: var(--sans);
  font-size: 1rem;
  letter-spacing: 0.02em;
  background: none;
  border: 1px solid var(--accent);
  color: var(--accent-deep);
  border-radius: 999px;
  padding: 0.85rem 2rem;
  min-height: 48px;
  cursor: pointer;
  margin: 0 auto;
  display: block;
  transition: background 0.5s var(--ease-resp), color 0.5s var(--ease-resp);
}
.quiz__btn:hover { background: var(--accent); color: var(--bg-cartao); }

/* desfecho */
.quiz__fim { text-align: center; }
.quiz__fim-eyebrow {
  font-family: var(--sans);
  font-size: 0.74rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-tenue);
  margin-bottom: var(--s-sm);
}
.quiz__fim-texto {
  font-family: var(--serif);
  font-size: 1.15rem;
  font-style: italic;
  line-height: 1.7;
  color: var(--primary-deep);
  margin-bottom: var(--s-md);
}
.quiz__fim-link {
  display: inline-block;
  font-family: var(--sans);
  font-size: 1.02rem;
  color: var(--bg-cartao);
  background: var(--accent);
  text-decoration: none;
  border-radius: 999px;
  padding: 0.9rem 1.8rem;
  min-height: 48px;
  transition: background 0.5s var(--ease-resp), transform 0.5s var(--ease-resp);
}
.quiz__fim-link:hover { background: var(--accent-deep); transform: translateY(-2px); }
.quiz__reiniciar {
  display: block;
  margin: var(--s-md) auto 0;
  background: none;
  border: none;
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.95rem;
  color: var(--text-tenue);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 3px;
  min-height: 44px;
}
.quiz__reiniciar:hover { color: var(--accent-deep); }

/* =========================================================================
   7. ÚLTIMA PÁGINA DO DIÁRIO — carta manuscrita. Contato = nota de rodapé.
   ========================================================================= */
.ultima-pagina {
  padding: var(--s-2xl) clamp(1.4rem, 6vw, 4rem) var(--s-xl);
  background:
    radial-gradient(120% 80% at 50% 100%, rgba(197, 106, 78, 0.05), transparent 60%),
    var(--bg);
}
.ultima-pagina__data {
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.95rem;
  color: var(--text-tenue);
  text-align: center;
  margin-bottom: var(--s-lg);
  letter-spacing: 0.02em;
}
.carta {
  max-width: var(--medida);
  margin: 0 auto;
  padding: var(--s-lg) clamp(1.2rem, 4vw, 2.4rem);
  background: var(--bg-cartao);
  border: 1px solid var(--linha);
  /* papel de carta: fios horizontais sutis de caderno */
  background-image: repeating-linear-gradient(
    to bottom,
    transparent,
    transparent calc(var(--lh-caderno) * 1em - 1px),
    rgba(214, 204, 196, 0.5) calc(var(--lh-caderno) * 1em)
  );
  background-position: 0 0.4em;
  box-shadow: 0 40px 90px -55px rgba(74, 69, 64, 0.5);
  position: relative;
}
.carta__abertura {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(1.8rem, 1.4rem + 2vw, 2.6rem);
  color: var(--primary-deep);
  margin-bottom: var(--s-sm);
}
.carta__paragrafo {
  font-family: var(--serif);
  font-size: clamp(1.08rem, 1rem + 0.4vw, 1.28rem);
  line-height: var(--lh-caderno);
  color: var(--text);
  margin-bottom: var(--s-sm);
}
.carta__paragrafo strong { color: var(--accent-deep); font-weight: 600; }
.carta__pergunta {
  display: inline-block;
  font-style: italic;
  font-weight: 500;
  color: var(--accent);
}
.carta__fecho {
  margin-top: var(--s-md);
  color: var(--primary-deep);
}
.carta__assinatura {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(2rem, 1.5rem + 2.5vw, 3rem);
  color: var(--accent);
  margin-top: var(--s-md);
  letter-spacing: 0.01em;
  /* leve inclinação manuscrita */
  transform: rotate(-2deg);
  transform-origin: left center;
}

/* contato como NOTA suave de rodapé — não botão gritante */
.nota-rodape {
  max-width: var(--medida);
  margin: var(--s-lg) auto 0;
  text-align: center;
}
.nota-rodape__texto {
  font-size: 1rem;
  color: var(--text-suave);
  line-height: 1.85;
  margin-bottom: var(--s-sm);
  max-width: 30rem;
  margin-inline: auto;
}
.nota-rodape__contato {
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.15rem;
  color: var(--accent-deep);
  text-decoration: none;
  border-bottom: 1px solid var(--blush);
  padding: 0.4rem 0.2rem;
  min-height: 44px;
  transition: border-color 0.5s var(--ease-resp), color 0.5s var(--ease-resp);
}
.nota-rodape__contato:hover {
  color: var(--accent);
  border-color: var(--accent);
}
.nota-rodape__dot {
  width: 0.55em; height: 0.55em;
  border-radius: 50%;
  background: var(--accent);
  flex: none;
}
.nota-rodape__detalhe {
  font-family: var(--sans);
  font-size: 0.85rem;
  line-height: 1.7;
  color: var(--text-tenue);
  margin-top: var(--s-md);
}

/* =========================================================================
   Rodapé de créditos
   ========================================================================= */
.creditos {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: var(--s-lg) var(--s-sm);
  border-top: 1px solid var(--linha);
}
.creditos p {
  font-family: var(--sans);
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  color: var(--text-tenue);
}
.creditos a {
  color: var(--text-suave);
  text-decoration: none;
  border-bottom: 1px solid var(--blush);
}
.creditos a:hover { color: var(--accent-deep); }

/* =========================================================================
   REVEAL — fades gentis sem overshoot (entram com a respiração)
   ========================================================================= */
.reveal {
  opacity: 0;
  transform: translateY(16px);
  transition:
    opacity 1.1s var(--ease-resp),
    transform 1.1s var(--ease-resp);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}
/* stagger por data-delay */
.reveal[data-delay="1"] { transition-delay: 0.12s; }
.reveal[data-delay="2"] { transition-delay: 0.24s; }
.reveal[data-delay="3"] { transition-delay: 0.36s; }
.reveal[data-delay="4"] { transition-delay: 0.48s; }
.reveal[data-delay="5"] { transition-delay: 0.60s; }

/* =========================================================================
   RESPONSIVO
   ========================================================================= */
@media (max-width: 540px) {
  :root { --lh-caderno: 1.85; }   /* caderno respira, mas não exagera no celular */
  .abertura { padding-top: clamp(5rem, 12vh, 7rem); }
  .quiz__flow { min-height: 22rem; }
}

/* =========================================================================
   prefers-reduced-motion — OBRIGATÓRIO.
   Conteúdo SEMPRE visível. Remove fades. CONGELA o pulse de respiração.
   ========================================================================= */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }

  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }

  /* respiração somática congelada num estado neutro e legível */
  .breathe,
  .breathe-spacing,
  .diary-nav__breath,
  .abertura__seguir svg {
    animation: none !important;
    transform: none !important;
    opacity: 1 !important;
    letter-spacing: normal !important;
  }

  /* tudo visível, sem deslocamento */
  .reveal {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

  /* o flow do quiz não depende de fade para funcionar */
  .quiz__tela.is-active { opacity: 1 !important; transform: none !important; }
}
