.zapibook-booking-widget {
	--zb-color-primary: #3a7bd5;
	--zb-color-secondary: #00d2ff;
	--zb-color-accent: #ff6b6b;
	--zb-font-family: inherit;

	font-family: var(--zb-font-family);
	max-width: 640px;
	margin: 0 auto;
	color: #222;
}

.zapibook-booking-widget * {
	box-sizing: border-box;
	font-family: inherit;
}

.zb-steps {
	display: flex;
	justify-content: space-between;
	margin-bottom: 24px;
	font-size: 13px;
}

.zb-step-indicator {
	flex: 1;
	text-align: center;
	padding: 8px 4px;
	border-bottom: 3px solid #e2e2e2;
	color: #999;
	transition: color 0.2s, border-color 0.2s;
}

.zb-step-indicator.active {
	color: var(--zb-color-primary);
	border-color: var(--zb-color-primary);
	font-weight: 600;
}

.zb-step-indicator.done {
	color: var(--zb-color-primary);
	border-color: var(--zb-color-primary);
}

.zb-panel {
	display: none;
}

.zb-panel.active {
	display: block;
	animation: zb-fade-in 0.2s ease;
}

@keyframes zb-fade-in {
	from { opacity: 0; transform: translateY(4px); }
	to { opacity: 1; transform: translateY(0); }
}

.zb-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
	gap: 12px;
	margin-bottom: 20px;
}

.zb-card {
	border: 2px solid #e2e2e2;
	border-radius: 8px;
	padding: 14px;
	cursor: pointer;
	text-align: left;
	background: #fff;
	transition: border-color 0.15s, box-shadow 0.15s;
}

.zb-card:hover {
	border-color: var(--zb-color-primary);
}

.zb-card.selected {
	border-color: var(--zb-color-primary);
	box-shadow: 0 0 0 1px var(--zb-color-primary);
	background: color-mix(in srgb, var(--zb-color-primary) 6%, white);
}

.zb-card-title {
	font-weight: 600;
	margin-bottom: 4px;
}

.zb-card-meta {
	font-size: 12px;
	color: #777;
}

.zb-color-dot {
	display: inline-block;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	margin-right: 6px;
	vertical-align: middle;
}

.zb-field {
	margin-bottom: 16px;
}

.zb-field label {
	display: block;
	font-weight: 600;
	margin-bottom: 6px;
	font-size: 14px;
}

.zb-field input[type="text"],
.zb-field input[type="email"],
.zb-field input[type="tel"],
.zb-field input[type="date"],
.zb-field textarea {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid #d6d6d6;
	border-radius: 6px;
	font-size: 14px;
}

.zb-slots {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 12px;
}

.zb-slot {
	border: 1px solid #d6d6d6;
	border-radius: 6px;
	padding: 8px 14px;
	cursor: pointer;
	background: #fff;
	font-size: 14px;
}

.zb-slot:hover {
	border-color: var(--zb-color-primary);
}

.zb-slot.selected {
	background: var(--zb-color-primary);
	border-color: var(--zb-color-primary);
	color: #fff;
}

.zb-actions {
	display: flex;
	justify-content: space-between;
	margin-top: 20px;
}

.zb-btn {
	display: inline-block;
	padding: 12px 24px;
	border-radius: 6px;
	border: none;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	background: var(--zb-color-primary);
	color: #fff;
	transition: opacity 0.15s;
}

.zb-btn:hover {
	opacity: 0.9;
}

.zb-btn:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

.zb-btn-secondary {
	background: transparent;
	color: var(--zb-color-primary);
	border: 1px solid var(--zb-color-primary);
}

.zb-summary {
	background: #f7f7f8;
	border-radius: 8px;
	padding: 16px;
	margin-bottom: 16px;
	font-size: 14px;
}

.zb-summary strong {
	color: var(--zb-color-primary);
}

.zb-message {
	padding: 16px;
	border-radius: 8px;
	font-size: 14px;
	margin-bottom: 12px;
}

.zb-message-success {
	background: #e6f7ee;
	color: #1c7c4d;
	border: 1px solid #b6e7cd;
}

.zb-message-error {
	background: #fdeded;
	color: #b3261e;
	border: 1px solid #f5c2c0;
}

.zb-success-icon {
	font-size: 40px;
	text-align: center;
	margin-bottom: 8px;
	color: var(--zb-color-accent);
}

.zb-loading {
	text-align: center;
	padding: 20px;
	color: #999;
}
