/*!
 * Mia waitlist · modal + form (additive, non-destructive).
 * On-brand: cream, terracotta, Fraunces display. Mobile-first.
 */

.mia-wl-overlay {
  position: fixed;
  inset: 0;
  z-index: 10001;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: rgba(28, 25, 23, 0.42);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.mia-wl-overlay.open {
  opacity: 1;
  pointer-events: auto;
}

.mia-wl-modal {
  width: 100%;
  max-width: 440px;
  background: var(--mia-cream, #F3EDE7);
  border-radius: 28px;
  padding: clamp(28px, 5vw, 40px);
  box-shadow: 0 40px 80px -20px rgba(28, 25, 23, 0.45);
  position: relative;
  transform: translateY(16px) scale(0.98);
  transition: transform 0.4s cubic-bezier(0.2, 0.7, 0.2, 1);
  text-align: center;
}
.mia-wl-overlay.open .mia-wl-modal { transform: translateY(0) scale(1); }

.mia-wl-close {
  position: absolute;
  top: 16px; right: 16px;
  width: 32px; height: 32px;
  border: 0; background: rgba(28,25,23,0.06);
  border-radius: 999px;
  font-size: 18px; line-height: 1; color: var(--mia-muted, #6B6259);
  cursor: pointer;
  transition: background 0.2s;
}
.mia-wl-close:hover { background: rgba(28,25,23,0.12); }

.mia-wl-ring {
  width: 56px; height: 56px;
  margin: 0 auto 18px;
}
.mia-wl-eyebrow {
  font-family: var(--mia-f-head, "Plus Jakarta Sans", sans-serif);
  font-size: 12px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--mia-amber, #C27821);
  margin-bottom: 12px;
}
.mia-wl-title {
  font-family: var(--mia-f-display, "Fraunces", serif);
  font-style: italic; font-weight: 500;
  font-size: clamp(26px, 4vw + 10px, 34px);
  line-height: 1.1; letter-spacing: -0.02em;
  color: var(--mia-ink, #1C1917);
  margin-bottom: 12px;
}
.mia-wl-sub {
  font-family: var(--mia-f-body, "Source Sans 3", sans-serif);
  font-size: 15px; line-height: 1.55;
  color: var(--mia-muted, #6B6259);
  margin-bottom: 24px;
  max-width: 32ch;
  margin-inline: auto;
}

.mia-wl-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.mia-wl-input {
  width: 100%;
  padding: 15px 18px;
  border-radius: 14px;
  border: 1px solid rgba(28,25,23,0.14);
  background: var(--mia-cream-soft, #FAF8F6);
  font-family: var(--mia-f-body, sans-serif);
  font-size: 16px;
  color: var(--mia-ink, #1C1917);
  outline: none;
  transition: border-color 0.25s, box-shadow 0.25s;
  text-align: center;
}
.mia-wl-input::placeholder { color: var(--mia-faint, #A09688); }
.mia-wl-input:focus {
  border-color: var(--mia-terracotta, #B5634B);
  box-shadow: 0 0 0 3px rgba(181,99,75,0.12);
}
.mia-wl-submit {
  width: 100%;
  padding: 15px 18px;
  border-radius: 14px;
  border: 0;
  background: var(--mia-ink, #1C1917);
  color: var(--mia-cream, #F3EDE7);
  font-family: var(--mia-f-head, sans-serif);
  font-weight: 600; font-size: 15px;
  cursor: pointer;
  transition: background 0.3s, transform 0.2s;
}
.mia-wl-submit:hover { background: var(--mia-terracotta, #B5634B); transform: translateY(-1px); }
.mia-wl-submit:disabled { opacity: 0.6; cursor: default; transform: none; }

.mia-wl-note {
  margin-top: 14px;
  font-size: 12px;
  color: var(--mia-faint, #A09688);
  font-family: var(--mia-f-body, sans-serif);
}

.mia-wl-error {
  color: #b94a3a;
  font-size: 13px;
  margin-top: 8px;
  min-height: 16px;
  font-family: var(--mia-f-body, sans-serif);
}

/* success state */
.mia-wl-success { display: none; }
.mia-wl-modal.is-success .mia-wl-form,
.mia-wl-modal.is-success .mia-wl-sub,
.mia-wl-modal.is-success .mia-wl-eyebrow,
.mia-wl-modal.is-success .mia-wl-note { display: none; }
.mia-wl-modal.is-success .mia-wl-success { display: block; }
.mia-wl-modal.is-success .mia-wl-title { margin-bottom: 8px; }

.mia-wl-check {
  width: 56px; height: 56px;
  margin: 0 auto 18px;
  border-radius: 999px;
  background: var(--mia-sage, #7A8F72);
  display: grid; place-items: center;
  animation: wl-pop 0.5s cubic-bezier(0.2, 0.9, 0.3, 1.3);
}
@keyframes wl-pop { from { transform: scale(0); } to { transform: scale(1); } }

@media (prefers-reduced-motion: reduce) {
  .mia-wl-overlay, .mia-wl-modal, .mia-wl-check { transition: none; animation: none; }
}
