/* =========================
   LOGIN PAGE
========================= */

.login-page {
    min-height: calc(100vh - 400px);
    display: flex;
    justify-content: center;   
    align-items: flex-start;   
    padding-top: 2rem;         
    padding-left: 1rem;
    padding-right: 1rem;
}

.login-card {
    width: 100%;
    max-width: 420px;
    background: var(--card-bg);
    border: 1px solid rgba(31, 45, 43, 0.12);
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0,0,0,0.08);
}

.login-header {
    background: linear-gradient(0deg, var(--green-dark), var(--green-main));
    color: var(--text-light);
    padding: 1rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.login-logo {
    height: 40px;
    width: auto;
}

.login-title {
    font-weight: 700;
    font-size: 1.05rem;
    line-height: 1.2;
}

.login-subtitle {
    font-size: 0.85rem;
    opacity: 0.9;
}

.login-body {
    padding: 1rem;
}

/* Inputs grandes y legibles */
.login-card .form-control {
    min-height: 46px;
    font-size: 1rem;
    border-radius: 10px;
    border-color: rgba(31, 45, 43, 0.18);
}

.login-card label {
    font-weight: 600;
    font-size: 0.9rem;
}

/* Botón principal */
.btn-login {
    background: var(--green-main);
    border: 1px solid var(--green-dark);
    color: var(--text-light);
    min-height: 46px;
    border-radius: 10px;
    font-weight: 700;
}

.btn-login:hover {
    background: var(--green-dark);
    color: var(--text-light);
}
