/*!
Theme Name: yiliaotest
Theme URI: http://underscores.me/
Author: Underscores.me
Author URI: http://underscores.me/
Description: Life science testing service WordPress theme.
Version: 1.1.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: yiliaotest
Tags: custom-logo, custom-menu, featured-images, responsive-layout
*/

:root {
	--color-primary: #3f5faf;
	--color-deep: #233b7a;
	--color-bright: #4169e1;
	--color-soft: #f3f7ff;
	--color-violet: #5a6fc8;
	--color-text: #1f2937;
	--color-muted: #5b6472;
	--color-border: #e5eaf4;
	--color-orange: #f59a23;
	--shadow-soft: 0 14px 38px rgba(35, 59, 122, 0.12);
	--shadow-card: 0 10px 26px rgba(35, 59, 122, 0.1);
	--radius: 8px;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	color: var(--color-text);
	background: #fff;
	font-family: "Microsoft YaHei", "PingFang SC", "Hiragino Sans GB", Arial, sans-serif;
	font-size: 16px;
	line-height: 1.7;
	letter-spacing: 0;
}


a {
	color: inherit;
	text-decoration: none;
}

a:hover {
	color: var(--color-primary);
}

img {
	display: block;
	max-width: 100%;
	height: auto;
}

button,
input,
textarea {
	font: inherit;
}

button {
	cursor: pointer;
}

.container {
	width: min(1200px, calc(100% - 48px));
	margin: 0 auto;
}

.icon {
	width: 1em;
	height: 1em;
	fill: none;
	stroke: currentColor;
	stroke-width: 2;
	stroke-linecap: round;
	stroke-linejoin: round;
	flex: 0 0 auto;
}

.screen-reader-text {
	position: absolute !important;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.skip-link:focus {
	top: 8px;
	left: 8px;
	z-index: 10000;
	width: auto;
	height: auto;
	padding: 10px 14px;
	clip: auto;
	color: #fff;
	background: var(--color-deep);
	border-radius: var(--radius);
}

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 0 24px;
	border-radius: 6px;
	font-weight: 700;
	line-height: 1;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.btn:hover {
	transform: translateY(-2px);
	color: #fff;
}

.btn--orange {
	color: #fff;
	background: var(--color-orange);
	box-shadow: 0 10px 22px rgba(245, 154, 35, 0.25);
}

.btn--orange:hover {
	background: #e88713;
}

.btn--blue {
	color: #fff;
	background: linear-gradient(135deg, var(--color-primary), var(--color-bright));
	box-shadow: 0 10px 22px rgba(63, 95, 175, 0.24);
}

.btn--outline {
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.65);
	background: rgba(255, 255, 255, 0.08);
}

.btn--outline:hover {
	background: rgba(255, 255, 255, 0.18);
}

.site-header {
	position: relative;
	z-index: 1000;
	background: #fff;
	box-shadow: 0 3px 18px rgba(35, 59, 122, 0.08);
}

.top-strip {
	height: 36px;
	background: #f6f8fc;
	color: var(--color-muted);
	font-size: 13px;
}

.top-strip__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 100%;
	gap: 20px;
}

.top-strip__welcome {
	margin: 0;
}

.top-links__menu,
.primary-menu,
.footer-menu {
	list-style: none;
	padding: 0;
	margin: 0;
}

.top-links__menu {
	display: flex;
	align-items: center;
	gap: 22px;
}

.top-links__item {
	position: relative;
}

.top-links__menu a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	white-space: nowrap;
}

.top-links__qr {
	position: absolute;
	top: calc(100% + 11px);
	right: 0;
	z-index: 1200;
	width: 146px;
	padding: 12px 12px 10px;
	text-align: center;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: 0 12px 28px rgba(20, 42, 86, 0.16);
	visibility: hidden;
	opacity: 0;
	pointer-events: none;
	transform: translateY(-6px);
	transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
}

.top-links__qr::before {
	content: "";
	position: absolute;
	top: -6px;
	right: 22px;
	width: 12px;
	height: 12px;
	background: #fff;
	border-top: 1px solid var(--color-border);
	border-left: 1px solid var(--color-border);
	transform: rotate(45deg);
}

.top-links__qr img {
	width: 118px;
	height: 118px;
	margin: 0 auto 6px;
	object-fit: cover;
}

.top-links__qr span {
	display: block;
	color: var(--color-text);
	font-size: 12px;
	line-height: 1.4;
}

.top-links__item:hover .top-links__qr,
.top-links__item:focus-within .top-links__qr {
	visibility: visible;
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}

.brand-row {
	background: #fff;
}

.brand-row__inner {
	display: grid;
	grid-template-columns: 330px minmax(360px, 520px) minmax(250px, 1fr);
	align-items: center;
	gap: 24px;
	min-height: 92px;
}

.site-branding {
	display: flex;
	align-items: center;
	gap: 14px;
	min-width: 0;
}

.brand-mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 112px;
	height: 48px;
	padding: 4px 0;
	background: transparent;
	color: var(--color-primary);
	box-shadow: none;
}

.brand-mark__image {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.custom-logo-link img {
	width: auto;
	max-width: 84px;
	max-height: 58px;
}

.brand-copy {
	min-width: 0;
}

.site-title {
	margin: 0;
	color: var(--color-primary);
	font-size: 25px;
	font-weight: 800;
	line-height: 1.2;
	white-space: nowrap;
}

.site-title a:hover {
	color: var(--color-deep);
}

.site-description {
	margin: 5px 0 0;
	color: var(--color-muted);
	font-size: 14px;
	white-space: nowrap;
}

.site-search {
	display: flex;
	height: 46px;
	border: 2px solid var(--color-primary);
	border-radius: 4px;
	overflow: hidden;
	background: #fff;
}

.site-search input {
	flex: 1;
	min-width: 0;
	border: 0;
	padding: 0 18px;
	color: var(--color-text);
	outline: 0;
}

.site-search button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 66px;
	border: 0;
	color: #fff;
	background: var(--color-primary);
}

.header-phone {
	display: flex;
	align-items: center;
	justify-self: end;
	gap: 12px;
	color: var(--color-deep);
	white-space: nowrap;
}

.header-phone__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	color: #fff;
	background: var(--color-primary);
}

.header-phone strong,
.header-phone small {
	display: block;
	line-height: 1.25;
}

.header-phone strong {
	font-size: 23px;
	font-weight: 900;
}

.header-phone small {
	margin-top: 4px;
	color: var(--color-muted);
	font-size: 12px;
}

.mobile-menu-toggle,
.mobile-search-row {
	display: none;
}

.main-navigation {
	height: 58px;
	background: var(--color-primary);
	color: #fff;
}

.main-navigation__inner,
.primary-menu {
	height: 100%;
}

.primary-menu {
	display: flex;
	align-items: stretch;
}

.primary-menu > li {
	position: relative;
	display: flex;
}

.primary-menu > li > a {
	display: flex;
	align-items: center;
	padding: 0 18px;
	color: #fff;
	font-weight: 700;
	font-size: 15px;
	white-space: nowrap;
}

.primary-menu > li.current-menu-item > a,
.primary-menu > li.current-menu-ancestor > a,
.primary-menu > li > a:hover,
.primary-menu > li.focus > a {
	color: #fff;
	background: var(--color-orange);
}

.primary-menu .sub-menu {
	position: absolute;
	top: 100%;
	left: 0;
	z-index: 50;
	display: grid;
	grid-template-columns: repeat(3, minmax(180px, 1fr));
	gap: 0;
	width: 760px;
	padding: 20px;
	margin: 0;
	list-style: none;
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	background: #fff;
	border-top: 4px solid var(--color-orange);
	box-shadow: var(--shadow-soft);
	transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
}

.primary-menu li:hover > .sub-menu,
.primary-menu li.focus > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.primary-menu .sub-menu a {
	display: block;
	padding: 10px 12px;
	color: var(--color-text);
	border-radius: 6px;
	font-size: 14px;
}

.primary-menu .sub-menu a:hover {
	color: var(--color-primary);
	background: var(--color-soft);
}

.home-hero {
	min-height: 520px;
	color: #fff;
	background-image: linear-gradient(90deg, rgba(35, 59, 122, 0.98) 0%, rgba(35, 59, 122, 0.88) 38%, rgba(63, 95, 175, 0.46) 64%, rgba(63, 95, 175, 0.08) 100%), url("assets/images/hero-lab.png");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center right;
}

.home-hero__inner {
	display: flex;
	align-items: center;
	min-height: 520px;
}

.home-hero__content {
	width: min(720px, 62%);
	padding: 32px 0 82px;
}

.home-hero h1 {
	margin: 0 0 18px;
	font-size: 46px;
	line-height: 1.18;
	font-weight: 900;
}

.home-hero__subtitle {
	margin: 0;
	max-width: 660px;
	font-size: 20px;
	line-height: 1.75;
	color: rgba(255, 255, 255, 0.92);
}

.home-hero__subtitle--mobile {
	display: none;
}

.hero-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 16px 22px;
	margin: 28px 0 30px;
}

.hero-badges span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: rgba(255, 255, 255, 0.9);
	font-size: 14px;
}

.hero-badges .icon {
	width: 28px;
	height: 28px;
	padding: 5px;
	border: 1px solid rgba(255, 255, 255, 0.28);
	border-radius: 50%;
}

.hero-actions {
	display: flex;
	gap: 16px;
}

.advantage-band {
	position: relative;
	margin-top: -64px;
	padding-bottom: 26px;
}

.advantage-card {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 0;
	padding: 28px 26px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: var(--shadow-soft);
}

.advantage-card__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 7px;
	padding: 0 14px;
	border-right: 1px solid var(--color-border);
}

.advantage-card__item:last-child {
	border-right: 0;
}

.advantage-card__item .icon {
	width: 36px;
	height: 36px;
	color: var(--color-primary);
}

.advantage-card__item strong {
	color: var(--color-text);
	font-size: 15px;
	line-height: 1.3;
}

.advantage-card__item span {
	color: var(--color-muted);
	font-size: 12px;
	line-height: 1.4;
}

.section {
	padding: 56px 0;
}

.section--white {
	background: #fff;
}

.section--blue {
	background: linear-gradient(180deg, #f5f8ff 0%, #eef4ff 100%);
}

.section-heading {
	margin: 0 0 28px;
	text-align: center;
}

.section-heading h2 {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 16px;
	margin: 0;
	color: var(--color-text);
	font-size: 28px;
	line-height: 1.25;
	font-weight: 900;
}

.section-heading h2::before,
.section-heading h2::after {
	content: "";
	width: 42px;
	height: 2px;
	background: linear-gradient(90deg, transparent, var(--color-primary));
}

.section-heading h2::after {
	background: linear-gradient(90deg, var(--color-primary), transparent);
}

.section-heading p {
	margin: 10px auto 0;
	max-width: 720px;
	color: var(--color-muted);
}

.section-heading--left {
	text-align: left;
}

.section-heading--left h2::before {
	display: none;
}

.section-heading--inline {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	text-align: left;
	gap: 24px;
}

.section-heading--inline h2::before {
	display: none;
}

.section-heading--inline p {
	margin-left: 0;
}

.section-heading--inline > a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: var(--color-primary);
	font-weight: 700;
	white-space: nowrap;
}

.service-card-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 18px;
}

.service-photo-card {
	position: relative;
	min-height: 186px;
	padding: 24px 22px 20px;
	overflow: hidden;
	color: #fff;
	background-size: cover;
	background-position: center;
	border-radius: 8px;
	box-shadow: var(--shadow-card);
}

.service-photo-card::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(63, 95, 175, 0.84), rgba(35, 59, 122, 0.66));
	transition: background 0.2s ease;
}

.service-photo-card:hover::before {
	background: linear-gradient(135deg, rgba(35, 59, 122, 0.9), rgba(63, 95, 175, 0.72));
}

.service-photo-card > * {
	position: relative;
	z-index: 1;
}

.service-photo-card__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	margin-bottom: 20px;
	border-radius: 50%;
	color: var(--color-primary);
	background: #fff;
}

.service-photo-card strong,
.service-photo-card em {
	display: block;
}

.service-photo-card strong {
	max-width: 92%;
	font-size: 20px;
	line-height: 1.25;
}

.service-photo-card em {
	margin-top: 8px;
	color: rgba(255, 255, 255, 0.82);
	font-style: normal;
	font-size: 13px;
	line-height: 1.5;
}

.service-photo-card__arrow {
	position: absolute;
	right: 18px;
	bottom: 18px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	border: 1px solid rgba(255, 255, 255, 0.5);
}

.category-icon-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 14px;
}

.category-icon-card,
.solution-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	min-height: 140px;
	padding: 24px 16px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 8px;
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.category-icon-card:hover,
.solution-card:hover,
.case-card:hover,
.archive-card:hover {
	transform: translateY(-5px);
	box-shadow: var(--shadow-card);
	border-color: rgba(63, 95, 175, 0.28);
}

.category-icon-card .icon,
.solution-card .icon {
	width: 38px;
	height: 38px;
	color: var(--color-primary);
}

.category-icon-card strong,
.solution-card strong {
	margin-top: 14px;
	color: var(--color-text);
	font-size: 16px;
	line-height: 1.35;
}

.category-icon-card span,
.solution-card span {
	margin-top: 6px;
	color: var(--color-muted);
	font-size: 13px;
	line-height: 1.45;
}

.solution-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 14px;
}

.solution-card {
	min-height: 166px;
	align-items: flex-start;
	text-align: left;
}

.solution-card .icon {
	width: 32px;
	height: 32px;
}

.lab-strength__grid {
	display: grid;
	grid-template-columns: 0.9fr 1.1fr;
	align-items: center;
	gap: 42px;
}

.lab-strength__copy .section-heading {
	margin-bottom: 22px;
}

.lab-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 12px;
	margin: 28px 0;
}

.lab-stats div {
	padding: 18px 14px;
	background: var(--color-soft);
	border: 1px solid var(--color-border);
	border-radius: 8px;
}

.lab-stats strong {
	display: block;
	color: var(--color-primary);
	font-size: 22px;
	line-height: 1.2;
}

.lab-stats span {
	color: var(--color-muted);
	font-size: 13px;
}

.lab-strength__image img {
	width: 100%;
	aspect-ratio: 16 / 8.5;
	object-fit: cover;
	border-radius: 8px;
	box-shadow: var(--shadow-soft);
}

.process-line {
	display: grid;
	grid-template-columns: repeat(8, 1fr);
	gap: 14px;
	position: relative;
}

.process-step {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 10px;
	color: var(--color-text);
}

.process-step span {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	color: #fff;
	background: var(--color-primary);
	box-shadow: 0 0 0 8px rgba(63, 95, 175, 0.08);
	font-weight: 900;
}

.process-step:first-child span {
	background: var(--color-orange);
}

.process-step strong {
	font-size: 14px;
	line-height: 1.35;
}

.case-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}

.case-card,
.archive-card {
	display: block;
	overflow: hidden;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: 0 6px 18px rgba(35, 59, 122, 0.06);
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.case-card img,
.archive-card img {
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
}

.case-card div,
.archive-card div {
	padding: 18px;
}

.case-card strong,
.archive-card strong {
	display: block;
	color: var(--color-text);
	font-size: 17px;
	line-height: 1.45;
}

.case-card p,
.archive-card p {
	margin: 10px 0;
	color: var(--color-muted);
	font-size: 14px;
	line-height: 1.7;
}

.case-card span,
.archive-card span {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	color: var(--color-primary);
	font-size: 14px;
	font-weight: 700;
}

.info-columns__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}

.info-column {
	padding: 24px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: 0 8px 20px rgba(35, 59, 122, 0.06);
}

.info-column header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 14px;
}

.info-column h2 {
	margin: 0;
	font-size: 20px;
}

.info-column header a {
	color: var(--color-primary);
	font-size: 14px;
	font-weight: 700;
}

.info-column ul {
	padding: 0;
	margin: 0;
	list-style: none;
}

.info-column li {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 12px;
	padding: 12px 0;
	border-top: 1px solid var(--color-border);
	font-size: 14px;
}

.info-column time {
	color: var(--color-muted);
	white-space: nowrap;
}

.contact-grid {
	display: grid;
	grid-template-columns: 0.8fr 1fr 1fr;
	gap: 24px;
	align-items: stretch;
}

.contact-list,
.contact-form,
.contact-map,
.consult-card,
.side-list,
.single-left,
.page-side {
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: 0 8px 22px rgba(35, 59, 122, 0.07);
}

.contact-list {
	display: flex;
	flex-direction: column;
	gap: 18px;
	padding: 26px;
}

.contact-list a,
.contact-list div {
	display: flex;
	gap: 14px;
	color: var(--color-text);
}

.contact-list .icon {
	width: 36px;
	height: 36px;
	padding: 8px;
	color: #fff;
	background: var(--color-primary);
	border-radius: 8px;
}

.contact-list strong,
.contact-list small {
	display: block;
}

.contact-list small {
	color: var(--color-muted);
}

.contact-map {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-height: 260px;
	overflow: hidden;
	background:
		linear-gradient(90deg, rgba(63, 95, 175, 0.08) 1px, transparent 1px),
		linear-gradient(rgba(63, 95, 175, 0.08) 1px, transparent 1px),
		#f7faff;
	background-size: 36px 36px;
}

.contact-map::before {
	content: "";
	position: absolute;
	inset: 40px;
	border: 2px dashed rgba(63, 95, 175, 0.18);
	border-radius: 50%;
}

.contact-map span {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 76px;
	height: 76px;
	color: #fff;
	background: var(--color-primary);
	border-radius: 50%;
	box-shadow: 0 14px 28px rgba(63, 95, 175, 0.28);
}

.contact-map strong {
	position: relative;
	margin-top: 14px;
	color: var(--color-deep);
}

.contact-form {
	padding: 24px;
}

.contact-form h3 {
	margin: 0 0 16px;
	font-size: 20px;
}

.contact-form label {
	display: block;
	margin-bottom: 12px;
	color: var(--color-muted);
	font-size: 13px;
}

.contact-form span {
	display: block;
	margin-bottom: 6px;
}

.contact-form input,
.contact-form textarea {
	width: 100%;
	border: 1px solid var(--color-border);
	border-radius: 6px;
	padding: 11px 12px;
	outline: 0;
}

.contact-form input:focus,
.contact-form textarea:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(63, 95, 175, 0.1);
}

.contact-form button {
	width: 100%;
	border: 0;
}

.page-hero {
	margin-top: 0;
	margin-bottom: 0;
	padding: 56px 0;
	color: #fff;
	background-image: linear-gradient(90deg, rgba(35, 59, 122, 0.96), rgba(63, 95, 175, 0.84)), url("assets/images/lab-panorama.png");
	background-size: cover;
	background-position: center;
}

.page-hero__inner {
	display: flex;
	align-items: center;
	min-height: auto;
}

.page-hero h1 {
	margin: 6px 0 10px;
	font-size: 38px;
	line-height: 1.25;
}

.page-hero p,
.page-hero__desc {
	max-width: 760px;
	margin: 0;
	color: rgba(255, 255, 255, 0.86);
}

.breadcrumbs {
	font-size: 14px;
}

.breadcrumbs a {
	color: rgba(255, 255, 255, 0.92);
}

.archive-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 28px;
}

.archive-layout--service {
	grid-template-columns: 280px 1fr;
	align-items: start;
}

.archive-sidebar {
	position: sticky;
	top: 20px;
	padding: 22px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: var(--shadow-card);
}

.archive-sidebar h2,
.single-left h2,
.consult-card h2,
.side-list h2,
.page-side h2 {
	margin: 0 0 16px;
	color: var(--color-deep);
	font-size: 20px;
}

.archive-sidebar nav,
.single-left nav,
.side-list {
	display: flex;
	flex-direction: column;
}

.archive-sidebar a,
.single-left a,
.side-list a {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 12px;
	color: var(--color-text);
	border-radius: 6px;
	border-bottom: 1px solid var(--color-border);
	font-size: 14px;
}

.archive-sidebar a:last-child,
.single-left a:last-child,
.side-list a:last-child {
	border-bottom: 0;
}

.archive-sidebar a.is-active,
.archive-sidebar a:hover,
.single-left a:hover,
.side-list a:hover {
	color: var(--color-primary);
	background: var(--color-soft);
}

.archive-sidebar a .icon:last-child {
	margin-left: auto;
}

.archive-card-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 22px;
}

.navigation.pagination {
	margin-top: 28px;
	text-align: center;
}

.nav-links {
	display: inline-flex;
	gap: 8px;
}

.page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 10px;
	border: 1px solid var(--color-border);
	border-radius: 6px;
}

.page-numbers.current {
	color: #fff;
	background: var(--color-primary);
	border-color: var(--color-primary);
}

.single-layout {
	display: grid;
	grid-template-columns: 230px minmax(0, 1fr) 270px;
	gap: 28px;
	align-items: start;
}

.single-left,
.single-right,
.page-side {
	position: sticky;
	top: 20px;
}

.single-left,
.page-side {
	padding: 20px;
}

.single-main,
.page-main {
	min-width: 0;
}

.single-featured,
.page-main__image {
	margin-bottom: 24px;
	overflow: hidden;
	border-radius: 8px;
}

.single-featured img,
.page-main__image {
	width: 100%;
	aspect-ratio: 16 / 7;
	object-fit: cover;
}

.entry-content {
	padding: 34px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: 0 8px 22px rgba(35, 59, 122, 0.06);
}

.entry-content > *:first-child {
	margin-top: 0;
}

.entry-content h2 {
	margin: 34px 0 14px;
	padding-left: 14px;
	color: var(--color-deep);
	border-left: 4px solid var(--color-primary);
	font-size: 24px;
	line-height: 1.35;
}

.entry-content h3 {
	margin: 26px 0 10px;
	color: var(--color-text);
	font-size: 19px;
}

.entry-content p,
.entry-content li {
	color: var(--color-muted);
}

.entry-content ul,
.entry-content ol {
	padding-left: 1.4em;
}

.entry-content table {
	display: block;
	width: 100%;
	overflow-x: auto;
	border-collapse: collapse;
}

.entry-content th,
.entry-content td {
	padding: 12px;
	border: 1px solid var(--color-border);
}

.consult-card,
.side-list {
	padding: 20px;
	margin-bottom: 20px;
}

.consult-card p {
	margin: 0 0 16px;
	color: var(--color-muted);
	font-size: 14px;
}

.consult-card .btn {
	width: 100%;
}

.consult-card__phone {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	margin-top: 14px;
	color: var(--color-primary);
	font-weight: 900;
}

.page-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 280px;
	gap: 28px;
	align-items: start;
}

.contact-grid--page {
	grid-template-columns: 0.9fr 1.1fr;
	margin-top: 24px;
}

.empty-state {
	padding: 48px;
	text-align: center;
	background: var(--color-soft);
	border: 1px dashed var(--color-border);
	border-radius: 8px;
}

