/* Gold Stars, inner-page styles.
 * Scope: about, contact, gallery, 404. Single file to keep HTTP round-trips tight.
 * Palette sourced from tokens.css. No new color tokens introduced here.
 */

/* ================================================================
 * Services archive (/services/)
 * ================================================================ */
.gs-svc-archive {
	padding-block: clamp(48px, 7vw, 80px);
	background: var(--gs-white);
}
.gs-services-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--gs-space-5);
}
.gs-service-card {
	display: grid;
	grid-template-rows: auto 1fr;
	overflow: hidden;
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-tile-radius-lg);
	background: var(--gs-white);
	box-shadow: var(--gs-shadow-sm);
	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-service-card:hover {
	transform: translateY(-6px);
	border-color: color-mix(in oklch, var(--gs-gold) 58%, var(--gs-border-light));
	box-shadow: var(--gs-shadow-md);
}
.gs-service-card__media {
	display: grid;
	place-items: center;
	aspect-ratio: 16 / 10;
	min-block-size: 180px;
	overflow: hidden;
	background: linear-gradient(135deg, color-mix(in srgb, var(--gs-gold) 18%, var(--gs-cream)), color-mix(in srgb, var(--gs-teal) 14%, var(--gs-sand)));
}
.gs-service-card[data-slug="umrah-hajj"] .gs-service-card__media,
.gs-service-card[data-slug="umrah"] .gs-service-card__media {
	background: linear-gradient(135deg, color-mix(in srgb, var(--gs-brown) 18%, var(--gs-cream)), color-mix(in srgb, var(--gs-gold) 20%, var(--gs-sand)));
}
.gs-service-card[data-slug="domestic-tourism"] .gs-service-card__media,
.gs-service-card[data-slug="domestic"] .gs-service-card__media {
	background: linear-gradient(135deg, color-mix(in srgb, var(--gs-teal) 20%, var(--gs-cream)), var(--gs-sand));
}
.gs-service-card[data-slug="international"] .gs-service-card__media,
.gs-service-card[data-slug="international-tourism"] .gs-service-card__media {
	background: linear-gradient(135deg, color-mix(in srgb, var(--gs-navy) 16%, var(--gs-cream)), color-mix(in srgb, var(--gs-teal) 18%, var(--gs-sand)));
}
.gs-service-card__media img {
	inline-size: 100%;
	block-size: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.45s var(--gs-ease-out);
}
.gs-service-card:hover .gs-service-card__media img {
	transform: scale(1.04);
}
.gs-service-card__icon {
	display: grid;
	place-items: center;
	inline-size: clamp(72px, 9vw, 96px);
	block-size: clamp(72px, 9vw, 96px);
	border: 1px solid color-mix(in srgb, var(--gs-white) 56%, transparent);
	border-radius: var(--gs-radius);
	background: color-mix(in srgb, var(--gs-white) 72%, transparent);
	color: var(--gs-navy);
	box-shadow: var(--gs-shadow-sm);
}
.gs-service-card__icon svg {
	inline-size: 56%;
	block-size: 56%;
}
.gs-service-card__body {
	display: flex;
	flex-direction: column;
	gap: var(--gs-space-3);
	padding: var(--gs-space-5);
}
.gs-service-card__eyebrow {
	color: var(--gs-gold-dark);
	font-size: var(--gs-type-0, var(--gs-text-xs));
	font-weight: 800;
	letter-spacing: 0;
}
.gs-service-card__title {
	margin: 0;
	color: var(--gs-navy);
	font-size: var(--gs-type-4, var(--gs-h3));
	line-height: 1.3;
}
.gs-service-card__hook,
.gs-service-card__copy {
	margin: 0;
	color: var(--gs-ink-70);
	line-height: 1.75;
}
.gs-service-card__hook {
	color: var(--gs-brown);
	font-weight: 700;
}
.gs-service-card__checks {
	display: grid;
	gap: var(--gs-space-2);
	margin: var(--gs-space-1) 0 0;
	padding: 0;
	list-style: none;
}
.gs-service-card__checks li {
	display: flex;
	align-items: flex-start;
	gap: var(--gs-space-2);
	color: var(--gs-navy);
	font-size: var(--gs-type-1, var(--gs-text-sm));
	font-weight: 700;
}
.gs-service-card__checks .bi {
	color: var(--gs-teal);
	flex: 0 0 auto;
	margin-block-start: 0.18em;
}
.gs-service-card__link {
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--gs-space-2);
	margin-block-start: auto;
	color: var(--gs-gold-dark);
	font-size: var(--gs-type-1, var(--gs-text-sm));
	font-weight: 800;
	text-decoration: none;
}
.gs-service-card__link:hover {
	color: var(--gs-navy);
}
.gs-service-card__link:focus-visible {
	outline: 2px solid var(--gs-focus-ring);
	outline-offset: 3px;
	border-radius: var(--gs-radius-sm);
}
@media (min-width: 640px) {
	.gs-services-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1024px) {
	.gs-services-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

/* ================================================================
 * .gs-tile — shared icon-tile primitive
 *
 * Used across about-service, hm-promise, dest-thing, 404-card,
 * contact-quick, pkg-summary. Hover: lift + gold border + icon rotate.
 * Extend with modifier classes rather than re-declaring the pattern.
 * ================================================================ */
.gs-tile {
	position: relative;
	padding: var(--gs-space-5);
	background: var(--gs-cream);
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-tile-radius);
	transition: var(--gs-transition);
	display: flex;
	flex-direction: column;
	gap: var(--gs-space-2);
	text-decoration: none;
	color: inherit;
	overflow: hidden;
}
.gs-tile:hover {
	transform: translateY(-4px);
	border-color: var(--gs-gold);
	box-shadow: var(--gs-shadow-md);
}
.gs-tile > i:first-child {
	font-size: 1.6rem;
	color: var(--gs-gold);
	display: block;
	margin-bottom: var(--gs-space-2);
	transition: transform 0.3s var(--gs-ease-out);
}
.gs-tile:hover > i:first-child {
	transform: scale(1.15) rotate(-4deg);
}
.gs-tile h3, .gs-tile h4 {
	font-size: var(--gs-text-lg);
	color: var(--gs-navy);
	margin: 0 0 var(--gs-space-2);
	font-weight: 700;
}
.gs-tile p {
	margin: 0;
	color: var(--gs-ink-70);
	font-size: var(--gs-text-base);
	line-height: 1.7;
}

