/* ========================================================
   WC Auth Portal — Design System + Responsive CSS
   ======================================================== */

/* ── CSS Variables ──────────────────────────────────────── */
:root {
  --wcap-accent:      #6246ea;
  --wcap-accent-dark: #4f38c7;
  --wcap-accent-soft: rgba(98,70,234,.12);

  --wcap-bg:       #ffffff;
  --wcap-surface:  #f8f7ff;
  --wcap-border:   #e2e0f0;
  --wcap-border-focus: #6246ea;

  --wcap-text:     #1a1a2e;
  --wcap-muted:    #6b6880;
  --wcap-error:    #e63946;
  --wcap-success:  #2a9d5c;
  --wcap-warning:  #f4a261;

  --wcap-radius:   12px;
  --wcap-radius-sm: 8px;
  --wcap-shadow:   0 4px 24px rgba(98,70,234,.12);
  --wcap-shadow-lg: 0 12px 48px rgba(98,70,234,.18);

  --wcap-font:     'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --wcap-trans:    0.2s ease;

  --wcap-max-w:    440px;
}

/* ── Base Reset ─────────────────────────────────────────── */
.wcap-auth-wrap *,
.wcap-auth-wrap *::before,
.wcap-auth-wrap *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
.wcap-auth-wrap {
  font-family: var(--wcap-font);
  color: var(--wcap-text);
  background: var(--wcap-bg);
  border: 1px solid var(--wcap-border);
  border-radius: var(--wcap-radius);
  box-shadow: var(--wcap-shadow);
  max-width: var(--wcap-max-w);
  width: 100%;
  margin: 0 auto;
  padding: 36px 36px 32px;
  position: relative;
}

