/* ══════════════════════════════════════════
   COMPONENTS — Boutons, cards, badges, typographie
   Système 9 couleurs v4
   ══════════════════════════════════════════ */

/* ── Typographie ── */
h2 { font-size: clamp(1.75rem, 2.7vw, 2.75rem); font-weight: 700; line-height: 1.15; margin-bottom: 1.2rem; }
h2 em { font-style: italic; font-weight: 300; color: inherit; }
h2.on-dark { color: var(--zv-white); }
h2.on-dark em { color: rgba(255,255,255,.75); }
h3 { font-size: 1.1rem; font-weight: 700; line-height: 1.3; margin-bottom: .6rem; }
.lead { font-size: .97rem; font-weight: 400; line-height: 1.8; color: var(--c2l); max-width: 640px; }
.lead.on-dark { color: rgba(255,255,255,.62); }
.body-text { font-size: .95rem; font-weight: 400; color: var(--c2l); line-height: 1.85; margin-bottom: 1.2rem; }

.eyebrow {
  display: inline-flex; align-items: center; gap: .6rem;
  font-size: .7rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase;
  color: var(--c2l); margin-bottom: 1.8rem;
  animation: fadeUp .7s ease both;
}
.eyebrow::before { content: ''; width: 24px; height: 2px; background: var(--c1); display: block; }

.section-tag {
  display: inline-flex; align-items: center; gap: .6rem;
  font-size: .8rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase;
  color: var(--c2l); margin-bottom: 1rem;
}
.section-tag::before { content: ''; display: block; width: 20px; height: 2px; background: var(--c1); }
.section-tag.muted { color: rgba(255,255,255,.45); }
.section-tag.muted::before { background: rgba(255,255,255,.25); }
.section-tag.center { justify-content: center; }

/* ── Boutons ── */
.btn {
  display: inline-block; font-family: var(--ff);
  font-size: .76rem; font-weight: 700; letter-spacing: .09em; text-transform: uppercase;
  text-decoration: none; padding: .85rem 1.85rem;
  border-radius: var(--radius); cursor: pointer; border: none;
  transition: all .22s;
}
.btn-primary   { background: var(--c3); color: var(--zv-white); }
.btn-primary:hover { background: var(--c3d); }
.btn-outline   { background: transparent; color: var(--c2); border: 2px solid var(--c2); }
.btn-outline:hover { border-color: var(--c2d); color: var(--c2d); }
.btn-dark      { background: var(--c2); color: var(--zv-white); }
.btn-dark:hover { background: var(--c2d); }
.btn-accent    { background: var(--c3); color: var(--zv-white); }
.btn-accent:hover { background: var(--c3d); }
.btn-ghost-dark { background: transparent; color: var(--zv-white); border: 2px solid rgba(255,255,255,.35); }
.btn-ghost-dark:hover { border-color: rgba(255,255,255,.7); }
.btn-full { width: 100%; text-align: center; }

/* ── Hero ── */
.hero-tagline {
  font-size: clamp(2.3rem, 3.6vw, 3.8rem); font-weight: 700;
  line-height: 1.1; color: var(--c2); margin-bottom: 1rem;
  animation: fadeUp .7s ease .1s both;
}
.hero-tagline em { font-style: italic; font-weight: 300; color: var(--c2); }
.hero-sub {
  font-size: 1rem; font-weight: 400; color: var(--c2l);
  line-height: 1.8; max-width: 500px; margin-bottom: 2.3rem;
  animation: fadeUp .7s ease .2s both;
}
.hero-btns { display: flex; gap: 1rem; flex-wrap: wrap; animation: fadeUp .7s ease .35s both; }
.hero-stats {
  display: flex; gap: 2.5rem; margin-top: 2.5rem;
  padding-top: 1.8rem; border-top: 1px solid var(--zv-border);
  animation: fadeUp .7s ease .5s both; flex-wrap: wrap;
}
.stat-num   { font-size: 1.9rem; font-weight: 700; color: var(--c2); line-height: 1; }
.stat-label { font-size: .7rem; font-weight: 400; letter-spacing: .05em; color: var(--c2l); margin-top: .3rem; }
.hero-badge {
  display: inline-flex; align-items: center; gap: .5rem;
  background: var(--c2); padding: .5rem 1.1rem; border-radius: 4px;
  font-size: .68rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: var(--zv-white); width: fit-content;
  animation: fadeUp .7s ease .5s both;
}
.hero-quote-area { animation: fadeUp .7s ease .7s both; }
.hero-quote-line { width: 36px; height: 2px; background: rgba(255,255,255,.3); margin-bottom: 1.3rem; }
.hero-quote {
  font-size: 1.45rem; font-weight: 300; font-style: italic;
  color: rgba(255,255,255,.87); line-height: 1.55; margin-bottom: 1.2rem;
}
.hero-quote strong { font-weight: 700; font-style: normal; color: var(--zv-white); }
.hero-quote-author { font-size: .68rem; font-weight: 700; letter-spacing: .13em; text-transform: uppercase; color: rgba(255,255,255,.38); }

