/* =============================================================
   DIÁRIO — Manoella Melim · Arquitetura de Interiores
   Páginas editoriais de leitura longa (índice + artigo).
   Reskin da referência editorial para a identidade Manoella:
   Cormorant no display, Hanken no corpo, paleta neutra quente,
   cantos vivos, hairlines, zero sombra, zero gradiente.
   Construído sobre os tokens do design system + site.css.
   ============================================================= */

/* páginas do diário têm header sólido fixo: empurra o conteúdo */
body.diario { padding-top: 86px; }

/* medida de leitura confortável — um pouco mais larga que o corpo padrão */
:root {
  --read-measure: 680px;
  --diario-max: 1180px;
  --fs-read:      1.1875rem;  /* 19px — corpo de leitura            */
  --fs-standfirst:1.375rem;   /* 22px — parágrafo de abertura       */
}

/* ============================================================
   ÍNDICE — topo enxuto
   ============================================================ */
.diario-lede {
  max-width: var(--diario-max);
  margin: 0 auto;
  padding: clamp(56px, 9vw, 132px) clamp(20px, 4vw, 64px) clamp(40px, 6vw, 72px);
}
.diario-lede__eyebrow { display: block; margin-bottom: var(--space-lg); }
.diario-lede__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: var(--fw-display-light);
  font-size: var(--fs-display);
  line-height: var(--lh-display);
  letter-spacing: var(--ls-display);
  text-transform: uppercase;
  color: var(--text-primary);
}
.diario-lede__sub {
  margin: var(--space-lg) 0 0;
  max-width: 40ch;
  font-family: var(--font-body);
  font-weight: var(--fw-body-light);
  font-size: var(--fs-lead);
  line-height: var(--lh-body);
  color: var(--text-secondary);
}

/* ============================================================
   ÍNDICE — artigo em destaque
   ============================================================ */
.feature {
  max-width: var(--diario-max);
  margin: 0 auto;
  padding: 0 clamp(20px, 4vw, 64px);
}
.feature__link {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: clamp(32px, 5vw, 72px);
  align-items: center;
  text-decoration: none;
  color: inherit;
  padding-top: var(--space-2xl);
  border-top: 1px solid var(--border-hairline);
}
.feature__media {
  position: relative;
  overflow: hidden;
  background: var(--surface-alt);
  aspect-ratio: 4 / 3;
  line-height: 0;
}
.feature__media img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform var(--dur-slow) var(--ease-out);
}
.feature__link:hover .feature__media img { transform: scale(1.03); }

.feature__body { min-width: 0; }
.feature__kicker { display: block; color: var(--accent-text); margin-bottom: var(--space-lg); }
.feature__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: var(--fw-display-light);
  font-size: var(--fs-h1);
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-heading);
  text-transform: uppercase;
  color: var(--text-primary);
  transition: color var(--dur) var(--ease);
}
.feature__link:hover .feature__title { color: var(--accent-text); }
.feature__meta {
  margin: var(--space-lg) 0 0;
  font-family: var(--font-body);
  font-size: var(--fs-caption);
  letter-spacing: var(--ls-label-sm);
  text-transform: uppercase;
  color: var(--text-caption);
}
.feature__meta .dot { margin: 0 10px; }
.feature__excerpt {
  margin: var(--space-lg) 0 0;
  max-width: 46ch;
  font-family: var(--font-body);
  font-weight: var(--fw-body-light);
  font-size: var(--fs-lead);
  line-height: var(--lh-body);
  color: var(--text-secondary);
}

@media (max-width: 859px) {
  .feature__link { grid-template-columns: 1fr; gap: var(--space-xl); }
  .feature__media { aspect-ratio: 16 / 10; }
}

/* ============================================================
   ÍNDICE — lista dos demais posts
   ============================================================ */
