/* Gold Stars, nav + footer + floaters chrome. Loads after base.css. */

/* Skip link, accessibility */
.gs-skip-link {
	position: absolute;
	top: -100px;
	inset-inline-start: 0;
	background: var(--gs-navy);
	color: #fff;
	padding: 0.6rem 1rem;
	z-index: 10000;
	transition: top 0.3s;
}
.gs-skip-link:focus { top: 0; color: #fff; }
.no-js .gs-fade-up {
	opacity: 1 !important;
	transform: none !important;
	transition: none !important;
}

/* Nav */
/* Edge-to-edge nav — defeats Elementor Kit's 1140px container-width injection */
body header.site-header,
body .site-header,
.site-header {
	position: sticky !important;
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	z-index: 100;
	background: var(--gs-cream);
	box-shadow: 0 1px 0 var(--gs-border-light);
	display: block !important;
}
body .site-header > .gs-nav,
.site-header .gs-nav {
	width: 100% !important;
	max-width: 100% !important;
}
.gs-nav-inner { max-width: 1400px; }
html, body { overflow-x: hidden; }
body.admin-bar .site-header { top: var(--wp-admin--admin-bar--height, 32px); }
.gs-nav {
	position: relative;
	background: color-mix(in srgb, var(--gs-white) 94%, transparent);
	backdrop-filter: saturate(1.4) blur(10px);
	-webkit-backdrop-filter: saturate(1.4) blur(10px);
	border-bottom: 1px solid var(--gs-border-light);
	padding: 0.85rem 0;
	transition: padding 0.3s var(--gs-ease-out), box-shadow 0.3s var(--gs-ease-out);
}
.gs-nav.is-scrolled { padding: 0.5rem 0; box-shadow: var(--gs-shadow-sm); }
.gs-scroll-progress {
	position: absolute;
	inset-block-start: 0;
	inset-inline-start: 0;
	z-index: 3;
	display: block;
	width: 0%;
	height: 3px;
	max-width: 100%;
	background: linear-gradient(90deg, #b88a23, #d4a843, #f0d37d);
	box-shadow: 0 1px 8px rgba(212, 168, 67, 0.32);
	pointer-events: none;
}
.gs-nav-inner {
	max-width: none;
	width: 100%;
	margin: 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding-inline: clamp(1rem, 4vw, 3rem);
	box-sizing: border-box;
}
.gs-nav-brand {
	display: flex;
	align-items: center;
	gap: 10px;
	text-decoration: none;
}
.gs-nav-brand .custom-logo { height: 44px; width: auto; }
.gs-nav-brand-name { font-weight: 800; font-size: 1rem; color: var(--gs-navy); letter-spacing: 0.02em; }
.gs-brand-logo {
	height: clamp(36px, 4vw, 48px);
	width: auto;
	object-fit: contain;
	display: block;
}
.gs-footer-logo {
	height: 40px;
	margin-block-end: var(--gs-space-3);
}
@media (max-width: 640px) {
	.gs-brand-logo { height: 32px; }
}

.gs-nav-links {
	display: none;
	list-style: none;
	padding: 0;
	margin: 0;
	gap: 0.3rem;
	align-items: center;
}
.gs-nav-links a {
	font-size: 0.92rem;
	font-weight: 600;
	color: var(--gs-navy);
	padding: 0.5rem 1rem;
	border-radius: var(--gs-radius-sm);
	display: inline-block;
	transition: var(--gs-transition);
}
.gs-nav-links a:hover,
.gs-nav-links .current-menu-item > a { color: var(--gs-teal); background: rgba(26, 107, 122, 0.06); }

.gs-nav-right { display: flex; align-items: center; gap: 0.65rem; }
.gs-lang-toggle {
	background: transparent;
	border: 2px solid var(--gs-teal);
	color: var(--gs-teal);
	border-radius: var(--gs-radius-pill);
	padding: 0.3rem 0.9rem;
	min-width: 44px;
	min-height: 44px;
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 1px;
	text-decoration: none;
	cursor: pointer;
	transition: var(--gs-transition);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.gs-lang-toggle:hover { background: var(--gs-teal); color: #fff; }
.gs-nav-cta { display: none; font-size: 0.88rem; padding: 0.5rem 1.3rem; }

.gs-nav-toggler {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 2px solid var(--gs-border-light);
	border-radius: var(--gs-radius-sm);
	padding: 0.35rem 0.55rem;
	min-width: 44px;
	min-height: 44px;
	color: var(--gs-navy);
	background: transparent;
	cursor: pointer;
	font-size: 1.3rem;
	line-height: 1;
}

.gs-mobile-menu {
	display: none;
	padding: 1rem 1.5rem;
	border-top: 1px solid var(--gs-border-light);
	margin-top: 0.5rem;
	background: #fff;
	max-block-size: calc(100svh - var(--gs-nav-offset, 70px));
	overflow-y: auto;
	overscroll-behavior: contain;
}
.gs-mobile-menu.is-open { display: block; }
.gs-mobile-menu ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.25rem; }
.gs-mobile-menu a {
	display: block;
	padding: 0.7rem 0.25rem;
	font-weight: 600;
	color: var(--gs-navy);
	border-radius: var(--gs-radius-sm);
}
.gs-mobile-menu a:hover { background: rgba(26, 107, 122, 0.06); color: var(--gs-teal); }

@media (min-width: 992px) {
	.gs-nav-links { display: flex; }
	.gs-nav-cta { display: inline-flex; }
	.gs-nav-toggler { display: none; }
}

/* Footer */
.gs-footer-wave { display: block; line-height: 0; }
.gs-footer-wave svg { display: block; width: 100%; height: 40px; }
.gs-footer {
	background: var(--gs-navy);
	color: rgba(255, 255, 255, 0.75);
	padding: 60px 0 0;
}
.gs-footer-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--gs-space-4);
}
.gs-footer h6 {
	color: #fff;
	font-size: 1rem;
	font-weight: 700;
	margin: 0 0 1rem;
	position: relative;
}
.gs-footer h6::after {
	content: "";
	display: block;
	width: 40px;
	height: 3px;
	background: var(--gs-gold);
	border-radius: 2px;
	margin-top: 0.6rem;
}
.gs-footer a {
	color: rgba(255, 255, 255, 0.65);
	font-size: 0.88rem;
	display: block;
	padding: 0.22rem 0;
	transition: var(--gs-transition);
}
.gs-footer a:hover { color: var(--gs-gold); }
.gs-footer .gs-footer-social {
	display: flex;
	gap: 0.65rem;
	flex-wrap: wrap;
	margin-top: 1rem;
}
.gs-footer-social a {
	width: 44px;
	height: 44px;
	background: rgba(255, 255, 255, 0.08);
	border-radius: 50%;
	display: flex !important;
	align-items: center;
	justify-content: center;
	padding: 0 !important;
	font-size: 0.95rem;
}
.gs-footer-social a:hover { background: var(--gs-gold); color: var(--gs-navy); transform: translateY(-3px); }
.gs-footer address { font-style: normal; line-height: 1.75; }
.gs-footer address div { display: flex; gap: 0.5rem; align-items: flex-start; margin-bottom: 0.5rem; font-size: 0.88rem; }
.gs-footer address .bi { color: var(--gs-gold); flex-shrink: 0; margin-top: 0.25rem; }
.gs-footer-bottom {
	max-width: 1200px;
	margin: 2.5rem auto 0;
	padding: 1.25rem var(--gs-space-4);
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	font-size: 0.82rem;
	color: rgba(255, 255, 255, 0.45);
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 0.5rem;
}
@media (min-width: 768px) {
	.gs-footer-grid { grid-template-columns: 2fr 1fr 1fr 1.5fr; }
}

/* WA floater */
.gs-wa-float {
	position: fixed;
	bottom: 1.5rem;
	inset-inline-end: 1.5rem;
	z-index: 999;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: var(--gs-wa-green);
	color: var(--gs-white);
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 8px 24px rgba(15, 122, 53, 0.34);
	animation: none;
	transition: var(--gs-transition);
}
.gs-wa-float i { font-size: 1.6rem; }
.gs-wa-float:hover { transform: scale(1.1); color: var(--gs-white); }

/* Back to top */
.gs-back-top {
	position: fixed;
	bottom: 1.5rem;
	inset-inline-start: 1.5rem;
	z-index: 999;
	width: 42px;
	height: 42px;
	border-radius: 50%;
	background: var(--gs-teal);
	color: #fff;
	border: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: var(--gs-shadow-md);
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: var(--gs-transition);
}
.gs-back-top.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
.gs-back-top:hover { background: var(--gs-gold); color: var(--gs-navy); transform: translateY(-3px); }
.gs-back-top i { font-size: 1.05rem; }

/* ============================================================
   Site-wide image treatment (matches home page accent style)
   Rounded corners + soft navy-tinted shadow + hover zoom.
   Applies to every image used in featured slots, cards, hero blocks,
   and body content across archives, singles, and pages.
   ============================================================ */

img.wp-post-image,
.gs-card-img img,
.gs-pkg-hero-img img,
.entry-content img,
.post-thumbnail img,
article.type-gs_package img,
article.type-gs_destination img,
article.type-gs_service img {
	border-radius: var(--gs-radius-lg, 16px) !important;
	box-shadow: 0 8px 24px rgba(26, 58, 92, 0.12);
	transition: transform 0.5s var(--gs-ease-out), box-shadow 0.5s var(--gs-ease-out);
	display: block;
	max-width: 100%;
	height: auto;
	overflow: hidden;
}

img.wp-post-image:hover,
.gs-card-img:hover img,
.gs-pkg-hero-img:hover img,
.entry-content img:hover {
	transform: translateY(-2px);
	box-shadow: 0 14px 34px rgba(26, 58, 92, 0.18);
}

/* Image containers: rounded + warm cream fallback so card shape matches home */
.gs-card-img,
.gs-pkg-hero-img {
	border-radius: var(--gs-radius-lg, 16px);
	overflow: hidden;
	background: linear-gradient(135deg, var(--gs-cream), var(--gs-sand));
	box-shadow: 0 4px 16px rgba(26, 58, 92, 0.08);
	aspect-ratio: 4 / 3;
}
.gs-card-img img,
.gs-pkg-hero-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Package archive cards, styled even outside front-page.php */
.gs-archive-packages {
	padding: clamp(80px, 10vw, 120px) clamp(16px, 4vw, 40px);
	max-width: 1240px;
	margin: 0 auto;
}
.gs-archive-head {
	text-align: center;
	margin-bottom: 3rem;
}
.gs-archive-head h1 {
	font-size: clamp(1.8rem, 4vw, 2.8rem);
	font-weight: 800;
	color: var(--gs-navy);
	margin: 0 0 0.6rem;
	letter-spacing: 0;
}
.gs-archive-sub { color: var(--gs-text-muted); font-size: 1.02rem; margin: 0; }

.gs-archive-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 1.5rem;
}
.gs-card {
	background: #fff;
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius-lg, 16px);
	overflow: hidden;
	transition: border-color 0.3s var(--gs-ease-out), box-shadow 0.3s var(--gs-ease-out), transform 0.3s var(--gs-ease-out);
	box-shadow: 0 2px 10px rgba(26, 58, 92, 0.05);
}
.gs-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 14px 34px rgba(26, 58, 92, 0.12);
	border-color: var(--gs-gold);
}
.gs-card-link { color: inherit; text-decoration: none; display: block; }
.gs-card .gs-card-img {
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: linear-gradient(135deg, var(--gs-cream), var(--gs-sand));
	position: relative;
	border-radius: var(--gs-radius-lg, 16px) var(--gs-radius-lg, 16px) 0 0;
	box-shadow: none;
}
.gs-card .gs-card-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s var(--gs-ease-out);
	border-radius: var(--gs-radius-lg, 16px) var(--gs-radius-lg, 16px) 0 0 !important;
	box-shadow: none;
}
.gs-card:hover .gs-card-img img { transform: scale(1.04); }
.gs-card-body {
	padding: 1.2rem 1.25rem 1.4rem;
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}
.gs-card-badge {
	align-self: flex-start;
	background: var(--gs-gold);
	color: var(--gs-navy);
	padding: 3px 11px;
	border-radius: 50px;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.4px;
	margin-bottom: 0.2rem;
}
.gs-card-title {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--gs-navy);
	margin: 0;
	line-height: 1.3;
}
.gs-card-stars { color: var(--gs-gold-dark); letter-spacing: 2px; font-size: 0.85rem; }
.gs-card-price {
	font-size: 1.15rem;
	font-weight: 800;
	color: var(--gs-teal);
	margin-top: 0.35rem;
	padding-top: 0.65rem;
	border-top: 1px solid var(--gs-border-light);
}

