/* ══ PAGE D'ACCUEIL ══════════════════════════════════════════ */

/* ── HERO ── */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:flex-end;
  color:#fff;overflow:hidden;
}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__img{width:100%;height:100%;object-fit:cover;object-position:center 55%}
.hero__overlay{
  position:absolute;inset:0;
  background:linear-gradient(170deg,rgba(14,28,49,.3) 0%,rgba(14,28,49,.75) 55%,rgba(14,28,49,.96) 100%)
}
.hero__content{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr;gap:var(--s12);
  align-items:flex-end;
  padding-top:100px;padding-bottom:var(--s16);
}
.hero__label{
  display:inline-flex;align-items:center;gap:var(--s3);
  font-size:var(--t-xs);font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--teal);margin-bottom:var(--s6);
}
.hero__label::before{content:'';display:block;width:28px;height:1px;background:var(--teal)}
.hero__title{
  font-size:var(--t-hero);font-weight:800;
  line-height:1;letter-spacing:-.03em;
  color:#fff;margin-bottom:var(--s6);
}
.hero__title em{font-style:italic;color:var(--teal);font-weight:600}
.hero__subtitle{
  font-size:var(--t-lead);line-height:1.75;
  color:rgba(255,255,255,.72);max-width:500px;margin-bottom:var(--s8);
}
.hero__actions{display:flex;flex-wrap:wrap;gap:var(--s4)}
.hero__stats{
  display:none;flex-direction:column;gap:1px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);
  overflow:hidden;backdrop-filter:blur(12px);
  align-self:flex-end;min-width:210px;
}
.hero__stat{
  padding:var(--s5) var(--s8);
  background:rgba(14,28,49,.5);
  border-bottom:1px solid rgba(255,255,255,.07);
}
.hero__stat:last-child{border-bottom:none}
.hero__stat-num{
  display:block;font-size:2.25rem;font-weight:800;
  line-height:1;color:#fff;margin-bottom:4px;letter-spacing:-.03em;
}
.hero__stat-num em{font-style:normal;color:var(--teal);font-size:1.25rem;font-weight:700}
.hero__stat-label{font-size:.6875rem;color:rgba(255,255,255,.55);letter-spacing:.04em;line-height:1.4}
.hero__scroll{
  position:absolute;bottom:var(--s8);left:50%;transform:translateX(-50%);
  z-index:1;display:flex;flex-direction:column;align-items:center;gap:var(--s2);
  color:rgba(255,255,255,.4);font-size:.6875rem;letter-spacing:.14em;text-transform:uppercase;
  animation:bob 2.2s ease-in-out infinite;
}
.hero__scroll svg{width:18px;height:18px}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ── TRUST STRIP ── */
.trust-strip{background:var(--navy);padding:var(--s8) 0;border-top:1px solid rgba(255,255,255,.06)}
.trust-strip__grid{display:grid;grid-template-columns:1fr;gap:var(--s5)}
.trust-item{display:flex;align-items:flex-start;gap:var(--s4)}
.trust-icon{
  width:36px;height:36px;flex-shrink:0;
  background:rgba(42,173,160,.12);border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  color:var(--teal);margin-top:2px;
}
.trust-icon svg{width:18px;height:18px}
.trust-item strong{display:block;color:#fff;font-size:var(--t-body);font-weight:700;margin-bottom:4px;letter-spacing:-.01em}
.trust-item span{font-size:var(--t-sm);color:rgba(255,255,255,.55);line-height:1.6}

/* ── SERVICES ── */
.services-grid{display:grid;grid-template-columns:1fr;gap:var(--s5)}
.service-card{
  position:relative;border-radius:var(--radius);overflow:hidden;
  aspect-ratio:4/3;display:flex;flex-direction:column;justify-content:flex-end;
  box-shadow:var(--sh-md);transition:var(--ease);
  isolation:isolate; /* empêche le transform d'animation de faire déborder le contenu */
}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.service-card img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;transition:transform .55s ease;
}
.service-card:hover img{transform:scale(1.04)}
.service-card__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(14,28,49,.92) 0%,rgba(14,28,49,.35) 50%,transparent 100%);
}
.service-card__body{position:relative;z-index:1;padding:var(--s8)}
.service-card__body .badge{margin-bottom:var(--s3)}
.service-card__body h3{font-size:clamp(1.375rem,2vw,1.75rem);font-weight:700;color:#fff;margin-bottom:var(--s2);line-height:1.2}
.service-card__body p{font-size:var(--t-sm);color:rgba(255,255,255,.75);line-height:1.65;margin-bottom:var(--s3)}
.service-card__link{
  display:inline-flex;align-items:center;gap:var(--s2);
  color:var(--teal);font-weight:700;font-size:var(--t-xs);
  letter-spacing:.1em;text-transform:uppercase;transition:var(--ease);
}
.service-card__link svg{width:14px;height:14px}
.service-card:hover .service-card__link{gap:var(--s4)}

/* ── STEPS ── */
.steps{display:flex;flex-direction:column;gap:0}
.step{
  display:flex;gap:var(--s8);padding:var(--s10) 0;
  border-bottom:1px solid var(--border);
}
.step:last-child{border-bottom:none}
.step__num{
  font-size:3rem;font-weight:800;color:var(--teal);
  opacity:.18;line-height:1;flex-shrink:0;width:56px;
  letter-spacing:-.04em;font-variant-numeric:tabular-nums;
}
.step__body h4{font-size:var(--t-h4);font-weight:700;margin-bottom:var(--s2);letter-spacing:-.01em}
.step__body p{font-size:var(--t-body);color:var(--muted);line-height:1.75}

/* ── PRICING ── */
.pricing-grid{display:grid;grid-template-columns:1fr;gap:var(--s4)}
.pricing-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius);padding:var(--s8);
  display:flex;flex-direction:column;gap:var(--s6);transition:var(--ease);
}
.pricing-card:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.2)}
.pricing-card--featured{
  border-color:var(--teal) !important;
  background:rgba(42,173,160,.07) !important;
}
.pricing-card__tag{
  display:inline-block;background:var(--coral);color:#fff;
  font-size:var(--t-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:4px 13px;border-radius:var(--radius-pill);align-self:flex-start;
}
.pricing-card h3{font-size:var(--t-h3);font-weight:700;color:#fff;line-height:1.2;margin-bottom:var(--s2)}
.pricing-card__price{line-height:1;display:flex;align-items:baseline;gap:var(--s2);margin:var(--s2) 0}
.pricing-card__price strong{font-size:3rem;color:#fff;font-weight:800;letter-spacing:-.04em}
.pricing-card__price span{font-size:var(--t-sm);color:rgba(255,255,255,.45);font-weight:400}
.pricing-card__features{display:flex;flex-direction:column;gap:var(--s3);flex:1}
.pricing-card__features li{
  display:flex;align-items:flex-start;gap:var(--s3);
  font-size:var(--t-body);color:rgba(255,255,255,.78);line-height:1.6;
}
.pricing-card__features li svg{width:16px;height:16px;flex-shrink:0;margin-top:3px;color:var(--teal)}

/* ── ECO STRIP ── */
.eco-strip{background:var(--teal);padding:var(--s10) 0}
.eco-strip__inner{display:flex;align-items:flex-start;gap:var(--s6)}
.eco-strip__icon{
  width:52px;height:52px;flex-shrink:0;
  background:rgba(255,255,255,.15);border-radius:var(--radius-pill);
  display:flex;align-items:center;justify-content:center;
}
.eco-strip__icon svg{width:26px;height:26px;color:#fff}
.eco-strip h4{font-size:var(--t-h4);font-weight:700;color:#fff;margin-bottom:var(--s2);letter-spacing:-.01em}
.eco-strip p{font-size:var(--t-body);color:rgba(255,255,255,.85);line-height:1.75;max-width:620px}

/* ── CTA FINAL ── */
.cta-final{background:var(--off)}
.cta-final__actions{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--s4);margin-top:var(--s10)}

/* ── RESPONSIVE ── */
@media(min-width:480px){
  .trust-strip__grid{grid-template-columns:repeat(2,1fr)}
}
@media(min-width:1024px){
  .trust-strip__grid{grid-template-columns:repeat(5,1fr)}
}
@media(min-width:640px){
  .pricing-grid{grid-template-columns:1fr 1fr}
  .services-grid{grid-template-columns:1fr 1fr}
}
@media(min-width:768px){
  .hero__content{grid-template-columns:1fr auto;align-items:flex-end}
  .hero__stats{display:flex}
  .steps{flex-direction:row;gap:0}
  .step{
    flex-direction:column;border-bottom:none;
    border-right:1px solid var(--border);
    padding:0 var(--s10) 0 0;
  }
  .step+.step{padding:0 var(--s10)}
  .step:last-child{border-right:none;padding-right:0}
  .step__num{width:auto}
}
@media(min-width:1024px){
  .services-grid{grid-template-columns:repeat(3,1fr)}
  .pricing-grid{grid-template-columns:repeat(3,1fr)}
}


/* ── HERO TITLE ANIMATION au chargement ── */
.hero__label {
  animation: fadeSlideIn .7s .2s cubic-bezier(.16,1,.3,1) both;
}
.hero__title {
  animation: fadeSlideIn .8s .35s cubic-bezier(.16,1,.3,1) both;
}
.hero__subtitle {
  animation: fadeSlideIn .8s .55s cubic-bezier(.16,1,.3,1) both;
}
.hero__actions {
  animation: fadeSlideIn .8s .7s cubic-bezier(.16,1,.3,1) both;
}
.hero__stats {
  animation: fadeSlideIn .9s .85s cubic-bezier(.16,1,.3,1) both;
}
@keyframes fadeSlideIn {
  from { opacity: 0; transform: translateY(28px); filter: blur(6px); }
  to   { opacity: 1; transform: translateY(0);    filter: blur(0); }
}

/* ── STEP HOVER : le numéro prend la couleur teal et grossit ── */
.step {
  transition: background .3s ease;
  padding-left: var(--s4);
  margin-left: calc(-1 * var(--s4));
  border-radius: var(--radius);
}
.step:hover { background: rgba(42,173,160,.04); }
.step:hover .step__num {
  opacity: 1;
  color: var(--teal);
  transform: scale(1.08);
}
.step__num { transition: opacity .35s ease, color .35s ease, transform .35s cubic-bezier(.16,1,.3,1); }

/* ── TRUST ITEMS : décalage staggeré à l'entrée ── */
.trust-item:nth-child(1) { transition-delay: 0s; }
.trust-item:nth-child(2) { transition-delay: .08s; }
.trust-item:nth-child(3) { transition-delay: .16s; }
.trust-item:nth-child(4) { transition-delay: .24s; }
.trust-item:nth-child(5) { transition-delay: .32s; }

/* ── SERVICE CARD LINK : flèche se déplace ── */
.service-card__link svg {
  transition: transform .28s cubic-bezier(.16,1,.3,1);
}
.service-card:hover .service-card__link svg {
  transform: translateX(6px);
}

/* ── HERO PERSONAL NOTE ── */
.hero__personal-note {
  margin-top: var(--s4);
  font-size: var(--t-sm);
  color: rgba(255,255,255,.50);
  letter-spacing: .01em;
}

/* ── ABOUT SECTION ── */
.about-section { background: var(--white); }
.about-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s12);
  align-items: start;
}
@media(min-width:768px){
  .about-grid { grid-template-columns: 340px 1fr; gap: var(--s16); align-items: center; }
}

/* ── MOBILE : carte compacte avec photo ronde à gauche ── */
.about-photo-mobile {
  display: flex;
  align-items: center;
  gap: var(--s6);
  margin-bottom: var(--s6);
}
.about-photo-mobile__img {
  width: 96px;
  height: 96px;
  border-radius: var(--radius-pill);
  object-fit: cover;
  object-position: center top;
  flex-shrink: 0;
  border: 3px solid var(--teal);
  box-shadow: var(--sh-md);
}
.about-photo-mobile__meta { flex: 1; min-width: 0; }
.about-photo-mobile__name {
  font-size: var(--t-h4);
  font-weight: 800;
  color: var(--navy);
  letter-spacing: -.02em;
  line-height: 1.2;
  margin-bottom: var(--s2);
}
.about-photo-mobile__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.about-photo-mobile__badges .about-badge { font-size: .575rem; padding: 4px 9px; }

/* ── DESKTOP : photo portrait classique ── */
.about-photo {
  position: relative;
  border-radius: var(--radius);
  overflow: visible;
  display: none; /* caché sur mobile, affiché ≥768px */
}
@media(min-width:768px){
  .about-photo { display: block; }
  .about-photo-mobile { display: none; }
}
.about-photo img {
  width: 100%;
  aspect-ratio: 3/4;
  max-height: 65vh;
  object-fit: cover;
  object-position: center top;
  border-radius: var(--radius);
  display: block;
  filter: grayscale(8%);
}
.about-photo__badges {
  position: absolute;
  bottom: -1rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: var(--s2);
  flex-wrap: wrap;
  justify-content: center;
  width: calc(100% + 2rem);
}
.about-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--navy);
  color: var(--teal);
  font-size: .625rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 5px 11px;
  border-radius: var(--radius-pill);
  white-space: nowrap;
  box-shadow: var(--sh-md);
}
.about-badge svg { width: 12px; height: 12px; flex-shrink: 0; }

