/* Auth pages (login, set/change password). Token-driven so they follow the
   light/dark toggle. */
.auth-card {
    max-width: 380px;
    margin: 60px auto;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 30px 30px 26px 30px;
    color: var(--text);
    font-family: var(--font-sans);
    box-shadow: var(--shadow-lg);
}

.auth-title {
    font-size: 18pt;
    font-weight: 700;
    color: var(--text);
    text-align: center;
    letter-spacing: -0.3px;
}
.auth-sub {
    font-size: 10pt;
    color: var(--text-muted);
    text-align: center;
    margin: 6px 0 18px 0;
}

.auth-form label {
    display: block;
    font-size: 9pt;
    color: var(--text-muted);
    font-weight: 600;
    margin: 12px 0 5px 0;
}
.auth-form input {
    width: 100%;
    box-sizing: border-box;
    background: var(--bg);
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    color: var(--text);
    padding: 10px 12px;
    font-size: 11pt;
    font-family: var(--font-sans);
    transition: border-color var(--transition), box-shadow var(--transition);
}
.auth-form input:focus {
    outline: none;
    border-color: var(--brand);
    box-shadow: var(--ring);
}
.auth-form button {
    width: 100%;
    margin-top: 16px;
    background: var(--brand);
    color: var(--text-inverse);
    border: none;
    border-radius: var(--radius-sm);
    padding: 12px;
    font-size: 11pt;
    font-weight: 600;
    cursor: pointer;
    box-shadow: var(--shadow-sm);
    transition: background var(--transition), transform var(--transition);
}
.auth-form button:hover {
    background: var(--brand-strong);
    transform: translateY(-1px);
}
.auth-form button.secondary {
    background: var(--surface-3);
    color: var(--text);
}
.auth-form button.secondary:hover {
    background: var(--border-strong);
}

.auth-help {
    font-size: 8.5pt;
    color: var(--text-subtle);
    margin-top: 8px;
    text-align: center;
}

.auth-divider {
    margin: 22px 0 6px 0;
    padding-top: 18px;
    border-top: 1px solid var(--border);
    text-align: center;
    font-size: 9pt;
    color: var(--text-muted);
}

.auth-back {
    margin-top: 18px;
    text-align: center;
    font-size: 9pt;
}
.auth-back a {
    color: var(--brand);
    text-decoration: none;
}
.auth-back a:hover {
    color: var(--warn);
}

.auth-card .msg {
    border-radius: var(--radius-sm);
    padding: 10px 12px;
    margin: 0 0 14px 0;
    font-size: 10pt;
}
.auth-card .msg.ok {
    background: var(--success-soft);
    border: 1px solid color-mix(in srgb, var(--success) 45%, transparent);
    color: var(--success);
}
.auth-card .msg.error {
    background: color-mix(in srgb, var(--danger) 14%, transparent);
    border: 1px solid color-mix(in srgb, var(--danger) 45%, transparent);
    color: var(--danger);
}
