/* ==========================================================================
   Faillissement.org — eigen editorial "openbaar register"-stijl.
   Inter + nl.legal-merkkleuren als subtiele knipoog. Geen zwevende AI-kaarten:
   hairline-scheidingen, sterke typografie, tabulaire cijfers, rust.
   ========================================================================== */

:root {
    /* nl.legal merkkleuren (exact) */
    --purple:       #4f2c75;
    --purple-deep:  #3b2058;
    --purple-05:    rgba(79,44,117,.05);
    --purple-10:    rgba(79,44,117,.10);
    --purple-20:    rgba(79,44,117,.20);
    --green:        #73b05d;
    --green-fresh:  #428628;
    --green-tint:   rgba(66,134,40,.10);

    --ink:          #1a1a1a;
    --ink-2:        #3d3d42;
    --ink-soft:     #6a6a72;
    --ink-faint:    #9a9aa2;

    --line:         #e8e8ec;
    --line-strong:  #d8d8de;
    --paper:        #ffffff;
    --paper-2:      #fafafa;

    --maxw:   1080px;
    --r:      6px;
    --mono:   "SFMono-Regular", ui-monospace, "JetBrains Mono", Menlo, Consolas, monospace;
    --sans:   'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }

body {
    margin: 0;
    background: var(--paper);
    color: var(--ink);
    font-family: var(--sans);
    font-size: 15.5px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

a { color: var(--purple); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 2px; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.tnum { font-variant-numeric: tabular-nums; }
.mono { font-family: var(--mono); }

/* ==========================================================================
   Masthead
   ========================================================================== */
/* Topbar (niet-sticky): groot logo links + advertentie rechts */
.topbar { background: #fff; border-bottom: 1px solid var(--line); }
.topbar-inner {
    max-width: var(--maxw); margin: 0 auto; padding: 14px 24px;
    min-height: 120px; display: flex; align-items: center; gap: 28px;
}
.brand-logo { display: inline-flex; align-items: center; }
.brand-logo:hover { text-decoration: none; }
.masthead-logo { height: 120px; width: auto; display: block; }

/* Advertentieruimte */
.ad-slot {
    margin-left: auto;
    background: var(--paper-2);
    border: 1px dashed var(--line-strong);
    border-radius: var(--r);
    display: grid; place-items: center;
    flex: 0 0 auto;
}
.ad-leaderboard { width: 728px; height: 90px; }
.ad-label {
    font-size: 11px; text-transform: uppercase; letter-spacing: .08em;
    color: var(--ink-faint);
}

/* Subnav (sticky, dun) */
.subnav {
    border-bottom: 1px solid var(--line);
    position: sticky; top: 0; z-index: 20;
    background: rgba(255,255,255,.94);
    backdrop-filter: saturate(180%) blur(8px);
}
.subnav-inner {
    max-width: var(--maxw); margin: 0 auto; padding: 0 24px;
    display: flex; align-items: center; gap: 4px; height: 46px;
}
.subnav a {
    font-size: 14px; font-weight: 500; color: var(--ink-soft);
    padding: 6px 12px; border-radius: 5px;
}
.subnav a:hover { color: var(--ink); background: var(--paper-2); text-decoration: none; }
.subnav a.active { color: var(--purple); background: var(--purple-05); }
.subnav-meta { margin-left: auto; font-size: 12.5px; color: var(--ink-faint); }
.subnav-adslot { margin-left: auto; }

/* ==========================================================================
   Pagina-koppen
   ========================================================================== */
.page-head { padding: 34px 0 18px; border-bottom: 1px solid var(--line); margin-bottom: 4px; }
.page-head h1 {
    font-size: 27px; font-weight: 700; letter-spacing: -.02em;
    margin: 0 0 6px; line-height: 1.15;
}
.page-head .sub { color: var(--ink-soft); font-size: 15px; margin: 0; }

/* Statbalk (editorial, geen kaarten) */
.stats { display: flex; gap: 32px; padding: 18px 0 6px; flex-wrap: wrap; }
.stat { display: flex; flex-direction: column; }
.stat .n { font-size: 22px; font-weight: 700; letter-spacing: -.02em; }
.stat .l { font-size: 12.5px; color: var(--ink-soft); text-transform: uppercase; letter-spacing: .05em; }

/* ==========================================================================
   Register (lijst van zaken) — rij-stijl, geen cards
   ========================================================================== */
.reg { margin: 6px 0 0; }
.reg-row {
    display: grid;
    grid-template-columns: 3px 1fr auto;
    gap: 0 16px; align-items: center;
    padding: 15px 8px 15px 0;
    border-bottom: 1px solid var(--line);
    color: var(--ink);
}
.reg-row:hover { background: var(--purple-05); text-decoration: none; }
.reg-accent { align-self: stretch; border-radius: 3px; background: var(--line-strong); }
.reg-accent.is-active  { background: var(--purple); }
.reg-accent.is-closed  { background: var(--line-strong); }
.reg-accent.is-neutral { background: var(--line-strong); }

.reg-main { min-width: 0; padding-left: 14px; }
.reg-name {
    font-size: 16.5px; font-weight: 650; letter-spacing: -.01em;
    color: var(--ink); display: flex; align-items: center; gap: 9px; flex-wrap: wrap;
}
.reg-row:hover .reg-name { color: var(--purple); }
.reg-meta {
    margin-top: 3px; font-size: 13px; color: var(--ink-soft);
    display: flex; flex-wrap: wrap; gap: 2px 14px;
}
.reg-meta .sep { color: var(--ink-faint); }

.reg-right { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.reg-soort { font-size: 12px; font-weight: 600; color: var(--ink-2); text-transform: uppercase; letter-spacing: .04em; }
.reg-date  { font-size: 13px; color: var(--ink-soft); }
.reg-nr    { font-family: var(--mono); font-size: 11.5px; color: var(--ink-faint); }

/* Kleine type-markering (geen pill) */
.tag {
    font-size: 11px; font-weight: 600; letter-spacing: .03em; text-transform: uppercase;
    color: var(--ink-soft); border: 1px solid var(--line-strong);
    padding: 1px 6px; border-radius: 4px; line-height: 1.5;
}
.tag.is-bedrijf { color: var(--purple); border-color: var(--purple-20); background: var(--purple-05); }

.empty {
    margin: 22px 0; padding: 22px;
    border: 1px dashed var(--line-strong); border-radius: var(--r);
    color: var(--ink-soft); background: var(--paper-2);
}

/* Paginatie */
.pager { display: flex; align-items: center; justify-content: space-between; padding: 22px 0 40px; }
.pager a {
    font-size: 14px; font-weight: 500; padding: 8px 14px;
    border: 1px solid var(--line-strong); border-radius: var(--r); color: var(--ink);
}
.pager a:hover { border-color: var(--purple); color: var(--purple); text-decoration: none; }
.pager .info { font-size: 13px; color: var(--ink-soft); }
.pager .spacer { flex: 1; }

/* Hint onderaan een gecapte (brede) browse-lijst */
.cap-hint {
    margin: 14px 0 40px;
    padding: 14px 16px;
    background: var(--purple-05);
    border: 1px solid var(--purple-20);
    border-radius: var(--r);
    color: var(--ink-2);
    font-size: 14px;
    line-height: 1.5;
}

/* ==========================================================================
   Zoeken: filter-rail + resultaten
   ========================================================================== */
.zoek-grid { display: grid; grid-template-columns: 248px minmax(0,1fr); gap: 0 40px; align-items: start; }
.zoek-main { min-width: 0; }
.zoek-main .page-head { padding-top: 26px; }
.filter-rail { position: sticky; top: 58px; padding-top: 26px; }
.filter-block { display: flex; flex-direction: column; margin-bottom: 15px; }
.filter-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--ink-soft); margin-bottom: 6px; }
.filters input[type="text"], .filters input[type="date"], .filters select {
    width: 100%; padding: 8px 10px;
    border: 1px solid var(--line-strong); border-radius: var(--r);
    font: inherit; font-size: 14px; background: #fff; color: var(--ink);
}
.filters select { cursor: pointer; }
.filters input:focus, .filters select:focus {
    border-color: var(--purple); outline: none; box-shadow: 0 0 0 3px var(--purple-10);
}
.filter-daterange { display: flex; align-items: center; gap: 6px; }
.filter-daterange input { flex: 1; min-width: 0; }
.filter-daterange span { color: var(--ink-faint); }
.filter-actions { margin-top: 18px; display: flex; flex-direction: column; gap: 10px; }
.filter-actions button {
    width: 100%; padding: 10px; cursor: pointer;
    background: var(--purple); color: #fff; border: 0; border-radius: var(--r);
    font: inherit; font-weight: 600; font-size: 14px;
}
.filter-actions button:hover { background: var(--purple-deep); }
.filter-clear { text-align: center; font-size: 13px; color: var(--ink-soft); }
.filter-clear:hover { color: var(--purple); }

/* ==========================================================================
   Detailpagina
   ========================================================================== */
.doc-head { padding: 14px 0 22px; border-bottom: 1px solid var(--line-strong); }
.doc-eyebrow {
    display: flex; align-items: center; gap: 10px;
    font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .06em;
    color: var(--ink-soft); margin-bottom: 10px;
}
.doc-eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--line-strong); }
.doc-eyebrow .dot.is-active { background: var(--purple); }
.doc-eyebrow .dot.is-closed { background: var(--line-strong); }
.doc-head h1 { font-size: 30px; font-weight: 700; letter-spacing: -.025em; margin: 0; line-height: 1.1; }
.doc-sub { margin-top: 10px; display: flex; flex-wrap: wrap; gap: 6px 18px; color: var(--ink-soft); font-size: 14px; }
.doc-sub .insnr { font-family: var(--mono); color: var(--ink-2); }
.doc-status {
    margin-top: 16px; font-size: 14.5px; color: var(--ink-2);
    padding-left: 12px; border-left: 3px solid var(--purple);
}
.doc-status.is-closed { border-left-color: var(--line-strong); }

/* Breadcrumb + SEO-introalinea */
.breadcrumb {
    display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
    padding-top: 22px; font-size: 13px; color: var(--ink-soft);
}
.breadcrumb a { color: var(--ink-soft); }
.breadcrumb a:hover { color: var(--purple); }
.bc-sep { color: var(--ink-faint); }
.bc-current { color: var(--ink-2); }
.doc-intro {
    font-size: 16px; line-height: 1.6; color: var(--ink-2);
    margin: 18px 0 0; max-width: 72ch;
}

/* Dossier-layout: vaste kerngegevens links, inhoud (verslagen + verloop) rechts */
.doc-grid { display: grid; grid-template-columns: 320px minmax(0,1fr); gap: 0 48px; align-items: start; }
.doc-main { min-width: 0; }
.doc-aside { position: sticky; top: 58px; display: flex; flex-direction: column; gap: 14px; padding-top: 24px; }
.info-card {
    border: 1px solid var(--line);
    border-radius: var(--r);
    background: #fff;
    padding: 18px 20px;
    box-shadow: var(--shadow);
}
.info-card > h3 {
    font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em;
    color: var(--ink-2); margin: 0 0 14px;
    padding-bottom: 11px; border-bottom: 1px solid var(--line);
}
/* Subtiel merkaccent op de primaire kaart */
.info-card--accent { border-top: 3px solid var(--purple); }

/* Compacte layout voor verse zaken met weinig inhoud: één kolom, geen lege rechterhelft */
.doc-grid.is-compact { grid-template-columns: minmax(0, 720px); gap: 0; }
.doc-grid.is-compact .doc-aside { position: static; padding-top: 24px; }
.doc-grid.is-compact .facts-c { grid-template-columns: 1fr 1fr; gap: 12px 28px; }
.doc-grid.is-compact .doc-main { padding-top: 4px; }
.facts-c { display: grid; grid-template-columns: 1fr; gap: 11px; margin: 0; }
.facts-c .row { display: flex; flex-direction: column; gap: 1px; }
.facts-c dt { font-size: 11.5px; text-transform: uppercase; letter-spacing: .04em; color: var(--ink-faint); }
.facts-c dd { margin: 0; font-size: 14.5px; color: var(--ink); }
.facts-c dd.mono { font-family: var(--mono); font-size: 13.5px; }
.aside-curator { padding: 11px 0 0; border-top: 1px solid var(--line); margin-top: 4px; }
.aside-curator:first-of-type { border-top: 0; margin-top: 0; padding-top: 0; }

.section { padding: 26px 0; border-bottom: 1px solid var(--line); }
.section:last-of-type { border-bottom: 0; }
.section > h2 {
    font-size: 12.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em;
    color: var(--ink-soft); margin: 0 0 16px;
}

.facts { display: grid; grid-template-columns: 200px 1fr; gap: 11px 20px; margin: 0; }
.facts dt { color: var(--ink-soft); font-size: 14px; }
.facts dd { margin: 0; font-size: 15px; color: var(--ink); }
.facts dd.mono { font-family: var(--mono); font-size: 14px; }

.hn-list { margin: 0; padding: 0; list-style: none; display: flex; flex-wrap: wrap; gap: 8px; }
.hn-list li { font-size: 13.5px; padding: 3px 10px; border: 1px solid var(--line-strong); border-radius: 999px; color: var(--ink-2); }
.hn-list .voorheen { color: var(--ink-faint); }

.curator { padding: 14px 0; border-top: 1px solid var(--line); }
.curator:first-of-type { border-top: 0; padding-top: 0; }
.curator .nm { font-weight: 650; display: flex; align-items: center; gap: 10px; }
.curator .role { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; color: var(--purple); }
.curator .info { margin-top: 5px; font-size: 13.5px; color: var(--ink-soft); display: flex; flex-direction: column; gap: 2px; }
.curator .info a { color: var(--ink-soft); }
.curator .info a:hover { color: var(--purple); }

/* Verslagen */
.reports { list-style: none; margin: 0; padding: 0; }
.reports li { display: flex; align-items: center; gap: 14px; padding: 11px 0; border-top: 1px solid var(--line); }
.reports li:first-child { border-top: 0; }
.reports .vdate { font-size: 13px; color: var(--ink-soft); min-width: 96px; font-variant-numeric: tabular-nums; }
.reports .vlink { font-weight: 550; flex: 1; }
.reports .vpdf {
    font-size: 11px; font-weight: 600; letter-spacing: .03em; text-transform: uppercase;
    color: var(--ink-soft); border: 1px solid var(--line-strong); border-radius: 4px; padding: 1px 6px;
}
.reports .veind {
    font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .03em;
    color: var(--green-fresh); background: var(--green-tint); border: 1px solid rgba(66,134,40,.25);
    border-radius: 4px; padding: 1px 7px;
}
/* Inklapbare staart van lange verslaglijsten */
.reports-more { margin-top: 2px; }
.reports-more > summary {
    list-style: none; cursor: pointer;
    font-size: 13px; font-weight: 600; color: var(--purple);
    padding: 11px 0; border-top: 1px solid var(--line);
}
.reports-more > summary::-webkit-details-marker { display: none; }
.reports-more > summary::before { content: "▸ "; }
.reports-more[open] > summary::before { content: "▾ "; }
.reports-more[open] > summary { color: var(--ink-soft); }
.section-count { font-weight: 400; color: var(--ink-faint); }

/* Verloop / tijdlijn */
.timeline { list-style: none; margin: 0; padding: 0; }
.timeline li { position: relative; padding: 0 0 18px 22px; border-left: 2px solid var(--line); margin-left: 4px; }
.timeline li:last-child { border-left-color: transparent; padding-bottom: 0; }
.timeline li::before {
    content: ""; position: absolute; left: -5px; top: 4px;
    width: 8px; height: 8px; border-radius: 50%;
    background: #fff; border: 2px solid var(--purple);
}
.timeline .td { font-size: 12.5px; color: var(--ink-faint); font-variant-numeric: tabular-nums; }
.timeline .tt { font-size: 14.5px; color: var(--ink); margin-top: 1px; }

.back { display: inline-block; margin: 26px 0 48px; font-size: 14px; color: var(--ink-soft); }
.back:hover { color: var(--purple); }

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer { border-top: 1px solid var(--line); background: var(--paper-2); margin-top: 20px; }
.footer-inner {
    max-width: var(--maxw); margin: 0 auto; padding: 26px 24px 40px;
    display: flex; flex-wrap: wrap; gap: 8px 30px;
    color: var(--ink-soft); font-size: 12.5px;
}
.footer-inner .fbrand { font-weight: 600; color: var(--ink-2); }

/* ==========================================================================
   Responsive
   ========================================================================== */
/* Leaderboard (728px) past niet naast het logo onder ~1040px → verbergen.
   Op smallere schermen later eventueel een mobiel bannerformaat (320×100). */
@media (max-width: 1040px) {
    .ad-leaderboard { display: none; }
}
/* Onder 960px: dossier + zoeken worden één kolom */
@media (max-width: 960px) {
    .doc-grid { grid-template-columns: 1fr; gap: 0; }
    .doc-aside { position: static; flex-direction: column; padding-top: 18px; }
    .zoek-grid { grid-template-columns: 1fr; gap: 0; }
    .filter-rail { position: static; padding-top: 18px; }
    .zoek-main .page-head { padding-top: 8px; }
}
@media (max-width: 720px) {
    .topbar-inner { gap: 14px; min-height: 0; padding: 12px 24px; }
    .masthead-logo { height: 76px; }
    .reg-right { display: none; }
    .reg-row { grid-template-columns: 3px 1fr; padding-right: 0; }
    .facts { grid-template-columns: 1fr; gap: 2px 0; }
    .facts dt { margin-top: 10px; }
}

/* ============================================================
   App / account / authenticatie  (layout_app.php + auth-views)
   ============================================================ */
.app-body { background: var(--paper-2); }
.app-topbar .topbar-inner { justify-content: space-between; }
.app-back { font-size: 14px; color: var(--ink-soft); text-decoration: none; font-weight: 600; }
.app-back:hover { color: var(--purple); }
.app-main { max-width: 1080px; margin: 0 auto; padding: 30px 24px 64px; }

.auth-wrap { max-width: 480px; margin: 28px auto 0; }
.auth-wrap--breed { max-width: 760px; }
.auth-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r); padding: 32px 32px 28px; }
.auth-title { font-size: 23px; font-weight: 800; letter-spacing: -.3px; margin: 0 0 6px; color: var(--ink); }
.auth-sub { color: var(--ink-soft); margin: 0 0 20px; font-size: 15px; line-height: 1.5; }

