/* ==========================================================================
	Cairn Booking — Single Template Styles
	Shared across events, activities, and stays
	========================================================================== */

:root {
	--cairn-green: #2C432E;
	--cairn-green-light: #3a5a3d;
	--cairn-green-pale: #e8efe9;
	--cairn-green-muted: #6b8a6e;
	--cairn-text: #1a1a1a;
	--cairn-text-light: #555;
	--cairn-border: #dde2dd;
	--cairn-bg-soft: #f5f7f5;
	--cairn-radius: 8px;
	--cairn-radius-sm: 4px;
}

/* ---------- Hero Cover Overrides ---------- */
.cairn-single-cover .wp-block-cover__inner-container {
	padding: 3rem 1rem;
}

.cairn-single-cover .cairn-event-title,
.cairn-single-cover .cairn-activity-title,
.cairn-single-cover .cairn-stays-title {
	font-weight: 700;
	text-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
}

/* ---------- Collapse empty sidebar column (contact-form activities) ---------- */
.wp-block-columns > .wp-block-column:empty {
	display: none;
}

.wp-block-columns > .wp-block-column:empty + .wp-block-column {
	flex-basis: 100% !important;
}

/* ---------- Meta Sidebar ---------- */
.cairn-meta-sidebar {
	background: var(--cairn-bg-soft);
	border: 1px solid var(--cairn-border);
	border-radius: var(--cairn-radius);
	padding: 1.5rem;
	gap: 0 !important;
}

.cairn-meta-item {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.875rem 0;
	border-bottom: 1px solid var(--cairn-border);
	margin: 0;
	color: var(--cairn-text);
	font-size: 0.95rem;
	line-height: 1.4;
}

.cairn-meta-item:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.cairn-meta-item:first-child {
	padding-top: 0;
}

.cairn-meta-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	min-width: 36px;
	background: var(--cb-primary, #2c432e);
	border-radius: 50%;
	color: var(--cb-primary-text, #ffffff);
}

.cairn-meta-icon svg {
	width: 18px;
	height: 18px;
	fill: var(--cb-primary-text, #ffffff);
}

.cairn-meta-label {
	display: block;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--cb-secondary-text, #3f5942);
	font-weight: 600;
	margin-bottom: 0.125rem;
}

.cairn-meta-value {
	display: block;
	font-weight: 600;
	color: var(--cairn-text);
	font-size: 1rem;
}

.cairn-meta-value.cairn-price-value {
	color: var(--cb-primary, #2c432e);
	font-size: 1.15rem;
}

.cairn-spots-badge {
	display: inline-block;
	background: var(--cb-secondary, #e8efe9);
	color: var(--cb-secondary-text, #2c432e);
	font-weight: 600;
	font-size: 0.85rem;
	padding: 0.25rem 0.75rem;
	border-radius: 20px;
}

/* ---------- Content Area ---------- */
.cairn-content-area {
	font-size: 1.05rem;
	line-height: 1.8;
	color: var(--cairn-text-light);
}

.cairn-content-area h2,
.cairn-content-area h3 {
	color: var(--cairn-text);
	margin-top: 2rem;
}

/* ---------- Section Divider ---------- */
.cairn-divider {
	border: none;
	border-top: 2px solid var(--cairn-green-pale);
	margin: 2.5rem 0;
}

/* ---------- Booking Form Section ---------- */
.cairn-booking-section {
	margin-top: 2rem;
}

.cairn-booking-section .wp-block-cairn-booking-event-booking-form,
.cairn-booking-section .wp-block-cairn-booking-flexible-booking-form,
.cairn-booking-section #cairn-flexible-booking-form {
	background: var(--cairn-bg-soft);
	border: 1px solid var(--cairn-border);
	border-radius: var(--cairn-radius);
	padding: 2rem;
}

.cairn-event-booking-form,
.cairn-booking-form {
	max-width: 100%;
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	box-shadow: none;
}

.cairn-event-booking-form h3,
.cairn-booking-form h3,
.cairn-booking-section h3 {
	color: var(--cb-primary, #2c432e);
	margin-top: 0;
	margin-bottom: 1.5rem;
	font-size: 1.25rem;
}

/* Calendar container */
#calendarContainer {
	margin-bottom: 1rem;
}

#calendarContainer .flatpickr-calendar {
	border: 1px solid var(--cairn-border);
	border-radius: var(--cairn-radius);
	box-shadow: none;
	width: 100%;
	max-width: 100%;
}

#calendarContainer .flatpickr-calendar .flatpickr-months {
	background: #2C432E !important;
	border-radius: var(--cairn-radius) var(--cairn-radius) 0 0;
}

#calendarContainer .flatpickr-calendar .flatpickr-months .flatpickr-month,
#calendarContainer .flatpickr-calendar .flatpickr-current-month,
#calendarContainer .flatpickr-calendar .flatpickr-current-month .cur-month,
#calendarContainer .flatpickr-calendar .flatpickr-current-month .numInputWrapper,
#calendarContainer .flatpickr-calendar .flatpickr-current-month input.cur-year {
	color: #fff !important;
	fill: #fff !important;
	background: transparent !important;
}

#calendarContainer .flatpickr-calendar .flatpickr-months .flatpickr-prev-month,
#calendarContainer .flatpickr-calendar .flatpickr-months .flatpickr-next-month {
	fill: #fff !important;
	color: #fff !important;
}

