body.login-body {

    margin: 0;

    font-family: 'Segoe UI', sans-serif;

    min-height: 100vh;

    overflow-x: hidden;

    overflow-y: auto;
}

/* 🔥 FONDO CON IMAGEN */
body.login-body::before {

    content: "";

    position: fixed;

    top: 0;
    left: 0;

    width: 100%;

    height: 100%;

    background:
        url('/images/bg-tienda.png')
        no-repeat
        center
        center/cover;

    filter: blur(8px) brightness(0.6);

    z-index: -1;
}

/* 🔥 CONTENEDOR */
.login-container {

    display: flex;

    justify-content: center;

    align-items: center;

    min-height: 100vh;

    padding: 20px;

    box-sizing: border-box;
}

/* 🔥 CARD GLASS */
.login-card {

    background: rgba(255, 255, 255, 0.85);

    backdrop-filter: blur(10px);

    border-radius: 20px;

    padding: 40px;

    width: 100%;

    max-width: 360px;

    text-align: center;

    color: #333;

    box-shadow:
        0 10px 40px rgba(0,0,0,0.4);

    border:
        1px solid rgba(255,255,255,0.3);

    box-sizing: border-box;

    animation: aparecer .4s ease;
}

/* 🔥 LOGO */
.logo {

    width: 200px;

    max-width: 100%;

    margin-bottom: 15px;
}

/* 🔥 TITULO */
.login-card h2 {

    margin-bottom: 10px;

    font-size: 32px;

    color: #222;
}

/* 🔥 INPUTS */
.input {

    width: 100%;

    padding: 12px;

    margin: 10px 0;

    border-radius: 10px;

    border: 1px solid #ccc;

    outline: none;

    background: #ffffff;

    color: #333;

    transition: 0.3s;

    box-sizing: border-box;

    font-size: 15px;
}

.input:focus {

    border-color: #ff9800;

    box-shadow:
        0 0 10px rgba(255,152,0,.3);
}

.input::placeholder {

    color: #888;
}

/* 🔥 OPCIONES */
.options {

    display: flex;

    justify-content: space-between;

    align-items: center;

    font-size: 12px;

    margin-bottom: 15px;

    color: #444;
}

/* 🔥 BOTÓN */
.btn-login {

    width: 100%;

    padding: 12px;

    border: none;

    background:
        linear-gradient(
            90deg,
            #ff3c3c,
            #ff9800
        );

    color: white;

    border-radius: 10px;

    font-size: 16px;

    font-weight: bold;

    cursor: pointer;

    transition: 0.3s;
}

.btn-login:hover {

    transform: scale(1.03);

    box-shadow:
        0 0 15px rgba(255,100,0,0.7);
}

/* 🔥 TEXTOS */
.subtitle {

    color: #978c8c;

    font-size: 14px;

    margin-bottom: 25px;
}

.footer {

    margin-top: 15px;

    font-size: 12px;

    color: #756d6d;
}

/* 🔥 ERROR */
.error {

    color: red;

    margin-top: 15px;

    font-weight: bold;

    text-align: center;
}

/* 🔥 ANIMACION */
@keyframes aparecer {

    from {

        opacity: 0;

        transform: translateY(20px);
    }

    to {

        opacity: 1;

        transform: translateY(0);
    }
}

/* 📱 TABLETS */
@media (max-width: 768px) {

    .login-card {

        padding: 35px 25px;
    }

    .logo {

        width: 170px;
    }

    .login-card h2 {

        font-size: 28px;
    }
}

/* 📱 CELULARES */
@media (max-width: 576px) {

    .login-container {

        padding: 15px;
    }

    .login-card {

        padding: 30px 20px;

        border-radius: 18px;
    }

    .logo {

        width: 140px;
    }

    .login-card h2 {

        font-size: 24px;
    }

    .subtitle {

        font-size: 13px;
    }

    .input {

        padding: 11px;

        font-size: 14px;
    }

    .btn-login {

        padding: 12px;

        font-size: 15px;
    }

    .options {

        font-size: 11px;
    }

    .footer {

        font-size: 11px;
    }
}