@font-face {
	font-family: Roboto;
	src: url(https://aos-hc.org/wp-content/themes/xcare/mypage/font/Roboto-SemiBold.woff2) format('woff2');
	font-weight: 600;
	font-style: normal;
	font-display: swap
}

@font-face {
	font-family: Sora;
	src: url(https://aos-hc.org/wp-content/themes/xcare/mypage/font/Sora-Regular.woff2) format('woff2');
	font-weight: 400;
	font-style: normal;
	font-display: swap
}

html {
	scroll-behavior: smooth
}

body {
	position: relative;
	font-family: Sora, sans-serif;
	font-size: 14px;
	color: #000;
	padding: 0;
	overflow-x: hidden;
	margin: 0
}

* {
	margin: 0;
	padding: 0;
	border: 0;
	font-family: Sora, sans-serif
}

p {
	font-size: 16px;
	color: #000;
	margin-bottom: 25px;
	font-family: Roboto, sans-serif;
	line-height: 28px
}

p:last-child {
	margin: 0
}

h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 0;
	color: #181a17;
	padding: 0;
	font-family: Sora, sans-serif
}

a {
	text-decoration: none;
	-webkit-transition: all .5s ease-in-out;
	-moz-transition: all .5s ease-in-out;
	-o-transition: all .5s ease-in-out;
	transition: all .5s ease-in-out;
	font-family: Sora, sans-serif
}

a:focus,
a:hover {
	text-decoration: none;
	outline: 0
}

main a {
	font-family: Roboto;
	color: unset;
	text-decoration: none
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	background: #fff;
	box-shadow: 0 1px 0 rgba(17, 41, 83, .08)
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	width: min(100%, 1920px);
	min-height: 80px;
	margin: 0 auto;
	padding: 0 52px
}

.mobile-logo,
.site-logo {
	display: inline-flex;
	align-items: center;
	flex: 0 0 auto;
	text-decoration: none
}

.site-logo img {
	display: block;
	width: clamp(160px, 10.5vw, 205px);
	height: auto
}

.desktop-nav {
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 1 1 auto;
	min-width: 0
}

.desktop-nav ul {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0;
	margin: 0;
	padding: 0;
	list-style: none
}

.desktop-nav>ul>li {
	position: relative;
	display: flex;
	align-items: center
}

.desktop-nav>ul>li:not(:last-child)::after {
	content: "";
	width: 5px;
	height: 5px;
	margin: 0 20px;
	border-radius: 50%;
	background: #415789
}

.desktop-nav a {
	display: inline-flex;
	align-items: center;
	min-height: 80px;
	color: #092452;
	font-size: 15px;
	font-weight: 600;
	line-height: 1;
	text-decoration: none;
	text-transform: uppercase;
	white-space: nowrap
}

.desktop-nav .has-dropdown:hover>a,
.desktop-nav a:hover {
	color: #415789
}

.header-appointment,
.mobile-appointment {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 54px;
	padding: 15px 34px;
	border-radius: 999px;
	background: #415789;
	color: #fff;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: .8px;
	line-height: 1;
	text-decoration: none;
	text-transform: uppercase;
	white-space: nowrap
}

.header-appointment:hover,
.mobile-appointment:hover {
	background: #112953;
	color: #fff
}

.mega-menu {
	position: absolute;
	top: 100%;
	left: 0;
	right: auto;
	width: 460px;
	z-index: 20;
	visibility: hidden;
	opacity: 0;
	transform: none;
	transition: opacity .22s ease, transform .22s ease, visibility .22s ease;
	pointer-events: none
}

.has-dropdown:focus-within .mega-menu,
.has-dropdown:hover .mega-menu {
	visibility: visible;
	opacity: 1;
	transform: none;
	pointer-events: auto
}

.mega-menu::before {
	content: "";
	position: absolute;
	top: -4px;
	left: 0;
	width: 230px;
	height: 4px;
	border-radius: 999px 999px 0 0;
	background: #415789
}

.desktop-nav .dropdown-menu-list,
.desktop-nav .mega-flyout,
.desktop-nav .mega-menu ul {
	display: block;
	align-items: initial;
	justify-content: initial;
	gap: 0;
	margin: 0;
	padding: 14px 0;
	background: #fff;
	box-shadow: 0 20px 45px rgba(17, 41, 83, .12)
}

.mega-menu__tabs {
	position: relative;
	width: 230px;
	min-height: 92px;
	border-right: 1px solid #edf0f6
}

.dropdown-menu-list>li,
.mega-menu__tabs>li {
	position: relative;
	display: block
}

.dropdown-menu-list>.has-flyout,
.mega-menu__tabs>.has-flyout {
	position: static
}

.desktop-nav .dropdown-menu-list a,
.desktop-nav .mega-menu a {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	min-height: 38px;
	padding: 10px 22px;
	color: #020915;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.2;
	text-align: left;
	text-transform: uppercase;
	white-space: normal
}

.desktop-nav .dropdown-menu-list a::before,
.desktop-nav .mega-menu a::before {
	content: "";
	flex: 0 0 auto;
	width: 0;
	height: 1px;
	margin-right: 0;
	background: currentColor;
	opacity: 0;
	transition: width .2s ease, margin .2s ease, opacity .2s ease
}

.desktop-nav .dropdown-menu-list a:hover::before,
.desktop-nav .mega-menu a:hover::before,
.desktop-nav .mega-menu__tabs>li:hover>a::before {
	width: 12px;
	margin-right: 7px;
	opacity: 1
}

.dropdown-menu-list .has-flyout>a::after,
.mega-menu__tabs>li>a::after {
	content: "";
	flex: 0 0 auto;
	width: 8px;
	height: 8px;
	margin-left: auto;
	border-top: 2px solid currentColor;
	border-right: 2px solid currentColor;
	transform: rotate(45deg)
}

.dropdown-menu-list a:hover,
.mega-menu a:hover,
.mega-menu__tabs>li:hover>a {
	background: #f5f7fb;
	color: #112953
}

.mega-flyout {
	position: absolute;
	top: 0;
	left: 100%;
	width: 230px;
	z-index: 30;
	min-height: 100%;
	visibility: hidden;
	opacity: 0;
	transform: translateX(10px);
	transition: opacity .18s ease, transform .18s ease, visibility .18s ease;
	pointer-events: none
}

.mega-flyout::before {
	content: "";
	position: absolute;
	top: -4px;
	left: 0;
	right: 0;
	height: 4px;
	border-radius: 999px 999px 0 0;
	background: #415789
}

.has-flyout:focus-within>.mega-flyout,
.has-flyout:hover>.mega-flyout {
	visibility: visible;
	opacity: 1;
	transform: translateX(0);
	pointer-events: auto
}

.simple-dropdown {
	position: relative
}

.dropdown-menu-list {
	position: absolute;
	top: 100%;
	left: 0;
	right: auto;
	width: 230px;
	z-index: 20;
	visibility: hidden;
	opacity: 0;
	transform: none;
	transition: opacity .22s ease, transform .22s ease, visibility .22s ease;
	pointer-events: none;
	list-style: none
}

.dropdown-menu-list::before {
	content: "";
	position: absolute;
	top: -4px;
	left: 0;
	right: 0;
	height: 4px;
	border-radius: 999px 999px 0 0;
	background: #415789
}

.simple-dropdown:focus-within>.dropdown-menu-list,
.simple-dropdown:hover>.dropdown-menu-list {
	visibility: visible;
	opacity: 1;
	transform: none;
	pointer-events: auto
}

.menu-toggle {
	display: none;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 9px;
	width: 46px;
	height: 46px;
	border: 0;
	border-radius: 50%;
	background: transparent;
	cursor: pointer
}

.menu-toggle span {
	display: block;
	width: 35px;
	height: 1px;
	border-radius: 999px;
	background: #222222;
}

.mobile-menu-backdrop {
	position: fixed;
	inset: 0;
	z-index: 1090;
	visibility: hidden;
	opacity: 0;
	background: rgba(0, 0, 0, .82);
	transition: opacity .28s ease, visibility .28s ease
}

.mobile-menu {
	position: fixed;
	top: 0;
	right: 0;
	z-index: 1100;
	width: min(600px, 54vw);
	height: 100vh;
	overflow-y: auto;
	background: #fff;
	transform: translateX(100%);
	transition: transform .32s ease;
	box-shadow: -20px 0 60px rgba(0, 0, 0, .18)
}

.mobile-menu__head {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	min-height: 148px;
	padding: 28px 52px;
	border-bottom: 1px solid #e4e4e4
}

.mobile-logo img {
	display: none;
	width: min(230px, 70%);
	height: auto
}

.mobile-menu__close {
	position: relative;
	width: 50px;
	height: 50px;
	border: 0;
	background: 0;
	cursor: pointer
}

.mobile-menu__close::after,
.mobile-menu__close::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 52px;
	height: 2px;
	border-radius: 999px;
	background: #092452
}

