/**
 * Home — Service cards mobile open panel (left-slide in/out, same path every time).
 */

.service-card-open-btn,
.service-card-close {
	display: none;
}

@media screen and (max-width: 767px) {
	body.wr-service-card-open {
		overflow: hidden;
	}

	.section.service .service-card {
		position: relative;
	}

	.section.service .service-card-font {
		cursor: pointer;
	}

	/* Mobile front-card affordance — bordered plus (matches Figma service card SM). */
	.section.service .service-card-open-btn {
		position: absolute;
		top: 18px;
		right: 18px;
		z-index: 2;
		display: flex;
		align-items: center;
		justify-content: center;
		width: 32px;
		height: 32px;
		border: 1.5px solid rgba(24, 49, 50, 0.55);
		border-radius: 50%;
		background: transparent;
		color: #183132;
		line-height: 1;
		flex: none;
		cursor: pointer;
		padding: 0;
		-webkit-appearance: none;
		appearance: none;
		font-size: 15px;
		font-family: remixicon !important;
		font-style: normal;
		font-weight: normal;
		-webkit-font-smoothing: antialiased;
	}

	.section.service .service-card-open-btn::before {
		line-height: 1;
		color: currentColor;
	}

	.section.service .service-card.is-open .service-card-open-btn,
	.section.service .service-card.is-closing .service-card-open-btn {
		opacity: 0;
		visibility: hidden;
	}

	/* Panel always uses fixed + left-origin slide — open and close share one path */
	.section.service .service-card-back {
		position: fixed;
		top: 50%;
		left: 20px;
		right: 20px;
		bottom: auto;
		z-index: 889;
		width: auto;
		height: auto;
		max-height: calc(100dvh - 40px);
		max-width: none;
		min-height: 0;
		margin: 0;
		padding: 40px 24px 32px;
		border-radius: var(--_base---r32);
		border: 2px solid rgba(255, 255, 255, 0.92);
		border-color: rgba(255, 255, 255, 0.92) rgba(255, 255, 255, 0.72) rgba(255, 255, 255, 0.72) rgba(255, 255, 255, 0.92);
		background-image: url('../img/Wrap.svg'), linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.9));
		background-position: 50%, 0 0;
		background-repeat: no-repeat, repeat;
		background-size: cover, auto;
		-webkit-backdrop-filter: blur(12px);
		backdrop-filter: blur(12px);
		box-shadow:
			0 16px 48px rgba(67, 56, 145, 0.14),
			1px 2px 8px rgba(0, 0, 0, 0.08);
		overflow-x: hidden;
		overflow-y: auto;
		justify-content: flex-start;
		gap: 24px;
		isolation: isolate;
		transform: translate(-100%, -50%);
		transform-origin: left center;
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
		transition:
			transform 0.52s cubic-bezier(0.22, 1, 0.36, 1),
			opacity 0.38s cubic-bezier(0.4, 0, 0.2, 1),
			visibility 0.38s step-end;
		will-change: transform, opacity;
	}

	.section.service .service-card.is-open,
	.section.service .service-card.is-closing {
		z-index: 890;
	}

	.section.service .service-card.is-open::before,
	.section.service .service-card.is-closing::before {
		content: '';
		position: fixed;
		inset: 0;
		z-index: 888;
		background: rgba(248, 247, 255, 0.72);
		-webkit-backdrop-filter: blur(14px);
		backdrop-filter: blur(14px);
		pointer-events: auto;
		transition: opacity 0.38s cubic-bezier(0.4, 0, 0.2, 1);
	}

	.section.service .service-card.is-open::before {
		opacity: 1;
	}

	.section.service .service-card.is-closing::before {
		opacity: 0;
		pointer-events: none;
	}

	.section.service .service-card.is-open .service-card-back,
	.section.service .service-card.is-closing .service-card-back {
		visibility: visible;
		transition:
			transform 0.52s cubic-bezier(0.22, 1, 0.36, 1),
			opacity 0.38s cubic-bezier(0.4, 0, 0.2, 1),
			visibility 0s step-end;
	}

	.section.service .service-card.is-open .service-card-back {
		transform: translate(0, -50%) !important;
		transform-origin: left center !important;
		opacity: 1;
		pointer-events: auto;
	}

	.section.service .service-card.is-closing .service-card-back {
		transform: translate(-100%, -50%) !important;
		transform-origin: left center !important;
		opacity: 0;
		pointer-events: none;
	}

	.section.service .service-card-close {
		position: absolute;
		top: 18px;
		right: 18px;
		z-index: 5;
		display: none;
		align-items: center;
		justify-content: center;
		width: 40px;
		height: 40px;
		padding: 0;
		border: 1.5px solid rgba(58, 51, 84, 0.32);
		border-radius: 50%;
		background: #fff;
		color: #3a3354;
		cursor: pointer;
		line-height: 1;
		flex: none;
		font-size: 20px;
		-webkit-appearance: none;
		appearance: none;
		box-shadow: 0 2px 10px rgba(67, 56, 145, 0.1);
		font-family: remixicon !important;
		font-style: normal;
		font-weight: normal;
		-webkit-font-smoothing: antialiased;
	}

	.section.service .service-card-close::before {
		line-height: 1;
		color: currentColor;
	}

	.section.service .service-card.is-open .service-card-close,
	.section.service .service-card.is-closing .service-card-close {
		display: flex;
	}

	.section.service .service-card.is-open .service-card-list {
		padding-right: 40px;
		flex: 0 1 auto;
	}

	.section.service .service-card.is-open .button-secondary {
		margin-top: 0;
		margin-bottom: 4px;
		flex-shrink: 0;
		align-self: flex-start;
	}
}

@media screen and (max-width: 479px) {
	.section.service .service-card-back {
		left: 16px;
		right: 16px;
		max-height: calc(100dvh - 32px);
		padding: 38px 20px 28px;
	}

	.section.service .service-card-close {
		top: 14px;
		right: 14px;
		width: 36px;
		height: 36px;
		font-size: 18px;
	}

	.section.service .service-card-open-btn {
		top: 14px;
		right: 14px;
		width: 28px;
		height: 28px;
		font-size: 14px;
	}
}

@media (prefers-reduced-motion: reduce) {
	@media screen and (max-width: 767px) {
		.section.service .service-card-back,
		.section.service .service-card.is-open::before,
		.section.service .service-card.is-closing::before {
			transition-duration: 0.01ms !important;
		}
	}
}
