/* Boerderij Jonker Booking — styling
 * Past bij de rustige, landelijke uitstraling van boerderijjonker.nl.
 * Aardse groen/bruin tinten, serif kopjes, ruime witruimte.
 */

.bj-form {
	--bj-primary: #7ba045;
	--bj-primary-dark: #5f8235;
	--bj-text: #2d2a26;
	--bj-muted: #6b665e;
	--bj-border: #d8d2c4;
	--bj-bg: #ffffff;
	--bj-bg-soft: #fbf8f1;
	--bj-error: #b3261e;
	--bj-success: #2f6a23;
	--bj-radius: 6px;

	box-sizing: border-box;
	max-width: 100%;
	color: var(--bj-text);
	font-family: inherit;
	font-size: 16px;
	line-height: 1.5;
	background: var(--bj-bg);
}
.bj-form *,
.bj-form *::before,
.bj-form *::after { box-sizing: border-box; }

.bj-form__title {
	font-family: Georgia, "Times New Roman", serif;
	font-weight: 400;
	font-size: 1.5rem;
	text-align: center;
	margin: 0 0 1rem;
	color: var(--bj-text);
}

.bj-form h2 {
	font-family: Georgia, "Times New Roman", serif;
	font-weight: 400;
	font-size: 1.25rem;
	margin: 0 0 0.75rem;
	color: var(--bj-text);
	border-bottom: 1px solid var(--bj-border);
	padding-bottom: 0.4rem;
}

.bj-section { margin-bottom: 1.75rem; }

/* Verticale ruimte tussen opeenvolgende blokken binnen een sectie */
.bj-section > * + *,
.bj-kampeer > * + * { margin-top: 1rem; }

.bj-row {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	gap: 0.9rem 1rem;
	align-items: end;
}

.bj-field { display: flex; flex-direction: column; min-width: 0; }
.bj-field--small { max-width: 160px; }
.bj-field--grow  { flex: 1 1 auto; }

/* In a default 12-col .bj-row, fields without an explicit col span full width
 * so unclassed rows stay readable. .bj-row--compact uses its own grid template
 * and is unaffected. */
.bj-row:not(.bj-row--compact) > .bj-field { grid-column: 1 / -1; }
.bj-row:not(.bj-row--compact) > .bj-col-2  { grid-column: span 2; }
.bj-row:not(.bj-row--compact) > .bj-col-3  { grid-column: span 3; }
.bj-row:not(.bj-row--compact) > .bj-col-4  { grid-column: span 4; }
.bj-row:not(.bj-row--compact) > .bj-col-5  { grid-column: span 5; }
.bj-row:not(.bj-row--compact) > .bj-col-6  { grid-column: span 6; }
.bj-row:not(.bj-row--compact) > .bj-col-7  { grid-column: span 7; }
.bj-row:not(.bj-row--compact) > .bj-col-8  { grid-column: span 8; }
.bj-row:not(.bj-row--compact) > .bj-col-9  { grid-column: span 9; }
.bj-row:not(.bj-row--compact) > .bj-col-10 { grid-column: span 10; }
.bj-row:not(.bj-row--compact) > .bj-col-12 { grid-column: 1 / -1; }

/* On smaller screens collapse all spanned fields to full width */
@media (max-width: 720px) {
	.bj-row:not(.bj-row--compact) > .bj-field { grid-column: 1 / -1; }
	.bj-field--small { max-width: none; }
}

.bj-field label,
.bj-field .bj-label {
	font-size: 0.9rem;
	color: var(--bj-muted);
	margin-bottom: 0.35rem;
	font-weight: 500;
}

.bj-req { color: var(--bj-error); margin-left: 2px; }

