/* AbHinc — Pages partagées (Conseil / Coaching / Formation / À propos / Contact)
   Builds on home.css and methode.css. Adds patterns reused across lever pages.
   ---------------------------------------------------------------- */

/* ---------- Bandeau de crédibilité (eyebrow mono pleine largeur) ---------- */
.credibilite {
  background: var(--paper-alt);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 28px 40px;
}
.credibilite-inner {
  max-width: var(--container); margin: 0 auto;
  display: flex; align-items: center; gap: 16px;
  flex-wrap: wrap;
  font-family: var(--mono);
  font-size: 13px; text-transform: uppercase; letter-spacing: 0.12em;
  color: var(--night);
}
.credibilite-inner .arrow { color: var(--sage); display: inline-flex; }
.credibilite-inner .sep {
  width: 28px; height: 1px; background: var(--line);
  display: inline-block;
}
.credibilite-inner .item { color: var(--mute); }
.credibilite-inner .item strong { color: var(--night); font-weight: 500; }

/* ---------- "Quand nous appeler" (liste de cas) ---------- */
.quand {
  padding: 120px 40px;
  background: var(--paper);
  position: relative; overflow: hidden;
}
.quand.alt { background: var(--paper-alt); }
.quand-bg-bang {
  position: absolute; right: -100px; top: -40px;
  opacity: 0.06; color: var(--sage); pointer-events: none;
}
.quand-inner {
  max-width: var(--container); margin: 0 auto;
  position: relative;
  display: grid; grid-template-columns: 0.85fr 1.15fr;
  gap: 80px; align-items: start;
}
.quand-head .ds-eyebrow { color: var(--sage); }
.quand-title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1.02; letter-spacing: -0.025em;
  color: var(--night); margin: 16px 0 0;
  text-wrap: balance;
}
.quand-title em { font-style: italic; color: var(--sage); }
.quand-list {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--line);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.quand-item {
  background: var(--paper);
  padding: 28px 28px 32px;
  display: grid; grid-template-columns: 36px 1fr;
  gap: 16px; align-items: start;
  position: relative;
}
.quand.alt .quand-item { background: var(--paper-alt); }
.quand-item .bang-bullet {
  color: var(--sage); display: inline-flex;
  margin-top: 2px;
}
.quand-item p {
  margin: 0;
  font-family: var(--sans); font-size: 16px; line-height: 1.55;
  color: var(--ink);
  text-wrap: pretty;
}
.quand-item p strong { font-weight: 500; color: var(--night); }
.quand-item p em { font-style: italic; color: var(--night); }

/* ---------- "Ce que nous faisons" (prose dense avec accent) ---------- */
.faisons {
  padding: 120px 40px;
  background: var(--paper);
  position: relative; overflow: hidden;
}
.faisons.alt { background: var(--paper-alt); }
.faisons-inner {
  max-width: var(--container); margin: 0 auto;
  position: relative;
  display: grid; grid-template-columns: 0.85fr 1.15fr;
  gap: 80px; align-items: start;
}
.faisons-head .ds-eyebrow { color: var(--sage); }
.faisons-title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1.02; letter-spacing: -0.025em;
  color: var(--night); margin: 16px 0 0;
  text-wrap: balance;
}
.faisons-title em { font-style: italic; color: var(--sage); }
.faisons-body {
  display: flex; flex-direction: column; gap: 24px;
  max-width: 680px;
}
.faisons-body p {
  font-family: var(--sans); font-size: 18px; line-height: 1.65;
  color: var(--ink); margin: 0; text-wrap: pretty;
}
.faisons-body p strong { font-weight: 500; color: var(--night); }
.faisons-body p em { font-style: italic; color: var(--night); }
.faisons-body .pullquote {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(22px, 2.2vw, 30px); line-height: 1.3;
  letter-spacing: -0.015em; color: var(--night);
  margin: 8px 0;
  padding: 0 0 0 24px;
  border-left: 3px solid var(--sage);
  text-wrap: pretty;
}
.faisons-body .pullquote em { font-style: italic; }

