/**
 * Lepilation Booking – Frontend styles (Elementor-safe overrides).
 *
 * @package Lepilation_Booking
 */

/* —— Font stack (Elementor overrides) —— */
.lepb-wrapper,
.lepb-wrapper *,
.lepb-wrapper input,
.lepb-wrapper select,
.lepb-wrapper textarea,
.lepb-wrapper button,
.lepb-wrapper label {
	font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji" !important;
}

.lepb-heading,
.lepb-subheading,
.lepb-step-circle,
.lepb-package-head,
.lepb-details-sum,
.lepb-cal-month,
.lepb-choice-name {
	font-family: "Playfair Display", Georgia, serif !important;
}

/* —— Design tokens —— */
.lepb-wrapper {
	--lep-accent: #e9bcb9;
	--lep-accent-hover: #d4a49f;
	--lep-accent-light: rgba(233, 188, 185, 0.08);
	--lep-text-dark: #2a2a2a;
	--lep-text-body: #707475;
	--lep-text-light: #999;
	--lep-border: #d5d5d5;
	--lep-border-light: #f0eeee;
	--lep-border-section: #e5e5e5;
	--lep-bg-white: #fff;
	--lep-bg-off: #faf8f7;
	--lep-bg-section: #f8f8f8;
	--lep-error: #e74c3c;
	--lep-success: #27ae60;
}

.lepb-wrapper {
	max-width: 780px;
	margin: 0 auto;
	padding: 48px 24px;
	color: var(--lep-text-body);
	font-size: 15px;
	line-height: 1.6;
	text-align: center;
}

.lepb-heading {
	font-weight: 400 !important;
	font-size: clamp(24px, 3.5vw, 32px) !important;
	color: var(--lep-text-dark) !important;
	margin: 0 0 10px 0 !important;
	text-align: center !important;
	line-height: 1.2 !important;
}

/* Step overline (“Schritt X”) */
.lepb-step-overline,
.lepb-step-panel > p:first-child.lepb-step-overline {
	font-family: ui-sans-serif, system-ui, sans-serif !important;
	font-size: 11px !important;
	font-weight: 500 !important;
	text-transform: uppercase !important;
	letter-spacing: 3px !important;
	color: var(--lep-accent) !important;
	margin: 0 0 8px !important;
	text-align: center !important;
}

.lepb-step-panel p:first-child + p,
.lepb-step2-intro,
.lepb-step-overline-text {
	font-size: 14px;
	color: var(--lep-text-body);
	margin-bottom: 24px;
	text-align: center;
}

.lepb-stepper {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	margin: 0 auto 48px auto;
	max-width: 640px;
	position: relative;
}

.lepb-step {
	flex: 1;
	text-align: center;
	font-size: 10px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	color: var(--lep-text-light);
	position: relative;
}

.lepb-step:not(:last-child)::after {
	content: "";
	position: absolute;
	top: 21px;
	left: calc(50% + 21px);
	width: calc(100% - 42px);
	height: 1px;
	background: var(--lep-border);
	z-index: 0;
}

.lepb-step.lepb-step--completed:not(:last-child)::after {
	background: var(--lep-accent);
}

.lepb-step-circle {
	width: 42px !important;
	height: 42px !important;
	border-radius: 50% !important;
	border: 1.5px solid var(--lep-border) !important;
	margin: 0 auto 8px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	font-size: 15px !important;
	font-weight: 400 !important;
	color: var(--lep-text-light) !important;
	background: var(--lep-bg-white) !important;
	position: relative;
	z-index: 2;
	transition: all 0.3s ease;
}

.lepb-step-circle--active,
.lepb-step-circle--done {
	background-color: var(--lep-accent) !important;
	border-color: var(--lep-accent) !important;
	color: #fff !important;
}

.lepb-step > div:last-child {
	margin-top: 4px;
}

/* —— Schritt 1: Kacheln —— */
.lepb-choice-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px;
	margin: 0 auto 32px auto;
	max-width: 600px;
}

.lepb-choice-grid--gender,
.lepb-choice-grid--2 {
	grid-template-columns: repeat(2, 1fr);
	max-width: 400px;
}

