/* ============================================================
 * NZB Planner — Frontend (Bootstrap-achtige look, custom CSS).
 * ============================================================ */

.od-form-wrap {
	--od-primary:        #0d6efd;
	--od-primary-hover:  #0b5ed7;
	--od-success:        #198754;
	--od-warning:        #f59f00;
	--od-warning-bg:     #fff3cd;
	--od-danger:         #dc3545;
	--od-danger-bg:      #f8d7da;
	--od-text:           #212529;
	--od-muted:          #6c757d;
	--od-border:         #dee2e6;
	--od-bg:             #f8f9fa;
	--od-shadow:         0 2px 12px rgba(0,0,0,.06);
	--od-radius:         10px;

	/* max-width wordt via inline-style ingesteld vanuit instellingen (form_max_width) */
	margin: 0 auto;
	color: var(--od-text);
	font-family: inherit;
	line-height: 1.5;
}

.od-form {
	background: #fff;
	border: 1px solid var(--od-border);
	border-radius: var(--od-radius);
	box-shadow: var(--od-shadow);
	padding: 2em;
}

/* ---------- Headers ---------- */

.od-form-header h2 {
	margin: 0 0 .2em;
	font-size: 1.05em;
	font-weight: 600;
}
.od-form-header p {
	margin: 0 0 1.25em;
	color: var(--od-muted);
	font-size: .9em;
}

.od-form-section { margin-bottom: 1.5em; padding-bottom: 1.25em; border-bottom: 1px solid var(--od-bg); }
.od-form-section:last-of-type { border-bottom: 0; padding-bottom: 0; }
.od-form-section-heading {
	margin: 0 0 .85em;
	font-weight: 600;
	color: #343a40;
}

/* ---------- Form fields ---------- */

.od-form-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1em;
	margin-bottom: 1em;
}
.od-form-grid-3 {
	grid-template-columns: 2fr 1fr 2fr;
}
.od-form-group {
	display: flex;
	flex-direction: column;
	gap: .3em;
	margin-bottom: 1em;
}
.od-form-group:last-child { margin-bottom: 0; }
.od-form-grid .od-form-group { margin-bottom: 0; }

.od-form-group label,
.od-field-label {
	font-size: .85em;
	font-weight: 500;
	color: #495057;
}
.od-form-group input[type="text"],
.od-form-group input[type="email"],
.od-form-group input[type="tel"],
.od-form-group input[type="number"],
.od-form-group select,
.od-form-group textarea {
	padding: .55em .75em;
	border: 1px solid var(--od-border);
	border-radius: 6px;
	font-size: 1em;
	font-family: inherit;
	background: #fff;
	transition: border-color .15s, box-shadow .15s;
}
.od-form-group textarea { resize: vertical; }
.od-form-group input:focus,
.od-form-group select:focus,
.od-form-group textarea:focus {
	outline: none;
	border-color: var(--od-primary);
	box-shadow: 0 0 0 3px rgba(13, 110, 253, .15);
}

.od-conditional[hidden] { display: none; }

/* ---------- Conditional fieldsets (Kind / Zorgprofessional) ---------- */

.od-conditional-group {
	border: 1px solid var(--od-border);
	border-radius: 6px;
	background: var(--od-bg);
	padding: .85em 1em;
	margin: .25em 0 1em;
}
.od-conditional-group[hidden] { display: none; }

/* ---------- Radio rows ---------- */

.od-radio-row {
	display: flex;
	gap: 1.5em;
	padding: .3em 0;
	flex-wrap: wrap;
}
.od-radio {
	display: inline-flex;
	align-items: center;
	gap: .4em;
	cursor: pointer;
	font-size: .95em;
	color: #343a40;
}
.od-radio input { accent-color: var(--od-primary); }

.od-person-type { gap: 2em; }

/* ---------- Help text ---------- */

.od-help {
	background: var(--od-bg);
	padding: .65em 1em;
	border-left: 3px solid var(--od-primary);
	border-radius: 4px;
	font-size: .85em;
	color: #495057;
	margin: 0 0 1em;
}

/* ---------- Lectures (ochtendprogramma) ---------- */