/* ---------- "Nos formats" (liste deux colonnes) ---------- */
.formats {
  padding: 120px 40px;
  background: var(--paper);
  position: relative;
}
.formats.alt { background: var(--paper-alt); }
.formats-inner {
  max-width: var(--container); margin: 0 auto;
}
.formats-head { max-width: 680px; margin-bottom: 64px; }
.formats-eyebrow { color: var(--sage); }
.formats-title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(36px, 4.6vw, 64px);
  line-height: 1.05; letter-spacing: -0.025em;
  color: var(--night); margin: 16px 0 0;
}
.formats-title em { font-style: italic; color: var(--sage); }
.formats-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.format-card {
  background: var(--paper-alt);
  border-radius: 16px;
  padding: 36px 32px;
  display: flex; flex-direction: column; gap: 14px;
  position: relative; overflow: hidden;
  min-height: 200px;
}
.formats.alt .format-card { background: var(--paper); border: 1px solid var(--line); }
.format-card .format-num {
  font-family: var(--mono); font-size: 12px;
  letter-spacing: 0.14em; color: var(--sage);
  text-transform: uppercase;
}
.format-card .format-name {
  font-family: var(--serif); font-weight: 400;
  font-size: 26px; line-height: 1.15; letter-spacing: -0.015em;
  color: var(--night); margin: 0;
}
.format-card .format-name em { font-style: italic; }
.format-card .format-desc {
  font-size: 15px; line-height: 1.6;
  color: var(--mute); margin: 0;
}
.format-card .format-meta {
  margin-top: auto;
  font-family: var(--mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.12em;
  color: var(--mute);
  padding-top: 14px; border-top: 1px solid var(--line);
}

/* ---------- "Souvent combiné avec" (2 petites cartes) ---------- */
.combine {
  padding: 120px 40px;
  background: var(--paper);
  border-top: 1px solid var(--line);
  position: relative;
}
.combine.dark {
  background: var(--night); color: #fff;
  border-top-color: rgba(255, 255, 255, 0.12);
}
.combine-inner { max-width: var(--container); margin: 0 auto; }
.combine-head {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 64px; align-items: end;
  margin-bottom: 56px;
}
.combine-eyebrow { color: var(--sage); }
.combine-title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(36px, 4.4vw, 60px);
  line-height: 1.05; letter-spacing: -0.025em;
  color: var(--night); margin: 16px 0 0;
}
.combine.dark .combine-title { color: #fff; }
.combine-title em { font-style: italic; color: var(--sage); }
.combine-aside {
  font-family: var(--sans); font-size: 16px;
  line-height: 1.6; color: var(--mute); max-width: 360px;
  margin: 0;
}
.combine.dark .combine-aside { color: rgba(255, 255, 255, 0.7); }
.combine-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.combine-card {
  background: var(--paper-alt);
  border-radius: 16px;
  padding: 32px;
  display: flex; flex-direction: column; gap: 16px;
  position: relative; overflow: hidden;
  text-decoration: none; color: inherit;
  transition: background var(--t-base), transform var(--t-base);
}
.combine.dark .combine-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: #fff;
}
.combine-card:hover { background: var(--paper); transform: translateY(-2px); }
.combine.dark .combine-card:hover {
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(127, 194, 155, 0.4);
}
.combine-card .combine-bang {
  position: absolute; right: -16px; bottom: -16px;
  color: var(--sage); opacity: 0.10;
}
.combine-card .combine-card-name {
  font-family: var(--mono); font-size: 12px;
  letter-spacing: 0.14em; color: var(--sage);
  text-transform: uppercase;
}
.combine-card .combine-card-title {
  font-family: var(--serif); font-weight: 400;
  font-size: 22px; line-height: 1.2; letter-spacing: -0.01em;
  color: var(--night); margin: 0;
}
.combine.dark .combine-card .combine-card-title { color: #fff; }
.combine-card .combine-card-title em { font-style: italic; }
.combine-card .combine-card-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--sans); font-size: 14px; font-weight: 500;
  color: var(--night);
  padding-bottom: 4px; border-bottom: 1px solid var(--night);
  align-self: flex-start;
  margin-top: 4px;
  transition: gap var(--t-base);
}
.combine.dark .combine-card .combine-card-link {
  color: var(--sage); border-bottom-color: var(--sage);
}
.combine-card:hover .combine-card-link { gap: 12px; }

