/* ==========================================================================
   Nexus — Quote modal (shared)
   Extracted from index.html, tokenized to brand vars.
   Brand-fix: inputs now use Antonio (was 'Inter'); colors → var(--nx).
   Behavior + the POST /api/leads contract live in assets/js/nexus-quote.js.
   ========================================================================== */
.nx-quote-overlay {
  position: fixed; inset: 0; z-index: 9999; display: none;
  background: rgba(0, 0, 0, 0.72); -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  align-items: center; justify-content: center; padding: var(--s-5);
  opacity: 0; transition: opacity var(--dur-fast) var(--ease-out);
}
.nx-quote-overlay.open { display: flex; opacity: 1; }

.nx-quote-modal {
  width: 100%; max-width: 480px; background: var(--surface);
  border: 1px solid var(--border-soft); border-radius: var(--r-card);
  padding: var(--s-6) var(--s-6) var(--s-6); color: var(--text);
  box-shadow: var(--shadow-elevate);
  transform: translateY(10px); transition: transform var(--dur) var(--ease-out);
  max-height: 92vh; overflow-y: auto;
}
.nx-quote-overlay.open .nx-quote-modal { transform: translateY(0); }

.nx-quote-close {
  position: absolute; top: 14px; right: 16px; background: transparent; border: 0;
  color: rgba(var(--fg-rgb), 0.55); font-size: 24px; line-height: 1; cursor: pointer;
  padding: 6px 10px; border-radius: var(--r-soft);
  transition: color var(--dur-fast) var(--ease-out), background-color var(--dur-fast) var(--ease-out);
}
.nx-quote-close:hover { color: var(--text); background: rgba(var(--fg-rgb), 0.06); }
.nx-quote-close:focus-visible { outline: 2px solid var(--nx); outline-offset: 2px; }

.nx-quote-modal__head { position: relative; margin-bottom: var(--s-5); }
.nx-quote-modal__eyebrow {
  display: inline-block; color: var(--nx); font-family: var(--font-sans); font-weight: var(--w-bold);
  font-size: 11px; letter-spacing: var(--track-eyebrow); text-transform: uppercase; margin-bottom: var(--s-2);
}
.nx-quote-modal__title {
  margin: 0; font-family: var(--font-sans); font-weight: var(--w-bold);
  font-size: 32px; letter-spacing: var(--track-snug); text-transform: uppercase;
}
.nx-quote-modal__sub { margin: 6px 0 0; color: rgba(var(--fg-rgb), 0.55); font-size: 13px; }

.nx-quote-field { margin-bottom: 14px; }
.nx-quote-field label {
  display: block; font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em;
  color: rgba(var(--fg-rgb), 0.55); margin-bottom: 6px; font-family: var(--font-sans); font-weight: var(--w-bold);
}
.nx-quote-field input, .nx-quote-field select, .nx-quote-field textarea {
  width: 100%; background: var(--page); border: 1px solid rgba(var(--fg-rgb), 0.14); color: var(--text);
  font-family: var(--font-sans); font-size: 14px; padding: 11px 13px; border-radius: var(--r-soft);
  outline: none; transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.nx-quote-field textarea { min-height: 90px; resize: vertical; }
.nx-quote-field input:focus-visible, .nx-quote-field select:focus-visible, .nx-quote-field textarea:focus-visible {
  border-color: var(--nx); box-shadow: 0 0 0 3px rgba(255, 2, 0, 0.22);
}
.nx-quote-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 420px) { .nx-quote-row { grid-template-columns: 1fr; } }

.nx-quote-submit {
  margin-top: 10px; width: 100%; background: var(--nx); color: #fff; border: 0;
  font-family: var(--font-sans); font-weight: var(--w-bold); font-size: 16px; letter-spacing: 0.08em;
  text-transform: uppercase; padding: 14px 18px; border-radius: var(--r-soft); cursor: pointer;
  transition: transform var(--dur-fast) var(--ease-out), background-color var(--dur-fast) var(--ease-out);
}
.nx-quote-submit:hover { background: #e50200; }
.nx-quote-submit:active { transform: translateY(1px); }
.nx-quote-submit:focus-visible { outline: 2px solid #fff; outline-offset: 2px; }
.nx-quote-submit[disabled] { opacity: 0.6; cursor: progress; }

.nx-quote-status { margin-top: 12px; min-height: 1.2em; font-size: 13px; }
.nx-quote-status.err { color: var(--nx); }
.nx-quote-status.ok { color: #22c55e; }

.nx-quote-success { text-align: center; padding: 12px 0 4px; }
.nx-quote-success__icon { width: 58px; height: 58px; border-radius: 50%; margin: 0 auto 14px; background: rgba(34, 197, 94, 0.15); display: grid; place-items: center; color: #22c55e; font-size: 28px; font-weight: 700; }
.nx-quote-success__title { font-family: var(--font-sans); font-weight: var(--w-bold); font-size: 24px; letter-spacing: -0.01em; text-transform: uppercase; margin: 0 0 6px; }
.nx-quote-success__body { color: rgba(var(--fg-rgb), 0.55); font-size: 14px; margin: 0 0 18px; line-height: 1.6; }
