/* ----------------------------------------------------------------------
 * Mijn KHMW — layout-only stylesheet
 *
 * Bewust GEEN kleuren, typografie of huisstijl. Wij leveren alleen:
 *   - Layout & spacing (grid, flex, padding)
 *   - Logische groepering (cards, lists)
 *   - Accessibility-defaults (focus styles)
 *
 * Het thema (Krista's design) levert kleur, typografie, achtergronden,
 * borders, schaduw en branding via een eigen stylesheet die NA deze
 * laadt en met dezelfde class-namen werkt.
 * ---------------------------------------------------------------------- */

/* BEM-prefix: alle klassen beginnen met `khmw-` */

/*
.khmw-eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.75rem;
    margin: 0 0 0.25rem;
}
*/

.khmw-dashboard__header {
    margin-bottom: 1.5rem;
}

.khmw-dashboard__title {
    margin: 0;
}

.khmw-dashboard__footer {
    margin-top: 2rem;
}

.khmw-meta {
    font-size: 0.85rem;
    opacity: 0.7;
    margin: 0;
}

/* Quicklinks ------------------------------------------------------- */
.khmw-quicklinks {
    margin: 0 0 2rem;
}

.khmw-quicklinks__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.khmw-quicklinks__item {
    display: inline-block;
    padding: 0.5rem 1rem;
    text-decoration: none;
}

/* Grid ------------------------------------------------------------- */
.khmw-grid {
    display: grid;
    gap: 1.25rem;
}

.khmw-grid--2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.khmw-grid--3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 900px) {
    .khmw-grid--3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 600px) {
    .khmw-grid--2,
    .khmw-grid--3 { grid-template-columns: 1fr; }
}

/* Card ------------------------------------------------------------- */
.khmw-card {
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.khmw-card__title {
    margin: 0 0 0.5rem;
    font-size: 1.05rem;
}

.khmw-card__action {
    margin-top: auto;
    align-self: flex-start;
}

/* Empty state ------------------------------------------------------ */
.khmw-empty {
    margin: 0;
    opacity: 0.7;
    font-style: italic;
}

/* Buttons (structure only — thema levert visuele stijl) ----------- */
.khmw-btn {
    display: inline-block;
    padding: 0.5rem 1rem;
    text-decoration: none;
    cursor: pointer;
}

/* Alerts ----------------------------------------------------------- */
.khmw-alert {
    padding: 1rem 1.25rem;
    margin: 1rem 0;
}

.khmw-alert p:last-child {
    margin-bottom: 0;
}

/* Focus visibility (accessibility default) ------------------------- */
.khmw-btn:focus-visible,
.khmw-quicklinks__item:focus-visible,
.khmw-card__action:focus-visible {
    outline: 2px solid currentColor;
    outline-offset: 2px;
}

/* Auth (login / register / wachtwoord-vergeten) -------------------- */
.khmw-auth {
    max-width: 28rem;
    margin: 2rem auto;
    padding: 1.5rem;
}

.khmw-auth__header {
    margin-bottom: 1.5rem;
}

.khmw-auth__title {
    margin: 0;
}

.khmw-auth__meta {
    margin: 0.5rem 0 0;
    color: #6b7c94;
    font-size: 0.95rem;
    line-height: 1.45;
}

.khmw-auth__form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1rem;
}

.khmw-auth__footer {
    margin-top: 1.5rem;
    font-size: 0.95rem;
}

.khmw-auth__link {
    text-decoration: underline;
}

.khmw-field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.khmw-field--inline {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.75rem;
}

/*
.khmw-field input[type="text"],
.khmw-field input[type="email"],
.khmw-field input[type="password"] {
    width: 100%;
    padding: 0.55rem 0.75rem;
    box-sizing: border-box;
    font: inherit;
}
*/

.khmw-input--code {
    font-size: 1.25rem;
    letter-spacing: 0.2em;
    text-align: center;
    max-width: 12rem;
}

body.khmw-member-area--auth .khmw-auth .khmw-btn--primary {
    background-color: #002266 !important;
    color: #ffffff !important;
    border: 1px solid #002266 !important;
}

.khmw-field-group {
    margin: 0;
}

/* Honeypot: visueel én voor screenreaders verbergen, maar wel
   in de DOM zodat bots 'm vinden en invullen. */
