/* M5 Auth Pages — Minimal Clean Design */
*, *::before, *::after { box-sizing: border-box !important; margin: 0; padding: 0; }
html { height: 100%; }

body.m5auth-body {
  min-height: 100vh !important;
  background: var(--m5a-bg, #f3f4f6) !important;
  font-family: var(--m5a-font, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif) !important;
  font-size: var(--m5a-font-size, 14px) !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 20px 16px !important;
  -webkit-font-smoothing: antialiased;
  background-size: cover !important;
  background-position: center !important;
  background-attachment: fixed !important;
}
body.m5auth-body.admin-bar { padding-top: 52px !important; }

/* Background blur overlay */
body.m5auth-body.has-bg-image::before {
  content: '';
  position: fixed; inset: 0;
  backdrop-filter: blur(var(--m5a-bg-blur, 0px));
  -webkit-backdrop-filter: blur(var(--m5a-bg-blur, 0px));
  z-index: 0; pointer-events: none;
}

/* Page wrapper */
.m5a-page { width: 100%; max-width: var(--m5a-card-width, 420px); position: relative; z-index: 1; }

/* Back home button */
.m5a-home-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  background: var(--m5a-home-bg, #ffffff) !important;
  color: var(--m5a-home-text, #374151) !important;
  border: 1px solid var(--m5a-home-border, #e5e7eb) !important;
  border-radius: 6px !important;
  padding: 7px 14px !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  text-decoration: none !important;
  margin-bottom: 16px !important;
  transition: border-color .15s;
  box-shadow: none !important;
}
.m5a-home-btn:hover { border-color: var(--m5a-input-focus, #3b82f6) !important; }
.m5a-home-btn svg { stroke: currentColor !important; flex-shrink: 0 !important; }

/* Card */
.m5a-card {
  background: var(--m5a-card-bg, #ffffff) !important;
  border-radius: var(--m5a-card-radius, 12px) !important;
  padding: var(--m5a-card-padding, 32px) !important;
  box-shadow: var(--m5a-card-shadow) !important;
  border: var(--m5a-card-border, 1px solid #e5e7eb) !important;
  width: 100% !important;
}

/* Logo */
.m5a-logo {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
  margin-bottom: var(--m5a-logo-margin, 24px) !important;
  width: 100% !important;
}
.m5a-logo img {
  max-width: var(--m5a-logo-width, 160px) !important;
  max-height: 80px !important;
  object-fit: contain !important;
  display: block !important;
  margin: 0 auto !important;
}

/* Headings */
.m5a-heading {
  font-size: var(--m5a-heading-size, 20px) !important;
  font-weight: var(--m5a-heading-weight, 600) !important;
  color: var(--m5a-heading-color, #111827) !important;
  text-align: center !important;
  margin: 0 0 4px !important;
  line-height: 1.2 !important;
  font-family: var(--m5a-font) !important;
}
.m5a-sub {
  font-size: var(--m5a-sub-size, 13px) !important;
  color: var(--m5a-sub-color, #6b7280) !important;
  text-align: center !important;
  margin: 0 0 18px !important;
  font-family: var(--m5a-font) !important;
}

/* Alerts */

/* Form */
.m5a-form { display: flex !important; flex-direction: column !important; gap: 10px !important; }

/* Field */
.m5a-field { display: flex !important; flex-direction: column !important; gap: 6px !important; }
.m5a-label {
  display: none !important;
  font-size: var(--m5a-label-size, 12px) !important;
  font-weight: 600 !important;
  color: var(--m5a-label-color, #374151) !important;
  font-family: var(--m5a-font) !important;
}
.m5a-req { color: #ef4444 !important; }

/* Input wrapper */
.m5a-input-wrap { position: relative !important; }

/* Input */
.m5a-input {
  display: block !important;
  width: 100% !important;
  height: var(--m5a-input-height, 46px) !important;
  min-height: var(--m5a-input-height, 46px) !important;
  background: var(--m5a-input-bg, #ffffff) !important;
  border: 1px solid var(--m5a-input-border, #d1d5db) !important;
  border-radius: var(--m5a-input-radius, 8px) !important;
  color: var(--m5a-input-text, #111827) !important;
  padding: 0 42px 0 14px !important;  /* right space for eye toggle */
  font-size: var(--m5a-font-size, 14px) !important;
  font-family: var(--m5a-font) !important;
  outline: none !important;
  box-shadow: none !important;
  transition: border-color .15s, box-shadow .15s;
  -webkit-appearance: none !important;
  line-height: var(--m5a-input-height, 46px) !important;
}
.m5a-input, .m5a-input.no-icon { padding-left: 14px !important; }
.m5a-input:focus {
  border-color: var(--m5a-input-focus, #3b82f6) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--m5a-input-focus, #3b82f6) 18%, transparent) !important;
  outline: none !important;
}
.m5a-input::placeholder { color: var(--m5a-input-ph, #9ca3af) !important; }

/* Input icons */
.m5a-input-icon {
  position: absolute !important; left: 13px !important; top: 50% !important;
  transform: translateY(-50%) !important; stroke: #9ca3af !important;
  pointer-events: none !important; width: 16px !important; height: 16px !important;
}
.m5a-toggle-pw {
  position: absolute !important; right: 12px !important; top: 50% !important;
  transform: translateY(-50%) !important; background: none !important;
  border: none !important; cursor: pointer !important; color: #9ca3af !important;
  padding: 4px !important; display: flex !important; align-items: center !important;
  box-shadow: none !important;
}
.m5a-toggle-pw:hover { color: var(--m5a-input-focus, #3b82f6) !important; }

/* 2-col row */
.m5a-row-2 { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 12px !important; }
@media (max-width: 380px) { .m5a-row-2 { grid-template-columns: 1fr !important; } }

/* Remember / forgot */
.m5a-row-between {
  display: flex !important; align-items: center !important;
  justify-content: space-between !important; font-size: 13px !important;
}
.m5a-remember {
  display: flex !important; align-items: center !important; gap: 7px !important;
  cursor: pointer !important; color: var(--m5a-label-color, #374151) !important;
  font-weight: 500 !important; user-select: none !important;
  font-size: 13px !important; font-family: var(--m5a-font) !important;
}
.m5a-remember input {
  width: 15px !important; height: 15px !important;
  accent-color: var(--m5a-input-focus, #3b82f6) !important; cursor: pointer !important;
}

/* Button */
.m5a-btn {
  display: flex !important; align-items: center !important; justify-content: center !important;
  gap: 8px !important; width: 100% !important;
  height: var(--m5a-btn-height, 46px) !important;
  min-height: var(--m5a-btn-height, 46px) !important;
  background: var(--m5a-btn-bg, #3b82f6) !important;
  border: var(--m5a-btn-border, none) !important;
  border-radius: var(--m5a-btn-radius, 8px) !important;
  color: var(--m5a-btn-text, #ffffff) !important;
  font-size: var(--m5a-btn-size, 15px) !important;
  font-weight: var(--m5a-btn-weight, 600) !important;
  font-family: var(--m5a-font) !important;
  cursor: pointer !important; margin-top: 4px !important;
  text-decoration: none !important; box-shadow: none !important;
  transition: opacity .15s, transform .12s;
  -webkit-appearance: none !important;
  line-height: 1 !important;
}
.m5a-btn:hover:not(:disabled) { opacity: .88 !important; transform: translateY(-1px) !important; }
.m5a-btn:active:not(:disabled) { transform: none !important; }
.m5a-btn:disabled { opacity: .55 !important; cursor: wait !important; }

/* Spinner */
.m5a-spin { animation: m5spin .8s linear infinite; }
@keyframes m5spin { to { transform: rotate(360deg); } }

/* Links */
.m5a-link { color: var(--m5a-link, #3b82f6) !important; font-weight: 600 !important; text-decoration: none !important; font-size: inherit !important; }
.m5a-link:hover { color: var(--m5a-link-hover, #1d4ed8) !important; text-decoration: underline !important; }

/* Bottom */
.m5a-switch { text-align: center !important; font-size: 13px !important; color: var(--m5a-sub-color, #6b7280) !important; margin-top: 14px !important; font-family: var(--m5a-font) !important; }
.m5a-credit { text-align: center !important; font-size: 11px !important; color: #d1d5db !important; margin-top: 10px !important; }
.m5a-credit a { color: var(--m5a-link, #3b82f6) !important; font-weight: 700 !important; text-decoration: none !important; }

/* Password strength */
.m5a-pw-strength { margin-top: 4px !important; }

/* Back to home — muted inline link */
.m5a-link-muted {
  color: var(--m5a-sub-color, #9ca3af) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  text-decoration: none !important;
}
.m5a-link-muted:hover {
  color: var(--m5a-link, #3b82f6) !important;
  text-decoration: underline !important;
}
