/* ============================================================
   MADEMOISELLE TRÉSORS — CLASSES UTILITAIRES DU GUIDE DIVI
   ------------------------------------------------------------
   Ce sont EXACTEMENT les classes décrites dans le « Guide de
   montage » (Parties 00, 07, 08, 09), à appliquer aux MODULES
   NATIFS de Divi via Avancé ▸ Classe CSS.
   → Tu n'as donc PLUS à coller le gros bloc CSS dans
     « Options du thème ▸ CSS personnalisé » : il est ici.
   Les couleurs pointent vers les variables de marque (style.css).
   ============================================================ */

/* ---------- base de marque (fond sombre + polices) ---------- */
body { background: var(--mt-bg); color: #ece8e1; font-family: 'Montserrat', sans-serif; }
h1, h2, h3, h4, h5 { font-family: 'Abril Fatface', Georgia, serif !important; font-weight: 400 !important; }

/* ---------- surtitre doré · classe mt-eyebrow ---------- */
.mt-eyebrow, .mt-eyebrow p {
  color: var(--mt-gold) !important;
  text-transform: uppercase;
  letter-spacing: .30em;
  font-size: 13px !important;
  font-weight: 600 !important;
  font-family: 'Montserrat', sans-serif !important;
  line-height: 1.4;
}

/* ---------- bouton BLEU ROI · classe mt-btn ---------- */
.mt-btn .et_pb_button, a.mt-btn {
  background: var(--mt-blue) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 2px !important;
  padding: 18px 40px !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 600 !important;
  text-transform: uppercase;
  letter-spacing: .20em;
  transition: all .4s ease !important;
}
.mt-btn .et_pb_button:after { display: none !important; }
.mt-btn .et_pb_button:hover, a.mt-btn:hover {
  transform: translateY(-2px);
  background: var(--mt-blue) !important;
  box-shadow: 0 16px 44px -10px rgba(58,73,201,.9), 0 0 0 1px var(--mt-gold) !important;
}

/* ---------- bouton OR · classe mt-btn-gold ---------- */
.mt-btn-gold .et_pb_button, a.mt-btn-gold {
  background: var(--mt-gold) !important;
  color: #161616 !important;
  border: 0 !important;
  border-radius: 2px !important;
  padding: 18px 40px !important;
  text-transform: uppercase;
  letter-spacing: .20em;
  font-weight: 600 !important;
}
.mt-btn-gold .et_pb_button:after { display: none !important; }
.mt-btn-gold .et_pb_button:hover { transform: translateY(-2px); box-shadow: 0 16px 40px -12px rgba(229,192,104,.6) !important; }

/* ---------- bouton CONTOUR · classe mt-btn-ghost ---------- */
.mt-btn-ghost .et_pb_button, a.mt-btn-ghost {
  background: transparent !important;
  color: #ece8e1 !important;
  border: 1px solid rgba(229,192,104,.4) !important;
  border-radius: 2px !important;
  padding: 18px 40px !important;
  text-transform: uppercase;
  letter-spacing: .20em;
  font-weight: 600 !important;
}
.mt-btn-ghost .et_pb_button:hover { border-color: var(--mt-gold) !important; color: var(--mt-gold) !important; }

/* ---------- dégradé cinématographique · classe mt-gradient ---------- */
.mt-gradient { background: radial-gradient(ellipse at center, #06131e 55%, #0b1f35 100%) !important; }

/* ---------- carte « offre » (zoom image au survol) · classe mt-card ---------- */
.mt-card { overflow: hidden; border: 1px solid rgba(255,255,255,.08); border-radius: 4px; }
.mt-card .et_pb_image_wrap img, .mt-card img { transition: transform 1s ease; }
.mt-card:hover .et_pb_image_wrap img, .mt-card:hover img { transform: scale(1.06); }

/* ---------- filet doré fin · classe mt-rule (module Diviseur) ---------- */
.mt-rule { border-color: rgba(229,192,104,.25) !important; }

/* ---------- gros numéro d'étape en contour or · classe mt-stepnum ---------- */
.mt-stepnum {
  font-family: 'Abril Fatface', Georgia, serif !important;
  font-size: 3.4rem !important;
  color: transparent !important;
  -webkit-text-stroke: 1px var(--mt-gold-soft);
}

/* ---------- formulaire de contact · classe mt-form ---------- */
.mt-form .et_pb_contact_field {
  background: rgba(18,18,22,.66) !important;
  border: 1px solid rgba(229,192,104,.16) !important;
  border-radius: 6px !important;
}
.mt-form input, .mt-form textarea, .mt-form select {
  background: rgba(255,255,255,.03) !important;
  color: #f1ece3 !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 3px !important;
}
.mt-form input:focus, .mt-form textarea:focus { border-color: var(--mt-gold) !important; }

/* ============================================================
   GRILLE PRODUITS · classe mt-shop
   ------------------------------------------------------------
   À appliquer au module « Woo Products » de Divi 5
   (Avancé ▸ Classe CSS : mt-shop). Reproduit les cartes de la
   maquette. Fonctionne aussi sur l'archive WooCommerce native.
   ============================================================ */
.mt-shop ul.products li.product {
  background: #141417 !important;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 6px;
  overflow: hidden;
  transition: .4s ease;
}
.mt-shop li.product:hover {
  transform: translateY(-5px);
  border-color: rgba(229,192,104,.3);
  box-shadow: 0 26px 60px -28px #000;
}
.mt-shop li.product img { aspect-ratio: 4/5; object-fit: cover; margin: 0 !important; }
.mt-shop li.product h2,
.mt-shop li.product h3,
.mt-shop li.product .woocommerce-loop-product__title {
  font-family: 'Abril Fatface', Georgia, serif !important;
  color: #f2efe8 !important;
  font-size: 1.1rem !important;
  padding: 16px 16px 4px;
}
.mt-shop li.product .price {
  color: var(--mt-gold) !important;
  font-family: 'Abril Fatface', Georgia, serif !important;
  padding: 0 16px;
  display: block;
}
.mt-shop li.product .price del { color: #6f6a61 !important; }
.mt-shop li.product .price ins { text-decoration: none; }
.mt-shop li.product .button {
  background: transparent !important;
  color: var(--mt-gold) !important;
  border: 1px solid rgba(229,192,104,.4) !important;
  border-radius: 2px !important;
  margin: 14px 16px 18px !important;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-weight: 600;
}
.mt-shop li.product .button:hover {
  background: var(--mt-blue) !important;
  color: #fff !important;
  border-color: var(--mt-blue) !important;
}
.mt-shop span.onsale {
  background: var(--mt-gold) !important;
  color: #161616 !important;
  border-radius: 2px;
}


/* ============================================================
   FORMULAIRE DE CONTACT DIVI (officiel) — à la charte
   ------------------------------------------------------------
   Calé sur le balisage réel : .et_pb_contact_form_container
   > .et_pb_contact_field(.has-background) > label.et_pb_contact_form_label
     + .input (input/textarea) ; bouton .et_pb_contact_submit.
   S'applique partout ; ajoute la classe « mt-form » au module pour
   le rendu « carte » (bordure + fond) comme la maquette.
   ============================================================ */

/* carte (option : classe mt-form sur le module) */
.et_pb_contact_form_container.mt-form {
  background: rgba(18,18,22,.55);
  backdrop-filter: blur(8px);
  border: 1px solid var(--mt-line);
  border-radius: 8px;
  padding: clamp(24px,3.2vw,40px);
}

/* labels en or */
.et_pb_contact_form_container .et_pb_contact_form_label {
  color: var(--mt-gold) !important;
  font-family: 'Montserrat', sans-serif !important;
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: .7rem !important;
  font-weight: 600 !important;
  margin-bottom: 8px;
  display: block;
}

/* champs SANS BORDURE : le conteneur porte un fond discret, l'input est transparent */
.et_pb_contact_form_container .et_pb_contact_field,
.et_pb_contact_form_container .et_pb_contact_field.has-background,
.mt-form .et_pb_contact_field {
  background: rgba(18,18,22,.66) !important;
  border: 0 !important;
  border-radius: 6px !important;
  padding: 12px 16px 14px !important;
}
.et_pb_contact_form_container .et_pb_contact_field:focus-within {
  box-shadow: inset 0 0 0 1px rgba(229,192,104,.45) !important;
}
.et_pb_contact_form_container .input,
.et_pb_contact_form_container input.input,
.et_pb_contact_form_container textarea.input,
.et_pb_contact_form_container select.input,
.et_pb_contact_form_container .et_pb_contact_message {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  color: #f4f1ea !important;
  padding: 6px 0 !important;
  font-family: 'Montserrat', sans-serif !important;
}
.et_pb_contact_form_container .input:focus,
.et_pb_contact_form_container .et_pb_contact_message:focus { border: 0 !important; box-shadow: none !important; outline: none !important; }
.et_pb_contact_form_container .input::placeholder,
.et_pb_contact_form_container .et_pb_contact_message::placeholder { color: #7d786f !important; }
/* select éventuel : flèche or */
.et_pb_contact_form_container select.input {
  appearance: none; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none' stroke='%23e5c068' stroke-width='1.5'%3E%3Cpath d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 4px center;
}
/* case à cocher éventuelle (+18) */
.et_pb_contact_form_container .et_pb_contact_field_checkbox input[type="checkbox"] + label i,
.et_pb_contact_form_container input[type="checkbox"] { accent-color: var(--mt-gold); }

/* bouton envoyer -> bleu roi */
.et_pb_contact_form_container .et_pb_contact_submit.et_pb_button {
  background: var(--mt-blue) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 2px !important;
  text-transform: uppercase;
  letter-spacing: .2em;
  font-weight: 600;
  padding: 16px 40px !important;
  transition: all .4s ease !important;
}
.et_pb_contact_form_container .et_pb_contact_submit.et_pb_button:after { display: none !important; }
.et_pb_contact_form_container .et_pb_contact_submit.et_pb_button:hover {
  transform: translateY(-2px);
  background: var(--mt-blue-glow) !important;
  box-shadow: 0 16px 44px -10px rgba(58,73,201,.95), 0 0 0 1px var(--mt-gold) !important;
}

/* messages succès / erreur */
.et_pb_contact_form_container .et-pb-contact-message { color: #e8e3d9; }
.et_pb_contact_form_container .et-pb-contact-message p,
.et_pb_contact_form_container .et-pb-contact-message ul li {
  background: rgba(31,43,143,.10) !important;
  border: 1px solid rgba(229,192,104,.2) !important;
  color: #e8e3d9 !important;
  border-radius: 6px !important;
  padding: 14px 18px !important;
}


/* ============================================================
   FORMULAIRE DE CONTACT NATIF DIVI (et_pb_contact_form)
   ------------------------------------------------------------
   Donne au module « Formulaire de contact » de Divi le look de
   la carte Contact de la maquette (envoi e-mail géré par Divi).
   ============================================================ */
.et_pb_contact_form_container {
  background: rgba(18,18,22,.66);
  backdrop-filter: blur(8px);
  border: 1px solid var(--mt-line);
  border-radius: 6px;
  padding: clamp(26px,3.5vw,40px) !important;
}
/* champs : boîte pleine, SANS bordure (label + champ dans un seul bloc) */
.et_pb_contact_form_container .et_pb_contact_field,
.et_pb_contact_form_container .et_pb_contact_field.has-background,
.mt-form .et_pb_contact_field {
  background: rgba(18,18,22,.66) !important;
  border: none !important;
  border-radius: 6px !important;
  padding: 13px 16px !important;
  margin-bottom: 16px !important;
}
.et_pb_contact_form_container .et_pb_contact_form_label {
  display: block; margin: 0 0 6px;
  font-family: 'Montserrat', sans-serif;
  font-size: .68rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--mt-gold) !important;
}
/* le champ lui-même : transparent, aucune bordure */
.et_pb_contact_form_container input.input,
.et_pb_contact_form_container .input,
.et_pb_contact_form_container textarea.et_pb_contact_message,
.et_pb_contact_form_container select,
.mt-form input.input,
.mt-form textarea.et_pb_contact_message,
.mt-form select {
  width: 100%;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  color: #f1ece3 !important;
  border-radius: 0 !important;
  padding: 2px 0 !important;
  font-family: 'Montserrat', sans-serif;
}
.et_pb_contact_form_container textarea.et_pb_contact_message { min-height: 120px; }
.et_pb_contact_form_container .input::placeholder,
.et_pb_contact_form_container textarea::placeholder { color: #7d786f !important; }
/* focus : fin liseré or à l'intérieur de la boîte (pas de bordure permanente) */
.et_pb_contact_form_container .et_pb_contact_field:focus-within,
.mt-form .et_pb_contact_field:focus-within {
  box-shadow: inset 0 0 0 1px var(--mt-gold) !important;
}
.et_pb_contact_form_container input:focus,
.et_pb_contact_form_container textarea:focus,
.et_pb_contact_form_container select:focus { outline: none !important; }

/* bouton « Envoyer » : bleu roi, pleine largeur, sans la flèche Divi */
.et_pb_contact_form_container .et_pb_contact_submit,
.et_pb_contact_form_container .et_pb_button.et_pb_contact_submit {
  background: var(--mt-blue) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 2px !important;
  padding: 16px 40px !important;
  text-transform: uppercase; letter-spacing: .2em; font-weight: 600;
  width: 100%;
  transition: all .4s ease !important;
}
.et_pb_contact_form_container .et_pb_contact_submit:after { display: none !important; }
.et_pb_contact_form_container .et_pb_contact_submit:hover {
  background: var(--mt-blue-glow) !important;
  transform: translateY(-2px);
  box-shadow: 0 16px 44px -10px rgba(58,73,201,.95), 0 0 0 1px var(--mt-gold) !important;
}

/* messages de retour (succès / erreurs) */
.et-pb-contact-message p, .et-pb-contact-message li { color: #e8e3d9 !important; }
.et-pb-contact-message ul { list-style: none; padding-left: 0; }
.et_pb_contact_form_container .et_pb_contact_error_text { color: #ff8a8a !important; }
