/* // SOURCE_HASH: <Version: 1.1.32.V> */
/* // Version: 1.1.32.V
// Last updated: 2025-12-27 16:35*/
/* File: dashboard/public/css/dashboard-public.css */
/* Shortcode: [dashboard] */
/* Version: 1.1.32.V */
/* Last updated: 2025-12-27 16:35 */
/* Dashboard pages should never show theme sidebars. */
body.vbd-dashboard-page #secondary,
body.vbd-dashboard-page .widget-area,
body.vbd-dashboard-page .sidebar,
body.vbd-dashboard-page .site-sidebar,
body.vbd-dashboard-page .right-sidebar,
body.vbd-dashboard-page .left-sidebar {
	display: none !important;
}

body.vbd-dashboard-page .content-area,
body.vbd-dashboard-page .site-content .content-area {
	width: 100% !important;
	max-width: 100% !important;
}

body.vbd-dashboard-page .site-main {
	margin: 0 !important;
}

.dashboard-app {
	max-width: 1100px;
	margin: 0 auto;
	padding: 18px 14px 40px;
	font-family: inherit;
	position: relative;
}

/* Minimal layout when the dashboard is rendered inside an iframe modal (Archief overlay). */
.dashboard-app.dashboard-app-embed {
	max-width: none;
	margin: 0;
	padding: 12px 14px 18px;
}

.dashboard-app .dashboard-title {
	margin: 0 0 12px;
}

.dashboard-app .dashboard-topbar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	padding: 12px 14px;
	border-radius: 12px;
	background: #fff;
	border: 1px solid rgba(0,0,0,0.08);
	box-shadow: 0 2px 10px rgba(0,0,0,0.05);
}

.dashboard-app .dashboard-topbar-title {
	font-weight: 900;
	font-size: 16px;
}

.dashboard-app .dashboard-topbar-actions {
	display: flex;
	gap: 30px;
	align-items: center;
	flex-wrap: wrap;
}

.dashboard-app .dashboard-tile {
	background: #fff;
	border: 1px solid rgba(0,0,0,0.08);
	border-radius: 14px;
	padding: 14px 16px;
	box-shadow: 0 2px 10px rgba(0,0,0,0.05);
}

.dashboard-app .dashboard-tile.dashboard-tile-clickable {
	cursor: pointer;
}

.dashboard-app .dashboard-tile.dashboard-tile-clickable:hover {
	border-color: rgba(0,0,0,0.14);
	box-shadow: 0 4px 14px rgba(0,0,0,0.07);
}

.dashboard-app .dashboard-tile h3 {
	margin: 0 0 8px;
}

.dashboard-app .dashboard-tile p {
	margin: 0 0 10px;
	color: rgba(0,0,0,0.72);
	font-weight: 600;
}

.dashboard-app .dashboard-tile-link {
	font-weight: 800;
	text-decoration: none;
	color: #1b5cff;
}

.dashboard-app .dashboard-tile-link:hover {
	text-decoration: underline;
}

.dashboard-app .dashboard-back-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 8px 12px;
	border-radius: 10px;
	border: 1px solid rgba(0,0,0,0.12);
	background: #fff;
	font-weight: 800;
	text-decoration: none;
	color: rgba(0,0,0,0.82);
	margin: 6px 0 14px;
}

.dashboard-app .dashboard-back-link:hover {
	background: rgba(0,0,0,0.04);
}

.dashboard-app .dashboard-notice {
	margin: 10px 0;
	padding: 12px 14px;
	border-radius: 10px;
	font-weight: 600;
	background: #f6f6f6;
	border: 1px solid rgba(0,0,0,0.08);
}

.dashboard-app .dashboard-notice-success {
	background: #f1fff4;
	border-color: rgba(0,140,30,0.2);
}

.dashboard-app .dashboard-notice-error {
	background: #fff2f2;
	border-color: rgba(180,20,20,0.20);
}

.dashboard-app .dashboard-notice-warning {
	background: #fffbe8;
	border-color: rgba(180,140,20,0.30);
}

.dashboard-app .dashboard-tiles {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
	margin-top: 14px;
}

@media (max-width: 950px) {
	.dashboard-app .dashboard-tiles {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 620px) {
	.dashboard-app .dashboard-tiles {
		grid-template-columns: 1fr;
	}
}

.dashboard-app .dashboard-actions-row {
	display: flex;
	gap: 10px;
	align-items: center;
	margin: 12px 0 14px;
	flex-wrap: wrap;
}

.dashboard-app .dashboard-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 14px;
	border-radius: 10px;
	border: 1px solid rgba(0,0,0,0.12);
	background: #1b5cff;
	color: #fff;
	font-weight: 900;
	text-decoration: none;
	cursor: pointer;
}

.dashboard-app .dashboard-button:hover {
	filter: brightness(0.98);
}

.dashboard-app .dashboard-button-secondary {
	background: #fff;
	color: rgba(0,0,0,0.85);
}

.dashboard-app .dashboard-button-secondary:hover {
	background: rgba(0,0,0,0.04);
	color: #808080;
}

.dashboard-app .dashboard-form-section {
	background: #fff;
	border: 1px solid rgba(0,0,0,0.08);
	border-radius: 12px;
	padding: 14px 16px;
	box-shadow: 0 2px 10px rgba(0,0,0,0.05);
	margin: 12px 0;
}

.dashboard-app .dashboard-form-section h3 {
	margin: 0 0 10px;
}

.dashboard-app .dashboard-field {
	margin-bottom: 12px;
}

.dashboard-app .dashboard-field label {
	display: block;
	font-weight: 800;
	margin-bottom: 6px;
}

