/* ─── Design tokens ──────────────────────────────────────── */
:root, [data-theme="dark"] {
    --bg: #0b0f1c;
    --bg-deep: #060914;
    --panel: #131a2b;
    --panel-2: #19223a;
    --panel-3: #1f2a47;
    --sidebar: rgba(13, 18, 32, 0.72);
    --topbar: rgba(13, 18, 32, 0.62);
    --border: #232c45;
    --border-strong: #2f3b5c;
    --text: #eef0f5;
    --text-2: #c6cbd6;
    --muted: #8c92a3;
    --muted-2: #6a7184;
    --accent: #5b8def;
    --accent-2: #7aa3f6;
    --accent-3: #4476df;
    --accent-soft: rgba(91, 141, 239, 0.16);
    --accent-weak: rgba(91, 141, 239, 0.08);
    --accent-ring: rgba(91, 141, 239, 0.32);
    --ok: #4fbf7a;
    --warn: #e2a850;
    --danger: #f06363;
    --danger-soft: rgba(240, 99, 99, 0.16);
    --shadow-sm: 0 1px 2px rgba(0,0,0,.4);
    --shadow: 0 8px 24px rgba(0,0,0,.45), 0 2px 4px rgba(0,0,0,.3);
    --shadow-lg: 0 24px 60px -16px rgba(0,0,0,.65);
    --shadow-glow: 0 8px 28px -8px rgba(91, 141, 239, .55);
    --radius-sm: 8px;
    --radius: 12px;
    --radius-lg: 16px;
    --radius-xl: 20px;
    --ease: cubic-bezier(.2, .8, .2, 1);
    --sidebar-width: 240px;
    --sidebar-collapsed: 68px;
    --ctrl-h: 42px;
    --ctrl-h-small: 32px;
}

[data-theme="light"] {
    --bg: #f4f6fb;
    --bg-deep: #e9edf6;
    --panel: #ffffff;
    --panel-2: #f6f8fc;
    --panel-3: #eef2f9;
    --sidebar: rgba(255, 255, 255, .78);
    --topbar: rgba(255, 255, 255, .82);
    --border: #e3e6ee;
    --border-strong: #cdd2dc;
    --text: #0e1422;
    --text-2: #2a3146;
    --muted: #6b7280;
    --muted-2: #9ca3af;
    --accent: #3b6ddb;
    --accent-2: #2c58b8;
    --accent-3: #5283e6;
    --accent-soft: rgba(59, 109, 219, 0.10);
    --accent-weak: rgba(59, 109, 219, 0.05);
    --accent-ring: rgba(59, 109, 219, 0.22);
    --shadow-sm: 0 1px 2px rgba(15,17,20,.05);
    --shadow: 0 6px 18px rgba(15,17,20,.07), 0 1px 2px rgba(15,17,20,.04);
    --shadow-lg: 0 24px 52px -14px rgba(15,17,20,.18);
    --shadow-glow: 0 8px 24px -8px rgba(59, 109, 219, .35);
}

/* ─── Basis ──────────────────────────────────────────────── */
* { box-sizing: border-box; }

html, body {
    margin: 0; padding: 0; min-height: 100%;
    background: var(--bg); color: var(--text);
    font: 14px/1.55 'Inter', -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif;
    -webkit-font-smoothing: antialiased;
}
html { transition: background-color .25s var(--ease), color .25s var(--ease); }

a { color: var(--text); text-decoration: none; transition: color .15s var(--ease); }
a:hover { color: var(--accent); }
::selection { background: var(--accent-soft); color: var(--accent-2); }

h1, h2, h3, h4 { font-weight: 600; letter-spacing: -0.01em; margin: 0 0 .4em; color: var(--text); line-height: 1.2; }
h1 { font-size: 1.6rem; }
h2 { font-size: 1.2rem; }
h3 { font-size: 1.0rem; }

.muted { color: var(--muted); }
.spacer { height: 16px; }
.right { text-align: right; }
.flex-between { display: flex; justify-content: space-between; align-items: center; gap: 12px; }

code { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: .85em; color: var(--text-2); background: var(--panel-2); padding: 2px 6px; border-radius: 6px; }

/* ─── App shell ──────────────────────────────────────────── */
.app {
    display: grid;
    grid-template-columns: var(--sidebar-width) 1fr;
    min-height: 100vh;
    transition: grid-template-columns .25s var(--ease);
}
:root[data-sidebar-collapsed] .app {
    grid-template-columns: var(--sidebar-collapsed) 1fr;
}

/* ─── Sidebar ────────────────────────────────────────────── */
.sidebar {
    background: var(--sidebar);
    backdrop-filter: saturate(180%) blur(20px);
    -webkit-backdrop-filter: saturate(180%) blur(20px);
    border-right: 1px solid var(--border);
    padding: 18px 12px 16px;
    position: sticky; top: 0;
    height: 100vh; overflow-y: auto;
    display: flex; flex-direction: column;
    gap: 6px;
}

.brand {
    display: flex; align-items: center; gap: 12px;
    padding: 8px 10px 18px;
    margin-bottom: 4px;
}
.brand-logo {
    width: 36px; height: 36px;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 60%, color-mix(in oklab, var(--accent) 60%, white 40%) 100%);
    box-shadow: var(--shadow-glow);
    display: grid; place-items: center;
    color: #fff; font-weight: 700;
    flex-shrink: 0;
}
.brand-text { display: flex; flex-direction: column; line-height: 1.15; min-width: 0; }
.brand-name { font-weight: 600; color: var(--text); white-space: nowrap; }
.brand-sub { font-size: .72rem; color: var(--muted); letter-spacing: .04em; text-transform: uppercase; }

.sidebar-toggle {
    margin-left: auto;
    width: 30px; height: 30px;
    border: 1px solid var(--border);
    background: transparent;
    border-radius: 8px;
    color: var(--muted);
    display: grid; place-items: center;
    cursor: pointer;
    transition: color .15s var(--ease), border-color .15s var(--ease), background .15s var(--ease), transform .25s var(--ease);
    flex-shrink: 0;
}
.sidebar-toggle:hover { color: var(--text); border-color: var(--border-strong); background: var(--panel-2); }
:root[data-sidebar-collapsed] .sidebar-toggle { transform: rotate(180deg); }

.nav-section-label {
    font-size: .68rem;
    color: var(--muted-2);
    text-transform: uppercase;
    letter-spacing: .08em;
    padding: 12px 12px 6px;
    white-space: nowrap;
}

.nav-item {
    display: flex; align-items: center; gap: 12px;
    padding: 9px 12px;
    border-radius: 10px;
    color: var(--text-2);
    cursor: pointer;
    border: 1px solid transparent;
    transition: background .12s var(--ease), color .12s var(--ease), border-color .12s var(--ease);
    font-size: .92rem;
    background: transparent;
    width: 100%;
    text-align: left;
}
.nav-item:hover { background: var(--panel-2); color: var(--text); }
.nav-item.active {
    background: var(--accent-soft);
    color: var(--accent-2);
    border-color: color-mix(in srgb, var(--accent) 22%, transparent);
}
.nav-item .icon {
    width: 18px; height: 18px;
    flex-shrink: 0;
    stroke: currentColor; fill: none; stroke-width: 2;
    stroke-linecap: round; stroke-linejoin: round;
}
.nav-item .nav-label { flex: 1; white-space: nowrap; overflow: hidden; }
.nav-item .nav-badge {
    font-size: .7rem;
    padding: 1px 7px;
    border-radius: 999px;
    background: var(--panel-3);
    color: var(--text-2);
}
.nav-item.active .nav-badge {
    background: color-mix(in srgb, var(--accent) 22%, transparent);
    color: var(--accent-2);
}

/* Wijzigingsverzoeken: rood opvallend zodat admin niet vergeet te
 * behandelen. Geldt op zowel inactieve als actieve tab-state. */
#nav-changerequests .nav-badge,
#nav-changerequests.active .nav-badge {
    background: var(--danger);
    color: #fff;
    font-weight: 600;
}

/* Toast-meldingen: fixed rechtsboven zodat ze nooit de
 * pagina-flow verstoren (geen content-verspringen tijdens polling
 * of na een actie). Stack verticaal als er meerdere zijn. */
#alerts {
    position: fixed;
    top: 16px;
    right: 16px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 8px;
    max-width: 360px;
    pointer-events: none;
}
#alerts .alert {
    pointer-events: auto;
    padding: 10px 14px;
    border-radius: 10px;
    box-shadow: 0 8px 24px rgba(0,0,0,.25);
    font-size: .88rem;
    animation: alertSlide .22s var(--ease);
}
@keyframes alertSlide {
    from { transform: translateX(20px); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

/* ─── Dashboard ─────────────────────────────────────────── */
.dash-kpis {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    margin-bottom: 14px;
}
.dash-kpi {
    background: var(--panel-2);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 16px 18px;
    transition: transform .12s var(--ease), border-color .12s var(--ease);
}
.dash-kpi:hover { border-color: var(--border-strong); }
.dash-kpi .kpi-label {
    font-size: .75rem;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 6px;
}
.dash-kpi .kpi-value {
    font-size: 1.9rem;
    font-weight: 700;
    color: var(--text);
    line-height: 1;
    font-variant-numeric: tabular-nums;
}
.dash-kpi .kpi-sub {
    font-size: .75rem;
    color: var(--muted);
    margin-top: 6px;
}

.dash-row {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 14px;
}
@media (max-width: 900px) { .dash-row { grid-template-columns: 1fr; } }

.dash-card {
    background: var(--panel-2);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 16px 18px;
}
.dash-card-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 12px;
}
.dash-card-head h3 { margin: 0; font-size: .95rem; }

.dash-legend {
    display: flex;
    justify-content: center;
    gap: 14px;
    flex-wrap: wrap;
    margin-top: 8px;
    font-size: .82rem;
    color: var(--muted);
}
.dash-legend .legend-item { display: inline-flex; align-items: center; gap: 6px; }
.dash-legend .legend-dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; }

/* Battery-style progress voor events */
.event-progress {
    padding: 14px 0;
    border-bottom: 1px solid var(--border);
}
.event-progress:last-child { border-bottom: none; }
.event-progress .ep-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 8px;
    flex-wrap: wrap;
    gap: 8px;
}
.event-progress .ep-naam { font-weight: 600; color: var(--text); }
.event-progress .ep-date { font-size: .78rem; color: var(--muted); }
.event-progress .ep-bars { display: flex; flex-direction: column; gap: 6px; }
.event-progress .ep-bar-row {
    display: grid;
    grid-template-columns: 120px 1fr 90px;
    align-items: center;
    gap: 10px;
    font-size: .82rem;
}
.event-progress .ep-bar-label { color: var(--muted); }
.event-progress .ep-bar-track {
    height: 8px;
    background: var(--panel-3);
    border-radius: 999px;
    overflow: hidden;
    position: relative;
}
.event-progress .ep-bar-fill {
    height: 100%;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--accent), var(--accent-3));
    transition: width .4s var(--ease);
}
.event-progress .ep-bar-fill.high { background: linear-gradient(90deg, var(--ok), color-mix(in srgb, var(--ok) 70%, white)); }
.event-progress .ep-bar-fill.mid { background: linear-gradient(90deg, var(--warn), color-mix(in srgb, var(--warn) 70%, white)); }
.event-progress .ep-bar-fill.low { background: linear-gradient(90deg, var(--danger), color-mix(in srgb, var(--danger) 70%, white)); }
.event-progress .ep-bar-count {
    text-align: right;
    font-variant-numeric: tabular-nums;
    color: var(--text-2);
    font-size: .82rem;
}

