/* Specialty Service sub-page styles. */
/* Used by Stained Glass, Art Conservation, Conservation & Custom Fabrication, etc. */
/* sg- namespace retained from the original design. */

/* ---- Hero: full-bleed dark with large type ---- */
.sg-hero {
	position: relative;
	min-height: 520px;
	display: flex;
	align-items: center;
	overflow: hidden;
}

.sg-hero__bg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center 40%;
	filter: brightness(0.22);
}

.sg-hero__content {
	position: relative;
	z-index: 2;
	max-width: 700px;
	padding: var(--sp-80) var(--sp-64);
	color: var(--color-text-inverse);
}

.sg-hero__breadcrumb {
	font-family: var(--ff-sans);
	font-size: var(--fs-12);
	color: rgba(245, 240, 232, 0.5);
	margin-bottom: var(--sp-24);
}

.sg-hero__breadcrumb a {
	color: rgba(245, 240, 232, 0.5);
	transition: color var(--duration) var(--ease-out);
}

.sg-hero__breadcrumb a:hover {
	color: var(--color-gold);
}

.sg-hero__heading {
	font-family: var(--ff-serif);
	font-size: clamp(var(--fs-36), 4vw, var(--fs-60));
	font-weight: var(--fw-light);
	line-height: var(--lh-tight);
	margin-bottom: var(--sp-20);
}

.sg-hero__body {
	font-size: var(--fs-16);
	line-height: var(--lh-normal);
	color: rgba(245, 240, 232, 0.7);
	margin-bottom: var(--sp-32);
	max-width: 540px;
}

/* ---- Stat bar ---- */
.sg-stats {
	background: var(--color-bg-dark);
	padding: var(--sp-32) 0;
	border-bottom: 1px solid rgba(245, 240, 232, 0.08);
}

.sg-stats__inner {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--sp-48);
}

.sg-stat {
	text-align: center;
	color: var(--color-text-inverse);
}

.sg-stat__number {
	font-family: var(--ff-serif);
	font-size: var(--fs-32);
	font-weight: var(--fw-light);
	line-height: 1;
	margin-bottom: var(--sp-4);
}

.sg-stat__label {
	font-size: var(--fs-11);
	font-weight: var(--fw-medium);
	text-transform: uppercase;
	letter-spacing: var(--ls-wider);
	color: rgba(245, 240, 232, 0.45);
}

.sg-stat__sep {
	width: 1px;
	height: 36px;
	background: rgba(245, 240, 232, 0.1);
}

/* ---- Intro ---- */
.sg-intro {
	background: var(--color-bg);
	padding: var(--sp-80) 0;
	border-bottom: 1px solid var(--color-border);
}

.sg-intro__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--sp-64);
	align-items: center;
}

.sg-intro__label {
	font-family: var(--ff-sans);
	font-size: var(--fs-11);
	font-weight: var(--fw-semibold);
	text-transform: uppercase;
	letter-spacing: var(--ls-widest);
	color: var(--color-gold);
	margin-bottom: var(--sp-12);
}

.sg-intro__heading {
	font-family: var(--ff-serif);
	font-size: clamp(var(--fs-28), 3vw, var(--fs-40));
	font-weight: var(--fw-light);
	line-height: var(--lh-snug);
	color: var(--color-text);
	margin-bottom: var(--sp-20);
}

.sg-intro__text {
	font-size: var(--fs-15);
	line-height: var(--lh-normal);
	color: var(--color-text-body);
	margin-bottom: var(--sp-16);
}

.sg-intro__media {
	overflow: hidden;
}

.sg-intro__img {
	width: 100%;
	height: auto;
	transition: transform 0.6s var(--ease-out);
}

.sg-intro__media:hover .sg-intro__img {
	transform: scale(1.03);
}

/* ---- Service types — grid cards ---- */
.sg-services {
	background: var(--color-bg-cream);
	padding: var(--sp-80) 0;
}

.sg-services__header {
	text-align: center;
	margin-bottom: var(--sp-48);
}

.sg-services__label {
	font-family: var(--ff-sans);
	font-size: var(--fs-11);
	font-weight: var(--fw-semibold);
	text-transform: uppercase;
	letter-spacing: var(--ls-widest);
	color: var(--color-gold);
	margin-bottom: var(--sp-12);
}

.sg-services__heading {
	font-family: var(--ff-serif);
	font-size: clamp(var(--fs-28), 3vw, var(--fs-40));
	font-weight: var(--fw-light);
	line-height: var(--lh-snug);
	color: var(--color-text);
}

.sg-services__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--sp-24);
}

.sg-svc {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-top: 3px solid var(--color-gold);
	padding: var(--sp-40) var(--sp-32);
	display: flex;
	flex-direction: column;
}

.sg-svc__icon {
	color: var(--color-gold);
	margin-bottom: var(--sp-20);
}

.sg-svc__title {
	font-family: var(--ff-serif);
	font-size: var(--fs-24);
	font-weight: var(--fw-regular);
	color: var(--color-text);
	margin-bottom: var(--sp-12);
}

.sg-svc__text {
	font-size: var(--fs-15);
	line-height: var(--lh-normal);
	color: var(--color-text-body);
	flex: 1;
}

/* ---- Types of work ---- */
.sg-types {
	background: var(--color-bg);
	padding: var(--sp-80) 0;
}

.sg-type {
	display: grid;
	grid-template-columns: 1.3fr 1fr;
	gap: var(--sp-48);
	align-items: center;
	padding: var(--sp-56) 0;
	border-bottom: 1px solid var(--color-border);
}

.sg-type:first-child {
	padding-top: 0;
}