.lepb-choice-grid--gender .lepb-choice-card,
.lepb-choice-grid--2 .lepb-choice-card {
	padding: 24px 20px !important;
}

.lepb-choice-card {
	background: var(--lep-bg-off) !important;
	border: 1.5px solid var(--lep-border-section) !important;
	border-radius: 8px !important;
	padding: 32px 24px !important;
	text-align: center !important;
	cursor: pointer;
	transition: all 0.3s ease;
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	gap: 10px !important;
	font: inherit !important;
	color: inherit !important;
	width: 100%;
	box-sizing: border-box !important;
}

.lepb-choice-card:hover {
	border-color: var(--lep-accent) !important;
	box-shadow: 0 4px 20px rgba(233, 188, 185, 0.12);
	transform: translateY(-2px);
}

.lepb-choice-card--selected {
	border-color: var(--lep-accent) !important;
	background: var(--lep-bg-white) !important;
	box-shadow: 0 0 0 2px var(--lep-accent) !important;
}

.lepb-choice-card svg,
.lepb-choice-card .lepb-choice-icon {
	width: 36px !important;
	height: 36px !important;
	color: var(--lep-accent) !important;
	stroke: var(--lep-accent) !important;
	margin-bottom: 4px;
}

.lepb-choice-name {
	font-size: 18px !important;
	font-weight: 400 !important;
	color: var(--lep-text-dark) !important;
	display: block !important;
}

.lepb-choice-desc {
	font-size: 13px !important;
	font-weight: 300 !important;
	color: var(--lep-text-body) !important;
	line-height: 1.5 !important;
	display: block !important;
}

.lepb-form-field {
	margin-bottom: 20px !important;
}

.lepb-form-field .lepb-label {
	display: block !important;
	margin-bottom: 8px !important;
	font-size: 13px !important;
	font-weight: 500 !important;
	color: var(--lep-text-dark) !important;
	text-align: center;
}

.lepb-form-field label {
	display: block !important;
	margin-bottom: 6px !important;
	font-size: 13px !important;
	font-weight: 500 !important;
	color: var(--lep-text-dark) !important;
}

.lepb-input,
.lepb-select,
.lepb-textarea {
	width: 100% !important;
	background-color: var(--lep-bg-white) !important;
	border: 1px solid var(--lep-border) !important;
	border-radius: 8px !important;
	padding: 14px 16px !important;
	font-size: 16px !important;
	color: #333 !important;
	transition: border-color 0.3s ease !important;
	box-shadow: none !important;
	outline: none !important;
	-webkit-appearance: none !important;
	appearance: none !important;
	box-sizing: border-box !important;
}

.lepb-input:focus,
.lepb-select:focus,
.lepb-textarea:focus {
	border-color: var(--lep-accent) !important;
	box-shadow: none !important;
	outline: none !important;
}

.lepb-input::placeholder,
.lepb-textarea::placeholder {
	color: #aaa !important;
	font-weight: 300 !important;
}

.lepb-textarea {
	min-height: 120px !important;
	resize: vertical !important;
}

.lepb-input--error {
	border-color: var(--lep-error) !important;
}

.lepb-field-error {
	font-size: 12px;
	color: var(--lep-error);
	margin-top: 4px;
}

/* —— Schritt 3 —— */
.lepb-step-panel[data-step="3"] {
	max-width: 560px !important;
	margin: 0 auto !important;
	text-align: left !important;
}

.lepb-contact-names {
	display: block;
}

@media (min-width: 768px) {
	.lepb-contact-names {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 0 20px;
		align-items: start;
	}

	.lepb-contact-names .lepb-form-field {
		margin-bottom: 20px !important;
	}
}

.lepb-primary-btn {
	background-color: var(--lep-accent) !important;
	color: #fff !important;
	border: 1px solid var(--lep-accent) !important;
	border-radius: 0 !important;
	font-size: 11px !important;
	font-weight: 600 !important;
	letter-spacing: 2px !important;
	text-transform: uppercase !important;
	padding: 14px 32px !important;
	cursor: pointer !important;
	transition: all 0.3s ease !important;
	line-height: normal !important;
	background-image: none !important;
}

.lepb-primary-btn:hover {
	background-color: transparent !important;
	color: var(--lep-accent) !important;
	border-color: var(--lep-accent) !important;
}