.gs-pagination {
	text-align: center;
	padding: 2.5rem 1rem 1rem;
}
.gs-pagination .page-numbers {
	display: inline-flex;
	min-width: 44px;
	min-height: 44px;
	align-items: center;
	justify-content: center;
	padding: 0 12px;
	margin: 0 3px;
	border: 1px solid var(--gs-border-light);
	border-radius: 10px;
	color: var(--gs-navy);
	font-weight: 600;
	text-decoration: none;
}
.gs-pagination .page-numbers.current { background: var(--gs-navy); color: #fff; border-color: var(--gs-navy); }
.gs-pagination .page-numbers:hover { border-color: var(--gs-gold); color: var(--gs-gold-dark); }

/* Single package/destination/service hero thumbnail */
.gs-single-package .gs-pkg-hero {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	padding: clamp(80px, 10vw, 120px) clamp(16px, 4vw, 40px);
	max-width: 1240px;
	margin: 0 auto;
}
@media (min-width: 880px) {
	.gs-single-package .gs-pkg-hero { grid-template-columns: 3fr 2fr; }
}
.gs-pkg-hero-img { aspect-ratio: 4 / 3; }
.gs-pkg-hero-body { padding: 0.5rem 0; }
.gs-pkg-title { font-size: clamp(1.7rem, 3vw, 2.4rem); font-weight: 800; color: var(--gs-navy); margin: 0 0 0.75rem; line-height: 1.2; }
.gs-pkg-price { font-size: 1.4rem; font-weight: 800; color: var(--gs-teal); margin: 0.8rem 0; padding: 0.5rem 0; border-top: 1px solid var(--gs-border-light); border-bottom: 1px solid var(--gs-border-light); }
.gs-pkg-badge { display: inline-block; background: var(--gs-gold); color: var(--gs-navy); padding: 4px 11px; border-radius: 50px; font-size: 0.74rem; font-weight: 800; margin-bottom: 0.5rem; }
.gs-pkg-city { display: inline-block; margin-inline-start: 0.5rem; color: var(--gs-text-muted); font-weight: 600; }
.gs-pkg-stars { color: var(--gs-gold-dark); letter-spacing: 2px; font-size: 1rem; margin-bottom: 0.3rem; }
.gs-pkg-room { color: var(--gs-text-muted); font-size: 0.95rem; }
.gs-pkg-urgency {
	display: inline-block;
	background: rgba(236, 106, 92, 0.14);
	color: oklch(0.55 0.15 30);
	padding: 4px 10px;
	border-radius: 50px;
	font-size: 0.78rem;
	font-weight: 700;
	margin: 0.3rem 0 0.8rem;
}
.gs-pkg-window, .gs-pkg-block {
	margin: 0;
	padding: 0;
}
.gs-pkg-block h3 {
	font-size: 1.25rem;
	color: var(--gs-navy);
	margin: 0 0 0.85rem;
	display: flex;
	align-items: center;
	gap: 0.55rem;
}
.gs-pkg-block ul { padding-inline-start: 1.3rem; margin: 0; color: var(--gs-ink-70); }
.gs-pkg-block ul li { margin-block: 0.4rem; }
.gs-pkg-cta { max-width: 1240px; margin: 2rem auto; padding: 0 clamp(16px, 4vw, 40px); text-align: center; }

/* ============================================================
   Rich single-package body (trip summary, how-it-works, FAQ,
   similar packages, CTA band). Added 2026-04-24.
   ============================================================ */
.gs-single-package .gs-container {
	max-width: 1240px;
	margin-inline: auto;
	padding-inline: clamp(16px, 4vw, 40px);
}

.gs-pkg-title-en {
	font-family: var(--gs-font-en);
	color: var(--gs-text-muted);
	font-size: 0.95rem;
	letter-spacing: 0.03em;
	margin-bottom: 0.5rem;
}

/* Enhanced price block */
.gs-pkg-price {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 0.55rem;
	padding: 1rem 1.25rem;
	background: linear-gradient(135deg, #fff 0%, var(--gs-cream) 100%);
	border-radius: 14px;
	border: 1px solid var(--gs-border-light);
	margin: 1rem 0;
}
.gs-pkg-price-total {
	display: flex;
	align-items: baseline;
	gap: 0.5rem;
	flex-wrap: wrap;
}
.gs-pkg-price-kicker {
	font-size: 0.72rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--gs-text-muted);
	font-weight: 700;
	margin-inline-end: 0.25rem;
}
.gs-pkg-price-total strong {
	font-size: 1.6rem;
	color: var(--gs-navy);
	font-weight: 800;
}
.gs-pkg-price-suffix {
	font-size: 0.88rem;
	color: var(--gs-text-muted);
}
.gs-pkg-price-breakdown {
	flex-basis: 100%;
	font-size: 0.8rem;
	color: var(--gs-text-muted);
	margin-top: 0.1rem;
}

/* Trip summary tiles */
.gs-pkg-summary {
	padding: clamp(32px, 5vw, 56px) 0;
	background: var(--gs-cream);
}
.gs-pkg-summary-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 0.75rem;
}
.gs-pkg-tile {
	background: #fff;
	border: 1px solid var(--gs-border-light);
	border-radius: 12px;
	padding: 1rem 1.1rem;
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	transition: var(--gs-transition);
}
.gs-pkg-tile:hover {
	transform: translateY(-2px);
	border-color: color-mix(in oklch, var(--gs-gold) 50%, var(--gs-border-light));
	box-shadow: var(--gs-shadow-sm);
}
.gs-pkg-tile > i {
	font-size: 1.3rem;
	color: var(--gs-gold);
	margin-bottom: 0.35rem;
}
.gs-pkg-tile-val {
	font-size: 1rem;
	font-weight: 700;
	color: var(--gs-navy);
	line-height: 1.3;
}
.gs-pkg-tile-lbl {
	font-size: 0.75rem;
	color: var(--gs-text-muted);
	letter-spacing: 0.02em;
}