.site-footer {
	color: rgba(255, 255, 255, 0.82);
	background: linear-gradient(135deg, #13264f, #0f2247);
}

.footer-grid {
	display: grid;
	grid-template-columns: 1.3fr 0.8fr 0.9fr 1fr 1.25fr;
	gap: 28px;
	padding: 58px 0 42px;
}

.footer-logo {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 120px;
	height: 50px;
	margin-bottom: 16px;
	color: #fff;
}

.footer-logo img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.footer-brand h2,
.footer-nav h3,
.footer-contact h3 {
	margin: 0 0 15px;
	color: #fff;
	font-size: 18px;
}

.footer-nav__toggle {
	width: 100%;
	padding: 0;
	color: inherit;
	text-align: left;
	background: transparent;
	border: 0;
	font: inherit;
	font-weight: inherit;
}

.footer-brand p {
	margin: 0;
	font-size: 14px;
	line-height: 1.9;
}

.footer-menu a {
	display: block;
	padding: 4px 0;
	color: rgba(255, 255, 255, 0.74);
	font-size: 14px;
}

.footer-menu a:hover {
	color: #fff;
}

.footer-contact ul {
	padding: 0;
	margin: 0 0 18px;
	list-style: none;
}

.footer-contact li {
	display: flex;
	gap: 10px;
	margin-bottom: 10px;
	font-size: 14px;
}

.footer-contact .icon {
	margin-top: 4px;
}

.qr-box {
	display: grid;
	grid-template-columns: 90px 1fr;
	align-items: center;
	gap: 12px;
}

.qr-box img,
.qr-placeholder {
	width: 90px;
	height: 90px;
	border-radius: 4px;
	background: #fff;
}

.qr-placeholder {
	background:
		linear-gradient(90deg, #111 10px, transparent 10px) 0 0 / 20px 20px,
		linear-gradient(#111 10px, transparent 10px) 0 0 / 20px 20px,
		#fff;
	border: 8px solid #fff;
}

.qr-box span {
	font-size: 13px;
}

.footer-bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.footer-bottom .container {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 12px 22px;
	padding: 16px 0;
	font-size: 13px;
	color: rgba(255, 255, 255, 0.62);
}

.floating-actions {
	position: fixed;
	right: 0;
	top: 50%;
	z-index: 950;
	display: grid;
	width: 72px;
	overflow: visible;
	background: #056fd0;
	box-shadow: 0 10px 28px rgba(12, 59, 128, 0.24);
	transform: translateY(-50%);
}

.floating-actions__item {
	position: relative;
}

.floating-actions__button {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 6px;
	width: 72px;
	min-height: 74px;
	padding: 9px 6px;
	color: #fff;
	background: #056fd0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.18);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.2;
	text-align: center;
	transition: background 0.18s ease;
}

.floating-actions__button .icon {
	width: 24px;
	height: 24px;
	stroke-width: 2.4;
}

.floating-actions__button:hover,
.floating-actions__button:focus-visible,
.floating-actions__item:hover .floating-actions__button,
.floating-actions__item:focus-within .floating-actions__button {
	color: #fff;
	background: #064eaa;
}

.floating-actions > .floating-actions__button:last-child {
	border-bottom: 0;
}

.floating-actions__panel {
	position: absolute;
	right: 72px;
	top: 50%;
	z-index: -1;
	visibility: hidden;
	opacity: 0;
	pointer-events: none;
	transform: translate(10px, -50%);
	transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
}

.floating-actions__item:hover .floating-actions__panel,
.floating-actions__item:focus-within .floating-actions__panel {
	z-index: 1;
	visibility: visible;
	opacity: 1;
	pointer-events: auto;
	transform: translate(0, -50%);
}

.floating-actions__panel--phone {
	width: 178px;
	padding: 13px 15px;
	background: #fff;
	border-radius: 6px;
	box-shadow: 0 10px 26px rgba(20, 42, 86, 0.18);
}

.floating-actions__panel--phone::after,
.floating-actions__panel--wechat::after {
	content: "";
	position: absolute;
	right: -7px;
	top: 50%;
	width: 14px;
	height: 14px;
	background: #fff;
	transform: translateY(-50%) rotate(45deg);
}

.floating-actions__panel--phone strong {
	display: block;
	margin-bottom: 5px;
	color: var(--color-text);
	font-size: 15px;
	font-weight: 900;
	line-height: 1.35;
}

.floating-actions__panel--phone a {
	display: block;
	color: #056fd0;
	font-size: 18px;
	font-weight: 900;
	line-height: 1.45;
	letter-spacing: 0;
}

.floating-actions__panel--phone a:hover {
	color: var(--color-orange);
}

.floating-actions__panel--wechat {
	width: 178px;
	padding: 14px 14px 13px;
	text-align: center;
	background: #fff;
	border-radius: 8px;
	box-shadow: 0 10px 26px rgba(20, 42, 86, 0.18);
}

.floating-actions__panel--wechat img {
	width: 150px;
	height: 150px;
	margin: 0 auto 9px;
	object-fit: cover;
	border: 1px solid #e4eaf4;
}

.floating-actions__panel--wechat span {
	display: block;
	color: var(--color-text);
	font-size: 13px;
	line-height: 1.4;
}

.mobile-consult-bar {
	display: none;
}

@media (max-width: 1199px) {
	.brand-row__inner {
		grid-template-columns: 300px minmax(300px, 1fr) minmax(225px, auto);
		gap: 18px;
	}

	.primary-menu > li > a {
		padding: 0 12px;
		font-size: 14px;
	}

	.service-card-grid,
	.case-grid {
		grid-template-columns: repeat(3, 1fr);
	}

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

	.footer-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 900px) {
	.container {
		width: min(100% - 32px, 1200px);
	}

	.top-strip {
		height: 34px;
	}

	.top-links__menu {
		gap: 12px;
	}

	.brand-row__inner {
		grid-template-columns: 1fr auto auto;
		min-height: 76px;
	}

	.brand-row .site-search {
		display: none;
	}

	.mobile-search-row {
		display: block;
		padding: 0 0 14px;
		background: #fff;
	}

	.site-search--mobile {
		height: 46px;
	}

	.header-phone {
		gap: 8px;
	}

	.header-phone__icon {
		width: 42px;
		height: 42px;
	}

	.header-phone strong {
		font-size: 20px;
	}

	.header-phone small {
		display: none;
	}

	.mobile-menu-toggle {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 44px;
		height: 44px;
		border: 0;
		color: var(--color-deep);
		background: transparent;
	}

	.mobile-menu-toggle .icon {
		width: 34px;
		height: 34px;
	}

	.main-navigation {
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		z-index: 1200;
		width: min(78vw, 360px);
		height: auto;
		padding: 84px 0 24px;
		overflow-y: auto;
		background: #fff;
		color: var(--color-text);
		box-shadow: -20px 0 40px rgba(0, 0, 0, 0.16);
		transform: translateX(110%);
		transition: transform 0.24s ease;
	}

	.main-navigation.is-open {
		transform: translateX(0);
	}

	.main-navigation__inner {
		width: 100%;
		height: auto;
	}

	.primary-menu {
		display: block;
		height: auto;
	}

	.primary-menu > li {
		display: block;
	}

	.primary-menu > li > a {
		display: block;
		padding: 14px 24px;
		color: var(--color-text);
		border-bottom: 1px solid var(--color-border);
	}

	.primary-menu > li.current-menu-item > a,
	.primary-menu > li.current-menu-ancestor > a,
	.primary-menu > li > a:hover {
		color: var(--color-primary);
		background: var(--color-soft);
	}

	.primary-menu .sub-menu {
		position: static;
		display: block;
		width: auto;
		padding: 0 0 8px;
		opacity: 1;
		visibility: visible;
		transform: none;
		border-top: 0;
		box-shadow: none;
		background: #f8fbff;
	}

	.primary-menu .sub-menu a {
		padding: 9px 32px;
		font-size: 13px;
	}

	.home-hero,
	.home-hero__inner {
		min-height: 400px;
	}

	.home-hero__content {
		width: 72%;
		padding-bottom: 54px;
	}

	.home-hero h1 {
		font-size: 38px;
	}

	.advantage-card {
		grid-template-columns: repeat(3, 1fr);
	}

	.advantage-card__item {
		padding: 14px;
		border-bottom: 1px solid var(--color-border);
	}

	.advantage-card__item:nth-child(3n) {
		border-right: 0;
	}

	.advantage-card__item:nth-last-child(-n+3) {
		border-bottom: 0;
	}

	.service-card-grid,
	.category-icon-grid,
	.archive-card-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.solution-grid {
		display: flex;
		overflow-x: auto;
		scroll-snap-type: x mandatory;
		padding-bottom: 8px;
	}

	.solution-card {
		min-width: 220px;
		scroll-snap-align: start;
	}

	.lab-strength__grid,
	.contact-grid,
	.archive-layout--service,
	.single-layout,
	.page-layout,
	.contact-grid--page {
		grid-template-columns: 1fr;
	}

	.single-left,
	.single-right,
	.page-side,
	.archive-sidebar {
		position: static;
	}

	.case-grid,
	.info-columns__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.footer-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 767px) {
	body {
		padding-bottom: 64px;
		font-size: 15px;
	}

	.container {
		width: calc(100% - 28px);
	}

	.top-strip {
		height: 32px;
		font-size: 12px;
	}

	.top-strip__welcome {
		overflow: hidden;
		white-space: nowrap;
		text-overflow: ellipsis;
	}

	.top-links__menu a {
		gap: 4px;
	}

	.brand-row__inner {
		min-height: 72px;
		gap: 10px;
	}

	.brand-mark {
		width: 80px;
		height: 34px;
		padding: 0;
	}

	.site-branding {
		gap: 9px;
	}

	.site-title {
		max-width: 170px;
		overflow: hidden;
		font-size: 20px;
		text-overflow: ellipsis;
	}

	.site-description {
		font-size: 12px;
		max-width: 180px;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.header-phone__icon {
		display: none;
	}

	.header-phone strong {
		font-size: 20px;
	}

	.mobile-menu-toggle {
		width: 38px;
		height: 38px;
	}

	.mobile-search-row {
		padding-bottom: 12px;
	}

	.site-search--mobile {
		height: 44px;
		border-width: 1px;
	}

	.site-search--mobile input {
		padding: 0 14px;
		font-size: 14px;
	}

	.site-search--mobile button {
		min-width: 82px;
		font-weight: 700;
	}

	.home-hero {
		min-height: 338px;
		background-image: linear-gradient(90deg, rgba(35, 59, 122, 0.96) 0%, rgba(35, 59, 122, 0.78) 52%, rgba(63, 95, 175, 0.32) 100%), url("assets/images/hero-lab.png");
		background-position: center right 28%;
	}

	.home-hero__inner {
		min-height: 338px;
	}

	.home-hero__content {
		width: 100%;
		padding: 24px 0 34px;
	}

	.home-hero h1 {
		max-width: 330px;
		margin-bottom: 12px;
		font-size: 30px;
		line-height: 1.26;
	}

	.home-hero__subtitle {
		max-width: 310px;
		font-size: 16px;
		line-height: 1.65;
	}

	.home-hero__subtitle--desktop,
	.hero-badges {
		display: none;
	}

	.home-hero__subtitle--mobile {
		display: block;
	}

	.hero-actions {
		margin-top: 22px;
		gap: 12px;
	}

	.hero-actions .btn {
		min-height: 42px;
		padding: 0 18px;
		font-size: 15px;
	}

	.advantage-band {
		margin-top: -18px;
		padding-bottom: 12px;
	}

	.advantage-card {
		grid-template-columns: repeat(2, 1fr);
		padding: 16px;
	}

	.advantage-card__item {
		padding: 12px 8px;
	}

	.advantage-card__item:nth-child(n+5) {
		display: none;
	}

	.advantage-card__item:nth-child(2n) {
		border-right: 0;
	}

	.advantage-card__item:nth-child(3n) {
		border-right: 1px solid var(--color-border);
	}

	.advantage-card__item:nth-child(3),
	.advantage-card__item:nth-child(4) {
		border-bottom: 0;
	}

	.section {
		padding: 34px 0;
	}

	.section-heading {
		margin-bottom: 18px;
	}

	.section-heading h2 {
		font-size: 22px;
	}

	.section-heading h2::before,
	.section-heading h2::after {
		width: 28px;
	}

	.section-heading p {
		font-size: 13px;
		line-height: 1.6;
	}

	.section-heading--inline {
		align-items: center;
	}

	.section-heading--inline p {
		display: none;
	}

	.service-card-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 12px;
	}

	.service-card-grid .service-photo-card:nth-child(n+7) {
		display: none;
	}

	.service-photo-card {
		min-height: 136px;
		padding: 16px 14px;
		border-radius: 8px;
	}

	.service-photo-card__icon {
		width: 34px;
		height: 34px;
		margin-bottom: 12px;
	}

	.service-photo-card strong {
		font-size: 16px;
	}

	.service-photo-card em {
		display: none;
	}

	.service-photo-card__arrow {
		right: 12px;
		bottom: 12px;
		width: 24px;
		height: 24px;
	}

	.category-icon-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 10px;
	}

	.category-icon-card {
		min-height: 96px;
		align-items: center;
		justify-content: center;
		padding: 14px 10px;
	}

	.category-icon-card:nth-child(n+9) {
		display: none;
	}

	.category-icon-card .icon {
		width: 30px;
		height: 30px;
	}

	.category-icon-card strong {
		margin-top: 8px;
		font-size: 15px;
	}

	.category-icon-card span {
		display: none;
	}

	.solution-grid .solution-card:nth-child(n+4) {
		display: none;
	}

	.solution-card {
		min-width: 72%;
		min-height: 122px;
		padding: 18px;
	}

	.lab-strength__grid {
		gap: 18px;
	}

	.lab-strength__copy {
		order: 2;
	}

	.lab-strength__image {
		order: 1;
	}

	.lab-strength__image img {
		aspect-ratio: 16 / 9;
	}

	.lab-stats {
		grid-template-columns: repeat(2, 1fr);
		gap: 10px;
		margin: 18px 0;
	}

	.lab-stats div {
		padding: 13px 12px;
	}

	.lab-stats strong {
		font-size: 18px;
	}

	.desktop-rich-section {
		display: none;
	}

	.case-grid {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.case-grid .case-card:nth-child(n+3) {
		display: none;
	}

	.case-card {
		display: grid;
		grid-template-columns: 112px 1fr;
	}

	.case-card img {
		height: 100%;
		aspect-ratio: auto;
	}

	.case-card div {
		padding: 12px;
	}

	.case-card p {
		display: none;
	}

	.front-page .contact-form,
	.front-page .contact-map {
		display: none;
	}

	.contact-grid {
		grid-template-columns: 1fr;
	}

	.contact-list {
		padding: 18px;
	}

	.page-hero {
		padding: 32px 0;
	}

	.page-hero__inner {
		min-height: auto;
	}

	.page-hero h1 {
		font-size: 28px;
	}

	.archive-card-grid {
		grid-template-columns: 1fr;
		gap: 14px;
	}

	.archive-card {
		display: grid;
		grid-template-columns: 126px 1fr;
	}

	.archive-card img {
		height: 100%;
		aspect-ratio: auto;
	}

	.archive-card div {
		padding: 12px;
	}

	.archive-card p {
		display: none;
	}

	.entry-content {
		padding: 22px 18px;
	}

	.entry-content h2 {
		font-size: 22px;
	}

	.entry-content h3 {
		font-size: 18px;
	}

	.entry-content p,
	.entry-content li {
		font-size: 15px;
		line-height: 1.8;
	}

	.single-left,
	.single-right,
	.page-side,
	.archive-sidebar {
		display: none;
	}

	.page-layout,
	.single-layout {
		display: block;
	}

	.footer-grid {
		grid-template-columns: 1fr;
		gap: 18px;
		padding: 32px 0 22px;
	}

	.footer-nav {
		display: none;
	}

	.footer-contact ul {
		margin-bottom: 0;
	}

	.qr-box {
		display: none;
	}

	.footer-bottom .container {
		padding-bottom: 18px;
		font-size: 12px;
	}

	.floating-actions {
		display: none;
	}

	.mobile-consult-bar {
		position: fixed;
		right: 0;
		bottom: 0;
		left: 0;
		z-index: 1300;
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		height: 60px;
		color: #fff;
		box-shadow: 0 -8px 22px rgba(35, 59, 122, 0.16);
	}

	.mobile-consult-bar a {
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 6px;
		color: #fff;
		font-weight: 800;
		font-size: 14px;
	}

	.mobile-consult-bar__phone {
		background: var(--color-deep);
	}

	.mobile-consult-bar__online {
		background: var(--color-primary);
	}

	.mobile-consult-bar__quote {
		background: var(--color-orange);
	}
}

@media (max-width: 390px) {
	.site-title {
		max-width: 145px;
		font-size: 18px;
	}

	.site-description {
		max-width: 145px;
	}

	.header-phone strong {
		font-size: 17px;
	}

	.home-hero h1 {
		font-size: 27px;
	}

	.hero-actions .btn {
		padding: 0 14px;
	}
}

/* Professional inner page refinements */
.archive-hero .page-hero__inner,
.page-hero--pro .page-hero__inner,
.single-hero-pro .page-hero__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 280px;
	gap: 42px;
}

.archive-hero__panel,
.page-hero__panel,
.single-hero-pro__card {
	align-self: center;
	padding: 24px;
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.24);
	border-radius: 8px;
	backdrop-filter: blur(8px);
}

.archive-hero__panel strong,
.page-hero__panel strong,
.single-hero-pro__card strong {
	display: block;
	color: #fff;
	font-size: 18px;
}

.archive-hero__panel span,
.page-hero__panel span {
	display: block;
	margin: 8px 0 14px;
	color: rgba(255, 255, 255, 0.88);
	font-size: 22px;
	font-weight: 900;
}

.archive-hero__panel a,
.page-hero__panel a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 38px;
	padding: 0 16px;
	color: #fff;
	background: var(--color-orange);
	border-radius: 6px;
	font-weight: 800;
}

.service-directory__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px;
}

.service-directory-card {
	display: grid;
	grid-template-rows: auto 1fr auto;
	min-width: 0;
	min-height: 318px;
	padding: 22px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: 0 8px 22px rgba(35, 59, 122, 0.07);
}

.service-directory-card__head {
	display: flex;
	align-items: center;
	gap: 14px;
	min-width: 0;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--color-border);
}

.service-directory-card__head > .icon {
	width: 44px;
	height: 44px;
	padding: 10px;
	color: #fff;
	background: linear-gradient(135deg, var(--color-primary), var(--color-violet));
	border-radius: 8px;
}

.service-directory-card__head strong,
.service-directory-card__head em {
	display: block;
}

.service-directory-card__head span {
	min-width: 0;
}

.service-directory-card__head strong {
	color: var(--color-deep);
	font-size: 20px;
	line-height: 1.35;
}

.service-directory-card__head em {
	color: var(--color-muted);
	font-size: 13px;
	font-style: normal;
}

.service-directory-card ul {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px 16px;
	min-width: 0;
	padding: 16px 0 10px;
	margin: 0;
	list-style: none;
}

.service-directory-card li {
	min-width: 0;
}

.service-directory-card li a {
	display: block;
	position: relative;
	min-width: 0;
	max-width: 100%;
	padding-left: 14px;
	color: var(--color-muted);
	font-size: 14px;
	line-height: 1.45;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.service-directory-card li a::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.7em;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--color-primary);
}

.service-directory-card__more {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: var(--color-primary);
	font-weight: 800;
}

.archive-sidebar--rich {
	padding: 0;
	overflow: hidden;
}

.archive-sidebar__title {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 20px;
	color: #fff;
	background: linear-gradient(135deg, var(--color-deep), var(--color-primary));
}

.archive-sidebar__title h2 {
	margin: 0;
	color: #fff;
}

.archive-sidebar--rich nav {
	padding: 10px;
}

.archive-sidebar--rich a em {
	margin-left: auto;
	min-width: 28px;
	height: 22px;
	border-radius: 999px;
	background: var(--color-soft);
	color: var(--color-primary);
	font-style: normal;
	text-align: center;
	line-height: 22px;
	font-size: 12px;
}

.sidebar-cta {
	margin: 10px 14px 16px;
	padding: 16px;
	background: var(--color-soft);
	border: 1px solid var(--color-border);
	border-radius: 8px;
}

.sidebar-cta strong {
	color: var(--color-deep);
}

.sidebar-cta p {
	margin: 8px 0 14px;
	color: var(--color-muted);
	font-size: 13px;
	line-height: 1.65;
}

.sidebar-cta .btn {
	width: 100%;
	min-height: 38px;
}

.archive-intro-card {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 330px;
	gap: 24px;
	align-items: center;
	margin-bottom: 22px;
	padding: 24px;
	background: linear-gradient(135deg, #fff, #f6f9ff);
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: 0 8px 22px rgba(35, 59, 122, 0.06);
}

.archive-intro-card h2 {
	margin: 0 0 8px;
	color: var(--color-deep);
	font-size: 24px;
}

.archive-intro-card p {
	margin: 0;
	color: var(--color-muted);
}

.archive-intro-card ul {
	padding: 0;
	margin: 0;
	list-style: none;
	display: grid;
	gap: 10px;
}

.archive-intro-card li {
	display: flex;
	align-items: center;
	gap: 8px;
	color: var(--color-text);
	font-weight: 700;
}

.archive-intro-card .icon {
	color: var(--color-primary);
}

.archive-card-grid--pro {
	gap: 18px;
}

.archive-card--service {
	display: flex;
	flex-direction: column;
}

.archive-card--service img {
	aspect-ratio: 16 / 8;
}

.archive-card--service div {
	display: flex;
	flex: 1;
	flex-direction: column;
}

.archive-card__badge {
	align-self: flex-start;
	margin-bottom: 10px;
	padding: 4px 9px;
	border-radius: 999px;
	color: var(--color-primary);
	background: var(--color-soft);
	font-size: 12px;
	font-weight: 800;
}

.archive-card--service ul {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	padding: 0;
	margin: auto 0 14px;
	list-style: none;
}

.archive-card--service li {
	padding: 4px 8px;
	border-radius: 999px;
	background: #f8fbff;
	color: var(--color-muted);
	font-size: 12px;
}

.archive-card--service em {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	color: var(--color-primary);
	font-style: normal;
	font-weight: 800;
}

.archive-process-cta__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 1.2fr auto;
	gap: 26px;
	align-items: center;
	padding: 28px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: 0 8px 22px rgba(35, 59, 122, 0.06);
}

.archive-process-cta h2 {
	margin: 0 0 8px;
	color: var(--color-deep);
}

.archive-process-cta p {
	margin: 0;
	color: var(--color-muted);
}

.archive-process-cta ol {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 10px;
	padding: 0;
	margin: 0;
	list-style: none;
	counter-reset: process;
}

.archive-process-cta li {
	position: relative;
	padding: 14px 10px;
	text-align: center;
	background: var(--color-soft);
	border-radius: 8px;
	color: var(--color-text);
	font-weight: 800;
}

.archive-process-cta li::before {
	counter-increment: process;
	content: counter(process, decimal-leading-zero);
	display: block;
	color: var(--color-primary);
	font-size: 13px;
}

.single-hero-pro__tag {
	display: inline-flex;
	margin-bottom: 12px;
	padding: 5px 12px;
	border-radius: 999px;
	color: #fff;
	background: rgba(255, 255, 255, 0.16);
	font-weight: 800;
}

.single-hero-pro__summary {
	max-width: 780px;
	font-size: 17px;
	line-height: 1.8;
}

.single-hero-pro__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 24px;
}

.single-hero-pro__card ul {
	padding: 0;
	margin: 14px 0 0;
	list-style: none;
}

.single-hero-pro__card li {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: 10px;
	color: rgba(255, 255, 255, 0.9);
}

.single-layout--pro {
	grid-template-columns: 240px minmax(0, 1fr) 292px;
}

.single-left--pro a.is-active {
	color: var(--color-primary);
	background: var(--color-soft);
}

.single-overview {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 12px;
	margin-bottom: 18px;
}

.single-overview div {
	padding: 16px 14px;
	background: var(--color-soft);
	border: 1px solid var(--color-border);
	border-radius: 8px;
}

.single-overview span,
.single-overview strong {
	display: block;
}

.single-overview span {
	color: var(--color-muted);
	font-size: 12px;
}

.single-overview strong {
	margin-top: 4px;
	color: var(--color-deep);
	line-height: 1.35;
}

.entry-content--pro {
	font-size: 16px;
}

.entry-content--pro h2 {
	display: flex;
	align-items: center;
	gap: 10px;
	padding-left: 0;
	border-left: 0;
}

.entry-content--pro h2::before {
	content: "";
	width: 8px;
	height: 24px;
	border-radius: 999px;
	background: linear-gradient(180deg, var(--color-primary), var(--color-violet));
}

.entry-content--pro ul li,
.entry-content--pro ol li {
	margin-bottom: 8px;
}

.single-bottom-cta {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 20px;
	align-items: center;
	margin-top: 22px;
	padding: 24px;
	color: #fff;
	background: linear-gradient(135deg, var(--color-deep), var(--color-primary));
	border-radius: 8px;
	box-shadow: var(--shadow-card);
}

