/**
 * /user/login and /user/register — ECCDIS Figma-matched styling.
 *
 * Design tokens
 * ─────────────
 *   --green-accent : #2e9e6e  (input borders, title, accents)
 *   --dark-navy    : #1e293b  (labels, headings)
 *   --btn-dark     : #1e2d3d → #283548  (button gradient)
 *   --muted        : #6b7280  (secondary text)
 *   --icon-gray    : #9ca3af  (field icons, placeholders)
 *   --error        : #ef4444  (validation errors)
 *   --blob-green   : #22c55e  (background gradient blobs)
 */

/* ═══════════════════════════════════════════════════
   GLOBAL FORM RESETS
   Global style.css sets `form { width: 230px; height: 50px }` — undo on auth pages.
   ═══════════════════════════════════════════════════ */
.login-page form,
.register-page form,
.forgot-password-page form,
.reset-password-page form,
.login-page form#user-login-form,
.register-page form#user-register-form {
  width: 100% !important;
  max-width: none !important;
  height: auto !important;
  min-height: 0 !important;
  position: static !important;
}

.login-page .login-input-with-icon input[type="text"],
.login-page .login-input-with-icon input[type="password"],
.register-page .login-input-with-icon input[type="text"],
.register-page .login-input-with-icon input[type="password"],
.register-page .login-input-with-icon input[type="email"],
.forgot-password-page .login-input-with-icon input[type="text"],
.reset-password-page .login-input-with-icon input[type="password"],
.reset-password-page .login-input-with-icon input[type="text"] {
  height: auto !important;
  padding: 0 !important;
  border-radius: 0 !important;
  border: none !important;
}

/* ═══════════════════════════════════════════════════
   PAGE CONTAINER — green gradient blob background
   ═══════════════════════════════════════════════════ */
.login-page,
.register-page,
.forgot-password-page,
.reset-password-page {
  position: relative;
  min-height: calc(100vh - 107px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem 1rem;
  box-sizing: border-box;
  overflow: hidden;
  background: linear-gradient(180deg, #ddf6e8 0%, #eee5dc 35%, #f2ddd0 50%, #e6ede5 70%, #d8f0e4 100%);
}

.login-page::before,
.register-page::before,
.forgot-password-page::before,
.reset-password-page::before {
  content: "";
  position: absolute;
  top: 0;
  left: -8%;
  width: 116%;
  height: 326px;
  background: linear-gradient(135deg, #1aab5a 0%, #2ecb6e 35%, #5ee8a0 70%, #8af0c0 100%);
  border-bottom-left-radius: 20% 160px;
  border-bottom-right-radius: 20% 160px;
  z-index: 0;
}

.login-page::after,
.register-page::after,
.forgot-password-page::after,
.reset-password-page::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    url("../img/book-globe.png") left bottom -30px / 332px 235px no-repeat,
    url("../img/kids-backpacks.png") right 26px bottom -30px / 353px 250px no-repeat;
  z-index: 0;
  opacity: 0.13;
  filter: invert(36%) sepia(68%) saturate(350%) hue-rotate(110deg) brightness(65%) contrast(85%);
}

/* Paper plane background asset */
.plane {
  position: absolute;
  top: 20px;
  right: 25%;
  width: 140px;
  height: 114px;
  z-index: 1;
  opacity: 0.92;
  pointer-events: none;
}

.plane img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  mix-blend-mode: screen;
  filter: none;
}

/* ═══════════════════════════════════════════════════
   CARD WRAPPER
   ═══════════════════════════════════════════════════ */
.login-page__inner {
  width: 100%;
  max-width: 400px;
  /* Reduced width for a more compact form */
}

.register-page .login-page__inner {
  max-width: 400px;
  /* Match login card width exactly */
}

/* ═══════════════════════════════════════════════════
   CARD — wrapped by a thin green line matching Figma
   ═══════════════════════════════════════════════════ */
.login-card {
  background: #ffffff !important;
  border: none !important;
  /* Replaced standard border with a box-shadow border to eliminate sub-pixel centering blur */
  border-radius: 14px !important;
  /* Figma exact border-radius */
  padding: 24px 24px 20px 24px !important;
  /* Premium Figma padding */
  box-shadow:
    0px 0px 0px 1px #00E28A,
    /* Razor-sharp 1px bright green border that snaps to the physical pixel grid */
    0px 12px 24px -8px #0D223F1A,
    0px 25px 50px -12px #0D223F2E !important;
  /* Figma double drop shadows */
  position: relative;
  z-index: 2;
  box-sizing: border-box !important;
  width: 100% !important;
}

/* Specific height and layout for the Login Page card to match Figma aspect ratio and positioning */
.login-page:not(.register-page) .login-card {
  height: auto !important;
  /* Changed from fixed 613px to auto to prevent bottom footer logos from overflowing and getting cut off */
  min-height: 613px !important;
  max-height: none !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
}

/* ═══════════════════════════════════════════════════
   BRANDING (logos + title)
   ═══════════════════════════════════════════════════ */
.login-card__branding {
  text-align: center;
  margin-bottom: 57px !important;
  /* Increased to 57px (1.5x of 38px) to provide a very generous spacious gap under the logos on all forms */
}

.login-card__logos {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-bottom: 0.85rem;
}

.login-card__logo-slot img {
  display: block;
  object-fit: contain;
  border-radius: 4px;
}

/* ── Title ── */
.login-card__title {
  margin: 0;
  font-family: 'Montserrat', system-ui, sans-serif;
  font-size: 17.3px;
  font-weight: 600;
  line-height: 25px;
  letter-spacing: 0.35px;
  color: #D4A82E;
  /* Figma lighter golden mustard exact */
}

.login-card__title-line {
  display: block;
}

.login-card__title-dark {
  color: #1e293b;
  font-weight: 500;
  font-size: 17.3px;
  line-height: 25px;
  letter-spacing: 0.35px;
}

/* ── Kicker (register page "Create an account") ── */
.login-card__kicker {
  margin: 0 0 0.4rem;
  font-family: 'Montserrat', 'Poppins', system-ui, sans-serif;
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: #1e293b;
}

/* ═══════════════════════════════════════════════════
   FORM REGION
   ═══════════════════════════════════════════════════ */
.login-card__form-region .block {
  margin: 0;
}

.login-card__form-region form.user-login-form,
.login-card__form-region form#user-login-form,
.login-card__form-region form.user-register-form,
.login-card__form-region form#user-register-form {
  margin: 0;
}

