/* =========================================================
   Deck Bar - Page Accueil
   Fichier nettoyé

   Contient :
   - Hero / cartes animées
   - Classes utilitaires Elementor utilisées sur l'accueil
   - Boutons accueil
   - Mosaïques de 3 images
   - Avis Google Trustindex
   ========================================================= */

/* =========================================================
   1. Hero - titre avec 2 couleurs
   ========================================================= */

.deck-hero-title {
  display: flex;
  flex-direction: column;
  line-height: 0.95;
  margin-bottom: 24px;
}

.deck-hero-welcome {
  color: var(--deck-green) !important;
  font-size: clamp(46px, 5vw, 78px);
  font-weight: 400;
  letter-spacing: -0.04em;
}

.deck-hero-brand {
  color: var(--deck-deep) !important;
  font-size: clamp(70px, 8vw, 128px);
  font-weight: 900;
  letter-spacing: -0.06em;
}

.deck-hero-intro,
.deck-hero-intro p {
  color: var(--deck-deep) !important;
  font-size: clamp(22px, 2vw, 32px);
  line-height: 1.25;
  font-weight: 400;
  max-width: 850px;
}

/* =========================================================
   2. Hero - deck de cartes animé
   ========================================================= */

.deck-hero-right {
  position: relative !important;
  min-height: 430px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.deck-card-stack {
  position: relative;
  width: 360px;
  height: 430px;
}

.deck-playing-card {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 300px;
  aspect-ratio: 3 / 4;
  background: var(--deck-white);
  border: 16px solid var(--deck-white);
  border-radius: 26px;
  overflow: hidden;
  box-shadow:
    0 0 0 1px rgba(2, 32, 29, 0.50),
    0 28px 20px rgba(0, 0, 0, 0.32);
  opacity: 0;
  transform-origin: center center;

  animation-name: deckCardContinuous;
  animation-duration: 12.5s;
  animation-timing-function: cubic-bezier(0.16, 0.84, 0.28, 1);
  animation-iteration-count: infinite;
  animation-fill-mode: both;

  will-change: transform, opacity;
  backface-visibility: hidden;
  transform: translate3d(0, 0, 0);
}

.deck-playing-card img,
.deck-card-photo img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
}

.deck-card-photo {
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: var(--deck-dark);
}

.deck-card-photo::before,
.deck-card-photo::after {
  display: none !important;
}

.deck-playing-card.card-1 {
  --base-z: 1;
  --active-z: 101;
  animation-delay: 0s;
  --final-x: -52%;
  --final-y: -50%;
  --final-rotate: -5deg;
}

.deck-playing-card.card-2 {
  --base-z: 2;
  --active-z: 102;
  animation-delay: 2.5s;
  --final-x: -51%;
  --final-y: -51%;
  --final-rotate: 3deg;
}

.deck-playing-card.card-3 {
  --base-z: 3;
  --active-z: 103;
  animation-delay: 5s;
  --final-x: -50%;
  --final-y: -49%;
  --final-rotate: -2deg;
}

.deck-playing-card.card-4 {
  --base-z: 4;
  --active-z: 104;
  animation-delay: 7.5s;
  --final-x: -49%;
  --final-y: -51%;
  --final-rotate: 5deg;
}

.deck-playing-card.card-5 {
  --base-z: 5;
  --active-z: 105;
  animation-delay: 10s;
  --final-x: -48%;
  --final-y: -50%;
  --final-rotate: -3deg;
}

@keyframes deckCardContinuous {
  0% {
    opacity: 0;
    transform:
      translate3d(230%, -50%, 0)
      rotate(16deg)
      scale(2);
  }

  4% {
    opacity: 1;
  }

  22% {
    opacity: 1;
    transform:
      translate3d(var(--final-x), var(--final-y), 0)
      rotate(var(--final-rotate))
      scale(1);
  }

  100% {
    opacity: 1;
    transform:
      translate3d(var(--final-x), var(--final-y), 0)
      rotate(var(--final-rotate))
      scale(1);
  }
}

.deck-playing-card.card-1 img,
.deck-playing-card.card-2 img,
.deck-playing-card.card-3 img,
.deck-playing-card.card-4 img,
.deck-playing-card.card-5 img {
  object-position: center center !important;
}

@media (prefers-reduced-motion: reduce) {
  .deck-playing-card {
    animation: none !important;
    opacity: 1 !important;
    z-index: var(--base-z) !important;
    transform: translate(var(--final-x), var(--final-y)) rotate(var(--final-rotate)) !important;
  }
}

