/*
Theme Name: Divi Child
Template: Divi
Description: Thème enfant pour Divi
Author: Any Communication
Author URI: https://any-communication.com
Version: 1.6.44
*/
@import url("../Divi/style.css");

/***

GLOBAL

***/

body {
  background: radial-gradient(
      circle at 20% 30%,
      rgba(227, 44, 44, 0.25),
      transparent 60%
    ),
    radial-gradient(
      circle at 80% 70%,
      rgba(245, 166, 35, 0.25),
      transparent 60%
    ),
    linear-gradient(135deg, #0e0e0e, #1a1a1a);
  background-attachment: fixed;
}

#main-content {
  background-color: transparent;
}

.et_pb_section,
.et_pb_section_0,
.et_section_regular {
  padding: 0;
}

.et_pb_text_inner ol li li {
  margin-bottom: 0.5em;
}

.row-vcenter {
  display: flex;
  align-items: center;
}

/* =========================================================
 * FIX Menu Mobile - Fiches Produit uniquement
 * =======================================================*/

@media (max-width: 980px) {
  .single-product #main-header .et_pb_section,
  .single-product #main-header .et_pb_row {
    padding-top: 15px !important;
  }
}

/* 1) On neutralise tout fond imposé par le plugin sur le menu */
body .menudv-account-menu {
  background-color: transparent !important; /* si l’extension posait juste une couleur */
  background: none !important; /* si l’extension posait un background complet */
}

/* 2) On applique TON fond custom */
body .menudv-account-menu {
  background: radial-gradient(
      circle at 20% 30%,
      rgba(227, 44, 44, 0.25),
      transparent 60%
    ),
    radial-gradient(
      circle at 80% 70%,
      rgba(245, 166, 35, 0.25),
      transparent 60%
    ),
    linear-gradient(135deg, #0e0e0e, #1a1a1a) !important;
  background-attachment: scroll !important;
  border: 2px solid rgba(255, 255, 255, 0.27) !important;
}
/*PERSONNALISER LE BOUTON DE RETOUR EN HAUT DE PAGE*/

/*Opacité du bouton et effets d'animation (pour tous les navigateurs)*/
.et_pb_scroll_top.et-visible {
  opacity: 1;
  -webkit-animation: fadeInBottom 1s;
  -moz-animation: fadeInBottom 1s;
  -o-animation: fadeInBottom 1s;
  animation: fadeInBottom 1s;
}

/*Positionnement et couleur du bouton*/
.et_pb_scroll_top.et-pb-icon {
  right: calc(
    50% - 25px
  ); /*distance du bouton par rapport à la droite de la fenêtre*/
  bottom: 50px; /*distance du bouton par rapport au bas de la fenêtre*/
  overflow: hidden;
  isolation: isolate;
  border-radius: 25px; /*Propriété permettant d'arrondir le bouton, supprimez la si vous voulez un bouton carré*/
  border: 2px solid rgba(255, 255, 255, 0.363);
  box-shadow: 2px 0 18px 0 rgba(0, 0, 0, 0.3);
  background: transparent !important;
}

/* Couche verre (blur + distorsion + voile), on n'utilise PAS ::before pour ne pas écraser l'icône */
.et_pb_scroll_top.et-pb-icon::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
  filter: none;
  background: rgba(255, 255, 255, 0.1);
  box-shadow: inset 2px 2px 1px rgba(255, 255, 255, 0.5),
    inset -1px -1px 1px rgba(255, 255, 255, 0.5);
  border-radius: inherit;
  z-index: 0;
}

html:not(.is-firefox) .et_pb_scroll_top.et-pb-icon::after {
  filter: url(#de-glass-distortion);
}

/*Choix de l'icone et couleur de celui-ci*/
.et_pb_scroll_top:before {
  position: relative;
  z-index: 1;
  content: "\36"; /* icone provenant des icones de bases de Divi*/
  color: #fff; /*couleur de l'icône*/
}

/* Classe personnalisée : .liquid-glass */
/* 
1) Base wrapper 
- Creates a positioned container that clips overflow. 
- All visual effects will be applied within this boundary.
*/
.de-liquidGlass-wrapper,
.cky-btn-revisit-wrapper {
  position: relative;
  overflow: hidden;
}

/* couche blur, glass de base, tous navigateurs */
.de-liquidGlass-wrapper::before,
.cky-btn-revisit-wrapper::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  isolation: isolate !important;
  -webkit-backdrop-filter: blur(14px) saturate(160%) !important;
  backdrop-filter: blur(14px) saturate(160%) !important;
  filter: none !important;
}

