/* Before adding any unnecessary CSS rules, please check out the Snap documentation at https://bit.ly/3PqSii8. */
/* Override Styles */
/*
.service-style-1 h2 {margin: 10px 0;}
.ry-menu .ry-nav li .dropdown-toggle {padding: 30px 0;}
ul#quick-links li a {display: block;width: 100%;}
#in-services-3 ul li a {margin-left: 0px;margin-top:30px}
*/
[x-cloak] { display: none !important; }
.promotions img { min-width: 22rem; max-width:22rem;}
#in-services-style-2.squares .ry-each:before, #in-services-style-2.squares .ry-each img {border-radius: 0;}
.mobile-menu-icon a{display: flex;height: 100%;width: 100%;justify-content: center;align-items: center;}
body.fancybox-active .ry-sticky-menu.fixed {z-index: 9999;}
.testimonials-swiper p,
.testimonials-swiper-2 p{
overflow: hidden;
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 4
}
.service-hover {
    position: absolute;
    z-index: 9;
    opacity: 0;
    transition: opacity 0.3s ease;
    text-align: center;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    color: white;
}

/* Show service-hover when parent with data-target is hovered */
[data-target]:hover .service-hover {
    opacity: 1;
}

/* Apply the overlay effect when parent is hovered */
[data-target]:hover .service-hover::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    z-index: -1; /* Make sure it's behind the text */
}
.mm-navbar {
	color: #ffffff;
}

/* HP Edits - Started <November 13, 2025> */

/**/
	/*fonts*/

	/*btns*/

/*Modal*/
/* Header */
	/**/
body[data-page-name="index"] #navigation {
    position: absolute;
}

.header-social-btn-fill div.col-xs-12:nth-child(odd) .cta-icon {
    background-color: var(--color-primary-background);
}
mm-burger {
    color: #374151;
}
.snap-mobile-menu {
    background-color: var(--color-primary-text);
}
.ry-menu .ry-nav li.primary .caret {
    border-color: #374151;
}

.ry-menu .ry-nav li.primary:hover .caret {
    border-color: var(--color-secondary-background);
}
/* Hero */
	/**/

.with-gradient:before {
    background-image: linear-gradient(to bottom, white, transparent, #333333ad);
}

.slider-info {
    min-height: fit-content;
}

/* CTA */
	/**/
/* Welcome */
	/**/
.module-welcome.style-5 .ry-each.image-wrapper {
    max-width: fit-content;
    border: none;
}
.module-welcome.style-5 .ry-text p {
    margin: 30px 0;
    font-size: 1.25rem;
    line-height: 1.75rem;
    text-align: left !important;
}
.module-welcome.style-5 .ry-text .ry-btn {
    margin-left: 0;
}
.module-welcome.style-5:before {
    background-position: right;
}
/* Services */
	/**/
#services-7 .each-block {
    margin-bottom: 100px;
    overflow: visible;
}

.ry-services.style2 .ry-each .title {
    bottom: -65px;
    width: 80%;
}

.ry-services.style2 .ry-each .each-block:hover .title {
    bottom: -65px;
  
}

.ry-services.style2 .ry-each .photo {
    background: #e0eff7;
    border-radius: 999px;
}

.ry-services.style2 .ry-each .photo:before {
    background: #b6d1de;
    border-radius: 999px;
    height: 60%;
    width: 60%;
    left: 20%;
    top: 20%;
}

#services-7 .each-block::before {
    content: "";
    position: absolute;
    top: -5%;
    left: -5%;
    height: 110%;
    width: 110%;
    border: 3px solid var(--color-primary-background);
    border-radius: 999px;
    transition: all ease .4s;
}

.ry-services.style2 .ry-each .photo img {
    object-fit: contain;
    height: 50%;
    width: 50%;
    top: 25%;
    left: 25%;
    z-index: 2;
    transition: all ease .4s;
}

.ry-services.style2 .ry-each .each-block:hover .photo:after {
    height: 0;
}

.ry-services.style2 .ry-each .each-block:hover .button-svg {
    opacity: 0;
}

#services-7 .each-block:hover::before {
    border: 13px solid var(--color-primary-background);
}