/* =========================================================
   3. Classes utilitaires Elementor - Accueil
   ========================================================= */

.deck-c-green {
  color: var(--deck-green) !important;
}

.deck-c-deep {
  color: var(--deck-deep) !important;
}

.deck-c-white {
  color: var(--deck-white) !important;
}

.deck-c-mint {
  color: var(--deck-mint) !important;
}

.deck-f-title {
  font-size: clamp(42px, 5vw, 76px) !important;
}

.deck-f-display {
  font-size: clamp(70px, 8vw, 128px) !important;
}

.deck-f-lead {
  font-size: clamp(20px, 1.8vw, 28px) !important;
}

.deck-w-light,
.deck-w-regular {
  font-weight: 400 !important;
}

.deck-w-black {
  font-weight: 900 !important;
}

.deck-lh-tight {
  line-height: 0.95 !important;
}

.deck-lh-display {
  line-height: 0.9 !important;
}

.deck-lh-normal {
  line-height: 1.3 !important;
}

.deck-track-tight {
  letter-spacing: -0.04em !important;
}

.deck-track-display {
  letter-spacing: -0.06em !important;
}

.deck-max-xl {
  max-width: 850px !important;
}

/* =========================================================
   4. Boutons - Accueil
   ========================================================= */

.deck-btn,
.elementor-button.deck-btn,
a.deck-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  margin-top: 20px !important;
  margin-bottom: 20px !important;
  background: var(--deck-accent) !important;
  color: var(--deck-dark) !important;
  border: none !important;
  border-radius: var(--deck-radius-pill) !important;
  padding: 12px 24px !important;
  font-weight: 800 !important;
  font-size: 15px !important;
  line-height: 1 !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
}

.deck-btn:hover,
.elementor-button.deck-btn:hover,
a.deck-btn:hover {
  background: var(--deck-accent-hover) !important;
  color: var(--deck-dark) !important;
  transform: translateY(-2px);
}

.deck-btn-dark,
.elementor-button.deck-btn-dark,
a.deck-btn-dark {
  background: var(--deck-dark) !important;
  color: var(--deck-white) !important;
}

.deck-btn-dark:hover,
.elementor-button.deck-btn-dark:hover,
a.deck-btn-dark:hover {
  background: var(--deck-dark-2) !important;
  color: var(--deck-white) !important;
}

/* =========================================================
   5. Mosaïque images - 3 images par bloc

   Structure Elementor attendue :
   .deck-img-mosaic
     .deck-img-tile
     .deck-img-tile
     .deck-img-tile

   PC/tablette : 1 image à gauche sur 2 lignes + 2 images à droite
   Mobile : 3 images carrées sur une seule ligne
   ========================================================= */

.deck-img-mosaic,
.deck-img-mosaic > .e-con-inner {
  display: grid !important;
  justify-content: center !important;
  align-items: center !important;
}

.deck-img-mosaic .deck-img-tile {
  margin: 0 !important;
  overflow: hidden !important;
  border-radius: 12px !important;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.22) !important;
  background: var(--deck-white) !important;
  padding: 0 !important;
}

.deck-img-mosaic .deck-img-tile .elementor-widget-container,
.deck-img-mosaic .deck-img-tile a,
.deck-img-mosaic .deck-img-tile picture {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  overflow: hidden !important;
  border-radius: 12px !important;
  box-sizing: border-box !important;
  padding: 0 !important;
  margin: 0 !important;
}

.deck-img-mosaic .deck-img-tile img {
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
  border-radius: 0 !important;
  margin: 0 !important;
}

