/**
 * Services section — grid + desktop row panels / mobile inline accordion.
 *
 * @package WoodMart Child
 */

.wi-services {
	--wi-color-surface: #262626;
	--wi-color-surface-raised: #2c2c2c;
	--wi-color-text: #f0f0f0;
	--wi-color-text-muted: #d0d0d0;
	--wi-color-accent: #008080;
	--wi-color-border: #3d3d3d;
	--wi-color-border-strong: #4a4a4a;
	--wi-space-3: 1rem;
	--wi-space-4: 1.25rem;
	--wi-space-5: 1.5rem;
	--wi-space-6: 2rem;
	--wi-space-7: 2.5rem;
	--wi-space-8: 3rem;
	--wi-radius-lg: 10px;
	--wi-contact-radius: clamp(14px, 1.35vw, 18px);
	--wi-shadow-sm: 0 1px 2px rgb(0 0 0 / 0.35);
	--wi-transition-fast: 0.18s ease;
	--wi-services-gap: clamp(1.25rem, 2.5vw, 1.625rem);
	--wi-services-accent-soft: rgb(0 128 128 / 0.38);
	--wi-services-accent-hover: rgb(0 128 128 / 0.55);
}

@media (prefers-reduced-motion: reduce) {
	.wi-services {
		--wi-transition-fast: 0.01ms;
	}
}

.wi-services {
	margin: 0;
	padding: clamp(var(--wi-space-6), 4vw, var(--wi-space-8)) 0 clamp(var(--wi-space-7), 3.5vw, var(--wi-space-8));
	color: var(--wi-color-text);
	box-sizing: border-box;
}

.wi-services__head {
	margin: 0 0 clamp(var(--wi-space-6), 3.5vw, var(--wi-space-7));
	padding: 0;
	text-align: center;
}

.wi-services__title {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: baseline;
	gap: 0.35em 0.5em;
	margin: 0;
	font-family: system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	font-size: clamp(1.875rem, 3.6vw, 2.875rem);
	font-weight: 800;
	line-height: 1.05;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.wi-services__title-part {
	color: var(--wi-color-text);
}

.wi-services__title-part--accent {
	color: var(--wi-color-accent);
}

.wi-services__title--plain {
	display: block;
	color: var(--wi-color-text);
}

.wi-services__row {
	margin: 0 0 var(--wi-services-gap);
	padding: 0;
}

.wi-services__row:last-child {
	margin-bottom: 0;
}

.wi-services__card-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wi-services-gap);
}

.wi-services__cell {
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
}

.wi-services__card {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 100%;
	margin: 0;
	padding: 0;
	border-radius: var(--wi-contact-radius);
	background-color: var(--wi-color-surface);
	border: 1px solid var(--wi-color-border);
	box-shadow: var(--wi-shadow-sm);
	cursor: default;
	text-align: center;
	color: inherit;
	font: inherit;
	transition:
		border-color var(--wi-transition-fast),
		box-shadow var(--wi-transition-fast);
}

.wi-services__card:hover:not(.is-active) {
	border-color: var(--wi-services-accent-hover);
	box-shadow: 0 0 0 1px var(--wi-services-accent-soft);
	background: var(--wi-color-accent) !important;
	color: #fff !important;
}

.wi-services__card:focus-visible {
	outline: 2px solid var(--wi-color-accent);
	outline-offset: 3px;
	background: var(--wi-color-accent) !important;
	color: #fff !important;
}

.wi-services__card.is-active {
	border-color: var(--wi-color-accent);
	box-shadow: 0 0 0 1px var(--wi-services-accent-soft);
	background: var(--wi-color-accent) !important;
	color: #fff !important;
}

.wi-services__card-visual {
	display: block;
	width: 100%;
	border-radius: calc(var(--wi-contact-radius) - 2px) calc(var(--wi-contact-radius) - 2px) 0 0;
	overflow: hidden;
	background-color: var(--wi-color-surface-raised);
	aspect-ratio: 16 / 10;
}