.sg-type:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.sg-type--reverse {
	grid-template-columns: 1fr 1.3fr;
}

.sg-type--reverse .sg-type__media {
	order: 2;
}

.sg-type__media {
	overflow: hidden;
}

.sg-type__img {
	width: 100%;
	height: auto;
	transition: transform 0.6s var(--ease-out);
}

.sg-type__media:hover .sg-type__img {
	transform: scale(1.03);
}

.sg-type__label {
	font-family: var(--ff-sans);
	font-size: var(--fs-11);
	font-weight: var(--fw-semibold);
	text-transform: uppercase;
	letter-spacing: var(--ls-widest);
	color: var(--color-gold);
	margin-bottom: var(--sp-12);
}

.sg-type__title {
	font-family: var(--ff-serif);
	font-size: clamp(var(--fs-24), 2.5vw, var(--fs-36));
	font-weight: var(--fw-light);
	line-height: var(--lh-snug);
	color: var(--color-text);
	margin-bottom: var(--sp-16);
}

.sg-type__text {
	font-size: var(--fs-15);
	line-height: var(--lh-normal);
	color: var(--color-text-body);
	margin-bottom: var(--sp-12);
}

/* ---- Process ---- */
.sg-process {
	background: var(--color-bg-dark);
	color: var(--color-text-inverse);
	padding: var(--sp-80) 0;
}

.sg-process__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--sp-64);
	align-items: start;
}

.sg-process__label {
	font-family: var(--ff-sans);
	font-size: var(--fs-11);
	font-weight: var(--fw-semibold);
	text-transform: uppercase;
	letter-spacing: var(--ls-widest);
	color: var(--color-gold);
	margin-bottom: var(--sp-16);
}

.sg-process__heading {
	font-family: var(--ff-serif);
	font-size: clamp(var(--fs-28), 3vw, var(--fs-40));
	font-weight: var(--fw-light);
	line-height: var(--lh-snug);
	margin-bottom: var(--sp-20);
}

.sg-process__text {
	font-size: var(--fs-15);
	line-height: var(--lh-normal);
	color: rgba(245, 240, 232, 0.7);
	margin-bottom: var(--sp-12);
}

.sg-process__steps {
	display: flex;
	flex-direction: column;
	gap: var(--sp-24);
}

.sg-process__step {
	display: flex;
	gap: var(--sp-16);
	align-items: flex-start;
}

.sg-process__step-num {
	font-family: var(--ff-serif);
	font-size: var(--fs-24);
	font-weight: var(--fw-light);
	color: var(--color-gold);
	line-height: 1;
	flex-shrink: 0;
	width: 32px;
}

.sg-process__step-text {
	font-size: var(--fs-14);
	line-height: var(--lh-normal);
	color: rgba(245, 240, 232, 0.7);
	padding-top: 2px;
}

.sg-process__step-text strong {
	color: var(--color-text-inverse);
	font-weight: var(--fw-semibold);
}

/* ---- FAQ ---- */
.sg-faq {
	background: var(--color-bg-cream);
	padding: var(--sp-64) 0;
}

.sg-faq__heading {
	font-family: var(--ff-serif);
	font-size: clamp(var(--fs-24), 2.5vw, var(--fs-36));
	font-weight: var(--fw-light);
	color: var(--color-text);
	margin-bottom: var(--sp-32);
	text-align: center;
}

.sg-faq__grid {
	max-width: 780px;
	margin-inline: auto;
}

.sg-faq__grid .faq__item {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-bottom: none;
	padding-inline: var(--sp-24);
}

.sg-faq__grid .faq__item:last-child {
	border-bottom: 1px solid var(--color-border);
}

.sg-faq__grid .faq__item[open] {
	background: var(--color-bg);
	border-color: var(--color-gold);
}

.sg-faq__grid .faq__answer {
	padding-bottom: var(--sp-20);
}

/* ---- Responsive ---- */
@media (max-width: 768px) {
	.sg-hero {
		min-height: 400px;
	}

	.sg-hero__content {
		padding: var(--sp-40) var(--container-pad);
	}

	.sg-stats__inner {
		gap: var(--sp-28);
	}

	.sg-intro__inner {
		grid-template-columns: 1fr;
		gap: var(--sp-32);
	}

	.sg-intro__media {
		order: -1;
	}

	.sg-services__grid {
		grid-template-columns: 1fr;
	}

	.sg-type {
		grid-template-columns: 1fr;
		gap: var(--sp-28);
	}

	.sg-type--reverse {
		grid-template-columns: 1fr;
	}

	.sg-type--reverse .sg-type__media {
		order: -1;
	}

	.sg-type__media {
		order: -1;
	}

	.sg-process__inner {
		grid-template-columns: 1fr;
		gap: var(--sp-40);
	}
}

@media (max-width: 480px) {
	.sg-hero {
		min-height: 340px;
	}

	.sg-hero__content {
		padding: var(--sp-32) var(--sp-20);
	}

	.sg-hero__heading {
		font-size: var(--fs-32);
	}

	.sg-stats__inner {
		flex-wrap: wrap;
		gap: var(--sp-20);
		justify-content: space-around;
	}

	.sg-stat__sep {
		display: none;
	}

	.sg-intro {
		padding: var(--sp-48) 0;
	}

	.sg-services {
		padding: var(--sp-48) 0;
	}

	.sg-types {
		padding: var(--sp-48) 0;
	}

	.sg-type {
		padding: var(--sp-40) 0;
	}

	.sg-process {
		padding: var(--sp-56) 0;
	}

	.sg-faq {
		padding: var(--sp-48) 0;
	}
}