.single-bottom-cta h2 {
	margin: 0 0 8px;
	color: #fff;
	font-size: 22px;
}

.single-bottom-cta p {
	margin: 0;
	color: rgba(255, 255, 255, 0.84);
}

.consult-card--strong {
	background: linear-gradient(180deg, #fff, #f7faff);
	border-top: 4px solid var(--color-orange);
}

.side-list--numbered {
	counter-reset: side-links;
}

.side-list--numbered a::before {
	counter-increment: side-links;
	content: counter(side-links, decimal-leading-zero);
	min-width: 28px;
	color: var(--color-primary);
	font-weight: 900;
}

.page-capability-strip {
	margin-top: -34px;
	position: relative;
	z-index: 5;
}

.page-capability-strip .container {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	padding: 22px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: var(--shadow-soft);
}

.page-capability-strip div {
	display: grid;
	grid-template-columns: 38px 1fr;
	column-gap: 12px;
	align-items: center;
	padding: 0 18px;
	border-right: 1px solid var(--color-border);
}

.page-capability-strip div:last-child {
	border-right: 0;
}

.page-capability-strip .icon {
	grid-row: span 2;
	width: 38px;
	height: 38px;
	color: var(--color-primary);
}

.page-capability-strip strong {
	color: var(--color-deep);
	line-height: 1.25;
}

.page-capability-strip span {
	color: var(--color-muted);
	font-size: 13px;
}

.page-layout--pro {
	grid-template-columns: minmax(0, 1fr) 300px;
}

.page-image-grid {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 22px;
	align-items: stretch;
	margin-bottom: 24px;
	padding: 22px;
	background: linear-gradient(135deg, #fff, #f5f8ff);
	border: 1px solid var(--color-border);
	border-radius: 8px;
}

.page-image-grid img {
	height: 100%;
	min-height: 260px;
	margin-bottom: 0;
	object-fit: cover;
}

.page-image-grid h2 {
	margin: 0 0 10px;
	color: var(--color-deep);
}

.page-image-grid p {
	margin: 0 0 16px;
	color: var(--color-muted);
}

.page-image-grid ul {
	display: grid;
	gap: 10px;
	padding: 0;
	margin: 0;
	list-style: none;
}

.page-image-grid li {
	display: flex;
	align-items: center;
	gap: 8px;
	color: var(--color-text);
	font-weight: 700;
}

.page-image-grid .icon {
	color: var(--color-primary);
}

@media (max-width: 900px) {
	.archive-hero .page-hero__inner,
	.page-hero--pro .page-hero__inner,
	.single-hero-pro .page-hero__inner,
	.archive-intro-card,
	.archive-process-cta__grid,
	.single-layout--pro,
	.page-layout--pro,
	.page-image-grid {
		grid-template-columns: 1fr;
	}

	.service-directory__grid {
		grid-template-columns: 1fr;
	}

	.single-overview {
		grid-template-columns: repeat(2, 1fr);
	}

	.page-capability-strip .container {
		grid-template-columns: repeat(2, 1fr);
	}

	.page-capability-strip div:nth-child(2n) {
		border-right: 0;
	}

	.page-capability-strip div:nth-child(-n+2) {
		padding-bottom: 16px;
		border-bottom: 1px solid var(--color-border);
	}

	.page-capability-strip div:nth-child(n+3) {
		padding-top: 16px;
	}
}

@media (max-width: 767px) {
	.archive-hero__panel,
	.page-hero__panel,
	.single-hero-pro__card {
		display: none;
	}

	.service-directory-card {
		min-height: 0;
		padding: 18px;
	}

	.service-directory-card ul {
		grid-template-columns: minmax(0, 1fr);
	}

	.service-directory .section-heading--inline {
		display: grid;
		grid-template-columns: minmax(0, 1fr) auto;
		gap: 10px;
		align-items: center;
	}

	.service-directory .section-heading--inline h2 {
		min-width: 0;
	}

	.service-directory .section-heading--inline h2::after {
		display: none;
	}

	.service-directory .section-heading--inline > a {
		min-width: 0;
		gap: 4px;
		font-size: 13px;
	}

	.service-directory-card li:nth-child(n+6) {
		display: none;
	}

	.archive-intro-card {
		padding: 18px;
	}

	.archive-card--service {
		display: grid;
		grid-template-columns: 112px 1fr;
	}

	.archive-card--service img {
		height: 100%;
		aspect-ratio: auto;
	}

	.archive-card--service ul,
	.archive-card--service p {
		display: none;
	}

	.archive-process-cta__grid {
		padding: 18px;
	}

	.archive-process-cta ol {
		grid-template-columns: repeat(5, minmax(0, 1fr));
		overflow-x: auto;
		padding-bottom: 4px;
	}

	.single-hero-pro__summary {
		font-size: 15px;
	}

	.single-hero-pro__actions .btn {
		width: 100%;
	}

	.single-overview {
		grid-template-columns: 1fr 1fr;
	}

	.single-overview div {
		padding: 12px;
	}

	.single-bottom-cta {
		grid-template-columns: 1fr;
		padding: 18px;
	}

	.page-capability-strip {
		margin-top: 0;
	}

	.page-capability-strip .container {
		width: 100%;
		grid-template-columns: 1fr 1fr;
		border-radius: 0;
		box-shadow: none;
	}

	.page-capability-strip div {
		padding: 12px;
	}

	.page-capability-strip strong {
		font-size: 14px;
	}

	.page-capability-strip span {
		display: none;
	}

	.page-image-grid {
		padding: 16px;
	}

	.page-image-grid img {
		min-height: 180px;
	}
}

/* Contact page */
.contact-page {
	background: #fff;
}

.contact-hero {
	color: #fff;
	background-image: linear-gradient(90deg, rgba(35, 59, 122, 0.98), rgba(63, 95, 175, 0.74), rgba(63, 95, 175, 0.18)), url("assets/images/hero-lab.png");
	background-size: cover;
	background-position: center right;
}

.contact-hero__inner {
	display: flex;
	align-items: center;
	min-height: 268px;
}

.contact-hero__copy {
	width: min(760px, 70%);
}

.contact-hero .breadcrumbs {
	margin: 0 0 18px;
	color: rgba(255, 255, 255, 0.82);
}

.contact-hero h1 {
	margin: 0 0 10px;
	font-size: 42px;
	line-height: 1.2;
	font-weight: 900;
}

.contact-hero__copy > p:not(.breadcrumbs) {
	margin: 0;
	font-size: 20px;
	color: rgba(255, 255, 255, 0.92);
}

.contact-hero__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 26px;
	margin-top: 34px;
}

.contact-hero__badges span {
	display: grid;
	grid-template-columns: 34px auto;
	column-gap: 10px;
	align-items: center;
	min-width: 120px;
}

.contact-hero__badges .icon {
	grid-row: span 2;
	width: 34px;
	height: 34px;
	padding: 7px;
	border: 1px solid rgba(255, 255, 255, 0.42);
	border-radius: 50%;
}

.contact-hero__badges strong,
.contact-hero__badges em {
	display: block;
	line-height: 1.25;
}

.contact-hero__badges strong {
	font-size: 14px;
}

.contact-hero__badges em {
	color: rgba(255, 255, 255, 0.72);
	font-size: 12px;
	font-style: normal;
}

.contact-breadcrumb-mobile {
	display: none;
}

.contact-main-section {
	padding: 52px 0 42px;
}

.contact-main-grid {
	display: grid;
	grid-template-columns: 0.82fr 1.18fr;
	gap: 28px;
	align-items: stretch;
}

.contact-card {
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: 0 12px 32px rgba(35, 59, 122, 0.08);
}

.contact-card__heading {
	margin-bottom: 24px;
}

.contact-card__heading h2 {
	position: relative;
	margin: 0;
	padding-bottom: 12px;
	color: var(--color-text);
	font-size: 24px;
	line-height: 1.25;
}

.contact-card__heading h2::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 34px;
	height: 3px;
	border-radius: 999px;
	background: var(--color-primary);
}

.contact-methods {
	padding: 30px;
}

.contact-method {
	display: grid;
	grid-template-columns: 54px 1fr;
	gap: 18px;
	padding: 24px 0;
	border-bottom: 1px solid var(--color-border);
}

.contact-method:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.contact-method__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	color: #fff;
	background: linear-gradient(135deg, var(--color-primary), var(--color-deep));
	border-radius: 50%;
	box-shadow: 0 10px 20px rgba(63, 95, 175, 0.22);
}

.contact-method strong,
.contact-method a,
.contact-method span,
.contact-method small {
	display: block;
}

.contact-method strong {
	margin-bottom: 4px;
	color: var(--color-text);
	font-size: 16px;
	line-height: 1.35;
}

.contact-method a {
	color: var(--color-primary);
	font-size: 18px;
	font-weight: 900;
	line-height: 1.4;
}

.contact-method span {
	color: var(--color-text);
	line-height: 1.55;
}

.contact-method small {
	margin-top: 2px;
	color: var(--color-muted);
	font-size: 13px;
	line-height: 1.5;
}

.contact-message-card {
	padding: 30px;
}

.contact-pro-form {
	display: grid;
	gap: 18px;
}

.contact-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
}

.contact-pro-form label {
	display: block;
	color: var(--color-text);
	font-weight: 700;
}

.contact-pro-form label span {
	display: block;
	margin-bottom: 8px;
	font-size: 14px;
}

.contact-pro-form em {
	color: #e53935;
	font-style: normal;
}

.contact-pro-form input,
.contact-pro-form textarea {
	width: 100%;
	border: 1px solid #d9e1ef;
	border-radius: 6px;
	padding: 13px 14px;
	color: var(--color-text);
	background: #fff;
	outline: 0;
	transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.contact-pro-form input:focus,
.contact-pro-form textarea:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(63, 95, 175, 0.1);
}

.contact-pro-form textarea {
	resize: vertical;
	min-height: 136px;
}

.contact-pro-form button {
	width: 100%;
	border: 0;
	border-radius: 6px;
}

.contact-form-safe {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	margin: -4px 0 0;
	color: #8a94a6;
	font-size: 13px;
}

.contact-form-safe .icon {
	width: 16px;
	height: 16px;
}

.contact-quote-band {
	padding: 34px 0 28px;
	background: linear-gradient(180deg, #eef5ff, #f8fbff);
	border-top: 1px solid var(--color-border);
}

.contact-quote-band__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 1.1fr auto;
	gap: 28px;
	align-items: center;
}

.contact-quote-band h2 {
	margin: 0 0 8px;
	color: var(--color-text);
	font-size: 22px;
}

.contact-quote-band p {
	margin: 0;
	color: var(--color-muted);
	font-size: 14px;
}

.contact-quote-features {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
}

.contact-quote-features div {
	display: grid;
	grid-template-columns: 38px 1fr;
	column-gap: 10px;
	align-items: center;
}

.contact-quote-features .icon {
	grid-row: span 2;
	width: 36px;
	height: 36px;
	padding: 8px;
	color: var(--color-primary);
	background: #fff;
	border-radius: 50%;
	box-shadow: 0 8px 18px rgba(63, 95, 175, 0.12);
}

.contact-quote-features strong,
.contact-quote-features span {
	display: block;
	line-height: 1.35;
}

.contact-quote-features strong {
	color: var(--color-text);
	font-size: 15px;
}

.contact-quote-features span {
	color: var(--color-muted);
	font-size: 12px;
}

.contact-quote-actions {
	display: flex;
	gap: 20px;
}

.contact-quote-actions .btn {
	min-width: 156px;
	gap: 8px;
	border-radius: 6px;
}

.btn--outline-blue {
	color: var(--color-primary);
	background: #fff;
	border: 1px solid var(--color-primary);
}

.btn--outline-blue:hover {
	color: var(--color-primary);
	background: var(--color-soft);
}

@media (max-width: 1100px) {
	.contact-quote-band__inner {
		grid-template-columns: 1fr;
	}

	.contact-quote-actions {
		justify-content: center;
	}
}

@media (max-width: 900px) {
	.contact-main-grid {
		grid-template-columns: 1fr;
	}

	.contact-hero__copy {
		width: 100%;
	}
}

@media (max-width: 767px) {
	.contact-page {
		background: #f7faff;
	}

	.contact-hero {
		background-image: linear-gradient(90deg, rgba(35, 59, 122, 0.98), rgba(63, 95, 175, 0.78)), url("assets/images/hero-lab.png");
		background-position: center right 26%;
	}

	.contact-hero__inner {
		min-height: 210px;
		align-items: flex-start;
		padding-top: 34px;
	}

	.contact-hero .breadcrumbs {
		display: none;
	}

	.contact-hero h1 {
		font-size: 28px;
	}

	.contact-hero__copy > p:not(.breadcrumbs) {
		max-width: 270px;
		font-size: 14px;
		line-height: 1.7;
	}

	.contact-hero__badges {
		display: grid;
		grid-template-columns: repeat(4, 1fr);
		gap: 0;
		margin-top: 24px;
		padding: 14px 10px;
		background: #fff;
		border: 1px solid var(--color-border);
		border-radius: 8px;
		box-shadow: var(--shadow-card);
		transform: translateY(28px);
	}

	.contact-hero__badges span {
		display: flex;
		flex-direction: column;
		align-items: center;
		min-width: 0;
		gap: 7px;
		text-align: center;
		color: var(--color-text);
	}

	.contact-hero__badges .icon {
		width: 30px;
		height: 30px;
		padding: 6px;
		color: var(--color-primary);
		border-color: var(--color-border);
	}

	.contact-hero__badges strong {
		font-size: 12px;
		line-height: 1.25;
	}

	.contact-hero__badges em {
		display: none;
	}

	.contact-breadcrumb-mobile {
		display: block;
		padding: 46px 0 0;
		background: #fff;
	}

	.contact-breadcrumb-mobile .breadcrumbs {
		margin: 0;
		color: var(--color-muted);
		font-size: 12px;
	}

	.contact-breadcrumb-mobile .breadcrumbs a {
		color: var(--color-muted);
	}

	.contact-main-section {
		padding: 16px 0 24px;
		background: #fff;
	}

	.contact-main-grid {
		gap: 18px;
	}

	.contact-methods,
	.contact-message-card {
		padding: 22px 18px;
	}

	.contact-card__heading {
		margin-bottom: 14px;
	}

	.contact-card__heading h2 {
		font-size: 20px;
	}

	.contact-method {
		grid-template-columns: 46px 1fr;
		gap: 14px;
		padding: 18px 0;
	}

	.contact-method__icon {
		width: 42px;
		height: 42px;
	}

	.contact-method a {
		font-size: 16px;
	}

	.contact-method span,
	.contact-method small {
		font-size: 13px;
	}

	.contact-form-row {
		grid-template-columns: 1fr;
		gap: 14px;
	}

	.contact-pro-form {
		gap: 14px;
	}

	.contact-pro-form input,
	.contact-pro-form textarea {
		padding: 12px;
	}

	.contact-pro-form textarea {
		min-height: 112px;
	}

	.contact-quote-band {
		padding: 24px 0;
	}

	.contact-quote-band__inner {
		gap: 20px;
	}

	.contact-quote-band header {
		text-align: center;
	}

	.contact-quote-features {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.contact-quote-features div {
		padding: 14px;
		background: #fff;
		border: 1px solid var(--color-border);
		border-radius: 8px;
	}

	.contact-quote-actions {
		display: grid;
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.contact-quote-actions .btn {
		width: 100%;
	}

	.site-footer .footer-nav {
		display: block;
		border-bottom: 1px solid rgba(255, 255, 255, 0.12);
	}

	.site-footer .footer-nav h3 {
		position: relative;
		margin: 0;
		padding: 14px 0;
		font-size: 15px;
	}

	.site-footer .footer-nav h3::after {
		content: "";
		position: absolute;
		right: 0;
		top: 50%;
		width: 8px;
		height: 8px;
		border-right: 1px solid rgba(255, 255, 255, 0.8);
		border-bottom: 1px solid rgba(255, 255, 255, 0.8);
		transform: translateY(-60%) rotate(45deg);
	}

	.site-footer .footer-nav .footer-menu {
		display: none;
	}

	.site-footer .footer-nav.is-open .footer-menu {
		display: block;
		padding: 4px 0 14px;
	}

	.site-footer .footer-nav.is-open h3::after {
		transform: translateY(-35%) rotate(225deg);
	}
}

/* Contact page precision pass */
.contact-main-section > .container,
.contact-quote-band > .container {
	width: min(1200px, calc(100% - 48px));
}

.contact-main-section {
	padding-top: 44px;
}

.contact-main-grid {
	grid-template-columns: 424px minmax(0, 1fr);
	gap: 28px;
}

.contact-card {
	border-color: #dce5f4;
	box-shadow: 0 10px 30px rgba(35, 59, 122, 0.06);
}

.contact-methods,
.contact-message-card {
	padding: 28px 30px 30px;
}

.contact-card__heading {
	margin-bottom: 22px;
}

.contact-card__heading h2 {
	font-size: 23px;
	letter-spacing: 0;
}

.contact-method {
	grid-template-columns: 52px 1fr;
	gap: 18px;
	padding: 24px 0;
}

.contact-method__icon {
	display: flex !important;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	color: #fff;
	font-size: 22px;
	background: linear-gradient(135deg, #274aa0, #365fc4);
	border-radius: 50%;
	box-shadow: 0 13px 24px rgba(39, 74, 160, 0.22);
}

.contact-method__icon .icon {
	width: 22px;
	height: 22px;
	color: #fff;
	stroke: currentColor;
}

.contact-method strong,
.contact-method a,
.contact-method div > span,
.contact-method small {
	display: block;
}

.contact-method > span:not(.contact-method__icon) {
	display: inline;
}

.contact-method div > span {
	color: var(--color-text);
	line-height: 1.55;
}

.contact-method strong {
	margin-bottom: 3px;
	font-size: 15px;
}

.contact-method a {
	font-size: 18px;
	line-height: 1.32;
}

.contact-method small {
	margin-top: 2px;
	font-size: 12px;
}

.contact-method--qr {
	align-items: start;
}

.contact-qr-image {
	width: 116px;
	height: 116px;
	margin: 8px 0 4px;
	padding: 6px;
	object-fit: cover;
	background: #fff;
	border: 1px solid #dce5f4;
	border-radius: 6px;
	box-shadow: 0 8px 18px rgba(35, 59, 122, 0.08);
}

.qr-box img {
	object-fit: cover;
	padding: 5px;
}

.contact-pro-form {
	gap: 16px;
}

.contact-form-row {
	gap: 24px;
}

.contact-pro-form label span {
	margin-bottom: 7px;
	font-size: 13px;
}

.contact-pro-form input {
	min-height: 46px;
	padding: 10px 14px;
}

.contact-pro-form textarea {
	height: 138px;
	min-height: 138px;
	padding: 12px 14px;
}

.contact-pro-form input,
.contact-pro-form textarea {
	border-color: #d5deed;
	font-size: 15px;
}

.contact-pro-form input::placeholder,
.contact-pro-form textarea::placeholder {
	color: #8b96a8;
}

.contact-pro-form button {
	min-height: 44px;
	margin-top: 2px;
	box-shadow: 0 12px 24px rgba(63, 95, 175, 0.18);
}

.contact-form-safe {
	margin-top: -2px;
	font-size: 12px;
}

@media (max-width: 900px) {
	.contact-main-section > .container,
	.contact-quote-band > .container {
		width: min(100% - 32px, 1088px);
	}

	.contact-main-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 767px) {
	.contact-main-section > .container,
	.contact-quote-band > .container {
		width: calc(100% - 28px);
	}

	.contact-main-section {
		padding-top: 16px;
	}

	.contact-methods,
	.contact-message-card {
		padding: 22px 18px;
	}

	.contact-method {
		grid-template-columns: 44px 1fr;
		gap: 14px;
		padding: 17px 0;
	}

	.contact-method__icon {
		width: 42px;
		height: 42px;
		font-size: 20px;
	}

	.contact-method__icon .icon {
		width: 20px;
		height: 20px;
	}

	.contact-qr-image {
		width: 104px;
		height: 104px;
	}

	.contact-pro-form textarea {
		height: 112px;
		min-height: 112px;
	}
}

/* News archive */
.news-archive-page {
	background: #fff;
}

.news-hero {
	color: #fff;
	background-image: linear-gradient(90deg, rgba(20, 56, 136, 0.98), rgba(38, 82, 174, 0.78), rgba(65, 105, 225, 0.2)), url("assets/images/hero-lab.png");
	background-position: center right;
	background-size: cover;
}

.news-hero__inner {
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-height: 230px;
}

.news-hero h1 {
	margin: 0 0 12px;
	font-size: 42px;
	font-weight: 900;
	line-height: 1.15;
	letter-spacing: 0;
}

.news-hero p {
	max-width: 780px;
	margin: 0;
	color: rgba(255, 255, 255, 0.92);
	font-size: 20px;
	font-weight: 700;
	line-height: 1.55;
}

.news-breadcrumb-row {
	padding: 18px 0;
	background: #fff;
	border-bottom: 1px solid var(--color-border);
}

.news-breadcrumb-row .breadcrumbs {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 9px;
	margin: 0;
	color: #728099;
	font-size: 14px;
}

.news-breadcrumb-row .breadcrumbs a {
	color: var(--color-primary);
	font-weight: 700;
}

.news-breadcrumb-row .breadcrumbs span {
	display: inline-flex;
	align-items: center;
	gap: 9px;
}

.news-breadcrumb-row .breadcrumbs span::before {
	content: ">";
	color: #a6b1c2;
	font-size: 12px;
}

.news-content-section {
	padding: 32px 0 54px;
	background: linear-gradient(180deg, #fff 0, #f7faff 100%);
}

.news-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 32px;
	align-items: start;
}

.news-main-column {
	min-width: 0;
}

.news-filter-tabs {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	margin-bottom: 24px;
	overflow: hidden;
	background: #fff;
	border: 1px solid #dbe4f2;
	border-radius: 8px;
	box-shadow: 0 10px 26px rgba(35, 59, 122, 0.06);
}

.news-filter-tabs a {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 58px;
	padding: 0 14px;
	color: var(--color-text);
	font-size: 15px;
	font-weight: 800;
	text-align: center;
	border-right: 1px solid #e8eef7;
	transition: color 0.18s ease, background 0.18s ease;
}

.news-filter-tabs a:last-child {
	border-right: 0;
}

.news-filter-tabs a:hover,
.news-filter-tabs a.is-active {
	color: #fff;
	background: linear-gradient(135deg, #123b98, var(--color-primary));
}

.news-list {
	background: #fff;
	border: 1px solid #dbe4f2;
	border-radius: 8px;
	box-shadow: 0 14px 34px rgba(35, 59, 122, 0.07);
}

.news-list-item {
	display: grid;
	grid-template-columns: 242px minmax(0, 1fr);
	gap: 28px;
	padding: 24px;
	border-bottom: 1px solid #e8eef7;
}

.news-list-item:last-child {
	border-bottom: 0;
}

.news-list-item__image {
	display: block;
	overflow: hidden;
	border-radius: 8px;
	background: #edf3ff;
}

.news-list-item__image img {
	width: 100%;
	aspect-ratio: 242 / 150;
	object-fit: cover;
	transition: transform 0.24s ease;
}

.news-list-item:hover .news-list-item__image img {
	transform: scale(1.04);
}

.news-list-item__body {
	display: flex;
	flex-direction: column;
	min-width: 0;
	padding: 2px 0;
}

.news-list-item__title {
	display: block;
	margin-bottom: 10px;
	color: var(--color-text);
	font-size: 20px;
	font-weight: 900;
	line-height: 1.45;
}

.news-list-item__title:hover {
	color: var(--color-primary);
}

.news-list-item__body p {
	margin: 0;
	color: var(--color-muted);
	font-size: 15px;
	line-height: 1.7;
}

.news-list-item__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 22px;
	margin-top: auto;
	padding-top: 18px;
	color: #7a8495;
	font-size: 13px;
}

.news-list-item__meta span,
.news-list-item__meta time {
	white-space: nowrap;
}

.news-sidebar {
	display: grid;
	gap: 22px;
}

.news-side-card,
.news-promo-card {
	background: #fff;
	border: 1px solid #dbe4f2;
	border-radius: 8px;
	box-shadow: 0 12px 30px rgba(35, 59, 122, 0.07);
}

.news-side-card {
	padding: 24px;
}

.news-side-card h2 {
	position: relative;
	margin: 0 0 20px;
	padding-bottom: 12px;
	color: var(--color-text);
	font-size: 20px;
	font-weight: 900;
	line-height: 1.25;
}

.news-side-card h2::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 32px;
	height: 3px;
	border-radius: 999px;
	background: var(--color-primary);
}

.news-hot-card ol {
	display: grid;
	gap: 14px;
	padding: 0;
	margin: 0;
	list-style: none;
}

.news-hot-card li {
	display: grid;
	grid-template-columns: 22px 1fr;
	gap: 10px;
	min-width: 0;
}

.news-hot-card li > span {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	margin-top: 3px;
	color: #fff;
	background: var(--color-primary);
	border-radius: 50%;
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
}

.news-hot-card li:nth-child(n+4) > span {
	color: var(--color-primary);
	background: #eaf0ff;
}

.news-hot-card a {
	display: -webkit-box;
	overflow: hidden;
	color: var(--color-text);
	font-size: 14px;
	font-weight: 800;
	line-height: 1.5;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}

.news-hot-card em {
	display: block;
	margin-top: 3px;
	color: #8a94a6;
	font-size: 12px;
	font-style: normal;
}

.news-service-card {
	display: grid;
	gap: 0;
}

.news-service-card a {
	display: grid;
	grid-template-columns: 40px 1fr;
	column-gap: 12px;
	padding: 14px 0;
	border-bottom: 1px solid #edf1f7;
}

.news-service-card a:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.news-service-card a > span {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	grid-row: span 2;
	color: var(--color-primary);
	background: #eef4ff;
	border-radius: 50%;
}

.news-service-card .icon {
	width: 20px;
	height: 20px;
}

.news-service-card strong {
	display: block;
	color: var(--color-text);
	font-size: 15px;
	font-weight: 900;
	line-height: 1.35;
}

.news-service-card em {
	display: block;
	margin-top: 4px;
	color: var(--color-muted);
	font-size: 12px;
	font-style: normal;
	line-height: 1.45;
}

.news-contact-card ul {
	display: grid;
	gap: 14px;
	padding: 0;
	margin: 0 0 18px;
	list-style: none;
}

.news-contact-card li {
	display: grid;
	grid-template-columns: 34px 1fr;
	gap: 10px;
	align-items: start;
}

.news-contact-card .icon {
	width: 32px;
	height: 32px;
	padding: 7px;
	color: #fff;
	background: var(--color-primary);
	border-radius: 50%;
}

.news-contact-card strong,
.news-contact-card span {
	display: block;
	line-height: 1.45;
}

.news-contact-card strong {
	color: var(--color-primary);
	font-size: 18px;
	font-weight: 900;
}

.news-contact-card span {
	color: var(--color-muted);
	font-size: 13px;
}

.news-contact-card .btn {
	width: 100%;
	min-height: 42px;
}

.news-promo-card {
	overflow: hidden;
}

.news-promo-card img {
	width: 100%;
	aspect-ratio: 320 / 170;
	object-fit: cover;
}

.news-promo-card div {
	padding: 18px 20px 20px;
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(238, 244, 255, 0.96));
}

.news-promo-card strong,
.news-promo-card span {
	display: block;
}

.news-promo-card strong {
	color: var(--color-deep);
	font-size: 18px;
	font-weight: 900;
	line-height: 1.35;
}

.news-promo-card span {
	margin: 5px 0 14px;
	color: var(--color-muted);
	font-size: 13px;
}

.news-promo-card a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 34px;
	padding: 0 14px;
	color: #fff;
	background: var(--color-orange);
	border-radius: 6px;
	font-size: 13px;
	font-weight: 900;
}