.dashboard-app .dashboard-field input[type="text"],
.dashboard-app .dashboard-field input[type="email"],
.dashboard-app .dashboard-field input[type="number"],
.dashboard-app .dashboard-field input[type="date"],
.dashboard-app .dashboard-field input[type="password"],
.dashboard-app .dashboard-field textarea,
.dashboard-app .dashboard-field select {
	width: 100%;
	padding: 10px 12px;
	border-radius: 10px;
	border: 1px solid rgba(0,0,0,0.12);
	background: #fff;
	font-weight: 600;
}

.dashboard-app .dashboard-grid-2 {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}

.dashboard-app .dashboard-grid-3 {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px;
}

.dashboard-app .dashboard-grid-3-461 {
	display: grid;
	grid-template-columns: 4fr 1fr 1fr;
	gap: 12px;
}

.dashboard-app .dashboard-static-field {
	/* Lijkt op form field, maar zonder input-border */
	align-self: end;
}

.dashboard-app .dashboard-static-label {
	font-size: 12px;
	font-weight: 600;
	color: rgba(0,0,0,0.58);
	margin: 0 0 4px;
}

.dashboard-app .dashboard-static-value {
	font-size: 14px;
	font-weight: 900;
	color: rgba(0,0,0,0.85);
	padding: 7px 10px;
	line-height: 1.35;
}

@media (max-width: 820px) {
	.dashboard-app .dashboard-grid-2,
	.dashboard-app .dashboard-grid-3,
	.dashboard-app .dashboard-grid-3-461 {
		grid-template-columns: 1fr;
	}
}

.dashboard-app .dashboard-checkbox {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: 700;
}

.dashboard-app .dashboard-password-field,
.dashboard-password-field {
	display: flex;
	align-items: center;
	gap: 10px;
}

.dashboard-app .dashboard-password-field input,
.dashboard-password-field input {
	flex: 1 1 auto;
	min-width: 0;
}

.dashboard-app .dashboard-permissions {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px 18px;
	font-size: 14px;
}

@media (max-width: 900px) {
	.dashboard-app .dashboard-permissions {
		grid-template-columns: 1fr;
	}
}

.dashboard-app .dashboard-permission-row {
	display: inline-flex;
	align-items: flex-start;
	gap: 10px;
	font-weight: 400;
	line-height: 1.25;
}

.dashboard-app .dashboard-permission-row input[type="checkbox"] {
	margin: 2px 0 0 0;
}
.dashboard-app .dashboard-user-photo-preview,
.dashboard-user-photo-preview {
	width: 250px;
	height: 250px;
	max-width: 250px;
	max-height: 250px;
	border-radius: 14px;
	border: 1px solid rgba(0,0,0,0.14);
	overflow: hidden;
	background: rgba(0,0,0,0.03);
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 6px 6px 0 rgba(0,0,0,0.08);
	flex: 0 0 auto;
}

.dashboard-app .dashboard-user-photo-preview img,
.dashboard-user-photo-preview img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.dashboard-app .dashboard-avatar {
	width: 38px;
	height: 38px;
	border-radius: 10px;
	border: 1px solid rgba(0,0,0,0.10);
	background: rgba(0,0,0,0.04);
	overflow: hidden;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.dashboard-app .dashboard-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}


/* ===== Admin module header & tabs ===== */
.dashboard-app .dashboard-module-header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 12px;
	flex-wrap: wrap;
	margin: 10px 0 12px;
}

.dashboard-app .dashboard-module-title {
	margin: 0;
	font-size: 22px;
	line-height: 1.2;
}

.dashboard-app .dashboard-module-subtitle {
	margin: 6px 0 0;
	font-weight: 700;
	color: rgba(0,0,0,0.60);
}

.dashboard-app .dashboard-tabs {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	margin: 8px 0 14px;
}

.dashboard-app .dashboard-tab {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 8px 12px;
	border-radius: 999px;
	border: 1px solid rgba(0,0,0,0.12);
	background: #fff;
	text-decoration: none;
	font-weight: 800;
	color: rgba(0,0,0,0.78);
}

.dashboard-app .dashboard-tab:hover {
	background: rgba(0,0,0,0.04);
}

.dashboard-app .dashboard-tab.is-active {
	background: #1b5cff;
	border-color: #1b5cff;
	color: #fff;
}

/* ===== Settings / placeholders ===== */
.dashboard-app .dashboard-placeholder-box {
	background: #fff;
	border: 1px dashed rgba(0,0,0,0.20);
	border-radius: 12px;
	padding: 14px 16px;
	margin: 12px 0;
}

.dashboard-app .dashboard-placeholder-box h3 {
	margin: 0 0 8px;
}

.dashboard-app .dashboard-placeholder-box p {
	margin: 0;
	font-weight: 600;
	color: rgba(0,0,0,0.70);
}

/* ===== Maintenance ===== */
.dashboard-app .dashboard-maintenance-box {
	background: #fff;
	border: 1px solid rgba(0,0,0,0.10);
	border-radius: 12px;
	padding: 16px 16px;
	margin: 16px 0;
	box-shadow: 0 2px 10px rgba(0,0,0,0.05);
}

.dashboard-app .dashboard-maintenance-box h2 {
	margin: 0 0 8px;
}

.dashboard-app .dashboard-maintenance-box p {
	margin: 0;
	font-weight: 700;
	color: rgba(0,0,0,0.70);
}

/* ===== Nummering / sequences ===== */
.dashboard-app .dashboard-sequence-block {
	border: 1px solid rgba(0,0,0,0.08);
	border-radius: 12px;
	padding: 12px 12px 10px;
	margin: 12px 0;
	background: #ffffff;
}

