/** GLOBAL CSS **/
.ry-section-headline h2 {
    font-size: clamp(2.5rem, 2.1814rem + 1.3072vw, 3.75rem);
    letter-spacing: -1px;
    line-height: 1.1;
    color: #252525;
    font-weight: 400;
    font-family: "";
}
.ry-section-headline h2 .span-1 {
    color: #4e5368
}
.ry-section-headline {
    position: relative;
    padding-bottom: 1.5vw;
}
.ry-section-headline:before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 320px;
    height: 3px;
    background-color: #86c6de;
}
.ry-background-section, .ry-background-section img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    object-fit: cover;
}
.ry-btn.ry-btn-transparent {
    border-radius: 8px;
    background-color: transparent;
    border: 2px solid #85c5dd;
    padding: 17px 25px;
    font-size: 18px !important;
    text-transform: uppercase;
    color: #000;
    font-weight: 600;
    text-align: center;
}
.ry-btn.ry-btn-transparent:hover {
    background-color: #85c5dd;
    border: 2px solid #85c5dd;
}
.ry-btn-wrap {
    display: flex;
    justify-content: center;
    margin-top: 1.5vw
}
.ry-section-background, .ry-section-background img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: -1;
}
.ry-padding-section {
	padding: 6vw 0;
}
.ry-each-link, .ry-each-link a {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	z-index: 999;
}
/** HEADER **/
div#navigation.fixed {
    background: #fff;
}
body[data-page-name="index"] div#navigation.bg-transparent {
    background: transparent;
}
.ry-menu .ry-nav li a {
    text-transform: uppercase;
}
.ry-menu .dropdown-menu.hover a {
    padding: 12px 20px;
    display: inline-block;
    width: 100%;
}

.homepage-swiper .ry-btn.ry-btn-transparent {
    color: #fff;
}

/** HP WELCOME **/
.ry-hp-welcome-section {
    padding: 6vw 0;
    position: relative;
    min-height: 892px;
}
.ry-hp-welcome-section .ry-flex {
    justify-content: space-between;
    align-items: center;
    gap: 4em;
}
.ry-hp-welcome-section .ry-flex .ry-each {
    width: 100%;
    max-width: 640px;
}
.ry-welcome-image-wrap {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
	max-width: 50%;
    /*max-width: 855px;*/
    min-height: 892px;
    z-index: 1;
}
.ry-welcome-image-wrap img {
    width: 100%;
    object-fit: cover;
}
.ry-hp-welcome-section .ry-btn.ry-btn-transparent {
    color: #000
}
.ry-hp-welcome-section .ry-content {
    height: 100%;
    min-height: 600px;
    display: flex;
}
.ry-hp-welcome-section .ry-btn-wrap {
    justify-content: flex-start;
}
.ry-hp-welcome-section .ry-flex .ry-each:not(.hidden) {
    display: flex;
    flex-direction: column;
    gap: 1.5vw;
}
/** END HP WELCOME **/

/** HP SERVICES **/
.ry-hp-services {
    padding: 12vw 0;
}
.ry-hp-services .ry-section-headline:before {
    left: 50%;
    transform: translateX(-50%)
}
.ry-hp-services .services-swiper .ry-services-icon, 
.ry-hp-services .services-swiper .ry-services-icon img {
    max-width: max-content;
}
.ry-hp-services .services-swiper .ry-services-icon {
    margin-bottom: 1.5vw;
}
.ry-hp-services .ry-services-info .ry-services-title {
    font-size: clamp(1.5rem, 1.4044rem + 0.3922vw, 1.875rem);
    color: #65718b;
    font-weight: 400;
    font-family: "";
    margin-bottom: 1.5vw;
}
.ry-hp-services .swiper-slide {
    min-height: 599px;
    padding: 3em !important;
	position: relative;
	top: 0;
	transition: all ease 0.3s;
}
.ry-hp-services .swiper-slide:hover {
    top: -2em;
}
.ry-hp-services .services-swiper {
    padding: 2.5em 0;
}
.ry-hp-services .swiper-slide:nth-child(odd) {
    border-radius: 20px;
    background: #e3ebf0;
}
.ry-hp-services .swiper-slide:nth-child(even) {
    border-radius: 20px;
    background: #65718b;
}
.ry-hp-services .swiper-slide:nth-child(even) .ry-services-title,
.ry-hp-services .swiper-slide:nth-child(even) p {
    color: #fff;
}
.ry-hp-services .swiper-slide:nth-child(even) .ry-services-icon img {
    filter: brightness(0) invert(100%)
}
.ry-hp-services .swiper-slide .ry-arrow-wrap {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
}
.ry-hp-services .swiper-slide:nth-child(odd) .ry-arrow-wrap {
    background-color: #65718b;
}
.ry-hp-services .swiper-slide:nth-child(even) .ry-arrow-wrap {
    background-color: #fff;
}
.ry-hp-services .swiper-slide:nth-child(odd) .ry-arrow-wrap svg {
    fill: #fff;
}
.ry-hp-services .ry-services-content p {
    font-size: 16px;
    line-height: 1.6;
    color: #65718b;
    font-weight: 400;
    font-family: "Montserrat";
}
.ry-hp-services .swiper-slide > div {
    justify-content: space-between;
    min-height: 503px;
}