.news-empty-state {
	padding: 42px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 8px;
}

.news-subscribe-band {
	padding: 28px 0;
	color: #fff;
	background: linear-gradient(135deg, #10317d, #114bb7 62%, #173a8f);
}

.news-subscribe-band__inner {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr) auto;
	gap: 24px;
	align-items: center;
}

.news-subscribe-band__mark {
	color: #fff;
	font-size: 30px;
	font-weight: 900;
	line-height: 1;
}

.news-subscribe-band h2 {
	margin: 0 0 5px;
	color: #fff;
	font-size: 24px;
	font-weight: 900;
	line-height: 1.3;
}

.news-subscribe-band p {
	margin: 0;
	color: rgba(255, 255, 255, 0.78);
	font-size: 14px;
}

.news-archive-page .pagination {
	margin: 26px 0 0;
}

.news-archive-page .nav-links {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
	justify-content: center;
}

.news-archive-page .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 38px;
	height: 38px;
	padding: 0 12px;
	color: var(--color-text);
	background: #fff;
	border: 1px solid #dbe4f2;
	border-radius: 6px;
	font-size: 14px;
	font-weight: 800;
}

.news-archive-page .page-numbers.current,
.news-archive-page .page-numbers:hover {
	color: #fff;
	background: var(--color-primary);
	border-color: var(--color-primary);
}

@media (max-width: 1024px) {
	.news-layout {
		grid-template-columns: minmax(0, 1fr) 292px;
		gap: 24px;
	}

	.news-list-item {
		grid-template-columns: 210px minmax(0, 1fr);
		gap: 22px;
	}
}

@media (max-width: 900px) {
	.news-layout {
		grid-template-columns: 1fr;
	}

	.news-sidebar {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.news-contact-card,
	.news-promo-card {
		grid-column: span 2;
	}
}

@media (max-width: 767px) {
	.news-hero__inner {
		min-height: 190px;
	}

	.news-hero h1 {
		font-size: 32px;
	}

	.news-hero p {
		font-size: 16px;
	}

	.news-breadcrumb-row {
		padding: 12px 0;
	}

	.news-content-section {
		padding: 18px 0 34px;
	}

	.news-filter-tabs {
		display: flex;
		overflow-x: auto;
		margin-right: -14px;
		margin-left: -14px;
		border-right: 0;
		border-left: 0;
		border-radius: 0;
		scrollbar-width: none;
	}

	.news-filter-tabs::-webkit-scrollbar {
		display: none;
	}

	.news-filter-tabs a {
		min-width: 96px;
		min-height: 48px;
		font-size: 14px;
		white-space: nowrap;
	}

	.news-list {
		border-right: 0;
		border-left: 0;
		border-radius: 0;
		box-shadow: none;
	}

	.news-list-item {
		grid-template-columns: 122px minmax(0, 1fr);
		gap: 14px;
		padding: 16px 0;
	}

	.news-list-item__image,
	.news-list-item__image img {
		border-radius: 6px;
	}

	.news-list-item__image img {
		aspect-ratio: 122 / 92;
	}

	.news-list-item__title {
		display: -webkit-box;
		overflow: hidden;
		margin-bottom: 6px;
		font-size: 16px;
		line-height: 1.42;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
	}

	.news-list-item__body p {
		display: -webkit-box;
		overflow: hidden;
		font-size: 13px;
		line-height: 1.55;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
	}

	.news-list-item__meta {
		gap: 10px;
		padding-top: 9px;
		font-size: 12px;
	}

	.news-list-item__meta span:nth-child(2) {
		display: none;
	}

	.news-sidebar {
		grid-template-columns: 1fr;
		gap: 16px;
	}

	.news-contact-card,
	.news-promo-card {
		grid-column: auto;
	}

	.news-side-card {
		padding: 20px 18px;
	}

	.news-subscribe-band__inner {
		grid-template-columns: 1fr;
		gap: 14px;
		text-align: center;
	}

	.news-subscribe-band .btn {
		width: 100%;
	}
}

@media (max-width: 420px) {
	.news-list-item {
		grid-template-columns: 104px minmax(0, 1fr);
		gap: 12px;
	}

	.news-list-item__image img {
		aspect-ratio: 104 / 86;
	}

	.news-list-item__title {
		font-size: 15px;
	}

	.news-list-item__body p {
		-webkit-line-clamp: 1;
	}
}

/* Standard archive */
.standard-archive-page {
	background: #fff;
}

.standard-hero {
	margin-top: 0;
	margin-bottom: 0;
	padding: 56px 0;
	color: #fff;
	background-image: linear-gradient(90deg, rgba(15, 60, 147, 0.98), rgba(26, 82, 183, 0.86), rgba(42, 111, 210, 0.28)), url("assets/images/hero-lab.png");
	background-position: center right;
	background-size: cover;
}

.standard-hero__inner {
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-height: auto;
}

.standard-hero h1 {
	margin: 0 0 14px;
	font-size: 42px;
	font-weight: 900;
	line-height: 1.15;
	letter-spacing: 0;
}

.standard-hero__desc,
.standard-hero__desc p {
	max-width: 760px;
	margin: 0;
	color: rgba(255, 255, 255, 0.92);
	font-size: 20px;
	font-weight: 700;
	line-height: 1.55;
}

.standard-breadcrumb-row {
	padding: 18px 0;
	background: #fff;
	border-bottom: 1px solid var(--color-border);
}

.standard-breadcrumb-row .breadcrumbs {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 9px;
	margin: 0;
	color: #728099;
	font-size: 14px;
}

.standard-breadcrumb-row .breadcrumbs a {
	color: var(--color-primary);
	font-weight: 700;
}

.standard-breadcrumb-row .breadcrumbs span {
	display: inline-flex;
	align-items: center;
	gap: 9px;
}

.standard-breadcrumb-row .breadcrumbs span::before {
	content: ">";
	color: #a6b1c2;
	font-size: 12px;
}

.standard-content-section {
	padding: 32px 0 54px;
	background: linear-gradient(180deg, #fff 0, #f7faff 100%);
}

.standard-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 32px;
	align-items: start;
}

.standard-main-column {
	min-width: 0;
}

.standard-list-shell {
	overflow: hidden;
	background: #fff;
	border: 1px solid #dbe4f2;
	border-radius: 8px;
	box-shadow: 0 14px 34px rgba(35, 59, 122, 0.07);
}

.standard-list-head {
	display: flex;
	gap: 18px;
	align-items: center;
	justify-content: space-between;
	padding: 22px 24px;
	border-bottom: 1px solid #e8eef7;
}

.standard-list-head h2 {
	margin: 0 0 6px;
	color: var(--color-text);
	font-size: 21px;
	font-weight: 900;
	line-height: 1.3;
}

.standard-list-head p {
	margin: 0;
	color: var(--color-muted);
	font-size: 14px;
	line-height: 1.55;
}

.standard-list-head__quote {
	display: inline-flex;
	flex: 0 0 auto;
	align-items: center;
	gap: 6px;
	min-height: 40px;
	padding: 0 14px;
	color: var(--color-primary);
	background: #f1f6ff;
	border: 1px solid #dbe6fb;
	border-radius: 6px;
	font-size: 14px;
	font-weight: 900;
}

.standard-list-head__quote:hover {
	color: #fff;
	background: var(--color-primary);
}

.standard-list {
	display: grid;
}

.standard-list-item {
	display: grid;
	grid-template-columns: 72px minmax(0, 1fr) auto;
	gap: 20px;
	align-items: start;
	padding: 24px;
	border-bottom: 1px solid #e8eef7;
}

.standard-list-item:last-child {
	border-bottom: 0;
}

.standard-list-item__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 74px;
	color: var(--color-primary);
	background: #f1f6ff;
	border: 1px solid #dbe6fb;
	border-radius: 8px;
}

.standard-list-item__icon .icon {
	width: 32px;
	height: 32px;
}

.standard-list-item__body {
	min-width: 0;
}

.standard-list-item__title {
	display: block;
	margin: 0 0 8px;
	color: var(--color-text);
	font-size: 19px;
	font-weight: 900;
	line-height: 1.45;
}

.standard-list-item__title:hover {
	color: var(--color-primary);
}

.standard-list-item__excerpt {
	margin: 0;
	color: var(--color-muted);
	font-size: 14px;
	line-height: 1.7;
}

.standard-list-item__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 12px;
	color: #7a8495;
	font-size: 12px;
}

.standard-list-item__meta span,
.standard-list-item__meta time {
	display: inline-flex;
	align-items: center;
	min-height: 24px;
	padding: 0 9px;
	background: #f3f7ff;
	border: 1px solid #e2eafb;
	border-radius: 6px;
	white-space: nowrap;
}

.standard-list-item__more {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	align-self: center;
	color: var(--color-primary);
	font-size: 13px;
	font-weight: 900;
	white-space: nowrap;
}

.standard-archive-page .pagination {
	margin: 0;
	padding: 24px;
	border-top: 1px solid #e8eef7;
	text-align: center;
}

.standard-archive-page .nav-links {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
	justify-content: center;
}

.standard-archive-page .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 38px;
	height: 38px;
	padding: 0 12px;
	color: var(--color-text);
	background: #fff;
	border: 1px solid #dbe4f2;
	border-radius: 6px;
	font-size: 14px;
	font-weight: 800;
}

.standard-archive-page .page-numbers.current,
.standard-archive-page .page-numbers:hover {
	color: #fff;
	background: var(--color-primary);
	border-color: var(--color-primary);
}

.standard-sidebar {
	display: grid;
	gap: 22px;
}

.standard-side-card {
	padding: 24px;
	background: #fff;
	border: 1px solid #dbe4f2;
	border-radius: 8px;
	box-shadow: 0 12px 30px rgba(35, 59, 122, 0.07);
}

.standard-side-card h2 {
	position: relative;
	margin: 0 0 20px;
	padding-bottom: 12px;
	color: var(--color-text);
	font-size: 20px;
	font-weight: 900;
	line-height: 1.25;
}

.standard-side-card h2::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 32px;
	height: 3px;
	border-radius: 999px;
	background: var(--color-primary);
}

.standard-hot-card ol {
	display: grid;
	gap: 14px;
	padding: 0;
	margin: 0;
	list-style: none;
}

.standard-hot-card li {
	display: grid;
	grid-template-columns: 22px 1fr;
	gap: 10px;
	min-width: 0;
}

.standard-hot-card li > span {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	margin-top: 3px;
	color: #fff;
	background: var(--color-primary);
	border-radius: 4px;
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
}

.standard-hot-card li:nth-child(n+4) > span {
	color: var(--color-primary);
	background: #eaf0ff;
}

.standard-hot-card a {
	display: -webkit-box;
	overflow: hidden;
	color: var(--color-text);
	font-size: 14px;
	font-weight: 800;
	line-height: 1.5;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}

.standard-hot-card em {
	display: block;
	margin-top: 3px;
	color: #8a94a6;
	font-size: 12px;
	font-style: normal;
}

.standard-service-card {
	display: grid;
	gap: 0;
}

.standard-service-card a {
	display: grid;
	grid-template-columns: 40px 1fr;
	column-gap: 12px;
	padding: 14px 0;
	border-bottom: 1px solid #edf1f7;
}

.standard-service-card a:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.standard-service-card a > span {
	display: flex;
	grid-row: span 2;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	color: var(--color-primary);
	background: #eef4ff;
	border-radius: 8px;
}

.standard-service-card .icon {
	width: 20px;
	height: 20px;
}

.standard-service-card strong {
	display: block;
	color: var(--color-text);
	font-size: 15px;
	font-weight: 900;
	line-height: 1.35;
}

.standard-service-card em {
	display: -webkit-box;
	overflow: hidden;
	margin-top: 4px;
	color: var(--color-muted);
	font-size: 12px;
	font-style: normal;
	line-height: 1.45;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
}

.standard-quote-card p {
	margin: 0 0 18px;
	color: var(--color-muted);
	font-size: 14px;
	line-height: 1.7;
}

.standard-quote-card ul {
	display: grid;
	gap: 14px;
	padding: 0;
	margin: 0 0 20px;
	list-style: none;
}

.standard-quote-card li {
	display: grid;
	grid-template-columns: 34px minmax(0, 1fr);
	gap: 10px;
	align-items: start;
}

.standard-quote-card .icon {
	width: 32px;
	height: 32px;
	padding: 7px;
	color: #fff;
	background: var(--color-primary);
	border-radius: 50%;
}

.standard-quote-card strong,
.standard-quote-card span {
	display: block;
	line-height: 1.45;
}

.standard-quote-card strong {
	color: var(--color-primary);
	font-size: 18px;
	font-weight: 900;
}

.standard-quote-card span {
	color: var(--color-muted);
	font-size: 13px;
}

.standard-quote-card .btn {
	width: 100%;
}

.standard-cta-band {
	padding: 0 0 54px;
	background: #f7faff;
}

.standard-cta-band__inner {
	display: grid;
	grid-template-columns: 72px minmax(0, 1fr) auto;
	gap: 20px;
	align-items: center;
	padding: 26px 44px;
	background: linear-gradient(90deg, #fff, #edf5ff);
	border: 1px solid #dbe4f2;
	border-radius: 8px;
	box-shadow: 0 12px 30px rgba(35, 59, 122, 0.06);
}

.standard-cta-band__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 58px;
	height: 58px;
	color: var(--color-primary);
	background: #eaf1ff;
	border: 1px solid #d5e2fb;
	border-radius: 8px;
}

.standard-cta-band__icon .icon {
	width: 34px;
	height: 34px;
}

.standard-cta-band h2 {
	margin: 0 0 6px;
	color: var(--color-primary);
	font-size: 24px;
	font-weight: 900;
	line-height: 1.25;
}

.standard-cta-band p {
	margin: 0;
	color: var(--color-muted);
	font-size: 15px;
	line-height: 1.7;
}

@media (max-width: 1024px) {
	.standard-layout {
		grid-template-columns: minmax(0, 1fr) 292px;
		gap: 24px;
	}

	.standard-list-item {
		grid-template-columns: 64px minmax(0, 1fr);
		gap: 18px;
	}

	.standard-list-item__more {
		grid-column: 2;
		justify-self: start;
		margin-top: -4px;
	}
}

@media (max-width: 900px) {
	.standard-layout {
		grid-template-columns: 1fr;
	}

	.standard-sidebar {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.standard-quote-card {
		grid-column: span 2;
	}

	.standard-cta-band__inner {
		grid-template-columns: 58px minmax(0, 1fr);
	}

	.standard-cta-band .btn {
		grid-column: 2;
		justify-self: start;
	}
}

@media (max-width: 767px) {
	.standard-hero {
		padding: 32px 0;
	}

	.standard-hero__inner {
		min-height: auto;
	}

	.standard-hero h1 {
		font-size: 32px;
	}

	.standard-hero__desc,
	.standard-hero__desc p {
		font-size: 16px;
	}

	.standard-breadcrumb-row {
		padding: 12px 0;
	}

	.standard-content-section {
		padding: 18px 0 34px;
	}

	.standard-list-shell {
		border-right: 0;
		border-left: 0;
		border-radius: 0;
		box-shadow: none;
	}

	.standard-list-head {
		display: block;
		padding: 18px 0;
	}

	.standard-list-head h2 {
		font-size: 18px;
	}

	.standard-list-head__quote {
		margin-top: 12px;
	}

	.standard-list-item {
		grid-template-columns: 48px minmax(0, 1fr);
		gap: 12px;
		padding: 18px 0;
	}

	.standard-list-item__icon {
		width: 46px;
		height: 54px;
		border-radius: 6px;
	}

	.standard-list-item__icon .icon {
		width: 24px;
		height: 24px;
	}

	.standard-list-item__title {
		display: -webkit-box;
		overflow: hidden;
		margin-bottom: 6px;
		font-size: 16px;
		line-height: 1.42;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
	}

	.standard-list-item__excerpt {
		display: -webkit-box;
		overflow: hidden;
		font-size: 13px;
		line-height: 1.55;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
	}

	.standard-list-item__meta {
		gap: 6px;
		margin-top: 9px;
		font-size: 12px;
	}

	.standard-list-item__meta span,
	.standard-list-item__meta time {
		min-height: 22px;
		padding: 0 7px;
	}

	.standard-list-item__more {
		grid-column: 2;
		font-size: 12px;
	}

	.standard-sidebar {
		grid-template-columns: 1fr;
		gap: 16px;
	}

	.standard-quote-card {
		grid-column: auto;
	}

	.standard-side-card {
		padding: 20px 18px;
	}

	.standard-cta-band {
		padding-bottom: 34px;
	}

	.standard-cta-band__inner {
		grid-template-columns: 1fr;
		gap: 14px;
		padding: 22px 18px;
	}

	.standard-cta-band .btn {
		grid-column: auto;
		width: 100%;
	}
}

@media (max-width: 420px) {
	.standard-list-item__meta time:nth-of-type(n+2) {
		display: none;
	}

	.standard-cta-band h2 {
		font-size: 21px;
	}
}

/* Process page */
.process-page {
	background: #fff;
}

.process-hero {
	background-image: linear-gradient(90deg, rgba(237, 246, 255, 0.98) 0%, rgba(237, 246, 255, 0.9) 37%, rgba(237, 246, 255, 0.25) 66%, rgba(237, 246, 255, 0.06) 100%), url("assets/images/hero-lab.png");
	background-position: center right;
	background-size: cover;
}

.process-hero__inner {
	display: flex;
	align-items: center;
	min-height: 255px;
}

.process-hero__copy {
	width: min(680px, 64%);
}

.process-hero h1 {
	margin: 0 0 8px;
	color: #123b98;
	font-size: 48px;
	font-weight: 900;
	line-height: 1.12;
	letter-spacing: 0;
}

.process-hero__lead {
	margin: 0 0 6px;
	color: var(--color-text);
	font-size: 22px;
	font-weight: 900;
	line-height: 1.35;
}

.process-hero__desc {
	margin: 0;
	color: var(--color-muted);
	font-size: 15px;
	line-height: 1.7;
}

.process-hero__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 18px;
	margin-top: 28px;
}

.process-hero__badges span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 38px;
	color: var(--color-deep);
	font-size: 14px;
	font-weight: 800;
}

.process-hero__badges .icon {
	width: 34px;
	height: 34px;
	padding: 8px;
	color: var(--color-primary);
	background: rgba(255, 255, 255, 0.76);
	border: 1px solid rgba(63, 95, 175, 0.25);
	border-radius: 50%;
	box-shadow: 0 8px 18px rgba(63, 95, 175, 0.08);
}

.process-breadcrumb-row {
	padding: 15px 0;
	background: #fff;
	border-bottom: 1px solid var(--color-border);
}

.process-breadcrumb-row .breadcrumbs {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 9px;
	margin: 0;
	color: #728099;
	font-size: 14px;
}

.process-breadcrumb-row .breadcrumbs a {
	color: var(--color-primary);
	font-weight: 800;
}

.process-breadcrumb-row .breadcrumbs span {
	display: inline-flex;
	align-items: center;
	gap: 9px;
}

.process-breadcrumb-row .breadcrumbs span::before {
	content: ">";
	color: #a6b1c2;
	font-size: 12px;
}

.process-timeline-section {
	padding: 26px 0 8px;
	background: #fff;
}

.process-timeline-card {
	position: relative;
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 18px;
	padding: 22px 42px 26px;
	background: #fff;
	border: 1px solid #dce5f4;
	border-radius: 8px;
	box-shadow: 0 12px 34px rgba(35, 59, 122, 0.08);
}