.bj-form input[type="text"],
.bj-form input[type="email"],
.bj-form input[type="tel"],
.bj-form input[type="number"],
.bj-form input[type="date"],
.bj-form select,
.bj-form textarea {
	width: 100%;
	padding: 0.6rem 0.75rem;
	border: 1px solid var(--bj-border);
	border-radius: var(--bj-radius);
	background: var(--bj-bg);
	color: var(--bj-text);
	font: inherit;
	line-height: 1.3;
	transition: border-color .15s ease, box-shadow .15s ease;
}
.bj-form input:focus,
.bj-form select:focus,
.bj-form textarea:focus {
	outline: none;
	border-color: var(--bj-primary);
	box-shadow: 0 0 0 3px rgba(123,160,69,0.18);
}
.bj-form textarea { resize: vertical; min-height: 100px; }

.bj-checks {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
	background: var(--bj-bg-soft);
	border: 1px solid var(--bj-border);
	border-radius: var(--bj-radius);
	padding: 0.7rem 0.9rem;
}
.bj-check {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.95rem;
	color: var(--bj-text);
	margin: 0;
	font-weight: 400;
	cursor: pointer;
}
.bj-check input { width: auto; }

.bj-svr-nr { margin-top: 0.6rem; max-width: 280px; }

.bj-actions {
	display: flex;
	justify-content: flex-end;
	margin-top: 1rem;
}

.bj-btn {
	display: inline-block;
	padding: 0.7rem 1.5rem;
	background: var(--bj-primary);
	color: #fff;
	font: inherit;
	font-weight: 600;
	border: none;
	border-radius: var(--bj-radius);
	cursor: pointer;
	transition: background .15s ease, transform .05s ease;
}
.bj-btn:hover   { background: var(--bj-primary-dark); }
.bj-btn:active  { transform: translateY(1px); }
.bj-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.bj-btn--primary { padding: 0.85rem 1.75rem; font-size: 1rem; }

/* Honeypot */
.bj-hp {
	position: absolute;
	left: -10000px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* Status / feedback */
.bj-status {
	padding: 0.9rem 1rem;
	border-radius: var(--bj-radius);
	margin-bottom: 1rem;
	font-weight: 500;
}
.bj-status--error   { background: #fdecea; color: var(--bj-error); border: 1px solid #f5c2bf; }
.bj-status--success { background: #eaf4e6; color: var(--bj-success); border: 1px solid #c3e0b6; }

/* Compact (homepage) variant */
.bj-form--compact {
	background: var(--bj-bg);
	border: 1px solid var(--bj-border);
	border-radius: 10px;
	padding: 1.5rem 1.75rem;
	box-shadow: 0 6px 24px rgba(0,0,0,0.12);
	max-width: 760px;
	margin: 0 auto;
	position: relative;
	z-index: 2;
}

/* De Elementor-widget om het compacte formulier krijgt standaard 45vh
 * top margin (was bedoeld voor het oude, hogere formulier). Overschrijven
 * zodat het formulier mooi over de drone-video drijft op zowel desktop
 * als mobiel. Doel: formulier overlapt de video, met onderrand net onder
 * de video zodat de witte sectie + "Welkom bij Boerderij Jonker" titel
 * zichtbaar blijft (zie referentie). */
.elementor .elementor-widget-container:has(> .bj-form--compact) {
	margin-top: 42vh !important;
}
@media (min-width: 1600px) {
	.elementor .elementor-widget-container:has(> .bj-form--compact) {
		margin-top: 51vh !important;
	}
}
@media (max-width: 1024px) {
	.elementor .elementor-widget-container:has(> .bj-form--compact) {
		margin-top: 15vh !important;
	}
}
@media (max-width: 720px) {
	.elementor .elementor-widget-container:has(> .bj-form--compact) {
		margin-top: 16vh !important;
	}
}
.bj-row--compact {
	grid-template-columns: 1.2fr 1fr 1fr auto;
	align-items: end;
}
.bj-field--submit { align-self: end; }
.bj-form--compact .bj-btn { white-space: nowrap; }

/* Responsive */
@media (max-width: 720px) {
	.bj-row--compact { grid-template-columns: 1fr; }
	.bj-form--compact { padding: 1.25rem; }
	.bj-actions { justify-content: stretch; }
	.bj-actions .bj-btn { width: 100%; }
}