.ry-hp-services .services-swiper {
	width: 100%;
	padding-bottom: 40px; /* give space for scrollbar */
}
.ry-hp-services .services-swiper .swiper-scrollbar {
	position: relative;
	background: #e3ebef;
	height: 4px !important;
	border-radius: 8px;
	overflow: visible;  
	margin-top: 3.5vw;
}
.ry-hp-services .services-swiper .swiper-scrollbar-drag {
	background: #4e5368;
	border-radius: 8px;
	height: 16px;     
	top: -6px;
	transform-origin: center;
	cursor: pointer;
}
.ry-hp-services .services-swiper .swiper-scrollbar-drag:hover {
	background: #85c5dd;
}
.ry-hp-services .ry-btn-wrap {
    margin-top: 0;
}
/** END HP SERVICES **/

/** HP TEAM **/
.ry-hp-team-section {
    padding: 6vw 0;
    position: relative;
    min-height: 892px;
}
.ry-hp-team-section .ry-flex {
	justify-content: flex-end;
	align-items: center;
	gap: 4em;
	width: 100%;
}
.ry-hp-team-section .ry-flex .ry-each {
    width: 100%;
    max-width: 640px;
}
.ry-team-image-wrap {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    max-width: 855px;
    min-height: 892px;
    z-index: 1;
}
.ry-hp-team-section .ry-btn.ry-btn-transparent {
    color: #000
}
.ry-hp-team-section .ry-content {
    height: 100%;
    min-height: 600px;
    display: flex;
}
.ry-hp-team-section .ry-btn-wrap {
    justify-content: flex-start;
}
.ry-hp-team-section .ry-flex .ry-each:not(.hidden) {
    display: flex;
    flex-direction: column;
    gap: 1.5vw;
}
/** END HP WELCOME **/

/** HP TESTIMONIAL **/
.ry-hp-testimonial {
    background: #dceff6;
}
.ry-hp-testimonial .ry-section-headline {
    margin-bottom: 4vw;
}
.ry-hp-testimonial .testimonials-swiper .swiper-slide {
    padding: 4em;
    gap: 2em;
    border-radius: 20px;
}
.ry-hp-testimonial .testimonials-swiper .swiper-slide .ry-quote-wrap img {
    max-width: 61px;
    width: 100%;
}
/*.ry-hp-testimonial .testimonials-swiper .swiper-slide:nth-child(odd) {
    background: #fff;
}
.ry-hp-testimonial .testimonials-swiper .swiper-slide:nth-child(even) {
    background: #65718b;
}
.ry-hp-testimonial .testimonials-swiper .swiper-slide:nth-child(even) * {
    color: #fff
}*/
.ry-hp-testimonial .testimonials-swiper .swiper-slide-active {
    background: #65718b
}
.ry-hp-testimonial .testimonials-swiper .swiper-slide-active * {
    color: #fff;
}
.ry-hp-testimonial .testimonials-swiper .swiper-slide:not(.swiper-slide-active) {
    background: #fff;
}
.ry-hp-testimonial .testimonials-swiper .swiper-slide:not(.swiper-slide-active) * {
    color: #65718b;
}
.ry-hp-testimonial .testimonials-swiper .swiper-slide:not(.swiper-slide-active) .ry-g-icon img {
    filter: brightness(60%);
}
.ry-hp-testimonial .testimonials-swiper .swiper-slide svg {
    width: 18px;
}
/*.ry-hp-testimonial .testimonials-swiper .swiper-slide:nth-child(odd) .ry-g-icon img {
    filter: brightness(0.5);
}*/
.ry-hp-testimonial .ry-section-headline:before {
    top: 50%;
    right: 0;
    left: unset;
    width: 100%;
    max-width: 32%;
}
.ry-hp-testimonial .ry-section-headline {
    padding-bottom: 0;
}
@media (min-width: 1081px) {
	.ry-hp-testimonial .testimonials-swiper .swiper-slide {
		max-width: 800px;
		width: 100%;
	}
}
/** END HP TESTIMONIAL **/

/** HP APPOINTMENT **/
.ry-hp-appointment .ry-btn.ry-btn-transparent {
    color: #fff
}
.ry-hp-appointment select {
    color: #9faccb;
}
.ry-hp-appointment textarea {
    height: 154px;
}

/** FOOTER **/
div#footer-each-wrap {
    display: flex;
    gap: 4em;
    justify-content: center;
    padding-bottom: 2vw;
}
.ry-container-1280 {
    max-width: 1280px;
    width: 90%;
    margin: 0 auto;
    float: none;
}
div#footer-each-wrap div#footer-info-each {
    width: 400px;
}
.ry-social-lines:before {
	content: "";
	display: block;
	left: -11vw;
	top: 50%;
	position: absolute;
	opacity: 0.302;
	width: 190px;
	height: 1px;
	background-color: #72cdce;
}
.ry-social-lines:after {
	content: "";
	display: block;
	right: -11vw;
	top: 50%;
	position: absolute;
	opacity: 0.302;
	width: 190px;
	height: 1px;
	background-color: #72cdce;
}
.ry-footer-title h4 {
    font-size: clamp(1.5rem, 1.3088rem + 0.7843vw, 2.25rem);
    color: #b9d5e5;
    font-weight: 400;
    font-family: "Lora";
}
div#footer-each-wrap div#footer-info-each ul li p {
    font-size: 14px;
    line-height: 1.4;
}
div#footer-each-wrap a.phone .span-1 {
    font-size: 16px;
}