.khmw-honeypot {
    position: absolute !important;
    left: -10000px !important;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

/* Mijn KHMW — pagina-achtergrond (Figma) ----------------------------- */
body.khmw-member-area {
    background-color: #f4f7f9;
}

body.khmw-member-area .khmw-shell {
    --khmw-shell-bg: #f4f7f9;
    --khmw-shell-card-bg: #ffffff;
    --khmw-shell-card-border: transparent;
    --khmw-shell-card-radius: 0;
    --khmw-shell-muted: #6b7c94;
}

/* Shell (sidebar + main) -------------------------------------------- */
/* Design-tokens — thema/designers kunnen deze overschrijven. */
.khmw-shell {
    --khmw-shell-bg: transparent;
    --khmw-shell-card-bg: #fff;
    --khmw-shell-card-border: rgba(0, 0, 0, 0.08);
    --khmw-shell-card-radius: 8px;
    --khmw-shell-title: #002266;
    --khmw-shell-accent: #ae1639;
    --khmw-shell-text: #002266;
    --khmw-shell-muted: rgba(0, 34, 102, 0.65);
    --khmw-shell-sidebar-active: #002266;
}

/* !important op de kritieke layout-regels omdat het Salient-thema sterk
   gespecificeerde regels heeft (.container ul li { list-style: disc },
   etc.) die anders onze sidebar-grid en list-reset overschrijven. */
.khmw-shell {
    display: grid !important;
    grid-template-columns: 220px minmax(0, 1fr) !important;
    gap: 2rem;
    margin: 1.5rem 0;
}

.khmw-shell__sidebar {
    padding-top: 0.25rem;
}

/* Mobiele "Menu"-toggle — alleen zichtbaar onder 800px (zie media query). */
.khmw-shell__toggle {
    display: none;
}

.khmw-shell__eyebrow {
    margin: 0 0 1rem;
}

.khmw-shell ul,
.khmw-shell__list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.khmw-shell li {
    list-style: none !important;
    margin: 0 !important;
    padding: 0;
}

.khmw-shell__list {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.khmw-shell__item--logout {
    margin-top: 1rem;
}

.khmw-shell__sublist {
    list-style: none !important;
    padding: 0.15rem 0 0 2.75rem !important;
    margin: 0 !important;
}

body.khmw-member-area .khmw-shell__sublist {
    padding-left: 3rem !important;
}

.khmw-shell__item.is-expanded > .khmw-shell__sublist {
    display: block;
}

.khmw-shell__subitem {
    list-style: none !important;
    margin: 0 !important;
    padding: 0;
}

.khmw-shell__subitem .khmw-shell__link {
    padding: 0.35rem 0;
    font-weight: 400;
}

.khmw-shell__subitem.is-active .khmw-shell__link {
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 0.35rem;
}

.khmw-shell__link {
    display: block;
    padding: 0.5rem 0;
    text-decoration: none;
}

.khmw-shell__item.is-active > .khmw-shell__link {
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 0.35rem;
}

.khmw-shell__item.is-expanded > .khmw-shell__link--parent {
    font-weight: 500;
    text-decoration: none;
}

.khmw-shell__main {
    min-width: 0;
}

/* Page header ------------------------------------------------------- */
.khmw-page__header {
    margin: 0 0 1.5rem;
}

.khmw-page__header--has-action {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem 1.5rem;
}

.khmw-page__header-text {
    min-width: 0;
    flex: 1 1 16rem;
}

.khmw-page__header-action {
    flex: 0 0 auto;
    align-self: flex-start;
}

.khmw-page__title {
    margin: 0 0 0.35rem;
    color: var(--khmw-shell-accent, inherit);
}

.khmw-page__meta {
    margin: 0;
    color: var(--khmw-shell-muted, inherit);
    opacity: 1;
    font-size: 0.95rem;
}

.khmw-page__meta-sep {
    margin: 0 0.4rem;
    opacity: 0.6;
}

@media (max-width: 800px) {
    .khmw-shell {
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 1rem;
    }
}

/* Cards (shell) ----------------------------------------------------- */
.khmw-shell .khmw-card {
    background: var(--khmw-shell-card-bg, #fff);
    border: 1px solid var(--khmw-shell-card-border, rgba(0, 0, 0, 0.08));
    border-radius: var(--khmw-shell-card-radius, 8px);
}

body.khmw-member-area .khmw-shell .khmw-card,
body.khmw-member-area .khmw-shell .khmw-detail-card,
body.khmw-member-area .khmw-shell .khmw-profile-hero {
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.khmw-shell .khmw-eyebrow {
    color: var(--khmw-shell-accent, inherit);
}

/* Action button (layout) -------------------------------------------- */
.khmw-btn--action {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.55rem 1.1rem;
    border-radius: 999px;
    text-decoration: none;
    white-space: nowrap;
}

.khmw-btn--icon-right {
    flex-direction: row;
    align-items: center;
    gap: 10px;
}

/* Bordeaux buttons (Figma Button/bordeaux/*) ----------------------- */
.khmw-btn--bordeaux-fill,
.khmw-btn--bordeaux-line {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 20px;
    border-radius: 100px;
    font: inherit;
    font-weight: 600;
    text-decoration: none;
    white-space: nowrap;
    cursor: pointer;
    border: 1px solid #AE1639;
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.khmw-btn--bordeaux-fill {
    background: #AE1639;
    color: #ffffff;
}

.khmw-btn--bordeaux-fill:hover,
.khmw-btn--bordeaux-fill:focus {
    background: #8f1230;
    border-color: #8f1230;
    color: #ffffff;
}

.khmw-btn--bordeaux-line {
    background: #ffffff;
    color: #AE1639;
}

.khmw-btn--bordeaux-line:hover,
.khmw-btn--bordeaux-line:focus {
    background: #AE1639;
    color: #ffffff;
}

.khmw-btn__icon {
    display: inline-flex;
    line-height: 0;
}

.khmw-btn__icon svg {
    display: block;
}

/* External link with arrow ------------------------------------------ */
.khmw-link--arrow::after {
    content: '›';
    margin-left: 0.15rem;
}

/* Dashboard cards --------------------------------------------------- */
.khmw-shell--dashboard .khmw-card {
    padding: 1.875rem;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.khmw-shell--dashboard .khmw-mededelingen__item + .khmw-mededelingen__item,
.khmw-shell--dashboard .khmw-documenten__item + .khmw-documenten__item {
    border-top-color: #e1e8ed;
}

.khmw-shell--dashboard .khmw-dashboard__event {
    border-top-color: #e1e8ed;
}

.khmw-shell--dashboard a.khmw-btn--pill,
.khmw-shell--dashboard .khmw-btn--pill {
    color: #ae1639 !important;
    border-color: #ae1639 !important;
    background: #fff !important;
}

.khmw-shell--dashboard a.khmw-btn--pill:hover,
.khmw-shell--dashboard a.khmw-btn--pill:focus,
.khmw-shell--dashboard .khmw-btn--pill:hover,
.khmw-shell--dashboard .khmw-btn--pill:focus {
    color: #fff !important;
    background: #ae1639 !important;
}

.khmw-shell--dashboard .khmw-mededelingen__title a,
.khmw-shell--dashboard .khmw-dashboard__event-title a {
    font-weight: 600;
}

.khmw-dashboard__layout {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 1.25rem;
    align-items: start;
}

.khmw-dashboard__col--left {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    min-width: 0;
}

.khmw-dashboard__col--right {
    min-width: 0;
}

@media (max-width: 900px) {
    .khmw-dashboard__layout {
        grid-template-columns: 1fr !important;
    }
}

.khmw-dashboard__grid {
    align-items: start;
}

.khmw-mededelingen,
.khmw-documenten {
    list-style: none !important;
    padding: 0 !important;
    margin: 0.5rem 0 0 !important;
    display: flex;
    flex-direction: column;
}

.khmw-mededelingen li,
.khmw-documenten li {
    list-style: none !important;
    margin: 0 !important;
}

.khmw-dashboard__grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 1.25rem;
}

@media (max-width: 700px) {
    .khmw-dashboard__grid {
        grid-template-columns: 1fr !important;
    }
}

.khmw-mededelingen__item {
    padding: 0.75rem 0;
}

.khmw-mededelingen__item + .khmw-mededelingen__item {
    border-top: 1px solid currentColor;
    border-top-color: rgba(0, 0, 0, 0.08);
}

.khmw-mededelingen__title {
    margin: 0 0 0.5rem;
    font-size: 1.125rem;
}

.khmw-mededelingen__excerpt {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.5;
}

.khmw-documenten__item {
    padding: 0.65rem 0;
}

.khmw-documenten__item + .khmw-documenten__item {
    border-top: 1px solid currentColor;
    border-top-color: rgba(0, 0, 0, 0.08);
}

.khmw-documenten__title {
    display: block;
    font-weight: 600;
    text-decoration: none;
    margin-bottom: 0.15rem;
}

.khmw-documenten__meta {
    margin: 0;
    font-size: 0.8125rem;
    opacity: 1;
}

.khmw-card__action-row {
    margin: 1rem 0 0;
}

.khmw-btn--pill {
    display: inline-block;
    padding: 0.45rem 1rem;
    border: 1px solid var(--khmw-shell-accent, currentColor);
    border-radius: 999px;
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 500;
    white-space: nowrap;
}

.khmw-dashboard__events {
    list-style: none !important;
    padding: 0 !important;
    margin: 0.5rem 0 0 !important;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.khmw-dashboard__event {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 0.75rem 1rem;
    padding: 0.85rem 0;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.khmw-dashboard__events .khmw-dashboard__event:first-child {
    border-top: 0;
    padding-top: 0;
}

.khmw-dashboard__event-date {
    flex: 0 0 auto;
    min-width: 4.5rem;
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--khmw-shell-accent, inherit);
}

.khmw-dashboard__event-body {
    flex: 1 1 12rem;
    min-width: 0;
}

.khmw-dashboard__event-title {
    margin: 0 0 0.2rem;
    font-weight: 600;
    font-size: 0.95rem;
}

.khmw-dashboard__event-title a {
    text-decoration: none;
    color: var(--khmw-shell-text, inherit);
}

.khmw-dashboard__event-title a:hover,
.khmw-dashboard__event-title a:focus {
    text-decoration: underline;
}

.khmw-dashboard__event-meta {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.45;
    color: var(--khmw-shell-muted, inherit);
}

.khmw-dashboard__event .khmw-btn--pill {
    flex: 0 0 auto;
    margin-left: auto;
    align-self: center;
}

/* Profile hero + detail cards -------------------------------------- */
.khmw-profile-hero {
    display: grid !important;
    grid-template-columns: 160px minmax(0, 1fr);
    gap: 1.5rem;
    align-items: start;
    margin: 0 0 1.5rem;
    padding: 1.5rem;
}

.khmw-profile-hero__avatar {
    width: 100%;
    aspect-ratio: 1 / 1;
    display: block;
    object-fit: cover;
    background: rgba(0, 0, 0, 0.04);
    border: 1px solid rgba(0, 0, 0, 0.08);
}

.khmw-profile-hero__avatar--placeholder {
    position: relative;
}

.khmw-profile-hero__avatar--placeholder::before,
.khmw-profile-hero__avatar--placeholder::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top right,
        transparent calc(50% - 1px), rgba(0, 0, 0, 0.25) 50%,
        transparent calc(50% + 1px));
}

.khmw-profile-hero__avatar--placeholder::after {
    background: linear-gradient(to bottom right,
        transparent calc(50% - 1px), rgba(0, 0, 0, 0.25) 50%,
        transparent calc(50% + 1px));
}

.khmw-profile-hero__name {
    margin: 0 0 0.35rem;
    font-size: 1.35rem;
    line-height: 1.25;
    color: var(--khmw-shell-title, inherit);
}

.khmw-profile-hero__meta {
    margin: 0 0 0.85rem;
    font-size: 0.9rem;
    color: var(--khmw-shell-accent, inherit);
}

.khmw-profile-hero__bio {
    margin: 0 0 0.85rem;
    font-size: 0.95rem;
    line-height: 1.6;
    color: var(--khmw-shell-text, inherit);
}

.khmw-profile-hero__bio p {
    margin: 0;
}

.khmw-profile-hero__links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1.25rem;
    align-items: baseline;
    font-size: 0.95rem;
}

.khmw-profile-hero__orcid {
    color: var(--khmw-shell-text, inherit);
}

@media (max-width: 700px) {
    .khmw-profile-hero {
        grid-template-columns: 1fr !important;
    }

    .khmw-profile-hero__media {
        max-width: 160px;
    }
}

/* Legacy hero (edit-scherm) ----------------------------------------- */
.khmw-hero {
    display: grid !important;
    grid-template-columns: 120px minmax(0, 1fr) auto;
    gap: 1.25rem;
    align-items: start;
    margin: 0 0 1.5rem;
}

.khmw-hero__avatar img,
.khmw-hero__avatar-placeholder {
    width: 100px;
    height: 100px;
    display: block;
    background: rgba(0, 0, 0, 0.04);
    border: 1px solid rgba(0, 0, 0, 0.08);
}

.khmw-hero__avatar-placeholder {
    position: relative;
}

.khmw-hero__avatar-placeholder::before,
.khmw-hero__avatar-placeholder::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top right,
        transparent calc(50% - 1px), rgba(0, 0, 0, 0.25) 50%,
        transparent calc(50% + 1px));
}

.khmw-hero__avatar-placeholder::after {
    background: linear-gradient(to bottom right,
        transparent calc(50% - 1px), rgba(0, 0, 0, 0.25) 50%,
        transparent calc(50% + 1px));
}

.khmw-hero__name {
    margin: 0 0 0.25rem;
    font-size: 1.15rem;
}

.khmw-hero__meta {
    margin: 0 0 0.6rem;
    opacity: 0.75;
    font-size: 0.9rem;
}

.khmw-hero__bio {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.55;
}

.khmw-hero__bio p {
    margin: 0;
}

.khmw-hero__action {
    align-self: start;
}

.khmw-hero--avatar .khmw-hero__body {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
}

.khmw-avatar-form,
.khmw-avatar-form--delete {
    display: inline-flex;
    gap: 0.5rem;
    align-items: center;
    margin: 0;
}

.khmw-avatar-form__file {
    max-width: 12rem;
}

@media (max-width: 700px) {
    .khmw-hero {
        grid-template-columns: 1fr !important;
        text-align: left;
    }
}

/* Profile cards grid ---------------------------------------------- */
.khmw-profile-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 1.25rem;
}