/* ================================================================
 * Shared page shell
 * ================================================================ */
.gs-page {
	background: var(--gs-cream);
	color: var(--gs-ink);
	font-family: var(--gs-font-ar);
	direction: rtl;
	line-height: 1.7;
}

.gs-container {
	max-width: 1240px;
	margin-inline: auto;
	padding-inline: clamp(1rem, 2vw, 2rem);
}

.gs-about-section-head {
	text-align: center;
	margin-bottom: var(--gs-space-6);
}

.gs-about-eyebrow {
	display: inline-block;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-size: var(--gs-text-sm);
	font-weight: 700;
	color: var(--gs-teal);
	margin-bottom: var(--gs-space-3);
	position: relative;
	padding-block: var(--gs-space-2);
}
.gs-about-eyebrow::before {
	content: "";
	position: absolute;
	inset-block-end: 0;
	inset-inline-start: 50%;
	transform: translateX(50%);
	width: 36px;
	height: 2px;
	background: var(--gs-gold);
}

.gs-about-kicker {
	display: inline-block;
	font-size: var(--gs-text-xs);
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: var(--gs-gold-dark);
	font-weight: 700;
	margin-bottom: var(--gs-space-3);
}

.gs-about-title {
	font-family: var(--gs-font-ar);
	font-size: var(--gs-h1);
	font-weight: 800;
	line-height: 1.15;
	letter-spacing: 0;
	color: var(--gs-navy);
	margin: 0 0 var(--gs-space-4);
}
.gs-about-title-accent {
	color: var(--gs-teal);
	position: relative;
	white-space: nowrap;
}
.gs-about-title-accent::after {
	content: "";
	position: absolute;
	inset-block-end: 0.08em;
	inset-inline: 0;
	height: 0.22em;
	background: var(--gs-gold);
	opacity: 0.45;
	border-radius: 2px;
	z-index: -1;
}

.gs-about-h2 {
	font-size: var(--gs-h2);
	font-weight: 700;
	color: var(--gs-navy);
	line-height: 1.25;
	margin: 0 0 var(--gs-space-4);
}

.gs-about-lead {
	font-size: var(--gs-text-lg);
	line-height: 1.75;
	max-width: 65ch;
	color: var(--gs-ink-70);
	margin: 0;
}

/* ================================================================
 * About — hero
 * ================================================================ */
.gs-about-hero {
	position: relative;
	padding: clamp(var(--gs-space-7), 8vw, var(--gs-space-9)) 0;
	overflow: hidden;
	background: linear-gradient(180deg, var(--gs-cream) 0%, var(--gs-white) 100%);
}
.gs-about-hero-bg {
	position: absolute;
	inset: 0;
	pointer-events: none;
}
.gs-about-grid {
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(var(--gs-border-light) 1px, transparent 1px),
		linear-gradient(90deg, var(--gs-border-light) 1px, transparent 1px);
	background-size: 48px 48px;
	opacity: 0.25;
	mask-image: radial-gradient(ellipse at 50% 45%, var(--gs-ink) 0%, transparent 70%);
}

.gs-about-hero-inner {
	position: relative;
	text-align: center;
	padding-block: var(--gs-space-5);
}
.gs-about-hero-meta {
	display: flex;
	gap: var(--gs-space-5);
	flex-wrap: wrap;
	justify-content: center;
	margin-top: var(--gs-space-5);
}
.gs-about-meta-item {
	display: inline-flex;
	align-items: center;
	gap: var(--gs-space-2);
	padding: var(--gs-space-2) var(--gs-space-4);
	background: var(--gs-white);
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius-pill);
	font-size: var(--gs-text-sm);
	color: var(--gs-navy);
	box-shadow: var(--gs-shadow-sm);
}
.gs-about-meta-item i { color: var(--gs-gold); }

/* ================================================================
 * About — stats strip
 * ================================================================ */
.gs-about-stats {
	padding: var(--gs-space-7) 0;
	background: var(--gs-navy);
	color: var(--gs-white);
}
.gs-about-stats-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: var(--gs-space-6);
	text-align: center;
}
.gs-about-stat {
	padding: var(--gs-space-4);
	border-inline-start: 1px solid rgba(255, 255, 255, 0.12);
}
.gs-about-stat:first-child {
	border-inline-start: none;
}
.gs-about-stat-num,
.gs-about-stat-suffix {
	font-family: var(--gs-font-en);
	font-size: clamp(2.2rem, 4vw, 3.5rem);
	font-weight: 800;
	line-height: 1;
	color: var(--gs-gold);
	display: inline-block;
}
.gs-about-stat-suffix {
	margin-inline-start: 2px;
}
.gs-about-stat-text {
	letter-spacing: 0;
}
.gs-about-stat-label {
	margin-top: var(--gs-space-3);
	font-size: var(--gs-text-base);
	color: rgba(255, 255, 255, 0.85);
	letter-spacing: 0.02em;
}

/* ================================================================
 * About — awards timeline
 * ================================================================ */
