/* 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;
}

.nextdoor-icon {
    filter: invert(1);
    width: 18px;
    height: 18px;
}

body[data-page-id="WebPage-a93cc36b-a32f-445f-ade5-cc26975d56b5"] div#footer-map {
    display: none;
}

/* 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;
}

.homepage-swiper h2 {
	text-shadow: 3px 3px 3px rgb(0 0 0 / 40%);
	    text-align: center;
}

#ry-pg-body :is(.navigation-3) {
    position: relative !important;
}

.mm-navbar__title > span {
    color: #fff;
}

@media (min-width: 1024px) {
	.navigation-3.fixed > .block.lg\:absolute.inset-0 {
		position: relative;
	}
}

@media (max-width: 1440px) {
	div#navigation-style-4.container {
		max-width: 1280px;
	}
}

div#navigation-style-4 {
    max-width: 1600px;
    width: 90%;
    padding: .5em 0 !important;
}

body#ry-pg-body div#navigation {
    position: static;
}

@media (max-width: 1080px) { 
	.ry-menu .ry-nav {font-size: 14px !important;}
}

@media (max-width: 1200px) { 
	div#navigation-style-4 {
		max-width: 90%;
	}
	.ry-menu .ry-nav {
		gap: 20px !important;
	}
	div#navigation-style-4 .cursor-pointer img {
		max-width: 200px;
	}
}

@media (max-width: 500px) {
    .snap-mobile-menu img {
        width: 175px;
        object-fit: contain;
    }
	
	div.module-brands.style-5 .content .brand-block .each-brand .logo img {
		width: 80px;
		height: 80px;
		object-fit: contain;
	}
}

@media (max-width: 1200px) {
	.module-19 .ry-generic * {
		text-align: center !important;
	}
	.module-19 .ry-btn.ry-btn-primary {
		margin: auto;
	}
}

.homepage-swiper .swiper-slide img {
	object-position: center top;
}

/** Services Start **/
.ry-services.style2 .ry-each .photo:before {
	display: none;
}
.ry-services.style2::before {
    top: 0;
    height: 100%;
    background-size: cover;
    background-repeat: no-repeat;
	background-position: center top;
    opacity: 1;
}

.custom-bg .ry-section, .custom-bg .ry-services.style2 {
	background: transparent;
}

#services-7 .each-block {
    border: 6px solid #ffffff99;
}
.ry-services.style2 > .relative, .ry-services.style2 .ry-container {
    position: relative;
    z-index: 9;
}

.ry-services.style2 .each-block .photo img {
	transform: translateX(-50%);
	object-fit: contain;
}

@media (max-width: 1080px) { 
	.ry-services.style2 .each-block .photo::before {
		background: transparent !important;
	}
	div.ry-services.style2 .each-block .photo img {
		padding: 0;
		max-width: 100px !important;
		top: -10%;
	}
	div.ry-services.style2 .each-block .title {
		bottom: 14%;
		line-height: 1.3;
		width: 100%;
		transform: initial !important;
		left: 0;
		right: 0;
		text-align: center;
		padding: 0 40px;
	}
	div.ry-services.style2 .each-block .title div {
		text-align: center;
	}
}

/** Services End **/

.module-testimonials.style-2::before, .module-testimonials.style-3::after {
	background: url(https://s3.amazonaws.com/static.organiclead.com/Site-251c5b10-7701-44c3-9528-b623f63d4283/Assets/footer_background.jpg);
	background-size: cover;
	background-position: center bottom;
	background-repeat: no-repeat;
}

.cta-content {
    background: url(https://s3.amazonaws.com/static.organiclead.com/Site-251c5b10-7701-44c3-9528-b623f63d4283/Assets/cta_background.jpg);
    background-size: cover;
    margin-top: 0 !important;
}
.cta-content .mb-2.text-2xl.font-bold.tracking-tight.text-white h3 {
    text-transform: capitalize !important;
    letter-spacing: 1px;
}

.lightbox-trigger {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 30px;
}

.lightbox-trigger .ry-each img {
	width: 100%;
	max-width: 100%;
	cursor: pointer;
}

.lightbox {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.8);
	display: none;
	justify-content: center;
	align-items: center;
	z-index: 9999;
}

.lightbox img {
	max-width: 90%;
	max-height: 80%;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.close {
	position: absolute;
	top: 10px;
	right: 20px;
	color: white;
	font-size: 30px;
	cursor: pointer;
}
.lightbox-trigger .ry-each img:hover {
	opacity: 0.7;
}

@media screen and (max-width: 992px) {
	.lightbox-trigger{
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 5px;
	}
}

#ry-footer ul {
    line-height: 2;
}

@media screen and (max-width: 1024px) {
	div#ry-footer h4 {
		font-size: 1rem;
	}
	
	div#ry-footer ul li {
		font-size: 14px !important;
	}
}
.team-inner-page.style3 .ry-flex.object-top .photo img {
    margin: 0;
}