/* Webza Booking — page styles. Extends webza-pure design tokens. */

.webza-booking {
	padding: 56px 0 96px;
	background: linear-gradient(180deg, var(--c-bg) 0%, #fff 100%);
	min-height: 70vh;
}

.webza-booking__header {
	text-align: center;
	max-width: 720px;
	margin: 0 auto 40px;
}

.webza-booking__header h1 {
	margin: 0 0 12px;
	font-size: clamp(2rem, 4vw, 2.6rem);
}

.webza-booking__lead {
	color: var(--c-secondary);
	font-size: 1.05rem;
	margin: 0;
}

/* Panels */
.webza-booking__panel {
	max-width: 880px;
	margin: 0 auto 24px;
	background: #fff;
	border-radius: var(--radius);
	box-shadow: 0 12px 40px rgba(28, 2, 54, .08);
	padding: 36px 40px;
}

@media (max-width: 600px) {
	.webza-booking__panel { padding: 24px; }
}

.webza-booking__step-head {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 20px;
	flex-wrap: wrap;
}

.webza-booking__step-num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: var(--c-webza-2);
	color: #fff;
	font-weight: 700;
	font-size: .9rem;
}

.webza-booking__step-head h2 {
	margin: 0;
	font-size: 1.3rem;
	flex: 1;
}

.webza-booking__back {
	background: transparent;
	border: 0;
	color: var(--c-primary);
	font-size: .9rem;
	cursor: pointer;
	padding: 6px 10px;
	font-weight: 600;
}

.webza-booking__back:hover { text-decoration: underline; }

.webza-booking__chosen-date,
.webza-booking__chosen-slot {
	color: var(--c-secondary);
	margin: 0 0 18px;
	font-size: .95rem;
}

/* Loading & empty — [hidden] must beat the class rule, so use :not() */
.webza-booking__loading:not([hidden]),
.webza-booking__empty:not([hidden]) {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 20px 0;
	color: var(--c-secondary);
	font-size: .95rem;
}

.webza-booking__empty:not([hidden]) {
	background: var(--c-bg);
	padding: 24px;
	border-radius: 8px;
}

.webza-booking__spinner {
	display: inline-block;
	width: 18px;
	height: 18px;
	border: 2px solid var(--c-border);
	border-top-color: var(--c-primary);
	border-radius: 50%;
	animation: webza-booking-spin .8s linear infinite;
}

@keyframes webza-booking-spin { to { transform: rotate(360deg); } }

/* Date cards */
.webza-booking__dates {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
	gap: 12px;
}

.webza-booking__date-card {
	background: #fff;
	border: 2px solid var(--c-border);
	border-radius: 10px;
	padding: 16px 8px;
	text-align: center;
	cursor: pointer;
	transition: all .15s ease;
	font-family: inherit;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.webza-booking__date-card:hover {
	border-color: var(--c-primary);
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(146, 83, 179, .12);
}

.webza-booking__date-day {
	font-size: .75rem;
	font-weight: 600;
	color: var(--c-secondary);
	text-transform: uppercase;
	letter-spacing: .06em;
}

.webza-booking__date-num {
	font-size: 1.8rem;
	font-weight: 800;
	color: var(--c-ink);
	line-height: 1;
	margin: 4px 0;
}

.webza-booking__date-month {
	font-size: .8rem;
	color: var(--c-secondary);
}

.webza-booking__date-slots {
	font-size: .72rem;
	color: var(--c-primary);
	font-weight: 600;
	margin-top: 8px;
}

/* Time cards */
.webza-booking__times {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
	gap: 10px;
}

.webza-booking__time-card {
	background: #fff;
	border: 2px solid var(--c-border);
	border-radius: 8px;
	padding: 14px 10px;
	font-size: 1.05rem;
	font-weight: 600;
	color: var(--c-ink);
	cursor: pointer;
	transition: all .15s ease;
	font-family: inherit;
}

.webza-booking__time-card:hover {
	border-color: var(--c-webza-red);
	color: var(--c-webza-red);
	transform: translateY(-2px);
}

/* Form */
.webza-booking__form {
	display: grid;
	gap: 16px;
}

.webza-booking__field {
	display: block;
}

.webza-booking__field > span {
	display: block;
	font-weight: 500;
	font-size: .95rem;
	margin-bottom: 6px;
}

.webza-booking__field > span em {
	color: var(--c-webza-red);
	font-style: normal;
	margin-left: 2px;
}

.webza-booking__field > span small {
	font-weight: 400;
	color: var(--c-secondary);
	font-size: .85rem;
}

.webza-booking__field input,
.webza-booking__field textarea {
	width: 100%;
	padding: 12px 14px;
	border: 1px solid var(--c-border);
	border-radius: 8px;
	font: inherit;
	background: #fff;
}

.webza-booking__field input:focus,
.webza-booking__field textarea:focus {
	outline: 2px solid var(--c-primary);
	outline-offset: 1px;
	border-color: var(--c-primary);
}

.webza-booking__field textarea {
	resize: vertical;
	min-height: 90px;
}

.webza-booking__error {
	background: #fde8e7;
	color: #9b2421;
	border: 1px solid #f3b6b3;
	border-radius: 8px;
	padding: 12px 14px;
	font-size: .95rem;
}

.webza-booking__legal {
	font-size: .82rem;
	color: var(--c-secondary);
	margin: 8px 0 0;
	line-height: 1.5;
}

#webza-booking-submit {
	justify-self: start;
	margin-top: 6px;
}

/* Success */
.webza-booking__success {
	text-align: center;
	padding: 20px 0;
}

.webza-booking__success-icon {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	background: var(--c-accent);
	color: #fff;
	font-size: 2.6rem;
	font-weight: 700;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 16px;
	box-shadow: 0 8px 20px rgba(97, 206, 112, .35);
}

.webza-booking__success h2 {
	margin: 0 0 16px;
}

.webza-booking__success-when {
	font-size: 1.2rem;
	font-weight: 600;
	color: var(--c-webza-2);
	margin: 0 0 16px;
}

.webza-booking__success p {
	color: var(--c-secondary);
	margin: 0 0 12px;
	font-size: 1rem;
	line-height: 1.6;
}

.webza-booking__success .btn {
	margin-top: 18px;
}
