.oem-page .section-heading{flex-direction: column;gap: 10px;align-items: normal;}
.oem-page .section-heading__line{background: var(--bwo-color-teal);width: 50px;height: 3px;display: block;}
.oem-page .oem-solution .section-heading{align-items: center;gap: 16px;}
.oem-page .oem-solution .section-heading .section-heading__eyebrow {font-size: clamp(24px, 3.8vw, 48px);line-height: 1.2;}
.oem-page .oem-solution .section-heading__line{width: 60px;}
.oem-page .section-heading--left{margin-bottom: 16px;}
.oem-page {
	background: linear-gradient(180deg, #ffffff 0%, #f6fbfb 100%);
}
.oem-solution {
	padding-top: 108px;
	padding-bottom: 108px;
}
.oem-solution__box {
	position: relative;
	display: grid;
	gap: 18px;
	max-width: 1060px;
	margin-inline: auto;
	padding: 56px 52px;
	border-radius: 28px;
	background: #ffffff;
	box-shadow: 0 22px 60px rgb(16 38 59 / 8%);
	overflow: hidden;
	text-align: center;
}
.oem-solution__box::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at top left, rgb(10 170 168 / 18%) 0%, rgb(10 170 168 / 0%) 52%),
		radial-gradient(circle at bottom right, rgb(0 138 155 / 12%) 0%, rgb(0 138 155 / 0%) 58%);
	pointer-events: none;
}
.oem-solution__box > * {
	position: relative;
}
.oem-solution__title {
	margin: 0;
	color: var(--bwo-color-navy);
	font-size: clamp(34px, 3.8vw, 54px);
	font-weight: 900;
	line-height: 1.18;
}
.oem-solution__text {
	margin: 0;
	color: #5f6876;
	font-size: 16px;
	line-height: 1.95;
	max-width: 920px;
	margin-inline: auto;
}
.oem-strengths {
	padding-bottom: 108px;
}
.oem-strengths__header {
	display: grid;
	gap: 14px;
	margin-bottom: 34px;
}
.oem-strengths__intro {
	margin: 0;
	color: #5f6876;
	font-size: 16px;
	line-height: 1.9;
}
.oem-strengths__grid {
	position: relative;
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 34px 22px;
	border-radius: 28px;
	background: #ffffff;
	box-shadow: 0 22px 60px rgb(16 38 59 / 8%);
}
.oem-strengths__grid .oem-strengths__list{display: flex;flex-direction: column;gap: 18px;}
.oem-strengths__grid .oem-strengths__img{overflow: hidden;border-radius: 22px;}
.oem-strengths__grid .oem-strengths__img:hover img{transform: scale(1.08);}
.oem-strengths__item {
	grid-column: span 4;
	display: grid;
	gap: 10px;
	padding: 20px 20px 18px;
	border-radius: 22px;
	background: rgb(246 251 251 / 90%);
	border: 1px solid rgb(16 38 59 / 6%);
	min-width: 0;
}
.oem-strengths__item-head {
	display: flex;
	align-items: center;
	gap: 12px;
}
.oem-strengths__item-head .oem-strengths__title {
	flex: 1;
}
.oem-strengths__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 999px;
	background: linear-gradient(135deg, #0aaab0 0%, #008a9b 100%);
	color: #ffffff;
	font-size: 14px;
	font-weight: 900;
	letter-spacing: 0.12em;
	box-shadow: 0 18px 44px rgb(10 170 168 / 18%);
}
.oem-strengths__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: 16px;
	background: rgb(10 170 168 / 12%);
}
.oem-strengths__icon img {
	width: 22px;
	height: 22px;
}
.oem-strengths__title {
	margin: 0;
	color: var(--bwo-color-navy);
	font-size: 15px;
	font-weight: 900;
	line-height: 1.35;
}
.oem-strengths__text {
	margin: 0;
	color: #5f6876;
	font-size: 13px;
	line-height: 1.75;
}
.oem-customization {
	padding-bottom: 108px;
}
.oem-customization__header {
	display: grid;
	gap: 14px;
	margin-bottom: 44px;
}
.oem-customization__intro {
	margin: 0;
	color: #5f6876;
	font-size: 16px;
	line-height: 1.9;
	max-width: 920px;
}
.oem-customization__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
}
.custom-card {
	border-radius: 26px;
	background: #ffffff;
	box-shadow: 0 22px 60px rgb(16 38 59 / 8%);
	overflow: hidden;
}
.custom-card .custom-card__content{padding: 30px 26px 28px;}
.custom-card__title {
	margin: 0;
	color: var(--bwo-color-navy);
	font-size: 20px;
	font-weight: 900;
	line-height: 1.35;
}
.custom-card__list {
	margin: 16px 0 0;
	color: #5f6876;
	font-size: 15px;
	line-height: 1.85;
}
.oem-control {
	padding-bottom: 108px;
}
.oem-control__header {
	margin-bottom: 28px;
}
.oem-control__intro {
	display: grid;
	gap: 12px;
	max-width: 980px;
	margin-bottom: 34px;
}
.oem-control__text {
	margin: 0;
	color: #5f6876;
	font-size: 16px;
	line-height: 1.95;
}
.oem-control__stack {
	display: flex;
	gap: 24px;
	flex-direction: column;
}
.capability-card {
	padding: 34px 30px 30px;
	border-radius: 28px;
	background: #ffffff;
	box-shadow: 0 22px 60px rgb(16 38 59 / 8%);
	width: 100%;
}
.capability-card__head {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 14px;
}
.capability-card__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	border-radius: 18px;
	background: linear-gradient(135deg, #0aaab0 0%, #008a9b 100%);
	color: #ffffff;
	font-size: 14px;
	font-weight: 900;
	letter-spacing: 0.12em;
}
.capability-card__title {
	margin: 0;
	color: var(--bwo-color-navy);
	font-size: 20px;
	font-weight: 900;
	line-height: 1.35;
	flex: 1;
}
.capability-card__text {
	margin: 0;
	color: #5f6876;
	font-size: 15px;
	line-height: 1.95;
}
.capability-card__subhead {
	margin-top: 38px;
	color: var(--bwo-color-navy);
	font-size: 14px;
	font-weight: 900;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}