.lepb-secondary-btn {
	background-color: transparent !important;
	color: var(--lep-text-dark) !important;
	border: 1px solid var(--lep-border) !important;
	border-radius: 0 !important;
	font-size: 11px !important;
	font-weight: 600 !important;
	letter-spacing: 2px !important;
	text-transform: uppercase !important;
	padding: 14px 28px !important;
	cursor: pointer !important;
	transition: all 0.3s ease !important;
	line-height: normal !important;
	background-image: none !important;
}

.lepb-secondary-btn:hover {
	border-color: var(--lep-accent) !important;
	color: var(--lep-accent) !important;
}

.lepb-sticky-summary {
	position: sticky !important;
	bottom: 0 !important;
	background: var(--lep-bg-white) !important;
	border-top: 1px solid var(--lep-border-section) !important;
	padding: 16px 24px !important;
	box-shadow: 0 -4px 16px rgba(0, 0, 0, 0.06) !important;
	z-index: 100 !important;
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	margin-top: 32px !important;
}

/* Schritt 1: kein Gesamtpreis — Buttons bündig rechts */
.lepb-sticky-summary.lepb-sticky-summary--step1 {
	justify-content: flex-end !important;
}

.lepb-summary-price {
	font-size: 15px !important;
	font-weight: 600 !important;
	color: var(--lep-text-dark) !important;
	display: flex !important;
	flex-direction: column !important;
	align-items: flex-start !important;
	gap: 2px !important;
}

.lepb-summary-price-line {
	display: inline !important;
}

#lepb-total-price,
.lepb-summary-price #lepb-total-price {
	font-size: 22px !important;
	color: var(--lep-accent) !important;
	font-weight: 700 !important;
	margin-left: 8px !important;
}

.lepb-session-info {
	display: block !important;
	font-size: 12px !important;
	font-weight: 400 !important;
	color: var(--lep-success) !important;
	margin-top: 2px !important;
	line-height: 1.35 !important;
}

/* Sitzungspaket-Kacheln (Schritt 2, nur Laser) */
.lepb-session-packs {
	margin-top: 32px !important;
	padding-top: 28px !important;
	padding-left: 4px !important;
	padding-right: 4px !important;
	border-top: 1px solid var(--lep-border-section) !important;
	text-align: center !important;
	/* Kind darf Schatten zeichnen, Eltern-Panel clippt nicht (Schritte-Container hat overflow:hidden) */
	overflow: visible !important;
}

.lepb-session-packs .lepb-subheading {
	text-align: center !important;
	border-bottom: none !important;
	padding-bottom: 0 !important;
	margin-top: 0 !important;
}

.lepb-session-intro {
	font-size: 14px !important;
	color: var(--lep-text-body) !important;
	margin: 0 0 20px 0 !important;
	line-height: 1.6 !important;
}

.lepb-session-cards {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 16px !important;
	margin-bottom: 16px !important;
	/* Platz für Auswahl-Ring (box-shadow) und Badges oben – sonst clippt .lepb-steps-container */
	padding: 14px 12px 8px 12px !important;
	box-sizing: border-box !important;
}

.lepb-session-card {
	border: 1.5px solid var(--lep-border-section) !important;
	border-radius: 8px !important;
	padding: 24px 16px !important;
	text-align: center !important;
	cursor: pointer !important;
	transition: all 0.3s ease !important;
	background: var(--lep-bg-off) !important;
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	gap: 6px !important;
	position: relative !important;
	font: inherit !important;
	color: inherit !important;
	box-sizing: border-box !important;
}

.lepb-session-card:hover {
	border-color: var(--lep-accent) !important;
	box-shadow: 0 4px 16px rgba(233, 188, 185, 0.12) !important;
}

.lepb-session-card:focus {
	outline: 2px solid var(--lep-accent) !important;
	outline-offset: 2px !important;
}

.lepb-session-card--selected {
	border-color: var(--lep-accent) !important;
	background: var(--lep-bg-white) !important;
	box-shadow: 0 0 0 2px var(--lep-accent) !important;
}

