/* Custom Services — BK Ciandre-inspired layout, site-aligned accents */

.cs-page {
	--cs-inner: min(1240px, 92vw);
	--cs-radius: 12px;
	--cs-dark: #111111;
	--cs-gray: #f5f5f5;
	--cs-text: #333333;
	--cs-muted: #666666;
	--cs-accent: var(--ts-primary-color, #c6a37b);
	width: 100%;
	overflow: hidden;
	color: var(--cs-text);
	font-family: var(--ts-font-family, sans-serif);
	background: #fff;
}

.cs-page .cs-container {
	width: var(--cs-inner);
	margin: 0 auto;
}

.cs-page .cs-section {
	padding: clamp(56px, 7vw, 96px) 0;
}

.cs-page .cs-section--white { background: #fff; }
.cs-page .cs-section--gray { background: var(--cs-gray); }

.cs-page .cs-kicker {
	font-size: 0.75rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--cs-accent);
	margin: 0 0 12px;
}

.cs-page .cs-section-title {
	font-family: var(--ts-heading-font-family, serif);
	font-size: clamp(1.35rem, 2.8vw, 2rem);
	font-weight: 400;
	line-height: 1.2;
	margin: 0 0 20px;
	color: var(--ts-heading-color, #1a1a1a);
	text-transform: none;
}

.cs-page .cs-section-title--center { text-align: center; }

.cs-page .cs-text,
.cs-page .cs-lead {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--cs-muted);
	margin: 0 0 20px;
}

.cs-page .cs-lead--center {
	text-align: center;
	max-width: 760px;
	margin-left: auto;
	margin-right: auto;
}

.cs-page .cs-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 12px 28px;
	border-radius: 6px;
	font-size: 0.82rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	text-decoration: none;
	transition: 0.2s ease;
	border: 1px solid transparent;
	cursor: pointer;
}

.cs-page .cs-btn--dark {
	background: var(--cs-dark);
	color: #fff;
	border-color: var(--cs-dark);
}

.cs-page .cs-btn--dark:hover {
	background: #333;
	color: #fff;
	text-decoration: none;
}

.cs-page .cs-btn--outline {
	background: transparent;
	color: var(--cs-dark);
	border-color: var(--cs-dark);
}

.cs-page .cs-btn--outline:hover {
	background: var(--cs-dark);
	color: #fff;
	text-decoration: none;
}

.cs-page .cs-btn--light {
	background: #fff;
	color: var(--cs-dark);
	border-color: #fff;
}

.cs-page .cs-btn--light:hover {
	background: transparent;
	color: #fff;
	text-decoration: none;
}

.cs-page .cs-btn--lg {
	padding: 14px 36px;
}

.cs-page .cs-cta-center {
	text-align: center;
	margin-top: 36px;
}

/* Reveal */
.cs-page .cs-reveal {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.65s ease, transform 0.65s ease;
}

.cs-page .cs-reveal.is-visible {
	opacity: 1;
	transform: none;
}

/* Hero */
.cs-page .cs-hero {
	position: relative;
	min-height: clamp(520px, 72vh, 780px);
	display: flex;
	align-items: center;
	padding: clamp(80px, 10vw, 120px) 4vw;
	background-size: cover;
	background-position: center;
	color: #fff;
}

.cs-page .cs-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.82) 0%, rgba(0, 0, 0, 0.55) 55%, rgba(0, 0, 0, 0.35) 100%);
}

.cs-page .cs-hero__grid {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: clamp(28px, 4vw, 56px);
	align-items: center;
}

.cs-page .cs-hero__title {
	font-family: var(--ts-heading-font-family, serif);
	font-size: clamp(2rem, 4.5vw, 3.5rem);
	line-height: 1.1;
	margin: 0 0 16px;
	color: #fff;
	font-weight: 400;
}

.cs-page .cs-hero__subtitle {
	font-size: clamp(1rem, 1.6vw, 1.25rem);
	opacity: 0.9;
	margin: 0 0 28px;
	line-height: 1.5;
}