.gs-about-awards {
	padding: var(--gs-space-9) 0;
	background: var(--gs-white);
}
.gs-about-timeline {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: var(--gs-space-5);
}
.gs-about-award {
	background: var(--gs-cream);
	padding: var(--gs-space-5);
	border-radius: var(--gs-radius);
	border: 1px solid var(--gs-border-light);
	transition: var(--gs-transition);
}
.gs-about-award:hover {
	transform: translateY(-4px);
	box-shadow: var(--gs-shadow-md);
	border-color: color-mix(in oklch, var(--gs-gold) 40%, var(--gs-border-light));
}
.gs-about-award-top {
	background: linear-gradient(135deg, color-mix(in srgb, var(--gs-gold) 10%, var(--gs-white)) 0%, var(--gs-white) 100%);
	border-color: color-mix(in oklch, var(--gs-gold) 35%, var(--gs-border-light));
}
.gs-about-award-year {
	font-family: var(--gs-font-en);
	font-size: 0.85rem;
	letter-spacing: 0.08em;
	font-weight: 700;
	color: var(--gs-teal);
	margin-bottom: var(--gs-space-3);
}
.gs-about-award-body {
	display: flex;
	gap: var(--gs-space-4);
	align-items: flex-start;
}
.gs-about-award-icon {
	font-size: 1.6rem;
	color: var(--gs-gold);
	flex-shrink: 0;
	padding-block-start: 2px;
}
.gs-about-award-title {
	font-size: var(--gs-text-lg);
	color: var(--gs-navy);
	margin: 0 0 var(--gs-space-2);
	font-weight: 700;
}
.gs-about-award-note {
	margin: 0;
	font-size: var(--gs-text-sm);
	color: var(--gs-text-muted);
}

/* ================================================================
 * About — founder
 * ================================================================ */
.gs-about-founder {
	padding: var(--gs-space-9) 0;
	background: var(--gs-cream);
	position: relative;
}
.gs-about-founder-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--gs-space-8);
	align-items: center;
}
@media (max-width: 860px) {
	.gs-about-founder-grid { grid-template-columns: 1fr; }
}
.gs-about-founder-photo {
	position: relative;
	border-radius: var(--gs-radius-lg);
	overflow: hidden;
	aspect-ratio: 4 / 3;
	box-shadow: var(--gs-shadow-hard-gold);
}
.gs-about-founder-photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.gs-about-founder-badge {
	position: absolute;
	inset-block-end: var(--gs-space-4);
	inset-inline-start: var(--gs-space-4);
	display: inline-flex;
	align-items: center;
	gap: var(--gs-space-2);
	padding: var(--gs-space-2) var(--gs-space-4);
	background: var(--gs-navy);
	color: var(--gs-white);
	border-radius: var(--gs-radius-pill);
	font-size: var(--gs-text-sm);
	font-weight: 600;
	box-shadow: var(--gs-shadow-md);
}
.gs-about-founder-badge i { color: var(--gs-gold); }
.gs-about-founder-title {
	color: var(--gs-gold-dark);
	font-size: var(--gs-text-base);
	font-weight: 600;
	margin-bottom: var(--gs-space-4);
}
.gs-about-founder-bio {
	font-size: var(--gs-text-base);
	line-height: 1.75;
	color: var(--gs-ink-70);
	margin: 0 0 var(--gs-space-5);
}
.gs-about-founder-quote {
	margin: var(--gs-space-5) 0;
	padding: var(--gs-space-5) var(--gs-space-6);
	background: var(--gs-white);
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius);
	font-style: italic;
	color: var(--gs-navy);
	position: relative;
	box-shadow: var(--gs-shadow-sm);
}
.gs-about-founder-quote::before {
	content: "“";
	position: absolute;
	inset-block-start: -10px;
	inset-inline-start: var(--gs-space-4);
	font-family: Georgia, serif;
	font-size: 3.5rem;
	line-height: 1;
	color: var(--gs-gold);
	background: var(--gs-white);
	padding: 0 0.35rem;
}
.gs-about-founder-quote p { margin: 0; font-size: var(--gs-text-lg); line-height: 1.7; }

.gs-about-founder-cta { margin-top: var(--gs-space-5); }

/* ================================================================
 * About — services tiles
 * ================================================================ */
.gs-about-services {
	padding: var(--gs-space-9) 0;
	background: var(--gs-white);
}
.gs-about-services-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: var(--gs-space-4);
}
.gs-about-service-tile {
	display: flex;
	flex-direction: column;
	gap: var(--gs-space-2);
	padding: var(--gs-space-5);
	background: var(--gs-cream);
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius);
	text-decoration: none;
	color: inherit;
	transition: var(--gs-transition);
	position: relative;
	overflow: hidden;
}
.gs-about-service-tile > i {
	font-size: 1.8rem;
	color: var(--gs-teal);
	transition: transform 0.3s var(--gs-ease-out);
}
.gs-about-service-tile:hover {
	transform: translateY(-4px);
	border-color: var(--gs-gold);
	box-shadow: var(--gs-shadow-md);
}
.gs-about-service-tile:hover > i {
	transform: scale(1.15) rotate(-4deg);
	color: var(--gs-gold);
}
.gs-about-service-name {
	font-size: var(--gs-text-lg);
	margin: 0;
	color: var(--gs-navy);
	font-weight: 700;
}
.gs-about-service-tag {
	font-size: var(--gs-text-sm);
	color: var(--gs-text-muted);
	margin: 0;
}
.gs-about-service-arrow {
	position: absolute;
	inset-block-end: var(--gs-space-4);
	inset-inline-start: var(--gs-space-4);
	color: var(--gs-gold);
	opacity: 0;
	transform: translateX(8px);
	transition: opacity 0.3s var(--gs-ease-out), transform 0.3s var(--gs-ease-out);
	display: inline-block;
}
.gs-about-service-tile:hover .gs-about-service-arrow,
.gs-contact-quick:hover .gs-about-service-arrow {
	opacity: 1;
	transform: translateX(0);
}

/* ================================================================
 * About — pullquote
 * ================================================================ */
.gs-about-pullquote {
	padding: var(--gs-space-9) 0;
	background: var(--gs-navy);
	color: var(--gs-white);
	text-align: center;
	position: relative;
}
.gs-about-pullquote-mark {
	font-size: 8rem;
	line-height: 0.3;
	color: var(--gs-gold);
	opacity: 0.7;
	margin-bottom: var(--gs-space-4);
	font-family: Georgia, serif;
}
.gs-about-pullquote-text {
	font-size: clamp(1.4rem, 3vw, 2rem);
	font-weight: 500;
	line-height: 1.55;
	max-width: 800px;
	margin: 0 auto;
}
.gs-about-pullquote-line {
	display: block;
	margin-top: var(--gs-space-3);
	color: var(--gs-gold);
	font-weight: 700;
}

