.elementor-94 .elementor-element.elementor-element-b6bb5cd{--display:flex;--min-height:415px;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;}.elementor-94 .elementor-element.elementor-element-b6bb5cd:not(.elementor-motion-effects-element-type-background), .elementor-94 .elementor-element.elementor-element-b6bb5cd > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://martialmagie.fr/wp-content/uploads/2025/11/BANDEAU-DEFINITIF.jpg");background-position:center center;background-repeat:no-repeat;background-size:cover;}.elementor-94 .elementor-element.elementor-element-881f1b0{--display:flex;--flex-direction:column;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--justify-content:center;--align-items:center;}.elementor-widget-heading .elementor-heading-title{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );color:var( --e-global-color-primary );}.elementor-94 .elementor-element.elementor-element-401216d{text-align:center;}.elementor-94 .elementor-element.elementor-element-401216d .elementor-heading-title{font-family:"Roboto", Sans-serif;font-size:25px;font-weight:600;text-transform:uppercase;color:#FFFFFF;}.elementor-94 .elementor-element.elementor-element-5edd2d7{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--justify-content:center;}.elementor-widget-image .widget-image-caption{color:var( --e-global-color-text );font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-94 .elementor-element.elementor-element-d9f43f5{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--margin-top:15px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:10px;--padding-bottom:0px;--padding-left:20px;--padding-right:20px;}.elementor-94 .elementor-element.elementor-element-e18de4f{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-94 .elementor-element.elementor-element-e18de4f.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-94 .elementor-element.elementor-element-2b87379{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;text-align:center;font-family:"Roboto", Sans-serif;font-size:34px;font-weight:600;color:#0C0000;}.elementor-94 .elementor-element.elementor-element-3fcd79e{margin:-26px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;text-align:center;}.elementor-94 .elementor-element.elementor-element-3fcd79e .elementor-heading-title{font-family:"Roboto", Sans-serif;font-size:21px;font-weight:600;color:#000000;}.elementor-94 .elementor-element.elementor-element-557345b{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:50px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}.elementor-94 .elementor-element.elementor-element-9fbf24a{text-align:center;font-family:"Roboto", Sans-serif;font-size:30px;font-weight:600;color:#000000;}.elementor-94 .elementor-element.elementor-element-cf53451{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:40px;--padding-bottom:40px;--padding-left:20px;--padding-right:20px;}@media(min-width:788px){.elementor-94 .elementor-element.elementor-element-b6bb5cd{--content-width:1251px;}.elementor-94 .elementor-element.elementor-element-881f1b0{--content-width:1200px;}.elementor-94 .elementor-element.elementor-element-5edd2d7{--width:50%;}.elementor-94 .elementor-element.elementor-element-d9f43f5{--content-width:1200px;}.elementor-94 .elementor-element.elementor-element-e18de4f{--width:54%;}.elementor-94 .elementor-element.elementor-element-557345b{--width:66.6666%;}.elementor-94 .elementor-element.elementor-element-cf53451{--content-width:1200px;}}@media(max-width:796px) and (min-width:788px){.elementor-94 .elementor-element.elementor-element-b6bb5cd{--content-width:1200px;}}@media(max-width:796px){.elementor-94 .elementor-element.elementor-element-b6bb5cd{--min-height:359px;}.elementor-94 .elementor-element.elementor-element-9fbf24a{text-align:center;font-size:20px;}}@media(max-width:787px){.elementor-94 .elementor-element.elementor-element-b6bb5cd:not(.elementor-motion-effects-element-type-background), .elementor-94 .elementor-element.elementor-element-b6bb5cd > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-position:-453px 75px;background-repeat:repeat;}.elementor-94 .elementor-element.elementor-element-e18de4f{--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-94 .elementor-element.elementor-element-ddcb698{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-94 .elementor-element.elementor-element-557345b{--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-94 .elementor-element.elementor-element-7edceaf{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}}/* Start custom CSS for container, class: .elementor-element-d9f43f5 *//* Styles généraux pour le formulaire Contact Form 7 */
.wpcf7-form {
    max-width: 800px;
    margin: 0 auto;
    padding: 20px;
    background-color: #f9f9f9;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
    font-family: 'Arial', sans-serif;
    color: #333;
}

