/* Front-end booking widget */
.dp-booking-calendar {
	max-width: 480px;
	margin: 0 0 2em;
	font-size: 15px;
}

.dp-booking-calendar--week,
.dp-booking-calendar--month {
	max-width: 540px;
}

.dp-booking-calendar__title {
	margin-bottom: 0.75em;
}

.dp-booking-calendar__closed {
	padding: 0.75em 1em;
	background: #f5f5f5;
	border: 1px solid #ddd;
	border-radius: 4px;
}

.dp-booking-step {
	margin-bottom: 1em;
}

.dp-booking-step__heading {
	font-weight: bold;
	margin-bottom: 0.5em;
}

.dp-booking-date-input {
	display: block;
	margin-top: 0.4em;
	padding: 0.4em;
}

.dp-booking-slots {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5em;
}

.dp-booking-slot {
	padding: 0.5em 0.8em;
	border: 1px solid #999;
	background: #fff;
	border-radius: 4px;
	cursor: pointer;
}

.dp-booking-slot:hover:not(:disabled) {
	border-color: #2271b1;
	color: #2271b1;
}

.dp-booking-slot--booked,
.dp-booking-slot:disabled {
	background: #eee;
	color: #999;
	border-color: #ccc;
	cursor: not-allowed;
}

.dp-booking-form p {
	margin-bottom: 0.75em;
}

.dp-booking-form input[type="text"],
.dp-booking-form input[type="email"],
.dp-booking-form input[type="tel"] {
	display: block;
	width: 100%;
	max-width: 320px;
	padding: 0.5em;
	margin-top: 0.3em;
	box-sizing: border-box;
}

.dp-booking-honeypot {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.dp-booking-message {
	min-height: 1.4em;
	color: #333;
}

.dp-booking-message--error {
	color: #c0392b;
	font-weight: bold;
}

.dp-booking-done-message {
	padding: 0.75em 1em;
	background: #eafaf1;
	border: 1px solid #27ae60;
	border-radius: 4px;
}

/* ---- Week calendar ---- */
.dp-booking-week-nav {
	display: flex;
	align-items: center;
	gap: 0.5em;
	margin-bottom: 0.75em;
}

.dp-booking-week-label {
	flex: 1;
	text-align: center;
	font-weight: bold;
	font-size: 14px;
}

.dp-booking-week-nav button {
	padding: 0.3em 0.7em;
	border: 1px solid #ccc;
	background: #fff;
	border-radius: 4px;
	cursor: pointer;
	font-size: 13px;
}

.dp-booking-week-nav button:disabled {
	color: #aaa;
	border-color: #e0e0e0;
	cursor: not-allowed;
}

.dp-booking-week-nav button:hover:not(:disabled) {
	border-color: #2271b1;
	color: #2271b1;
}

.dp-booking-week-grid {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 4px;
}

.dp-booking-week-day {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 0.5em 0.2em;
	border: 1px solid #ccc;
	background: #fff;
	border-radius: 4px;
	cursor: pointer;
	font-size: 12px;
	line-height: 1.5;
}

.dp-booking-week-day__name {
	font-weight: bold;
}

.dp-booking-week-day__date {
	font-size: 11px;
}

.dp-booking-week-day:hover:not(:disabled):not(.dp-booking-week-day--selected) {
	border-color: #2271b1;
	color: #2271b1;
}

.dp-booking-week-day--selected {
	background: #2271b1;
	color: #fff !important;
	border-color: #2271b1;
}

.dp-booking-week-day--past,
.dp-booking-week-day:disabled {
	background: #f5f5f5;
	color: #bbb !important;
	border-color: #e8e8e8;
	cursor: not-allowed;
}

.dp-booking-week-day--sat:not(:disabled) {
	color: #1565c0;
}

.dp-booking-week-day--sun:not(:disabled) {
	color: #c62828;
}

/* ---- Month calendar ---- */
.dp-booking-month-nav {
	display: flex;
	align-items: center;
	gap: 0.5em;
	margin-bottom: 0.75em;
}

.dp-booking-month-label {
	flex: 1;
	text-align: center;
	font-weight: bold;
	font-size: 15px;
}

.dp-booking-month-nav button {
	padding: 0.3em 0.7em;
	border: 1px solid #ccc;
	background: #fff;
	border-radius: 4px;
	cursor: pointer;
	font-size: 13px;
}

.dp-booking-month-nav button:disabled {
	color: #aaa;
	border-color: #e0e0e0;
	cursor: not-allowed;
}

.dp-booking-month-nav button:hover:not(:disabled) {
	border-color: #2271b1;
	color: #2271b1;
}

.dp-booking-month-header {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 2px;
	margin-bottom: 2px;
}

.dp-booking-month-dow {
	text-align: center;
	font-size: 12px;
	font-weight: bold;
	padding: 0.3em 0;
	color: #555;
}

.dp-booking-month-dow--sat {
	color: #1565c0;
}

.dp-booking-month-dow--sun {
	color: #c62828;
}

.dp-booking-month-body {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 2px;
}

.dp-booking-month-day {
	display: block;
	text-align: center;
	padding: 0.45em 0.1em;
	border: 1px solid #ddd;
	background: #fff;
	border-radius: 3px;
	cursor: pointer;
	font-size: 13px;
	min-height: 2em;
	line-height: 1.1;
}

.dp-booking-month-day--empty {
	border-color: transparent;
	background: transparent;
	pointer-events: none;
}

.dp-booking-month-day:hover:not(:disabled):not(.dp-booking-month-day--selected):not(.dp-booking-month-day--empty) {
	border-color: #2271b1;
	color: #2271b1;
}

.dp-booking-month-day--selected {
	background: #2271b1;
	color: #fff !important;
	border-color: #2271b1;
}

.dp-booking-month-day--past,
.dp-booking-month-day:disabled:not(.dp-booking-month-day--empty) {
	background: #f5f5f5;
	color: #bbb;
	border-color: #e8e8e8;
	cursor: not-allowed;
}

.dp-booking-month-day--sat:not(:disabled):not(.dp-booking-month-day--selected) {
	color: #1565c0;
}

.dp-booking-month-day--sun:not(:disabled):not(.dp-booking-month-day--selected) {
	color: #c62828;
}

/* Admin screens */
.dp-booking-badge {
	display: inline-block;
	padding: 0.15em 0.7em;
	border-radius: 3px;
	font-size: 12px;
	color: #fff;
}

.dp-booking-badge-active,
.dp-booking-badge-confirmed {
	background: #2e7d32;
}

.dp-booking-badge-inactive,
.dp-booking-badge-cancelled {
	background: #757575;
}

.dp-booking-badge-pending {
	background: #f9a825;
}

.dp-booking-badge-rejected {
	background: #c0392b;
}

.dp-booking-delete-link {
	color: #c0392b;
}

.dp-booking-delete-link:hover {
	color: #922b21;
}
