/* ======================================================
   CARDS — Composants cartes et boîtes icônes
   Dépendances : style.css (variables --color-*, --space-*)
   ====================================================== */

/* ======================================================
   BASE CARDS & BOX-ICON
   ====================================================== */
.card,
.box-icon-blanche,
.box-icon-rouge,
.box-icon-blanche-btn,
.card-bg-fonce {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 28px 24px;
  background: var(--color-blanc);
  border: 1px solid var(--color-gris-medium);
  text-align: left;
  width: 100%;
  box-sizing: border-box;
  --widgets-spacing: 10px 10px !important;
}

.card-bg-fonce {
  background: var(--color-gris-fonce);
  color: var(--color-blanc);
}

/* ======================================================
   TYPOGRAPHIE INTERNE AUX CARDS
   ====================================================== */
.card h3 {
  padding-top: 20px;
  margin-bottom: 0px;
}

.card h3 + ul {
  margin-top: 20px;
}

.single-references .card ul li {
  font-size: 16px !important;
  line-height: 1.5em !important;
}

.single-references .grid--3 h4 {
  color: var(--color-primary);
  font-size: 32px;
}

/* ======================================================
   ÉTATS & VARIANTES STRUCTURELLES
   ====================================================== */
.card:hover,
.box-icon-blanche:hover,
.box-icon-blanche-btn:hover {
  transform: translateY(-4px);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.15);
}

.card--button,
.box-icon-blanche-btn {
  justify-content: space-between;
}

.card--nofond,
.box-icon-ss-fond {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  background: none;
  border: none;
  padding: 0;
  --widgets-spacing-row: 6px;
}

.card--center,
.box-icon-blanche.is-centered,
.box-icon-rouge.is-centered {
  align-items: center;
  text-align: center;
}

/* ======================================================
   ICÔNES DANS LES CARDS
   ====================================================== */
.ic-box-blanche,
.icon-box,
.elementor-icon svg {
  max-width: 100%;
  width: auto;
  display: block;
  align-self: flex-start;
  margin-bottom: 12px;
}

.elementor-icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

.card .ic-box-blanche img {
  height: 64px;
  width: auto;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}

.card.card--floating-icon-lg .ic-box-rouge img {
  height: 250px;
  width: auto;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}

.card--center .ic-box-blanche,
.card--center .elementor-widget-image {
  align-self: center;
  display: flex;
  justify-content: center;
}

/* ======================================================
   CONTENU INTERNE (widgets Elementor)
   ====================================================== */
.card .elementor-widget-text-editor {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  text-align: left;
  flex: 1 1 auto;
}

.card--center .elementor-widget-text-editor {
  text-align: center;
}

.elementor-widget-button {
  margin-top: auto;
  align-self: flex-start;
}

.card--center .elementor-widget-button {
  align-self: center;
}

.icon-list-pill li .elementor-icon-list-text,
.bloc-icon-horizontal li .elementor-icon-list-text {
  padding-right: 24px;
}

/* ======================================================
   CARDS AVEC ICÔNE FLOTTANTE
   ====================================================== */
