/* KleurKompas — auth pagina's */

.auth-section {
    padding-top: var(--space-2xl);
}

.auth-card-wrap {
    max-width: 28rem;
    margin-inline: auto;
}

.auth-card {
    padding: var(--space-xl);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}

.auth-title {
    margin: 0 0 var(--space-sm);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    letter-spacing: -0.02em;
}

.auth-intro {
    margin: 0 0 var(--space-lg);
    font-size: 0.9375rem;
    color: var(--color-text-muted);
    line-height: 1.55;
}

.auth-actions {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.auth-actions .auth-submit {
    width: 100%;
    text-align: center;
}

.auth-flashes {
    margin: 0 0 var(--space-md);
    padding: 0;
    list-style: none;
}

.auth-flashes .feedback {
    margin-bottom: var(--space-sm);
}

.feedback {
    padding: var(--space-md);
    border-radius: var(--radius-md);
    font-size: 0.9375rem;
}

.auth-form .form-group {
    margin-bottom: var(--space-md);
}

.auth-form label {
    display: block;
    margin-bottom: var(--space-xs);
    font-size: 0.9375rem;
    font-weight: 600;
}

.auth-form input[type="text"],
.auth-form input[type="email"],
.auth-form input[type="password"] {
    display: block;
    width: 100%;
    padding: 0.65rem 0.75rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font: inherit;
    background-color: var(--color-background);
    color: var(--color-text);
    box-shadow: inset 0 1px 2px rgba(37, 37, 37, 0.05);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.auth-form input::placeholder {
    color: var(--color-text-muted);
}

.auth-form input:hover {
    border-color: color-mix(in srgb, var(--color-border) 55%, var(--color-text-muted));
}

.auth-form input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 20%, transparent);
}

.form-hint {
    margin: var(--space-xs) 0 0;
    font-size: 0.8125rem;
    color: var(--color-text-muted);
}

.auth-submit {
    width: 100%;
    margin-top: var(--space-sm);
}

.auth-switch {
    margin: var(--space-lg) 0 0;
    font-size: 0.9375rem;
    color: var(--color-text-muted);
    text-align: center;
}

.auth-switch + .auth-switch {
    margin-top: var(--space-sm);
}

.auth-switch a {
    font-weight: 600;
}

.feedback a {
    color: inherit;
    font-weight: 600;
}

.feedback-success {
    background-color: #E8F5E9;
    border: 1px solid #B7DFC3;
    color: #1F4D2E;
}

.feedback-info {
    background-color: #E8F0F8;
    border: 1px solid #B8D0E8;
    color: #1F3D5C;
}

.feedback-error {
    background-color: #FCEEE8;
    border: 1px solid #E8C4B8;
    color: #7A3E2E;
}

/* Email icon */
.auth-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3.25rem;
    height: 3.25rem;
    margin-bottom: var(--space-lg);
    border-radius: var(--radius-md);
    background-color: var(--color-secondary);
    color: var(--color-primary);
}

/* Email address display block */
.auth-email-display {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    padding: var(--space-sm) var(--space-md);
    margin-bottom: var(--space-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background-color: var(--color-background);
}

.auth-email-label {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    font-weight: 500;
}

.auth-email-value {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--color-text);
    word-break: break-all;
}