.lepb-session-badge {
	position: absolute !important;
	top: -10px !important;
	background: var(--lep-accent) !important;
	color: #fff !important;
	font-family: ui-sans-serif, system-ui, sans-serif !important;
	font-size: 10px !important;
	font-weight: 600 !important;
	letter-spacing: 1px !important;
	text-transform: uppercase !important;
	padding: 3px 12px !important;
	border-radius: 10px !important;
}

.lepb-session-card-name {
	font-family: "Playfair Display", Georgia, serif !important;
	font-size: 17px !important;
	font-weight: 400 !important;
	color: var(--lep-text-dark) !important;
	margin-top: 6px !important;
}

.lepb-session-card-desc {
	font-size: 12px !important;
	color: var(--lep-text-body) !important;
}

.lepb-session-card-price {
	font-size: 20px !important;
	font-weight: 600 !important;
	color: var(--lep-accent) !important;
	margin-top: 4px !important;
}

.lepb-session-card-save {
	font-size: 11px !important;
	font-weight: 500 !important;
	color: var(--lep-success) !important;
	background: rgba(39, 174, 96, 0.06) !important;
	padding: 3px 10px !important;
	border-radius: 12px !important;
}

.lepb-session-summary {
	margin-top: 12px !important;
	padding: 12px 16px !important;
	background: var(--lep-bg-off) !important;
	border-radius: 6px !important;
	font-size: 13px !important;
	color: var(--lep-text-body) !important;
	text-align: center !important;
}

.lepb-session-summary span,
.lepb-session-summary strong {
	color: var(--lep-success) !important;
	font-weight: 500 !important;
}

.lepb-summary-main {
	display: flex !important;
	flex-direction: column !important;
	align-items: flex-start !important;
	gap: 6px !important;
	text-align: left !important;
	flex: 1 !important;
	min-width: 0 !important;
}

.lepb-volume-summary {
	font-size: 13px !important;
	line-height: 1.45 !important;
	color: var(--lep-text-body) !important;
	max-width: 100% !important;
}

.lepb-coupon-summary {
	font-size: 13px !important;
	line-height: 1.45 !important;
	color: var(--lep-text-body) !important;
	max-width: 100% !important;
}

.lepb-coupon-summary-label {
	color: var(--lep-text-dark) !important;
	font-weight: 500 !important;
}

.lepb-coupon-summary-reduction {
	color: var(--lep-text-body) !important;
	font-weight: 500 !important;
}

.lepb-coupon-summary-save {
	color: var(--lep-success) !important;
	font-weight: 700 !important;
}

.lepb-volume-summary-rule {
	display: block !important;
	font-weight: 500 !important;
	color: var(--lep-text-dark) !important;
}

.lepb-volume-summary-save-row {
	margin-top: 2px !important;
}

.lepb-volume-save-prefix {
	color: var(--lep-text-dark) !important;
	font-weight: 500 !important;
}

.lepb-volume-save-amount {
	color: var(--lep-success) !important;
	font-weight: 700 !important;
	font-size: 13px !important;
}

.lepb-total-savings-summary {
	font-size: 13px !important;
	line-height: 1.45 !important;
	max-width: 100% !important;
}

.lepb-total-savings-label {
	color: var(--lep-text-dark) !important;
	font-weight: 600 !important;
}

.lepb-total-savings-amount {
	color: var(--lep-success) !important;
	font-weight: 700 !important;
}

.lepb-sticky-actions {
	display: flex !important;
	gap: 10px !important;
	align-items: center !important;
	flex-wrap: wrap;
}

.lepb-duration-estimate {
	font-size: 14px !important;
	color: var(--lep-text-body) !important;
	margin-bottom: 20px !important;
	text-align: center;
}

.lepb-steps-container {
	position: relative;
	overflow: hidden;
}

.lepb-step-panel {
	transition: opacity 0.3s ease, transform 0.3s ease;
}

.lepb-step-panel--hidden {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	opacity: 0;
	transform: translateX(30px);
	pointer-events: none;
	visibility: hidden;
}

.lepb-step-panel--active {
	position: relative;
	opacity: 1;
	transform: translateX(0);
	pointer-events: auto;
	visibility: visible;
}

/* Schritt 2: Abstand zum Rand, sonst clippt overflow:hidden am .lepb-steps-container Schatten der Kacheln */
.lepb-step-panel[data-step="2"].lepb-step-panel--active {
	padding-left: 8px !important;
	padding-right: 8px !important;
	box-sizing: border-box !important;
}

