/**
 * Modale CF7 Sobery — styles isolés (hors Tailwind global).
 */
#sobery-cf7-modal.sobery-modal {
  --sm-primary: var(--color-primary, #D98563);
  --sm-secondary: var(--color-secondary, #91BDAD);
  --sm-foreground: var(--color-foreground, #1A1A1A);
  --sm-grey: var(--color-neutral-grey, #85827D);
  --sm-bg-main: var(--color-bg-main, #FDFFFE);
  --sm-bg-alt: var(--color-bg-alt, #F6F4F0);
  --sm-line: rgba(133, 130, 125, 0.25);
  --sm-font-display: var(--font-display, "Larken", serif);
  --sm-font-body: var(--font-body, "Maven Pro", sans-serif);

  position: fixed;
  inset: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s ease;
  font-family: var(--sm-font-body);
}

#sobery-cf7-modal.sobery-modal.is-open,
#sobery-cf7-modal.sobery-modal[aria-hidden="false"] {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

#sobery-cf7-modal .sobery-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(26, 26, 26, 0.45);
  backdrop-filter: blur(8px);
}

#sobery-cf7-modal .sobery-modal__dialog {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 36rem;
  max-height: min(92vh, 760px);
  overflow: hidden;
  border-radius: 1.5rem;
  border: 1px solid var(--sm-line);
  background: var(--sm-bg-main);
  color: var(--sm-foreground);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

#sobery-cf7-modal .sobery-modal__accent {
  height: 4px;
  background: linear-gradient(90deg, var(--sm-primary), var(--sm-secondary), var(--sm-primary));
}

#sobery-cf7-modal .sobery-modal__header {
  flex-shrink: 0;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--sm-line);
  background: linear-gradient(180deg, var(--sm-bg-alt), var(--sm-bg-main));
}

#sobery-cf7-modal .sobery-modal__header-row {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}

#sobery-cf7-modal .sobery-modal__heading {
  font-family: var(--sm-font-display);
  font-size: 1.5rem;
  line-height: 1.25;
  margin: 0.5rem 0 0;
}

#sobery-cf7-modal .sobery-modal__intro {
  font-size: 0.875rem;
  color: var(--sm-grey);
  line-height: 1.6;
  margin: 0.5rem 0 0;
  white-space: pre-line;
}

#sobery-cf7-modal .sobery-modal__badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.25rem 0.75rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  background: rgba(145, 189, 173, 0.15);
  border: 1px solid rgba(145, 189, 173, 0.35);
  color: var(--sm-secondary);
}

#sobery-cf7-modal .sobery-modal__close {
  flex-shrink: 0;
  width: 2.75rem;
  height: 2.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--sm-line);
  border-radius: 0.75rem;
  background: var(--sm-bg-main);
  color: var(--sm-grey);
  cursor: pointer;
  margin-left: auto;
}

#sobery-cf7-modal .sobery-modal__close:hover {
  border-color: rgba(217, 133, 99, 0.35);
  color: var(--sm-foreground);
}

#sobery-cf7-modal .sobery-modal__body {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 1.5rem;
  background: var(--sm-bg-main);
}

#sobery-cf7-modal .sobery-modal__body .hidden {
  display: none !important;
}

@media (min-width: 640px) {
  #sobery-cf7-modal.sobery-modal {
    padding: 1.5rem;
  }
  #sobery-cf7-modal .sobery-modal__header {
    padding: 1.5rem 1.75rem;
  }
  #sobery-cf7-modal .sobery-modal__body {
    padding: 1.75rem;
  }
}


.sobery-modal.sobery-modal--open {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

html.sobery-modal-open,
body.sobery-modal-open {
  overflow: hidden;
}

#sobery-cf7-modal .sobery-modal__header-content {
  flex: 1;
  min-width: 0;
}

#sobery-cf7-modal .sobery-modal__icon-wrap {
  display: none;
}

@media (min-width: 640px) {
  #sobery-cf7-modal .sobery-modal__icon-wrap {
    display: flex;
    width: 3rem;
    height: 3rem;
    align-items: center;
    justify-content: center;
    border-radius: 1rem;
    border: 1px solid rgba(145, 189, 173, 0.35);
    background: rgba(145, 189, 173, 0.1);
    color: var(--sm-secondary);
    flex-shrink: 0;
  }
}

#sobery-cf7-modal .sobery-cf7-panel.hidden {
  display: none !important;
}

/* Newsletter — modale : champs contenus + bouton lisible */
#sobery-cf7-modal .sobery-cf7-modal-body .sobery-form-newsletter .wpcf7-form {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  gap: 0.75rem;
  width: 100%;
  max-width: 100%;
}

#sobery-cf7-modal .sobery-cf7-modal-body .sobery-form-newsletter .wpcf7-form p {
  flex: none;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  margin: 0;
}

#sobery-cf7-modal .sobery-cf7-modal-body .sobery-form-newsletter .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
  max-width: 100%;
}

#sobery-cf7-modal .sobery-cf7-modal-body .sobery-form-newsletter .wpcf7-email,
#sobery-cf7-modal .sobery-cf7-modal-body .sobery-form-newsletter .wpcf7-text {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

#sobery-cf7-modal .sobery-cf7-modal-body .sobery-form-newsletter .wpcf7-submit {
  width: 100%;
  color: var(--sm-bg-main, #fdfffe) !important;
  background-color: var(--sm-primary, #d98563);
}

#sobery-cf7-modal .sobery-cf7-modal-body .sobery-form-newsletter .wpcf7-submit:hover,
#sobery-cf7-modal .sobery-cf7-modal-body .sobery-form-newsletter .wpcf7-submit:focus {
  color: var(--sm-bg-main, #fdfffe) !important;
  background-color: #c07050;
}
