/* ══════════════════════════════════════
   XQuizMe Auth — Login / Register / Forgot
   Theme-proof — High specificity overrides
   ══════════════════════════════════════ */

/* ── Master reset inside auth wrap ── */
.xqm-auth-wrap,
.xqm-auth-wrap *,
.xqm-auth-wrap *::before,
.xqm-auth-wrap *::after {
  box-sizing: border-box !important;
  -webkit-font-smoothing: antialiased !important;
}

.xqm-auth-wrap {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  min-height: 70vh !important;
  padding: 40px 16px !important;
  direction: rtl !important;
  font-family: 'Assistant', 'Segoe UI', sans-serif !important;
  color: #16324f !important;
  background: transparent !important;
  border: none !important;
  margin: 0 auto !important;
}

/* ── Card ── */
.xqm-auth-wrap .xqm-auth-card {
  width: 100% !important;
  max-width: 440px !important;
  background: #fff !important;
  border: 1px solid #d8e0e8 !important;
  border-radius: 10px !important;
  box-shadow: 0 4px 18px rgba(18,52,86,.07) !important;
  overflow: hidden !important;
  padding: 0 !important;
  margin: 0 auto !important;
}

/* Government top stripe */
.xqm-auth-wrap .xqm-auth-card::before {
  content: '' !important;
  display: block !important;
  height: 5px !important;
  background: #005ea5 !important;
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ── Logo ── */
.xqm-auth-wrap .xqm-auth-logo {
  display: flex !important;
  justify-content: center !important;
  padding: 24px 0 0 !important;
  margin: 0 !important;
  border: none !important;
  background: transparent !important;
}

/* ── Tabs ── */
.xqm-auth-wrap .xqm-auth-tabs {
  display: flex !important;
  margin: 18px 24px 0 !important;
  border: 1px solid #d8e0e8 !important;
  border-radius: 6px !important;
  overflow: hidden !important;
  background: #f3f5f7 !important;
  padding: 3px !important;
  gap: 3px !important;
}
.xqm-auth-wrap .xqm-auth-tab {
  flex: 1 !important;
  padding: 10px 0 !important;
  text-align: center !important;
  font-family: 'Assistant', 'Segoe UI', sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #5d7187 !important;
  background: transparent !important;
  border: none !important;
  cursor: pointer !important;
  transition: all .2s !important;
  border-radius: 4px !important;
  line-height: 1 !important;
  outline: none !important;
  box-shadow: none !important;
  margin: 0 !important;
  text-decoration: none !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}
.xqm-auth-wrap .xqm-auth-tab.active {
  background: #fff !important;
  color: #005ea5 !important;
  box-shadow: 0 1px 4px rgba(0, 0, 0, .08) !important;
  border: none !important;
}
.xqm-auth-wrap .xqm-auth-tab:hover {
  color: #16324f !important;
  background: rgba(0,0,0,.03) !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
}
.xqm-auth-wrap .xqm-auth-tab.active:hover {
  background: #fff !important;
  color: #005ea5 !important;
  box-shadow: 0 1px 4px rgba(0, 0, 0, .08) !important;
}

/* ── Panels ── */
.xqm-auth-wrap .xqm-auth-panel {
  display: none !important;
  padding: 24px 28px 28px !important;
  border: none !important;
  background: transparent !important;
  margin: 0 !important;
}
.xqm-auth-wrap .xqm-auth-panel.active {
  display: block !important;
  animation: xqmAuthFadeIn .25s ease !important;
}
@keyframes xqmAuthFadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.xqm-auth-wrap .xqm-auth-title {
  font-size: 22px !important;
  font-weight: 800 !important;
  color: #16324f !important;
  margin: 0 0 4px !important;
  text-align: center !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  line-height: 1.3 !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}
.xqm-auth-wrap .xqm-auth-subtitle {
  font-size: 14px !important;
  color: #5d7187 !important;
  text-align: center !important;
  margin: 0 0 22px !important;
  padding: 0 !important;
  border: none !important;
  font-weight: 400 !important;
  line-height: 1.4 !important;
}

/* ── Fields ── */
.xqm-auth-wrap .xqm-auth-field {
  margin-bottom: 18px !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
}
.xqm-auth-wrap .xqm-auth-field > label {
  display: block !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #16324f !important;
  margin: 0 0 7px !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  line-height: 1.3 !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}
/* Required asterisk */
.xqm-auth-wrap .xqm-auth-field > label::after {
  content: ' *' !important;
  color: #b10e1e !important;
  font-weight: 700 !important;
}

/* ── Input — THEME OVERRIDE ── */
.xqm-auth-wrap .xqm-auth-input-wrap {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
}
.xqm-auth-wrap .xqm-auth-input-icon {
  position: absolute !important;
  right: 14px !important;
  color: #8ca0b3 !important;
  pointer-events: none !important;
  z-index: 1 !important;
}

.xqm-auth-wrap .xqm-auth-input,
.xqm-auth-wrap input.xqm-auth-input,
.xqm-auth-wrap input[type="text"].xqm-auth-input,
.xqm-auth-wrap input[type="email"].xqm-auth-input,
.xqm-auth-wrap input[type="password"].xqm-auth-input {
  width: 100% !important;
  height: 44px !important;
  padding: 0 14px !important;
  border: 1px solid #97a8b8 !important;
  border-radius: 6px !important;
  font-family: 'Assistant', 'Segoe UI', sans-serif !important;
  font-size: 15px !important;
  color: #16324f !important;
  background: #fff !important;
  transition: border-color .15s, box-shadow .15s !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  outline: none !important;
  box-shadow: none !important;
  margin: 0 !important;
  line-height: normal !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  min-height: 44px !important;
  max-height: 44px !important;
}
/* When inside a wrap with icon — add right padding for RTL */
.xqm-auth-wrap .xqm-auth-input-wrap .xqm-auth-input,
.xqm-auth-wrap .xqm-auth-input-wrap input.xqm-auth-input {
  padding-right: 42px !important;
}
/* When has toggle button — add left padding */
.xqm-auth-wrap .xqm-has-toggle .xqm-auth-input,
.xqm-auth-wrap .xqm-has-toggle input.xqm-auth-input {
  padding-left: 48px !important;
}

/* Focus state */
.xqm-auth-wrap .xqm-auth-input:focus,
.xqm-auth-wrap input.xqm-auth-input:focus,
.xqm-auth-wrap input[type="text"].xqm-auth-input:focus,
.xqm-auth-wrap input[type="email"].xqm-auth-input:focus,
.xqm-auth-wrap input[type="password"].xqm-auth-input:focus {
  border-color: #005ea5 !important;
  outline: 3px solid rgba(0,94,165,.12) !important;
  box-shadow: none !important;
  background: #fff !important;
  color: #16324f !important;
}

/* Placeholder */
.xqm-auth-wrap .xqm-auth-input::placeholder {
  color: #b0bec5 !important;
  opacity: 1 !important;
}

/* ── Toggle password button ── */
.xqm-auth-wrap .xqm-auth-toggle-pass {
  position: absolute !important;
  left: 5px !important;
  right: auto !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  background: #f3f5f7 !important;
  border: 1px solid #d8e0e8 !important;
  cursor: pointer !important;
  color: #5d7187 !important;
  width: 34px !important;
  height: 34px !important;
  min-width: 34px !important;
  min-height: 34px !important;
  max-width: 34px !important;
  max-height: 34px !important;
  border-radius: 6px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background .15s, color .15s, border-color .15s !important;
  z-index: 2 !important;
  padding: 0 !important;
  margin: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  text-decoration: none !important;
  line-height: 1 !important;
  font-size: 0 !important;
  overflow: hidden !important;
}
.xqm-auth-wrap .xqm-auth-toggle-pass:hover {
  background: #e8f1f8 !important;
  color: #005ea5 !important;
  border-color: #005ea5 !important;
  outline: none !important;
  box-shadow: none !important;
}
.xqm-auth-wrap .xqm-auth-toggle-pass:focus {
  outline: none !important;
  box-shadow: none !important;
}
.xqm-auth-wrap .xqm-auth-toggle-pass svg {
  display: block !important;
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0 !important;
}

/* Name row */
.xqm-auth-wrap .xqm-auth-name-row {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 12px !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
}

/* ── Password rules ── */
.xqm-auth-wrap .xqm-auth-pass-rules {
  margin-top: 10px !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 5px 16px !important;
  border: none !important;
  padding: 0 !important;
  background: transparent !important;
}
.xqm-auth-wrap .xqm-pass-rule {
  font-size: 12px !important;
  color: #8ca0b3 !important;
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
  transition: color .2s !important;
  font-weight: 500 !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
}
.xqm-auth-wrap .xqm-rule-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  border-radius: 50% !important;
  font-size: 11px !important;
  flex-shrink: 0 !important;
  border: 1.5px solid #d8e0e8 !important;
  background: #fff !important;
  color: #8ca0b3 !important;
  transition: all .2s !important;
  line-height: 1 !important;
  padding: 0 !important;
  margin: 0 !important;
}
.xqm-auth-wrap .xqm-pass-rule.pass {
  color: #00703c !important;
}
.xqm-auth-wrap .xqm-pass-rule.pass .xqm-rule-icon {
  background: #00703c !important;
  border-color: #00703c !important;
  color: #fff !important;
}
.xqm-auth-wrap .xqm-pass-rule.fail {
  color: #b10e1e !important;
}
.xqm-auth-wrap .xqm-pass-rule.fail .xqm-rule-icon {
  border-color: #b10e1e !important;
  color: #b10e1e !important;
  background: #fff !important;
}

