/* ===== QUI-SOMMES-NOUS.CSS - Page-specific overrides only ===== */
/* Base bloc styles are in css/blocs/*.css (loaded dynamically) */

/* Override: page-specific delay values */
.delay-1 { transition-delay: 0.1s; }
.delay-2 { transition-delay: 0.2s; }
.delay-3 { transition-delay: 0.3s; }
.delay-4 { transition-delay: 0.4s; }

.btn--primary:hover,
.btn--outline:hover {
  color: var(--text-light);
}

/* Grille asymétrique pour les split-section de la page QSN (blocs 43, 44) :
   colonne image élargie de 10vh pour donner plus de course au chevron scroll-linked.
   Le responsive 1024px → 1fr est géré par components.css, mais il faut re-scoper
   ici car cette règle (page CSS) est chargée après le media query de components.css. */
@media (min-width: 1025px) {
  .split-section {
    grid-template-columns: calc(50% + 10vh) calc(50% - 10vh);
  }
}

#operations-section {
  background: var(--bg-dark);
}

/* ===== CTA SECTION (page-specific overrides) ===== */
.cta-section {
  min-height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 6rem 4rem;
  background: var(--accent);
  position: relative;
  overflow: hidden;
}

.cta-section__pattern {
  position: absolute;
  inset: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 50px;
  opacity: 0.15;
}

.cta-section__pattern svg {
  width: 200px;
  height: 400px;
}

.cta-section__pattern svg path {
  stroke: var(--text-light);
  stroke-width: 1;
  fill: none;
}

.cta-section__content {
  position: relative;
  z-index: 1;
}

.cta-section__title {
  margin-bottom: 1.5rem;
}

.cta-section__text {
  font-size: 1.125rem;
  opacity: 0.85;
  max-width: 500px;
  margin: 0 auto 2.5rem;
}

.cta-section__actions {
  display: flex;
  justify-content: center;
  gap: 3rem;
}

/* CTA animation initial states */
.cta-section__pattern svg {
  will-change: transform, opacity;
}
.cta-section__pattern svg:nth-child(1) { transform: translateX(-150px) scale(0.8); opacity: 0; }
.cta-section__pattern svg:nth-child(2) { transform: translateX(-80px) scale(0.85); opacity: 0; }
.cta-section__pattern svg:nth-child(3) { transform: translateX(0) scale(0.9); opacity: 0; }
.cta-section__pattern svg:nth-child(4) { transform: translateX(80px) scale(0.85); opacity: 0; }
.cta-section__pattern svg:nth-child(5) { transform: translateX(150px) scale(0.8); opacity: 0; }

.cta-section__title,
.cta-section__text {
  will-change: transform, opacity;
  opacity: 0;
  transform: scale(0.92);
}

.cta-section__actions {
  will-change: transform, opacity;
  opacity: 0;
  transform: translateY(30px);
}

/* ===== IMMO SECTION — QSN page-specific ID overrides ===== */
/* Notre apport : trait bleu gauche, orange droite */
#operations-section .immo-section__grid {
  gap: 0;
}

#operations-section .immo-section__col--left {
  text-align: left;
  border-left: 2px solid var(--accent);
  padding: 0 2rem;
}

#operations-section .immo-section__col--right {
  text-align: left;
  border-left: 2px solid var(--abenex-orange);
  padding-left: 2rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* Immobilier : trait bleu gauche, orange droite */
#immobilier-section .immo-section__grid {
  gap: 0;
}

#immobilier-section .immo-section__col--left {
  text-align: left;
  border-left: 2px solid var(--accent);
  padding: 0 2rem;
}

#immobilier-section .immo-section__col--right {
  text-align: left;
  border-left: 2px solid var(--abenex-orange);
  padding-left: 2rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}


/* ===== RESPONSIVE: 1200px ===== */
@media (max-width: 1200px) {
  .engagement-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ===== RESPONSIVE: 768px ===== */
@media (max-width: 768px) {
  .cta-section {
    padding: 4rem 1.5rem;
  }

  .cta-section__actions {
    flex-direction: column;
  }

  .cta-section__actions .btn {
    white-space: normal;
    height: auto;
    min-height: var(--btn-height);
  }
}
