/* =========================================================================
   Anchor — Service Detail Pages
   Cinematic hero, magazine intro, pillars grid, signature programs cards,
   inclusions checklist, formats list, dark process timeline, FAQ accordion,
   closing CTA ribbon.
   ========================================================================= */


/* ============================================================
   1. SVC HERO — cinematic full-bleed with brand wash
   ============================================================ */

.svc-hero {
	position: relative;
	min-height: 70vh;
	min-height: 70dvh;
	display: flex;
	align-items: center;
	color: #fff;
	overflow: hidden;
	isolation: isolate;
	padding: clamp(100px, 14vh, 160px) 0 clamp(60px, 9vh, 110px);
}

.svc-hero__media {
	position: absolute;
	inset: 0;
	z-index: -2;
}
.svc-hero__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	animation: heroZoom 14s var(--ease) forwards;
}

.svc-hero__overlay {
	position: absolute;
	inset: 0;
	z-index: -1;
	background:
		linear-gradient(180deg, rgba(0,0,0,0.15) 0%, rgba(0,0,0,0) 30%, rgba(0,0,0,0.55) 100%),
		linear-gradient(105deg, rgba(40, 14, 48, 0.85) 0%, rgba(66, 27, 73, 0.65) 35%, rgba(66, 27, 73, 0.2) 65%, rgba(66, 27, 73, 0) 85%);
}

.svc-hero__inner {
	max-width: 720px;
	position: relative;
	z-index: 1;
}

.svc-hero__crumbs {
	font-size: 12px;
	letter-spacing: 0.12em;
	color: rgba(255, 255, 255, 0.85);
	margin-bottom: 18px;
}
.svc-hero__crumbs a { color: rgba(255, 255, 255, 0.7); text-decoration: none; }
.svc-hero__crumbs a:hover { color: var(--brand-secondary); }
.svc-hero__crumbs span { margin: 0 8px; opacity: 0.6; }

.svc-hero__eyebrow {
	display: inline-block;
	font-family: var(--font-body);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.32em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.92);
	margin-bottom: 18px;
	padding-bottom: 8px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.3);
}

.svc-hero__title {
	font-family: var(--font-display);
	font-size: clamp(40px, 6vw, 78px);
	line-height: 1;
	font-weight: 500;
	letter-spacing: -0.02em;
	margin: 0 0 18px;
	color: #fff;
	text-wrap: balance;
}
.svc-hero__title em {
	font-style: italic;
	color: var(--brand-secondary);
	font-weight: 400;
	display: block;
}

.svc-hero__lede {
	font-size: 17px;
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.92);
	margin: 0 0 28px;
	font-weight: 300;
	max-width: 600px;
}

.svc-hero__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.svc-hero__cta {
	display: inline-flex;
	align-items: center;
	padding: 16px 30px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	border-radius: 0;
	border: 1.5px solid;
	transition: all 0.2s var(--ease);
	min-height: 48px;
}
.svc-hero__cta--primary {
	background: var(--brand-secondary);
	color: #fff;
	border-color: var(--brand-secondary);
}
.svc-hero__cta--primary:hover {
	background: #fff;
	color: var(--brand-primary);
	border-color: #fff;
}
.svc-hero__cta--ghost {
	background: transparent;
	color: #fff;
	border-color: rgba(255, 255, 255, 0.55);
}
.svc-hero__cta--ghost:hover {
	background: rgba(255, 255, 255, 0.10);
	border-color: #fff;
}


/* ============================================================
   2. SVC INTRO — pull quote
   ============================================================ */

.svc-intro {
	background: #fff;
	padding: clamp(60px, 9vw, 100px) 0;
}

.svc-intro__inner {
	max-width: 760px;
	margin: 0 auto;
	text-align: center;
}

.svc-intro__quote {
	font-family: var(--font-display);
	font-size: clamp(24px, 3.4vw, 38px);
	line-height: 1.25;
	color: var(--brand-primary);
	font-weight: 500;
	letter-spacing: -0.02em;
	margin: 0 0 28px;
	position: relative;
	text-wrap: balance;
}

.svc-intro__mark {
	display: block;
	font-family: var(--font-display);
	font-size: 90px;
	line-height: 0.5;
	color: var(--brand-secondary);
	margin-bottom: 4px;
	opacity: 0.55;
}

.svc-intro__para {
	font-size: 17px;
	line-height: 1.75;
	color: var(--brand-text);
	font-weight: 300;
	margin: 0;
}