/* ── Labels ── */
.login-card__form-region label {
  display: block;
  margin-bottom: 0.5rem !important;
  /* Premium spacing below label */
  font-family: 'Montserrat', system-ui, sans-serif !important;
  font-size: 14px !important;
  /* Perfect typography matching the image */
  font-weight: 700 !important;
  /* Bold */
  color: #0c1a32 !important;
  /* Deep dark navy */
}

/* ═══════════════════════════════════════════════════
   INPUT WITH ICON — thin gray border, transparent addon
   ═══════════════════════════════════════════════════ */
.login-input-with-icon {
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 351.6000061035156px !important;
  height: 40.38999938964844px !important;
  min-height: 38.400001525878906px !important;
  box-sizing: border-box;
  border: 1px solid #cbd5e1 !important;
  border-radius: 10px !important;
  padding-left: 12px !important;
  /* Premium spacious margin matching Figma */
  padding-right: 12px !important;
  /* Balanced right margin */
  gap: 12px !important;
  /* Spacious gap between icon and input text */
  overflow: hidden;
  background: #fff;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  margin: 0 auto;
}

.login-input-with-icon>* {
  border: 0 !important;
  box-shadow: none !important;
  background-image: none !important;
}

.login-input-with-icon:focus-within {
  border-color: #1e293b !important;
  /* Figma dark navy focus border */
  box-shadow: 0 0 0 3px rgba(30, 41, 59, 0.08) !important;
}

.login-form-item--name .login-input-with-icon,
.login-form-item--pass .login-input-with-icon {
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

/* Error state */
.form-item--error.login-form-item--name .login-input-with-icon,
.form-item--error.login-form-item--pass .login-input-with-icon,
.form-item--error.login-form-item--mail .login-input-with-icon {
  border-color: #f87171 !important;
  /* Crisp light-coral red border matching the image */
  box-shadow: 0 0 0 2px rgba(248, 113, 113, 0.12) !important;
}

/* ── Icon addon (transparent — no gray bg) ── */
.login-input-with-icon__addon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: auto;
  flex-shrink: 0;
  border: 0 !important;
  background: transparent;
  color: #64748b !important;
  /* Premium muted blue-gray matching the image */
  box-shadow: none !important;
}

.login-input-with-icon__error-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  border: 0 !important;
  color: #ef4444 !important;
  pointer-events: auto !important;
  cursor: help !important;
  box-shadow: none !important;
}

/* ── Inputs inside the icon wrapper ── */
.login-input-with-icon input[type="text"],
.login-input-with-icon input[type="password"],
.login-input-with-icon input[type="email"] {
  flex: 1;
  min-width: 0;
  width: 1% !important;
  border: none !important;
  border-left: 0 !important;
  border-right: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  font-family: 'Montserrat', system-ui, sans-serif !important;
  font-size: 14px !important;
  /* Exact font size matching placeholder */
  font-weight: 500 !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  outline: none !important;
  appearance: none;
  -webkit-appearance: none;
  background-image: none !important;
  background: transparent !important;
  color: #1e293b !important;
  height: 100%;
}

.login-input-with-icon .form-text,
.login-input-with-icon .form-password,
.login-input-with-icon .password-field,
.login-input-with-icon input.form-control,
.login-input-with-icon input {
  border: 0 !important;
  border-left: 0 !important;
  border-right: 0 !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  background-image: none !important;
}

.login-input-with-icon input::placeholder {
  color: #94a3b8 !important;
  /* Beautiful muted blue-gray matching the image */
  font-family: 'Montserrat', system-ui, sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
}

.login-input-with-icon input:focus {
  outline: none;
}

/* ═══════════════════════════════════════════════════
   PASSWORD TOGGLE — transparent background
   ═══════════════════════════════════════════════════ */
.login-input-with-icon--password {
  position: relative;
}

.login-password-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: auto;
  flex-shrink: 0;
  border: none;
  border-left: 0 !important;
  border-right: 0 !important;
  background: transparent;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  color: #64748b !important;
  cursor: pointer;
  padding: 0;
  transition: color 0.15s ease;
  appearance: none;
  -webkit-appearance: none;
}

.login-password-toggle:hover,
.login-password-toggle:focus {
  background: transparent;
  color: #6b7280;
}

.login-password-toggle:focus {
  outline: 2px solid #2e9e6e;
  outline-offset: -2px;
}

/* ═══════════════════════════════════════════════════
   FORM ITEM SPACING
   ═══════════════════════════════════════════════════ */
.login-form-item--name,
.login-form-item--pass,
.login-form-item--mail {
  margin-bottom: 20px !important;
  /* Clean, consistent vertical spacing between input blocks */
}

/* ═══════════════════════════════════════════════════
   REMEMBER ME + FORGOT PASSWORD ROW
   ═══════════════════════════════════════════════════ */
.login-card__remember-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin: 0 auto 24px auto !important;
  /* Perfect 24px vertical spacing between Remember row and reCAPTCHA */
  width: 100% !important;
  max-width: 351.6000061035156px !important;
  /* Perfectly matches the input fields width to align the checkbox */
  flex-wrap: nowrap !important;
}

.login-card__remember-row .form-item,
.login-card__remember-row .js-form-item,
.login-card__remember-row .form-type-checkbox,
.login-card__remember-row .js-form-type-checkbox,
.login-card__remember-row .form-item-remember-me,
.login-card__remember-row .js-form-item-remember-me {
  margin: 0 !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 0 !important;
  /* Using margin-right on checkbox for bulletproof cross-browser spacing */
  flex-wrap: nowrap !important;
  width: auto !important;
  float: none !important;
}

.login-card__remember-row .form-type-checkbox label,
.login-card__remember-row .js-form-type-checkbox label,
.login-card__remember-row .form-item-remember-me label,
.login-card__remember-row .js-form-item-remember-me label {
  margin: 0 !important;
  font-family: 'Montserrat', system-ui, sans-serif !important;
  font-size: 14px !important;
  /* Perfect typography scale matching inputs */
  font-weight: 600 !important;
  /* Premium semi-bold / medium weight */
  color: #334155 !important;
  /* Slate navy matching reference mockup exactly */
  cursor: pointer;
  white-space: nowrap !important;
  display: inline-flex !important;
  /* Perfect flex centering */
  align-items: center !important;
  line-height: 1 !important;
  /* Prevent text baseline shifting */
  height: 16px !important;
  /* Explicitly match checkbox height */
  vertical-align: middle !important;
  float: none !important;
  width: auto !important;
}