/* ── Cards piliers ── */
.card {
  background: var(--zv-white); padding: 2.4rem 2rem;
  border-top: 2px solid var(--zv-border);
  transition: border-color .25s, background .25s;
}
.card:hover { border-top-color: var(--c1); background: var(--zv-light); }
.card-icon { display: none; }
.card h3   { color: var(--c2); }
.card p    { font-size: .86rem; font-weight: 400; color: var(--c2l); line-height: 1.7; margin-top: .45rem; }

/* ── Offres ── */
.offre-card {
  background: var(--zv-light); padding: 2.6rem 2.3rem;
  border-top: 2px solid var(--zv-border); transition: border-color .25s, background .25s;
}
.offre-card:hover { border-top-color: var(--c1); background: var(--zv-white); }
.offre-num { font-size: .67rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--c2l); margin-bottom: .9rem; }
.offre-card h3 { color: var(--c2); margin-bottom: .65rem; }
.offre-card p  { font-size: .86rem; font-weight: 400; color: var(--c2l); line-height: 1.7; margin-bottom: 1.2rem; }
.offre-link {
  font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: var(--c2); text-decoration: none;
  display: inline-flex; align-items: center; gap: .35rem;
}
.offre-link::after { content: '→'; }
.offre-link:hover  { color: var(--c2d); }

/* ── Résultats ── */
.result-item { text-align: center; padding: 2.2rem 1rem; }
.result-num  { font-size: 2.6rem; font-weight: 700; color: var(--zv-white); line-height: 1; margin-bottom: .45rem; }
.result-label { font-size: .78rem; font-weight: 400; color: rgba(255,255,255,.42); line-height: 1.5; }

/* ── Cas clients ── */
.cas-card { background: var(--zv-white); padding: 2.4rem 2.2rem; border-top: 2px solid var(--zv-border); }
.cas-card blockquote {
  font-size: .93rem; font-style: italic; font-weight: 400; color: var(--c2l);
  line-height: 1.65; border-left: 2px solid var(--c1);
  padding-left: 1rem; margin-bottom: 1.5rem;
}
.cas-card h3    { font-size: 1.05rem; margin-bottom: .45rem; }
.cas-desc       { font-size: .84rem; font-weight: 300; color: var(--c2l); line-height: 1.7; margin-bottom: 1rem; }
.cas-result     { display: flex; align-items: flex-start; gap: .7rem; padding: .38rem 0; border-bottom: 1px solid var(--zv-border); font-size: .84rem; }
.cas-result:last-child { border-bottom: none; }
.cas-result-num   { font-weight: 700; color: var(--c2); min-width: 70px; }
.cas-result-label { font-weight: 300; color: var(--c2l); }

/* ── Principes ── */
.principe-card { background: var(--zv-white); padding: 1.7rem; border-top: 2px solid var(--zv-border); transition: border-top-color .2s, background .2s; }
.principe-card:hover { border-top-color: var(--c1); background: var(--zv-light); }
.principe-card h3 { font-size: .88rem; font-weight: 700; color: var(--c2); margin-bottom: .4rem; }
.principe-card p  { font-size: .83rem; font-weight: 300; color: var(--c2l); line-height: 1.7; }

/* ── Pills ── */
.dim-row  { display: flex; gap: .7rem; flex-wrap: wrap; margin: 1.8rem 0; }
.dim-pill { background: var(--c2); color: var(--zv-white); padding: .45rem 1.1rem; border-radius: 4px; font-size: .72rem; font-weight: 700; letter-spacing: .05em; }
.tag-pill { display: inline-block; background: var(--zv-light); color: var(--c2); border: 1px solid var(--zv-border); padding: .3rem .82rem; border-radius: 4px; font-size: .73rem; font-weight: 700; margin: .2rem; }
.tag-accent { display: inline-block; background: var(--zv-light); color: var(--c2); border: 1px solid var(--zv-border); padding: .3rem .82rem; border-radius: 4px; font-size: .73rem; font-weight: 700; margin: .2rem; }

/* ── CTA ── */
.cta-band h2      { color: var(--zv-white); }
.cta-band h2 em   { color: rgba(255,255,255,.88); font-style: italic; }
.cta-desc         { color: rgba(255,255,255,.75); font-size: .95rem; font-weight: 300; line-height: 1.8; max-width: 500px; margin-top: .8rem; }
.cta-btns         { display: flex; flex-direction: column; gap: .7rem; }