.mobile-menu__close::before {
	transform: translate(-50%, -50%) rotate(45deg)
}

.mobile-menu__close::after {
	transform: translate(-50%, -50%) rotate(-45deg)
}

.mobile-nav {
	margin: 0;
	padding: 0;
	list-style: none
}

.mobile-nav li {
	border-bottom: 1px solid #e4e4e4
}

.mobile-nav>li>a,
.mobile-nav>li>button {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	min-height: 55px;
	padding: 24px 52px;
	border: 0;
	background: #fff;
	color: #030303;
	font-size: 28px;
	font-weight: 600;
	line-height: 1.15;
	text-align: left;
	text-decoration: none;
	text-transform: uppercase
}

.mobile-nav .has-submenu>button {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	border: 0;
	text-align: left;
	text-transform: uppercase
}

.mobile-nav button::after {
	content: "";
	width: 14px;
	height: 14px;
	border-top: 3px solid #262626;
	border-right: 3px solid #262626;
	transform: rotate(45deg);
	transition: transform .2s ease
}

.mobile-nav__item.is-open>button::after {
	transform: rotate(135deg)
}

.mobile-nav ul {
	display: none;
	margin: 0;
	padding: 0;
	background: #f7f8fb;
	list-style: none
}

.mobile-nav__item.is-open>ul {
	display: block
}

