/* =============================================================================
   PLEIN SUD — Page "À propos de nous"  (templates/page-about.php)
   Namespace .ps-about__*  ·  tokens globaux uniquement.
   ============================================================================= */

.ps-about {
  background: var(--ps-cream);
}
.ps-about__inner {
  max-width: var(--ps-content);
  margin: 0 auto;
  padding: 22px 20px 40px;
  box-sizing: border-box;
}

/* --- Breadcrumb (repris du style produit) --------------------------------- */
.ps-about .ps-breadcrumb { font-size: 13px; color: var(--ps-muted); margin-bottom: 22px; }
.ps-about .ps-breadcrumb a { color: var(--ps-muted); text-decoration: none; }
.ps-about .ps-breadcrumb a:hover { color: var(--ps-gold); }
.ps-about .ps-breadcrumb .sep { margin: 0 8px; color: var(--ps-line); }

/* --- Éléments partagés ---------------------------------------------------- */
.ps-about__eyebrow {
  font-family: var(--ps-font-body);
  text-transform: uppercase;
  letter-spacing: var(--ps-ls-eyebrow);
  font-size: var(--ps-fs-eyebrow);
  font-weight: 600;
  color: var(--ps-gold-dark);
  margin: 0 0 14px;
}
.ps-about__eyebrow--ink { color: rgba(var(--ps-ink-rgb), .72); }

.ps-about__h2 {
  font-family: var(--ps-font-heading);
  font-weight: 400;
  color: var(--ps-ink);
  font-size: 30px;
  line-height: 1.15;
  letter-spacing: var(--ps-ls-heading);
  margin: 0 0 18px;
}
.ps-about__h3 {
  font-family: var(--ps-font-heading);
  font-weight: 400;
  color: var(--ps-ink);
  font-size: 22px;
  line-height: 1.2;
  margin: 0 0 14px;
}
.ps-about__p {
  font-family: var(--ps-font-body);
  color: var(--ps-body);
  font-size: 15px;
  line-height: 1.75;
  margin: 0 0 16px;
}
.ps-about__p:last-child { margin-bottom: 0; }

/* Rythme vertical entre grandes sections */
.ps-about__story,
.ps-about__timeline-block,
.ps-about__cols,
.ps-about__values,
.ps-about__team { margin-top: 64px; }

/* =============================================================================
   1) HERO
   ============================================================================= */
.ps-about__hero {
  margin-top: 6px;
  background: linear-gradient(135deg, #e2ba63 0%, #d7ac52 55%, #cf9f42 100%);
  border-radius: 20px;
  padding: 52px 56px;
  box-sizing: border-box;
}
.ps-about__hero-title {
  font-family: var(--ps-font-heading);
  font-weight: 400;
  color: var(--ps-ink);
  font-size: 40px;
  line-height: 1.1;
  letter-spacing: var(--ps-ls-heading);
  margin: 0 0 18px;
}
.ps-about__hero-text {
  font-family: var(--ps-font-body);
  color: rgba(var(--ps-ink-rgb), .85);
  font-size: 15px;
  line-height: 1.75;
  max-width: 640px;
  margin: 0;
}

/* =============================================================================
   2) NOTRE HISTOIRE
   ============================================================================= */
.ps-about__story {
  display: grid;
  grid-template-columns: 55fr 45fr;
  gap: 48px;
  align-items: center;
}
.ps-about__story-media { margin: 0; }
.ps-about__story-img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: 16px;
}
.ps-about__signature { margin-top: 24px; }
.ps-about__sign-name {
  display: block;
  font-family: var(--ps-font-body);
  font-weight: 600;
  color: var(--ps-gold);
  font-size: 16px;
}
.ps-about__sign-role {
  display: block;
  font-family: var(--ps-font-body);
  font-style: italic;
  color: var(--ps-muted);
  font-size: 14px;
  margin-top: 2px;
}

/* =============================================================================
   3) TIMELINE — Dix ans de croissance
   ============================================================================= */
.ps-about__timeline-block {
  background: var(--ps-cream-soft);
  border: 1px solid var(--ps-line);
  border-radius: 20px;
  padding: 48px 48px 52px;
  box-sizing: border-box;
}
.ps-about__timeline {
  list-style: none;
  margin: 34px 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}
.ps-about__milestone {
  position: relative;
  padding-top: 30px;
}
/* ligne horizontale reliant les points */
.ps-about__milestone::before {
  content: "";
  position: absolute;
  top: 51px; /* centré sur le dot */
  left: 0;
  right: -28px; /* traverse le gap vers la colonne suivante */
  height: 2px;
  background: var(--ps-line);
  z-index: 0;
}
.ps-about__milestone:last-child::before { right: 0; }
.ps-about__year {
  display: block;
  font-family: var(--ps-font-heading);
  color: var(--ps-gold);
  font-size: 28px;
  line-height: 1;
}
.ps-about__dot {
  position: relative;
  z-index: 1;
  display: block;
  width: 12px;
  height: 12px;
  margin: 12px 0 16px;
  border-radius: 50%;
  background: var(--ps-gold);
  box-shadow: 0 0 0 4px var(--ps-cream-soft);
}
.ps-about__ms-title {
  font-family: var(--ps-font-body);
  font-weight: 700;
  color: var(--ps-ink);
  font-size: 15px;
  margin: 0 0 8px;
}
.ps-about__ms-text {
  font-family: var(--ps-font-body);
  color: var(--ps-muted);
  font-size: 13px;
  line-height: 1.6;
  margin: 0;
}