.lepb-subheading {
	font-size: clamp(22px, 3vw, 26px) !important;
	font-weight: 400 !important;
	color: var(--lep-text-dark) !important;
	margin: 24px 0 10px 0 !important;
	border-bottom: 1px solid var(--lep-border-section) !important;
	padding-bottom: 8px !important;
	text-align: left;
}

.lepb-hidden {
	display: none !important;
}

.lepb-message {
	margin-bottom: 20px !important;
	padding: 16px 20px !important;
	border-radius: 6px !important;
	font-size: 14px !important;
	line-height: 1.5 !important;
}

.lepb-message--hidden {
	display: none !important;
}

.lepb-message:not(.lepb-message--error):not(.lepb-message--hidden) {
	background: rgba(39, 174, 96, 0.06) !important;
	border: 1px solid rgba(39, 174, 96, 0.2) !important;
	color: #1a7a3a !important;
}

.lepb-message--error:not(.lepb-message--hidden) {
	background: rgba(231, 76, 60, 0.06) !important;
	border: 1px solid rgba(231, 76, 60, 0.2) !important;
	color: #c0392b !important;
}

.lepb-package-hint {
	margin-bottom: 20px !important;
	padding: 16px 20px !important;
	background: var(--lep-bg-off) !important;
	border-left: 3px solid var(--lep-accent) !important;
	border-radius: 0 6px 6px 0 !important;
	font-size: 14px !important;
	text-align: left !important;
}

.lepb-package-hint .lepb-secondary-btn {
	margin-top: 10px !important;
	padding: 8px 20px !important;
	font-size: 10px !important;
}

.lepb-blocked-hint,
.lepb-step-panel[data-step="4"] .lepb-duration-estimate {
	font-size: 14px !important;
	color: var(--lep-text-body) !important;
	margin-bottom: 20px !important;
}

.lepb-blocked-hint {
	padding: 12px 14px !important;
	background: var(--lep-bg-off) !important;
	border: 1px solid var(--lep-border-light) !important;
	border-radius: 8px !important;
	text-align: left !important;
}

.lepb-date-field .lepb-label {
	text-align: left !important;
}

/* —— Kalender —— */
.lepb-step-panel[data-step="4"] {
	max-width: 560px !important;
	margin: 0 auto !important;
	text-align: left !important;
}

.lepb-datepicker {
	max-width: 100% !important;
	width: 100% !important;
	padding: 20px !important;
	background: var(--lep-bg-off) !important;
	border: 1px solid var(--lep-border-section) !important;
	border-radius: 8px !important;
	margin-bottom: 16px !important;
	box-sizing: border-box !important;
	overflow: hidden !important;
}

.lepb-datepicker--loading {
	opacity: 0.65 !important;
	pointer-events: none !important;
}

.lepb-datepicker-toolbar {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	margin-bottom: 16px !important;
}

.lepb-cal-month {
	font-size: 18px !important;
	font-weight: 400 !important;
	color: var(--lep-text-dark) !important;
	flex: 1;
	text-align: center !important;
}

.lepb-cal-nav {
	width: 36px !important;
	height: 36px !important;
	min-width: 36px !important;
	border: 1px solid var(--lep-border) !important;
	background: var(--lep-bg-white) !important;
	border-radius: 50% !important;
	font-size: 18px !important;
	line-height: 1 !important;
	color: var(--lep-text-dark) !important;
	cursor: pointer;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	transition: all 0.2s ease;
	flex: 0 0 auto !important;
}

.lepb-cal-nav:hover:not(:disabled) {
	border-color: var(--lep-accent) !important;
	color: var(--lep-accent) !important;
}

.lepb-cal-nav:disabled {
	opacity: 0.35 !important;
	cursor: not-allowed !important;
}

.lepb-cal-weekdays {
	display: grid !important;
	grid-template-columns: repeat(7, 1fr) !important;
	gap: 4px !important;
	margin-bottom: 8px !important;
	font-size: 11px !important;
	font-weight: 600 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.5px !important;
	color: var(--lep-text-light) !important;
	text-align: center !important;
}