/* Includes + excludes */
.gs-pkg-includes {
	padding: clamp(40px, 6vw, 72px) 0;
	background: #fff;
}
.gs-pkg-includes-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 820px) {
	.gs-pkg-includes-grid { grid-template-columns: 1fr 1fr; }
}
.gs-pkg-block-inc,
.gs-pkg-block-exc {
	background: #fff;
	border: 1px solid var(--gs-border-light);
	border-radius: 14px;
	padding: 1.5rem 1.6rem;
	transition: var(--gs-transition);
}
.gs-pkg-block-inc:hover {
	border-color: color-mix(in oklch, var(--gs-success) 40%, var(--gs-border-light));
	box-shadow: var(--gs-shadow-sm);
}
.gs-pkg-block-exc:hover {
	border-color: color-mix(in oklch, var(--gs-coral) 40%, var(--gs-border-light));
	box-shadow: var(--gs-shadow-sm);
}
.gs-pkg-block-inc h3 i { color: var(--gs-success); }
.gs-pkg-block-exc h3 i { color: var(--gs-coral); }
.gs-pkg-block-inc ul,
.gs-pkg-block-exc ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
.gs-pkg-block-inc ul li,
.gs-pkg-block-exc ul li {
	padding: 0.5rem 0;
	border-block-end: 1px dashed var(--gs-border-light);
	position: relative;
	padding-inline-start: 1.5rem;
	color: var(--gs-ink-70);
}
.gs-pkg-block-inc ul li:last-child,
.gs-pkg-block-exc ul li:last-child { border-block-end: 0; }
.gs-pkg-block-inc ul li::before {
	content: "\F26E";
	font-family: "bootstrap-icons";
	position: absolute;
	inset-inline-start: 0;
	color: var(--gs-success);
	font-size: 0.9rem;
	line-height: 1.5;
}
.gs-pkg-block-exc ul li::before {
	content: "\F62A";
	font-family: "bootstrap-icons";
	position: absolute;
	inset-inline-start: 0;
	color: var(--gs-coral);
	font-size: 0.9rem;
	line-height: 1.5;
}