/* ================================================================
 * About — CTA
 * ================================================================ */
.gs-about-cta {
	padding: var(--gs-space-9) 0;
	background: linear-gradient(135deg, var(--gs-teal) 0%, var(--gs-navy) 100%);
	color: var(--gs-white);
}
.gs-about-cta-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--gs-space-6);
	flex-wrap: wrap;
}
.gs-about-cta-title { font-size: var(--gs-h2); margin: 0 0 var(--gs-space-3); color: var(--gs-white); font-weight: 700; }
.gs-about-cta-sub   { font-size: var(--gs-text-lg); max-width: 56ch; color: rgba(255, 255, 255, 0.85); margin: 0; }
.gs-about-cta-actions {
	display: flex;
	gap: var(--gs-space-3);
	flex-wrap: wrap;
}
.gs-btn-ghost-light {
	background: transparent;
	color: var(--gs-white);
	border: 1px solid rgba(255, 255, 255, 0.3);
	padding: 0.85rem 1.5rem;
	border-radius: var(--gs-radius-pill);
	font-weight: 600;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	text-decoration: none;
	transition: var(--gs-transition);
}
.gs-btn-ghost-light:hover {
	background: var(--gs-white);
	color: var(--gs-navy);
	border-color: var(--gs-white);
}

/* ================================================================
 * About — CMS prose fallback
 * ================================================================ */
.gs-about-cms { padding: var(--gs-space-7) 0; background: var(--gs-white); }
.gs-about-prose {
	max-width: 65ch;
	margin-inline: auto;
	font-size: var(--gs-text-base);
	line-height: 1.75;
	color: var(--gs-ink);
}
.gs-about-prose h2, .gs-about-prose h3 { color: var(--gs-navy); margin-top: var(--gs-space-6); }
.gs-about-prose ul li { margin-block: var(--gs-space-2); }

/* ================================================================
 * Contact page
 * ================================================================ */
.gs-contact-hero {
	padding: clamp(var(--gs-space-7), 8vw, var(--gs-space-9)) 0 var(--gs-space-7);
	background: linear-gradient(180deg, var(--gs-cream) 0%, var(--gs-white) 100%);
}
.gs-contact-hero-copy { text-align: center; }
.gs-contact-hero .gs-about-lead { margin-inline: auto; }

.gs-contact-status {
	display: inline-flex;
	align-items: center;
	gap: var(--gs-space-2);
	margin-top: var(--gs-space-5);
	padding: var(--gs-space-2) var(--gs-space-4);
	background: var(--gs-white);
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius-pill);
	font-size: var(--gs-text-sm);
	box-shadow: var(--gs-shadow-sm);
}
.gs-contact-status-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--gs-text-muted);
	flex-shrink: 0;
}
.gs-contact-status[data-status="open"] .gs-contact-status-dot {
	background: var(--gs-success);
	box-shadow: 0 0 0 4px color-mix(in oklch, var(--gs-success) 30%, transparent);
	animation: none;
}

.gs-contact-actions {
	padding: var(--gs-space-6) 0;
	background: var(--gs-white);
}
.gs-contact-actions-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--gs-space-4);
}
.gs-contact-card {
	position: relative;
	display: flex;
	gap: var(--gs-space-5);
	align-items: flex-start;
	padding: var(--gs-space-5);
	background: var(--gs-white);
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius);
	text-decoration: none;
	color: inherit;
	transition: var(--gs-transition);
	overflow: hidden;
}
.gs-contact-card::before {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at top left, color-mix(in oklch, var(--gs-teal) 10%, transparent) 0%, transparent 60%);
	opacity: 0;
	transition: opacity 0.4s var(--gs-ease-out);
	pointer-events: none;
}
.gs-contact-card:hover {
	transform: translateY(-4px);
	border-color: var(--gs-gold);
	box-shadow: var(--gs-shadow-md);
}
.gs-contact-card:hover::before { opacity: 1; }
.gs-contact-card-icon {
	flex-shrink: 0;
	width: 54px;
	height: 54px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--gs-radius);
	background: var(--gs-cream);
	color: var(--gs-teal);
	font-size: 1.6rem;
	transition: var(--gs-transition);
}
.gs-contact-card-wa .gs-contact-card-icon {
	background: var(--gs-wa-green);
	color: var(--gs-white);
	box-shadow: 0 8px 20px color-mix(in oklch, var(--gs-wa-green) 40%, transparent);
}
.gs-contact-card-phone .gs-contact-card-icon {
	background: color-mix(in oklch, var(--gs-navy) 10%, var(--gs-white));
	color: var(--gs-navy);
}
.gs-contact-card-office .gs-contact-card-icon {
	background: color-mix(in oklch, var(--gs-gold) 20%, var(--gs-white));
	color: var(--gs-gold-dark);
}
.gs-contact-card-body { position: relative; flex: 1; }
.gs-contact-card-kicker {
	display: block;
	font-size: var(--gs-text-xs);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--gs-gold-dark);
	font-weight: 700;
	margin-bottom: var(--gs-space-2);
}
.gs-contact-card-title {
	margin: 0 0 var(--gs-space-2);
	font-size: var(--gs-text-lg);
	color: var(--gs-navy);
	font-weight: 700;
}
.gs-contact-card-note { margin: 0; color: var(--gs-ink-70); }
.gs-contact-card-sub  { margin: var(--gs-space-1) 0 0; color: var(--gs-text-muted); font-size: var(--gs-text-sm); }
.gs-contact-card-arrow {
	position: absolute;
	top: 0;
	inset-inline-end: 0;
	color: var(--gs-gold);
	opacity: 0;
	transform: translateX(8px);
	transition: var(--gs-transition);
}
.gs-contact-card:hover .gs-contact-card-arrow { opacity: 1; transform: translateX(0); }

