/**
 * Kaus Booking — Plugin-spezifische Frontend-Styles.
 *
 * Das Markup nutzt die Theme-Klassen (.booking-section, .booking-steps,
 * .calendar-wrap, .cal-grid, .timeslot, .booking-form). Diese Datei ergänzt
 * nur das, was das Theme nicht abdeckt:
 *   - Versteckte Schritte
 *   - Loading-/Fehler-/Success-Status
 *   - Prepare-Link
 *   - Plugin-eigene Inputs (placeholder-Style auf Theme-Niveau)
 */

.kausb-form { width: 100%; }

.kausb-step[hidden] { display: none !important; }

/* ─── Tag-Kacheln: zukünftige ohne Slots gleich grau wie leere ─────── */
.kausb-form .cal-grid__day:disabled,
.kausb-form .cal-grid__day.is-empty:not(.is-selected) {
	color: #ccc;
	cursor: not-allowed;
	background: transparent;
}

/* ─── Slot-Spalte: kompakte Action-Zone unter den Slots ─────────────── */
.kausb-form .kausb-slots-col .booking-selected {
	margin-top: 12px;
}
.kausb-form .kausb-slots-col .calendar__actions {
	margin-top: 12px;
}

/* ─── Slot-Loading ─────────────────────────────────────────────────── */
.kausb-loading,
.kausb-no-slots {
	color: var(--c-gray, #666);
	font-size: 0.85rem;
	font-style: italic;
	grid-column: 1 / -1;
	margin: 0;
	padding: 0.5rem 0;
}

/* ─── Prepare-Link (Schritt 2) ─────────────────────────────────────── */
.kausb-prepare-link {
	margin: 12px 0 16px;
	font-size: 0.875rem;
}
.kausb-prepare-link a {
	color: var(--c-green, #89b402);
	font-weight: 500;
	text-decoration: none;
}
.kausb-prepare-link a:hover {
	text-decoration: underline;
}

/* ─── Fehler-Box ───────────────────────────────────────────────────── */
.kausb-error-box {
	background: rgba(192, 57, 43, 0.08);
	border: 1px solid rgba(192, 57, 43, 0.4);
	color: #a32621;
	border-radius: var(--r-btn, 8px);
	padding: 12px 16px;
	margin: 12px 0;
	font-size: 0.875rem;
}
.kausb-error-box ul {
	margin: 0;
	padding: 0 0 0 1.25rem;
}

/* ─── Erfolg ───────────────────────────────────────────────────────── */
.kausb-success {
	text-align: center;
	padding: 1rem 0;
}
.kausb-success-icon {
	color: var(--c-green, #89b402);
	margin-bottom: 0.5rem;
}
.kausb-success h2 {
	margin: 0 0 0.5rem;
	color: var(--c-green, #89b402);
}
.kausb-success-step .booking-form__summary {
	max-width: 420px;
	margin: 1rem auto;
	text-align: left;
}

/* ─── Zurück-Button (Schritt 2) ────────────────────────────────────── */
.kausb-back-btn {
	width: 100%;
	margin-top: 8px;
}

.kausb-phone-group {
	display: flex;
	gap: 8px;
}
.kausb-phone-group select {
	flex: 0 0 auto;
	width: auto;
	padding: 8px 10px;
	border: 1px solid var(--c-purple-light, #d5d7e7);
	border-radius: var(--r-btn, 8px);
	background: #fff;
	font-family: inherit;
	font-size: inherit;
}
.kausb-phone-group input[type="tel"] {
	flex: 1 1 auto;
}
.kausb-manage-actions {
	display: flex;
	gap: 12px;
	margin: 20px 0 0;
	flex-wrap: wrap;
}
.kausb-manage-panel {
	margin-top: 24px;
	padding-top: 20px;
	border-top: 1px solid var(--c-purple-light, #e7e8f3);
}
.kausb-manage-panel h3,
.kausb-manage-panel h4 {
	margin-top: 0;
}
.kausb-manage-confirm-actions {
	display: flex;
	gap: 12px;
	margin-top: 16px;
	flex-wrap: wrap;
}
.kausb-manage-panel textarea {
	width: 100%;
	padding: 8px 12px;
	border: 1px solid var(--c-purple-light, #d5d7e7);
	border-radius: var(--r-btn, 8px);
	font-family: inherit;
	box-sizing: border-box;
}

@media (max-width: 767px) {
	.kausb-form .kausb-manage-actions,
	.kausb-form .kausb-manage-confirm-actions {
		flex-direction: column;
	}
	.kausb-form .kausb-manage-actions .btn,
	.kausb-form .kausb-manage-confirm-actions .btn {
		width: 100%;
	}
	.kausb-form .booking-steps {
		gap: 4px;
	}
	.kausb-form .booking-step__num {
		width: 32px;
		height: 32px;
		font-size: 1rem;
	}
	.kausb-form .booking-step__line {
		width: 16px;
	}
	.kausb-form .booking-form__row {
		grid-template-columns: 1fr;
	}
	.kausb-form .calendar-wrap,
	.kausb-form .booking-form {
		padding: 16px;
	}
}

/* Pflichtfeld-Hinweis am Formular-Anfang (A11y: erklärt was * bedeutet) */
.booking-form__required-hint {
	font-size: 0.85rem;
	color: #555;
	margin: 0 0 16px;
}
.booking-form__required-hint span[aria-hidden] {
	color: #c0392b;
	font-weight: 700;
}
/* Fehlerbox erhält Fokus per JS — Fokus-Ring sichtbar machen */
.kausb-error-box:focus {
	outline: 3px solid #c0392b;
	outline-offset: 2px;
}

/* Hinweis-Box im Online-Modus: erscheint wenn KEINE Online-Slots
   im sichtbaren Monat freigegeben sind. JS blendet die Box wieder
   aus sobald freie Slots gefunden werden. */
.kausb-online-notice {
	background: #fff8e1;
	border-left: 4px solid #f5a623;
	border-radius: 4px;
	padding: 14px 18px;
	margin: 0 0 20px;
	font-size: .9375rem;
	color: #6d4c00;
}
.kausb-online-notice[hidden] { display: none; }

/* Online-Badge: kleines Pillchen-Label das in Auswahl, Summary und
   Erfolgs-Anzeige darauf hinweist dass es eine Online-Sprechstunde
   ist. Dezent, nicht aufdringlich. */
.kausb-online-badge {
	display: inline-block;
	vertical-align: baseline;
	margin-left: 6px;
	padding: 2px 9px;
	font-size: .75rem;
	font-weight: 600;
	line-height: 1.4;
	color: #4a4f8a;
	background: rgba(126, 131, 188, 0.15);
	border: 1px solid rgba(126, 131, 188, 0.4);
	border-radius: 999px;
	letter-spacing: .01em;
	white-space: nowrap;
}
.kausb-online-hint {
	display: inline-block;
	margin-top: 4px;
	font-size: .8125rem;
	color: #4a4f8a;
	font-style: italic;
}

/* Sprach-Hinweis im Stil der Absage-Regelung. Hintergrund (grün) zieht
   sich über die volle Browserbreite, der Inhalt ist auf 900px begrenzt
   und zentriert — exakt unter dem Kalender. */
.kausb-language-notice {
	background: var(--c-green-light, #f4f8e3);
	color: var(--c-black, #000);
	margin: 32px 0 0;
	padding: 28px 0 16px;
	font-size: .9375rem;
	line-height: 1.6;
	/* Über die volle Browserbreite ausdehnen — bricht aus einem
	   eventuell begrenzten Eltern-Container aus. */
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
}
.kausb-language-notice__inner {
	position: relative;
	max-width: 900px;
	margin: 0 auto;
	padding: 0;
	box-sizing: border-box;
}
/* Mobile: Inhalt vom Bildschirmrand wegrücken damit's mit dem
   Theme-Container (Kalender, Step-Pills, etc.) in einer Flucht steht.
   Das Theme nutzt 20px Seitenabstand auf kleinen Viewports. */
@media (max-width: 940px) {
	.kausb-language-notice__inner {
		padding-left: 20px;
		padding-right: 20px;
	}
	.kausb-language-notice__inner::before {
		left: 20px;
	}
}
.kausb-language-notice__inner::before {
	content: "i";
	position: absolute;
	top: -44px;
	left: 0;
	width: 36px;
	height: 36px;
	background: var(--c-green, #a3c44e);
	color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	/* KEIN font-family/font-style override — das Theme-Font (sans, fett)
	   soll greifen, damit's wie die anderen i-Bubbles auf der Seite aussieht. */
	font-weight: 700;
	font-size: 1.125rem;
}
.kausb-language-notice strong { color: var(--c-black, #000); }

/* Wartungs-Modus: wird angezeigt wenn Buchungen pausiert sind. Dezenter
   gelblicher Kasten mit Info-Icon links. */
.kausb-paused-notice {
	display: flex;
	gap: 16px;
	align-items: flex-start;
	padding: 24px 28px;
	background: #fff8e1;
	border-left: 4px solid #f5a623;
	border-radius: 6px;
	color: #6d4c00;
	font-size: 1rem;
	line-height: 1.6;
}
.kausb-paused-notice__icon {
	flex: 0 0 auto;
	width: 32px;
	height: 32px;
	color: #b78313;
	margin-top: 2px;
}
.kausb-paused-notice p {
	margin: 0;
}