@media (max-width: 700px) {
    .khmw-profile-grid {
        grid-template-columns: 1fr !important;
    }
}

.khmw-detail-card .khmw-eyebrow {
    margin: 0 0 0.75rem;
}

.khmw-detail-row {
    display: grid;
    grid-template-columns: 11rem minmax(0, 1fr);
    gap: 1rem;
    padding: 0.55rem 0;
    align-items: baseline;
}

.khmw-detail-row + .khmw-detail-row {
    border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.khmw-detail-row__label {
    font-size: 0.9rem;
    color: var(--khmw-shell-muted, inherit);
    opacity: 1;
}

.khmw-detail-row__value {
    font-size: 0.95rem;
    word-break: break-word;
    color: var(--khmw-shell-text, inherit);
}

.khmw-detail-row__value--full {
    grid-column: 1 / -1;
}

.khmw-detail-row__private {
    margin-left: 0.4rem;
    font-size: 0.8rem;
    opacity: 0.55;
}

@media (max-width: 540px) {
    .khmw-detail-row {
        grid-template-columns: 1fr;
        gap: 0.25rem;
    }
}

/* Profile edit form ------------------------------------------------ */

/*
.khmw-input {
    width: 100%;
    padding: 0.45rem 0.6rem;
    box-sizing: border-box;
    font: inherit;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.18);
    border-radius: 2px;
}
*/

.khmw-input--textarea {
    min-height: 8rem;
    resize: vertical;
}

.khmw-form-actions {
    display: flex;
    gap: 0.75rem;
    margin: 1.5rem 0 0;
}

.khmw-profile-bio {
    margin-top: 1.25rem;
}

/* Wijzigingsverzoek ------------------------------------------------ */
.khmw-shell--wijziging .khmw-page__meta {
    opacity: 0.5;
    max-width: 42rem;
}

.khmw-wijziging-hero {
    display: grid;
    grid-template-columns: auto auto 1fr;
    gap: 1.25rem 1.5rem;
    align-items: start;
    margin-bottom: 1.25rem;
}

.khmw-wijziging-hero__avatar {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    object-fit: cover;
    display: block;
}

.khmw-wijziging-hero__avatar--placeholder {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: #e8edf1;
    position: relative;
}

.khmw-wijziging-hero__aside {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    align-items: flex-start;
}

.khmw-wijziging-hero__upload,
.khmw-wijziging-hero__remove {
    cursor: pointer;
    position: relative;
}

.khmw-wijziging-hero__file,
.khmw-wijziging-hero__remove-check {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
}

.khmw-wijziging-hero__remove:has(.khmw-wijziging-hero__remove-check:checked) {
    background: rgba(0, 0, 0, 0.06);
}

.khmw-wijziging-hero__name {
    margin: 0 0 0.25rem;
    font-size: 1.35rem;
    font-weight: 600;
}

.khmw-wijziging-hero__meta {
    margin: 0 0 0.75rem;
    opacity: 0.55;
    font-size: 0.95rem;
}

.khmw-wijziging-input {
    width: 100%;
    padding: 0.55rem 0.75rem;
    box-sizing: border-box;
    font: inherit;
    background: #f4f7f9;
    border: 1px solid transparent;
    border-radius: 2px;
}

.khmw-wijziging-input:focus {
    border-color: rgba(0, 0, 0, 0.2);
    outline: none;
}

.khmw-wijziging-input--bio {
    min-height: 6rem;
    resize: vertical;
}

.khmw-wijziging-row {
    display: grid;
    grid-template-columns: minmax(8rem, 38%) 1fr;
    gap: 0.75rem 1rem;
    align-items: center;
    padding: 0.35rem 0;
}

.khmw-wijziging-row__label {
    opacity: 0.5;
    font-size: 0.95rem;
}

.khmw-wijziging-row__private {
    display: block;
    font-size: 0.8rem;
    opacity: 0.75;
}

.khmw-wijziging-name-fields {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.5rem;
}

.khmw-wijziging-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.5rem;
}

/* Header-actieknoppen profiel + wijzigingsverzoek — zelfde ritme */
.khmw-shell--profile .khmw-page__header-action .khmw-btn--action,
.khmw-shell--profile .khmw-page__header-action .khmw-btn--bordeaux-line {
    margin: 0;
    display: inline-flex !important;
    align-items: center;
    box-sizing: border-box;
}