.process-timeline-line {
	position: absolute;
	top: 44px;
	left: 86px;
	right: 86px;
	height: 3px;
	background:
		radial-gradient(circle at 20% 50%, #0f4fc1 0 4px, transparent 4px),
		radial-gradient(circle at 40% 50%, #0f4fc1 0 4px, transparent 4px),
		radial-gradient(circle at 60% 50%, #0f4fc1 0 4px, transparent 4px),
		radial-gradient(circle at 80% 50%, #0f4fc1 0 4px, transparent 4px),
		linear-gradient(90deg, var(--color-primary), #2f6bf0);
}

.process-timeline-step {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.process-timeline-step span {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	color: #fff;
	background: linear-gradient(135deg, #1648b6, var(--color-primary));
	border: 5px solid #fff;
	border-radius: 50%;
	box-shadow: 0 8px 18px rgba(22, 72, 182, 0.24);
	font-size: 17px;
	font-weight: 900;
	line-height: 1;
}

.process-timeline-step strong {
	margin-top: 16px;
	color: var(--color-text);
	font-size: 16px;
	font-weight: 900;
	line-height: 1.35;
}

.process-timeline-step em {
	margin-top: 4px;
	color: var(--color-muted);
	font-size: 13px;
	font-style: normal;
	line-height: 1.45;
}

.process-section {
	padding: 22px 0 12px;
}

.process-section--white {
	background: #fff;
}

.process-section--soft {
	background: #fbfdff;
}

.process-section-heading {
	margin-bottom: 22px;
	text-align: center;
}

.process-section-heading h2 {
	position: relative;
	display: inline-block;
	margin: 0;
	padding-bottom: 12px;
	color: var(--color-text);
	font-size: 26px;
	font-weight: 900;
	line-height: 1.3;
}

.process-section-heading h2::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	width: 42px;
	height: 3px;
	background: var(--color-primary);
	border-radius: 999px;
	transform: translateX(-50%);
}

.process-step-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

.process-detail-card {
	display: grid;
	grid-template-columns: 76px 1fr;
	gap: 18px;
	align-items: center;
	min-height: 118px;
	padding: 22px 24px;
	background: #fff;
	border: 1px solid #dce5f4;
	border-radius: 8px;
	box-shadow: 0 8px 24px rgba(35, 59, 122, 0.05);
}

.process-detail-card__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	color: var(--color-primary);
	background: #edf3ff;
	border-radius: 50%;
}

.process-detail-card__icon .icon {
	width: 34px;
	height: 34px;
}

.process-detail-card h3 {
	display: flex;
	align-items: center;
	gap: 12px;
	margin: 0 0 7px;
	color: var(--color-text);
	font-size: 17px;
	font-weight: 900;
	line-height: 1.35;
}

.process-detail-card h3 span {
	color: #0f59df;
	font-size: 18px;
}

.process-detail-card ul,
.process-material-card ul {
	padding: 0 0 0 16px;
	margin: 0;
	color: var(--color-muted);
	font-size: 13px;
	line-height: 1.65;
}

.process-material-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 16px;
}

.process-material-card {
	min-height: 142px;
	padding: 22px 20px 20px;
	background: #fff;
	border: 1px solid #dce5f4;
	border-radius: 8px;
	box-shadow: 0 8px 22px rgba(35, 59, 122, 0.05);
}

.process-material-card div {
	color: var(--color-primary);
}

.process-material-card .icon {
	width: 42px;
	height: 42px;
}

.process-material-card h3 {
	margin: 10px 0 8px;
	color: #1045b3;
	font-size: 16px;
	font-weight: 900;
	line-height: 1.35;
}

.process-promise-section {
	padding-top: 20px;
}

.process-promise-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
}

.process-promise-card {
	display: grid;
	grid-template-columns: 58px 1fr;
	gap: 14px;
	align-items: center;
	min-height: 86px;
	padding: 18px 20px;
	background: #fff;
	border: 1px solid #dce5f4;
	border-radius: 8px;
	box-shadow: 0 8px 22px rgba(35, 59, 122, 0.05);
}

.process-promise-card > span {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	color: var(--color-primary);
	background: #edf3ff;
	border-radius: 50%;
}

.process-promise-card .icon {
	width: 28px;
	height: 28px;
}

.process-promise-card h3 {
	margin: 0 0 4px;
	color: #1045b3;
	font-size: 17px;
	font-weight: 900;
	line-height: 1.3;
}

.process-promise-card p {
	margin: 0;
	color: var(--color-muted);
	font-size: 13px;
	line-height: 1.55;
}

.process-faq-section {
	padding-bottom: 28px;
}

.process-faq-list {
	border: 1px solid #dce5f4;
	border-radius: 8px;
	overflow: hidden;
	background: #fff;
}

.process-faq-item {
	border-bottom: 1px solid #dce5f4;
}

.process-faq-item:last-child {
	border-bottom: 0;
}

.process-faq-item summary {
	display: grid;
	grid-template-columns: 32px 1fr 18px;
	gap: 12px;
	align-items: center;
	min-height: 52px;
	padding: 0 18px 0 24px;
	color: #1045b3;
	font-size: 16px;
	font-weight: 900;
	list-style: none;
	cursor: pointer;
}

.process-faq-item summary::-webkit-details-marker {
	display: none;
}

.process-faq-item summary span {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	color: #fff;
	background: var(--color-primary);
	border-radius: 50%;
	font-size: 18px;
	font-weight: 900;
	line-height: 1;
}

.process-faq-item summary span::before {
	content: "+";
	transform: translateY(-1px);
}

.process-faq-item[open] summary span::before {
	content: "-";
}

.process-faq-item summary::after {
	content: "";
	justify-self: end;
	width: 9px;
	height: 9px;
	border-right: 2px solid var(--color-primary);
	border-bottom: 2px solid var(--color-primary);
	transform: rotate(45deg);
	transition: transform 0.18s ease;
}

.process-faq-item[open] summary::after {
	transform: rotate(225deg);
}

.process-faq-item p {
	margin: 0;
	padding: 0 58px 18px 68px;
	color: var(--color-muted);
	font-size: 14px;
	line-height: 1.75;
}

.process-quote-cta {
	padding: 0 0 1px;
	background: #fff;
}

.process-quote-cta__inner {
	display: grid;
	grid-template-columns: 82px minmax(0, 1fr) auto;
	gap: 26px;
	align-items: center;
	padding: 30px 54px;
	color: #fff;
	background-image: linear-gradient(90deg, rgba(16, 53, 134, 0.96), rgba(17, 78, 191, 0.92)), url("assets/images/lab-panorama.png");
	background-position: center;
	background-size: cover;
	border-radius: 8px 8px 0 0;
}

.process-quote-cta__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 72px;
	height: 72px;
	color: #fff;
	border: 2px solid rgba(255, 255, 255, 0.6);
	border-radius: 8px;
}

.process-quote-cta__icon .icon {
	width: 42px;
	height: 42px;
}

.process-quote-cta h2 {
	margin: 0 0 6px;
	color: #fff;
	font-size: 26px;
	font-weight: 900;
	line-height: 1.3;
}

.process-quote-cta p {
	margin: 0;
	color: rgba(255, 255, 255, 0.86);
	font-size: 15px;
	line-height: 1.65;
}

.process-quote-cta__actions {
	display: flex;
	gap: 18px;
	align-items: center;
}

.process-quote-cta__actions .btn {
	min-width: 142px;
	border-radius: 4px;
}

@media (max-width: 1100px) {
	.process-timeline-card {
		padding-right: 26px;
		padding-left: 26px;
	}

	.process-timeline-line {
		left: 70px;
		right: 70px;
	}

	.process-step-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.process-material-grid {
		grid-template-columns: repeat(3, 1fr);
	}

	.process-promise-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 900px) {
	.process-hero__copy {
		width: min(700px, 76%);
	}

	.process-timeline-card {
		display: flex;
		gap: 18px;
		overflow-x: auto;
		padding: 20px 18px 22px;
		scrollbar-width: none;
	}

	.process-timeline-card::-webkit-scrollbar {
		display: none;
	}

	.process-timeline-line {
		left: 42px;
		right: 42px;
	}

	.process-timeline-step {
		flex: 0 0 138px;
	}

	.process-quote-cta__inner {
		grid-template-columns: 70px 1fr;
		padding: 26px 28px;
	}

	.process-quote-cta__actions {
		grid-column: 1 / -1;
		justify-content: center;
	}
}

@media (max-width: 767px) {
	.process-hero {
		background-image: linear-gradient(90deg, rgba(236, 246, 255, 0.98), rgba(236, 246, 255, 0.86)), url("assets/images/hero-lab.png");
	}

	.process-hero__inner {
		min-height: 210px;
	}

	.process-hero__copy {
		width: 100%;
	}

	.process-hero h1 {
		font-size: 36px;
	}

	.process-hero__lead {
		font-size: 18px;
	}

	.process-hero__badges {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 10px;
		margin-top: 18px;
	}

	.process-hero__badges span {
		font-size: 13px;
	}

	.process-hero__badges .icon {
		width: 30px;
		height: 30px;
		padding: 7px;
	}

	.process-breadcrumb-row {
		padding: 12px 0;
	}

	.process-timeline-section {
		padding-top: 18px;
	}

	.process-timeline-card {
		margin-right: -14px;
		margin-left: -14px;
		border-right: 0;
		border-left: 0;
		border-radius: 0;
		box-shadow: none;
	}

	.process-timeline-line {
		display: none;
	}

	.process-timeline-step {
		padding: 0 4px;
	}

	.process-section {
		padding: 18px 0 8px;
	}

	.process-section-heading {
		margin-bottom: 16px;
	}

	.process-section-heading h2 {
		font-size: 22px;
	}

	.process-step-grid,
	.process-material-grid,
	.process-promise-grid {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.process-detail-card {
		grid-template-columns: 56px 1fr;
		gap: 14px;
		min-height: 0;
		padding: 18px;
	}

	.process-detail-card__icon {
		width: 52px;
		height: 52px;
	}

	.process-detail-card__icon .icon {
		width: 28px;
		height: 28px;
	}

	.process-detail-card h3 {
		font-size: 16px;
	}

	.process-material-card {
		min-height: 0;
		padding: 18px;
	}

	.process-promise-card {
		min-height: 0;
	}

	.process-faq-item summary {
		grid-template-columns: 28px 1fr 14px;
		gap: 10px;
		min-height: 50px;
		padding: 0 14px;
		font-size: 15px;
	}

	.process-faq-item p {
		padding: 0 16px 16px 52px;
		font-size: 13px;
	}

	.process-quote-cta__inner {
		grid-template-columns: 1fr;
		gap: 16px;
		padding: 24px 20px;
		text-align: center;
		border-radius: 0;
	}

	.process-quote-cta__icon {
		justify-self: center;
	}

	.process-quote-cta h2 {
		font-size: 22px;
	}

	.process-quote-cta__actions {
		display: grid;
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.process-quote-cta__actions .btn {
		width: 100%;
	}
}

/* Universal consultation modal */
body.has-consultation-modal-open {
	overflow: hidden;
}

.consultation-modal[hidden] {
	display: none;
}

.consultation-modal {
	position: fixed;
	inset: 0;
	z-index: 3000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 28px;
	opacity: 0;
	transition: opacity 0.18s ease;
}

.consultation-modal.is-open {
	opacity: 1;
}

.consultation-modal__overlay {
	position: absolute;
	inset: 0;
	background: rgba(5, 19, 48, 0.72);
	backdrop-filter: blur(5px);
}

.consultation-modal__dialog {
	position: relative;
	width: min(1120px, calc(100vw - 42px));
	max-height: calc(100vh - 42px);
	overflow: hidden;
	background: #fff;
	border: 1px solid rgba(255, 255, 255, 0.5);
	border-radius: 12px;
	box-shadow: 0 26px 70px rgba(5, 19, 48, 0.36);
	transform: translateY(16px) scale(0.98);
	transition: transform 0.18s ease;
}

.consultation-modal.is-open .consultation-modal__dialog {
	transform: translateY(0) scale(1);
}

.consultation-modal__close {
	position: absolute;
	top: 18px;
	right: 18px;
	z-index: 3;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	padding: 0;
	color: #1d3768;
	background: #fff;
	border: 1px solid #dce5f4;
	border-radius: 50%;
	box-shadow: 0 8px 18px rgba(35, 59, 122, 0.12);
	font-size: 30px;
	line-height: 1;
}

.consultation-modal__main {
	display: grid;
	grid-template-columns: 360px minmax(0, 1fr);
	min-height: 620px;
}

.consultation-modal__side {
	position: relative;
	padding: 46px 42px 34px;
	color: #fff;
	background-image: linear-gradient(160deg, rgba(52, 138, 238, 0.98), rgba(0, 73, 184, 0.98)), url("assets/images/lab-panorama.png");
	background-position: center;
	background-size: cover;
}

.consultation-modal__side::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: 0;
	width: 58%;
	height: 42%;
	background: linear-gradient(135deg, transparent, rgba(255, 255, 255, 0.08));
	pointer-events: none;
}

.consultation-modal__side-head {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
}

.consultation-modal__side-head .icon {
	width: 34px;
	height: 34px;
}

.consultation-modal__side-head h2 {
	margin: 0;
	color: #fff;
	font-size: 28px;
	font-weight: 900;
	line-height: 1.2;
}

.consultation-modal__qr {
	width: 208px;
	height: 208px;
	margin: 30px auto 14px;
	padding: 10px;
	object-fit: cover;
	background: #fff;
	border-radius: 8px;
	box-shadow: 0 16px 34px rgba(0, 35, 99, 0.24);
}

.consultation-modal__qr-caption {
	margin: 0;
	text-align: center;
	font-size: 16px;
	font-weight: 800;
}

.consultation-modal__phone {
	display: grid;
	grid-template-columns: 42px 1fr;
	column-gap: 12px;
	align-items: center;
	margin: 30px 0 24px;
	padding: 22px 0 24px;
	border-top: 1px solid rgba(255, 255, 255, 0.18);
	border-bottom: 1px solid rgba(255, 255, 255, 0.18);
}

.consultation-modal__phone .icon {
	grid-row: span 3;
	width: 40px;
	height: 40px;
}

.consultation-modal__phone span,
.consultation-modal__phone em {
	display: block;
	color: rgba(255, 255, 255, 0.86);
	font-style: normal;
	line-height: 1.3;
}

.consultation-modal__phone a {
	display: block;
	color: #fff;
	font-size: 30px;
	font-weight: 900;
	line-height: 1.25;
}

.consultation-modal__trust {
	position: relative;
	z-index: 1;
	display: grid;
	gap: 14px;
	padding: 0;
	margin: 0;
	list-style: none;
}

.consultation-modal__trust li {
	display: grid;
	grid-template-columns: 48px 1fr;
	gap: 14px;
	align-items: center;
}

.consultation-modal__trust .icon {
	width: 46px;
	height: 46px;
	padding: 10px;
	background: rgba(255, 255, 255, 0.16);
	border: 1px solid rgba(255, 255, 255, 0.24);
	border-radius: 50%;
}

.consultation-modal__trust strong,
.consultation-modal__trust em {
	display: block;
	line-height: 1.35;
}

.consultation-modal__trust strong {
	color: #fff;
	font-size: 16px;
}

.consultation-modal__trust em {
	color: rgba(255, 255, 255, 0.78);
	font-size: 13px;
	font-style: normal;
}

.consultation-modal__form-panel {
	padding: 40px 72px 34px;
	overflow-y: auto;
}

.consultation-modal__heading {
	margin-bottom: 24px;
	text-align: center;
}

.consultation-modal__heading h2 {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 22px;
	margin: 0 0 8px;
	color: #12264a;
	font-size: 36px;
	font-weight: 900;
	line-height: 1.2;
}

.consultation-modal__heading h2::before,
.consultation-modal__heading h2::after {
	content: "";
	width: 58px;
	height: 2px;
	background: linear-gradient(90deg, transparent, var(--color-primary));
}

.consultation-modal__heading h2::after {
	background: linear-gradient(90deg, var(--color-primary), transparent);
}

.consultation-modal__heading p {
	margin: 0;
	color: #3e4b63;
	font-size: 17px;
	line-height: 1.5;
}

.consultation-form {
	display: grid;
	gap: 14px;
}

.consultation-form__trap {
	position: absolute;
	left: -9999px;
	opacity: 0;
	pointer-events: none;
}

.consultation-purpose {
	padding: 0;
	margin: 0 0 4px;
	border: 0;
}

.consultation-purpose legend {
	margin-bottom: 10px;
	color: var(--color-text);
	font-size: 15px;
	font-weight: 900;
}

.consultation-purpose legend span {
	color: var(--color-muted);
	font-weight: 400;
}

.consultation-purpose__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px 14px;
}

.consultation-purpose__option {
	position: relative;
	display: block;
}

.consultation-purpose__option input {
	position: absolute;
	inset: 0;
	opacity: 0;
}

.consultation-purpose__option span {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 0 12px;
	color: #31405b;
	background: #fff;
	border: 1px solid #d5deed;
	border-radius: 999px;
	font-size: 15px;
	font-weight: 800;
	line-height: 1.25;
	text-align: center;
	transition: color 0.18s ease, background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
	cursor: pointer;
}

.consultation-purpose__option input:focus-visible + span {
	box-shadow: 0 0 0 3px rgba(63, 95, 175, 0.18);
}

.consultation-purpose__option input:checked + span {
	color: #fff;
	background: linear-gradient(135deg, #0d49b7, var(--color-primary));
	border-color: #0d49b7;
	box-shadow: 0 10px 18px rgba(25, 78, 183, 0.18);
}

.consultation-field {
	display: grid;
	grid-template-columns: 108px minmax(0, 1fr);
	align-items: center;
	min-height: 54px;
	background: #fff;
	border: 1px solid #d5deed;
	border-radius: 8px;
	overflow: hidden;
}

.consultation-field span {
	padding-left: 20px;
	color: #27344d;
	font-weight: 800;
	white-space: nowrap;
}

.consultation-field em {
	color: #e53935;
	font-style: normal;
}

.consultation-field input,
.consultation-field textarea {
	width: 100%;
	border: 0;
	outline: 0;
	padding: 13px 16px;
	color: var(--color-text);
	background: transparent;
	font-size: 15px;
}

.consultation-field input::placeholder,
.consultation-field textarea::placeholder {
	color: #8b96a8;
}

.consultation-field--textarea {
	position: relative;
	grid-template-columns: 108px minmax(0, 1fr);
	align-items: start;
	min-height: 118px;
}

.consultation-field--textarea span {
	padding-top: 14px;
}

.consultation-field textarea {
	min-height: 106px;
	resize: none;
	line-height: 1.6;
}

.consultation-field--textarea small {
	position: absolute;
	right: 16px;
	bottom: 8px;
	color: #8b96a8;
	font-size: 12px;
}

.consultation-form__submit {
	width: 100%;
	min-height: 52px;
	margin-top: 2px;
	border: 0;
	border-radius: 8px;
	font-size: 20px;
}

.consultation-form__submit:disabled {
	opacity: 0.72;
	cursor: wait;
	transform: none;
}

.consultation-form__privacy,
.consultation-form__status {
	margin: 0;
	text-align: center;
}

.consultation-form__privacy {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	color: #7a8495;
	font-size: 13px;
}

.consultation-form__privacy .icon {
	width: 16px;
	height: 16px;
	color: var(--color-primary);
}

.consultation-form__status {
	min-height: 22px;
	font-size: 14px;
	font-weight: 800;
}

.consultation-form__status.is-success {
	color: #0f8a4b;
}

.consultation-form__status.is-error {
	color: #c62828;
}

.consultation-modal__bottom {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	padding: 18px 42px;
	background: #f7faff;
	border-top: 1px solid #dce5f4;
}

.consultation-modal__bottom span {
	display: grid;
	grid-template-columns: 40px 1fr;
	column-gap: 10px;
	align-items: center;
	padding: 0 20px;
	border-right: 1px solid #dce5f4;
}

.consultation-modal__bottom span:last-child {
	border-right: 0;
}

.consultation-modal__bottom .icon {
	grid-row: span 2;
	width: 36px;
	height: 36px;
	color: var(--color-primary);
}

.consultation-modal__bottom strong,
.consultation-modal__bottom em {
	display: block;
	line-height: 1.32;
}

.consultation-modal__bottom strong {
	color: #13356f;
	font-size: 15px;
}

.consultation-modal__bottom em {
	color: var(--color-muted);
	font-size: 12px;
	font-style: normal;
}

.home-consult-cta-section {
	padding: 38px 0;
}

.home-consult-cta {
	display: grid;
	grid-template-columns: 78px minmax(0, 1fr) auto;
	gap: 24px;
	align-items: center;
	padding: 32px 42px;
	color: #fff;
	background-image: linear-gradient(90deg, rgba(16, 53, 134, 0.98), rgba(17, 78, 191, 0.92)), url("assets/images/lab-panorama.png");
	background-position: center;
	background-size: cover;
	border-radius: 8px;
	box-shadow: 0 16px 38px rgba(35, 59, 122, 0.14);
}

.home-consult-cta__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 68px;
	height: 68px;
	border: 2px solid rgba(255, 255, 255, 0.58);
	border-radius: 8px;
}

.home-consult-cta__icon .icon {
	width: 38px;
	height: 38px;
}

.home-consult-cta h2 {
	margin: 0 0 8px;
	color: #fff;
	font-size: 26px;
	font-weight: 900;
	line-height: 1.3;
}

.home-consult-cta p {
	margin: 0;
	color: rgba(255, 255, 255, 0.86);
	font-size: 15px;
	line-height: 1.7;
}

.home-consult-cta__actions {
	display: flex;
	gap: 14px;
	align-items: center;
}

.home-consult-cta__actions .btn {
	min-width: 136px;
}

.home-consult-cta__trust {
	grid-column: 2 / -1;
	display: flex;
	flex-wrap: wrap;
	gap: 22px;
	padding-top: 4px;
}

.home-consult-cta__trust span {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	color: rgba(255, 255, 255, 0.9);
	font-size: 14px;
	font-weight: 800;
}

.home-consult-cta__trust .icon {
	width: 18px;
	height: 18px;
}

.contact-modal-entry-card > p {
	margin: 0 0 20px;
	color: var(--color-muted);
	line-height: 1.8;
}

.contact-modal-entry-card__actions {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 14px;
	margin-bottom: 22px;
}

.contact-modal-entry-card__actions .btn {
	width: 100%;
}

.contact-modal-entry-card ul {
	display: grid;
	gap: 12px;
	padding: 18px;
	margin: 0;
	list-style: none;
	background: #f7faff;
	border: 1px solid #dce5f4;
	border-radius: 8px;
}

.contact-modal-entry-card li {
	display: flex;
	align-items: center;
	gap: 9px;
	color: #26344e;
	font-weight: 800;
}

.contact-modal-entry-card li .icon {
	width: 20px;
	height: 20px;
	color: var(--color-primary);
}

@media (max-width: 1024px) {
	.consultation-modal__dialog {
		width: min(940px, calc(100vw - 32px));
	}

	.consultation-modal__main {
		grid-template-columns: 310px minmax(0, 1fr);
	}

	.consultation-modal__side {
		padding: 38px 30px 30px;
	}

	.consultation-modal__form-panel {
		padding: 36px 40px 30px;
	}

	.consultation-purpose__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.consultation-modal__bottom {
		grid-template-columns: repeat(2, 1fr);
		row-gap: 14px;
	}

	.consultation-modal__bottom span:nth-child(2n) {
		border-right: 0;
	}

	.home-consult-cta {
		grid-template-columns: 70px 1fr;
	}

	.home-consult-cta__actions,
	.home-consult-cta__trust {
		grid-column: 1 / -1;
	}

	.home-consult-cta__actions {
		justify-content: center;
	}
}

@media (max-width: 767px) {
	.consultation-modal {
		align-items: center;
		justify-content: center;
		padding: 16px;
	}

	.consultation-modal__dialog {
		width: min(460px, calc(100vw - 32px));
		max-height: calc(100vh - 32px);
		border-radius: 12px;
		overflow-y: auto;
	}

	.consultation-modal__close {
		top: 12px;
		right: 12px;
		width: 36px;
		height: 36px;
		font-size: 26px;
	}

	.consultation-modal__main {
		grid-template-columns: 1fr;
		min-height: 0;
	}

	.consultation-modal__side {
		padding: 26px 20px 22px;
		text-align: center;
	}

	.consultation-modal__side-head {
		justify-content: center;
	}

	.consultation-modal__side-head h2 {
		font-size: 22px;
	}

	.consultation-modal__qr {
		width: 138px;
		height: 138px;
		margin: 18px auto 8px;
	}

	.consultation-modal__qr-caption {
		font-size: 14px;
	}

	.consultation-modal__phone {
		grid-template-columns: 34px 1fr;
		margin: 18px 0 16px;
		padding: 16px 0;
		text-align: left;
	}

	.consultation-modal__phone .icon {
		width: 32px;
		height: 32px;
	}

	.consultation-modal__phone a {
		font-size: 24px;
	}

	.consultation-modal__trust {
		grid-template-columns: 1fr;
		text-align: left;
	}

	.consultation-modal__trust li {
		grid-template-columns: 38px 1fr;
	}

	.consultation-modal__trust .icon {
		width: 36px;
		height: 36px;
		padding: 8px;
	}

	.consultation-modal__form-panel {
		padding: 24px 18px 18px;
	}

	.consultation-modal__heading {
		margin-bottom: 18px;
	}

	.consultation-modal__heading h2 {
		font-size: 28px;
	}

	.consultation-modal__heading h2::before,
	.consultation-modal__heading h2::after {
		width: 34px;
	}

	.consultation-modal__heading p {
		font-size: 15px;
	}

	.consultation-purpose__grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 10px;
	}

	.consultation-purpose__option span {
		min-height: 42px;
		border-radius: 8px;
		font-size: 14px;
	}

	.consultation-field,
	.consultation-field--textarea {
		grid-template-columns: 1fr;
	}

	.consultation-field span {
		padding: 10px 14px 0;
	}

	.consultation-field input,
	.consultation-field textarea {
		padding: 8px 14px 12px;
	}

	.consultation-field--textarea small {
		right: 14px;
	}

	.consultation-form__submit {
		width: 100%;
		font-size: 18px;
	}

	.consultation-modal__bottom {
		display: none;
	}

	.home-consult-cta-section {
		padding: 24px 0;
	}

	.home-consult-cta {
		grid-template-columns: 1fr;
		gap: 16px;
		padding: 24px 20px;
		text-align: center;
	}

	.home-consult-cta__icon {
		justify-self: center;
	}

	.home-consult-cta h2 {
		font-size: 22px;
	}

	.home-consult-cta__actions {
		display: grid;
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.home-consult-cta__actions .btn {
		width: 100%;
	}

	.home-consult-cta__trust {
		justify-content: center;
		gap: 12px;
	}

	.contact-modal-entry-card__actions {
		grid-template-columns: 1fr;
	}
}

/* Consultation modal compact pass */
.consultation-modal__dialog {
	width: min(800px, calc(100vw - 42px));
}

.consultation-modal__main {
	grid-template-columns: 260px minmax(0, 1fr);
	min-height: 560px;
}

.consultation-modal__side {
	padding: 34px 28px 28px;
}

.consultation-modal__side-head h2 {
	font-size: 22px;
}

.consultation-modal__qr {
	width: 158px;
	height: 158px;
	margin: 22px auto 12px;
}

.consultation-modal__qr-caption {
	font-size: 14px;
}

.consultation-modal__phone {
	grid-template-columns: 36px 1fr;
	margin: 22px 0 18px;
	padding: 18px 0;
}

.consultation-modal__phone .icon {
	width: 34px;
	height: 34px;
}

.consultation-modal__phone a {
	font-size: 23px;
}

.consultation-modal__trust {
	gap: 12px;
}

.consultation-modal__trust li {
	grid-template-columns: 40px 1fr;
	gap: 12px;
}

.consultation-modal__trust .icon {
	width: 38px;
	height: 38px;
	padding: 9px;
}

.consultation-modal__form-panel {
	padding: 34px 42px 28px;
}

.consultation-modal__heading {
	margin-bottom: 20px;
}

.consultation-modal__heading h2 {
	font-size: 30px;
}

.consultation-modal__heading h2::before,
.consultation-modal__heading h2::after {
	width: 42px;
}

.consultation-modal__heading p {
	font-size: 15px;
}

.consultation-form {
	gap: 12px;
}

.consultation-field input,
.consultation-field textarea,
.consultation-field select {
	width: 100%;
	border: 0;
	outline: 0;
	padding: 13px 16px;
	color: var(--color-text);
	background-color: transparent;
	font-size: 15px;
}

.consultation-field select {
	appearance: none;
	background-image: linear-gradient(45deg, transparent 50%, #51617a 50%), linear-gradient(135deg, #51617a 50%, transparent 50%);
	background-position: calc(100% - 20px) 50%, calc(100% - 14px) 50%;
	background-repeat: no-repeat;
	background-size: 6px 6px, 6px 6px;
	cursor: pointer;
}

.consultation-form__submit {
	min-height: 50px;
	font-size: 18px;
}

.consultation-modal__bottom {
	padding: 14px 24px;
}

.consultation-modal__bottom span {
	grid-template-columns: 32px 1fr;
	column-gap: 8px;
	padding: 0 10px;
}

.consultation-modal__bottom .icon {
	width: 30px;
	height: 30px;
}

.consultation-modal__bottom strong {
	font-size: 13px;
}

.consultation-modal__bottom em {
	font-size: 11px;
}

@media (max-width: 767px) {
	.consultation-modal__dialog {
		width: min(460px, calc(100vw - 32px));
	}

	.consultation-modal__main {
		grid-template-columns: 1fr;
		min-height: 0;
	}

	.consultation-modal__side {
		padding: 26px 20px 22px;
	}

	.consultation-modal__qr {
		width: 138px;
		height: 138px;
		margin: 18px auto 8px;
	}

	.consultation-modal__form-panel {
		padding: 24px 18px 18px;
	}

	.consultation-field select {
		padding: 8px 36px 12px 14px;
	}
}

/* Consultation modal latest refinement */
.consultation-modal__main {
	grid-template-columns: 248px minmax(0, 1fr);
	min-height: 500px;
}

.consultation-modal__side {
	padding: 24px 24px 22px;
}

.consultation-modal__side-head .icon {
	width: 28px;
	height: 28px;
}

.consultation-modal__side-head h2 {
	font-size: 20px;
}

.consultation-modal__qr {
	width: 130px;
	height: 130px;
	margin: 16px auto 8px;
}

.consultation-modal__qr-caption {
	font-size: 13px;
}

.consultation-modal__phone {
	grid-template-columns: 30px minmax(0, 1fr);
	margin: 16px 0 14px;
	padding: 14px 0;
}

.consultation-modal__phone .icon {
	width: 28px;
	height: 28px;
}

.consultation-modal__phone a {
	display: inline-block;
	font-size: 20px;
	letter-spacing: 0;
	white-space: nowrap;
	word-break: keep-all;
}

.consultation-modal__phone span,
.consultation-modal__phone em {
	font-size: 12px;
}

.consultation-modal__trust {
	gap: 9px;
}

.consultation-modal__trust li {
	grid-template-columns: 34px 1fr;
	gap: 10px;
}

.consultation-modal__trust .icon {
	width: 32px;
	height: 32px;
	padding: 7px;
}

.consultation-modal__trust strong {
	font-size: 14px;
}

.consultation-modal__trust em {
	font-size: 12px;
}

.consultation-modal__form-panel {
	padding: 26px 34px 22px;
}

.consultation-modal__heading {
	margin-bottom: 14px;
}

.consultation-modal__heading h2 {
	font-size: 28px;
}

.consultation-modal__heading p {
	font-size: 14px;
}

.consultation-form {
	gap: 10px;
}

.consultation-field {
	min-height: 48px;
}

.consultation-field input,
.consultation-field textarea,
.consultation-field select {
	padding-top: 10px;
	padding-bottom: 10px;
}

.consultation-field--textarea {
	min-height: 96px;
}

.consultation-field textarea {
	min-height: 86px;
}

.consultation-form__submit {
	min-height: 46px;
}

.consultation-modal__bottom {
	padding: 8px 18px;
}

.consultation-modal__bottom span {
	grid-template-columns: 28px 1fr;
	padding: 0 8px;
}

.consultation-modal__bottom .icon {
	width: 26px;
	height: 26px;
}

@media (max-width: 767px) {
	.consultation-modal__side,
	.consultation-modal__bottom {
		display: none;
	}

	.consultation-modal__main {
		display: block;
		min-height: 0;
	}

	.consultation-modal__form-panel {
		padding: 54px 18px 18px;
	}

	.consultation-modal__heading h2::before,
	.consultation-modal__heading h2::after {
		display: none;
	}
}

/* Consultation modal softer visual pass */
.consultation-modal {
	padding: 24px;
}

.consultation-modal__overlay {
	background: rgba(15, 23, 42, 0.56);
	backdrop-filter: blur(3px);
}

.consultation-modal__dialog {
	width: min(800px, calc(100vw - 40px));
	border: 1px solid rgba(214, 226, 242, 0.9);
	border-radius: 10px;
	box-shadow: 0 22px 58px rgba(15, 23, 42, 0.28);
}

.consultation-modal__close {
	top: 14px;
	right: 14px;
	z-index: 10;
	width: 38px;
	height: 38px;
	color: #24324a;
	background: #f8fbff;
	border-color: #d9e4f2;
	box-shadow: 0 6px 14px rgba(15, 35, 72, 0.08);
	font-size: 0;
}

.consultation-modal__close::before {
	content: "\00d7";
	font-size: 28px;
	font-weight: 400;
	line-height: 1;
}

.consultation-modal__main {
	grid-template-columns: 248px minmax(0, 1fr);
	min-height: 0;
}

.consultation-modal__side {
	padding: 26px 24px 18px;
	color: #1f3558;
	background: linear-gradient(180deg, #eef6ff 0%, #e8f1fb 100%);
	border-right: 1px solid #dbe6f4;
}

.consultation-modal__side::after {
	display: none;
}

.consultation-modal__side-head .icon {
	width: 25px;
	height: 25px;
	color: #2f6fd0;
}

.consultation-modal__side-head h2 {
	color: #1f3558;
	font-size: 20px;
	font-weight: 800;
}

.consultation-modal__qr {
	width: 128px;
	height: 128px;
	margin: 15px auto 8px;
	box-shadow: 0 10px 22px rgba(35, 59, 122, 0.12);
}

.consultation-modal__qr-caption {
	color: #244365;
	font-size: 13px;
	font-weight: 700;
}

.consultation-modal__phone {
	grid-template-columns: 28px minmax(0, 1fr);
	margin: 16px 0 12px;
	padding: 13px 0;
	border-color: #d1dfef;
}

.consultation-modal__phone .icon {
	width: 26px;
	height: 26px;
	color: #2f6fd0;
}

.consultation-modal__phone span,
.consultation-modal__phone em {
	color: #65758b;
	font-size: 12px;
}

.consultation-modal__phone a {
	color: #2457b7;
	font-size: 20px;
	font-weight: 800;
}

.consultation-modal__trust {
	gap: 8px;
}

.consultation-modal__trust li {
	grid-template-columns: 30px minmax(0, 1fr);
	gap: 9px;
}

.consultation-modal__trust .icon {
	width: 28px;
	height: 28px;
	padding: 6px;
	color: #2f6fd0;
	background: rgba(47, 111, 208, 0.08);
	border-color: rgba(47, 111, 208, 0.16);
}

.consultation-modal__trust strong {
	color: #203047;
	font-size: 13px;
	font-weight: 700;
}

.consultation-modal__trust em {
	color: #6b7a90;
	font-size: 11px;
}

.consultation-modal__form-panel {
	padding: 26px 34px 14px;
}

.consultation-modal__heading {
	margin-bottom: 14px;
}

.consultation-modal__heading h2 {
	color: #162744;
	font-size: 26px;
	font-weight: 800;
}

.consultation-modal__heading h2::before,
.consultation-modal__heading h2::after {
	width: 36px;
	background: linear-gradient(90deg, transparent, #8eaddd);
}

.consultation-modal__heading h2::after {
	background: linear-gradient(90deg, #8eaddd, transparent);
}

.consultation-modal__heading p {
	color: #68768a;
	font-size: 13px;
}

.consultation-form {
	gap: 9px;
}

.consultation-field {
	min-height: 47px;
	background: #fbfdff;
	border-color: #d9e4f2;
}

.consultation-field span {
	color: #26364f;
	font-weight: 700;
}

.consultation-field input,
.consultation-field textarea,
.consultation-field select {
	color: #26364f;
	font-size: 14px;
}

.consultation-field input::placeholder,
.consultation-field textarea::placeholder {
	color: #8b98ab;
}

.consultation-field--textarea {
	min-height: 92px;
}

.consultation-field textarea {
	min-height: 78px;
}

.consultation-form__submit {
	min-height: 46px;
	background: #426bd6;
	box-shadow: 0 8px 18px rgba(66, 107, 214, 0.18);
	font-size: 17px;
	font-weight: 700;
}

.consultation-form__privacy {
	margin: 2px 0 0;
	color: #7a8798;
	font-size: 12px;
}

.consultation-modal__bottom {
	padding: 8px 18px 9px;
	background: #f8fbff;
	border-top: 1px solid #e3ebf6;
}

.consultation-modal__bottom span {
	grid-template-columns: 24px minmax(0, 1fr);
	min-height: 32px;
	padding: 0 9px;
}

.consultation-modal__bottom .icon {
	width: 23px;
	height: 23px;
	color: #3768c5;
}

.consultation-modal__bottom strong {
	color: #203047;
	font-size: 12px;
	font-weight: 700;
}

.consultation-modal__bottom em {
	color: #7a8798;
	font-size: 10px;
}

@media (max-width: 767px) {
	.consultation-modal {
		padding: 0;
	}

	.consultation-modal__dialog {
		width: 100%;
		max-height: 100dvh;
		border-radius: 0;
	}

	.consultation-modal__close {
		top: 10px;
		right: 10px;
		width: 34px;
		height: 34px;
	}

	.consultation-modal__close::before {
		font-size: 25px;
	}

	.consultation-modal__side,
	.consultation-modal__bottom {
		display: none;
	}

	.consultation-modal__form-panel {
		padding: 42px 14px 12px;
	}

	.consultation-modal__heading {
		margin-bottom: 9px;
	}

	.consultation-modal__heading h2 {
		margin-bottom: 3px;
		font-size: 22px;
	}

	.consultation-modal__heading h2::before,
	.consultation-modal__heading h2::after {
		display: none;
	}

	.consultation-modal__heading p {
		font-size: 12px;
		line-height: 1.35;
	}

	.consultation-form {
		gap: 7px;
	}

	.consultation-field,
	.consultation-field--textarea {
		grid-template-columns: 86px minmax(0, 1fr);
		min-height: 44px;
		border-radius: 7px;
	}

	.consultation-field span {
		padding: 0 0 0 12px;
		font-size: 14px;
		line-height: 1.25;
	}

	.consultation-field input,
	.consultation-field textarea,
	.consultation-field select {
		min-height: 42px;
		padding: 0 12px;
		font-size: 14px;
	}

	.consultation-field select {
		padding-right: 34px;
		background-position: calc(100% - 18px) 50%, calc(100% - 12px) 50%;
	}

	.consultation-field--textarea {
		align-items: start;
		min-height: 76px;
	}

	.consultation-field--textarea span {
		padding-top: 11px;
	}

	.consultation-field textarea {
		min-height: 74px;
		padding: 10px 30px 10px 12px;
		line-height: 1.45;
	}

	.consultation-field--textarea small {
		right: 10px;
		bottom: 6px;
		font-size: 11px;
	}

	.consultation-form__submit {
		min-height: 42px;
		font-size: 16px;
	}

	.consultation-form__privacy {
		display: none;
	}
}

/* About page */
.about-page {
	background: #fff;
}

.about-hero {
	color: #fff;
	background-image: linear-gradient(90deg, rgba(11, 49, 132, 0.98) 0%, rgba(15, 71, 174, 0.88) 43%, rgba(15, 71, 174, 0.34) 72%, rgba(15, 71, 174, 0.1) 100%), url("assets/images/hero-lab.png");
	background-position: center;
	background-size: cover;
}

.about-hero__inner {
	display: flex;
	align-items: center;
	min-height: 245px;
}

.about-hero__copy {
	max-width: 780px;
}

.about-hero h1 {
	margin: 0 0 14px;
	color: #fff;
	font-size: 42px;
	font-weight: 900;
	line-height: 1.16;
}

.about-hero__lead,
.about-hero__text {
	margin: 0;
	color: rgba(255, 255, 255, 0.92);
	font-weight: 800;
	line-height: 1.8;
}

.about-hero__lead {
	font-size: 21px;
}

.about-hero__text {
	margin-top: 8px;
	font-size: 18px;
}

.about-breadcrumb-row {
	padding: 13px 0;
	background: #f5f8ff;
	border-bottom: 1px solid #e7edf8;
}

.about-breadcrumb-row .breadcrumbs {
	margin: 0;
	color: var(--color-muted);
	font-size: 13px;
}

.about-breadcrumb-row .breadcrumbs a {
	color: var(--color-muted);
}

.about-section {
	padding: 30px 0 0;
}

.about-intro-section {
	padding-top: 34px;
}

.about-section-title {
	margin: 0 0 18px;
}

.about-section-title h2 {
	position: relative;
	display: inline-block;
	margin: 0;
	padding-bottom: 10px;
	color: #111827;
	font-size: 25px;
	font-weight: 900;
	line-height: 1.28;
}

.about-section-title h2::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 36px;
	height: 3px;
	background: linear-gradient(90deg, var(--color-primary), #6d8cff);
	border-radius: 999px;
}

.about-intro-grid {
	display: grid;
	grid-template-columns: minmax(0, 0.92fr) minmax(420px, 1fr);
	gap: 44px;
	align-items: center;
}

.about-intro-copy p {
	margin: 0 0 16px;
	color: #263244;
	font-size: 15px;
	line-height: 1.9;
}

.about-intro-copy p:last-child {
	margin-bottom: 0;
}

.about-intro-image {
	margin: 0;
}

.about-intro-image img {
	width: 100%;
	aspect-ratio: 16 / 8;
	object-fit: cover;
	border-radius: 8px;
	box-shadow: 0 14px 36px rgba(35, 59, 122, 0.12);
}

.about-stat-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 28px;
	margin-top: 26px;
}

.about-stat-card {
	display: grid;
	grid-template-columns: 50px minmax(0, 1fr);
	column-gap: 16px;
	align-items: center;
	min-height: 92px;
	padding: 18px 24px;
	background: #fff;
	border: 1px solid #dfe7f5;
	border-radius: 8px;
	box-shadow: 0 10px 26px rgba(30, 72, 160, 0.08);
}

.about-stat-card .icon {
	grid-row: span 2;
	width: 42px;
	height: 42px;
	color: #1749ba;
}

.about-stat-card strong,
.about-stat-card span {
	display: block;
	min-width: 0;
}

.about-stat-card strong {
	color: #0d3ea3;
	font-size: 25px;
	font-weight: 900;
	line-height: 1.1;
}

.about-stat-card strong em {
	margin-left: 4px;
	font-size: 13px;
	font-style: normal;
	font-weight: 800;
}

.about-stat-card span {
	margin-top: 4px;
	color: var(--color-muted);
	font-size: 13px;
	line-height: 1.35;
}

.about-domain-grid {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 14px;
}

.about-domain-card,
.about-value-card {
	background: linear-gradient(180deg, #fff, #f7faff);
	border: 1px solid #e3eaf6;
	border-radius: 8px;
	box-shadow: 0 8px 22px rgba(35, 59, 122, 0.06);
}

.about-domain-card {
	min-height: 142px;
	padding: 22px 16px 18px;
	text-align: center;
}

.about-domain-card .icon,
.about-value-card .icon {
	color: #1749ba;
}

.about-domain-card .icon {
	width: 42px;
	height: 42px;
	margin-bottom: 13px;
}

.about-domain-card h3 {
	margin: 0 0 8px;
	color: #17223a;
	font-size: 16px;
	font-weight: 900;
	line-height: 1.35;
}

.about-domain-card p {
	margin: 0;
	color: var(--color-muted);
	font-size: 12px;
	line-height: 1.55;
}

.about-timeline {
	position: relative;
	display: grid;
	grid-template-columns: repeat(7, minmax(0, 1fr));
	gap: 0;
	padding: 10px 10px 18px;
	background: linear-gradient(180deg, #fbfdff, #f1f6ff);
	border: 1px solid #e3eaf6;
	border-radius: 8px;
}

.about-timeline::before {
	content: "";
	position: absolute;
	top: 30px;
	left: 36px;
	right: 36px;
	height: 2px;
	background: linear-gradient(90deg, rgba(23, 73, 186, 0.12), rgba(23, 73, 186, 0.56), rgba(23, 73, 186, 0.12));
}

.about-timeline-item {
	position: relative;
	z-index: 1;
	padding: 0 12px;
	text-align: center;
}

.about-timeline-item > span {
	display: block;
	width: 13px;
	height: 13px;
	margin: 14px auto 18px;
	background: #fff;
	border: 4px solid #1749ba;
	border-radius: 999px;
	box-shadow: 0 0 0 5px #eef4ff;
}

.about-timeline-item strong {
	display: block;
	color: #123b96;
	font-size: 15px;
	font-weight: 900;
}

.about-timeline-item h3 {
	margin: 9px 0 4px;
	color: #17223a;
	font-size: 13px;
	font-weight: 900;
	line-height: 1.4;
}

.about-timeline-item p {
	margin: 0;
	color: var(--color-muted);
	font-size: 12px;
	line-height: 1.45;
}

.about-value-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
}

.about-value-card {
	min-height: 132px;
	padding: 22px 24px;
	text-align: center;
}

.about-value-card .icon {
	width: 36px;
	height: 36px;
	margin-bottom: 12px;
}

.about-value-card h3 {
	margin: 0 0 8px;
	color: #17223a;
	font-size: 16px;
	font-weight: 900;
}

.about-value-card p {
	margin: 0;
	color: var(--color-muted);
	font-size: 13px;
	line-height: 1.65;
}

.about-lab-grid {
	display: grid;
	grid-template-columns: minmax(320px, 390px) minmax(0, 1fr);
	gap: 26px;
	align-items: stretch;
}

.about-lab-feature {
	position: relative;
	min-height: 300px;
	overflow: hidden;
	color: #fff;
	border-radius: 8px;
	box-shadow: 0 16px 34px rgba(16, 53, 134, 0.18);
}

.about-lab-feature::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(13, 57, 151, 0.95), rgba(13, 68, 178, 0.72));
}

.about-lab-feature img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.about-lab-feature__content {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	min-height: 300px;
	padding: 28px;
}

.about-lab-feature h3 {
	margin: 0 0 18px;
	color: #fff;
	font-size: 18px;
	font-weight: 900;
	line-height: 1.5;
}

.about-lab-feature ul {
	display: grid;
	gap: 9px;
	padding: 0;
	margin: 0 0 22px;
	list-style: none;
}

.about-lab-feature li {
	display: flex;
	align-items: center;
	gap: 8px;
	color: rgba(255, 255, 255, 0.93);
	font-size: 13px;
	line-height: 1.45;
}

.about-lab-feature li .icon {
	width: 16px;
	height: 16px;
	color: #fff;
}

.about-mini-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 38px;
	padding: 0 16px;
	align-self: flex-start;
	color: #123b96;
	background: #fff;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 900;
}

.about-mini-button:hover {
	color: #123b96;
}

.about-mini-button .icon {
	width: 15px;
	height: 15px;
}

.about-mini-button--blue {
	color: #fff;
	background: #1749ba;
}

.about-mini-button--blue:hover {
	color: #fff;
	background: #123b96;
}

.about-lab-detail {
	min-width: 0;
}

.about-lab-stats {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 12px;
	margin-bottom: 18px;
}

.about-lab-stats div {
	display: grid;
	grid-template-columns: 34px 1fr;
	column-gap: 10px;
	align-items: center;
	min-height: 76px;
	padding: 13px;
	background: #f6f9ff;
	border: 1px solid #e4ebf7;
	border-radius: 8px;
}

.about-lab-stats .icon {
	grid-row: span 2;
	width: 30px;
	height: 30px;
	color: #1749ba;
}

.about-lab-stats strong {
	color: #0d3ea3;
	font-size: 18px;
	font-weight: 900;
	line-height: 1.1;
}

.about-lab-stats strong em {
	margin-left: 3px;
	font-size: 11px;
	font-style: normal;
}

.about-lab-stats span {
	color: var(--color-muted);
	font-size: 12px;
	line-height: 1.3;
}

.about-equipment-title {
	margin: 0 0 12px;
	color: #17223a;
	font-size: 15px;
	font-weight: 900;
}

.about-equipment-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 12px;
}

.about-equipment-card,
.about-cert-card {
	margin: 0;
	background: #fff;
	border: 1px solid #e3eaf6;
	border-radius: 8px;
	box-shadow: 0 8px 22px rgba(35, 59, 122, 0.06);
}

.about-equipment-card {
	overflow: hidden;
}

.about-equipment-card img {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
}

.about-equipment-card figcaption {
	padding: 9px 8px 11px;
	text-align: center;
}

.about-equipment-card strong,
.about-equipment-card span {
	display: block;
}

.about-equipment-card strong {
	color: #17223a;
	font-size: 12px;
	font-weight: 900;
}

.about-equipment-card span {
	margin-top: 3px;
	color: var(--color-muted);
	font-size: 11px;
	line-height: 1.35;
}

.about-cert-section {
	padding-top: 32px;
}

.about-cert-grid {
	display: grid;
	grid-template-columns: 230px minmax(0, 1fr);
	gap: 24px;
	align-items: center;
}

.about-cert-copy p {
	margin: 0 0 18px;
	color: var(--color-muted);
	font-size: 14px;
	line-height: 1.75;
}

.about-cert-list {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 16px;
}

.about-cert-card {
	padding: 10px 10px 12px;
	text-align: center;
}

.about-cert-card img {
	width: 100%;
	height: 146px;
	object-fit: contain;
	object-position: center top;
	background: #fff;
}

.about-cert-card figcaption {
	margin-top: 9px;
	color: #17223a;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.45;
}

.about-client-section {
	padding-bottom: 28px;
}

.about-industry-row,
.about-client-row {
	display: grid;
	align-items: center;
	border: 1px solid #e3eaf6;
	background: #fff;
}

.about-industry-row {
	grid-template-columns: repeat(10, minmax(0, 1fr));
	border-radius: 8px 8px 0 0;
}

.about-industry-row span {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 78px;
	padding: 10px 6px;
	color: #17223a;
	font-size: 13px;
	font-weight: 800;
	text-align: center;
	border-right: 1px solid #e3eaf6;
}

.about-industry-row span:last-child {
	border-right: 0;
}

.about-industry-row .icon {
	width: 30px;
	height: 30px;
	color: #1749ba;
}

.about-client-row {
	grid-template-columns: repeat(10, minmax(0, 1fr));
	border-top: 0;
	border-radius: 0 0 8px 8px;
	box-shadow: 0 10px 26px rgba(35, 59, 122, 0.07);
}

.about-client-row span {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 68px;
	padding: 8px;
	color: #24324a;
	font-size: 20px;
	font-weight: 900;
	line-height: 1.1;
	text-align: center;
	overflow-wrap: anywhere;
	border-right: 1px solid #e3eaf6;
}

.about-client-row span:last-child {
	border-right: 0;
}

.about-client-row span:nth-child(3),
.about-client-row span:nth-child(6),
.about-client-row span:nth-child(7),
.about-client-row span:nth-child(8),
.about-client-row span:nth-child(9) {
	font-size: 15px;
}

.about-bottom-cta {
	margin: 2px 0 36px;
}

.about-bottom-cta__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 26px;
	align-items: center;
	padding: 30px 42px;
	color: #fff;
	background-image: linear-gradient(90deg, rgba(13, 57, 151, 0.98), rgba(13, 76, 188, 0.86), rgba(13, 76, 188, 0.46)), url("assets/images/hero-lab.png");
	background-position: center;
	background-size: cover;
	border-radius: 8px;
	box-shadow: 0 16px 34px rgba(16, 53, 134, 0.18);
}

.about-bottom-cta h2,
.about-bottom-cta p {
	margin: 0;
	color: #fff;
}

.about-bottom-cta h2 {
	font-size: 27px;
	font-weight: 900;
	line-height: 1.3;
}

.about-bottom-cta p {
	margin-top: 8px;
	color: rgba(255, 255, 255, 0.88);
	font-size: 19px;
	font-weight: 800;
}

.about-bottom-cta__actions {
	display: flex;
	gap: 14px;
	align-items: center;
}

.about-bottom-cta__actions .btn {
	min-width: 150px;
}

@media (max-width: 1100px) {
	.about-domain-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.about-lab-grid,
	.about-cert-grid {
		grid-template-columns: 1fr;
	}

	.about-lab-stats,
	.about-equipment-grid,
	.about-cert-list {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.about-industry-row,
	.about-client-row {
		grid-template-columns: repeat(5, minmax(0, 1fr));
	}

	.about-industry-row span:nth-child(5n),
	.about-client-row span:nth-child(5n) {
		border-right: 0;
	}

	.about-industry-row span:nth-child(n+6),
	.about-client-row span:nth-child(n+6) {
		border-top: 1px solid #e3eaf6;
	}
}

@media (max-width: 900px) {
	.about-intro-grid {
		grid-template-columns: 1fr;
		gap: 22px;
	}

	.about-stat-grid,
	.about-value-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 14px;
	}

	.about-timeline {
		display: flex;
		gap: 10px;
		overflow-x: auto;
		padding: 14px;
		scrollbar-width: none;
	}

	.about-timeline::-webkit-scrollbar {
		display: none;
	}

	.about-timeline::before {
		display: none;
	}

	.about-timeline-item {
		flex: 0 0 138px;
		padding: 12px;
		background: #fff;
		border: 1px solid #e3eaf6;
		border-radius: 8px;
	}

	.about-timeline-item > span {
		display: none;
	}

	.about-bottom-cta__inner {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 767px) {
	.about-page .container {
		width: min(100% - 28px, 1200px);
	}

	.about-hero {
		background-image: linear-gradient(90deg, rgba(11, 49, 132, 0.98), rgba(15, 71, 174, 0.84), rgba(15, 71, 174, 0.28)), url("assets/images/hero-lab.png");
		background-position: 70% center;
	}

	.about-hero__inner {
		min-height: 176px;
	}

	.about-hero__copy {
		width: 72%;
	}

	.about-hero h1 {
		margin-bottom: 8px;
		font-size: 30px;
	}

	.about-hero__lead {
		font-size: 15px;
		line-height: 1.65;
	}

	.about-hero__desktop-text,
	.about-breadcrumb-row {
		display: none;
	}

	.about-section,
	.about-intro-section,
	.about-cert-section {
		padding-top: 18px;
	}

	.about-section-title {
		margin-bottom: 12px;
	}

	.about-section-title h2 {
		padding-bottom: 8px;
		font-size: 21px;
	}

	.about-intro-grid {
		gap: 12px;
	}

	.about-intro-copy p {
		margin-bottom: 10px;
		font-size: 14px;
		line-height: 1.75;
	}

	.about-intro-copy p:nth-of-type(2),
	.about-intro-image {
		display: none;
	}

	.about-stat-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 10px;
		margin-top: 14px;
	}

	.about-stat-card {
		grid-template-columns: 34px minmax(0, 1fr);
		column-gap: 9px;
		min-height: 66px;
		padding: 11px;
	}

	.about-stat-card .icon {
		width: 29px;
		height: 29px;
	}

	.about-stat-card strong {
		font-size: 20px;
	}

	.about-stat-card strong em,
	.about-stat-card span {
		font-size: 11px;
	}

	.about-domain-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 10px;
	}

	.about-domain-card {
		min-height: 102px;
		padding: 14px 10px 12px;
	}

	.about-domain-card:nth-child(n+5) {
		display: none;
	}

	.about-domain-card .icon {
		width: 32px;
		height: 32px;
		margin-bottom: 8px;
	}

	.about-domain-card h3 {
		margin-bottom: 0;
		font-size: 14px;
	}

	.about-domain-card p {
		display: none;
	}

	.about-timeline {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 10px;
		padding: 0;
		background: transparent;
		border: 0;
		border-radius: 0;
	}

	.about-timeline-item {
		min-height: 82px;
		padding: 12px 8px;
	}

	.about-timeline-item:nth-child(n+5) {
		display: none;
	}

	.about-timeline-item h3 {
		margin: 5px 0 0;
		font-size: 12px;
	}

	.about-timeline-item p {
		display: none;
	}

	.about-value-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 10px;
	}

	.about-value-card {
		min-height: 88px;
		padding: 14px 10px;
	}

	.about-value-card .icon {
		width: 30px;
		height: 30px;
		margin-bottom: 7px;
	}

	.about-value-card h3 {
		margin-bottom: 0;
		font-size: 14px;
	}

	.about-value-card p {
		display: none;
	}

	.about-lab-grid {
		gap: 12px;
	}

	.about-lab-feature,
	.about-lab-feature__content {
		min-height: 236px;
	}

	.about-lab-feature__content {
		padding: 18px;
	}

	.about-lab-feature h3 {
		margin-bottom: 12px;
		font-size: 16px;
	}

	.about-lab-feature ul {
		gap: 7px;
		margin-bottom: 14px;
	}

	.about-lab-feature li:nth-child(n+4) {
		display: none;
	}

	.about-mini-button {
		width: 100%;
		min-height: 36px;
	}

	.about-lab-stats {
		display: none;
	}

	.about-equipment-title {
		margin-top: 2px;
	}

	.about-equipment-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 10px;
	}

	.about-equipment-card:nth-child(n+5) {
		display: none;
	}

	.about-equipment-card img {
		aspect-ratio: 5 / 3;
	}

	.about-cert-grid {
		gap: 10px;
	}

	.about-cert-copy p,
	.about-cert-copy .about-mini-button {
		display: none;
	}

	.about-cert-list {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 10px;
	}

	.about-cert-card {
		padding: 8px;
	}

	.about-cert-card:nth-child(n+4) {
		display: none;
	}

	.about-cert-card img {
		height: 112px;
	}

	.about-cert-card figcaption {
		margin-top: 6px;
		font-size: 11px;
	}

	.about-client-section {
		padding-bottom: 18px;
	}

	.about-industry-row {
		grid-template-columns: repeat(5, minmax(0, 1fr));
		border-radius: 8px;
	}

	.about-industry-row span {
		min-height: 58px;
		gap: 5px;
		padding: 7px 4px;
		font-size: 11px;
	}

	.about-industry-row span:nth-child(n+6),
	.about-client-row {
		display: none;
	}

	.about-industry-row .icon {
		width: 24px;
		height: 24px;
	}

	.about-bottom-cta {
		margin: 0 0 28px;
	}

	.about-bottom-cta__inner {
		gap: 16px;
		padding: 22px 18px;
		text-align: center;
	}

	.about-bottom-cta h2 {
		font-size: 22px;
	}

	.about-bottom-cta p {
		margin-top: 5px;
		font-size: 15px;
	}

	.about-bottom-cta__actions {
		display: grid;
		grid-template-columns: 1fr;
		gap: 10px;
	}

	.about-bottom-cta__actions .btn {
		width: 100%;
		min-width: 0;
	}
}