.side-footer {
    margin-top: auto;
    padding-top: 12px;
    border-top: 1px solid var(--border);
    display: flex; flex-direction: column; gap: 4px;
}
.side-user {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 12px;
    margin-bottom: 6px;
}
.side-user-avatar {
    width: 32px; height: 32px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
    color: #fff;
    display: grid; place-items: center;
    font-weight: 600;
    font-size: .8rem;
    flex-shrink: 0;
}
.side-user-meta { display: flex; flex-direction: column; min-width: 0; line-height: 1.15; }
.side-user-naam { font-size: .88rem; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.side-user-rol { font-size: .68rem; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; }
:root[data-sidebar-collapsed] .side-user-meta,
:root[data-sidebar-collapsed] .side-user { display: none; }
:root[data-sidebar-collapsed] #side-user { display: none !important; }

/* Collapsed sidebar — hide labels, center icons */
:root[data-sidebar-collapsed] .brand-text,
:root[data-sidebar-collapsed] .nav-label,
:root[data-sidebar-collapsed] .nav-section-label,
:root[data-sidebar-collapsed] .nav-badge,
:root[data-sidebar-collapsed] .brand-text * {
    display: none;
}
:root[data-sidebar-collapsed] .nav-item { justify-content: center; padding: 10px; }
:root[data-sidebar-collapsed] .brand {
    flex-direction: column;
    gap: 10px;
    padding: 8px 0 16px;
    align-items: center;
}
:root[data-sidebar-collapsed] .sidebar-toggle { margin: 0; }

/* ─── Main + topbar ──────────────────────────────────────── */
.main { display: flex; flex-direction: column; min-width: 0; }

.topbar {
    position: sticky; top: 0; z-index: 10;
    background: var(--topbar);
    backdrop-filter: saturate(180%) blur(20px);
    -webkit-backdrop-filter: saturate(180%) blur(20px);
    border-bottom: 1px solid var(--border);
    padding: 12px 24px;
    display: flex; align-items: center; gap: 16px;
}
.topbar h1 { font-size: 1.1rem; margin: 0; flex: 1; }

.content { padding: 28px 32px 80px; max-width: 1200px; width: 100%; align-self: center; }

/* ─── Cards ──────────────────────────────────────────────── */
.card {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 22px;
    box-shadow: var(--shadow-sm);
    margin-bottom: 16px;
}
.card.compact { padding: 14px 16px; }
.card.elevated { box-shadow: var(--shadow); }

details.card.collapsible { padding: 0; }
details.card.collapsible > summary {
    list-style: none;
    cursor: pointer;
    padding: 18px 22px;
    user-select: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
details.card.collapsible > summary::-webkit-details-marker { display: none; }
details.card.collapsible > summary h2 {
    margin: 0;
    flex: 1;
}
details.card.collapsible > summary::after {
    content: '';
    width: 10px;
    height: 10px;
    border-right: 2px solid var(--muted);
    border-bottom: 2px solid var(--muted);
    transform: rotate(-45deg);
    transition: transform .15s var(--ease);
    margin-right: 4px;
}
details.card.collapsible[open] > summary::after { transform: rotate(45deg); }
details.card.collapsible[open] > *:not(summary) { padding-left: 22px; padding-right: 22px; }
details.card.collapsible[open] > *:last-child { padding-bottom: 22px; }
details.card.collapsible.danger-card {
    border-color: color-mix(in srgb, var(--danger) 35%, var(--border));
}

/* ─── Forms ──────────────────────────────────────────────── */
.row { display: flex; gap: 12px; flex-wrap: wrap; }
.row > * { flex: 1; min-width: 180px; }

.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.form-grid .full { grid-column: 1 / -1; }
@media (max-width: 720px) { .form-grid { grid-template-columns: 1fr; } }

label {
    display: block;
    font-size: .82rem;
    color: var(--muted);
    margin-bottom: 5px;
}

input[type="text"], input[type="email"], input[type="datetime-local"],
input[type="url"], input[type="number"], input[type="password"],
input[type="tel"], input[type="search"], input[type="date"], input[type="time"],
select, textarea {
    width: 100%;
    height: var(--ctrl-h);
    padding: 0 13px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--panel-2);
    color: var(--text);
    font: inherit;
    line-height: 1.2;
    transition: border-color .15s var(--ease), box-shadow .15s var(--ease), background .15s var(--ease);
}
input::placeholder, textarea::placeholder { color: var(--muted-2); }
input:not([type="checkbox"]):not([type="radio"]):hover, select:hover, textarea:hover { border-color: var(--border-strong); }
input:not([type="checkbox"]):not([type="radio"]):focus, select:focus, textarea:focus {
    outline: none;
    background: var(--panel);
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-ring);
}
textarea { height: auto; min-height: 90px; padding: 11px 13px; resize: vertical; line-height: 1.5; }

/* ─── Number stepper ─────────────────────────────────────
 * Custom − / + knoppen rond <input type="number">. De native
 * browser-spinners worden verborgen; de wrapper-knoppen tonen
 * duidelijke iconen en ondersteunen press-and-hold (zie
 * number-stepper.js). */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    appearance: none;
    margin: 0;
}
input[type="number"] { -moz-appearance: textfield; }

.num-stepper {
    display: inline-flex;
    align-items: stretch;
    width: 100%;
    height: var(--ctrl-h);
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--panel-2);
    overflow: hidden;
    transition: border-color .15s var(--ease), box-shadow .15s var(--ease), background .15s var(--ease);
}
.num-stepper:hover { border-color: var(--border-strong); }
.num-stepper:focus-within {
    background: var(--panel);
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-ring);
}
.num-stepper > input[type="number"] {
    flex: 1 1 auto;
    width: auto;
    height: 100%;
    border: none;
    background: transparent;
    text-align: center;
    border-radius: 0;
    padding: 0 6px;
    font-variant-numeric: tabular-nums;
    -moz-appearance: textfield;
}
.num-stepper > input[type="number"]:focus {
    box-shadow: none;
    background: transparent;
}
.num-stepper-btn {
    flex: 0 0 36px;
    display: grid;
    place-items: center;
    border: none;
    background: var(--panel-2);
    color: var(--text-2);
    cursor: pointer;
    user-select: none;
    transition: background .12s var(--ease), color .12s var(--ease);
    padding: 0;
    font-size: 0;
    line-height: 0;
    border-right: 1px solid var(--border);
}
.num-stepper-btn.num-stepper-up { border-right: none; border-left: 1px solid var(--border); }
.num-stepper-btn:hover { background: var(--panel-3); color: var(--text); }
.num-stepper-btn:active { background: var(--accent-soft); color: var(--accent-2); }
.num-stepper-btn svg { display: block; }

/* Compactere variant binnen settings-panelen + form-designer rows. */
.settings-row .num-stepper,
.fd-section .num-stepper,
.floating-body .num-stepper { height: var(--ctrl-h-small); }
.settings-row .num-stepper-btn,
.fd-section .num-stepper-btn,
.floating-body .num-stepper-btn { flex-basis: 30px; }

/* Normalize native date/time/datetime-local inputs so they line up with text
 * inputs at exactly the same visual height. Browsers (especially Chromium on
 * macOS) apply their own font and padding to the editable segments and to the
 * calendar-picker indicator — without these overrides those controls look
 * subtly shorter and have a darker icon than the surrounding form. */
input[type="date"], input[type="time"], input[type="datetime-local"] {
    font-variant-numeric: tabular-nums;
}
input[type="date"]::-webkit-datetime-edit,
input[type="time"]::-webkit-datetime-edit,
input[type="datetime-local"]::-webkit-datetime-edit { padding: 0; }
input[type="date"]::-webkit-datetime-edit-fields-wrapper,
input[type="time"]::-webkit-datetime-edit-fields-wrapper,
input[type="datetime-local"]::-webkit-datetime-edit-fields-wrapper { padding: 0; }
input[type="date"]::-webkit-datetime-edit-text,
input[type="time"]::-webkit-datetime-edit-text,
input[type="datetime-local"]::-webkit-datetime-edit-text {
    color: var(--muted);
    padding: 0 2px;
}
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator {
    opacity: .55;
    cursor: pointer;
    filter: invert(0);
    transition: opacity .15s var(--ease);
}
input[type="date"]::-webkit-calendar-picker-indicator:hover,
input[type="time"]::-webkit-calendar-picker-indicator:hover,
input[type="datetime-local"]::-webkit-calendar-picker-indicator:hover {
    opacity: 1;
}
[data-theme="dark"] input[type="date"]::-webkit-calendar-picker-indicator,
[data-theme="dark"] input[type="time"]::-webkit-calendar-picker-indicator,
[data-theme="dark"] input[type="datetime-local"]::-webkit-calendar-picker-indicator {
    filter: invert(1);
}

/* Selects render their own arrow which is sized differently per browser.
 * Replace it with our own SVG so the right-side affordance matches the
 * calendar-picker icon weight and color. */
select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%238c92a3' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 34px;
}
select.owner-select,
select.rol-select { background-position: right 8px center; padding-right: 26px; }

.checkbox-row { display: flex; align-items: center; gap: 8px; padding: 8px 0; color: var(--text-2); }
.checkbox-row input { accent-color: var(--accent); width: auto; }

.hint { font-size: .82rem; color: var(--muted); margin-top: 5px; }
.hint.detected { color: var(--ok); }

