.h100 {
  height: 100% !important;
}

#login #main {
  background: none;
  max-height: 100%;
  background-image: url("../img/banner-login.png") !important;
  background-repeat: no-repeat;
  background-size: cover;
}

.content-full {
  padding: 0 !important;
}

.login {
  background: rgba(255, 255, 255, 0.04);
  border-left: 1px solid rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  padding: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin: 0;
  width: 100%;
  max-width: none;
}

.login header {
  border-bottom: none; 
}

.login header .logo {
  width: 200px;
}

.login input:focus, 
.login input:hover {
  border-color: #5ba4cf !important; 
}

.login footer {
  border-top: none;
  text-align: center; 
  padding: 0;
}

 .btn-primary {
  width: 100%;
  padding: 6px;
  background: #5BA4CF;
  color: #0A2342;
  border: none;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
  margin-top: 6px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  transition: background 0.2s, transform 0.15s;
  height: 40px !important;
}

.btn-secondary {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 13px 16px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.08);
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    color: #fff;
    height: 40px;
    margin-bottom: 1.75rem;
    letter-spacing: 0.3px;
    transition: background 0.2s, border-color 0.2s;
}

.btn-secondary:hover, 
.btn-secondary:focus {
    background: rgba(255, 255, 255, 0.14);
    border-color: rgba(255, 255, 255, 0.35);
    color: #fff !important;
}

.ms-logo {
    width: 18px;
    height: 18px;
    flex-shrink: 0; 
}

 .sep {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 1.5rem;
}
.sep-line { 
  flex: 1; 
  height: 1px; 
  background: rgba(255,255,255,0.1); 
}

.sep span {
  font-size: 10px;
  color: rgba(255,255,255,0.3);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 400;
}

.smart-form footer {
  background: none;
}

.smart-form fieldset {
  background: none;
}

.client-form header {
  background: none;
}

.smart-form {
  width: 80%;
}

.smart-form .note, .note {
  color: #727d8c;
  text-transform: uppercase;
  font-size: 12px;
  margin-bottom: 10px;
  font-weight: bold;
}

.smart-form .input input {
  width: 100%;
  padding: 20px 16px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 10px;
  font-size: 14px;
  color: #fff;
  background: rgba(255, 255, 255, 0.07);
  outline: none;
  transition: border-color 0.2s, background 0.2s;
}

h2 {
  font-size: 32px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.5px;
  margin-bottom: 0.4rem;
}

.subtitle {
  font-size: 16px;
  color: rgba(255, 255, 255, 0.45);
  font-weight: 300;
  margin-bottom: 2rem; 
}

.logo-svg {
  width: 450px;
}

.st0 {
  fill: #164e81;
}

.st1 {
  fill: #fff;
}

.st2 {
  fill: url(#Degradado_sin_nombre_331);
}

.st3 {
  fill: url(#Degradado_sin_nombre_335);
}

.st4 {
  fill: url(#Degradado_sin_nombre_332);
}

.st5 {
  fill: url(#Degradado_sin_nombre_334);
}

.st6 {
  fill: url(#Degradado_sin_nombre_333);
}

.st7 {
  fill: #d22508;
}

.st8 {
  fill: #548d03;
}

.st9 {
  fill: #147499;
}

.st10 {
  fill: url(#Degradado_sin_nombre_33);
}

.st11 {
  fill: url(#Degradado_sin_nombre_25); 
}

.texto-login {
  position: absolute;
  bottom: 200px;
  left: 50px;
}

.texto-login h2 {
  color: #5ba4cf;
  font-size: 45px;
  margin-bottom: 0;
}

.texto-login h3 {
  color: white;
  margin: -10px 0 15px 0;
  font-size: 40px;
  font-weight: 600;
}

.texto-login p {
  font-size: 18px;
  color: rgba(255, 255, 255, 0.45);
  font-weight: 300;
  margin-bottom: 2rem;
}

.mb30 {
  margin-bottom: 30px;
}

@media only screen and (min-width: 768px) {

} 