@media (max-width: 390px) {
	.about-hero__copy {
		width: 78%;
	}

	.about-domain-card h3,
	.about-value-card h3 {
		font-size: 13px;
	}

	.about-cert-card img {
		height: 96px;
	}
}

/* Lab strength page */
.lab-page {
	background: #fff;
}

.lab-hero {
	color: #fff;
	background-image: linear-gradient(90deg, rgba(4, 46, 134, 0.96) 0%, rgba(10, 66, 170, 0.86) 43%, rgba(10, 66, 170, 0.36) 72%, rgba(10, 66, 170, 0.08) 100%), url("assets/images/hero-lab.png");
	background-position: center right;
	background-size: cover;
}

.lab-hero__inner {
	display: flex;
	align-items: center;
	min-height: 270px;
}

.lab-hero__copy {
	width: min(680px, 68%);
}

.lab-hero h1 {
	margin: 0 0 10px;
	color: #fff;
	font-size: 46px;
	font-weight: 900;
	line-height: 1.16;
	letter-spacing: 0;
}

.lab-hero p {
	margin: 0;
	color: rgba(255, 255, 255, 0.9);
	font-size: 18px;
	font-weight: 700;
	line-height: 1.6;
}

.lab-hero__breadcrumbs {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
	margin-top: 42px;
	color: rgba(255, 255, 255, 0.86);
	font-size: 14px;
	font-weight: 800;
}