.wi-services__card-thumb {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.wi-services__card-thumb--placeholder {
	display: block;
	width: 100%;
	height: 100%;
	min-height: 8rem;
	background: linear-gradient(
		168deg,
		color-mix(in srgb, var(--wi-color-surface-raised) 88%, var(--wi-color-accent) 12%) 0%,
		var(--wi-color-surface) 100%
	);
}

.wi-services__card-label {
	display: block;
	width: 100%;
	padding: var(--wi-space-4) var(--wi-space-4) var(--wi-space-5);
	font-family: system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	font-size: clamp(1rem, 2vw, 1.125rem);
	font-weight: 800;
	line-height: 1.2;
	letter-spacing: -0.02em;
}

/* -------------------------------------------------------------------------
   Desktop panel (hidden on small screens; collapsed when [hidden])
   ------------------------------------------------------------------------- */
.wi-services__desktop-panel {
	margin-top: var(--wi-services-gap);
	padding: clamp(var(--wi-space-5), 3vw, var(--wi-space-7));
	border-radius: var(--wi-contact-radius);
	background-color: var(--wi-color-surface);
	border: 1px solid var(--wi-color-border);
	box-shadow: var(--wi-shadow-sm);
	display: none;
}

.wi-services__desktop-panel[hidden] {
	display: none !important;
	margin-top: 0 !important;
	padding: 0 !important;
	border-width: 0 !important;
	min-height: 0 !important;
	overflow: hidden !important;
	box-shadow: none !important;
}

/* -------------------------------------------------------------------------
   Mobile inline bodies (hidden on desktop)
   ------------------------------------------------------------------------- */
.wi-services__mobile-body {
	margin-top: var(--wi-space-3);
	padding: var(--wi-space-4);
	border-radius: var(--wi-radius-lg);
	background-color: var(--wi-color-surface);
	border: 1px solid var(--wi-color-border);
}

.wi-services__mobile-body[hidden] {
	display: none !important;
}

.wi-services__mobile-body .wi-services__detail-media {
	display: none;
}

.wi-services__detail-inner {
	display: flex;
	flex-direction: column;
	gap: var(--wi-space-4);
	align-items: stretch;
}

.wi-services__detail-copy {
	display: flex;
	flex-direction: column;
	gap: var(--wi-space-4);
	min-width: 0;
}

.wi-services__detail-media {
	flex-shrink: 0;
	width: 100%;
	max-width: 12rem;
	border-radius: var(--wi-radius-lg);
	overflow: hidden;
	background-color: var(--wi-color-surface-raised);
}

.wi-services__detail-img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
	object-position: center;
}

.wi-services__detail-title {
	margin: 0;
	font-family: system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	font-size: clamp(1.125rem, 2.2vw, 1.5rem);
	font-weight: 800;
	line-height: 1.15;
	letter-spacing: -0.02em;
	color: var(--wi-color-text);
}

.wi-services__detail-content {
	font-size: clamp(0.9375rem, 1.4vw, 1.0625rem);
	line-height: 1.6;
	color: color-mix(in srgb, var(--wi-color-text-muted) 90%, var(--wi-color-text) 10%);
}

.wi-services__detail-content > *:first-child {
	margin-top: 0;
}

.wi-services__detail-content > *:last-child {
	margin-bottom: 0;
}

@media (min-width: 48rem) {
	.wi-services__card-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.wi-services__desktop-panel:not([hidden]) {
		display: block;
	}

	.wi-services__mobile-body {
		display: none !important;
	}

	.wi-services__desktop-body .wi-services__detail-inner {
		display: grid;
		grid-template-columns: minmax(10rem, 40%) minmax(0, 1fr);
		column-gap: clamp(var(--wi-space-4), 2.5vw, var(--wi-space-6));
		align-items: stretch;
		min-height: 0;
	}

	.wi-services__desktop-body .wi-services__detail-inner:not(:has(.wi-services__detail-media)) {
		grid-template-columns: 1fr;
	}

	.wi-services__desktop-body .wi-services__detail-media {
		grid-column: 1;
		grid-row: 1;
		display: flex;
		flex-direction: column;
		width: 100%;
		max-width: none;
		height: 100%;
		min-height: 0;
		align-self: stretch;
		border-radius: var(--wi-radius-lg);
		overflow: hidden;
		background-color: var(--wi-color-surface-raised);
	}

	.wi-services__desktop-body .wi-services__detail-copy {
		grid-column: 2;
		grid-row: 1;
		align-self: stretch;
		min-height: 0;
	}

	.wi-services__desktop-body .wi-services__detail-inner:not(:has(.wi-services__detail-media)) .wi-services__detail-copy {
		grid-column: 1 / -1;
	}

	.wi-services__desktop-body .wi-services__detail-img {
		display: block;
		width: 100%;
		height: 100%;
		flex: 1 1 auto;
		min-height: 0;
		object-fit: cover;
		object-position: center;
	}
}