/* ── Brand Header ───────────────────────────────────────── */
.wcap-auth-brand {
  text-align: center;
  margin-bottom: 24px;
}
.wcap-auth-brand img,
.wcap-auth-brand .custom-logo {
  max-height: 48px;
  width: auto;
}
.wcap-brand-name {
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: -0.03em;
  background: linear-gradient(135deg, var(--wcap-accent), #a78bfa);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Tabs ───────────────────────────────────────────────── */
.wcap-tabs {
  display: flex;
  background: var(--wcap-surface);
  border-radius: var(--wcap-radius-sm);
  padding: 4px;
  gap: 4px;
  margin-bottom: 28px;
}
.wcap-auth-wrap .wcap-tab {
  flex: 1;
  background: transparent;
  border: none;
  border-radius: 6px;
  padding: 10px 0;
  font-size: .875rem;
  font-weight: 600;
  color: var(--wcap-muted);
  cursor: pointer;
  transition: all var(--wcap-trans);
  font-family: var(--wcap-font);
  letter-spacing: .01em;
}
.wcap-auth-wrap .wcap-tab:hover { color: var(--wcap-text); background: transparent; }
.wcap-auth-wrap .wcap-tab--active {
  background: var(--wcap-bg) !important;
  color: var(--wcap-accent) !important;
  box-shadow: 0 1px 6px rgba(98,70,234,.14);
}

/* ── Message banner ─────────────────────────────────────── */
.wcap-message {
  padding: 12px 16px;
  border-radius: var(--wcap-radius-sm);
  font-size: .875rem;
  font-weight: 500;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 8px;
  line-height: 1.4;
}
.wcap-message[hidden] { display: none; }
.wcap-message--error   { background: #fff2f2; color: var(--wcap-error);   border: 1px solid #ffd0d0; }
.wcap-message--success { background: #f0fdf6; color: var(--wcap-success); border: 1px solid #c3f0d9; }

/* ── Fields ─────────────────────────────────────────────── */
.wcap-field {
  margin-bottom: 18px;
}
.wcap-field label {
  display: block;
  font-size: .8125rem;
  font-weight: 600;
  color: var(--wcap-text);
  margin-bottom: 6px;
  letter-spacing: .01em;
}
.wcap-required { color: var(--wcap-error); margin-left: 2px; }

.wcap-input-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.wcap-input-wrap input {
  width: 100%;
  padding: 12px 44px 12px 42px;
  border: 1.5px solid var(--wcap-border);
  border-radius: var(--wcap-radius-sm);
  font-size: .9375rem;
  font-family: var(--wcap-font);
  color: var(--wcap-text);
  background: var(--wcap-bg);
  outline: none;
  transition: border-color var(--wcap-trans), box-shadow var(--wcap-trans);
  -webkit-appearance: none;
}
.wcap-input-wrap input:focus {
  border-color: var(--wcap-border-focus);
  box-shadow: 0 0 0 3px var(--wcap-accent-soft);
}
.wcap-input-wrap input::placeholder { color: #b5b2c9; }
.wcap-input-wrap input.wcap-has-error {
  border-color: var(--wcap-error);
  box-shadow: 0 0 0 3px rgba(230,57,70,.1);
}

/* No left icon: reduce left padding */
.wcap-input-wrap input:first-child:not(:only-child) { padding-left: 14px; }
.wcap-row-two .wcap-input-wrap input { padding-left: 14px; }

/* ── Input icons (SVG inline via CSS background) ──────── */
.wcap-input-icon {
  position: absolute;
  left: 13px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  opacity: .45;
  pointer-events: none;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  flex-shrink: 0;
}
.wcap-icon-user  { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236b6880' stroke-width='2'%3E%3Ccircle cx='12' cy='8' r='4'/%3E%3Cpath stroke-linecap='round' d='M4 20c0-4 3.582-7 8-7s8 3 8 7'/%3E%3C/svg%3E"); }
.wcap-icon-lock  { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236b6880' stroke-width='2'%3E%3Crect x='5' y='11' width='14' height='10' rx='2'/%3E%3Cpath stroke-linecap='round' d='M8 11V7a4 4 0 018 0v4'/%3E%3C/svg%3E"); }
.wcap-icon-mail  { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236b6880' stroke-width='2'%3E%3Crect x='3' y='5' width='18' height='14' rx='2'/%3E%3Cpath stroke-linecap='round' d='M3 7l9 6 9-6'/%3E%3C/svg%3E"); }
.wcap-icon-phone { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236b6880' stroke-width='2'%3E%3Cpath stroke-linecap='round' d='M3 5a2 2 0 012-2h3.28a1 1 0 01.948.684l1.498 4.493a1 1 0 01-.502 1.21l-2.257 1.13a11.042 11.042 0 005.516 5.516l1.13-2.257a1 1 0 011.21-.502l4.493 1.498a1 1 0 01.684.949V19a2 2 0 01-2 2h-1C9.716 21 3 14.284 3 6V5z'/%3E%3C/svg%3E"); }
.wcap-icon-eye   { display: block; width: 18px; height: 18px; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236b6880' stroke-width='2'%3E%3Cpath stroke-linecap='round' d='M15 12a3 3 0 11-6 0 3 3 0 016 0z'/%3E%3Cpath stroke-linecap='round' d='M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z'/%3E%3C/svg%3E"); background-size: contain; background-repeat: no-repeat; }
.wcap-icon-eye--off { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236b6880' stroke-width='2'%3E%3Cpath stroke-linecap='round' d='M17.94 17.94A10.07 10.07 0 0112 20c-7 0-11-8-11-8a18.45 18.45 0 015.06-5.94M9.9 4.24A9.12 9.12 0 0112 4c7 0 11 8 11 8a18.5 18.5 0 01-2.16 3.19m-6.72-1.07a3 3 0 11-4.24-4.24'/%3E%3Cline x1='1' y1='1' x2='23' y2='23' stroke-linecap='round'/%3E%3C/svg%3E"); }
.wcap-icon-back  { display: inline-block; width: 16px; height: 16px; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236246ea' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M15 19l-7-7 7-7'/%3E%3C/svg%3E"); background-size: contain; background-repeat: no-repeat; }

/* ── Password toggle button ─────────────────────────────── */
.wcap-pw-toggle {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  opacity: .5;
  transition: opacity var(--wcap-trans);
  display: flex;
  align-items: center;
}
.wcap-pw-toggle:hover { opacity: 1; }

/* ── Password strength ──────────────────────────────────── */
.wcap-pw-strength-bar {
  height: 4px;
  background: var(--wcap-border);
  border-radius: 2px;
  margin-top: 8px;
  overflow: hidden;
}
.wcap-pw-strength-fill {
  height: 100%;
  width: 0;
  border-radius: 2px;
  transition: width .35s ease, background-color .35s ease;
}
.wcap-pw-strength-label {
  font-size: .75rem;
  font-weight: 600;
  margin-top: 4px;
  display: block;
}

/* ── Remember me / links row ────────────────────────────── */
.wcap-row-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}
.wcap-checkbox-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: .8125rem;
  color: var(--wcap-muted);
  user-select: none;
}
.wcap-checkbox-label input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--wcap-accent);
  cursor: pointer;
}
.wcap-link {
  background: none;
  border: none;
  color: var(--wcap-accent);
  font-size: .8125rem;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--wcap-font);
  padding: 0;
  text-decoration: none;
  transition: color var(--wcap-trans);
}
.wcap-link:hover { color: var(--wcap-accent-dark); text-decoration: underline; }

/* ── Primary button ─────────────────────────────────────── */
.wcap-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 13px 24px;
  border: none;
  border-radius: var(--wcap-radius-sm);
  font-family: var(--wcap-font);
  font-size: .9375rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--wcap-trans);
  letter-spacing: .01em;
  position: relative;
  overflow: hidden;
}
.wcap-btn-primary {
  background: var(--wcap-accent);
  color: #fff;
  box-shadow: 0 2px 10px rgba(98,70,234,.3);
}
.wcap-btn-primary:hover:not(:disabled) {
  background: var(--wcap-accent-dark);
  box-shadow: 0 4px 18px rgba(98,70,234,.4);
  transform: translateY(-1px);
}
.wcap-btn-primary:active { transform: translateY(0); }
.wcap-btn-primary:disabled { opacity: .7; cursor: not-allowed; transform: none; }
.wcap-btn-full { width: 100%; }

/* ── Spinner ─────────────────────────────────────────────── */
.wcap-spinner {
  width: 18px;
  height: 18px;
  border: 2.5px solid rgba(255,255,255,.35);
  border-top-color: #fff;
  border-radius: 50%;
  animation: wcap-spin .65s linear infinite;
  flex-shrink: 0;
}
.wcap-spinner[hidden] { display: none; }
@keyframes wcap-spin { to { transform: rotate(360deg); } }

/* ── Two-column row ─────────────────────────────────────── */
.wcap-row-two {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

/* ── Switch hint ────────────────────────────────────────── */
.wcap-switch-hint {
  text-align: center;
  font-size: .8125rem;
  color: var(--wcap-muted);
  margin-top: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

/* ── Lost password head ─────────────────────────────────── */
.wcap-lost-head { margin-bottom: 20px; }
.wcap-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: none;
  color: var(--wcap-accent);
  font-size: .875rem;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--wcap-font);
  padding: 0 0 12px 0;
  transition: color var(--wcap-trans);
}
.wcap-back-btn:hover { color: var(--wcap-accent-dark); }
.wcap-lost-desc {
  font-size: .875rem;
  color: var(--wcap-muted);
  line-height: 1.5;
}

/* ── Panel show/hide animation ──────────────────────────── */
.wcap-panel[hidden] { display: none; }
.wcap-panel { animation: wcap-fade-in .25s ease; }
@keyframes wcap-fade-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Popup trigger button (standalone) ──────────────────── */
.wcap-popup-trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 22px;
  border-radius: var(--wcap-radius-sm);
  font-family: var(--wcap-font);
  font-size: .9rem;
  font-weight: 600;
  cursor: pointer;
  border: none;
}

/* ── Popup overlay ──────────────────────────────────────── */
.wcap-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15,10,40,.65);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  opacity: 0;
  transition: opacity .25s ease;
}
.wcap-overlay:not([hidden]) {
  display: flex;
  opacity: 0;
  animation: wcap-overlay-in .25s ease forwards;
}
@keyframes wcap-overlay-in { to { opacity: 1; } }
.wcap-overlay[hidden] { display: none; }

.wcap-popup-inner {
  position: relative;
  width: 100%;
  max-width: 460px;
  max-height: 90dvh;
  overflow-y: auto;
  background: var(--wcap-bg);
  border-radius: var(--wcap-radius);
  box-shadow: var(--wcap-shadow-lg);
  padding: 40px 36px 32px;
  animation: wcap-popup-in .3s cubic-bezier(.34,1.56,.64,1);
  scrollbar-width: thin;
}
@keyframes wcap-popup-in {
  from { transform: scale(.9) translateY(16px); opacity: 0; }
  to   { transform: scale(1)  translateY(0);    opacity: 1; }
}

.wcap-popup-close {
  position: absolute;
  top: 14px;
  right: 16px;
  width: 32px;
  height: 32px;
  background: var(--wcap-surface);
  border: none;
  border-radius: 50%;
  font-size: 1.1rem;
  cursor: pointer;
  color: var(--wcap-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--wcap-trans);
  z-index: 1;
}
.wcap-popup-close:hover {
  background: var(--wcap-accent-soft);
  color: var(--wcap-accent);
}

/* Popup — no outer card shadow (card is the popup itself) */
.wcap-overlay .wcap-auth-wrap {
  border: none;
  box-shadow: none;
  padding: 0;
  max-width: 100%;
}

/* ── Responsive: Tablet ──────────────────────────────────── */
@media (max-width: 600px) {
  .wcap-auth-wrap {
    padding: 28px 20px 24px;
    border-radius: 12px;
  }
  .wcap-popup-inner {
    padding: 32px 20px 24px;
    border-radius: 16px;
  }
  .wcap-row-two {
    grid-template-columns: 1fr;
  }
  .wcap-auth-brand { margin-bottom: 20px; }
  .wcap-tabs { margin-bottom: 22px; }
}

/* ── Responsive: Mobile ─────────────────────────────────── */
@media (max-width: 420px) {
  .wcap-auth-wrap {
    padding: 24px 16px 20px;
  }
  .wcap-popup-inner {
    padding: 28px 16px 20px;
    max-height: 95dvh;
  }
  .wcap-input-wrap input {
    font-size: .875rem;
    padding: 11px 40px 11px 40px;
  }
  .wcap-btn { padding: 12px 20px; font-size: .875rem; }
  .wcap-overlay { padding: 0; align-items: flex-end; }
  .wcap-popup-inner {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    max-height: 92dvh;
    animation: wcap-popup-mobile-in .3s cubic-bezier(.34,1.2,.64,1);
  }
  @keyframes wcap-popup-mobile-in {
    from { transform: translateY(100%); }
    to   { transform: translateY(0); }
  }
}

/* ── My Account page wrapper ────────────────────────────── */
.woocommerce .wcap-auth-wrap {
  margin: 40px auto;
}

/* ── Accessibility ──────────────────────────────────────── */
.wcap-btn:focus-visible,
.wcap-tab:focus-visible,
.wcap-input-wrap input:focus-visible,
.wcap-link:focus-visible {
  outline: 2px solid var(--wcap-accent);
  outline-offset: 2px;
}
@media (prefers-reduced-motion: reduce) {
  .wcap-panel,
  .wcap-overlay,
  .wcap-popup-inner {
    animation: none;
  }
}

/* ========================================================
   Checkout login panel
   ======================================================== */
.wcap-checkout-login-wrap {
  border: 1.5px solid var(--wcap-border);
  border-radius: var(--wcap-radius);
  margin-bottom: 24px;
  overflow: hidden;
}
.wcap-checkout-login-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 18px;
  background: var(--wcap-surface);
  font-size: .875rem;
  color: var(--wcap-muted);
  flex-wrap: wrap;
}
.wcap-checkout-login-icon { font-style: normal; font-size: 1rem; }
.wcap-checkout-toggle-btn {
  background: none;
  border: none;
  color: var(--wcap-accent);
  font-weight: 600;
  font-size: .875rem;
  font-family: var(--wcap-font);
  cursor: pointer;
  padding: 0;
  text-decoration: underline;
  transition: color var(--wcap-trans);
}
.wcap-checkout-toggle-btn:hover { color: var(--wcap-accent-dark); }

.wcap-checkout-login-box {
  padding: 20px 18px 18px;
  border-top: 1.5px solid var(--wcap-border);
  animation: wcap-fade-in .2s ease;
}
.wcap-checkout-login-box[hidden] { display: none; }

.wcap-checkout-form {
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  max-width: 100% !important;
}
.wcap-checkout-login-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.wcap-checkout-login-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 16px;
  flex-wrap: wrap;
}
.wcap-lost-link { margin-left: auto; }

