/* ==========================================================================
   Safari Premium — Single (excursion / accommodation / car) layout
   Two-column body with sticky right rail booking widget.
   ========================================================================== */

.sp-single {
	background: var(--sp-color-cream);
}

/* Top: breadcrumb + gallery */
.sp-single__top {
	background: var(--sp-color-off-white);
	padding: 32px 0 24px;
}
.sp-single__breadcrumbs { margin-bottom: 18px; }

/* Hero gallery */
.sp-single__hero {
	position: relative;
	border-radius: var(--sp-radius-xl);
	overflow: hidden;
}
.sp-single__hero .sp-placeholder { aspect-ratio: 21 / 9; }
.sp-single__thumbs {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 10px;
	margin-top: 12px;
}
.sp-single__thumbs .sp-placeholder {
	aspect-ratio: 4 / 3;
	border-radius: var(--sp-radius-sm);
	overflow: hidden;
}

/* Gallery grid (used on accommodations) */
.sp-gallery-grid {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr;
	grid-template-rows: 200px 200px;
	gap: 10px;
	border-radius: var(--sp-radius-xl);
	overflow: hidden;
}
.sp-gallery-grid .sp-placeholder { aspect-ratio: auto; height: 100%; }
.sp-gallery-grid__hero { grid-row: span 2; }
.sp-gallery-grid__more {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--sp-color-cream);
	font-family: var(--sp-font-sans);
	font-size: var(--sp-text-sm);
	font-weight: 600;
	background: rgba(92,46,10,0.3);
}
.sp-gallery-cell { position: relative; }
@media (max-width: 767px) {
	.sp-gallery-grid {
		grid-template-columns: 2fr 1fr;
		grid-template-rows: 160px 160px;
	}
}