.dashboard-app .dashboard-sequence-block h4 {
	margin: 0 0 10px;
	font-weight: 900;
}

.dashboard-app .dashboard-sequence-preview {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-top: 8px;
	padding: 10px 12px;
	border-radius: 12px;
	background: #fbfbfb;
	border: 1px dashed rgba(0,0,0,0.18);
	font-weight: 700;
	flex-wrap: wrap;
}

.dashboard-app .dashboard-sequence-preview .label {
	color: rgba(0,0,0,0.65);
}

.dashboard-app .dashboard-sequence-preview code {
	padding: 4px 8px;
	border-radius: 10px;
	background: #ffffff;
	border: 1px solid rgba(0,0,0,0.10);
	font-weight: 900;
}


/* ===== Tables / badges / email UI ===== */
.dashboard-app .dashboard-muted {
	color: rgba(0,0,0,0.60);
	font-weight: 600;
	font-size: 13px;
	margin-top: 4px;
}

.dashboard-app .dashboard-table {
	width: 100%;
	border-collapse: collapse;
	background: #fff;
	border: 1px solid rgba(0,0,0,0.10);
	border-radius: 12px;
	overflow: hidden;
}

.dashboard-app .dashboard-table th,
.dashboard-app .dashboard-table td {
	padding: 10px 12px;
	border-bottom: 1px solid rgba(0,0,0,0.08);
	vertical-align: top;
}

.dashboard-app .dashboard-table th {
	text-align: left;
	font-weight: 900;
	background: #fbfbfb;
}

.dashboard-app .dashboard-table tbody tr:hover td {
	background: rgba(0,0,0,0.02);
}

.dashboard-app .dashboard-actions-inline {
	display: inline-flex;
	gap: 30px;
	align-items: center;
	flex-wrap: wrap;
}

.dashboard-app .dashboard-link {
	font-weight: 800;
	color: #1b5cff;
	text-decoration: none;
	background: none;
	border: 0;
	padding: 0;
	cursor: pointer;
}

.dashboard-app .dashboard-link:hover {
	text-decoration: underline;
}

.dashboard-app .dashboard-link.danger {
	color: #b00020;
}

.dashboard-app .dashboard-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 900;
	border: 1px solid rgba(0,0,0,0.10);
	background: #fff;
	margin-right: 6px;
}

.dashboard-app .dashboard-badge.is-green {
	background: #f1fff4;
	border-color: rgba(0,140,30,0.20);
	color: rgba(0,100,20,1);
}

.dashboard-app .dashboard-badge.is-gray {
	background: #f6f6f6;
	border-color: rgba(0,0,0,0.10);
	color: rgba(0,0,0,0.65);
}

.dashboard-app .dashboard-badge.is-amber {
	background: #fff7e6;
	border-color: rgba(160,100,0,0.22);
	color: rgba(120,70,0,1);
}

.dashboard-app .dashboard-textarea-large {
	min-height: 160px;
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
	font-size: 13px;
	line-height: 1.4;
}

.dashboard-app .dashboard-email-vars {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

.dashboard-app .dashboard-email-vars code {
	padding: 4px 8px;
	border-radius: 10px;
	background: #ffffff;
	border: 1px solid rgba(0,0,0,0.10);
	font-weight: 900;
}

.dashboard-app .dashboard-email-templates-grid {
	align-items: start;
}

/* =========================================================
   Compact UX overrides (v1.1.20)
   - kleinere typografie
   - minder whitespace
   - consistente action bars
   - modal styling
   ========================================================= */

.dashboard-app{
  max-width: 1200px;
  padding: 14px 12px 34px;
  font-size: 14px;
  line-height: 1.35;
}

.dashboard-app h2{ font-size: 20px; margin: 0; }
.dashboard-app h3{ font-size: 16px; margin: 0 0 8px; }
.dashboard-app h4{ font-size: 14px; margin: 0 0 6px; }

.dashboard-actions-row{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  margin: 8px 0 10px;
}

.dashboard-actions-right{
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.dashboard-actions-row-footer{
  margin-top: 12px;
}

.dashboard-form-section{
  padding: 10px 12px;
  margin: 10px 0;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,0.08);
  background: #fff;
  box-shadow: 0 1px 6px rgba(0,0,0,0.04);
}

.dashboard-card{
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,0.08);
  background: #fff;
  box-shadow: 0 1px 6px rgba(0,0,0,0.04);
}

.dashboard-field{
  margin-bottom: 8px;
}

.dashboard-field label{
  font-weight: 700;
  font-size: 13px;
  margin-bottom: 4px;
}

.dashboard-field input[type="text"],
.dashboard-field input[type="email"],
.dashboard-field input[type="number"],
.dashboard-field input[type="date"],
.dashboard-field input[type="password"],
.dashboard-field select,
.dashboard-field textarea{
  padding: 7px 9px;
  border-radius: 8px;
}

/* Mijn profiel layout */
.dashboard-profile-grid{
	display: grid;
	grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
	gap: 14px;
	align-items: start;
}

@media (max-width: 900px){
	.dashboard-profile-grid{ grid-template-columns: 1fr; }
}

/* Maak wachtwoordvelden compacter op Mijn profiel */
.dashboard-profile-grid .dashboard-password-field input[type="password"]{
	max-width: 360px;
}

.dashboard-grid-2,
.dashboard-grid-3{
  gap: 8px;
}

.dashboard-button{
  padding: 8px 12px;
  border-radius: 8px;
  font-weight: 700;
  font-size: 13px;
}

.dashboard-table th,
.dashboard-table td{
  padding: 8px 10px;
  font-size: 13px;
  vertical-align: top;
}

.dashboard-radio-row{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
}

.dashboard-radio-row label{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 0;
  font-weight: 600;
}