/* Password match */
.xqm-auth-wrap .xqm-auth-pass-match {
  font-size: 13px !important;
  margin-top: 8px !important;
  font-weight: 600 !important;
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
  border: none !important;
  padding: 0 !important;
  background: transparent !important;
}
.xqm-auth-wrap .xqm-auth-pass-match.ok {
  color: #00703c !important;
}
.xqm-auth-wrap .xqm-auth-pass-match.no {
  color: #b10e1e !important;
}

/* ── Feedback ── */
.xqm-auth-wrap .xqm-auth-feedback {
  display: none !important;
  padding: 10px 14px !important;
  border-radius: 6px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  margin-bottom: 14px !important;
  line-height: 1.5 !important;
}
.xqm-auth-wrap .xqm-auth-feedback.success {
  display: block !important;
  background: #e7f4ec !important;
  color: #00703c !important;
  border: 1px solid #b6e8cb !important;
}
.xqm-auth-wrap .xqm-auth-feedback.error {
  display: block !important;
  background: #f8e9eb !important;
  color: #b10e1e !important;
  border: 1px solid #f5c6cb !important;
}

/* ── Buttons — FULL THEME OVERRIDE ── */
.xqm-auth-wrap .xqm-auth-btn,
.xqm-auth-wrap button.xqm-auth-btn {
  min-height: 44px !important;
  padding: 10px 20px !important;
  border-radius: 6px !important;
  font-family: 'Assistant', 'Segoe UI', sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  border: 1px solid transparent !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;
  transition: background .15s, border-color .15s, color .15s !important;
  text-decoration: none !important;
  line-height: 1 !important;
  outline: none !important;
  box-shadow: none !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  margin: 0 !important;
}
.xqm-auth-wrap .xqm-auth-btn-primary,
.xqm-auth-wrap button.xqm-auth-btn-primary {
  background: #005ea5 !important;
  color: #fff !important;
  border-color: #005ea5 !important;
}
.xqm-auth-wrap .xqm-auth-btn-primary:hover,
.xqm-auth-wrap .xqm-auth-btn-primary:active,
.xqm-auth-wrap .xqm-auth-btn-primary:focus,
.xqm-auth-wrap button.xqm-auth-btn-primary:hover,
.xqm-auth-wrap button.xqm-auth-btn-primary:active,
.xqm-auth-wrap button.xqm-auth-btn-primary:focus {
  background: #004b84 !important;
  border-color: #004b84 !important;
  color: #fff !important;
  outline: none !important;
  box-shadow: none !important;
}
.xqm-auth-wrap .xqm-auth-btn-primary:disabled,
.xqm-auth-wrap button.xqm-auth-btn-primary:disabled {
  opacity: .4 !important;
  cursor: not-allowed !important;
  background: #005ea5 !important;
  color: #fff !important;
}
.xqm-auth-wrap .xqm-auth-btn-ghost,
.xqm-auth-wrap a.xqm-auth-btn-ghost {
  background: #fff !important;
  color: #16324f !important;
  border: 1px solid #d8e0e8 !important;
}
.xqm-auth-wrap .xqm-auth-btn-ghost:hover,
.xqm-auth-wrap .xqm-auth-btn-ghost:active,
.xqm-auth-wrap .xqm-auth-btn-ghost:focus,
.xqm-auth-wrap a.xqm-auth-btn-ghost:hover {
  background: #eef2f6 !important;
  color: #16324f !important;
  border-color: #d8e0e8 !important;
  box-shadow: none !important;
  outline: none !important;
}
.xqm-auth-wrap .xqm-auth-btn-block {
  display: flex !important;
  width: 100% !important;
}