/* ============================================================
   3. SVC PILLARS — 2x2 / 4-col grid
   ============================================================ */

.svc-pillars { padding: clamp(60px, 9vw, 110px) 0; }

.svc-pillars__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px;
	margin-top: 32px;
}
@media (min-width: 880px) {
	.svc-pillars__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

.svc-pillar {
	background: #fff;
	padding: 32px 26px;
	border-radius: 14px;
	border: 1px solid rgba(66, 27, 73, 0.06);
	transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease), border-color 0.3s var(--ease);
}
.svc-pillar:hover {
	transform: translateY(-4px);
	box-shadow: 0 24px 48px rgba(66, 27, 73, 0.12);
	border-color: rgba(201, 86, 28, 0.3);
}

.svc-pillar__icon {
	margin-bottom: 16px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	background: linear-gradient(135deg, rgba(201, 86, 28, 0.10) 0%, rgba(66, 27, 73, 0.06) 100%);
	border-radius: 12px;
	color: var(--brand-secondary);
	transition: background-color 0.3s var(--ease), color 0.3s var(--ease), transform 0.3s var(--ease);
}
.svc-pillar:hover .svc-pillar__icon {
	background: var(--brand-secondary);
	color: #fff;
	transform: scale(1.05);
}
.svc-pillar__icon .icon { width: 22px; height: 22px; }

.svc-pillar__title {
	font-family: var(--font-display);
	font-size: 19px;
	font-weight: 500;
	color: var(--brand-primary);
	letter-spacing: -0.01em;
	margin: 0 0 8px;
	line-height: 1.25;
}

.svc-pillar__desc {
	font-size: 14px;
	color: var(--brand-text);
	line-height: 1.6;
	font-weight: 300;
	margin: 0;
}


/* ============================================================
   4. SVC PROGRAMS — image-led cards
   ============================================================ */

.svc-programs { padding: clamp(60px, 9vw, 110px) 0; }

.svc-programs__grid {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	gap: 24px;
	margin-top: 32px;
}
@media (min-width: 720px) {
	.svc-programs__grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
	.svc-programs__grid--4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1024px) {
	.svc-programs__grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

.svc-program {
	background: var(--surface-soft);
	border-radius: 14px;
	overflow: hidden;
	transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease);
}
.svc-program:hover {
	transform: translateY(-6px);
	box-shadow: 0 28px 56px rgba(66, 27, 73, 0.15);
}

.svc-program__media {
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--brand-primary);
}
.svc-program__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s var(--ease);
}
.svc-program:hover .svc-program__media img { transform: scale(1.06); }

.svc-program__body {
	padding: 22px 22px 26px;
}

.svc-program__title {
	font-family: var(--font-display);
	font-size: 18px;
	font-weight: 500;
	color: var(--brand-primary);
	letter-spacing: -0.01em;
	margin: 0 0 8px;
	line-height: 1.25;
}

.svc-program__desc {
	font-size: 14px;
	line-height: 1.6;
	color: var(--brand-text);
	font-weight: 300;
	margin: 0;
}


/* ============================================================
   4.5  SVC GALLERY — mid-page image strip
   Asymmetric 4-up grid; cells lift on hover.
   ============================================================ */

.svc-gallery { padding: clamp(40px, 6vw, 80px) 0; }

.svc-gallery__strip {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	grid-auto-rows: 1fr;
	gap: 12px;
	max-width: 1200px;
	margin: 0 auto;
}
@media (min-width: 760px) {
	.svc-gallery__strip {
		grid-template-columns: 1.4fr 1fr 1fr;
		grid-template-rows: repeat(2, minmax(180px, 1fr));
		gap: 14px;
	}
	/* Mosaic layout: first image takes a tall slot on the left,
	   the rest fan out across two rows on the right. */
	.svc-gallery__cell--1 { grid-row: span 2; grid-column: 1; }
	.svc-gallery__cell--2 { grid-column: 2; }
	.svc-gallery__cell--3 { grid-column: 3; }
	.svc-gallery__cell--4 { grid-column: 2 / span 2; }
}

.svc-gallery__cell {
	position: relative;
	border-radius: 14px;
	overflow: hidden;
	background: var(--brand-primary);
	transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease);
	min-height: 200px;
}
.svc-gallery__cell:hover {
	transform: translateY(-4px);
	box-shadow: 0 28px 56px rgba(66, 27, 73, 0.18);
}
.svc-gallery__cell img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.7s var(--ease), filter 0.5s var(--ease);
	filter: saturate(0.96);
}
.svc-gallery__cell:hover img {
	transform: scale(1.06);
	filter: saturate(1.08);
}