.cs-page .cs-profile-card {
	display: flex;
	gap: 16px;
	align-items: flex-start;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: var(--cs-radius);
	padding: 18px;
	max-width: 480px;
}

.cs-page .cs-profile-card__avatar {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
}

.cs-page .cs-profile-card__name {
	display: block;
	font-size: 1rem;
	margin-bottom: 4px;
}

.cs-page .cs-profile-card__role {
	display: block;
	font-size: 0.78rem;
	opacity: 0.75;
	margin-bottom: 8px;
}

.cs-page .cs-profile-card__text {
	margin: 0;
	font-size: 0.88rem;
	line-height: 1.55;
	opacity: 0.9;
}

.cs-page .cs-stats-card {
	background: #fff;
	color: var(--cs-dark);
	border-radius: var(--cs-radius);
	padding: clamp(24px, 3vw, 36px);
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px;
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.25);
}

.cs-page .cs-stats-card__item {
	text-align: center;
}

.cs-page .cs-stats-card__item i {
	font-size: 1.25rem;
	color: var(--cs-accent);
	margin-bottom: 10px;
}

.cs-page .cs-stats-card__item strong {
	display: block;
	font-size: clamp(1.2rem, 2vw, 1.65rem);
	line-height: 1.1;
	margin-bottom: 6px;
}

.cs-page .cs-stats-card__item span {
	font-size: 0.72rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--cs-muted);
}

/* Tags */
.cs-page .cs-tags-row {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: center;
	padding: 28px 0;
}

.cs-page .cs-tag {
	padding: 8px 18px;
	border: 1px solid #ddd;
	border-radius: 999px;
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	background: #fff;
}

/* Zigzag */
.cs-page .cs-zigzag__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(32px, 5vw, 72px);
	align-items: center;
}

.cs-page .cs-zigzag--reverse .cs-zigzag__media { order: 2; }
.cs-page .cs-zigzag--reverse .cs-zigzag__content { order: 1; }

.cs-page .cs-zigzag__media img {
	width: 100%;
	border-radius: var(--cs-radius);
	display: block;
	object-fit: cover;
	aspect-ratio: 4 / 3;
}

.cs-page ul.cs-bullet-list {
	margin: 20px 0 24px;
	padding: 0;
	list-style: none;
}

.cs-page ul.cs-bullet-list > li {
	position: relative;
	padding-left: 18px;
	margin-bottom: 10px;
	font-size: 0.95rem;
	list-style: none;
	list-style-type: none;
}

.cs-page ul.cs-bullet-list > li::marker {
	content: "";
}

.cs-page ul.cs-bullet-list > li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.55em;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--cs-accent);
}

/* Benefits */
.cs-page .cs-benefits {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin-top: 36px;
}

.cs-page .cs-benefit {
	display: flex;
	gap: 14px;
	background: #fff;
	padding: 22px;
	border-radius: var(--cs-radius);
}

.cs-page .cs-benefit__num {
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--cs-dark);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.85rem;
	font-weight: 700;
}

.cs-page .cs-benefit h3 {
	font-size: 0.95rem;
	margin: 0 0 8px;
	font-weight: 600;
}

.cs-page .cs-benefit p {
	margin: 0;
	font-size: 0.9rem;
	line-height: 1.6;
	color: var(--cs-muted);
}

/* Product rows */
.cs-page .cs-product-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	align-items: center;
	margin-bottom: 48px;
}

.cs-page .cs-product-row__media img {
	width: 100%;
	border-radius: var(--cs-radius);
	aspect-ratio: 4/3;
	object-fit: cover;
}

.cs-page .cs-product-row__title {
	font-size: 1.25rem;
	margin: 0 0 14px;
}

.cs-page .cs-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 16px;
}

