/* =========================================================
   SRI LANKA CALLING — MAIN STYLESHEET
   Design tokens: tea-leaf green, sand, cinnamon terracotta,
   ocean teal, turmeric gold. Editorial serif + humanist sans.
   ========================================================= */

:root {
	/* Color — sampled directly from the brand logo (palm/wordmark teal, sunset coral, gold) */
	--slc-ink: #0E3B3F;        /* deep teal-black — primary dark, headers, footer bg */
	--slc-sand: #FBF6EE;       /* warm cream — page background, pairs with coral/sun */
	--slc-terracotta: #FB734D; /* sunset coral, from the logo's sun — primary accent, CTAs */
	--slc-teal: #0BA8B8;       /* logo palm/wordmark teal — secondary accent, links */
	--slc-gold: #F8BF56;       /* logo "CALLING" gold — highlights */
	--slc-white: #FFFFFF;
	--slc-ink-soft: #3D6468;   /* lighter teal-ink for body text on light bg */
	--slc-border: rgba(14, 59, 63, 0.12);

	/* Type */
	--slc-font-display: 'Fraunces', Georgia, serif;
	--slc-font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

	/* Layout */
	--slc-container-width: 1180px;
	--slc-radius: 6px;
	--slc-radius-lg: 14px;
}

/* ---------- Reset & base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
	margin: 0;
	font-family: var(--slc-font-body);
	color: var(--slc-ink);
	background: var(--slc-sand);
	line-height: 1.6;
	font-size: 16px;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4 {
	font-family: var(--slc-font-display);
	font-weight: 600;
	line-height: 1.15;
	margin: 0 0 0.5em;
	color: var(--slc-ink);
}
p { margin: 0 0 1em; }

.slc-container {
	max-width: var(--slc-container-width);
	margin: 0 auto;
	padding: 0 24px;
}

/* Respect reduced motion preference */
@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	* { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* Visible keyboard focus */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible {
	outline: 3px solid var(--slc-gold);
	outline-offset: 2px;
}

/* ---------- Buttons ---------- */
.slc-btn {
	display: inline-block;
	padding: 14px 28px;
	border-radius: var(--slc-radius);
	font-weight: 600;
	font-size: 0.95rem;
	transition: transform 0.15s ease, background 0.15s ease;
	border: 2px solid transparent;
}
.slc-btn-primary {
	background: var(--slc-terracotta);
	color: var(--slc-white);
}
.slc-btn-primary:hover { background: #B14F30; transform: translateY(-1px); }
.slc-btn-ghost {
	background: transparent;
	border-color: rgba(255,255,255,0.6);
	color: var(--slc-white);
}
.slc-btn-ghost:hover { background: rgba(255,255,255,0.12); }

/* ---------- Top bar ---------- */
.slc-topbar {
	background: var(--slc-ink);
	color: var(--slc-sand);
	font-size: 0.85rem;
}
.slc-topbar-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 8px 24px;
}
.slc-topbar-tagline { margin: 0; opacity: 0.85; }

/* ---------- Social icons ---------- */
.slc-social-links {
	display: flex;
	gap: 12px;
	align-items: center;
}
.slc-social-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: rgba(255,255,255,0.1);
	color: var(--slc-sand);
	transition: background 0.15s ease, transform 0.15s ease;
}
.slc-social-icon svg { width: 16px; height: 16px; }
.slc-social-icon:hover {
	background: var(--slc-terracotta);
	transform: translateY(-2px);
}
.slc-footer-brand .slc-social-icon {
	background: rgba(27,58,47,0.08);
	color: var(--slc-ink);
}
.slc-footer-brand .slc-social-icon:hover {
	background: var(--slc-terracotta);
	color: var(--slc-white);
}