/* Body */
.about-body { padding-top: 0; }
@media(min-width:768px){ .about-body { padding-top: 0; } }

/* Certifications list */
.about-certs {
  display: flex;
  flex-direction: column;
  gap: var(--s5);
  margin-top: var(--s8);
  padding-top: var(--s8);
  border-top: 1px solid var(--border);
}
.about-cert {
  display: flex;
  align-items: flex-start;
  gap: var(--s4);
}
.about-cert > svg {
  width: 20px; height: 20px;
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--teal);
}
.about-cert strong {
  display: block;
  font-size: var(--t-body);
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 3px;
}
.about-cert span {
  font-size: var(--t-sm);
  color: var(--muted);
  line-height: 1.6;
}

/* Call CTA */
.about-call {
  margin-top: var(--s8);
  display: flex;
  flex-direction: column;
  gap: var(--s3);
}
.about-call__note {
  font-size: var(--t-sm);
  color: var(--muted);
  line-height: 1.65;
}

/* ── ALERT COST (intendance) ── */
.alert-cost {
  display: flex;
  align-items: flex-start;
  gap: var(--s6);
  background: #fff8f0;
  border: 1px solid rgba(224,90,58,.18);
  border-left: 3px solid var(--coral);
  border-radius: var(--radius);
  padding: 1.25rem 1.5rem;
  margin-bottom: var(--s12);
}
.alert-cost__icon {
  width: 42px; height: 42px;
  flex-shrink: 0;
  background: rgba(224,90,58,.1);
  border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  color: var(--coral);
  margin-top: 2px;
}
.alert-cost strong {
  display: block;
  font-size: var(--t-body);
  font-weight: 700;
  color: var(--navy);
  margin-bottom: var(--s2);
}
.alert-cost p {
  font-size: var(--t-sm);
  color: var(--muted);
  line-height: 1.7;
}