.dashboard-muted{
  font-size: 12px;
}

.dashboard-doc-upload-status{
  font-size: 12px;
}

.dashboard-details{
  margin-top: 10px;
  padding-top: 8px;
  border-top: 1px solid rgba(0,0,0,0.08);
}

.dashboard-details > summary{
  cursor: pointer;
  font-weight: 800;
  list-style: none;
}

.dashboard-details > summary::-webkit-details-marker{
  display:none;
}

.dashboard-row-primary td{
  background: rgba(0,0,0,0.03);
}

.dashboard-actions-cell{
  white-space: nowrap;
}

.dashboard-actions-cell .dashboard-button{
  margin-right: 6px;
}

/* Modal */
.dashboard-modal-overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.45);
  display: none;
  z-index: 99999;
  padding: 16px;
}

.dashboard-modal-overlay.is-open{
  display: flex;
  align-items: center;
  justify-content: center;
}

.dashboard-modal{
  width: 100%;
  max-width: 760px;
  max-height: 90vh;
  overflow: auto;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.10);
  background: #fff;
  box-shadow: 0 10px 30px rgba(0,0,0,0.25);
  padding: 12px 14px;
}

.dashboard-modal-header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}

.dashboard-modal-close{
  white-space: nowrap;
}
/* ========================================================================== */
/* UX compact tweaks (Sprint C UX) - v1.1.21 */
/* ========================================================================== */

.dashboard-app {
	font-size: 14px;
}

.dashboard-app .dashboard-module-title {
	font-size: 20px;
	margin: 12px 0 12px;
}

.dashboard-app .dashboard-form-section {
	padding: 12px 14px;
	margin: 12px 0;
}

.dashboard-app .dashboard-form-section h3 {
	font-size: 15px;
	margin: 0 0 10px;
}

.dashboard-app .dashboard-grid-2,
.dashboard-app .dashboard-grid-3 {
	gap: 10px;
}

.dashboard-app .dashboard-field {
	margin-bottom: 10px;
}

.dashboard-app .dashboard-field label {
	font-size: 12px;
	margin-bottom: 4px;
}

.dashboard-app .dashboard-field input[type="text"],
.dashboard-app .dashboard-field input[type="email"],
.dashboard-app .dashboard-field input[type="number"],
.dashboard-app .dashboard-field input[type="date"],
.dashboard-app .dashboard-field input[type="password"],
.dashboard-app .dashboard-field select,
.dashboard-app .dashboard-field textarea {
	padding: 7px 10px;
	border-radius: 10px;
	font-size: 13px;
}

.dashboard-app .dashboard-field textarea {
	min-height: 90px;
}

.dashboard-app .dashboard-button {
	padding: 7px 12px;
	border-radius: 999px;
	font-size: 13px;
}

.dashboard-app .dashboard-button-small {
	padding: 5px 10px;
	font-size: 12px;
}

.dashboard-app .dashboard-muted {
	font-size: 12px;
}

/* Page header actions (titel + knoppen rechts) */
.dashboard-page-header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 12px;
	flex-wrap: wrap;
	margin: 6px 0 14px;
}

.dashboard-page-header h2 {
	margin: 0;
	font-size: 18px;
	line-height: 1.2;
}

.dashboard-page-actions {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 30px;
	flex-wrap: wrap;
}

.dashboard-page-footer-actions {
	margin-top: 14px;
}

/* Section header with actions (zoals contactpersonen) */
.dashboard-section-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 10px;
}

/* Compact tables */
.dashboard-card--table {
	padding: 0;
	overflow-x: auto;
	border-radius: 12px;
}

.dashboard-table--compact th,
.dashboard-table--compact td {
	padding: 6px 10px;
	font-size: 14px;
	vertical-align: middle;
}

/* C3b – Plan catalogus compact (Producten & prijzen) */
.dashboard-placeholder-box--compact {
	padding: 14px;
}

.dashboard-button-add {
	background: #1b5cff;
	border-color: #1b5cff;
	color: #fff;
}

.dashboard-button-add:hover {
	filter: brightness(0.9);
}

.dashboard-plan-table .dashboard-col-price {
	width: 220px;
}

.dashboard-price-input-wrap {
	display: inline-flex;
	align-items: center;
	gap: 10px;
}

.dashboard-input--price {
	width: 160px;
	max-width: 100%;
	font-size: 14px;
	padding: 7px 10px;
	height: 36px;
	border-radius: 10px;
}

.dashboard-plan-tier h2 {
	font-size: 18px;
}

/* Archive details */
.dashboard-documents-archive {
	margin-top: 12px;
}

.dashboard-documents-archive summary {
	cursor: pointer;
	font-weight: 600;
}

.dashboard-documents-archive summary.dashboard-doc-archive-summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

.dashboard-documents-archive summary.dashboard-doc-archive-summary .dashboard-doc-archive-summary-title {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.dashboard-documents-archive summary.dashboard-doc-archive-summary .dashboard-doc-bulk-actions {
	display: inline-flex;
	gap: 8px;
	align-items: center;
}

.dashboard-documents-archive .dashboard-doc-check-col {
	width: 38px;
}

.dashboard-documents-archive .dashboard-doc-check-col input[type="checkbox"] {
	margin: 0;
}

/* Modal */
.dashboard-modal {
	position: fixed;
	inset: 0;
	z-index: 99999;
	background: rgba(0,0,0,0.35);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
}

.dashboard-modal[aria-hidden="true"] {
	display: none;
}

.dashboard-modal-dialog {
	background: #fff;
	border-radius: 14px;
	width: min(760px, 100%);
	max-height: calc(100vh - 32px);
	overflow: auto;
	box-shadow: 0 18px 50px rgba(0,0,0,0.25);
}

/* Wide modal (used for Archief overlay) */
.dashboard-modal-dialog--wide {
	width: 90vw !important;
	max-width: 90vw !important;
	height: 90vh !important;
	max-height: 90vh !important;
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

/* Archief modal sizing fallback (forces 90% viewport even if --wide class is missing) */
#dashboard-archive-modal .dashboard-modal-dialog {
	width: 90vw !important;
	max-width: 90vw !important;
	height: 90vh !important;
	max-height: 90vh !important;
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

#dashboard-archive-modal .dashboard-modal-body {
	flex: 1;
	display: flex;
	flex-direction: column;
	min-height: 0;
}

#dashboard-archive-modal .dashboard-modal-body iframe {
	flex: 1;
	min-height: 0;
	width: 100%;
	border: 0;
}