.postlist {
  max-width: var(--diario-max);
  margin: clamp(56px, 9vw, 120px) auto 0;
  padding: 0 clamp(20px, 4vw, 64px) clamp(72px, 12vw, 160px);
}
.postlist__h {
  margin: 0 0 var(--space-xl);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--border-hairline);
}
.post {
  display: grid;
  grid-template-columns: 200px 1fr auto;
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
  padding: clamp(28px, 4vw, 48px) 0;
  border-bottom: 1px solid var(--border-hairline);
  text-decoration: none;
  color: inherit;
}
.post__media {
  position: relative;
  overflow: hidden;
  background: var(--surface-alt);
  aspect-ratio: 4 / 3;
  line-height: 0;
}
.post__media img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform var(--dur-slow) var(--ease-out);
}
.post:hover .post__media img { transform: scale(1.03); }
.post__body { min-width: 0; }
.post__kicker { display: block; color: var(--accent-text); margin-bottom: var(--space-sm); }
.post__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: var(--fw-display);
  font-size: var(--fs-h3);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-h3);
  text-transform: uppercase;
  color: var(--text-primary);
  transition: color var(--dur) var(--ease);
}
.post:hover .post__title { color: var(--accent-text); }
.post__excerpt {
  margin: var(--space-sm) 0 0;
  max-width: 52ch;
  font-family: var(--font-body);
  font-weight: var(--fw-body-light);
  font-size: var(--fs-small);
  line-height: var(--lh-body);
  color: var(--text-secondary);
}
.post__meta {
  text-align: right;
  font-family: var(--font-body);
  font-size: var(--fs-caption);
  letter-spacing: var(--ls-label-sm);
  text-transform: uppercase;
  color: var(--text-caption);
  white-space: nowrap;
}
.post__meta .yr { display: block; }
.post__meta .rt { display: block; margin-top: 6px; }

@media (max-width: 859px) {
  .post { grid-template-columns: 140px 1fr; gap: var(--space-lg); align-items: start; }
  .post__meta { grid-column: 2; text-align: left; margin-top: var(--space-sm); }
  .post__meta .rt { display: inline; margin: 0; }
  .post__meta .yr { display: inline; }
  .post__meta .yr::after { content: " · "; }
}
@media (max-width: 560px) {
  .post { grid-template-columns: 1fr; }
  .post__media { aspect-ratio: 16 / 10; max-width: 100%; }
}

/* ============================================================
   ARTIGO — barra de progresso de leitura
   ============================================================ */
.progress-track {
  position: fixed; top: 0; left: 0; right: 0;
  height: 2px; z-index: 60;
  background: transparent;
}
.progress-fill {
  height: 100%; width: 0%;
  background: var(--text-primary);
  transition: width 80ms linear;
}
@media (prefers-reduced-motion: reduce) { .progress-fill { transition: none; } }

/* ============================================================
   ARTIGO — cabeçalho
   ============================================================ */
.article-head {
  max-width: 920px;
  margin: 0 auto;
  padding: clamp(48px, 8vw, 104px) clamp(20px, 4vw, 64px) 0;
}
.article-head__kicker { display: block; color: var(--accent-text); margin-bottom: var(--space-xl); }
.article-title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: var(--fw-display-light);
  font-size: var(--fs-display);
  line-height: var(--lh-display);
  letter-spacing: var(--ls-display);
  text-transform: uppercase;
  color: var(--text-primary);
  max-width: 16ch;
}
.article-standfirst {
  margin: clamp(28px, 4vw, 44px) 0 0;
  max-width: 60ch;
  font-family: var(--font-body);
  font-weight: var(--fw-body-light);
  font-size: var(--fs-standfirst);
  line-height: 1.5;
  color: var(--text-secondary);
}
.article-meta {
  margin: clamp(28px, 4vw, 44px) 0 0;
  font-family: var(--font-body);
  font-size: var(--fs-caption);
  letter-spacing: var(--ls-label-sm);
  text-transform: uppercase;
  color: var(--text-caption);
}
.article-meta .dot { margin: 0 10px; }

/* abertura — imagem em destaque */
.article-hero {
  max-width: var(--diario-max);
  margin: clamp(40px, 6vw, 80px) auto 0;
  padding: 0 clamp(20px, 4vw, 64px);
}
.article-hero__img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  display: block;
  background: var(--surface-alt);
}
.article-hero__cap {
  max-width: var(--read-measure);
  margin: var(--space-md) auto 0;
  display: flex; justify-content: space-between; gap: var(--space-lg);
  font-family: var(--font-body);
  font-size: var(--fs-small);
  line-height: var(--lh-tight);
  color: var(--text-caption);
}
.article-hero__cap .credit {
  flex-shrink: 0;
  font-size: var(--fs-caption);
  letter-spacing: var(--ls-label-sm);
  text-transform: uppercase;
}