/* ─── Buttons ────────────────────────────────────────────── */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    height: var(--ctrl-h);
    padding: 0 16px;
    border: 1px solid var(--border);
    background: var(--panel-2);
    color: var(--text);
    border-radius: 10px;
    font: inherit;
    font-weight: 500;
    line-height: 1;
    cursor: pointer;
    transition: background .15s var(--ease), border-color .15s var(--ease), transform .05s, box-shadow .15s;
    text-decoration: none;
    white-space: nowrap;
}
.btn:hover { background: var(--panel-3); border-color: var(--border-strong); }
.btn:active { transform: translateY(1px); }
.btn.primary {
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-3) 100%);
    border-color: transparent;
    color: #fff;
    box-shadow: var(--shadow-glow);
}
.btn.primary:hover { filter: brightness(1.06); }
.btn.ghost { background: transparent; border-color: transparent; color: var(--muted); }
.btn.ghost:hover { color: var(--text); background: var(--panel-2); }
.btn.danger { color: var(--danger); border-color: color-mix(in srgb, var(--danger) 35%, var(--border)); background: var(--danger-soft); }
.btn.small { height: var(--ctrl-h-small); padding: 0 12px; font-size: .85rem; }
select.small, input.small, .field.small input, .field.small select { height: var(--ctrl-h-small); padding: 0 10px; font-size: .85rem; }
.btn .icon { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

/* ─── Toggle group (Ja/Nee aanwezigheid) ─────────────────── */
.toggle-group {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    background: var(--panel-2);
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: 4px;
    width: 100%;
    max-width: 360px;
    margin: 0 auto;
    position: relative;
}
.toggle-group input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
    width: 1px; height: 1px;
}
.toggle-group label {
    margin: 0;
    text-align: center;
    padding: 10px 18px;
    border-radius: 999px;
    cursor: pointer;
    color: var(--muted);
    font-size: .92rem;
    font-weight: 500;
    transition: background .15s var(--ease), color .15s var(--ease);
    border: 1px solid transparent;
}
.toggle-group input[type="radio"]:checked + label {
    background: var(--panel);
    color: var(--text);
    border-color: var(--border-strong);
}
.toggle-group.aanwezig input[type="radio"]:checked + label.ja {
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-3) 100%);
    color: #fff;
    border-color: transparent;
}

/* ─── Alerts ─────────────────────────────────────────────── */
.alert {
    padding: 11px 14px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: var(--panel-2);
    color: var(--text-2);
    margin-bottom: 12px;
}
.alert.error { border-color: color-mix(in srgb, var(--danger) 35%, var(--border)); color: var(--danger); background: var(--danger-soft); }
.alert.success { border-color: color-mix(in srgb, var(--ok) 35%, var(--border)); color: var(--ok); background: color-mix(in srgb, var(--ok) 10%, transparent); }

/* ─── Tables ─────────────────────────────────────────────── */
table {
    width: 100%;
    max-width: 100%;
    border-collapse: collapse;
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    table-layout: auto;
    font-size: .88rem;
}
th, td { text-align: left; padding: 9px 12px; border-bottom: 1px solid var(--border); vertical-align: top; }
th { background: var(--panel-2); font-size: .78rem; color: var(--muted); font-weight: 500; text-transform: uppercase; letter-spacing: .04em; }
tr:last-child td { border-bottom: none; }
tr:hover td { background: var(--panel-2); }

/* Table-wrap: laat de tabel nooit breder worden dan z'n parent */
#guests-table-wrap,
.table-wrap {
    max-width: 100%;
    overflow-x: auto;
}

/* Genodigden-tabel: compactere padding zodat alle kolommen passen op
 * normale schermbreedtes zonder horizontale scroll. We gebruiken
 * expliciete classes op de td's i.p.v. nth-child, want de eerste
 * kolom (bulk-checkbox) wordt voor non-admin verborgen — dat zou
 * positie-gebaseerde regels onbetrouwbaar maken. */
#guests-table-wrap table { table-layout: auto; width: 100%; }
#guests-table-wrap th,
#guests-table-wrap td { padding: 5px 8px; }
#guests-table-wrap td.col-bedrijf,
#guests-table-wrap td.col-functie {
    max-width: 160px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
/* Persoon-cel ruim genoeg voor naam + badge zonder ellipsis. */
#guests-table-wrap td.col-persoon { min-width: 220px; line-height: 1.3; }
#guests-table-wrap td.col-persoon strong { font-size: .92rem; }
#guests-table-wrap td.col-persoon .muted { font-size: .76rem; }
#guests-table-wrap td:last-child { white-space: nowrap; }
/* Smallere eigenaar-dropdown in deze tabel — 110px was overdreven. */
#guests-table-wrap select.owner-select { min-width: 0; width: 100%; max-width: 130px; }
/* Op smalle schermen Bedrijf + Functie gewoon verbergen. */
@media (max-width: 1100px) {
    #guests-table-wrap th.col-bedrijf,
    #guests-table-wrap th.col-functie,
    #guests-table-wrap td.col-bedrijf,
    #guests-table-wrap td.col-functie { display: none; }
}

/* ─── Badges ─────────────────────────────────────────────── */
.badge {
    display: inline-block;
    padding: 2px 9px;
    font-size: .72rem;
    border-radius: 999px;
    background: var(--panel-3);
    color: var(--text-2);
}
.badge.ja { background: color-mix(in srgb, var(--ok) 18%, transparent); color: var(--ok); }
.badge.nee { background: color-mix(in srgb, var(--danger) 18%, transparent); color: var(--danger); }
.badge.pending { background: color-mix(in srgb, var(--warn) 18%, transparent); color: var(--warn); }
.badge.unsubscribed { background: var(--panel-3); color: var(--muted); border: 1px solid var(--border); font-size: .68rem; }
.badge.shortlist { background: color-mix(in srgb, var(--accent) 14%, transparent); color: var(--accent-2); border: 1px solid color-mix(in srgb, var(--accent) 28%, transparent); font-size: .64rem; padding: 1px 7px; }

/* B / I / U toggle-knoppen in design-paneel */
.text-style-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px; height: 32px;
    border-radius: 8px;
    background: var(--panel-2);
    border: 1px solid var(--border);
    cursor: pointer;
    user-select: none;
    transition: background .12s, color .12s, border-color .12s;
    color: var(--muted);
    font-family: serif;
    font-size: 1rem;
}
.text-style-btn:hover { color: var(--text); border-color: var(--border-strong); }
.text-style-btn:has(input:checked) {
    background: var(--accent);
    color: #fff;
    border-color: transparent;
}
.badge.group { background: color-mix(in srgb, var(--accent) 10%, transparent); color: var(--text-2); border: 1px solid var(--border); font-size: .68rem; }
.badge.cr-delete {
    background: color-mix(in srgb, var(--danger) 16%, transparent);
    color: var(--danger);
    border: 1px solid color-mix(in srgb, var(--danger) 36%, transparent);
    font-size: .64rem;
    padding: 1px 7px;
    cursor: pointer;
    user-select: none;
}
.badge.cr-edit {
    background: color-mix(in srgb, var(--warn) 18%, transparent);
    color: var(--warn);
    border: 1px solid color-mix(in srgb, var(--warn) 36%, transparent);
    font-size: .64rem;
    padding: 1px 7px;
    cursor: pointer;
    user-select: none;
}
.badge.cr-delete:hover, .badge.cr-edit:hover { filter: brightness(1.15); }
.badge.hubspot { background: color-mix(in srgb, #ff7a59 18%, transparent); color: #c2410c; border: 1px solid color-mix(in srgb, #ff7a59 32%, transparent); font-size: .68rem; }

/* Pool-groepen-chips */
.pool-groups-bar .chip {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 12px; border-radius: 999px;
    background: var(--panel-3); color: var(--text-2);
    border: 1px solid var(--border);
    font-size: .82rem; cursor: pointer;
    transition: background .12s var(--ease), color .12s var(--ease), border-color .12s var(--ease);
}
.pool-groups-bar .chip:hover { background: var(--panel-2); }
.pool-groups-bar .chip.active {
    background: var(--accent-soft);
    color: var(--accent-2);
    border-color: color-mix(in srgb, var(--accent) 40%, transparent);
}
.pool-groups-bar .chip .chip-count {
    background: color-mix(in srgb, var(--panel-3) 60%, transparent);
    color: var(--muted);
    border-radius: 999px;
    padding: 1px 7px;
    font-size: .7rem;
}
.pool-groups-bar .chip.active .chip-count {
    background: color-mix(in srgb, var(--accent) 18%, transparent);
    color: var(--accent-2);
}
.badge.clickable { cursor: pointer; user-select: none; transition: background .12s var(--ease); }
.badge.clickable:hover { background: var(--accent-soft); color: var(--accent-2); }

.guest-popover { display: inline-block; position: relative; }
.guest-popover summary {
    list-style: none;
    cursor: pointer;
    display: inline-block;
}
.guest-popover summary::-webkit-details-marker { display: none; }
.guest-popover[open] summary .badge { background: var(--accent-soft); color: var(--accent-2); }
.guest-popover .guest-list {
    list-style: none;
    margin: 6px 0 0;
    padding: 10px 12px;
    background: var(--panel);
    border: 1px solid var(--border-strong);
    border-radius: 10px;
    box-shadow: var(--shadow-lg);
    font-size: .85rem;
    line-height: 1.5;
    min-width: 240px;
    max-width: 320px;
    position: absolute;
    z-index: 30;
    top: calc(100% + 6px);
    left: 0;
    white-space: normal;
}
.guest-popover .guest-list li { padding: 2px 0; }
.guest-popover .guest-list li + li { border-top: 1px solid var(--border); padding-top: 6px; margin-top: 4px; }

/* ─── Event list cards ───────────────────────────────────── */
.event-grid { display: grid; gap: 12px; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); }

.event-row {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 18px 20px;
    background: var(--panel);
    background-size: cover;
    background-position: center;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    cursor: pointer;
    overflow: hidden;
    transition: border-color .15s var(--ease), transform .15s var(--ease), box-shadow .15s var(--ease);
}
.event-row:hover { border-color: var(--accent); transform: translateY(-1px); box-shadow: var(--shadow-glow); }
.event-row .meta { color: var(--muted); font-size: .85rem; margin-top: 6px; position: relative; z-index: 1; }
.event-row .slug { color: var(--muted-2); font-size: .75rem; margin-top: 12px; font-family: 'JetBrains Mono', monospace; position: relative; z-index: 1; }
.event-row > div { position: relative; z-index: 1; }
.event-row.has-bg::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(0, 0, 0, .55) 0%, rgba(0, 0, 0, .8) 100%);
    z-index: 0;
}
.event-row.has-bg { color: #fff; border-color: transparent; }
.event-row.has-bg strong { color: #fff; }
.event-row.has-bg .meta { color: rgba(255, 255, 255, .85); }
.event-row.has-bg .slug { color: rgba(255, 255, 255, .65); }

.detail-bg-card {
    position: relative;
    background-size: cover;
    background-position: center;
    overflow: hidden;
}
.detail-bg-card.has-bg::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(0, 0, 0, .55) 0%, rgba(0, 0, 0, .8) 100%);
    z-index: 0;
}
.detail-bg-card > * { position: relative; z-index: 1; }
.detail-bg-card.has-bg, .detail-bg-card.has-bg code, .detail-bg-card.has-bg .muted { color: rgba(255, 255, 255, .9); }
.detail-bg-card.has-bg code { background: rgba(0, 0, 0, .35); }

