*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

.login-shell{
  min-height:100vh;
  display:grid;
  grid-template-columns:1fr 1fr;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}

.login-left{
  background:#ffffff;
  display:flex;
  flex-direction:column;
  padding:44px 56px;
}

.login-brand{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:48px;
}
.login-brand img{height:32px;width:auto;}
.login-brand-text{font-size:22px;font-weight:700;color:#0b1220;letter-spacing:.2px;}

.login-card{margin:auto;max-width:400px;width:100%;}

.login-card h1{
  font-size:30px;
  font-weight:700;
  color:#0b1220;
  margin-bottom:6px;
}
.login-card .subtitle{
  font-size:14px;
  color:#6b7280;
  margin-bottom:28px;
}

.lf-field{margin-bottom:18px;}
.lf-field label{
  display:block;
  font-size:13px;
  font-weight:500;
  color:#374151;
  margin-bottom:6px;
}
.lf-field input{
  width:100%;
  border:1px solid #d1d5db;
  border-radius:6px;
  padding:11px 14px;
  font-size:15px;
  outline:none;
  color:#0b1220;
  transition:border-color .15s,box-shadow .15s;
}
.lf-field input:focus{
  border-color:#2f7dd6;
  box-shadow:0 0 0 3px rgba(47,125,214,.15);
}

.pw-wrap{position:relative;}
.pw-wrap input{padding-right:44px;}
.pw-toggle{
  position:absolute;right:10px;top:50%;
  transform:translateY(-50%);
  border:none;background:transparent;
  color:#9ca3af;cursor:pointer;padding:6px;
  border-radius:4px;line-height:0;
}
.pw-toggle:hover{color:#374151;background:rgba(0,0,0,.05);}

.lf-row{
  display:flex;align-items:center;
  gap:16px;margin-top:8px;
}
.lf-btn{
  background:#2f7dd6;color:#fff;
  border:none;border-radius:6px;
  padding:11px 22px;font-size:15px;
  font-weight:600;cursor:pointer;
  white-space:nowrap;
  box-shadow:0 2px 8px rgba(47,125,214,.3);
  transition:filter .15s;
}
.lf-btn:hover{filter:brightness(.94);}

.lf-remember{
  display:flex;align-items:center;
  gap:7px;font-size:13px;color:#6b7280;
  user-select:none;cursor:pointer;
}
.lf-remember input{width:15px;height:15px;cursor:pointer;}

.lf-links{margin-top:22px;font-size:13px;color:#6b7280;}
.lf-links a{color:#2f7dd6;text-decoration:none;}
.lf-links a:hover{text-decoration:underline;}

.lf-error{
  margin-top:16px;padding:10px 14px;
  border-radius:6px;
  background:rgba(220,38,38,.08);
  color:#b91c1c;font-size:13px;
  border:1px solid rgba(220,38,38,.18);
}
.lf-success{
  margin-top:16px;padding:10px 14px;
  border-radius:6px;
  background:rgba(34,197,94,.08);
  color:#166534;font-size:13px;
  border:1px solid rgba(34,197,94,.2);
}

.login-right{
  background:#ffffff;
  display:flex;align-items:center;
  justify-content:center;padding:48px;
  position:relative;overflow:hidden;
  border-left:1px solid rgba(0,0,0,.08);
}

.login-promo{text-align:center;position:relative;z-index:1;max-width:380px;}
.login-promo-logo{
  width:72px;height:72px;
  border-radius:20px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  display:flex;align-items:center;
  justify-content:center;margin:0 auto 28px;
}
.login-promo-logo img{width:46px;height:auto;}
.login-promo h2{
  font-size:26px;font-weight:700;
  color:#111827;line-height:1.25;
  margin-bottom:14px;
}
.login-promo p{
  font-size:14px;
  color:#6b7280;
  line-height:1.6;
}
.login-promo-badges{
  display:flex;justify-content:center;
  gap:10px;flex-wrap:wrap;margin-top:28px;
}
.lp-badge{
  background:rgba(0,0,0,.05);
  border:1px solid rgba(0,0,0,.10);
  border-radius:999px;padding:5px 14px;
  font-size:12px;color:#374151;
}

.login-right-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:16px;
  width:100%;
  max-width:520px;
}
.login-right-logo{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
}
.login-right-logo img{
  width:100%;
  max-width:480px;
  height:auto;
  object-fit:contain;
  filter:drop-shadow(0 4px 24px rgba(0,0,0,.10));
}
.login-promo{
  text-align:center;
  width:100%;
}
.login-promo h2{
  font-size:26px;font-weight:700;
  color:#111827;line-height:1.25;
  margin-bottom:14px;
}
.login-promo p{
  font-size:14px;
  color:#6b7280;
  line-height:1.6;
  margin-bottom:0;
}

@media(max-width:860px){
  .login-shell{grid-template-columns:1fr;}
  .login-right{display:none;}
  .login-left{
    padding:32px 24px;
    min-height:100vh;
    min-height:100dvh;
    justify-content:center;
  }
  .login-brand{margin-bottom:32px;}
}

/* --- Right panel: cross-fade rotator (CSS-only) --- */
.lp-rotator {
  position: relative;
  width: 100%;
  min-height: 360px;
}

.lp-badges {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 20px;
}

.lp-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  text-align: center;
}

.lp-slide-ops { animation: lpFadeSwap 10s infinite; }
.lp-slide-sec { animation: lpFadeSwap 10s infinite; animation-delay: 5s; }

@keyframes lpFadeSwap {
  0%   { opacity: 0; transform: translateY(8px); }
  8%   { opacity: 1; transform: translateY(0); }
  42%  { opacity: 1; transform: translateY(0); }
  50%  { opacity: 0; transform: translateY(8px); }
  100% { opacity: 0; transform: translateY(8px); }
}

@media (prefers-reduced-motion: reduce) {
  .lp-slide { position: static; opacity: 1; transform: none; animation: none; }
  .lp-slide-ops { display: none; }
}