/* ============================================================
   ARTIGO — layout com sumário lateral
   ============================================================ */
.article-layout {
  max-width: var(--diario-max);
  margin: clamp(48px, 7vw, 96px) auto 0;
  padding: 0 clamp(20px, 4vw, 64px);
}
.article-grid {
  display: grid;
  grid-template-columns: 200px minmax(0, var(--read-measure)) 1fr;
  gap: clamp(40px, 5vw, 72px);
  justify-content: center;
}

/* Sumário (TOC) */
.toc {
  position: sticky; top: 120px;
  align-self: start;
  padding-top: 6px;
}
.toc__h {
  margin: 0 0 var(--space-md);
  font-family: var(--font-body);
  font-weight: var(--fw-body-medium);
  font-size: var(--fs-caption);
  letter-spacing: var(--ls-label-sm);
  text-transform: uppercase;
  color: var(--text-caption);
}
.toc__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.toc__list a {
  display: block;
  padding: 7px 0 7px 14px;
  border-left: 1px solid var(--border-hairline);
  font-family: var(--font-body);
  font-weight: var(--fw-body);
  font-size: var(--fs-small);
  line-height: 1.4;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-caption);
  text-decoration: none;
  transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.toc__list a:hover { color: var(--text-primary); }
.toc__list li.active a { color: var(--text-primary); border-left-color: var(--accent); }
.toc__list a:focus-visible { outline: 1px solid var(--focus-ring); outline-offset: 3px; }

@media (max-width: 980px) {
  .article-grid { grid-template-columns: minmax(0, var(--read-measure)); }
  .toc { display: none; }
}

/* ============================================================
   ARTIGO — corpo
   ============================================================ */
.article { grid-column: 2; max-width: var(--read-measure); min-width: 0; }

.article p {
  margin: 0 0 var(--space-lg);
  font-family: var(--font-body);
  font-weight: var(--fw-body-light);
  font-size: var(--fs-read);
  line-height: 1.7;
  color: var(--text-primary);
}
.article p a {
  color: var(--accent-text);
  text-decoration: underline;
  text-decoration-color: var(--accent);
  text-underline-offset: 4px;
  transition: text-decoration-color var(--dur) var(--ease);
}
.article p a:hover { text-decoration-color: var(--accent-text); }
.article em { font-style: italic; }
.article strong { font-weight: var(--fw-body-semibold); }

.article-h2 {
  margin: clamp(48px, 7vw, 80px) 0 var(--space-lg);
  font-family: var(--font-display);
  font-weight: var(--fw-display);
  font-size: var(--fs-h3);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-h3);
  text-transform: uppercase;
  color: var(--text-primary);
  scroll-margin-top: 110px;
}

/* figura no corpo */
.article figure { margin: clamp(40px, 6vw, 64px) 0; }
.article figure img {
  width: 100%; display: block;
  aspect-ratio: 3 / 2; object-fit: cover;
  background: var(--surface-alt);
}
.article figure figcaption {
  margin-top: var(--space-md);
  font-family: var(--font-body);
  font-size: var(--fs-small);
  line-height: var(--lh-tight);
  color: var(--text-caption);
}

/* pull quote — Cormorant grande, muito respiro */
.pull-quote {
  margin: clamp(48px, 8vw, 88px) 0;
  padding: clamp(40px, 6vw, 64px) 0;
  border-top: 1px solid var(--border-hairline);
  border-bottom: 1px solid var(--border-hairline);
}
.pull-quote p {
  margin: 0;
  font-family: var(--font-display);
  font-weight: var(--fw-display-light);
  font-size: var(--fs-h2);
  line-height: 1.25;
  letter-spacing: 0.01em;
  color: var(--text-primary);
}
.pull-quote .attr {
  display: block;
  margin-top: var(--space-lg);
  font-family: var(--font-body);
  font-weight: var(--fw-body-medium);
  font-size: var(--fs-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--text-caption);
}

/* marcadores de nota de rodapé */
.fn-ref {
  font-size: 0.62em;
  vertical-align: super;
  color: var(--accent-text);
  font-weight: var(--fw-body-semibold);
  text-decoration: none;
  margin-left: 2px;
}
.fn-ref:hover { text-decoration: underline; text-underline-offset: 3px; }