.mobile-nav ul a,
.mobile-nav ul button {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	width: 100%;
	min-height: 58px;
	padding: 17px 64px;
	border: 0;
	background: #f7f8fb;
	color: #415789;
	font-size: 15px;
	font-weight: 600;
	line-height: 1.25;
	text-align: left;
	text-decoration: none;
	text-transform: uppercase
}

.mobile-nav ul button {
	justify-content: space-between
}

.mobile-nav ul button::after {
	width: 9px;
	height: 9px;
	border-width: 2px
}

.mobile-nav ul ul {
	background: #eef2f7
}

.mobile-nav ul ul a {
	min-height: 48px;
	padding: 14px 76px;
	background: #eef2f7;
	color: #092452;
	font-size: 13px
}

.mobile-appointment {
	display: none;
	margin: 28px 52px 42px
}

body.menu-open {
	overflow: hidden
}

body.menu-open .mobile-menu-backdrop {
	visibility: visible;
	opacity: 1
}

body.menu-open .mobile-menu {
	transform: translateX(0)
}

.hero-slider-section {
	background: #fff
}

.heroSwiper {
	position: relative;
	overflow: hidden;
	height: clamp(620px, 44vw, 820px);
	border-radius: 0
}

.heroSwiper .swiper-slide,
.heroSwiper .swiper-wrapper {
	height: 100%
}

.hero-slide {
	position: relative;
	height: 100%;
	overflow: hidden
}

.hero-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	z-index: 1
}

.hero-overlay {
	position: absolute;
	inset: 0;
	z-index: 2;
	background: linear-gradient(90deg, rgba(65, 87, 137, .92) 0, rgba(65, 87, 137, .72) 25%, rgba(65, 87, 137, .18) 55%, rgba(15, 26, 45, .12) 100%)
}

.hero-slide .container {
	position: relative;
	z-index: 3;
	height: 100%
}

.hero-slide .row {
	height: 100%
}

.hero-copy {
	color: #fff
}

.hero-kicker {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	max-width: 100%;
	margin-bottom: 35px;
	padding: 8px 18px;
	border: 1px solid rgba(255, 255, 255, .9);
	border-radius: 999px;
	color: #fff;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 1.8px;
	line-height: 1;
	text-transform: uppercase;
	white-space: nowrap
}

.hero-copy .banner-heading {
	margin: 0 0 22px;
	color: #fff;
	font-size: clamp(46px, 4vw, 35px);
	font-weight: 400;
	line-height: 1.05
}

.hero-appointment {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 12px 28px;
	border-radius: 999px;
	background: #415789;
	color: #fff;
	font-size: 15px;
	font-weight: 600;
	line-height: 1;
	text-decoration: none;
	font-family: Sora;
	text-transform: uppercase
}

.hero-appointment:hover {
	background: #112953;
	color: #fff
}

.hero-form {
	width: 100%
}

.hero-form .row {
	--bs-gutter-x: 14px;
	--bs-gutter-y: 12px
}

.hero-form-layer {
	position: absolute;
	inset: 0;
	z-index: 3;
	pointer-events: none
}

.hero-form-layer .container,
.hero-form-layer .row {
	height: 100%
}

.hero-form-layer .hero-form {
	pointer-events: auto
}

.hero-form input,
.hero-form textarea {
	width: 100%;
	min-height: 48px;
	padding: 12px 16px;
	border: 0;
	border-radius: 0;
	outline: 0;
	background: rgba(255, 255, 255, .82);
	color: #112953;
	font-size: 13px;
	font-weight: 600;
	line-height: 1.2
}

.hero-form textarea {
	min-height: 88px;
	resize: none
}

.hero-form input::placeholder,
.hero-form textarea::placeholder {
	color: #415789;
	opacity: 1
}

.hero-form button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	min-height: 48px;
	padding: 13px 30px;
	border-radius: 0;
	background: #415789;
	color: #fff;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 1px;
	line-height: 1;
	text-transform: uppercase;
	transition: background .3s ease
}

.hero-form button:hover {
	background: #112953
}

.hero-form button svg {
	transition: transform .3s ease
}

.hero-form button:hover svg {
	transform: translate(3px, -3px)
}

.hero-pagination {
	position: absolute;
	right: 34px;
	bottom: 31px;
	z-index: 5;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 14px;
	width: auto !important
}

@media(max-width:1500px) {
	.site-header__inner {
		gap: 18px;
		padding: 0 34px
	}

	.desktop-nav>ul>li:not(:last-child)::after {
		margin: 0 14px
	}

	.desktop-nav a {
		font-size: 13px
	}

	.header-appointment {
		min-height: 50px;
		padding: 14px 26px;
		font-size: 12px
	}
}

@media(max-width:1199px) {
	.site-header__inner {
		min-height: 76px;
		padding: 0 22px
	}

	.site-logo img {
		width: 165px
	}

	.desktop-nav,
	.header-appointment {
		display: none
	}

	.menu-toggle {
		display: flex
	}
}