.empty-state {
    padding: 64px 24px;
    text-align: center;
    color: var(--muted);
    border: 1px dashed var(--border);
    border-radius: var(--radius-lg);
    background: var(--panel);
}

/* ─── Page header (in main) ──────────────────────────────── */
.page-header {
    display: flex; justify-content: space-between; align-items: flex-start; gap: 16px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}
.page-header h1 { margin: 0 0 4px; }
.page-header .subtitle { color: var(--muted); }

/* Detail-view header: Terug + titel links, actie-iconen rechts */
.detail-header-left {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    min-width: 0;
    flex: 1 1 auto;
}
.detail-header-left > div { min-width: 0; }
.detail-header-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 0 0 auto;
    flex-wrap: wrap;
}
.detail-header-actions > .btn {
    flex: 0 0 auto;
    min-width: 0;
    width: auto;
}
.back-btn {
    height: var(--ctrl-h-small);
    padding: 0 10px 0 8px;
    border: 1px solid var(--border);
    background: var(--panel-2);
    color: var(--muted);
    font-size: .85rem;
    margin-top: 4px;
}
.back-btn:hover {
    color: var(--text);
    background: var(--panel-3);
    border-color: var(--border-strong);
}
.back-btn svg {
    flex-shrink: 0;
}

/* ─── Theme toggle ───────────────────────────────────────── */
.theme-toggle {
    width: 32px; height: 32px;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: var(--panel-2);
    color: var(--muted);
    cursor: pointer;
    display: grid; place-items: center;
    transition: color .15s, border-color .15s;
}
.theme-toggle:hover { color: var(--text); border-color: var(--border-strong); }

/* ─── Guest row ──────────────────────────────────────────── */
.guest-row {
    border: 1px solid var(--border);
    background: var(--panel-2);
    padding: 14px;
    border-radius: var(--radius);
    margin-bottom: 8px;
    position: relative;
}
.guest-row .remove {
    position: absolute;
    top: 8px;
    right: 8px;
    width: auto;
    height: var(--ctrl-h-small);
    padding: 0 12px;
    font-size: .78rem;
}

/* Defensief: events met een oude custom_css uit de form-designer
 * kunnen .btn globaal hebben gestyled (vóór de fix die de selector
 * scopt naar [type="submit"] + .primary). Forceer ghost-knoppen
 * terug naar transparant + auto-breedte zodat de Verwijderen-knop
 * in een gast-rij niet als full-width primary opduikt. */
.public-page .btn.ghost,
.public-page button.ghost,
.guest-row .remove.ghost,
.guest-row button.remove {
    background: transparent !important;
    color: var(--muted) !important;
    border: 1px solid transparent !important;
    box-shadow: none !important;
    width: auto !important;
    display: inline-flex !important;
}
.public-page .btn.ghost:hover,
.public-page button.ghost:hover {
    color: var(--text) !important;
    background: var(--panel-2) !important;
}

/* ─── Header banner (public register) ────────────────────── */
.header-banner {
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-3) 100%);
    color: #fff;
    padding: 36px 28px;
    margin-bottom: 16px;
    background-size: cover; background-position: center;
}
.header-banner h1 { color: #fff; margin: 0 0 8px; }
.header-banner .meta { opacity: .85; }

/* ─── Container (used on register page) ──────────────────── */
.container { max-width: 960px; margin: 0 auto; padding: 20px 20px 80px; }
.container.narrow { max-width: 640px; }
/* Top-padding op de publieke registratiepagina blijft gelijk aan
 * left/right (20 px) — overschrijft eventuele oudere custom_css uit
 * de form-designer die nog 32 px had. Hogere specificiteit (2 classes
 * + 2 type-selectors) zodat de inline event-css niet wint. */
body.public-page main.container { padding-top: 20px; }

/* ─── Mail composer (popup + floating tool windows) ──────── */
.mailings-modal-card {
    position: relative;
    width: min(94vw, 760px);
    max-height: 92vh;
    display: flex; flex-direction: column;
    padding: 18px 20px;
    gap: 14px;
}

/* Floating "Bewaard."-status linksonder in de mailings-modal — beweegt
 * niets in de toolbar wanneer-ie verschijnt of verdwijnt. */
.draft-saved-toast {
    position: absolute;
    left: 18px;
    bottom: 14px;
    z-index: 5;
    font-size: .78rem;
    color: var(--muted);
    background: var(--panel-2);
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: 6px 12px;
    box-shadow: var(--shadow-sm);
    opacity: 0;
    transform: translateY(4px);
    pointer-events: none;
    transition: opacity .18s ease, transform .18s ease;
}
.draft-saved-toast:not(:empty) {
    opacity: 1;
    transform: translateY(0);
}

/* Floating tool-window panels — palette + settings sit alongside the
 * mailings popup as draggable side widgets, like a desktop design tool. */
.floating-panel {
    position: fixed;
    top: 80px;
    width: 240px;
    max-height: calc(100vh - 120px);
    background: var(--panel-2);
    border: 1px solid var(--border);
    border-radius: 12px;
    box-shadow: var(--shadow-lg);
    display: flex; flex-direction: column;
    z-index: 60; /* above modal-overlay (10) and modal-card (50) */
    overflow: hidden;
}
.floating-panel[data-default-pos="left"] { left: 24px; }
.floating-panel[data-default-pos="right"] { right: 24px; }
.floating-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 10px 12px;
    background: var(--panel-3);
    border-bottom: 1px solid var(--border);
    cursor: grab;
    user-select: none;
}
.floating-head:active { cursor: grabbing; }
.floating-title {
    font-size: .72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--muted);
}
.floating-grab {
    color: var(--muted-2);
    font-size: 1rem;
    line-height: 1;
    letter-spacing: -2px;
}
.floating-body {
    padding: 12px 12px 14px;
    overflow-y: auto;
    flex: 1;
}
@media (max-width: 1100px) {
    /* Stack panels under the modal on narrow viewports — keep them
     * visible so the user can still pick elements. */
    .floating-panel {
        position: relative; top: auto; left: auto; right: auto;
        width: 100%;
        margin: 12px auto 0;
        max-height: 320px;
    }
    .mailings-modal-card { margin-bottom: 8px; }
}
.mailings-head {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border);
}
.mailings-head-row {
    display: flex;
    align-items: flex-start;
    gap: 16px;
}
.mailings-head-left {
    flex: 1;
    min-width: 0; /* allow text to wrap inside flex parent */
}
.mailings-head-left h2 {
    font-size: 1.1rem;
    line-height: 1.25;
    word-break: keep-all;
    overflow-wrap: anywhere;
}
.mailings-head-tools {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.mailings-head-tools select.small { width: auto; min-width: 180px; }
.mailings-meta-row {
    display: grid;
    grid-template-columns: 1.2fr 2fr 1fr 1.2fr;
    gap: 10px;
}
.mailings-meta-row label { display: block; font-size: .72rem; color: var(--muted); margin-bottom: 4px; text-transform: uppercase; letter-spacing: .04em; }
@media (max-width: 1100px) {
    .mailings-meta-row { grid-template-columns: repeat(2, 1fr); }
}
.mail-side-section + .mail-side-section { margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--border); }
.mail-side-section h3 {
    margin: 0 0 4px;
    font-size: .78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--muted);
}
.mail-side-section p.muted { font-size: .76rem; margin: 0 0 10px; line-height: 1.4; }
.palette-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.palette-item {
    border: 1px solid var(--border);
    background: var(--panel);
    color: var(--text-2);
    border-radius: 10px;
    padding: 10px 8px;
    font-size: .8rem;
    font-weight: 500;
    text-align: center;
    cursor: grab;
    user-select: none;
    transition: border-color .15s var(--ease), color .15s var(--ease), background .15s var(--ease), transform .08s var(--ease);
}
.palette-item:hover {
    border-color: var(--accent);
    color: var(--text);
    background: var(--panel-3);
}
.palette-item:active { cursor: grabbing; transform: scale(.97); }
.palette-item.small-pill {
    font-size: .72rem;
    padding: 6px 8px;
    border-radius: 999px;
    background: var(--panel-3);
}

.mail-canvas-wrap {
    background: var(--panel-3);
    border-radius: 14px;
    padding: 16px 12px;
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    border: 1px solid var(--border);
}
.device-toggle {
    display: inline-flex;
    gap: 4px;
    margin: 0 auto 16px;
    padding: 4px;
    background: var(--panel-2);
    border: 1px solid var(--border);
    border-radius: 999px;
    width: fit-content;
}
.mail-canvas-wrap .device-toggle { display: flex; justify-content: center; }
.device-btn {
    min-width: 100px;
    border-radius: 999px;
    border: 1px solid transparent;
    background: transparent;
    color: var(--muted);
}
.device-btn:hover { color: var(--text); background: transparent; border-color: transparent; }
.device-btn.active {
    background: var(--panel);
    color: var(--text);
    border-color: var(--border-strong);
    box-shadow: var(--shadow-sm);
}

.mail-canvas {
    background: #ffffff;
    color: #1a1a1a;
    padding: 0;
    margin: 0 auto;
    min-height: 360px;
    box-shadow: var(--shadow-lg);
    border-radius: 10px;
    width: 100%;
    max-width: 600px;
    transition: max-width .25s var(--ease);
}
.mail-canvas.mobile { max-width: 360px; }

.mail-canvas .mail-block {
    position: relative;
    border: 2px solid transparent;
    cursor: pointer;
    transition: border-color .12s;
}
.mail-canvas .mail-block:hover { border-color: color-mix(in srgb, var(--accent) 28%, transparent); }
.mail-canvas .mail-block.selected { border-color: var(--accent); }
.mail-canvas .mail-block .block-actions {
    position: absolute;
    top: 6px; right: 6px;
    display: none;
    gap: 4px;
    z-index: 5;
}
.mail-canvas .mail-block.selected .block-actions { display: inline-flex; }
/* Inline-bewerking: contenteditable-velden krijgen een dunne dashed-omrand
   bij hover/focus zodat je ziet waar je kan klikken om te typen. We zetten
   `cursor: text` om duidelijk te maken dat het veld typeable is. */
