/* =========================================================
   Soul Vacation — WordPress chrome additions
   Styles for elements added in the WP theme that were not in
   the original static build: the header actions wrapper, the
   slide-down search panel, and the in-content social share row.
   Tokens come from styles.css.
   ========================================================= */

/* --- Header actions (search + reserve + burger live in col 3) --- */
.sv-header__actions {
	justify-self: end;
	display: flex;
	align-items: center;
	gap: 22px;
}
.sv-search-toggle {
	background: transparent;
	border: 0;
	padding: 4px;
	color: inherit;
	cursor: pointer;
	display: inline-flex;
	line-height: 0;
	opacity: 0.9;
	transition: opacity calc(300ms * var(--motion-scale)) var(--ease-out);
}
.sv-search-toggle:hover { opacity: 1; }
.sv-header__actions .sv-reserve { justify-self: auto; }

/* On mobile the original CSS hides .sv-reserve and shows .sv-burger.
   Keep the search toggle visible alongside the burger. */
@media (max-width: 900px) {
	.sv-header__actions { gap: 14px; }
}

/* --- Slide-down search panel (from the top) --- */
.sv-search {
	position: fixed;
	inset: 0 0 auto 0;
	z-index: 60;
	background: var(--c-pearl);
	color: var(--c-charcoal);
	transform: translateY(-100%);
	transition: transform calc(520ms * var(--motion-scale)) var(--ease-drawer);
	box-shadow: 0 18px 60px -28px rgba(8,16,24,0.5);
	will-change: transform;
}
.sv-search.is-open { transform: translateY(0); }
.sv-search__inner {
	max-width: 1100px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	gap: 24px;
	padding: 30px 52px;
}
.sv-search__form {
	flex: 1;
	display: flex;
	align-items: center;
	gap: 18px;
	border-bottom: 1px solid rgba(14,22,32,0.18);
}
.sv-search__form input[type="search"] {
	flex: 1;
	border: 0;
	background: transparent;
	font-family: var(--f-display);
	font-style: italic;
	font-weight: 300;
	font-size: clamp(22px, 3.4vw, 38px);
	color: var(--c-charcoal);
	padding: 10px 0;
	outline: none;
}
.sv-search__form input[type="search"]::placeholder {
	color: rgba(14,22,32,0.35);
}
.sv-search__submit {
	background: transparent;
	border: 0;
	font-family: var(--f-body);
	font-size: 11px;
	letter-spacing: var(--track-nav);
	text-transform: uppercase;
	color: var(--c-slate);
	cursor: pointer;
	padding: 8px 0;
	white-space: nowrap;
}
.sv-search__close {
	position: relative;
	width: 36px; height: 36px;
	background: transparent;
	border: 0;
	cursor: pointer;
	color: var(--c-charcoal);
	flex: none;
}
.sv-search__close span {
	position: absolute;
	left: 6px; right: 6px; top: 50%;
	height: 1px;
	background: currentColor;
}
.sv-search__close span:nth-child(1) { transform: rotate(45deg); }
.sv-search__close span:nth-child(2) { transform: rotate(-45deg); }
@media (max-width: 700px) {
	.sv-search__inner { padding: 22px 24px; gap: 14px; }
}

/* When search is open, prevent body scroll jump (paired with JS class). */
html.sv-search-open { overflow: hidden; }

/* --- In-content social share row (journal stories) --- */
.sv-share {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 16px;
	margin: 40px 0;
	padding: 22px 0;
	border-top: 1px solid rgba(14,22,32,0.12);
	border-bottom: 1px solid rgba(14,22,32,0.12);
}
.sv-share__lab {
	font-family: var(--f-display);
	font-style: italic;
	font-weight: 300;
	font-size: 16px;
	color: rgba(14,22,32,0.55);
	margin-right: 4px;
}
.sv-share__link {
	font-family: var(--f-body);
	font-size: 11px;
	letter-spacing: var(--track-nav);
	text-transform: uppercase;
	color: var(--c-slate);
	padding: 6px 0;
	position: relative;
	transition: color calc(300ms * var(--motion-scale)) var(--ease-out);
}
.sv-share__link::after {
	content: "";
	position: absolute;
	left: 0; right: 0; bottom: 0;
	height: 1px;
	background: currentColor;
	opacity: 0;
	transform: scaleX(0);
	transform-origin: left;
	transition: transform calc(360ms * var(--motion-scale)) var(--ease-out),
				opacity calc(240ms * var(--motion-scale)) var(--ease-out);
}
.sv-share__link:hover { color: var(--c-aegean); }
.sv-share__link:hover::after { opacity: 0.8; transform: scaleX(1); }

/* --- Empty image-slot fallback (before client uploads photos) --- */
.sv-img--empty {
	background: linear-gradient(135deg, var(--c-bone), var(--c-pearl));
	min-height: 100%;
	width: 100%;
}

/* --- Search results / archive grid (uses journal card styling) --- */
.sv-results {
	max-width: 1100px;
	margin: 0 auto;
	padding: 140px 52px 100px;
}
.sv-results__head { margin-bottom: 48px; }
@media (max-width: 700px) {
	.sv-results { padding: 110px 24px 70px; }
}

/* =========================================================
   Button compatibility + new template utilities
   The static build used page-specific CTA classes and the
   generic .btn-solid / .btn-outline. The WP templates use a
   normalised .btn / .btn--solid / .btn--ghost trio; map them
   to the same visual language here.
   ========================================================= */