.login-card__remember-row input[type="checkbox"] {
  width: 16px !important;
  height: 16px !important;
  accent-color: #1e293b !important;
  /* Same dark navy color */
  cursor: pointer;
  margin: 0 !important;
  margin-right: 12px !important;
  /* Precise horizontal gap matching reference image exactly */
  padding: 0 !important;
  flex-shrink: 0 !important;
  display: inline-flex !important;
  vertical-align: middle !important;
  float: none !important;
}

.login-card__link-forgot {
  font-family: 'Montserrat', 'Poppins', system-ui, sans-serif;
  font-size: 0.85rem;
  font-weight: 600;
  color: #1e293b !important;
  text-decoration: none !important;
  white-space: nowrap;
}

.login-card__link-forgot:hover {
  text-decoration: underline !important;
}

/* ═══════════════════════════════════════════════════
   REGISTER PAGE — Figma-matched layout & field ordering
   ═══════════════════════════════════════════════════ */

/* Make the register form a flex column so we can control field order */
.register-page .user-register-form {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
}

.register-page .user-register-form .js-form-item,
.register-page .user-register-form .form-item,
.register-page .user-register-form .form-type-password-confirm,
.register-page .user-register-form .form-actions {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  width: 100% !important;
  margin: 0 !important;
  float: none !important;
}

.register-page .user-register-form .js-form-item,
.register-page .user-register-form .form-item {
  margin-bottom: 20px !important;
}

.register-page .user-register-form .js-form-item-account-name,
.register-page .user-register-form .form-item-account-name,
.register-page .user-register-form .login-form-item--pass {
  margin-bottom: 20px !important;
}

.register-page .user-register-form .form-actions {
  margin-bottom: 0 !important;
  margin-top: 0.2rem !important;
}

.register-page .user-register-form .form-type-password-confirm,
.register-page .user-register-form .js-form-type-password-confirm {
  margin-bottom: 0.95rem !important;
}

.register-page .user-register-form .form-type-password-confirm .js-form-item:last-child,
.register-page .user-register-form .js-form-type-password-confirm .js-form-item:last-child,
.register-page .user-register-form .form-type-password-confirm .form-item:last-child,
.register-page .user-register-form .js-form-type-password-confirm .form-item:last-child {
  margin-bottom: 0 !important;
}

.register-page .user-register-form .form-item-account-name+.js-form-item,
.register-page .user-register-form .js-form-item-account-name+.js-form-item,
.register-page .user-register-form .login-form-item--pass+.form-actions,
.register-page .user-register-form .login-form-item--pass+.js-form-item,
.register-page .user-register-form .login-form-item--pass+.form-item {
  margin-top: 0 !important;
}

.register-page .user-register-form label {
  display: block !important;
  width: 100% !important;
  margin: 0 0 0.5rem 0 !important;
  position: static !important;
  float: none !important;
}

/* Flatten the account fieldset so its children join the flex flow directly */
.register-page .user-register-form fieldset,
.register-page .user-register-form details {
  display: contents !important;
}

.register-page .user-register-form fieldset>legend,
.register-page .user-register-form details>summary {
  display: none !important;
}

.register-page .user-register-form .fieldset-wrapper,
.register-page .user-register-form .details-wrapper {
  display: contents !important;
}

/* Strip fieldset border/padding (fallback for non-contents browsers) */
.register-page .login-card__form-region fieldset {
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  min-width: 0;
}

.register-page .login-card__form-region fieldset legend {
  display: none !important;
}

/* ── Figma field order ───────────────────────────────
   1. First Name + Last Name
   2. Username
   3. Email address
   4. Contact Number
   5. Address
   6. Password + Confirm password
   7. Create account button
   ─────────────────────────────────────────────────── */
.register-page .register-form__name-row {
  order: 1 !important;
}

.register-page .js-form-item-account-name,
.register-page .form-item-account-name {
  order: 2 !important;
}

.register-page .js-form-item-account-mail,
.register-page .form-item-account-mail {
  order: 3 !important;
}

.register-page .js-form-item-field-contact-number,
.register-page .form-item-field-contact-number {
  order: 4 !important;
}

.register-page .js-form-item-field-address,
.register-page .form-item-field-address {
  order: 5 !important;
}

.register-page .js-form-type-password-confirm,
.register-page .form-type-password-confirm {
  order: 6 !important;
}

.register-page .form-actions {
  order: 7 !important;
}

.register-page .form-type-password-confirm,
.register-page .js-form-type-password-confirm {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  margin-top: 0 !important;
}

.register-page .form-type-password-confirm>.js-form-item,
.register-page .js-form-type-password-confirm>.js-form-item,
.register-page .form-type-password-confirm>.form-item,
.register-page .js-form-type-password-confirm>.form-item {
  order: initial !important;
  margin: 0 !important;
}

/* ── Hide password strength indicator and match text ── */
.register-page .password-strength,
.register-page [class*="password-strength"],
.register-page .password-confirm-message,
.register-page .js-password-strength,
.register-page .password-strength__title,
.register-page .password-strength__indicator {
  display: none !important;
}

.register-page .description {
  font-size: 0.8rem;
  line-height: 1.4;
  color: #9ca3af;
  margin-top: 0.3rem;
}

/* Register page plain inputs — thin border matching Figma */
.register-page .login-card__form-region .form-item:not(.login-form-item) input[type="email"],
.register-page .login-card__form-region .form-item:not(.login-form-item) input[type="text"],
.register-page .login-card__form-region .form-item:not(.login-form-item) input[type="password"],
.register-page .login-card__form-region .form-item:not(.login-form-item) input[type="tel"],
.register-page .login-card__form-region .form-item:not(.login-form-item) input[type="number"],
.register-page .login-card__form-region .form-item:not(.login-form-item) select,
.register-page .login-card__form-region .form-item:not(.login-form-item) textarea {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  padding: 0.625rem 0.75rem;
  font-size: 0.95rem;
  font-family: 'Montserrat', 'Poppins', system-ui, sans-serif;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  background: #fff;
  color: #333;
}

