/* MonitorDevs - Login personalizado */
body {
  background: #0b3d5c !important;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
body:before {
  content: "";
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(0,163,224,0.15) 0%, transparent 60%);
  pointer-events: none;
}
/* Layout contenido login (solo página de login) */
.task-login #layout-content {
  background: #0a3a55 !important;
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
  padding: 28px 36px 20px !important;
  max-width: 400px !important;
  width: 100% !important;
  margin: 20px auto !important;
  position: relative;
  border: 1px solid rgba(255,255,255,0.06);
}
#logo {
  display: block !important;
  max-width: 130px !important;
  height: auto !important;
  margin: 0 auto 20px auto !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  top: 6vh !important;
}
#brand-header {
  text-align: center;
  margin-bottom: 16px;
  margin-top: 40px;
  line-height: 1.3;
}
.brand-name {
  display: block;
  font-family: "Segoe UI", Arial, sans-serif;
  font-size: 30px;
  font-weight: 600;
  color: #ffffff;
  letter-spacing: 0.5px;
}
.brand-sub {
  display: block;
  font-family: "Segoe UI", Arial, sans-serif;
  font-size: 18px;
  font-weight: 300;
  color: rgba(255,255,255,0.6);
  letter-spacing: 2px;
  text-transform: uppercase;
}
/* OCULTAR LABELS EXTERNOS (Usuario / Contraseña) */
#login-form td.title,
#login-form td.title label {
  display: none !important;
  visibility: hidden !important;
  position: fixed !important;
  left: -9999px !important;
  width: 0 !important;
  height: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
/* OCULTAR ICONOS INPUT-GROUP-TEXT (Roundcube nativos) */
.task-login .input-group-text,
.task-login .input-group-text.icon,
.task-login i.icon.user,
.task-login i.icon.pass,
.login-form .input-group-text,
#login-form .input-group-text {
  display: none !important;
}
/* OCULTAR ICONOS user/pass de la fuente Icons */
.icon.user:before,
.icon.pass:before,
.input-group-text.icon.user:before,
.input-group-text.icon.pass:before {
  display: none !important;
  content: none !important;
}
#login-form table { width: 100%; }
#login-form { top: 10vh !important; }
#login-form td { display: block; padding: 0; margin: 0; }
/* Input usuario con icono */
#login-form input[id="rcmloginuser"] {
  width: 100% !important;
  padding: 11px 14px 11px 36px !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  border-radius: 10px !important;
  font-size: 14px !important;
  color: #ffffff !important;
  transition: all 0.2s ease !important;
  box-sizing: border-box !important;
  margin-bottom: 8px !important;
  background: rgba(255,255,255,0.08) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' opacity='0.5'%3E%3Cpath d='M20 21v-2a4 4 0 0 0-4-4H8a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E") 8px 50% no-repeat !important;
  background-size: 18px 18px !important;
}
/* Input contraseña con icono */
#login-form input[id="rcmloginpwd"] {
  width: 100% !important;
  padding: 11px 14px 11px 36px !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  border-radius: 10px !important;
  font-size: 14px !important;
  color: #ffffff !important;
  transition: all 0.2s ease !important;
  box-sizing: border-box !important;
  margin-bottom: 8px !important;
  background: rgba(255,255,255,0.08) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' opacity='0.5'%3E%3Crect x='3' y='11' width='18' height='11' rx='2' ry='2'/%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'/%3E%3C/svg%3E") 8px 50% no-repeat !important;
  background-size: 18px 18px !important;
}
#login-form input::placeholder { color: rgba(255,255,255,0.4) !important; }
#login-form input[type="text"]:focus,
#login-form input[type="password"]:focus {
  border-color: #00a3e0 !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(0,163,224,0.2) !important;
}
#login-form input[type="submit"] {
  width: 100% !important;
  padding: 12px !important;
  background: linear-gradient(135deg, #0055a5, #00a3e0) !important;
  color: white !important;
  border: none !important;
  border-radius: 10px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: transform 0.2s, box-shadow 0.2s !important;
  margin-top: 2px !important;
}
#login-form input[type="submit"]:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(0,85,165,0.4);
}
#login-form input[type="submit"]:active { transform: translateY(0); }
#login-footer {
  text-align: center;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.footer-brand {
  font-size: 11px;
  color: rgba(255,255,255,0.3);
  margin: 0;
  font-family: "Segoe UI", Arial, sans-serif;
}
/* Mensaje de error */
#login-form .message, div.warning {
  background: rgba(255,193,7,0.1);
  border: 1px solid rgba(255,193,7,0.2);
  color: #ffc107;
  border-radius: 10px;
  padding: 8px 12px;
  font-size: 13px;
  margin-bottom: 8px;
}/* Fix: input 2FA code a 100% de ancho */
input#2FA_code {
  width: 100% !important;
  box-sizing: border-box !important;
}
/* Toda la fila del input 2FA también */
td:has(input#2FA_code) {
  width: 100% !important;
}

/* ===== Fix: input 2FA code al 100% de ancho ===== */
.task-login td.input-group.input-group-lg input#2FA_code.form-control {
  width: 100% !important;
  flex: 1 1 100% !important;
  -ms-flex: 1 1 100% !important;
  box-sizing: border-box !important;
}
.task-login td.input-group.input-group-lg {
  width: 100% !important;
  display: flex !important;
}