/* Section heading shared */
.gs-pkg-h2 {
	font-size: clamp(1.4rem, 3vw, 1.9rem);
	color: var(--gs-navy);
	font-weight: 700;
	margin: 0 0 1.75rem;
	text-align: center;
}

/* CMS body prose */
.gs-pkg-body { padding: clamp(32px, 5vw, 56px) 0; background: var(--gs-cream); }
.gs-pkg-prose { max-width: 65ch; margin-inline: auto; line-height: 1.75; }
.gs-pkg-prose h2, .gs-pkg-prose h3 { color: var(--gs-navy); margin-top: 1.5rem; }

/* How it works */
.gs-pkg-how {
	padding: clamp(48px, 7vw, 80px) 0;
	background: #fff;
}
.gs-pkg-steps {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1rem;
	counter-reset: none;
}
.gs-pkg-steps li {
	position: relative;
	padding: 1.5rem 1.5rem 1.5rem 1.5rem;
	padding-inline-start: 4rem;
	background: var(--gs-cream);
	border: 1px solid var(--gs-border-light);
	border-radius: 14px;
	transition: var(--gs-transition);
}
.gs-pkg-steps li:hover {
	transform: translateY(-3px);
	border-color: var(--gs-gold);
	box-shadow: var(--gs-shadow-sm);
}
.gs-pkg-step-num {
	position: absolute;
	inset-inline-start: 1.25rem;
	top: 1.25rem;
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--gs-navy);
	color: var(--gs-gold);
	font-family: var(--gs-font-en);
	font-weight: 800;
	font-size: 1.15rem;
	border-radius: 50%;
	box-shadow: var(--gs-shadow-sm);
}
.gs-pkg-steps strong {
	display: block;
	font-size: 1.05rem;
	color: var(--gs-navy);
	margin-bottom: 0.25rem;
}
.gs-pkg-steps p {
	margin: 0;
	font-size: 0.9rem;
	color: var(--gs-ink-70);
}

