/**
 * Booking System Styles
 * Styles for the booking system matching the theme design
 */

/* Events Overview */
.events-overview {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	margin-top: 2rem;
}

.event-card {
	background-color: var(--wp--preset--color--white, #ffffff);
	border-radius: 12px;
	padding: 2rem;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	overflow: hidden;
}

.event-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.event-card-inner {
	display: flex;
	gap: 2rem;
	align-items: flex-start;
}

.event-image {
	flex-shrink: 0;
	width: 300px;
	max-width: 100%;
}

.event-image img,
.event-thumbnail {
	width: 100%;
	height: auto;
	border-radius: 12px;
	display: block;
	transition: transform 0.2s ease;
	object-fit: cover;
}

.event-card:hover .event-image img,
.event-card:hover .event-thumbnail {
	transform: scale(1.02);
}

.event-image a {
	display: block;
	text-decoration: none;
}

.event-content-wrapper {
	flex: 1;
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.event-header {
	margin-bottom: 1.5rem;
	flex: 1;
}

.event-header h3 {
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	font-family: var(--wp--preset--font-family--serif, Georgia, serif);
	font-size: 1.5rem;
	margin-bottom: 0.5rem;
}

.event-date {
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	font-weight: 500;
	font-size: 1.1rem;
	margin-top: 0.75rem;
	margin-bottom: 0.5rem;
	line-height: 1.5;
}

.event-date strong {
	color: var(--wp--preset--color--terracotta, #C97D60);
	font-weight: 600;
	margin-right: 0.5rem;
}

.event-location-overview {
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	font-weight: 500;
	font-size: 1rem;
	margin-top: 0.5rem;
	line-height: 1.5;
}

.event-location-overview strong {
	color: var(--wp--preset--color--terracotta, #C97D60);
	font-weight: 600;
	margin-right: 0.5rem;
}

/* Past Events */
.past-events-overview {
	margin-top: 4rem;
	padding-top: 3rem;
	border-top: 2px solid var(--wp--preset--color--light-beige, #E8DED0);
}

.past-events-title {
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	font-family: var(--wp--preset--font-family--serif, Georgia, serif);
	font-size: 2rem;
	margin-bottom: 2rem;
	text-align: center;
}

.past-event {
	opacity: 0.85;
}

.past-event:hover {
	opacity: 1;
}

.past-event .event-header h3 a {
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	text-decoration: none;
	transition: color 0.2s ease;
}

.past-event .event-header h3 a:hover {
	color: var(--wp--preset--color--terracotta, #C97D60);
}

.event-content {
	margin-bottom: 1.5rem;
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	line-height: 1.7;
}

.event-content p {
	margin-bottom: 1rem;
}

.event-description {
	margin-bottom: 1.5rem;
	padding: 1rem;
	background-color: var(--wp--preset--color--light-beige, #E8DED0);
	border-radius: 8px;
	font-size: 0.9rem;
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
}

.event-booking-info {
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid var(--wp--preset--color--light-beige, #E8DED0);
	text-align: left;
	width: 100%;
}

.spots-info {
	margin-bottom: 1rem;
	font-weight: 500;
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
}

.spots-info.full {
	color: var(--wp--preset--color--terracotta, #C97D60);
}

.spots-info.closed {
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	font-weight: 600;
}

.no-booking-required {
	color: var(--wp--preset--color--soft-green, #8B9A7A);
	font-weight: 500;
	font-style: italic;
}

/* Booking Button */
.booking-button {
	display: inline-block;
	background-color: var(--wp--preset--color--terracotta, #C97D60);
	color: var(--wp--preset--color--white, #ffffff);
	padding: 0.875rem 2rem;
	border-radius: 8px;
	text-decoration: none;
	font-weight: 600;
	transition: background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
	border: none;
	cursor: pointer;
	font-size: 0.95rem;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
	white-space: nowrap;
	text-align: center;
	line-height: 1.4;
	vertical-align: middle;
	box-sizing: border-box;
}

.booking-button:hover {
	background-color: var(--wp--preset--color--brown, #6B5B4F);
	color: var(--wp--preset--color--white, #ffffff);
	text-decoration: none;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.booking-hint {
	margin-top: 0.5rem;
	font-size: 0.875rem;
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	opacity: 0.8;
}

.booking-button:focus {
	outline: 2px solid var(--wp--preset--color--terracotta, #C97D60);
	outline-offset: 2px;
}

/* Booking Form */
.booking-form-container {
	max-width: 600px;
	margin: 2rem auto;
	padding: 2rem;
	background-color: var(--wp--preset--color--white, #ffffff);
	border-radius: 12px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.booking-form-container h2 {
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	font-family: var(--wp--preset--font-family--serif, Georgia, serif);
	font-size: 1.75rem;
	margin-bottom: 1.5rem;
}

.event-booking-details {
	margin-bottom: 1.5rem;
	padding: 1.5rem;
	background-color: var(--wp--preset--color--light-beige, #E8DED0);
	border-radius: 8px;
}

.event-date-info,
.event-location-info,
.event-deadline-info {
	margin-bottom: 0.75rem;
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	font-size: 1rem;
	line-height: 1.6;
}

.event-date-info:last-child,
.event-location-info:last-child,
.event-deadline-info:last-child {
	margin-bottom: 0;
}

.event-date-info strong,
.event-location-info strong,
.event-deadline-info strong {
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	font-weight: 600;
	margin-right: 0.5rem;
}

.booking-success-message {
	padding: 1.5rem;
	background-color: var(--wp--preset--color--soft-green, #8B9A7A);
	color: var(--wp--preset--color--white, #ffffff);
	border-radius: 8px;
	margin-bottom: 1.5rem;
	text-align: center;
}

.booking-full {
	padding: 1.5rem;
	background-color: var(--wp--preset--color--terracotta, #C97D60);
	color: var(--wp--preset--color--white, #ffffff);
	border-radius: 8px;
	text-align: center;
	font-weight: 500;
}

.booking-form {
	margin-top: 1.5rem;
}

.form-group {
	margin-bottom: 1.5rem;
}

.form-group label {
	display: block;
	margin-bottom: 0.5rem;
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	font-weight: 500;
}

.form-group .required {
	color: var(--wp--preset--color--terracotta, #C97D60);
}

.form-control {
	width: 100%;
	padding: 0.75rem;
	border: 1px solid var(--wp--preset--color--beige, #D4C4B0);
	border-radius: 8px;
	font-size: 1rem;
	font-family: inherit;
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	background-color: var(--wp--preset--color--white, #ffffff);
	transition: border-color 0.2s ease;
}

.form-control:focus {
	outline: none;
	border-color: var(--wp--preset--color--terracotta, #C97D60);
	box-shadow: 0 0 0 3px rgba(201, 125, 96, 0.1);
}

.form-control textarea {
	resize: vertical;
	min-height: 100px;
}

.booking-submit-button {
	background-color: var(--wp--preset--color--terracotta, #C97D60);
	color: var(--wp--preset--color--white, #ffffff);
	padding: 1rem 2rem;
	border: none;
	border-radius: 8px;
	font-size: 1rem;
	font-weight: 500;
	cursor: pointer;
	transition: background-color 0.2s ease;
	width: 100%;
}

.booking-submit-button:hover {
	background-color: var(--wp--preset--color--brown, #6B5B4F);
}

.booking-submit-button:focus {
	outline: 2px solid var(--wp--preset--color--terracotta, #C97D60);
	outline-offset: 2px;
}

/* Thank You Page */
.booking-confirmation-details {
	margin: 2rem 0;
	padding: 1.5rem;
	background-color: var(--wp--preset--color--light-beige, #E8DED0);
	border-radius: 8px;
}

.booking-confirmation-details h3 {
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	font-family: var(--wp--preset--font-family--serif, Georgia, serif);
	margin-bottom: 1rem;
}

.booking-confirmation-details p {
	margin-bottom: 0.5rem;
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
}

.booking-confirmation-details strong {
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
}

/* Responsive Design */
@media (max-width: 782px) {
	.events-overview {
		gap: 1.5rem;
	}

	.event-card {
		padding: 1.5rem;
	}

	.event-card-inner {
		flex-direction: column;
		gap: 1.5rem;
	}

	.event-image {
		width: 100%;
	}

	.booking-form-container {
		margin: 1rem;
		padding: 1.5rem;
	}
}

/* Admin Styles */
.booking-details-row {
	background-color: #f9f9f9;
}

.booking-details-row td {
	padding: 1rem 2rem;
}

/* Single Event Page Styles */
.event-meta-info {
	margin-bottom: 2rem;
	padding: 1.5rem;
	background-color: var(--wp--preset--color--white, #ffffff);
	border-radius: 12px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.event-date-time,
.event-location,
.event-booking-deadline {
	margin-bottom: 1rem;
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	font-size: 1.1rem;
	line-height: 1.6;
}

.event-date-time:last-child,
.event-location:last-child,
.event-booking-deadline:last-child {
	margin-bottom: 0;
}

.event-date-time strong,
.event-location strong,
.event-booking-deadline strong {
	color: var(--wp--preset--color--terracotta, #C97D60);
	font-weight: 600;
	margin-right: 0.5rem;
}

.event-additional-info {
	margin: 2rem 0;
	padding: 1.5rem;
	background-color: var(--wp--preset--color--light-beige, #E8DED0);
	border-radius: 12px;
}

.event-additional-info h3 {
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	font-family: var(--wp--preset--font-family--serif, Georgia, serif);
	margin-bottom: 1rem;
}

.event-booking-cta-box {
	margin: 2rem 0;
	padding: 2rem;
	background: linear-gradient(135deg, var(--wp--preset--color--terracotta, #C97D60) 0%, var(--wp--preset--color--dark-brown, #3A2E2A) 100%);
	border-radius: 12px;
	text-align: center;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.booking-cta-button {
	display: inline-block;
	padding: 1.25rem 3rem;
	background-color: var(--wp--preset--color--white, #ffffff);
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
	font-size: 1.25rem;
	font-weight: 700;
	text-decoration: none;
	border-radius: 8px;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.booking-cta-button:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
	color: var(--wp--preset--color--dark-brown, #3A2E2A);
}

.booking-cta-hint {
	margin-top: 1rem;
	color: var(--wp--preset--color--white, #ffffff);
	font-size: 0.9rem;
	opacity: 0.9;
}

.booking-status-message {
	margin: 0;
	color: var(--wp--preset--color--white, #ffffff);
	font-size: 1.1rem;
	font-weight: 600;
}

.booking-status-message.full {
	background-color: rgba(255, 255, 255, 0.2);
	padding: 1rem;
	border-radius: 8px;
}

.booking-status-message.closed {
	background-color: rgba(255, 255, 255, 0.2);
	padding: 1rem;
	border-radius: 8px;
}

.booking-status-message.no-booking {
	background-color: rgba(255, 255, 255, 0.2);
	padding: 1rem;
	border-radius: 8px;
}

.event-booking-section {
	margin-top: 2rem;
	padding-top: 2rem;
	border-top: 2px solid var(--wp--preset--color--light-beige, #E8DED0);
	text-align: center;
}