@media (max-width: 700px) {
    .khmw-wijziging-hero {
        grid-template-columns: 1fr;
    }

    .khmw-wijziging-row {
        grid-template-columns: 1fr;
    }

    .khmw-wijziging-name-fields {
        grid-template-columns: 1fr;
    }
}

/* Modal (wijzigingsverzoek succes — Figma bevestiging) ------------- */
html.khmw-modal-open {
    overflow: hidden;
}

.khmw-modal {
    position: fixed;
    inset: 0;
    z-index: 100000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    box-sizing: border-box;
}

.khmw-modal[hidden] {
    display: none !important;
}

.khmw-modal__backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 34, 102, 0.5);
}

.khmw-modal__panel {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 1.7rem;
    width: min(100%, 32.625rem);
    max-height: calc(100vh - 3rem);
    overflow: auto;
    background: #ffffff;
    padding: 1.875rem;
    box-shadow: 0 18px 48px rgba(0, 34, 102, 0.18);
}

.khmw-modal__title {
    margin: 0;
    font-size: 1.875rem;
    line-height: 1.17;
    font-weight: 500;
}

.khmw-modal__text {
    margin: 0;
    line-height: 1.55;
    color: #002266;
}

.khmw-modal__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

@media (max-width: 540px) {
    .khmw-modal__panel {
        padding: 1.5rem 1.25rem;
    }
}

/* Outline button (structureel — kleur komt uit thema) -------------- */
.khmw-btn--outline {
    background: transparent;
    border: 1px solid currentColor;
    padding: 0.5rem 0.9rem;
}

.khmw-btn--small {
    padding: 0.3rem 0.6rem;
    font-size: 0.85rem;
}

/* Security page ---------------------------------------------------- */
.khmw-security-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 1.25rem;
}

@media (max-width: 800px) {
    .khmw-security-grid { grid-template-columns: 1fr !important; }
}

.khmw-security-form .khmw-field + .khmw-field {
    margin-top: 0.75rem;
}

.khmw-inline-form {
    display: inline-flex;
    margin: 0;
}

.khmw-2fa__pill {
    display: inline-block;
    padding: 0.1rem 0.55rem;
    border: 1px solid currentColor;
    border-radius: 999px;
    font-size: 0.8rem;
}

.khmw-2fa__pill--active   { color: #0a7f2e; }
.khmw-2fa__pill--pending  { color: #b26200; }
.khmw-2fa__pill--inactive { color: #888; }

.khmw-2fa__steps {
    margin: 0.5rem 0 1rem 1.25rem;
    padding: 0;
    line-height: 1.5;
}

.khmw-2fa__qr {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
    margin: 0.75rem 0 1rem;
}

.khmw-2fa__qr img {
    background: #fff;
    padding: 0.5rem;
    border: 1px solid rgba(0, 0, 0, 0.08);
}

.khmw-2fa__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin: 0.75rem 0 1rem;
}

.khmw-2fa__disable summary {
    cursor: pointer;
    font-size: 0.9rem;
    opacity: 0.8;
}

.khmw-input--code {
    font-size: 1.5rem !important;
    letter-spacing: 0.5rem;
    text-align: center;
    max-width: 14rem;
}

.khmw-backup-codes__list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0.5rem 0 0 !important;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.35rem 1rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

@media (max-width: 540px) {
    .khmw-backup-codes__list { grid-template-columns: 1fr; }
}

.khmw-sessions {
    margin-top: 1.25rem;
}

.khmw-sessions__table {
    width: 100%;
    border-collapse: collapse;
    margin: 0.75rem 0 1rem;
    font-size: 0.95rem;
}

.khmw-sessions__table th,
.khmw-sessions__table td {
    text-align: left;
    padding: 0.6rem 0.5rem;
    vertical-align: top;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.khmw-sessions__table thead th {
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.75rem;
    opacity: 0.7;
    font-weight: 600;
}

@media (max-width: 700px) {
    .khmw-sessions__table thead { display: none; }
    .khmw-sessions__table tr {
        display: grid;
        grid-template-columns: 1fr auto;
        gap: 0.25rem 0.5rem;
        padding: 0.5rem 0;
        border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    }
    .khmw-sessions__table td { border: 0; padding: 0; }
}

/* Ledenbestand --------------------------------------------------- */
.khmw-members__form {
    margin: 0 0 1.5rem;
}

.khmw-members__search {
    margin: 0 0 1.25rem;
}

.khmw-members__search-input {
    width: 100%;
    padding: 0.65rem 0.85rem;
    box-sizing: border-box;
/*
    font: inherit;
    border: 1px solid var(--khmw-shell-card-border, rgba(0, 0, 0, 0.12));
    border-radius: 4px;
    background: var(--khmw-shell-card-bg, #fff);
    color: var(--khmw-shell-text, inherit);
*/
}

.khmw-members__search-input:focus-visible {
    outline: 2px solid var(--khmw-shell-title, currentColor);
    outline-offset: 1px;
}

.khmw-members__bar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem 1.5rem;
}

.khmw-members__filters {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem 1.25rem;
    flex: 1 1 20rem;
    min-width: 0;
}

.khmw-members__field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    min-width: 0;
}

.khmw-members__label {
    text-transform: uppercase;
    letter-spacing: 0.07em;
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--khmw-shell-accent, inherit);
}

.khmw-members__select {
    width: 100%;
    padding: 0.55rem 0.75rem;
    box-sizing: border-box;
    font: inherit;
    border: 1px solid var(--khmw-shell-card-border, rgba(0, 0, 0, 0.12));
    border-radius: 4px;
    background: var(--khmw-shell-card-bg, #fff);
    color: var(--khmw-shell-text, inherit);
    cursor: pointer;
}

.khmw-members__select:focus-visible {
    outline: 2px solid var(--khmw-shell-title, currentColor);
    outline-offset: 1px;
}

.khmw-members__pagination {
    flex: 0 0 auto;
    align-self: flex-end;
}

.khmw-members__pagination-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    flex-wrap: wrap;
    gap: 0.35rem;
    align-items: center;
    justify-content: flex-end;
}

.khmw-members__pagination-list li {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.khmw-members__pagination-list .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2rem;
    height: 2rem;
    padding: 0 0.35rem;
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 600;
    line-height: 1;
    box-sizing: border-box;
}

.khmw-members__pagination-list .page-numbers.dots {
    min-width: auto;
    padding: 0 0.15rem;
    background: transparent;
    color: var(--khmw-shell-text, inherit);
}

.khmw-members__reset {
    margin: 0.75rem 0 0;
    font-size: 0.9rem;
}

.khmw-members__empty {
    margin: 0;
    padding: 2rem 0;
    font-style: italic;
    color: var(--khmw-shell-muted, inherit);
}

.khmw-shell--members {
    --khmw-members-photo: 120px;
    --khmw-members-accent: #ae1639;
    --khmw-members-blue: #002266;
    --khmw-members-muted: rgba(0, 34, 102, 0.55);
    --khmw-members-row-border: #e4e8ee;
}

.khmw-members__table-wrap {
    background: var(--khmw-shell-card-bg, #fff);
    border: 0;
    border-radius: 0;
    overflow: visible;
}

.khmw-members__table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
    font-size: 0.95rem;
}

.khmw-members__table th,
.khmw-members__table td {
    text-align: left;
    padding: 1.15rem 1rem;
    border: 0 !important;
    border-bottom: 1px solid var(--khmw-members-row-border, rgba(0, 0, 0, 0.08)) !important;
    vertical-align: top;
}

.khmw-members__table tbody tr:last-child td {
    border-bottom: 0 !important;
}