/* Quick-start selector */
.gs-contact-selector {
	padding: var(--gs-space-7) 0;
	background: var(--gs-cream);
}
.gs-contact-selector-head { text-align: center; }
.gs-contact-selector-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: var(--gs-space-3);
	max-width: 1000px;
	margin-inline: auto;
}
.gs-contact-quick {
	position: relative;
	display: flex;
	align-items: center;
	gap: var(--gs-space-3);
	padding: var(--gs-space-4) var(--gs-space-5);
	background: var(--gs-white);
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius);
	text-decoration: none;
	color: var(--gs-navy);
	font-weight: 600;
	transition: var(--gs-transition);
	overflow: hidden;
}
.gs-contact-quick > i {
	font-size: 1.2rem;
	color: var(--gs-teal);
	transition: transform 0.3s var(--gs-ease-out);
}
.gs-contact-quick:hover {
	border-color: var(--gs-gold);
	transform: translateY(-2px);
	box-shadow: var(--gs-shadow-sm);
}
.gs-contact-quick:hover > i {
	transform: scale(1.2);
	color: var(--gs-gold);
}
.gs-contact-quick > span:nth-child(2) { flex: 1; }
.gs-contact-quick .gs-about-service-arrow {
	position: static;
	opacity: 0;
	transform: translateX(8px);
}

/* Map + side */
.gs-contact-map-section {
	padding: var(--gs-space-8) 0;
	background: var(--gs-white);
}
.gs-contact-map-grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: var(--gs-space-5);
}
@media (max-width: 860px) {
	.gs-contact-map-grid { grid-template-columns: 1fr; }
}
.gs-contact-map-frame {
	border-radius: var(--gs-radius-lg);
	overflow: hidden;
	border: 1px solid var(--gs-border-light);
	box-shadow: var(--gs-shadow-md);
}
.gs-contact-map-frame iframe { display: block; width: 100%; min-height: 420px; border: 0; }
.gs-contact-map-side { display: flex; flex-direction: column; gap: var(--gs-space-4); }
.gs-contact-hours,
.gs-contact-trust,
.gs-contact-email {
	padding: var(--gs-space-5);
	background: var(--gs-cream);
	border-radius: var(--gs-radius);
	border: 1px solid var(--gs-border-light);
}
.gs-contact-hours-title,
.gs-contact-trust-title,
.gs-contact-email-title {
	font-size: var(--gs-text-base);
	color: var(--gs-navy);
	margin: 0 0 var(--gs-space-3);
	display: flex;
	align-items: center;
	gap: var(--gs-space-2);
	font-weight: 700;
}
.gs-contact-hours-title i,
.gs-contact-trust-title i,
.gs-contact-email-title i { color: var(--gs-gold); }
.gs-contact-hours-list { list-style: none; padding: 0; margin: 0; }
.gs-contact-hours-list li {
	display: flex;
	justify-content: space-between;
	padding: var(--gs-space-2) 0;
	border-block-end: 1px dashed var(--gs-border-light);
}
.gs-contact-hours-list li:last-child { border: 0; }
.gs-contact-hours-list strong { color: var(--gs-navy); }
.gs-contact-trust-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--gs-space-2);
	font-size: var(--gs-text-sm);
	color: var(--gs-ink-70);
}
.gs-contact-trust-list i { color: var(--gs-teal); margin-inline-end: var(--gs-space-1); }
.gs-contact-email a {
	color: var(--gs-teal);
	text-decoration: none;
	font-weight: 600;
	font-family: var(--gs-font-en);
}
.gs-contact-email a:hover { color: var(--gs-gold-dark); text-decoration: underline; }

/* ================================================================
 * Gallery page
 * ================================================================ */
.gs-gallery-hero {
	padding: clamp(var(--gs-space-7), 8vw, var(--gs-space-9)) 0 var(--gs-space-6);
	background: linear-gradient(180deg, var(--gs-cream) 0%, var(--gs-white) 100%);
}
.gs-gallery-hero-inner { text-align: center; }
.gs-gallery-hero .gs-about-lead { margin-inline: auto; }

.gs-gallery-filters {
	padding: var(--gs-space-3) 0 var(--gs-space-5);
	background: var(--gs-white);
	position: sticky;
	top: var(--gs-nav-offset, 70px);
	z-index: 10;
	backdrop-filter: blur(10px);
	background: color-mix(in oklch, var(--gs-white) 92%, transparent);
	border-block-end: 1px solid var(--gs-border-light);
}
.gs-gallery-filter-row {
	display: flex;
	gap: var(--gs-space-2);
	overflow-x: auto;
	scrollbar-width: thin;
	padding-block: var(--gs-space-2);
	padding-inline: var(--gs-space-2);
	justify-content: center;
	flex-wrap: wrap;
}
.gs-gallery-chip {
	display: inline-flex;
	align-items: center;
	gap: var(--gs-space-2);
	min-height: 44px;
	padding: var(--gs-space-2) var(--gs-space-4);
	background: var(--gs-white);
	color: var(--gs-navy);
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius-pill);
	font-weight: 600;
	font-size: var(--gs-text-sm);
	cursor: pointer;
	transition: var(--gs-transition);
	white-space: nowrap;
	font-family: inherit;
}
.gs-gallery-chip:hover {
	border-color: var(--gs-gold);
	background: var(--gs-cream);
}
.gs-gallery-chip.is-active {
	background: var(--gs-navy);
	color: var(--gs-white);
	border-color: var(--gs-navy);
}
.gs-gallery-chip-count {
	font-size: var(--gs-text-xs);
	font-weight: 700;
	padding: 2px 6px;
	background: color-mix(in oklch, currentColor 15%, transparent);
	border-radius: 10px;
	font-family: var(--gs-font-en);
}

.gs-gallery-grid-section {
	padding: var(--gs-space-6) 0 var(--gs-space-9);
	background: var(--gs-white);
}
.gs-gallery-grid {
	columns: 2;
	column-gap: var(--gs-space-3);
}
@media (min-width: 700px)  { .gs-gallery-grid { columns: 3; } }
@media (min-width: 1024px) { .gs-gallery-grid { columns: 4; } }

