/* AwadhMed Premium Login + OTP Reset Upgrade
   Reference: doctor healthcare login mockup supplied by user.
   This file is loaded last so it safely upgrades only the login/auth popup UI.
*/

body.awm-login-open {
  overflow: hidden;
}

.login-overlay {
  padding: 18px;
}

.login-overlay.open .login-backdrop {
  background:
    linear-gradient(90deg, rgba(2, 11, 23, 0.84), rgba(8, 20, 38, 0.72)),
    url('../assets/images/awadhmed-login-bg.png') left center / cover no-repeat;
  backdrop-filter: blur(9px) saturate(120%);
}

.login-panel.awm-premium-login {
  width: min(940px, calc(100vw - 34px)) !important;
  max-height: 90vh !important;
  display: grid !important;
  grid-template-columns: minmax(300px, 0.94fr) minmax(390px, 1.06fr) !important;
  background: #ffffff !important;
  border: 1px solid rgba(255,255,255,.72) !important;
  border-radius: 24px !important;
  overflow: hidden !important;
  box-shadow: 0 34px 110px rgba(0, 0, 0, 0.46), 0 0 0 1px rgba(16, 163, 143, 0.10) !important;
}

.login-panel.awm-premium-login::before,
.login-panel.awm-premium-login::after {
  display: none !important;
}

.login-brand-side {
  position: relative;
  min-height: 640px;
  padding: 44px 42px;
  background:
    radial-gradient(circle at 16% 88%, rgba(25, 165, 151, .16), transparent 34%),
    linear-gradient(145deg, rgba(247, 255, 253, 0.97), rgba(228, 250, 246, 0.86));
  color: #14254c;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-right: 1px solid rgba(19, 148, 132, 0.11);
  isolation: isolate;
}

.login-brand-side::before {
  content: '';
  position: absolute;
  inset: auto -40px -90px -70px;
  height: 260px;
  background: radial-gradient(circle, rgba(30, 166, 153, .15), rgba(30, 166, 153, 0) 68%);
  z-index: -1;
}

.login-brand-logo {
  text-align: center;
  margin-bottom: 34px;
}