/* FAQ */
.gs-pkg-faq {
	padding: clamp(48px, 7vw, 80px) 0;
	background: var(--gs-cream);
}
.gs-pkg-faq-list {
	max-width: 740px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
}
.gs-pkg-faq-list details {
	background: #fff;
	border: 1px solid var(--gs-border-light);
	border-radius: 12px;
	padding: 1rem 1.25rem;
	transition: var(--gs-transition);
}
.gs-pkg-faq-list details[open] {
	border-color: color-mix(in oklch, var(--gs-gold) 45%, var(--gs-border-light));
	box-shadow: var(--gs-shadow-sm);
}
.gs-pkg-faq-list summary {
	cursor: pointer;
	font-weight: 700;
	color: var(--gs-navy);
	list-style: none;
	padding-inline-end: 2rem;
	position: relative;
}
.gs-pkg-faq-list summary::-webkit-details-marker { display: none; }
.gs-pkg-faq-list summary::after {
	content: "+";
	position: absolute;
	inset-inline-end: 0;
	top: 0;
	font-size: 1.4rem;
	line-height: 1;
	color: var(--gs-gold);
	transition: transform 0.3s var(--gs-ease-out);
}
.gs-pkg-faq-list details[open] summary::after { content: "−"; }
.gs-pkg-faq-list p {
	margin: 0.75rem 0 0;
	color: var(--gs-ink-70);
	line-height: 1.75;
}

