@layer components {
    .listing-main__header--vacature {
        grid-column: 1 / -1;
    }

    .vacature-listing {
        display: grid;
        gap: var(--space-32, 2rem);
    }

    .vacature-listing__section {
        display: grid;
        gap: var(--space-16, 1rem);
        min-width: 0;
    }

    .vacature-listing__section-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: var(--space-16, 1rem);
        padding-bottom: var(--space-12, 0.75rem);
        border-bottom: var(--border-width-hairline, 1px) solid var(--color-border);
    }

    .vacature-listing__section-header h2 {
        margin: 0;
        font-size: var(--text-xl);
        font-weight: var(--font-weight-extrabold, 800);
        line-height: var(--leading-title);
    }

    .content-card--vacature .content-card__label,
    .content-card--vacature .listing-layout-card__label {
        background-color: var(--color-brand-primary, #f5c400);
        color: var(--color-black, #111);
    }

    .vacature-header__meta {
        flex-wrap: wrap;
        row-gap: var(--space-8, 0.5rem);
    }

    .vacature-content {
        margin-top: 0;
    }

    .vacature-application {
        display: grid;
        gap: var(--space-20, 1.25rem);
        margin-top: var(--space-32, 2rem);
        padding: clamp(1rem, 2vw, 1.5rem);
        border: var(--border-width-hairline, 1px) solid var(--color-border);
        border-radius: var(--radius-corner, 0.5rem);
        background: color-mix(in oklch, var(--color-bg-surface) 70%, transparent);
    }

    .vacature-application__header {
        display: grid;
        gap: var(--space-8, 0.5rem);
    }

    .vacature-application__header h2 {
        margin: 0;
        font-size: var(--text-xl);
        font-weight: var(--font-weight-extrabold, 800);
        line-height: var(--leading-title);
    }

    .vacature-application__header p {
        margin: 0;
        color: var(--color-text-muted);
    }

    .vacature-form {
        display: grid;
        gap: var(--space-16, 1rem);
    }

    .vacature-form__grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: var(--space-16, 1rem);
    }

    .vacature-form label,
    .vacature-form__account {
        display: grid;
        gap: var(--space-8, 0.5rem);
        min-width: 0;
    }

    .vacature-form__field--wide {
        grid-column: 1 / -1;
    }

    .vacature-form span,
    .vacature-form__label {
        color: var(--color-heading, var(--color-text));
        font-weight: var(--font-weight-bold, 700);
        line-height: var(--leading-ui);
    }

    .vacature-form__field-header {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: var(--space-8, 0.5rem);
        justify-content: space-between;
    }

    .vacature-form__field-header small,
    .vacature-form__file-help {
        color: var(--color-text-muted);
        font-size: var(--text-sm);
        font-weight: var(--font-weight-medium, 500);
        line-height: var(--leading-snug);
    }

    .vacature-form b {
        display: inline-flex;
        align-items: center;
        min-height: 1.375rem;
        padding: 0 var(--space-8, 0.5rem);
        border-radius: 999px;
        background: color-mix(in oklch, var(--color-danger) 12%, transparent);
        color: var(--color-danger);
        font-size: var(--text-xs);
        font-weight: var(--font-weight-bold, 700);
        text-transform: uppercase;
    }

    .vacature-form input,
    .vacature-form textarea {
        width: 100%;
        min-width: 0;
        border: var(--border-width-hairline, 1px) solid var(--color-border);
        border-radius: var(--radius-corner, 0.5rem);
        background: var(--color-bg-surface);
        color: var(--color-text);
        font: inherit;
        transition: border-color 160ms ease, box-shadow 160ms ease, background-color 160ms ease;
    }

    .vacature-form input {
        min-height: 2.75rem;
        padding: 0 var(--space-14, 0.875rem);
    }

    .vacature-form textarea {
        min-height: 8rem;
        padding: var(--space-12, 0.75rem) var(--space-14, 0.875rem);
        line-height: var(--leading-reading);
        resize: vertical;
    }

    .vacature-form textarea.vacature-form__textarea--compact {
        min-height: 4.75rem;
    }

    .vacature-form input:focus-visible,
    .vacature-form textarea:focus-visible {
        border-color: var(--color-link);
        outline: var(--border-width-hairline, 1px) solid var(--color-link);
        outline-offset: 0.125rem;
        box-shadow: 0 0 0 0.25rem color-mix(in oklch, var(--color-link) 12%, transparent);
    }

    .vacature-form input[aria-invalid="true"],
    .vacature-form textarea[aria-invalid="true"] {
        border-color: var(--color-danger);
    }

    .vacature-form em {
        color: var(--color-danger);
        font-size: var(--text-sm);
        font-style: normal;
        font-weight: var(--font-weight-semibold, 600);
    }

    .vacature-form__account {
        padding: var(--space-16, 1rem);
        border: var(--border-width-hairline, 1px) solid var(--color-border);
        border-radius: var(--radius-corner, 0.5rem);
        background: var(--color-bg-surface);
    }

    .vacature-form__account strong {
        color: var(--color-heading, var(--color-text));
    }

    .vacature-form__file-field {
        padding: var(--space-14, 0.875rem);
        border: var(--border-width-hairline, 1px) dashed color-mix(in oklch, var(--color-border) 75%, var(--color-text-muted));
        border-radius: var(--radius-corner, 0.5rem);
        background: color-mix(in oklch, var(--color-bg-surface) 78%, transparent);
    }

    .vacature-form__file-control {
        position: relative;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
        gap: var(--space-12, 0.75rem);
        min-height: 3.75rem;
        padding: var(--space-8, 0.5rem) var(--space-14, 0.875rem) var(--space-8, 0.5rem) var(--space-8, 0.5rem);
        border: var(--border-width-hairline, 1px) solid var(--color-border);
        border-radius: var(--radius-corner, 0.5rem);
        background: var(--color-bg-surface);
        transition: border-color 160ms ease, box-shadow 160ms ease, background-color 160ms ease;
    }

    .vacature-form__file-input {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        min-height: 0;
        padding: 0;
        opacity: 0;
        cursor: pointer;
        z-index: 2;
    }

    .vacature-form__file-button {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: var(--space-8, 0.5rem);
        min-height: 2.75rem;
        padding: 0 var(--space-18, 1.125rem);
        border-radius: calc(var(--radius-corner, 0.5rem) - 0.125rem);
        background: var(--color-brand-primary);
        color: var(--color-black);
        font-weight: var(--font-weight-bold, 700);
        line-height: 1;
        white-space: nowrap;
        transition: background-color 160ms ease, transform 160ms ease;
    }

    .vacature-form__file-button span {
        color: inherit;
        font-weight: inherit;
        line-height: 1;
    }

    .vacature-form__file-button .vacature-form__file-icon {
        position: static;
        display: block;
        width: 1rem;
        height: 1rem;
        flex: 0 0 auto;
        overflow: visible;
        fill: currentColor;
        pointer-events: none;
    }

    .vacature-form__file-name {
        min-width: 0;
        overflow: hidden;
        color: var(--color-text-muted);
        font-weight: var(--font-weight-medium, 500);
        line-height: var(--leading-ui);
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .vacature-form__file-control:hover,
    .vacature-form__file-control:has(.vacature-form__file-input:focus-visible) {
        border-color: var(--color-link);
        box-shadow: 0 0 0 0.25rem color-mix(in oklch, var(--color-link) 12%, transparent);
    }

    .vacature-form__file-control:hover .vacature-form__file-button,
    .vacature-form__file-control:has(.vacature-form__file-input:focus-visible) .vacature-form__file-button {
        background: var(--color-brand-primary-hover);
        transform: translateY(-0.0625rem);
    }

    .vacature-form__actions {
        display: flex;
        flex-wrap: wrap;
        gap: var(--space-12, 0.75rem);
        align-items: center;
        padding-top: var(--space-4, 0.25rem);
    }

    .vacature-form__submit {
        justify-self: start;
        min-height: 3rem;
        padding: 0 var(--space-20, 1.25rem);
        border: var(--border-width-hairline, 1px) solid var(--color-link);
        border-radius: var(--radius-corner, 0.5rem);
        background: var(--color-link);
        color: var(--color-white, #fff);
        font-weight: var(--font-weight-bold, 700);
        cursor: pointer;
        transition: filter 160ms ease, transform 160ms ease;
    }

    .vacature-form__submit:hover,
    .vacature-form__submit:focus-visible {
        filter: brightness(0.95);
        transform: translateY(-0.0625rem);
    }

    .vacature-message {
        margin: 0;
        padding: var(--space-14, 0.875rem) var(--space-16, 1rem);
        border: var(--border-width-hairline, 1px) solid var(--color-border);
        border-radius: var(--radius-corner, 0.5rem);
        background: var(--color-bg-surface);
        color: var(--color-text);
        font-weight: var(--font-weight-semibold, 600);
    }

    .vacature-message--success {
        border-color: color-mix(in oklch, var(--color-success, #2e7d32) 48%, var(--color-border));
        color: var(--color-success, #2e7d32);
    }

    .vacature-message--warning {
        border-color: color-mix(in oklch, var(--color-warning, #b26a00) 48%, var(--color-border));
        color: var(--color-warning, #b26a00);
    }

    .vacature-message--error {
        border-color: color-mix(in oklch, var(--color-danger) 48%, var(--color-border));
        color: var(--color-danger);
    }

    @media (max-width: 47.9375rem) {
        .vacature-form__grid {
            grid-template-columns: minmax(0, 1fr);
        }

        .vacature-form__submit {
            width: 100%;
        }

        .vacature-form__field-header {
            justify-content: flex-start;
        }
    }
}