/* =============================================================================
   4) THREE COLUMNS
   ============================================================================= */
.ps-about__cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}
.ps-about__checklist {
  list-style: none;
  margin: 0 0 16px;
  padding: 0;
}
.ps-about__checklist li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-family: var(--ps-font-body);
  color: var(--ps-body);
  font-size: 14px;
  line-height: 1.5;
  margin-bottom: 10px;
}
.ps-about__checklist svg {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  margin-top: 1px;
  color: var(--ps-gold);
  stroke-width: 2.4;
}

/* =============================================================================
   5) NOS VALEURS
   ============================================================================= */
.ps-about__values-head { margin-bottom: 26px; }
.ps-about__values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.ps-about__value-card {
  background: var(--ps-cream-soft);
  border: 1px solid var(--ps-line);
  border-radius: var(--ps-radius);
  padding: 28px;
  box-sizing: border-box;
}
.ps-about__value-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  margin-bottom: 18px;
  color: var(--ps-white);
}
.ps-about__value-icon svg { width: 22px; height: 22px; }
.ps-about__value-icon--olive { background: var(--ps-olive); }
.ps-about__value-icon--terracotta { background: var(--ps-terracotta); }
.ps-about__value-icon--gold { background: var(--ps-gold); }
.ps-about__value-title {
  font-family: var(--ps-font-body);
  font-weight: 700;
  color: var(--ps-ink);
  font-size: 17px;
  margin: 0 0 10px;
}
.ps-about__value-text {
  font-family: var(--ps-font-body);
  color: var(--ps-muted);
  font-size: 14px;
  line-height: 1.65;
  margin: 0;
}

/* =============================================================================
   6) NOS PROMOTRICES
   ============================================================================= */
.ps-about__team-head { margin-bottom: 26px; }
.ps-about__team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.ps-about__member-media {
  position: relative;
  margin-bottom: 16px;
}
.ps-about__member-img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 14px;
}
.ps-about__member-badge {
  position: absolute;
  left: 12px;
  bottom: 12px;
  background: var(--ps-gold);
  color: var(--ps-white);
  font-family: var(--ps-font-body);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: var(--ps-radius-pill);
}
.ps-about__member-name {
  font-family: var(--ps-font-body);
  font-weight: 700;
  color: var(--ps-ink);
  font-size: 16px;
  margin: 0 0 4px;
}
.ps-about__member-role {
  font-family: var(--ps-font-body);
  font-weight: 600;
  color: var(--ps-gold);
  font-size: 12px;
  margin: 0 0 8px;
}
.ps-about__member-bio {
  font-family: var(--ps-font-body);
  color: var(--ps-muted);
  font-size: 13px;
  line-height: 1.6;
  margin: 0;
}

/* =============================================================================
   7) NEWSLETTER — annule la double contrainte de .ps-section__inner
   ============================================================================= */
.ps-about .ps-section { margin-top: 64px; }
.ps-about .ps-section__inner {
  max-width: none;
  padding: 0;
}

/* =============================================================================
   RESPONSIVE
   ============================================================================= */
@media (max-width: 991px) {
  .ps-about__hero { padding: 40px 32px; }
  .ps-about__hero-title { font-size: 32px; }

  .ps-about__story { grid-template-columns: 1fr; gap: 32px; }
  .ps-about__story-media { order: -1; }
  .ps-about__story-img { aspect-ratio: 16 / 10; }

  .ps-about__timeline-block { padding: 36px 28px 40px; }
  .ps-about__timeline { grid-template-columns: repeat(2, 1fr); gap: 28px 24px; }
  .ps-about__milestone:nth-child(2n)::before { right: 0; }

  .ps-about__cols { grid-template-columns: 1fr; gap: 34px; }
  .ps-about__values-grid { grid-template-columns: 1fr; }
  .ps-about__team-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 560px) {
  .ps-about__inner { padding: 18px 16px 32px; }
  .ps-about__hero { padding: 32px 24px; }
  .ps-about__hero-title { font-size: 27px; }
  .ps-about__h2 { font-size: 25px; }

  .ps-about__timeline { grid-template-columns: 1fr; gap: 4px; }
  .ps-about__milestone { padding-top: 22px; padding-left: 24px; }
  .ps-about__milestone::before { /* passe en ligne verticale */
    top: 34px;
    bottom: -4px;
    left: 5px;
    right: auto;
    width: 2px;
    height: auto;
  }
  .ps-about__milestone:last-child::before { display: none; }
  .ps-about__dot { position: absolute; left: 0; top: 30px; margin: 0; }

  .ps-about__team-grid { grid-template-columns: 1fr; }
}