.capability-card__list {
	margin: 12px 0 0;
	padding-left: 18px;
	color: #5f6876;
	font-size: 15px;
	line-height: 1.85;
}
.capability-card__list li {
	list-style: disc;
}
.capability-card__list li + li {
	margin-top: 10px;
}
.capability-card__equip {
	margin: 12px 0 0;
	padding: 0;
	list-style: none;
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
}
.capability-card__equip-item {
	display: grid;
	gap: 10px;
	min-width: 0;
}
.capability-card__equip-item .capability-card__media-frame {
	border-radius: 20px;
}
.capability-card__equip-label {
	margin: 0;
	color: var(--bwo-color-navy);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.4;
	text-align: center;
}
.capability-card__media {
	margin-top: 14px;
	display: grid;
	gap: 12px;
}
.capability-card__media-frame {
	position: relative;
	width: 100%;
	border-radius: 22px;
	aspect-ratio: 16 / 9;
	border: 1px solid rgb(16 38 59 / 10%);
	overflow: hidden;
	display: grid;
	place-items: center;
}
.capability-card__media-frame video{
	max-width: 100%;
	max-height: 100%;
}
.capability-card__media-frame > * {
	position: relative;
}
.capability-card__media-play {
	width: 0;
	height: 0;
	border-left: 18px solid var(--bwo-color-teal);
	border-top: 11px solid transparent;
	border-bottom: 11px solid transparent;
	filter: drop-shadow(0 10px 24px rgb(16 38 59 / 20%));
	margin-left: 4px;
}
.capability-card__media-text {
	margin: 0;
	color: #5f6876;
	font-size: 14px;
	line-height: 1.9;
	max-width: 860px;
}
.capability-card__flow {
	display: flex;
	align-items: center;
	gap: 0;
	padding: 14px 12px;
	border-radius: 22px;
	background: rgb(246 251 251 / 52%);
	border: 1px solid rgb(16 38 59 / 6%);
	margin-top: 12px;
	overflow-x: auto;
	scrollbar-width: thin;
}
.capability-card__flow::-webkit-scrollbar {
	width: 4px;
	height: 4px;
}
.capability-card__flow::-webkit-scrollbar-track {
	height: 4px;
	background-color: #f5f6f7;
	-webkit-border-radius: 2em;
	-moz-border-radius: 2em;
	border-radius: 2em;
}
.capability-card__flow-step {
	position: relative;
	flex: 0 0 auto;
	min-width: 168px;
	padding: 0 18px;
	display: flex;
	justify-content: center;
}
.capability-card__flow-step:not(:last-child)::after {
	content: "";
	position: absolute;
	right: -18px;
	top: 50%;
	width: 36px;
	height: 2px;
	transform: translateY(-50%);
	background: rgb(10 170 168 / 28%);
}
.capability-card__flow-step:not(:last-child)::before {
	content: "";
	position: absolute;
	right: -18px;
	top: 50%;
	width: 8px;
	height: 8px;
	transform: translate(28px, -50%) rotate(45deg);
	border-top: 2px solid rgb(10 170 168 / 38%);
	border-right: 2px solid rgb(10 170 168 / 38%);
}
.capability-card__flow-label {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 8px;
	min-height: 84px;
	padding: 12px 14px;
	border-radius: 18px;
	background: #ffffff;
	border: 1px solid rgb(16 38 59 / 10%);
	color: var(--bwo-color-navy);
	font-size: 12px;
	font-weight: 800;
	text-align: center;
	line-height: 1.35;
	box-shadow: 0 16px 34px rgb(16 38 59 / 8%);
	min-width: 0;
}
.capability-card__flow-icon {
  width: 28px;
  height: 28px;
  color: var(--bwo-color-teal);
  flex: 0 0 auto;
}