.lepb-cal-wd {
	padding: 4px 0;
}

.lepb-cal-cells {
	display: flex !important;
	flex-direction: column !important;
	gap: 4px !important;
}

.lepb-cal-row {
	display: grid !important;
	grid-template-columns: repeat(7, 1fr) !important;
	gap: 4px !important;
}

.lepb-cal-cell {
	aspect-ratio: 1 !important;
	min-height: 0 !important;
	max-height: 44px !important;
	width: 100% !important;
	border: 1px solid transparent !important;
	border-radius: 50% !important;
	background: var(--lep-bg-white) !important;
	font-size: 14px !important;
	color: var(--lep-text-dark) !important;
	cursor: pointer;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	transition: all 0.15s ease;
	box-sizing: border-box !important;
}

.lepb-cal-cell--enabled:hover {
	background: var(--lep-accent-light) !important;
	border-color: var(--lep-accent) !important;
}

.lepb-cal-cell--selected {
	background: var(--lep-accent) !important;
	color: #fff !important;
	font-weight: 600 !important;
	border-color: var(--lep-accent) !important;
}

.lepb-cal-cell--disabled,
.lepb-cal-cell:disabled {
	background: transparent !important;
	color: #ccc !important;
	cursor: not-allowed !important;
	opacity: 0.5 !important;
}

.lepb-cal-cell--pad {
	visibility: hidden !important;
	pointer-events: none !important;
	aspect-ratio: 1 !important;
	max-height: 44px !important;
}

.lepb-cal-selected {
	margin: 8px 0 0 !important;
	font-size: 14px !important;
	color: var(--lep-text-body) !important;
}

.lepb-step-panel[data-step="4"] .lepb-select {
	margin-top: 8px !important;
}

.lepb-step-panel[data-step="4"] > p:last-of-type {
	font-size: 13px !important;
	color: var(--lep-text-light) !important;
	font-style: italic !important;
	margin-top: 16px !important;
	text-align: left !important;
}

/* —— Pakete & Behandlungen —— */
.lepb-packages-grid {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important;
	gap: 16px !important;
	margin-bottom: 24px !important;
}

.lepb-package-card {
	border: 1px solid var(--lep-border-section) !important;
	border-radius: 8px !important;
	padding: 24px 20px !important;
	background: var(--lep-bg-off) !important;
	text-align: center !important;
	transition: all 0.3s ease;
	cursor: pointer;
	position: relative;
}

.lepb-package-card:hover {
	border-color: var(--lep-accent) !important;
	box-shadow: 0 4px 20px rgba(233, 188, 185, 0.12);
}

.lepb-package-card--selected {
	border-color: var(--lep-accent) !important;
	box-shadow: 0 0 0 2px var(--lep-accent) !important;
	background: var(--lep-bg-white) !important;
}

.lepb-package-head {
	font-size: 18px !important;
	font-weight: 400 !important;
	color: var(--lep-text-dark) !important;
	margin-bottom: 6px !important;
	display: block !important;
}

.lepb-package-desc {
	font-size: 13px !important;
	color: var(--lep-text-body) !important;
	margin-bottom: 12px !important;
}

.lepb-price-old {
	text-decoration: line-through !important;
	color: #bbb !important;
	font-size: 14px !important;
	margin-right: 8px !important;
}

.lepb-price-pack {
	font-size: 22px !important;
	font-weight: 600 !important;
	color: var(--lep-accent) !important;
}

.lepb-package-save {
	display: inline-block;
	font-size: 11px;
	font-weight: 500;
	color: var(--lep-success);
	background: rgba(39, 174, 96, 0.06);
	padding: 3px 10px;
	border-radius: 12px;
	margin-top: 8px;
}

.lepb-badge {
	display: inline-block !important;
	font-size: 10px !important;
	text-transform: uppercase !important;
	letter-spacing: 1px !important;
	background: var(--lep-accent) !important;
	color: #fff !important;
	padding: 4px 12px !important;
	border-radius: 12px !important;
	margin-bottom: 10px !important;
}

.lepb-details {
	margin-bottom: 8px;
}

