/* =========================================================
   AUTH / LOGIN
========================================================= */

body.login-page{
  margin:0;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:
    radial-gradient(circle at top left, rgba(59,130,246,.18), transparent 28%),
    radial-gradient(circle at bottom right, rgba(14,165,233,.12), transparent 24%),
    linear-gradient(135deg, #020617, #0f172a 45%, #0b1220);
  color:#e5e7eb;
}

body.login-page .login-shell{
  width:100%;
  max-width:1040px;
  display:grid;
  grid-template-columns:1.08fr .92fr;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  border-radius:26px;
  background:rgba(15,23,42,.78);
  backdrop-filter:blur(10px);
  box-shadow:0 30px 80px rgba(0,0,0,.35);
}

body.login-page .login-side{
  position:relative;
  padding:42px;
  border-right:1px solid rgba(255,255,255,.08);
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:20px;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
}

body.login-page .login-side::after{
  content:"";
  position:absolute;
  inset:auto -80px -80px auto;
  width:220px;
  height:220px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(14,165,233,.10), transparent 65%);
  pointer-events:none;
}

body.login-page .login-brand{
  display:flex;
  align-items:center;
  gap:14px;
  font-weight:700;
  font-size:22px;
  color:#f8fafc;
}

body.login-page .brand-icon{
  width:54px;
  height:54px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, rgba(59,130,246,.26), rgba(14,165,233,.18));
  border:1px solid rgba(255,255,255,.08);
  font-size:22px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}

body.login-page .login-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  width:max-content;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  color:#cbd5e1;
  font-size:12px;
  font-weight:600;
  letter-spacing:.02em;
}

body.login-page .login-side h1{
  margin:0;
  font-size:36px;
  line-height:1.08;
  color:#f8fafc;
  letter-spacing:-.02em;
}

body.login-page .login-side p{
  margin:0;
  color:#94a3b8;
  font-size:15px;
  line-height:1.7;
  max-width:560px;
}

body.login-page .feature-list{
  display:grid;
  gap:12px;
  margin-top:6px;
}

body.login-page .feature{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:14px 15px;
  border-radius:15px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.05);
  color:#cbd5e1;
}

body.login-page .feature i{
  margin-top:2px;
  color:#60a5fa;
  width:18px;
  text-align:center;
}

body.login-page .feature strong{
  display:block;
  color:#e2e8f0;
  font-size:14px;
  margin-bottom:2px;
}

body.login-page .feature span{
  display:block;
  color:#94a3b8;
  font-size:13px;
  line-height:1.55;
}

body.login-page .login-panel{
  padding:42px;
  display:flex;
  align-items:center;
  justify-content:center;
}

body.login-page .login-card{
  width:100%;
  max-width:390px;
}

body.login-page .login-card-head{
  margin-bottom:22px;
}

body.login-page .login-card h2{
  margin:0 0 8px;
  font-size:30px;
  line-height:1.1;
  color:#f8fafc;
  letter-spacing:-.02em;
}

body.login-page .login-card .sub{
  margin:0;
  color:#94a3b8;
  font-size:14px;
  line-height:1.6;
}

body.login-page .alert-error{
  margin-bottom:16px;
  padding:12px 14px;
  border-radius:14px;
  background:rgba(239,68,68,.10);
  border:1px solid rgba(239,68,68,.25);
  color:#fecaca;
  font-size:14px;
  line-height:1.5;
  display:flex;
  gap:10px;
  align-items:flex-start;
}

body.login-page .alert-error i{
  margin-top:2px;
  flex:0 0 auto;
}

body.login-page .form-group{
  margin-bottom:14px;
}

body.login-page .form-label{
  display:block;
  margin-bottom:8px;
  color:#e5e7eb;
  font-weight:600;
  font-size:14px;
}

body.login-page .input-wrap{
  position:relative;
}

body.login-page .input-icon{
  position:absolute;
  left:14px;
  top:50%;
  transform:translateY(-50%);
  color:#64748b;
  pointer-events:none;
}

body.login-page .input-wrap input{
  width:100%;
  min-height:50px;
  border-radius:15px;
  border:1px solid rgba(255,255,255,.08);
  background:#111827;
  color:#e5e7eb;
  padding:12px 44px 12px 42px;
  outline:none;
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

body.login-page .input-wrap input::placeholder{
  color:#64748b;
}

body.login-page .input-wrap input:focus{
  border-color:rgba(59,130,246,.55);
  box-shadow:0 0 0 4px rgba(59,130,246,.12);
  background:#0f1a2f;
}

body.login-page .password-toggle{
  position:absolute;
  right:10px;
  top:50%;
  transform:translateY(-50%);
  border:none;
  background:transparent;
  color:#94a3b8;
  cursor:pointer;
  width:30px;
  height:30px;
  border-radius:10px;
  display:grid;
  place-items:center;
}

body.login-page .login-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin:4px 0 18px;
  flex-wrap:wrap;
}

body.login-page .login-check{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#94a3b8;
  font-size:13px;
  user-select:none;
}

body.login-page .login-check input{
  accent-color:#2563eb;
}

