/* ──────────────────────────────────────────────────────────────
   PepTek · Klaviyo frontend widgets
   Restock alert, footer newsletter, account newsletter banner,
   post-purchase opt-in.
   ────────────────────────────────────────────────────────────── */

/* ─── Footer Newsletter (shared across pages) ─── */
.footer-newsletter {
  background: var(--pp-tint, #F8E6FA);
  border-top: 1.5px solid var(--line, #EFE6F1);
  padding: 28px 32px;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

.footer-newsletter .fn-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink-2, #2A2740);
  white-space: nowrap;
}

.footer-newsletter .fn-form {
  display: flex;
  gap: 8px;
  align-items: center;
  flex: 1;
  min-width: 240px;
}

.footer-newsletter .fn-form input[type="email"] {
  flex: 1;
  padding: 10px 14px;
  border: 1.5px solid var(--line, #EFE6F1);
  border-radius: 12px;
  font-size: 14px;
  background: #fff;
  color: var(--ink, #0B0A14);
  outline: none;
  transition: border-color 0.15s;
}

.footer-newsletter .fn-form input[type="email"]:focus {
  border-color: var(--pp, #9D27A9);
}

.footer-newsletter .fn-form button {
  padding: 10px 20px;
  background: var(--pp, #9D27A9);
  color: #fff;
  border: none;
  border-radius: 12px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s;
}

.footer-newsletter .fn-form button:hover:not(:disabled) {
  background: var(--pp-2, #6F1B79);
}

.footer-newsletter .fn-form button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.footer-newsletter .fn-success {
  color: var(--pp, #9D27A9);
  font-weight: 600;
  font-size: 14px;
}

.footer-newsletter .fn-err {
  color: #EF4444;
  font-size: 12px;
  margin-top: 4px;
}

/* ─── Restock Alert Widget ─── */
.restock-widget {
  background: #fff;
  border: 1.5px solid var(--line, #EFE6F1);
  border-radius: 18px;
  padding: 20px 24px;
  box-shadow: var(--clay-w-sm,
    0 14px 32px -14px rgba(60, 24, 130, 0.22),
    inset 2px 3px 0 rgba(255,255,255,0.95));
  margin-top: 16px;
  max-width: 480px;
}

.restock-widget.done {
  text-align: center;
  padding: 16px 24px;
}

.restock-widget .restock-confirm {
  color: var(--pp, #9D27A9);
  font-weight: 600;
  font-size: 14px;
}

.restock-widget .restock-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink-2, #2A2740);
  margin-bottom: 12px;
}

.restock-widget .restock-form {
  display: flex;
  gap: 8px;
  align-items: center;
}

.restock-widget .restock-form input[type="email"] {
  flex: 1;
  padding: 10px 14px;
  border: 1.5px solid var(--line, #EFE6F1);
  border-radius: 12px;
  font-size: 14px;
  background: #fff;
  color: var(--ink, #0B0A14);
  outline: none;
}

.restock-widget .restock-form input[type="email"]:focus {
  border-color: var(--pp, #9D27A9);
}

.restock-widget .restock-form button {
  padding: 10px 20px;
  background: var(--ink-2, #2A2740);
  color: #fff;
  border: none;
  border-radius: 12px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s;
}

.restock-widget .restock-form button:hover:not(:disabled) {
  background: var(--ink, #0B0A14);
}

.restock-widget .restock-err {
  color: #EF4444;
  font-size: 12px;
  margin-top: 6px;
}

/* ─── Account Newsletter Banner ─── */
.nl-banner {
  background: var(--pp-tint, #F8E6FA);
  border: 1.5px solid var(--pp-soft, #D58CDD);
  border-radius: 16px;
  padding: 16px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.nl-banner-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.nl-banner-eye {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--pp, #9D27A9);
  font-family: Montserrat, sans-serif;
}

.nl-banner-msg {
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-2, #2A2740);
}

.nl-banner-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.nl-dismiss {
  background: none;
  border: none;
  color: var(--ink-3, #6E6B85);
  font-size: 18px;
  cursor: pointer;
  padding: 0 4px;
  line-height: 1;
}

.nl-dismiss:hover {
  color: var(--ink, #0B0A14);
}

/* ─── Post-purchase opt-in panel ─── */
.ty-optin {
  margin-top: 24px;
}

.ty-optin h3 {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 4px;
}

@media (max-width: 600px) {
  .footer-newsletter {
    flex-direction: column;
    align-items: flex-start;
    padding: 20px 16px;
  }

  .footer-newsletter .fn-form {
    flex-direction: column;
    width: 100%;
  }

  .footer-newsletter .fn-form input,
  .footer-newsletter .fn-form button {
    width: 100%;
  }

  .restock-widget .restock-form {
    flex-direction: column;
  }

  .restock-widget .restock-form input,
  .restock-widget .restock-form button {
    width: 100%;
  }

  .nl-banner {
    flex-direction: column;
    align-items: flex-start;
  }
}