.gs-gallery-item {
	break-inside: avoid;
	margin: 0 0 var(--gs-space-3);
	display: block;
	opacity: 1;
	transform: none;
	animation: none;
}
.gs-gallery-item.is-hidden { display: none; }
.gs-gallery-trigger {
	position: relative;
	display: block;
	border: 0;
	padding: 0;
	width: 100%;
	cursor: zoom-in;
	border-radius: var(--gs-radius);
	overflow: hidden;
	background: var(--gs-cream);
	transition: var(--gs-transition);
}
.gs-gallery-trigger img {
	width: 100%;
	height: auto;
	display: block;
	transition: transform 0.7s var(--gs-ease-out);
}
.gs-gallery-trigger:hover { box-shadow: var(--gs-shadow-md); }
.gs-gallery-trigger:hover img { transform: scale(1.05); }

.gs-gallery-caption {
	position: absolute;
	inset-inline: 0;
	inset-block-end: 0;
	padding: var(--gs-space-5) var(--gs-space-4) var(--gs-space-4);
	background: linear-gradient(180deg, rgba(26, 58, 92, 0.04) 0%, rgba(13, 34, 55, 0.94) 100%);
	color: var(--gs-white);
	opacity: 0;
	transform: translateY(8px);
	transition: var(--gs-transition);
	text-align: start;
}
.gs-gallery-trigger:hover .gs-gallery-caption,
.gs-gallery-trigger:focus-visible .gs-gallery-caption { opacity: 1; transform: translateY(0); }
.gs-gallery-caption-title {
	display: block;
	font-weight: 700;
	font-size: var(--gs-text-base);
}
.gs-gallery-caption-sub {
	display: block;
	font-size: var(--gs-text-xs);
	color: rgba(255, 255, 255, 0.9);
	text-transform: uppercase;
	letter-spacing: 0;
	margin-top: 2px;
}
.gs-gallery-zoom {
	position: absolute;
	top: var(--gs-space-3);
	inset-inline-end: var(--gs-space-3);
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.92);
	color: var(--gs-navy);
	border-radius: 50%;
	font-size: 0.9rem;
	opacity: 0;
	transform: scale(0.85);
	transition: var(--gs-transition);
}
.gs-gallery-trigger:hover .gs-gallery-zoom,
.gs-gallery-trigger:focus-visible .gs-gallery-zoom { opacity: 1; transform: scale(1); }

/* Lightbox */
.gs-gallery-lightbox {
	border: none;
	background: rgba(26, 58, 92, 0.97);
	color: var(--gs-white);
	padding: 0;
	width: 100vw;
	max-width: 100vw;
	height: 100vh;
	max-height: 100vh;
	overflow: hidden;
}
.gs-gallery-lightbox::backdrop { background: rgba(0, 0, 0, 0.8); }
.gs-gallery-lightbox figure {
	margin: 0;
	height: 100%;
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--gs-space-4);
	padding: var(--gs-space-5);
}
.gs-gallery-lightbox img {
	max-width: min(92vw, 1400px);
	max-height: 82vh;
	object-fit: contain;
	border-radius: var(--gs-radius);
	box-shadow: var(--gs-shadow-lg);
}
.gs-gallery-lightbox figcaption {
	font-size: var(--gs-text-base);
	color: rgba(255, 255, 255, 0.88);
	text-align: center;
}
.gs-gallery-lightbox-close,
.gs-gallery-lightbox-prev,
.gs-gallery-lightbox-next {
	position: absolute;
	width: 48px;
	height: 48px;
	border: none;
	background: rgba(255, 255, 255, 0.12);
	color: var(--gs-white);
	border-radius: 50%;
	cursor: pointer;
	font-size: 1.1rem;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: var(--gs-transition);
	backdrop-filter: blur(12px);
}
.gs-gallery-lightbox-close:hover,
.gs-gallery-lightbox-prev:hover,
.gs-gallery-lightbox-next:hover {
	background: rgba(255, 255, 255, 0.25);
	transform: scale(1.05);
}
.gs-gallery-lightbox-close { top: var(--gs-space-4); inset-inline-end: var(--gs-space-4); }
.gs-gallery-lightbox-prev  { top: 50%; inset-inline-start: var(--gs-space-4); transform: translateY(-50%); }
.gs-gallery-lightbox-next  { top: 50%; inset-inline-end: var(--gs-space-4); transform: translateY(-50%); }
.gs-gallery-lightbox-prev:hover,
.gs-gallery-lightbox-next:hover { transform: translateY(-50%) scale(1.05); }

/* ================================================================
 * 404 page
 * ================================================================ */
.gs-page-404 { min-height: 70vh; display: flex; align-items: center; }
.gs-404-hero {
	width: 100%;
	padding: var(--gs-space-9) 0;
	background: linear-gradient(135deg, var(--gs-cream) 0%, var(--gs-white) 100%);
}
.gs-404-inner { text-align: center; }
.gs-404-mark {
	font-family: var(--gs-font-en);
	font-size: clamp(5rem, 14vw, 10rem);
	font-weight: 900;
	line-height: 1;
	color: color-mix(in oklch, var(--gs-teal) 25%, transparent);
	letter-spacing: 0;
	margin-bottom: var(--gs-space-4);
	user-select: none;
}
.gs-404-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
	gap: var(--gs-space-4);
	max-width: 900px;
	margin: var(--gs-space-6) auto 0;
}
.gs-404-card {
	position: relative;
	padding: var(--gs-space-5);
	background: var(--gs-white);
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius);
	text-decoration: none;
	color: inherit;
	transition: var(--gs-transition);
	display: flex;
	flex-direction: column;
	gap: var(--gs-space-2);
	text-align: start;
	overflow: hidden;
}
.gs-404-card > i {
	font-size: 1.8rem;
	color: var(--gs-teal);
	transition: transform 0.3s var(--gs-ease-out);
}
.gs-404-card:hover {
	border-color: var(--gs-gold);
	transform: translateY(-4px);
	box-shadow: var(--gs-shadow-md);
}
.gs-404-card:hover > i { transform: scale(1.2) rotate(-5deg); color: var(--gs-gold); }
.gs-404-card h3 { margin: 0; color: var(--gs-navy); font-size: var(--gs-text-lg); font-weight: 700; }
.gs-404-card p  { margin: 0; color: var(--gs-text-muted); font-size: var(--gs-text-sm); }
.gs-404-arrow {
	position: absolute;
	inset-block-end: var(--gs-space-4);
	inset-inline-start: var(--gs-space-4);
	color: var(--gs-gold);
	opacity: 0;
	transform: translateX(8px);
	transition: var(--gs-transition);
}
.gs-404-card:hover .gs-404-arrow { opacity: 1; transform: translateX(0); }