@media(max-width:991px) {
	.mobile-menu {
		width: min(600px, 54vw)
	}

	.heroSwiper {
		height: clamp(650px, 88vw, 800px)
	}

	.hero-slide {
		height: 100%;
		padding: 0
	}

	.hero-overlay {
		background: linear-gradient(90deg, rgba(65, 87, 137, .92) 0, rgba(65, 87, 137, .76) 100%)
	}

	.hero-slide .row {
		align-items: flex-start !important;
		padding-top: 48px
	}

	.hero-kicker {
		margin-bottom: 30px
	}

	.hero-form {
		max-width: 720px;
		margin: 0 auto
	}

	.hero-form-layer {
		position: absolute;
		inset: 0;
		z-index: 5;
		margin-top: 0;
		padding-bottom: 0;
		pointer-events: none
	}

	.hero-form-layer .container,
	.hero-form-layer .row {
		height: 100%
	}

	.hero-form-layer .row {
		align-items: flex-start !important;
		padding-top: 150px
	}

	.hero-copy {
		max-width: 680px;
		margin-top: 0
	}

	.hero-copy .banner-heading {
		font-size: clamp(35px, 6vw, 58px);
		line-height: 1.08
	}

	.hero-form input,
	.hero-form textarea {
		min-height: 46px
	}

	.hero-form textarea {
		min-height: 82px
	}

	.hero-form button {
		min-height: 48px
	}
}

@media(max-width:767px) {
	.mobile-menu {
		width: min(600px, 86vw)
	}
}

@media(max-width:575px) {
	.site-header__inner {
		min-height: 74px;
		padding: 0 18px
	}

	.site-logo img {
		width: 168px
	}

	.menu-toggle {
		width: 42px;
		height: 42px
	}

	.mobile-menu {
		width: min(600px, 88vw)
	}

	.mobile-menu__head {
		min-height: 148px;
		padding: 24px 36px
	}

	.mobile-logo img {
		width: 210px;
		max-width: 100%
	}

	.mobile-menu__close {
		width: 44px;
		height: 44px
	}

	.mobile-menu__close::after,
	.mobile-menu__close::before {
		width: 50px
	}

	.mobile-nav>li>a,
	.mobile-nav>li>button {
		padding: 12px 46px;
		font-size: clamp(14px, 12px, 28px)
	}

	.mobile-nav button::after {
		width: 11px;
		height: 11px;
		border-width: 2px
	}

	.mobile-nav ul a,
	.mobile-nav ul button {
		min-height: 54px;
		padding: 16px 54px;
		font-size: 13px
	}

	.mobile-nav ul ul a {
		min-height: 46px;
		padding: 13px 62px;
		font-size: 12px
	}

	.mobile-appointment {
		display: flex;
		margin-right: 36px;
		margin-left: 36px;
		padding-right: 18px;
		padding-left: 18px;
		font-size: 11px
	}

	.heroSwiper {
		height: 760px
	}

	.hero-slide {
		height: 100%;
		padding: 0
	}

	.hero-img {
		object-position: center
	}

	.hero-kicker {
		padding: 8px 12px;
		font-size: 9px;
		letter-spacing: 1px;
		white-space: normal;
		text-align: center
	}

	.hero-copy h1 {
		font-size: 30px;
		line-height: 1.08
	}

	.hero-copy h1 span {
		font-size: 22px;
		line-height: 1.2
	}

	.hero-appointment {
		min-height: 40px;
		padding: 11px 20px;
		font-size: 13px
	}

	.hero-form input,
	.hero-form textarea {
		min-height: 40px;
		padding: 9px 14px;
		font-size: 12px
	}

	.hero-form textarea {
		min-height: 66px
	}

	.hero-form button {
		min-height: 42px;
		padding: 10px 20px;
		font-size: 12px
	}

	.hero-form-layer {
		top: 0;
		bottom: auto;
		height: auto;
		margin-top: 0;
		padding-bottom: 0;
		transform: translateY(385px)
	}

	.hero-slide .row {
		align-items: flex-start !important;
		padding-top: 42px
	}

	.hero-form-layer .row {
		align-items: flex-start !important;
		height: auto;
		padding-top: 0
	}

	.hero-copy {
		margin-top: 0
	}

	.hero-form {
		margin-top: 0
	}

	.hero-pagination {
		right: 22px;
		bottom: 24px
	}
}

.title {
	margin: 0;
	font-size: 35px;
	font-family: Roboto
}

.heading-one {
	font-size: 150px;
	line-height: 160px;
	font-weight: 700;
	font-family: Roboto;
	color: #00000052;
	margin-top: 0;
	margin-bottom: 20px;
	padding-top: 0;
	padding-bottom: 0;
	letter-spacing: normal;
	text-transform: uppercase;
	text-align: center;
	display: block
}

.but-style {
	background: #415789;
	color: #fff;
	padding: 15px 30px;
	border-radius: 30px;
	margin-top: 15px;
	display: inline-block;
	transition: all .3s ease-in-out;
	text-decoration: none
}

.but-style svg {
	transition: transform .3s ease-in-out
}

