/* lead_capture-sdk v3.0.0 — default theme.
 * Override any token by passing { theme: { accent, bg, text, border, fontDisplay, fontBody } }
 * to LeadCapture.mount(), or by setting CSS variables on .lead-capture-host.
 */
.lead-capture-host {
  --lead-capture-accent:        #c9a84c;        /* hollow gold (default) */
  --lead-capture-accent-soft:   rgba(201,168,76,0.10);
  --lead-capture-accent-strong: rgba(201,168,76,0.24);
  --lead-capture-bg:            #fbfaf6;
  --lead-capture-text:          #1f2226;
  --lead-capture-text-soft:     #6b7280;
  --lead-capture-border:        #e6e1d6;
  --lead-capture-error:         #8a3028;
  --lead-capture-success:       #2a6040;
  --lead-capture-font-display:  'Cinzel', Georgia, serif;
  --lead-capture-font-body:     'Lora', Georgia, serif;

  position: fixed; inset: 0; z-index: 9999;
  display: flex; align-items: center; justify-content: center;
}

.lead-capture-backdrop {
  position: absolute; inset: 0;
  background: rgba(20,30,40,0.40);
  backdrop-filter: blur(2px);
}

.lead-capture-dialog {
  position: relative;
  background: var(--lead-capture-bg);
  color:      var(--lead-capture-text);
  border: 1px solid var(--lead-capture-border);
  box-shadow: 0 24px 64px rgba(20,30,40,0.20);
  width: min(520px, 92vw);
  max-height: 92vh; overflow-y: auto;
  padding: 28px 28px 24px;
  font-family: var(--lead-capture-font-body);
}
.lead-capture-close {
  position: absolute; top: 10px; right: 10px;
  width: 28px; height: 28px;
  border: none; background: transparent;
  font-size: 22px; line-height: 1; cursor: pointer;
  color: var(--lead-capture-text-soft);
  border-radius: 999px;
  transition: background 120ms ease, color 120ms ease;
}
.lead-capture-close:hover { background: var(--lead-capture-accent-soft); color: var(--lead-capture-text); }

.lead-capture-title {
  margin: 0 0 6px;
  font-family: var(--lead-capture-font-display);
  font-size: 22px; letter-spacing: 0.5px;
  color: var(--lead-capture-text);
}
.lead-capture-sub {
  margin: 0 0 18px;
  font-size: 14px; color: var(--lead-capture-text-soft); line-height: 1.5;
}

.lead-capture-form { display: flex; flex-direction: column; gap: 12px; }

.lead-capture-field { display: flex; flex-direction: column; gap: 4px; }
.lead-capture-label {
  font-family: var(--lead-capture-font-display);
  font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--lead-capture-text-soft);
}
.lead-capture-form input[type=text],
.lead-capture-form input[type=email],
.lead-capture-form select,
.lead-capture-form textarea {
  width: 100%;
  padding: 9px 11px;
  border: 1px solid var(--lead-capture-border);
  background: #fff;
  color: var(--lead-capture-text);
  font-family: var(--lead-capture-font-body);
  font-size: 14px;
  outline: none;
  border-radius: 4px;
  transition: border-color 120ms ease, box-shadow 120ms ease;
}
.lead-capture-form input:focus,
.lead-capture-form select:focus,
.lead-capture-form textarea:focus {
  border-color: var(--lead-capture-accent);
  box-shadow: 0 0 0 3px var(--lead-capture-accent-soft);
}
.lead-capture-form textarea { resize: vertical; min-height: 88px; }

.lead-capture-hp {
  position: absolute !important;
  left: -10000px !important; top: -10000px !important;
  width: 1px !important; height: 1px !important;
  opacity: 0 !important;
}

.lead-capture-cta {
  margin-top: 6px;
  padding: 11px 16px;
  border: 1px solid var(--lead-capture-accent);
  border-radius: 999px;
  background: transparent;
  color: var(--lead-capture-accent);
  font-family: var(--lead-capture-font-display);
  font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase;
  font-weight: 600;
  cursor: pointer;
  transition: background 140ms ease, color 140ms ease;
}
.lead-capture-cta:hover:not(:disabled) {
  background: var(--lead-capture-accent-soft);
}
.lead-capture-cta:active:not(:disabled) {
  background: var(--lead-capture-accent-strong);
}
.lead-capture-cta:disabled { opacity: 0.55; cursor: wait; }

.lead-capture-status {
  margin-top: 4px;
  padding: 9px 11px;
  font-size: 13px;
  border: 1px solid transparent;
  border-radius: 4px;
}
.lead-capture-status-error   { border-color: rgba(138,48,40,0.30);  background: #fdf3f1; color: var(--lead-capture-error); }
.lead-capture-status-success { border-color: rgba(42,96,64,0.25);   background: #f1faf4; color: var(--lead-capture-success); }
