/*=========================================================
  File: Hotel/css/auth.css
=========================================================*/

.auth-body{
  min-height: 100vh;
  background: #f6f9ff;
  overflow: hidden;
}

.auth-bg::before,
.auth-bg::after{
  content: "";
  position: fixed;
  pointer-events: none;
  z-index: 0;
  width: 90vh;
  height: 90vh;
  border-radius: 50%;
  filter: blur(0px);
  animation: authFloat 7s ease-in-out infinite;
  animation-duration: 9s;
}

.auth-bg::before{
  top: -35vh;
  right: -20vw;
  background: radial-gradient(circle at 30% 30%, rgba(13,110,253,.25), rgba(13,110,253,0) 60%);
}

.auth-wrap{
  position: relative;
  z-index: 1;
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
}

.auth-card{
  width: min(520px, 92vw);
  border-radius: 18px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
  animation: authFadeUp .45s ease-out both;
}

.auth-brand{
  display:flex;
  align-items:center;
  gap:14px;
}

.auth-mark{
  width: 64px;
  height: 64px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  background: linear-gradient(135deg, rgba(13,110,253,.10), rgba(0,200,255,.10));
  border: 1px solid rgba(13,110,253,.15);
  padding: 6px;
}

.auth-logo-img{
  width: 52px;
  height: 52px;
  object-fit: contain;
  filter: drop-shadow(0 1px 3px rgba(0,0,0,.15));
}

.auth-title{
  font-weight: 800;
  letter-spacing: .2px;
  font-size: 22px;
  line-height: 1.1;
}

.auth-subtitle{
  color: rgba(33,37,41,.65);
  font-size: 13px;
}

.auth-hint{
  display:flex;
  align-items:center;
  gap:8px;
  color: rgba(33,37,41,.60);
  font-size: 12px;
}

.auth-footer{
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap: 16px;
  border-top: 1px solid rgba(0,0,0,.06);
  padding-top: 14px;
}

.input-group-text{
  background: #f4f7ff;
  border-color: rgba(13,110,253,.18);
}

.form-control:focus{
  box-shadow: 0 0 0 .22rem rgba(13,110,253,.18);
  border-color: rgba(13,110,253,.45);
}
@keyframes authFadeUp {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes authFloat {
  0%   { transform: translateY(0); }
  50%  { transform: translateY(8px); }
  100% { transform: translateY(0); }
}