/* ---------- Header ---------- */
.slc-header {
	background: var(--slc-white);
	border-bottom: 1px solid var(--slc-border);
	position: sticky;
	top: 0;
	z-index: 100;
}
.slc-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 16px 24px;
}
.slc-logo-text {
	font-family: var(--slc-font-display);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--slc-ink);
}
.slc-logo-link { display: inline-flex; align-items: center; }
.slc-logo-img {
	height: 64px;
	width: auto;
	display: block;
}
.slc-logo .custom-logo-link img {
	height: 64px;
	width: auto;
	max-width: none;
}
.slc-nav-list {
	display: flex;
	gap: 32px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.slc-nav-list a {
	font-weight: 500;
	font-size: 0.95rem;
	position: relative;
	padding-bottom: 4px;
}
.slc-nav-list a:hover { color: var(--slc-terracotta); }
.slc-mobile-toggle {
	display: none;
	flex-direction: column;
	gap: 5px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 8px;
}
.slc-mobile-toggle span {
	width: 24px;
	height: 2px;
	background: var(--slc-ink);
}

/* ---------- Hero ---------- */
.slc-hero {
	position: relative;
	min-height: 88vh;
	display: flex;
	align-items: center;
	overflow: hidden;
	color: var(--slc-white);
}
.slc-hero-media {
	position: absolute;
	inset: 0;
	z-index: 0;
}
.slc-hero-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.slc-hero-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(27,58,47,0.55) 0%, rgba(27,58,47,0.75) 100%);
}
.slc-hero-content {
	position: relative;
	z-index: 1;
	max-width: 760px;
	padding: 60px 24px;
}
.slc-eyebrow {
	text-transform: uppercase;
	letter-spacing: 0.12em;
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--slc-gold);
	margin-bottom: 16px;
}
.slc-eyebrow-dark {
	text-transform: uppercase;
	letter-spacing: 0.12em;
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--slc-teal);
	margin-bottom: 12px;
}
.slc-archive-header .slc-pill {
	display: inline-block;
	margin-top: 16px;
}
.slc-hero-title {
	font-size: clamp(2.2rem, 5vw, 3.6rem);
	color: var(--slc-white);
	margin-bottom: 20px;
}
.slc-hero-sub {
	font-size: 1.15rem;
	max-width: 600px;
	opacity: 0.92;
	margin-bottom: 32px;
}
.slc-hero-actions {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
}

/* ---------- Hero Slideshow ---------- */
.slc-slideshow {
	position: relative;
	min-height: 88vh;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	color: var(--slc-white);
}
.slc-slideshow-media {
	position: absolute;
	inset: 0;
	z-index: 0;
}
.slc-slideshow-track {
	position: relative;
	z-index: 1;
	width: 100%;
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
}
.slc-slide {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.6s ease;
	pointer-events: none;
}
.slc-slide.is-active {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}
.slc-slide-content {
	max-width: 760px;
	padding: 60px 24px;
	text-align: center;
}
.slc-slide-icon {
	display: block;
	font-size: 3rem;
	margin-bottom: 20px;
	line-height: 1;
}
.slc-slide-title {
	font-size: clamp(2rem, 4.5vw, 3.2rem);
	color: var(--slc-white);
	margin-bottom: 20px;
}
.slc-slide-body {
	font-size: 1.2rem;
	max-width: 620px;
	margin: 0 auto 18px;
	opacity: 0.95;
}
.slc-slide-quote {
	font-family: var(--slc-font-display);
	font-style: italic;
	font-size: 1.15rem;
	color: var(--slc-gold);
	margin: 0;
}

.slc-slideshow-actions {
	position: relative;
	z-index: 1;
	justify-content: center;
	padding-bottom: 36px;
}

.slc-slideshow-controls {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	gap: 20px;
	padding-bottom: 20px;
}
.slc-slideshow-playpause {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	border: 1px solid rgba(255,255,255,0.4);
	background: rgba(255,255,255,0.08);
	color: var(--slc-white);
	cursor: pointer;
	font-size: 0.8rem;
	transition: background 0.15s ease;
}
.slc-slideshow-playpause:hover { background: rgba(255,255,255,0.18); }
.slc-icon-play { display: none; }
.slc-slideshow-playpause[aria-pressed="true"] .slc-icon-pause { display: none; }
.slc-slideshow-playpause[aria-pressed="true"] .slc-icon-play { display: inline; }

.slc-slideshow-dots {
	display: flex;
	gap: 10px;
}
.slc-slideshow-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	border: 1.5px solid rgba(255,255,255,0.6);
	background: transparent;
	padding: 0;
	cursor: pointer;
	transition: background 0.2s ease, transform 0.2s ease;
}
.slc-slideshow-dot.is-active {
	background: var(--slc-gold);
	border-color: var(--slc-gold);
	transform: scale(1.2);
}
.slc-slideshow-dot:hover { border-color: var(--slc-white); }

/* ---------- Section titles ---------- */
.slc-section-title {
	font-size: clamp(1.6rem, 3vw, 2.2rem);
	text-align: center;
}
.slc-section-intro {
	text-align: center;
	max-width: 640px;
	margin: 0 auto 40px;
	color: var(--slc-ink-soft);
}
section { padding: 80px 0; }

