/* ============================================================
   Mooke Dashboard — frontend styles (scope: .mkdb-app)
   Vrolijk design: gradient sidebar, kleur per module, ronde vormen
   ============================================================ */

.mkdb-app *,
.mkdb-app *::before,
.mkdb-app *::after { box-sizing: border-box; }

.mkdb-app {
	--mkdb-bg:        #eef1f8;
	--mkdb-card:      #ffffff;
	--mkdb-ink:       #1f2937;
	--mkdb-muted:     #6b7280;
	--mkdb-line:      #e6e8f0;
	--mkdb-notes:     #f59e0b;
	--mkdb-agenda:    #3b82f6;
	--mkdb-files:     #10b981;
	--mkdb-board:     #ec4899;
	--mkdb-messages:  #f97316;
	--mkdb-profile:   #8b5cf6;
	--mkdb-radius:    18px;
	--mkdb-shadow:    0 10px 30px rgba(31,41,55,.08);
	--mkdb-shadow-sm: 0 4px 14px rgba(31,41,55,.07);

	font-family: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	color: var(--mkdb-ink);
	background: var(--mkdb-bg);
	border-radius: var(--mkdb-radius);
	overflow: hidden;
	display: flex;
	min-height: 640px;
	box-shadow: var(--mkdb-shadow);
	line-height: 1.5;
}

.mkdb-app .mkdb-loading {
	margin: auto;
	color: var(--mkdb-muted);
	font-weight: 600;
}

