/**
 * Panel Login Page Styles
 * Split layout: background image left, white card right
 */

:root {
    --login-bg: #f5eeef;
    --login-primary: #c4a4a4;
    --login-primary-dark: #a88a8a;
    --login-accent: #d4a5a5;
    --login-white: #ffffff;
    --login-text: #5a4a50;
    --login-text-light: #9a8a90;
    --login-border: #e8dde0;
    --login-pink-light: #f8e8ea;
    --login-font-serif: 'Playfair Display', Georgia, serif;
    --login-font-sans: 'Source Sans 3', -apple-system, BlinkMacSystemFont, sans-serif;
}

.login-page,
.login-page * {
    box-sizing: border-box;
}

body {
    font-family: var(--login-font-sans);
    background: var(--login-bg);
    min-height: 100vh;
    color: var(--login-text);
    line-height: 1.5;
}

/* ─── Full-page background layout ─── */
.login-page {
    min-height: 100vh;
    padding-top: 4.5rem;
    background: url("../../images/panel/login-bg-JyJ2ClR.png") center center / cover no-repeat;
    background-color: var(--login-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    padding-left: 30%;
}

/* ─── Card wrapper ─── */
.login-card-wrap {
    width: 520px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
}

/* ─── White card ─── */
.login-card {
    width: 100%;
    max-width: 400px;
    background: var(--login-white);
    border-radius: 20px;
    padding: 2.5rem 2.25rem;
    box-shadow: 0 8px 40px rgba(90, 74, 80, 0.08);
}

.login-card__logo {
    display: flex;
    justify-content: center;
    margin-bottom: 1.75rem;
}

.login-card__logo img {
    height: 42px;
    width: auto;
}

.login-card__title {
    font-family: var(--login-font-serif);
    font-size: 1.6rem;
    font-weight: 500;
    color: var(--login-text);
    text-align: center;
    margin: 0 0 0.2rem;
}

.login-card__subtitle {
    font-size: 0.9rem;
    color: var(--login-text-light);
    text-align: center;
    margin: 0 0 1.75rem;
}

.login-card__error {
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: #dc2626;
    padding: 0.75rem 1rem;
    border-radius: 8px;
    font-size: 0.875rem;
    text-align: center;
    margin-bottom: 1rem;
}

.login-card__success {
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    color: #16a34a;
    padding: 0.75rem 1rem;
    border-radius: 8px;
    font-size: 0.875rem;
    text-align: center;
    margin-bottom: 1rem;
}

/* ─── Form ─── */
.login-form {
    display: flex;
    flex-direction: column;
    gap: 1.15rem;
}

.login-form__group {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.login-form__group label {
    font-size: 0.7rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    color: var(--login-text-light);
    text-transform: uppercase;
}

.login-form__input-wrap {
    position: relative;
    display: flex;
    align-items: center;
}

.login-form__icon {
    position: absolute;
    left: 1rem;
    width: 18px;
    height: 18px;
    color: var(--login-text-light);
    pointer-events: none;
}

.login-form__input-wrap input {
    width: 100%;
    padding: 0.85rem 1rem 0.85rem 2.85rem;
    font-family: var(--login-font-sans);
    font-size: 0.95rem;
    color: var(--login-text);
    background: var(--login-pink-light);
    border: 1px solid transparent;
    border-radius: 8px;
    transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}

.login-form__input-wrap input::placeholder {
    color: var(--login-text-light);
}

.login-form__input-wrap input:focus {
    outline: none;
    background: var(--login-white);
    border-color: var(--login-accent);
    box-shadow: 0 0 0 3px rgba(212, 165, 165, 0.15);
}

.login-form__forgot {
    font-size: 0.85rem;
    color: var(--login-accent);
    text-decoration: none;
    transition: color 0.2s;
    margin-top: -0.35rem;
}

.login-form__forgot:hover {
    color: var(--login-primary-dark);
}

.login-form__submit {
    width: 100%;
    padding: 0.9rem;
    font-family: var(--login-font-sans);
    font-size: 1rem;
    font-weight: 600;
    color: var(--login-white);
    background: var(--login-accent);
    border: none;
    border-radius: 50px;
    cursor: pointer;
    transition: background 0.2s, transform 0.15s, box-shadow 0.2s;
    margin-top: 0.25rem;
}

.login-form__submit:hover {
    background: var(--login-primary-dark);
    transform: translateY(-1px);
    box-shadow: 0 4px 16px rgba(196, 164, 164, 0.35);
}

.login-form__submit:active {
    transform: translateY(0);
}

/* ─── Divider ─── */
.login-card__divider {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin: 1.5rem 0 1.25rem;
}

.login-card__divider::before,
.login-card__divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--login-border);
}

.login-card__divider span {
    font-size: 0.8rem;
    color: var(--login-text-light);
    white-space: nowrap;
}

/* ─── Register CTA ─── */
.login-card__no-account {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--login-text);
    text-align: center;
    margin: 0 0 0.75rem;
}

.login-card__register {
    display: block;
    width: 100%;
    padding: 0.8rem;
    font-family: var(--login-font-sans);
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--login-accent);
    text-align: center;
    text-decoration: none;
    border: 1.5px solid var(--login-border);
    border-radius: 50px;
    transition: border-color 0.2s, color 0.2s, background 0.2s;
}

.login-card__register:hover {
    border-color: var(--login-accent);
    color: var(--login-primary-dark);
    background: var(--login-pink-light);
}

/* ─── Responsive: tablet ─── */
@media (max-width: 1024px) {
    .login-card-wrap {
        width: 460px;
        padding: 2rem;
    }
}

/* ─── Responsive: mobile ─── */
@media (max-width: 768px) {
    .login-page {
        justify-content: center;
        padding: 5rem 1rem 2rem;
        background-position: center top;
    }

    .login-card-wrap {
        width: 100%;
        max-width: 420px;
        padding: 0;
    }

    .login-card {
        padding: 2rem 1.5rem;
        border-radius: 18px;
    }
}

@media (max-width: 480px) {
    .login-page {
        padding: 5rem 0.75rem 1.5rem;
    }

    .login-card {
        padding: 1.75rem 1.25rem;
    }

    .login-card__title {
        font-size: 1.4rem;
    }

    .login-card__logo img {
        height: 36px;
    }
}