.cs-page .cs-pill {
	padding: 6px 14px;
	border: 1px solid #ddd;
	border-radius: 999px;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

/* Cards */
.cs-page .cs-cards {
	display: grid;
	gap: 20px;
	margin-top: 32px;
}

.cs-page .cs-cards--4 { grid-template-columns: repeat(4, 1fr); }

.cs-page .cs-card {
	background: #fff;
	border-radius: var(--cs-radius);
	padding: 28px 22px;
	box-shadow: 0 8px 28px rgba(0, 0, 0, 0.06);
}

.cs-page .cs-card i {
	font-size: 1.5rem;
	color: var(--cs-accent);
	margin-bottom: 14px;
}

.cs-page .cs-card h3 {
	font-size: 1rem;
	margin: 0 0 10px;
	font-weight: 600;
}

.cs-page .cs-card p {
	margin: 0;
	font-size: 0.9rem;
	line-height: 1.6;
	color: var(--cs-muted);
}

.cs-page .cs-card--link {
	text-decoration: none;
	color: inherit;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.cs-page .cs-card--link:hover {
	transform: translateY(-4px);
	box-shadow: 0 14px 36px rgba(0, 0, 0, 0.1);
	text-decoration: none;
	color: inherit;
}

.cs-page .cs-card--link span {
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--cs-accent);
}

/* Icon features */
.cs-page .cs-icon-features {
	display: grid;
	gap: 18px;
	margin-top: 8px;
}

.cs-page .cs-icon-feature {
	display: flex;
	gap: 14px;
	align-items: flex-start;
}

.cs-page .cs-icon-feature i {
	font-size: 1.25rem;
	color: var(--cs-accent);
	margin-top: 4px;
}

.cs-page .cs-icon-feature strong {
	display: block;
	margin-bottom: 4px;
}

.cs-page .cs-icon-feature p {
	margin: 0;
	font-size: 0.9rem;
	color: var(--cs-muted);
}

/* QC */
.cs-page .cs-qc-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
	margin-top: 20px;
}

.cs-page .cs-qc-item {
	background: #fff;
	padding: 18px;
	border-radius: var(--cs-radius);
}

.cs-page .cs-qc-item strong {
	display: block;
	margin-bottom: 6px;
	font-size: 0.9rem;
}

.cs-page .cs-qc-item p {
	margin: 0;
	font-size: 0.85rem;
	color: var(--cs-muted);
}

/* Stats band */
.cs-page .cs-stats-band {
	background: #e8e8e8;
	padding: clamp(40px, 5vw, 64px) 0;
}

.cs-page .cs-stats-band__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
	text-align: center;
}

.cs-page .cs-stats-band__item strong {
	display: block;
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	line-height: 1;
	margin-bottom: 8px;
	color: var(--cs-dark);
}

.cs-page .cs-stats-band__item span {
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--cs-muted);
}

/* Team */
.cs-page .cs-team-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	margin-top: 32px;
}

.cs-page .cs-team-card img {
	width: 100%;
	aspect-ratio: 4/3;
	object-fit: cover;
	border-radius: var(--cs-radius);
	display: block;
}

.cs-page .cs-team-card figcaption {
	margin-top: 10px;
	font-size: 0.88rem;
	text-align: center;
	color: var(--cs-muted);
}

/* Certificates */
.cs-page .cs-cert-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 16px;
	margin-top: 28px;
}

.cs-page .cs-cert-badge {
	background: #fff;
	border: 1px solid #e0e0e0;
	border-radius: var(--cs-radius);
	padding: 20px 12px;
	text-align: center;
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

/* Projects */
.cs-page .cs-project-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
	margin-top: 32px;
}

.cs-page .cs-project-card img {
	width: 100%;
	aspect-ratio: 4/3;
	object-fit: cover;
	border-radius: var(--cs-radius);
	display: block;
}

.cs-page .cs-project-card h3 {
	font-size: 0.92rem;
	margin: 12px 0 0;
	font-weight: 600;
}

/* Process */
.cs-page .cs-process {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 16px;
	margin-top: 36px;
	position: relative;
}

.cs-page .cs-process__step {
	background: #fff;
	border-radius: var(--cs-radius);
	padding: 24px 16px;
	text-align: center;
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.05);
}

.cs-page .cs-process__icon {
	font-size: 1.35rem;
	color: var(--cs-accent);
	margin-bottom: 10px;
}

.cs-page .cs-process__num {
	display: block;
	font-size: 0.72rem;
	color: var(--cs-muted);
	margin-bottom: 6px;
}