/* Similar packages */
.gs-pkg-similar {
	padding: clamp(48px, 7vw, 80px) 0;
	background: #fff;
}
.gs-pkg-similar-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 1.25rem;
}
.gs-pkg-similar-card {
	background: #fff;
	border: 1px solid var(--gs-border-light);
	border-radius: 14px;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	display: flex;
	flex-direction: column;
	transition: var(--gs-transition);
}
.gs-pkg-similar-card:hover {
	transform: translateY(-4px);
	border-color: var(--gs-gold);
	box-shadow: var(--gs-shadow-md);
}
.gs-pkg-similar-img {
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--gs-cream);
}
.gs-pkg-similar-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s var(--gs-ease-out);
}
.gs-pkg-similar-card:hover .gs-pkg-similar-img img { transform: scale(1.05); }
.gs-pkg-similar-body {
	padding: 1rem 1.1rem;
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}
.gs-pkg-similar-city {
	display: inline-block;
	font-size: 0.72rem;
	letter-spacing: 0.06em;
	color: var(--gs-teal);
	font-weight: 700;
}
.gs-pkg-similar-name {
	font-size: 1rem;
	color: var(--gs-navy);
	font-weight: 700;
	margin: 0.1rem 0 0.1rem;
}
.gs-pkg-similar-stars { color: var(--gs-gold-dark); letter-spacing: 2px; font-size: 0.9rem; }
.gs-pkg-similar-price { color: var(--gs-navy); font-weight: 800; margin-top: 0.2rem; }

/* Final CTA band */
.gs-pkg-cta-band {
	padding: clamp(48px, 7vw, 80px) 0;
	background: linear-gradient(135deg, var(--gs-teal) 0%, var(--gs-navy) 100%);
	color: #fff;
}
.gs-pkg-cta-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	flex-wrap: wrap;
}
.gs-pkg-cta-title {
	color: #fff;
	font-size: clamp(1.3rem, 3vw, 1.9rem);
	margin: 0 0 0.5rem;
	font-weight: 700;
}
.gs-pkg-cta-sub {
	color: rgba(255, 255, 255, 0.85);
	margin: 0;
	max-width: 52ch;
}
.gs-pkg-cta-actions { display: flex; gap: 0.6rem; flex-wrap: wrap; }