.footnotes {
  margin-top: clamp(56px, 9vw, 96px);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--border-hairline);
}
.footnotes__h {
  margin: 0 0 var(--space-md);
  font-family: var(--font-body);
  font-weight: var(--fw-body-medium);
  font-size: var(--fs-caption);
  letter-spacing: var(--ls-label-sm);
  text-transform: uppercase;
  color: var(--text-caption);
}
.footnotes ol { list-style: none; counter-reset: fn; margin: 0; padding: 0; }
.footnotes li {
  counter-increment: fn;
  position: relative;
  margin: 0 0 var(--space-md);
  padding-left: 28px;
  font-family: var(--font-body);
  font-weight: var(--fw-body-light);
  font-size: var(--fs-small);
  line-height: var(--lh-body);
  color: var(--text-secondary);
}
.footnotes li::before {
  content: counter(fn);
  position: absolute; left: 0; top: 0;
  font-weight: var(--fw-body-semibold);
  color: var(--accent-text);
}

/* ============================================================
   ARTIGO — compartilhar (discreto, sem sombra)
   ============================================================ */
.share-inline {
  grid-column: 2;
  max-width: var(--read-measure);
  margin: clamp(48px, 7vw, 72px) auto 0;
  padding-top: var(--space-lg);
  border-top: 1px solid var(--border-hairline);
  display: flex; align-items: center; gap: var(--space-lg);
  flex-wrap: wrap;
}
.share-inline__label {
  font-family: var(--font-body);
  font-weight: var(--fw-body-medium);
  font-size: var(--fs-caption);
  letter-spacing: var(--ls-label-sm);
  text-transform: uppercase;
  color: var(--text-caption);
}
.share-inline__btns { display: flex; gap: var(--space-sm); }
.share-btn {
  display: inline-flex; align-items: center; gap: var(--space-xs);
  padding: 9px 16px;
  border: 1px solid var(--border-hairline);
  background: transparent;
  color: var(--text-primary);
  font-family: var(--font-body);
  font-weight: var(--fw-body-medium);
  font-size: var(--fs-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: border-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
.share-btn:hover { border-color: var(--accent); color: var(--accent-text); }
.share-btn:focus-visible { outline: 1px solid var(--focus-ring); outline-offset: 3px; }
.share-btn svg { width: 15px; height: 15px; }

/* ============================================================
   ARTIGO — bloco do autor
   ============================================================ */
.author {
  grid-column: 2;
  max-width: var(--read-measure);
  margin: clamp(48px, 7vw, 80px) auto 0;
  padding-top: clamp(32px, 5vw, 48px);
  border-top: 1px solid var(--border-hairline);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(20px, 3vw, 32px);
  align-items: start;
}
.author__avatar {
  width: 84px; height: 84px;
  object-fit: cover;
  background: var(--surface-alt);
  display: block;
}
.author__monogram {
  width: 84px; height: 84px;
  background: var(--surface-alt);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-weight: var(--fw-display-light);
  font-size: 1.9rem;
  letter-spacing: 0.06em;
  color: var(--text-primary);
}
.author__name {
  margin: 0;
  font-family: var(--font-display);
  font-weight: var(--fw-display);
  font-size: var(--fs-h3);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-h3);
  text-transform: uppercase;
  color: var(--text-primary);
}
.author__role {
  margin: 6px 0 0;
  font-family: var(--font-body);
  font-weight: var(--fw-body-medium);
  font-size: var(--fs-caption);
  letter-spacing: var(--ls-label-sm);
  text-transform: uppercase;
  color: var(--text-caption);
}
.author__bio {
  margin: var(--space-md) 0 0;
  max-width: 52ch;
  font-family: var(--font-body);
  font-weight: var(--fw-body-light);
  font-size: var(--fs-small);
  line-height: var(--lh-body);
  color: var(--text-secondary);
}

/* ============================================================
   ARTIGO — newsletter (seção invertida, sem gradiente)
   ============================================================ */
.newsletter {
  background: var(--surface-inverse);
  margin: clamp(64px, 9vw, 120px) 0 0;
  padding: clamp(56px, 9vw, 112px) clamp(20px, 4vw, 64px);
}
.newsletter__inner { max-width: var(--read-measure); margin: 0 auto; }
.newsletter__eyebrow {
  display: block; margin-bottom: var(--space-lg);
  font-family: var(--font-body);
  font-weight: var(--fw-body-medium);
  font-size: var(--fs-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--mm-goat-soft);
}
.newsletter__h {
  margin: 0;
  font-family: var(--font-display);
  font-weight: var(--fw-display-light);
  font-size: var(--fs-h2);
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-heading);
  text-transform: uppercase;
  color: var(--text-on-dark);
  max-width: 18ch;
}
.newsletter__sub {
  margin: var(--space-lg) 0 0;
  max-width: 48ch;
  font-family: var(--font-body);
  font-weight: var(--fw-body-light);
  font-size: var(--fs-lead);
  line-height: var(--lh-body);
  color: var(--mm-mud-puddle);
}
.newsletter__form {
  margin: clamp(28px, 4vw, 40px) 0 0;
  display: flex; gap: var(--space-sm);
  max-width: 520px;
}
.newsletter__input {
  flex: 1; min-width: 0;
  background: transparent;
  border: 1px solid var(--border-on-dark);
  border-radius: 0;
  padding: 15px 16px;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--text-on-dark);
  outline: none;
  transition: border-color var(--dur) var(--ease);
}
.newsletter__input::placeholder { color: var(--mm-mud-puddle); }
.newsletter__input:focus { border-color: var(--mm-soft-violet); }
.newsletter__submit {
  flex-shrink: 0;
  background: transparent;
  border: 1px solid var(--mm-soft-violet);
  border-radius: 0;
  padding: 15px 28px;
  font-family: var(--font-body);
  font-weight: var(--fw-body-medium);
  font-size: var(--fs-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--text-on-dark);
  cursor: pointer;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.newsletter__submit:hover { background: var(--mm-soft-violet); color: var(--text-primary); }
.newsletter__submit:focus-visible { outline: 1px solid var(--mm-soft-violet); outline-offset: 3px; }
.newsletter__disclaimer {
  margin: var(--space-md) 0 0;
  font-family: var(--font-body);
  font-size: var(--fs-caption);
  letter-spacing: 0.02em;
  text-transform: none;
  color: var(--mm-mud-puddle);
}
@media (max-width: 560px) {
  .newsletter__form { flex-direction: column; }
}

/* ============================================================
   ARTIGO — continue lendo (3 cartões)
   ============================================================ */
.related {
  max-width: var(--diario-max);
  margin: 0 auto;
  padding: clamp(64px, 10vw, 128px) clamp(20px, 4vw, 64px) clamp(72px, 12vw, 160px);
}
.related__h {
  margin: 0 0 var(--space-xl);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--border-hairline);
}
.related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(28px, 4vw, 56px);
}
.related-card { display: flex; flex-direction: column; text-decoration: none; color: inherit; }
.related-card__media {
  position: relative; overflow: hidden;
  background: var(--surface-alt);
  aspect-ratio: 4 / 3; line-height: 0;
  margin-bottom: var(--space-md);
}
.related-card__media img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform var(--dur-slow) var(--ease-out);
}
.related-card:hover .related-card__media img { transform: scale(1.03); }
.related-card__kicker { display: block; color: var(--accent-text); margin-bottom: var(--space-sm); }
.related-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: var(--fw-display);
  font-size: var(--fs-h3);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-h3);
  text-transform: uppercase;
  color: var(--text-primary);
  transition: color var(--dur) var(--ease);
}
.related-card:hover .related-card__title { color: var(--accent-text); }
.related-card__time {
  margin: var(--space-sm) 0 0;
  font-family: var(--font-body);
  font-size: var(--fs-caption);
  letter-spacing: var(--ls-label-sm);
  text-transform: uppercase;
  color: var(--text-caption);
}
@media (max-width: 859px) {
  .related__grid { grid-template-columns: 1fr; gap: clamp(32px, 8vw, 48px); }
}

/* ============================================================
   reveal calmo (compartilhado com o site)
   ============================================================ */
.js .reveal {
  opacity: 0; transform: translateY(16px);
  transition: opacity var(--dur) var(--ease-out), transform var(--dur) var(--ease-out);
}
.js .reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .js .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
}
