﻿/* ---------- Unified Auth pages styles (Login, Register, Forgot/Reset) ---------- */

/* top-level wrapper that centers content */
.auth-page {
    display: flex;
    justify-content: center;
    padding: 36px 18px;
    background: #fafafa;
}

/* container that holds visual + form columns */
.auth-card-wrap {
    display: grid;
    grid-template-columns: 460px 1fr;
    gap: 28px;
    align-items: start;
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
}

/* visual column (logo/hero) */
.auth-side-visual {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 26px;
}

.auth-visual-inner {
    background: linear-gradient(180deg, rgba(255,255,255,0.9), #fff);
    border-radius: 10px;
    padding: 26px;
    box-shadow: 0 18px 44px rgba(11,77,120,0.04);
    text-align: center;
}

    .auth-visual-inner img {
        max-width: 260px;
        height: auto;
        display: block;
        margin: 0 auto 12px;
    }

/* right column: card containing the form */
.auth-side-form {
    display: flex;
    align-items: flex-start;
    padding: 10px 0;
}

.auth-card {
    width: 100%;
    max-width: 540px;
    padding: 26px 28px;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 10px 30px rgba(12,35,60,0.04);
}

/* Common title & paragraph */
.auth-title {
    margin: 0 0 12px;
    color: #0b577f;
    font-size: 1.25rem;
    font-weight: 700;
}

.auth-sub {
    color: #6b7a86;
    margin-top: 8px;
}

/* form controls uniform */
.form-group {
    margin-bottom: 16px;
}

.form-label {
    display: block;
    margin-bottom: 6px;
    color: #2a3f50;
    font-weight: 600;
}

.form-control {
    width: 100%;
    padding: 12px 14px;
    border-radius: 8px;
    border: 1px solid #e6eef5;
    background: #f8fbfd;
    font-size: 0.98rem;
}

    .form-control:focus {
        border-color: #1f7fbf;
        outline: none;
        box-shadow: 0 10px 24px rgba(31,127,191,0.08);
    }

/* error & help text */
.text-danger {
    color: #c33;
    font-size: .94rem;
    margin-top: 6px;
    display: block;
}

.auth-help {
    color: #8b98a6;
    font-size: .9rem;
    margin-top: 6px;
    display: block;
}

/* Confirm / success panels */
.auth-success {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 28px;
    gap: 10px;
}

    .auth-success .title {
        font-size: 1.15rem;
        font-weight: 700;
        color: #155724;
    }

    .auth-success .desc {
        color: #2e6b3d;
    }

/* Primary button reuse (same as earlier) */
.btn-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 20px;
    border-radius: 10px;
    background: linear-gradient(180deg, #0f7fcf 0%, #0a5f9a 100%);
    color: #fff;
    font-weight: 700;
    font-size: 1rem;
    border: 0;
    box-shadow: 0 10px 22px rgba(10,95,154,0.14), 0 3px 6px rgba(10,95,154,0.06);
    transition: transform .08s ease, box-shadow .08s ease;
    cursor: pointer;
    text-decoration: none;
}

    .btn-primary:hover {
        transform: translateY(-2px);
    }

/* Secondary link button */
.auth-card .small-link {
    color: #0f7fcf;
    text-decoration: none;
    font-weight: 600;
}

/* Form-actions spacing */
.form-actions {
    display: flex;
    gap: 12px;
    align-items: center;
    margin-top: 12px;
}

/* Small screens: stack columns and full-width */
@media (max-width: 900px) {
    .auth-card-wrap {
        grid-template-columns: 1fr;
        padding: 0 12px;
    }

    .auth-side-visual {
        order: 1;
        padding: 12px;
    }

    .auth-side-form {
        order: 2;
        padding: 12px 0;
    }

    .auth-card {
        padding: 20px;
    }

    .btn-primary {
        width: 100%;
    }
}

/* Small adjustments for confirmation/links */
.confirm-actions {
    margin-top: 18px;
    display: flex;
    gap: 12px;
    justify-content: center;
}