.ry-services.style2 .ry-each .each-block:hover .photo:before {
    opacity: 1;
    width: 80%;
    height: 80%;
    left: 10%;
    top: 10%;
}

.ry-services.style2 .ry-each .each-block:hover .photo img {
    height: 70%;
    width: 70%;
    left: 15%;
    top: 15%;
}
/* Meet the Team */
	/**/


/* Insurance */
	/**/
/* Brand */
	/**/
/* Request Appointment */
	/**/
/* Testimonials */
	/**/
.module-testimonials.style-4 .swiper-slide {
    color: #666;
    background: transparent;
}

.module-testimonials.style-4 .review-separator {
    transform: translate(-10px, -50%);
}
/* Footer */
	/**/
#ry-footer-3 .footer-contents::before, #ry-footer-3::after {
    background-color: var(--color-secondary-background);
    opacity: 1;
}
/*Media Queries*/
	/**/

@media screen and (max-width:1320px){
    .module-welcome.style-5:before {
        background-position: center;
    }
    .module-welcome.style-5 .ry-each:not(.image-wrapper) {
        max-width: 100%;
        padding-right: 0;
        padding-bottom: 30px;
        justify-content: center;
    }
    .module-welcome.style-5 .ry-text p {
        text-align: center !important;
    }
    .module-welcome.style-5 .ry-each .ry-text .ry-btn {
        margin-left: auto;
        margin-right: auto;
    }
}
@media (min-width: 768px) {
    .slider-info-center-bottom {
        bottom: 0%;
    }
}
@media (max-width: 768px) {
	#hp-slider, #hp-slider .swiper-wrapper, .homepage-swiper .swiper-slide img {
		height: 100% !important;
	}
}
@media (width < 1080px) {
    .custom-headline span {
        display: block;
    }
	body[data-page-name="index"] #navigation {
		position: relative;
	}
    #section-hp-services:before, .module-19.style2:before, .ry-services.style2::before {
        opacity: 1;
    }
    .module-welcome.style-5 .ry-text p {
        text-align: center !important;
    }
    .ry-services.style2 .each-block .title {
        bottom: -105px;
        width: 100%;
    }
    
    #services-7 .each-block {
        background: #e0eff7;
    }
    
    .ry-services.style2 .each-block .photo:before {
        background: #b6d1de;
        height: 80%;
        width: 80%;
        border-radius: 999px;
        left: 10%;
        top: 10%;
    }
    
    .ry-services.style2 .each-block .photo img {
        border-radius: 0;
        z-index: 2;
        height: 80%;
        width: 80%;
        left: 10%;
        top: 10%;
    }
    
    #services-7 .each-block::before {
        height: 100%;
        width: 100%;
        top: 0;
        left: 0;
        border: 5px solid var(--color-primary-background);
    }
}


@media (width < 767px) {
    #hp-slider, #hp-slider .swiper-wrapper, .homepage-swiper .swiper-slide img {
        height: 100% !important;
    }
    .with-gradient:before {
        background-image: linear-gradient(to bottom, white, transparent, #397b9e);
    }
}
@media (max-width:486px){
    .snap-mobile-menu img {
        max-height: 40px;
        margin-right: 150px;
    }
}
/* End - HP Edits*/

body#ry-pg-body div#navigation {
    position: static;
    background: #eeeeee;
}
.cta-btn.ry-btn-primary, .cta-btn.ry-btn-secondary {
    background: transparent !important;
    color: #333;
}

.cta-btn.ry-btn-primary:hover, .cta-btn.ry-btn-secondary:hover {
    color: #55a3a7 !important;
}

.cta-btn.ry-btn-primary span.cta-icon-wrap span.cta-icon {
    background: #6ecbd0;
    color: white;
}

.cta-btn.ry-btn-secondary span.cta-icon-wrap span.cta-icon {
    background: #dfb76c;
    color: white;
}

.custom-headline h2 .span-1 {
	display: block;
}

body[data-page-name="contact-us"] div#footer-map {
	display: none;
}

body[data-page-name="contact-us"] #ry-footer-3 {
	padding-top: 220px;
}