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

.sticky-icons ul {
    padding: 0;
}
.sticky-icons ul li {
    list-style: unset;
}
/* 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%);
	letter-spacing: 4px;
	font-size: clamp(1.625rem, 0.95rem + 3.375vw, 5rem);
	line-height: 120%;
}

#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;
	}
	.ry-menu .ry-nav li.primary {
		margin-top: 10px;
	}
}

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

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

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

.module-testimonials h6, .module-testimonials p, .module-testimonials h2 {
    text-align: center !important;
}

img.rev-icon {
    max-width: 70px;
    height: auto;
    width:100%;
}


@media (max-width: 1080px) { 
	.ry-menu .ry-nav {
		font-size: 14px !important;
	}
	
	div.module-testimonials h6, .module-testimonials p, .module-testimonials h2 {
		text-align: center !important;
	}
	
	div#team-inner-block {
		padding: 2em 1em;
	}

	div#team-inner-block img {
		max-width: 220px;
	}

	div#team-inner-block {
		flex-direction: column;
	}

	div#team-inner-block .flex {
		padding: 0 !important;
		background: transparent;
		width: 100%;
	}

}

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

@media (max-width:991px) {

	.main-title h2 {
		line-height: 1.2;
		font-size: 30px !important;
	}

	.sub-title h4 {
		font-size: 20px !important;
	}
	
	div#section-hp-services .grid h4 {
		font-size: 23px;
		line-height: 1.3;
	}
	
	div#footer-map {
		height: 400px !important;
	}
	
	div#rev-flex h3 {
		font-size: 22px !important;
	}
}

@media (max-width:768px) {
	
	img#hp-rev-image {
		height: auto !important;
		border-top-left-radius: 20px;
		border-top-right-radius: 20px;
	}

	div#hp-rev-image-block {
		width: 100% !important;
	}

	div#hp-rev-image-flex {
		display: block !important;
		border-radius: 20px;
	}

	div#rev-flex {
		width: 100%;
	}
}

@media (max-width:767px) {
	
	.snap-mobile-menu .gap-6 {
		gap: 0 10px;
	}

	.homepage-swiper .slider-info {
		max-width: 100%;
		text-align: center;
		position:static !important;
	}

	.homepage-swiper .slider-info .mb-4 {
		margin-bottom:0 !important;
	}

	.homepage-swiper .homepage-swiper {
		margin-top: 0em;
	}

	.homepage-swiper .swiper-slide {
		padding-top:0;
	}
	
	.homepage-swiper .swiper-slide img {
		height: 100% !important;
	}
	.homepage-swiper .slider-info {
		padding-bottom: 50px;
	}
}

@media (max-width: 500px) {
	
   .snap-mobile-menu img { 
		max-height: 65px;
	}
	
	.snap-mobile-menu .gap-6 {
		gap: 0 10px;
	}
}

div#section-hp-team .swiper.homepage-team-swiper h6 {
    letter-spacing: 2px;
    font-size: clamp(1.25rem, 1.2037rem + 0.2469vw, 1.5rem);
}

@media (max-width: 1024px) {
	div#section-hp-team .mx-auto .md\:text-center.text-gray-500>p {
		text-align: center !important;
	}
	.homepage-team-swiper .text-gray-800 {
		font-size: 20px;
	}
	.homepage-team-swiper .text-gray-600 {
		font-size: 16px;
	}
}

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

@media (max-width: 1080px) {
	.homepage-swiper .swiper-slide img {
		height: 100% !important;
	}
	.slider-info {
		width: 100% !important;
		max-width: 100% !important;
	}
	.slider-info {
		width: 100%;
		max-width: 100%;
	}
	.homepage-swiper h2 {
		text-align: center !important;
	}
	#navigation-style-3,
	.navigation-3 .hidden.lg\:flex,
	.homepage-video-slider::before {
		display: none !important;
	}
}

@media (min-width: 1081px) {
	.homepage-video-slider {
		max-height: 100vh;
		overflow: hidden;
	}
	.homepage-video-slider::before {
		background: linear-gradient(to bottom, white 14%, transparent, transparent);
		opacity: 1;
	}
}


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

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

.slider-info-center-bottom {
	max-width: 100% !important;
}

.ry-services.style2 .ry-each .photo:before {
	background: transparent;
}
.ry-services.style2 .ry-each .photo {
    background: linear-gradient(to top, var(--color-primary-background), var(--color-secondary-background));
}

.ry-services.style2 .ry-each .photo img {
    top: 17%;
    left: 50%;
    object-fit: contain;
    max-width: 150px;
    max-height: 130px;
    transform: translateX(-50%);
}

@media (max-width: 1080px) {
	
	.ry-services.style2 .each-block .photo {
		background: linear-gradient(to top, var(--color-primary-background), var(--color-secondary-background));
	}
	.ry-services.style2 .each-block .photo img {
		filter:brightness(0) invert(1);
		padding:40px;
		top: -13%;
	}
}

@media (min-width:980px) and (max-width: 1080px) {
        .ry-services.style2 .each-block .title div {
        font-size:16px;
        min-width:130px
    }
}
@media(max-width:768px){
    .ry-services.style2, #brand-section-heading,#hp-insurance-1 {
        text-align:center
    }
}

#section-hp-services:before, .module-19.style2:before, .ry-services.style2::before {
	opacity: 1;
}

@media (max-width:600px) {
	#services-7 .each-block {
	  border: none;
	}

	.ry-services.style2 .each-block .photo {
	  padding-bottom: 0;
	  height: 200px;
	  max-width: 200px;
	  margin: auto;
	  border: 2px solid #fff;
	}
	
	.ry-services.style2 .button-wrapper {
	  padding-top: 1em;
	}
	
	.ry-services.style2 .each-block .title div {
	  font-size: 16px;
	  max-width: 90%;
	  margin: auto;
	  line-height: 1.2;
	}
}

/** Services Style **/
#services-12 .slick-arrow {
  height: 50px;
  width: 50px;
  background: #ccc3bd;
  border-radius: 8px;
  display: flex !important;
  justify-content: center;
  align-items: center;
  font-size: 0;
  line-height: 0;
  position: absolute;
  top: 50%;
  display: block;
  padding: 0;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  cursor: pointer;
  border: none;
  outline: none;
  z-index: 9;
}