.card.card--floating-icon .ic-box-blanche,
.card.card--floating-icon .icon-box,
.card.card--floating-icon .elementor-icon,
.card.is-floating-icon .ic-box-blanche,
.card.is-floating-icon .icon-box,
.card.is-floating-icon .elementor-icon,
.card.card--floating-icon-lg .ic-box-rouge,
.card.card--floating-icon .ic-box-rouge {
  position: absolute;
  top: 0;
  left: 24px !important;
  transform: translate(0, -50%) !important;
  z-index: 10;
  width: 90px;
  height: 90px;
  background-color: var(--color-gris-clair);
  border-radius: 50%;
  border: 8px solid var(--color-blanc);
  box-shadow: 0px 5px 1px rgba(215, 215, 215, 0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0px;
  overflow: hidden;
}

.card.card--floating-icon .ic-box-rouge {
  margin-bottom: 90px;
}

.card.card--floating-icon .ic-box-rouge img {
  border-radius: 50%;
  width: 100%;
}

.card.card--floating-icon-lg .ic-box-rouge {
  top: 0;
  left: 0%;
  transform: translate(18%, -50%);
}

/* SVG contenu dans l'icône flottante */
.card.is-floating-icon .ic-box-blanche img,
.card.is-floating-icon .ic-box-rouge img,
.card.is-floating-icon .icon-box img,
.card.is-floating-icon .elementor-icon svg {
  max-height: 100%;
  width: auto;
  margin-bottom: 0;
}

.card.card--floating-icon {
  position: relative;
  margin-top: 50px;
  overflow: visible !important;
  padding-top: 40px;
}

.card.card--floating-icon-lg {
  position: relative;
  overflow: visible;
  margin-top: 140px;
  padding-top: 140px;
}

.card.card--floating-icon .elementor-icon,
.card.card--floating-icon-lg .elementor-icon {
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(0, -50%);
  border-radius: 50%;
  border: 8px solid var(--color-blanc);
  box-shadow: 0 5px 10px rgba(215, 215, 215, 0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-gris-clair);
  z-index: 10;
  padding: 20px;
}

.card.card--floating-icon .elementor-icon {
  width: 90px;
  height: 90px;
}

.card.card--floating-icon-lg .elementor-icon,
.card.card--floating-icon-lg .ic-box-rouge {
  width: 250px;
  height: 250px;
}

.card.card--floating-icon .elementor-icon-box-content {
  margin-top: 10px;
}

.card.card--floating-icon-lg .elementor-icon svg,
.card.card--floating-icon .elementor-icon svg,
.box-icon-rouge.card--floating-icon-lg .elementor-icon svg,
.box-icon-rouge.card--floating-icon-lg .ic-box-rouge {
  width: auto;
  max-height: 100%;
  margin-bottom: 0;
}

/* Responsive — icône flottante lg */
@media (max-width: 767px) {
  .card.card--floating-icon-lg {
    margin-top: 80px;
    padding-top: 90px;
  }

  .card.card--floating-icon-lg .ic-box-rouge {
    width: 150px;
    height: 150px;
  }
}

/* ======================================================
   CARD CTA
   ====================================================== */
.card-cta {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.card-cta .cta-content {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.card-cta .cta-action {
  display: flex;
  justify-content: center;
}

.card-cta .elementor-widget-button {
  margin: 0;
}

@media (min-width: 768px) {
  .card-cta {
    flex-direction: row;
    align-items: stretch;
    justify-content: space-between;
    gap: 32px;
  }

  .card-cta .cta-content {
    flex: 1 1 auto;
    flex-direction: row;
    align-items: center;
    gap: 24px;
  }

  .card-cta .cta-action {
    flex: 0 0 auto;
    align-items: center;
    justify-content: center;
  }
}

/* ======================================================
   TABLEAU 3 PHASES (composant card)
   ====================================================== */
.tableau-3-phases .card {
  height: 100%;
}

.tableau-3-phases .card .elementor-widget-text-editor:not(:last-child)::after {
  content: "";
  background-image: url("https://tvhconsulting2026.kinsta.cloud/wp-content/uploads/2023/03/fleche-transition-2.svg");
  background-repeat: no-repeat;
  background-size: contain;
  width: 116%;
  height: 50px;
  position: absolute;
  bottom: -50px;
  left: -8%;
}

.tableau-3-phases .card .elementor-widget-text-editor {
  width: 100%;
  padding: 30px 0 20px 0;
  gap: 6px;
}

.tableau-3-phases .card h3 {
  padding-top: 0;
}

#content .tableau-3-phases .card .ic-box-blanche {
  padding: 0;
  overflow: hidden;
}

@media (max-width: 1214px) {
  .tableau-3-phases
    .card
    .elementor-widget-text-editor:not(:last-child)::after {
    width: 118%;
    height: 50px;
    bottom: -50px;
    left: -9%;
  }
}

@media (max-width: 1024px) {
  .tableau-3-phases
    .card
    .elementor-widget-text-editor:not(:last-child)::after {
    width: 106%;
    height: 100px;
    bottom: -90px;
    left: -3%;
  }
}

/* ======================================================
   TÉMOIGNAGES — VARIANTES BOX (card-like)
   ====================================================== */
.photo-box-temoignage {
  width: 180px;
  height: 180px;
  align-self: center;
  border-radius: 200px;
  border: 2px solid #f5f5f5;
  overflow: hidden;
}

.box-temoignage-rouge {
  background-image:
    url(/wp-content/uploads/2021/03/elipse-v5-01.svg),
    url(/wp-content/uploads/2021/01/trait-rouge-droit.svg),
    linear-gradient(
      180deg,
      rgba(179, 8, 56, 1) 0%,
      rgba(179, 8, 56, 1) 25%,
      rgba(245, 245, 245, 1) 25%,
      rgba(245, 245, 245, 1) 100%
    );
  background-repeat: no-repeat, no-repeat, repeat-y;
  background-size: 70%, 50%, 100%;
  background-position:
    top center,
    bottom 0% right -2%,
    left top;
  border: 1px solid #e2e2e2;
  padding: 28px 24px 28px 24px;
}

.box-temoignage-noir {
  border: 1px solid #e2e2e2;
  padding: 28px 24px 28px 24px;
  background: #353d44;
}

.box-temoignage-rouge .elementor-widget-button .elementor-button,
.box-temoignage-noir .elementor-widget-button .elementor-button {
  padding: 8px 8px 8px 30px;
}

.box-temoignage-noir > * {
  align-self: center;
}

.box-temoignage-autre p {
  font-size: 12px;
}

.ic-temoignage svg {
  width: 19px;
  height: 19px;
}
