/*
  EZ-Login Front Styles
  Presets: modern | minimal | glass | dark | aurora | soft
*/

.ez-login-form,
.ez-login-form *{
  box-sizing: border-box;
}

/* Respect the HTML hidden attribute (Elementor/theme styles can override it) */
.ez-login-form [hidden]{
  display: none !important;
}

/* Step switching (avoid Elementor flicker if it removes [hidden]) */
.ez-login-instance .ez-login-verify-form{display:none;}
.ez-login-instance.is-step-verify .ez-login-verify-form{display:block;}
.ez-login-instance.is-step-verify .ez-login-sms-form{display:none;}

.ez-login-form{
  --ez-card: #ffffff;
  --ez-bg: #ffffff;
  --ez-soft: rgba(15, 23, 42, 0.04);
  --ez-border: rgba(15, 23, 42, 0.10);
  --ez-text: #0f172a;
  --ez-muted: #64748b;
  --ez-primary: #2563eb;
  --ez-primary-contrast: #ffffff;
  --ez-google: #f59e0b;
  --ez-danger: #dc2626;
  --ez-success: #16a34a;
  --ez-radius: 18px;
  --ez-shadow: 0 16px 46px rgba(2, 6, 23, 0.10);
  --ez-ring: rgba(37, 99, 235, 0.32);
  --ez-input-bg: #ffffff;
  --ez-input-border: rgba(15, 23, 42, 0.14);

  width: 100%;
  direction: rtl;
  text-align: right;
  font-family: inherit;
  background: var(--ez-card);
  border: 1px solid var(--ez-border);
  border-radius: var(--ez-radius);
  box-shadow: var(--ez-shadow);
  padding: 18px;
  position: relative;
  overflow: hidden;
}

.ez-layout-compact{max-width: 520px; margin: 0 auto;}
.ez-layout-fluid{max-width: none; margin: 0;}

/* subtle highlight for some presets */
.ez-preset-modern.ez-login-form::before,
.ez-preset-aurora.ez-login-form::before{
  content: "";
  position: absolute;
  inset: -2px -2px auto -2px;
  height: 120px;
  background: radial-gradient(80rem 10rem at 10% 0%, rgba(37,99,235,.20), transparent 60%),
              radial-gradient(80rem 10rem at 90% 10%, rgba(245,158,11,.14), transparent 62%);
  pointer-events: none;
}

/* Shake on error */
@keyframes ezShake{0%,100%{transform:translateX(0)}20%{transform:translateX(6px)}40%{transform:translateX(-6px)}60%{transform:translateX(4px)}80%{transform:translateX(-4px)}}
.ez-login-instance.is-error{animation: ezShake .45s ease;}

/* Tabs */
.ez-login-tabs{
  position: relative;
  display: flex;
  gap: 6px;
  padding: 6px;
  border-radius: 999px;
  background: var(--ez-soft);
  border: 1px solid var(--ez-border);
  margin: 0 0 14px 0;
}

.ez-tab-btn{
  flex: 1;
  border: 0;
  background: transparent;
  color: var(--ez-muted);
  font-weight: 800;
  padding: 10px 12px;
  border-radius: 999px;
  cursor: pointer;
  transition: transform .12s ease, background-color .15s ease, box-shadow .15s ease, color .15s ease;
}

.ez-tab-btn:hover{transform: translateY(-1px);}

.ez-tab-btn.is-active{
  color: var(--ez-text);
  background: var(--ez-card);
  box-shadow: 0 10px 26px rgba(2, 6, 23, 0.12);
}

.ez-tab-panels{display:block;}
.ez-tab-panel{animation: ezFadeIn .22s ease;}
@keyframes ezFadeIn{from{opacity:.0; transform:translateY(4px)}to{opacity:1; transform:translateY(0)}}

/* Titles */
.ez-login-title{
  margin: 0 0 12px 0;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: -0.2px;
  color: var(--ez-text);
  position: relative;
  z-index: 1;
}

.ez-login-section{margin-bottom: 16px; position: relative; z-index: 1;}

/* Inputs */
.ez-login-input{
  width: 100%;
  padding: 11px 12px;
  border-radius: 14px;
  border: 1px solid var(--ez-input-border);
  background: var(--ez-input-bg);
  color: var(--ez-text);
  outline: none;
  margin: 10px 0;
  transition: box-shadow .15s ease, border-color .15s ease, transform .12s ease;
}

.ez-login-input::placeholder{color: rgba(100,116,139,.85);}

.ez-login-input:focus{
  border-color: rgba(37,99,235,.55);
  box-shadow: 0 0 0 4px var(--ez-ring);
}

/* Phone hint above OTP */
.ez-login-phone-preview{
  margin: 10px 0 0 0;
  font-size: 13px;
  line-height: 1.7;
  color: var(--ez-muted);
  background: var(--ez-soft);
  border: 1px solid var(--ez-border);
  border-radius: 14px;
  padding: 9px 12px;
}

.ez-login-phone-text{
  color: var(--ez-text);
  font-weight: 900;
}

/* Register fields */
.ez-login-register-fields{
  margin-top: 10px;
  padding: 12px;
  border-radius: 16px;
  border: 1px dashed rgba(15,23,42,.18);
  background: var(--ez-soft);
}

.ez-field-row{display:block; margin: 0 0 10px 0;}
.ez-field-label{display:block; font-size: 13px; font-weight: 800; color: var(--ez-muted); margin-bottom: 6px;}
.ez-req{color: var(--ez-danger); font-weight: 900;}