.register-page .login-card__form-region .form-item:not(.login-form-item) input::placeholder,
.register-page .login-card__form-region .form-item:not(.login-form-item) textarea::placeholder {
  color: #b0b8c4;
  font-weight: 400;
}

.register-page .login-card__form-region .form-item:not(.login-form-item) input:focus,
.register-page .login-card__form-region .form-item:not(.login-form-item) select:focus,
.register-page .login-card__form-region .form-item:not(.login-form-item) textarea:focus {
  border-color: #2e9e6e;
  box-shadow: 0 0 0 3px rgba(46, 158, 110, 0.1);
  outline: none;
}

.register-page .login-card__form-region .form-item:not(.login-form-item) textarea {
  min-height: 76px;
  resize: vertical;
}

.register-page .login-card__form-region .form-item--error:not(.login-form-item) input,
.register-page .login-card__form-region .form-item--error:not(.login-form-item) textarea {
  border-color: #ef4444;
  box-shadow: 0 0 0 2px rgba(239, 68, 68, 0.1);
}

/* ═══════════════════════════════════════════════════
   ERROR MESSAGES
   ═══════════════════════════════════════════════════ */
.login-card__form-region .form-item--error-message,
.login-card__form-region .form-item__error-message {
  margin: 0.3rem 0 0;
  font-size: 0.8rem;
  color: #ef4444;
}

.login-card__form-region .block-title,
.login-card__form-region h2.block-title {
  display: none;
}

/* ═══════════════════════════════════════════════════
   CAPTCHA
   ═══════════════════════════════════════════════════ */
.login-card__form-region .user-login-form .js-form-item,
.login-card__form-region #user-login-form .js-form-item,
.login-card__form-region .user-register-form .js-form-item,
.login-card__form-region #user-register-form .js-form-item {
  display: block !important;
  align-items: stretch !important;
  flex-wrap: nowrap !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  width: 100% !important;
  box-sizing: border-box;
}

.login-card__form-region .form-type-captcha.js-form-item,
.login-card__form-region .js-form-item.form-type-captcha {
  text-align: center;
}

.login-card__form-region .form-type-captcha.form-item--error .captcha,
.login-card__form-region .js-form-item.form-type-captcha.form-item--error .captcha {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.15) !important;
}

.login-card__form-region .captcha {
  display: flex !important;
  justify-content: flex-start !important;
  /* Left-align the reCAPTCHA iframe */
  align-items: center !important;
  width: 100% !important;
  max-width: 351.6000061035156px !important;
  height: 66.3px !important;
  /* Scaled height: 78px * 0.85 */
  min-height: 66.3px !important;
  margin: 0 auto 20px auto !important;
  /* Symmetrically centered container matching input offsets */
  box-sizing: border-box !important;
  border: none !important;
  /* Strip outer duplicate borders */
  background: transparent !important;
  /* Strip duplicate backgrounds */
  overflow: visible !important;
  /* Ensure it is never clipped */
  position: relative !important;
}

.login-card__form-region .captcha iframe {
  width: 304px !important;
  height: 78px !important;
  transform: scale(0.85) !important;
  /* Scaled down by 15% to look compact and premium */
  transform-origin: left center !important;
  /* Anchored to the left edge so it matches input margins perfectly */
  border: none !important;
  flex-shrink: 0 !important;
  margin: 0 !important;
}

.login-card__form-region .captcha img {
  display: block !important;
  max-width: 100% !important;
  width: auto !important;
  height: auto !important;
  margin: 0 auto !important;
  flex-shrink: 0;
}

.login-card__form-region .captcha .reload-captcha,
.login-card__form-region .captcha a.reload-captcha {
  display: inline-block;
  margin: 0;
}

.login-card__form-region .captcha details#captcha {
  margin: 0 auto;
  max-width: 100%;
  width: 100%;
}

.login-card__form-region .captcha details#captcha .details-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
}

.login-card__form-region .captcha-error-message {
  color: #ef4444 !important;
  font-size: 0.8rem !important;
  font-weight: 500 !important;
  margin-top: 0.35rem !important;
  display: block !important;
  text-align: left !important;
  width: 100% !important;
  max-width: 351.6000061035156px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  position: static !important;
}

/* ═══════════════════════════════════════════════════
   SUBMIT BUTTON — dark navy with subtle left→right gradient
   ═══════════════════════════════════════════════════ */
.login-card__form-region .form-actions {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  width: 100% !important;
  margin: 0 auto !important;
  /* Centered horizontally, removed unnecessary vertical margins */
  padding: 0 !important;
}