/* Archief modal sizing fallback (legacy overlay structure: dashboard-modal-overlay + dashboard-modal) */
#dashboard-archive-modal.dashboard-modal-overlay .dashboard-modal {
	width: 90vw !important;
	max-width: 90vw !important;
	height: 90vh !important;
	max-height: 90vh !important;
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

#dashboard-archive-modal.dashboard-modal-overlay .dashboard-modal-body {
	flex: 1;
	display: flex;
	flex-direction: column;
	min-height: 0;
}

#dashboard-archive-modal.dashboard-modal-overlay .dashboard-modal-body iframe {
	flex: 1;
	min-height: 0;
	width: 100%;
	border: 0;
	height: 100% !important;
}

/* Force iframe to scale inside 90vh dialog even if inline height is present */
#dashboard-archive-modal .dashboard-modal-body iframe {
	height: 100% !important;
}


.dashboard-modal-dialog--wide .dashboard-modal-body {
	flex: 1;
	display: flex;
	flex-direction: column;
}

.dashboard-modal-body--archive {
	gap: 12px;
}

.dashboard-archive-iframe {
	flex: 1;
	width: 100%;
	height: 100%;
	border: 0;
	border-radius: 12px;
	background: #fff;
}

.dashboard-modal-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 12px 14px;
	border-bottom: 1px solid #eee;
}

.dashboard-modal-body {
	padding: 12px 14px 14px;
}

.dashboard-modal-close {
	appearance: none;
	border: 0;
	background: transparent;
	font-size: 22px;
	line-height: 1;
	padding: 4px 8px;
	cursor: pointer;
}

.dashboard-actions-row--modal {
	display: flex;
	justify-content: flex-end;
	gap: 8px;
	margin-top: 12px;
}

/* Ensure radio rows stay horizontal */
.dashboard-app .dashboard-radio-row {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: center;
}

.dashboard-app .dashboard-radio-row label {
	margin: 0;
}

/* Responsive */
@media (max-width: 980px) {
	.dashboard-app .dashboard-grid-3 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 720px) {
	.dashboard-app .dashboard-grid-2,
	.dashboard-app .dashboard-grid-3 {
		grid-template-columns: 1fr;
	}
	.dashboard-page-header {
		align-items: flex-start;
	}
	.dashboard-page-actions {
		justify-content: flex-start;
	}
}

/* =========================================================
   v1.1.22 - UX baseline (knoppen + compacte formulieren)
   ========================================================= */

/* Titelafstand (o.a. "Klant bewerken") */
.dashboard-page-header{
  margin: 40px 0 20px;
}

/* Actieknoppen: meer ruimte tussen knoppen */
.dashboard-page-actions{
  gap: 32px;
}
.dashboard-actions-row{
  gap: 32px;
}

/* Compactere velden (norm voor SAAS frontend) */
.dashboard-app .dashboard-form-section h3{
  font-size: 15px;
  margin: 0 0 10px;
}
.dashboard-app .dashboard-field label{
  font-size: 12px;
  margin: 0 0 6px;
}
.dashboard-app .dashboard-field input,
.dashboard-app .dashboard-field select,
.dashboard-app .dashboard-field textarea{
  font-size: 13px;
  padding: 6px 10px;
  min-height: 36px;
}
.dashboard-app .dashboard-field textarea{
  min-height: 90px;
}

/* Knoppen: standaard donkergrijs (#808080) met wit font */
.dashboard-app .dashboard-button,
.dashboard-button{
  background: #808080;
  border-color: #6f6f6f;
  color: #fff;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  font-size: 13px;
  font-weight: 800;
  transition: transform .12s ease, filter .12s ease, background-color .12s ease, border-color .12s ease;
}

.dashboard-app .dashboard-button:hover,
.dashboard-button:hover{
  transform: scale(1.1);
  filter: brightness(1.05);
}

.dashboard-app .dashboard-button:active,
.dashboard-button:active{
  transform: scale(1.08);
  filter: brightness(0.9);
}

/* Variants */
.dashboard-app .dashboard-button-primary,
.dashboard-button-primary{
  background: #808080;
  border-color: #6f6f6f;
}

.dashboard-app .dashboard-button-secondary,
.dashboard-button-secondary{
  background: #808080;
  border-color: #6f6f6f;
  color: #fff;
}

/* Zoeken: blauw (consistent met links/tiles) */
.dashboard-app .dashboard-button-search,
.dashboard-button-search{
  background: #1b5cff;
  border-color: #1547c9;
  color: #fff;
}

.dashboard-app .dashboard-button-danger,
.dashboard-button-danger{
  background: #c62828;
  border-color: #a61f1f;
  color: #fff;
}

.dashboard-app .dashboard-button-view,
.dashboard-button-view{
  background: #2e7d32;
  border-color: #256628;
  color: #fff;
}


