body.login-body {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
}

.login-card {
    background: var(--card);
    width: 100%;
    max-width: 380px;
    padding: 2.75rem 2.5rem;
    border-radius: 16px;
    box-shadow: 0 12px 36px 0 rgba(44, 32, 83, .06);
    text-align: center;
}

.login-logo { width: 60px; height: 60px; margin: 0 auto 1.25rem; display: block; }
.login-tagline { font-weight: 700; font-size: 12px; letter-spacing: 1px; text-transform: uppercase; color: var(--wine); margin: 0 0 1.25rem; }

.login-card h1 { font-weight: 1000; font-size: 28px; margin: 0 0 .5rem; }
.login-card .muted { font-size: 16px; margin: 0 0 1.75rem; line-height: 1.5; }

.btn-google {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .7rem;
    width: 100%;
    background: #fff;
    border: 1px solid var(--border);
    color: var(--ink);
    font-family: inherit;
    font-weight: 700;
    font-size: 15px;
    padding: .8rem 1.1rem;
    border-radius: 10px;
    text-decoration: none;
    transition: border-color .15s, box-shadow .15s;
}
.btn-google:hover { border-color: var(--lime); box-shadow: 0 8px 20px 0 rgba(44, 32, 83, .04); }

.login-card .footnote { margin-top: 1.5rem; }
