/* Centrale proefles-kalender — Bastiaens huisstijl (red primary + yellow accent + Gilroy/Lato).
   Layout: filter-card bovenaan, slots gegroepeerd per dag met bold typografie. */

.nlpg-cursuskalender{
	--nlpg-primary: var(--e-global-color-primary, #B8000B);
	--nlpg-deep: #8B0008;
	--nlpg-accent: var(--e-global-color-b318c1c, #E6B000);
	--nlpg-text: var(--e-global-color-text, #222);
	--nlpg-muted: #6b7280;
	--nlpg-soft: #fafafa;
	--nlpg-border: #e9e9eb;
	--nlpg-border-strong: #d4d4d8;
	--nlpg-heading-font: var(--e-global-typography-primary-font-family, 'Gilroy'), 'Gilroy', system-ui, sans-serif;
	--nlpg-body-font: var(--e-global-typography-text-font-family, 'Lato'), 'Lato', system-ui, sans-serif;

	font-family: var(--nlpg-body-font);
	color: var(--nlpg-text);
	max-width: 1100px;
	margin: 40px auto 64px;
	padding: 0 16px;
	box-sizing: border-box;
}
.nlpg-cursuskalender *, .nlpg-cursuskalender *::before, .nlpg-cursuskalender *::after{ box-sizing: inherit; }

/* Header */
.nlpg-cursuskalender__header{ margin: 0 0 26px; }
.nlpg-cursuskalender__title{
	margin: 0 0 6px;
	font-family: var(--nlpg-heading-font);
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--nlpg-text);
	line-height: 1.1;
}
.nlpg-cursuskalender__intro{
	margin: 0;
	color: var(--nlpg-muted);
	font-size: 1rem;
	max-width: 580px;
}

/* Filter bar — clean horizontal row, geen card-look */
.nlpg-ck-filters{
	display: flex;
	flex-wrap: wrap;
	gap: 18px 28px;
	align-items: center;
	justify-content: space-between;
	padding: 4px 0 20px;
	border-bottom: 1px solid var(--nlpg-border);
	margin-bottom: 26px;
}
.nlpg-ck-chips{
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
/* Chips — specificiteit-bump tegen Elementor button styling die border-radius platslaat. */
.nlpg-cursuskalender button.nlpg-ck-chip,
.nlpg-cursuskalender button.nlpg-ck-chip:hover{
	padding: 9px 20px !important;
	background-color: #fff;
	border: 2px solid var(--nlpg-deep) !important;
	border-radius: 999px !important;
	cursor: pointer;
	font-family: var(--nlpg-body-font) !important;
	font-size: .9rem !important;
	font-weight: 700 !important;
	color: var(--nlpg-deep);
	letter-spacing: .01em !important;
	line-height: 1.2 !important;
	text-transform: none !important;
	text-shadow: none !important;
	box-shadow: none !important;
	transition: background-color .15s ease, color .15s ease;
}
.nlpg-cursuskalender button.nlpg-ck-chip:hover{
	background-color: color-mix(in srgb, var(--nlpg-deep) 8%, #fff);
}
.nlpg-cursuskalender button.nlpg-ck-chip--active,
.nlpg-cursuskalender button.nlpg-ck-chip--active:hover{
	background-color: var(--nlpg-deep);
	color: #fff;
}

.nlpg-ck-daterange{ display: flex; align-items: flex-end; gap: 12px; flex-wrap: wrap; }
.nlpg-ck-daterange label{
	display: flex;
	flex-direction: column;
	gap: 5px;
	font-size: .68rem;
	font-weight: 700;
	color: var(--nlpg-muted);
	text-transform: uppercase;
	letter-spacing: .08em;
	font-family: var(--nlpg-body-font);
}
.nlpg-cursuskalender .nlpg-ck-daterange input[type="date"]{
	padding: 10px 14px;
	border: 1.5px solid var(--nlpg-border-strong);
	border-radius: 8px;
	background: #fff;
	font-size: .92rem;
	color: var(--nlpg-text);
	font-family: inherit;
	font-weight: 600;
	min-width: 160px;
	box-shadow: none;
	-webkit-appearance: none;
	appearance: none;
}
.nlpg-cursuskalender .nlpg-ck-daterange input[type="date"]:focus{
	outline: none;
	border-color: var(--nlpg-primary);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--nlpg-primary) 14%, transparent);
}
.nlpg-cursuskalender button.nlpg-ck-reset,
.nlpg-cursuskalender button.nlpg-ck-reset:hover{
	padding: 10px 16px !important;
	background-color: transparent;
	border: 1.5px solid transparent !important; /* matched aan date-input border zodat hoogtes gelijk lopen */
	border-radius: 8px !important;
	font-family: var(--nlpg-body-font) !important;
	font-size: .92rem !important;
	font-weight: 700 !important;
	color: var(--nlpg-muted);
	cursor: pointer;
	text-transform: uppercase;
	letter-spacing: .04em !important;
	line-height: 1.4 !important;
	box-shadow: none !important;
	text-shadow: none !important;
	transition: color .12s ease;
}
.nlpg-cursuskalender button.nlpg-ck-reset:hover{ color: var(--nlpg-deep); }

.nlpg-ck-summary{
	margin: 0 0 18px;
	font-size: .88rem;
	color: var(--nlpg-muted);
	font-weight: 600;
}

/* Slot lijst */
.nlpg-ck-list{ display: flex; flex-direction: column; gap: 44px; }

/* Dag-groep */
.nlpg-ck-daygroup{ display: flex; flex-direction: column; gap: 10px; }
.nlpg-ck-dayhead{
	display: flex;
	align-items: center;
	gap: 18px;
	padding: 0 4px 14px;
	border-bottom: 2px solid var(--nlpg-border);
	margin-bottom: 8px;
}
.nlpg-ck-daytile{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 64px;
	min-width: 64px;
	padding: 8px 4px;
	background: var(--nlpg-deep);
	color: #fff;
	border-radius: 10px;
	line-height: 1;
}
.nlpg-ck-daytile__day{
	font-family: var(--nlpg-heading-font);
	font-size: 1.85rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	font-variant-numeric: tabular-nums;
}
.nlpg-ck-daytile__month{
	margin-top: 4px;
	font-size: .68rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	opacity: .92;
}
.nlpg-ck-dayhead__text{ display: flex; flex-direction: column; gap: 3px; }
.nlpg-ck-dayhead__dow{
	font-family: var(--nlpg-heading-font);
	font-size: 1.35rem;
	font-weight: 700;
	color: var(--nlpg-text);
	letter-spacing: -0.01em;
	text-transform: capitalize;
	line-height: 1.1;
}
.nlpg-ck-dayhead__count{
	font-size: .8rem;
	color: var(--nlpg-muted);
	font-weight: 600;
	letter-spacing: .02em;
}
.nlpg-ck-dayhead__today{
	display: inline-block;
	margin-left: auto;
	padding: 5px 12px;
	background: var(--nlpg-accent);
	color: #1f1f1f;
	border-radius: 999px;
	font-size: .7rem;
	font-weight: 800;
	letter-spacing: .08em;
	text-transform: uppercase;
}

/* Slot card */
.nlpg-ck-slot{
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 24px;
	padding: 18px 22px;
	background: #fff;
	border: 1px solid var(--nlpg-border);
	border-radius: 12px;
}

.nlpg-ck-slot__time{
	display: flex;
	flex-direction: column;
	min-width: 92px;
}
.nlpg-ck-slot__time-start{
	font-family: var(--nlpg-heading-font);
	font-size: 1.85rem;
	font-weight: 700;
	color: var(--nlpg-text);
	letter-spacing: -0.02em;
	font-variant-numeric: tabular-nums;
	line-height: 1;
}
.nlpg-ck-slot__time-end{
	font-size: .8rem;
	color: var(--nlpg-muted);
	font-weight: 600;
	font-variant-numeric: tabular-nums;
	margin-top: 4px;
}

.nlpg-ck-slot__body{ display: flex; flex-direction: column; gap: 4px; }
.nlpg-ck-slot__title{
	font-family: var(--nlpg-heading-font);
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--nlpg-text);
	letter-spacing: -0.005em;
}
.nlpg-ck-slot__sub{
	font-size: .85rem;
	color: var(--nlpg-muted);
	font-weight: 500;
}

.nlpg-cursuskalender a.nlpg-ck-book,
.nlpg-cursuskalender a.nlpg-ck-book:hover{
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 22px;
	background-color: var(--nlpg-deep);
	color: #fff !important;
	text-decoration: none;
	border-radius: 8px;
	font-family: var(--nlpg-body-font);
	font-weight: 700;
	font-size: .9rem;
	letter-spacing: .02em;
	text-transform: uppercase;
	transition: filter .15s ease;
	white-space: nowrap;
	border: 0;
	box-shadow: none;
}
.nlpg-cursuskalender a.nlpg-ck-book:hover{ filter: brightness(1.12); }
.nlpg-cursuskalender a.nlpg-ck-book svg{ width: 16px; height: 16px; }

.nlpg-ck-nobook{
	color: var(--nlpg-muted);
	font-style: italic;
	font-size: .85rem;
	font-weight: 500;
	padding-right: 6px;
}

/* Empty / loading */
.nlpg-ck-empty,
.nlpg-ck-loading{
	text-align: center;
	padding: 64px 24px;
	background: #fff;
	border: 1px dashed var(--nlpg-border-strong);
	border-radius: 12px;
	color: var(--nlpg-muted);
	font-size: .95rem;
	font-weight: 500;
}
.nlpg-ck-empty strong,
.nlpg-ck-loading strong{
	display: block;
	font-family: var(--nlpg-heading-font);
	font-size: 1.15rem;
	color: var(--nlpg-text);
	margin-bottom: 6px;
	font-weight: 700;
}

/* Tablet (≤900): list gap kleiner, tile en typografie verkleinen */
@media (max-width: 900px){
	.nlpg-ck-list{ gap: 32px; }
	.nlpg-ck-slot{ gap: 18px; padding: 16px 18px; }
	.nlpg-ck-slot__time-start{ font-size: 1.65rem; }
}

/* Mobiel (≤640): kalender stackt, knop full width, tile compacter */
@media (max-width: 640px){
	.nlpg-cursuskalender{ margin: 24px auto 40px; }
	.nlpg-cursuskalender__title{ font-size: 1.6rem; }
	.nlpg-ck-filters{ gap: 14px; flex-direction: column; align-items: flex-start; }
	.nlpg-ck-daterange{ width: 100%; }
	.nlpg-ck-list{ gap: 28px; }
	.nlpg-ck-slot{
		grid-template-columns: auto 1fr;
		gap: 14px;
	}
	.nlpg-ck-slot__time{ min-width: 72px; }
	.nlpg-ck-slot__time-start{ font-size: 1.5rem; }
	.nlpg-cursuskalender a.nlpg-ck-book{
		grid-column: 1 / -1;
		justify-content: center;
		width: 100%;
	}
	.nlpg-ck-nobook{
		grid-column: 1 / -1;
		text-align: center;
		padding: 0;
	}
	.nlpg-ck-daytile{ width: 54px; min-width: 54px; padding: 7px 4px; }
	.nlpg-ck-daytile__day{ font-size: 1.5rem; }
	.nlpg-ck-dayhead{ flex-wrap: wrap; gap: 12px; }
	.nlpg-ck-dayhead__dow{ font-size: 1.15rem; }
	.nlpg-ck-dayhead__today{ margin-left: 0; }
}

/* Klein (≤400): nog iets compacter zodat alles past op iPhone SE */
@media (max-width: 400px){
	.nlpg-cursuskalender{ padding: 0 12px; }
	.nlpg-ck-slot{ padding: 14px; }
	.nlpg-ck-slot__time-start{ font-size: 1.35rem; }
	.nlpg-ck-daytile{ width: 48px; min-width: 48px; }
	.nlpg-ck-daytile__day{ font-size: 1.3rem; }
}