/* ---------- Why Sri Lanka: comparison strip ---------- */
.slc-why { background: var(--slc-white); }
.slc-compare-strip {
	max-width: 760px;
	margin: 0 auto;
	border: 1px solid var(--slc-border);
	border-radius: var(--slc-radius-lg);
	overflow: hidden;
}
.slc-compare-row {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr;
	align-items: center;
}
.slc-compare-row:not(:last-child) { border-bottom: 1px solid var(--slc-border); }
.slc-compare-header {
	background: var(--slc-ink);
	color: var(--slc-white);
	font-weight: 600;
	font-size: 0.9rem;
}
.slc-compare-label, .slc-compare-cell {
	padding: 16px 20px;
	text-align: center;
}
.slc-compare-label { text-align: left; font-weight: 500; }
.slc-compare-highlight {
	background: rgba(199, 93, 58, 0.08);
	color: var(--slc-terracotta);
	font-weight: 700;
}
.slc-compare-header .slc-compare-highlight {
	background: var(--slc-terracotta);
	color: var(--slc-white);
}
.slc-compare-footnote {
	text-align: center;
	font-size: 0.8rem;
	color: var(--slc-ink-soft);
	opacity: 0.7;
	margin-top: 16px;
}

/* ---------- Activity grid ---------- */
.slc-activities { background: var(--slc-sand); }
.slc-activity-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	gap: 20px;
}
.slc-activity-card {
	background: var(--slc-white);
	border: 1px solid var(--slc-border);
	border-radius: var(--slc-radius-lg);
	padding: 40px 20px;
	text-align: center;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.slc-activity-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 24px rgba(27,58,47,0.1);
}
.slc-activity-icon {
	display: block;
	font-size: 2.4rem;
	margin-bottom: 12px;
}
.slc-activity-name {
	font-family: var(--slc-font-display);
	font-weight: 600;
	font-size: 1.1rem;
}

/* ---------- Card grid (locations + posts) ---------- */
.slc-card-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}
.slc-card {
	display: block;
	background: var(--slc-white);
	border-radius: var(--slc-radius-lg);
	overflow: hidden;
	border: 1px solid var(--slc-border);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.slc-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 32px rgba(27,58,47,0.12);
}
.slc-card-media {
	position: relative;
	aspect-ratio: 4/3;
	overflow: hidden;
	background: var(--slc-border);
}
.slc-card-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.slc-card-tag {
	position: absolute;
	top: 12px;
	left: 12px;
	background: var(--slc-terracotta);
	color: var(--slc-white);
	font-size: 0.75rem;
	font-weight: 600;
	padding: 4px 10px;
	border-radius: 100px;
}
.slc-card-body { padding: 20px; }
.slc-card-title { font-size: 1.2rem; margin-bottom: 8px; }
.slc-card-excerpt { color: var(--slc-ink-soft); font-size: 0.92rem; margin: 0; }
.slc-card-date {
	font-size: 0.8rem;
	color: var(--slc-teal);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin-bottom: 6px;
}
.slc-card-credit {
	font-size: 0.78rem;
	color: var(--slc-ink-soft);
	font-style: italic;
	margin: 8px 0 0;
}

.slc-featured-locations { background: var(--slc-white); }
.slc-blog-preview { background: var(--slc-sand); }

/* ---------- CTA ---------- */
.slc-cta {
	background: var(--slc-ink);
	color: var(--slc-white);
	text-align: center;
}
.slc-cta h2 { color: var(--slc-white); }
.slc-cta-inner { max-width: 560px; margin: 0 auto; }