/* voile, bordure, relief, tous navigateurs */
.de-liquidGlass-wrapper::after,
.cky-btn-revisit-wrapper::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  background: rgba(255, 255, 255, 0.15) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3) !important;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12) !important;
}

/* contenu au dessus */
.de-liquidGlass-wrapper .et_pb_column,
.de-liquidGlass-wrapper .et_pb_column .et_pb_module,
.cky-btn-revisit-wrapper > * {
  position: relative;
  z-index: 1;
}

/* distorsion seulement hors Firefox */
html:not(.is-firefox) .de-liquidGlass-wrapper::before,
html:not(.is-firefox) .cky-btn-revisit-wrapper::before {
  filter: url(#de-glass-distortion) !important;
}

@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .de-liquidGlass-wrapper::before,
  .cky-btn-revisit-wrapper::before {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  .de-liquidGlass-wrapper::after,
  .cky-btn-revisit-wrapper::after {
    background: rgba(255,255,255,.75) !important;
  }
}

/* Masquer le label CookieYes */
.cky-btn-revisit-wrapper .cky-revisit-text {
  display: none !important;
}


/***

Personalisation better reviews

***/
/* Marges "universelles" */
.brtpmj_businessheader {
  margin-bottom: 0;
}
.brtpmj_business_ratings {
  margin-bottom: 15px;
}

/* Mobile: tout centré et empilé */
@media (max-width: 767.98px) {
  .brtpmj_businessheader {
    display: flex !important;
    flex-direction: column;
    align-items: center;
    text-align: center !important;
  }
  .brtpmj_businessheader img {
    float: none !important;
    display: block;
  }
  .brtpmj_business_name {
    margin: 8px 0 0 !important;
    text-align: center !important;
  }
  .brtpmj_business_ratings {
    display: flex !important;
    align-items: center;
    justify-content: center;
    text-align: center !important;
    margin-left: 0 !important; /* pas d’indent sur mobile */
  }
}

/* Tablette/PC: tout en ligne + espace de 20px avant la notation */
@media (min-width: 768px) {
  .brtpmj_businessheader,
  .brtpmj_business_ratings {
    display: inline-flex !important;
    align-items: center;
    vertical-align: middle;
    text-align: left !important;
    margin-bottom: 0 !important;
  }
  .brtpmj_business_name {
    margin-left: 10px;
  } /* espace logo → nom */
  .brtpmj_business_ratings {
    margin-left: 20px;
  } /* espace nom → notation */
}

/* Forcer overflow visible uniquement sur la rangée du header */
#main-header .et_pb_row_0_tb_header.et_pb_row--with-menu {
  overflow: visible !important;
}

/******* 

Contact

*******/
.wpcf7-form select option {
  color: #0e0e0e !important;
  background-color: #fff !important;
}
/******* 

Mon Compte 

*******/
.woocommerce-MyAccount-navigation,
.woocommerce-MyAccount-tabs {
  display: none;
}

.woocommerce-account .woocommerce-MyAccount-content {
  width: 100%;
}

.woocommerce form.login,
.woocommerce form.register {
  margin-top: 0;
}

/******* 

Auth

*******/
/* Scope uniquement au module qui a la classe keep-tabs-inline */
.et_pb_tabs.keep-tabs-inline ul.et_pb_tabs_controls {
  background-color: transparent !important;
  display: grid !important;
  grid-template-columns: repeat(
    2,
    minmax(0, 1fr)
  ) !important; /* 2 colonnes tout le temps */
  align-items: stretch;
}