.but-style:hover svg {
	transform: translate(3px, -3px)
}

.but-style:hover {
	color: #fff;
	background: #364974
}

.service-card {
	position: relative;
	border-radius: 20px;
	overflow: hidden;
	height: 550px;
	border: 0;
	box-shadow: 0 4px 15px rgba(0, 0, 0, .1);
	transition: transform .3s ease
}

.service-card:hover {
	transform: translateY(-5px)
}

.service-card .bg-img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 1
}

.service-card .overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgb(0 0 0 / 39%);
	z-index: 2
}

.service-card .card-content {
	position: relative;
	z-index: 3;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	text-align: center;
	padding: 2rem;
	color: #fff
}

.service-card p {
	line-height: 1.6;
	color: #fff
}

.service-slider-section {
	background: #fff;
	overflow: hidden
}

.service-slider-shell {
	margin-left: max(16px, calc((100vw - 1320px)/ 2))
}

.swiper-container-wrapper {
	position: relative;
	overflow: visible
}

.mySwiper {
	overflow: visible;
	padding-right: 0
}

.custom-nav-wrapper {
	display: flex;
	justify-content: space-between;
	gap: 10px;
	margin: 0 clamp(16px, 20vw, 410px) 76px 0;
	align-items: center
}

.nav-icons {
	display: inline-flex;
	gap: 25px
}

.custom-next,
.custom-prev {
	width: 50px;
	height: 50px;
	border: 1px solid #112953;
	background: #fff;
	color: #112953;
	border-radius: 4px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: all .3s ease
}

.custom-next svg,
.custom-prev svg {
	width: 19px;
	height: 19px
}

.custom-next:hover,
.custom-prev:hover {
	background: #112953;
	color: #fff
}

.slider-card {
	position: relative;
	height: 586px;
	border-radius: 30px;
	overflow: hidden;
	background: #dfe6ef
}

.slider-card::after {
	content: "";
	position: absolute;
	bottom: 0;
	right: 0;
	width: 172px;
	height: 172px;
	background: #fff;
	z-index: 4;
	clip-path: path("M172 0 L172 172 L0 172 C37 171 58 155 70 125 C82 94 91 78 119 70 C151 62 170 40 172 0 Z");
	pointer-events: none
}

.slider-card::before {
	display: none
}

.slider-card .bg-img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 1
}

.slider-card .overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(24, 34, 67, .92) 0, rgba(48, 58, 92, .68) 30%, rgba(48, 58, 92, .08) 66%);
	z-index: 2
}

.slider-card .card-content {
	position: relative;
	z-index: 3;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 0 25px 75px;
	color: #fff
}

.slider-card span {
	display: block;
	margin-bottom: 8px;
	color: rgba(255, 255, 255, .72);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 1.1px;
	line-height: 1.2;
	text-transform: uppercase
}

.slider-card h4 {
	color: #fff;
	font-size: clamp(24px, 1.75vw, 25px);
	font-weight: 600;
	line-height: 35px;
	margin: 0;
	max-width: 410px;
	padding-right: 50px
}

.card-btn {
	position: absolute;
	bottom: 22px;
	right: 16px;
	width: 57px;
	height: 57px;
	border: 1px solid #112953;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #112953;
	background: #fff;
	z-index: 6;
	text-decoration: none;
	transition: all .3s ease
}

.card-btn svg {
	width: 21px;
	height: 21px
}

.slider-card:hover .card-btn {
	background: #112953;
	color: #fff;
	border-color: #112953
}

.card-btn svg path {
	stroke: #112953
}

.slider-card:hover .card-btn svg path {
	stroke: #fff
}

@media(max-width:1199px) {
	.custom-nav-wrapper {
		margin-bottom: 42px
	}

	.slider-card {
		height: 520px
	}
}

@media(max-width:767px) {
	.service-slider-shell {
		margin-left: 16px;
		margin-right: 16px
	}

	.custom-nav-wrapper {
		justify-content: space-between;
		margin: 0 16px 28px 0
	}

	.custom-next,
	.custom-prev {
		width: 48px;
		height: 48px
	}

	.slider-card {
		height: 460px;
		border-radius: 24px
	}

	.slider-card .card-content {
		padding: 0 26px 62px
	}

	.slider-card h4 {
		font-size: 24px;
		padding-right: 42px
	}

	.slider-card::after {
		width: 146px;
		height: 146px;
		clip-path: path("M146 0 L146 146 L0 146 C31 145 49 132 59 106 C70 80 77 66 101 59 C128 52 144 34 146 0 Z")
	}

	.card-btn {
		width: 50px;
		height: 50px;
		bottom: 22px;
		right: 22px
	}
}

.testimonial-section {
	background: #fff
}

.testimonial-box {
	position: relative;
	border-radius: 42px;
	overflow: hidden;
	background: radial-gradient(circle at 2px 2px, rgba(255, 255, 255, .07) 1px, transparent 1.4px) 0 0/22px 22px, linear-gradient(135deg, #43588d 0, #3e5182 100%)
}

.testimonial-box>.row {
	position: relative;
	z-index: 2;
	min-height: 645px
}

.testimonial-box::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: 0;
	width: 214px;
	height: 92px;
	background: #edf8ff;
	border-top-left-radius: 44px;
	z-index: 1
}