.mail-canvas [data-edit-prop] {
    cursor: text;
    border-radius: 4px;
    transition: outline-color .12s, background .12s;
    outline: 1px dashed transparent;
    outline-offset: 2px;
}
.mail-canvas .mail-block:hover [data-edit-prop] {
    outline-color: color-mix(in srgb, var(--accent) 30%, transparent);
}
.mail-canvas [data-edit-prop]:focus {
    outline-color: var(--accent);
    background: color-mix(in srgb, var(--accent) 6%, transparent);
}
.mail-canvas [data-edit-prop]:empty::before {
    content: attr(data-placeholder);
    opacity: .45;
    font-style: italic;
}
.mail-canvas .mail-block .block-actions button {
    width: 28px; height: 28px;
    padding: 0;
    border: 1px solid var(--border);
    background: var(--panel);
    color: var(--text-2);
    border-radius: 8px;
    cursor: pointer;
    display: inline-flex;
    align-items: center; justify-content: center;
    box-shadow: var(--shadow-sm);
    transition: background .15s var(--ease), color .15s var(--ease),
                border-color .15s var(--ease), transform .08s var(--ease);
}
.mail-canvas .mail-block .block-actions button:hover {
    background: var(--panel-2);
    color: var(--text);
    border-color: var(--border-strong);
}
.mail-canvas .mail-block .block-actions button:active { transform: translateY(1px); }
.mail-canvas .mail-block .block-actions button.danger {
    color: var(--danger);
    background: var(--danger-soft);
    border-color: color-mix(in srgb, var(--danger) 35%, var(--border));
}
.mail-canvas .mail-block .block-actions button.danger:hover {
    background: var(--danger);
    color: #fff;
    border-color: var(--danger);
}
.mail-canvas .mail-block .block-actions button svg {
    width: 14px; height: 14px;
    fill: none; stroke: currentColor;
    stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round;
    pointer-events: none;
}

.sortable-ghost { opacity: .35; }
.sortable-drag { opacity: .85; }

.settings-row { margin-bottom: 12px; }
.settings-row label { display: block; font-size: .78rem; color: var(--muted); margin-bottom: 4px; }
.settings-row input, .settings-row select, .settings-row textarea {
    font-size: .85rem;
    padding: 7px 9px;
}

/* ─── Role-based visibility ──────────────────────────────── */
/* Rol-gebaseerde zichtbaarheid:
 *   data-role-admin → admin + super_admin (= dagelijks beheer)
 *   data-role-super-admin → enkel super_admin (= technische config)
 *   data-role-user-only → enkel sales (gebruikt voor wijzigings-
 *     verzoek-knoppen die admin zelf niet hoeft)
 *   data-role-writer → iedereen behalve viewer (= alle mutations)
 *
 * Viewer is een nieuwe alleen-lezen rol: alle write-knoppen worden
 * verborgen via data-role-writer of data-role-admin. */
body[data-rol="user"] [data-role-admin],
body[data-rol="viewer"] [data-role-admin] { display: none !important; }
body[data-rol="user"] [data-role-super-admin],
body[data-rol="viewer"] [data-role-super-admin],
body[data-rol="admin"] [data-role-super-admin] { display: none !important; }
body[data-rol="admin"] [data-role-user-only],
body[data-rol="super_admin"] [data-role-user-only] { display: none !important; }
body[data-rol="viewer"] [data-role-writer] { display: none !important; }
.perm-hidden { display: none !important; }

/* ─── Lock-banner (Genodigden countdown) ─────────────────── */
.lock-banner.ok {
    border-color: color-mix(in srgb, var(--ok) 35%, var(--border));
    background: color-mix(in srgb, var(--ok) 8%, var(--panel));
}
.lock-banner.ok strong { color: var(--ok); }
.lock-banner.warn {
    border-color: color-mix(in srgb, var(--warn) 35%, var(--border));
    background: color-mix(in srgb, var(--warn) 8%, var(--panel));
}
.lock-banner.warn strong { color: var(--warn); }
.lock-banner.crit {
    border-color: color-mix(in srgb, var(--danger) 35%, var(--border));
    background: color-mix(in srgb, var(--danger) 8%, var(--panel));
}
.lock-banner.crit strong { color: var(--danger); }

/* ─── Pill-toggle (iOS-stijl switch) ─────────────────────── */
.pill-toggle {
    position: relative;
    display: inline-block;
    width: 42px;
    height: 22px;
    flex-shrink: 0;
}
.pill-toggle input {
    opacity: 0;
    width: 0;
    height: 0;
    position: absolute;
}
.pill-slider {
    position: absolute;
    cursor: pointer;
    inset: 0;
    background: var(--panel-3);
    border: 1px solid var(--border);
    transition: background .2s var(--ease), border-color .2s var(--ease);
    border-radius: 999px;
}
.pill-slider::before {
    position: absolute;
    content: '';
    height: 16px;
    width: 16px;
    left: 2px;
    bottom: 2px;
    background: #fff;
    transition: transform .2s var(--ease), background .2s var(--ease);
    border-radius: 50%;
    box-shadow: 0 1px 2px rgba(0, 0, 0, .25);
}
.pill-toggle input:checked + .pill-slider {
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-3) 100%);
    border-color: transparent;
}
.pill-toggle input:checked + .pill-slider::before {
    transform: translateX(20px);
}
.pill-toggle input:disabled + .pill-slider {
    opacity: .55;
    cursor: not-allowed;
}

.perm-row {
    display: flex; align-items: center; justify-content: space-between;
    gap: 12px;
    padding: 10px 4px;
    border-bottom: 1px dashed var(--border);
}
.perm-row:last-child { border-bottom: none; }
.perm-row .perm-label { display: flex; flex-direction: column; gap: 2px; }
.perm-row .perm-label .perm-title { font-weight: 500; color: var(--text); }
.perm-row .perm-label .perm-desc { font-size: .8rem; color: var(--muted); }
.perm-section { margin-top: 14px; }
.perm-section:first-child { margin-top: 0; }
.perm-section-title {
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--muted);
    margin: 0 0 6px;
    font-weight: 500;
}

/* ─── Selection toggle (Genodigden) ──────────────────────── */
.sel-toggle {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 3px 9px;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: var(--panel-2);
    cursor: pointer;
    font-size: .75rem;
    line-height: 1.4;
    color: var(--muted);
    transition: background .15s, color .15s, border-color .15s;
    user-select: none;
}
.sel-toggle:hover { color: var(--text); border-color: var(--border-strong); }
.sel-toggle.on {
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-3) 100%);
    color: #fff;
    border-color: transparent;
}
.sel-toggle .check { width: 11px; height: 11px; }

.selector-pill {
    display: inline-block;
    padding: 1px 7px;
    margin-right: 4px;
    border-radius: 999px;
    background: var(--panel-3);
    color: var(--text-2);
    font-size: .72rem;
}

/* ─── Tab buttons ────────────────────────────────────────── */
.btn-tab.active {
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-3) 100%);
    border-color: transparent;
    color: #fff;
}

/* ─── Modal ──────────────────────────────────────────────── */
.modal {
    position: fixed; inset: 0;
    display: grid; place-items: center;
    z-index: 100;
    padding: 24px;
}
.modal[hidden] { display: none; }
.modal-overlay {
    position: absolute; inset: 0;
    background: rgba(8, 12, 22, 0.65);
    backdrop-filter: blur(4px);
}
.modal-card {
    position: relative;
    background: var(--panel);
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    padding: 24px;
    max-width: 720px;
    width: 100%;
    max-height: calc(100vh - 80px);
    overflow-y: auto;
}

/* ─── Stats grid (event-detail) ──────────────────────────── */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 12px;
    margin: 8px 0 16px;
}
.stat-card {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 14px 16px;
}
.stat-card .label {
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--muted);
    margin-bottom: 6px;
}
.stat-card .value {
    font-size: 1.6rem;
    font-weight: 600;
    color: var(--text);
    line-height: 1;
}
.stat-card.accent { border-color: color-mix(in srgb, var(--accent) 45%, var(--border)); }
.stat-card.accent .value { color: var(--accent-2); }

.row-actions { display: inline-flex; gap: 6px; flex-wrap: nowrap; }
.row-actions .btn {
    width: 96px;
    min-width: 96px;
    height: 28px;
    padding: 0 8px;
    font-size: .72rem;
    letter-spacing: .01em;
    justify-content: center;
    white-space: nowrap;
}

select.owner-select,
select.rol-select {
    height: var(--ctrl-h-small);
    padding: 0 10px;
    font-size: .78rem;
    min-width: 110px;
    width: auto;
    line-height: 1;
}

.action-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}
.action-bar > .btn { flex: 0 0 auto; min-width: auto; }

th.filter-th {
    vertical-align: top;
    padding: 8px 10px;
}
th.filter-th .th-label {
    font-size: .72rem;
    color: var(--muted);
    margin-bottom: 4px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: .04em;
}
th.filter-th .th-filter {
    width: 100%;
    padding: 5px 8px;
    font-size: .8rem;
    border: 1px solid var(--border);
    background: var(--panel);
    color: var(--text);
    border-radius: 6px;
    font-family: inherit;
    text-transform: none;
    letter-spacing: 0;
    font-weight: 400;
}
th.filter-th .th-filter:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 2px var(--accent-ring);
}
th.filter-th.has-active .th-label { color: var(--accent-2); }
th.filter-th.has-active .th-filter { border-color: var(--accent); }

/* ─── Tabs (form / preview) ──────────────────────────────── */
.form-pane { display: flex; flex-direction: column; min-width: 0; }
.tabs {
    display: inline-flex;
    gap: 4px;
    padding: 4px;
    background: var(--panel-2);
    border: 1px solid var(--border);
    border-radius: 999px;
    margin-bottom: 12px;
    align-self: flex-start;
}
.tab {
    border: none;
    background: transparent;
    color: var(--muted);
    padding: 7px 16px;
    border-radius: 999px;
    cursor: pointer;
    font: inherit;
    font-size: .88rem;
    font-weight: 500;
    transition: background .15s var(--ease), color .15s var(--ease);
}
.tab:hover { color: var(--text); }
.tab.active {
    background: var(--panel);
    color: var(--text);
    box-shadow: var(--shadow-sm);
}

#preview-frame {
    width: 100%;
    height: calc(100vh - 200px);
    min-height: 600px;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--panel);
    box-shadow: var(--shadow);
}