.login-brand-logo-mark {
  width: 78px;
  height: 78px;
  border-radius: 20px;
  margin: 0 auto 18px;
  background: linear-gradient(135deg, #23b7a4, #098e83);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 34px;
  box-shadow: 0 18px 34px rgba(9, 142, 131, .24);
}

.login-brand-name {
  font-family: 'Montserrat', 'Inter', sans-serif;
  font-size: clamp(2rem, 4.2vw, 2.55rem);
  letter-spacing: .012em;
  font-weight: 900;
  line-height: 1;
  color: #122b61;
}

.login-brand-name span {
  color: #18a694;
}

.login-brand-tagline {
  margin-top: 12px;
  color: #44516f;
  font-size: .83rem;
  font-weight: 600;
}

.login-brand-divider {
  width: 44px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, #20aa9a, transparent);
  margin: 18px auto 0;
}

.login-brand-points {
  display: grid;
  gap: 24px;
  margin-top: 18px;
}

.login-brand-point {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 15px;
  align-items: start;
}

.login-brand-point i {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: #139484;
  border: 1px solid rgba(19, 148, 132, .14);
  background: rgba(255,255,255,.66);
  font-size: 19px;
}

.login-brand-point b {
  display: block;
  color: #1e2d57;
  font-size: .95rem;
  font-weight: 800;
  margin-bottom: 5px;
}

.login-brand-point span {
  display: block;
  color: #5d6781;
  font-size: .79rem;
  line-height: 1.55;
  font-weight: 500;
}

.login-panel.awm-premium-login .login-form-side {
  position: relative !important;
  max-height: 90vh !important;
  overflow-y: auto !important;
  background: #ffffff !important;
  color: #172856 !important;
  padding: 42px 48px 34px !important;
  scrollbar-width: thin;
  scrollbar-color: rgba(20, 157, 142, .35) transparent;
}

.login-panel.awm-premium-login .login-form-side::-webkit-scrollbar { width: 7px; }
.login-panel.awm-premium-login .login-form-side::-webkit-scrollbar-track { background: transparent; }
.login-panel.awm-premium-login .login-form-side::-webkit-scrollbar-thumb { background: rgba(20, 157, 142, .35); border-radius: 999px; }

.login-panel.awm-premium-login .login-close {
  top: 20px !important;
  right: 22px !important;
  width: 34px !important;
  height: 34px !important;
  border: none !important;
  background: transparent !important;
  color: #172856 !important;
  font-size: 1.1rem !important;
  box-shadow: none !important;
}

.login-panel.awm-premium-login .login-close:hover {
  background: rgba(18,43,97,.06) !important;
  transform: none !important;
}

.login-panel.awm-premium-login .login-header {
  padding: 16px 0 22px !important;
  text-align: left !important;
}

.login-panel.awm-premium-login .login-brand-ring {
  display: none !important;
}

.login-panel.awm-premium-login .login-title {
  font-family: 'Montserrat', 'Inter', sans-serif !important;
  font-size: 1.62rem !important;
  font-weight: 900 !important;
  letter-spacing: -0.03em !important;
  background: none !important;
  -webkit-text-fill-color: #122b61 !important;
  color: #122b61 !important;
  margin: 0 0 9px !important;
}

.login-panel.awm-premium-login .login-subtitle {
  color: #5d6781 !important;
  font-size: .88rem !important;
  font-weight: 500 !important;
}

.login-panel.awm-premium-login .fw-banner.show {
  border-radius: 13px !important;
  margin: 0 0 14px !important;
}

.login-panel.awm-premium-login .lf-auth-tabs {
  display: none !important;
}

.login-panel.awm-premium-login .login-tabs {
  margin: 0 0 20px !important;
  padding: 5px !important;
  border-radius: 14px !important;
  background: #f4f7fb !important;
  border: 1px solid #e8edf4 !important;
}

.login-panel.awm-premium-login .login-tab {
  color: #6b7590 !important;
  border-radius: 11px !important;
  padding: .7rem .8rem !important;
  font-size: .78rem !important;
  letter-spacing: 0 !important;
  font-weight: 800 !important;
}

.login-panel.awm-premium-login .login-tab.active {
  background: #ffffff !important;
  color: #119888 !important;
  border: 1px solid #e5edf4 !important;
  box-shadow: 0 8px 18px rgba(32, 71, 119, .08) !important;
}

.login-panel.awm-premium-login .login-form-wrap {
  padding: 0 !important;
}

.login-panel.awm-premium-login .lf-group {
  margin-bottom: 18px !important;
}

.login-panel.awm-premium-login .lf-label {
  display: block !important;
  color: #182b5b !important;
  font-size: .82rem !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  font-weight: 800 !important;
  margin-bottom: 9px !important;
}

.login-panel.awm-premium-login .lf-input-wrap {
  position: relative !important;
}

.login-panel.awm-premium-login .lf-input {
  height: 58px !important;
  border-radius: 12px !important;
  border: 1px solid #d9e0e9 !important;
  background: #ffffff !important;
  color: #172856 !important;
  padding-left: 56px !important;
  font-size: .92rem !important;
  font-weight: 600 !important;
  box-shadow: 0 6px 16px rgba(38, 54, 82, .035) !important;
}

.login-panel.awm-premium-login .lf-input::placeholder {
  color: #8a95aa !important;
  font-weight: 500 !important;
}

.login-panel.awm-premium-login .lf-input:focus {
  border-color: #22a99a !important;
  box-shadow: 0 0 0 4px rgba(34, 169, 154, .12) !important;
}

.login-panel.awm-premium-login .lf-input-icon {
  left: 20px !important;
  color: #7d8aa1 !important;
  font-size: 1rem !important;
}

.login-panel.awm-premium-login .lf-eye {
  right: 18px !important;
  color: #7d8aa1 !important;
}

.login-panel.awm-premium-login .lf-row {
  margin: -4px 0 22px !important;
}

.login-panel.awm-premium-login .lf-remember {
  color: #5d6781 !important;
  font-size: .78rem !important;
}

.login-panel.awm-premium-login .lf-forgot,
.login-panel.awm-premium-login .awm-link-btn {
  color: #119888 !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
}

.login-panel.awm-premium-login .lf-submit,
.login-panel.awm-premium-login .lf-send-otp-btn,
.login-panel.awm-premium-login .lf-otp-verify-btn,
.login-panel.awm-premium-login .lf-2fa-verify-btn,
.login-panel.awm-premium-login .awm-reset-primary {
  height: 58px !important;
  border: none !important;
  border-radius: 12px !important;
  background: linear-gradient(135deg, #20b5a3, #0a9788) !important;
  color: #fff !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  box-shadow: 0 16px 26px rgba(14, 151, 136, .22) !important;
}

.login-panel.awm-premium-login .lf-submit:hover,
.login-panel.awm-premium-login .awm-reset-primary:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 20px 32px rgba(14, 151, 136, .26) !important;
}

.login-panel.awm-premium-login #fwAttemptInfo,
.login-panel.awm-premium-login .lf-trust-strip,
.login-panel.awm-premium-login #staffAccessHint {
  color: #6a7388 !important;
}