#calendarContainer .flatpickr-calendar .flatpickr-months .flatpickr-prev-month:hover svg,
#calendarContainer .flatpickr-calendar .flatpickr-months .flatpickr-next-month:hover svg {
	fill: #c8d8ca !important;
}

#calendarContainer .flatpickr-calendar .flatpickr-weekdays {
	background: #2C432E !important;
}

#calendarContainer .flatpickr-calendar span.flatpickr-weekday {
	color: rgba(255, 255, 255, 0.85) !important;
	background: transparent !important;
	font-weight: 600;
}

#calendarContainer .flatpickr-calendar .flatpickr-day.selected,
#calendarContainer .flatpickr-calendar .flatpickr-day.selected:hover {
	background: #2C432E !important;
	border-color: #2C432E !important;
	color: #fff !important;
}

#calendarContainer .flatpickr-calendar .flatpickr-day:hover {
	background: #c8d8ca !important;
	border-color: #c8d8ca !important;
}

#calendarContainer .flatpickr-calendar .flatpickr-day.today {
	border-color: #2C432E !important;
}

#calendarContainer .flatpickr-calendar .flatpickr-day.today:hover {
	background: #c8d8ca !important;
	border-color: #2C432E !important;
}

/* Per-date spot indicators */
#calendarContainer .flatpickr-day {
	position: relative;
}

.cairn-date-spots {
	position: absolute;
	bottom: 1px;
	right: 2px;
	font-size: 8px;
	line-height: 1;
	color: #2C432E;
	font-weight: 600;
	opacity: 0.7;
}

.cairn-form-row {
	margin-bottom: 1.25rem;
}

.cairn-event-booking-form label,
.cairn-booking-form label {
	display: block;
	margin-bottom: 0.4rem;
	font-weight: 500;
	color: var(--cairn-text);
	font-size: 0.9rem;
}

.cairn-event-booking-form input[type="text"],
.cairn-event-booking-form input[type="email"],
.cairn-event-booking-form input[type="number"],
.cairn-booking-form input[type="text"],
.cairn-booking-form input[type="email"],
.cairn-booking-form input[type="number"],
.cairn-booking-form input[id="contact_name"] {
	width: 97%;
	padding: 0.7rem 0.9rem;
	border: 1px solid var(--cairn-border);
	border-radius: var(--cairn-radius-sm);
	font-size: 1rem;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	background: #fff;
}
.cairn-event-booking-form textarea[id="contact_message"] {
	width: 98%;
}

