::-ms-expand {
	display: none;
}
:root {
	--c-red-600: #dc2626;
	--c-slate-100: #f1f5f9;
	--c-slate-200: #e2e8f0;
	--c-slate-300: #cbd5e1;
	--c-slate-50: #f8fafc;
	--c-slate-500: #64748b;
	--c-slate-600: #475569;
	--c-slate-700: #334155;
	--c-slate-900: #0f172a;
	--c-white: #ffffff;
}
*,
::before,
::after {
	box-sizing: border-box;
}
a,
area,
button,
input,
label,
select,
summary,
textarea,
[tabindex] {
	touch-action: manipulation;
}
body {
	background: #e9e9e9;
	color: #222;
	font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	margin: 0;
}
button:focus,
input:focus,
select:focus,
textarea:focus,
[contenteditable]:focus {
	outline: 0;
}
input {
	border: 1px solid #d0d7e2;
	border-radius: 8px;
	font-size: 14px;
	outline: none;
	padding: 6px 8px;
}
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
	-webkit-appearance: none;
}
input[type="number"] {
	-moz-appearance: textfield;
}
label {
	color: #6b7280;
	font-size: 13px;
	font-weight: 600;
}
main {
	background: #ffffff;
	display: flex;
	flex: 1;
	flex-direction: column;
	gap: 12px;
	min-height: 100dvh;
	overflow: auto;
	padding: 9px;
}
main[data-user-level="1"] .home-card-link {
	opacity: 0.6;
	pointer-events: none;
}
main[data-user-level="1"] .vt-filter,
main[data-user-level="1"] [data-filter],
main[data-user-level="1"] .filter,
main[data-user-level="1"] .filter input,
main[data-user-level="1"] .filter select,
main[data-user-level="1"] input[type="search"],
main[data-user-level="1"] #log-charter-filter,
main[data-user-level="1"] #log-date-filter {
	background: #ffffff;
	opacity: 1;
	pointer-events: auto;
}
main[data-user-level="1"] .vt-week-actions .vt-week-btn:not(.vt-week-open){
	filter: grayscale(1);
	opacity: 0.4;
	pointer-events: none;
}
main[data-user-level="1"] button,
main[data-user-level="1"] input,
main[data-user-level="1"] select,
main[data-user-level="1"] textarea {
	opacity: 0.6;
	pointer-events: none;
}
table {
	border-collapse: collapse;
}
.absolute {
	position: absolute;
}
.account {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.account-chat {
	gap: 14px;
}
.account-empty {
	color: var(--c-slate-500);
	margin: 0;
}
.account-flag {
	background: #fef3c7;
	border-radius: 999px;
	color: #92400e;
	font-size: 0.8rem;
	font-weight: 600;
	padding: 4px 10px;
}
.account-grid {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
.account-header {
	align-items: center;
	display: flex;
	gap: 12px;
	justify-content: space-between;
}
.account-panel {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 14px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 14px;
}
.account-panel button {
	background: var(--c-slate-900);
	border: none;
	border-radius: 999px;
	color: var(--c-white);
	cursor: pointer;
	font-weight: 600;
	padding: 8px 12px;
}
.account-panel form {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.account-panel h2 {
	font-size: 1.05rem;
	margin: 0;
}
.account-panel input,
.account-panel textarea {
	border: 1px solid var(--c-slate-300);
	border-radius: 10px;
	font-size: 0.9rem;
	padding: 6px 10px;
}
.account-panel label {
	display: flex;
	flex-direction: column;
	font-size: 0.85rem;
	gap: 6px;
}
.account-status {
	background: #e0f2fe;
	border-radius: 12px;
	color: #0c4a6e;
	font-size: 0.9rem;
	padding: 8px 12px;
}
.admin {
	display: flex;
	flex-direction: column;
	gap: 18px;
}
.admin-actions {
	align-items: center;
	display: inline-flex;
	flex-wrap: wrap;
	gap: 10px;
}
.admin-add input,
.admin-item-edit input {
	border: 1px solid var(--c-slate-300);
	border-radius: 10px;
	flex: 1 1 160px;
	font-size: 0.95rem;
	padding: 8px 10px;
}
.admin-add,
.admin-item-edit {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.admin-btn {
	background: var(--c-slate-900);
	border: none;
	border-radius: 999px;
	color: var(--c-white);
	cursor: pointer;
	font-size: 0.85rem;
	font-weight: 600;
	padding: 8px 14px;
}
.admin-btn.is-danger {
	background: var(--c-red-600);
}
.admin-card {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-200);
	border-radius: 12px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 10px;
}
.admin-cards {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.admin-check {
	align-items: center;
	color: var(--c-slate-700);
	display: inline-flex;
	font-size: 0.85rem;
	gap: 6px;
}
.admin-header h1 {
	margin: 0 0 6px;
}
.admin-header p {
	color: var(--c-slate-500);
	margin: 0;
}
.admin-help {
	color: var(--c-slate-500);
	margin: 0 0 6px;
}
.admin-inline-actions form {
	margin: 0;
}
.admin-item {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 14px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 12px;
}
.admin-item-edit {
	justify-content: space-between;
}
.admin-level-title {
	color: var(--c-slate-600);
	font-size: 0.8rem;
}
.admin-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.admin-menu-levels {
	align-items: center;
	display: inline-flex;
	flex-wrap: wrap;
	gap: 10px;
}
.admin-move {
	align-items: center;
	display: inline-flex;
	gap: 8px;
}
.admin-move-btn {
	padding: 6px 10px;
}
.admin-quick {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-200);
	border-radius: 14px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 12px;
}
.admin-quick h2 {
	font-size: 1rem;
	margin: 0;
}
.admin-quick-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.admin-section {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-200);
	border-radius: 16px;
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: 16px;
}
.admin-section h2 {
	font-size: 1.1rem;
	margin: 0;
}
.admin-section-card {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 14px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 12px;
}
.admin-section-head {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: space-between;
}
.admin-section-head h3 {
	font-size: 1rem;
	margin: 0;
}
.admin-section-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.admin-section.is-collapsed .admin-section-body,
.admin-quick.is-collapsed .admin-section-body {
	display: none;
}
.admin-text-block {
	align-items: stretch;
}
.admin-text-block textarea {
	border: 1px solid var(--c-slate-300);
	border-radius: 10px;
	font-size: 0.9rem;
	min-height: 100px;
	padding: 8px 10px;
	resize: vertical;
	width: 100%;
}
.admin-textarea {
	border: 1px solid var(--c-slate-300);
	border-radius: 10px;
	font-size: 0.9rem;
	min-height: 120px;
	padding: 8px 10px;
	resize: vertical;
	width: 100%;
}
.admin-toggle {
	background: var(--c-slate-200);
	border: none;
	border-radius: 999px;
	color: var(--c-slate-900);
	cursor: pointer;
	font-size: 0.8rem;
	font-weight: 600;
	padding: 6px 12px;
}
.admin-week {
	align-items: center;
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 999px;
	display: flex;
	gap: 6px;
	padding: 6px 10px;
}
.admin-week-empty {
	color: var(--c-slate-500);
	font-size: 0.9rem;
	margin: 0;
}
.admin-week-label {
	color: var(--c-slate-900);
	font-size: 0.9rem;
}
.admin-weeks {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.afkap {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.afkap summary {
	display: block;
	list-style: none !important;
	padding-left: 0;
}
.afkap summary::-webkit-details-marker {
	display: none !important;
}
.afkap summary::after {
	content: '' !important;
	display: none !important;
}
.afkap summary::marker {
	color: transparent;
	content: '' !important;
	display: none !important;
}
.afkap-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}
.afkap-alert {
	background: #fff7ed;
	border: 1px solid #fdba74;
	border-radius: 10px;
	color: #9a3412;
	font-weight: 600;
	padding: 10px 12px;
	padding-left: 38px;
	position: relative;
}
.afkap-alert.dup::before {
	background: #fb923c;
}
.afkap-alert.exists::before {
	background: #f59e0b;
}
.afkap-alert::before {
	align-items: center;
	background: #fdba74;
	border-radius: 50%;
	color: #7c2d12;
	content: '!';
	display: flex;
	font-size: 0.7rem;
	font-weight: 900;
	height: 16px;
	justify-content: center;
	left: 12px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 16px;
}
.afkap-btn {
	background: var(--c-slate-200);
	border: none;
	border-radius: 999px;
	color: var(--c-slate-900);
	cursor: pointer;
	font-size: 0.85rem;
	font-weight: 600;
	padding: 8px 14px;
	text-decoration: none;
}
.afkap-btn-add {
	background: #0b1220;
	color: var(--c-white);
}
.afkap-btn-danger {
	background: #fee2e2;
	color: #991b1b;
}
.afkap-btn-icon {
	line-height: 0;
	padding: 4px 6px;
}
.afkap-btn-icon svg {
	display: block;
	fill: currentColor;
	height: 14px;
	width: 14px;
}
.afkap-btn-mini {
	font-size: 0.68rem;
	padding: 2px 10px;
}
.afkap-btn-outline {
	background: var(--c-white);
	border: 1px solid var(--c-slate-300);
	color: var(--c-slate-900);
}
.afkap-btn-primary {
	background: var(--c-slate-900);
	color: var(--c-white);
}
.afkap-btn-small {
	font-size: 0.75rem;
	padding: 4px 8px;
}
.afkap-btn-success {
	background: #dcfce7;
	color: #166534;
}
.afkap-col {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.afkap-col-actions {
	align-items: center;
	display: inline-flex;
	gap: 8px;
}
.afkap-col-actions form {
	display: inline-flex;
}
.afkap-col-actions-wide {
	overflow: visible;
	text-overflow: clip;
	white-space: normal;
}
.afkap-delete-actions {
	align-items: center;
	display: inline-flex;
	gap: 6px;
}
.afkap-delete-card {
	align-items: center;
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 999px;
	box-shadow: 0 6px 16px rgba(15, 23, 42, 0.18);
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: 700;
	gap: 8px;
	padding: 6px 8px;
}
.afkap-delete-pop {
	margin-top: 6px;
	position: absolute;
	right: 12px;
	top: 100%;
	z-index: 10;
}
.afkap-delete-pop.is-hidden {
	display: none;
}
.afkap-dup {
	padding-right: 18px;
	position: relative;
}
.afkap-dup::after {
	align-items: center;
	background: #f97316;
	border-radius: 50%;
	color: var(--c-white);
	content: '!';
	display: flex;
	font-size: 0.7rem;
	font-weight: 700;
	height: 14px;
	justify-content: center;
	position: absolute;
	right: 4px;
	top: 50%;
	transform: translateY(-50%);
	width: 14px;
}
.afkap-empty {
	color: var(--c-slate-500);
	padding: 18px;
	text-align: center;
}
.afkap-form h2 {
	font-size: 1rem;
	margin: 0;
}
.afkap-form input,
.afkap-form select,
.afkap-subform input,
.afkap-subform select {
	border: 1px solid var(--c-slate-300);
	border-radius: 8px;
	font-size: 0.85rem;
	padding: 6px 8px;
}
.afkap-form label,
.afkap-subform label {
	display: flex;
	flex-direction: column;
	font-size: 0.85rem;
	gap: 4px;
}
.afkap-form textarea {
	border: 1px solid var(--c-slate-300);
	border-radius: 10px;
	font-size: 0.9rem;
	padding: 8px 10px;
}
.afkap-form,
.afkap-subform {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 12px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 12px;
}
.afkap-form-grid,
.afkap-subform {
	display: grid;
	gap: 8px;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}
.afkap-form-wide {
	grid-column: 1 / -1;
}
.afkap-form.is-hidden {
	display: none;
}
.afkap-head-actions {
	align-items: center;
	display: inline-flex;
	gap: 10px;
	justify-self: end;
}
.afkap-header {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	justify-content: space-between;
}
.afkap-inline {
	align-items: end;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}
.afkap-inline-controls {
	align-items: center;
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: 700;
	gap: 28px;
	white-space: nowrap;
}
.afkap-inline-controls label {
	align-items: center;
	display: inline-flex;
	font-size: 0.78rem;
	gap: 12px;
}
.afkap-inline-controls option {
	background: var(--c-white);
	color: var(--c-slate-900);
}
.afkap-inline-controls select {
	appearance: auto;
	background: var(--c-white);
	border: 1px solid var(--c-slate-300);
	border-radius: 6px;
	color: var(--c-slate-900);
	font-size: 0.75rem;
	font-weight: 600;
	height: 24px;
	line-height: 24px;
	min-width: 72px;
	padding: 2px 4px;
	-webkit-appearance: auto;
}
.afkap-input {
	border: 1px solid var(--c-slate-300);
	border-radius: 8px;
	font-size: 0.8rem;
	padding: 4px 6px;
	width: 100%;
}
.afkap-label {
	color: var(--c-slate-600);
	display: block;
	font-size: 0.7rem;
	font-weight: 600;
}
.afkap-line {
	align-items: center;
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-200);
	border-radius: 10px;
	display: grid;
	font-size: 0.82rem;
	gap: 8px;
	grid-template-columns: repeat(5, minmax(120px, 1fr));
	padding: 8px;
}
.afkap-line-form {
	background: var(--c-slate-200);
	padding: 6px;
}
.afkap-line-head {
	background: var(--c-slate-200);
	font-weight: 700;
}
.afkap-line-offset {
	margin-top: 8px;
}
.afkap-lines {
	display: grid;
	gap: 6px;
	grid-template-columns: 1fr;
	margin-top: 10px;
}
.afkap-option {
	background: var(--c-white);
	border: 1px solid var(--c-slate-300);
	border-radius: 999px;
	color: var(--c-slate-900);
	cursor: pointer;
	font-size: 0.72rem;
	font-weight: 700;
	padding: 2px 8px;
}
.afkap-option-group {
	align-items: center;
	display: inline-flex;
	gap: 6px;
}
.afkap-option.is-active {
	background: var(--c-slate-900);
	border-color: var(--c-slate-900);
	color: var(--c-white);
}
.afkap-panel {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.afkap-panels {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.afkap-rit {
	background: var(--c-slate-100);
	border: 1px solid var(--c-slate-200);
	border-radius: 12px;
	margin-bottom: 10px;
	padding: 10px;
}
.afkap-rit summary,
.afkap-winkel summary {
	list-style: none;
}
.afkap-rit,
.afkap-winkel {
	position: relative;
}
.afkap-rit-head {
	align-items: center;
	display: grid;
	font-weight: 600;
	gap: 10px;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}
.afkap-select {
	appearance: auto;
	background: var(--c-white);
	border: 1px solid var(--c-slate-300);
	border-radius: 6px;
	color: var(--c-slate-900);
	font-size: 0.75rem;
	padding: 2px 4px;
}
.afkap-summary {
	cursor: pointer;
	display: block;
	list-style: none;
	text-align: left;
	width: 100%;
}
.afkap-summary::-webkit-details-marker {
	display: none !important;
}
.afkap-summary::marker {
	color: transparent;
	content: '' !important;
	display: none !important;
}
.afkap-table-wrap {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.afkap-title h1 {
	margin: 0 0 6px;
}
.afkap-title p {
	color: var(--c-slate-500);
	margin: 0;
}
.afkap-winkel {
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin-top: 8px;
}
.afkap-winkel summary::-webkit-details-marker {
	display: none !important;
}
.afkap-winkel summary::marker {
	color: transparent;
	content: '' !important;
	display: none !important;
}
.afkap-winkel-actions {
	align-items: center;
	display: inline-flex;
	gap: 16px;
	justify-content: flex-end;
	width: 100%;
}
.afkap-winkel-head {
	font-size: 0.78rem;
	grid-template-columns: minmax(140px, 1.1fr) minmax(160px, 1.4fr) minmax(120px, 0.8fr) minmax(260px, 2.2fr);
}
.app {
	display: flex;
	height: 100dvh;
	overflow: hidden;
}
.block {
	background: #fff;
	border-radius: 25px;
	box-shadow: 0 4px 6px rgba(0, 0, 0, .1);
	color: #000;
	display: block;
	font-size: 0.45rem;
	margin: auto;
	min-height: 100px;
	transition: .6s;
	width: 10vw;
}
.block a {
	color: inherit;
	text-decoration: none;
}
.block:hover {
	box-shadow: 0 4px 6px rgb(255, 102, 0);
}
.btn {
	align-items: center;
	background: #f4f6f8;
	border: 1px solid transparent;
	border-radius: 999px;
	box-shadow: 0 3px 10px rgba(15, 118, 110, .3);
	color: inherit;
	cursor: pointer;
	display: inline-flex;
	flex: 1;
	font-size: 14px;
	font-weight: 600;
	justify-content: center;
	padding: 6px 10px;
	text-align: center;
	text-decoration: none;
}
.buttons {
	display: flex;
	gap: 8px;
	margin-top: 4px;
}
.buttons a {
	text-decoration: none;
}
.center {
	text-align: center;
}
.charter-actions {
	display: flex;
	justify-content: flex-end;
}
.charter-btn {
	background: var(--c-slate-900);
	border: none;
	border-radius: 999px;
	color: var(--c-white);
	cursor: pointer;
	font-size: 0.85rem;
	font-weight: 600;
	padding: 6px 12px;
	text-decoration: none;
}
.charter-content {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 14px;
	min-height: 200px;
	padding: 16px;
}
.charter-editor {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 14px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 14px;
}
.charter-editor input {
	border: 1px solid var(--c-slate-300);
	border-radius: 8px;
	font-size: 0.9rem;
	padding: 6px 8px;
}
.charter-editor label {
	display: flex;
	flex-direction: column;
	font-size: 0.85rem;
	gap: 6px;
}
.charter-editor-area {
	background: var(--c-white);
	border: 1px solid var(--c-slate-300);
	border-radius: 10px;
	min-height: 280px;
	padding: 12px;
}
.charter-editor-area table {
	border-collapse: collapse;
	margin: 10px 0;
	width: 100%;
}
.charter-editor-area th {
	background: var(--c-slate-100);
	text-align: left;
}
.charter-editor-area th,
.charter-editor-area td {
	border: 1px solid var(--c-slate-300);
	min-width: 60px;
	padding: 6px 8px;
}
.charter-header {
	align-items: center;
	display: flex;
	gap: 12px;
	justify-content: space-between;
}
.charter-header h1 {
	margin: 0;
}
.charter-page {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.charter-select {
	background: var(--c-slate-100);
	border: 1px solid var(--c-slate-200);
	border-radius: 8px;
	font-size: 0.8rem;
	padding: 4px 6px;
}
.charter-status {
	background: #e0f2fe;
	border-radius: 12px;
	color: #0c4a6e;
	font-size: 0.9rem;
	padding: 8px 12px;
}
.charter-toolbar {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.charter-toolbar button {
	background: var(--c-slate-100);
	border: 1px solid var(--c-slate-200);
	border-radius: 8px;
	cursor: pointer;
	font-size: 0.8rem;
	font-weight: 600;
	padding: 4px 8px;
}
.errorlog {
	display: flex;
	flex-direction: column;
	gap: 16px;
	padding: 18px;
}
.errorlog-actions {
	display: flex;
	justify-content: flex-end;
}
.errorlog-card {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 12px;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
	padding: 12px 14px;
}
.errorlog-clear {
	background: var(--c-slate-100);
	border: 1px solid var(--c-slate-300);
	border-radius: 8px;
	color: var(--c-slate-700);
	font-size: 0.85rem;
	font-weight: 600;
	padding: 6px 10px;
}
.errorlog-clear:hover {
	background: var(--c-slate-200);
}
.errorlog-count {
	background: var(--c-slate-100);
	border-radius: 999px;
	color: var(--c-slate-700);
	font-size: 0.8rem;
	font-weight: 700;
	padding: 2px 8px;
}
.errorlog-empty {
	background: var(--c-slate-50);
	border: 1px dashed var(--c-slate-300);
	border-radius: 10px;
	color: var(--c-slate-600);
	padding: 16px;
}
.errorlog-file {
	color: var(--c-slate-900);
	font-size: 0.95rem;
	font-weight: 700;
}
.errorlog-head {
	align-items: baseline;
	display: flex;
	gap: 12px;
	justify-content: space-between;
}
.errorlog-head h2 {
	font-size: 1.4rem;
	margin: 0;
}
.errorlog-label {
	color: var(--c-slate-500);
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.errorlog-list {
	display: grid;
	gap: 12px;
}
.errorlog-meta {
	color: var(--c-slate-600);
	font-size: 0.9rem;
	margin: 0;
}
.errorlog-msg {
	color: var(--c-slate-700);
	font-size: 0.9rem;
	margin-top: 10px;
	white-space: pre-wrap;
}
.errorlog-row {
	display: grid;
	font-size: 0.9rem;
	gap: 8px;
	grid-template-columns: 70px 1fr;
	margin-top: 4px;
}
.errorlog-title {
	align-items: center;
	display: flex;
	gap: 12px;
	justify-content: space-between;
	margin-bottom: 6px;
}
.errorlog-value {
	color: var(--c-slate-700);
}
.field {
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.fit {
	width: fit-content;
}
.fixed {
	position: fixed;
}
.float-left {
	float: left;
}
.float-right {
	float: right;
}
.full {
	width: 100%;
}
.hidden {
	display: none;
}
.hide-x {
	overflow-x: hidden;
}
.hide-y {
	overflow-y: hidden;
}
.home {
	display: flex;
	flex-direction: column;
	gap: 18px;
	min-width: 0;
}
.home-card {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-200);
	border-radius: 12px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 10px;
}
.home-card-desc {
	color: var(--c-slate-500);
	font-size: 0.85rem;
}
.home-card-link {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 10px;
	color: var(--c-slate-900);
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding: 10px 12px;
	text-decoration: none;
}
.home-card-title {
	font-weight: 600;
}
.home-cards {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.home-empty {
	color: var(--c-slate-500);
}
.home-hero {
	background: linear-gradient(135deg, var(--c-slate-900), #0f766e);
	border-radius: 16px;
	color: var(--c-white);
	padding: 18px;
}
.home-hero h1 {
	font-size: 1.6rem;
	margin: 0 0 6px;
}
.home-hero p {
	margin: 0;
	opacity: 0.85;
}
.home-section {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 14px;
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: 14px;
}
.home-section-head {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: space-between;
}
.home-section-head h2 {
	font-size: 1.2rem;
	margin: 0;
}
.home-sections {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.is-hidden {
	display: none;
}
.left {
	text-align: left;
}
.log {
	background: #f9fafb;
	border: 1px solid rgba(209, 213, 219, .9);
	border-radius: 10px;
	padding: 8px 10px;
	position: relative;
}
.log-body {
	margin: 2px 0 0;
	padding: 0 0 0 6px;
}
.log-header {
	align-items: baseline;
	display: flex;
	font-size: 0.85rem;
	gap: 6px;
	justify-content: space-between;
	padding-left: 6px;
}
.log-row {
	align-items: center;
	color: #1f2937;
	display: flex;
	font-size: 0.85rem;
	gap: 6px;
}
.log-value {
	align-items: center;
	background: #ffffff;
	border: 1px solid #e2e8f0;
	border-radius: 8px;
	display: inline-flex;
	min-height: 20px;
	padding: 2px 6px;
}
.log::before {
	background: linear-gradient(to bottom, #22c55e, #0f766e);
	border-radius: 999px;
	bottom: 10px;
	content: "";
	left: 0;
	position: absolute;
	top: 10px;
	width: 3px;
}
.login {
	align-items: center;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-height: 100vh;
	padding: 40px 16px;
	position: relative;
}
.login-card {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 14px;
	box-shadow: 0 6px 18px rgba(15, 23, 42, 0.06);
	display: flex;
	flex-direction: column;
	gap: 12px;
	max-width: 360px;
	padding: 18px 20px;
	width: 100%;
}
.login-card button {
	background: var(--c-slate-900);
	border: none;
	border-radius: 999px;
	color: var(--c-white);
	cursor: pointer;
	font-weight: 600;
	padding: 8px 12px;
}
.login-card form {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.login-card h1 {
	margin: 0;
}
.login-card input {
	border: 1px solid var(--c-slate-300);
	border-radius: 10px;
	font-size: 0.9rem;
	padding: 6px 10px;
}
.login-card label {
	display: flex;
	flex-direction: column;
	font-size: 0.85rem;
	gap: 6px;
}
.login-card p {
	color: var(--c-slate-500);
	margin: 0;
}
.login-error {
	background: #fee2e2;
	border-radius: 10px;
	color: #991b1b;
	font-size: 0.85rem;
	padding: 8px 10px;
}
.login-footer {
	color: var(--c-slate-500);
	display: flex;
	flex-wrap: wrap;
	font-size: 0.8rem;
	gap: 12px;
	justify-content: center;
	margin-top: 18px;
}
.login-info {
	align-items: center;
	background: var(--c-white);
	border: 1px solid var(--c-slate-300);
	border-radius: 50%;
	color: var(--c-slate-900);
	cursor: pointer;
	display: flex;
	font-weight: 700;
	height: 36px;
	justify-content: center;
	position: absolute;
	right: 16px;
	text-decoration: none;
	top: 16px;
	width: 36px;
}
.login-info:focus {
	outline: 2px solid var(--c-slate-900);
	outline-offset: 2px;
}
.login-info:hover {
	background: var(--c-slate-100);
}
.login-qr {
	display: flex;
	justify-content: center;
	padding: 6px 0;
}
.login-qr img {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 12px;
	padding: 6px;
}
.login-secret {
	color: var(--c-slate-600);
	display: flex;
	flex-direction: column;
	font-size: 0.82rem;
	gap: 4px;
}
.login-secret code {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-200);
	border-radius: 8px;
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
	font-size: 0.8rem;
	padding: 6px 8px;
}
.main-home {
	margin: auto;
}
.main-placeholder {
	color: #555;
	display: flex;
	flex-wrap: wrap;
	font-size: 1rem;
	gap: 4px;
	text-align: center;
}
.margin {
	margin: 1rem;
}
.margin-auto {
	margin: auto;
}
.nav-link {
	border-radius: 6px;
	color: inherit;
	display: block;
	font-size: .95rem;
	opacity: .9;
	padding: 8px 10px;
	text-decoration: none;
}
.nav-link:focus-visible {
	background: rgba(255, 255, 255, .12);
	opacity: 1;
}
.overflow {
	overflow: auto;
}
.overflow-x {
	overflow-x: auto;
}
.overflow-y {
	overflow-y: auto;
}
.padded {
	padding: 1rem;
}
.panel {
	background: #ffffff;
	border-radius: 16px;
	box-shadow: 0 8px 20px rgba(15, 23, 42, .08);
	display: flex;
	flex: 1 1 auto;
	flex-direction: column;
	min-height: 0;
	padding: 12px 14px;
}
.panel-filters {
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 12px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 12px;
}
.panel-filters h3 {
	font-size: 1rem;
	margin: 0;
}
.panel-filters input,
.panel-filters select {
	border: 1px solid #cbd5e1;
	border-radius: 10px;
	font-size: 0.95rem;
	padding: 8px 10px;
}
.panel-filters label {
	font-size: 0.85rem;
}
.panel-form {
	display: grid;
	flex: 0 0 auto;
	grid-template-columns: 1fr;
	row-gap: 8px;
}
.panel-logs {
	display: flex;
	flex: 1 1 auto;
	flex-direction: column;
	gap: 10px;
	min-height: 0;
	overflow: auto;
}
.panel-split {
	display: grid;
	flex: 1 1 auto;
	gap: 12px;
	grid-template-columns: 2fr 1fr;
	min-height: 0;
}
.pas-scan {
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 14px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin: 0 0 12px;
	padding: 12px;
}
.pas-scan input {
	border: 1px solid #cbd5e1;
	border-radius: 10px;
	font-size: 0.95rem;
	padding: 8px 10px;
}
.pas-scan label {
	color: #0f172a;
	font-size: 0.85rem;
	font-weight: 600;
}
.pas-scan-note {
	color: #64748b;
	font-size: 0.75rem;
}
.pas-scan-readonly {
	background: #f1f5f9;
}
.pasjes-card {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-200);
	border-radius: 12px;
	padding: 8px;
}
.pasjes-card-inner {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 12px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 12px;
}
.pasjes-card-inner h1 {
	color: var(--c-slate-900);
	font-size: 1rem;
	font-weight: 700;
	margin: 0;
}
.pasjes-card-inner p {
	color: var(--c-slate-700);
	margin: 0;
}
.pasjes-card-link {
	color: inherit;
	text-decoration: none;
}
.pasjes-driver,
.pasjes-charter {
	font-size: 1rem;
	font-weight: 600;
	margin: 4px 0;
}
.pasjes-grid {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.pasjes-page {
	display: flex;
	flex-direction: column;
	gap: 16px;
	width: 100%;
}
.pasjes-page a {
	color: inherit;
	text-decoration: none;
}
.pasjes-scan {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-200);
	border-radius: 18px;
	box-shadow: 0 6px 16px rgba(15, 23, 42, .08);
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin: 0;
	padding: 12px;
	text-align: left;
	width: 100%;
}
.pasjes-scan input {
	border: 1px solid var(--c-slate-300);
	border-radius: 10px;
	font-size: 0.95rem;
	padding: 8px 10px;
}
.pasjes-scan label {
	color: var(--c-slate-900);
	font-size: 0.85rem;
	font-weight: 600;
}
.pasjes-scan-note {
	color: var(--c-slate-500);
	font-size: 0.75rem;
}
.pasjes-scan-readonly {
	background: var(--c-slate-100);
}
.pasjes-section {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 14px;
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: 14px;
}
.pasjes-section-head h2 {
	font-size: 1.15rem;
	margin: 0;
}
.pasjes-sections {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.pasjes-sl-inline {
	color: var(--c-slate-700);
	font-size: 0.85rem;
	font-weight: 600;
}
.pasjes-sl-inline:empty {
	display: none;
}
.pointer {
	cursor: pointer;
}
.rawmap {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.rawmap-actions {
	display: flex;
	justify-content: flex-end;
}
.rawmap-btn {
	background: var(--c-slate-900);
	border: none;
	border-radius: 999px;
	color: var(--c-white);
	cursor: pointer;
	font-size: 0.85rem;
	font-weight: 600;
	padding: 6px 12px;
}
.rawmap-card {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 12px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 10px;
}
.rawmap-card h3 {
	color: var(--c-slate-600);
	font-size: 0.85rem;
	margin: 0;
}
.rawmap-grid {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.rawmap-header h1 {
	margin: 0 0 6px;
}
.rawmap-header p {
	color: var(--c-slate-500);
	margin: 0;
}
.rawmap-panel {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 14px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 14px;
}
.rawmap-panel label {
	display: flex;
	flex-direction: column;
	font-size: 0.85rem;
	gap: 6px;
}
.rawmap-panel textarea {
	border: 1px solid var(--c-slate-300);
	border-radius: 10px;
	font-size: 0.9rem;
	padding: 8px 10px;
}
.rawmap-select {
	border: 1px solid var(--c-slate-300);
	border-radius: 8px;
	font-size: 0.85rem;
	padding: 6px 8px;
}
.rawmap-value {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-200);
	border-radius: 8px;
	color: var(--c-slate-900);
	font-size: 0.85rem;
	padding: 6px 8px;
	word-break: break-word;
}
.readonly-toast {
	align-items: center;
	background: #ffffff;
	border: 1px solid #e2e8f0;
	border-radius: 10px;
	bottom: 18px;
	box-shadow: 0 8px 18px rgba(15, 23, 42, .15);
	color: #0f172a;
	display: flex;
	font-size: 0.82rem;
	gap: 8px;
	opacity: 0;
	padding: 8px 10px;
	pointer-events: none;
	position: fixed;
	right: 18px;
	transform: translateY(8px);
	transition: opacity .2s ease, transform .2s ease;
	z-index: 999;
}
.readonly-toast button {
	background: transparent;
	border: none;
	color: #64748b;
	cursor: pointer;
	font-size: 1rem;
	line-height: 1;
	padding: 0;
}
.readonly-toast.is-show {
	opacity: 1;
	transform: translateY(0);
}
.relative {
	position: relative;
}
.right {
	text-align: right;
}
.sidebar {
	background: #002b5b;
	color: #f7f9fc;
	display: flex;
	flex-direction: column;
	padding: 16px 14px;
	width: 250px;
}
.sidebar-account-menu {
	background: var(--c-slate-200);
	border: 1px solid var(--c-slate-200);
	border-radius: 10px;
	bottom: 40px;
	box-shadow: 0 8px 16px rgba(15, 23, 42, 0.12);
	display: none;
	flex-direction: column;
	gap: 4px;
	left: 50%;
	min-width: 160px;
	padding: 6px;
	position: absolute;
	transform: translateX(-50%);
	z-index: 20;
}
.sidebar-account-menu .nav-link {
	color: var(--c-slate-900);
}
.sidebar-account-menu.is-open {
	display: flex;
}
.sidebar-auth {
	display: flex;
	justify-content: center;
	width: 100%;
}
.sidebar-auth-btn {
	background: rgba(255, 255, 255, .14);
	border-radius: 999px;
	color: #f7f9fc;
	font-weight: 600;
	text-align: center;
	width: 100%;
}
.sidebar-bottom {
	align-items: center;
	border-top: 1px solid rgba(255, 255, 255, .18);
	display: flex;
	flex-direction: column;
	gap: 8px;
	justify-content: center;
	margin-top: auto;
	padding-top: 12px;
}
.sidebar-bottom .sidebar-auth {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 6px;
	position: relative;
}
.sidebar-bottom .sidebar-auth-btn {
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 999px;
	color: #f7f9fc;
	font-size: 0.8rem;
	font-weight: 600;
	padding: 4px 10px;
	width: auto;
}
.sidebar-nav {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.sidebar-title {
	font-size: 1.25rem;
	font-weight: 600;
	letter-spacing: .03em;
}
.sidebar-top {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.sticky {
	position: sticky;
}
.ticket {
	border: 1px solid var(--c-slate-200);
	border-radius: 14px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 12px;
}
.ticket-actions {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.ticket-body {
	color: var(--c-slate-900);
	font-size: 0.9rem;
}
.ticket-buttons {
	align-items: center;
	display: flex;
	gap: 8px;
}
.ticket-buttons button {
	background: var(--c-slate-900);
	border: none;
	border-radius: 999px;
	color: var(--c-white);
	cursor: pointer;
	font-size: 0.75rem;
	font-weight: 600;
	line-height: 1.2;
	padding: 4px 8px;
}
.ticket-close {
	display: flex;
}
.ticket-close button {
	background: #ef4444;
	border: none;
	border-radius: 999px;
	color: var(--c-white);
	cursor: pointer;
	font-size: 0.75rem;
	font-weight: 600;
	line-height: 1.2;
	padding: 4px 8px;
}
.ticket-closed-note {
	color: var(--c-slate-500);
	font-size: 0.85rem;
	margin: 0;
}
.ticket-head {
	color: var(--c-slate-600);
	display: flex;
	font-size: 0.85rem;
	gap: 10px;
	justify-content: space-between;
}
.ticket-message {
	background: var(--c-slate-50);
	border-radius: 12px;
	padding: 8px 10px;
}
.ticket-message.is-own {
	background: #e0f2fe;
}
.ticket-messages {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.ticket-meta {
	color: var(--c-slate-500);
	display: flex;
	font-size: 0.75rem;
	gap: 8px;
	justify-content: space-between;
	margin-bottom: 4px;
}
.ticket-meta-right {
	align-items: center;
	display: flex;
	gap: 8px;
}
.ticket-own {
	background: #1d4ed8;
	border-radius: 999px;
	color: var(--c-white);
	font-size: 0.65rem;
	font-weight: 700;
	padding: 2px 8px;
}
.ticket-owner {
	color: var(--c-slate-900);
	font-weight: 600;
}
.ticket-reopen button {
	background: var(--c-slate-900);
	border: none;
	border-radius: 999px;
	color: var(--c-white);
	cursor: pointer;
	font-size: 0.75rem;
	font-weight: 600;
	line-height: 1.2;
	padding: 4px 8px;
}
.ticket-reply {
	display: flex;
	gap: 8px;
}
.ticket-reply input {
	flex: 1;
	width: 100%;
}
.ticket-status {
	background: var(--c-slate-200);
	border-radius: 999px;
	color: var(--c-slate-600);
	font-size: 0.7rem;
	font-weight: 600;
	padding: 2px 8px;
}
.ticket-title {
	color: var(--c-slate-900);
	font-weight: 600;
}
.tl {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.tl-btn {
	background: var(--c-slate-900);
	border: none;
	border-radius: 999px;
	color: var(--c-white);
	cursor: pointer;
	font-size: 0.85rem;
	font-weight: 600;
	padding: 7px 14px;
	text-decoration: none;
}
.tl-btn.is-danger {
	background: var(--c-red-600);
}
.tl-btn.tl-add {
	background: #16a34a;
}
.tl-cell {
	border-right: 1px solid var(--c-slate-900);
	font-size: 0.85rem;
	padding: 6px 8px;
}
.tl-cell:last-child {
	border-right: none;
}
.tl-empty {
	color: var(--c-slate-500);
	font-size: 0.95rem;
	margin: 0;
}
.tl-head {
	background: #dbeafe;
	font-weight: 700;
}
.tl-header {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	justify-content: space-between;
}
.tl-inline-actions {
	margin-top: 10px;
}
.tl-input {
	background: var(--c-white);
	border: 1px solid var(--c-slate-300);
	border-radius: 8px;
	font-size: 0.85rem;
	padding: 4px 6px;
	width: 100%;
}
.tl-readonly .tl-inline-actions {
	display: none;
}
.tl-readonly .tl-input,
.tl-readonly .tl-select {
	background: var(--c-slate-100);
	pointer-events: none;
}
.tl-row {
	border-bottom: 1px solid var(--c-slate-900);
	display: grid;
	grid-template-columns: 2.5fr 1fr 0.8fr 0.8fr 2.5fr;
}
.tl-row:last-child {
	border-bottom: none;
}
.tl-section {
	background: #fef9c3;
	font-weight: 700;
}
.tl-section-title {
	grid-column: 1 / -1;
}
.tl-select {
	appearance: none;
	background: var(--c-white);
	border: 1px solid var(--c-slate-300);
	border-radius: 8px;
	font-size: 0.85rem;
	min-height: 26px;
	padding: 4px 6px;
	width: 100%;
	-webkit-appearance: none;
}
.tl-sheet {
	border: 1px solid var(--c-slate-900);
	border-radius: 8px;
	overflow: hidden;
}
.tl-tab {
	background: var(--c-slate-200);
	border-radius: 999px;
	color: var(--c-slate-900);
	font-size: 0.85rem;
	padding: 4px 10px;
	text-decoration: none;
}
.tl-tab.is-active {
	background: var(--c-slate-900);
	color: var(--c-white);
}
.tl-task-row .tl-cell {
	background: var(--c-slate-200);
	font-weight: 600;
}
.tl-title h1 {
	margin: 0 0 6px;
}
.tl-title p {
	color: var(--c-slate-500);
	margin: 0;
}
.tl-week-add {
	align-items: center;
	display: flex;
	gap: 6px;
}
.tl-week-add input {
	border: 1px solid var(--c-slate-300);
	border-radius: 10px;
	font-size: 0.85rem;
	padding: 4px 8px;
	width: 120px;
}
.tl-weeks,
.tl-tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.trailer-card {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-200);
	border-radius: 16px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 12px;
}
.trailer-fields {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}
.trailer-fields input,
.trailer-fields select {
	background: var(--c-white);
	border: 1px solid var(--c-slate-300);
	border-radius: 8px;
	font-size: 0.85rem;
	padding: 6px 8px;
}
.trailer-fields label {
	color: var(--c-slate-600);
	display: flex;
	flex-direction: column;
	font-size: 0.8rem;
	gap: 4px;
}
.trailer-title {
	align-items: baseline;
	display: flex;
	gap: 12px;
	justify-content: space-between;
}
.trailer-title h2 {
	font-size: 1rem;
	margin: 0;
}
.trailers {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.trailers-actions {
	display: flex;
	justify-content: flex-end;
}
.trailers-grid {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.trailers-header {
	align-items: center;
	display: flex;
	gap: 16px;
	justify-content: space-between;
}
.trailers-header h1 {
	margin: 0 0 6px;
}
.trailers-header p {
	color: var(--c-slate-500);
	margin: 0;
}
.trailers-readonly input,
.trailers-readonly select {
	background: var(--c-slate-100);
}
.trailers-readonly input,
.trailers-readonly select,
.trailers-readonly button {
	pointer-events: none;
}
.trailers-save {
	background: var(--c-slate-900);
	border: none;
	border-radius: 999px;
	color: var(--c-white);
	cursor: pointer;
	font-size: 0.9rem;
	font-weight: 600;
	padding: 8px 16px;
}
.underline {
	text-decoration: underline;
}
.users-actions {
	display: flex;
	gap: 8px;
	justify-content: flex-end;
}
.users-btn {
	background: var(--c-slate-900);
	border: none;
	border-radius: 999px;
	color: var(--c-white);
	cursor: pointer;
	font-size: 0.85rem;
	font-weight: 600;
	padding: 6px 12px;
}
.users-btn.is-danger {
	background: var(--c-red-600);
}
.users-card {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-200);
	border-radius: 12px;
	padding: 10px;
}
.users-check {
	align-items: center;
	color: var(--c-slate-700);
	display: inline-flex;
	font-size: 0.85rem;
	gap: 6px;
}
.users-empty {
	color: var(--c-slate-500);
	margin: 0;
}
.users-form {
	align-items: center;
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.users-form input,
.users-form select {
	border: 1px solid var(--c-slate-300);
	border-radius: 8px;
	font-size: 0.9rem;
	padding: 6px 8px;
}
.users-header h1 {
	margin: 0 0 6px;
}
.users-header p {
	color: var(--c-slate-500);
	margin: 0;
}
.users-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.users-page {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.users-panel {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 14px;
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: 14px;
}
.users-panel h2 {
	font-size: 1.05rem;
	margin: 0;
}
.vt-background {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.vt-bg-grid {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(2, minmax(320px, 1fr));
}
.vt-bg-grid > div {
	align-items: start;
	column-gap: 12px;
	display: grid;
	grid-template-columns: 180px 1fr;
	row-gap: 6px;
}
.vt-bg-grid code {
	background: var(--c-slate-100);
	border-radius: 4px;
	padding: 0 4px;
}
.vt-bg-grid input {
	height: 36px;
	min-height: auto;
}
.vt-bg-grid label {
	font-weight: 600;
	grid-column: 1;
}
.vt-bg-grid small {
	color: var(--c-slate-500);
	font-size: 0.8rem;
	grid-column: 1;
}
.vt-bg-grid textarea,
.vt-bg-grid input {
	background: var(--c-slate-50);
	border: 1px solid #ccd5e1;
	border-radius: 8px;
	font-size: 0.9rem;
	grid-column: 2;
	line-height: 1.3;
	min-height: 110px;
	padding: 6px 8px;
	width: 100%;
}
.vt-dock {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.vt-dock textarea {
	border: 1px solid var(--c-slate-300);
	border-radius: 10px;
	font-size: 0.9rem;
	padding: 8px 10px;
	width: 100%;
}
.vt-no-access {
	align-items: center;
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 10px;
	bottom: 18px;
	box-shadow: 0 8px 18px rgba(15, 23, 42, .15);
	color: var(--c-slate-900);
	display: flex;
	font-size: 0.82rem;
	gap: 8px;
	opacity: 0;
	padding: 8px 10px;
	pointer-events: none;
	position: fixed;
	right: 18px;
	transform: translateY(8px);
	transition: opacity .2s ease, transform .2s ease;
	z-index: 999;
}
.vt-no-access button {
	background: transparent;
	border: none;
	color: var(--c-slate-500);
	cursor: pointer;
	font-size: 1rem;
	line-height: 1;
	padding: 0;
}
.vt-no-access.is-show {
	opacity: 1;
	transform: translateY(0);
}
.vt-rc-import {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.vt-rc-import textarea {
	border: 1px solid var(--c-slate-300);
	border-radius: 10px;
	font-size: 0.9rem;
	padding: 8px 10px;
	width: 100%;
}
.vt-week-main {
	background: var(--c-slate-200);
	padding: 16px;
}
.vt-week-main .vt {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.vt-week-main .vt-actions {
	display: flex;
	justify-content: flex-end;
	min-width: 90px;
}
.vt-week-main .vt-actions-toggle {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: center;
}
.vt-week-main .vt-actions-toggle .vt-day-action {
	background: var(--c-slate-300);
	color: var(--c-slate-900);
}
.vt-week-main .vt-actions-toggle .vt-day-action.is-active {
	background: var(--c-slate-900);
	color: var(--c-white);
}
.vt-week-main .vt-add .vt-form input[readonly] {
	background: #eef2f7;
	color: var(--c-slate-600);
}
.vt-week-main .vt-add .vt-form input[type="text"],
.vt-week-main .vt-add .vt-form select {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-300);
	border-radius: 8px;
	font-size: 0.9rem;
	padding: 6px 8px;
	width: 100%;
}
.vt-week-main .vt-add .vt-update-actions {
	display: flex;
	gap: 8px;
	margin-top: 8px;
}
.vt-week-main .vt-arrival {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.vt-week-main .vt-arrival-card {
	background: var(--c-white);
	border: 1px solid var(--c-slate-300);
	border-radius: 12px;
	padding: 10px 12px;
}
.vt-week-main .vt-arrival-note {
	color: var(--c-slate-500);
	display: block;
	font-size: 0.75rem;
	margin-top: 4px;
}
.vt-week-main .vt-arrival-row {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.vt-week-main .vt-arrival-row input {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-300);
	border-radius: 8px;
	padding: 6px 8px;
	width: 100%;
}
.vt-week-main .vt-arrival-row label {
	color: var(--c-slate-900);
	display: block;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	margin-bottom: 4px;
	text-transform: uppercase;
}
.vt-week-main .vt-arrival-row span {
	display: block;
	font-size: 1.2rem;
	font-weight: 600;
	margin-bottom: 6px;
}
.vt-week-main .vt-arrival-row strong {
	display: block;
	font-size: 0.95rem;
}
.vt-week-main .vt-arrival-secondary {
	display: block;
	font-size: 1rem;
	font-weight: 600;
}
.vt-week-main .vt-back-btn {
	box-shadow: 0 10px 22px rgba(15, 23, 42, 0.25);
	position: fixed;
	right: 16px;
	top: 16px;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
	z-index: 30;
}
.vt-week-main .vt-back-btn:hover {
	background: #111827;
	box-shadow: 0 14px 28px rgba(15, 23, 42, 0.35);
	transform: translateY(-1px);
}
.vt-week-main .vt-balie-toggle {
	background: var(--c-slate-200);
	color: var(--c-slate-900);
}
.vt-week-main .vt-balie-toggle.is-active {
	background: var(--c-slate-900);
	color: var(--c-white);
}
.vt-week-main .vt-cell-locked {
	background: #fef2f2;
}
.vt-week-main .vt-cell-locked input,
.vt-week-main .vt-cell-locked select,
.vt-week-main .vt-cell-locked textarea {
	opacity: 0.6;
	pointer-events: none;
}
.vt-week-main .vt-cell-main {
	background: #dae9f8;
}
.vt-week-main .vt-cell-notes {
	background: #fbe2d5;
}
.vt-week-main .vt-cell-time {
	background: #fbe2d5;
}
.vt-week-main .vt-col-charter {
	min-width: 120px;
	width: 120px;
}
.vt-week-main .vt-col-choice {
	min-width: 65px;
	width: 65px;
}
.vt-week-main .vt-col-dock {
	min-width: 44px;
	width: 44px;
}
.vt-week-main .vt-col-hidden {
	display: none;
}
.vt-week-main .vt-col-mdbsl {
	min-width: 60px;
	width: 60px;
}
.vt-week-main .vt-col-multi {
	min-width: 50px;
	width: 50px;
}
.vt-week-main .vt-col-naar {
	min-width: 100px;
	width: 100px;
}
.vt-week-main .vt-col-narrow {
	min-width: 45px;
	width: 45px;
}
.vt-week-main .vt-col-opmerkingen {
	min-width: 120px;
	width: 120px;
}
.vt-week-main .vt-col-pincode {
	min-width: 110px;
	width: 110px;
}
.vt-week-main .vt-col-ritnummer {
	min-width: 120px;
	width: 120px;
}
.vt-week-main .vt-col-time {
	min-width: 55px;
	width: 55px;
}
.vt-week-main .vt-col-wie {
	min-width: 80px;
	width: 80px;
}
.vt-week-main .vt-column-option {
	align-items: center;
	display: flex;
	font-size: 0.85rem;
	gap: 8px;
}
.vt-week-main .vt-column-option input {
	margin: 0;
}
.vt-week-main .vt-column-panel {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 12px;
	box-shadow: 0 12px 26px rgba(15, 23, 42, 0.18);
	display: grid;
	gap: 6px;
	max-height: 320px;
	min-width: 180px;
	overflow: auto;
	padding: 10px 12px;
	position: absolute;
	right: 0;
	top: calc(100% + 6px);
	z-index: 40;
}
.vt-week-main .vt-column-panel.is-hidden {
	display: none;
}
.vt-week-main .vt-column-toggle {
	background: var(--c-slate-200);
	color: var(--c-slate-900);
}
.vt-week-main .vt-column-toggle.is-active {
	background: var(--c-slate-900);
	color: var(--c-white);
}
.vt-week-main .vt-columns {
	position: relative;
}
.vt-week-main .vt-day {
	background: var(--c-slate-200);
	border-radius: 999px;
	color: var(--c-slate-900);
	display: inline-flex;
	font-size: 0.85rem;
	padding: 4px 10px;
	text-decoration: none;
}
.vt-week-main .vt-day-action {
	background: var(--c-slate-900);
	color: var(--c-white);
}
.vt-week-main .vt-day-action.is-disabled {
	opacity: .55;
	pointer-events: none;
}
.vt-week-main .vt-day-head {
	align-items: center;
	display: flex;
	gap: 10px;
	justify-content: space-between;
}
.vt-week-main .vt-day.active {
	background: var(--c-slate-900);
	color: var(--c-white);
}
.vt-week-main .vt-days {
	display: flex;
	flex-wrap: nowrap;
	gap: 6px;
	overflow-x: auto;
}
.vt-week-main .vt-days-actions {
	align-items: center;
	display: flex;
	flex-wrap: nowrap;
	gap: 8px;
	overflow-x: auto;
}
.vt-week-main .vt-days-actions .vt-day-action {
	text-align: center;
}
.vt-week-main .vt-days-balie {
	align-items: center;
	display: flex;
	flex-wrap: nowrap;
	gap: 8px;
	margin-left: auto;
}
.vt-week-main .vt-days-bar {
	align-items: center;
	display: flex;
	flex-wrap: nowrap;
	gap: 12px;
	justify-content: space-between;
	overflow: visible;
}
.vt-week-main .vt-debug {
	background: var(--c-slate-100);
	border: 1px dashed #94a3b8;
	border-radius: 8px;
	color: var(--c-slate-700);
	font-size: 0.8rem;
	margin-top: 8px;
	padding: 8px 10px;
}
.vt-week-main .vt-debug-item {
	color: var(--c-slate-600);
	font-size: 0.8rem;
}
.vt-week-main .vt-debug-list {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin-top: 6px;
}
.vt-week-main .vt-debug-toggle {
	align-items: center;
	display: flex;
	font-size: 0.85rem;
	gap: 6px;
	margin-top: 6px;
}
.vt-week-main .vt-filter-row.is-hidden {
	display: none;
}
.vt-week-main .vt-form {
	display: grid;
	gap: 8px;
	max-width: 520px;
}
.vt-week-main .vt-form input[type="text"],
.vt-week-main .vt-form input[type="file"] {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-300);
	border-radius: 8px;
	font-size: 0.9rem;
	padding: 6px 8px;
}
.vt-week-main .vt-kpi-actions {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.vt-week-main .vt-kpi-actions-grid {
	display: grid;
	gap: 8px;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}
.vt-week-main .vt-kpi-actions-grid .vt-day {
	align-items: center;
	display: inline-flex;
	justify-content: center;
	min-height: 34px;
}
.vt-week-main .vt-kpi-actions-grid.is-hidden {
	display: none;
}
.vt-week-main .vt-kpi-bad {
	color: var(--c-red-600);
	font-weight: 600;
}
.vt-week-main .vt-kpi-block {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-200);
	border-radius: 12px;
	padding: 10px 12px;
}
.vt-week-main .vt-kpi-block p {
	font-size: 0.9rem;
	margin: 4px 0;
}
.vt-week-main .vt-kpi-good {
	color: #0f766e;
	font-weight: 600;
}
.vt-week-main .vt-kpis {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.vt-week-main .vt-live {
	background: #dcfce7;
	border-radius: 999px;
	color: #166534;
	font-size: 0.75rem;
	font-weight: 700;
	padding: 4px 10px;
}
.vt-week-main .vt-live-time {
	color: var(--c-slate-600);
	font-size: 0.75rem;
	font-weight: 600;
}
.vt-week-main .vt-live-time.is-hidden {
	display: none;
}
.vt-week-main .vt-live-wrap {
	align-items: center;
	display: inline-flex;
	gap: 8px;
}
.vt-week-main .vt-live.is-hidden {
	display: none;
}
.vt-week-main .vt-main {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.vt-week-main .vt-matrix tbody th {
	background: var(--c-slate-100);
	font-weight: 600;
}
.vt-week-main .vt-matrix td,
.vt-week-main .vt-matrix th {
	text-align: center;
}
.vt-week-main .vt-matrix thead th {
	background: var(--c-slate-200);
	border-bottom: 1px solid var(--c-slate-300);
}
.vt-week-main .vt-multi {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	position: relative;
}
.vt-week-main .vt-multi.is-open .vt-tags-menu {
	display: grid;
	gap: 6px;
}
.vt-week-main .vt-overview {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.vt-week-main .vt-overview-card {
	background: var(--c-white);
	border-radius: 12px;
	box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08);
	padding: 12px 14px;
}
.vt-week-main .vt-overview-cards {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}
.vt-week-main .vt-overview-grid {
	display: grid;
	gap: 16px;
}
.vt-week-main .vt-overview-header {
	align-items: center;
	display: flex;
	justify-content: space-between;
}
.vt-week-main .vt-overview-label {
	color: var(--c-slate-600);
	display: block;
	font-size: 0.75rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}
.vt-week-main .vt-overview-table {
	border-collapse: collapse;
	width: 100%;
}
.vt-week-main .vt-overview-table tbody tr:nth-child(even){
	background: var(--c-slate-50);
}
.vt-week-main .vt-overview-table th {
	color: var(--c-slate-900);
	font-size: 0.75rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.vt-week-main .vt-overview-table th,
.vt-week-main .vt-overview-table td {
	border-bottom: 1px solid var(--c-slate-200);
	padding: 6px 8px;
	text-align: left;
}
.vt-week-main .vt-overview-value {
	font-size: 1.2rem;
}
.vt-week-main .vt-panel {
	background: var(--c-white);
	border-radius: 12px;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
	padding: 14px;
}
.vt-week-main .vt-pincodes .vt-panel {
	margin-bottom: 12px;
}
.vt-week-main .vt-print-only {
	display: none;
}
.vt-week-main .vt-print-value {
	display: block;
	font-size: 0.95rem;
	font-weight: 600;
}
.vt-week-main .vt-progress {
	align-items: center;
	display: flex;
	gap: 10px;
	margin-top: 10px;
}
.vt-week-main .vt-progress-bar {
	animation: vt-progress 1.2s ease-in-out infinite;
	background: linear-gradient(90deg, #0ea5e9, #38bdf8);
	border-radius: 999px;
	height: 6px;
	width: 160px;
}
.vt-week-main .vt-progress.is-hidden {
	display: none;
}
.vt-week-main .vt-rc-high {
	color: #b91c1c;
	font-weight: 600;
}
.vt-week-main .vt-readonly {
	background: var(--c-slate-100);
	border-radius: 6px;
	display: inline-block;
	min-width: 48px;
	padding: 2px 6px;
}
.vt-week-main .vt-report {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.vt-week-main .vt-report-actions {
	align-items: center;
	display: flex;
	gap: 8px;
}
.vt-week-main .vt-report-header {
	align-items: center;
	display: flex;
	justify-content: space-between;
}
.vt-week-main .vt-report-table {
	border-collapse: collapse;
	width: 100%;
}
.vt-week-main .vt-report-table th {
	background: #83cceb;
	font-size: 0.7rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.vt-week-main .vt-report-table th,
.vt-week-main .vt-report-table td {
	border: 1px solid var(--c-slate-300);
	font-size: 0.8rem;
	padding: 4px 6px;
	text-align: left;
}
.vt-week-main .vt-row-forms {
	height: 0;
	overflow: hidden;
	position: absolute;
	width: 0;
}
.vt-week-main .vt-row-locked input,
.vt-week-main .vt-row-locked select,
.vt-week-main .vt-row-locked textarea {
	opacity: 0.6;
	pointer-events: none;
}
.vt-week-main .vt-row-locked td {
	background: #fef2f2;
}
.vt-week-main .vt-search-btn {
	align-items: center;
	background: transparent;
	border: none;
	color: var(--c-slate-700);
	cursor: pointer;
	display: inline-flex;
	font-size: 12px;
	height: 14px;
	justify-content: center;
	line-height: 1;
	margin-left: 6px;
	padding: 0;
	vertical-align: middle;
	width: 14px;
}
.vt-week-main .vt-table {
	border-collapse: collapse;
	min-width: 100%;
	table-layout: fixed;
	width: 100%;
}
.vt-week-main .vt-table input,
.vt-week-main .vt-table select,
.vt-week-main .vt-table textarea {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-300);
	border-radius: 8px;
	font-size: 0.75rem;
	padding: 2px 4px;
	width: 100%;
}
.vt-week-main .vt-table input.vt-naar-input {
	color: #000000;
	font-weight: 700;
}
.vt-week-main .vt-table textarea.vt-opmerkingen {
	min-height: 32px;
	overflow: hidden;
	resize: none;
}
.vt-week-main .vt-table th {
	background: #83cceb;
	font-size: 0.65rem;
	letter-spacing: 0.04em;
	position: sticky;
	text-transform: uppercase;
	top: 0;
	z-index: 1;
}
.vt-week-main .vt-table th,
.vt-week-main .vt-table td {
	border: 1px solid var(--c-slate-300);
	padding: 2px 4px;
	text-align: center;
	vertical-align: middle;
}
.vt-week-main .vt-table-wrap {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 12px;
	overflow: auto;
}
.vt-week-main .vt-tag {
	align-items: center;
	background: var(--c-slate-100);
	border-radius: 999px;
	color: var(--c-slate-700);
	display: inline-flex;
	font-size: 0.7rem;
	font-weight: 600;
	gap: 4px;
	padding: 2px 6px;
}
.vt-week-main .vt-tag button {
	background: none;
	border: none;
	color: var(--c-slate-500);
	cursor: pointer;
	font-size: 0.8rem;
	line-height: 1;
	padding: 0;
}
.vt-week-main .vt-tag-option {
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-200);
	border-radius: 6px;
	color: var(--c-slate-700);
	cursor: pointer;
	font-size: 0.75rem;
	font-weight: 600;
	padding: 4px 6px;
	text-align: left;
}
.vt-week-main .vt-tag-option:hover {
	background: var(--c-slate-100);
}
.vt-week-main .vt-tags {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	min-height: 24px;
}
.vt-week-main .vt-tags-add {
	background: var(--c-slate-200);
	border: 1px solid var(--c-slate-300);
	border-radius: 6px;
	color: var(--c-slate-700);
	cursor: pointer;
	font-size: 0.7rem;
	font-weight: 700;
	padding: 2px 6px;
}
.vt-week-main .vt-tags-input {
	display: none;
}
.vt-week-main .vt-tags-menu {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 8px;
	box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
	display: none;
	left: 0;
	max-height: 220px;
	min-width: 160px;
	overflow: auto;
	padding: 6px;
	position: absolute;
	top: calc(100% + 6px);
	z-index: 10;
}
.vt-week-main .vt-time-early {
	background: #d1fae5;
}
.vt-week-main .vt-time-late {
	background: #fca5a5;
}
.vt-week-main .vt-time-missing {
	background: var(--c-slate-200);
	color: var(--c-slate-500);
}
.vt-week-main .vt-time-neutral {
	background: transparent;
	color: inherit;
}
.vt-week-main .vt-time-ontime {
	background: #86efac;
}
.vt-week-main .vt-time-overdue {
	color: #b91c1c;
	font-weight: 600;
}
.vt-week-main .vt-time-warning {
	background: #fef3c7;
}
.vt-week-main .vt-toolbar {
	align-items: center;
	display: flex;
	gap: 16px;
	justify-content: space-between;
}
.vt-week-main .vt-update-actions {
	display: flex;
	gap: 8px;
	margin-top: 12px;
}
.vt-week-main .vt-update-compare {
	border-top: 1px dashed var(--c-slate-300);
	color: var(--c-slate-600);
	font-size: 0.85rem;
	margin-top: 8px;
	padding-top: 8px;
}
.vt-week-main .vt-update-day {
	color: var(--c-slate-500);
	font-size: 0.8rem;
	margin-left: 6px;
}
.vt-week-main .vt-update-list {
	display: grid;
	gap: 8px;
}
.vt-week-main .vt-update-meta {
	color: var(--c-slate-500);
	font-size: 0.85rem;
}
.vt-week-main .vt-update-row {
	align-items: center;
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-200);
	border-radius: 10px;
	display: flex;
	gap: 12px;
	justify-content: space-between;
	padding: 8px 10px;
}
.vt-week-main .vt-update-times {
	color: var(--c-slate-700);
	display: flex;
	flex-direction: column;
	font-size: 0.85rem;
	gap: 4px;
	text-align: right;
}
.vt-week-main .vt-week-actions {
	display: grid;
	gap: 6px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}
.vt-week-main .vt-week-btn {
	background: var(--c-slate-900);
	border: none;
	border-radius: 8px;
	color: var(--c-white);
	cursor: pointer;
	font-size: 0.85rem;
	padding: 6px 10px;
	text-decoration: none;
}
.vt-week-main .vt-week-btn.is-danger {
	background: var(--c-red-600);
}
.vt-week-main .vt-week-btn.is-muted {
	background: #94a3b8;
	cursor: not-allowed;
}
.vt-week-main .vt-week-btn[disabled] {
	opacity: 0.7;
}
.vt-week-main .vt-week-card {
	align-items: center;
	background: var(--c-slate-50);
	border: 1px solid var(--c-slate-200);
	border-radius: 12px;
	display: flex;
	gap: 12px;
	justify-content: space-between;
	padding: 12px;
}
.vt-week-main .vt-week-current {
	color: var(--c-slate-900);
	font-size: 1rem;
	font-weight: 600;
	margin: 0;
}
.vt-week-main .vt-week-info {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
}
.vt-week-main .vt-week-label {
	color: var(--c-slate-500);
	font-size: 0.75rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.vt-week-main .vt-week-label-col {
	min-width: 80px;
}
.vt-week-main .vt-week-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.vt-week-main .vt-week-metric {
	background: var(--c-white);
	border: 1px solid var(--c-slate-200);
	border-radius: 10px;
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding: 6px 10px;
}
.vt-week-main .vt-week-metric.vt-kpi-bad {
	background: #feecec;
	border-color: #fecaca;
}
.vt-week-main .vt-week-metric.vt-kpi-good {
	background: #e7f8ee;
	border-color: #bbf7d0;
}
.vt-week-main .vt-week-summary {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 0;
}
.vt-week-main .vt-week-value {
	color: var(--c-slate-900);
	font-size: 1rem;
	font-weight: 600;
}
.vt-week-main.is-balie .vt-filter-row th[data-field="reden_codes"],
.vt-week-main.is-balie .vt-filter-row th[data-field="charter"],
.vt-week-main.is-balie .vt-filter-row th[data-field="naar"],
.vt-week-main.is-balie .vt-filter-row th[data-field="mdb"],
.vt-week-main.is-balie .vt-filter-row th[data-field="sl"],
.vt-week-main.is-balie .vt-filter-row th[data-field="con"],
.vt-week-main.is-balie .vt-filter-row th[data-field="afk"],
.vt-week-main.is-balie .vt-filter-row th[data-field="sdl"],
.vt-week-main.is-balie .vt-filter-row th[data-field="wie"],
.vt-week-main.is-balie .vt-filter-row th[data-field="cmf"] {
	display: none;
}
.vt-week-main.is-balie .vt-kpi-actions {
	display: none;
}
.vt-week-main.is-balie .vt-table th[data-field="reden_codes"],
.vt-week-main.is-balie .vt-table td[data-field="reden_codes"],
.vt-week-main.is-balie .vt-table th[data-field="charter"],
.vt-week-main.is-balie .vt-table td[data-field="charter"],
.vt-week-main.is-balie .vt-table th[data-field="naar"],
.vt-week-main.is-balie .vt-table td[data-field="naar"],
.vt-week-main.is-balie .vt-table th[data-field="mdb"],
.vt-week-main.is-balie .vt-table td[data-field="mdb"],
.vt-week-main.is-balie .vt-table th[data-field="sl"],
.vt-week-main.is-balie .vt-table td[data-field="sl"],
.vt-week-main.is-balie .vt-table th[data-field="con"],
.vt-week-main.is-balie .vt-table td[data-field="con"],
.vt-week-main.is-balie .vt-table th[data-field="afk"],
.vt-week-main.is-balie .vt-table td[data-field="afk"],
.vt-week-main.is-balie .vt-table th[data-field="sdl"],
.vt-week-main.is-balie .vt-table td[data-field="sdl"],
.vt-week-main.is-balie .vt-table th[data-field="wie"],
.vt-week-main.is-balie .vt-table td[data-field="wie"],
.vt-week-main.is-balie .vt-table th[data-field="cmf"],
.vt-week-main.is-balie .vt-table td[data-field="cmf"] {
	display: none;
}
.vt-week-main[data-user-level="1"] .vt-balie-toggle,
.vt-week-main[data-user-level="1"] .vt-back-btn {
	filter: none;
	opacity: 1;
	pointer-events: auto;
}
.vt-week-main[data-user-level="1"] .vt-column-panel input {
	pointer-events: auto;
}
.vt-week-main[data-user-level="1"] .vt-column-toggle {
	filter: none;
	opacity: 1;
	pointer-events: auto;
}
.vt-week-main[data-user-level="1"] .vt-days .vt-day[href*="/overzicht"] {
	filter: grayscale(1);
	opacity: 0.4;
	pointer-events: none;
}
.vt-week-main[data-user-level="1"] .vt-kpi-actions,
.vt-week-main[data-user-level="1"] .vt-day-action,
.vt-week-main[data-user-level="1"] .vt-delete-rit,
.vt-week-main[data-user-level="1"] .vt-days-actions,
.vt-week-main[data-user-level="1"] .vt-actions-toggle {
	filter: grayscale(1);
	opacity: 0.4;
	pointer-events: none;
}
.vt-week-main[data-user-level="1"] .vt-table input,
.vt-week-main[data-user-level="1"] .vt-table select,
.vt-week-main[data-user-level="1"] .vt-table textarea,
.vt-week-main[data-user-level="1"] .vt-filter {
	background: var(--c-slate-100);
	pointer-events: none;
}
.wide {
	max-width: 1200px;
}
@keyframes vt-progress {
	0% {
		opacity: 0.4;
	}
	100% {
		opacity: 0.4;
	}
	50% {
		opacity: 1;
	}
}
@media (max-width: 600px){
	main {
		overflow: visible;
		padding: 8px;
	}
	.afkap-actions {
		width: 100%;
	}
	.afkap-btn {
		padding: 8px 12px;
	}
	.afkap-head-actions {
		justify-self: start;
	}
	.afkap-header {
		align-items: flex-start;
		flex-direction: column;
	}
	.afkap-inline-controls {
		display: none;
	}
	.afkap-line {
		grid-template-columns: 1fr;
	}
	.afkap-line.afkap-line-head,
	.afkap-line.afkap-line-form {
		grid-template-columns: 1fr;
	}
	.afkap-option-group {
		flex-wrap: wrap;
	}
	.afkap-rit-head {
		grid-template-columns: 1fr;
	}
	.afkap-winkel-actions {
		flex-wrap: wrap;
		row-gap: 10px;
	}
	.app {
		flex-direction: column;
		height: auto;
		min-height: 100dvh;
		overflow: visible;
	}
	.nav-link {
		font-size: 0.85rem;
		padding: 6px 8px;
	}
	.sidebar {
		gap: 10px;
		padding: 10px 12px;
		width: 100%;
	}
	.sidebar-bottom {
		font-size: 0.75rem;
		padding-top: 6px;
	}
	.sidebar-nav {
		flex-direction: row;
		flex-wrap: wrap;
		gap: 6px;
	}
	.sidebar-title {
		font-size: 1rem;
	}
}
@media (max-width: 700px){
	.admin-btn {
		text-align: center;
		width: 100%;
	}
	.home-hero h1 {
		font-size: 1.3rem;
	}
	.home-section-head {
		align-items: flex-start;
	}
}
@media (max-width: 800px){
	.panel-split {
		grid-template-columns: 1fr;
	}
}
@media (max-width: 900px){
	.afkap-col-actions {
		grid-column: 1 / -1;
		justify-content: flex-start;
	}
	.afkap-line {
		grid-template-columns: repeat(2, minmax(120px, 1fr));
	}
	.afkap-line.afkap-line-head,
	.afkap-line.afkap-line-form {
		grid-template-columns: repeat(2, minmax(120px, 1fr));
	}
	.afkap-rit-head {
		grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
	}
	.tl-row {
		grid-template-columns: 2fr 1fr 1fr 1fr 2fr;
	}
	.vt-bg-grid {
		grid-template-columns: 1fr;
	}
	.vt-week-main .vt-day {
		text-align: center;
	}
	.vt-week-main .vt-days,
	.vt-week-main .vt-days-actions {
		width: 100%;
	}
	.vt-week-main .vt-days-actions {
		flex-wrap: nowrap;
		overflow-x: auto;
	}
	.vt-week-main .vt-days-bar {
		align-items: stretch;
		flex-direction: column;
	}
	.vt-week-main .vt-readonly {
		box-sizing: border-box;
		max-width: 100%;
		min-width: 0;
	}
	.vt-week-main .vt-table td[data-field="tijd"] .vt-readonly {
		display: block;
	}
	.vt-week-main .vt-table th,
	.vt-week-main .vt-table td {
		font-size: 0.6rem;
		overflow: hidden;
		padding: 2px 3px;
	}
	.vt-week-main .vt-table th[data-field="dock"],
	.vt-week-main .vt-table td[data-field="dock"],
	.vt-week-main .vt-table th[data-field="pincode"],
	.vt-week-main .vt-table td[data-field="pincode"],
	.vt-week-main .vt-table th[data-field="multi_dc"],
	.vt-week-main .vt-table td[data-field="multi_dc"],
	.vt-week-main .vt-table th[data-field="lps"],
	.vt-week-main .vt-table td[data-field="lps"],
	.vt-week-main .vt-table th[data-field="vps"],
	.vt-week-main .vt-table td[data-field="vps"],
	.vt-week-main .vt-table th[data-field="tht"],
	.vt-week-main .vt-table td[data-field="tht"],
	.vt-week-main .vt-table th[data-field="binnen"],
	.vt-week-main .vt-table td[data-field="binnen"],
	.vt-week-main .vt-table th[data-field="start"],
	.vt-week-main .vt-table td[data-field="start"],
	.vt-week-main .vt-table th[data-field="klaar"],
	.vt-week-main .vt-table td[data-field="klaar"],
	.vt-week-main .vt-table th[data-field="lt"],
	.vt-week-main .vt-table td[data-field="lt"],
	.vt-week-main .vt-table th[data-field="reden_codes"],
	.vt-week-main .vt-table td[data-field="reden_codes"],
	.vt-week-main .vt-table th[data-field="opmerkingen"],
	.vt-week-main .vt-table td[data-field="opmerkingen"],
	.vt-week-main .vt-table th[data-field="mdb"],
	.vt-week-main .vt-table td[data-field="mdb"],
	.vt-week-main .vt-table th[data-field="sl"],
	.vt-week-main .vt-table td[data-field="sl"],
	.vt-week-main .vt-table th[data-field="con"],
	.vt-week-main .vt-table td[data-field="con"],
	.vt-week-main .vt-table th[data-field="afk"],
	.vt-week-main .vt-table td[data-field="afk"],
	.vt-week-main .vt-table th[data-field="sdl"],
	.vt-week-main .vt-table td[data-field="sdl"],
	.vt-week-main .vt-table th[data-field="wie"],
	.vt-week-main .vt-table td[data-field="wie"],
	.vt-week-main .vt-table th[data-field="cmf"],
	.vt-week-main .vt-table td[data-field="cmf"] {
		display: none;
	}
	.vt-week-main .vt-table th[data-field="ritnummer"],
	.vt-week-main .vt-table td[data-field="ritnummer"],
	.vt-week-main .vt-table th[data-field="naar"],
	.vt-week-main .vt-table td[data-field="naar"],
	.vt-week-main .vt-table th[data-field="rc"],
	.vt-week-main .vt-table td[data-field="rc"],
	.vt-week-main .vt-table th[data-field="tijd"],
	.vt-week-main .vt-table td[data-field="tijd"] {
		display: table-cell;
	}
	.vt-week-main .vt-toolbar {
		align-items: flex-start;
		flex-direction: column;
	}
	.vt-week-main .vt-week-card {
		align-items: flex-start;
		flex-direction: column;
	}
}
@media print {
	.vt-week-main {
		background: var(--c-white);
	}
	.vt-week-main .vt-arrival-card {
		padding: 6px 8px;
	}
	.vt-week-main .vt-arrival-row {
		gap: 8px;
	}
	.vt-week-main .vt-arrival-row input {
		display: none;
	}
	.vt-week-main .vt-arrival-row label {
		font-size: 0.65rem;
		margin-bottom: 2px;
	}
	.vt-week-main .vt-arrival-row span {
		font-size: 0.9rem;
		margin-bottom: 2px;
	}
	.vt-week-main .vt-arrival-row strong {
		font-size: 0.8rem;
	}
	.vt-week-main .vt-arrival-secondary {
		font-size: 0.8rem;
	}
	.vt-week-main .vt-back-btn,
	.vt-week-main .vt-print-btn,
	.vt-week-main .btn {
		display: none;
	}
	.vt-week-main .vt-panel {
		border: 1px solid var(--c-slate-300);
		box-shadow: none;
		padding: 6px;
	}
	.vt-week-main .vt-print-only {
		display: block;
	}
	.vt-week-main .vt-print-value {
		font-size: 0.75rem;
		margin-top: 2px;
	}
	.vt-week-main .vt-report {
		gap: 8px;
	}
	.vt-week-main .vt-report-grid {
		grid-template-columns: 1fr;
	}
	.vt-week-main .vt-report-header h2 {
		font-size: 0.9rem;
		margin: 0;
	}
	.vt-week-main .vt-report-header p {
		font-size: 0.7rem;
		margin: 2px 0 0;
	}
	.vt-week-main .vt-report-table {
		table-layout: fixed;
	}
	.vt-week-main .vt-report-table td {
		word-break: break-word;
	}
	.vt-week-main .vt-report-table th {
		font-size: 0.6rem;
	}
	.vt-week-main .vt-report-table th,
	.vt-week-main .vt-report-table td {
		font-size: 0.65rem;
		padding: 2px 3px;
	}
	@page {
		margin: 6mm;
		size: A4 landscape;
	}
}