/* meinGarten Terminbuchung – Frontend-Widget (2-Schritt-Wizard) */
.tvr-widget {
	--tvr-accent: #1F3328;   /* Dunkelgrün */
	--tvr-dark:   #17251D;
	--tvr-sage:   #98B9A4;
	--tvr-cream:  #F6F1E8;
	--tvr-text:   #1B1D18;
	--tvr-muted:  #6D746B;
	--tvr-line:   #E6E0D4;
	max-width: 1140px;
	margin: 0 auto;
	font-family: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	color: var(--tvr-text);
	background: #fff;
	border: 1px solid var(--tvr-line);
	border-radius: 5px;
	padding: 20px 25px;
	box-shadow: 0 10px 34px rgba(31, 51, 40, .07);
	box-sizing: border-box;
}
.tvr-widget *, .tvr-widget *::before, .tvr-widget *::after { box-sizing: border-box; }
.tvr-widget [hidden] { display: none !important; }

/* Alle Schritte gleich hoch -> die Box springt beim Wechsel nicht (feste Höhe). */
.tvr-step { min-height: 572px; }
/* Schritt 1 (Datum/Uhrzeit) folgt dem Inhalt -> kein toter Leerraum unten. */
.tvr-step-when { display: flex; flex-direction: column; min-height: 0; padding-bottom: 9px; }
/* "Weiter" sitzt unten in der rechten Spalte -> Spalten gleich hoch, Kalender füllt links bis unten. */
.tvr-step-when .tvr-nav { margin-top: auto; }
/* Schritt-1-Überschriften vertikal mittig zwischen Formular-Oberkante und Kalender/Uhrzeit-Oberkante (30px oben = 30px unten). */
.tvr-step-when .tvr-pane-title { margin-top: 9px; margin-bottom: 30px; }
.tvr-success { display: flex; flex-direction: column; justify-content: center; }

/* Step titles */
.tvr-pane-title {
	display: flex; align-items: center; gap: 9px;
	font-size: 19px; font-weight: 700; color: var(--tvr-text);
	margin: 0 0 12px;
}
.tvr-step-no {
	display: inline-flex; align-items: center; justify-content: center;
	width: 23px; height: 23px; border-radius: 50%;
	background: var(--tvr-sage); color: #fff; font-size: 12px; font-weight: 800;
}

/* When-area: calendar + times */
.tvr-when {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 56px;
	align-items: stretch;
}
.tvr-pane-times { min-width: 0; min-height: 360px; display: flex; flex-direction: column; }
.tvr-cal-input { display: none; }
/* Platz für den Kalender reservieren, damit flatpickr beim Mount nichts verschiebt (kein CLS). */
.tvr-cal-mount { min-height: 360px; }

/* Times */
/* Gleich breite Zeit-Buttons: Grid mit gleich großen Spalten (keine breiteren in der letzten Reihe). */
.tvr-times { display: grid; grid-template-columns: repeat(auto-fill, minmax(96px, 1fr)); gap: 9px; align-content: flex-start; }
.tvr-times-msg { grid-column: 1 / -1; color: var(--tvr-muted); font-size: 14px; margin: 4px 0; }
.tvr-widget .tvr-slot {
	appearance: none; -webkit-appearance: none;
	border: 1px solid var(--tvr-line);
	background: #fff;
	color: var(--tvr-text);
	border-radius: 5px;
	padding: 11px 4px;
	font-size: 15px; font-weight: 600; font-family: inherit;
	cursor: pointer;
	text-align: center;
	transition: border-color .12s, background .12s, color .12s, transform .05s;
}
.tvr-widget .tvr-slot:hover,
.tvr-widget .tvr-slot:focus-visible {
	border-color: var(--tvr-sage); background: #eef3ef; color: var(--tvr-accent); outline: none;
}
.tvr-widget .tvr-slot:active { transform: scale(.97); }
.tvr-widget .tvr-slot.selected,
.tvr-widget .tvr-slot.selected:hover,
.tvr-widget .tvr-slot.selected:focus-visible {
	background: var(--tvr-accent); border-color: var(--tvr-accent); color: #fff;
}

/* Chosen summary banner (Schritt 2) */
.tvr-chosen {
	display: flex; align-items: center; gap: 15px;
	background: #eef3ef; border: 1px solid #d8e3da;
	border-radius: 5px; padding: 12px 14px; margin: 0 0 20px;
	font-size: 15px; font-weight: 700; color: var(--tvr-accent);
}
.tvr-chosen-ico { display: inline-flex; align-items: center; line-height: 0; color: var(--tvr-accent); }
.tvr-chosen-ico svg { display: block; width: 18px; height: 18px; }

