/* =============================================================
   Trainingen Lijst Plugin — trainingen-lijst.css
   Stijl: clean, professioneel, Nederlandse trainingsmarkt
   ============================================================= */

:root {
	--tl-accent:         #0057b8;
	--tl-accent-hover:   #003e8a;
	--tl-bijna-vol:      #d97706;
	--tl-bijna-vol-bg:   #fffbeb;
	--tl-bijna-vol-brd:  #fcd34d;
	--tl-beschikbaar-bg: #f0f7ff;
	--tl-beschikbaar-brd:#bfdbfe;
	--tl-tekst:          #1e293b;
	--tl-subtekst:       #64748b;
	--tl-bg:             #ffffff;
	--tl-radius:         12px;
	--tl-shadow:         0 2px 8px rgba(0,0,0,.08);
	--tl-shadow-hover:   0 6px 20px rgba(0,87,184,.15);
	--tl-font:           'Segoe UI', Arial, sans-serif;
}

/* Wrapper */
.tl-wrapper {
	font-family: var(--tl-font);
	color: var(--tl-tekst);
	max-width: 900px;
	margin: 0 auto;
}

/* Legenda */
.tl-legend {
	display: flex;
	gap: 12px;
	margin-bottom: 28px;
	flex-wrap: wrap;
}

/* Badges */
.tl-badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 1.25rem;
	font-weight: 600;
	letter-spacing: .04em;
	text-transform: uppercase;
	padding: 3px 10px;
	border-radius: 999px;
}

.tl-badge--beschikbaar {
	background: #dbeafe;
	color: #1d4ed8;
}

.tl-badge--bijna-vol {
	background: #fef3c7;
	color: #92400e;
}

.tl-badge--volgeboekt {
	background: #e2e8f0;
	color: #64748b;
}

/* Maandblok */
.tl-maand-blok {
	margin-bottom: 36px;
}

.tl-maand-titel {
	font-size: 1.5rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--tl-subtekst);
	margin: 0 0 14px;
	padding-bottom: 8px;
	border-bottom: 2px solid #e2e8f0;
}

/* Kaartenraster */
.tl-kaarten {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 16px;
}

/* Kaart */
.tl-kaart {
	background: var(--tl-bg);
	border-radius: var(--tl-radius);
	border: 1.5px solid var(--tl-beschikbaar-brd);
	box-shadow: var(--tl-shadow);
	display: flex;
	flex-direction: column;
	transition: box-shadow .2s ease, transform .2s ease;
}

.tl-kaart:hover {
	box-shadow: var(--tl-shadow-hover);
	transform: translateY(-2px);
}

.tl-kaart--beschikbaar {
	background: var(--tl-beschikbaar-bg);
	border-color: var(--tl-beschikbaar-brd);
}

.tl-kaart--bijna-vol {
	background: var(--tl-bijna-vol-bg);
	border-color: var(--tl-bijna-vol-brd);
}

.tl-kaart--volgeboekt {
	background: #f8fafc;
	border-color: #cbd5e1;
	opacity: .75;
}

.tl-kaart--volgeboekt:hover {
	box-shadow: var(--tl-shadow);
	transform: none;
}

/* Kaart header */
.tl-kaart__header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding: 16px 16px 10px;
	gap: 8px;
}

.tl-kaart__plaats {
	font-size: 1.5rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	gap: 5px;
	color: var(--tl-tekst);
}

.tl-kaart__plaats svg {
	width: 16px;
	height: 16px;
	color: var(--tl-accent);
	flex-shrink: 0;
}

/* Kaart body */
.tl-kaart__body {
	padding: 0 16px 14px;
	flex: 1;
}

.tl-kaart__datum,
.tl-kaart__adres {
	display: flex;
	align-items: flex-start;
	gap: 6px;
	margin: 0 0 8px;
	font-size: 1.3rem;
	color: var(--tl-subtekst);
	line-height: 1.4;
}

.tl-kaart__datum svg,
.tl-kaart__adres svg {
	width: 15px;
	height: 15px;
	flex-shrink: 0;
	margin-top: 1px;
}

.tl-kaart__cursusid {
	font-size: .78rem;
	color: #94a3b8;
	margin: 0;
}

.tl-kaart__cursusid--na {
	font-style: italic;
}

/* Kaart footer */
.tl-kaart__footer {
	padding: 12px 16px 16px;
	border-top: 1px solid rgba(0,0,0,.06);
}

/* Keuzeknop */
.tl-knop {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	padding: 10px 18px;
	background: var(--tl-accent);
	color: #fff !important;
	font-family: var(--tl-font);
	font-size: 1.3rem;
	font-weight: 600;
	text-decoration: none;
	border-radius: 8px;
	border: none;
	cursor: pointer;
	transition: background .18s ease, box-shadow .18s ease;
	box-sizing: border-box;
}

.tl-knop svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	transition: transform .18s ease;
}

.tl-knop:hover {
	background: var(--tl-accent-hover);
	text-decoration: none;
	color: #fff;
}

.tl-knop:hover svg {
	transform: translateX(3px);
}

.tl-knop--bijna-vol {
	background: var(--tl-bijna-vol);
}

.tl-knop--bijna-vol:hover {
	background: #b45309;
	color: #fff;
}

.tl-knop[aria-disabled="true"] {
	background: #94a3b8;
	cursor: not-allowed;
	pointer-events: none;
}

/* Volgeboekt knop */
.tl-knop--volgeboekt {
	background: #94a3b8 !important;
	cursor: pointer;
}

.tl-knop--volgeboekt:hover {
	background: #64748b !important;
	color: #fff;
}

.tl-knop--volgeboekt svg {
	transform: none !important;
}

/* Geen events */
.tl-no-events {
	color: var(--tl-subtekst);
	font-style: italic;
}

/* Responsive */
@media (max-width: 480px) {
	.tl-kaarten {
		grid-template-columns: 1fr;
	}
}