.cairn-event-booking-form input:focus,
.cairn-booking-form input:focus {
	outline: none;
	border-color: var(--cb-primary, #2c432e);
	box-shadow: 0 0 0 3px rgba(44, 67, 46, 0.12);
}

/* Stripe card element */
#card-element {
	padding: 0.75rem 0.9rem;
	border: 1px solid var(--cairn-border);
	border-radius: var(--cairn-radius-sm);
	background: #fff;
	margin-bottom: 0.5rem;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

#card-element.StripeElement--focus {
	border-color: var(--cb-primary, #2c432e);
	box-shadow: 0 0 0 3px rgba(44, 67, 46, 0.12);
}

#card-errors {
	color: #dc3545;
	font-size: 0.85rem;
	margin-top: 0.4rem;
}

/* Quantity + Price flex row */
.cairn-form-flex {
	display: flex;
	gap: 2rem;
	align-items: flex-start;
}

.cairn-form-flex > div {
	flex: 1;
}

.cairn-quantity-input {
	width: 80px !important;
}

.cairn-help-text {
	font-size: 0.8rem;
	color: var(--cairn-muted);
	margin-top: 0.3rem;
}

.cairn-price,
.price-display {
	font-size: 1.2rem;
	font-weight: 600;
	color: var(--cb-primary, #2c432e);
}

.cairn-total {
	font-size: 1.2rem;
	font-weight: 600;
	color: var(--cb-primary, #2c432e);
}

/* ---------- Buttons ---------- */
.cairn-submit-button,
.cairn-event-booking-form button[type="submit"],
.cairn-booking-form button[type="submit"] {
	display: block;
	width: 100%;
	padding: 0.85rem 1.5rem;
	background-color: var(--cb-calendar-header-bg, #2c432e);
	color: var(--cb-calendar-header-text, #ffffff);
	border: none;
	border-radius: var(--cairn-radius-sm);
	font-size: 1rem;
	font-weight: 600;
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.1s ease;
	letter-spacing: 0.02em;
}

.cairn-submit-button:hover,
.cairn-event-booking-form button[type="submit"]:hover,
.cairn-booking-form button[type="submit"]:hover {
	background-color: var(--cb-primary-hover, #3a5a3d);
}

.cairn-submit-button:active,
.cairn-event-booking-form button[type="submit"]:active,
.cairn-booking-form button[type="submit"]:active {
	transform: translateY(1px);
}

.cairn-submit-button:disabled {
	background-color: #999;
	cursor: not-allowed;
	transform: none;
}

/* ---------- Price Display ---------- */
.cairn-price, .cairn-total {
	display: inline-block;
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--cb-primary, #2c432e);
}

.cairn-quantity-price-inputs {
	display: flex;
	gap: 1.5rem;
	align-items: flex-start;
}

.cairn-quantity-field {
	flex: 1;
}

.cairn-price-field {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.cairn-base-price,
.cairn-total-price {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.cairn-base-price span,
.cairn-total-price span {
	font-weight: 600;
}

.cairn-total-price span {
	color: var(--cb-primary, #2c432e);
	font-size: 1.15rem;
}

.cairn-help-text {
	display: block;
	font-size: 0.8rem;
	color: var(--cairn-green-muted);
	margin-top: 0.3rem;
}

/* ---------- Messages ---------- */
.cairn-message,
.success-message {
	padding: 12px;
	border-radius: 6px;
	margin-bottom: 1em;
	font-size: 0.95rem;
	font-weight: 500;
}

.cairn-message--success,
.success-message {
	background: #f0fdf4;
	border: 1px solid #bbf7d0;
	color: #166534;
}

.cairn-message--error,
.error-message {
	padding: 12px;
	background: #fef2f2;
	border: 1px solid #fecaca;
	border-radius: 6px;
	color: #991b1b;
}

/* ---------- Responsive ---------- */
@media (max-width: 781px) {
	.cairn-quantity-price-inputs {
		flex-direction: column;
		gap: 1rem;
	}

	.cairn-event-booking-form,
	.cairn-booking-form {
		padding: 1.25rem;
	}
}