/* ============================================================
   5. SVC INCLUSIONS — checklist
   ============================================================ */

.svc-inclusions { padding: clamp(60px, 9vw, 110px) 0; }

.svc-inclusions__list {
	list-style: none;
	padding: 0;
	margin: 32px 0 0;
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	gap: 12px;
}
@media (min-width: 720px) {
	.svc-inclusions__list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.svc-inclusions__list li {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	padding: 18px 22px;
	background: #fff;
	border-radius: 12px;
	border: 1px solid rgba(66, 27, 73, 0.08);
	font-size: 15px;
	line-height: 1.5;
	color: var(--brand-text);
	font-weight: 400;
	transition: border-color 0.2s var(--ease);
}
.svc-inclusions__list li:hover { border-color: rgba(201, 86, 28, 0.4); }

.svc-inclusions__list svg {
	width: 22px;
	height: 22px;
	flex-shrink: 0;
	color: #fff;
	background: var(--brand-secondary);
	border-radius: 50%;
	padding: 4px;
	margin-top: 1px;
}


/* ============================================================
   6. SVC FORMATS — numbered cards
   ============================================================ */

.svc-formats { padding: clamp(60px, 9vw, 110px) 0; }

.svc-formats__grid {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	gap: 16px;
	margin-top: 32px;
}
@media (min-width: 640px) {
	.svc-formats__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1024px) {
	.svc-formats__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

.svc-format {
	position: relative;
	padding: 32px 24px 28px;
	background: var(--surface-soft);
	border-radius: 14px;
	border: 1px solid transparent;
	transition: all 0.3s var(--ease);
	overflow: hidden;
}
.svc-format::before {
	content: "";
	position: absolute;
	top: 0; left: 0;
	width: 100%;
	height: 3px;
	background: var(--brand-secondary);
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform 0.4s var(--ease);
}
.svc-format:hover {
	transform: translateY(-4px);
	background: #fff;
	border-color: rgba(66, 27, 73, 0.08);
	box-shadow: 0 24px 48px rgba(66, 27, 73, 0.12);
}
.svc-format:hover::before { transform: scaleX(1); }

.svc-format__num {
	font-family: var(--font-display);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.22em;
	color: var(--brand-secondary);
	margin-bottom: 14px;
	display: block;
}

.svc-format__title {
	font-family: var(--font-display);
	font-size: 19px;
	font-weight: 500;
	color: var(--brand-primary);
	letter-spacing: -0.01em;
	margin: 0 0 10px;
	line-height: 1.25;
}

.svc-format__desc {
	font-size: 14px;
	line-height: 1.6;
	color: var(--brand-text);
	font-weight: 300;
	margin: 0;
}


/* ============================================================
   7. SVC PROCESS — dark timeline (4 steps)
   ============================================================ */

.svc-process { padding: clamp(70px, 10vw, 130px) 0; }

.svc-process .s-head { color: #fff; }
.svc-process .s-head__title { color: #fff; }

.svc-process__steps {
	list-style: none;
	margin: 40px 0 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	gap: 24px;
	counter-reset: steps;
}
@media (min-width: 720px) {
	.svc-process__steps { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1024px) {
	.svc-process__steps { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

.svc-process__step {
	position: relative;
	padding: 28px 24px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.10);
	border-radius: 14px;
	transition: background-color 0.3s var(--ease), border-color 0.3s var(--ease);
}
.svc-process__step:hover {
	background: rgba(255, 255, 255, 0.10);
	border-color: rgba(201, 86, 28, 0.5);
}

.svc-process__n {
	font-family: var(--font-display);
	font-size: 44px;
	line-height: 1;
	font-weight: 500;
	color: var(--brand-secondary);
	display: block;
	margin-bottom: 16px;
	letter-spacing: -0.02em;
}

.svc-process__body h3 {
	font-family: var(--font-display);
	font-size: 19px;
	font-weight: 500;
	color: #fff;
	letter-spacing: -0.01em;
	margin: 0 0 8px;
	line-height: 1.25;
}

.svc-process__body p {
	font-size: 14px;
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.78);
	font-weight: 300;
	margin: 0;
}


/* ============================================================
   8. SVC FAQ — accordion
   ============================================================ */

.svc-faq { padding: clamp(60px, 9vw, 110px) 0; }

.svc-faq__list {
	max-width: 820px;
	margin: 32px auto 0;
}

.svc-faq__item {
	background: var(--surface-soft);
	border: 1px solid rgba(66, 27, 73, 0.08);
	border-radius: 12px;
	margin-bottom: 12px;
	overflow: hidden;
	transition: border-color 0.2s var(--ease), background-color 0.2s var(--ease);
}
.svc-faq__item[open] {
	background: #fff;
	border-color: rgba(201, 86, 28, 0.35);
	box-shadow: 0 12px 32px rgba(66, 27, 73, 0.08);
}

.svc-faq__q {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	padding: 20px 26px;
	cursor: pointer;
	list-style: none;
	font-family: var(--font-display);
	font-size: 17px;
	font-weight: 500;
	color: var(--brand-primary);
	letter-spacing: -0.005em;
	line-height: 1.4;
	transition: color 0.2s var(--ease);
}
.svc-faq__q::-webkit-details-marker { display: none; }
.svc-faq__q:hover { color: var(--brand-secondary); }

.svc-faq__chev {
	width: 20px;
	height: 20px;
	flex-shrink: 0;
	color: var(--brand-secondary);
	transition: transform 0.3s var(--ease);
}
.svc-faq__item[open] .svc-faq__chev { transform: rotate(-180deg); }

.svc-faq__a {
	padding: 0 26px 22px;
	font-size: 15px;
	line-height: 1.7;
	color: var(--brand-text);
	font-weight: 300;
	animation: faqSlide 280ms var(--ease);
}

@keyframes faqSlide {
	from { opacity: 0; transform: translateY(-4px); }
	to   { opacity: 1; transform: translateY(0); }
}


/* ============================================================
   9. SVC CTA — closing branded ribbon
   ============================================================ */

.svc-cta {
	position: relative;
	padding: clamp(70px, 10vw, 130px) 0;
	color: #fff;
	overflow: hidden;
	isolation: isolate;
}

.svc-cta__bg {
	position: absolute;
	inset: 0;
	z-index: -2;
}
.svc-cta__bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	filter: brightness(0.4);
}
.svc-cta::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background: linear-gradient(135deg, rgba(40, 14, 48, 0.92) 0%, rgba(66, 27, 73, 0.85) 60%, rgba(201, 86, 28, 0.6) 100%);
}

.svc-cta__inner {
	text-align: center;
	max-width: 720px;
}

.svc-cta__tagline {
	font-family: var(--font-script);
	font-size: clamp(24px, 3vw, 36px);
	color: var(--brand-secondary);
	line-height: 1;
	margin-bottom: 18px;
	font-weight: 700;
	display: block;
}

.svc-cta__title {
	font-family: var(--font-display);
	font-size: clamp(34px, 5vw, 56px);
	line-height: 1.05;
	letter-spacing: -0.02em;
	color: #fff;
	margin: 0 0 18px;
	font-weight: 500;
	text-wrap: balance;
}
.svc-cta__title em {
	font-style: italic;
	color: var(--brand-secondary);
	font-weight: 400;
}

.svc-cta__lede {
	font-size: 16px;
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.88);
	margin: 0 auto 30px;
	font-weight: 300;
	max-width: 540px;
}

.svc-cta__actions {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 12px;
	justify-content: center;
}

.svc-cta__btn {
	display: inline-flex;
	align-items: center;
	padding: 16px 32px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	border-radius: 0;
	border: 1.5px solid;
	transition: all 0.2s var(--ease);
	min-height: 48px;
}
.svc-cta__btn--primary {
	background: #fff;
	color: var(--brand-primary);
	border-color: #fff;
}
.svc-cta__btn--primary:hover {
	background: var(--brand-secondary);
	color: #fff;
	border-color: var(--brand-secondary);
}
.svc-cta__btn--ghost {
	background: transparent;
	color: #fff;
	border-color: rgba(255, 255, 255, 0.55);
}
.svc-cta__btn--ghost:hover {
	background: rgba(255, 255, 255, 0.10);
	border-color: #fff;
}


/* ============================================================
   Reduced-motion friendliness
   ============================================================ */

@media (prefers-reduced-motion: reduce) {
	.svc-hero__media img,
	.svc-pillar,
	.svc-program,
	.svc-format,
	.svc-process__step,
	.svc-faq__a {
		animation: none !important;
		transition: none !important;
		transform: none !important;
	}
}
