/* WAVE96 — Login gate and user-auth shell lock. Global and intentionally independent from section CSS. */
html[data-taif-auth="pending"] .shell,
html[data-taif-auth="locked"] .shell{
  pointer-events:none;
  user-select:none;
  filter:blur(1px) saturate(.92);
}

html[data-taif-auth="pending"] .page-bg,
html[data-taif-auth="locked"] .page-bg{
  pointer-events:none;
}

.taif-auth-gate{
  position:fixed;
  inset:0;
  z-index:99999;
  display:grid;
  place-items:center;
  padding:24px;
  direction:rtl;
  background:
    radial-gradient(circle at 50% 0%, rgba(96,165,250,.22), transparent 34%),
    linear-gradient(180deg, rgba(239,246,255,.98), rgba(248,250,252,.98));
  font-family:var(--taif-font-family, "Segoe UI", Tahoma, Arial, sans-serif);
}

.taif-auth-card{
  width:min(100%, 440px);
  border:1px solid rgba(37,99,235,.24);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,251,255,.96));
  box-shadow:0 32px 90px rgba(15,23,42,.18), inset 0 1px 0 rgba(255,255,255,.92);
  padding:24px 24px 22px;
  color:#0f172a;
}

.taif-auth-card__brand{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:14px;
  margin-bottom:18px;
}

.taif-auth-card__logo{
  width:58px;
  height:58px;
  border-radius:15px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, #2563eb, #4f83f5);
  color:#fff;
  font:900 18px/1 var(--taif-font-family, "Segoe UI", Tahoma, Arial, sans-serif);
  letter-spacing:.04em;
  box-shadow:0 14px 28px rgba(37,99,235,.24);
  flex:0 0 auto;
}

.taif-auth-card__copy{
  min-width:0;
}

.taif-auth-card__title{
  margin:0 0 6px;
  font:900 25px/1.25 var(--taif-font-family, "Segoe UI", Tahoma, Arial, sans-serif);
  color:#0f172a;
}

.taif-auth-card__subtitle{
  margin:0;
  color:#64748b;
  font:700 13.5px/1.7 var(--taif-font-family, "Segoe UI", Tahoma, Arial, sans-serif);
}

.taif-auth-form{
  display:grid;
  gap:13px;
}

.taif-auth-field{
  display:grid;
  gap:7px;
}

.taif-auth-field__label{
  font:800 13px/1.35 var(--taif-font-family, "Segoe UI", Tahoma, Arial, sans-serif);
  color:#475569;
  text-align:center;
}

.taif-auth-password-wrap{
  position:relative;
  display:block;
}

.taif-auth-field__control{
  width:100%;
  height:46px;
  border:1px solid rgba(203,213,225,.90);
  border-radius:12px;
  padding:0 13px;
  background:#fff;
  color:#0f172a;
  outline:none;
  box-sizing:border-box;
  font:800 15px/1 var(--taif-font-family, "Segoe UI", Tahoma, Arial, sans-serif);
  text-align:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.90);
}

.taif-auth-field--password .taif-auth-field__control{
  padding-inline:46px;
  direction:ltr;
  text-align:center;
}

.taif-auth-field__control::placeholder{
  color:#94a3b8;
  opacity:1;
  direction:rtl;
  text-align:center;
}

.taif-auth-field__control:focus,
.taif-auth-field__control:focus-visible{
  border-color:rgba(15,23,42,.82);
  box-shadow:0 0 0 1px rgba(15,23,42,.82), inset 0 1px 0 rgba(255,255,255,.92);
}

.taif-auth-password-toggle{
  position:absolute;
  inset-inline-end:8px;
  top:50%;
  transform:translateY(-50%);
  width:32px;
  height:32px;
  border:1px solid rgba(148,163,184,.42);
  border-radius:10px;
  display:grid;
  place-items:center;
  color:#475569;
  background:linear-gradient(180deg, #fff, #f8fafc);
  cursor:pointer;
  padding:0;
}

.taif-auth-password-toggle svg{
  width:18px;
  height:18px;
  display:block;
  pointer-events:none;
}

.taif-auth-password-toggle:focus,
.taif-auth-password-toggle:focus-visible{
  outline:none;
  border-color:rgba(15,23,42,.78);
  box-shadow:0 0 0 1px rgba(15,23,42,.72);
}

.taif-auth-message{
  min-height:20px;
  color:#b91c1c;
  font:800 12.5px/1.55 var(--taif-font-family, "Segoe UI", Tahoma, Arial, sans-serif);
  text-align:right;
}

.taif-auth-message:empty{
  min-height:0;
}

.taif-auth-submit{
  height:47px;
  border:1px solid rgba(22,163,74,.22);
  border-radius:13px;
  background:linear-gradient(180deg, #22c55e, #16a34a);
  color:#fff;
  cursor:pointer;
  font:900 15px/1 var(--taif-font-family, "Segoe UI", Tahoma, Arial, sans-serif);
  box-shadow:0 16px 30px rgba(22,163,74,.22), inset 0 1px 0 rgba(255,255,255,.22);
}

.taif-auth-submit:focus,
.taif-auth-submit:focus-visible{
  outline:none;
  box-shadow:0 0 0 2px rgba(15,23,42,.76), 0 16px 30px rgba(22,163,74,.22);
}

@media (max-width: 560px){
  .taif-auth-gate{
    padding:14px;
  }
  .taif-auth-card{
    padding:20px 18px 18px;
    border-radius:16px;
  }
  .taif-auth-card__brand{
    align-items:flex-start;
  }
  .taif-auth-card__title{
    font-size:22px;
  }
}