.gs-btn-wa {
	background: var(--gs-wa-green);
	color: #fff;
	padding: 0.9rem 1.5rem;
	border-radius: 50px;
	text-decoration: none;
	font-weight: 700;
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	transition: var(--gs-transition);
}
.gs-btn-wa:hover {
	background: var(--gs-wa-green-dark);
	transform: translateY(-2px);
	box-shadow: 0 10px 24px rgba(15, 122, 53, 0.34);
	color: #fff;
}

/* Hero action row holds the WA + optional Pay-Online buttons side by side */
.gs-pkg-actions {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	margin-top: 1rem;
	align-items: flex-start;
}
@media (min-width: 540px) {
	.gs-pkg-actions { flex-direction: row; flex-wrap: wrap; }
}

/* Paymob "ادفع أونلاين" button — navy primary to signal trust/banking,
   with a tiny line underneath marking the provider */
.gs-btn-pay {
	background: var(--gs-navy);
	color: #fff;
	padding: 0.7rem 1.35rem;
	border-radius: 50px;
	text-decoration: none;
	font-weight: 700;
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	transition: var(--gs-transition);
	position: relative;
}
.gs-btn-pay:hover {
	background: color-mix(in oklch, var(--gs-navy) 85%, #000);
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 10px 24px rgba(26, 58, 92, 0.35);
}
.gs-btn-pay-sub {
	display: block;
	font-size: 0.62rem;
	font-weight: 500;
	opacity: 0.75;
	letter-spacing: 0.04em;
	margin-top: 1px;
}
.gs-btn-pay i { font-size: 1.05rem; }

/* ============================================================
   Single service template (single-gs_service.php)
   ============================================================ */
.gs-single-service,
.gs-single-destination {
	max-width: 1240px;
	margin: 0 auto;
	padding: clamp(56px, 8vw, 100px) clamp(16px, 4vw, 40px);
}
.gs-svc-hero,
.gs-dest-hero {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	margin-bottom: 3rem;
	align-items: center;
}
@media (min-width: 880px) {
	.gs-svc-hero,
	.gs-dest-hero { grid-template-columns: 5fr 4fr; gap: 3rem; }
}
.gs-svc-hero-img,
.gs-dest-hero-img {
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: var(--gs-radius-lg, 16px);
	background: linear-gradient(135deg, var(--gs-cream), var(--gs-sand));
	box-shadow: 0 8px 24px rgba(26, 58, 92, 0.12);
}
.gs-svc-hero-img img,
.gs-dest-hero-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.gs-svc-icon {
	display: inline-flex;
	width: 60px;
	height: 60px;
	align-items: center;
	justify-content: center;
	border-radius: 14px;
	background: rgba(26, 107, 122, 0.1);
	color: var(--gs-teal);
	font-size: 1.8rem;
	margin-bottom: 1rem;
}
.gs-svc-title,
.gs-dest-title {
	font-size: clamp(1.8rem, 4vw, 2.8rem);
	font-weight: 800;
	color: var(--gs-navy);
	margin: 0 0 0.6rem;
	letter-spacing: 0;
	line-height: 1.2;
}
.gs-svc-promise,
.gs-dest-tagline {
	font-size: 1.1rem;
	color: var(--gs-ink-70);
	margin: 0 0 1.4rem;
	line-height: 1.6;
}
.gs-svc-body,
.gs-dest-body {
	max-width: 65ch;
	margin: 0 auto 3rem;
	font-size: 1rem;
	line-height: 1.75;
}
.gs-svc-body h3,
.gs-dest-body h3,
.gs-svc-body h4,
.gs-dest-body h4 {
	color: var(--gs-navy);
	margin-top: 2rem;
	margin-bottom: 0.8rem;
}
.gs-svc-body ul,
.gs-dest-body ul { padding-inline-start: 1.5rem; }
.gs-svc-body li,
.gs-dest-body li { margin-bottom: 0.4rem; }
.gs-svc-body blockquote {
	border: 1px solid color-mix(in oklch, var(--gs-gold) 45%, var(--gs-border-light));
	border-radius: var(--gs-radius-sm);
	background: color-mix(in oklch, var(--gs-gold) 8%, var(--gs-white));
	padding: 1rem;
	margin: 1.5rem 0;
	color: var(--gs-teal);
	font-style: italic;
	font-size: 1.05rem;
}

.gs-svc-proofs {
	max-width: 860px;
	margin: 0 auto 3rem;
	background: linear-gradient(135deg, var(--gs-cream), var(--gs-white));
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius-lg, 16px);
	padding: 1.75rem 2rem;
}
.gs-svc-proofs h2,
.gs-svc-proofs h3 { color: var(--gs-navy); margin: 0 0 1rem; font-size: 1.2rem; }
.gs-svc-proofs ul { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr; gap: 0.6rem; }
@media (min-width: 680px) { .gs-svc-proofs ul { grid-template-columns: repeat(2, 1fr); } }
.gs-svc-proofs li {
	display: flex;
	align-items: flex-start;
	gap: 0.6rem;
	color: var(--gs-navy);
	font-weight: 600;
	font-size: 0.95rem;
}
.gs-svc-proofs .bi { color: var(--gs-gold-dark); flex-shrink: 0; margin-top: 0.15rem; }