.dashboard-app .dashboard-button-archive,
.dashboard-button-archive{
  background: #c96a00;
  border-color: #a85600;
  color: #fff;
}

/* Kleine buttons behouden hoogte */
.dashboard-app .dashboard-button-small,
.dashboard-button-small{
  min-height: 36px;
}

/* Abonnement-terms */
.dashboard-subscription-terms{
  margin-top: 8px;
  color: #555;
  font-size: 12px;
}


/* Document type/categorie dropdown in documenten-tabel */
.dashboard-doc-category-cell {
	white-space: nowrap;
}

.dashboard-doc-category-select {
	max-width: 240px;
}

.dashboard-doc-category-status {
	margin-left: 6px;
	font-size: 12px;
}


/* Sprint 1.1.32.S - UX tweaks */
.dashboard-app .dashboard-button-secondary:hover,
.dashboard-button-secondary:hover{
	color: #808080;
}

/* Kleine hulptekst achter label (max 10px) */
.dashboard-app .dashboard-label-help{
	font-size: 10px;
	font-weight: 400;
	color: rgba(0,0,0,0.55);
	margin-left: 6px;
}

/* Archief filterbar: gelijke breedte/hoogte voor selects en input */
.dashboard-app .dashboard-archive-filters select,
.dashboard-app .dashboard-archive-filters input[type="text"]{
	width: 100%;
	box-sizing: border-box;
	height: 38px;
	min-height: 38px;
}


/* Password visibility toggles */
.dashboard-app .dashboard-input-row {
	display: flex;
	align-items: center;
	gap: 10px;
}

.dashboard-app .dashboard-input-row input {
	flex: 1;
	min-width: 0;
}

.dashboard-app .dashboard-pass-toggle {
	white-space: nowrap;
	padding: 10px 12px;
	border-radius: 12px;
	border: 1px solid rgba(0,0,0,0.16);
	background: rgba(255,255,255,0.96);
	cursor: pointer;
	font-weight: 700;
}

/* =========================================================
   Sprint 1.2.01.B2e – Gebruikersbeheer UI/UX refinements
   ========================================================= */

/* 4-koloms grid (o.a. Contact & pasfoto) */
.dashboard-app .dashboard-grid-4,
.dashboard-grid-4 {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}

@media (max-width: 980px) {
	.dashboard-app .dashboard-grid-4,
	.dashboard-grid-4 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 720px) {
	.dashboard-app .dashboard-grid-4,
	.dashboard-grid-4 {
		grid-template-columns: 1fr;
	}
}

/* Pasfoto veld rechts uitlijnen */
.dashboard-app .dashboard-field-photo,
.dashboard-field-photo {
	align-self: start;
}

.dashboard-app .dashboard-field-photo input[type="file"],
.dashboard-field-photo input[type="file"] {
	width: 100%;
}

/* Portrait preview (180x220) */
.dashboard-app .dashboard-user-photo-preview--portrait,
.dashboard-user-photo-preview--portrait {
	width: 180px;
	height: 220px;
	border-radius: 14px;
	background: #f7f7f7;
	border: 1px solid #e6e6e6;
	box-shadow: 6px 6px 0 rgba(0,0,0,0.06);
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: 10px;
}

.dashboard-app .dashboard-user-photo-preview--portrait img,
.dashboard-user-photo-preview--portrait img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

/* Rechten: 2 kolommen, elke permissie op eigen regel */
.dashboard-app .dashboard-permissions,
.dashboard-permissions {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px 24px;
	font-size: 13px;
}

@media (max-width: 720px) {
	.dashboard-app .dashboard-permissions,
	.dashboard-permissions {
		grid-template-columns: 1fr;
	}
}

.dashboard-app .dashboard-permission-row,
.dashboard-permission-row {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-weight: 600;
	line-height: 1.35;
}

.dashboard-app .dashboard-permission-row input[type="checkbox"],
.dashboard-permission-row input[type="checkbox"] {
	margin-top: 2px;
}


