.elementor-1535 .elementor-element.elementor-element-2e5ed60a{--display:flex;--min-height:600px;--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;--overlay-opacity:0.95;--margin-top:-150px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1535 .elementor-element.elementor-element-2e5ed60a:not(.elementor-motion-effects-element-type-background), .elementor-1535 .elementor-element.elementor-element-2e5ed60a > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://www.office64.fr/wp-content/uploads/2026/04/40_EspaceEntreprise_OH64_siteWeb_desktop_V5-1.png");background-position:center center;background-size:cover;}.elementor-1535 .elementor-element.elementor-element-2e5ed60a::before, .elementor-1535 .elementor-element.elementor-element-2e5ed60a > .elementor-background-video-container::before, .elementor-1535 .elementor-element.elementor-element-2e5ed60a > .e-con-inner > .elementor-background-video-container::before, .elementor-1535 .elementor-element.elementor-element-2e5ed60a > .elementor-background-slideshow::before, .elementor-1535 .elementor-element.elementor-element-2e5ed60a > .e-con-inner > .elementor-background-slideshow::before, .elementor-1535 .elementor-element.elementor-element-2e5ed60a > .elementor-motion-effects-container > .elementor-motion-effects-layer::before{background-color:transparent;--background-overlay:'';background-image:linear-gradient(180deg, #FFFFFF 5%, #FFFFFF00 35%);}.elementor-1535 .elementor-element.elementor-element-c73274f{--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;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--margin-top:50px;--margin-bottom:50px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.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 );text-transform:var( --e-global-typography-primary-text-transform );color:var( --e-global-color-primary );}.elementor-1535 .elementor-element.elementor-element-cea2215{text-align:center;}.elementor-1535 .elementor-element.elementor-element-cea2215 .elementor-heading-title{font-family:"Barlow", Sans-serif;font-size:64px;font-weight:700;text-transform:uppercase;color:var( --e-global-color-cb4d073 );}.elementor-1535 .elementor-element.elementor-element-d628e0e{--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;}@media(max-width:1024px){.elementor-1535 .elementor-element.elementor-element-2e5ed60a{--min-height:400px;}.elementor-1535 .elementor-element.elementor-element-d628e0e{--padding-top:0px;--padding-bottom:0px;--padding-left:25px;--padding-right:25px;}}@media(max-width:767px){.elementor-1535 .elementor-element.elementor-element-cea2215 .elementor-heading-title{font-size:32px;}}/* Start custom CSS for heading, class: .elementor-element-cea2215 *//* ============================================================
   TITRE PRINCIPAL DE PAGE — H1 EN 2 LIGNES
   ============================================================ */
.oh64-h1-prefix {
  display: block;
  color: #7ECDE5;
  font-size: 0.45em;
  letter-spacing: 0.02em;
  margin-bottom: 0.2em;
  text-transform: none;
}

.oh64-h1-main {
  display: block;
  color: var(--oh64-blue-dark);
  font-size: 1em;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}/* End custom CSS */
/* Start custom CSS for shortcode, class: .elementor-element-fd35d47 *//* ============================================================
   FORMULAIRES OFFICE64 — STYLES UNIFIÉS
   Compatible RGAA / WCAG AA :
     - Labels visibles (pas masqués)
     - Contraste suffisant (≥ 4.5:1 pour le texte)
     - Focus visible
     - Indication caractère obligatoire accessible
   ============================================================ */

:root {
  /* Couleurs de la charte OFFICE64.
     À ajuster si tu as les codes hex exacts depuis la maquette. */
  --oh64-blue:        #3f5faa;  /* Bleu principal (labels, texte champs) */
  --oh64-blue-dark:   #0566B0;  /* Bleu foncé pour titres de sections */
  --oh64-blue-muted:  #5a7ab8;  /* Bleu moyen pour sous-sections (suffisamment contrasté) */
  --oh64-bg:          #eaf8fc;  /* Fond des blocs */
  --oh64-border:      #39bfe8;  /* Bordure des champs */
  --oh64-error:       #b00020;  /* Rouge erreur */
  --oh64-radius:      18px;
  --oh64-input-radius: 4px;
}

/* ============================================================
   MENTION CHAMPS OBLIGATOIRES
   ============================================================ */
.required-notice {
  color: var(--oh64-blue);
  font-size: 0.85em;
  font-weight: 600;
  margin: 0 0 1em 0;
}

/* ============================================================
   TITRES (titre principal de page seulement, pas les sections)
   ============================================================ */
.oh64-form-title {
  color: var(--oh64-blue-dark);
  font-size: 28px;
  font-weight: 700;
  margin: 28px 0 12px;
  line-height: 1.1;
}

/* ============================================================
   FIELDSETS / LEGENDS (sections du formulaire)
   ============================================================ */
.oh64-fieldset {
  border: none;
  padding: 0;
  margin: 0 0 1.5em 0;
}

.oh64-legend {
  padding: 0;
  margin-bottom: 0.6em;
  color: var(--oh64-blue);
  font-size: 13px;
  font-weight: 700;
}

/* Sections principales (= remplace les anciens h2) */
.oh64-fieldset--section {
  margin-bottom: 2em;
}

.oh64-legend--section {
  font-size: 28px;
  font-weight: 700;
  color: var(--oh64-blue-dark);
  margin-bottom: 0.6em;
  line-height: 1.1;
}

/* Sous-sections (= remplace les anciens h3 — RÉFÉRENCES PROFESSIONNELLES etc.) */
.oh64-fieldset--subsection {
  margin: 1.5em 0;
}

.oh64-legend--subsection {
  font-size: 13px;
  font-weight: 700;
  color: var(--oh64-blue-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.8em;
}

/* ============================================================
   BLOCS FORMULAIRE
   ============================================================ */
.oh64-form-wrapper {
  background: var(--oh64-bg);
  border-radius: var(--oh64-radius);
  padding: 28px;
  margin: 0 0 28px;
}

/* ============================================================
   LIGNES / GRID (colonnes responsives)
   ============================================================ */
.oh64-form-row {
  margin-bottom: 14px;
}

.oh64-form-row--2col,
.oh64-form-row--3col {
  display: grid;
  gap: 18px;
}

.oh64-form-row--2col {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.oh64-form-row--3col {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.oh64-form-col--small {
  max-width: 100%;
}

/* ============================================================
   LABELS (VISIBLES — pas masqués)
   ============================================================ */
.oh64-label {
  display: block;
  color: var(--oh64-blue);
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 6px;
}

/* Astérisque obligatoire : visible mais aria-hidden,
   ce qui est cohérent avec la mention en haut du formulaire. */
.oh64-label span[aria-hidden="true"] {
  color: var(--oh64-blue-dark);
  margin-left: 2px;
}

/* ============================================================
   CHAMPS
   ============================================================ */
.oh64-form-wrapper input[type="text"],
.oh64-form-wrapper input[type="email"],
.oh64-form-wrapper input[type="tel"],
.oh64-form-wrapper input[type="url"],
.oh64-form-wrapper input[type="number"],
.oh64-form-wrapper input[type="date"],
.oh64-form-wrapper input[type="file"],
.oh64-form-wrapper select,
.oh64-form-wrapper textarea {
  width: 100%;
  min-height: 38px;
  border: 2px solid var(--oh64-border);
  border-radius: var(--oh64-input-radius);
  background: #fff;
  color: var(--oh64-blue);
  font-size: 14px;
  font-weight: 700;
  padding: 9px 14px;
  box-sizing: border-box;
  outline: none;
}

.oh64-form-wrapper textarea {
  min-height: 52px;
  resize: vertical;
}

/* Placeholder (uniformisé). Contraste suffisant pour rester lisible. */
.oh64-form-wrapper input::placeholder,
.oh64-form-wrapper textarea::placeholder {
  color: var(--oh64-blue);
  opacity: 0.55;
}

/* Focus : visible + accessible (RGAA 10.7.1) */
.oh64-form-wrapper input:focus,
.oh64-form-wrapper input:focus-visible,
.oh64-form-wrapper select:focus,
.oh64-form-wrapper select:focus-visible,
.oh64-form-wrapper textarea:focus,
.oh64-form-wrapper textarea:focus-visible {
  border-color: var(--oh64-blue-dark);
  box-shadow: 0 0 0 3px rgba(5, 102, 176, 0.2);
}

/* Select : on garde l'apparence native pour l'accessibilité (flèche du navigateur) */
.oh64-form-wrapper select {
  appearance: auto;
  cursor: pointer;
}

/* ============================================================
   RADIOS / CHECKBOXES
   ============================================================ */
.oh64-form-wrapper input[type="radio"],
.oh64-form-wrapper input[type="checkbox"] {
  accent-color: var(--oh64-blue-dark);
  margin-right: 6px;
}

/* Focus visible pour radios/checkboxes */
.oh64-form-wrapper input[type="radio"]:focus-visible,
.oh64-form-wrapper input[type="checkbox"]:focus-visible {
  outline: 2px solid var(--oh64-blue-dark);
  outline-offset: 2px;
}

/* Liste d'items WPCF7 (radios/checkboxes en ligne par défaut chez CF7) */
.wpcf7-list-item {
  display: inline-block;
  margin: 0 16px 0 0;
}

.wpcf7-list-item-label {
  color: var(--oh64-blue);
  font-size: 14px;
  font-weight: 700;
  margin-left: 4px;
  cursor: pointer;
}

/* ============================================================
   CGU / ACCEPTANCE
   ============================================================ */
.oh64-form-cgu,
.oh64-form-cgu label,
.oh64-form-cgu a {
  color: var(--oh64-blue);
  font-size: 13px;
  font-weight: 700;
}

.oh64-form-cgu a {
  text-decoration: underline;
}

.oh64-form-cgu a:hover,
.oh64-form-cgu a:focus {
  color: var(--oh64-blue-dark);
}

/* ============================================================
   FOOTER (bouton submit + CGU)
   ============================================================ */
.oh64-form-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 18px;
  flex-wrap: wrap;
}

/* ============================================================
   BOUTON ENVOYER
   ============================================================ */
.oh64-btn-submit,
.oh64-form-wrapper input[type="submit"] {
  background: var(--oh64-blue-dark);
  color: #fff;
  border: 0;
  border-radius: 999px;
  padding: 12px 34px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.oh64-btn-submit:hover,
.oh64-form-wrapper input[type="submit"]:hover {
  background: var(--oh64-blue);
}

.oh64-btn-submit:focus,
.oh64-btn-submit:focus-visible,
.oh64-form-wrapper input[type="submit"]:focus,
.oh64-form-wrapper input[type="submit"]:focus-visible {
  outline: 3px solid var(--oh64-blue-dark);
  outline-offset: 3px;
}

/* Bouton désactivé (RGAA : doit rester perceptible mais clairement non-actif) */
.oh64-btn-submit:disabled,
.oh64-form-wrapper input[type="submit"]:disabled {
  background: #aaa;
  cursor: not-allowed;
  opacity: 0.7;
}

/* ============================================================
   MESSAGES CF7 (validation, erreurs, succès)
   ============================================================ */
.wpcf7-not-valid-tip {
  color: var(--oh64-error);
  font-size: 12px;
  font-weight: 600;
  margin-top: 4px;
  display: block;
}

.wpcf7-response-output {
  border: 2px solid var(--oh64-blue) !important;
  color: var(--oh64-blue);
  font-weight: 700;
  border-radius: var(--oh64-input-radius);
  padding: 12px;
}

/* États d'erreur sur les champs invalides */
.oh64-form-wrapper input.wpcf7-not-valid,
.oh64-form-wrapper select.wpcf7-not-valid,
.oh64-form-wrapper textarea.wpcf7-not-valid {
  border-color: var(--oh64-error);
}

/* ============================================================
   CLASSE UTILITAIRE — masquage visuel mais lecture SR
   À utiliser uniquement quand vraiment nécessaire (jamais sur un label !).
   ============================================================ */
.oh64-visually-hidden {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
  .oh64-form-wrapper {
    padding: 20px;
  }

  .oh64-form-row--2col,
  .oh64-form-row--3col {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .oh64-form-footer {
    flex-direction: column;
    align-items: flex-start;
  }

  .oh64-legend--section {
    font-size: 24px;
  }
}/* End custom CSS */