/* Buttons */
.tvr-widget .tvr-btn {
	display: inline-block;
	background: var(--tvr-accent); color: #fff;
	border: 0; border-radius: 5px;
	padding: 14px 26px;
	font-size: 16px; font-weight: 700; font-family: inherit;
	cursor: pointer; text-decoration: none;
	transition: background .15s, opacity .15s, transform .05s;
}
.tvr-widget .tvr-btn:hover { background: var(--tvr-dark); color: #fff; }
.tvr-widget .tvr-btn:active { transform: scale(.99); }
.tvr-widget .tvr-btn:disabled { opacity: .45; cursor: default; }
.tvr-submit { width: 100%; margin-top: 4px; }
.tvr-next { min-width: 160px; }
.tvr-nav { display: flex; justify-content: flex-end; margin-top: 22px; }

.tvr-widget .tvr-back {
	display: inline-flex; align-items: center; gap: 5px;
	border: 0; background: none; padding: 4px 2px; margin: 0 0 16px;
	color: var(--tvr-accent); font-family: inherit; font-size: 14px; font-weight: 700;
	cursor: pointer;
}
.tvr-widget .tvr-back:hover { color: var(--tvr-dark); text-decoration: underline; }

/* Contact fields */
.tvr-form { margin: 0; }
.tvr-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.tvr-field { display: block; }
.tvr-col-2 { grid-column: 1 / -1; }
.tvr-label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 6px; color: #3a3f37; }
.tvr-widget .tvr-input {
	width: 100%;
	padding: 12px 13px;
	border: 1px solid #d9d6cd;
	border-radius: 5px;
	font-size: 15px; font-family: inherit;
	background: #fff; color: var(--tvr-text);
	transition: border-color .15s, box-shadow .15s;
}
.tvr-widget .tvr-input:focus { outline: none; border-color: var(--tvr-accent); box-shadow: 0 0 0 3px rgba(31, 51, 40, .14); }
.tvr-widget textarea.tvr-input { resize: vertical; }
/* Auswahlfeld wie die Text-Inputs, eigener Chevron in Markenfarbe. */
.tvr-widget select.tvr-select {
	appearance: none; -webkit-appearance: none;
	cursor: pointer;
	padding-right: 34px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231F3328' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
	background-size: 13px;
}
.tvr-widget select.tvr-select:invalid { color: var(--tvr-muted); }

.tvr-consent {
	display: flex; align-items: flex-start; gap: 10px;
	font-size: 13.5px; color: #4a4f46; line-height: 1.45;
	margin: 16px 0 18px;
}
.tvr-consent input { margin-top: 2px; width: 17px; height: 17px; accent-color: var(--tvr-accent); flex: 0 0 auto; }
.tvr-widget .tvr-consent a { color: var(--tvr-accent); text-decoration: underline; font-weight: 600; }
.tvr-widget .tvr-consent a:hover { color: var(--tvr-dark); }
.tvr-hp { position: absolute; left: -9999px; height: 0; overflow: hidden; }

.tvr-msg { margin-top: 12px; font-size: 14px; color: #c0392b; text-align: center; }
.tvr-recaptcha-note { margin: 14px 0 0; font-size: 11.5px; line-height: 1.5; color: var(--tvr-muted); text-align: center; }
.tvr-widget .tvr-recaptcha-note a { color: var(--tvr-muted); text-decoration: underline; }
.tvr-widget .tvr-recaptcha-note a:hover { color: var(--tvr-accent); }
/* Schwebendes reCAPTCHA-Badge ausblenden – der Pflicht-Hinweis steht stattdessen im Formular. */
.grecaptcha-badge { visibility: hidden !important; }

/* Success */
.tvr-success { text-align: center; padding: 30px 18px; }
.tvr-success-icon {
	width: 60px; height: 60px; line-height: 60px;
	margin: 0 auto 14px; border-radius: 50%;
	background: var(--tvr-accent); color: #fff; font-size: 32px;
}
.tvr-success-title { margin: 0 0 8px; font-size: 22px; color: var(--tvr-text); }
.tvr-success-text { margin: 0 auto 16px; max-width: 460px; color: #4a4f46; font-size: 15px; line-height: 1.55; }
.tvr-calendar-buttons { margin-bottom: 18px; }
.tvr-widget .tvr-cal-btn {
	display: inline-block; margin: 4px;
	padding: 9px 15px; background: #fff;
	border: 1px solid var(--tvr-line); border-radius: 5px;
	color: var(--tvr-text); text-decoration: none; font-size: 13px; font-weight: 600;
}
.tvr-widget .tvr-cal-btn:hover { border-color: var(--tvr-sage); background: #eef3ef; color: var(--tvr-accent); }
.tvr-widget .tvr-restart {
	background: none; border: 0; color: var(--tvr-accent); cursor: pointer;
	font-size: 14px; font-weight: 700; font-family: inherit; text-decoration: underline;
}
.tvr-widget .tvr-restart:hover { color: var(--tvr-dark); }

/* ---- flatpickr inline, brand-themed, touch-friendly ---- */
.tvr-widget .flatpickr-calendar.inline {
	box-shadow: none;
	border: 1px solid var(--tvr-line);
	border-radius: 5px;
	padding: 6px 8px 10px;
	margin: 0;
	top: 0; /* flatpickr setzt inline top:2px -> Unterkante bündig mit dem "Weiter"-Button */
	width: 100%;
	max-width: none;
	font-family: inherit;
}
.tvr-widget .flatpickr-months { padding-top: 4px; position: relative; }
/* Monat/Jahr linksbündig zu den Datums-Spalten; beide Pfeile nach rechts. */
.tvr-widget .flatpickr-current-month { left: 8px; width: auto; padding: 7px 0 0; text-align: left; }
.tvr-widget .flatpickr-prev-month { left: auto; right: 34px; }
.tvr-widget .flatpickr-next-month { left: auto; right: 6px; }
.tvr-widget .flatpickr-month { color: var(--tvr-accent); }
.tvr-widget .flatpickr-current-month .cur-month,
.tvr-widget .flatpickr-current-month .numInputWrapper { font-weight: 800; color: var(--tvr-accent); }
.tvr-widget .flatpickr-weekday { color: var(--tvr-muted); font-weight: 700; font-size: 78%; }
.tvr-widget .flatpickr-prev-month svg, .tvr-widget .flatpickr-next-month svg { fill: var(--tvr-accent); }
.tvr-widget .flatpickr-prev-month:hover svg, .tvr-widget .flatpickr-next-month:hover svg { fill: var(--tvr-sage); }
.tvr-widget .flatpickr-days, .tvr-widget .dayContainer { width: 100%; min-width: 0; max-width: none; }
.tvr-widget .flatpickr-day {
	max-width: none; height: 56px; line-height: 55px;
	border-radius: 5px; color: var(--tvr-text); font-weight: 600;
}
.tvr-widget .flatpickr-day:hover { background: #eef3ef; border-color: #eef3ef; color: var(--tvr-accent); }
.tvr-widget .flatpickr-day.today { border-color: var(--tvr-sage); }
.tvr-widget .flatpickr-day.selected,
.tvr-widget .flatpickr-day.selected:hover {
	background: var(--tvr-accent); border-color: var(--tvr-accent); color: #fff;
}
.tvr-widget .flatpickr-day.flatpickr-disabled,
.tvr-widget .flatpickr-day.flatpickr-disabled:hover,
.tvr-widget .flatpickr-day.prevMonthDay, .tvr-widget .flatpickr-day.nextMonthDay {
	color: #c7c3b8; background: transparent; border-color: transparent;
}
.tvr-widget .flatpickr-day.flatpickr-disabled { text-decoration: line-through; }

/* ---- Responsive: Tablet-Portrait + Mobile (gestapelt) ---- */
@media (max-width: 820px) {
	.tvr-widget { padding: 18px; border-radius: 5px; }
	.tvr-step { min-height: 0; } /* mobil content-getrieben (kein erzwungener Leerraum) */
	.tvr-step-when .tvr-nav { margin-top: 22px; }
	.tvr-when { grid-template-columns: 1fr; gap: 20px; }
	.tvr-pane { display: flex; flex-direction: column; }
	.tvr-cal-mount { display: flex; justify-content: center; min-height: 348px; }
	.tvr-pane-times { min-height: 132px; }
	.tvr-grid { grid-template-columns: 1fr 1fr; }
	.tvr-nav { justify-content: stretch; }
	.tvr-next { width: 100%; }
}
@media (max-width: 520px) {
	.tvr-widget { padding: 14px; }
	.tvr-grid { grid-template-columns: 1fr; }
	.tvr-times { grid-template-columns: repeat(auto-fill, minmax(84px, 1fr)); }
	/* Termin-Banner: Uhrzeit komplett in die zweite Zeile. */
	.tvr-chosen { align-items: flex-start; }
	.tvr-chosen-time { display: block; }
	/* "Ihr Anliegen": hoch genug für den ganzen Platzhaltertext (~4 Zeilen). */
	.tvr-widget textarea.tvr-input { min-height: 116px; }
}