.lab-hero__breadcrumbs a {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: #fff;
}

.lab-hero__breadcrumbs .icon {
	width: 18px;
	height: 18px;
}

.lab-hero__breadcrumbs span::before {
	content: ">";
	margin-right: 10px;
	color: rgba(255, 255, 255, 0.7);
}

.lab-intro-section {
	padding: 42px 0 38px;
	background: #fff;
}

.lab-intro {
	display: grid;
	grid-template-columns: minmax(0, 460px) minmax(0, 1fr);
	gap: 38px;
	align-items: center;
}

.lab-intro__image {
	margin: 0;
}

.lab-intro__image img {
	display: block;
	width: 100%;
	aspect-ratio: 460 / 250;
	object-fit: cover;
	border-radius: 6px;
	box-shadow: 0 14px 34px rgba(12, 52, 130, 0.1);
}

.lab-section-heading {
	margin-bottom: 26px;
	text-align: center;
}

.lab-section-heading--left {
	margin-bottom: 14px;
	text-align: left;
}

.lab-section-heading h2 {
	position: relative;
	display: inline-block;
	margin: 0;
	padding-bottom: 12px;
	color: var(--color-text);
	font-size: 26px;
	font-weight: 900;
	line-height: 1.3;
	letter-spacing: 0;
}

.lab-section-heading h2::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	width: 42px;
	height: 3px;
	background: var(--color-primary);
	border-radius: 999px;
	transform: translateX(-50%);
}

.lab-section-heading--left h2::after {
	left: 0;
	transform: none;
}

.lab-section-heading p {
	max-width: 720px;
	margin: 10px auto 0;
	color: var(--color-muted);
	font-size: 14px;
	line-height: 1.7;
}

.lab-intro__content > p {
	margin: 0 0 22px;
	color: var(--color-muted);
	font-size: 15px;
	line-height: 1.9;
}

.lab-stat-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
}

.lab-stat-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-height: 118px;
	padding: 18px 12px;
	text-align: center;
	background: #fff;
	border: 1px solid #dce5f4;
	border-radius: 8px;
	box-shadow: 0 8px 22px rgba(35, 59, 122, 0.05);
}

.lab-stat-card .icon {
	width: 34px;
	height: 34px;
	margin-bottom: 10px;
	color: var(--color-primary);
}

.lab-stat-card strong {
	color: #0f4fc1;
	font-size: 17px;
	font-weight: 900;
	line-height: 1.2;
}

.lab-stat-card span {
	margin-top: 6px;
	color: var(--color-muted);
	font-size: 12px;
	line-height: 1.45;
}

.lab-section {
	padding: 34px 0 42px;
}

.lab-section--white {
	background: #fff;
}

.lab-section--soft {
	background: linear-gradient(180deg, #f5f9ff 0%, #fff 100%);
}

.lab-env-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 12px;
}

.lab-env-card {
	min-width: 0;
	text-align: center;
}

.lab-env-card__image {
	height: 128px;
	background-image: url("assets/images/lab-panorama.png");
	background-size: 440% auto;
	border-radius: 5px;
	box-shadow: 0 8px 18px rgba(12, 52, 130, 0.08);
}

.lab-env-card h3 {
	margin: 12px 0 0;
	color: var(--color-text);
	font-size: 15px;
	font-weight: 900;
	line-height: 1.35;
}

.lab-env-card p {
	margin: 6px auto 0;
	color: var(--color-muted);
	font-size: 12px;
	line-height: 1.55;
}

.lab-equipment-wrap,
.lab-certificate-wrap {
	display: grid;
	grid-template-columns: 32px minmax(0, 1fr) 32px;
	gap: 12px;
	align-items: center;
}

.lab-side-arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	color: var(--color-primary);
	background: #edf4ff;
	border-radius: 50%;
	font-size: 24px;
	font-weight: 400;
	line-height: 1;
}

.lab-equipment-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 14px;
}

.lab-equipment-card {
	min-height: 142px;
	padding: 16px 12px 14px;
	text-align: center;
	background: #fff;
	border: 1px solid #dce5f4;
	border-radius: 8px;
	box-shadow: 0 8px 22px rgba(35, 59, 122, 0.05);
}

.lab-equipment-card__visual {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 78px;
	height: 62px;
	margin: 0 auto 12px;
	color: var(--color-primary);
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(237, 244, 255, 0.88)),
		url("assets/images/service-collage.png");
	background-position: center;
	background-size: cover;
	border: 1px solid #e0e8f6;
	border-radius: 5px;
}

.lab-equipment-card__visual .icon {
	width: 32px;
	height: 32px;
}

.lab-equipment-card h3 {
	min-height: 38px;
	margin: 0 0 4px;
	color: var(--color-text);
	font-size: 14px;
	font-weight: 900;
	line-height: 1.35;
}

.lab-equipment-card span {
	color: #425f9d;
	font-size: 13px;
	font-weight: 800;
}

.lab-carousel-dots {
	display: flex;
	justify-content: center;
	gap: 7px;
	margin-top: 18px;
}

.lab-carousel-dots span {
	width: 6px;
	height: 6px;
	background: #c8d6ee;
	border-radius: 50%;
}

.lab-carousel-dots span:first-child {
	width: 18px;
	background: var(--color-primary);
	border-radius: 999px;
}

.lab-certificate-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 16px;
}

.lab-certificate-card {
	text-align: center;
}