/* Si Divi colle et_pb_tabs_vertically_stacked, on garde la grille quand même */
.et_pb_tabs.keep-tabs-inline.et_pb_tabs_vertically_stacked
  ul.et_pb_tabs_controls {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

/* Neutralise le float et les largeurs forcées */
.et_pb_tabs.keep-tabs-inline .et_pb_tabs_controls li {
  margin: 0 !important;
  width: auto !important;
  float: none !important;
  list-style: none;
}

/* Rend les onglets cliquables à 100% de leur cellule */
.et_pb_tabs.keep-tabs-inline .et_pb_tabs_controls li a {
  display: block;
  width: 100%;
  text-align: center;
  padding: 12px 10px;
  white-space: normal; /* évite que le texte force un retour à la ligne global */
  line-height: 1.2;
  box-sizing: border-box;
}

/* Cacher visuellement les labels, mais garder l'accessibilité */
.screen-reader-text {
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap;
}

/* Conteneur commun login/register */
.c7-auth-ui p {
  margin-bottom: 14px;
}

/* Champs texte 100% + style demandé */
.c7-auth-ui input[type="text"],
.c7-auth-ui input[type="email"],
.c7-auth-ui input[type="password"],
.c7-auth-ui input[type="tel"],
.c7-auth-ui input[type="number"] {
  display: block;
  width: 100%;
  box-sizing: border-box;
  padding: 12px 14px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.1);
  border: 2px solid rgba(255, 255, 255, 0.27);
  color: inherit;
}

/* Souligne le focus */
.c7-auth-ui input:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(46, 163, 242, 0.25);
  border-color: rgba(255, 255, 255, 0.45);
}

/* "Se souvenir de moi" stylé comme un champ */
.c7-auth-ui .login-remember label,
.c7-auth-ui .c7-remember-wrapper label {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.1);
  border: 2px solid rgba(255, 255, 255, 0.27);
  cursor: pointer;
}

/* Taille et couleur de la case à cocher */
.c7-auth-ui input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--et_pb_accent_color, #2ea3f2);
}

/* Boutons full width, héritent du style Divi via .et_pb_button */
.c7-auth-ui .button,
.c7-auth-ui #wp-submit {
  width: 100%;
  box-sizing: border-box;
}

/* Cache visuel des labels dans le form d'inscription, accessibilité préservée */
.c7-register-form label {
  position: absolute !important;
  height: 1px !important;
  width: 1px !important;
  overflow: hidden !important;
  clip: rect(1px, 1px, 1px, 1px) !important;
  white-space: nowrap !important;
}

/* Messages d’erreur */
.c7-errors {
  margin-bottom: 16px;
  padding: 10px 12px;
  border-radius: 6px;
  background: rgba(255, 0, 0, 0.08);
  border: 1px solid rgba(255, 0, 0, 0.25);
}
.c7-errors ul {
  margin: 0;
  padding-left: 18px;
  padding-bottom: 0;
}

.c7-lostpass {
  margin-bottom: 0 !important;
}

.c7-error-turnstile {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: rgba(255, 69, 58, 0.09); /* léger rouge */
  border: 1px solid rgba(255, 69, 58, 0.35);
  color: #ff453a;
  font-weight: 500;
}

/* Bouton "Créer mon compte" de ton formulaire d'inscription */
.c7-auth-ui .c7-register-form button[type="submit"],
.c7-auth-ui .c7-register-form input[type="submit"] {
  cursor: pointer !important;
}

.c7sl-facebook,
.c7sl-google {
  margin-top: 10px;
}

/******* 

Fiches Produis

*******/
/* =========================================================
 * Switch STL à télécharger <-> Produit fini
 * =======================================================*/

.c7-switch-buttons {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}
.c7-switch-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  border-radius: 5px;
  padding: 0 14px;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,0.27);
  background: rgba(255,255,255,0.1);
  color: inherit;
}
.c7-switch-btn.is-active{
  background: rgba(255,255,255,0.27);
  border:none;
}
.c7-switch-hint{
  margin-top: 8px;
  font-size: 13px;
  opacity: 0.82;
}

/* Masquage total de la quantité sur STL, sans marge résiduelle */
.single-product.c7-is-stl form.cart .quantity { display:none !important; }
.single-product.c7-is-stl form.cart .variations_button { gap: 10px; }
.single-product.c7-is-stl form.cart .single_add_to_cart_button { width: 100%; }

.single-product .variations_button, .single-product form.cart {
    gap: 0 !important;
    padding-top: 15px;
}

/* CSS des tiroirs (caractéristiques, ingériant)  */
ul.et_pb_tabs_controls {
  background-color: rgba(255, 255, 255, 0.1) !important;
}
ul.et_pb_tabs_controls:after {
  border-top: 1px solid rgba(255, 255, 255, 0.27) !important;
}
.et_pb_tabs_controls li {
  border-right: 1px solid rgba(255, 255, 255, 0.27) !important;
}
.toggle-content ul {
  padding: 0 0 15px 2em !important;
}
.toggle-section {
  margin-top: 10px;
}
.toggle-title {
  position: relative;
  padding: 14px 20px;
  margin-bottom: 10px;
  background: rgba(255, 255, 255, 0.1);
  border: 2px solid rgba(255, 255, 255, 0.27);
  border-radius: 3px;
}