.testimonial-review-col,
.testimonial-static-col {
	position: relative;
	z-index: 2
}

.testimonial-static-col {
	display: flex
}

.testimonial-image {
	width: 100%;
	min-height: 645px;
	border-radius: 30px;
	overflow: hidden
}

.testimonial-image img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
	object-position: center
}

.testimonial-review-col {
	display: flex;
	align-items: center
}

.testimonial-content {
	width: 100%;
	color: #fff;
	padding: 0 25px
}

.testimonial-content h4 {
	margin: 0 0 70px;
	color: #fff;
	font-size: clamp(34px, 2.8vw, 46px);
	font-weight: 600;
	line-height: 1.15
}

.testimonialSwiper {
	width: 100%;
	overflow: hidden
}

.testimonialSwiper .swiper-wrapper {
	display: flex;
	align-items: stretch
}

.testimonialSwiper .swiper-slide {
	flex: 0 0 100%;
	min-width: 100%;
	height: auto
}

.testimonial-review {
	position: relative;
	padding-left: 130px
}

.quote-mark {
	position: absolute;
	top: 2px;
	left: 0;
	color: rgba(255, 255, 255, .18);
	font-family: Georgia, serif;
	font-size: 205px;
	font-weight: 700;
	line-height: .66
}

.stars {
	margin-bottom: 30px;
	color: #ffbf00;
	font-size: 24px;
	letter-spacing: 4px;
	line-height: 1
}

.testimonial-review p {
	margin: 0 0 46px;
	color: rgba(255, 255, 255, .92);
	font-family: Sora, sans-serif;
	font-weight: 400;
	line-height: 1.5;
	font-size: 16px
}

.review-author {
	color: #fff;
	font-size: 22px;
	font-weight: 600;
	line-height: 1.2
}

.review-role {
	margin-top: 8px;
	color: rgba(255, 255, 255, .48);
	font-size: 15px;
	font-weight: 600;
	letter-spacing: .8px;
	line-height: 1.2;
	text-transform: uppercase
}

.testimonial-pagination {
	position: absolute;
	right: 58px;
	bottom: 36px;
	z-index: 3;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 14px;
	width: auto
}

.testimonial-pagination .swiper-pagination-bullet {
	width: 13px;
	height: 13px;
	margin: 0 !important;
	background: #415789;
	opacity: 1
}

.testimonial-pagination .swiper-pagination-bullet-active {
	width: 20px;
	height: 20px;
	border: 1px solid #415789;
	background: #3f5283;
	box-shadow: inset 0 0 0 4px #edf8ff
}

.testimonial-pagination.swiper-pagination-clickable.swiper-pagination-bullets.swiper-pagination-horizontal {
	justify-content: right;
	bottom: 25px;
	padding-right: 50px
}

@media(max-width:1199px) {
	.testimonial-box {
		padding: 42px 0 0 42px
	}

	.testimonial-box>.row {
		min-height: 560px
	}

	.testimonial-image {
		min-height: 560px
	}

	.testimonial-review {
		padding-left: 100px
	}

	.quote-mark {
		font-size: 160px
	}

	.testimonial-review p {
		font-size: 18px
	}
}

@media(max-width:991px) {
	.testimonial-box {
		padding: 28px 28px 92px;
		border-radius: 34px
	}

	.testimonial-box>.row {
		min-height: 0
	}

	.testimonial-image {
		min-height: 0;
		height: clamp(320px, 58vw, 500px);
		border-radius: 28px
	}

	.testimonial-content {
		max-width: none;
		padding: 42px 8px 0
	}

	.testimonial-content h4 {
		margin-bottom: 34px
	}

	.testimonial-review p {
		max-width: none
	}
}

@media(max-width:767px) {
	.testimonial-box {
		padding: 14px 14px 74px;
		border-radius: 24px
	}

	.testimonial-box::after {
		width: 132px;
		height: 86px;
		border-top-left-radius: 34px
	}

	.testimonial-image {
		height: clamp(240px, 78vw, 330px);
		border-radius: 20px
	}

	.testimonial-content h4 {
		margin-bottom: 22px;
		font-size: 30px
	}

	.testimonial-review {
		padding-left: 0
	}

	.quote-mark {
		position: static;
		display: block;
		height: 54px;
		margin-bottom: 4px;
		font-size: 92px;
		line-height: .72
	}

	.stars {
		margin-bottom: 18px;
		font-size: 19px;
		letter-spacing: 2px
	}

	.testimonial-review p {
		margin-bottom: 26px;
		font-size: 17px;
		line-height: 1.58
	}

	.review-author {
		font-size: 18px
	}

	.review-role {
		font-size: 12px
	}

	.testimonial-pagination {
		right: 20px;
		bottom: 22px;
		gap: 11px
	}
}

.expert-care-section {
	background: #fff
}