.khmw-members__table thead th {
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--khmw-members-accent, var(--khmw-shell-accent, inherit));
    opacity: 1;
    background: transparent;
    padding-top: 0.5rem;
    padding-bottom: 0.85rem;
    vertical-align: bottom;
}

.khmw-members__col-photo {
    width: var(--khmw-members-photo, 120px);
    padding-left: 0 !important;
    padding-right: 0.75rem !important;
}

.khmw-members__col-name-h,
.khmw-members__col-name {
    width: 22%;
}

.khmw-members__col-sectie-h,
.khmw-members__col-sectie {
    width: 24%;
}

.khmw-members__col-affiliatie-h,
.khmw-members__col-affiliatie {
    width: 24%;
    line-height: 1.45;
}

.khmw-members__col-sinds,
.khmw-members__table thead .khmw-members__col-sinds {
    width: 6.5rem;
    text-align: center !important;
    white-space: nowrap;
}

.khmw-members__col-status,
.khmw-members__table thead .khmw-members__col-status {
    width: 5.5rem;
    text-align: center !important;
    white-space: nowrap;
}

.khmw-members__avatar {
    display: block;
    width: var(--khmw-members-photo, 120px);
    height: var(--khmw-members-photo, 120px);
    object-fit: cover;
    background: rgba(0, 0, 0, 0.04);
}

.khmw-members__avatar--placeholder {
    position: relative;
    background: rgba(0, 0, 0, 0.04);
}

.khmw-members__avatar--placeholder::before,
.khmw-members__avatar--placeholder::after {
    content: "";
    position: absolute;
    inset: 0;
    border: 1px solid rgba(0, 0, 0, 0.12);
}

.khmw-members__avatar--placeholder::after {
    background:
        linear-gradient(to top right, transparent calc(50% - 1px), rgba(0, 0, 0, 0.12) 50%, transparent calc(50% + 1px)),
        linear-gradient(to top left,  transparent calc(50% - 1px), rgba(0, 0, 0, 0.12) 50%, transparent calc(50% + 1px));
}

.khmw-members__name {
    display: inline-block;
    text-decoration: none;
    font-weight: 700;
    color: var(--khmw-members-blue, var(--khmw-shell-text, inherit));
    line-height: 1.35;
}

.khmw-members__name:hover,
.khmw-members__name:focus {
    text-decoration: underline;
}

.khmw-members__sectie-primary {
    display: block;
    color: var(--khmw-members-blue, var(--khmw-shell-text, inherit));
    font-weight: 600;
    line-height: 1.35;
}

.khmw-members__sectie-secondary {
    display: block;
    margin-top: 0.2rem;
    font-size: 0.85rem;
    color: var(--khmw-members-muted, var(--khmw-shell-muted, inherit));
    line-height: 1.3;
    font-weight: 400;
}

.khmw-members__col-affiliatie,
.khmw-members__col-sinds,
.khmw-members__col-status {
    color: var(--khmw-members-blue, var(--khmw-shell-text, inherit));
    font-weight: 500;
}

@media (max-width: 900px) {
    .khmw-members__filters {
        grid-template-columns: 1fr;
    }

    .khmw-members__bar {
        flex-direction: column;
        align-items: stretch;
    }

    .khmw-members__pagination-list {
        justify-content: flex-start;
    }
}

@media (max-width: 720px) {
    .khmw-members__table thead {
        display: none;
    }

    .khmw-members__table,
    .khmw-members__table tbody,
    .khmw-members__table tr,
    .khmw-members__table td {
        display: block;
        width: 100% !important;
    }

    .khmw-members__table tr {
        padding: 1rem 0;
        border-bottom: 1px solid var(--khmw-members-row-border, rgba(0, 0, 0, 0.08)) !important;
    }

    .khmw-members__table td {
        border: 0 !important;
        padding: 0.25rem 0 !important;
        text-align: left !important;
    }

    .khmw-members__col-photo {
        margin-bottom: 0.75rem;
    }

    .khmw-members__col-name {
        margin-bottom: 0.35rem;
    }
}

/* Pagination (documenten e.d.) ------------------------------------- */
.khmw-pagination {
    margin: 1.25rem 0;
}

.khmw-pagination__list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    flex-wrap: wrap;
    gap: 0.35rem 0.6rem;
    align-items: center;
    justify-content: center;
}

.khmw-pagination__list li { margin: 0 !important; padding: 0 !important; }

.khmw-pagination__list .page-numbers {
    display: inline-block;
    padding: 0.3rem 0.6rem;
    border: 1px solid transparent;
    text-decoration: none;
    border-radius: 4px;
}

.khmw-pagination__list .page-numbers.current {
    border-color: currentColor;
    font-weight: 600;
}

/* Legacy pagination (andere pagina's) ------------------------------ */
.khmw-btn--text {
    background: transparent;
    border: 0;
    padding: 0.5rem 0.4rem;
    text-decoration: underline;
}

/* Documenten ----------------------------------------------------- */
.khmw-docs__filterbar {
    margin: 0 0 1.25rem;
}

.khmw-docs__filterbar-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 11rem auto;
    gap: 0.75rem 1rem;
    align-items: center;
}

.khmw-docs__filterbar-row .khmw-field {
    margin: 0;
    min-width: 0;
}

.khmw-docs__filter--search .khmw-input,
.khmw-docs__filter--year .khmw-input {
    width: 100%;
    box-sizing: border-box;
}

.khmw-docs__filterbar-actions {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 0.75rem;
    justify-content: flex-end;
}

.khmw-docs__filterbar-actions .khmw-btn {
    margin: 0;
    white-space: nowrap;
}

@media (max-width: 720px) {
    .khmw-docs__filterbar-row {
        grid-template-columns: 1fr;
    }

    .khmw-docs__filterbar-actions {
        justify-content: flex-start;
    }
}

.khmw-docs__layout {
    display: grid !important;
    grid-template-columns: 16rem minmax(0, 1fr);
    gap: 2rem;
    align-items: start;
}

@media (max-width: 820px) {
    .khmw-docs__layout { grid-template-columns: 1fr !important; }
}

.khmw-docs__cats {
    font-size: 0.95rem;
}

.khmw-docs__cat-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0.5rem 0 0 !important;
}

.khmw-docs__cat-list li { margin: 0 !important; padding: 0 !important; }

.khmw-docs__cat-group {
    margin-top: 0.9rem !important;
}

.khmw-docs__cat-head {
    display: inline-block;
    font-weight: 600;
    text-decoration: none;
    padding: 0.15rem 0;
}

.khmw-docs__cat-head:hover,
.khmw-docs__cat-head.is-active { text-decoration: underline; }

.khmw-docs__cat-sublist {
    list-style: none !important;
    padding: 0 0 0 0.25rem !important;
    margin: 0.35rem 0 0 !important;
}

.khmw-docs__cat-sublist li { margin: 0.15rem 0 !important; }

.khmw-docs__cat-item a {
    display: inline-block;
    padding: 0.15rem 0;
    text-decoration: none;
}

.khmw-docs__cat-item a:hover,
.khmw-docs__cat-item.is-active a { text-decoration: underline; font-weight: 600; }

.khmw-docs__results {
    padding: 1rem 1rem 0.5rem;
    background: rgba(0, 0, 0, 0.02);
    border-radius: 6px;
}

body.khmw-member-area .khmw-shell--docs .khmw-docs__layout {
    padding: 1.875rem !important;
    background: #ffffff !important;
    border-radius: 0 !important;
}

body.khmw-member-area .khmw-shell--docs .khmw-docs__cats,
body.khmw-member-area .khmw-shell--docs .khmw-docs__results {
    padding: 0 !important;
    background: transparent !important;
}

body.khmw-member-area .khmw-shell--docs .khmw-docs__filterbar {
    padding: 1.875rem !important;
    background: #ffffff !important;
    border-radius: 0 !important;
    max-width: none;
}

