/* ==========================================================
   Fair Future Foundation - Newsletter Popup
   File: /assets/css/fff-newsletter-popup.css
   ========================================================== */

:root{
  --fff-nl-bg: #ffffff;
  --fff-nl-ink: #0f172a;
  --fff-nl-muted: rgba(15,23,42,0.72);
  --fff-nl-line: rgba(15,23,42,0.10);
  --fff-nl-shadow: 0 18px 60px rgba(0,0,0,0.22);
  --fff-nl-radius: 10px;
  --fff-nl-accent: #4267b2;
}

/* Kill spacing Divi pour le holder */
.et_pb_section.fff-nl-holder,
.et_pb_row.fff-nl-holder-row{
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
}

.et_pb_section.fff-nl-holder{
  height: 0 !important;
  min-height: 0 !important;
}

/* Root */
.fff-nl-modal{
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: none;
}

.fff-nl-modal.is-open{
  display: block;
}

.fff-nl-backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.55);
}

/* Dialog */
.fff-nl-dialog{
  position: relative;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
}

.fff-nl-close{
  position: absolute;
  top: 18px;
  right: 18px;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.25);
  background: rgba(0,0,0,0.25);
  color: #fff;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.18s ease, background 0.18s ease;
}

.fff-nl-close:hover{
  transform: scale(1.03);
  background: rgba(0,0,0,0.34);
}

.fff-nl-card{
  width: 100%;
  max-width: 560px;
  background: var(--fff-nl-bg);
  border-radius: var(--fff-nl-radius);
  box-shadow: var(--fff-nl-shadow);
  border: 1px solid rgba(255,255,255,0.08);
  overflow: hidden;
}

/* Header */
.fff-nl-header{
  padding: 20px 22px 14px;
  border-bottom: 1px solid var(--fff-nl-line);
  background: linear-gradient(180deg, rgba(66,103,178,0.10), rgba(66,103,178,0.00));
}

.fff-nl-badge{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(66,103,178,0.95);
  font-weight: 800;
}

.fff-nl-title{
  margin: 10px 0 8px;
  font-size: 22px;
  line-height: 1.2;
  color: var(--fff-nl-ink);
  font-weight: 800;
}

.fff-nl-subtitle{
  margin: 0;
  font-size: 14px;
  line-height: 1.45;
  color: var(--fff-nl-muted);
}

/* Body */
.fff-nl-body{
  padding: 16px 22px 6px;
}

/* WPForms cleanup inside modal */
.fff-nl-body .wpforms-container{
  margin: 0 !important;
}

.fff-nl-body .wpforms-field{
  padding: 8px 0 !important;
}

.fff-nl-body input[type="text"],
.fff-nl-body input[type="email"],
.fff-nl-body input[type="tel"],
.fff-nl-body select,
.fff-nl-body textarea{
  width: 100% !important;
  border-radius: 8px !important;
  border: 1px solid rgba(15,23,42,0.18) !important;
  background: #fff !important;
  padding: 12px 12px !important;
  font-size: 15px !important;
  transition: box-shadow 0.18s ease, border-color 0.18s ease;
}

.fff-nl-body input[type="text"]:focus,
.fff-nl-body input[type="email"]:focus,
.fff-nl-body input[type="tel"]:focus,
.fff-nl-body select:focus,
.fff-nl-body textarea:focus{
  outline: none !important;
  border-color: rgba(66,103,178,0.55) !important;
  box-shadow: 0 0 0 4px rgba(66,103,178,0.18) !important;
}

.fff-nl-body .wpforms-submit{
  width: 100% !important;
  border-radius: 8px !important;
  padding: 12px 14px !important;
  font-weight: 800 !important;
  background: var(--fff-nl-accent) !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  transition: transform 0.18s ease, filter 0.18s ease, box-shadow 0.18s ease;
}