@media (max-width: 600px) {
  .wcap-checkout-login-grid { grid-template-columns: 1fr; }
  .wcap-checkout-login-actions { gap: 12px; }
  .wcap-lost-link { margin-left: 0; }
}

/* ========================================================
   Lost password / reset password page
   ======================================================== */
.wcap-page-wrap {
  padding: 40px 16px 60px;
  min-height: 60vh;
  display: flex;
  align-items: flex-start;
  justify-content: center;
}
.wcap-page-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--wcap-text);
  margin-bottom: 6px;
  letter-spacing: -.02em;
}
.wcap-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: none;
  color: var(--wcap-accent);
  font-size: .875rem;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--wcap-font);
  text-decoration: none;
  padding: 0 0 10px 0;
  transition: color var(--wcap-trans);
}
.wcap-back-btn:hover { color: var(--wcap-accent-dark); }

/* ========================================================
   WooCommerce native notices inside WCAP pages
   ======================================================== */
.wcap-page-wrap .woocommerce-error,
.wcap-page-wrap .woocommerce-message,
.wcap-page-wrap .woocommerce-info {
  list-style: none;
  padding: 12px 16px;
  border-radius: var(--wcap-radius-sm);
  font-size: .875rem;
  font-weight: 500;
  margin-bottom: 18px;
  border: 1px solid var(--wcap-border);
}
.wcap-page-wrap .woocommerce-error   { background: #fff2f2; color: var(--wcap-error);   border-color: #ffd0d0; }
.wcap-page-wrap .woocommerce-message { background: #f0fdf6; color: var(--wcap-success); border-color: #c3f0d9; }
.wcap-page-wrap .woocommerce-info    { background: #f3f0ff; color: var(--wcap-accent);  border-color: var(--wcap-border); }
.wcap-page-wrap .woocommerce-error li,
.wcap-page-wrap .woocommerce-message li,
.wcap-page-wrap .woocommerce-info li { margin: 0; }