.capability-card__flow-text {
  display: block;
  max-width: 152px;
}
.capability-card__note {
	margin: 16px 0 0;
	color: #5f6876;
	font-size: 15px;
	line-height: 1.9;
}
.oem-concept {
	padding: 0 0 108px;
}
.oem-concept__inner {
	display: grid;
	gap: 44px;
}
.oem-concept__header {
	display: grid;
	gap: 14px;
}
.oem-concept__title {
	margin: 0;
	color: var(--bwo-color-navy);
	font-size: clamp(32px, 3.4vw, 52px);
	font-weight: 900;
	line-height: 1.14;
}
.oem-concept .section-heading__eyebrow {
	color: rgb(17 38 59 / 82%);
}
.oem-flow {
	--oem-flow-pad-x: 22px;
	--oem-flow-badge-size: 44px;
	position: relative;
	display: grid;
	/* gap: 18px; */
	padding: 36px var(--oem-flow-pad-x);
	border-radius: 28px;
	background: #ffffff;
	border: 1px solid rgb(16 38 59 / 8%);
	box-shadow: 0 22px 60px rgb(16 38 59 / 8%);
}
.oem-flow::before {
	content: "";
	position: absolute;
	left: 50%;
	top: 28px;
	bottom: 28px;
	width: 2px;
	height: 86%;
	transform: translateX(-50%);
	background: rgb(10 170 168 / 18%);
	border-radius: 999px;
}
.oem-flow__step {
	--oem-flow-gap: 22px;
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1fr) var(--oem-flow-badge-size) minmax(0, 1fr);
	grid-template-areas: "left cap right";
	column-gap: var(--oem-flow-gap);
	align-items: center;
	z-index: 1;
}
.oem-flow__step:not(:first-child){margin-top: -55px;}
.oem-flow__card {
	grid-area: left;
	justify-self: end;
	align-self: center;
	width: min(560px, 100%);
}
.oem-flow__step--right .oem-flow__card {
	grid-area: right;
	justify-self: start;
	align-self: center;
	width: min(560px, 100%);
}
.oem-flow__cap {
	display: flex;
	justify-content: center;
	align-items: center;
	grid-area: cap;
	position: relative;
	height: var(--oem-flow-badge-size);
	align-self: center;
}
.oem-flow__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: var(--oem-flow-badge-size);
	height: var(--oem-flow-badge-size);
	position: relative;
	border-radius: 999px;
	background: linear-gradient(135deg, #0aaab0 0%, #008a9b 100%);
	color: #ffffff;
	font-size: 16px;
	font-weight: 900;
	box-shadow: 0 18px 44px rgb(10 170 168 / 18%);
	flex: 0 0 auto;
}
.oem-flow__step--left .oem-flow__badge::before,
.oem-flow__step--right .oem-flow__badge::after {
	content: "";
	position: absolute;
	top: 50%;
	width: var(--oem-flow-gap);
	height: 2px;
	transform: translateY(-50%);
	background: rgb(10 170 168 / 28%);
}
.oem-flow__step--left .oem-flow__badge::before {
	right: 100%;
}
.oem-flow__step--right .oem-flow__badge::after {
	left: 100%;
}
.oem-flow__card {
	padding: 30px 18px;
	border-radius: 22px;
	background: rgb(246 251 251 / 92%);
	border: 1px solid rgb(16 38 59 / 6%);
}
.oem-flow__title {
	margin: 0;
	color: var(--bwo-color-navy);
	font-size: 15px;
	font-weight: 900;
	line-height: 1.35;
}
.oem-flow__list {
	margin: 12px 0 0;
	padding-left: 18px;
	color: #5f6876;
	font-size: 13px;
	line-height: 1.75;
}
.oem-flow__list li{list-style: disc;}
.oem-flow__list li + li {
	margin-top: 8px;
}
.oem-flow__finish {
	position: relative;
	justify-self: center;
	margin-top: 10px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 14px;
	border-radius: 999px;
	background: rgb(10 170 168 / 12%);
	border: 1px solid rgb(10 170 168 / 22%);
}
.oem-flow__finish-label {
	color: var(--bwo-color-navy);
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}
.oem-video {
	display: grid;
	grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
	gap: 26px;
	align-items: center;
	padding: 28px;
	border-radius: 28px;
	background: #ffffff;
	border: 1px solid rgb(16 38 59 / 8%);
	box-shadow: 0 22px 60px rgb(16 38 59 / 8%);
}
.oem-video__content {
	display: grid;
	gap: 14px;
}
.oem-video__title {
	margin: 0;
	color: var(--bwo-color-navy);
	font-size: 22px;
	font-weight: 900;
	line-height: 1.3;
}
.oem-video__text {
	margin: 0;
	color: #5f6876;
	font-size: 15px;
	line-height: 1.9;
}
.oem-video__frame {
	width: 100%;
}
.oem-video__placeholder {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	border-radius: 22px;
	background:
		linear-gradient(135deg, rgb(10 170 168 / 18%) 0%, rgb(0 138 155 / 10%) 44%, rgb(17 38 59 / 4%) 100%),
		url("../img/about-collage-03.png") center / cover no-repeat;
	border: 1px solid rgb(16 38 59 / 10%);
	overflow: hidden;
}
.oem-faq {
	padding-bottom: 108px;
}
.oem-faq__header {
	margin-bottom: 36px;
}
.oem-faq__accordion {
	border-radius: 26px;
	overflow: hidden;
	box-shadow: 0 22px 60px rgb(16 38 59 / 8%);
	background: #ffffff;
}
.oem-faq__item {
	border: 0;
	border-bottom: 1px solid rgb(16 38 59 / 8%);
}
.oem-faq__item:last-child {
	border-bottom: 0;
}
.oem-faq__button {
	padding: 22px 24px;
	font-weight: 900;
	color: var(--bwo-color-navy);
	background: #ffffff;
}
.oem-faq__button:focus {
	box-shadow: none;
}
.oem-faq__body {
	padding: 0 24px 24px;
	color: #5f6876;
	font-size: 15px;
	line-height: 1.9;
}
@media (max-width: 1199.98px) {
	.oem-solution__box {
		padding: 48px 44px;
	}
	.oem-strengths__grid {
		padding: 26px 22px;
		gap: 14px;
	}
	.oem-strengths__item {
		grid-column: auto;
	}
	.oem-customization__grid {
		grid-template-columns: 1fr;
	}
	.capability-card__flow-step {
		min-width: 156px;
		padding: 0 16px;
	}
	.capability-card__equip {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
	.oem-flow__step {
		--oem-flow-gap: 16px;
		column-gap: var(--oem-flow-gap);
	}
}
@media (max-width: 991.98px) {
	.oem-solution,
	.oem-strengths,
	.oem-customization,
	.oem-control,
	.oem-faq {
		padding-top: 48px;
		padding-bottom: 48px;
	}
	.oem-solution__box{
		padding: 30px 24px;
	}
	.oem-concept {
		padding: 0 0 28px;
	}
	.oem-video {
		grid-template-columns: 1fr;
	}
}
@media (max-width: 767.98px) {
	.oem-solution__text{
		font-size: 14px;
	}
	.oem-strengths__header {
		margin-bottom: 24px;
	}
	.oem-strengths__badge {
		width: 40px;
		height: 40px;
		font-size: 13px;
	}
	.oem-strengths__icon {
		width: 38px;
		height: 38px;
	}
	.oem-strengths__icon img {
		width: 20px;
		height: 20px;
	}
	.oem-strengths__title {
		font-size: 14px;
	}
	.oem-strengths__text {
		font-size: 13px;
	}
	.capability-card__flow {
		padding: 12px 10px;
	}
	.capability-card__flow-step {
		min-width: 148px;
		padding: 0 14px;
	}
	.capability-card__flow-label {
		min-height: 76px;
		padding-inline: 12px;
	}
	.capability-card__equip {
		grid-template-columns: repeat(1, minmax(0, 1fr));
		gap: 14px;
	}
	.capability-card__equip-label {
		font-size: 12px;
	}
	.oem-flow::before {
		left: calc(var(--oem-flow-pad-x) + 22px);
		transform: none;
	}
	.oem-flow__step {
		--oem-flow-badge-size: 44px;
		grid-template-columns: var(--oem-flow-badge-size) minmax(0, 1fr);
		grid-template-areas: "cap content";
		column-gap: 14px;
	}
	.oem-flow__cap {
		justify-content: flex-start;
	}
	.oem-flow__card,
	.oem-flow__step--right .oem-flow__card {
		grid-area: content;
		justify-self: stretch;
	}
	.oem-flow__step--left .oem-flow__badge::before,
	.oem-flow__step--right .oem-flow__badge::after {
		display: none;
	}
	.capability-card{padding:20px;}
	.capability-card__title{font-size: 16px;}
	.oem-concept__inner{gap:20px}
	.oem-flow__step:not(:first-child){margin-top: 10px;}
	.capability-card__subhead{margin-top: 20px;}
}
@media (max-width: 360px) {
	.oem-flow {
		--oem-flow-pad-x: 18px;
	}
	.oem-video {
		padding-inline: 18px;
	}
	.oem-solution__box {
		padding-inline: 20px;
	}
}