/* ---------- Encart "Cas spécifique" (pilotage conseil) ---------- */
.cas-specifique {
  padding: 120px 40px;
  background: var(--paper-alt);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  position: relative; overflow: hidden;
}
.cas-bg-bang {
  position: absolute; right: -80px; bottom: -80px;
  color: var(--sage); opacity: 0.10; pointer-events: none;
}
.cas-inner {
  max-width: 1080px; margin: 0 auto;
  position: relative;
  background: var(--paper);
  border-radius: 16px;
  padding: 56px 56px 56px 64px;
  border-left: 6px solid var(--sage);
  display: grid; grid-template-columns: 0.7fr 1.3fr;
  gap: 64px; align-items: start;
}
.cas-head .ds-eyebrow { color: var(--sage); }
.cas-title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.1; letter-spacing: -0.015em;
  color: var(--night); margin: 16px 0 0;
}
.cas-title em { font-style: italic; }
.cas-body {
  display: flex; flex-direction: column; gap: 18px;
}
.cas-body p {
  margin: 0; font-family: var(--sans);
  font-size: 16px; line-height: 1.6; color: var(--ink);
  text-wrap: pretty;
}
.cas-body p em { font-style: italic; color: var(--night); }
.cas-body p strong { font-weight: 500; color: var(--night); }
.cas-tags {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-top: 8px;
}
.cas-tags span {
  font-family: var(--mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.1em;
  padding: 5px 10px; border-radius: 999px;
  background: var(--paper-alt); color: var(--mute);
  border: 1px solid var(--line);
}

/* ---------- Coaching illimité (section dédiée full-bleed) ---------- */
.illimite {
  padding: 140px 40px;
  background: var(--night); color: #fff;
  position: relative; overflow: hidden;
}
.illimite-bg-bang-1 {
  position: absolute; right: -60px; top: -40px;
  color: var(--sage); opacity: 0.12; pointer-events: none;
}
.illimite-bg-bang-2 {
  position: absolute; left: -120px; bottom: -120px;
  color: var(--teal); opacity: 0.06; pointer-events: none;
}
.illimite-inner { max-width: var(--container); margin: 0 auto; position: relative; }
.illimite-mini-hero {
  display: grid; grid-template-columns: 0.85fr 1.15fr;
  gap: 64px; align-items: end;
  margin-bottom: 80px;
}
.illimite-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 6px 14px; background: var(--sage); color: var(--night);
  border-radius: 999px;
  font-family: var(--mono);
  font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em;
  white-space: nowrap;
  margin-bottom: 24px;
}
.illimite-title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(48px, 6.5vw, 100px);
  line-height: 0.96; letter-spacing: -0.035em;
  color: #fff; margin: 0;
  text-wrap: balance;
}
.illimite-title em { font-style: italic; color: var(--sage); }
.illimite-title .punct { color: var(--sage); }
.illimite-lead {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(22px, 2.2vw, 28px); line-height: 1.35;
  color: rgba(255, 255, 255, 0.85);
  margin: 0; text-wrap: pretty;
}
.illimite-lead em { font-style: italic; color: var(--sage); }
.illimite-pitch {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(30px, 3vw, 42px); line-height: 1.25;
  letter-spacing: -0.015em;
  color: var(--sage); margin: 0 0 40px;
  text-wrap: pretty;
}
.illimite-pitch em { font-style: italic; color: #fff; }
.illimite-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 48px; align-items: start;
  margin-top: 40px;
}
.illimite-prose {
  display: flex; flex-direction: column; gap: 20px;
}
.illimite-prose p {
  font-family: var(--sans); font-size: 17px; line-height: 1.65;
  color: rgba(255, 255, 255, 0.85);
  margin: 0; text-wrap: pretty;
}
.illimite-prose p strong { font-weight: 500; color: #fff; }
.illimite-prose p em { font-style: italic; color: var(--sage); }
.illimite-prose .neg {
  font-family: var(--serif); font-weight: 400;
  font-size: 22px; line-height: 1.35;
  color: #fff;
  padding: 16px 0 16px 24px;
  border-left: 3px solid var(--sage);
}
.illimite-mecanique {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 16px;
  padding: 32px;
  display: flex; flex-direction: column; gap: 20px;
}
.illimite-mecanique-title {
  font-family: var(--mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--sage);
  padding-bottom: 12px; border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}
.illimite-step {
  display: grid; grid-template-columns: 28px 1fr;
  gap: 14px; align-items: start;
}
.illimite-step .bang-bullet {
  color: var(--sage); display: inline-flex; margin-top: 1px;
}
.illimite-step p {
  margin: 0; font-family: var(--sans);
  font-size: 15px; line-height: 1.55;
  color: rgba(255, 255, 255, 0.85);
}
.illimite-step p strong { font-weight: 500; color: #fff; }
.illimite-step p em { font-style: italic; color: var(--sage); }
.illimite-footnote {
  margin-top: 24px;
  font-family: var(--mono); font-size: 12px;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: rgba(255, 255, 255, 0.5);
}

/* ---------- About: valeurs ---------- */
.valeurs {
  padding: 140px 40px;
  background: var(--paper-alt);
  position: relative; overflow: hidden;
}
.valeurs-bg-bang {
  position: absolute; right: -80px; top: -40px;
  color: var(--sage); opacity: 0.08; pointer-events: none;
}
.valeurs-inner { max-width: var(--container); margin: 0 auto; position: relative; }
.valeurs-head {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: end;
  margin-bottom: 64px;
}
.valeurs-eyebrow { color: var(--sage); }
.valeurs-title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(44px, 5.5vw, 84px);
  line-height: 1; letter-spacing: -0.03em;
  color: var(--night); margin: 16px 0 0;
}
.valeurs-title em { font-style: italic; color: var(--sage); }
.valeurs-aside {
  font-family: var(--sans); font-size: 16px;
  line-height: 1.6; color: var(--mute); max-width: 380px;
  margin: 0;
}
.valeurs-grid {
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: var(--line);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.valeur {
  background: var(--paper-alt);
  padding: 36px 28px;
  display: flex; flex-direction: column; gap: 14px;
  position: relative;
}
.valeur .valeur-bang { color: var(--sage); display: inline-flex; }
.valeur .valeur-num {
  font-family: var(--mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--mute);
}
.valeur .valeur-name {
  font-family: var(--serif); font-weight: 500;
  font-size: 22px; line-height: 1.15; letter-spacing: -0.01em;
  color: var(--night); margin: 0;
}
.valeur .valeur-name em { font-style: italic; }
.valeur .valeur-desc {
  font-family: var(--sans); font-size: 14px; line-height: 1.55;
  color: var(--mute); margin: 0;
  text-wrap: pretty;
}

/* ---------- About: team ---------- */
.team {
  padding: 140px 40px;
  background: var(--paper);
  position: relative; overflow: hidden;
}
.team-inner { max-width: var(--container); margin: 0 auto; }
.team-head { max-width: 880px; margin-bottom: 80px; }
.team-eyebrow { color: var(--sage); }
.team-title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(44px, 5.5vw, 84px);
  line-height: 1; letter-spacing: -0.03em;
  color: var(--night); margin: 16px 0 0;
}
.team-title em { font-style: italic; color: var(--sage); }
.team-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 48px;
}
.team-member {
  display: grid; grid-template-columns: 240px 1fr;
  gap: 36px; align-items: start;
}
.member-photo-wrap {
  position: relative; border-radius: 12px;
  overflow: hidden;
  background: var(--paper-alt);
  width: 240px; height: 300px;
  background-image: repeating-linear-gradient(35deg, rgba(228, 222, 211, 0.6) 0 8px, transparent 8px 14px);
  display: flex; align-items: center; justify-content: center;
}
.member-photo-wrap.tone-sage { background-color: var(--sage); }
.member-photo-wrap img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}
.member-photo-wrap .placeholder-label {
  font-family: var(--mono); font-size: 11px;
  color: var(--mute); letter-spacing: 0.05em;
  text-transform: uppercase;
  background: rgba(251, 248, 243, 0.8);
  padding: 4px 10px; border-radius: 999px;
}
.member-photo-wrap .member-index {
  position: absolute; top: 14px; left: 14px;
  padding: 4px 10px;
  background: var(--night); color: #fff;
  border-radius: 999px;
  font-size: 11px; font-family: var(--mono);
  letter-spacing: 0.08em;
}
.member-info { padding-top: 8px; }
.member-name {
  font-family: var(--serif); font-weight: 500;
  font-size: 30px; line-height: 1.1; letter-spacing: -0.015em;
  color: var(--night); margin: 0;
}
.member-role {
  font-family: var(--mono); font-size: 12px;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--sage); margin-top: 8px;
}
.member-bio {
  font-family: var(--sans); font-size: 15px; line-height: 1.65;
  color: var(--mute); margin-top: 18px;
  display: flex; flex-direction: column; gap: 12px;
}
.member-bio p { margin: 0; text-wrap: pretty; }
.member-bio p strong { font-weight: 500; color: var(--night); }
.member-bio p em { font-style: italic; color: var(--night); }

