/*
 * Eduval — WooCommerce Authentication Pages (Login / Register / Lost Password)
 * Premium centered layout matching the cart page design system.
 */

/* -------------------------------------------------------------------------
 * Variables & Base Layout
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) {
  /* Ligeiramente mais estreito: alinha login / lost-password / registo */
  --eduval-auth-max: min(420px, 100%);
  --eduval-auth-pad-y: clamp(16px, 3vw, 28px);
  --eduval-auth-pad-x: clamp(16px, 3vw, 32px);
  --eduval-auth-surface: var(--white);
  --eduval-auth-border: color-mix(in srgb, var(--bg-blue) 12%, #e5e7eb);
  --eduval-auth-shadow: 0 20px 50px rgba(38, 30, 80, 0.10);
  --eduval-auth-radius: clamp(16px, 2vw, 24px);
  --eduval-auth-input-radius: 12px;
  --eduval-auth-btn-radius: 999px;
}

body.woocommerce-account:not(.logged-in) .site-main {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--bg-blue-secondary) 60%, var(--white)) 0%,
    var(--white) 100%
  );
  display: flex;
  flex-direction: column;
}

body.woocommerce-account:not(.logged-in) .site-main > .container {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  width: 100% !important;
  max-width: none !important;
  padding: var(--eduval-auth-pad-y) var(--eduval-auth-pad-x) !important;
  margin: 0 !important;
}

body.woocommerce-account:not(.logged-in) .site-main > .container > article {
  width: 100%;
  max-width: var(--eduval-auth-max);
  margin: 0 auto;
}

body.woocommerce-account:not(.logged-in) .entry-content {
  margin: 0;
  padding: 0;
}

/* Hide page title since we have form titles */
body.woocommerce-account:not(.logged-in) .entry-title,
body.woocommerce-account:not(.logged-in) .page-title {
  display: none;
}

/* -------------------------------------------------------------------------
 * WooCommerce Notices
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) .woocommerce-notices-wrapper {
  max-width: var(--eduval-auth-max);
  margin: 0 auto 16px;
  padding: 0;
}

body.woocommerce-account:not(.logged-in) .woocommerce-notices-wrapper :is(.woocommerce-message, .woocommerce-info, .woocommerce-error) {
  /* Auth pages also use toast notices (outside card/content flow). */
  position: fixed !important;
  top: 102px !important; /* ~10px abaixo da navbar para ver borda superior */
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: min(92vw, 760px) !important;
  max-width: 760px !important;
  z-index: 9999 !important;
  box-shadow: 0 14px 30px rgba(16, 24, 40, 0.18);
}

/* Some Woo/Wordfence flows output notices outside .woocommerce-notices-wrapper. */
body.woocommerce-account:not(.logged-in) .woocommerce > :is(.woocommerce-message, .woocommerce-info, .woocommerce-error),
body.woocommerce-account:not(.logged-in) .entry-content > :is(.woocommerce-message, .woocommerce-info, .woocommerce-error),
body.woocommerce-account:not(.logged-in) .site-main :is(ul.woocommerce-error, ul.woocommerce-info, ul.woocommerce-message) {
  position: fixed !important;
  top: 102px !important; /* ~10px abaixo da navbar para ver borda superior */
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: min(92vw, 760px) !important;
  max-width: 760px !important;
  margin: 0 !important;
  z-index: 9999 !important;
  box-shadow: 0 14px 30px rgba(16, 24, 40, 0.18);
}

body.woocommerce-account:not(.logged-in) :is(.woocommerce-message, .woocommerce-info, .woocommerce-error, ul.woocommerce-error, ul.woocommerce-info, ul.woocommerce-message).eduval-toast-notice {
  cursor: pointer;
  padding-right: 48px !important;
  transition: opacity 180ms ease, transform 180ms ease;
  text-align: justify;
  text-justify: inter-word;
}

body.woocommerce-account:not(.logged-in) :is(.woocommerce-message, .woocommerce-info, .woocommerce-error, ul.woocommerce-error, ul.woocommerce-info, ul.woocommerce-message) {
  cursor: pointer;
}

/* Ícone WooCommerce (::before): mesma caixa 30×30 e offset horizontal que o botão fechar (8px). */
body.woocommerce-account:not(.logged-in) :is(.woocommerce-message, .woocommerce-info, .woocommerce-error, ul.woocommerce-message, ul.woocommerce-info, ul.woocommerce-error)::before {
  top: 50% !important;
  left: 8px !important;
  margin: 0 !important;
  width: 30px !important;
  height: 30px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transform: translateY(-50%) !important;
  line-height: 1 !important;
  font-size: 1.125rem !important;
  box-sizing: border-box !important;
}