.login-panel.awm-premium-login .lf-trust-strip {
  border-top: 1px solid #edf1f6 !important;
  padding: 18px 0 0 !important;
  margin-top: 22px !important;
}

.login-panel.awm-premium-login .lf-trust-item {
  color: #738095 !important;
  letter-spacing: 0 !important;
  font-size: .68rem !important;
}

.login-panel.awm-premium-login .lf-trust-item i {
  color: #119888 !important;
}

.login-panel.awm-premium-login #staffAccessHint {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  opacity: 1 !important;
  color: #119888 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  font-size: .78rem !important;
  font-weight: 800 !important;
}

.login-panel.awm-premium-login .am-google-box {
  border: 0 !important;
  background: transparent !important;
  padding: 0 !important;
  margin-top: 18px !important;
}

.login-panel.awm-premium-login .am-google-title {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  color: #7a8498 !important;
  font-size: .78rem !important;
  font-weight: 700 !important;
  justify-content: center !important;
  margin-bottom: 12px !important;
}

.login-panel.awm-premium-login .am-google-title::before,
.login-panel.awm-premium-login .am-google-title::after {
  content: '';
  flex: 1;
  height: 1px;
  background: #e3e9f1;
}

.login-panel.awm-premium-login .am-firebase-google-btn,
.login-panel.awm-premium-login .awm-social-btn {
  min-height: 52px !important;
  border: 1px solid #dfe6ef !important;
  border-radius: 11px !important;
  background: #ffffff !important;
  color: #202638 !important;
  font-weight: 850 !important;
  box-shadow: none !important;
}

.awm-social-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 12px;
}

.awm-social-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  cursor: pointer;
  font-family: 'Montserrat', 'Inter', sans-serif;
}

