/**
 * Reassurance Section 2 - Cartes de reassurance avec image latérale
 *
 * Layout: 3 cartes empilées (col-lg-5) + image (col-lg-7)
 * Fonctionnalités:
 * - Position image configurable (gauche/droite)
 * - Border-radius personnalisable sur image
 * - Design responsive
 * - Cards avec icône + titre + description
 *
 * @package Dioqa_UI_Kit
 */

/* ============================================
   Section Container
   ============================================ */

.reassurance-section-2 {
  overflow: hidden;
}

/* Force les colonnes à avoir la même hauteur */
.reassurance-section-2 .row {
  align-items: stretch !important;
  display: flex;
}

/* Force les colonnes en mode flex sur desktop */
@media (min-width: 992px) {
  .reassurance-section-2 .col-lg-5,
  .reassurance-section-2 .col-lg-7 {
    display: flex !important;
    flex-direction: column !important;
  }
}

/* ============================================
   Cards Container
   ============================================ */

.reassurance-2-cards {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

/* ============================================
   Individual Card
   ============================================ */

.reassurance-2-card {
  background-color: var(--bs-white, #ffffff);
  border-radius: var(--radius-lg, 10px);
  padding: 35px 20px;
  transition: all 0.3s ease;
}

.reassurance-2-card-inner {
  display: flex;
  align-items: center;
  gap: 24px;
}

/* Hover effect sur la carte */
.reassurance-2-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

/* ============================================
   Icon
   ============================================ */

.reassurance-2-icon {
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.reassurance-2-icon-img {
  width: 40px;
  height: 40px;
  object-fit: contain;
}

/* ============================================
   Content (Text Area)
   ============================================ */

.reassurance-2-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Title */
.reassurance-2-title {
  font-family: var(--font-heading, 'Outfit', sans-serif);
  font-weight: 500;
  font-size: var(--text-xl, 20px);
  color: var(--bs-dark, #3b3949);
  margin: 0;
  line-height: 1.4;
}

/* Description */
.reassurance-2-description {
  font-family: var(--font-body, 'Work Sans', sans-serif);
  font-weight: 400;
  font-size: var(--text-lg, 18px);
  color: var(--bs-text, #6b687d);
  margin: 0;
  line-height: 1.6;
}

/* ============================================
   Image Column
   ============================================ */

.reassurance-2-image {
  width: 100%;
  border-radius: var(--img-radius, 16px);
  overflow: hidden;
  position: relative;
}

/* Sur desktop, l'image prend toute la hauteur de la colonne */
@media (min-width: 992px) {
  .reassurance-2-image {
    flex: 1 !important;
    height: 100% !important;
    min-height: 0 !important;
  }

  .reassurance-2-image img {
    width: 100% !important;
    height: 100% !important;
    border-radius: var(--img-radius, 16px);
    object-fit: cover !important;
    position: absolute !important;
    top: 0;
    left: 0;
  }
}

/* Sur mobile/tablet, comportement normal */
@media (max-width: 991.98px) {
  .reassurance-2-image {
    min-height: 350px;
  }

  .reassurance-2-image img {
    width: 100%;
    height: auto;
    border-radius: var(--img-radius, 16px);
  }
}

/* ============================================
   Dark Background Adaptation
   ============================================ */

/* Adapter les cartes sur fond sombre */
.bg-primary .reassurance-2-card,
.bg-dark .reassurance-2-card,
.bg-black .reassurance-2-card {
  background-color: rgba(255, 255, 255, 0.1);
}

.bg-primary .reassurance-2-title,
.bg-dark .reassurance-2-title,
.bg-black .reassurance-2-title {
  color: var(--bs-white, #ffffff);
}

.bg-primary .reassurance-2-description,
.bg-dark .reassurance-2-description,
.bg-black .reassurance-2-description {
  color: rgba(255, 255, 255, 0.85);
}

/* ============================================
   Responsive Design
   ============================================ */

/* Tablet (< 992px) */
@media (max-width: 991.98px) {
  /* Reset flex sur les colonnes car elles sont empilées */
  .reassurance-section-2 .col-12 {
    display: block !important;
  }

  .reassurance-2-cards {
    gap: 20px;
    margin-bottom: 32px;
  }

  .reassurance-2-card {
    padding: 28px 18px;
  }

  .reassurance-2-card-inner {
    gap: 20px;
  }

  .reassurance-2-icon {
    width: 48px;
    height: 48px;
  }

  .reassurance-2-icon-img {
    width: 36px;
    height: 36px;
  }

  .reassurance-2-title {
    font-size: var(--text-lg, 18px);
  }

  .reassurance-2-description {
    font-size: var(--text-base, 16px);
  }
}

/* Mobile (< 768px) */
@media (max-width: 767.98px) {
  .reassurance-2-cards {
    gap: 16px;
    margin-bottom: 24px;
  }

  .reassurance-2-card {
    padding: 24px 16px;
  }

  .reassurance-2-card-inner {
    gap: 16px;
  }

  .reassurance-2-icon {
    width: 44px;
    height: 44px;
  }

  .reassurance-2-icon-img {
    width: 32px;
    height: 32px;
  }

  .reassurance-2-title {
    font-size: var(--text-base, 16px);
  }

  .reassurance-2-description {
    font-size: var(--text-sm, 14px);
  }

  .reassurance-2-image {
    min-height: 280px;
  }

  /* Sur mobile, force l'ordre : cartes puis image */
  .reassurance-section-2 .row {
    flex-direction: column !important;
  }
}

/* Small Mobile (< 576px) */
@media (max-width: 575.98px) {
  .reassurance-2-card {
    padding: 20px 14px;
  }

  .reassurance-2-card-inner {
    gap: 14px;
  }

  .reassurance-2-content {
    gap: 8px;
  }

  .reassurance-2-image {
    min-height: 240px;
  }
}

/* ============================================
   Accessibility & Motion
   ============================================ */

/* Réduire les animations pour les utilisateurs sensibles */
@media (prefers-reduced-motion: reduce) {
  .reassurance-2-card {
    transition: none;
  }

  .reassurance-2-card:hover {
    transform: none;
  }
}

/* Focus visible pour accessibilité clavier */
.reassurance-2-card:focus-within {
  outline: 2px solid var(--bs-primary, #007bff);
  outline-offset: 2px;
}