.preview-bar {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 14px;
    margin-bottom: 8px;
    border-radius: 10px;
    background: var(--accent-soft);
    border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--border));
    color: var(--text);
}
.preview-bar .pill {
    background: color-mix(in srgb, var(--accent) 32%, transparent);
    color: var(--accent-2);
    padding: 2px 10px;
    border-radius: 999px;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.preview-bar .grow { flex: 1; font-size: .88rem; color: var(--muted); }

/* ─── Autocomplete (locatie) ─────────────────────────────── */
.autocomplete { position: relative; }
.autocomplete-list {
    position: absolute;
    top: calc(100% + 4px);
    left: 0; right: 0;
    background: var(--panel);
    border: 1px solid var(--border-strong);
    border-radius: 10px;
    box-shadow: var(--shadow);
    z-index: 30;
    max-height: 280px;
    overflow-y: auto;
    padding: 4px;
}
.autocomplete-list[hidden] { display: none; }
.autocomplete-item {
    padding: 8px 10px;
    border-radius: 8px;
    cursor: pointer;
    color: var(--text-2);
    font-size: .9rem;
    display: flex; flex-direction: column; gap: 2px;
}
.autocomplete-item:hover, .autocomplete-item.active {
    background: var(--accent-soft);
    color: var(--text);
}
.autocomplete-item .meta { font-size: .75rem; color: var(--muted); }
.autocomplete-empty { padding: 10px; color: var(--muted); font-size: .85rem; text-align: center; }

/* ─── Image upload ───────────────────────────────────────── */
.upload-row { display: flex; gap: 8px; align-items: center; }
.upload-row .preview {
    width: 64px; height: 40px;
    border-radius: 8px;
    background: var(--panel-2) center/cover no-repeat;
    border: 1px solid var(--border);
    flex-shrink: 0;
}

/* ─── Public register themes (kept for backward compat) ──── */
body.theme-gvr {
    --accent: #BE2134; --accent-2: #951a29; --accent-3: #d83b4f;
    --bg: #F5F0E8; --panel: #ffffff; --panel-2: #fbf8f2; --panel-3: #f0eadc;
    --border: #e5dfd2; --border-strong: #c9c0ac;
    --text: #1A1A1A; --text-2: #33363d; --muted: #6b6b6b; --muted-2: #9ca3af;
    --shadow-glow: 0 8px 24px -8px rgba(190, 33, 52, .35);
}
body.theme-magisch {
    --accent: #D4AF37; --accent-2: #b8951f; --accent-3: #e6c560;
    --bg: #1c0d2b; --panel: #2a1a3d; --panel-2: #321f48; --panel-3: #3d2856;
    --border: #43305c; --border-strong: #5a4378;
    --text: #f5e9d8; --text-2: #d8c8b0; --muted: #b9a8c9; --muted-2: #8c7da0;
}
body.theme-industrieel {
    --accent: #EA580C; --accent-2: #c2440a; --accent-3: #ff7434;
    --bg: #e7e5e4; --panel: #ffffff; --panel-2: #f5f4f3; --panel-3: #ebeae9;
    --border: #d6d3d1; --border-strong: #a8a29e;
    --text: #1f2937; --text-2: #374151; --muted: #6b7280; --muted-2: #9ca3af;
}
body.theme-natuur {
    --accent: #16a34a; --accent-2: #117a37; --accent-3: #22c55e;
    --bg: #f5f0e3; --panel: #fdfaf2; --panel-2: #f7f1e1; --panel-3: #ede4cf;
    --border: #d8cfb6; --border-strong: #b8a98a;
    --text: #14532d; --text-2: #2a623f; --muted: #6b7280; --muted-2: #9ca3af;
}
body.theme-klassiek {
    --accent: #1e3a8a; --accent-2: #172d6a; --accent-3: #3b5cad;
    --bg: #f3f1ec; --panel: #ffffff; --panel-2: #f7f5f0; --panel-3: #ede9e0;
    --border: #d8d4ca; --border-strong: #b5b0a3;
    --text: #0f172a; --text-2: #2a3146; --muted: #6b7280; --muted-2: #9ca3af;
}

/* ─── Envelope designer ─────────────────────────────────── */
.env-designer-grid {
    display: grid;
    grid-template-columns: 1fr 240px;
    gap: 18px;
    align-items: start;
}
.env-canvas-wrap { min-width: 0; }
.env-canvas {
    position: relative;
    background:
        repeating-linear-gradient(0deg, rgba(0,0,0,.04) 0 1px, transparent 1px 40px),
        repeating-linear-gradient(90deg, rgba(0,0,0,.04) 0 1px, transparent 1px 40px),
        var(--panel-2);
    border: 1px dashed var(--border-strong);
    border-radius: 6px;
    width: 100%;
    overflow: hidden;
    user-select: none;
}
.env-block {
    position: absolute;
    box-sizing: border-box;
    border: 1px dashed transparent;
    cursor: move;
}
.env-block:hover, .env-block.selected { border-color: var(--accent); }
.env-block-address {
    background: rgba(255,255,255,.0);
    color: #1a1a1a;
    font-family: 'Helvetica', 'Arial', sans-serif;
    line-height: 1.25;
    white-space: pre-wrap;
    padding: 2px 4px;
}
.env-block-logo {
    background: var(--panel-3);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    border: 1px dashed var(--border);
}
.env-block-logo .env-logo-empty {
    display: flex; align-items: center; justify-content: center;
    width: 100%; height: 100%;
    color: var(--muted); font-size: .75rem;
}
.env-resize {
    position: absolute;
    width: 12px; height: 12px;
    right: -6px; bottom: -6px;
    background: var(--accent);
    border: 2px solid var(--panel);
    border-radius: 3px;
    cursor: nwse-resize;
}
.env-side .settings-row { margin-bottom: 10px; }
.env-side .settings-row label { display:block; font-size:.78rem; color: var(--muted); margin-bottom: 4px; }

/* ─── Form designer ─────────────────────────────────────── */
.fd-grid {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 14px;
    height: 76vh;
    min-height: 520px;
}
.fd-side {
    overflow-y: auto;
    padding-right: 4px;
}
/* Per-letter title-color chips */
.title-letter-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}
.title-letter-chip {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: 1.5px solid var(--border);
    border-radius: 8px;
    background: var(--panel);
    color: var(--text);
    cursor: pointer;
    transition: border-color .12s var(--ease), transform .05s var(--ease);
    box-shadow: inset 0 -3px 0 var(--chip-color);
}
.title-letter-chip:hover { border-color: var(--accent); transform: translateY(-1px); }
.title-letter-chip.has-override { border-color: var(--chip-color); box-shadow: inset 0 -4px 0 var(--chip-color); }
.title-letter-chip input[type="color"] {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    opacity: 0; cursor: pointer;
    border: none; padding: 0;
    background: transparent;
}
.title-letter-glyph {
    font-weight: 600;
    font-size: .92rem;
    pointer-events: none;
    user-select: none;
}
.title-letter-clear {
    position: absolute;
    top: -4px; right: -4px;
    width: 16px; height: 16px;
    border-radius: 50%;
    border: 1px solid var(--border-strong);
    background: var(--panel);
    color: var(--muted);
    font-size: 11px; line-height: 1;
    cursor: pointer;
    display: grid; place-items: center;
    padding: 0;
}
.title-letter-clear:hover { color: var(--danger); border-color: var(--danger); }

@keyframes fd-section-flash-anim {
    0%   { box-shadow: 0 0 0 0 var(--accent-ring); border-color: var(--accent); }
    50%  { box-shadow: 0 0 0 6px var(--accent-ring); border-color: var(--accent); }
    100% { box-shadow: 0 0 0 0 transparent; border-color: var(--border); }
}
.fd-section.fd-section-flash {
    animation: fd-section-flash-anim 1.1s ease-out;
    border-color: var(--accent);
}

.fd-section {
    margin-bottom: 10px;
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 0 12px;
    background: var(--panel-2);
}
.fd-section[open] { padding-bottom: 12px; }
.fd-section > summary {
    list-style: none;
    cursor: pointer;
    padding: 12px 0;
    font-weight: 500;
    color: var(--text);
    user-select: none;
}
.fd-section > summary::-webkit-details-marker { display: none; }
.fd-section > summary::after { content: '＋'; float: right; color: var(--muted); }
.fd-section[open] > summary::after { content: '−'; }
/* Wanneer fd-section gebruikt wordt binnen de mail-composer settings-
 * panel (smaller dan de form-designer): iets kleinere padding zodat de
 * inhoud van een sectie meer ruimte heeft voor labels + inputs. */
#mail-settings .fd-section { padding: 0 10px; margin-bottom: 8px; }
#mail-settings .fd-section > summary { padding: 10px 0; font-size: .82rem; text-transform: uppercase; letter-spacing: .04em; }
#mail-settings .fd-section[open] { padding-bottom: 10px; }
.fd-side input[type="color"] { width: 100%; height: 36px; padding: 2px; cursor: pointer; }
.fd-side input[type="range"] { width: 100%; }
.fd-side .settings-row { margin-bottom: 10px; }
.fd-side .settings-row label { display: block; font-size:.78rem; color: var(--muted); margin-bottom: 4px; }
.fd-side .row { display:flex; }
.fd-preview {
    background: repeating-linear-gradient(45deg, rgba(0,0,0,.025) 0 8px, transparent 8px 16px);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 8px;
    overflow: hidden;
}

/* ─── Modern slider + color picker (scoped to designer panels) ── */
.fd-side input[type="range"] {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 26px;
    background: transparent;
    padding: 0;
    border: 0;
    margin: 0;
}
.fd-side input[type="range"]::-webkit-slider-runnable-track {
    height: 6px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--accent) 0%, var(--accent-3) 100%);
    background-color: var(--panel-3);
    box-shadow: inset 0 0 0 1px var(--border);
}
.fd-side input[type="range"]::-moz-range-track {
    height: 6px;
    border-radius: 999px;
    background: var(--panel-3);
    box-shadow: inset 0 0 0 1px var(--border);
}
.fd-side input[type="range"]::-moz-range-progress {
    height: 6px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--accent) 0%, var(--accent-3) 100%);
}
.fd-side input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 18px; height: 18px;
    margin-top: -6px;
    border-radius: 999px;
    background: var(--panel);
    border: 2px solid var(--accent);
    box-shadow: var(--shadow-sm), 0 0 0 4px transparent;
    cursor: grab;
    transition: box-shadow .15s var(--ease), transform .12s var(--ease);
}
.fd-side input[type="range"]::-moz-range-thumb {
    width: 18px; height: 18px;
    border-radius: 999px;
    background: var(--panel);
    border: 2px solid var(--accent);
    box-shadow: var(--shadow-sm);
    cursor: grab;
}
.fd-side input[type="range"]:hover::-webkit-slider-thumb {
    box-shadow: var(--shadow-sm), 0 0 0 6px var(--accent-ring);
}
.fd-side input[type="range"]:active::-webkit-slider-thumb {
    cursor: grabbing;
    transform: scale(1.05);
}
.fd-side input[type="range"]:focus { outline: none; }

/* Color pickers — clean rounded swatch, no system chrome. */
.fd-side input[type="color"] {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 38px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--panel-2);
    padding: 4px;
    cursor: pointer;
    transition: border-color .15s var(--ease), box-shadow .15s var(--ease);
}
.fd-side input[type="color"]:hover { border-color: var(--border-strong); }
.fd-side input[type="color"]:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-ring); }
.fd-side input[type="color"]::-webkit-color-swatch-wrapper { padding: 0; border-radius: 6px; }
.fd-side input[type="color"]::-webkit-color-swatch { border: 0; border-radius: 6px; }
.fd-side input[type="color"]::-moz-color-swatch { border: 0; border-radius: 6px; }

/* Same treatment for the envelope-designer side panel so all designer
 * tools feel like one studio. */