/* ================================================================
 * Shared utility — glowing primary button
 * ================================================================ */
.gs-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--gs-space-2);
	padding: 0.85rem 1.5rem;
	border-radius: var(--gs-radius-pill);
	font-weight: 700;
	text-decoration: none;
	font-family: inherit;
	transition: var(--gs-transition);
	border: 1px solid transparent;
	cursor: pointer;
}
.gs-btn-primary {
	background: var(--gs-gold);
	color: var(--gs-navy);
}
.gs-btn-primary:hover {
	background: var(--gs-gold-dark);
	color: var(--gs-white);
	transform: translateY(-2px);
	box-shadow: var(--gs-shadow-gold);
}
.gs-btn-glow {
	position: relative;
	box-shadow: var(--gs-shadow-sm);
}

/* ================================================================
 * Reduced motion
 * ================================================================ */
@media (prefers-reduced-motion: reduce) {
	.gs-contact-status[data-status="open"] .gs-contact-status-dot,
	.gs-gallery-item { animation: none; }
	.gs-gallery-item { opacity: 1; transform: none; }
}

/* ================================================================
 * Packages archive (/packages/)
 * ================================================================ */
.gs-archive-hero {
	padding: clamp(var(--gs-space-7), 8vw, var(--gs-space-9)) 0 var(--gs-space-6);
	background: linear-gradient(180deg, var(--gs-cream) 0%, var(--gs-white) 100%);
}
.gs-archive-hero-inner { text-align: center; }
.gs-archive-hero .gs-about-lead { margin-inline: auto; }

.gs-archive-filters {
	padding: var(--gs-space-3) 0 var(--gs-space-5);
	background: var(--gs-white);
	border-block-end: 1px solid var(--gs-border-light);
	position: sticky;
	top: var(--gs-nav-offset, 70px);
	z-index: 10;
	backdrop-filter: blur(8px);
	background: color-mix(in oklch, var(--gs-white) 92%, transparent);
}
.gs-archive-filter-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--gs-space-2);
	justify-content: center;
}
.gs-archive-filter-row .gs-gallery-chip { text-decoration: none; }

.gs-archive-list {
	padding: var(--gs-space-6) 0 var(--gs-space-9);
	background: var(--gs-cream);
}
.gs-archive-pagination {
	margin-top: var(--gs-space-6);
	display: flex;
	justify-content: center;
	gap: var(--gs-space-2);
	flex-wrap: wrap;
}
.gs-archive-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.5rem 0.85rem;
	background: var(--gs-white);
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius-pill);
	text-decoration: none;
	color: var(--gs-navy);
	font-weight: 600;
	min-width: 44px;
	min-height: 44px;
	justify-content: center;
	transition: var(--gs-transition);
}
.gs-archive-pagination .page-numbers:hover {
	border-color: var(--gs-gold);
	color: var(--gs-gold-dark);
}
.gs-archive-pagination .page-numbers.current {
	background: var(--gs-navy);
	color: var(--gs-gold);
	border-color: var(--gs-navy);
}

.gs-archive-empty {
	text-align: center;
	padding: var(--gs-space-8) var(--gs-space-4);
	background: var(--gs-white);
	border-radius: var(--gs-radius-lg);
	border: 2px dashed var(--gs-border-light);
	max-width: 600px;
	margin-inline: auto;
}
.gs-archive-empty > i {
	font-size: 3rem;
	color: var(--gs-gold);
	display: block;
	margin-bottom: var(--gs-space-3);
}
.gs-archive-empty h3 {
	font-size: var(--gs-h3);
	color: var(--gs-navy);
	margin: 0 0 var(--gs-space-2);
}
.gs-archive-empty p {
	color: var(--gs-ink-70);
	margin: 0 0 var(--gs-space-5);
}

/* ================================================================
 * Destination single (/destination/<slug>/)
 * ================================================================ */
.gs-single-destination {
	background: var(--gs-cream);
}
.gs-dest-hero {
	position: relative;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--gs-space-5);
	padding: clamp(80px, 10vw, 120px) clamp(16px, 4vw, 40px) var(--gs-space-7);
	max-width: 1240px;
	margin-inline: auto;
	background: var(--gs-white);
}
@media (min-width: 880px) {
	.gs-dest-hero { grid-template-columns: 3fr 2fr; align-items: center; }
}
.gs-dest-hero-img {
	aspect-ratio: 4 / 3;
	border-radius: var(--gs-radius-lg);
	overflow: hidden;
	box-shadow: var(--gs-shadow-md);
}
.gs-dest-hero-img img { width: 100%; height: 100%; object-fit: cover; display: block; }

.gs-dest-things {
	padding: var(--gs-space-8) 0;
	background: var(--gs-white);
}
.gs-dest-things-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: var(--gs-space-4);
}
.gs-dest-thing-tile {
	padding: var(--gs-space-5);
	background: var(--gs-cream);
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius);
	transition: var(--gs-transition);
}
.gs-dest-thing-tile:hover {
	transform: translateY(-3px);
	border-color: var(--gs-gold);
	box-shadow: var(--gs-shadow-sm);
}
.gs-dest-thing-tile > i {
	font-size: 1.6rem;
	color: var(--gs-gold);
	display: block;
	margin-bottom: var(--gs-space-3);
}
.gs-dest-thing-tile h3 {
	font-size: var(--gs-text-lg);
	color: var(--gs-navy);
	margin: 0 0 var(--gs-space-2);
	font-weight: 700;
}
.gs-dest-thing-tile p {
	margin: 0;
	color: var(--gs-ink-70);
	font-size: var(--gs-text-base);
	line-height: 1.7;
}