.lab-certificate-card__paper {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	height: 168px;
	padding: 18px 14px;
	overflow: hidden;
	background:
		linear-gradient(#fff, #fff) padding-box,
		linear-gradient(135deg, #d5a13a, #ffe7a2 40%, #c98928) border-box;
	border: 8px solid transparent;
	border-radius: 4px;
	box-shadow: 0 10px 24px rgba(35, 59, 122, 0.08);
}

.lab-certificate-card:nth-child(2n) .lab-certificate-card__paper {
	background:
		linear-gradient(#fff, #fff) padding-box,
		linear-gradient(135deg, #9fb5dc, #e8f0ff 45%, #6682bf) border-box;
}

.lab-certificate-card:nth-child(3n) .lab-certificate-card__paper {
	background:
		linear-gradient(#fff, #fff) padding-box,
		linear-gradient(135deg, #d8b95b, #fff4c8 45%, #bd7e2c) border-box;
}

.lab-certificate-card__paper span {
	position: absolute;
	top: 13px;
	left: 50%;
	width: 34px;
	height: 34px;
	border: 2px solid rgba(207, 67, 58, 0.55);
	border-radius: 50%;
	transform: translateX(-50%);
}

.lab-certificate-card__paper strong {
	margin-top: 30px;
	color: #233b7a;
	font-size: 13px;
	font-weight: 900;
	line-height: 1.5;
}

.lab-certificate-card__paper em {
	margin-top: 10px;
	color: #9b6d21;
	font-size: 12px;
	font-style: normal;
	font-weight: 800;
}

.lab-certificate-card__paper i {
	position: absolute;
	right: 18px;
	bottom: 18px;
	width: 40px;
	height: 40px;
	border: 2px solid rgba(207, 67, 58, 0.34);
	border-radius: 50%;
}

.lab-certificate-card h3 {
	margin: 12px 0 0;
	color: var(--color-text);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.45;
}

.lab-cta-section {
	padding: 0 0 34px;
	background: #fff;
}

.lab-cta {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 24px;
	align-items: center;
	padding: 34px 46px;
	color: #fff;
	background-image: linear-gradient(90deg, rgba(12, 62, 158, 0.96), rgba(16, 74, 182, 0.9) 50%, rgba(16, 74, 182, 0.35) 100%), url("assets/images/hero-lab.png");
	background-position: center right;
	background-size: cover;
	border-radius: 8px;
	box-shadow: 0 14px 34px rgba(12, 52, 130, 0.14);
}

.lab-cta h2 {
	margin: 0 0 8px;
	color: #fff;
	font-size: 28px;
	font-weight: 900;
	line-height: 1.3;
}

.lab-cta p {
	margin: 0;
	color: rgba(255, 255, 255, 0.88);
	font-size: 15px;
	line-height: 1.65;
}

.lab-cta .btn {
	min-width: 180px;
	border-radius: 4px;
}

@media (max-width: 1180px) {
	.lab-intro {
		grid-template-columns: minmax(0, 420px) minmax(0, 1fr);
		gap: 28px;
	}

	.lab-stat-grid,
	.lab-equipment-grid,
	.lab-certificate-grid {
		grid-template-columns: repeat(3, 1fr);
	}

	.lab-env-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 900px) {
	.lab-hero__copy {
		width: min(640px, 78%);
	}

	.lab-intro {
		grid-template-columns: 1fr;
	}

	.lab-intro__image img {
		aspect-ratio: 16 / 8;
	}

	.lab-stat-grid {
		grid-template-columns: repeat(4, 1fr);
	}

	.lab-equipment-wrap,
	.lab-certificate-wrap {
		grid-template-columns: 1fr;
	}

	.lab-side-arrow {
		display: none;
	}

	.lab-equipment-grid,
	.lab-certificate-grid {
		display: flex;
		gap: 14px;
		overflow-x: auto;
		padding-bottom: 4px;
		scroll-snap-type: x mandatory;
		scrollbar-width: none;
	}

	.lab-equipment-grid::-webkit-scrollbar,
	.lab-certificate-grid::-webkit-scrollbar {
		display: none;
	}

	.lab-equipment-card {
		flex: 0 0 176px;
		scroll-snap-align: start;
	}

	.lab-certificate-card {
		flex: 0 0 172px;
		scroll-snap-align: start;
	}
}

@media (max-width: 767px) {
	.lab-hero {
		background-image: linear-gradient(90deg, rgba(6, 47, 133, 0.95), rgba(13, 75, 183, 0.76)), url("assets/images/hero-lab.png");
		background-position: center right 28%;
	}

	.lab-hero__inner {
		min-height: 220px;
	}

	.lab-hero__copy {
		width: 100%;
	}

	.lab-hero h1 {
		font-size: 34px;
	}

	.lab-hero p {
		max-width: 78%;
		font-size: 15px;
	}

	.lab-hero__breadcrumbs {
		margin-top: 28px;
		font-size: 13px;
	}

	.lab-intro-section,
	.lab-section {
		padding: 28px 0;
	}

	.lab-intro {
		gap: 20px;
	}

	.lab-intro__image img {
		aspect-ratio: 16 / 10;
	}

	.lab-section-heading {
		margin-bottom: 18px;
	}

	.lab-section-heading h2 {
		font-size: 22px;
	}

	.lab-section-heading p,
	.lab-intro__content > p {
		font-size: 13px;
		line-height: 1.75;
	}

	.lab-stat-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 10px;
	}

	.lab-stat-card {
		min-height: 104px;
		padding: 15px 10px;
	}

	.lab-env-grid {
		display: flex;
		gap: 12px;
		overflow-x: auto;
		padding-bottom: 4px;
		scroll-snap-type: x mandatory;
		scrollbar-width: none;
	}

	.lab-env-grid::-webkit-scrollbar {
		display: none;
	}

	.lab-env-card {
		flex: 0 0 74%;
		scroll-snap-align: start;
	}

	.lab-env-card__image {
		height: 132px;
		background-size: 330% auto;
	}

	.lab-equipment-card {
		flex-basis: 152px;
		min-height: 132px;
	}

	.lab-certificate-card {
		flex-basis: 156px;
	}

	.lab-certificate-card__paper {
		height: 150px;
	}

	.lab-cta-section {
		padding-bottom: 24px;
	}

	.lab-cta {
		grid-template-columns: 1fr;
		gap: 18px;
		padding: 28px 22px;
		background-image: linear-gradient(90deg, rgba(12, 62, 158, 0.95), rgba(16, 74, 182, 0.84)), url("assets/images/hero-lab.png");
		text-align: left;
	}

	.lab-cta h2 {
		font-size: 22px;
	}

	.lab-cta .btn {
		width: 100%;
	}
}

/* Primary navigation layout refinement */
@media (min-width: 768px) {
	.main-navigation__inner {
		display: flex;
	}

	.primary-menu {
		width: 100%;
	}

	.primary-menu > li {
		flex: 1 1 0;
		min-width: 0;
		justify-content: center;
	}

	.primary-menu > li > a {
		justify-content: center;
		width: 100%;
		padding-right: 10px;
		padding-left: 10px;
		text-align: center;
	}

	.primary-menu > li > .sub-menu {
		display: flex;
		flex-wrap: nowrap;
		grid-template-columns: none;
		width: max-content;
		min-width: 100%;
		max-width: calc(100vw - 40px);
		padding: 16px 18px;
	}

	.primary-menu > li > .sub-menu > li {
		flex: 0 0 auto;
	}

	.primary-menu > li > .sub-menu a {
		padding: 12px 20px;
		white-space: nowrap;
	}

	.primary-menu > li:nth-last-child(-n+2) > .sub-menu {
		right: 0;
		left: auto;
	}

	.primary-menu > li.primary-menu__service-root > .sub-menu {
		display: grid;
		grid-template-columns: repeat(5, minmax(132px, 1fr));
		width: min(920px, calc(100vw - 40px));
		padding: 18px 20px;
	}

	.primary-menu > li.primary-menu__service-root > .sub-menu > li {
		min-width: 0;
	}

	.primary-menu > li.primary-menu__service-root > .sub-menu a {
		padding: 10px 12px;
		white-space: normal;
	}
}

/* Lab page real image refinement */
.lab-hero {
	background-image: linear-gradient(90deg, rgba(4, 46, 134, 0.96) 0%, rgba(10, 66, 170, 0.88) 42%, rgba(10, 66, 170, 0.42) 72%, rgba(10, 66, 170, 0.08) 100%), var(--lab-hero-image, url("assets/images/hero-lab.png"));
	background-position: center;
}

.lab-intro {
	grid-template-columns: minmax(0, 520px) minmax(0, 1fr);
	gap: 42px;
}

.lab-intro__image img {
	aspect-ratio: 520 / 320;
}

.lab-env-grid {
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
}

.lab-env-card {
	padding: 0 0 18px;
	overflow: hidden;
	background: #fff;
	border: 1px solid #dce5f4;
	border-radius: 8px;
	box-shadow: 0 10px 26px rgba(35, 59, 122, 0.06);
	text-align: left;
}

.lab-env-card__image {
	height: auto;
	margin: 0;
	background: none;
	box-shadow: none;
	border-radius: 0;
}

.lab-env-card__image img {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 9.5;
	object-fit: cover;
}

.lab-env-card h3,
.lab-env-card p {
	padding-right: 18px;
	padding-left: 18px;
}

.lab-env-card h3 {
	margin-top: 16px;
}

.lab-equipment-carousel {
	display: grid;
	grid-template-columns: 38px minmax(0, 1fr) 38px;
	gap: 14px;
	align-items: center;
}

.lab-equipment-track {
	min-width: 0;
	overflow-x: auto;
	scroll-behavior: smooth;
	scroll-snap-type: x mandatory;
	scrollbar-width: none;
}

.lab-equipment-track::-webkit-scrollbar {
	display: none;
}

.lab-equipment-track:focus {
	outline: 3px solid rgba(63, 95, 175, 0.18);
	outline-offset: 4px;
}

.lab-equipment-grid {
	display: flex;
	grid-template-columns: none;
	gap: 18px;
	min-width: max-content;
}

.lab-equipment-card {
	flex: 0 0 212px;
	min-height: 0;
	padding: 0;
	overflow: hidden;
	scroll-snap-align: start;
	text-align: left;
}

.lab-equipment-card__image {
	margin: 0;
	background: #eef4ff;
}

.lab-equipment-card__image img {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
}

.lab-equipment-card__body {
	padding: 15px 16px 16px;
}

.lab-equipment-card h3 {
	min-height: 0;
	margin-bottom: 7px;
	font-size: 15px;
}

.lab-side-arrow {
	border: 0;
	cursor: pointer;
	transition: background 0.18s ease, color 0.18s ease, opacity 0.18s ease;
}

.lab-side-arrow:hover {
	color: #fff;
	background: var(--color-primary);
}

.lab-side-arrow:disabled {
	cursor: default;
	opacity: 0.35;
}

.lab-side-arrow:disabled:hover {
	color: var(--color-primary);
	background: #edf4ff;
}

.lab-certificate-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 18px;
}

.lab-certificate-card {
	margin: 0;
	text-align: center;
}

.lab-certificate-card__image {
	height: 245px;
	padding: 10px;
	background: #fff;
	border: 1px solid #dce5f4;
	border-radius: 8px;
	box-shadow: 0 10px 26px rgba(35, 59, 122, 0.06);
}

.lab-certificate-card__image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.lab-certificate-card figcaption {
	margin-top: 12px;
	color: var(--color-text);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.45;
}

.lab-cta {
	background-image: linear-gradient(90deg, rgba(12, 62, 158, 0.96), rgba(16, 74, 182, 0.9) 50%, rgba(16, 74, 182, 0.36) 100%), var(--lab-cta-image, url("assets/images/hero-lab.png"));
}

@media (max-width: 1180px) {
	.lab-intro {
		grid-template-columns: minmax(0, 430px) minmax(0, 1fr);
	}

	.lab-equipment-card {
		flex-basis: 196px;
	}

	.lab-certificate-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 900px) {
	.lab-intro {
		grid-template-columns: 1fr;
	}

	.lab-equipment-carousel {
		grid-template-columns: 1fr;
	}

	.lab-equipment-carousel .lab-side-arrow {
		display: none;
	}

	.lab-equipment-track {
		margin-right: -14px;
		padding-bottom: 4px;
	}

	.lab-certificate-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 767px) {
	.lab-hero {
		background-image: linear-gradient(90deg, rgba(6, 47, 133, 0.95), rgba(13, 75, 183, 0.76)), var(--lab-hero-image, url("assets/images/hero-lab.png"));
	}

	.lab-env-grid {
		display: flex;
		gap: 12px;
		overflow-x: auto;
		padding-bottom: 4px;
		scroll-snap-type: x mandatory;
		scrollbar-width: none;
	}

	.lab-env-grid::-webkit-scrollbar {
		display: none;
	}

	.lab-env-card {
		flex: 0 0 82%;
		scroll-snap-align: start;
	}

	.lab-equipment-card {
		flex-basis: 172px;
	}

	.lab-equipment-card__body {
		padding: 12px 12px 14px;
	}

	.lab-certificate-grid {
		gap: 12px;
	}

	.lab-certificate-card__image {
		height: 190px;
		padding: 8px;
	}

	.lab-cta {
		background-image: linear-gradient(90deg, rgba(12, 62, 158, 0.95), rgba(16, 74, 182, 0.84)), var(--lab-cta-image, url("assets/images/hero-lab.png"));
	}
}

/* Unified inner page hero: process / contact / lab */
.process-hero,
.contact-hero,
.lab-hero {
	color: #17233a;
	background-image: linear-gradient(90deg, rgba(238, 247, 255, 0.98) 0%, rgba(238, 247, 255, 0.92) 42%, rgba(238, 247, 255, 0.42) 72%, rgba(238, 247, 255, 0.08) 100%), url("assets/images/hero-lab.png");
	background-position: center right;
	background-size: cover;
}

.lab-hero {
	background-image: linear-gradient(90deg, rgba(238, 247, 255, 0.98) 0%, rgba(238, 247, 255, 0.92) 42%, rgba(238, 247, 255, 0.42) 72%, rgba(238, 247, 255, 0.08) 100%), var(--lab-hero-image, url("assets/images/hero-lab.png"));
}

.process-hero__inner,
.contact-hero__inner,
.lab-hero__inner {
	display: flex;
	align-items: center;
	min-height: 236px;
}

.process-hero__copy,
.contact-hero__copy,
.lab-hero__copy {
	width: min(720px, 68%);
}

.process-hero__breadcrumbs,
.contact-hero .breadcrumbs,
.lab-hero__breadcrumbs {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0 0 12px;
	color: #5f6f86;
	font-size: 13px;
	font-weight: 500;
	line-height: 1.4;
}

.process-hero__breadcrumbs a,
.contact-hero .breadcrumbs a,
.lab-hero__breadcrumbs a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: #315da8;
	font-weight: 600;
}

.process-hero__breadcrumbs span,
.contact-hero .breadcrumbs span,
.lab-hero__breadcrumbs span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.contact-hero .breadcrumbs span::before,
.process-hero__breadcrumbs span::before,
.lab-hero__breadcrumbs span::before {
	content: ">";
	color: #94a3b8;
	font-size: 12px;
	font-weight: 400;
}

.lab-hero__breadcrumbs .icon {
	display: none;
}

.process-hero h1,
.contact-hero h1,
.lab-hero h1 {
	margin: 0 0 8px;
	color: #123b86;
	font-size: 40px;
	font-weight: 800;
	line-height: 1.16;
	letter-spacing: 0;
}

.process-hero__lead {
	margin: 0 0 6px;
	color: #17233a;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.4;
}

.process-hero__desc,
.contact-hero__copy > p:not(.breadcrumbs),
.lab-hero p {
	max-width: 620px;
	margin: 0;
	color: #536277;
	font-size: 15px;
	font-weight: 400;
	line-height: 1.7;
}

.process-hero__badges,
.contact-hero__badges,
.lab-hero__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 12px;
	margin-top: 22px;
}

.process-hero__badges span,
.contact-hero__badges span,
.lab-hero__badges span {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	min-width: 0;
	min-height: 34px;
	padding: 0 12px;
	color: #24436f;
	background: rgba(255, 255, 255, 0.78);
	border: 1px solid #d7e3f4;
	border-radius: 999px;
	box-shadow: 0 5px 14px rgba(37, 75, 140, 0.08);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.25;
}

.process-hero__badges .icon,
.contact-hero__badges .icon,
.lab-hero__badges .icon {
	width: 18px;
	height: 18px;
	padding: 0;
	color: #3768c5;
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
}

.contact-hero__badges strong {
	color: inherit;
	font-size: inherit;
	font-weight: inherit;
}

.contact-hero__badges em {
	display: none;
}

.contact-breadcrumb-mobile,
.process-breadcrumb-row {
	display: none !important;
}

@media (max-width: 900px) {
	.process-hero__copy,
	.contact-hero__copy,
	.lab-hero__copy {
		width: min(620px, 76%);
	}
}

@media (max-width: 767px) {
	.process-hero,
	.contact-hero,
	.lab-hero {
		background-image: linear-gradient(90deg, rgba(238, 247, 255, 0.98) 0%, rgba(238, 247, 255, 0.9) 62%, rgba(238, 247, 255, 0.34) 100%), url("assets/images/hero-lab.png");
		background-position: center right 28%;
	}

	.lab-hero {
		background-image: linear-gradient(90deg, rgba(238, 247, 255, 0.98) 0%, rgba(238, 247, 255, 0.9) 62%, rgba(238, 247, 255, 0.34) 100%), var(--lab-hero-image, url("assets/images/hero-lab.png"));
	}

	.process-hero__inner,
	.contact-hero__inner,
	.lab-hero__inner {
		min-height: 198px;
	}

	.process-hero__copy,
	.contact-hero__copy,
	.lab-hero__copy {
		width: 100%;
	}

	.process-hero__breadcrumbs,
	.contact-hero .breadcrumbs,
	.lab-hero__breadcrumbs {
		margin-bottom: 9px;
		font-size: 12px;
	}

	.process-hero h1,
	.contact-hero h1,
	.lab-hero h1 {
		margin-bottom: 6px;
		font-size: 30px;
		line-height: 1.2;
	}

	.process-hero__lead {
		margin-bottom: 4px;
		font-size: 16px;
	}

	.process-hero__desc,
	.contact-hero__copy > p:not(.breadcrumbs),
	.lab-hero p {
		max-width: 72%;
		font-size: 13px;
		line-height: 1.58;
	}

	.process-hero__badges,
	.contact-hero__badges,
	.lab-hero__badges {
		gap: 8px;
		margin-top: 14px;
	}

	.process-hero__badges span,
	.contact-hero__badges span,
	.lab-hero__badges span {
		min-height: 30px;
		padding: 0 9px;
		font-size: 12px;
	}

	.process-hero__badges .icon,
	.contact-hero__badges .icon,
	.lab-hero__badges .icon {
		width: 16px;
		height: 16px;
	}
}

@media (max-width: 420px) {
	.process-hero__badges span:nth-child(n+4),
	.contact-hero__badges span:nth-child(n+4),
	.lab-hero__badges span:nth-child(n+4) {
		display: none;
	}

	.process-hero__desc,
	.contact-hero__copy > p:not(.breadcrumbs),
	.lab-hero p {
		max-width: 82%;
	}
}

/* Unified inner page hero: about / news / standard */
.about-hero,
.news-hero,
.standard-hero {
	color: #17233a;
	background-image: linear-gradient(90deg, rgba(238, 247, 255, 0.98) 0%, rgba(238, 247, 255, 0.92) 42%, rgba(238, 247, 255, 0.42) 72%, rgba(238, 247, 255, 0.08) 100%), url("assets/images/hero-lab.png");
	background-position: center right;
	background-size: cover;
}

.about-hero__inner,
.news-hero__inner,
.standard-hero__inner {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: flex-start;
	min-height: 236px;
	text-align: left;
}

.about-hero__copy,
.news-hero__copy,
.standard-hero__copy {
	width: min(720px, 68%);
}

.about-hero__breadcrumbs,
.news-hero__breadcrumbs,
.standard-hero__breadcrumbs {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 0 0 12px;
	color: #5f6f86;
	font-size: 13px;
	font-weight: 500;
	line-height: 1.4;
}

.about-hero__breadcrumbs a,
.news-hero__breadcrumbs a,
.standard-hero__breadcrumbs a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: #315da8;
	font-weight: 600;
}

.about-hero__breadcrumbs span,
.news-hero__breadcrumbs span,
.standard-hero__breadcrumbs span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.about-hero__breadcrumbs span::before,
.news-hero__breadcrumbs span::before,
.standard-hero__breadcrumbs span::before {
	content: ">";
	color: #94a3b8;
	font-size: 12px;
	font-weight: 400;
}

.about-hero h1,
.news-hero h1,
.standard-hero h1 {
	margin: 0 0 8px;
	color: #123b86;
	font-size: 40px;
	font-weight: 800;
	line-height: 1.16;
	letter-spacing: 0;
}

.about-hero__lead,
.about-hero__text,
.news-hero__copy > p,
.standard-hero__desc,
.standard-hero__desc p {
	max-width: 620px;
	margin: 0;
	color: #536277;
	font-size: 15px;
	font-weight: 400;
	line-height: 1.7;
}

.about-hero__lead {
	margin-bottom: 4px;
	color: #17233a;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.4;
}

.standard-hero__desc p {
	margin: 0;
}

.about-hero__badges,
.news-hero__badges,
.standard-hero__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 12px;
	margin-top: 22px;
}

.about-hero__badges span,
.news-hero__badges span,
.standard-hero__badges span {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	min-width: 0;
	min-height: 34px;
	padding: 0 12px;
	color: #24436f;
	background: rgba(255, 255, 255, 0.78);
	border: 1px solid #d7e3f4;
	border-radius: 999px;
	box-shadow: 0 5px 14px rgba(37, 75, 140, 0.08);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.25;
}

.about-hero__badges .icon,
.news-hero__badges .icon,
.standard-hero__badges .icon {
	width: 18px;
	height: 18px;
	padding: 0;
	color: #3768c5;
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
}

.about-breadcrumb-row,
.news-breadcrumb-row,
.standard-breadcrumb-row {
	display: none !important;
}

@media (max-width: 900px) {
	.about-hero__copy,
	.news-hero__copy,
	.standard-hero__copy {
		width: min(620px, 76%);
	}
}

@media (max-width: 767px) {
	.about-hero,
	.news-hero,
	.standard-hero {
		background-image: linear-gradient(90deg, rgba(238, 247, 255, 0.98) 0%, rgba(238, 247, 255, 0.9) 62%, rgba(238, 247, 255, 0.34) 100%), url("assets/images/hero-lab.png");
		background-position: center right 28%;
	}

	.about-hero__inner,
	.news-hero__inner,
	.standard-hero__inner {
		min-height: 198px;
	}

	.about-hero__copy,
	.news-hero__copy,
	.standard-hero__copy {
		width: 100%;
	}

	.about-hero__breadcrumbs,
	.news-hero__breadcrumbs,
	.standard-hero__breadcrumbs {
		margin-bottom: 9px;
		font-size: 12px;
	}

	.about-hero h1,
	.news-hero h1,
	.standard-hero h1 {
		margin-bottom: 6px;
		font-size: 30px;
		line-height: 1.2;
	}

	.about-hero__lead {
		margin-bottom: 4px;
		font-size: 16px;
	}

	.about-hero__text,
	.news-hero__copy > p,
	.standard-hero__desc,
	.standard-hero__desc p {
		max-width: 72%;
		font-size: 13px;
		line-height: 1.58;
	}

	.about-hero__badges,
	.news-hero__badges,
	.standard-hero__badges {
		gap: 8px;
		margin-top: 14px;
	}

	.about-hero__badges span,
	.news-hero__badges span,
	.standard-hero__badges span {
		min-height: 30px;
		padding: 0 9px;
		font-size: 12px;
	}

	.about-hero__badges .icon,
	.news-hero__badges .icon,
	.standard-hero__badges .icon {
		width: 16px;
		height: 16px;
	}
}

@media (max-width: 420px) {
	.about-hero__badges span:nth-child(n+4),
	.news-hero__badges span:nth-child(n+4),
	.standard-hero__badges span:nth-child(n+4) {
		display: none;
	}

	.about-hero__text,
	.news-hero__copy > p,
	.standard-hero__desc,
	.standard-hero__desc p {
		max-width: 82%;
	}
}

/* Contact page mobile layout */
@media (max-width: 767px) {
	.contact-page {
		background: #fff;
	}

	.contact-page .contact-hero {
		overflow: visible;
		background-image: linear-gradient(90deg, rgba(234, 246, 255, 0.98) 0%, rgba(234, 246, 255, 0.88) 54%, rgba(234, 246, 255, 0.36) 100%), url("assets/images/hero-lab.png");
		background-position: center right 24%;
		background-size: cover;
	}

	.contact-page .contact-hero__inner {
		position: relative;
		min-height: 230px;
		align-items: flex-start;
		padding-top: 30px;
		padding-bottom: 64px;
	}

	.contact-page .contact-hero__copy {
		width: 100%;
	}

	.contact-page .contact-hero .breadcrumbs {
		display: flex;
		margin-bottom: 10px;
		color: #526a8a;
		font-size: 13px;
	}

	.contact-page .contact-hero .breadcrumbs a {
		color: #174e9d;
	}

	.contact-page .contact-hero h1 {
		margin-bottom: 6px;
		color: #123b86;
		font-size: 30px;
		font-weight: 900;
		line-height: 1.16;
	}

	.contact-page .contact-hero__copy > p:not(.breadcrumbs) {
		max-width: 270px;
		color: #24436f;
		font-size: 14px;
		line-height: 1.58;
	}

	.contact-page .contact-hero__badges {
		position: absolute;
		right: 0;
		bottom: -30px;
		left: 0;
		display: grid;
		grid-template-columns: repeat(4, minmax(0, 1fr));
		gap: 8px;
		margin: 0;
		padding: 14px 10px;
		background: #fff;
		border: 1px solid #dbe4f2;
		border-radius: 8px;
		box-shadow: 0 12px 28px rgba(35, 59, 122, 0.12);
	}

	.contact-page .contact-hero__badges span,
	.contact-page .contact-hero__badges span:nth-child(n+4) {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		gap: 6px;
		min-width: 0;
		min-height: 38px;
		padding: 0;
		color: #123b86;
		text-align: center;
		background: transparent;
		border: 0;
		border-radius: 0;
		box-shadow: none;
		font-size: 12px;
		font-weight: 900;
		line-height: 1.2;
	}

	.contact-page .contact-hero__badges .icon {
		width: 18px;
		height: 18px;
		color: #1d65d8;
	}

	.contact-page .contact-hero__badges strong {
		color: inherit;
		font-size: inherit;
		font-weight: inherit;
	}

	.contact-page .contact-hero__badges em {
		display: none;
	}

	.contact-page .contact-main-section {
		padding: 50px 0 24px;
		background: #fff;
	}

	.contact-page .contact-main-grid {
		grid-template-columns: minmax(0, 1fr);
		gap: 18px;
	}

	.contact-page .contact-card {
		border-color: #edf1f8;
		box-shadow: 0 10px 24px rgba(35, 59, 122, 0.06);
	}

	.contact-page .contact-methods,
	.contact-page .contact-message-card {
		padding: 22px 18px;
	}
}

@media (max-width: 420px) {
	.contact-page .contact-hero__badges {
		gap: 5px;
		padding-right: 8px;
		padding-left: 8px;
	}

	.contact-page .contact-hero__badges span {
		font-size: 11px;
	}
}

/* Consultation modal — WeChat variant (mobile) */
@media (max-width: 767px) {
	.consultation-modal.is-variant-wechat {
		padding: 20px 16px;
	}

	.consultation-modal.is-variant-wechat .consultation-modal__dialog {
		width: min(420px, calc(100vw - 32px));
		max-height: calc(100vh - 40px);
		overflow-y: auto;
	}

	.consultation-modal.is-variant-wechat .consultation-modal__main {
		display: grid;
		grid-template-columns: 1fr;
		min-height: 0;
	}

	.consultation-modal.is-variant-wechat .consultation-modal__side {
		display: block;
		padding: 38px 24px 30px;
		color: #fff;
		background-color: #123b86;
		background-image: linear-gradient(160deg, rgba(52, 138, 238, 0.98), rgba(0, 73, 184, 0.98));
		text-align: center;
		border-right: 0;
	}

	.consultation-modal.is-variant-wechat .consultation-modal__side::after {
		display: none;
	}

	.consultation-modal.is-variant-wechat .consultation-modal__side-head .icon {
		width: 34px;
		height: 34px;
		color: #fff;
	}

	.consultation-modal.is-variant-wechat .consultation-modal__side-head h2 {
		color: #fff;
		font-size: 22px;
	}

	.consultation-modal.is-variant-wechat .consultation-modal__qr {
		width: 150px;
		height: 150px;
		margin: 20px auto 10px;
		padding: 8px;
		object-fit: cover;
		background: #fff;
		border-radius: 8px;
		box-shadow: 0 12px 26px rgba(0, 35, 99, 0.25);
	}

	.consultation-modal.is-variant-wechat .consultation-modal__qr-caption {
		margin: 0;
		color: #fff;
		font-size: 14px;
	}

	.consultation-modal.is-variant-wechat .consultation-modal__phone {
		display: grid;
		grid-template-columns: 32px 1fr;
		align-items: center;
		column-gap: 12px;
		margin: 22px 0 8px;
		padding: 16px 0;
		border-top: 1px solid rgba(255, 255, 255, 0.2);
		border-bottom: 1px solid rgba(255, 255, 255, 0.2);
	}

	.consultation-modal.is-variant-wechat .consultation-modal__phone .icon {
		grid-row: span 3;
		width: 32px;
		height: 32px;
	}

	.consultation-modal.is-variant-wechat .consultation-modal__phone span,
	.consultation-modal.is-variant-wechat .consultation-modal__phone em {
		display: block;
		color: rgba(255, 255, 255, 0.86);
		font-style: normal;
		line-height: 1.3;
	}

	.consultation-modal.is-variant-wechat .consultation-modal__phone a {
		display: block;
		color: #fff;
		font-size: 24px;
		font-weight: 900;
		line-height: 1.25;
	}

	.consultation-modal.is-variant-wechat .consultation-modal__trust {
		display: none;
	}

	.consultation-modal.is-variant-wechat .consultation-modal__form-panel,
	.consultation-modal.is-variant-wechat .consultation-modal__bottom {
		display: none;
	}
}