.toggle-title:after {
  content: "▼";
  font-family: "dashicons";
  speak: none;
  font-weight: 400;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 16px;
  transition: transform 0.3s ease;
  padding-right: 20px;
}

.toggle-title.opened:after {
  content: "▲";
}

.toggle-content {
  overflow: hidden;
  transition: height 0.4s ease;
  height: 0;
}

.toggle-title,
.et_pb_tab_content h2,
.et_pb_tab_content h3 {
  font-size: 22px;
}

/* Tablette */
@media (max-width: 980px) {
  .toggle-title,
  .et_pb_tab_content h2,
  .et_pb_tab_content h3 {
    font-size: 20px;
  }
}

/* Mobile */
@media (max-width: 767px) {
  .toggle-title,
  .et_pb_tab_content h2,
  .et_pb_tab_content h3 {
    font-size: 18px;
  }
}

.woocommerce form.cart .quantity input.qty {
  color:#fff;
  background: rgba(255, 255, 255, 0.1);
  border: 2px solid rgba(255, 255, 255, 0.27) !important;
  border-radius: 5px;
}

/* =========================================================
 * Connec7e Badges WooCommerce
 * =======================================================*/
.woocommerce div.product .c7-badges{
  display: grid;
  grid-template-columns: repeat(3, max-content);
  justify-content: start;
  align-items: start;
  column-gap: 18px;
  row-gap: 10px;
  margin-top: 12px;
}

.woocommerce div.product .c7-badge-link,
.woocommerce div.product .c7-badge-link:visited{
  color: #f5a623;
  text-decoration: none;
}

.woocommerce div.product .c7-badge-link .c7-badge-text{
  color: #f5a623;
  text-decoration: underline !important;
  text-decoration-color: #f5a623 !important;
  text-underline-offset: 3px;
}

.woocommerce div.product .c7-badge-link:hover .c7-badge-text{
  color: #fff;
  text-decoration-color: #fff !important;
}

.woocommerce div.product .c7-badge-item{
  display: inline-flex;
  align-items: flex-end;
  gap: 8px;
  line-height: 1.1;
}

.woocommerce div.product .c7-badge-icon{
  width: 25px;
  height: 25px;
  flex: 0 0 auto;
  display: block;
  object-fit: contain;
}

.woocommerce div.product .c7-badge-text{
  display: inline-block;
  line-height: 1.1;
  white-space: nowrap;
}

/* Mobile, centré, plus d’espace entre colonnes */
@media (max-width: 980px){
  .woocommerce div.product .c7-badges{
    grid-template-columns: repeat(2, max-content);
    justify-content: center;
    column-gap: 40px;
    
  }
}

/* Mobile, bouton ajouter au panier en pleine largeur */
@media (max-width: 980px){
  .woocommerce div.product form.cart .single_add_to_cart_button,
  .woocommerce div.product form.cart .button{
    width: 100%;
    display: block;
  }

  .woocommerce div.product form.cart{
    width: 100%;
  }

  .woocommerce div.product form.variations_form .variations select,
  .woocommerce div.product form.variations_form .variations .value{
    width: 100%;
  }
}


/* =========================================================
 * Login : cookie + Turnstile CSS UI auth
 * =======================================================*/
.c7-auth-ui .cf-turnstile{display:block;width:100%!important;max-width:100%!important;margin:10px 0 10px;}
.c7-auth-ui .cf-turnstile>iframe,
.c7-auth-ui .cf-turnstile>div{display:block;width:100%!important;max-width:100%!important}

.c7-auth-ui>p:empty, .c7-auth-ui form>p:empty{display:none;margin:0}

.c7-auth-ui .et_pb_button,
.c7-auth-ui button,
.c7-auth-ui input[type=submit]{cursor:pointer}

.c7-auth-ui .c7ev-notice{background:#eaf7ea;border:1px solid #b7e1b7;color:#0b6b0b;padding:12px;border-radius:6px;margin:0 0 16px}
.c7-auth-ui .c7ev-error {background:#fdecec;border:1px solid #f5b5b5;color:#7d0d0d;padding:12px;border-radius:6px;margin:0 0 16px}