.gs-svc-gallery {
	margin: 3rem auto 4rem;
	max-width: 1240px;
}
.gs-svc-gallery h2,
.gs-svc-gallery h3 {
	color: var(--gs-navy);
	margin: 0 0 1.5rem;
	font-size: 1.4rem;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.gs-svc-gallery h2 .bi,
.gs-svc-gallery h3 .bi { color: var(--gs-gold-dark); }
.gs-gallery-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 0.75rem;
}
.gs-gallery-item {
	display: block;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	border-radius: var(--gs-radius-lg, 16px);
	box-shadow: 0 4px 16px rgba(26, 58, 92, 0.08);
	transition: box-shadow 0.3s var(--gs-ease-out), transform 0.3s var(--gs-ease-out);
}
.gs-gallery-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s var(--gs-ease-out);
	border-radius: var(--gs-radius-lg, 16px);
}
.gs-gallery-item:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 28px rgba(26, 58, 92, 0.18);
}
.gs-gallery-item:hover img { transform: scale(1.05); }

.gs-svc-cta {
	text-align: center;
	padding: 2.5rem 1.5rem;
	background: radial-gradient(circle at 50% 0%, rgba(212, 168, 67, 0.15), transparent 60%), var(--gs-cream);
	border-radius: var(--gs-radius-lg, 16px);
	margin-top: 3rem;
}
.gs-svc-cta h2,
.gs-svc-cta h3 { color: var(--gs-navy); margin: 0 0 0.5rem; font-size: 1.4rem; }
.gs-svc-cta p { color: var(--gs-ink-70); margin: 0 0 1.25rem; }

/* ============================================================
   Destination single extras (things to do + meta strip + related packages)
   ============================================================ */
.gs-dest-things {
	margin: 3rem auto;
	max-width: 1100px;
}
.gs-dest-things h3 { color: var(--gs-navy); text-align: center; margin: 0 0 1.75rem; font-size: 1.5rem; }
.gs-things-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1.25rem;
}
.gs-thing {
	background: #fff;
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius-lg, 16px);
	padding: 1.4rem 1.25rem;
	transition: border-color 0.3s var(--gs-ease-out), box-shadow 0.3s var(--gs-ease-out), transform 0.3s var(--gs-ease-out);
}
.gs-thing:hover { border-color: var(--gs-gold); transform: translateY(-3px); box-shadow: 0 10px 24px rgba(26, 58, 92, 0.08); }
.gs-thing-icon {
	display: inline-flex;
	width: 44px;
	height: 44px;
	align-items: center;
	justify-content: center;
	border-radius: 10px;
	background: rgba(26, 107, 122, 0.1);
	color: var(--gs-teal);
	font-size: 1.25rem;
	margin-bottom: 0.75rem;
}
.gs-thing h4 { color: var(--gs-navy); margin: 0 0 0.4rem; font-size: 1.05rem; font-weight: 700; }
.gs-thing p { color: var(--gs-ink-70); margin: 0; font-size: 0.92rem; line-height: 1.65; }

.gs-dest-meta-strip {
	max-width: 1100px;
	margin: 2rem auto;
	padding: 1.25rem 1.5rem;
	background: var(--gs-navy);
	color: var(--gs-cream);
	border-radius: var(--gs-radius-lg, 16px);
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.75rem;
	font-size: 0.95rem;
}
@media (min-width: 680px) { .gs-dest-meta-strip { grid-template-columns: 1fr 1fr; gap: 2rem; } }
.gs-dest-meta-strip strong { color: var(--gs-gold); margin-inline-end: 0.4rem; }

.gs-dest-packages {
	margin: 3rem auto;
	max-width: 1240px;
}
.gs-dest-packages h3 { color: var(--gs-navy); margin: 0 0 1.5rem; font-size: 1.4rem; }