.fff-nl-body .wpforms-submit:hover{
  transform: translateY(-1px);
  filter: brightness(1.03);
  box-shadow: 0 10px 22px rgba(0,0,0,0.16);
}

/* Footer */
.fff-nl-footer{
  padding: 14px 22px 18px;
  border-top: 1px solid var(--fff-nl-line);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.fff-nl-footnote{
  font-size: 12px;
  color: var(--fff-nl-muted);
}

.fff-nl-actions{
  display: flex;
  gap: 10px;
}

.fff-nl-secondary,
.fff-nl-primary{
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 800;
  cursor: pointer;
  border: 1px solid rgba(15,23,42,0.12);
  transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
}

.fff-nl-secondary{
  background: #fff;
  color: var(--fff-nl-ink);
}

.fff-nl-primary{
  background: rgba(66,103,178,0.12);
  border-color: rgba(66,103,178,0.22);
  color: rgba(66,103,178,1);
}

.fff-nl-secondary:hover,
.fff-nl-primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(0,0,0,0.12);
  filter: brightness(1.02);
}

/* Mobile */
@media (max-width: 480px){
  .fff-nl-card{
    max-width: 100%;
  }
  .fff-nl-title{
    font-size: 20px;
  }
  .fff-nl-actions{
    flex-direction: column;
  }
}
/* WPForms: force hide form title/description (top block) */
.fff-nl-body .wpforms-head-container,
.fff-nl-body .wpforms-title,
.fff-nl-body .wpforms-description{
  display: none !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
/* ==========================================================
   FFF Newsletter Popup - WPForms checkbox fix (scoped)
   Objectif: neutraliser le style global trop agressif
   ========================================================== */

.fff-nl-body .wpforms-field-checkbox ul,
.fff-nl-body .wpforms-field-checkbox li{
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.fff-nl-body .wpforms-field-checkbox li{
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}

/* Checkbox: taille et look clean, sans effets globaux */
.fff-nl-body .wpforms-field-checkbox input[type="checkbox"]{
  -webkit-appearance: none !important;
  appearance: none !important;
  width: 18px !important;
  height: 18px !important;
  border: 2px solid rgba(0,0,0,0.28) !important;
  border-radius: 4px !important;
  background: #fff !important;
  box-shadow: none !important;
  outline: none !important;
  margin: 0 !important;
  flex: 0 0 18px !important;
  cursor: pointer !important;
  position: relative !important;
}

/* Etat coché: coche nette */
.fff-nl-body .wpforms-field-checkbox input[type="checkbox"]:checked{
  border-color: rgba(0,0,0,0.55) !important;
  background: #fff !important;
}

.fff-nl-body .wpforms-field-checkbox input[type="checkbox"]:checked::after{
  content: "" !important;
  position: absolute !important;
  left: 5px !important;
  top: 1px !important;
  width: 5px !important;
  height: 10px !important;
  border: solid rgba(0,0,0,0.85) !important;
  border-width: 0 2px 2px 0 !important;
  transform: rotate(45deg) !important;
}

/* Focus accessible, sans gros halo */
.fff-nl-body .wpforms-field-checkbox input[type="checkbox"]:focus-visible{
  box-shadow: 0 0 0 3px rgba(66,103,178,0.20) !important;
}

/* Label: pas de marge bizarre */
.fff-nl-body .wpforms-field-checkbox label{
  margin: 0 !important;
  cursor: pointer !important;
}

/* ==========================================================
   Divi Builder hard stop (prevents flicker in Visual Builder)
   ========================================================== */

/* Divi Visual Builder */
html.et-fb .fff-nl-modal,
body.et-fb .fff-nl-modal{
  display: none !important;
}

/* Divi Theme Builder / previews (safer broad net) */
html.et-tb .fff-nl-modal,
body.et-tb .fff-nl-modal,
html.et_pb_preview .fff-nl-modal,
body.et_pb_preview .fff-nl-modal{
  display: none !important;
}