.gs-dest-meta {
	padding: var(--gs-space-6) 0;
	background: var(--gs-cream);
}
.gs-dest-meta-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--gs-space-4);
}
.gs-dest-meta-card {
	padding: var(--gs-space-5);
	background: var(--gs-white);
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius);
}
.gs-dest-meta-card p {
	margin: var(--gs-space-2) 0 0;
	color: var(--gs-ink);
	font-size: var(--gs-text-base);
	line-height: 1.7;
}

.gs-dest-packages {
	padding: var(--gs-space-8) 0;
	background: var(--gs-white);
}

/* ================================================================
 * Honeymoon page
 * ================================================================ */
.gs-hm-hero {
	position: relative;
	padding: clamp(var(--gs-space-7), 8vw, var(--gs-space-9)) 0 var(--gs-space-7);
	background: linear-gradient(180deg, color-mix(in srgb, var(--gs-gold) 9%, var(--gs-white)) 0%, var(--gs-cream) 100%);
	overflow: hidden;
}
.gs-hm-hero-bg {
	position: absolute;
	inset: 0;
	pointer-events: none;
}
.gs-hm-hero-inner { text-align: center; position: relative; }
.gs-hm-hero .gs-about-lead { margin-inline: auto; }
.gs-hm-hero-meta {
	display: flex;
	gap: var(--gs-space-4);
	justify-content: center;
	flex-wrap: wrap;
	margin-top: var(--gs-space-5);
}

.gs-hm-promise {
	padding: clamp(48px, 7vw, 80px) 0;
	background: var(--gs-white);
}
.gs-hm-promise-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: var(--gs-space-4);
}
.gs-hm-promise-tile {
	padding: var(--gs-space-5);
	background: var(--gs-cream);
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius);
	transition: var(--gs-transition);
}
.gs-hm-promise-tile:hover {
	transform: translateY(-4px);
	border-color: var(--gs-gold);
	box-shadow: var(--gs-shadow-md);
}
.gs-hm-promise-tile > i {
	font-size: 1.6rem;
	color: var(--gs-gold);
	display: block;
	margin-bottom: var(--gs-space-3);
}
.gs-hm-promise-tile h3 {
	font-size: var(--gs-text-lg);
	color: var(--gs-navy);
	margin: 0 0 var(--gs-space-2);
	font-weight: 700;
}
.gs-hm-promise-tile p {
	margin: 0;
	color: var(--gs-ink-70);
	font-size: var(--gs-text-base);
	line-height: 1.7;
}

/* Packages grid */
.gs-hm-packages {
	padding: clamp(48px, 7vw, 80px) 0;
	background: var(--gs-cream);
}
.gs-hm-packages-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--gs-space-4);
}
.gs-hm-pkg-card {
	background: var(--gs-white);
	border: 1px solid var(--gs-border-light);
	border-radius: var(--gs-radius);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	display: flex;
	flex-direction: column;
	transition: var(--gs-transition);
	position: relative;
}
.gs-hm-pkg-card:hover {
	transform: translateY(-4px);
	border-color: var(--gs-gold);
	box-shadow: var(--gs-shadow-md);
}
.gs-hm-pkg-media {
	position: relative;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--gs-cream);
}
.gs-hm-pkg-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s var(--gs-ease-out);
}
.gs-hm-pkg-card:hover .gs-hm-pkg-media img { transform: scale(1.05); }
.gs-hm-pkg-media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 50%, rgba(26, 58, 92, 0.35));
	pointer-events: none;
}
.gs-hm-pkg-tag {
	position: absolute;
	top: var(--gs-space-3);
	inset-inline-start: var(--gs-space-3);
	background: var(--gs-white);
	color: var(--gs-coral);
	padding: 4px 12px;
	border-radius: var(--gs-radius-pill);
	font-size: 0.72rem;
	font-weight: 700;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
}
.gs-hm-pkg-body {
	padding: var(--gs-space-4);
	display: flex;
	flex-direction: column;
	gap: var(--gs-space-2);
	flex: 1;
}
.gs-hm-pkg-city {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	font-size: 0.72rem;
	color: var(--gs-teal);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.gs-hm-pkg-name {
	font-size: var(--gs-text-lg);
	color: var(--gs-navy);
	margin: 0;
	font-weight: 700;
	line-height: 1.3;
}
.gs-hm-pkg-stars {
	color: var(--gs-gold-dark);
	letter-spacing: 2px;
	font-size: 0.9rem;
}
.gs-hm-pkg-price {
	padding: var(--gs-space-2) 0;
	border-block-start: 1px dashed var(--gs-border-light);
	margin-top: auto;
}
.gs-hm-pkg-price-kicker {
	display: block;
	font-size: var(--gs-text-xs);
	color: var(--gs-text-muted);
	letter-spacing: 0.05em;
	margin-bottom: 2px;
}
.gs-hm-pkg-price strong {
	font-size: var(--gs-text-lg);
	color: var(--gs-navy);
	font-weight: 800;
}
.gs-hm-pkg-cta {
	display: inline-flex;
	justify-content: space-between;
	align-items: center;
	color: var(--gs-gold-dark);
	font-weight: 700;
	font-size: var(--gs-text-sm);
	transition: color 0.2s ease;
}
.gs-hm-pkg-card:hover .gs-hm-pkg-cta { color: var(--gs-navy); }

/* Quote band */
.gs-hm-quote {
	padding: clamp(56px, 8vw, 88px) 0;
	background: var(--gs-navy);
	color: var(--gs-white);
	text-align: center;
}
.gs-hm-quote-mark {
	font-family: Georgia, serif;
	font-size: 6rem;
	line-height: 0.25;
	color: var(--gs-gold);
	opacity: 0.8;
	margin-bottom: var(--gs-space-3);
}
.gs-hm-quote-text {
	font-size: clamp(1.4rem, 3.5vw, 2.1rem);
	font-weight: 500;
	line-height: 1.5;
	max-width: 800px;
	margin: 0 auto;
	color: var(--gs-white);
}
.gs-hm-quote-by {
	margin-top: var(--gs-space-4);
	color: var(--gs-gold);
	font-weight: 600;
}
