.c-auth-page {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px 20px;
    overflow: auto;
}

.c-auth-card {
    width: min(100%, 420px);
    background: var(--color-surface-primary);
    border: 1px solid var(--color-border-primary);
    border-radius: 16px;
    padding: 24px;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);
}

.c-auth-card__eyebrow {
    margin: 0 0 8px;
    color: var(--color-brand-primary);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.c-auth-card__title {
    margin: 0;
    color: var(--color-text-primary);
    font-family: "Radio Canada", "Poppins", sans-serif;
    font-size: 28px;
    line-height: 1.1;
}

.c-auth-card__description {
    margin: 12px 0 0;
    color: var(--color-text-secondary);
    font-size: 14px;
    line-height: 1.6;
}

.c-auth-form {
    display: grid;
    gap: 16px;
    margin-top: 24px;
}

.c-auth-form__field {
    display: grid;
    gap: 8px;
}

.c-auth-form__label {
    color: var(--color-text-primary);
    font-size: 13px;
    font-weight: 600;
}

.c-auth-form__input {
    width: 100%;
    min-height: 44px;
    border: 1px solid var(--color-border-primary);
    border-radius: 10px;
    padding: 0 14px;
    color: var(--color-text-primary);
    background: var(--color-surface-primary);
    font: inherit;
    font-size: 14px;
}

.c-auth-form__input:focus-visible {
    outline: 2px solid var(--color-brand-primary);
    outline-offset: 2px;
}

.c-auth-form__submit {
    min-height: 44px;
    border: 0;
    border-radius: 10px;
    background: var(--color-brand-primary);
    color: var(--color-surface-primary);
    font: inherit;
    font-weight: 600;
    cursor: pointer;
}

.c-auth-form__errors,
.c-auth-form__non-field-errors {
    margin: 0;
    padding-left: 18px;
    color: #b42318;
    font-size: 13px;
}

.c-auth-form__help {
    margin: 0;
    color: var(--color-text-secondary);
    font-size: 12px;
    line-height: 1.5;
}

@media (max-width: 768px) {
    .c-auth-page {
        padding:
            max(16px, env(safe-area-inset-top))
            16px
            max(16px, env(safe-area-inset-bottom));
    }

    .c-auth-card {
        padding: 20px;
    }
}
