/* =========================================================================
   Homepage — styles spécifiques aux sections de la home
   (hero : voir hero.css)
   ========================================================================= */

/* ----- News + livre LP (2 colonnes desktop) ----- */
/* Padding-top réduit pour que la grille pointe au-dessus du fold (juste après le hero). */
.np-section--news {
  padding-block-start: var(--space-6);
}

/* Layout principal : 1 col mobile/tablette, 2 cols dès 1024px */
.np-news__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
}
@media (min-width: 1024px) {
  .np-news__layout {
    grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
    gap: var(--space-7);
    align-items: start;
  }
}
.np-news__main { min-width: 0; } /* autorise le grid-item à shrink (sinon les cards débordent) */

.np-news__title {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  color: var(--np-ink-soft);
  margin: 0 0 var(--space-6);
  max-width: 36ch;
}

.np-news__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}
@media (min-width: 640px)  { .np-news__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) {
  /* Avec le layout 2 cols, la colonne main est plus étroite : on reste à 3 cards mais plus serrées. */
  .np-news__grid { grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
}

.np-news__footer {
  margin-top: var(--space-6);
  text-align: end;
}

/* ----- Aside : présentation du livre Louis Pernot ----- */
.np-book-feature {
  background: var(--np-cream);
  border: 1px solid var(--np-border);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-3);
}
@media (min-width: 1024px) {
  .np-book-feature {
    position: sticky;
    top: 100px;
  }
}

.np-book-feature__cover-link { display: block; }
.np-book-feature__cover {
  height: clamp(180px, 28vh, 260px);
  width: auto;
  display: block;
  box-shadow: 0 12px 32px rgba(26,26,26,0.18), 0 2px 8px rgba(26,26,26,0.08);
  background: var(--np-cream-dim);
}

.np-book-feature__eyebrow {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--np-accent);
  margin: var(--space-3) 0 0;
}
.np-book-feature__title {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.25rem, 1.8vw, 1.5rem);
  line-height: 1.25;
  margin: 0;
  color: var(--np-ink);
  max-width: 26ch;
}
.np-book-feature__lede {
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--np-ink-soft);
  margin: 0;
  max-width: 32ch;
}
.np-book-feature__cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
  color: var(--np-ink);
  margin-block-start: var(--space-2);
}
.np-book-feature__cta::after { content: "→"; transition: transform var(--t-fast); }
.np-book-feature__cta:hover { color: var(--np-accent); }
.np-book-feature__cta:hover::after { transform: translateX(4px); }

.np-book-feature__portrait {
  width: 110px;
  height: 147px;
  object-fit: cover;
  object-position: center 40%;
  margin-block-start: var(--space-4);
  box-shadow: 0 4px 20px rgba(26,26,26,0.10);
}

/* Reveal — état initial (avant entrée dans le viewport) */
.np-section--news[data-reveal] .np-eyebrow,
.np-section--news[data-reveal] .np-news__title,
.np-section--news[data-reveal] .np-news__grid > a,
.np-section--news[data-reveal] .np-news__footer,
.np-section--news[data-reveal] .np-book-feature {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 800ms cubic-bezier(0.22, 1, 0.36, 1),
              transform 800ms cubic-bezier(0.22, 1, 0.36, 1);
}

/* Reveal — état révélé (cascade) */
.np-section--news[data-reveal].is-revealed .np-eyebrow                    { opacity: 1; transform: none; transition-delay: 0ms; }
.np-section--news[data-reveal].is-revealed .np-news__title                { opacity: 1; transform: none; transition-delay: 120ms; }
.np-section--news[data-reveal].is-revealed .np-news__grid > a:nth-child(1){ opacity: 1; transform: none; transition-delay: 260ms; }
.np-section--news[data-reveal].is-revealed .np-news__grid > a:nth-child(2){ opacity: 1; transform: none; transition-delay: 380ms; }
.np-section--news[data-reveal].is-revealed .np-news__grid > a:nth-child(3){ opacity: 1; transform: none; transition-delay: 500ms; }
.np-section--news[data-reveal].is-revealed .np-news__footer               { opacity: 1; transform: none; transition-delay: 640ms; }
.np-section--news[data-reveal].is-revealed .np-book-feature               { opacity: 1; transform: none; transition-delay: 200ms; }

@media (prefers-reduced-motion: reduce) {
  .np-section--news[data-reveal] .np-eyebrow,
  .np-section--news[data-reveal] .np-news__title,
  .np-section--news[data-reveal] .np-news__grid > a,
  .np-section--news[data-reveal] .np-news__footer,
  .np-section--news[data-reveal] .np-book-feature {
    opacity: 1; transform: none; transition: none;
  }
}

/* ----- Approfondir (commentaire verset par verset) ----- */
/* Le bloc "livre" qui occupait la 2e colonne a été retiré (doublon avec
   l'aside livre LP dans la section Actualités). On reste sur 1 colonne lecture. */
.np-deepen__col--commentary {
  max-width: var(--reading-max);
}

.np-deepen__list {
  list-style: none;
  margin: var(--space-5) 0;
  padding: 0;
  display: grid;
  gap: var(--space-2);
  border-block-start: 1px solid var(--np-border);
  padding-block-start: var(--space-4);
}
.np-deepen__list a {
  font-family: var(--font-serif);
  font-size: 1.15rem;
  color: var(--np-ink);
  text-decoration: none;
  border-block-end: 1px solid transparent;
  padding-block-end: var(--space-2);
  display: block;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.np-deepen__list a:hover {
  color: var(--np-accent);
  border-block-end-color: var(--np-accent);
}

/* ----- Audio/Video rail ----- */
.np-av__rail {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 78%;
  gap: var(--space-4);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-block: var(--space-4);
  padding-inline: var(--space-1);
  margin-inline: calc(var(--gutter-mobile) * -1);
  padding-inline-start: var(--gutter-mobile);
  scrollbar-width: thin;
}
@media (min-width: 640px)  { .np-av__rail { grid-auto-columns: 44%; } }
@media (min-width: 1024px) { .np-av__rail { grid-auto-columns: 30%; margin-inline: 0; padding-inline-start: 0; } }

.np-av__card {
  scroll-snap-align: start;
  background: var(--np-white);
  border: 1px solid var(--np-border);
  padding: var(--space-5);
  display: grid;
  gap: var(--space-3);
  align-content: start;
  min-height: 180px;
}

.np-av__icon {
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--np-cream);
  color: var(--np-accent);
  border-radius: 50%;
}

.np-av__card-title {
  font-family: var(--font-serif);
  font-size: 1.3rem;
  font-weight: 600;
  margin: 0;
}
.np-av__card-meta {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--np-ink-soft);
  margin: 0;
}

.np-av__footer {
  margin-top: var(--space-6);
  text-align: end;
}