/* ---------- Footer ---------- */
.slc-footer {
	background: var(--slc-sand);
	border-top: 1px solid var(--slc-border);
	padding-top: 60px;
}
.slc-footer-grid {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr;
	gap: 40px;
	padding-bottom: 40px;
}
.slc-footer-logo-img {
	height: 56px;
	width: auto;
	display: block;
	margin-bottom: 12px;
}
.slc-footer-tagline { color: var(--slc-ink-soft); margin-bottom: 20px; max-width: 320px; }
.footer-widget-title {
	font-size: 1rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin-bottom: 16px;
}
.slc-footer-nav {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.slc-footer-nav a:hover { color: var(--slc-terracotta); }
.slc-footer-bottom {
	border-top: 1px solid var(--slc-border);
	padding: 20px 0;
	text-align: center;
	font-size: 0.85rem;
	color: var(--slc-ink-soft);
}

/* ---------- Single Location ---------- */
.slc-location-hero {
	position: relative;
	height: 60vh;
	min-height: 360px;
	display: flex;
	align-items: flex-end;
	color: var(--slc-white);
	overflow: hidden;
}
.slc-location-hero-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
}
.slc-location-hero-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(27,58,47,0.1) 0%, rgba(27,58,47,0.85) 100%);
}
.slc-location-hero-content {
	position: relative;
	z-index: 1;
	padding-bottom: 40px;
}
.slc-location-hero-content h1 { color: var(--slc-white); margin: 0; }
.slc-location-tags { display: flex; gap: 8px; margin-bottom: 12px; }
.slc-tag {
	background: rgba(255,255,255,0.15);
	border: 1px solid rgba(255,255,255,0.3);
	padding: 4px 12px;
	border-radius: 100px;
	font-size: 0.8rem;
	font-weight: 600;
}
.slc-tag:hover { background: var(--slc-terracotta); }
.slc-location-content { padding: 60px 24px; max-width: 820px; margin: 0 auto; }
.slc-location-body { font-size: 1.05rem; }
.slc-location-body p { margin-bottom: 1.3em; }

/* Video gallery */
.slc-video-gallery { margin-top: 50px; }
.slc-video-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px;
}
.slc-video-wrapper {
	position: relative;
	aspect-ratio: 16/9;
	border-radius: var(--slc-radius-lg);
	overflow: hidden;
	background: var(--slc-ink);
}
.slc-video-wrapper iframe {
	width: 100%;
	height: 100%;
	border: 0;
}

.slc-back-link { margin-top: 40px; }
.slc-back-link a { font-weight: 600; color: var(--slc-teal); }
.slc-back-link a:hover { color: var(--slc-terracotta); }

/* ---------- Star rating widget (single location page) ---------- */
.slc-rating-widget {
	margin: 48px auto 24px;
	padding: 32px;
	background: var(--slc-white);
	border: 1px solid var(--slc-border);
	border-radius: var(--slc-radius-lg);
	max-width: 820px;
}
.slc-back-link { margin-top: 40px; max-width: 820px; margin-left: auto; margin-right: auto; }
.slc-back-link a { font-weight: 600; color: var(--slc-teal); }
.slc-back-link a:hover { color: var(--slc-terracotta); }
.slc-rating-title {
	font-size: 1.1rem;
	margin-bottom: 12px;
}
.slc-rating-summary {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 16px;
	flex-wrap: wrap;
}
.slc-rating-avg {
	font-size: 2rem;
	font-weight: 700;
	font-family: var(--slc-font-display);
	color: var(--slc-ink);
	line-height: 1;
}
.slc-rating-count {
	font-size: 0.85rem;
	color: var(--slc-ink-soft);
}
.slc-rating-threshold {
	font-size: 0.9rem;
	color: var(--slc-ink-soft);
	font-style: italic;
	margin-bottom: 16px;
}

/* Interactive star input buttons */
.slc-star-input {
	display: flex;
	gap: 6px;
	margin-bottom: 12px;
}
.slc-star-btn {
	background: none;
	border: none;
	font-size: 2rem;
	color: var(--slc-border);
	cursor: pointer;
	padding: 0;
	line-height: 1;
	transition: color 0.1s ease, transform 0.1s ease;
}
.slc-star-btn:hover,
.slc-star-btn.is-hovered { color: var(--slc-gold); transform: scale(1.15); }
.slc-star-btn.is-selected { color: var(--slc-gold); }
.slc-star-btn.is-voted { color: var(--slc-gold); cursor: default; }
.slc-star-btn:disabled { cursor: default; }
.slc-rating-feedback {
	font-size: 0.88rem;
	color: var(--slc-teal);
	font-weight: 600;
	min-height: 1.4em;
	margin: 0;
}

/* Read-only star display (used in summary and on cards) */
.slc-rating-stars-display,
.slc-card-rating-stars {
	display: inline-flex;
	gap: 2px;
	font-size: 1rem;
	line-height: 1;
}

/* Card rating row */
.slc-card-rating {
	display: flex;
	align-items: center;
	gap: 5px;
	margin-bottom: 8px;
}
.slc-card-rating-score {
	font-weight: 700;
	font-size: 0.88rem;
	color: var(--slc-ink);
}
.slc-card-rating-count {
	font-size: 0.8rem;
	color: var(--slc-ink-soft);
}

