/*
 * Page: login
 * Centered card on a minimal full-viewport background.
 */

.login-shell {
    min-height: 100dvh;
    display: grid;
    place-items: center;
    padding: var(--space-6);
    background: linear-gradient(
        180deg,
        color-mix(in oklch, var(--color-background) 100%, transparent),
        color-mix(in oklch, var(--color-muted) 40%, var(--color-background))
    );
}

.login-card {
    width: 100%;
    max-width: 24rem;
}

.login-brand {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    justify-content: center;
    margin-bottom: var(--space-6);
    font-weight: 600;
    letter-spacing: var(--tracking-tight);
    color: var(--color-foreground);
}

.login-brand-mark {
    width: var(--space-10);
    height: var(--space-10);
    border-radius: var(--radius-md);
    background-color: var(--color-primary);
    color: var(--color-primary-foreground);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
}

.login-footer-hint {
    margin-top: var(--space-4);
    font-size: var(--text-xs);
    text-align: center;
    color: var(--color-muted-foreground);
}

/* Theme toggle on login (top-right corner of viewport) */
.login-theme-toggle {
    position: absolute;
    top: var(--space-4);
    right: var(--space-4);
}
