/* css/modules/composition.css — Portada dinámica v1 (módulos manifest 1-7).
   Aislado: NO toca el CSS inline de la home. Usa tokens de qsd-tokens.css. */

.mod-composition { display: flex; flex-direction: column; }

/* ── hero-cover ── */
.mod-hero-cover-pr2 {
  background: var(--surface-card-light, #fff); border-radius: 14px; overflow: hidden;
  box-shadow: 0 6px 34px rgba(28,27,24,.11); margin-bottom: var(--space-2xl, 3rem);
}
.mod-hero-cover__media { display:block; aspect-ratio:16/9; max-height: clamp(320px, 46vh, 540px); overflow:hidden; }
.mod-hero-cover__media img { width:100%; height:100%; object-fit:cover; display:block; }
.mod-hero-cover__body { padding: var(--space-lg,1.5rem) var(--space-xl,2rem) var(--space-xl,2rem); }
.mod-hero-typographic {
  background: var(--band-crema,#faf8f5); border-left: 3px solid var(--accent-editorial,#1e4a57);
  border-radius: 12px; padding: var(--space-xl,2rem); margin-bottom: var(--space-2xl,3rem);
}
.mod-hero__kicker { font:600 .72rem/1 'Source Sans 3',sans-serif; letter-spacing:.14em; text-transform:uppercase; color: var(--accent-editorial,#1e4a57); }
.mod-hero__title { font-family: var(--font-display,'Playfair Display'),serif; font-weight:800; font-size: clamp(1.7rem,3.4vw,2.6rem); line-height:1.15; margin:.5rem 0 0; }
.mod-hero__title a { color: var(--ink-primary,#1c1b18); text-decoration:none; }
.mod-hero__excerpt { color: var(--ink-secondary,#5c5a54); font-size:1rem; margin:.6rem 0 0; max-width:60ch; }
.mod-hero__byline { color: var(--ink-muted,#8a8478); font-size:.8rem; }

/* ── lead-stack: fila de lecturas ── */
.mod-lead-stack { display:grid; grid-template-columns: repeat(3,1fr); gap: var(--space-lg,1.5rem); margin-bottom: var(--space-2xl,3rem); }

/* ── quote-band: la frase viva ── */
.mod-quote-band {
  text-align:center; padding: var(--space-2xl,3rem) var(--space-lg,1.5rem); margin:0 0 var(--space-2xl,3rem);
  border-top:1px solid var(--border-on-light,rgba(28,27,24,.1)); border-bottom:1px solid var(--border-on-light,rgba(28,27,24,.1));
}
.mod-quote-band__label { font:600 .7rem/1 'Source Sans 3',sans-serif; letter-spacing:.16em; text-transform:uppercase; color: var(--accent-editorial,#1e4a57); }
.mod-quote-band__text { font-family: var(--font-display,'Playfair Display'),serif; font-style:italic; font-size: clamp(1.4rem,3vw,2.1rem); line-height:1.4; color: var(--ink-primary,#1c1b18); margin:.8rem auto; max-width:32ch; }
.mod-quote-band__text::before { content:"\201C"; } .mod-quote-band__text::after { content:"\201D"; }
.mod-quote-band__source { font-size:.85rem; color: var(--ink-muted,#8a8478); text-decoration:none; border-bottom:1px solid currentColor; }

/* ── coverage-cluster: grupo etiquetado + grilla uniforme ── */
.mod-cluster { margin-bottom: var(--space-2xl,3rem); }
.mod-cluster__label { font-family: var(--font-headline,'Libre Baskerville'),serif; font-size:1.05rem; font-weight:700; color: var(--accent-editorial,#1e4a57); letter-spacing:.02em; margin:0 0 var(--space-lg,1.5rem); padding-bottom:.5rem; border-bottom:2px solid rgba(30,74,87,.2); }
.mod-cluster__grid { display:grid; grid-template-columns: repeat(3,1fr); gap: var(--space-xl,2rem); }

/* ── card uniforme ── */
.mod-card { display:flex; flex-direction:column; text-decoration:none; color:inherit; background:var(--surface-card-light,#fff); border:1px solid var(--border-on-light,rgba(28,27,24,.08)); border-radius:10px; overflow:hidden; transition:transform .15s, box-shadow .15s; }
.mod-card:hover { transform: translateY(-2px); box-shadow:0 8px 24px rgba(28,27,24,.1); }
.mod-card__media { aspect-ratio:16/9; overflow:hidden; background:#eceae5; }
.mod-card__media img { width:100%; height:100%; object-fit:cover; display:block; }
.mod-card--text { border-top:3px solid var(--accent-editorial,#1e4a57); }
.mod-card__body { padding: var(--space-md,1rem) var(--space-lg,1.5rem) var(--space-lg,1.5rem); display:flex; flex-direction:column; gap:.3rem; }
.mod-card__kicker { font:600 .68rem/1 'Source Sans 3',sans-serif; letter-spacing:.04em; color:var(--ink-muted,#8a8478); text-transform:uppercase; }
.mod-card__title { font-family: var(--font-headline,'Libre Baskerville'),serif; font-size:1.05rem; line-height:1.32; font-weight:700; color:var(--ink-primary,#1c1b18); margin:0; }
.mod-lead .mod-card__title { font-size:.98rem; }
.mod-card__excerpt { font-size:.85rem; line-height:1.5; color:var(--ink-secondary,#5c5a54); display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }

/* ── breathing-space ── */
.mod-breathing { display:flex; align-items:center; justify-content:center; gap:1rem; margin: var(--space-xl,2rem) 0 var(--space-2xl,3rem); color:var(--ink-muted,#8a8478); }
.mod-breathing::before, .mod-breathing::after { content:""; flex:1; height:1px; background:var(--border-on-light,rgba(28,27,24,.12)); }
.mod-breathing__label { font:600 .72rem/1 'Source Sans 3',sans-serif; letter-spacing:.18em; text-transform:uppercase; white-space:nowrap; }

/* ── hero-image: banda foto ── */
.mod-hero-image { margin-bottom: var(--space-2xl,3rem); border-radius:14px; overflow:hidden; }
.mod-hero-image__link { position:relative; display:block; }
.mod-hero-image img { width:100%; aspect-ratio:21/9; object-fit:cover; display:block; }
.mod-hero-image--text .mod-hero-image__link { background: linear-gradient(135deg,#16323b,#1e4a57); min-height:220px; }
.mod-hero-image__overlay { position:absolute; left:0; right:0; bottom:0; padding: var(--space-xl,2rem); background:linear-gradient(0deg, rgba(10,12,18,.85), transparent); }
.mod-hero-image__kicker { font:600 .72rem/1 'Source Sans 3',sans-serif; letter-spacing:.12em; text-transform:uppercase; color:#e0a64a; }
.mod-hero-image__title { font-family: var(--font-display,'Playfair Display'),serif; font-weight:800; font-size: clamp(1.4rem,2.8vw,2.2rem); line-height:1.18; color:#f5f2ec; margin:.4rem 0 0; max-width:24ch; }

/* ── MOBILE ── */
@media (max-width: 980px) {
  .mod-lead-stack, .mod-cluster__grid { grid-template-columns: 1fr; }
  .mod-hero-cover__media { max-height: clamp(220px,56vw,340px); }
  .mod-hero-image img { aspect-ratio:16/9; }
  .mod-quote-band__text { max-width:none; }
}