/* Styles pour les rangées (lignes) */
.rang-form {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 20px;
    gap: 15px;
    align-items: end; /* Aligne les champs au bas pour une meilleure uniformité */
}

/* Styles pour les demi-colonnes */
.demi-colonne {
    flex: 1;
    min-width: 200px; /* Évite que ça devienne trop étroit sur mobile */
}

/* Styles pour la colonne pleine */
.colonne {
    flex: 1 1 100%;
    width: 100%;
}

/* Styles pour les labels (ajoutés via CF7, ou personnalisés si besoin) */
.wpcf7-form label {
    display: block;
    margin-bottom: 5px;
    font-weight: bold;
    color: #555;
    font-size: 14px;
}

/* Styles pour les champs de saisie (text, email, tel) */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"] {
    width: 100%;
    padding: 12px 15px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    font-size: 16px;
    transition: all 0.3s ease;
    background-color: #fff;
    box-sizing: border-box;
}

.wpcf7-form input[type="text"]:focus,
.wpcf7-form input[type="email"]:focus,
.wpcf7-form input[type="tel"]:focus {
    border-color: #b91c2c;
    outline: none;
    box-shadow: 0 0 0 3px rgba(185, 28, 44, 0.1);
    transform: translateY(-1px); /* Effet de levée légère pour l'inviter à interagir */
}

/* Styles pour la textarea */
.wpcf7-form textarea {
    width: 100%;
    min-height: 120px;
    padding: 12px 15px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    font-size: 16px;
    resize: vertical; /* Permet le redimensionnement vertical seulement */
    transition: all 0.3s ease;
    background-color: #fff;
    box-sizing: border-box;
}

.wpcf7-form textarea:focus {
    border-color: #b91c2c;
    outline: none;
    box-shadow: 0 0 0 3px rgba(185, 28, 44, 0.1);
}

/* Styles pour le bouton submit */
.wpcf7-form input[type="submit"] {
    background-color: #b91c2c;
    color: white;
    padding: 15px 30px;
    border: none;
    border-radius: 8px;
    font-size: 18px;
    font-weight: bold;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 10px rgba(185, 28, 44, 0.3);
    width: 100%; /* Pour qu'il prenne toute la largeur dans sa colonne */
    text-transform: uppercase;
    letter-spacing: 1px;
}

.wpcf7-form input[type="submit"]:hover {
    background-color: #a01a25;
    transform: translateY(-2px);
    box-shadow: 0 6px 15px rgba(185, 28, 44, 0.4);
}

.wpcf7-form input[type="submit"]:active {
    transform: translateY(0);
}

/* Styles pour le reCAPTCHA */
.wpcf7-form .wpcf7-recaptcha {
    margin: 20px 0;
    text-align: center;
}

/* Styles pour la case d'acceptation */
[data-name="collectedesdonnes"] {
  margin: 48px 0;
  padding: 39px 7px 11px 0px;
  background-color: #ffe6e9;   /* fond rose clair assorti au rouge */
  border: 1px solid #fca5a5;   /* bordure légèrement plus claire */
  border-radius: 8px;
  font-size: 14px;
  color: #b91c2c;              /* texte rouge foncé */
}

/* Tablette et mobile : on augmente le padding-top */
@media (max-width: 991px) {
  [data-name="collectedesdonnes"] {
    padding: 67px 7px 11px 0px;
  }
}

.wpcf7-form .wpcf7-acceptance input[type="checkbox"] {
    margin-right: 10px;
    transform: scale(1.2); /* Rend la case plus visible */
}