/*
body.khmw-member-area .khmw-shell--docs .khmw-docs__filterbar .khmw-input {
    border: 1px solid #d8dde6 !important;
    border-radius: 0 !important;
    padding: 0.65rem 0.85rem !important;
    color: #002266 !important;
    background: #fff !important;
}
*/

body.khmw-member-area .khmw-shell--docs .khmw-docs__filterbar-actions .khmw-btn--primary {
    border-radius: 999px !important;
    padding: 0.55rem 1.35rem !important;
    font-weight: 600 !important;
    background-color: #002266 !important;
    color: #ffffff !important;
    border: 1px solid #002266 !important;
    -webkit-text-fill-color: #ffffff !important;
}

body.khmw-member-area[data-form-submit="see-through"] .khmw-shell button.khmw-btn[type="submit"],
body.khmw-member-area .khmw-shell button.khmw-btn[type="submit"] {
    background-color: #ffffff !important;
    color: #002266 !important;
    border: 1px solid #002266 !important;
    -webkit-text-fill-color: #002266 !important;
}

body.khmw-member-area[data-form-submit="see-through"] .khmw-shell button.khmw-btn--primary[type="submit"],
body.khmw-member-area .khmw-shell button.khmw-btn--primary[type="submit"],
body.khmw-member-area .khmw-shell .khmw-btn.khmw-btn--outline.khmw-btn--primary {
    background-color: #002266 !important;
    color: #ffffff !important;
    border-color: #002266 !important;
    -webkit-text-fill-color: #ffffff !important;
}

body.khmw-member-area .khmw-shell button.khmw-btn--primary[type="submit"]:hover,
body.khmw-member-area .khmw-shell button.khmw-btn--primary[type="submit"]:focus {
    background-color: #001a4d !important;
    color: #ffffff !important;
    border-color: #001a4d !important;
}

body.khmw-member-area .khmw-shell--docs .khmw-docs__filterbar-actions .khmw-btn--text {
    color: #002266 !important;
    font-weight: 500;
}

.khmw-docs__count {
    margin: 0 0 0.75rem;
}

.khmw-docs__table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.95rem;
}

.khmw-docs__table th,
.khmw-docs__table td {
    text-align: left;
    padding: 0.6rem 0.5rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    vertical-align: middle;
}

.khmw-docs__table thead th {
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.75rem;
    opacity: 0.7;
    font-weight: 600;
}

.khmw-docs__col-title a { text-decoration: none; }
.khmw-docs__col-title a:hover,
.khmw-docs__col-title a:focus { text-decoration: underline; }

.khmw-docs__col-action {
    text-align: right;
    white-space: nowrap;
    width: 1%;
}

.khmw-docs__open {
    text-decoration: underline;
    font-weight: 500;
}

@media (max-width: 720px) {
    .khmw-docs__table thead { display: none; }
    .khmw-docs__table tr {
        display: grid;
        grid-template-columns: 1fr auto;
        gap: 0.2rem 0.5rem;
        padding: 0.5rem 0;
    }
    .khmw-docs__table td { border: 0; padding: 0.1rem 0; }
    .khmw-docs__col-title { grid-column: 1 / -1; }
    .khmw-docs__col-action { text-align: left; }
}

/* =========================================================================
   Historische leden  ([khmw_historische_leden])
   Figma node 85:4522 — zoek + A-Z + kaartgrid + "Toon meer".
   ========================================================================= */

.khmw-hl {
    margin: 0;
    font-family: Inter, system-ui, sans-serif;
    color: #002266;
}

.khmw-hl__toolbar {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    row-gap: 27px;
    column-gap: 1.5rem;
    margin-bottom: 32px;
}

.khmw-hl__search {
    display: flex;
    flex-direction: column;
    gap: 7px;
    grid-column: 1;
    grid-row: 1;
    max-width: 418px;
}

.khmw-hl__search-label {
    font-weight: 700;
    font-size: 12px;
    line-height: 16px;
    color: #002266;
}

.khmw-hl__search-input {
    width: 100%;
    height: 37px;
    padding: 0 13px;
    border: 1px solid #c6c8ca;
    border-radius: 0;
    background: #fff;
    font: inherit;
    font-size: 12px;
    line-height: 16px;
    color: #002266;
    box-sizing: border-box;
}

.khmw-hl__search-input::placeholder {
    color: #949494;
}

.khmw-hl__letters {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    grid-column: 1;
    grid-row: 2;
    align-self: end;
}

.khmw-hl__letter {
    display: inline-block;
    font-size: 16px;
    line-height: 24px;
    color: #002266;
    text-decoration: underline;
    min-width: 0;
    text-align: center;
}

.khmw-hl__letter:hover,
.khmw-hl__letter:focus {
    color: #0000ff;
}

.khmw-hl__letter.is-active {
    font-weight: 700;
    text-decoration: none;
}

.khmw-hl__count {
    margin: 0;
    font-size: 16px;
    line-height: 24px;
    text-align: right;
    white-space: nowrap;
    grid-column: 2;
    grid-row: 2;
    align-self: end;
}

@media (max-width: 720px) {
    .khmw-hl__toolbar {
        grid-template-columns: 1fr;
        row-gap: 16px;
    }

    .khmw-hl__search {
        max-width: none;
    }

    .khmw-hl__letters,
    .khmw-hl__count {
        grid-column: 1;
        grid-row: auto;
    }

    .khmw-hl__count {
        text-align: left;
    }
}

.khmw-hl__empty {
    padding: 2rem 0;
    text-align: center;
    font-style: italic;
    color: #002266;
    opacity: 0.75;
}

.khmw-hl__empty a {
    margin-left: 0.5rem;
    color: #002266;
    font-weight: 600;
}

/* --- Kaart-grid -------------------------------------------------------- */

.khmw-hl__grid {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 32px;
    align-items: stretch;
}

@media (max-width: 1100px) {
    .khmw-hl__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 640px) {
    .khmw-hl__grid { grid-template-columns: 1fr; }
}

.khmw-hl__card {
    display: flex;
    align-items: stretch;
    height: 100%;
    background: #f5f5f5;
    border: 0;
    padding: 0;
}

.khmw-hl__media {
    flex: 0 0 88px;
    width: 88px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: 8px 6px;
    overflow: hidden;
    background: #dde1e6;
    box-sizing: border-box;
}

.khmw-hl__media img {
    width: 76px;
    height: 100px;
    max-width: 76px;
    max-height: 100px;
    object-fit: contain;
    object-position: center top;
    display: block;
    flex-shrink: 0;
    background: #fff;
}

.khmw-hl__media--default img {
    width: 76px;
    height: 100px;
    object-fit: contain;
    background: #fff;
    filter: contrast(1.15);
}

.khmw-hl__media-placeholder {
    width: 76px;
    height: 100px;
    flex-shrink: 0;
    background: #fff;
    background-image:
        linear-gradient(to top right, transparent calc(50% - 1px), rgba(0, 34, 102, 0.25) 50%, transparent calc(50% + 1px)),
        linear-gradient(to top left,  transparent calc(50% - 1px), rgba(0, 34, 102, 0.25) 50%, transparent calc(50% + 1px));
}

.khmw-hl__body {
    flex: 1 1 auto;
    min-width: 0;
    min-height: 100%;
    padding: 10px 14px;
    background: #f5f5f5;
    box-sizing: border-box;
}

.khmw-hl__name {
    margin: 0 0 4px;
    font-size: 18px;
    font-weight: 600;
    line-height: 24px;
    color: #002266;
}

.khmw-hl__periode {
    margin: 0 0 6px;
    font-size: 12px;
    line-height: 16px;
    color: #002266;
}

.khmw-hl__fields {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 12px;
    line-height: 16px;
    color: #002266;
}

