/* ─────────────────────────────────────────────
   STYLE V14 — AUDIT FINAL & SCEAU MAISON
   Charge APRÈS toutes les couches V7→V13.
   Strictement additif : aucune règle existante n'est supprimée.
   Aucun sélecteur ne réécrit en cascade les structures de base.
───────────────────────────────────────────── */


/* ════════════════════════════════════════════
   1. AFFINEMENTS TYPOGRAPHIQUES
   Harmonisation des hairlines : letter-spacing
   trop serrés sur certains caps de section.
   ════════════════════════════════════════════ */

/* Eyebrows et caps en small-caps : aération douce */
.pensee-eyebrow,
.cine-cap,
.about-eyebrow,
.svc-eyebrow {
  letter-spacing: 0.18em;
}

/* Numéros romains et années en small-caps : très légère respiration */
.ft-cp,
.ft-tag,
.pensee-signature small {
  letter-spacing: 0.04em;
}


/* ════════════════════════════════════════════
   2. ESPACEMENTS — RESPIRATION FINALE
   +4 à +6% sur les zones les plus lues, sans
   recalcul global qui casserait l'équilibre V13.
   ════════════════════════════════════════════ */

/* Footer : un cran plus aéré entre les blocs */
.ft-top { padding-top: calc(var(--ft-pad-top, 56px) * 1.04); }
.ft-bot { padding-top: calc(var(--ft-bot-pad, 24px) * 1.05); padding-bottom: calc(var(--ft-bot-pad, 24px) * 1.10); }

/* Manifeste page Pensée : interlignes des stances très légèrement adoucis */
.pensee-body .pm-stanza {
  line-height: 1.42;
}

/* Signature manifeste : remontée d'un cran pour respirer après la dernière stance */
.pensee-signature--house {
  margin-top: calc(2.4em * 1.05);
}


/* ════════════════════════════════════════════
   3. CONTRASTES — APAISEMENT DES SECONDAIRES
   Les textes secondaires V13 étaient à .72.
   On affine ponctuellement pour les très petits
   labels (Maison indépendante, copyright).
   ════════════════════════════════════════════ */

.ft-indep,
.ft-cp {
  opacity: 0.78;  /* lisible mais discret */
}


/* ════════════════════════════════════════════
   4. SCEAU MAISON — IDENTITÉ INSTITUTIONNELLE
   Composant réutilisable, injecté programmatiquement
   par script-v15.js dans le footer et la page Pensée.
   ════════════════════════════════════════════ */

/* Wrapper neutre du sceau */
.maison-seal {
  display: inline-block;
  line-height: 0;
  vertical-align: middle;
  /* Le PNG du sceau a un fond ivoire (245,237,224) quasi identique
     au fond du site (245,239,225). L'intégration est invisible. */
  background: transparent;
}

.maison-seal img {
  display: block;
  width: 100%;
  height: auto;
  /* Décrispation très légère du sceau pour qu'il dialogue
     avec le grain photographique des images du site */
  filter: contrast(0.96) saturate(0.94);
}


/* 4.a — Sceau dans le FOOTER
   Positionné sous le copyright, centré, très petit, très discret.
   Ne remplace pas le SVG d'écusson de la première colonne. */

.ft-bot .maison-seal {
  width: 38px;
  margin: 18px auto 0;
  opacity: 0.42;
  transition: opacity 720ms cubic-bezier(.22,.61,.36,1);
}
.ft-bot .maison-seal:hover {
  opacity: 0.66;
}