.expert-care-item {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 30px;
	min-height: 158px;
	padding: 34px 0;
	border-top: 1px solid rgba(65, 87, 137, .65);
	border-bottom: 1px solid rgba(65, 87, 137, .65);
	color: #415789;
	text-decoration: none;
	isolation: isolate
}

.expert-care-item:hover {
	color: #415789
}

.expert-info {
	position: relative;
	z-index: 2;
	display: flex;
	align-items: baseline;
	gap: 16px;
	min-width: 0
}

.expert-name {
	color: #415789;
	font-size: 50px;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1
}

.expert-role {
	color: #000;
	font-size: clamp(13px, 1vw, 16px);
	font-weight: 600;
	letter-spacing: 2px;
	line-height: 1.25;
	text-transform: uppercase;
	white-space: nowrap
}

.expert-btn {
	position: relative;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	flex: 0 0 auto;
	min-width: 188px;
	min-height: 62px;
	padding: 16px 28px;
	border: 1px solid #112953;
	border-radius: 999px;
	color: #112953;
	background: #fff;
	font-size: 15px;
	font-weight: 600;
	letter-spacing: 2px;
	line-height: 1;
	text-transform: uppercase;
	transition: background .3s ease, color .3s ease, transform .3s ease
}

.expert-btn svg {
	transition: transform .3s ease
}

.expert-care-item:hover .expert-btn {
	background: #112953;
	color: #fff
}

.expert-care-item:hover .expert-btn svg {
	transform: translate(3px, -3px)
}

.expert-hover-image {
	position: absolute;
	top: 50%;
	left: 52%;
	z-index: 5;
	width: min(28vw, 360px);
	aspect-ratio: 4/5;
	border-radius: 22px;
	overflow: hidden;
	opacity: 0;
	pointer-events: none;
	transform: translate(-50%, -50%) scale(.92) rotate(-2deg);
	transition: opacity .35s ease, transform .35s ease;
	box-shadow: 0 24px 60px rgba(17, 41, 83, .22)
}

.expert-hover-image img,
.expert-mobile-image img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
	object-position: top center
}

.expert-care-item:hover .expert-hover-image {
	opacity: 1;
	transform: translate(-50%, -50%) scale(1) rotate(0)
}

.expert-mobile-image {
	display: none
}

@media(max-width:1199px) {
	.expert-care-item {
		min-height: 138px
	}

	.expert-info {
		flex-direction: column;
		align-items: flex-start;
		gap: 8px
	}

	.expert-role {
		white-space: normal
	}

	.expert-hover-image {
		left: 58%;
		width: min(34vw, 300px)
	}
}

@media(max-width:767px) {
	.expert-care-item {
		flex-direction: column;
		align-items: stretch;
		gap: 18px;
		min-height: 0;
		padding: 22px 0
	}

	.expert-hover-image {
		display: none
	}

	.expert-mobile-image {
		display: block;
		width: 100%;
		aspect-ratio: 1/.78;
		border-radius: 20px;
		overflow: hidden
	}

	.expert-name {
		font-size: clamp(36px, 10vw, 54px)
	}

	.expert-role {
		font-size: 12px;
		letter-spacing: 1.4px
	}

	.expert-btn {
		width: fit-content;
		min-width: 154px;
		min-height: 52px;
		padding: 14px 22px;
		font-size: 13px;
		letter-spacing: 1.5px
	}
}

.insuranceSwiper {
	overflow: hidden;
	padding: 8px 0 18px
}

.insuranceSwiper .swiper-wrapper {
	align-items: center;
	transition-timing-function: linear !important
}

.insuranceSwiper .swiper-slide {
	height: auto;
	display: flex;
	align-items: center;
	justify-content: center
}

.insurance-logo {
	width: 100%;
	min-height: 120px;
	display: flex;
	align-items: center;
	justify-content: center
}

.insurance-logo img {
	max-width: 230px;
	max-height: 92px;
	width: auto;
	height: auto;
	display: block;
	object-fit: contain;
	filter: saturate(.95)
}

@media(max-width:991px) {
	.insurance-logo {
		min-height: 96px
	}

	.insurance-logo img {
		max-width: 190px;
		max-height: 76px
	}

	.title {
		font-size: 25px
	}

	.heading-one {
		font-size: 50px;
		line-height: 50px
	}

	.service-card {
		height: 400px
	}
}

@media(max-width:575px) {
	.insuranceSwiper {
		padding-top: 0
	}

	.insurance-logo {
		min-height: 84px
	}

	.insurance-logo img {
		max-width: 145px;
		max-height: 62px
	}
}

.site-footer {
	background: #fff;
	color: #092452;
	padding: 64px 0 38px
}

.footer-shell {
	display: grid;
	grid-template-columns: minmax(260px, 460px) minmax(0, 1fr);
	gap: clamp(48px, 8vw, 150px);
	width: min(100% - 80px, 1840px);
	margin: 0 auto
}

.footer-brand {
	padding-top: 10px
}

.footer-logo {
	display: inline-flex;
	align-items: center;
	margin-bottom: 26px
}

.footer-logo img {
	display: block;
	width: min(390px, 100%);
	height: auto
}