/* ---------- About: réseau (logos) ---------- */
.reseau {
  padding: 96px 40px;
  background: var(--paper-alt);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.reseau-inner {
  max-width: var(--container); margin: 0 auto;
  display: grid; grid-template-columns: 0.7fr 1.3fr;
  gap: 64px; align-items: center;
}
.reseau-text { max-width: 360px; }
.reseau-eyebrow {
  font-family: var(--mono); font-size: 12px;
  text-transform: uppercase; letter-spacing: 0.12em;
  color: var(--sage); margin-bottom: 14px;
}
.reseau-headline {
  font-family: var(--serif); font-weight: 400;
  font-size: 26px; line-height: 1.25; letter-spacing: -0.01em;
  color: var(--night); margin: 0 0 16px;
}
.reseau-headline em { font-style: italic; }
.reseau-body {
  font-family: var(--sans); font-size: 15px; line-height: 1.6;
  color: var(--mute); margin: 0; text-wrap: pretty;
}

/* ---------- Contact: hero sage + form ---------- */
.contact-hero {
  background: var(--sage); color: var(--night);
  padding: 100px 40px;
  position: relative; overflow: hidden;
}
.contact-hero-bg-bang {
  position: absolute; right: -80px; top: -60px;
  color: var(--night); opacity: 0.22; pointer-events: none;
}
.contact-hero-bg-bang-2 {
  position: absolute; left: -80px; bottom: -120px;
  color: var(--night); opacity: 0.10; pointer-events: none;
}
.contact-hero-inner {
  max-width: var(--container); margin: 0 auto;
  position: relative;
}
.contact-hero-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 6px 14px;
  background: var(--night); color: #fff;
  border-radius: 999px;
  font-family: var(--mono);
  font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em;
  margin-bottom: 40px;
  white-space: nowrap;
}
.contact-hero-eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--sage); display: inline-block; }
.contact-hero-title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(60px, 8vw, 140px);
  line-height: 0.92; letter-spacing: -0.035em;
  color: var(--night); margin: 0;
}
.contact-hero-title em { font-style: italic; }
.contact-hero-title .punct { color: var(--night); }
.contact-hero-row {
  display: grid; grid-template-columns: 1.1fr 1fr;
  gap: 64px; align-items: start;
  margin-top: 56px;
}
.contact-hero-lead {
  font-family: var(--sans); font-size: 20px; line-height: 1.55;
  color: var(--night); opacity: 0.85; max-width: 540px;
  margin: 0; text-wrap: pretty;
}
.contact-hero-meta {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  padding: 24px 0;
  border-top: 1px solid rgba(30, 42, 58, 0.18);
  border-bottom: 1px solid rgba(30, 42, 58, 0.18);
}
.contact-hero-meta .l {
  font-family: var(--mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--night); opacity: 0.65;
}
.contact-hero-meta .v {
  font-family: var(--mono); font-size: 13px;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--night); font-weight: 500;
  margin-top: 4px;
}