.od-lectures {
	display: flex;
	flex-direction: column;
	gap: .5em;
}
.od-lectures-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .65em;
}
.od-lectures-grid .od-lecture-none {
	grid-column: 1 / -1;
}
.od-lecture {
	display: flex;
	gap: .65em;
	align-items: flex-start;
	cursor: pointer;
	border: 1px solid var(--od-border);
	border-radius: 8px;
	padding: .75em 1em;
	background: #fff;
	transition: all .12s;
}
.od-lecture:hover { background: var(--od-bg); }
.od-lecture input {
	margin-top: .2em;
	accent-color: var(--od-primary);
}
.od-lecture-content {
	display: flex;
	flex-direction: column;
	gap: .25em;
	flex: 1;
}
.od-lecture-title { font-weight: 600; font-size: .95em; }
.od-lecture-desc { color: var(--od-muted); font-size: .85em; }
.od-lecture-meta { margin-top: .15em; }
.od-lecture:has(input:checked) {
	background: rgba(13,110,253,.08);
	border-color: var(--od-primary);
}
.od-lecture.od-lecture-full { background: var(--od-warning-bg); border-color: #ffe69c; }
.od-lecture-none { background: var(--od-bg); border-style: dashed; }

/* ---------- Workshops (middagprogramma) ---------- */

.od-workshops { display: flex; flex-direction: column; gap: .65em; }
.od-workshop {
	border: 1px solid var(--od-border);
	border-radius: 8px;
	padding: .85em 1.1em;
	transition: border-color .15s, box-shadow .15s;
}
.od-workshop:has(input:checked) {
	border-color: var(--od-primary);
	box-shadow: 0 0 0 2px rgba(13,110,253,.08);
}
/* Smaller workshop titles per request */
.od-workshop-head h4 {
	margin: 0 0 .1em;
	font-size: .82em;
	font-weight: 600;
	color: #343a40;
}
.od-workshop-head p {
	margin: 0 0 .5em;
	color: var(--od-muted);
	font-size: .78em;
}

.od-slots {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .5em;
}
.od-slot {
	display: block;
	cursor: pointer;
	border: 1px solid var(--od-border);
	border-radius: 6px;
	padding: .55em .75em;
	background: #fff;
	transition: all .12s;
}
.od-slot:hover { background: var(--od-bg); }
.od-slot input {
	margin-right: .5em;
	vertical-align: middle;
	accent-color: var(--od-primary);
}
.od-slot-content { display: inline-flex; gap: .65em; align-items: center; }
.od-slot-time { font-weight: 600; font-size: .95em; }
.od-slot:has(input:checked) {
	background: rgba(13,110,253,.08);
	border-color: var(--od-primary);
}
.od-slot.od-slot-full { background: var(--od-warning-bg); border-color: #ffe69c; }
.od-slot.od-is-disabled { opacity: .45; cursor: not-allowed; }
.od-slot.od-is-disabled:hover { background: #fff; }
.od-slot.od-slot-full.od-is-disabled { background: var(--od-warning-bg); }

.od-pill {
	display: inline-block;
	padding: .15em .55em;
	font-size: .78em;
	font-weight: 600;
	background: var(--od-bg);
	border-radius: 999px;
	color: var(--od-text);
}
.od-pill-warning { background: var(--od-warning-bg); color: #664d03; }

/* Wachtlijst-pills: standaard is alleen 'Zet mij op de wachtlijst' zichtbaar.
   Zodra de bezoeker de optie selecteert, swappen we naar 'U staat nu op de wachtlijst'. */
.od-pill-on-waitlist { display: none; }
.od-slot.od-slot-full:has(input:checked) .od-pill-waitlist,
.od-lecture.od-lecture-full:has(input:checked) .od-pill-waitlist { display: none; }
.od-slot.od-slot-full:has(input:checked) .od-pill-on-waitlist,
.od-lecture.od-lecture-full:has(input:checked) .od-pill-on-waitlist { display: inline-block; }

/* Conditioneel kind/zorgprof-fieldset — sub-blok met inset zodat de inputs
 * niet tegen de rand van de form-section staan. */
.od-conditional-group {
	border: 0;
	padding: .85em 1em;
	margin: 0 0 .85em;
	background: var(--od-bg);
	border-radius: 6px;
}
.od-conditional-group[hidden] { display: none; }

/* ---------- Terms checkbox ---------- */

.od-terms-section {
	background: var(--od-bg);
	border: 1px solid var(--od-border);
	border-radius: 8px;
	padding: .85em 1em;
	margin-top: 1em;
}
.od-terms {
	display: flex;
	align-items: flex-start;
	gap: .65em;
	cursor: pointer;
	font-size: .9em;
	color: var(--od-text);
}
.od-terms input {
	margin-top: .2em;
	accent-color: var(--od-primary);
	width: 16px;
	height: 16px;
}
.od-terms-text { display: inline; }
.od-terms-text p { display: inline; margin: 0; }
.od-terms-text a {
	color: var(--od-primary);
	text-decoration: underline;
}
.od-terms-text a:hover { text-decoration-thickness: 2px; }
.od-required-marker { color: var(--od-danger); font-weight: 600; }

/* ---------- Messages ---------- */

.od-messages { margin: 1em 0 0; }
.od-messages.od-error {
	padding: .85em 1em;
	background: var(--od-danger-bg);
	border: 1px solid #f5c2c7;
	border-radius: 6px;
	color: #58151c;
}
.od-messages.od-error p { margin: .15em 0; }
.od-messages.od-success {
	padding: .85em 1em;
	background: #d1e7dd;
	border: 1px solid #a3cfbb;
	border-radius: 6px;
	color: #0a3622;
}

/* ---------- Edit-form: disabled radio/checkbox-labels ---------- */

.od-radio.od-disabled {
	opacity: .55;
	cursor: not-allowed;
}
.od-radio.od-disabled input {
	cursor: not-allowed;
}

/* ---------- Buttons ---------- */

.od-form-footer { margin-top: 1.5em; display: flex; gap: .65em; flex-wrap: wrap; }
.od-btn {
	display: inline-block;
	padding: .6em 1.4em;
	font-size: 1em;
	font-weight: 500;
	border: 0;
	border-radius: 6px;
	cursor: pointer;
	font-family: inherit;
	transition: background .15s, transform .05s;
	text-decoration: none;
}
.od-btn:active { transform: translateY(1px); }
.od-btn-primary { background: var(--od-primary); color: #fff; }
.od-btn-primary:hover { background: var(--od-primary-hover); color: #fff; }
.od-btn-primary:disabled { opacity: .6; cursor: not-allowed; }
.od-btn-secondary { background: var(--od-bg); color: var(--od-text); border: 1px solid var(--od-border); }
.od-btn-secondary:hover { background: #e9ecef; color: var(--od-text); }
.od-btn-danger { background: var(--od-danger); color: #fff; }
.od-btn-danger:hover { background: #b02a37; color: #fff; }

/* ---------- Success page ---------- */

.od-success-card {
	padding: 2.5em 2em;
	background: #d1e7dd;
	border: 1px solid #a3cfbb;
	border-radius: var(--od-radius);
	text-align: center;
}
.od-success-card h2 { margin: 0 0 .5em; color: #0a3622; font-size: 1.3em; }
.od-success-card p { margin: 0; color: #0a3622; }

/* ---------- Cancel-pagina ---------- */

.od-cancel-heading {
	margin: 1em 0 .5em;
	font-weight: 600;
	color: #343a40;
}
.od-cancel-list {
	list-style: none;
	padding: 0;
	margin: 0 0 1.25em;
}
.od-cancel-list li {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: .75em;
	padding: .75em 1em;
	border: 1px solid var(--od-border);
	border-radius: 6px;
	margin-bottom: .5em;
	background: #fff;
}
.od-cancel-list .od-pill { white-space: nowrap; }

/* ---------- Mobile ---------- */

@media (max-width: 640px) {
	.od-form { padding: 1.25em; }
	.od-form-grid,
	.od-form-grid-3,
	.od-slots,
	.od-lectures-grid { grid-template-columns: 1fr; }
	.od-cancel-list li { flex-direction: column; align-items: flex-start; }
}

/* ------------------------------------------------------------------
 * Item-link (extern) — naast lezing- en workshoptitels
 * ------------------------------------------------------------------ */
.od-item-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-left: .4em;
	width: 1.55em;
	height: 1.55em;
	border: 1px solid var(--od-border);
	border-radius: 6px;
	color: var(--od-muted);
	background: #fff;
	text-decoration: none;
	vertical-align: middle;
	transition: background .12s ease, border-color .12s ease, color .12s ease;
}
.od-item-link:link,
.od-item-link:visited { color: var(--od-muted); }
.od-item-link:hover,
.od-item-link:focus {
	background: var(--od-bg);
	border-color: var(--od-muted);
	color: #495057;
}
.od-item-link-icon { display: block; }
.od-item-link-note {
	display: inline-block;
	margin-left: .35em;
	font-size: .6em;
	font-weight: 400;
	color: var(--od-muted);
	vertical-align: middle;
	white-space: nowrap;
}
.od-recaptcha-section { display: flex; justify-content: flex-start; }
.od-recaptcha-section .g-recaptcha { transform-origin: 0 0; }
