        /* Variables tomadas del estilo de registro */
        :root {
            --color-white: #ffffff;
            --color-text-main: #34495e;
            /* Texto principal oscuro */
            --color-text-sub: #7f8c8d;
            /* Texto secundario gris */
            --color-blue-link: #007bff;
            /* Azul de enlaces y acciones */
            --color-teal: #00a896;
            /* Azul/verde del logo */
            --color-card-bg: #ffffff;
            --color-border: #e0e0e0;
            --color-button-blue: #3498db;
            /* Azul del botón registrarse */
            --color-button-blue-hover: #2980b9;
        }

        body {
            font-family: 'Inter', sans-serif;
            margin: 0;
            padding: 0;
            background-color: #f0f2f5;
            /* Fondo más claro similar a la imagen */
            display: flex;
            justify-content: center;
            align-items: center;
            min-height: 100vh;
        }

        /* Contenedor principal del formulario */
        .login-container {
            background-color: var(--color-card-bg);
            border-radius: 8px;
            /* Sombra similar a la imagen */
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
            padding: 30px 40px;
            /* Ajuste del padding */
            width: 100%;
            max-width: 450px;
            /* Ancho máximo similar a la imagen */
            text-align: center;
        }

        /* Logo CreditLink */
        .logo-div {
            display: flex;
            align-items: center;
            justify-content: center;
            /* Centrar el logo */
            color: var(--color-text-main);
            font-size: 1.1rem;
            font-weight: 600;
            margin-bottom: 25px;
            /* Espacio debajo del logo */
        }

        .logo-icon {
            width: 18px;
            height: 18px;
            margin-right: 8px;
            display: inline-grid;
            grid-template-columns: 1fr 1fr;
            gap: 1.5px;
        }

        .logo-icon>div {
            background-color: var(--color-teal);
            border-radius: 2px;
        }

        /* Títulos y subtítulos */
        .login-container h2 {
            font-size: 1.7rem;
            /* Tamaño de fuente del título */
            font-weight: 700;
            color: var(--color-text-main);
            margin-bottom: 8px;
        }

        .login-container p {
            font-size: 0.95rem;
            color: var(--color-text-sub);
            margin-bottom: 30px;
            /* Espacio debajo del subtítulo */
            line-height: 1.4;
        }

        .inputs-box {

            width: 89%;
            margin: auto;
        }

        /* Grupos de formulario */
        .form-group {
            margin-bottom: 18px;
            /* Espacio entre campos */
            text-align: left;
            /* Alineación del texto a la izquierda */
        }

        .form-group input {
            width: 100%;
            padding: 12px 15px;
            /* Más padding para que coincida con la imagen */
            border: 1px solid var(--color-border);
            border-radius: 5px;
            /* Bordes ligeramente más suaves */
            box-sizing: border-box;
            font-size: 0.95rem;
            color: var(--color-text-main);
            transition: border-color 0.2s, box-shadow 0.2s;
            background-color: var(--color-white);
            /* Fondo blanco para inputs */
        }

        .form-group input:focus {
            border-color: var(--color-blue-link);
            /* Azul más brillante al enfocar */
            outline: none;
            box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.25);
        }

        /* Enlace de Olvidó Contraseña */
        .forgot-password-link {
            text-align: right;
            /* Alinear a la derecha */
            margin-bottom: 25px;
            font-size: 0.9rem;
        }

        .forgot-password-link a {
            color: var(--color-blue-link);
            text-decoration: none;
            font-weight: 500;
            transition: color 0.2s;
            display: none;
        }

        .forgot-password-link a:hover {
            text-decoration: underline;
        }


        /* Botón de Login */
        .login-button {
            width: 89%;
            padding: 11px 20px;
            background-color: var(--color-button-blue);
            color: var(--color-white);
            border: none;
            border-radius: 5px;
            font-size: 1.05rem;
            font-weight: 600;
            cursor: pointer;
            transition: background-color 0.2s, transform 0.1s, box-shadow 0.2s;
            box-shadow: 0 2px 8px rgba(0, 123, 255, 0.2);
        }

        .login-button:hover {
            background-color: var(--color-button-blue-hover);
            transform: translateY(-1px);
            box-shadow: 0 4px 10px rgba(0, 123, 255, 0.3);
        }

        .login-button:active {
            transform: translateY(0);
        }

        /* Enlace de Registro */
        .register-link {
            display: block;
            margin-top: 25px;
            font-size: 0.9rem;
            color: var(--color-text-sub);
        }

        .register-link a {
            color: var(--color-blue-link);
            text-decoration: none;
            font-weight: 500;
        }

        .register-link a:hover {
            text-decoration: underline;
        }

        /* Contenedor de mensajes (reemplazo de alert) */
        #message-box {
            margin-top: 25px;
            padding: 10px;
            border-radius: 5px;
            font-size: 0.9rem;
            font-weight: 500;
            opacity: 0;
            transition: opacity 0.3s ease-in-out;
            pointer-events: none;
        }

        #message-box.visible {
            opacity: 1;
            pointer-events: auto;
        }

        #message-box.error {
            background-color: #f8d7da;
            color: #721c24;
            border: 1px solid #f5c6cb;
        }

        #message-box.success {
            background-color: #d4edda;
            color: #155724;
            border: 1px solid #c3e6cb;
        }