/* Título (linha 1) + corpo: filtro woocommerce_add_error + .eduval-wc-notice-after-title */
body.woocommerce-account:not(.logged-in) .eduval-toast-notice strong {
  display: block;
  font-weight: 800;
  margin: 0;
  line-height: 1.25;
}

body.woocommerce-account:not(.logged-in) .eduval-toast-notice .eduval-wc-notice-after-title {
  display: block;
  margin: 3px 0 0;
  line-height: 1.45;
}

body.woocommerce-account:not(.logged-in) .eduval-toast-notice.is-dismissing {
  opacity: 0;
  transform: translate(-50%, -8px) !important;
  pointer-events: none;
}

body.woocommerce-account:not(.logged-in) .eduval-toast-close {
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--bg-blue) 14%, #e5e7eb);
  background: rgba(255, 255, 255, 0.94);
  color: #475569;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.07);
  transition:
    background-color 160ms ease,
    border-color 160ms ease,
    color 160ms ease,
    box-shadow 160ms ease;
}

body.woocommerce-account:not(.logged-in) .eduval-toast-close:hover,
body.woocommerce-account:not(.logged-in) .eduval-toast-close:focus-visible {
  background: #fff;
  border-color: color-mix(in srgb, var(--bg-blue) 24%, #cbd5e1);
  color: #0f172a;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.1);
  outline: none;
}

body.woocommerce-account:not(.logged-in) .woocommerce-error.eduval-toast-notice .eduval-toast-close {
  border-color: color-mix(in srgb, #dc2626 28%, #fecaca);
  color: #b91c1c;
}

body.woocommerce-account:not(.logged-in) .woocommerce-error.eduval-toast-notice .eduval-toast-close:hover,
body.woocommerce-account:not(.logged-in) .woocommerce-error.eduval-toast-notice .eduval-toast-close:focus-visible {
  border-color: color-mix(in srgb, #dc2626 40%, #fca5a5);
  color: #991b1b;
}

body.woocommerce-account:not(.logged-in) .woocommerce-info.eduval-toast-notice .eduval-toast-close {
  border-color: color-mix(in srgb, #0284c7 28%, #bae6fd);
  color: #0369a1;
}

body.woocommerce-account:not(.logged-in) .woocommerce-info.eduval-toast-notice .eduval-toast-close:hover,
body.woocommerce-account:not(.logged-in) .woocommerce-info.eduval-toast-notice .eduval-toast-close:focus-visible {
  border-color: color-mix(in srgb, #0284c7 38%, #7dd3fc);
  color: #075985;
}

body.woocommerce-account:not(.logged-in) .woocommerce-message.eduval-toast-notice .eduval-toast-close {
  border-color: color-mix(in srgb, #16a34a 28%, #bbf7d0);
  color: #15803d;
}

body.woocommerce-account:not(.logged-in) .woocommerce-message.eduval-toast-notice .eduval-toast-close:hover,
body.woocommerce-account:not(.logged-in) .woocommerce-message.eduval-toast-notice .eduval-toast-close:focus-visible {
  border-color: color-mix(in srgb, #16a34a 38%, #86efac);
  color: #166534;
}

/* WooCommerce places a WooCommerce-font icon in ::before with position:absolute; left ~1.5em.
 * Theme padding must leave room or the glyph overlaps the copy (default WC uses ~3.5em start padding). */
body.woocommerce-account:not(.logged-in) .woocommerce-message,
body.woocommerce-account:not(.logged-in) .woocommerce-info,
body.woocommerce-account:not(.logged-in) .woocommerce-error {
  border-radius: var(--eduval-auth-input-radius);
  padding-block: 14px;
  padding-inline-end: 18px;
  padding-inline-start: 3.125rem;
  margin: 0 0 16px;
  font-size: 0.92rem;
  line-height: 1.5;
}

body.woocommerce-account:not(.logged-in) .woocommerce-error {
  background: #fef2f2;
  border: 1px solid color-mix(in srgb, #dc2626 28%, #fecaca);
  border-left: 4px solid #dc2626;
  color: #991b1b;
}

body.woocommerce-account:not(.logged-in) .woocommerce-message {
  background: #dcfce7;
  border: 1px solid color-mix(in srgb, #16a34a 28%, #bbf7d0);
  border-left: 4px solid #16a34a;
  color: #166534;
}

body.woocommerce-account:not(.logged-in) .woocommerce-info {
  background: #e0f2fe;
  border: 1px solid color-mix(in srgb, #0284c7 28%, #bae6fd);
  border-left: 4px solid #0284c7;
  color: #075985;
}

/* -------------------------------------------------------------------------
 * Main Auth Container (Login / Register columns)
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) .woocommerce {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch;
  gap: 0;
  width: 100%;
  max-width: var(--eduval-auth-max) !important;
  margin: 0 auto;
  padding: 0;
  grid-template-columns: unset !important;
}

body.woocommerce-account:not(.logged-in) #customer_login {
  width: 100%;
}

body.woocommerce-account:not(.logged-in) #customer_login::before,
body.woocommerce-account:not(.logged-in) #customer_login::after {
  display: none;
}

body.woocommerce-account:not(.logged-in) #customer_login .u-column1,
body.woocommerce-account:not(.logged-in) #customer_login .u-column2,
body.woocommerce-account:not(.logged-in) #customer_login .col-1,
body.woocommerce-account:not(.logged-in) #customer_login .col-2 {
  width: 100%;
  max-width: 100%;
  float: none;
  margin: 0;
  padding: 0;
}

body.woocommerce-account:not(.logged-in) #customer_login .u-column1,
body.woocommerce-account:not(.logged-in) #customer_login .col-1 {
  position: relative;
}

/* -------------------------------------------------------------------------
 * Cartão único: título + corpo (sem gap entre faixas — mockup Criar conta / login)
 * Borda + sombra só no .eduval-auth-card; o h2 é só faixa + linha divisória.
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) .eduval-auth-card {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  background: var(--eduval-auth-surface);
  border: 1px solid var(--eduval-auth-border);
  border-radius: var(--eduval-auth-radius);
  box-shadow: var(--eduval-auth-shadow);
  overflow: hidden;
}

body.woocommerce-account:not(.logged-in) .eduval-auth-card > .eduval-auth-title {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  flex-shrink: 0;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: clamp(14px, 2.4vw, 20px) clamp(20px, 4vw, 28px) !important;
  box-sizing: border-box !important;
  font-size: clamp(0.88rem, 1.1vw + 0.62rem, 1.02rem) !important;
  font-weight: 800 !important;
  color: var(--bg-blue) !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  text-align: center !important;
  line-height: 1.3 !important;
  background: var(--eduval-auth-surface) !important;
  border: none !important;
  border-bottom: 1px solid var(--eduval-auth-border) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* Layout clássico WC (duas colunas / h2 directo): cartão só no formulário */
body.woocommerce-account:not(.logged-in) .u-column1 > h2,
body.woocommerce-account:not(.logged-in) .u-column2 > h2,
body.woocommerce-account:not(.logged-in) .col-1 > h2,
body.woocommerce-account:not(.logged-in) .col-2 > h2,
body.woocommerce-account:not(.logged-in) .entry-content .woocommerce > h2 {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  width: 100% !important;
  max-width: none !important;
  font-size: clamp(0.9rem, 1.2vw + 0.65rem, 1.05rem) !important;
  font-weight: 800 !important;
  color: var(--bg-blue) !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  text-align: center !important;
  line-height: 1.35 !important;
  margin: 0 !important;
  padding: clamp(18px, 2.5vw, 22px) clamp(22px, 4vw, 30px) !important;
  background: var(--eduval-auth-surface) !important;
  border: 1px solid var(--eduval-auth-border) !important;
  border-radius: var(--eduval-auth-radius) var(--eduval-auth-radius) 0 0 !important;
  box-sizing: border-box !important;
  box-shadow: none !important;
}

body.woocommerce-account:not(.logged-in) .woocommerce-form-login,
body.woocommerce-account:not(.logged-in) .woocommerce-form-register,
body.woocommerce-account:not(.logged-in) .woocommerce-ResetPassword {
  background: var(--eduval-auth-surface);
  border: 1px solid var(--eduval-auth-border);
  border-radius: var(--eduval-auth-radius);
  box-shadow: var(--eduval-auth-shadow);
  padding: clamp(24px, 4vw, 32px);
  margin: 0;
}

body.woocommerce-account:not(.logged-in) .u-column1 > h2 + .woocommerce-form-login,
body.woocommerce-account:not(.logged-in) .u-column2 > h2 + .woocommerce-form-register,
body.woocommerce-account:not(.logged-in) .col-1 > h2 + .woocommerce-form-login,
body.woocommerce-account:not(.logged-in) .col-2 > h2 + .woocommerce-form-register,
body.woocommerce-account:not(.logged-in) .woocommerce > h2 + .woocommerce-form-login,
body.woocommerce-account:not(.logged-in) .woocommerce > h2 + .woocommerce-form-register {
  border-top: 0 !important;
  border-radius: 0 0 var(--eduval-auth-radius) var(--eduval-auth-radius) !important;
  margin-top: 0 !important;
  box-shadow: var(--eduval-auth-shadow) !important;
}

/* Por cima do bloco anterior: formulários dentro do cartão unificado */
body.woocommerce-account:not(.logged-in) .eduval-auth-card > .woocommerce-form-login,
body.woocommerce-account:not(.logged-in) .eduval-auth-card > .woocommerce-form-register,
body.woocommerce-account:not(.logged-in) .eduval-auth-card > .woocommerce-ResetPassword {
  flex: 1 1 auto;
  width: 100%;
  margin: 0 !important;
  padding: clamp(20px, 4vw, 28px) clamp(22px, 4vw, 30px) !important;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

body.woocommerce-account:not(.logged-in) .eduval-auth-login-link {
  display: block;
  width: 100%;
  max-width: var(--eduval-auth-max);
  margin: 20px auto 32px;
  padding: 0;
  text-align: center;
  font-size: 0.9rem;
  line-height: 1.45;
  box-sizing: border-box;
}

body.woocommerce-account:not(.logged-in) .eduval-auth-login-link a {
  color: var(--bg-blue);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
}

body.woocommerce-account:not(.logged-in) .eduval-auth-login-link a:hover {
  color: color-mix(in srgb, var(--bg-blue) 88%, #000);
}

body.woocommerce-account:not(.logged-in) .eduval-auth-register-prompt {
  margin: 20px 0 0;
  text-align: center;
  font-size: 0.9rem;
  line-height: 1.45;
}

body.woocommerce-account:not(.logged-in) .eduval-auth-register-prompt a {
  color: var(--bg-blue);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
}

body.woocommerce-account:not(.logged-in) .eduval-auth-register-prompt a:hover {
  color: color-mix(in srgb, var(--bg-blue) 88%, #000);
}

/* -------------------------------------------------------------------------
 * Form Fields
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) .woocommerce-form-row {
  margin: 0 0 16px;
  padding: 0;
}

body.woocommerce-account:not(.logged-in) .woocommerce-form-row:last-of-type {
  margin-bottom: 0;
}

body.woocommerce-account:not(.logged-in) .woocommerce-form-row label {
  display: block;
  font-size: 0.875rem;
  font-weight: 700;
  color: color-mix(in srgb, var(--bg-blue) 85%, #374151);
  margin: 0 0 8px;
  letter-spacing: 0.01em;
}

body.woocommerce-account:not(.logged-in) .woocommerce-form-row label .required {
  color: var(--color-secondary);
  margin-left: 2px;
}

body.woocommerce-account:not(.logged-in) .woocommerce-Input,
body.woocommerce-account:not(.logged-in) .input-text {
  width: 100%;
  padding: 14px 18px;
  font-size: 1rem;
  line-height: 1.5;
  color: var(--bg-blue);
  background: var(--white);
  border: 1.5px solid color-mix(in srgb, var(--bg-blue) 18%, #e5e7eb);
  border-radius: var(--eduval-auth-input-radius);
  transition: 
    border-color 180ms ease,
    box-shadow 180ms ease,
    background-color 180ms ease;
  box-sizing: border-box;
}

body.woocommerce-account:not(.logged-in) .woocommerce-Input::placeholder,
body.woocommerce-account:not(.logged-in) .input-text::placeholder {
  color: #9ca3af;
  opacity: 1;
}

body.woocommerce-account:not(.logged-in) .woocommerce-Input:hover,
body.woocommerce-account:not(.logged-in) .input-text:hover {
  border-color: color-mix(in srgb, var(--bg-blue) 35%, #e5e7eb);
  background: color-mix(in srgb, var(--bg-blue-secondary) 30%, var(--white));
}

body.woocommerce-account:not(.logged-in) .woocommerce-Input:focus,
body.woocommerce-account:not(.logged-in) .input-text:focus {
  border-color: var(--bg-blue);
  background: var(--white);
  outline: none;
  box-shadow: 
    0 0 0 3px color-mix(in srgb, var(--bg-blue) 12%, transparent),
    0 1px 2px rgba(0, 0, 0, 0.05);
}

/* -------------------------------------------------------------------------
 * Checkbox (Remember me)
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) .woocommerce-form__label-for-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 0.88rem;
  color: color-mix(in srgb, var(--bg-blue) 70%, #374151);
  user-select: none;
}

body.woocommerce-account:not(.logged-in) .woocommerce-form__input-checkbox {
  width: 18px;
  height: 18px;
  margin: 0;
  cursor: pointer;
  accent-color: var(--bg-blue);
  border-radius: 4px;
}

/* -------------------------------------------------------------------------
 * Buttons
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) .woocommerce-form-login__submit,
body.woocommerce-account:not(.logged-in) .woocommerce-form-register__submit,
body.woocommerce-account:not(.logged-in) .woocommerce-ResetPassword .button,
body.woocommerce-account:not(.logged-in) .woocommerce-Button {
  display: block;
  width: 100%;
  padding: 14px 24px;
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  line-height: 1.3;
  color: var(--white);
  background: var(--bg-blue);
  border: none;
  border-radius: var(--eduval-auth-btn-radius);
  cursor: pointer;
  transition: 
    background-color 180ms ease,
    transform 100ms ease,
    box-shadow 180ms ease;
  box-shadow: 
    0 4px 14px color-mix(in srgb, var(--bg-blue) 25%, transparent),
    0 1px 3px rgba(0, 0, 0, 0.1);
}

body.woocommerce-account:not(.logged-in) .woocommerce-form-login__submit:hover,
body.woocommerce-account:not(.logged-in) .woocommerce-form-register__submit:hover,
body.woocommerce-account:not(.logged-in) .woocommerce-ResetPassword .button:hover,
body.woocommerce-account:not(.logged-in) .woocommerce-Button:hover {
  background: color-mix(in srgb, var(--bg-blue) 88%, var(--color-secondary));
  transform: translateY(-1px);
  box-shadow: 
    0 6px 20px color-mix(in srgb, var(--bg-blue) 30%, transparent),
    0 2px 6px rgba(0, 0, 0, 0.12);
}

body.woocommerce-account:not(.logged-in) .woocommerce-form-login__submit:active,
body.woocommerce-account:not(.logged-in) .woocommerce-form-register__submit:active,
body.woocommerce-account:not(.logged-in) .woocommerce-ResetPassword .button:active,
body.woocommerce-account:not(.logged-in) .woocommerce-Button:active {
  transform: translateY(0);
  box-shadow: 
    0 2px 8px color-mix(in srgb, var(--bg-blue) 20%, transparent),
    0 1px 2px rgba(0, 0, 0, 0.08);
}

body.woocommerce-account:not(.logged-in) .woocommerce-form-login__submit:focus,
body.woocommerce-account:not(.logged-in) .woocommerce-form-register__submit:focus,
body.woocommerce-account:not(.logged-in) .woocommerce-ResetPassword .button:focus,
body.woocommerce-account:not(.logged-in) .woocommerce-Button:focus {
  outline: none;
  box-shadow: 
    0 0 0 3px color-mix(in srgb, var(--bg-blue) 25%, transparent),
    0 4px 14px color-mix(in srgb, var(--bg-blue) 25%, transparent);
}

/* -------------------------------------------------------------------------
 * Lost password link (formulário de login WC padrão)
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) .woocommerce-LostPassword,
body.woocommerce-account:not(.logged-in) .lost_password {
  text-align: center;
  margin: 16px 0 0;
  padding: 0;
}

body.woocommerce-account:not(.logged-in) .woocommerce-LostPassword a,
body.woocommerce-account:not(.logged-in) .lost_password a {
  color: color-mix(in srgb, var(--bg-blue) 75%, #6b7280);
  font-size: 0.88rem;
  font-weight: 600;
  text-decoration: none;
  transition: color 150ms ease;
}

body.woocommerce-account:not(.logged-in) .woocommerce-LostPassword a:hover,
body.woocommerce-account:not(.logged-in) .lost_password a:hover {
  color: var(--bg-blue);
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* -------------------------------------------------------------------------
 * Divider between Login and Register
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) #customer_login .u-column1::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    color-mix(in srgb, var(--bg-blue) 18%, #e5e7eb) 20%,
    color-mix(in srgb, var(--bg-blue) 18%, #e5e7eb) 80%,
    transparent 100%
  );
  margin: 24px 0 0;
  position: relative;
}

body.woocommerce-account:not(.logged-in) #customer_login .u-column1::before {
  content: "ou";
  display: block;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  margin-top: calc(24px - 10px);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--bg-blue-secondary) 60%, var(--white)) 0%,
    var(--white) 100%
  );
  padding: 0 16px;
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: color-mix(in srgb, var(--bg-blue) 45%, #9ca3af);
  z-index: 1;
}

/* -------------------------------------------------------------------------
 * Lost Password Form (standalone)
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) .woocommerce-ResetPassword p:first-child {
  font-size: 0.92rem;
  line-height: 1.6;
  color: color-mix(in srgb, var(--bg-blue) 65%, #374151);
  text-align: center;
  margin: 0 0 20px;
  padding: 0;
}

body.woocommerce-account:not(.logged-in) .woocommerce-ResetPassword .clear {
  display: none;
}

/* Reset Password form (new password entry) */
body.woocommerce-account:not(.logged-in) .woocommerce-ResetPassword .form-row-first,
body.woocommerce-account:not(.logged-in) .woocommerce-ResetPassword .form-row-last {
  width: 100%;
  float: none;
  padding: 0;
}

/* -------------------------------------------------------------------------
 * Registration Form specific
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) .woocommerce-form-register p:not(.form-row):not(.woocommerce-form-row) {
  font-size: 0.92rem;
  line-height: 1.55;
  color: color-mix(in srgb, var(--bg-blue) 60%, #6b7280);
  text-align: center;
  margin: 0 0 18px;
  padding: 14px 16px;
  background: color-mix(in srgb, var(--bg-blue-secondary) 50%, var(--white));
  border-radius: var(--eduval-auth-input-radius);
  border: 1px solid color-mix(in srgb, var(--bg-blue) 10%, #e5e7eb);
}

/* -------------------------------------------------------------------------
 * Privacy Policy link (if present via hook)
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) .woocommerce-privacy-policy-text {
  font-size: 0.82rem;
  line-height: 1.5;
  color: color-mix(in srgb, var(--bg-blue) 55%, #6b7280);
  text-align: center;
  margin: 16px 0 0;
}

body.woocommerce-account:not(.logged-in) .woocommerce-privacy-policy-text a {
  color: var(--bg-blue);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* -------------------------------------------------------------------------
 * Responsive
 * ---------------------------------------------------------------------- */
@media (max-width: 600px) {
  body.woocommerce-account:not(.logged-in) {
    --eduval-auth-max: 100%;
  }
  
  body.woocommerce-account:not(.logged-in) .site-main > .container {
    padding: clamp(12px, 3vw, 20px) clamp(12px, 3vw, 16px) !important;
  }
  
  body.woocommerce-account:not(.logged-in) .woocommerce-form-login,
  body.woocommerce-account:not(.logged-in) .woocommerce-form-register,
  body.woocommerce-account:not(.logged-in) .woocommerce-ResetPassword {
    padding: clamp(18px, 4vw, 24px);
  }
  
  body.woocommerce-account:not(.logged-in) .entry-content .woocommerce > h2,
  body.woocommerce-account:not(.logged-in) .u-column1 > h2,
  body.woocommerce-account:not(.logged-in) .u-column2 > h2 {
    padding: clamp(16px, 3vw, 20px) clamp(18px, 4vw, 24px) !important;
  }

  body.woocommerce-account:not(.logged-in) .eduval-auth-card > .eduval-auth-title {
    padding: clamp(12px, 3vw, 16px) clamp(16px, 3vw, 22px) !important;
  }

  body.woocommerce-account:not(.logged-in) .eduval-auth-card > .woocommerce-form-login,
  body.woocommerce-account:not(.logged-in) .eduval-auth-card > .woocommerce-form-register,
  body.woocommerce-account:not(.logged-in) .eduval-auth-card > .woocommerce-ResetPassword {
    padding: clamp(16px, 4vw, 22px) clamp(16px, 3vw, 22px) !important;
  }
  
  body.woocommerce-account:not(.logged-in) .woocommerce-Input,
  body.woocommerce-account:not(.logged-in) .input-text {
    padding: 12px 14px;
    font-size: 16px; /* Prevents iOS zoom on focus */
  }

  body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields .input-text,
  body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields select {
    padding: 12px 14px;
    font-size: 16px;
  }
  
  body.woocommerce-account:not(.logged-in) .woocommerce-form-login__submit,
  body.woocommerce-account:not(.logged-in) .woocommerce-form-register__submit,
  body.woocommerce-account:not(.logged-in) .woocommerce-ResetPassword .button,
  body.woocommerce-account:not(.logged-in) .woocommerce-Button {
    padding: 12px 20px;
    font-size: 1rem;
  }

  body.woocommerce-account:not(.logged-in) .woocommerce-notices-wrapper :is(.woocommerce-message, .woocommerce-info, .woocommerce-error) {
    top: 86px !important; /* +10px face ao header em mobile */
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
  }

  body.woocommerce-account:not(.logged-in) .woocommerce > :is(.woocommerce-message, .woocommerce-info, .woocommerce-error),
  body.woocommerce-account:not(.logged-in) .entry-content > :is(.woocommerce-message, .woocommerce-info, .woocommerce-error),
  body.woocommerce-account:not(.logged-in) .site-main :is(ul.woocommerce-error, ul.woocommerce-info, ul.woocommerce-message) {
    top: 86px !important; /* +10px face ao header em mobile */
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
  }

}

/* -------------------------------------------------------------------------
 * Focus States (accessibility)
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) a:focus-visible {
  outline: 2px solid var(--bg-blue);
  outline-offset: 2px;
  border-radius: 4px;
}

/* -------------------------------------------------------------------------
 * Loading / Processing state
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) .woocommerce-form.processing {
  opacity: 0.7;
  pointer-events: none;
}

body.woocommerce-account:not(.logged-in) .woocommerce-form.processing button[type="submit"] {
  position: relative;
  color: transparent;
}

body.woocommerce-account:not(.logged-in) .woocommerce-form.processing button[type="submit"]::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 20px;
  margin: -10px 0 0 -10px;
  border: 2px solid transparent;
  border-top-color: var(--white);
  border-right-color: var(--white);
  border-radius: 50%;
  animation: eduval-auth-spin 600ms linear infinite;
}

@keyframes eduval-auth-spin {
  to {
    transform: rotate(360deg);
  }
}

/* -------------------------------------------------------------------------
 * Logged-in My Account page overrides (sidebar layout)
 * Inherit from woocommerce-account.css but ensure auth pages don't conflict
 * ---------------------------------------------------------------------- */
body.woocommerce-account.logged-in .woocommerce-form-login,
body.woocommerce-account.logged-in .woocommerce-form-register {
  background: transparent;
  border: none;
  border-radius: 0;
  box-shadow: none;
  padding: 0;
}

/* -------------------------------------------------------------------------
 * Logo / Brand above form (only shows if custom logo is set via PHP)
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in).has-custom-logo .site-main > .container::before {
  content: "";
  display: block;
  width: clamp(70px, 10vw, 100px);
  height: clamp(70px, 10vw, 100px);
  margin: 0 auto clamp(16px, 2vw, 24px);
  background: var(--eduval-login-logo-image) center/contain no-repeat;
  border-radius: 16px;
  box-shadow: 0 8px 24px rgba(38, 30, 80, 0.12);
}

/* -------------------------------------------------------------------------
 * Back to home link (injected via JS after .woocommerce)
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) .eduval-auth-back-link {
  display: block;
  width: 100%;
  max-width: var(--eduval-auth-max);
  margin: 20px auto 32px;
  padding: 0;
  text-align: center;
  font-size: 0.88rem;
  font-weight: 600;
  color: color-mix(in srgb, var(--bg-blue) 70%, #6b7280);
  text-decoration: none;
  transition: color 150ms ease;
  box-sizing: border-box;
}

body.woocommerce-account:not(.logged-in) .eduval-auth-back-link:hover {
  color: var(--bg-blue);
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* -------------------------------------------------------------------------
 * Animation on page load
 * ---------------------------------------------------------------------- */
@keyframes eduval-auth-fade-in {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

body.woocommerce-account:not(.logged-in) .eduval-auth-card {
  animation: eduval-auth-fade-in 350ms ease-out both;
}

/* -------------------------------------------------------------------------
 * Alternador Iniciar sessão / Novo registo
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) .eduval-auth-mode-switch {
  width: 100%;
  max-width: var(--eduval-auth-max);
  margin: 0 auto 20px;
  box-sizing: border-box;
}

body.woocommerce-account:not(.logged-in) .eduval-auth-mode-switch__list {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 4px;
  gap: 4px;
  border-radius: 12px;
  background: color-mix(in srgb, var(--bg-blue-secondary) 28%, #fff);
  border: 1px solid var(--eduval-auth-border);
}

body.woocommerce-account:not(.logged-in) .eduval-auth-mode-switch__item {
  flex: 1;
  margin: 0;
}

body.woocommerce-account:not(.logged-in) .eduval-auth-mode-switch__link {
  display: block;
  text-align: center;
  padding: 10px 12px;
  border-radius: 10px;
  font-weight: 700;
  font-size: 0.92rem;
  text-decoration: none;
  color: color-mix(in srgb, var(--bg-blue) 52%, #4b5563);
  transition:
    background-color 160ms ease,
    color 160ms ease,
    box-shadow 160ms ease;
}

body.woocommerce-account:not(.logged-in) .eduval-auth-mode-switch__link:hover {
  color: var(--bg-blue);
}

body.woocommerce-account:not(.logged-in) .eduval-auth-mode-switch__link.is-active {
  background: var(--white);
  color: var(--bg-blue);
  box-shadow: 0 4px 14px rgba(22, 35, 74, 0.1);
}

/* Formulário de registo mais largo (mais campos) */
body.woocommerce-account:not(.logged-in) article:has(.eduval-auth-register-wrap) {
  max-width: min(560px, 100%) !important;
}

body.woocommerce-account:not(.logged-in):has(.eduval-auth-register-wrap) .woocommerce-notices-wrapper {
  max-width: min(560px, 100%);
}

body.woocommerce-account:not(.logged-in) .eduval-auth-register-section-title {
  margin: 20px 0 12px;
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--bg-blue) 62%, #374151);
  border-bottom: 1px dashed color-mix(in srgb, var(--bg-blue) 14%, #dbe3ea);
  padding-bottom: 8px;
}

body.woocommerce-account:not(.logged-in) .eduval-auth-register-section-title:first-of-type {
  margin-top: 0;
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-toggle-row {
  margin-top: 8px;
  margin-bottom: 4px;
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields {
  margin: 12px 0 8px;
  padding: clamp(18px, 3.5vw, 24px) clamp(18px, 3.5vw, 24px) clamp(10px, 2vw, 14px);
  border: 1px solid var(--eduval-auth-border);
  border-radius: var(--eduval-auth-input-radius);
  background: color-mix(in srgb, var(--bg-blue-secondary) 42%, var(--white));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.7),
    0 1px 2px rgba(38, 30, 80, 0.04);
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields:not([hidden]) {
  animation: eduval-auth-fade-in 280ms ease-out both;
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields__legend.eduval-auth-register-section-title {
  float: none;
  width: 100%;
  margin: 0 0 16px;
  padding: 0 0 10px;
}

/* Morada WC: woocommerce_form_field usa <p class="form-row …"> (não .woocommerce-form-row). */
body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields p.form-row {
  margin: 0 0 16px;
  padding: 0;
  width: 100%;
  float: none;
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields p.form-row.form-row-first,
body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields p.form-row.form-row-last {
  width: 100%;
  float: none;
}

@media (min-width: 601px) {
  body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields p.form-row.form-row-first {
    width: 48%;
    float: left;
    margin-right: 4%;
  }

  body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields p.form-row.form-row-last {
    width: 48%;
    float: right;
    margin-right: 0;
  }
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields p.form-row.form-row-wide {
  width: 100% !important;
  float: none !important;
  margin-right: 0 !important;
  clear: both;
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields .clear {
  clear: both;
  display: block;
  height: 0;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields p.form-row:last-of-type {
  margin-bottom: 6px;
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields p.form-row label {
  display: block;
  font-size: 0.875rem;
  font-weight: 700;
  color: color-mix(in srgb, var(--bg-blue) 85%, #374151);
  margin: 0 0 8px;
  letter-spacing: 0.01em;
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields p.form-row label .required {
  color: var(--color-secondary);
  margin-left: 2px;
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields p.form-row .optional {
  font-weight: 600;
  color: color-mix(in srgb, var(--bg-blue) 45%, #6b7280);
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields p.form-row .description,
body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields span.description {
  display: block;
  margin: 8px 0 0;
  font-size: 0.82rem;
  line-height: 1.45;
  color: color-mix(in srgb, var(--bg-blue) 52%, #6b7280);
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields select,
body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields .select2-container .select2-selection--single {
  border-radius: var(--eduval-auth-input-radius);
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields .input-text,
body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields select {
  width: 100%;
  max-width: 100%;
  padding: 14px 18px;
  font-size: 1rem;
  line-height: 1.5;
  color: var(--bg-blue);
  background: var(--white);
  border: 1.5px solid color-mix(in srgb, var(--bg-blue) 18%, #e5e7eb);
  border-radius: var(--eduval-auth-input-radius);
  transition:
    border-color 180ms ease,
    box-shadow 180ms ease,
    background-color 180ms ease;
  box-sizing: border-box;
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields .input-text:hover,
body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields select:hover {
  border-color: color-mix(in srgb, var(--bg-blue) 35%, #e5e7eb);
  background: color-mix(in srgb, var(--bg-blue-secondary) 30%, var(--white));
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields .input-text:focus,
body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields select:focus {
  border-color: var(--bg-blue);
  background: var(--white);
  outline: none;
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--bg-blue) 12%, transparent),
    0 1px 2px rgba(0, 0, 0, 0.05);
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-fields .woocommerce-input-wrapper {
  display: block;
  width: 100%;
}

body.woocommerce-account:not(.logged-in) .eduval-register-billing-toggle-row label {
  font-weight: 600;
  line-height: 1.45;
}

body.woocommerce-account:not(.logged-in) .woocommerce-form-login,
body.woocommerce-account:not(.logged-in) .woocommerce-form-register,
body.woocommerce-account:not(.logged-in) .woocommerce-ResetPassword {
  animation: eduval-auth-fade-in 350ms ease-out both;
}

body.woocommerce-account:not(.logged-in) .eduval-auth-card .woocommerce-form-login,
body.woocommerce-account:not(.logged-in) .eduval-auth-card .woocommerce-form-register,
body.woocommerce-account:not(.logged-in) .eduval-auth-card .woocommerce-ResetPassword {
  animation: none;
}

body.woocommerce-account:not(.logged-in) .entry-content .woocommerce > h2,
body.woocommerce-account:not(.logged-in) #customer_login .u-column1 > h2,
body.woocommerce-account:not(.logged-in) #customer_login .u-column2 > h2 {
  animation: eduval-auth-fade-in 350ms ease-out both;
}

body.woocommerce-account:not(.logged-in) #customer_login .u-column2 > h2,
body.woocommerce-account:not(.logged-in) #customer_login .u-column2 > .woocommerce-form-register {
  animation-delay: 80ms;
}

/* -------------------------------------------------------------------------
 * Placeholder text styling
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) .woocommerce-Input:-webkit-autofill,
body.woocommerce-account:not(.logged-in) .input-text:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 1000px var(--white) inset;
  -webkit-text-fill-color: var(--bg-blue);
  transition: background-color 5000s ease-in-out 0s;
}

/* -------------------------------------------------------------------------
 * Footer spacing on auth pages
 * ---------------------------------------------------------------------- */
body.woocommerce-account:not(.logged-in) .site-footer {
  margin-top: 0 !important;
}
