:root{
  --ps-blue:#00CEFF;         /* azul principal */
  --ps-blue-700:#0f2fb7;
  --ps-blue-900:#0a1f7b;
  --ps-yellow:#FFD84D;       /* acento */
  --ps-white:#ffffff;
  --ps-text:#1a1a1a;
  --radius-xxl:22px;
  --shadow-lg:0 20px 50px rgba(10,31,123,.25);
}

html,body{
  height:100%;
}

body{
  /* fondo general */
  background: radial-gradient(1200px 600px at 25% -10%, rgba(255,216,77,.15), transparent 60%),
              linear-gradient(135deg, #eef2ff 0%, #ffffff 60%);
  background-attachment: fixed;
  color-scheme: only light;
  font-smooth: always;
  -webkit-font-smoothing: antialiased;
}

/* -------- Tarjeta de Login -------- */
.login-shell{
  background: transparent;
  border:0;
  box-shadow:none;
}

.login-card{
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  gap:0;
  background: var(--ps-white);
  border-radius: var(--radius-xxl);
  overflow:hidden;
  box-shadow: var(--shadow-lg);
  margin: 32px 12px;
}

/* Lado Ilustración */
.art-side{
  background: #321EB4;
  background: linear-gradient(90deg, rgba(50, 30, 180, 1) 0%, rgba(57, 38, 214, 1) 50%, rgba(63, 4, 134, 1) 100%);
  color:#e9eeff;
  padding: 28px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.art-wrap{ width:100%; max-width:520px; text-align:center; }
.art-side .brand{ width:180px; filter: drop-shadow(0 6px 12px rgba(0,0,0,.22)); }
.scene{
  width:100%; max-width:420px; aspect-ratio:1/1; border-radius:24px;
  overflow:hidden; box-shadow: inset 0 0 0 1px rgba(255,255,255,.08), 0 10px 30px rgba(0,0,0,.25);
  margin: 12px auto 18px;
}
.greeting{ color:#fff; font-weight:700; letter-spacing:.2px; }
.subgreeting{ color:#e5ebff; margin:0; }
.hint{ color:#d6ddff; opacity:.9; }

/* Lado Formulario */
.form-side{
  background: var(--ps-white);
  padding: 26px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.form-inner{ width:100%; max-width:520px; }
.text-primary-ps{ color: var(--ps-blue); }

#modal_login .form-control, 
#modal_login .form-select {
  height: 44px;
  font-size: 15px;
  border-radius: 12px;
}

.input-group-text{
  background:#f3f5ff;
  border:1px solid #e6eaff;
  border-right:0;
  border-radius: 10px 0px 0px 10px !important;
}
.input-group .form-control{
	border-radius: 0px 10px 10px 0px !important;
  border-left:0;
}

/* Botón de login amarillo (estilo MS) */
.btn-login{
  width:100%;
  max-width:260px;
  padding:12px 18px;
  border:none;
  border-radius:14px;
  background: var(--ps-blue);          /* amarillo */
  color:#1a1a1a;               /* texto oscuro para contraste */
  font-weight:600;
  letter-spacing:.2px;
  transition:transform .08s ease, box-shadow .2s ease, background .2s ease;
  box-shadow:0 10px 20px rgba(0,0,0,.15);
}
.btn-login:hover{
  background:var(--ps-blue);
  transform:translateY(-1px);
}
.btn-login:active{
  transform:translateY(0);
}
.btn-login:focus{
  outline:0;
}

/* Links/branding */
.brand-link{
  color: var(--ps-blue);
  text-decoration: none;
  border-bottom: 1px dashed rgba(20,69,230,.35);
}
.brand-link:hover{ color: var(--ps-blue-700); }

/* Footer barra vieja (si se usara) */
.footer-form{
  border-top:0;
}

/* Responsivo */
@media (max-width: 991px){
  .login-card{ grid-template-columns: 1fr; }