/* Spinner */
.xqm-auth-wrap .xqm-auth-spinner {
  animation: xqmAuthSpin .8s linear infinite !important;
}
@keyframes xqmAuthSpin {
  to { transform: rotate(360deg); }
}

/* ── Links ── */
.xqm-auth-wrap .xqm-auth-link-row {
  text-align: center !important;
  margin-top: 16px !important;
  border: none !important;
  padding: 0 !important;
  background: transparent !important;
}
.xqm-auth-wrap .xqm-auth-link,
.xqm-auth-wrap button.xqm-auth-link {
  background: none !important;
  border: none !important;
  color: #005ea5 !important;
  font-family: inherit !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  text-decoration: none !important;
  transition: color .15s !important;
  padding: 0 !important;
  margin: 0 !important;
  outline: none !important;
  box-shadow: none !important;
}
.xqm-auth-wrap .xqm-auth-link:hover,
.xqm-auth-wrap button.xqm-auth-link:hover {
  color: #004b84 !important;
  text-decoration: underline !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
}

/* ── Logged in state ── */
.xqm-auth-wrap .xqm-auth-logged-in {
  text-align: center !important;
  padding: 32px 24px !important;
  border: none !important;
  background: transparent !important;
}
.xqm-auth-wrap .xqm-auth-avatar {
  display: flex !important;
  justify-content: center !important;
  margin-bottom: 12px !important;
}
.xqm-auth-wrap .xqm-auth-avatar img {
  width: 64px !important;
  height: 64px !important;
  border-radius: 50% !important;
  border: 3px solid #d8e0e8 !important;
}
.xqm-auth-wrap .xqm-auth-logged-in h3 {
  font-size: 20px !important;
  font-weight: 800 !important;
  color: #16324f !important;
  margin: 0 0 6px !important;
  border: none !important;
  padding: 0 !important;
}
.xqm-auth-wrap .xqm-auth-logged-in p {
  font-size: 15px !important;
  color: #5d7187 !important;
  margin: 0 0 20px !important;
}
.xqm-auth-wrap .xqm-auth-logged-actions {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}

/* ── Responsive ── */
@media (max-width: 480px) {
  .xqm-auth-wrap {
    padding: 20px 10px !important;
    min-height: 60vh !important;
  }
  .xqm-auth-wrap .xqm-auth-card {
    border-radius: 8px !important;
  }
  .xqm-auth-wrap .xqm-auth-panel {
    padding: 20px 18px 24px !important;
  }
  .xqm-auth-wrap .xqm-auth-name-row {
    grid-template-columns: 1fr !important;
  }
  .xqm-auth-wrap .xqm-auth-pass-rules {
    grid-template-columns: 1fr !important;
  }
}