/* Desktop */
@media (min-width: 1025px) {
  .deck-img-mosaic,
  .deck-img-mosaic > .e-con-inner {
    grid-template-columns: 300px 300px !important;
    grid-template-rows: 300px 300px !important;
    gap: 1rem !important;
    width: fit-content !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  :is(.deck-img-mosaic, .deck-img-mosaic > .e-con-inner) > .deck-img-tile:nth-child(1) {
    grid-column: 1 !important;
    grid-row: 1 / span 2 !important;
    align-self: center !important;
  }

  :is(.deck-img-mosaic, .deck-img-mosaic > .e-con-inner) > .deck-img-tile:nth-child(2) {
    grid-column: 2 !important;
    grid-row: 1 !important;
  }

  :is(.deck-img-mosaic, .deck-img-mosaic > .e-con-inner) > .deck-img-tile:nth-child(3) {
    grid-column: 2 !important;
    grid-row: 2 !important;
  }

  .deck-img-mosaic .deck-img-tile {
    width: 300px !important;
    height: 300px !important;
    max-width: 300px !important;
    max-height: 300px !important;
  }
}

/* Tablette */
@media (min-width: 768px) and (max-width: 1024px) {
  .deck-img-mosaic,
  .deck-img-mosaic > .e-con-inner {
    grid-template-columns: 150px 150px !important;
    grid-template-rows: 150px 150px !important;
    gap: 0.75rem !important;
    width: fit-content !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  :is(.deck-img-mosaic, .deck-img-mosaic > .e-con-inner) > .deck-img-tile:nth-child(1) {
    grid-column: 1 !important;
    grid-row: 1 / span 2 !important;
    align-self: center !important;
  }

  :is(.deck-img-mosaic, .deck-img-mosaic > .e-con-inner) > .deck-img-tile:nth-child(2) {
    grid-column: 2 !important;
    grid-row: 1 !important;
  }

  :is(.deck-img-mosaic, .deck-img-mosaic > .e-con-inner) > .deck-img-tile:nth-child(3) {
    grid-column: 2 !important;
    grid-row: 2 !important;
  }

  .deck-img-mosaic .deck-img-tile {
    width: 150px !important;
    height: 150px !important;
    max-width: 150px !important;
    max-height: 150px !important;
  }
}

/* Mobile */
@media (max-width: 767px) {
  .deck-img-mosaic,
  .deck-img-mosaic > .e-con-inner {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    grid-template-rows: 1fr !important;
    gap: 0.5rem !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  :is(.deck-img-mosaic, .deck-img-mosaic > .e-con-inner) > .deck-img-tile:nth-child(1),
  :is(.deck-img-mosaic, .deck-img-mosaic > .e-con-inner) > .deck-img-tile:nth-child(2),
  :is(.deck-img-mosaic, .deck-img-mosaic > .e-con-inner) > .deck-img-tile:nth-child(3) {
    grid-column: auto !important;
    grid-row: auto !important;
  }

  .deck-img-mosaic .deck-img-tile {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 / 1 !important;
    max-width: none !important;
    max-height: none !important;
    margin: 0 !important;
    transform: none !important;
    border-radius: 12px !important;
    background: transparent !important;
  }

  .deck-img-mosaic .deck-img-tile .elementor-widget-container,
  .deck-img-mosaic .deck-img-tile a,
  .deck-img-mosaic .deck-img-tile picture {
    height: 100% !important;
    aspect-ratio: 1 / 1 !important;
    border-radius: 12px !important;
  }
}

/* =========================================================
   6. Responsive général accueil
   ========================================================= */

@media (max-width: 921px) {
  .deck-hero-right {
    min-height: 360px;
  }

  .deck-card-stack {
    width: 300px;
    height: 360px;
  }

  .deck-playing-card {
    width: 185px;
    border-width: 12px;
    border-radius: 22px;
  }

  .deck-f-display {
    font-size: clamp(58px, 12vw, 90px) !important;
  }

  .deck-f-title {
    font-size: clamp(38px, 8vw, 62px) !important;
  }
}

@media (max-width: 767px) {
  .deck-hero-right {
    min-height: 300px;
  }

  .deck-card-stack {
    width: 250px;
    height: 300px;
  }

  .deck-playing-card {
    width: 150px;
    border-width: 10px;
    border-radius: 18px;
  }

  .deck-f-display {
    font-size: clamp(48px, 15vw, 70px) !important;
  }

  .deck-f-title {
    font-size: clamp(34px, 10vw, 52px) !important;
  }

  .deck-f-lead {
    font-size: 20px !important;
  }
}

/* =========================================================
   7. Avis Google Trustindex
   ========================================================= */

body .elementor-element-f94385a.deck-reviews-section
.ti-widget.ti-goog
.ti-reviews-container-wrapper
.ti-review-item.source-Google
> .ti-inner,
.deck-reviews-section
.ti-widget.ti-goog
.ti-reviews-container-wrapper
.ti-review-item.source-Google
> .ti-inner {
  background-color: rgba(10, 101, 98, 0.50) !important;
  background-image: none !important;
  border: 1px solid rgba(0, 51, 51, 0.18) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
}