body.login-page .btn-login{
  width:100%;
  min-height:50px;
  border:none;
  border-radius:15px;
  cursor:pointer;
  color:white;
  font-weight:700;
  font-size:15px;
  background:linear-gradient(135deg, #2563eb, #0ea5e9);
  box-shadow:0 12px 24px rgba(37,99,235,.22);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}

body.login-page .login-foot{
  margin-top:18px;
  color:#94a3b8;
  font-size:12px;
  line-height:1.6;
  text-align:center;
}

@media (max-width: 900px){
  body.login-page .login-shell{
    grid-template-columns:1fr;
    max-width:460px;
  }

  body.login-page .login-side{
    display:none;
  }

  body.login-page .login-panel{
    padding:28px;
  }
}

@media (max-width: 480px){
  body.login-page{
    padding:16px;
  }

  body.login-page .login-panel{
    padding:22px;
  }

  body.login-page .login-card h2{
    font-size:26px;
  }
}

/* =========================================================
   AUTH / CHANGE PASSWORD
========================================================= */

.pw-page{
  width:100%;
}

.pw-panel{
  width:100%;
  max-width:720px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:26px;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.015));
  box-shadow:0 20px 50px rgba(0,0,0,.18);
  overflow:hidden;
}

.pw-panel__bd{
  padding:30px;
}

.pw-brand{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:18px;
}

.pw-brand__icon{
  width:48px;
  height:48px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, rgba(59,130,246,.28), rgba(14,165,233,.18));
  border:1px solid rgba(255,255,255,.08);
  color:#fff;
  font-size:18px;
  flex:0 0 auto;
}

.pw-brand__name{
  color:#f8fafc;
  font-size:18px;
  font-weight:700;
  line-height:1.1;
}

.pw-brand__sub{
  color:#94a3b8;
  font-size:13px;
  margin-top:3px;
}

.pw-title{
  margin:0 0 10px;
  color:#f8fafc;
  font-size:30px;
  line-height:1.08;
  letter-spacing:-.02em;
}

.pw-sub{
  margin:0 0 22px;
  color:#94a3b8;
  font-size:15px;
  line-height:1.75;
  max-width:620px;
}

.pw-info{
  margin-bottom:18px;
  padding:14px 16px;
  border-radius:16px;
  background:rgba(37,99,235,.10);
  border:1px solid rgba(59,130,246,.28);
  color:#dbeafe;
  font-size:14px;
  line-height:1.6;
  display:flex;
  gap:10px;
  align-items:flex-start;
}

.pw-alert{
  margin-bottom:18px;
  padding:14px 16px;
  border-radius:16px;
  background:rgba(239,68,68,.10);
  border:1px solid rgba(239,68,68,.25);
  color:#fecaca;
  font-size:14px;
  line-height:1.6;
  display:flex;
  gap:10px;
  align-items:flex-start;
}

.pw-form{
  display:grid;
  gap:16px;
}

.pw-field{
  display:grid;
  gap:8px;
}

.pw-label{
  color:#e5e7eb;
  font-weight:600;
  font-size:14px;
}

.pw-input-wrap{
  position:relative;
}

.pw-icon{
  position:absolute;
  left:14px;
  top:50%;
  transform:translateY(-50%);
  color:#64748b;
  pointer-events:none;
}

.pw-input{
  width:100%;
  min-height:50px;
  border-radius:15px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(2,6,23,.35);
  color:#e5e7eb;
  padding:12px 46px 12px 42px;
  outline:none;
}

.pw-input::placeholder{
  color:#64748b;
}

.pw-toggle{
  position:absolute;
  right:10px;
  top:50%;
  transform:translateY(-50%);
  border:none;
  background:transparent;
  color:#94a3b8;
  cursor:pointer;
  width:30px;
  height:30px;
  border-radius:10px;
  display:grid;
  place-items:center;
}

.pw-rules{
  margin-top:4px;
  padding:14px 16px;
  border-radius:16px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  color:#94a3b8;
  font-size:13px;
  line-height:1.65;
}

.pw-status{
  font-size:12px;
  min-height:18px;
  margin-top:2px;
}

.pw-status--ok{
  color:#86efac;
}

.pw-status--error{
  color:#fca5a5;
}

.pw-submit{
  width:100%;
  min-height:52px;
  border:none;
  border-radius:16px;
  cursor:pointer;
  color:#fff;
  font-weight:700;
  font-size:16px;
  background:linear-gradient(135deg, #2563eb, #0ea5e9);
  box-shadow:0 12px 24px rgba(37,99,235,.20);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin-top:6px;
}

.pw-foot{
  margin-top:16px;
  color:#94a3b8;
  font-size:12px;
  line-height:1.6;
  text-align:center;
}

@media (max-width: 768px){
  .pw-panel__bd{
    padding:22px;
  }

  .pw-title{
    font-size:26px;
  }
}

@media (max-width: 480px){
  .pw-panel__bd{
    padding:18px;
  }

  .pw-title{
    font-size:24px;
  }

  .pw-sub{
    font-size:14px;
    line-height:1.6;
  }

  .pw-info,
  .pw-alert,
  .pw-rules{
    padding:12px 14px;
  }
}