.khmw-hl__field--functie dd {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
}

.khmw-hl__field {
    margin: 0;
}

.khmw-hl__field dt {
    display: inline;
    margin: 0;
    font-weight: 700;
}

.khmw-hl__field dt::after { content: ' '; }

.khmw-hl__field dd {
    display: inline;
    margin: 0;
    font-weight: 400;
}

/* --- "Toon meer" ------------------------------------------------------- */

.khmw-hl__more {
    margin: 40px 0 0;
    text-align: center;
}

.khmw-hl__more-btn {
    display: inline-block;
    padding: 10px 20px;
    border: 1px solid #002266;
    border-radius: 5px;
    background: #fff;
    color: #002266 !important;
    text-decoration: none !important;
    font-weight: 700;
    font-size: 16px;
    line-height: 24px;
    box-shadow: none;
}

.khmw-hl__more-btn:hover,
.khmw-hl__more-btn:focus {
    background: #002266;
    color: #fff !important;
}

 
 
/* ======================================================================
   [khmw_publicaties] - publicatie-archief op /khmw/publicaties/
   Layout-only; thema vult kleuren/typografie in.
   ====================================================================== */

.khmw-publicaties {
    margin: 0;
    max-width: 1320px;
}

.khmw-publicaties__empty {
    padding: 2rem 0;
    text-align: center;
    opacity: 0.7;
}

.khmw-publicaties__grid {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 306px));
    gap: 32px;
    align-items: stretch;
    justify-content: start;
}
.khmw-publicaties__grid > li.khmw-publicaties__card {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}
.khmw-publicaties__grid > li.khmw-publicaties__card::before,
.khmw-publicaties__grid > li.khmw-publicaties__card::marker {
    content: none !important;
    display: none !important;
}
@media (max-width: 1400px) {
    .khmw-publicaties__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 1000px) {
    .khmw-publicaties__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
    .khmw-publicaties__grid { grid-template-columns: 1fr; }
}

.khmw-publicaties__card {
    display: flex !important;
    flex-direction: column;
    height: 100%;
    background: rgba(0, 34, 102, 0.05);
    text-align: left;
}

.khmw-publicaties__media {
    display: block;
    width: 100%;
    height: 187px;
    background: #dde1e6;
    overflow: hidden;
    text-decoration: none !important;
}
.khmw-publicaties__media img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center center;
    display: block;
}
.khmw-publicaties__media-placeholder {
    display: block;
    width: 100%;
    height: 187px;
    background: #dde1e6;
}

.khmw-publicaties__body {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    flex: 1 1 auto;
    gap: 16px;
    padding: 24px 24px 30px;
}

.khmw-publicaties__head {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.khmw-publicaties__title {
    margin: 0;
    font-size: 22px;
    font-weight: 600;
    line-height: 30px;
    color: #002266;
}
.khmw-publicaties__title a {
    text-decoration: none;
    color: inherit;
}
.khmw-publicaties__title a:hover,
.khmw-publicaties__title a:focus { text-decoration: underline; }

.khmw-publicaties__excerpt {
    margin: 0;
    font-size: 16px;
    line-height: 24px;
    color: #002266;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.khmw-publicaties__more {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    align-self: flex-start;
    padding-bottom: 2px;
    border-bottom: 1px solid #002266;
    font-size: 14px;
    line-height: 20px;
    color: #002266 !important;
    text-decoration: none !important;
}
.khmw-publicaties__more:hover,
.khmw-publicaties__more:focus {
    color: #002266 !important;
}
.khmw-publicaties__more-icon {
    display: inline-block;
    width: 16px;
    height: 16px;
    background: currentColor;
    mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='black' d='M3.33 8h9.34M8.67 4.67 12 8l-3.33 3.33' stroke='black' stroke-width='1.33' fill='none'/%3E%3C/svg%3E") center / contain no-repeat;
    -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='black' d='M3.33 8h9.34M8.67 4.67 12 8l-3.33 3.33' stroke='black' stroke-width='1.33' fill='none'/%3E%3C/svg%3E") center / contain no-repeat;
}

/* --- Toon meer ------------------------------------------------------- */

.khmw-publicaties__loadmore {
    margin: 40px 0 0;
    text-align: center;
}
.khmw-publicaties__loadmore-btn {
    display: inline-block;
    padding: 10px 20px;
    border: 1px solid #002266;
    border-radius: 5px;
    background: #fff;
    color: #002266 !important;
    text-decoration: none !important;
    font-weight: 700;
    font-size: 16px;
    line-height: 24px;
    box-shadow: none;
}
.khmw-publicaties__loadmore-btn:hover,
.khmw-publicaties__loadmore-btn:focus {
    background: #002266;
    color: #fff !important;
}

/* ====================================================================
 * [khmw_prijzen] — "Alle prijzen" met filterbalk + kaartgrid
 *
 * Kleuren komen zoveel mogelijk van het thema; we zetten alleen
 * overschrijfbare CSS-variabelen met nette KHMW-fallbacks.
 * ==================================================================== */
.khmw-prijzen {
    --khmw-prijzen-accent: #b8902d;          /* gouden labelkleur */
    --khmw-prijzen-title:  #002266;          /* KHMW-blauw voor titels */
    --khmw-prijzen-border: rgba(0, 0, 0, 0.12);
    margin: 0;
}

/* --- Filterbalk ----------------------------------------------------- */
.khmw-prijzen__filters {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.25rem 1.5rem;
    align-items: end;
    margin: 0 0 2.5rem;
}
.khmw-prijzen__field {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    min-width: 0;
}
.khmw-prijzen__label {
    text-transform: uppercase;
    letter-spacing: 0.07em;
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--khmw-prijzen-accent);
}
.khmw-prijzen__field--search {
    grid-column: 1 / -1;
}
.khmw-prijzen__search {
    width: 100%;
    padding: 0.6rem 0.75rem;
    border: 1px solid var(--khmw-prijzen-border);
    border-radius: 4px;
    background-color: #fff;
    font-size: 0.95rem;
    line-height: 1.3;
    color: var(--khmw-prijzen-title);
}
.khmw-prijzen__search:focus-visible {
    outline: 2px solid var(--khmw-prijzen-title);
    outline-offset: 1px;
}
.khmw-prijzen__select {
    width: 100%;
    padding: 0.6rem 0.75rem;
    border: 1px solid var(--khmw-prijzen-border);
    border-radius: 4px;
    background-color: #fff;
    font-size: 0.95rem;
    line-height: 1.3;
    color: var(--khmw-prijzen-title);
    cursor: pointer;
}
.khmw-prijzen__select:focus-visible {
    outline: 2px solid var(--khmw-prijzen-title);
    outline-offset: 1px;
}
.khmw-prijzen__reset {
    align-self: center;
    font-size: 0.85rem;
    text-decoration: underline;
}
.khmw-prijzen__submit {
    padding: 0.55rem 1rem;
    cursor: pointer;
}