/* ---------- Archive / taxonomy header ---------- */
.slc-archive-header {
	background: var(--slc-white);
	border-bottom: 1px solid var(--slc-border);
	padding: 60px 0 30px;
	text-align: center;
}
.slc-filter-pills {
	display: flex;
	gap: 10px;
	justify-content: center;
	flex-wrap: wrap;
	margin-top: 20px;
}
.slc-pill {
	padding: 8px 18px;
	border: 1px solid var(--slc-border);
	border-radius: 100px;
	font-size: 0.88rem;
	font-weight: 600;
}
.slc-pill:hover { border-color: var(--slc-terracotta); color: var(--slc-terracotta); }
.slc-pill.is-active { background: var(--slc-ink); color: var(--slc-white); border-color: var(--slc-ink); }

.slc-archive-locations .slc-container,
.slc-blog-index .slc-container { padding-top: 50px; padding-bottom: 50px; }

/* ---------- Single post & pages ---------- */
.slc-post-header { background: var(--slc-white); padding-bottom: 30px; }
.slc-post-thumb { aspect-ratio: 16/6; overflow: hidden; margin-bottom: 30px; }
.slc-post-thumb img { width: 100%; height: 100%; object-fit: cover; }
.slc-post-date { color: var(--slc-teal); font-weight: 600; font-size: 0.85rem; text-transform: uppercase; }
.slc-post-credit { color: var(--slc-ink-soft); font-weight: 500; text-transform: none; font-style: italic; }
.slc-post-content { max-width: 760px; margin: 0 auto; padding: 50px 24px; font-size: 1.05rem; }
.slc-post-tags { margin-top: 30px; }

.slc-page-header { background: var(--slc-white); padding: 60px 0 30px; border-bottom: 1px solid var(--slc-border); }
.slc-page-content { max-width: 760px; padding: 50px 24px; }

/* ---------- 404 ---------- */
.slc-404-content { text-align: center; padding: 120px 24px; }

/* ---------- Photo upload form ---------- */
.slc-upload-intro, .slc-gallery-intro { margin-bottom: 30px; }
.slc-upload-form {
	max-width: 540px;
	background: var(--slc-white);
	border: 1px solid var(--slc-border);
	border-radius: var(--slc-radius-lg);
	padding: 32px;
}
.slc-form-row { margin-bottom: 22px; }
.slc-form-row label {
	display: block;
	font-weight: 600;
	margin-bottom: 8px;
	font-size: 0.95rem;
}
.slc-required { color: var(--slc-terracotta); }
.slc-form-row input[type="text"],
.slc-form-row input[type="email"],
.slc-form-row input[type="file"],
.slc-form-row select,
.slc-form-row textarea {
	width: 100%;
	padding: 12px 14px;
	border: 1px solid var(--slc-border);
	border-radius: var(--slc-radius);
	font-family: var(--slc-font-body);
	font-size: 1rem;
	background: var(--slc-sand);
}
.slc-form-row textarea {
	resize: vertical;
	min-height: 160px;
	line-height: 1.6;
}
.slc-form-row select {
	cursor: pointer;
}
.slc-form-row input:focus,
.slc-form-row select:focus,
.slc-form-row textarea:focus {
	outline: none;
	border-color: var(--slc-teal);
}
.slc-form-hint {
	font-size: 0.82rem;
	color: var(--slc-ink-soft);
	margin: 6px 0 0;
}
.slc-form-disclaimer { margin-top: 16px; }
.slc-honeypot-field {
	position: absolute;
	left: -9999px;
	top: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}
.slc-form-notice {
	max-width: 540px;
	padding: 14px 18px;
	border-radius: var(--slc-radius);
	margin-bottom: 24px;
	font-weight: 500;
}
.slc-form-notice-success {
	background: rgba(11, 168, 184, 0.12);
	color: var(--slc-ink);
	border: 1px solid var(--slc-teal);
}
.slc-form-notice-error {
	background: rgba(251, 115, 77, 0.12);
	color: var(--slc-ink);
	border: 1px solid var(--slc-terracotta);
}