.awm-social-btn i.fa-google { color: #4285f4; }
.awm-social-btn i.fa-apple { color: #111827; }

.login-panel.awm-premium-login .am-google-msg {
  color: #768196 !important;
  text-align: center !important;
  margin-top: 8px !important;
  font-size: .68rem !important;
}

.login-panel.awm-premium-login .lf-2fa-pane.active,
.login-panel.awm-premium-login .lf-otp-pane.active {
  display: block !important;
}

.login-panel.awm-premium-login .lf-2fa-pane,
.login-panel.awm-premium-login .lf-otp-pane,
.login-panel.awm-premium-login .login-success,
.login-panel.awm-premium-login .awm-reset-pane {
  color: #172856 !important;
}

.login-panel.awm-premium-login .login-success h3,
.login-panel.awm-premium-login .lf-2fa-info-title {
  color: #122b61 !important;
}

.login-panel.awm-premium-login .login-success p,
.login-panel.awm-premium-login .lf-2fa-info-sub,
.login-panel.awm-premium-login .lf-otp-hint,
.login-panel.awm-premium-login .lf-otp-timer {
  color: #677287 !important;
}

.login-panel.awm-premium-login .lf-2fa-digit,
.login-panel.awm-premium-login .lf-otp-digit {
  color: #122b61 !important;
  background: #fff !important;
  border-color: #d9e0e9 !important;
}

.login-panel.awm-premium-login .fw-captcha.show {
  background: #fff8e6 !important;
  border-color: rgba(214, 163, 55, .32) !important;
  color: #172856 !important;
}

/* Password reset / forgot OTP pane */
.awm-reset-pane.hidden { display: none !important; }
.awm-reset-pane {
  animation: awmFadeUp .25s ease both;
}

.awm-reset-card {
  background: #f7fbff;
  border: 1px solid #e3edf8;
  border-radius: 16px;
  padding: 16px;
  margin-bottom: 18px;
  display: flex;
  gap: 13px;
  align-items: flex-start;
}

.awm-reset-card-icon {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: rgba(32,181,163,.11);
  color: #119888;
  flex: 0 0 auto;
}

.awm-reset-title {
  font-weight: 900;
  color: #122b61;
  margin-bottom: 3px;
}

.awm-reset-sub {
  color: #667287;
  font-size: .78rem;
  line-height: 1.55;
}

.awm-reset-grid {
  display: grid;
  gap: 14px;
}

.awm-reset-select {
  height: 52px;
  width: 100%;
  border-radius: 12px;
  border: 1px solid #d9e0e9;
  background: #fff;
  color: #172856;
  padding: 0 14px;
  font-weight: 750;
  outline: none;
}

.awm-reset-actions {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-top: 16px;
}

.awm-reset-secondary {
  height: 52px;
  padding: 0 18px;
  border-radius: 12px;
  border: 1px solid #d9e0e9;
  background: #fff;
  color: #172856;
  font-weight: 900;
  cursor: pointer;
}

.awm-reset-primary {
  width: 100%;
  cursor: pointer;
}

.awm-otp-hint {
  border: 1px dashed rgba(17, 152, 136, .38);
  background: rgba(32, 181, 163, .08);
  color: #172856;
  border-radius: 14px;
  padding: 12px 14px;
  font-size: .78rem;
  line-height: 1.55;
  margin-top: 12px;
}

.awm-otp-code {
  display: inline-flex;
  gap: 4px;
  margin-left: 6px;
  font-size: 1rem;
  font-weight: 950;
  color: #0a9788;
  letter-spacing: .14em;
}

.awm-reset-msg {
  min-height: 20px;
  color: #be123c;
  font-size: .76rem;
  font-weight: 750;
}

.awm-reset-msg.ok { color: #0f8f7f; }

@keyframes awmFadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Style the fallback AwadhAuth modal too, in case another flow opens it. */
.awm-login-overlay {
  background:
    linear-gradient(90deg, rgba(2, 11, 23, .84), rgba(8, 20, 38, .72)),
    url('../assets/images/awadhmed-login-bg.png') left center / cover no-repeat !important;
  backdrop-filter: blur(9px) saturate(120%) !important;
}

.awm-login-card {
  border-radius: 24px !important;
  border: 1px solid rgba(255,255,255,.72) !important;
  box-shadow: 0 34px 110px rgba(0,0,0,.46) !important;
}

@media (max-width: 820px) {
  .login-overlay { padding: 12px; }
  .login-panel.awm-premium-login {
    width: min(96vw, 520px) !important;
    grid-template-columns: 1fr !important;
    max-height: 93vh !important;
    border-radius: 20px !important;
  }
  .login-brand-side {
    min-height: auto;
    padding: 24px 24px 18px;
  }
  .login-brand-logo { margin-bottom: 14px; }
  .login-brand-logo-mark { width: 56px; height: 56px; border-radius: 16px; font-size: 25px; margin-bottom: 12px; }
  .login-brand-name { font-size: 1.8rem; }
  .login-brand-tagline, .login-brand-divider { display: none; }
  .login-brand-points { display: none; }
  .login-panel.awm-premium-login .login-form-side {
    padding: 26px 22px 24px !important;
    max-height: 72vh !important;
  }
  .login-panel.awm-premium-login .login-header { padding-top: 8px !important; }
  .login-panel.awm-premium-login .login-title { font-size: 1.38rem !important; }
  .awm-social-row { grid-template-columns: 1fr; }
}

@media (max-width: 460px) {
  .login-panel.awm-premium-login .login-form-side { padding: 24px 18px !important; }
  .login-panel.awm-premium-login .lf-input { height: 54px !important; }
  .login-panel.awm-premium-login .lf-submit,
  .login-panel.awm-premium-login .awm-reset-primary { height: 54px !important; }
  .awm-reset-actions { flex-direction: column; align-items: stretch; }
  .awm-reset-secondary { width: 100%; }
}


/* AwadhMed Compact Login Size + Public Index Admin Hide Patch */
.login-panel.awm-premium-login {
  width: min(780px, calc(100vw - 32px)) !important;
  max-height: 84vh !important;
  grid-template-columns: minmax(245px, .88fr) minmax(330px, 1.12fr) !important;
  border-radius: 20px !important;
}
.login-brand-side {
  min-height: 500px !important;
  padding: 28px 30px !important;
}
.login-brand-logo { margin-bottom: 22px !important; }
.login-brand-logo-mark {
  width: 60px !important;
  height: 60px !important;
  border-radius: 18px !important;
  font-size: 26px !important;
  margin-bottom: 14px !important;
}
.login-brand-name { font-size: clamp(1.62rem, 3.2vw, 2.05rem) !important; }
.login-brand-tagline { margin-top: 8px !important; font-size: .74rem !important; }
.login-brand-divider { margin-top: 14px !important; }
.login-brand-points { gap: 15px !important; margin-top: 10px !important; }
.login-brand-point { grid-template-columns: 36px 1fr !important; gap: 12px !important; }
.login-brand-point i { width: 36px !important; height: 36px !important; border-radius: 12px !important; font-size: 16px !important; }
.login-brand-point b { font-size: .82rem !important; margin-bottom: 3px !important; }
.login-brand-point span { font-size: .68rem !important; line-height: 1.42 !important; }
.login-panel.awm-premium-login .login-form-side {
  max-height: 84vh !important;
  padding: 26px 34px 24px !important;
}
.login-panel.awm-premium-login .login-close { top: 12px !important; right: 14px !important; width: 30px !important; height: 30px !important; }
.login-panel.awm-premium-login .login-header { padding: 8px 0 15px !important; }
.login-panel.awm-premium-login .login-title { font-size: 1.36rem !important; margin-bottom: 5px !important; }
.login-panel.awm-premium-login .login-subtitle { font-size: .78rem !important; }
.login-panel.awm-premium-login .login-tabs { margin-bottom: 14px !important; }
.login-panel.awm-premium-login .login-tab { padding: .55rem .62rem !important; font-size: .7rem !important; }
.login-panel.awm-premium-login .lf-group { margin-bottom: 12px !important; }
.login-panel.awm-premium-login .lf-label { font-size: .74rem !important; margin-bottom: 6px !important; }
.login-panel.awm-premium-login .lf-input {
  height: 46px !important;
  border-radius: 11px !important;
  padding-left: 46px !important;
  font-size: .82rem !important;
}
.login-panel.awm-premium-login .lf-input-icon { left: 16px !important; font-size: .9rem !important; }
.login-panel.awm-premium-login .lf-eye { right: 15px !important; }
.login-panel.awm-premium-login .lf-row { margin: -2px 0 14px !important; }
.login-panel.awm-premium-login .lf-submit,
.login-panel.awm-premium-login .lf-send-otp-btn,
.login-panel.awm-premium-login .lf-otp-verify-btn,
.login-panel.awm-premium-login .lf-2fa-verify-btn,
.login-panel.awm-premium-login .awm-reset-primary { height: 48px !important; border-radius: 11px !important; }
.login-panel.awm-premium-login .am-google-box { margin-top: 12px !important; }
.login-panel.awm-premium-login .am-google-title { margin-bottom: 8px !important; font-size: .7rem !important; }
.login-panel.awm-premium-login .am-firebase-google-btn,
.login-panel.awm-premium-login .awm-social-btn { min-height: 44px !important; border-radius: 10px !important; font-size: .8rem !important; }
.awm-social-row { gap: 9px !important; margin-top: 8px !important; }
.login-panel.awm-premium-login .lf-trust-strip { padding-top: 12px !important; margin-top: 14px !important; }
.login-panel.awm-premium-login .lf-trust-item { font-size: .58rem !important; }
#staffAccessHint, #tabStaff, #formStaff { display: none !important; }
@media (max-width: 820px) {
  .login-panel.awm-premium-login { width: min(94vw, 460px) !important; max-height: 90vh !important; }
  .login-brand-side { padding: 18px 20px 14px !important; }
  .login-brand-logo-mark { width: 48px !important; height: 48px !important; font-size: 22px !important; margin-bottom: 8px !important; }
  .login-brand-name { font-size: 1.45rem !important; }
  .login-panel.awm-premium-login .login-form-side { padding: 22px 20px 20px !important; max-height: 76vh !important; }
}