.ez-login-register-fields .ez-login-input{margin: 0;}

/* Buttons */
.ez-login-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 11px 14px;
  border-radius: 14px;
  border: 1px solid transparent;
  background: var(--ez-primary);
  color: var(--ez-primary-contrast);
  cursor: pointer;
  text-decoration: none;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.2;
  transition: transform .12s ease, box-shadow .15s ease, filter .15s ease, opacity .15s ease;
}

.ez-login-btn:hover{transform: translateY(-1px); box-shadow: 0 14px 28px rgba(2, 6, 23, 0.14);}
.ez-login-btn:active{transform: translateY(0);}

.ez-login-btn:disabled{
  opacity: .55;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

/* Verify actions */
.ez-login-actions{
  display: flex;
  gap: 10px;
  margin-top: 10px;
}

.ez-login-actions .ez-login-btn{
  width: auto;
  flex: 1;
  background: var(--ez-soft);
  color: var(--ez-text);
  border-color: var(--ez-border);
  box-shadow: none;
}

.ez-login-actions .ez-login-btn:hover{
  box-shadow: 0 10px 22px rgba(2, 6, 23, 0.10);
}

/* Google */
.ez-google-login-button{
  background: var(--ez-google);
}

/* Messages */
.ez-login-message{
  margin: 10px 0 0 0;
  font-size: 13px;
  line-height: 1.8;
  border-radius: 14px;
  padding: 10px 12px;
  border: 1px solid transparent;
  background: transparent;
}

.ez-login-message:empty{display:none;}

.ez-login-message--error{
  color: #7f1d1d;
  background: rgba(220, 38, 38, 0.10);
  border-color: rgba(220, 38, 38, 0.18);
}

.ez-login-message--info{
  color: #064e3b;
  background: rgba(22, 163, 74, 0.10);
  border-color: rgba(22, 163, 74, 0.18);
}

.ez-login-timer{
  margin-top: 10px;
  font-size: 12px;
  color: var(--ez-muted);
}

/* honeypot */
.ez-hp{position:absolute!important;left:-99999px!important;top:-99999px!important;opacity:0!important;height:0!important;width:0!important;pointer-events:none!important;}

/* captcha */
.ez-captcha{margin:10px 0 6px 0;}
.ez-captcha > div{max-width:100%;}

/* Presets */
.ez-preset-modern{
  --ez-card: #ffffff;
  --ez-soft: rgba(37, 99, 235, 0.07);
  --ez-border: rgba(15, 23, 42, 0.10);
  --ez-primary: #2563eb;
  --ez-google: #f59e0b;
}

.ez-preset-minimal{
  --ez-card: #ffffff;
  --ez-soft: rgba(15, 23, 42, 0.03);
  --ez-border: rgba(15, 23, 42, 0.08);
  --ez-shadow: 0 10px 26px rgba(2, 6, 23, 0.08);
  --ez-primary: #0f172a;
  --ez-ring: rgba(15, 23, 42, 0.20);
}

.ez-preset-glass{
  --ez-card: rgba(255,255,255,.62);
  --ez-soft: rgba(255,255,255,.40);
  --ez-border: rgba(255,255,255,.55);
  --ez-shadow: 0 18px 55px rgba(2, 6, 23, 0.14);
  --ez-input-bg: rgba(255,255,255,.70);
  --ez-input-border: rgba(15, 23, 42, 0.10);
}

.ez-preset-glass.ez-login-form{
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.ez-preset-dark{
  --ez-card: #0b1220;
  --ez-soft: rgba(148, 163, 184, 0.12);
  --ez-border: rgba(148, 163, 184, 0.18);
  --ez-text: #e5e7eb;
  --ez-muted: #94a3b8;
  --ez-primary: #38bdf8;
  --ez-google: #fbbf24;
  --ez-shadow: 0 18px 60px rgba(0,0,0,.40);
  --ez-ring: rgba(56, 189, 248, 0.28);
  --ez-input-bg: rgba(15, 23, 42, 0.55);
  --ez-input-border: rgba(148, 163, 184, 0.24);
}

.ez-preset-dark .ez-login-message--error{color:#fecaca;}
.ez-preset-dark .ez-login-message--info{color:#bbf7d0;}

.ez-preset-aurora{
  --ez-primary: #8b5cf6;
  --ez-google: #22c55e;
  --ez-soft: rgba(139, 92, 246, 0.08);
  --ez-ring: rgba(139, 92, 246, 0.28);
}

.ez-preset-aurora.ez-login-form::before{
  background: radial-gradient(80rem 10rem at 20% 0%, rgba(139,92,246,.22), transparent 60%),
              radial-gradient(80rem 10rem at 85% 10%, rgba(34,197,94,.18), transparent 62%),
              radial-gradient(80rem 10rem at 60% 0%, rgba(14,165,233,.14), transparent 62%);
}

.ez-preset-soft{
  --ez-primary: #16a34a;
  --ez-google: #0ea5e9;
  --ez-soft: rgba(22, 163, 74, 0.07);
  --ez-ring: rgba(22, 163, 74, 0.22);
}

/* Responsive */
@media (max-width: 520px){
  .ez-login-form{padding: 14px; border-radius: 16px;}
  .ez-login-actions{flex-direction: column;}
  .ez-login-actions .ez-login-btn{width: 100%;}
}