/* ── Discours ── */
.discours-p { font-size: .95rem; font-weight: 300; color: rgba(255,255,255,.65); line-height: 1.85; margin-bottom: 1.1rem; }

/* ── Clients ── */
.clients-band > p { font-size: .67rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--c2l); opacity: .45; margin-bottom: 1.8rem; }
.client-logo  { height: 28px; width: auto; opacity: .85; filter: grayscale(0); transition: opacity .2s, filter .2s; }
.client-logo:hover { opacity: .7; filter: grayscale(0); }
.client-ph    { height: 25px; background: var(--c2); opacity: .09; border-radius: 3px; }

/* ── Qualiopi badge ── */
.qualiopi-badge {
  display: inline-flex; align-items: center; gap: 1rem;
  background: var(--zv-light); border: 1px solid var(--zv-border);
  padding: 1rem 1.6rem; border-radius: var(--radius); margin-top: 1.8rem;
}
.qualiopi-badge-icon { font-size: 1.7rem; }
.qualiopi-badge-text strong { display: block; font-size: .86rem; font-weight: 700; color: var(--c2); letter-spacing: .04em; }
.qualiopi-badge-text span   { font-size: .74rem; font-weight: 400; }

/* ── Recrutement ── */
.engagement-card { background: var(--zv-light); padding: 2.2rem 1.9rem; border-top: 2px solid var(--zv-border); }
.engagement-card .icon { font-size: 1.45rem; margin-bottom: .85rem; }
.engagement-card h3 { font-size: .95rem; font-weight: 700; margin-bottom: .65rem; }
.engagement-card p, .engagement-card li { font-size: .84rem; font-weight: 400; color: var(--c2l); line-height: 1.7; }
.engagement-card ul { padding-left: 1.1rem; margin-top: .4rem; }
.engagement-card li { margin-bottom: .3rem; }

.processus-step {
  flex: 1; min-width: 128px; padding: 1.8rem 1.2rem;
  text-align: center; background: var(--zv-white); position: relative;
}
.processus-step::after { content: '→'; position: absolute; right: -14px; top: 38%; font-size: 1.1rem; color: var(--c1); z-index: 1; }
.processus-step:last-child::after { display: none; }
.step-circle {
  width: 46px; height: 46px; border-radius: 50%;
  border: 2px solid var(--c1);
  display: flex; align-items: center; justify-content: center;
  font-size: .88rem; font-weight: 800; color: var(--c1);
  margin: 0 auto .85rem;
  transition: background .2s;
}
.processus-step:hover .step-circle { background: var(--c1); color: white; }
.processus-step h4 { font-size: .83rem; font-weight: 700; color: var(--c2); margin-bottom: .25rem; }
.processus-step p  { font-size: .76rem; font-weight: 300; color: var(--c2l); line-height: 1.6; }
@media (max-width: 960px) { .processus-step::after { display: none; } }

.profil-card {
  background: var(--c2); padding: 1.9rem 1.4rem;
  text-align: center; border-bottom: 2px solid rgba(255,255,255,.08);
  transition: background .2s;
}
.profil-card:hover { background: var(--c2d); }
.profil-card h3 { font-size: .95rem; font-weight: 700; color: var(--zv-white); margin-bottom: .42rem; }
.profil-card p  { font-size: .78rem; font-weight: 300; color: rgba(255,255,255,.48); line-height: 1.6; }

/* ── RSE ── */
.rse-card   { background: var(--zv-white); padding: 2.3rem 2.1rem; }
.rse-card h3 { font-size: 1.05rem; font-weight: 700; margin-bottom: .85rem; }
.rse-card p  { font-size: .86rem; font-weight: 300; color: var(--c2l); line-height: 1.75; }
.rse-mesure  { background: var(--zv-light); padding: 1.9rem 1.6rem; border-left: 2px solid var(--c1); }
.rse-mesure:hover { background: var(--zv-white); }
.rse-mesure h4 { font-size: .86rem; font-weight: 700; margin-bottom: .4rem; }
.rse-mesure p  { font-size: .82rem; font-weight: 300; color: var(--c2l); line-height: 1.7; }

/* ── Contact ── */
.contact-details { margin-top: 1.9rem; display: flex; flex-direction: column; gap: 1.3rem; }
.contact-detail  { display: flex; gap: 1rem; align-items: flex-start; }
.detail-icon {
  width: 35px; height: 35px; border-radius: 50%;
  background: var(--zv-light); border: 1px solid var(--zv-border);
  display: flex; align-items: center; justify-content: center;
  font-size: .78rem; flex-shrink: 0;
}
.detail-label { font-size: .67rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--c2l); opacity: .58; margin-bottom: .12rem; }
.detail-value { font-size: .92rem; color: var(--c2); }