/* form section */
.contact-form-section {
  padding: 120px 40px;
  background: var(--paper);
  position: relative;
}
.contact-form-inner {
  max-width: var(--container); margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1.5fr;
  gap: 96px; align-items: start;
}
.contact-form-aside {
  position: sticky; top: 100px;
}
.contact-form-aside .ds-eyebrow { color: var(--sage); }
.contact-form-aside-title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(32px, 3.6vw, 52px);
  line-height: 1.05; letter-spacing: -0.025em;
  color: var(--night); margin: 16px 0 32px;
}
.contact-form-aside-title em { font-style: italic; color: var(--sage); }
.contact-coords {
  display: flex; flex-direction: column; gap: 18px;
  padding: 24px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.contact-coords .row {
  display: grid; grid-template-columns: 80px 1fr;
  gap: 16px; align-items: baseline;
}
.contact-coords .l {
  font-family: var(--mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.12em;
  color: var(--mute);
}
.contact-coords .v {
  font-family: var(--sans); font-size: 15px;
  color: var(--ink); line-height: 1.5;
}
.contact-coords .v a { border-bottom: 1px solid var(--line); }
.contact-coords .v a:hover { border-bottom-color: var(--night); }
.contact-coords .v .sub {
  font-family: var(--mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--mute); display: block; margin-top: 2px;
}

.contact-form {
  background: var(--paper-alt);
  border-radius: 16px;
  padding: 48px;
}
.contact-form .form-required-note {
  font-size: 11px; color: var(--mute);
  font-family: var(--mono); letter-spacing: 0.08em;
  margin: 0 0 24px;
  text-transform: uppercase;
}
.contact-form .form-required-note span { color: var(--teal); font-weight: 600; }
.contact-form form {
  display: grid; gap: 26px;
}
.contact-form .row2 {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 26px;
}
.contact-form .field { display: block; }
.contact-form .field-label {
  font-family: var(--sans); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.12em;
  color: var(--mute); font-weight: 500;
  display: block;
}
.contact-form .field-label.required::after { content: ' *'; color: var(--teal); font-weight: 600; }
.contact-form .field input,
.contact-form .field textarea {
  width: 100%; background: transparent;
  border: none; border-bottom: 1px solid var(--line);
  padding: 12px 0; font-size: 16px;
  font-family: inherit; color: var(--ink);
  outline: none; border-radius: 0;
  transition: border-color var(--t-fast);
}
.contact-form .field textarea { resize: vertical; min-height: 80px; padding-top: 14px; }
.contact-form .field input:focus,
.contact-form .field textarea:focus { border-bottom-color: var(--night); }
.contact-form .field input.error,
.contact-form .field textarea.error { border-bottom-color: var(--teal); }
.contact-form .field-error {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.05em; color: var(--teal);
  margin-top: 6px;
}

.need-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.need-tag {
  padding: 8px 14px; border-radius: 999px;
  border: 1px solid var(--line); background: transparent;
  color: var(--ink); font-size: 13px; cursor: pointer;
  font-family: inherit; transition: all var(--t-fast);
}
.need-tag.active { border-color: var(--night); background: var(--night); color: #fff; }

.contact-form-foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; flex-wrap: wrap;
}
.contact-form-disclaimer {
  font-size: 12px; color: var(--mute);
  max-width: 360px; line-height: 1.5;
}
.contact-form .btn-submit {
  padding: 16px 26px; background: var(--night); color: #fff;
  border: none; border-radius: 999px;
  font-size: 15px; font-weight: 500;
  display: inline-flex; align-items: center; gap: 10px;
  cursor: pointer;
  transition: opacity var(--t-fast);
}
.contact-form .btn-submit:hover { opacity: 0.92; }

/* form sent state */
.contact-form-sent {
  padding: 36px 0;
  display: flex; flex-direction: column; gap: 16px;
}
.contact-form-sent .sent-tag {
  font-family: var(--mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--sage);
}
.contact-form-sent h3 {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.1; letter-spacing: -0.02em;
  color: var(--night); margin: 0;
}
.contact-form-sent h3 em { font-style: italic; color: var(--sage); }
.contact-form-sent p {
  font-family: var(--sans); font-size: 16px; line-height: 1.55;
  color: var(--mute); margin: 0;
}
.contact-form-sent p strong { color: var(--night); font-weight: 500; }

/* ---------- Contact: bandeau 3 manques ---------- */
.contact-3manques {
  padding: 120px 40px;
  background: var(--paper-alt);
  border-top: 1px solid var(--line);
}
.contact-3manques-inner { max-width: var(--container); margin: 0 auto; }
.contact-3manques-head {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 64px; align-items: end;
  margin-bottom: 56px;
}
.contact-3manques-eyebrow { color: var(--sage); }
.contact-3manques-title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(36px, 4.4vw, 60px);
  line-height: 1.05; letter-spacing: -0.025em;
  color: var(--night); margin: 16px 0 0;
}
.contact-3manques-title em { font-style: italic; color: var(--sage); }
.contact-3manques-aside {
  font-family: var(--sans); font-size: 16px; line-height: 1.6;
  color: var(--mute); margin: 0; max-width: 380px;
}
.contact-3manques-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.compact-manque {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 28px 28px 24px;
  display: flex; flex-direction: column; gap: 14px;
  text-decoration: none; color: inherit;
  transition: background var(--t-base), transform var(--t-base), border-color var(--t-base);
  position: relative; overflow: hidden;
}
.compact-manque:hover {
  background: #fff; transform: translateY(-2px);
  border-color: var(--sage);
}
.compact-manque .cm-bang {
  position: absolute; right: -14px; bottom: -16px;
  color: var(--sage); opacity: 0.10;
}
.compact-manque .cm-num {
  font-family: var(--mono); font-size: 12px;
  letter-spacing: 0.14em; color: var(--sage);
  text-transform: uppercase;
}
.compact-manque .cm-title {
  font-family: var(--serif); font-weight: 400;
  font-size: 22px; line-height: 1.15; letter-spacing: -0.01em;
  color: var(--night); margin: 0;
}
.compact-manque .cm-title em { font-style: italic; }
.compact-manque .cm-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--sans); font-size: 13px; font-weight: 500;
  color: var(--night);
  align-self: flex-start;
  transition: gap var(--t-base);
}
.compact-manque:hover .cm-link { gap: 12px; }