/* Support-impersonatie banner */
.dashboard-support-banner{
	border: 1px solid rgba(0,0,0,0.10);
	background: rgba(255, 245, 220, 0.9);
	padding: 10px 14px;
	border-radius: 14px;
	margin: 0 0 12px 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

.dashboard-support-banner .dashboard-support-banner-text{
	font-size: 14px;
	font-weight: 700;
}

.dashboard-support-banner .dashboard-support-banner-actions{
	display: flex;
	gap: 10px;
	align-items: center;
}



/* =========================================================
   UX consistency (Sprint 1.2.01.B3b)
   - Topbar: standaard "Terug naar uw dashboard"
   - Form actions: Annuleren + Opslaan rechts onder (30px)
   - Buttons: Annuleren rood, Opslaan donkergroen, hover 10% groter
   ========================================================= */

.dashboard-app .dashboard-topbar-actions{
	gap: 30px;
}

.dashboard-actions-row.dashboard-actions-row--form,
.dashboard-actions-row.dashboard-actions-row--modal{
	justify-content: flex-end;
	align-items: center;
	gap: 30px;
	flex-wrap: wrap;
}

.dashboard-button.dashboard-button-save{
	background: #0b6b2f;
	border: 1px solid rgba(0,0,0,0.10);
	color: #fff;
	transition: transform 0.12s ease, background-color 0.12s ease, border-color 0.12s ease;
}

.dashboard-button.dashboard-button-cancel{
	background: #b00000;
	border: 1px solid rgba(0,0,0,0.10);
	color: #fff;
	transition: transform 0.12s ease, background-color 0.12s ease, border-color 0.12s ease;
}

.dashboard-button.dashboard-button-save:hover{
	background: #075622;
	transform: scale(1.10);
}

.dashboard-button.dashboard-button-cancel:hover{
	background: #8f0000;
	transform: scale(1.10);
}

.dashboard-button.dashboard-button-save:focus,
.dashboard-button.dashboard-button-cancel:focus{
	outline: none;
	box-shadow: 0 0 0 3px rgba(0,0,0,0.10);
}

/* Mijn profiel: wachtwoordvelden compacter (ongeveer 1/3 breedte) */
.dashboard-profile-grid .dashboard-password-field input[type="password"]{
	flex: 0 0 33%;
	max-width: 33%;
	min-width: 260px;
	border-radius: 10px;
}

@media (max-width: 900px){
	.dashboard-profile-grid .dashboard-password-field input[type="password"]{
		flex: 1 1 auto;
		max-width: none;
		min-width: 0;
	}
}

/* ==========================================================
   Sprint 1.2.01.C2f – Abonnementen UX polish
   ========================================================== */

/* Consistente input styling (ook voor zoek & datumvelden) */
.dashboard-app .dashboard-input,
.dashboard-app input.dashboard-input,
.dashboard-app select.dashboard-input{
	border: 1px solid rgba(0,0,0,0.10);
	border-radius: 10px;
	padding: 10px 12px;
	background: #fff;
	font-weight: 600;
	font-size: 14px;
	box-shadow: 0 1px 0 rgba(0,0,0,0.02);
}

.dashboard-app .dashboard-field input[type="date"],
.dashboard-app .dashboard-field input[type="date"]:focus{
	appearance: auto;
}

/* Maak ook date inputs gelijk aan text inputs */
.dashboard-app .dashboard-field input[type="date"]{
	border: 1px solid rgba(0,0,0,0.10);
	border-radius: 10px;
	padding: 10px 12px;
	background: #fff;
	font-weight: 600;
	font-size: 14px;
	box-shadow: 0 1px 0 rgba(0,0,0,0.02);
}

/* Iets compacter voor select dropdowns (minder “schreeuwerig”) */
.dashboard-app .dashboard-field select{
	font-size: 13px;
}

/* 4-koloms grid voor formulieren */
.dashboard-grid-4{
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

@media (max-width: 980px){
	.dashboard-grid-4{
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 560px){
	.dashboard-grid-4{
		grid-template-columns: 1fr;
	}
}

/* Abonnement samenvatting (2 kolommen) */
.dashboard-subscription-summary{
	margin: 8px 0 14px 0;
}

.dashboard-subscription-summary .dashboard-summary-row{
	margin: 2px 0;
	line-height: 1.45;
}

.dashboard-subscription-summary .dashboard-subscription-col{
	border: 1px solid rgba(0,0,0,0.06);
	border-radius: 12px;
	padding: 12px 14px;
	background: #fff;
}

.dashboard-subscription-summary .dashboard-subscription-col--financial{
	background: rgba(0,0,0,0.015);
}

/* Inline bar (bij single klant view) */
.dashboard-inline-bar{
	display:flex;
	gap: 12px;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
}

/* Login popup: acties naast elkaar */
.dashboard-login-box .dashboard-actions{
	display:flex;
	gap: 12px;
	justify-content: flex-end;
	flex-wrap: wrap;
}

/* ===============================
 * Sprint C3b – SAAS-brede UI/UX uniformering (admin + beheer)
 * =============================== */

/* Uniforme input/select styling binnen dashboard forms (theme-overschrijvend) */
.dashboard-form input[type="text"],
.dashboard-form input[type="email"],
.dashboard-form input[type="password"],
.dashboard-form input[type="number"],
.dashboard-form input[type="tel"],
.dashboard-form input[type="date"],
.dashboard-form textarea,
.dashboard-form select,
.dashboard-admin-customer-form input[type="text"],
.dashboard-admin-customer-form input[type="email"],
.dashboard-admin-customer-form input[type="password"],
.dashboard-admin-customer-form input[type="number"],
.dashboard-admin-customer-form input[type="tel"],
.dashboard-admin-customer-form input[type="date"],
.dashboard-admin-customer-form textarea,
.dashboard-admin-customer-form select,
.dashboard-admin-customers input[type="text"],
.dashboard-admin-customers input[type="email"],
.dashboard-admin-customers input[type="password"],
.dashboard-admin-customers input[type="number"],
.dashboard-admin-customers input[type="tel"],
.dashboard-admin-customers input[type="date"],
.dashboard-admin-customers textarea,
.dashboard-admin-customers select,
.dashboard-search-form input[type="text"],
.dashboard-search-form input[type="search"],
.dashboard-search-form select
{
	font-size: 13px !important;
	line-height: 1.2 !important;
	padding: 8px 10px !important;
	border-radius: 12px !important;
	border: 1px solid rgba(0,0,0,0.18) !important;
	background: #fff !important;
	box-shadow: none !important;
}

.dashboard-form input[type="date"],
.dashboard-admin-customer-form input[type="date"],
.dashboard-admin-customers input[type="date"],
.dashboard-search-form input[type="date"]{
	min-height: 38px !important;
}

.dashboard-form select,
.dashboard-admin-customer-form select,
.dashboard-admin-customers select,
.dashboard-search-form select{
	min-height: 38px !important;
}

.dashboard-form input:focus,
.dashboard-form select:focus,
.dashboard-form textarea:focus,
.dashboard-search-form input:focus,
.dashboard-search-form select:focus{
	outline: none !important;
	border-color: rgba(0,0,0,0.45) !important;
	box-shadow: 0 0 0 3px rgba(0,0,0,0.06) !important;
}

/* Overal 30px ruimte tussen buttons + rechts uitlijnen waar relevant */
.dashboard-actions-inline,
.dashboard-actions-row,
.dashboard-page-actions,
.dashboard-actions-row--modal,
.dashboard-login-box .dashboard-actions{
	gap: 30px !important;
}

.dashboard-actions-inline{
	display:flex;
	justify-content:flex-end;
	align-items:center;
	flex-wrap: wrap;
}

/* Actie-cellen in tabellen: rechts, knoppen naast elkaar */
.dashboard-table td.dashboard-actions-cell,
.dashboard-table th.dashboard-actions-cell{
	text-align: right;
	white-space: nowrap;
}

.dashboard-table td.dashboard-actions-cell .dashboard-actions-inline{
	justify-content: flex-end;
}

/* Modals: extra binnenmarge zodat velden niet tegen de rand plakken */
.dashboard-modal-dialog .dashboard-form{
	padding: 16px 18px 18px 18px !important;
}

.dashboard-modal-dialog .dashboard-actions-row--modal{
	margin-top: 18px;
}

/* Plan catalogus: compactere tabellen/inputs */
.dashboard-plan-table td,
.dashboard-plan-table th{
	padding: 8px 10px !important;
}

.dashboard-plan-table .dashboard-price-input-wrap{
	min-width: 140px;
}

.dashboard-plan-table .dashboard-input--price{
	min-height: 34px !important;
	height: 34px !important;
	padding: 6px 10px !important;
	font-size: 13px !important;
}

/* Selects in catalogus iets compacter */
.dashboard-plan-table select,
.dashboard-customer-subscription-form select{
	font-size: 13px !important;
}

/* Collapsible panels (Klant bewerken) */
.dashboard-collapsible-panel{
	border: 1px solid rgba(0,0,0,0.06);
	border-radius: 14px;
	background: #fff;
	margin: 0 0 18px 0;
	box-shadow: 0 4px 14px rgba(0,0,0,0.04);
}

.dashboard-collapsible-panel > summary{
	cursor: pointer;
	padding: 14px 18px;
	font-weight: 600;
	list-style: none;
	user-select: none;
}

.dashboard-collapsible-panel > summary::-webkit-details-marker{
	display:none;
}

.dashboard-collapsible-panel[open] > summary{
	border-bottom: 1px solid rgba(0,0,0,0.06);
	border-radius: 14px 14px 0 0;
}

.dashboard-collapsible-body{
	padding: 16px 18px 18px 18px;
}

/* ========== Sprint 1.2.01.D1: Gebouwen/Locaties – foto grid + checkboxes ========== */
.vbd-photo-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
	margin-top: 12px;
}

.vbd-photo-item {
	height: 350px;
	border-radius: 14px;
	overflow: hidden;
	background: #f3f4f6;
	box-shadow: 0 4px 14px rgba(0,0,0,0.06);
}

.vbd-photo-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.dashboard-field-checkbox {
	padding-top: 28px;
}

.dashboard-field-checkbox label {
	display: flex;
	gap: 10px;
	align-items: center;
	font-weight: 600;
}

.dashboard-field-checkbox input[type="checkbox"] {
	width: auto;
	height: auto;
}


/* ===============================
   Gebouwbeheer: Kenmerken & faciliteiten (compact + netjes)
   =============================== */

.dashboard-app .gb-form .gb-metrics-grid {
	margin-bottom: 14px;
}

.dashboard-app .gb-form .gb-features-frame {
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: 14px;
	padding: 14px;
	background: rgba(0, 0, 0, 0.02);
}

.dashboard-app .gb-form .gb-features-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 10px 18px;
}

@media (max-width: 980px) {
	.dashboard-app .gb-form .gb-features-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 560px) {
	.dashboard-app .gb-form .gb-features-grid {
		grid-template-columns: 1fr;
	}
}

.dashboard-app .gb-form .gb-feature-item label {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 0;
	font-weight: 400;
	line-height: 1.2;
}

.dashboard-app .gb-form .gb-feature-item input[type="checkbox"] {
	margin: 0;
	width: 18px;
	height: 18px;
}

.dashboard-app .gb-form .gb-subfields {
	margin-top: 12px;
	padding-top: 12px;
	border-top: 1px dashed rgba(0, 0, 0, 0.12);
}

.dashboard-app .gb-form .gb-subfields-grid .dashboard-field {
	margin-bottom: 0;
}

.dashboard-app .gb-form .gb-custom-features {
	margin-top: 12px;
	padding-top: 12px;
	border-top: 1px dashed rgba(0, 0, 0, 0.12);
}

.dashboard-app .gb-form .gb-custom-features-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
}

.dashboard-app .gb-form .gb-custom-features-head strong {
	display: block;
	margin-bottom: 2px;
}

.dashboard-app .gb-form .gb-custom-features-list {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-top: 8px;
}

.dashboard-app .gb-form .gb-custom-feature-row {
	display: flex;
	align-items: center;
	gap: 10px;
}

.dashboard-app .gb-form .gb-custom-feature-row input[type="checkbox"] {
	margin: 0;
	width: 18px;
	height: 18px;
}

.dashboard-app .gb-form .gb-custom-feature-row input[type="text"] {
	flex: 1;
	min-width: 220px;
}

.dashboard-app .gb-form .gb-remove-feature {
	padding: 6px 10px;
	line-height: 1;
}


/* Dashboard pagina's: nooit een theme-zijbalk tonen */
body.vbd-dashboard-page #secondary,
body.vbd-dashboard-page #left-sidebar,
body.vbd-dashboard-page #right-sidebar,
body.vbd-dashboard-page .widget-area {
	display: none !important;
}

body.vbd-dashboard-page .content-area {
	width: 100% !important;
	max-width: 100% !important;
}