/* Améliorations pour mobile (responsive) */
@media (max-width: 768px) {
    .wpcf7-form {
        padding: 15px;
        margin: 10px;
    }
    
    .rang-form {
        flex-direction: column;
        gap: 10px;
    }
    
    .demi-colonne {
        min-width: 100%;
    }
    
    .wpcf7-form input[type="submit"] {
        padding: 18px 30px;
        font-size: 20px; /* Plus grand sur mobile pour faciliter le tap */
    }
}

/* Messages de validation/success (optionnel, pour plus de convivialité) */
.wpcf7-response-output {
    border-radius: 8px;
    padding: 15px;
    margin: 20px 0;
    font-weight: bold;
}

.wpcf7-not-valid-tip {
    color: #dc3545;
    border-color: #dc3545;
}

.wpcf7-validation-errors {
    background-color: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
}

.wpcf7-mail-sent-ok {
    background-color: #d4edda;
    color: #155724;
    border: 1px solid #c3e6cb;
}/* End custom CSS */
/* Start custom CSS for text-editor, class: .elementor-element-08c1aa3 *//* ================================
   Formulaire Contact – Style convivial
   Collez ce CSS tel quel (ex: contact.css)
   ================================ */

/* Palette & variables */
:root {
  --bg: #0f1221;
  --card: #151a2f;
  --card-2: #1a2040;
  --text: #e9edff;
  --muted: #b7c2ff;
  --primary: #6c8cff;         /* Couleur d’accent “envie de cliquer” */
  --primary-strong: #4e6cff;
  --ring: #90a7ff;
  --success: #36d399;
  --error: #ff7a7a;
  --warning: #ffce73;
  --radius: 16px;
  --shadow: 0 10px 30px rgba(10, 14, 35, .35), inset 0 1px 0 rgba(255,255,255,.06);
}

/* Mode clair si votre site l’impose: ajustez via body.light */
@media (prefers-color-scheme: light) {
  :root {
    --bg: #f6f8ff;
    --card: #ffffff;
    --card-2: #f1f4ff;
    --text: #1c2240;
    --muted: #5b6aa8;
    --primary: #3b61ff;
    --primary-strong: #2447e6;
    --ring: #6f8cff;
    --shadow: 0 8px 24px rgba(18, 32, 120, .12);
  }
}

/* Contexte de section (optionnel) */
.contact-section {
  min-height: 100dvh;
  padding: clamp(24px, 4vw, 64px);
  background:
    radial-gradient(1200px 600px at 10% -10%, rgba(108,140,255,.18), transparent 60%),
    radial-gradient(900px 500px at 110% 10%, rgba(54,211,153,.12), transparent 60%),
    var(--bg);
  display: grid;
  place-items: center;
}

/* Carte formulaire (appliquez .contact-card au conteneur du <form>) */
.contact-card {
  width: min(680px, 100%);
  background: linear-gradient(180deg, var(--card), var(--card-2));
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: clamp(20px, 3.2vw, 40px);
  color: var(--text);
  position: relative;
  overflow: hidden;
}

/* Halo décoratif subtil */
.contact-card::after {
  content: "";
  position: absolute;
  inset: -40% -20% auto -20%;
  height: 60%;
  background: radial-gradient(500px 140px at 30% 50%, rgba(108,140,255,.20), transparent 70%);
  pointer-events: none;
}

/* Titre + sous-titre */
.contact-title {
  font-size: clamp(1.4rem, 2.6vw, 2rem);
  font-weight: 700;
  letter-spacing: .2px;
  margin: 0 0 .25rem;
}
.contact-subtitle {
  color: var(--muted);
  font-size: .975rem;
  margin: 0 0 1.5rem;
}

/* Grid du formulaire */
.contact-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(12px, 2vw, 18px);
}
.contact-form .full { grid-column: 1 / -1; }

/* Groupe champ */
.form-group {
  position: relative;
}

/* Label flottant accessible */
.form-label {
  display: inline-block;
  font-size: .9rem;
  color: var(--muted);
  margin-bottom: .45rem;
}

