/* components.css */

/* ---------- LEAD MODAL ---------- */
.ff-lead-modal[hidden]{ display:none !important; }
.ff-lead-modal{
  position:fixed;
  inset:0;
  z-index:120;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: clamp(16px, 4vw, 28px);
}
.ff-lead-backdrop{
  position:absolute;
  inset:0;
  background: rgba(18,19,23,.58);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.ff-lead-dialog{
  position:relative;
  width: min(640px, 92vw);
  max-height: min(70vh, 640px);
  background:#fff;
  color:#121317;
  border-radius: 22px;
  border: 1px solid rgba(33,34,38,.08);
  box-shadow: 0 20px 60px rgba(18,19,23,.18);
  padding: clamp(16px, 2.6vw, 22px);
  display:grid;
  gap: clamp(12px, 1.4vw, 18px);
  overflow:auto;
}
.ff-lead-modal.is-loading .ff-lead-dialog{ opacity:0.96; }
.ff-lead-close{
  position:absolute;
  top: clamp(10px, 1.6vw, 14px);
  right: clamp(10px, 1.6vw, 14px);
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(33,34,38,.14);
  background: rgba(255,255,255,.92);
  color:#121317;
  font-size: 18px;
  line-height: 1;
  cursor:pointer;
  display:grid;
  place-items:center;
  transition: transform .12s ease, border-color .12s ease, background .12s ease;
}
.ff-lead-close:hover,
.ff-lead-close:focus-visible{
  transform: translateY(-1px);
  border-color: #121317;
  background:#fff;
  outline:none;
}
.ff-lead-header h2{
  margin:0;
  font-size: clamp(24px, 3vw, 34px);
  font-weight:700;
  letter-spacing:-.01em;
  text-align:center;
}
.ff-lead-header p{
  margin:10px 0 16px;
  color:#45474D;
  line-height:1.6;
  font-size: clamp(15px, 1.3vw, 18px);
  text-align:center;
}
.ff-lead-form{
  display:grid;
  gap: 10px;
}
.ff-lead-row{
  display:grid;
  gap:10px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.ff-lead-field{
  display:grid;
  gap:6px;
}
.ff-lead-field label{
  font-weight:600;
  font-size: 15px;
  color:#2F3034;
}
.ff-lead-field input{
  width:100%;
  padding: 13px 14px;
  border-radius: 10px;
  border: 1px solid rgba(33,34,38,.12);
  background:#fff;
  font-size: 16px;
  color:#121317;
  transition: border-color .12s ease, box-shadow .12s ease;
}
.ff-lead-field input:focus{
  outline:none;
  border-color: rgba(10,20,120,.4);
  box-shadow: 0 0 0 3px rgba(10,20,120,.12);
}
.ff-lead-privacy{
  display:flex;
  align-items:center;
  gap:10px;
  font-size: 14px;
  color:#45474D;
  margin: 4px 0 0;
}
.ff-lead-privacy input{
  margin-top:2px;
  width:18px;
  height:18px;
}
.ff-lead-privacy a{ color:#121317; }
.ff-lead-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:-26px;
  margin-left:auto;
  justify-content:flex-end;
  align-items:center;
}
.ff-lead-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 12px 18px;
  border-radius: 999px;
  border:1px solid transparent;
  cursor:pointer;
  font-weight:600;
  font-size: 15px;
  transition: transform .12s ease, background .12s ease, color .12s ease, border-color .12s ease;
}
.ff-lead-btn--primary{
  background:#121317;
  color:#fff;
}
.ff-lead-btn--primary:hover,
.ff-lead-btn--primary:focus-visible{
  background:#2F3034;
  transform: translateY(-1px);
  outline:none;
}
.ff-lead-btn--ghost{
  background:transparent;
  color:#121317;
  border-color: rgba(33,34,38,.16);
}
.ff-lead-btn--ghost:hover,
.ff-lead-btn--ghost:focus-visible{
  border-color:#121317;
  transform: translateY(-1px);
  outline:none;
}
.ff-lead-status{
  font-size:14px;
  line-height:1.5;
  color:#45474D;
  min-height:20px;
  text-align:left;
  margin-bottom: -4px;
}

.ff-lead-status[data-state="success"]{ color:#0a7a28; }
.ff-lead-status[data-state="error"]{ color:#b3261e; }
.ff-lead-status[data-state="info"]{ color:#121317; }

@media (max-width: 640px){
  .ff-lead-dialog{
    margin: clamp(18px, 4vw, 28px);
    max-height: min(90vh, 720px);
    overflow:auto;
  }
}
