﻿/* ============================================================
   _LayoutLogin.css  —  Login / Registration page styles
   Uses shared design tokens from _LayoutThemes.css
   ============================================================ */

/* ── Page scaffold ── */
.login-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: var(--fx-outer-bg);
    font-family: 'Inter', 'Open Sans', Arial, sans-serif;
}

/* ── Card ── */
.login-card {
    width: 100%;
    max-width: 400px;
    background: var(--fx-content-bg);
    border: 1px solid var(--fx-border);
    border-radius: var(--fx-r-lg);
    padding: 40px 36px 36px;
}

/* ── Brand area ── */
.login-brand {
    text-align: center;
    margin-bottom: 15px;
}

    .login-brand img {
        height: 56px;
        margin-bottom: 8px;
    }

.login-brand-name {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: var(--fx-text-muted);
    letter-spacing: 0.4px;
    text-transform: uppercase;
}

/* ── Heading ── */
.login-heading {
    text-align: center;
    font-size: 22px;
    font-weight: 600;
    color: var(--fx-text);
    margin: 0 0 24px;
}

/* ── Form fields ── */
.login-field {
    margin-bottom: 16px;
}

    .login-field label {
        display: block;
        font-size: 13px;
        font-weight: 500;
        color: var(--fx-text-mid);
        margin-bottom: 5px;
    }

    .login-field .form-control {
        width: 100%;
        padding: 10px 12px;
        font-size: 14px;
        font-family: inherit;
        color: var(--fx-text);
        background: var(--fx-white);
        border: 1px solid var(--fx-border);
        border-radius: var(--fx-r);
        outline: none;
        transition: border-color var(--fx-speed);
    }

        .login-field .form-control::placeholder {
            color: var(--fx-text-muted);
        }

        .login-field .form-control:focus {
            border-color: var(--fx-icon);
            box-shadow: none;
        }

    /* ── Validation ── */
    .login-field .field-validation-error {
        display: block;
        font-size: 12px;
        color: #c0392b;
        margin-top: 4px;
        padding: 0;
        background: none;
        border: none;
    }

/* ── Forgot link ── */
.login-forgot {
    text-align: right;
    margin-bottom: 20px;
}

    .login-forgot a {
        font-size: 13px;
        color: var(--fx-text-muted);
        text-decoration: none;
        transition: color var(--fx-speed);
    }

        .login-forgot a:hover {
            color: var(--fx-text);
        }

/* ── Buttons ── */
.login-actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.login-btn-primary {
    display: block;
    width: 100%;
    padding: 10px;
    font-size: 14px;
    font-weight: 600;
    font-family: inherit;
    color: #fff;
    background-color: #5882c1;
    border: 1px solid #4e76b0;
    border-radius: var(--fx-r);
    cursor: pointer;
    transition: background-color var(--fx-speed);
}

    .login-btn-primary:hover {
        background-color: #496b9b;
    }

.login-btn-secondary {
    display: block;
    width: 100%;
    padding: 10px;
    font-size: 14px;
    font-weight: 500;
    font-family: inherit;
    color: var(--fx-text-mid);
    background-color: transparent;
    border: 1px solid var(--fx-border);
    border-radius: var(--fx-r);
    cursor: pointer;
    text-align: center;
    text-decoration: none;
    transition: background-color var(--fx-speed), color var(--fx-speed);
}

    .login-btn-secondary:hover {
        background-color: var(--fx-hover);
        color: var(--fx-text);
    }

/* ── Divider ── */
.login-divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 6px 0;
    color: var(--fx-text-muted);
    font-size: 12px;
}

    .login-divider::before,
    .login-divider::after {
        content: "";
        flex: 1;
        height: 1px;
        background: var(--fx-border);
    }

/* ── Footer text ── */
.login-footer {
    text-align: center;
    margin-top: 24px;
    font-size: 12px;
    color: var(--fx-text-muted);
}

/* ── Alert overrides inside login card ── */
.login-card .alert {
    font-size: 13px;
    border-radius: var(--fx-r);
    margin-bottom: 20px;
}

/* ── Register container (used by Register page) ── */
.register-container {
    position: relative;
    margin: auto;
    margin-top: 5%;
    max-width: 1000px;
}