/* Champs */
.input, .textarea, .select {
  width: 100%;
  appearance: none;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: var(--text);
  padding: 0.9rem 1rem;
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease, transform .06s ease;
}

/* Focus state “ring” + légère mise en avant */
.input:focus, .textarea:focus, .select:focus {
  border-color: var(--ring);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--ring) 22%, transparent);
  background: rgba(255,255,255,.06);
  transform: translateY(-1px);
}

/* Textarea */
.textarea { min-height: 160px; resize: vertical; }

/* Placeholder doux */
.input::placeholder, .textarea::placeholder {
  color: color-mix(in oklab, var(--muted) 70%, transparent);
}

/* Barre de progression au focus (micro-interaction) */
.form-group:has(.input:focus, .textarea:focus, .select:focus)::after {
  content: "";
  position: absolute;
  left: 10px; right: 10px; bottom: -2px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--primary), var(--success));
  filter: blur(.3px);
}

/* Messages d’aide/erreur/succès */
.help {
  font-size: .82rem;
  color: var(--muted);
  margin-top: .4rem;
}
.error { color: var(--error); }
.success { color: var(--success); }

/* États de validation (ajoutez .is-error / .is-success sur .form-group) */
.is-error .input, .is-error .textarea, .is-error .select {
  border-color: color-mix(in oklab, var(--error) 70%, transparent);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--error) 18%, transparent);
}
.is-success .input, .is-success .textarea, .is-success .select {
  border-color: color-mix(in oklab, var(--success) 60%, transparent);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--success) 18%, transparent);
}

/* Case à cocher & radio modernisées (optionnel) */
.control {
  display: flex;
  align-items: start;
  gap: .6rem;
  font-size: .95rem;
  color: var(--muted);
}
.control input[type="checkbox"],
.control input[type="radio"] {
  width: 18px; height: 18px;
  accent-color: var(--primary);
  margin-top: .2rem;
}

/* Bouton envoyer – “envie de cliquer” */
.button-submit {
  grid-column: 1 / -1;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: .6rem;
  padding: 0.95rem 1.15rem;
  border: 0;
  border-radius: 14px;
  background:
    radial-gradient(120% 120% at 10% 10%, color-mix(in oklab, var(--primary) 90%, white 0%) 0%, var(--primary-strong) 60%),
    var(--primary);
  color: white;
  font-weight: 700;
  letter-spacing: .2px;
  cursor: pointer;
  transform: translateY(0);
  transition: transform .08s ease, filter .2s ease, box-shadow .2s ease;
  box-shadow: 0 12px 24px color-mix(in oklab, var(--primary) 28%, transparent);
}
.button-submit:hover {
  filter: brightness(1.05);
  transform: translateY(-1px);
}
.button-submit:active {
  transform: translateY(0);
  box-shadow: 0 6px 16px color-mix(in oklab, var(--primary) 22%, transparent);
}

/* Icône flèche animée (si vous mettez un <svg> dans le bouton) */
.button-submit svg {
  transition: transform .18s ease;
}
.button-submit:hover svg {
  transform: translateX(2px);
}

/* Bandeau de confiance (optionnel) */
.trust-badges {
  display: flex;
  gap: 10px;
  align-items: center;
  color: var(--muted);
  font-size: .85rem;
  margin-top: .8rem;
}
.badge {
  padding: .35rem .6rem;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
}

/* Accessibilité: focus visible pour le bouton via clavier */
.button-submit:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--ring) 25%, transparent), 0 12px 24px color-mix(in oklab, var(--primary) 28%, transparent);
}

/* Responsive */
@media (max-width: 720px) {
  .contact-form { grid-template-columns: 1fr; }
}

/* Petites améliorations globales si vous ne les avez pas déjà */
form ::file-.elementor-94 .elementor-element.elementor-element-08c1aa3-button {
  border: 0;
  padding: .6rem .8rem;
  margin-right: .6rem;
  border-radius: 10px;
  background: var(--card-2);
  color: var(--text);
  cursor: pointer;
}/* End custom CSS */