.env-side input[type="range"],
.env-side input[type="color"] { /* inherit base from fd-side selectors */ }
.env-side input[type="range"] {
    -webkit-appearance: none; appearance: none;
    width: 100%; height: 26px; background: transparent; padding: 0; border: 0;
}
.env-side input[type="range"]::-webkit-slider-runnable-track {
    height: 6px; border-radius: 999px; background: var(--panel-3);
    box-shadow: inset 0 0 0 1px var(--border);
}
.env-side input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none; appearance: none;
    width: 18px; height: 18px; margin-top: -6px;
    border-radius: 999px; background: var(--panel);
    border: 2px solid var(--accent); box-shadow: var(--shadow-sm);
}
.env-side input[type="color"] {
    -webkit-appearance: none; appearance: none;
    width: 100%; height: 38px; border: 1px solid var(--border);
    border-radius: 10px; background: var(--panel-2); padding: 4px;
}
.env-side input[type="color"]::-webkit-color-swatch-wrapper { padding: 0; border-radius: 6px; }
.env-side input[type="color"]::-webkit-color-swatch { border: 0; border-radius: 6px; }

/* ─── Event-detail toolbar (5-column grid) ──────────────── */
.detail-toolbar {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 8px;
    margin: 0 0 16px;
}
.detail-toolbar .btn { width: 100%; }
.detail-toolbar-delete {
    grid-column: 5;
    grid-row: 1;
}
@media (max-width: 760px) {
    .detail-toolbar { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .detail-toolbar-delete { grid-column: 2; grid-row: 1; }
}

/* ─── Icon-only button variant ─────────────────────────── */
.btn.icon-only {
    padding: 0;
    width: var(--ctrl-h);
    aspect-ratio: 1;
    flex-shrink: 0;
}
.btn.small.icon-only { width: var(--ctrl-h-small); }
.btn.icon-only .icon { width: 18px; height: 18px; }
.btn.small.icon-only .icon { width: 16px; height: 16px; }

.settings-block-title {
    font-size: .72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--accent-2);
    margin: 0 0 10px;
}

.mail-drop-indicator {
    height: 3px;
    margin: 6px 12px;
    background: var(--accent);
    border-radius: 2px;
    box-shadow: 0 0 0 4px var(--accent-soft);
    pointer-events: none;
}
.palette-item.dragging {
    opacity: .5;
    transform: scale(.96);
}

/* ─── Font picker popover ─────────────────────────────── */
.font-picker-panel {
    position: fixed; inset: 0;
    z-index: 200;
}
.font-picker-overlay {
    position: absolute; inset: 0;
    background: rgba(0, 0, 0, .35);
    backdrop-filter: blur(4px);
}
.font-picker-card {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: min(92vw, 640px);
    max-height: 80vh;
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 14px;
    box-shadow: var(--shadow-lg);
    display: flex; flex-direction: column;
    overflow: hidden;
}
.font-picker-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 14px 16px;
    border-bottom: 1px solid var(--border);
    background: var(--panel-2);
}
.font-picker-title { font-weight: 600; }
.font-picker-controls {
    padding: 12px 16px;
    border-bottom: 1px solid var(--border);
    display: flex; flex-direction: column; gap: 10px;
}
.font-picker-search {
    width: 100%;
}
.font-picker-cats {
    display: flex; gap: 6px; flex-wrap: wrap;
}
.font-picker-chip {
    padding: 6px 12px;
    border: 1px solid var(--border);
    background: var(--panel-2);
    color: var(--muted);
    border-radius: 999px;
    font-size: .78rem;
    cursor: pointer;
    transition: background .15s var(--ease), color .15s var(--ease), border-color .15s var(--ease);
}
.font-picker-chip:hover {
    color: var(--text);
    background: var(--panel-3);
    border-color: var(--border-strong);
}
.font-picker-chip.active {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent);
}
.font-picker-list {
    overflow-y: auto;
    padding: 6px 8px 14px;
    flex: 1;
    min-height: 0;
}
.font-picker-row {
    display: flex; align-items: center; justify-content: space-between;
    width: 100%;
    padding: 12px 14px;
    border: 1px solid transparent;
    background: transparent;
    border-radius: 10px;
    cursor: pointer;
    transition: background .12s var(--ease), border-color .12s var(--ease);
    text-align: left;
    color: var(--text);
}
.font-picker-row:hover {
    background: var(--panel-2);
    border-color: var(--border);
}
.font-picker-row.selected {
    background: var(--accent-soft);
    border-color: color-mix(in srgb, var(--accent) 35%, var(--border));
}
.font-picker-row .fp-name {
    font-size: 1.05rem;
    font-weight: 500;
    line-height: 1.3;
}
.font-picker-row .fp-cat {
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--muted);
}

/* The trigger button that replaces the old <select data-prop="font"> */
.font-picker-trigger {
    display: flex; align-items: center; justify-content: space-between;
    width: 100%;
    padding: 0 12px;
    height: var(--ctrl-h);
    border: 1px solid var(--border);
    background: var(--panel-2);
    color: var(--text);
    border-radius: 10px;
    cursor: pointer;
    text-align: left;
    transition: border-color .15s var(--ease);
}
.font-picker-trigger:hover { border-color: var(--border-strong); }
.font-picker-trigger .fp-current { font-weight: 500; }
.font-picker-trigger .fp-current.muted { color: var(--muted); font-weight: 400; }
.font-picker-trigger::after {
    content: '⌄';
    color: var(--muted);
    margin-left: 8px;
}

/* ─── Mail-flow editor ────────────────────────────────── */
.flow-modal-card {
    width: min(94vw, 720px);
    max-height: 92vh;
    display: flex; flex-direction: column;
    padding: 18px 20px;
    gap: 16px;
}
.flow-head {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 16px;
    align-items: flex-start;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border);
}
.flow-head-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; justify-content: flex-end; }
.flow-head-actions select.small { width: auto; min-width: 180px; }
.flow-head-close { align-self: flex-start; }
.flow-canvas {
    overflow-y: auto;
    padding: 12px 0;
}
.flow-node {
    display: grid;
    grid-template-columns: 56px 1fr auto;
    gap: 14px;
    align-items: center;
    padding: 14px 16px;
    border: 1px solid var(--border);
    border-left: 4px solid var(--flow-color, var(--accent));
    background: var(--panel-2);
    border-radius: 12px;
    transition: opacity .15s var(--ease), background .15s var(--ease);
}
.flow-node.disabled { opacity: .55; }
.flow-node-icon {
    width: 48px; height: 48px;
    display: grid; place-items: center;
    border-radius: 50%;
    background: color-mix(in srgb, var(--flow-color, var(--accent)) 12%, transparent);
    color: var(--flow-color, var(--accent));
    font-size: 1.4rem;
}
.flow-node-label {
    font-weight: 600;
    font-size: 1rem;
    color: var(--text);
}
.flow-node-trigger {
    font-size: .8rem;
    color: var(--flow-color, var(--accent));
    margin-top: 2px;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.flow-node-desc { font-size: .82rem; margin-top: 4px; }
.flow-node-actions { display: flex; gap: 10px; align-items: center; }
.flow-toggle {
    position: relative;
    display: inline-block;
    width: 36px; height: 20px;
    cursor: pointer;
}
.flow-toggle input { opacity: 0; width: 0; height: 0; }
.flow-toggle span {
    position: absolute; inset: 0;
    background: var(--panel-3);
    border: 1px solid var(--border);
    border-radius: 999px;
    transition: background .15s var(--ease), border-color .15s var(--ease);
}
.flow-toggle span::after {
    content: '';
    position: absolute;
    width: 14px; height: 14px;
    left: 2px; top: 50%;
    transform: translateY(-50%);
    background: var(--panel);
    border-radius: 50%;
    box-shadow: var(--shadow-sm);
    transition: left .18s var(--ease), background .18s var(--ease);
}
.flow-toggle input:checked + span {
    background: color-mix(in srgb, var(--flow-color, var(--accent)) 60%, transparent);
    border-color: var(--flow-color, var(--accent));
}
.flow-toggle input:checked + span::after {
    left: 18px;
    background: #fff;
}
.flow-connector {
    display: flex; justify-content: center;
    color: var(--muted-2);
    margin: 4px 0;
}

.flow-add-row {
    display: flex; justify-content: center;
    margin-top: 8px;
}

/* Color-row used inside the mail-composer block-settings: 38px swatch
 * picker + flexible hex text + small Wis button. Stays on a single line
 * even in narrow side-panels (~240px wide). */
.color-row {
    display: flex;
    gap: 6px;
    align-items: center;
    flex-wrap: nowrap;
}
.color-row > input[type="color"] {
    flex: 0 0 38px;
    width: 38px;
    height: 32px;
    padding: 2px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--panel-2);
    cursor: pointer;
}
.color-row > input[type="color"]::-webkit-color-swatch-wrapper { padding: 0; border-radius: 5px; }
.color-row > input[type="color"]::-webkit-color-swatch { border: 0; border-radius: 5px; }
.color-row > input[type="color"]::-moz-color-swatch { border: 0; border-radius: 5px; }
.color-row > input[type="text"] {
    flex: 1 1 auto;
    min-width: 0;
    width: auto;
    height: 32px;
    padding: 0 8px;
    font-size: .8rem;
}
.color-row > .btn {
    flex: 0 0 auto;
}

/* ─── Modern slider + color picker for the mail composer's floating
 * panels (Elementen, Variabelen, Mail-achtergrond). Same look as the
 * form-designer + envelope-designer studio panels. */
.floating-panel input[type="range"] {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 26px;
    background: transparent;
    padding: 0;
    border: 0;
    margin: 0;
}
.floating-panel input[type="range"]::-webkit-slider-runnable-track {
    height: 6px; border-radius: 999px;
    background: var(--panel-3);
    box-shadow: inset 0 0 0 1px var(--border);
}
.floating-panel input[type="range"]::-moz-range-track {
    height: 6px; border-radius: 999px;
    background: var(--panel-3);
    box-shadow: inset 0 0 0 1px var(--border);
}
.floating-panel input[type="range"]::-moz-range-progress {
    height: 6px; border-radius: 999px;
    background: linear-gradient(90deg, var(--accent) 0%, var(--accent-3) 100%);
}
.floating-panel input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none; appearance: none;
    width: 18px; height: 18px;
    margin-top: -6px;
    border-radius: 999px;
    background: var(--panel);
    border: 2px solid var(--accent);
    box-shadow: var(--shadow-sm);
    cursor: grab;
    transition: box-shadow .15s var(--ease), transform .12s var(--ease);
}
.floating-panel input[type="range"]::-moz-range-thumb {
    width: 18px; height: 18px;
    border-radius: 999px;
    background: var(--panel);
    border: 2px solid var(--accent);
    box-shadow: var(--shadow-sm);
    cursor: grab;
}
.floating-panel input[type="range"]:hover::-webkit-slider-thumb {
    box-shadow: var(--shadow-sm), 0 0 0 6px var(--accent-ring);
}
.floating-panel input[type="range"]:active::-webkit-slider-thumb {
    cursor: grabbing; transform: scale(1.05);
}
.floating-panel input[type="range"]:focus { outline: none; }