.veld { margin: 0 0 15px; }
.veld > label { display: block; font-size: 13px; font-weight: 600; color: var(--ink-2); margin: 0 0 6px; }
.veld input[type=text], .veld input[type=email], .veld input[type=tel], .veld input[type=password] {
    width: 100%; box-sizing: border-box; font: inherit; font-size: 15px;
    padding: 10px 12px; border: 1px solid var(--line-strong); border-radius: var(--r);
    background: var(--paper); color: var(--ink); -webkit-appearance: none; }
.veld input:focus { outline: none; border-color: var(--purple); box-shadow: 0 0 0 3px var(--purple-10); }
.veld input[readonly] { background: var(--paper-2); color: var(--ink-soft); cursor: default; }
.veld .hint { font-size: 12px; color: var(--ink-faint); margin: 5px 0 0; }
.veld.is-fout input { border-color: #b42318; box-shadow: 0 0 0 3px rgba(180,35,24,.08); }
.veld .fout { font-size: 12px; color: #b42318; margin: 5px 0 0; }

.veld-rij { display: grid; grid-template-columns: 1fr 1fr; gap: 0 14px; }
.veld-rij--adres { grid-template-columns: 1fr .9fr; }

fieldset.blok { border: 0; border-top: 1px solid var(--line); margin: 20px 0 0; padding: 18px 0 0; }
fieldset.blok > legend { font-size: 12px; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-faint); font-weight: 700; padding: 0; margin: 0 0 13px; }

.check { display: flex; gap: 10px; align-items: flex-start; font-size: 14px; color: var(--ink-2); line-height: 1.45; }
.check input { margin-top: 3px; flex: none; }

.knop { display: inline-block; font: inherit; font-weight: 600; font-size: 15px; cursor: pointer;
    padding: 11px 22px; border-radius: var(--r); border: 1px solid var(--purple);
    background: var(--purple); color: #fff; text-decoration: none; }
.knop:hover { background: var(--purple-deep); border-color: var(--purple-deep); }
.knop--breed { width: 100%; box-sizing: border-box; text-align: center; }
.knop--rand { background: #fff; color: var(--purple); }
.knop--rand:hover { background: var(--purple-05); }
.knop--klein { padding: 7px 14px; font-size: 13px; }
.knop-vorm { display: inline; }

.auth-alt { margin: 18px 0 0; font-size: 14px; color: var(--ink-soft); text-align: center; }
.auth-alt a { color: var(--purple); font-weight: 600; }

.melding { border-radius: var(--r); padding: 12px 14px; font-size: 14px; line-height: 1.5; margin: 0 0 18px; border: 1px solid; }
.melding--info { background: var(--purple-05); border-color: var(--purple-20); color: var(--ink-2); }
.melding--fout { background: rgba(180,35,24,.06); border-color: rgba(180,35,24,.25); color: #842018; }
.melding--succes { background: var(--green-tint); border-color: rgba(66,134,40,.3); color: #2c5e1c; }

/* Foutpagina (500): referentiecode + technische details */
.foutcode { font-family: ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace; letter-spacing: .5px; }
.fout-details {
    background: var(--paper-2, #f6f5f3); border: 1px solid var(--line); border-radius: var(--r);
    padding: 14px 16px; font-size: 12.5px; line-height: 1.55; overflow-x: auto;
    white-space: pre-wrap; word-break: break-word; color: var(--ink-soft); margin: 8px 0 0;
}

.acc-head { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; margin: 0 0 22px; }
.acc-head h1 { font-size: 22px; font-weight: 800; letter-spacing: -.3px; margin: 0; }
.acc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.acc-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r); padding: 20px 22px; }
.acc-card h2 { font-size: 13px; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-faint); font-weight: 700; margin: 0 0 12px; }
.acc-card dl { margin: 0; display: grid; grid-template-columns: auto 1fr; gap: 7px 16px; font-size: 14px; }
.acc-card dt { color: var(--ink-soft); }
.acc-card dd { margin: 0; color: var(--ink); }
.badge { display: inline-block; font-size: 12px; font-weight: 700; padding: 2px 9px; border-radius: 999px; background: var(--purple-10); color: var(--purple); }
.perm-list { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 6px; }
.perm-list li { font-size: 12px; background: var(--paper-2); border: 1px solid var(--line); border-radius: 999px; padding: 3px 10px; color: var(--ink-2); }

@media (max-width: 620px) {
    .veld-rij, .veld-rij--adres, .acc-grid { grid-template-columns: 1fr; }
    .auth-card { padding: 24px 20px; }
}

/* Account-subnavigatie */
.acc-bar { display: flex; justify-content: space-between; align-items: center; gap: 16px; margin: 28px 0 24px; border-bottom: 1px solid var(--line); }
.acc-nav { display: flex; gap: 2px; flex-wrap: wrap; }
.acc-nav a { padding: 10px 14px; font-size: 14px; font-weight: 600; color: var(--ink-soft); text-decoration: none; border-bottom: 2px solid transparent; margin-bottom: -1px; }
.acc-nav a:hover { color: var(--ink); }
.acc-nav a.is-actief { color: var(--purple); border-bottom-color: var(--purple); }
.acc-bar form { margin: 0 0 8px; }

/* Inloggen / Registreren in de subnav (rechts) */
.subnav-auth { margin-left: auto; display: flex; align-items: center; gap: 6px; flex: none; }
.subnav a.subnav-login { border: 1px solid var(--line-strong); color: var(--ink-2); }
.subnav a.subnav-login:hover { border-color: var(--purple); color: var(--purple); background: transparent; }
.subnav a.subnav-cta { background: var(--purple); color: #fff; font-weight: 600; }
.subnav a.subnav-cta:hover { background: var(--purple-deep); color: #fff; }
@media (max-width: 640px) {
    .subnav-inner { overflow-x: auto; }
    .subnav-auth { margin-left: 6px; }
}

/* Uitloggen-knop in de subnav (ingelogd) */
.subnav-logout-form { margin: 0; display: inline-flex; }
.subnav button.subnav-logout { font: inherit; font-size: 14px; font-weight: 500; cursor: pointer; padding: 6px 12px; border-radius: 5px; border: 1px solid var(--line-strong); color: var(--ink-2); background: #fff; }
.subnav button.subnav-logout:hover { border-color: var(--purple); color: var(--purple); }

/* Passkeys */
.pk-list { list-style: none; margin: 4px 0 0; padding: 0; }
.pk-item { display: flex; align-items: center; gap: 12px; padding: 12px 0; border-top: 1px solid var(--line); font-size: 14px; }
.pk-item:first-child { border-top: 0; }
.pk-name { font-weight: 600; color: var(--ink); }
.pk-meta { color: var(--ink-faint); font-size: 12.5px; }
.pk-item form { margin: 0 0 0 auto; }
.pk-del { font: inherit; font-size: 13px; cursor: pointer; background: none; border: 0; color: #b42318; padding: 4px 6px; border-radius: 4px; }
.pk-del:hover { background: rgba(180,35,24,.07); text-decoration: underline; }
.pk-login { margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--line); text-align: center; }
.pk-login .hint { display: block; margin-top: 8px; }

/* Aan/uit-rijen in Beveiliging (passkey verplicht, 2FA) */
.pk-toggle { display: flex; align-items: center; gap: 16px; justify-content: space-between; }
.pk-toggle > div { min-width: 0; }
.pk-toggle form { margin: 0; flex: none; }

/* Volg-icoon in de zoekresultaten */
.reg-rij { position: relative; }
.reg-rij > .reg-row { padding-right: 38px; }
.volg-knop { position: absolute; top: 50%; right: 6px; transform: translateY(-50%); z-index: 2;
    background: none; border: 0; padding: 5px; cursor: pointer; line-height: 0; color: var(--line-strong);
    border-radius: 5px; transition: color .12s ease; }
.volg-knop svg { fill: none; stroke: currentColor; stroke-width: 1.7; display: block; }
.volg-knop:hover { color: var(--ink-soft); background: var(--paper-2); }
.volg-knop.is-gevolgd { color: var(--purple); }
.volg-knop.is-gevolgd svg { fill: currentColor; stroke: currentColor; }

/* Select in formulieren (alert-criteria) */
.veld select { width: 100%; box-sizing: border-box; font: inherit; font-size: 15px; padding: 10px 12px;
    border: 1px solid var(--line-strong); border-radius: var(--r); background: var(--paper); color: var(--ink); }
.veld select:focus { outline: none; border-color: var(--purple); box-shadow: 0 0 0 3px var(--purple-10); }
.pk-name a { color: var(--ink); font-weight: 600; text-decoration: none; }
.pk-name a:hover { color: var(--purple); }

/* Volg-ster opvallender + grote volg-knop (detailpagina) */
.volg-knop { color: var(--ink-faint); }
.volg-knop:hover { color: var(--purple); background: var(--purple-05); }
.volg-knop--groot { position: static; transform: none; display: inline-flex; align-items: center; gap: 8px;
    padding: 9px 18px; border: 1.5px solid var(--purple); border-radius: var(--r); color: var(--purple);
    font: inherit; font-size: 15px; font-weight: 600; }
.volg-knop--groot:hover { background: var(--purple-05); color: var(--purple); }
.volg-knop--groot svg { fill: none; stroke: currentColor; stroke-width: 1.7; }
.volg-knop--groot.is-gevolgd { background: var(--purple); border-color: var(--purple); color: #fff; }
.volg-knop--groot.is-gevolgd svg { fill: #fff; stroke: #fff; }
.doc-actions { margin-top: 16px; }

/* "Alert van deze zoekopdracht" + zoek-kop met actie */
.page-head--actie { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.alert-cta { display: inline-flex; align-items: center; gap: 7px; padding: 8px 14px; border-radius: var(--r);
    background: var(--purple); color: #fff; font-size: 14px; font-weight: 600; text-decoration: none; white-space: nowrap; flex: none; margin-bottom: 4px; }
.alert-cta:hover { background: var(--purple-deep); color: #fff; text-decoration: none; }
.alert-cta svg { fill: currentColor; }

/* Live preview van de alert */
.alert-preview { font-size: 14px; color: var(--ink-faint); margin: 0 0 16px; }
.alert-preview.is-actief { color: var(--purple); background: var(--purple-05); border: 1px solid var(--purple-20); border-radius: var(--r); padding: 10px 12px; }

/* Gratis registreren-CTA op de loginpagina */
.reg-cta { margin-top: 22px; padding-top: 20px; border-top: 1px solid var(--line); text-align: center; }
.reg-cta-titel { font-weight: 600; color: var(--ink-2); margin: 0 0 12px; font-size: 15px; }
.knop--groen { background: var(--green-fresh); border-color: var(--green-fresh); color: #fff; }
.knop--groen:hover { background: #356c20; border-color: #356c20; color: #fff; }

/* ── Admin-paneel ─────────────────────────────────────────────────────────── */

/* "Beheer"-link in de subnav (alleen voor admins) */
.subnav a.subnav-admin { border: 1px solid var(--purple-20); color: var(--purple); font-weight: 600; }
.subnav a.subnav-admin:hover { border-color: var(--purple); background: var(--purple-05); color: var(--purple); }

/* Impersonatie-banner (bovenaan, op iedere pagina tijdens impersonatie) */
.imp-banner { background: #6a3fa0; color: #fff; }
.imp-banner-inner { max-width: var(--maxw); margin: 0 auto; padding: 9px 24px; display: flex; align-items: center;
    justify-content: space-between; gap: 14px; font-size: 13.5px; }
.imp-banner strong { font-weight: 700; }
.imp-banner form { margin: 0; }
.imp-stop { font: inherit; font-size: 13px; font-weight: 600; cursor: pointer; color: #fff; background: rgba(255,255,255,.16);
    border: 1px solid rgba(255,255,255,.5); border-radius: 5px; padding: 5px 12px; white-space: nowrap; }
.imp-stop:hover { background: rgba(255,255,255,.28); }

/* Admin-subnavbalk: tabs links, "Mijn account" rechts */
.acc-bar--admin { margin-top: 24px; }
.adm-terug { font-size: 13.5px; font-weight: 600; color: var(--ink-soft); text-decoration: none; margin-bottom: 8px; white-space: nowrap; }
.adm-terug:hover { color: var(--purple); }
.adm-count { font-size: 14px; font-weight: 600; color: var(--ink-faint); }

/* Stat-tegels */
.adm-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.adm-stat { display: flex; flex-direction: column; gap: 3px; padding: 16px 18px; background: var(--paper);
    border: 1px solid var(--line); border-radius: var(--r); text-decoration: none; color: inherit; }
a.adm-stat:hover { border-color: var(--purple-20); background: var(--purple-05); }
.adm-stat-num { font-size: 26px; font-weight: 800; letter-spacing: -.5px; color: var(--ink); font-variant-numeric: tabular-nums; }
.adm-stat-label { font-size: 12.5px; color: var(--ink-soft); }
.adm-stat--let .adm-stat-num { color: #b42318; }

/* Beschrijvingslijst in admin-kaarten */
.adm-dl { margin: 0; display: grid; grid-template-columns: auto 1fr; gap: 7px 16px; font-size: 14px; }
.adm-dl dt { color: var(--ink-soft); }
.adm-dl dd { margin: 0; color: var(--ink); }
.adm-strong { font-weight: 700; color: var(--ink); }

/* Tabellen */
.adm-tablewrap { overflow-x: auto; }
.adm-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.adm-table th { text-align: left; font-size: 11.5px; text-transform: uppercase; letter-spacing: .05em;
    color: var(--ink-faint); font-weight: 700; padding: 6px 10px 6px 0; border-bottom: 1px solid var(--line); }
.adm-table td { padding: 9px 10px 9px 0; border-bottom: 1px solid var(--line); vertical-align: top; }
.adm-table tr:last-child td { border-bottom: 0; }
.adm-table--lijst td { vertical-align: middle; }
.adm-table a { color: var(--purple); text-decoration: none; font-weight: 600; }
.adm-table a:hover { text-decoration: underline; }
.adm-num { text-align: right; white-space: nowrap; color: var(--ink-soft); font-variant-numeric: tabular-nums; }
.adm-sub { font-size: 12px; color: var(--ink-faint); margin-top: 2px; }
.adm-mono { font-family: var(--mono); }

/* Pills/labels */
.pill { display: inline-block; font-size: 11px; font-weight: 700; padding: 1px 7px; border-radius: 999px;
    background: var(--paper-2); border: 1px solid var(--line-strong); color: var(--ink-soft);
    vertical-align: middle; margin-left: 4px; }
.pill--paars { background: var(--purple-10); border-color: var(--purple-20); color: var(--purple); }
.pill--groen { background: var(--green-tint); border-color: rgba(66,134,40,.3); color: #2c5e1c; }
.pill--rood  { background: rgba(180,35,24,.08); border-color: rgba(180,35,24,.25); color: #842018; }
.pill--tier  { background: var(--purple-05); border-color: var(--purple-20); color: var(--purple); text-transform: capitalize; margin-left: 0; }

/* Filterbalk */
.adm-filter { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin: 0 0 18px; }
.adm-zoek { flex: 1 1 260px; min-width: 180px; font: inherit; font-size: 14px; padding: 9px 12px;
    border: 1px solid var(--line-strong); border-radius: var(--r); }
.adm-filter select { font: inherit; font-size: 14px; padding: 9px 12px; border: 1px solid var(--line-strong);
    border-radius: var(--r); background: var(--paper); }
.adm-zoek:focus, .adm-filter select:focus { outline: none; border-color: var(--purple); box-shadow: 0 0 0 3px var(--purple-10); }
.adm-check { font-size: 13.5px; color: var(--ink-2); display: inline-flex; align-items: center; gap: 6px; }

/* Knoppen */
.adm-knop { font: inherit; font-size: 14px; font-weight: 600; cursor: pointer; padding: 8px 14px;
    border-radius: var(--r); border: 1px solid var(--purple); background: var(--purple); color: #fff; white-space: nowrap; }
.adm-knop:hover { background: var(--purple-deep); border-color: var(--purple-deep); }
.adm-knop--klein { padding: 5px 10px; font-size: 13px; }
.adm-knop--paars { background: #6a3fa0; border-color: #6a3fa0; }
.adm-knop--groen { background: var(--green-fresh); border-color: var(--green-fresh); }
.adm-knop--groen:hover { background: #356c20; border-color: #356c20; }
.adm-knop--rood { background: #fff; border-color: rgba(180,35,24,.4); color: #b42318; }
.adm-knop--rood:hover { background: rgba(180,35,24,.06); border-color: #b42318; }

/* Acties-blok (grid van losse formulieren) */
.adm-acties { display: flex; flex-wrap: wrap; gap: 8px; }
.adm-actieform { margin: 0; }
.adm-tierform { margin: 14px 0 0; }
.adm-tierform label { display: block; font-size: 13px; color: var(--ink-soft); margin-bottom: 6px; }
.adm-inline { display: flex; gap: 8px; }
.adm-inline select { flex: 1; font: inherit; font-size: 14px; padding: 8px 12px; border: 1px solid var(--line-strong);
    border-radius: var(--r); background: var(--paper); text-transform: capitalize; }

/* Mini-lijst (alerts) */
.adm-mini { list-style: none; margin: 0; padding: 0; font-size: 13.5px; }
.adm-mini li { padding: 6px 0; border-top: 1px solid var(--line); color: var(--ink-2); }
.adm-mini li:first-child { border-top: 0; }

/* Logvenster */
.adm-log { margin: 0; padding: 14px 16px; background: #1d1d22; color: #d8d8de; border-radius: var(--r);
    font-family: var(--mono); font-size: 12px; line-height: 1.55; overflow-x: auto; max-height: 360px; white-space: pre; }

@media (max-width: 720px) {
    .adm-stats { grid-template-columns: repeat(2, 1fr); }
}

/* ── Meldingen-badge in de account-tabs ─────────────────────────────────────── */
.nav-badge { display: inline-block; min-width: 16px; padding: 0 5px; font-size: 11px; line-height: 16px;
    font-weight: 700; text-align: center; color: #fff; background: var(--purple); border-radius: 999px; vertical-align: middle; }
.nav-badge--groot { font-size: 13px; line-height: 20px; min-width: 20px; padding: 0 7px; margin-left: 6px; }

/* ── Actuele-meldingen-feed ─────────────────────────────────────────────────── */
.feed { list-style: none; margin: 0; padding: 0; border: 1px solid var(--line); border-radius: var(--r); background: var(--paper); overflow: hidden; }
.feed-item { display: flex; align-items: flex-start; gap: 12px; padding: 13px 16px; border-top: 1px solid var(--line); }
.feed-item:first-child { border-top: 0; }
.feed-item.is-ongelezen { background: var(--purple-05); }
.feed-soort { flex: none; font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 999px; margin-top: 1px;
    background: var(--paper-2); border: 1px solid var(--line-strong); color: var(--ink-soft); }
.feed-soort--alert { background: var(--purple-10); border-color: var(--purple-20); color: var(--purple); }
.feed-soort--volg  { background: var(--green-tint); border-color: rgba(66,134,40,.3); color: #2c5e1c; }
.feed-body { flex: 1; min-width: 0; }
.feed-titel { font-weight: 600; font-size: 14.5px; }
.feed-titel a { color: var(--ink); text-decoration: none; }
.feed-titel a:hover { color: var(--purple); }
.feed-meta { font-size: 12.5px; color: var(--ink-soft); margin-top: 2px; }
.feed-tijd { flex: none; font-size: 12px; color: var(--ink-faint); white-space: nowrap; font-variant-numeric: tabular-nums; }

/* ── Verbruik / limieten ────────────────────────────────────────────────────── */
.verbruik-pakket { display: flex; justify-content: space-between; align-items: center; gap: 12px;
    padding-bottom: 12px; margin-bottom: 14px; border-bottom: 1px solid var(--line); }
.verbruik-pakketnaam { font-weight: 700; font-size: 15px; }
.verbruik-prijs { font-size: 13px; color: var(--ink-soft); white-space: nowrap; }
.verbruik-rij { margin-bottom: 12px; }
.verbruik-rij:last-child { margin-bottom: 0; }
.verbruik-kop { display: flex; justify-content: space-between; font-size: 13.5px; margin-bottom: 5px; }
.verbruik-cijfer { color: var(--ink-soft); font-variant-numeric: tabular-nums; }
.verbruik-balk { height: 7px; border-radius: 999px; background: var(--paper-2); border: 1px solid var(--line); overflow: hidden; }
.verbruik-vul { display: block; height: 100%; background: var(--purple); border-radius: 999px; }
.verbruik-vul.is-vol { background: #b42318; }

/* ── Team (subaccounts) ─────────────────────────────────────────────────────── */
.team-rij { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px;
    padding: 14px 0; border-top: 1px solid var(--line); }
.team-rij:first-of-type { border-top: 0; }
.team-info { min-width: 0; }
.team-naam { font-weight: 600; font-size: 14.5px; }
.team-sub { font-size: 12.5px; color: var(--ink-faint); margin-top: 2px; }
.team-vlaggen { display: flex; flex-wrap: wrap; gap: 6px 14px; margin-top: 6px; font-size: 12px; }
.team-vlaggen .vlag-aan { color: var(--green-fresh); }
.team-vlaggen .vlag-uit { color: var(--ink-faint); }
.team-acties { display: flex; flex-wrap: wrap; gap: 6px; justify-content: flex-end; flex: none; max-width: 60%; }
.is-disabled { opacity: .6; }

@media (max-width: 620px) {
    .team-rij { flex-direction: column; gap: 10px; }
    .team-acties { max-width: 100%; justify-content: flex-start; }
    .feed-tijd { display: none; }
}

/* ── Pakketkeuze (abonnement) ───────────────────────────────────────────────── */
.knop--grijs { background: #fff; border-color: var(--line-strong); color: var(--ink-2); }
.knop--grijs:hover { border-color: var(--purple); color: var(--purple); background: var(--purple-05); }
.knop:disabled, .knop--grijs:disabled { opacity: .5; cursor: not-allowed; }

.pakket-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 14px; }
.pakket-kaart { display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: var(--r);
    background: var(--paper); padding: 18px 18px 20px; }
.pakket-kaart.is-huidig { border-color: var(--purple-20); background: var(--purple-05); }
.pakket-kop { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.pakket-naam { font-size: 17px; font-weight: 800; letter-spacing: -.2px; }
.pakket-prijs { font-size: 22px; font-weight: 800; margin: 8px 0 2px; }
.pakket-prijs span { font-size: 12px; font-weight: 500; color: var(--ink-soft); margin-left: 4px; }
.pakket-oms { font-size: 13px; color: var(--ink-soft); margin: 4px 0 10px; }
.pakket-feat { list-style: none; margin: 6px 0 14px; padding: 0; font-size: 13.5px; }
.pakket-feat li { padding: 4px 0 4px 20px; position: relative; color: var(--ink-2); border-top: 1px solid var(--line); }
.pakket-feat li:first-child { border-top: 0; }
.pakket-feat li::before { content: "✓"; position: absolute; left: 0; color: var(--green-fresh); font-weight: 700; }
.pakket-actie { margin-top: auto; }
.pakket-calc { font-size: 13px; color: var(--ink-2); margin-bottom: 10px; line-height: 1.5; }
.pakket-calc .hint { display: block; }
.pakket-actie .knop { width: 100%; box-sizing: border-box; }

/* ── Maandprijs/jaar-regel + AV-akkoord (abonnement) ────────────────────────── */
.pakket-jaar { font-size: 12.5px; color: var(--ink-soft); margin: 0 0 10px; }
.av-akkoord { display: flex; gap: 9px; align-items: flex-start; font-size: 13px; color: var(--ink-2);
    margin: 0 0 12px; line-height: 1.45; }
.av-akkoord input { margin-top: 2px; flex: none; }

/* ── Juridische tekstpagina (algemene voorwaarden) ──────────────────────────── */
.legal { max-width: 760px; margin: 0 auto; padding-bottom: 48px; }
.legal h2 { font-size: 17px; font-weight: 700; letter-spacing: -.01em; margin: 28px 0 8px; color: var(--ink); }
.legal p, .legal li { font-size: 15px; line-height: 1.65; color: var(--ink-2); }
.legal ul { margin: 8px 0 8px; padding-left: 22px; }
.legal li { margin: 5px 0; }
.legal .legal-versie { margin-top: 28px; padding-top: 16px; border-top: 1px solid var(--line); font-size: 13px; color: var(--ink-faint); }
.site-footer a { color: var(--ink-soft); text-decoration: underline; text-underline-offset: 2px; }
.site-footer a:hover { color: var(--purple); }

/* ── Bulk-invoer + API-key ───────────────────────────────────────────────────── */
.veld textarea { width: 100%; box-sizing: border-box; font: inherit; font-size: 14px; padding: 10px 12px;
    border: 1px solid var(--line-strong); border-radius: var(--r); background: var(--paper); color: var(--ink);
    resize: vertical; min-height: 120px; }
.veld textarea:focus { outline: none; border-color: var(--purple); box-shadow: 0 0 0 3px var(--purple-10); }
.veld input[type=file] { font-size: 14px; }
.api-key { display: block; font-family: var(--mono); font-size: 14px; background: #1d1d22; color: #e6e6ea;
    padding: 14px 16px; border-radius: var(--r); word-break: break-all; user-select: all; }

/* ── Voordelen-/functiepagina ────────────────────────────────────────────────── */
.voordeel-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 14px; margin: 22px 0 10px; }
.voordeel { border: 1px solid var(--line); border-radius: var(--r); background: var(--paper); padding: 18px 20px; }
.voordeel-kop { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 6px; }
.voordeel-kop h2 { font-size: 16px; font-weight: 700; letter-spacing: -.01em; margin: 0; }
.voordeel p { font-size: 14px; line-height: 1.6; color: var(--ink-2); margin: 0; }
.voordeel-sectiekop { font-size: 20px; font-weight: 800; letter-spacing: -.3px; margin: 34px 0 4px; }
.voordeel-cta { margin: 34px 0 48px; padding: 26px; text-align: center; background: var(--purple-05);
    border: 1px solid var(--purple-20); border-radius: var(--r); }
.voordeel-cta-titel { font-size: 17px; font-weight: 700; color: var(--ink); margin: 0 0 14px; }

/* ── Archief-melding op detail (zaak uit het register) ──────────────────────── */
.doc-archief { margin: 10px 0 0; padding: 10px 14px; font-size: 13.5px; line-height: 1.5;
    color: var(--ink-soft); background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--r); }

/* Koppelingen — softwarekeuze-tegels (eerst kiezen, dan formulier) */
.koppel-keuze { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 14px; }
.koppel-tegel {
    display: block; padding: 18px 20px 16px; text-decoration: none; color: inherit;
    background: var(--paper); border: 1px solid var(--line); border-radius: var(--r);
    transition: border-color .15s ease, box-shadow .15s ease, transform .05s ease;
}
.koppel-tegel:hover { border-color: var(--purple); box-shadow: 0 3px 14px rgba(79, 44, 117, .10); }
.koppel-tegel:active { transform: translateY(1px); }
.koppel-tegel h3 { margin: 0 0 5px; font-size: 17px; color: var(--purple-deep); }
.koppel-tegel p { margin: 0; font-size: 13px; color: var(--ink-soft); line-height: 1.45; }
.koppel-tegel .koppel-pijl { display: inline-block; margin-top: 12px; font-size: 13px; font-weight: 700; color: var(--purple); }