/* ---------- Domaines (formation) ---------- */
.domaines {
  padding: 120px 40px;
  background: var(--paper);
  position: relative;
}
.domaines-inner { max-width: var(--container); margin: 0 auto; }
.domaines-head { max-width: 720px; margin-bottom: 56px; }
.domaines-eyebrow { color: var(--sage); }
.domaines-title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(36px, 4.4vw, 60px);
  line-height: 1.05; letter-spacing: -0.025em;
  color: var(--night); margin: 16px 0 0;
}
.domaines-title em { font-style: italic; color: var(--sage); }
.domaines-aside {
  margin-top: 28px;
  font-family: var(--sans); font-size: 16px; line-height: 1.55;
  color: var(--mute); max-width: 580px; text-wrap: pretty;
}
.domaines-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--line);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.domaine {
  background: var(--paper);
  padding: 40px 28px;
  display: flex; flex-direction: column; gap: 14px;
  position: relative; overflow: hidden;
}
.domaine .domaine-bang { color: var(--sage); display: inline-flex; }
.domaine .domaine-name {
  font-family: var(--serif); font-weight: 400;
  font-size: 26px; line-height: 1.15; letter-spacing: -0.015em;
  color: var(--night); margin: 0;
}
.domaine .domaine-name em { font-style: italic; }
.domaine .domaine-desc {
  font-family: var(--sans); font-size: 14px; line-height: 1.55;
  color: var(--mute); margin: 0; text-wrap: pretty;
}