/* Body */
.sp-single__body { padding: 48px 0 96px; }
.sp-single__body-inner {
	display: grid;
	grid-template-columns: 1fr 380px;
	gap: 56px;
	align-items: start;
}
.sp-single--wide-rail .sp-single__body-inner { grid-template-columns: 1fr 400px; }
.sp-single__title {
	font-family: var(--sp-font-serif);
	font-size: 52px;
	font-weight: 500;
	line-height: var(--sp-leading-tight);
	letter-spacing: var(--sp-tracking-tight);
	margin: 14px 0 16px;
	color: var(--sp-color-brown);
}
.sp-single__rail {
	position: sticky;
	top: calc(var(--sp-header-height) + 20px);
}
.sp-single__rail-card {
	background: var(--sp-color-off-white);
	border-radius: var(--sp-radius-2xl);
	border: 1px solid var(--sp-color-card-border);
	padding: 28px;
	box-shadow: var(--sp-shadow-card);
}
.sp-single__rail-price {
	display: flex;
	align-items: baseline;
	gap: 6px;
	margin-bottom: 4px;
}
.sp-single__rail-price-amount {
	font-family: var(--sp-font-serif);
	font-size: 34px;
	font-weight: 500;
	color: var(--sp-color-brown);
	font-variant-numeric: tabular-nums;
}
.sp-single__rail-meta {
	font-size: var(--sp-text-sm);
	color: var(--sp-color-muted-brown);
	margin-bottom: 20px;
}
.sp-single__rail-form {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

/* Date split (check-in / check-out) */
.sp-date-split {
	display: grid;
	grid-template-columns: 1fr 1fr;
	border: 1px solid var(--sp-color-card-border);
	border-radius: var(--sp-radius-md);
	overflow: hidden;
	margin-bottom: 14px;
}
.sp-date-split__cell { padding: 14px; }
.sp-date-split__cell + .sp-date-split__cell { border-left: 1px solid var(--sp-color-card-border); }
.sp-date-split__label {
	font-size: 11px;
	color: var(--sp-color-muted-brown);
	letter-spacing: var(--sp-tracking-wide);
	text-transform: uppercase;
	font-weight: 600;
}
.sp-date-split__value {
	font-size: var(--sp-text-base);
	color: var(--sp-color-brown);
	margin-top: 4px;
}

/* Total summary */
.sp-total {
	padding: 16px 0;
	border-top: 1px solid var(--sp-color-ivory);
	border-bottom: 1px solid var(--sp-color-ivory);
	margin-bottom: 20px;
	font-size: var(--sp-text-base);
}
.sp-total__row {
	display: flex;
	justify-content: space-between;
	margin-bottom: 6px;
}
.sp-total__row span:first-child { color: var(--sp-color-muted-brown); }
.sp-total__row span:last-child { color: var(--sp-color-brown); font-variant-numeric: tabular-nums; }
.sp-total__grand {
	display: flex;
	justify-content: space-between;
	font-family: var(--sp-font-serif);
	font-size: var(--sp-text-xl);
	color: var(--sp-color-brown);
	margin-top: 10px;
}
.sp-total__grand span:last-child { font-variant-numeric: tabular-nums; }

/* Meta bar (single excursion) */
.sp-meta-bar {
	display: flex;
	flex-wrap: wrap;
	gap: 28px;
	padding: 20px 0;
	border-top: 1px solid var(--sp-color-ivory);
	border-bottom: 1px solid var(--sp-color-ivory);
	margin-bottom: 36px;
	align-items: center;
}
.sp-meta-bar__item {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: var(--sp-text-base);
	color: var(--sp-color-muted-brown);
}
.sp-meta-bar__item .sp-icon { color: var(--sp-color-burnt-orange); }
.sp-meta-bar__rating {
	margin-left: auto;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.sp-meta-bar__rating-value {
	font-size: var(--sp-text-base);
	color: var(--sp-color-brown);
	margin-left: 6px;
	font-weight: 500;
}
.sp-meta-bar__rating-count {
	font-size: var(--sp-text-sm);
	color: var(--sp-color-muted-brown);
}

/* Section heading inside single */
.sp-single h2 {
	font-family: var(--sp-font-serif);
	font-size: 28px;
	font-weight: 500;
	margin: 0 0 14px;
	color: var(--sp-color-brown);
}
.sp-single h2 + p { margin-top: 0; }
.sp-single__prose p {
	font-size: var(--sp-text-lg);
	line-height: var(--sp-leading-prose);
	color: var(--sp-color-brown);
	margin: 0 0 14px;
}
.sp-single__prose-block { margin-bottom: 40px; }

/* Itinerary timeline */
.sp-itinerary {
	position: relative;
	padding-left: 32px;
	margin-bottom: 48px;
}
.sp-itinerary::before {
	content: "";
	position: absolute;
	left: 14px;
	top: 10px;
	bottom: 10px;
	width: 2px;
	background: var(--sp-color-ivory);
}
.sp-itinerary__step { margin-bottom: 24px; position: relative; }
.sp-itinerary__step:last-child { margin-bottom: 0; }
.sp-itinerary__step-marker {
	position: absolute;
	left: -32px;
	top: 2px;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background: var(--sp-gradient-sunset);
	color: var(--sp-color-cream);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: var(--sp-text-xs);
	font-weight: 600;
	font-family: var(--sp-font-sans);
}
.sp-itinerary__step-time {
	font-family: var(--sp-font-sans);
	font-size: var(--sp-text-xs);
	color: var(--sp-color-burnt-orange);
	font-weight: 600;
	letter-spacing: 0.1em;
}
.sp-itinerary__step-title {
	font-family: var(--sp-font-serif);
	font-size: 19px;
	color: var(--sp-color-brown);
	margin: 4px 0 6px;
}
.sp-itinerary__step-body {
	font-size: 14.5px;
	line-height: var(--sp-leading-base);
	color: var(--sp-color-muted-brown);
}

/* Included / Excluded */
.sp-included {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 32px;
	margin-bottom: 48px;
}
.sp-included__col h3 {
	font-family: var(--sp-font-serif);
	font-size: 22px;
	font-weight: 500;
	margin: 0 0 16px;
	color: var(--sp-color-brown);
}
.sp-included__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.sp-included__list li {
	display: flex;
	gap: 10px;
	font-size: 14.5px;
	color: var(--sp-color-brown);
}
.sp-included__list--in li .sp-icon { color: var(--sp-color-burnt-orange); flex-shrink: 0; margin-top: 2px; }
.sp-included__list--out li .sp-icon { color: var(--sp-color-muted-brown); flex-shrink: 0; margin-top: 2px; }
@media (max-width: 767px) {
	.sp-included { grid-template-columns: 1fr; gap: 24px; }
}

/* Meeting point card */
.sp-meeting {
	display: grid;
	grid-template-columns: 1.5fr 1fr;
	border: 1px solid var(--sp-color-card-border);
	border-radius: var(--sp-radius-xl);
	overflow: hidden;
	background: var(--sp-color-off-white);
}
.sp-meeting__map .sp-placeholder { aspect-ratio: auto; height: 100%; }
.sp-meeting__details { padding: 24px; }
.sp-meeting__label { font-size: var(--sp-text-sm); color: var(--sp-color-muted-brown); margin-bottom: 6px; letter-spacing: var(--sp-tracking-wide); text-transform: uppercase; font-weight: 600; }
.sp-meeting__address { font-family: var(--sp-font-serif); font-size: 20px; color: var(--sp-color-brown); margin-bottom: 12px; }
.sp-meeting__copy { font-size: var(--sp-text-base); line-height: var(--sp-leading-prose); color: var(--sp-color-muted-brown); }
.sp-meeting__link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 16px;
	font-size: var(--sp-text-sm);
	color: var(--sp-color-burnt-orange);
	font-weight: 500;
	text-decoration: none;
}
@media (max-width: 767px) {
	.sp-meeting { grid-template-columns: 1fr; }
	.sp-meeting__map .sp-placeholder { aspect-ratio: 16 / 9; }
}

/* Amenities grid (single accommodation) */
.sp-amenities-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	margin-bottom: 48px;
}
.sp-amenities-grid__item {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px;
	background: var(--sp-color-off-white);
	border-radius: var(--sp-radius-md);
	border: 1px solid var(--sp-color-card-border);
	font-size: var(--sp-text-base);
	color: var(--sp-color-brown);
}
.sp-amenities-grid__item .sp-icon { color: var(--sp-color-burnt-orange); flex-shrink: 0; }
@media (max-width: 767px) {
	.sp-amenities-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
	.sp-amenities-grid__item { padding: 12px; font-size: 13px; }
}