/* Recentrage du bloc copyright pour accueillir le sceau */
.ft-bot .ft-cp-wrap {
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
@media (min-width: 720px) {
  /* Sur grand écran on garde la rangée + sceau sous, mais on conserve
     l'alignement horizontal copyright/indep si c'était le cas. */
  .ft-bot .ft-cp-wrap {
    flex-direction: row;
    justify-content: center;
    gap: 22px;
  }
  .ft-bot .maison-seal {
    margin: 0 0 0 8px;
    width: 32px;
  }
}


/* 4.b — Sceau page PENSÉE
   Positionné juste avant la signature « Maison Caravelli / Florence · MCMXLVIII ».
   Format vignette, opacité forte mais taille discrète : il devient
   le visage de la signature. */

.pensee-body .maison-seal--pensee {
  display: block;
  width: 88px;
  margin: 36px auto 14px;
  opacity: 0.62;
}

.pensee-body .maison-seal--pensee + .pensee-signature--house {
  margin-top: 6px;
}


/* 4.c — Apparition douce du sceau au scroll */
.maison-seal {
  opacity: 0;
  transform: translateY(6px);
  transition:
    opacity 1100ms cubic-bezier(.22,.61,.36,1),
    transform 1100ms cubic-bezier(.22,.61,.36,1);
}
.maison-seal.is-in {
  opacity: var(--seal-opacity, 0.42);
  transform: translateY(0);
}
.pensee-body .maison-seal--pensee.is-in {
  --seal-opacity: 0.62;
}
.ft-bot .maison-seal.is-in {
  --seal-opacity: 0.42;
}


/* ════════════════════════════════════════════
   5. CORRECTIFS PONCTUELS
   Détails relevés à l'audit final.
   ════════════════════════════════════════════ */

/* Lien actif dans la nav : underline trop appuyé sur certaines pages */
.nl.active::after {
  opacity: 0.66;
}

/* Boutons CTA : très léger calage vertical pour éviter le saut
   au hover quand la transformation s'applique */
.btn,
.cta {
  will-change: transform;
}


/* ════════════════════════════════════════════
   6. PRÉFÉRENCE MOTION
   Respect strict de prefers-reduced-motion.
   ════════════════════════════════════════════ */

@media (prefers-reduced-motion: reduce) {
  .maison-seal,
  .maison-seal.is-in {
    transition: none;
    opacity: var(--seal-opacity, 0.42);
    transform: none;
  }
  .pensee-body .maison-seal--pensee.is-in {
    opacity: 0.62;
  }
}


/* ════════════════════════════════════════════════════════════════
   7. SECTION ARCHIVES — MÉMOIRE DU MÉTIER (page about uniquement)
   Frise éditoriale de 4 archives photographiques traitées au pipeline
   argentique du site. Inscrite dans la lignée du manifeste Pensée :
   « Avant nous, un métier nous précède. »
   Injection programmatique par script-v15.js.
   ════════════════════════════════════════════════════════════════ */

.archives {
  padding: 6.4rem 0 7.2rem;
  background: #F4EFE3;       /* crème + nuance plus chaude que le blanc général */
  position: relative;
  overflow: hidden;
}

.archives::before {
  /* Couture or désaturé en haut : marque institutionnelle, signature de section */
  content: "";
  position: absolute;
  top: 0; left: 50%;
  width: 64px;
  height: 1px;
  background: rgba(140, 110, 72, 0.32);
  transform: translateX(-50%);
}

.archives-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 1.6rem;
  text-align: center;
}

.archives-eyebrow {
  display: inline-block;
  font-family: 'Tenor Sans', 'Cormorant Garamond', serif;
  font-size: 0.78rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgba(140, 110, 72, 0.85);
  margin-bottom: 1.4rem;
}

.archives-h2 {
  font-family: 'Cormorant Garamond', 'Cormorant', serif;
  font-weight: 300;
  font-size: clamp(1.75rem, 3.4vw, 2.7rem);
  line-height: 1.18;
  color: #1F1B18;
  margin: 0 0 4rem;
  letter-spacing: -0.005em;
}
.archives-h2 em {
  font-style: italic;
  color: #4a3f33;
}

/* Frise — 4 colonnes desktop, défilement horizontal mobile */
.archives-frieze {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}

.archives-item {
  margin: 0;
  padding: 0;
  opacity: 0;
  transform: translateY(14px);
  transition:
    opacity 1100ms cubic-bezier(.22,.61,.36,1),
    transform 1100ms cubic-bezier(.22,.61,.36,1);
}
.archives-item.is-in {
  opacity: 1;
  transform: translateY(0);
}
.archives-item:nth-child(1).is-in { transition-delay:   0ms; }
.archives-item:nth-child(2).is-in { transition-delay: 120ms; }
.archives-item:nth-child(3).is-in { transition-delay: 240ms; }
.archives-item:nth-child(4).is-in { transition-delay: 360ms; }

.archives-item figure {
  margin: 0;
}

.archives-item img {
  display: block;
  width: 100%;
  height: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  object-position: center;
  background: #1F1B18;
  filter: contrast(0.98);
  /* Très léger encadrement pour évoquer une planche-contact */
  box-shadow:
    0 1px 0 rgba(255,255,255,.6) inset,
    0 0 0 1px rgba(140,110,72,.10);
}

.archives-item figcaption {
  font-family: 'Tenor Sans', sans-serif;
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(40, 32, 26, 0.55);
  text-align: center;
  margin-top: 14px;
}

/* Mobile — frise en scroll horizontal pour préserver le rythme */
@media (max-width: 720px) {
  .archives {
    padding: 4.2rem 0 4.8rem;
  }
  .archives-h2 {
    margin-bottom: 2.6rem;
  }
  .archives-frieze {
    grid-template-columns: none;
    grid-auto-flow: column;
    grid-auto-columns: 72%;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    padding: 0 1.2rem 8px;
    gap: 14px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .archives-frieze::-webkit-scrollbar { display: none; }
  .archives-item {
    scroll-snap-align: center;
  }
}

/* Préférence motion — pas d'animation */
@media (prefers-reduced-motion: reduce) {
  .archives-item,
  .archives-item.is-in {
    opacity: 1;
    transform: none;
    transition: none;
  }
}