.btn {
	display: inline-block;
	cursor: pointer;
	font-family: var(--f-body);
	font-weight: 400;
	font-size: 11px;
	letter-spacing: var(--track-nav);
	text-transform: uppercase;
	text-decoration: none;
	background: transparent;
	transition: background-color calc(220ms * var(--motion-scale)) var(--ease-out),
				color calc(220ms * var(--motion-scale)) var(--ease-out),
				letter-spacing calc(420ms * var(--motion-scale)) var(--ease-in-out);
}
.btn .ar { margin-left: 8px; }

/* Solid: filled, brand-blue — works on light CTA bands */
.btn--solid {
	background: var(--c-aegean);
	color: var(--c-snow);
	border: 1px solid var(--c-aegean);
	padding: 16px 30px;
}
.btn--solid:hover { background: var(--c-charcoal); border-color: var(--c-charcoal); }

/* Ghost / outline */
.btn--ghost,
.btn--outline {
	border: 1px solid rgba(14,22,32,0.4);
	color: var(--c-charcoal);
	padding: 16px 28px;
}
.btn--ghost:hover,
.btn--outline:hover { background: var(--c-charcoal); color: var(--c-snow); border-color: var(--c-charcoal); }

/* On dark surfaces (heroes), invert the ghost button */
.k-hero .btn--ghost, .s-hero .btn--ghost, .ab-hero .btn--ghost,
.booking .btn--ghost {
	border-color: rgba(255,255,255,0.6);
	color: var(--c-snow);
}

/* --- Inner-hero media (single room/treatment/programme heroes) --- */
.s-hero--inner, .k-hero--inner {
	position: relative;
	min-height: 62vh;
	min-height: 62svh;
	display: flex;
	align-items: flex-end;
	overflow: hidden;
	color: var(--c-snow);
	background: var(--c-charcoal);
}
.s-hero--inner .s-hero__media,
.k-hero--inner .k-hero__media {
	position: absolute; inset: 0;
	background-size: cover; background-position: center;
	transform: scale(1.05);
}
.s-hero--inner .s-hero__overlay,
.k-hero--inner .k-hero__overlay {
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(8,20,30,0.15) 0%, rgba(8,20,30,0.7) 100%);
}
.s-hero--inner .s-hero__content,
.k-hero--inner .k-hero__content {
	position: relative;
	padding: 60px 52px 70px;
	max-width: 820px;
}
.s-hero--inner .s-hero__h, .k-hero--inner .k-hero__h {
	font-family: var(--f-hero);
	font-weight: 200;
	font-size: clamp(40px, 6vw, 84px);
	line-height: 0.96;
	margin: 14px 0 0;
}
@media (max-width: 700px) {
	.s-hero--inner .s-hero__content,
	.k-hero--inner .k-hero__content { padding: 40px 24px 48px; }
}

/* --- Detail page: spec strip, includes, gallery --- */
.rm__specs--detail {
	display: flex; flex-wrap: wrap; gap: 30px 48px;
	list-style: none; padding: 0; margin: 0 0 40px;
	border-bottom: 1px solid rgba(14,22,32,0.12);
	padding-bottom: 30px;
}
.detail-benefits { margin: 40px 0; }
.room-gallery {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 16px;
	margin-top: 48px;
}
.room-gallery__img {
	aspect-ratio: 4 / 5;
	background-size: cover; background-position: center;
	border-radius: 2px;
}
.rm__actions--detail { display: flex; gap: 16px; flex-wrap: wrap; }

/* --- Home dine gallery + moodboard grid (when CSS not page-scoped) --- */
.food__gallery {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 14px;
	max-width: 1320px;
	margin: 40px auto 0;
	padding: 0 52px;
}
.food__gallery .bento__img { aspect-ratio: 1; background-size: cover; background-position: center; }
@media (max-width: 700px) { .food__gallery { padding: 0 24px; } }

/* --- Load more / pagination --- */
.jx-more {
	display: flex; justify-content: center;
	margin: 60px 0 0;
}
.jx-more .pagination, .jx-more .nav-links {
	display: flex; gap: 14px; align-items: center;
	font-family: var(--f-body); font-size: 12px; letter-spacing: var(--track-nav); text-transform: uppercase;
}
.jx-more .page-numbers {
	padding: 8px 12px; color: var(--c-slate); text-decoration: none;
	border: 1px solid transparent;
}
.jx-more .page-numbers.current { border-color: rgba(14,22,32,0.3); color: var(--c-charcoal); }

/* --- Simple page + 404 --- */
.sv-page__inner, .sv-404__inner {
	max-width: 760px; margin: 0 auto; padding: 160px 52px 100px;
}
.sv-404 { min-height: 70vh; display: flex; align-items: center; }
.sv-404__h, .sv-page__h {
	font-family: var(--f-display); font-weight: 300;
	font-size: clamp(36px, 5vw, 68px); line-height: 1.02; margin: 14px 0 24px;
}
.sv-404__inner { text-align: center; }
.jx-empty { font-family: var(--f-display); font-style: italic; font-size: 22px; color: rgba(14,22,32,0.55); }
@media (max-width: 700px) {
	.sv-page__inner, .sv-404__inner { padding: 120px 24px 70px; }
}