@media (max-width: 900px) {
    .khmw-prijzen__filters { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 540px) {
    .khmw-prijzen__filters { grid-template-columns: 1fr; }
}

/* --- Kaartgrid ------------------------------------------------------ */
/* De kaarten komen van Salient's nectar_post_grid (zelfde markup/classes
 * als de "Inschrijving actief"-sectie). De layout/typografie/kleur daarvan
 * wordt door het thema verzorgd; wij voegen hier bewust niets aan toe. */
.khmw-prijzen__grid-wrap {
    margin: 0;
}
.khmw-prijzen--loading .khmw-prijzen__grid-wrap {
    opacity: 0.55;
    pointer-events: none;
    transition: opacity 0.15s ease;
}

/* --- "Meer prijzen" (client-side inklappen) ------------------------- */
.khmw-prijzen .is-hidden {
    display: none !important;
}
.khmw-prijzen__loadmore {
    margin: 2.5rem 0 0;
    text-align: center;
}
.khmw-prijzen__loadmore[hidden] {
    display: none;
}
.khmw-prijzen__loadmore-btn {
    display: inline-block;
    padding: 0.65rem 1.75rem;
    border: 1px solid var(--khmw-prijzen-title);
    border-radius: 999px;
    background: transparent;
    color: var(--khmw-prijzen-title);
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease;
}
.khmw-prijzen__loadmore-btn:hover,
.khmw-prijzen__loadmore-btn:focus-visible {
    background: var(--khmw-prijzen-title);
    color: #fff;
}

/* =================================================================
   Mobile — Mijn KHMW ledenzone (profiel, wijziging, shell, …)
   ================================================================= */

@media (max-width: 800px) {
    .khmw-shell {
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 0.75rem;
        margin: 0.75rem 0;
        max-width: 100%;
        overflow-x: hidden;
    }

    .khmw-shell__main,
    .khmw-shell__sidebar {
        min-width: 0;
        max-width: 100%;
    }

    /* Sidebar: inklapbaar "Menu" (accordion) i.p.v. lange verticale lijst */
    .khmw-shell__sidebar {
        padding-top: 0;
    }

    .khmw-shell__eyebrow {
        display: none;
    }

    /* Toggle-knop "Menu" — !important i.v.m. Salient button_roundness */
    body.khmw-member-area .khmw-shell__sidebar button.khmw-shell__toggle,
    .khmw-shell__toggle {
        display: flex !important;
        align-items: center;
        justify-content: center;
        position: relative;
        width: 100%;
        padding: 0.85rem 1rem;
        margin: 0;
        background: #fff;
        border: 1px solid #e1e8ed;
        border-radius: 0 !important;
        -webkit-border-radius: 0 !important;
        color: #002266;
        font-size: 1rem;
        font-weight: 600;
        line-height: 1.2;
        text-align: center;
        cursor: pointer;
        appearance: none;
        -webkit-appearance: none;
    }

    .khmw-shell__toggle-label {
        pointer-events: none;
    }

    .khmw-shell__toggle-icon {
        position: absolute;
        right: 1rem;
        top: 50%;
        width: 0.6rem;
        height: 0.6rem;
        border-right: 2px solid #002266;
        border-bottom: 2px solid #002266;
        transform: translateY(-70%) rotate(45deg);
        transition: transform 0.2s ease;
        pointer-events: none;
    }

    .khmw-shell__sidebar.is-open .khmw-shell__toggle-icon {
        transform: translateY(-30%) rotate(-135deg);
    }

    /* Lijst standaard ingeklapt; uitklappen bij .is-open */
    .khmw-shell__nav {
        display: none;
        margin-top: 0.5rem;
    }

    .khmw-shell__sidebar.is-open .khmw-shell__nav {
        display: block;
    }

    .khmw-shell__list {
        display: flex !important;
        flex-direction: column;
        align-items: stretch;
        gap: 0.5rem;
        width: 100%;
    }

    .khmw-shell__item {
        flex: 0 0 auto;
        width: 100%;
        display: block;
    }

    .khmw-shell__item--logout {
        margin-top: 0;
    }

    .khmw-shell .khmw-shell__item > .khmw-shell__link,
    .khmw-shell__link {
        display: block !important;
        box-sizing: border-box;
        width: 100%;
        padding: 0.85rem 1rem !important;
        margin: 0 !important;
        border: 1px solid #e1e8ed;
        border-radius: 0 !important;
        background: #fff;
        color: #002266 !important;
        font-size: 0.95rem !important;
        font-weight: 600 !important;
        text-align: center;
        text-decoration: none !important;
    }

    .khmw-shell .khmw-shell__item.is-active > .khmw-shell__link {
        background: #ae1639;
        border-color: #ae1639;
        border-radius: 0 !important;
        color: #fff !important;
    }

    .khmw-shell .khmw-shell__item--logout > .khmw-shell__link {
        background: #002266;
        border-color: #002266;
        border-radius: 0 !important;
        color: #fff !important;
    }

    .khmw-shell__item.is-active > .khmw-shell__link::after,
    .khmw-shell__item > .khmw-shell__link::after {
        display: none !important;
    }

    .khmw-shell__sublist {
        display: flex !important;
        flex-direction: column;
        align-items: stretch;
        gap: 0.4rem;
        padding: 0.4rem 0 0 0.75rem !important;
        margin: 0 !important;
        width: 100%;
    }

    .khmw-shell__subitem {
        width: 100%;
    }

    .khmw-shell__subitem .khmw-shell__link {
        font-size: 0.875rem !important;
        padding: 0.6rem 0.9rem !important;
    }

    .khmw-page__header {
        margin-bottom: 1rem;
    }

    .khmw-page__header--has-action {
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
        gap: 0.75rem;
    }

    .khmw-page__header-text {
        flex: 0 0 auto;
    }

    .khmw-page__header-action {
        width: 100%;
        margin-top: 0.75rem;
        padding-top: 0;
    }

    .khmw-page__header-action .khmw-btn--action,
    .khmw-page__header-action .khmw-btn--bordeaux-line,
    .khmw-page__header-action .khmw-btn--bordeaux-fill {
        width: 100%;
        margin: 0 !important;
        justify-content: center;
        white-space: normal;
        text-align: center;
    }

    .khmw-shell--profile .khmw-page__header--has-action {
        gap: 0;
        margin-bottom: 1.5rem;
    }

    .khmw-shell--profile .khmw-page__header-text {
        margin-bottom: 0;
    }

    .khmw-dashboard__event {
        flex-wrap: wrap;
        gap: 0.75rem;
    }

    .khmw-dashboard__event .khmw-btn--pill {
        margin-left: 0;
        align-self: stretch;
        text-align: center;
    }
}

@media (max-width: 690px) {
    .khmw-page__title {
        font-size: 1.75rem !important;
        line-height: 1.2 !important;
    }

    .khmw-page__meta {
        font-size: 0.875rem;
    }

    .khmw-profile-grid,
    .khmw-wijziging-grid,
    .khmw-security-grid {
        gap: 1rem !important;
    }

    .khmw-wijziging-actions,
    .khmw-form-actions,
    .khmw-modal__actions {
        flex-direction: column;
        align-items: stretch;
    }

    .khmw-wijziging-actions .khmw-btn,
    .khmw-form-actions .khmw-btn,
    .khmw-modal__actions .khmw-btn {
        width: 100%;
        justify-content: center;
    }

    .khmw-btn--bordeaux-fill,
    .khmw-btn--bordeaux-line,
    .khmw-btn--action {
        white-space: normal;
        text-align: center;
    }

    .khmw-wijziging-hero__media {
        display: flex;
        justify-content: center;
    }

    .khmw-wijziging-hero__aside {
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
        width: 100%;
    }

    .khmw-modal {
        padding: 1rem;
        align-items: center;
    }

    .khmw-modal__panel {
        width: 100%;
        max-height: calc(100dvh - 2rem);
        padding: 1.25rem;
    }

    .khmw-modal__title {
        font-size: 1.5rem;
        line-height: 1.25;
    }

    .khmw-docs__table-wrap {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .khmw-hero--avatar .khmw-hero__body {
        width: 100%;
    }
}

@media (max-width: 540px) {
    .khmw-profile-hero {
        padding: 1.25rem !important;
    }

    .khmw-profile-hero__media {
        max-width: 140px;
        margin: 0 auto;
    }

    .khmw-profile-hero__body {
        width: 100%;
    }

    .khmw-detail-card,
    .khmw-wijziging-card {
        padding: 1rem !important;
    }
}