/* ---------- responsive ---------- */
@media (max-width: 1024px) {
  .quand-inner { grid-template-columns: 1fr; gap: 32px; }
  .faisons-inner { grid-template-columns: 1fr; gap: 32px; }
  .combine-head { grid-template-columns: 1fr; gap: 24px; }
  .combine-grid { grid-template-columns: 1fr; }
  .cas-inner { grid-template-columns: 1fr; gap: 32px; padding: 40px 32px 40px 40px; }
  .illimite-mini-hero { grid-template-columns: 1fr; gap: 24px; align-items: start; }
  .illimite-grid { grid-template-columns: 1fr; gap: 32px; }
  .valeurs-head { grid-template-columns: 1fr; gap: 24px; }
  .valeurs-grid { grid-template-columns: repeat(2, 1fr); }
  .team-grid { grid-template-columns: 1fr; }
  .reseau-inner { grid-template-columns: 1fr; gap: 32px; }
  .formats-grid { grid-template-columns: 1fr; }
  .contact-hero-row { grid-template-columns: 1fr; gap: 32px; }
  .contact-form-inner { grid-template-columns: 1fr; gap: 48px; }
  .contact-form-aside { position: static; }
  .contact-3manques-head { grid-template-columns: 1fr; gap: 24px; }
  .contact-3manques-grid { grid-template-columns: 1fr; }
  .domaines-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
  .credibilite, .quand, .faisons, .formats, .combine, .cas-specifique,
  .illimite, .valeurs, .team, .reseau, .contact-hero,
  .contact-form-section, .contact-3manques, .domaines {
    padding-left: 24px; padding-right: 24px;
  }
  .quand, .faisons, .formats, .combine, .cas-specifique, .illimite,
  .valeurs, .team, .contact-form-section, .contact-3manques, .domaines {
    padding-top: 72px; padding-bottom: 72px;
  }
  .reseau { padding-top: 56px; padding-bottom: 56px; }
  .quand-list { grid-template-columns: 1fr; }
  .valeurs-grid { grid-template-columns: 1fr; }
  .team-member { grid-template-columns: 1fr; gap: 20px; }
  .member-photo-wrap { width: 100%; height: 280px; }
  .cas-inner { padding: 32px 24px 32px 32px; }
  .contact-form { padding: 28px; }
  .contact-form .row2 { grid-template-columns: 1fr; }
  .contact-hero { padding-top: 56px; padding-bottom: 56px; }
  .contact-hero-meta { grid-template-columns: 1fr 1fr; }
  .domaines-grid { grid-template-columns: 1fr; }
}
