body {
    font-family: 'Inter', sans-serif;
    /* Light sea blue background color */
    background-color: #E6F3FC;
    /* Geometric temple pattern with brand-light tint */
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='152' height='152' viewBox='0 0 152 152'%3E%3Cg fill-rule='evenodd'%3E%3Cg id='temple' fill='%2347AFEF' fill-opacity='0.15'%3E%3Cpath d='M152 150v2H0v-2h28v-8H8v-20H0v-2h8V80h42v20h20v42H30v8h90v-8H80v-42h20V80h42v40h8V30h-8v40h-42V50H80V8h40V0h2v8h20v20h8V0h2v150zm-2 0v-28h-8v20h-20v8h28zM82 30v18h18V30H82zm20 18h20v20h18V30h-20V10H82v18h20v20zm0 2v18h18V50h-18zm20-22h18V10h-18v18zm-54 92v-18H50v18h18zm-20-18H28V82H10v38h20v20h38v-18H48v-20zm0-2V82H30v18h18zm-20 22H10v18h18v-18zm54 0v18h38v-20h20V82h-18v20h-20v20H82zm18-20H82v18h18v-18zm2-2h18V82h-18v18zm20 40v-18h18v18h-18zM30 0h-2v8H8v20H0v2h8v40h42V50h20V8H30V0zm20 48h18V30H50v18zm18-20H48v20H28v20H10V30h20V10h38v18zM30 50h18v18H30V50zm-2-40H10v18h18V10z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    margin: 0;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1rem;
}

.main-card {
    background-color: #ffffff;
    border-radius: 0;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
    max-width: 1100px;
    width: 100%;
    overflow: hidden;
    display: flex;
}

/* Left Image Panel */
.image-panel {
    padding: 1.5rem;
    flex: 1;
    display: none;
}

@media (min-width: 992px) {
    .image-panel {
        display: flex;
    }
}

.image-wrapper {
    width: 100%;
    height: 100%;
    border-radius: 0;
    overflow: hidden;
    background-color: #f3f4f6; /* Placeholder color before image loads */
    position: relative;
}

.image-wrapper::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /* Sea blue overlay blending the dark and light brand colors */
    background: linear-gradient(135deg, rgba(4, 18, 102, 0.6) 0%, rgba(71, 175, 239, 0.5) 100%);
    mix-blend-mode: multiply;
    pointer-events: none;
}

.image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    min-height: 650px;
    display: block;
}

/* Right Form Panel */
.form-panel {
    flex: 1;
    padding: 3rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

@media (min-width: 992px) {
    .form-panel {
        padding: 4rem 5rem 4rem 3rem;
    }
}

.auth-logo {
    text-align: center;
    margin-bottom: 2rem;
}

.auth-logo img {
    max-height: 80px;
    width: auto;
}

.auth-title {
    text-align: center;
    color: #111827;
    font-weight: 700;
    font-size: 1.75rem;
    margin-bottom: 0.5rem;
}

.auth-subtitle {
    text-align: center;
    color: #6b7280;
    font-size: 0.9rem;
    margin-bottom: 2.5rem;
}

.form-label {
    font-size: 0.85rem;
    color: #4b5563;
    font-weight: 500;
    margin-bottom: 0.5rem;
}

.forgot-password {
    font-size: 0.85rem;
    color: var(--brand-dark);
    text-decoration: none;
    font-weight: 600;
    text-decoration: underline;
}

.forgot-password:hover {
    color: var(--brand-light);
}
