:root {
    --vq-forest: #0f3d2e;
    --vq-forest-900: #08281e;
    --vq-teal: #1e6656;
    --vq-sage: #a7bfa1;
    --vq-gold: #d4af37;
    --vq-graphite: #2b2f33;
    --vq-cream: #f7f4ee;
    --vq-mist: #e6ece8;
    --vq-white: #fffdf9;
}

* {
    box-sizing: border-box;
}

body {
    align-items: center;
    background:
        radial-gradient(circle at 86% 18%, rgba(212, 175, 55, 0.16), transparent 28%),
        linear-gradient(135deg, var(--vq-forest-900), var(--vq-forest));
    color: var(--vq-graphite);
    display: flex;
    font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    justify-content: center;
    margin: 0;
    min-height: 100vh;
    padding: 24px;
}

.login-shell {
    background: var(--vq-white);
    border: 1px solid rgba(247, 244, 238, 0.18);
    border-radius: 8px;
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.34);
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(380px, 0.92fr);
    max-width: 1080px;
    min-height: 660px;
    overflow: hidden;
    width: 100%;
}

.login-brand-panel {
    background:
        linear-gradient(180deg, rgba(8, 40, 30, 0.86), rgba(15, 61, 46, 0.96)),
        radial-gradient(circle at 82% 78%, rgba(212, 175, 55, 0.25), transparent 30%);
    color: var(--vq-cream);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 54px;
    position: relative;
}

.login-brand-panel::after {
    border: 42px solid transparent;
    border-top-color: rgba(212, 175, 55, 0.82);
    border-radius: 54% 46% 62% 38%;
    bottom: 54px;
    content: "";
    height: 210px;
    opacity: 0.42;
    position: absolute;
    right: -38px;
    transform: rotate(28deg);
    width: 210px;
}

.login-brand-top,
.login-mobile-brand {
    align-items: center;
    display: flex;
    gap: 12px;
    position: relative;
    z-index: 1;
}

.login-brand-mark {
    align-items: center;
    background: linear-gradient(145deg, var(--vq-forest), var(--vq-teal));
    border: 1px solid rgba(247, 244, 238, 0.22);
    border-radius: 8px;
    color: var(--vq-cream);
    display: inline-flex;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 32px;
    font-weight: 700;
    height: 48px;
    justify-content: center;
    line-height: 1;
    position: relative;
    width: 48px;
}

.login-brand-mark::after {
    background: var(--vq-gold);
    border-radius: 999px;
    content: "";
    height: 8px;
    position: absolute;
    right: 9px;
    top: 10px;
    width: 8px;
}

.login-brand-word {
    color: var(--vq-cream);
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 34px;
    font-weight: 700;
    line-height: 1;
}

.login-brand-content {
    position: relative;
    z-index: 1;
}

.login-eyebrow {
    color: var(--vq-gold);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.18em;
    margin-bottom: 14px;
    text-transform: uppercase;
}

.login-brand-content h1 {
    color: var(--vq-cream);
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 54px;
    font-weight: 700;
    line-height: 0.98;
    margin: 0 0 20px;
    max-width: 520px;
}

.login-brand-content p {
    color: rgba(247, 244, 238, 0.78);
    font-size: 15px;
    line-height: 1.7;
    margin: 0;
    max-width: 440px;
}

.login-principles {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 34px;
}

.login-principles span {
    border: 1px solid rgba(247, 244, 238, 0.18);
    border-radius: 999px;
    color: var(--vq-cream);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.12em;
    padding: 8px 11px;
    text-transform: uppercase;
}

.login-card {
    align-self: center;
    padding: 58px 62px;
}

.login-mobile-brand {
    display: none;
    margin-bottom: 28px;
}

.login-mobile-brand .login-brand-word {
    color: var(--vq-forest);
}

.login-card h2 {
    color: var(--vq-forest);
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 42px;
    font-weight: 700;
    line-height: 1;
    margin: 0 0 6px;
}

.login-subtitle {
    color: #6f7974;
    margin: 0 0 30px;
}

.login-field {
    margin-bottom: 18px;
}

.login-field label {
    color: var(--vq-forest);
    display: block;
    font-size: 13px;
    font-weight: 700;
    margin-bottom: 7px;
}

.login-input-wrap {
    position: relative;
}

.login-input-wrap > i {
    color: var(--vq-sage);
    left: 14px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}

.login-input-wrap input {
    background: var(--vq-white);
    border: 1px solid rgba(15, 61, 46, 0.16);
    border-radius: 8px;
    color: var(--vq-graphite);
    height: 48px;
    padding: 0 44px;
    transition: border-color 0.18s ease, box-shadow 0.18s ease;
    width: 100%;
}

.login-input-wrap input:focus {
    border-color: var(--vq-teal);
    box-shadow: 0 0 0 3px rgba(167, 191, 161, 0.36);
    outline: none;
}

.login-toggle {
    align-items: center;
    background: transparent;
    border: 0;
    color: #7a8580;
    display: inline-flex;
    height: 48px;
    justify-content: center;
    position: absolute;
    right: 0;
    top: 0;
    width: 44px;
}

.login-forgot {
    color: var(--vq-teal);
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
}

.login-forgot:hover {
    color: var(--vq-forest);
}

.btn-login {
    align-items: center;
    background: linear-gradient(135deg, var(--vq-forest), var(--vq-teal));
    border: none;
    border-radius: 8px;
    color: var(--vq-cream);
    display: inline-flex;
    font-weight: 800;
    height: 48px;
    justify-content: center;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
    width: 100%;
}

.btn-login:hover {
    box-shadow: 0 12px 24px rgba(15, 61, 46, 0.22);
    transform: translateY(-1px);
}

.btn-login.loading {
    opacity: 0.76;
    pointer-events: none;
}

.login-spinner {
    animation: login-spin 1s linear infinite;
    border: 2px solid rgba(247, 244, 238, 0.8);
    border-radius: 50%;
    border-top-color: transparent;
    display: inline-block;
    height: 18px;
    width: 18px;
}

.login-error {
    background: #f8e2dc;
    border-left: 3px solid #a33a2f;
    color: #812b23;
    font-size: 13px;
    margin-bottom: 16px;
    padding: 10px 12px;
}

@keyframes login-spin {
    to {
        transform: rotate(360deg);
    }
}

@media (max-width: 900px) {
    .login-shell {
        grid-template-columns: minmax(0, 1fr);
        max-width: 520px;
        min-height: auto;
    }

    .login-brand-panel {
        display: none;
    }

    .login-card {
        padding: 38px 30px;
    }

    .login-mobile-brand {
        display: flex;
    }
}