/* Room cards (inside single accommodation) */
.sp-rooms {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
	margin-bottom: 48px;
}
.sp-rooms__card {
	background: var(--sp-color-off-white);
	border: 1px solid var(--sp-color-card-border);
	border-radius: var(--sp-radius-xl);
	overflow: hidden;
	box-shadow: var(--sp-shadow-card);
}
.sp-rooms__card .sp-placeholder { aspect-ratio: 16 / 10; }
.sp-rooms__body { padding: 20px; }
.sp-rooms__body-meta {
	font-size: var(--sp-text-sm);
	color: var(--sp-color-muted-brown);
	margin: 6px 0 12px;
	display: flex;
	gap: 12px;
}
.sp-rooms__body-foot {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
}
.sp-rooms__price {
	font-family: var(--sp-font-serif);
	font-size: 24px;
	font-weight: 500;
	color: var(--sp-color-brown);
}
.sp-rooms__price-unit { font-size: var(--sp-text-sm); color: var(--sp-color-muted-brown); }
.sp-rooms__select { font-size: var(--sp-text-sm); color: var(--sp-color-burnt-orange); font-weight: 500; text-decoration: none; }
@media (max-width: 767px) {
	.sp-rooms { grid-template-columns: 1fr; }
}

/* Distance / spec stats row */
.sp-stat-row {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	margin: 16px 0 48px;
}
.sp-stat {
	padding: 16px 20px;
	background: var(--sp-color-off-white);
	border-radius: var(--sp-radius-md);
	border: 1px solid var(--sp-color-card-border);
}
.sp-stat__value {
	font-family: var(--sp-font-serif);
	font-size: 22px;
	color: var(--sp-color-brown);
	font-variant-numeric: tabular-nums;
}
.sp-stat__label { font-size: var(--sp-text-sm); color: var(--sp-color-muted-brown); }

/* Policies grid */
.sp-policies {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
	margin-bottom: 48px;
}
.sp-policies__item {
	padding: 18px 0;
	border-top: 1px solid var(--sp-color-ivory);
}
.sp-policies__label { font-size: var(--sp-text-sm); color: var(--sp-color-muted-brown); margin-bottom: 4px; }
.sp-policies__value { font-size: var(--sp-text-md); color: var(--sp-color-brown); font-weight: 500; }
@media (max-width: 767px) {
	.sp-policies { grid-template-columns: 1fr; gap: 0; }
}