/* ---------- Public gallery ---------- */
.slc-gallery-content { padding-top: 50px; padding-bottom: 60px; }
.slc-gallery-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}
.slc-gallery-item {
	margin: 0;
	border-radius: var(--slc-radius-lg);
	overflow: hidden;
	background: var(--slc-white);
	border: 1px solid var(--slc-border);
}
.slc-gallery-item button.slc-gallery-trigger {
	display: block;
	width: 100%;
	padding: 0;
	border: none;
	background: none;
	cursor: pointer;
	overflow: hidden;
}
.slc-gallery-item img {
	width: 100% !important;
	height: 260px !important;
	max-width: 100% !important;
	aspect-ratio: auto;
	object-fit: cover;
	display: block;
	transition: transform 0.25s ease;
}
.slc-gallery-item button.slc-gallery-trigger:hover img {
	transform: scale(1.04);
}
.slc-gallery-item figcaption {
	padding: 14px 16px;
}
.slc-gallery-caption {
	display: block;
	font-weight: 600;
	font-size: 0.95rem;
}
.slc-gallery-credit {
	display: block;
	font-size: 0.8rem;
	color: var(--slc-ink-soft);
	margin-top: 2px;
}
.slc-gallery-empty {
	text-align: center;
	padding: 40px 0;
	color: var(--slc-ink-soft);
}

/* ---------- Lightbox (click a gallery thumbnail to view full size) ---------- */
.slc-lightbox {
	position: fixed;
	inset: 0;
	background: rgba(14, 59, 63, 0.92);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 1000;
	padding: 40px 24px;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.2s ease;
}
.slc-lightbox.is-open {
	opacity: 1;
	visibility: visible;
}
.slc-lightbox-inner {
	max-width: 90vw;
	max-height: 90vh;
	text-align: center;
}
.slc-lightbox-inner img {
	max-width: 100%;
	max-height: 80vh;
	width: auto;
	height: auto;
	border-radius: var(--slc-radius);
	display: block;
	margin: 0 auto;
}
.slc-lightbox-caption {
	color: var(--slc-white);
	margin-top: 16px;
	font-size: 1rem;
}
.slc-lightbox-credit {
	color: rgba(255,255,255,0.7);
	font-size: 0.85rem;
	margin-top: 4px;
}
.slc-lightbox-close {
	position: absolute;
	top: 20px;
	right: 24px;
	background: none;
	border: none;
	color: var(--slc-white);
	font-size: 2.2rem;
	line-height: 1;
	cursor: pointer;
	padding: 8px;
}
.slc-lightbox-close:hover { color: var(--slc-gold); }

/* ---------- Gallery CTA banner (link to upload form) ---------- */
.slc-gallery-cta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	background: var(--slc-white);
	border: 1px solid var(--slc-border);
	border-radius: var(--slc-radius-lg);
	padding: 24px 28px;
	margin-bottom: 36px;
	flex-wrap: wrap;
}
.slc-gallery-cta-text h3 { margin-bottom: 4px; font-size: 1.2rem; }
.slc-gallery-cta-text p { margin: 0; color: var(--slc-ink-soft); }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
	.slc-activity-grid { grid-template-columns: repeat(2, 1fr); }
	.slc-card-grid { grid-template-columns: repeat(2, 1fr); }
	.slc-footer-grid { grid-template-columns: 1fr; }
	.slc-video-grid { grid-template-columns: 1fr; }
	.slc-gallery-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
	.slc-nav-list { display: none; }
	.slc-mobile-toggle { display: flex; }
	.slc-primary-nav.is-open .slc-nav-list {
		display: flex;
		flex-direction: column;
		gap: 0;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: var(--slc-white);
		border-top: 1px solid var(--slc-border);
		padding: 8px 24px 16px;
	}
	.slc-primary-nav.is-open .slc-nav-list a {
		display: block;
		padding: 12px 0;
		border-bottom: 1px solid var(--slc-border);
	}
	.slc-header-inner { position: relative; }
	.slc-slideshow { min-height: 75vh; }
	.slc-slide-icon { font-size: 2.2rem; }
	.slc-slide-body { font-size: 1.05rem; }
	.slc-slide-quote { font-size: 1rem; }
	.slc-activity-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
	.slc-card-grid { grid-template-columns: 1fr; }
	.slc-gallery-grid { grid-template-columns: 1fr; }
	.slc-compare-row { grid-template-columns: 1.4fr 1fr 1fr; font-size: 0.85rem; }
	.slc-compare-label, .slc-compare-cell { padding: 10px 8px; }
	.slc-topbar-tagline { display: none; }
	section { padding: 50px 0; }
}