#services-12 .slick-arrow.slick-prev:before,
#services-12 .slick-arrow.slick-next:before {
  display: block;
  content: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" fill="%23fff" class="bi bi-chevron-left" viewBox="0 0 16 16"%3E%3Cpath fill-rule="evenodd" d="M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z"/%3E%3C/svg%3E');
  height: 25px;
  width: 25px;
}

#services-12 .slick-arrow.slick-next:before {
  content: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" fill="%23fff" class="bi bi-chevron-right" viewBox="0 0 16 16"%3E%3Cpath fill-rule="evenodd" d="M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z"/%3E%3C/svg%3E');
}

#services-12 .slick-prev:hover:before,
#services-12 .slick-prev:focus:before,
#services-12 .slick-next:hover:before,
#services-12 .slick-next:focus:before {
  opacity: 1;
}
#services-12 .slick-prev.slick-disabled:before,
#services-12 .slick-next.slick-disabled:before {
  opacity: 0.25;
}

#services-12 .slick-prev:before,
#services-12 .slick-next:before {
  font-size: 20px;
  line-height: 1;
  opacity: 1;
  color: #790000;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

#services-12 .slick-prev {
  left: -25px;
}

#services-12 .slick-next {
  right: -25px;
}

#services-12  .slick-track {
	display: flex;
    gap: 18px;
    padding: 50px 0 50px;
}

#services-12 .hp-service {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
	padding: 28px 2vw;
	position: relative;
	background: #ffffff;
}
#services-12 .hp-service:nth-child(even) {
	background: var(--color-secondary-background);
}
#services-12 .hp-service:nth-child(even) * {
    color: #fff;
}
#services-12 .hp-service:nth-child(even) img {
    filter: brightness(0) invert(1) !important;
}

#services-12 p {
    font-size: 18px;
    line-height: 1.5;
    text-align: center;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 5;
    line-clamp: 5;
    -webkit-box-orient: vertical;
    transition: 0.2s;
    min-height: 140px;
    color: #383838;
}

#services-12 .custom-btn {
    z-index: 999 !important;
}

#services-12 .rounded-full {
    width: 45px;
    height: 45px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
	color: #fff;
}
#services-12 .rounded-full i {
    font-size: 20px;
}

#services-12 .rounded-full {
    transition: 0.3s;
    background: var(--color-primary-background);
}
#services-12 .rounded-full {
    transition: 0.3s;
}
#services-12 .hp-service .text-3xl.font-semibold.py-6.px-2.mx-auto.text-center {
    min-height: 130px;
    display: flex;
    align-items: center;
    justify-content: center;
	font-size: clamp(1.1875rem, 1.15rem + 0.1875vw, 1.375rem);
}
#services-12 .hp-service .text-3xl.font-semibold.py-6.px-2.mx-auto.text-center h4 {
    line-height: 130%;
}
div#services-12 {
    padding: 0;
}
#services-12 > div:nth-child(even) {
	background: transparent;;
}
#services-12 .hp-service h4 {
	opacity: 1;
}
#services-12 img {
    filter: brightness(0) invert(.2) !important;
}
div#section-hp-services {
	background: url();
	background-size: cover;
}
#section-hp-services::before {
    top: unset;
    bottom: 0;
    height: 40%;
	background: var(--color-primary-background)
}
#services-12 > div:nth-child(odd) {
	background: transparent;
}

@media (max-width:600px) {
	#services-12 .slick-track {
	  padding: 0 !important;
	}

	#services-12 .hp-service .text-3xl.font-semibold.py-6.px-2.mx-auto.text-center {
	  min-height: auto !important;
	  padding: 0 0 10px 0 !important;
	}

	#services-12 p {
	  padding:  0 10px  !important;
	  font-size: 16px  !important;
	}
}

#ry-footer-3::before {
	    opacity: 1;
}

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

div#hp-brands-6 .bg-gray-200 img {
    filter: brightness(0) invert(1);
}

@media (min-width:1201px) {
    div.hp-team-style-8 {
		max-width: 1000px !important ;
		width: 90%;
		position: relative !important;
		left: 5% !important;
	}

	div.hp-team-style-8 img {
		width: 40% !important;
		max-width: 350px !important;
	}

	div.hp-team-style-8 .space-y-6.xl\:pl-32 {
		padding-left: 22% !important;
	}
}

body[data-page-name="frames"] #hp-brands-6::before {
	display: none;
}

body[data-page-name="frames"] div#hp-brands-6 {
    background-color: unset;
}

body[data-page-name="frames"] div#hp-brands-6 .bg-gray-200 img {
    filter: brightness(0);
}

body[data-page-name="frames"] #inner-flex,
body[data-page-name="frames"] div#hp-brands-6 {
	padding-top: 0 !important;
}

html, body {
    max-width: 100%;
    overflow-x: hidden;
}

.cookie_privacy-container {
    z-index: 300 !important;
}