.lepb-details-sum {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	gap: 12px !important;
	font-size: 18px !important;
	font-weight: 400 !important;
	color: var(--lep-text-dark) !important;
	padding: 18px 8px 18px 4px !important;
	cursor: pointer;
	list-style: none !important;
	border-bottom: 1px solid var(--lep-border-section) !important;
	text-align: left !important;
}

.lepb-details-sum::-webkit-details-marker {
	display: none;
}

/* Rosa Pfeil rechts: zu bei eingeklappt, auf bei ausgeklappt */
.lepb-details-sum::after {
	content: "" !important;
	display: block !important;
	flex-shrink: 0 !important;
	width: 0 !important;
	height: 0 !important;
	border-left: 5px solid transparent !important;
	border-right: 5px solid transparent !important;
	border-top: 6px solid var(--lep-accent) !important;
	transform-origin: 50% 40% !important;
	transition: transform 0.2s ease !important;
}

.lepb-details[open] > .lepb-details-sum::after {
	transform: rotate(180deg) !important;
}

.lepb-zone-rows {
	padding: 0 0 8px;
}

.lepb-treat-row {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	padding: 14px 12px !important;
	border-bottom: 1px solid var(--lep-border-light) !important;
	cursor: pointer;
	transition: background-color 0.2s ease;
	gap: 16px !important;
	text-align: left !important;
}

.lepb-treat-row:hover {
	background-color: var(--lep-bg-off) !important;
}

.lepb-treat-name {
	flex: 1 !important;
	font-size: 14.5px !important;
	font-weight: 400 !important;
	color: #444 !important;
}

.lepb-treat-price {
	font-size: 14.5px !important;
	font-weight: 600 !important;
	color: var(--lep-text-dark) !important;
	white-space: nowrap !important;
	margin-right: 12px !important;
}

.lepb-treat-row input[type="checkbox"] {
	width: 20px !important;
	height: 20px !important;
	min-width: 20px !important;
	accent-color: var(--lep-accent) !important;
	cursor: pointer !important;
	flex-shrink: 0 !important;
}

.lepb-coupon-row {
	margin-top: 20px !important;
	text-align: left !important;
}

.lepb-coupon-label {
	font-size: 13px !important;
	font-weight: 500 !important;
	color: var(--lep-text-dark) !important;
	margin-bottom: 8px !important;
}

.lepb-coupon-inline {
	display: flex !important;
	gap: 10px !important;
	align-items: center !important;
	flex-wrap: wrap;
}

.lepb-coupon-input {
	max-width: 240px !important;
	flex: 1 !important;
	min-width: 160px !important;
}

.lepb-packages-wrap,
.lepb-treatments-wrap {
	text-align: left;
}

/* —— Schritt 5: Zahlung —— */
.lepb-step-panel[data-step="5"] {
	max-width: 560px !important;
	margin: 0 auto !important;
	text-align: left !important;
}

.lepb-payment-methods {
	display: flex !important;
	flex-direction: column !important;
	gap: 12px !important;
	margin-bottom: 20px !important;
}

.lepb-payment-methods .lepb-payment-option.lepb-form-field {
	margin-bottom: 0 !important;
}

.lepb-payment-option {
	border: 1.5px solid var(--lep-border-section) !important;
	border-radius: 8px !important;
	padding: 16px 20px !important;
	cursor: pointer;
	transition: all 0.2s ease;
	background: var(--lep-bg-white) !important;
}

.lepb-payment-option:hover {
	border-color: var(--lep-accent) !important;
}

.lepb-payment-option:has(input:checked) {
	border-color: var(--lep-accent) !important;
	background: var(--lep-accent-light) !important;
	box-shadow: 0 0 0 1px var(--lep-accent) !important;
}

.lepb-payment-option label {
	display: flex !important;
	align-items: center !important;
	gap: 12px !important;
	cursor: pointer !important;
	font-size: 14px !important;
	font-weight: 400 !important;
	color: var(--lep-text-dark) !important;
	margin: 0 !important;
	font-family: ui-sans-serif, system-ui, sans-serif !important;
}

.lepb-payment-option input[type="radio"] {
	accent-color: var(--lep-accent) !important;
	width: 18px !important;
	height: 18px !important;
	flex-shrink: 0 !important;
}