.login-card__form-region .form-actions .form-submit,
.login-card__form-region .form-actions input[type="submit"] {
  width: 100%;
  max-width: 351.6000061035156px !important;
  height: 38.400001525878906px !important;
  min-height: 38.400001525878906px !important;
  margin: 0 auto !important;
  display: flex !important;
  align-items: center !important;
  /* Vertical alignment Middle */
  justify-content: center !important;
  /* Horizontal alignment Center */
  padding: 0 16px !important;
  /* Symmetrical padding to center the text perfectly vertically */
  border: none !important;
  border-radius: 12px !important;
  /* Match larger rounded corner ratio in image */
  background: linear-gradient(180deg, #1A3562 0%, #112448 50%, #0C1A32 100%) !important;
  /* Exact Figma vertical gradient */
  color: #fff;
  font-family: 'Montserrat', system-ui, sans-serif !important;
  font-size: 13px !important;
  /* Montserrat/Bold size matching Width 40px, Height 16px bounding box */
  font-weight: 700 !important;
  /* Bold */
  line-height: 16px !important;
  /* Height 16px */
  text-align: center !important;
  /* Horizontal alignment Center */
  cursor: pointer;
  transition: background-color 0.2s ease, box-shadow 0.2s ease, transform 0.1s ease;
  box-sizing: border-box;
  letter-spacing: normal !important;
  /* Clear any custom letter spacing */
  box-shadow: 0px 4px 14px 0px #1124486B, 0px 2px 0px 0px #FFFFFF1A inset !important;
}

.login-card__form-region .form-actions .form-submit:hover,
.login-card__form-region .form-actions input[type="submit"]:hover {
  background: linear-gradient(180deg, #224276 0%, #17305c 50%, #112448 100%) !important;
  /* Richer blue gradient on hover */
  box-shadow: 0px 6px 18px 0px #1124488A, 0px 2px 0px 0px #FFFFFF1A inset !important;
}

.login-card__form-region .form-actions .form-submit:active,
.login-card__form-region .form-actions input[type="submit"]:active {
  transform: scale(0.985);
  box-shadow: 0px 2px 6px 0px #1124484D, 0px 2px 0px 0px #FFFFFF1A inset !important;
}

/* ═══════════════════════════════════════════════════
   STATUS MESSAGES
   ═══════════════════════════════════════════════════ */
.login-card__form-region .messages {
  margin-bottom: 1rem;
  border-radius: 8px;
  font-size: 0.9rem;
}

/* ═══════════════════════════════════════════════════
   EXTRA SECTION (below form — register / login link)
   ═══════════════════════════════════════════════════ */
.login-card__extra {
  margin-top: 0.85rem !important;
  /* Compact spacing below the login button */
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

/* ── "Don't have an account? Register" ── */
.login-card__register-text {
  margin: 0;
  font-family: 'Montserrat', system-ui, sans-serif !important;
  font-size: 14px !important;
  color: #475569 !important;
  /* Slate Gray */
  text-align: center;
}

.login-card__register-text a {
  color: #0c1a32 !important;
  /* Deep dark navy */
  font-weight: 700 !important;
  /* Bold */
  text-decoration: underline !important;
  transition: color 0.15s ease;
}

.login-card__register-text a:hover {
  color: #2e9e6e !important;
}

/* ═══════════════════════════════════════════════════
   FOOTER LOGOS (UNICEF / Data for All)
   ═══════════════════════════════════════════════════ */
.login-card__footer-logos {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.5rem !important;
  /* Generous gap for larger logos */
  margin-top: 1rem !important;
  /* Tighter, more compact spacing below register text */
  padding-top: 0 !important;
}

.login-card__footer-logos img {
  height: 38px !important;
  /* Significantly larger, highly visible logos matching the image */
  object-fit: contain;
}

.login-card__footer-logos-divider {
  width: 1.5px !important;
  height: 40px !important;
  /* Symmetrical divider matching the new logo scale */
  background: #94a3b8 !important;
  /* Darker slate-gray divider exactly matching the image */
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════
   BODY BACKGROUND ON AUTH ROUTES
   ═══════════════════════════════════════════════════ */
body.path-user .dialog-off-canvas-main-canvas,
body.path-user-register .dialog-off-canvas-main-canvas,
body.page-user-register .dialog-off-canvas-main-canvas {
  background: transparent !important;
}

/* ═══════════════════════════════════════════════════
   REGISTER FORM NAME ROW (First Name / Last Name side-by-side)
   ═══════════════════════════════════════════════════ */
.register-form__name-row {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 1.25rem;
  width: 100%;
  margin-bottom: 0 !important;
}

.register-form__name-row>div {
  display: flex;
  flex-direction: column;
  flex: 1;
  width: 100%;
  min-width: 0;
  margin-bottom: 0 !important;
}

.register-page .register-form__name-row .js-form-item,
.register-page .register-form__name-row .form-item {
  margin-bottom: 0 !important;
}

.register-form__name-row label {
  margin-bottom: 0.35rem;
}

@media (max-width: 640px) {
  .register-form__name-row>div {
    flex-basis: 100%;
  }
}

/* Clean up and hide Drupal default field descriptions on auth forms to match Figma's clean design */
.login-card__form-region .description,
.login-card__form-region .form-item .description {
  display: none !important;
}

/* Final register-page spacing overrides */
.register-page .user-register-form .js-form-item-account-name,
.register-page .user-register-form .form-item-account-name {
  margin-bottom: 20px !important;
}

.register-page .user-register-form .js-form-item-pass-pass2,
.register-page .user-register-form .form-item-pass-pass2,
.register-page .user-register-form .js-form-item-account-pass-pass2,
.register-page .user-register-form .form-item-account-pass-pass2,
.register-page .user-register-form .login-form-item--pass:last-child {
  margin-bottom: 20px !important;
}

.register-page .user-register-form .form-actions {
  margin-top: 0 !important;
}

.register-page .login-card__form-region .form-item-field-address textarea,
.register-page .login-card__form-region .js-form-item-field-address textarea,
.register-page .login-card__form-region textarea[name="field_address"] {
  min-height: 52px !important;
  height: 52px !important;
  resize: none !important;
}

/* Inline SVG password visibility eye toggle styling */
.login-password-toggle__icon {
  display: block !important;
}

.login-password-toggle__icon--eye-slash {
  display: none !important;
}

/* When the password is shown, hide the standard eye and show the eye-slash outlines */
.login-password-toggle[aria-pressed="true"] .login-password-toggle__icon--eye {
  display: none !important;
}

.login-password-toggle[aria-pressed="true"] .login-password-toggle__icon--eye-slash {
  display: block !important;
}

/* Ensure any errored input/textarea on register/login page gets a premium red outline */
.register-page .form-item--error input,
.register-page .form-item--error textarea,
.register-page .form-item--error select,
.login-page .form-item--error input,
.login-page .form-item--error .login-input-with-icon {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.15) !important;
}

/* Style for inline error messages */
.register-page .form-item--error-message,
.login-page .form-item--error-message {
  color: #ef4444 !important;
  font-size: 0.8rem !important;
  font-weight: 500 !important;
  margin-top: 0.35rem !important;
  display: block !important;
  text-align: left !important;
  width: 100% !important;
  max-width: 351.6000061035156px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Ensure the messages container is static, block-level, and never overlaps */
.login-card__form-region .messages,
.register-page .messages,
.messages--error,
.messages {
  position: static !important;
  display: block;
  visibility: visible;
  opacity: 1 !important;
  float: none !important;
  clear: both !important;
  margin: 0 0 1.25rem 0 !important;
  z-index: 100 !important;
  box-sizing: border-box !important;
  width: 100% !important;
}

/* Hidden messages class to override layout */
.messages--hidden {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  height: 0 !important;
  border: none !important;
}

/* Premium error messages styling — force red alert instead of green */
.login-card__form-region .messages.messages--error,
.login-card__form-region .messages--error,
.login-card__form-region .messages[role="alert"],
.register-page .messages.error,
.register-page .messages--error {
  background-color: #fef2f2 !important;
  border: 1px solid #fee2e2 !important;
  color: #ef4444 !important;
  padding: 0.75rem 1rem !important;
  border-radius: 8px !important;
  font-family: 'Montserrat', system-ui, sans-serif !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
}

.login-card__form-region .messages.messages--error ul,
.register-page .messages ul {
  margin: 0 !important;
  padding: 0 0 0 1.2rem !important;
  color: #ef4444 !important;
}

.login-card__form-region .messages.messages--error li,
.register-page .messages li {
  color: #ef4444 !important;
  margin-bottom: 0.25rem !important;
}

.login-card__form-region .messages.messages--error li:last-child,
.register-page .messages li:last-child {
  margin-bottom: 0 !important;
}

/* ═══════════════════════════════════════════════════
   REGISTRATION SUCCESS TEXT (after account creation)
   ═══════════════════════════════════════════════════ */
.registration-success-text {
  font-family: 'Montserrat', system-ui, sans-serif !important;
  font-size: 0.88rem !important;
  font-weight: 600 !important;
  color: #16a34a !important;
  margin: 0 0 1.25rem 0 !important;
  line-height: 1.4 !important;
  text-align: center !important;
  display: block !important;
}

.registration-error-text {
  font-family: 'Montserrat', system-ui, sans-serif !important;
  font-size: 0.88rem !important;
  font-weight: 600 !important;
  color: #ef4444 !important;
  margin: 0 0 1.25rem 0 !important;
  line-height: 1.4 !important;
  text-align: center !important;
  display: block !important;
}

/* ═══════════════════════════════════════════════════
   FORGOT PASSWORD & RESET PASSWORD PAGES
   ═══════════════════════════════════════════════════ */

/* Background gradient for forgot/reset password body classes */
body.path-user-password .dialog-off-canvas-main-canvas,
body.page-user-password .dialog-off-canvas-main-canvas,
body.path-user-reset .dialog-off-canvas-main-canvas,
body.page-user-reset .dialog-off-canvas-main-canvas {
  background: transparent !important;
}

/* Hide Drupal's default field descriptions on forgot/reset pages */
.forgot-password-page .login-card__form-region .description,
.forgot-password-page .login-card__form-region .form-item .description,
.reset-password-page .login-card__form-region .description,
.reset-password-page .login-card__form-region .form-item .description {
  display: none !important;
}

/* Error styles for forgot password inline errors */
.forgot-password-page .form-item--error input,
.forgot-password-page .form-item--error textarea {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.15) !important;
}

.forgot-password-page .form-item--error-message,
.reset-password-page .form-item--error-message {
  color: #ef4444 !important;
  font-size: 0.8rem !important;
  font-weight: 500 !important;
  margin-top: 0.35rem !important;
  display: block !important;
  text-align: left !important;
}

/* Messages containers on forgot/reset pages */
.forgot-password-page .messages,
.forgot-password-page .messages--error,
.reset-password-page .messages,
.reset-password-page .messages--error {
  position: static !important;
  display: block;
  margin: 0 0 1.25rem 0 !important;
  box-sizing: border-box !important;
  width: 100% !important;
}

.forgot-password-page .messages.messages--error,
.forgot-password-page .messages--error,
.reset-password-page .messages.messages--error,
.reset-password-page .messages--error {
  background-color: transparent !important;
  border: none !important;
  color: #ef4444 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  font-family: 'Montserrat', system-ui, sans-serif !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  text-align: center !important;
}

.forgot-password-page .messages.messages--status,
.forgot-password-page .messages--status,
.reset-password-page .messages.messages--status,
.reset-password-page .messages--status {
  background-color: transparent !important;
  border: none !important;
  color: #16a34a !important;
  padding: 0 !important;
  border-radius: 0 !important;
  font-family: 'Montserrat', system-ui, sans-serif !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  text-align: center !important;
}

/* Hide Drupal's default password strength and match message indicators on auth forms */
.login-card .password-strength,
.login-card .password-confirm-message,
.login-card .password-suggestions {
  display: none !important;
}

/* Force all top-level message containers on the login page to be completely hidden, since status is printed as simple text and errors are printed inline */
.login-page:not(.register-page):not(.forgot-password-page):not(.reset-password-page) .messages,
.login-page:not(.register-page):not(.forgot-password-page):not(.reset-password-page) [data-drupal-messages] {
  display: none !important;
}

/* ═══════════════════════════════════════════════════
   CUSTOM REGISTER PAGE REDESIGN
   ═══════════════════════════════════════════════════ */

/* 8. Input field layout (CSS Grid matching specified layout) */
.register-page .login-card__form-region .form-item:not(.login-form-item) input[type="email"],
.register-page .login-card__form-region .form-item:not(.login-form-item) input[type="text"],
.register-page .login-card__form-region .form-item:not(.login-form-item) input[type="password"],
.register-page .login-card__form-region .form-item:not(.login-form-item) input[type="tel"],
.register-page .login-card__form-region .form-item:not(.login-form-item) input[type="number"],
.register-page .login-card__form-region .form-item:not(.login-form-item) select,
.register-page .login-card__form-region .form-item:not(.login-form-item) textarea {
  width: 100% !important;
  height: 40.38999938964844px !important;
  /* Thickness matched to Login page */
  padding: 0 13px !important;
  border: 1px solid #cbd5e1 !important;
  /* Border color matched to Login page */
  border-radius: 10px !important;
  /* Border-radius matched to Login page */
  background: #fff !important;
  color: #1d2a40 !important;
  font-size: 14px !important;
  outline: none !important;
  box-shadow: inset 0 1px 2px rgba(20, 38, 60, .04) !important;
  font-family: 'Montserrat', system-ui, sans-serif !important;
}

.register-page .login-card__form-region .form-item:not(.login-form-item) input::placeholder,
.register-page .login-card__form-region .form-item:not(.login-form-item) textarea::placeholder {
  color: #94a3b8 !important;
  font-family: 'Montserrat', system-ui, sans-serif !important;
  font-size: 14px !important;
}

.register-page .login-card__form-region .form-item:not(.login-form-item) input:focus,
.register-page .login-card__form-region .form-item:not(.login-form-item) select:focus,
.register-page .login-card__form-region .form-item:not(.login-form-item) textarea:focus {
  border-color: #1e293b !important;
  /* Focus color matched to Login page */
  box-shadow: 0 0 0 3px rgba(30, 41, 59, 0.08) !important;
  /* Focus outline matched to Login page */
  outline: none !important;
}

/* 9. Password input icons and wrapper */
.register-page .login-input-with-icon {
  width: 100% !important;
  max-width: none !important;
  height: 40.38999938964844px !important;
  /* Thickness matched to Login page */
  min-height: 38.400001525878906px !important;
  /* Min-height matched to Login page */
  border: 1px solid #cbd5e1 !important;
  /* Border color matched to Login page */
  border-radius: 10px !important;
  /* Border-radius matched to Login page */
  padding-left: 12px !important;
  /* Matched to Login page exact */
  padding-right: 12px !important;
  /* Matched to Login page exact */
  gap: 12px !important;
  /* Matched to Login page exact */
  background: #fff !important;
  box-shadow: inset 0 1px 2px rgba(20, 38, 60, .04) !important;
  box-sizing: border-box !important;
}

.register-page .login-input-with-icon:focus-within {
  border-color: #1e293b !important;
  /* Focus color matched to Login page */
  box-shadow: 0 0 0 3px rgba(30, 41, 59, 0.08) !important;
  /* Focus outline matched to Login page */
}

/* Ensure that any intermediate Drupal wrapper (like .js-form-wrapper, .password-parent, or .password-confirm) stretches to fill the available flex space */
.register-page .login-input-with-icon>.js-form-wrapper,
.register-page .login-input-with-icon>.password-parent,
.register-page .login-input-with-icon>.password-confirm {
  flex: 1 !important;
  width: 100% !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

/* Completely hide Drupal's dynamic password strength, match messages, and suggestions inside the custom icon wrapper */
.register-page .login-input-with-icon .password-strength,
.register-page .login-input-with-icon .password-confirm-message,
.register-page .login-input-with-icon .password-suggestions,
.register-page .login-input-with-icon .js-password-strength,
.register-page .login-input-with-icon .password-strength__title,
.register-page .login-input-with-icon .password-strength__indicator {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
}

/* High specificity rule to ensure password inputs inside the icon wrapper never inherit double borders/backgrounds */
.register-page .login-card__form-region .form-item:not(.login-form-item) .login-input-with-icon input[type="password"],
.register-page .login-input-with-icon input[type="password"] {
  flex: 1 !important;
  min-width: 0 !important;
  width: 100% !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  font-family: 'Montserrat', system-ui, sans-serif !important;
  font-size: 14px !important;
  /* Exact font size matching login page placeholder */
  font-weight: 500 !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  outline: none !important;
  appearance: none;
  -webkit-appearance: none;
  background-image: none !important;
  background: transparent !important;
  color: #1e293b !important;
  height: 100% !important;
}

.register-page .login-input-with-icon input[type="password"]::placeholder {
  color: #94a3b8 !important;
  font-family: 'Montserrat', system-ui, sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
}

.register-page .login-input-with-icon__addon {
  color: #64748b !important;
  /* Premium muted blue-gray matching login page */
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.register-page .login-password-toggle {
  color: #64748b !important;
  /* Premium muted blue-gray matching login page */
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* 10. Partner/Footer Logos */
.register-page .partner-logos {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 19px !important;
  margin-top: 15px !important;
}

.register-page .partner-logos .divider {
  height: 35px !important;
  width: 1.5px !important;
  background: #c9ccd2 !important;
  display: block !important;
}

/* 11. Already have an account text links */
.register-page .login-card__extra--register {
  margin: 18px 0 18px !important;
  text-align: center !important;
}

.register-page .login-card__register-text {
  color: #6b7079 !important;
  font-size: 14px !important;
  margin: 0 !important;
  font-family: 'Montserrat', system-ui, sans-serif !important;
}

.register-page .login-card__register-text a {
  color: #1a2a43 !important;
  font-weight: 800 !important;
  text-decoration: underline !important;
  text-underline-offset: 3px !important;
}

@media (max-width: 640px) {
  .register-page .navbar {
    padding: 0 18px !important;
  }

  .register-page .nav-links {
    gap: 16px !important;
    font-size: 13px !important;
  }

  .register-page .seal.gold {
    display: none !important;
  }

  .register-page .plane {
    right: 5% !important;
  }

  .register-page .login-page__inner {
    margin-top: 24px !important;
  }
}

/* ═══════════════════════════════════════════════════
   REGISTER FORM FIELD SPACING AND ALIGNMENTS
   ═══════════════════════════════════════════════════ */

/* Reset margins and set standard 20px bottom spacing for all valid register form fields except address */
.register-page .user-register-form .register-form__name-row,
.register-page .user-register-form .form-item-account-name,
.register-page .user-register-form .js-form-item-account-name,
.register-page .user-register-form .form-item-account-mail,
.register-page .user-register-form .js-form-item-account-mail,
.register-page .user-register-form .form-item-field-contact-number,
.register-page .user-register-form .js-form-item-field-contact-number {
  margin-top: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-bottom: 20px !important;
  /* Standardized 20px spacing matching Login page */
}

/* Visually adjust the Address textarea's bottom margin to 14px to achieve optical symmetry */
.register-page .user-register-form .form-item-field-address,
.register-page .user-register-form .js-form-item-field-address {
  margin-top: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-bottom: 14px !important;
  /* Optically balanced to match the 20px gap elsewhere */
}

/* Ensure the password confirm block and its password inputs have standard even margins */
.register-page .form-type-password-confirm,
.register-page .js-form-type-password-confirm {
  margin-top: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-bottom: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
}

.register-page .form-type-password-confirm>.js-form-item,
.register-page .js-form-type-password-confirm>.js-form-item,
.register-page .form-type-password-confirm>.form-item,
.register-page .js-form-type-password-confirm>.form-item {
  margin-top: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-bottom: 20px !important;
  /* Standardized 20px spacing between Password and Confirm Password */
}

/* Captcha wrapper alignment and margins */
.register-page .form-type-captcha,
.register-page .js-form-item.form-type-captcha {
  order: 6.5 !important;
  /* Ensure it renders exactly below Confirm Password */
  margin-top: 0 !important;
  margin-bottom: 20px !important;
}

/* Ensure Create account button has standard ordering */
.register-page .user-register-form .form-actions {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  order: 7 !important;
}

/* Hide empty drupal group containers or contextual wrappers that create large gaps */
.register-page .user-register-form>div:empty,
.register-page .user-register-form>fieldset:empty,
.register-page .user-register-form>details:empty {
  display: none !important;
}

/* Provide adequate spacing between labels and input fields on the register form to match the login page */
.register-page .login-card__form-region label {
  margin-bottom: 0.5rem !important;
  /* Spacing matched to Login page exact */
}

/* Style textareas on the register form to be taller with appropriate top/left padding for address inputs matching the mockup */
.register-page .login-card__form-region .form-item:not(.login-form-item) textarea {
  height: 80px !important;
  padding: 12px 13px !important;
}

/* Strip all default Drupal or Bootstrap error borders, backgrounds, and box-shadows from inputs inside custom icon wrappers */
.login-page .login-input-with-icon input,
.register-page .login-input-with-icon input,
.forgot-password-page .login-input-with-icon input,
.reset-password-page .login-input-with-icon input,
.login-input-with-icon input.error,
.login-input-with-icon input.is-invalid,
.login-input-with-icon input[class*="error"],
.login-input-with-icon input[class*="invalid"],
.form-item--error .login-input-with-icon input {
  border: none !important;
  border-left: 0 !important;
  border-right: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  outline: none !important;
}

/* Prevent split-second flicker of core Drupal status, warning, or error message containers on the register, password reset, and forgot password pages by hiding them initially */
.register-page .messages,
.register-page [data-drupal-messages],
.register-page .messages--status,
.register-page .messages--warning,
.register-page .messages--error,
.register-page .alert,
.reset-password-page .messages,
.reset-password-page [data-drupal-messages],
.reset-password-page .messages--status,
.reset-password-page .messages--warning,
.reset-password-page .messages--error,
.reset-password-page .alert,
.forgot-password-page .messages,
.forgot-password-page [data-drupal-messages],
.forgot-password-page .messages--status,
.forgot-password-page .messages--warning,
.forgot-password-page .messages--error,
.forgot-password-page .alert {
  display: none !important;
}

/* Strip browser autofill / autocomplete blue backgrounds and inner borders on all inputs inside custom wrappers */
.login-input-with-icon input:-webkit-autofill,
.login-input-with-icon input:-webkit-autofill:hover,
.login-input-with-icon input:-webkit-autofill:focus,
.login-input-with-icon input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 1000px #ffffff inset !important;
  /* Forces background to remain white */
  -webkit-text-fill-color: #1e293b !important;
  /* Forces text color to remain dark navy */
  transition: background-color 5000s ease-in-out 0s !important;
  border: none !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: none !important;
}

/* Extra vertical spacing specifically on the register page logos to match the login page's dynamically expanded flex-space gap */
.register-page .login-card__branding {
  margin-bottom: 75px !important;
}

/* ═══════════════════════════════════════════════════
   GLOBAL SECTION AND FORM OVERRIDES FOR AUTH PAGES
   ═══════════════════════════════════════════════════ */
/* Prevent parent section from shrinking the green background container on auth pages */
section:has(.login-page),
section:has(.register-page),
section:has(.forgot-password-page),
section:has(.reset-password-page) {
  display: block !important;
  padding: 0 !important;
}

.login-page,
.register-page,
.forgot-password-page,
.reset-password-page {
  width: 100% !important;
}

/* Remove legacy double borders, padding, margins and flex alignment from password forms inside our premium card layout */
.login-page form#user-pass-reset,
.login-page form#user-pass,
.register-page form#user-pass-reset,
.register-page form#user-pass,
.forgot-password-page form#user-pass,
.reset-password-page form#user-pass-reset,
.reset-password-page form#user-pass {
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  height: auto !important;
}

/* Errored input field highlights on registration page to guarantee high specificity and override default inputs */
.register-page .login-card__form-region .form-item--error:not(.login-form-item) input[type="email"],
.register-page .login-card__form-region .form-item--error:not(.login-form-item) input[type="text"],
.register-page .login-card__form-region .form-item--error:not(.login-form-item) input[type="password"],
.register-page .login-card__form-region .form-item--error:not(.login-form-item) input[type="tel"],
.register-page .login-card__form-region .form-item--error:not(.login-form-item) input[type="number"],
.register-page .login-card__form-region .form-item--error:not(.login-form-item) select,
.register-page .login-card__form-region .form-item--error:not(.login-form-item) textarea {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 2px rgba(239, 68, 68, 0.1) !important;
}

/* Fallback errored input highlights on login, forgot, and reset password pages */
.login-page .login-card__form-region .form-item--error input,
.login-page .login-card__form-region .form-item--error textarea,
.login-page .login-card__form-region .form-item--error select,
.forgot-password-page .login-card__form-region .form-item--error input,
.forgot-password-page .login-card__form-region .form-item--error textarea,
.reset-password-page .login-card__form-region .form-item--error input,
.reset-password-page .login-card__form-region .form-item--error textarea {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 2px rgba(239, 68, 68, 0.1) !important;
}

/* Strip all default browser and Bootstrap invalid outlines or red inner boxes from the input fields inside custom wrappers */
.login-input-with-icon input:invalid,
.login-input-with-icon input:required:invalid,
.login-input-with-icon input:focus:invalid,
.was-validated .login-input-with-icon .form-control:invalid,
.was-validated .login-input-with-icon .form-control:focus:invalid {
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  background: transparent !important;
}

/* Specific high-priority override to completely strip outlines, borders, and shadows from inner inputs when the wrapper is in an error state */
.login-page .form-item--error .login-input-with-icon input,
.register-page .form-item--error .login-input-with-icon input,
.forgot-password-page .form-item--error .login-input-with-icon input,
.reset-password-page .form-item--error .login-input-with-icon input,
.login-page .form-item--error .login-input-with-icon--password input,
.register-page .form-item--error .login-input-with-icon--password input {
  border: none !important;
  border-left: 0 !important;
  border-right: 0 !important;
  box-shadow: none !important;
  outline: none !important;
  background: transparent !important;
}