.footer-brand p {
	max-width: 430px;
	margin: 0 0 30px;
	color: #092452;
	font-family: Sora, sans-serif;
	font-size: 17px;
	font-weight: 600;
	line-height: 1.7
}

.footer-social {
	display: flex;
	align-items: center;
	gap: 16px
}

.footer-social a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border: 1px solid #092452;
	border-radius: 50%;
	color: #092452;
	text-decoration: none;
	transition: background .25s ease, color .25s ease, transform .25s ease
}

.footer-social a:hover {
	background: #092452;
	color: #fff;
	transform: translateY(-2px)
}

.footer-social svg {
	width: 22px;
	height: 22px;
	fill: currentColor
}

.footer-main h2 {
	margin: 0 0 60px;
	color: #092452;
	font-size: clamp(32px, 2.5vw, 30px);
	font-weight: 600;
	line-height: 1.22
}

.footer-columns {
	display: grid;
	grid-template-columns: minmax(160px, 1fr) minmax(220px, 1fr) minmax(290px, 1.1fr);
	gap: clamp(34px, 5vw, 82px);
	align-items: start
}

.footer-col h3 {
	margin: 0 0 28px;
	color: #2f65ce;
	font-size: 21px;
	font-weight: 600;
	line-height: 1.2
}

.footer-col ul {
	display: grid;
	gap: 17px;
	margin: 0;
	padding: 0;
	list-style: none
}

.footer-col a,
.footer-col p {
	margin: 0 0 16px;
	color: #000;
	font-family: Sora, sans-serif;
	font-size: 16px;
	font-weight: 600;
	line-height: 1.7;
	text-decoration: none
}

.footer-col a:hover {
	color: #092452
}

.footer-address p {
	max-width: 390px;
	color: #314676
}

.footer-address iframe {
	display: block;
	width: 100%;
	max-width: 360px;
	height: 104px;
	margin-top: 32px;
	border: 0
}

.footer-bottom {
	display: flex;
	justify-content: flex-end;
	margin-top: 40px;
	padding-top: 38px;
	border-top: 1px solid #cbd2df;
	color: #000;
	font-size: 16px;
	font-weight: 600
}

@media(max-width:1199px) {
	.footer-shell {
		grid-template-columns: 1fr;
		gap: 42px;
		width: min(100% - 48px, 960px)
	}

	.footer-brand {
		display: grid;
		grid-template-columns: minmax(220px, 320px) minmax(0, 1fr);
		gap: 30px 42px;
		align-items: center;
		padding-top: 0
	}

	.footer-logo {
		margin-bottom: 0
	}

	.footer-brand p {
		margin-bottom: 0
	}

	.footer-social {
		grid-column: 1/-1
	}

	.footer-main h2 {
		margin-bottom: 40px
	}
}

@media(max-width:991px) {
	.site-footer {
		padding-top: 52px
	}

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

	.footer-address {
		grid-column: 1/-1
	}

	.footer-address iframe {
		max-width: 100%;
		height: 180px
	}
}

@media(max-width:575px) {
	.site-footer {
		padding: 42px 0 28px
	}

	.footer-shell {
		width: min(100% - 32px, 540px);
		gap: 34px
	}

	.footer-brand {
		display: block
	}

	.footer-logo {
		margin-bottom: 22px
	}

	.footer-logo img {
		width: min(285px, 100%)
	}

	.footer-brand p {
		margin-bottom: 24px;
		font-size: 15px;
		line-height: 1.65
	}

	.footer-social a {
		width: 48px;
		height: 48px
	}

	.footer-main h2 {
		margin-bottom: 32px;
		font-size: 27px
	}

	.footer-columns {
		grid-template-columns: 1fr;
		gap: 30px
	}

	.footer-col h3 {
		margin-bottom: 16px;
		font-size: 19px
	}

	.footer-col ul {
		gap: 11px
	}

	.footer-col a,
	.footer-col p {
		margin-bottom: 10px;
		font-size: 14px
	}

	.footer-address iframe {
		height: 168px;
		margin-top: 22px
	}

	.footer-bottom {
		justify-content: flex-start;
		margin-top: 30px;
		padding-top: 24px;
		font-size: 14px
	}
}


.sticky-contact-buttons {
	position: fixed;
	right: 25px;
	bottom: 25px;
	z-index: 9999;
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.sticky-btn {
	width: 200px;
	height: 39px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 14px;
	color: #fff;
	font-size: 16px;
	font-weight: 600;
	text-decoration: none;
	border-radius: 7px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
}

.sticky-btn:hover {
	color: #fff;
	text-decoration: none;
}

.call-btn {
	background: #1473f9;
}

.whatsapp-btn {
	background: #2eaaa0;
}

.sticky-btn svg {
	flex-shrink: 0;
}

/* Mobile */
@media (max-width: 767px) {
	.sticky-contact-buttons {
		left: 0;
		right: 0;
		bottom: 0;
		flex-direction: row;
		gap: 0;
	}

	.sticky-btn {
		width: 50%;
		height: 54px;
		border-radius: 0;
		font-size: 18px;
		gap: 8px;
	}

	.sticky-btn svg {
		width: 21px;
		height: 21px;
	}
}