.lepb-payment-note {
	margin: 16px 0 !important;
	padding: 16px 20px !important;
	background: var(--lep-bg-off) !important;
	border: 1px solid var(--lep-border-light) !important;
	border-left: 3px solid var(--lep-accent) !important;
	border-radius: 0 6px 6px 0 !important;
	font-size: 14px !important;
	color: var(--lep-text-body) !important;
	line-height: 1.6 !important;
}

.lepb-gdpr label {
	display: flex !important;
	align-items: flex-start !important;
	gap: 10px !important;
	font-size: 13px !important;
	color: var(--lep-text-body) !important;
	line-height: 1.5 !important;
	cursor: pointer;
	font-family: ui-sans-serif, system-ui, sans-serif !important;
}

.lepb-gdpr input[type="checkbox"] {
	accent-color: var(--lep-accent) !important;
	width: 18px !important;
	height: 18px !important;
	min-width: 18px !important;
	margin-top: 2px !important;
	flex-shrink: 0 !important;
}

.lepb-loading {
	padding: 12px;
	color: var(--lep-text-body);
	text-align: left;
}

/* —— Elementor / Theme resets —— */
.lepb-wrapper .elementor-button,
.lepb-wrapper button,
.lepb-wrapper .lepb-primary-btn,
.lepb-wrapper .lepb-secondary-btn {
	line-height: normal !important;
	background-image: none !important;
}

.lepb-wrapper input:not([type="checkbox"]):not([type="radio"]),
.lepb-wrapper select,
.lepb-wrapper textarea {
	background-image: none !important;
}

/* Überschriften-Abstände: nur über .lepb-heading / .lepb-subheading (siehe Dateiende). */

/* —— Responsive —— */
@media (max-width: 1024px) {
	.lepb-wrapper {
		padding: 36px 20px !important;
	}

	.lepb-packages-grid {
		grid-template-columns: repeat(2, 1fr) !important;
	}
}

@media (max-width: 767px) {
	.lepb-wrapper {
		padding: 24px 16px !important;
	}

	.lepb-step > div:last-child {
		display: none !important;
	}

	.lepb-step-circle {
		width: 34px !important;
		height: 34px !important;
		font-size: 13px !important;
	}

	.lepb-step:not(:last-child)::after {
		top: 17px !important;
		left: calc(50% + 17px) !important;
		width: calc(100% - 34px) !important;
	}

	.lepb-choice-grid {
		grid-template-columns: 1fr !important;
	}

	.lepb-packages-grid {
		grid-template-columns: 1fr !important;
	}

	.lepb-session-cards {
		grid-template-columns: 1fr !important;
		gap: 12px !important;
	}

	.lepb-sticky-summary {
		flex-direction: column !important;
		align-items: stretch !important;
		gap: 12px !important;
		padding: 14px 16px !important;
	}

	.lepb-sticky-actions {
		justify-content: stretch !important;
	}

	.lepb-primary-btn,
	.lepb-secondary-btn {
		width: 100% !important;
		text-align: center !important;
	}

	.lepb-payment-option {
		padding: 14px 16px !important;
	}

	.lepb-datepicker {
		padding: 14px !important;
	}

	.lepb-cal-cell {
		max-height: 38px !important;
		font-size: 13px !important;
	}

	.lepb-cal-cell--pad {
		max-height: 38px !important;
	}
}

@media (max-width: 480px) {
	.lepb-step-circle {
		width: 30px !important;
		height: 30px !important;
		font-size: 12px !important;
	}

	.lepb-step:not(:last-child)::after {
		top: 15px !important;
		left: calc(50% + 15px) !important;
		width: calc(100% - 30px) !important;
	}

	.lepb-primary-btn {
		padding: 12px 20px !important;
		font-size: 10px !important;
	}

	.lepb-secondary-btn {
		padding: 12px 20px !important;
		font-size: 10px !important;
	}
}

/* Überschreibt breitere Theme/Elementor-Regeln für Wrapper-Überschriften (höhere Spezifität). */
.lepb-wrapper h2.lepb-heading {
	margin: 0 0 10px 0 !important;
	padding: 0 !important;
}

.lepb-wrapper h3.lepb-subheading {
	margin: 24px 0 10px 0 !important;
	padding: 0 0 8px 0 !important;
}
