/* ===================================================
   SOGH Services — Frontend Styles
=================================================== */

/* ── Services Grid ─────────────────────────────────── */
.sogh-services-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
	max-width: 1160px;
	margin: 0 auto;
}

@media (max-width: 1024px) {
	.sogh-services-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	.sogh-services-grid { grid-template-columns: 1fr; }
}

/* ── Card ──────────────────────────────────────────── */
.sogh-card {
	background: #fff;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 4px 24px rgba(0,0,0,.08);
	display: flex;
	flex-direction: column;
	transition: transform .25s ease, box-shadow .25s ease;
}

.sogh-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 12px 40px rgba(0,0,0,.14);
}

/* ── Card Image ────────────────────────────────────── */
.sogh-card__img-link {
	display: block;
	text-decoration: none;
}

.sogh-card__img-wrap {
	position: relative;
	height: 230px;
	overflow: hidden;
	background: #e8e8e8;
	border-radius: 12px 12px 0 0;
}

.sogh-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .35s ease;
}

.sogh-card:hover .sogh-card__img {
	transform: scale(1.05);
}

/* ── Card Body ─────────────────────────────────────── */
.sogh-card__body {
	padding: 1.25em 1.75em 2em;
	display: flex;
	flex-direction: column;
	flex: 1;
}

.sogh-card__cat {
	font-family: 'Saira', sans-serif;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 2.5px;
	text-transform: uppercase;
	color: #A1F152;
	margin-bottom: 6px;
}

.sogh-card__title {
	font-family: 'Saira', sans-serif;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.25;
	margin: 0 0 10px;
}

.sogh-card__title a {
	color: #24400E;
	text-decoration: none;
	transition: color .2s;
}

.sogh-card__title a:hover {
	color: #A1F152;
}

.sogh-card__desc {
	font-family: 'Golos Text', sans-serif;
	font-size: 14px;
	line-height: 1.65;
	color: #555;
	flex: 1;
	margin: 0 0 20px;
}

.sogh-card__link {
	font-family: 'Saira', sans-serif;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 1px;
	text-transform: uppercase;
	text-decoration: none;
	color: #A1F152;
	margin-top: auto;
	transition: color .2s;
}

.sogh-card__link:hover {
	color: #24400E;
}

/* ── Booking Button (shortcode) ────────────────────── */
.sogh-book-btn-wrap {
	text-align: center;
	margin: 8px 0;
}

.sogh-btn-book,
.sogh-book-btn {
	display: inline-block;
	background: #A1F152;
	color: #000;
	font-family: 'Saira', sans-serif;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	padding: 18px 44px;
	border: none;
	cursor: pointer;
	text-decoration: none;
	transition: background .2s, color .2s;
	margin: 6px;
}

.sogh-btn-book:hover,
.sogh-book-btn:hover {
	background: #A1F152;
	color: #000;
	opacity: .88;
}

/* ── Back link button ──────────────────────────────── */
.sogh-btn-back {
	display: inline-block;
	border: 2px solid #24400E;
	color: #24400E;
	font-family: 'Saira', sans-serif;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	padding: 16px 32px;
	text-decoration: none;
	transition: all .2s;
	margin: 6px;
}

.sogh-btn-back:hover {
	background: #24400E;
	color: #fff;
}

/* ── Featured Sessions (homepage) ──────────────────── */
.sogh-featured-wrap {
	width: 100%;
}

.sogh-featured-cta {
	text-align: center;
	margin-top: 40px;
}

.sogh-featured-cta__btn {
	display: inline-block;
	background: transparent;
	border: 2px solid #24400E;
	color: #24400E;
	font-family: 'Saira', sans-serif;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	padding: 16px 40px;
	text-decoration: none;
	transition: background .2s, color .2s;
}

.sogh-featured-cta__btn:hover {
	background: #24400E;
	color: #A1F152;
}

/* ── Single Service PHP Fallback ───────────────────── */
.sogh-s-hero {
	background: #24400E no-repeat center/cover;
	position: relative;
	text-align: center;
	padding: 100px 24px 80px;
	color: #fff;
}

.sogh-s-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,.65);
}

.sogh-s-hero > * { position: relative; z-index: 1; }

.sogh-s-cat   { font-family: 'Saira', sans-serif; font-size: 12px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: #A1F152; margin-bottom: 12px; }
.sogh-s-title { font-family: 'Saira', sans-serif; font-size: clamp(28px,5vw,52px); font-weight: 700; line-height: 1.1; letter-spacing: -1px; margin-bottom: 16px; }
.sogh-s-price { font-family: 'Saira', sans-serif; font-size: clamp(24px,4vw,36px); font-weight: 700; color: #A1F152; margin-bottom: 6px; }
.sogh-s-dur   { font-family: 'Golos Text', sans-serif; font-size: 14px; color: rgba(255,255,255,.6); }