/** HP RESPONSIVENESS **/
@media (max-width: 1440px) {
	.ry-welcome-image-wrap, .ry-hp-team-section > div.ry-team-image-wrap {
		max-width: 600px;
	}
	.ry-hp-services {
		padding: 8vw 0;
	}
}
@media (max-width: 1366px) {
	.ry-hp-welcome-section {
		min-height: auto;
	}
	.ry-welcome-image-wrap, 
	.ry-hp-team-section > div.ry-team-image-wrap {
		max-width: 100%;
		width: 35%;
	}
}
@media (max-width: 1080px) {
	div#navigation-style-4 {
        display: none;
    }
    .snap-mobile-menu {
        display: flex;
    }
	.ry-section-headline h2 {
		text-align: center;
	}
	.ry-section-headline:before {
		left: 50%;
		transform: translateX(-50%);
	}
	.ry-text p {
		text-align: center;
	}
	.homepage-swiper, .homepage-swiper .swiper-slide img {
		height: auto !important;
	}
	.slider-info {
		position: relative;
		background: #4e5368;
		width: 100%;
		transform: unset !important;
		left: 0;
		bottom: unset !important;
		z-index: 99;
		min-height: unset !important;
		opacity: 1;
	}
	.ry-hp-welcome-section .ry-flex {
		flex-direction: column;
		justify-content: center;
		margin: 0 auto;
		float: none;
	}
	.ry-hp-welcome-section .ry-flex .ry-each {
		position: relative;
		min-height: auto;
	}
	.ry-welcome-image-wrap, .ry-hp-team-section > div.ry-team-image-wrap {
		display: none;
	}
	.ry-hp-welcome-section {
		padding-top: 10vw;
	}
	.ry-hp-welcome-section .ry-flex .ry-welcome-image-wrap.ry-each.hidden,
	.ry-hp-team-section .ry-flex .ry-each.hidden.ry-team-image-wrap {
		display: block;
	}
	.ry-hp-team-section .ry-flex .ry-each.hidden.ry-team-image-wrap {
		position: relative;
		min-height: auto;
	}
	.ry-hp-welcome-section .ry-btn-wrap, .ry-btn-wrap {
		justify-content: center !important;
	}
	.ry-hp-team-section .ry-flex {
		justify-content: center;
		flex-direction: column;
	}
	.ry-hp-testimonial .ry-section-headline:before {
		display: none;
	}
	.testimonials-swiper {
		padding: 0 2em;
	}
	.ry-quote-wrap img {
		margin: 0 auto;
	}
	.ry-hp-testimonial .testimonials-swiper .swiper-slide p {
		text-align: center;
	}
	.ry-hp-testimonial .testimonials-swiper .swiper-slide .flex-col {
		flex-direction: column;
	}
	.ry-testi-name .flex {
		justify-content: center;
	}
	.ry-hp-testimonial .testimonials-swiper .swiper-slide .flex.items-center {
		justify-content: center;
	}
	.ry-hp-appointment .flex {
		flex-direction: column;
	}
}
@media (max-width: 768px) {
	.ry-hp-services .swiper-slide, .ry-hp-services .swiper-slide > div {
		min-height: 100%;
	}
	.ry-hp-services .ry-info-blocks {
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
	}
	.ry-hp-services .ry-info-blocks .ry-services-info * {
		text-align: center;
	}
	.ry-hp-services .swiper-slide .ry-arrow-wrap {
		margin: 0 auto;
	}
	div#footer-each-wrap {
		flex-direction: column;
		align-items: center;
	}
	.ry-social-lines:before, .ry-social-lines:after {
		display: none;
	}
	.testimonials-swiper {
		padding: 0 2em;
	}
	.ry-quote-wrap img {
		margin: 0 auto;
	}
	.ry-hp-testimonial .testimonials-swiper .swiper-slide p {
		text-align: center;
	}
	.ry-hp-testimonial .testimonials-swiper .swiper-slide .flex-col {
		flex-direction: column;
	}
	.ry-testi-name .flex {
		justify-content: center;
	}
	.ry-hp-testimonial .testimonials-swiper .swiper-slide .flex.items-center {
		justify-content: center;
	}
}
@media (max-width: 500px) {
	.ry-section-headline:before {
		display: none;
	}
	.ry-hp-welcome-section .ry-flex .ry-each:not(.hidden),
	.ry-hp-team-section .ry-flex .ry-each:not(.hidden) {
		gap: 6vw;
	}
}
.ry-team-image-wrap { max-width: 50%;}
.ry-hp-welcome-section {z-index: 2;}