/* ---------- Sidebar ---------- */
.mkdb-app .mkdb-side {
	width: 250px;
	flex: 0 0 250px;
	background: linear-gradient(165deg, #7c3aed 0%, #6366f1 48%, #3b82f6 100%);
	color: #fff;
	padding: 26px 18px;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.mkdb-app .mkdb-side-profile {
	text-align: center;
	padding: 8px 0 22px;
}
.mkdb-app .mkdb-avatar {
	width: 84px; height: 84px;
	border-radius: 50%;
	margin: 0 auto 12px;
	background-size: cover;
	background-position: center;
	display: flex; align-items: center; justify-content: center;
	font-weight: 800; font-size: 30px; color: #fff;
	border: 4px solid rgba(255,255,255,.35);
	box-shadow: 0 8px 20px rgba(0,0,0,.18);
}
.mkdb-app .mkdb-side-name { font-weight: 800; font-size: 18px; }
.mkdb-app .mkdb-side-sub  { font-size: 12.5px; opacity: .85; margin-top: 2px; }
.mkdb-app .mkdb-visiting {
	display: inline-block; margin-top: 10px;
	background: rgba(255,255,255,.18);
	padding: 4px 12px; border-radius: 999px; font-size: 12px; font-weight: 600;
}

.mkdb-app .mkdb-nav { display: flex; flex-direction: column; gap: 4px; margin-top: 6px; }
.mkdb-app .mkdb-nav button {
	display: flex; align-items: center; gap: 12px;
	width: 100%; border: 0; cursor: pointer;
	background: transparent; color: #fff;
	padding: 11px 14px; border-radius: 12px;
	font-size: 14.5px; font-weight: 600; font-family: inherit;
	text-align: left; transition: background .15s, transform .1s;
}
.mkdb-app .mkdb-nav button:hover { background: rgba(255,255,255,.14); }
.mkdb-app .mkdb-nav button.active { background: rgba(255,255,255,.95); color: #4338ca; box-shadow: var(--mkdb-shadow-sm); }
.mkdb-app .mkdb-nav .mkdb-ico { font-size: 18px; width: 22px; text-align: center; }
.mkdb-app .mkdb-nav .mkdb-badge {
	margin-left: auto; background: #ef4444; color: #fff;
	min-width: 20px; height: 20px; padding: 0 6px;
	border-radius: 999px; font-size: 11px; font-weight: 800;
	display: none; align-items: center; justify-content: center;
}
.mkdb-app .mkdb-nav .mkdb-badge.show { display: inline-flex; }

.mkdb-app .mkdb-side-foot { margin-top: auto; display: flex; flex-direction: column; gap: 8px; padding-top: 16px; }
.mkdb-app .mkdb-side-foot button {
	background: rgba(255,255,255,.16); color: #fff; border: 0;
	padding: 10px; border-radius: 12px; cursor: pointer;
	font-weight: 600; font-size: 13px; font-family: inherit;
}
.mkdb-app .mkdb-side-foot button:hover { background: rgba(255,255,255,.26); }

/* ---------- Main ---------- */
.mkdb-app .mkdb-main { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.mkdb-app .mkdb-top {
	display: flex; align-items: center; gap: 14px;
	padding: 20px 26px; background: var(--mkdb-card);
	border-bottom: 1px solid var(--mkdb-line);
}
.mkdb-app .mkdb-burger {
	display: none; border: 0; background: transparent; font-size: 22px; cursor: pointer; color: var(--mkdb-ink);
}
.mkdb-app .mkdb-top h1 { font-size: 21px; font-weight: 800; margin: 0; }
.mkdb-app .mkdb-top-right { margin-left: auto; display: flex; align-items: center; gap: 12px; }
.mkdb-app .mkdb-bell {
	position: relative; border: 0; background: #f3f4f8; cursor: pointer;
	width: 42px; height: 42px; border-radius: 12px; font-size: 18px;
}
.mkdb-app .mkdb-bell .mkdb-badge {
	position: absolute; top: -4px; right: -4px;
	background: #ef4444; color: #fff; min-width: 18px; height: 18px;
	border-radius: 999px; font-size: 10.5px; font-weight: 800;
	display: none; align-items: center; justify-content: center; padding: 0 5px;
}
.mkdb-app .mkdb-bell .mkdb-badge.show { display: inline-flex; }

.mkdb-app .mkdb-content { padding: 26px; overflow: auto; flex: 1; }

/* ---------- Generic UI ---------- */
.mkdb-app .mkdb-section-head {
	display: flex; align-items: center; gap: 12px; margin-bottom: 20px; flex-wrap: wrap;
}
.mkdb-app .mkdb-section-head h2 { margin: 0; font-size: 20px; font-weight: 800; }
.mkdb-app .mkdb-dot { width: 12px; height: 12px; border-radius: 50%; }

.mkdb-app .mkdb-btn {
	border: 0; cursor: pointer; font-family: inherit; font-weight: 700; font-size: 14px;
	padding: 10px 18px; border-radius: 12px; transition: transform .1s, box-shadow .15s, background .15s;
}
.mkdb-app .mkdb-btn:active { transform: translateY(1px); }
.mkdb-app .mkdb-btn-primary { background: #6366f1; color: #fff; box-shadow: 0 6px 16px rgba(99,102,241,.35); }
.mkdb-app .mkdb-btn-primary:hover { background: #4f46e5; }
.mkdb-app .mkdb-btn-ghost { background: #f3f4f8; color: var(--mkdb-ink); }
.mkdb-app .mkdb-btn-ghost:hover { background: #e8eaf3; }
.mkdb-app .mkdb-btn-sm { padding: 6px 12px; font-size: 12.5px; border-radius: 9px; }
.mkdb-app .mkdb-btn-danger { background: #fee2e2; color: #dc2626; }
.mkdb-app .mkdb-btn-danger:hover { background: #fecaca; }

.mkdb-app .mkdb-add-btn { margin-left: auto; }

.mkdb-app .mkdb-empty {
	text-align: center; color: var(--mkdb-muted); padding: 50px 20px;
	background: var(--mkdb-card); border-radius: var(--mkdb-radius); border: 2px dashed var(--mkdb-line);
}
.mkdb-app .mkdb-empty .mkdb-emoji { font-size: 40px; display: block; margin-bottom: 10px; }

.mkdb-app .mkdb-pill {
	display: inline-flex; align-items: center; gap: 5px;
	font-size: 11px; font-weight: 700; padding: 3px 9px; border-radius: 999px;
	background: #f3f4f8; color: var(--mkdb-muted);
}
.mkdb-app .mkdb-pill.private { background: #fde8ef; color: #be185d; }

/* ---------- Notities ---------- */
.mkdb-app .mkdb-notes-grid {
	display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 16px;
}
.mkdb-app .mkdb-note-card {
	border-radius: 16px; padding: 16px 16px 14px; min-height: 150px;
	box-shadow: var(--mkdb-shadow-sm); display: flex; flex-direction: column;
	border: 1px solid rgba(0,0,0,.05); position: relative;
}
.mkdb-app .mkdb-note-card h3 { margin: 0 0 8px; font-size: 15.5px; font-weight: 800; }
.mkdb-app .mkdb-note-card .mkdb-note-body { font-size: 13.5px; white-space: pre-wrap; flex: 1; color: #374151; word-break: break-word; }
.mkdb-app .mkdb-note-card .mkdb-note-foot { display: flex; align-items: center; gap: 6px; margin-top: 12px; }
.mkdb-app .mkdb-note-card .mkdb-note-actions { margin-left: auto; display: flex; gap: 6px; }
.mkdb-app .mkdb-icon-btn {
	border: 0; background: rgba(255,255,255,.6); cursor: pointer; width: 30px; height: 30px;
	border-radius: 9px; font-size: 14px; display: inline-flex; align-items: center; justify-content: center;
}
.mkdb-app .mkdb-icon-btn:hover { background: #fff; }

/* sticky kleuren (gedeeld door notities & prikbord) */
.mkdb-app .nc-yellow { background: #fff3b0; }
.mkdb-app .nc-pink   { background: #ffd6e8; }
.mkdb-app .nc-green  { background: #c7f9cc; }
.mkdb-app .nc-blue   { background: #cfe4ff; }
.mkdb-app .nc-orange { background: #ffe0b3; }
.mkdb-app .nc-purple { background: #e9d5ff; }
.mkdb-app .nc-mint   { background: #ccfbf1; }
.mkdb-app .nc-white  { background: #ffffff; }

/* ---------- Agenda ---------- */
.mkdb-app .mkdb-agenda-wrap { display: grid; grid-template-columns: 340px 1fr; gap: 22px; align-items: start; }
.mkdb-app .mkdb-cal {
	background: var(--mkdb-card); border-radius: var(--mkdb-radius); padding: 18px; box-shadow: var(--mkdb-shadow-sm);
}
.mkdb-app .mkdb-cal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.mkdb-app .mkdb-cal-head strong { font-size: 15px; }
.mkdb-app .mkdb-cal-head button { border: 0; background: #f3f4f8; width: 32px; height: 32px; border-radius: 9px; cursor: pointer; font-size: 16px; }
.mkdb-app .mkdb-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.mkdb-app .mkdb-cal-dow { font-size: 11px; font-weight: 700; color: var(--mkdb-muted); text-align: center; padding: 4px 0; }
.mkdb-app .mkdb-cal-day {
	aspect-ratio: 1; display: flex; align-items: center; justify-content: center;
	font-size: 13px; border-radius: 9px; position: relative; cursor: default; color: #374151;
}
.mkdb-app .mkdb-cal-day.empty { visibility: hidden; }
.mkdb-app .mkdb-cal-day.today { outline: 2px solid var(--mkdb-agenda); font-weight: 800; }
.mkdb-app .mkdb-cal-day.has {
	background: var(--mkdb-agenda); color: #fff; font-weight: 800; cursor: pointer;
}
.mkdb-app .mkdb-cal-day.sel { box-shadow: 0 0 0 3px rgba(59,130,246,.35); }

.mkdb-app .mkdb-agenda-list { display: flex; flex-direction: column; gap: 12px; }
.mkdb-app .mkdb-event {
	background: var(--mkdb-card); border-radius: 14px; padding: 14px 16px; box-shadow: var(--mkdb-shadow-sm);
	display: flex; gap: 14px; align-items: flex-start; border-left: 5px solid var(--mkdb-agenda);
}
.mkdb-app .mkdb-event .mkdb-event-date {
	text-align: center; min-width: 52px; background: #eaf2ff; border-radius: 10px; padding: 6px 4px; color: var(--mkdb-agenda);
}
.mkdb-app .mkdb-event .mkdb-event-date .d { font-size: 19px; font-weight: 800; line-height: 1; }
.mkdb-app .mkdb-event .mkdb-event-date .m { font-size: 11px; font-weight: 700; text-transform: uppercase; }
.mkdb-app .mkdb-event .mkdb-event-main { flex: 1; min-width: 0; }
.mkdb-app .mkdb-event h4 { margin: 0 0 3px; font-size: 15px; font-weight: 800; }
.mkdb-app .mkdb-event .mkdb-event-time { font-size: 12.5px; color: var(--mkdb-agenda); font-weight: 700; }
.mkdb-app .mkdb-event .mkdb-event-desc { font-size: 13px; color: #4b5563; margin-top: 4px; white-space: pre-wrap; }
.mkdb-app .mkdb-event .mkdb-note-actions { display: flex; gap: 6px; }

/* ---------- Bestanden ---------- */
.mkdb-app .mkdb-files-grid {
	display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 16px;
}
.mkdb-app .mkdb-file {
	background: var(--mkdb-card); border-radius: 14px; box-shadow: var(--mkdb-shadow-sm);
	overflow: hidden; display: flex; flex-direction: column; position: relative;
}
.mkdb-app .mkdb-file-thumb {
	height: 110px; display: flex; align-items: center; justify-content: center;
	font-size: 40px; background: #f6f7fb; background-size: cover; background-position: center;
}
.mkdb-app .mkdb-file-kind-pdf   { color: #e11d48; }
.mkdb-app .mkdb-file-kind-word  { color: #2563eb; }
.mkdb-app .mkdb-file-kind-excel { color: #059669; }
.mkdb-app .mkdb-file-kind-ppt   { color: #ea580c; }
.mkdb-app .mkdb-file-kind-text  { color: #6b7280; }
.mkdb-app .mkdb-file-kind-csv   { color: #16a34a; }
.mkdb-app .mkdb-file-kind-archive { color: #a16207; }
.mkdb-app .mkdb-file-info { padding: 10px 12px; }
.mkdb-app .mkdb-file-name { font-size: 13px; font-weight: 700; word-break: break-word; }
.mkdb-app .mkdb-file-meta { font-size: 11px; color: var(--mkdb-muted); margin-top: 3px; display: flex; align-items: center; gap: 6px; }
.mkdb-app .mkdb-file-actions { display: flex; gap: 6px; padding: 0 12px 12px; }
.mkdb-app .mkdb-file-actions .mkdb-btn { flex: 1; text-align: center; }

.mkdb-app .mkdb-dropzone {
	border: 2px dashed #c7cbe0; border-radius: 14px; padding: 22px; text-align: center;
	color: var(--mkdb-muted); cursor: pointer; transition: background .15s, border-color .15s; margin-bottom: 20px; background: var(--mkdb-card);
}
.mkdb-app .mkdb-dropzone.drag { background: #eef2ff; border-color: var(--mkdb-files); color: var(--mkdb-files); }
.mkdb-app .mkdb-dropzone strong { color: var(--mkdb-ink); }

/* ---------- Prikbord ---------- */
.mkdb-app .mkdb-board-toolbar { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; flex-wrap: wrap; }
.mkdb-app .mkdb-board-hint { font-size: 12.5px; color: var(--mkdb-muted); }
.mkdb-app .mkdb-board {
	position: relative; width: 100%; height: 560px; overflow: hidden;
	background:
		radial-gradient(circle, #d9deef 1.5px, transparent 1.5px);
	background-size: 22px 22px;
	background-color: #f6f7fc;
	border-radius: var(--mkdb-radius); box-shadow: inset 0 2px 10px rgba(31,41,55,.06);
	touch-action: none;
}
.mkdb-app .mkdb-board svg { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; }
.mkdb-app .mkdb-board svg line { stroke: #9aa3c4; stroke-width: 2.5; pointer-events: stroke; cursor: pointer; }
.mkdb-app .mkdb-board svg line:hover { stroke: #ec4899; stroke-width: 3.5; }
.mkdb-app .mkdb-sticky {
	position: absolute; width: 170px; min-height: 120px; border-radius: 4px;
	box-shadow: 3px 5px 14px rgba(31,41,55,.18); padding: 10px 12px 30px;
	font-size: 13px; transform: rotate(-1deg); cursor: grab;
	display: flex; flex-direction: column;
}
.mkdb-app .mkdb-sticky.dragging { cursor: grabbing; box-shadow: 6px 10px 22px rgba(31,41,55,.28); z-index: 50 !important; transform: rotate(0deg) scale(1.02); }
.mkdb-app .mkdb-sticky.link-source { outline: 3px solid var(--mkdb-board); outline-offset: 2px; }
.mkdb-app .mkdb-sticky textarea {
	border: 0; background: transparent; resize: none; width: 100%; flex: 1;
	font-family: inherit; font-size: 13px; color: #3b2f12; outline: none; line-height: 1.45;
}
.mkdb-app .mkdb-sticky[data-readonly="1"] textarea { cursor: default; }
.mkdb-app .mkdb-sticky-bar {
	position: absolute; left: 8px; right: 8px; bottom: 6px;
	display: flex; align-items: center; gap: 4px; opacity: 0; transition: opacity .12s;
}
.mkdb-app .mkdb-sticky:hover .mkdb-sticky-bar { opacity: 1; }
.mkdb-app .mkdb-sticky-bar button {
	border: 0; background: rgba(255,255,255,.55); cursor: pointer; width: 24px; height: 22px;
	border-radius: 6px; font-size: 12px; display: inline-flex; align-items: center; justify-content: center;
}
.mkdb-app .mkdb-sticky-bar button:hover { background: #fff; }
.mkdb-app .mkdb-sticky-bar .sw { width: 14px; height: 14px; border-radius: 50%; border: 1px solid rgba(0,0,0,.15); cursor: pointer; }

/* ---------- Berichten ---------- */
.mkdb-app .mkdb-msg-layout { display: grid; grid-template-columns: 280px 1fr; gap: 18px; align-items: start; }
.mkdb-app .mkdb-thread-list { display: flex; flex-direction: column; gap: 8px; }
.mkdb-app .mkdb-thread-item {
	background: var(--mkdb-card); border-radius: 12px; padding: 12px 14px; cursor: pointer;
	box-shadow: var(--mkdb-shadow-sm); border-left: 4px solid transparent; display: flex; gap: 10px; align-items: center;
}
.mkdb-app .mkdb-thread-item.active { border-left-color: var(--mkdb-messages); background: #fff7ed; }
.mkdb-app .mkdb-thread-item.unread { border-left-color: #ef4444; }
.mkdb-app .mkdb-thread-item .mkdb-mini-av {
	width: 36px; height: 36px; border-radius: 50%; flex: 0 0 36px; background-size: cover; background-position: center;
	display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 800; font-size: 13px;
}
.mkdb-app .mkdb-thread-item .t-name { font-weight: 700; font-size: 13.5px; }
.mkdb-app .mkdb-thread-item .t-snip { font-size: 12px; color: var(--mkdb-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 180px; }

.mkdb-app .mkdb-thread-view {
	background: var(--mkdb-card); border-radius: var(--mkdb-radius); padding: 18px; box-shadow: var(--mkdb-shadow-sm);
	display: flex; flex-direction: column; min-height: 420px;
}
.mkdb-app .mkdb-bubbles { flex: 1; display: flex; flex-direction: column; gap: 12px; overflow: auto; padding-right: 4px; }
.mkdb-app .mkdb-bubble { max-width: 80%; }
.mkdb-app .mkdb-bubble .b-head { display: flex; align-items: center; gap: 7px; margin-bottom: 4px; }
.mkdb-app .mkdb-bubble .mkdb-mini-av { width: 26px; height: 26px; font-size: 11px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 800; background-size: cover; }
.mkdb-app .mkdb-bubble .b-name { font-size: 12px; font-weight: 700; color: var(--mkdb-muted); }
.mkdb-app .mkdb-bubble .b-body { background: #f3f4f8; padding: 10px 14px; border-radius: 4px 14px 14px 14px; font-size: 13.5px; white-space: pre-wrap; word-break: break-word; }
.mkdb-app .mkdb-bubble.mine { align-self: flex-end; }
.mkdb-app .mkdb-bubble.mine .b-head { flex-direction: row-reverse; }
.mkdb-app .mkdb-bubble.mine .b-body { background: #ffedd5; border-radius: 14px 4px 14px 14px; }
.mkdb-app .mkdb-bubble .b-time { font-size: 10.5px; color: #9ca3af; margin-top: 3px; }

.mkdb-app .mkdb-reply { display: flex; gap: 8px; margin-top: 14px; border-top: 1px solid var(--mkdb-line); padding-top: 14px; }
.mkdb-app .mkdb-reply textarea {
	flex: 1; border: 1px solid var(--mkdb-line); border-radius: 12px; padding: 10px 12px;
	font-family: inherit; font-size: 13.5px; resize: vertical; min-height: 46px; outline: none;
}
.mkdb-app .mkdb-reply textarea:focus { border-color: var(--mkdb-messages); }

.mkdb-app .mkdb-visitor-note {
	background: #fff7ed; border: 1px solid #fed7aa; color: #9a3412; border-radius: 12px;
	padding: 12px 14px; font-size: 13px; margin-bottom: 14px;
}

/* ---------- Modal ---------- */
.mkdb-app .mkdb-modal-bg {
	position: fixed; inset: 0; background: rgba(17,24,39,.55); z-index: 99999;
	display: flex; align-items: center; justify-content: center; padding: 20px;
}
.mkdb-app .mkdb-modal {
	background: #fff; border-radius: 18px; width: 100%; max-width: 460px; padding: 24px;
	box-shadow: 0 30px 70px rgba(0,0,0,.35); max-height: 90vh; overflow: auto;
}
.mkdb-app .mkdb-modal h3 { margin: 0 0 16px; font-size: 18px; font-weight: 800; }
.mkdb-app .mkdb-field { margin-bottom: 14px; }
.mkdb-app .mkdb-field label { display: block; font-size: 12.5px; font-weight: 700; margin-bottom: 5px; color: #374151; }
.mkdb-app .mkdb-field input[type=text],
.mkdb-app .mkdb-field input[type=email],
.mkdb-app .mkdb-field input[type=password],
.mkdb-app .mkdb-field input[type=date],
.mkdb-app .mkdb-field input[type=time],
.mkdb-app .mkdb-field textarea {
	width: 100%; border: 1px solid var(--mkdb-line); border-radius: 11px; padding: 10px 12px;
	font-family: inherit; font-size: 14px; outline: none;
}
.mkdb-app .mkdb-field textarea { resize: vertical; min-height: 90px; }
.mkdb-app .mkdb-field input:focus, .mkdb-app .mkdb-field textarea:focus { border-color: #6366f1; }
.mkdb-app .mkdb-color-row { display: flex; gap: 8px; flex-wrap: wrap; }
.mkdb-app .mkdb-color-row .sw { width: 28px; height: 28px; border-radius: 50%; cursor: pointer; border: 2px solid transparent; }
.mkdb-app .mkdb-color-row .sw.sel { border-color: #1f2937; transform: scale(1.1); }
.mkdb-app .mkdb-toggle { display: flex; align-items: center; gap: 10px; font-size: 13.5px; font-weight: 600; cursor: pointer; }
.mkdb-app .mkdb-switch { width: 42px; height: 24px; background: #d1d5db; border-radius: 999px; position: relative; transition: background .15s; flex: 0 0 42px; }
.mkdb-app .mkdb-switch::after { content: ''; position: absolute; top: 3px; left: 3px; width: 18px; height: 18px; background: #fff; border-radius: 50%; transition: left .15s; }
.mkdb-app .mkdb-toggle input { display: none; }
.mkdb-app .mkdb-toggle input:checked + .mkdb-switch { background: #6366f1; }
.mkdb-app .mkdb-toggle input:checked + .mkdb-switch::after { left: 21px; }
.mkdb-app .mkdb-modal-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 18px; }

/* ---------- Popover (notificaties / kleurkiezer) ---------- */
.mkdb-app .mkdb-pop {
	position: absolute; background: #fff; border-radius: 14px; box-shadow: 0 16px 40px rgba(0,0,0,.22);
	padding: 8px; z-index: 9999; min-width: 280px; border: 1px solid var(--mkdb-line);
}
.mkdb-app .mkdb-pop h4 { margin: 6px 10px 8px; font-size: 13px; color: var(--mkdb-muted); }
.mkdb-app .mkdb-notif {
	display: flex; gap: 10px; padding: 10px; border-radius: 10px; cursor: pointer; align-items: flex-start;
}
.mkdb-app .mkdb-notif:hover { background: #f6f7fb; }
.mkdb-app .mkdb-notif .n-dot { width: 8px; height: 8px; border-radius: 50%; background: #ef4444; margin-top: 6px; flex: 0 0 8px; }
.mkdb-app .mkdb-notif .n-txt { font-size: 13px; }
.mkdb-app .mkdb-notif .n-txt b { font-weight: 800; }
.mkdb-app .mkdb-notif .n-time { font-size: 11px; color: #9ca3af; }

/* ---------- Users (mensen) ---------- */
.mkdb-app .mkdb-people-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px,1fr)); gap: 14px; }
.mkdb-app .mkdb-person {
	background: var(--mkdb-card); border-radius: 14px; padding: 18px; text-align: center; box-shadow: var(--mkdb-shadow-sm); cursor: pointer; transition: transform .12s;
}
.mkdb-app .mkdb-person:hover { transform: translateY(-3px); }
.mkdb-app .mkdb-person .mkdb-mini-av { width: 56px; height: 56px; border-radius: 50%; margin: 0 auto 10px; display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 800; font-size: 20px; background-size: cover; }
.mkdb-app .mkdb-person .p-name { font-weight: 700; font-size: 14px; }
.mkdb-app .mkdb-person .p-me { font-size: 11px; color: var(--mkdb-profile); font-weight: 700; }

/* ---------- Toast ---------- */
.mkdb-app .mkdb-toast-wrap { position: fixed; bottom: 22px; left: 50%; transform: translateX(-50%); z-index: 100000; display: flex; flex-direction: column; gap: 8px; }
.mkdb-app .mkdb-toast {
	background: #1f2937; color: #fff; padding: 11px 20px; border-radius: 999px; font-size: 13.5px; font-weight: 600;
	box-shadow: 0 10px 30px rgba(0,0,0,.3); animation: mkdbToast .25s ease;
}
.mkdb-app .mkdb-toast.err { background: #b91c1c; }
@keyframes mkdbToast { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

/* ---------- Auth ---------- */
.mkdb-auth-wrap { min-height: 560px; align-items: center; justify-content: center; background: linear-gradient(165deg, #7c3aed, #6366f1 50%, #3b82f6); }
.mkdb-auth-card {
	background: #fff; border-radius: 22px; padding: 38px 34px; width: 100%; max-width: 400px; margin: 30px;
	box-shadow: 0 30px 70px rgba(0,0,0,.25); text-align: center;
}
.mkdb-auth-logo { font-size: 46px; margin-bottom: 8px; }
.mkdb-auth-card h2 { margin: 0 0 4px; font-size: 24px; font-weight: 800; }
.mkdb-auth-sub { color: var(--mkdb-muted); font-size: 14px; margin: 0 0 22px; }
.mkdb-auth-form { display: flex; flex-direction: column; gap: 14px; text-align: left; }
.mkdb-auth-form label { font-size: 12.5px; font-weight: 700; color: #374151; display: flex; flex-direction: column; gap: 5px; }
.mkdb-auth-form input[type=text], .mkdb-auth-form input[type=email], .mkdb-auth-form input[type=password] {
	border: 1px solid var(--mkdb-line); border-radius: 12px; padding: 11px 13px; font-size: 14px; font-family: inherit; outline: none;
}
.mkdb-auth-form input:focus { border-color: #6366f1; }
.mkdb-auth-form .mkdb-remember { flex-direction: row; align-items: center; gap: 8px; font-weight: 600; }
.mkdb-auth-form .mkdb-btn { margin-top: 6px; }
.mkdb-auth-error { background: #fee2e2; color: #b91c1c; border-radius: 12px; padding: 11px 14px; font-size: 13px; font-weight: 600; margin-bottom: 18px; }
.mkdb-auth-foot { font-size: 12.5px; color: var(--mkdb-muted); margin: 18px 0 0; }

/* ---------- Responsive (incl. Divi/Theme Builder mobile fix) ---------- */
@media (max-width: 980px) {
	/* Forceer volledige breedte op de Divi flex-ancestors die anders inklappen */
	.et_pb_module:has(.mkdb-app),
	.et_pb_column:has(.mkdb-app),
	.et_pb_row:has(.mkdb-app),
	.et_pb_section:has(.mkdb-app),
	.et_builder_inner_content:has(.mkdb-app) { width: 100% !important; max-width: 100% !important; }

	.mkdb-app { display: block; min-height: 0; }
	.mkdb-app .mkdb-side {
		position: fixed; top: 0; left: 0; bottom: 0; width: 260px; z-index: 100000;
		transform: translateX(-100%); transition: transform .22s ease;
	}
	.mkdb-app .mkdb-side.open { transform: translateX(0); }
	.mkdb-app .mkdb-burger { display: inline-block; }
	.mkdb-app .mkdb-scrim {
		display: none; position: fixed; inset: 0; background: rgba(0,0,0,.45); z-index: 99999;
	}
	.mkdb-app .mkdb-scrim.show { display: block; }
	.mkdb-app .mkdb-agenda-wrap { grid-template-columns: 1fr; }
	.mkdb-app .mkdb-msg-layout { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
	.mkdb-app .mkdb-content { padding: 16px; }
	.mkdb-app .mkdb-top { padding: 14px 16px; }
	.mkdb-app .mkdb-notes-grid { grid-template-columns: 1fr 1fr; }
	.mkdb-app .mkdb-files-grid { grid-template-columns: 1fr 1fr; }
}