/* Specs table (single car) */
.sp-specs {
	background: var(--sp-color-off-white);
	border-radius: var(--sp-radius-xl);
	border: 1px solid var(--sp-color-card-border);
	overflow: hidden;
	margin-bottom: 48px;
}
.sp-specs__row {
	display: grid;
	grid-template-columns: 1fr 2fr;
	padding: 16px 24px;
	border-bottom: 1px solid var(--sp-color-ivory);
	font-size: 14.5px;
}
.sp-specs__row:last-child { border-bottom: 0; }
.sp-specs__row dt { color: var(--sp-color-muted-brown); margin: 0; }
.sp-specs__row dd { color: var(--sp-color-brown); font-weight: 500; margin: 0; }

/* Features grid (single car) */
.sp-features-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 14px;
	margin-bottom: 48px;
}
.sp-features-grid__item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px;
	background: var(--sp-color-off-white);
	border-radius: var(--sp-radius-sm);
	border: 1px solid var(--sp-color-card-border);
	font-size: var(--sp-text-base);
	color: var(--sp-color-brown);
}
.sp-features-grid__item .sp-icon { color: var(--sp-color-burnt-orange); flex-shrink: 0; }
@media (max-width: 767px) {
	.sp-features-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
	.sp-features-grid__item { padding: 10px; font-size: 13px; }
}

/* Rental terms list (single car) */
.sp-terms {
	list-style: none;
	padding: 0;
	margin: 0 0 18px;
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.sp-terms li {
	display: flex;
	gap: 12px;
	font-size: 14.5px;
	color: var(--sp-color-brown);
}
.sp-terms li .sp-icon { color: var(--sp-color-burnt-orange); flex-shrink: 0; margin-top: 2px; }

/* Add-on rows (sticky rail on single car) */
.sp-addons-title {
	font-size: var(--sp-text-xs);
	font-weight: 600;
	letter-spacing: var(--sp-tracking-wide);
	text-transform: uppercase;
	color: var(--sp-color-muted-brown);
	margin-bottom: 12px;
}
.sp-addon {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 0;
	border-bottom: 1px solid var(--sp-color-ivory);
	font-size: var(--sp-text-base);
	color: var(--sp-color-brown);
	cursor: pointer;
}
.sp-addon__price { color: var(--sp-color-muted-brown); font-size: var(--sp-text-sm); font-variant-numeric: tabular-nums; }
.sp-addon__label { flex: 1; }
.sp-addon .sp-checkbox__box {
	width: 18px;
	height: 18px;
	border-radius: 4px;
	border: 1.5px solid var(--sp-color-muted-brown);
	background: transparent;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: all var(--sp-dur-2) var(--sp-ease);
}
.sp-addon.is-checked .sp-checkbox__box {
	background: var(--sp-color-burnt-orange);
	border-color: var(--sp-color-burnt-orange);
	color: var(--sp-color-cream);
}

/* Two-up rail grid for adult/children inputs */
.sp-rail-grid-2 {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}
.sp-form-tos {
	font-size: var(--sp-text-xs);
	color: var(--sp-color-muted-brown);
}

/* Mobile-only: rail collapses below content */
@media (max-width: 1023px) {
	.sp-single__body-inner,
	.sp-single--wide-rail .sp-single__body-inner {
		grid-template-columns: 1fr;
	}
	.sp-single__rail { position: static; }
}
@media (max-width: 767px) {
	.sp-single__body { padding: 32px 0 64px; }
	.sp-single__title { font-size: 32px; }
	.sp-single h2 { font-size: 22px; }
	.sp-single__prose p { font-size: var(--sp-text-base); }
	.sp-meta-bar { gap: 14px; padding: 14px 0; margin-bottom: 24px; }
	.sp-meta-bar__rating { margin-left: 0; width: 100%; padding-top: 8px; border-top: 1px solid var(--sp-color-ivory); }
	.sp-itinerary__step-title { font-size: 17px; }
}

/* (Car-rental hero search styles were removed: the hero now reuses the shared
   .sp-page-hero--search modifier + search-widget, styled in components.css,
   which loads on the archive page. single.css is not enqueued there.) */