.floating-panel input[type="color"] {
    -webkit-appearance: none; appearance: none;
    height: 38px; padding: 4px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--panel-2);
    cursor: pointer;
    transition: border-color .15s var(--ease);
}
.floating-panel input[type="color"]:hover { border-color: var(--border-strong); }
.floating-panel input[type="color"]::-webkit-color-swatch-wrapper { padding: 0; border-radius: 6px; }
.floating-panel input[type="color"]::-webkit-color-swatch { border: 0; border-radius: 6px; }
.floating-panel input[type="color"]::-moz-color-swatch { border: 0; border-radius: 6px; }

/* Mail-achtergrond gradient + image rows: keep the two color pickers
 * compact side-by-side instead of stretching to full width. */
.mail-bg-grad-row {
    display: flex;
    gap: 6px;
    align-items: center;
}
.mail-bg-grad-row input[type="color"] {
    flex: 0 0 38px;
    width: 38px;
}
.mail-bg-alpha-row {
    display: grid;
    grid-template-columns: 60px 1fr 50px;
    gap: 8px;
    align-items: center;
    margin-top: 6px;
}
.mail-bg-alpha-row label {
    font-size: .72rem;
    color: var(--muted);
    margin: 0;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.mail-bg-alpha-row .alpha-val {
    font-size: .78rem;
    text-align: right;
    color: var(--muted);
}

/* ─── Form-designer modal header ────────────────────────── */
.fd-modal-card {
    width: 96vw;
    max-width: 1280px;
    max-height: 92vh;
    display: flex;
    flex-direction: column;
    padding: 18px 20px;
    gap: 14px;
}
.fd-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border);
}
.fd-head-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

/* "Ben je aanwezig?"-label op de publieke registratiepagina blijft altijd
 * gecentreerd, ook al heeft de form-designer een algemene `.public-page
 * label`-regel met text-align: left ingesteld. */
.public-page .aanwezig-label,
.public-page label.aanwezig-label {
    text-align: center !important;
    display: block;
}

/* Import-review-modal: per-rij card met input/existing-vergelijking +
 * radio-buttons voor de actie-keuze. */
.import-row {
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 12px 14px;
    margin-bottom: 10px;
    background: var(--panel-2);
}
.import-row.exact { border-color: color-mix(in srgb, var(--accent) 35%, var(--border)); }
.import-row.fuzzy { border-color: color-mix(in srgb, var(--warn, #d09d2a) 50%, var(--border)); }
.import-row.invalid { border-color: color-mix(in srgb, var(--danger) 35%, var(--border)); }
.import-row .row-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    margin-bottom: 6px;
    font-size: .82rem;
}
.import-row .row-head .row-tag {
    font-weight: 600;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    font-size: .72rem;
}
.import-row .row-tag.exact { color: var(--accent-2); }
.import-row .row-tag.fuzzy { color: var(--warn, #b8821b); }
.import-row .row-tag.invalid { color: var(--danger); }
.import-row .row-body {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px 14px;
    font-size: .82rem;
    margin: 4px 0 10px;
}
.import-row .row-body .col h4 {
    margin: 0 0 4px;
    font-size: .72rem;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    font-weight: 600;
}
.import-row .row-body .col .v { color: var(--text); }
.import-row .row-body .col .v .field {
    display: flex;
    gap: 6px;
}
.import-row .row-body .col .v .field span:first-child {
    color: var(--muted);
    min-width: 70px;
}
.import-row .row-body .col .v .field.diff span:last-child {
    color: var(--accent-2);
    font-weight: 500;
}
.import-row .action-picker {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    padding-top: 8px;
    border-top: 1px dashed var(--border);
    font-size: .82rem;
}
.import-row .action-picker label {
    display: flex;
    gap: 6px;
    align-items: center;
    cursor: pointer;
    margin: 0;
}

/* Mailings recipients-summary — compact info-blok bovenaan de mailings-
 * modal dat toont hoeveel gasten klaarstaan om gemaild te worden, met
 * een breakdown per bron (pool / HubSpot / event-import). */
.mail-recipients-summary {
    background: var(--panel-2);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 10px 14px;
    margin: 10px 0 0;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px 18px;
    font-size: .85rem;
}
.mail-recipients-summary[hidden] { display: none; }
.mail-recipients-summary .summary-total {
    font-weight: 600;
    color: var(--text);
}
.mail-recipients-summary .summary-source {
    color: var(--muted);
}
.mail-recipients-summary .summary-source strong { color: var(--text); font-weight: 600; }
.mail-recipients-summary .summary-warning {
    color: var(--danger);
    font-size: .78rem;
}

/* Gedeelde floating WYSIWYG-toolbar — verschijnt boven een actieve
 * selectie binnen om het even welk contenteditable veld op het platform
 * (mail-composer, form-designer preview, …). Knoppen: B / I / U,
 * lettergrootte, kleur, opmaak-wissen. Implementatie: rich-toolbar.js */
.rich-toolbar {
    position: absolute;
    z-index: 10000;
    background: #1f2330;
    color: #f1f3f9;
    border-radius: 8px;
    padding: 4px;
    box-shadow: 0 6px 24px rgba(0,0,0,.28);
    display: inline-flex;
    align-items: center;
    gap: 2px;
    font-size: 13px;
    user-select: none;
}
.rich-toolbar[hidden] { display: none; }
.rich-toolbar button {
    background: transparent;
    color: inherit;
    border: 0;
    padding: 4px 9px;
    cursor: pointer;
    border-radius: 5px;
    line-height: 1;
    font-size: 13px;
    font-weight: 600;
}
.rich-toolbar button:hover { background: rgba(255,255,255,.12); }
.rich-toolbar button[data-rt="size-trigger"] {
    display: inline-flex;
    align-items: baseline;
    gap: 3px;
}
.rich-toolbar button[data-rt="size-trigger"] small {
    font-size: 9px;
    opacity: .7;
}
/* Het size-popover hangt los aan body (niet binnen .rich-toolbar) zodat
 * geen enkele overflow/stacking-context van een ouder hem afsnijdt. JS
 * berekent top/left zodra de trigger-knop wordt aangeklikt. */
.rich-toolbar-size-menu {
    position: absolute;
    top: 0;
    left: 0;
    background: #1f2330;
    color: #f1f3f9;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 6px;
    padding: 4px;
    box-shadow: 0 6px 24px rgba(0,0,0,.34);
    display: grid;
    grid-template-columns: repeat(3, minmax(40px, 1fr));
    gap: 2px;
    z-index: 10001;
    max-height: 260px;
    overflow-y: auto;
    user-select: none;
}
.rich-toolbar-size-menu[hidden] { display: none; }
.rich-toolbar-size-menu button {
    background: transparent;
    color: inherit;
    border: 0;
    padding: 5px 10px;
    cursor: pointer;
    border-radius: 4px;
    font-size: 12px;
    font-variant-numeric: tabular-nums;
}
.rich-toolbar-size-menu button:hover { background: rgba(255,255,255,.14); }
.rich-toolbar-color {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 8px;
    cursor: pointer;
    border-radius: 5px;
}
.rich-toolbar-color:hover { background: rgba(255,255,255,.12); }
.rich-toolbar-color > span {
    font-weight: 700;
    text-decoration: underline;
    text-decoration-color: #5b8def;
    text-decoration-thickness: 2px;
    text-underline-offset: 2px;
}
.rich-toolbar-color input[type="color"] {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
    width: 100%;
    height: 100%;
}
.rich-toolbar-sep {
    width: 1px;
    align-self: stretch;
    background: rgba(255,255,255,.14);
    margin: 2px 4px;
}

/* Bedankt-pagina — basis-reset voor knop-breedte zodat bestaande events
 * (waarvan custom_css nog `.btn.primary { width: 100% }` bevat van het
 * stretch-formulier) hier toch een breedte krijgen die afhankelijk is
 * van de label-tekst. De form-designer kan dit verder per event
 * overschrijven via inline-style of nieuwe custom_css. */
.public-page #thanks .thanks-actions .btn,
.public-page #thanks .thanks-actions a.btn,
.public-page #thanks .thanks-actions button.btn {
    display: inline-block !important;
    width: auto !important;
    margin: 0 8px 8px 0;
}
.public-page #thanks .thanks-actions {
    margin-top: 14px;
}

/* ─── Alignment icon group + format toolbar ─────────────── */
.align-group, .format-toolbar {
    display: inline-flex;
    gap: 2px;
    padding: 2px;
    background: var(--panel-3);
    border: 1px solid var(--border);
    border-radius: 8px;
}
.align-group button, .format-toolbar button {
    width: 30px; height: 28px;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--muted);
    border-radius: 6px;
    cursor: pointer;
    display: inline-flex;
    align-items: center; justify-content: center;
    transition: background .12s var(--ease), color .12s var(--ease);
    font-size: .82rem;
    font-family: inherit;
}
.align-group button:hover, .format-toolbar button:hover {
    background: var(--panel);
    color: var(--text);
}
.align-group button.active, .format-toolbar button.active {
    background: var(--accent);
    color: #fff;
}
/* ─── Variable insert dropdown (in mail-composer settings) ─── */
.var-dropdown {
    position: relative;
    display: inline-block;
}
.var-dropdown .var-trigger {
    height: 28px;
    padding: 0 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--panel-2);
    color: var(--text-2);
    font-size: .78rem;
    cursor: pointer;
    line-height: 1;
}
.var-dropdown .var-trigger:hover {
    background: var(--panel-3);
    border-color: var(--border-strong);
    color: var(--text);
}
.var-dropdown .var-menu {
    position: absolute;
    top: 100%;
    left: 0;
    margin-top: 4px;
    z-index: 50;
    background: var(--panel);
    border: 1px solid var(--border-strong);
    border-radius: 10px;
    box-shadow: 0 8px 24px rgba(0,0,0,.18);
    padding: 4px;
    min-width: 220px;
    max-height: 280px;
    overflow-y: auto;
}
.var-dropdown .var-menu button {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    width: 100%;
    padding: 7px 10px;
    border: 0;
    background: transparent;
    border-radius: 6px;
    color: var(--text);
    cursor: pointer;
    font-size: .82rem;
    text-align: left;
    font-family: inherit;
}
.var-dropdown .var-menu button:hover {
    background: var(--accent-soft);
    color: var(--accent-2);
}
.var-dropdown .var-menu code {
    font-size: .72rem;
    background: var(--panel-2);
    padding: 1px 6px;
    border-radius: 4px;
}

.align-group svg, .format-toolbar svg {
    width: 14px; height: 14px;
    fill: none; stroke: currentColor;
    stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
    pointer-events: none;
}
.format-toolbar button.fmt-bold { font-weight: 700; }
.format-toolbar button.fmt-italic { font-style: italic; }
.format-toolbar { margin-bottom: 6px; }