/* FAQ */
.cs-page .cs-faq-wrap {
	max-width: 820px;
}

.cs-page .cs-faq__item {
	border-bottom: 1px solid #e5e5e5;
}

.cs-page .cs-faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 18px 0;
	border: 0;
	background: transparent;
	text-align: left;
	font-size: 1rem;
	font-weight: 600;
	cursor: pointer;
	color: var(--cs-dark);
}

.cs-page .cs-faq__toggle::before {
	content: "+";
	font-size: 1.25rem;
	line-height: 1;
}

.cs-page .cs-faq__item.is-open .cs-faq__toggle::before {
	content: "−";
}

.cs-page .cs-faq__answer {
	display: none;
	padding-bottom: 18px;
}

.cs-page .cs-faq__item.is-open .cs-faq__answer {
	display: block;
}

.cs-page .cs-faq__answer p {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.7;
	color: var(--cs-muted);
}

/* Contact */
.cs-page .cs-contact__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	align-items: start;
}

.cs-page .cs-contact__info {
	background: var(--cs-gray);
	border-radius: var(--cs-radius);
	padding: 32px;
}

.cs-page .cs-contact__info h3 {
	margin: 0 0 20px;
	font-size: 1.1rem;
}

.cs-page .cs-contact__info ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.cs-page .cs-contact__info li {
	display: flex;
	gap: 12px;
	align-items: flex-start;
	margin-bottom: 16px;
	font-size: 0.95rem;
	line-height: 1.5;
}

.cs-page .cs-contact__info i {
	color: var(--cs-accent);
	margin-top: 4px;
}

.cs-page .cs-contact__info a {
	color: inherit;
	text-decoration: underline;
}

/* Final CTA */
.cs-page .cs-final-cta {
	position: relative;
	text-align: center;
	padding: clamp(80px, 10vw, 120px) 4vw;
	background-size: cover;
	background-position: center;
	color: #fff;
}

.cs-page .cs-final-cta::before {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.65);
}

.cs-page .cs-final-cta__inner {
	position: relative;
	z-index: 1;
	max-width: 720px;
}

.cs-page .cs-final-cta h2 {
	font-family: var(--ts-heading-font-family, serif);
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	margin: 0 0 12px;
	color: #fff;
}

.cs-page .cs-final-cta p {
	margin: 0 0 28px;
	opacity: 0.9;
}

/* Full-width layout */
.cs-custom-services-layout .page-container,
.page-template-custom-services-template .page-container {
	max-width: 100%;
}

.cs-custom-services-layout #main-content,
.page-template-custom-services-template #main-content {
	width: 100% !important;
	max-width: 100%;
	float: none;
}

.cs-custom-services-layout #primary,
.page-template-custom-services-template #primary {
	padding: 0;
	width: 100%;
}

.cs-custom-services-layout article.page,
.page-template-custom-services-template article.page {
	margin: 0;
	padding: 0;
}

@media (max-width: 991px) {
	.cs-page .cs-hero__grid,
	.cs-page .cs-zigzag__grid,
	.cs-page .cs-product-row,
	.cs-page .cs-contact__grid {
		grid-template-columns: 1fr;
	}

	.cs-page .cs-zigzag--reverse .cs-zigzag__media,
	.cs-page .cs-zigzag--reverse .cs-zigzag__content { order: unset; }

	.cs-page .cs-benefits,
	.cs-page .cs-cards--4,
	.cs-page .cs-project-grid,
	.cs-page .cs-stats-band__grid,
	.cs-page .cs-process {
		grid-template-columns: repeat(2, 1fr);
	}

	.cs-page .cs-team-grid,
	.cs-page .cs-cert-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 575px) {
	.cs-page .cs-stats-card,
	.cs-page .cs-benefits,
	.cs-page .cs-cards--4,
	.cs-page .cs-project-grid,
	.cs-page .cs-stats-band__grid,
	.cs-page .cs-process,
	.cs-page .cs-team-grid,
	.cs-page .cs-cert-grid,
	.cs-page .cs-qc-grid {
		grid-template-columns: 1fr;
	}
}
