/* **********************************************************
 * ELEMENT STYLES
 * ******************************************************** */

/* *****************************
 * BUTTON ADDITIONAL STYLING
 * *************************** */
a.elementor-button.elementor-button-link {
  background-color: #0033cc; /* Initial background */
  position: relative;
  display: inline-block;
  text-decoration: none;
  overflow: hidden; /* Contains the circle */
  transition: all 0.65s ease-out !important;
  z-index: 1;
}
a.elementor-button.elementor-button-link::before {
  content: '';
  position: absolute;
  width: 0;
  height: 50%;
  border-radius: 50%;
  background: #ccccff;
  opacity: 0;
  top: 50%;
  left: -10%;
  transform: translate(-50%, -50%);
  transition: all 0.75s ease-out;
  z-index: -1;
  background-image: url(/wp-content/uploads/2025/07/Neptune-Favicon.png);
  background-repeat: no-repeat;
  background-position: center right;
  background-size: 30px;
}
a.elementor-button.elementor-button-link:hover,
a.elementor-button.elementor-button-link:focus {
  color: #202020; 
}
a.elementor-button.elementor-button-link:hover::before,
a.elementor-button.elementor-button-link:focus::before {
  width: 300%; 
  height: 500%; 
  opacity: 1;
}

/* Button Variations */
.btn-purp-hover-white a.elementor-button.elementor-button-link {
  background-color:#ccccff; /* Initial background */
  color: #202020;
}
.btn-purp-hover-white a.elementor-button.elementor-button-link::before {
  background-color: #ffffff;
}	
.btn-purp-hover-white a.elementor-button.elementor-button-link:hover,
.btn-purp-hover-white a.elementor-button.elementor-button-link:focus {
  color: #202020; 
}	
	
.btn-white-hover-purp a.elementor-button.elementor-button-link {
  background-color: #ffffff; /* Initial background */
  color: #202020; 	
}
.btn-white-hover-purp a.elementor-button.elementor-button-link::before {
  background-color: #ccccff;
}	
.btn-white-hover-purp a.elementor-button.elementor-button-link:hover,
.btn-white-hover-purp a.elementor-button.elementor-button-link:focus {
  color: #202020; 
}	


/* ******************************
 * ELEMENTOR MOTION EFFECTS TRANSITION
 * *************************** */
.elementor-element .elementor-widget-container.elementor-motion-effects-element {
    transition-duration: 2s;
}


/* *****************************
 * ELEMENT PADDING & MARGINS
 * *************************** */
.element-margin-bottom-0.elementor-element {
	margin-bottom: 0 !important;	
}


/* ******************************
 * BANNERS WITH OVERLAYS
 * *************************** */
.banner-overlay .jet-banner__overlay {
    mix-blend-mode: multiply;
    transition: all .5s ease-in-out;	
}
.banner-overlay .elementor-jet-banner {
	overflow: hidden;
}
.banner-overlay .elementor-jet-banner .jet-banner__img {
  transition: transform 1s, filter 2s ease-in-out;
  filter: blur(0px);
  transform: scale(1.0);
}
.banner-overlay .elementor-jet-banner:hover .jet-banner__img {
  transition: transform 1s, filter 2s ease-in-out;
  filter: blur(2px);
  transform: scale(1.1);
}
.banner-overlay .elementor-jet-banner:hover i {
	border-bottom: 2px solid #fff;
	padding-bottom: .5rem;
}

@media (max-width: 767px) {
	/* BANNER OVERLAY */
	.banner-overlay .elementor-jet-banner .jet-banner__img {
		transform: scale(1.65);	
	}	
	.banner-overlay .elementor-jet-banner:hover .jet-banner__img {
		transform: scale(1.75);	
	}	
}


/* ******************************
 * BLOG LISTING GRID SLIDER
 * *************************** */
.blog-slider .jet-listing-grid .jet-engine-listing-overlay-wrap .elementor-inner {
    height: 100%;
}
.blog-slider .blog-card .section-col .elementor-widget-wrap.elementor-element-populated {
    flex-direction: column;
}
.blog-slider .blog-card .section-col .inner-section-content {
    margin-bottom: auto;
}
.blog-slider .blog-card .elementor-container.elementor-column-gap-default {
    width: 100%;
}
.blog-slider .blog-card .inner-section-content {
    margin-bottom: 2rem;
}
.blog-slider .blog-card .blog-title {
    height: auto !important;	
	margin-bottom: 0 !important;
}
.blog-slider .blog-card .blog-title .elementor-widget-container {
    height: auto !important;
}


/* SET SAME HEIGHT */
.blog-slider .slick-track  {
	display: flex !important;	
}
.blog-slider .jet-listing-grid__item {
    height: auto !important;
} 
.blog-slider .blog-card {
    display: flex;	
	height: 100%;
}
.blog-slider .jet-listing-grid__item,
.blog-slider .jet-listing-grid__item .jet-engine-listing-overlay-wrap,
.blog-slider .jet-listing-grid__item .jet-engine-listing-overlay-wrap > div,
.blog-slider .jet-listing-grid__item .jet-engine-listing-overlay-wrap > div .elementor-section-wrap,
.blog-slider .jet-listing-grid__item .jet-engine-listing-overlay-wrap > div .elementor-section-wrap .blog-card {
  height: 100%;
}

/* No Padding on Bottom Button */
.page-template-full-width .jupiterx-main .elementor-section.elementor-section-boxed.inner-section-link .elementor-container,
.page-template-full-width .jupiterx-main .elementor-section.elementor-section-boxed.inner-section-link .elementor-container .elementor-widget-wrap {
    padding: 0 !important;
}
.blog-slider .inner-section-link {
    position: absolute !important;
    bottom: 0;
}


/* ******************************
 * PRODUCT LISTING GRID SLIDER
 * *************************** */
.product-slider .product-card {
    display: flex;	
}
.product-slider .product-card .section-col .elementor-widget-wrap.elementor-element-populated {
    flex-direction: column;
}
.product-slider .product-card .section-col .inner-section-content {
    margin-bottom: 3rem;
}
.product-slider .product-card .elementor-container.elementor-column-gap-default {
    width: 100%;
}
.product-slider .product-card .inner-section-content {

}
.product-slider .product-card .product-title {
	margin-bottom: 0 !important;
}
.product-slider .product-card .product-desc {

}
.product-slider .inner-section-link {
    position: absolute !important;
    bottom: 0;
}
.product-slider .product-card .jet-listing.jet-listing-dynamic-link {
    display: flex;
    flex-direction: row;
    align-content: stretch;
    flex-wrap: nowrap;
    align-items: stretch;
    width: 100%;
    height: 100%;
}
.product-slider .product-card a.jet-listing-dynamic-link__link {
    width: 100%;
    height: 100%;
    display: flex !important;
	font-size: 1.125rem !important;
}


/* ******************************
 * DEFAULT PAGER - SEARCH RESULTS, ETC
   NOTE: You CAN typically style the element directly
 * *************************** */
/* Default Pager - Search Results, etc */
.page-item.active .page-link {
    color: #fff;
    background-color: #555 !important;
    border-color: #111 !important;
}


/* ******************************
 * IMAGE GRID GALLERY LIGHTBOX
 * *************************** */
.mfp-close {
	font-size: 24px !important;
}
/* Kill Close & Arrow Background Hover Color */
.mfp-arrow,
.mfp-close:hover {
	background-color: transparent !important;
	border: none !important;
}

/* Hide Lightbox Alt Text Caption
 .mfp-bottom-bar .mfp-title { 
	display: none; 
} */

.elementor-lightbox .elementor-lightbox-image {
  border-radius: 10px;
  background: #FFFFFF;
}


/* ******************************
 * FLIP BOX
 * *************************** */
@media (max-width: 1024px) {		
	/* Fix for iOS z-index like bug - Flip Boxes cover Header, Mobile Menu, etc */
	.ios .ha-flip-box-container.ha-flip-effect-3d .ha-flip-box-back-inner, 
	.ios .ha-flip-box-container.ha-flip-effect-3d .ha-flip-box-front-inner {
		-webkit-transform: translateZ(0px) scale(.9) !important;
		transform: translateZ(0px) scale(.9) !important;
	}
}

@media (max-width: 767px) {
	/* FLIP BOX IOS FIX - not all but Design 9 caused Flip Box to appear on top of Header  */
	.ios .flip-boxes-icon-title-txt .ha-flip-box-container.ha-flip-effect-3d .ha-flip-box-inner-wrapper {
	  -webkit-transform-style: flat;
	  transform-style: preserve-3d;
	}	
}


/* ******************************
 * GOOGLE MAPS
 * *************************** */
.gm-style iframe + div {
    border: 0 !important;
}


/* ******************************
 * BACKGROUND OVERLAY for iPHONE - Add Class if Needed
 * *************************** */
@media (max-width: 767px) {
	/* Overlay */
	.responsive-phone-overlay-opacity .elementor-background-overlay {
		opacity: .7 !important;
	}
}


/* ******************************
 * JET HEADLINE
 * *************************** */
span.jet-headline__space {
    line-height: 1px;
}


/* ******************************
 * ICON LIST CENTERED ON MOBILE - add class mobile-center - or center-1200 for Tablet Landscape 
 * *************************** */
@media (max-width: 767px) {
	.mobile-center .elementor-icon-list-item,
	.mobile-center .elementor-icon-list-item a {
		text-align: center !important;
	}
}

@media (max-width: 1200px) {
	.center-1200  .elementor-icon-list-item,
	.center-1200 .elementor-icon-list-item a {
		text-align: center !important;
	}
}


/* *****************************
 * JUPITER RAVEN ADVANCED VIDEO ELEMENT
 * *************************** */
.raven-video-mejs-player {
    z-index: 9000 !important;
    display: block;
    background: rgba(0,0,0,.9) !important;
}
.raven-video-mejs-player .raven-video-mejs-player {
	z-index: 9000 !important;
}

/* Keep Header, Scroll Buttons, Hero Overlay Behind Popup*/
.mejs-fullscreen header.jupiterx-header,
.safari.mejs-fullscreen header.jupiterx-header,
.mejs-fullscreen .ha-has-bg-overlay>.elementor-widget-container,
.safari.mejs-fullscreen .ha-has-bg-overlay>.elementor-widget-container,
.mejs-fullscreen .jupiterx-corner-buttons {
	z-index: 0;
}


/* *****************************
 * ADVANCED ACCORDION - some helpers if needed
 * *************************** */
 /* Space Between Toggles */
.jupiterx-single-advanced-accordion-wrapper {
	margin-bottom: 5px;	
}

/* Force the Border Color on Toggle Header */
.jx-single-accordion-header {
    border-color: #EEE !important;
}
.jx-ac-inactive .jx-single-accordion-header {
    border-color: transparent !important;
}


/* *****************************
 * JUPITER TESTIMONIAL CAROUSEL TWEAKS
 * *************************** */
.elementor-widget-raven-testimonial-carousel .swiper-wrapper {
  margin-bottom: 3rem !important;
   min-height: fit-content !important;    
}
.elementor-widget-raven-testimonial-carousel .raven-main-swiper {
   min-height: fit-content !important;
}
.elementor-widget-raven-testimonial-carousel .raven-main-swiper .swiper-slide {
    overflow-y: visible;
    min-height: fit-content !important;
    display: flex;
	justify-content: center;
}
.elementor-widget-raven-testimonial-carousel .raven-main-swiper .swiper-slide .raven-testimonial {
    justify-content: center;
}


/* *****************************
 * MARQUEE SCROLLING TEXT
 * *************************** */
.raven-marquee-left-gradient-overlay, .raven-marquee-right-gradient-overlay {
	z-index: 20 !important;
}

@media (max-width: 480px) {
	.raven-marquee-left-gradient-overlay,
	.raven-marquee-right-gradient-overlay {
        width: 30px !important;
    }
}


/* *****************************
 * SOCIAL ICONS
 * *************************** */
.elementor-widget-social-icons {
  flex-basis: auto !important;   
}


/* *****************************
 * SVG ICONS
 * *************************** */
.svg-triangles .ha-svg-draw-container svg {
    width: 31.25rem !important;
    height: 14rem !important;
}
.svg-trident .ha-svg-draw-container svg {
    width: 19.75rem !important;
    height: 10.4rem !important;
    margin: 0rem -0.5rem -0.5rem !important;
    z-index: 0 !important;
    opacity: .85;
}


/* *****************************
 * GRADIENT HEADING
 * *************************** */
.ha-gradient-heading a {
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-color: transparent;
    background-image: linear-gradient(178deg, #ccccff 20%, #6685E0 80%) !important;
    background-size: 100% 100%;
    background-position: 100% 100%;
    transition: background-position 1s ease, background-size 1s ease;
}
.ha-gradient-heading a:hover {
    background-size: 200% 200%; 
    background-position: 100% 100%;
}

/* Light Gradient for Dark BGs */
.gradient-light .ha-gradient-heading a {
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-color: transparent;
    background-image: linear-gradient(178deg,  #ccccff 40%,  #0033cc 100%) !important;
    background-size: 100% 100%;
    background-position: 100% 100%;
    transition: background-position 1s ease, background-size 1s ease;
}
.gradient-light .ha-gradient-heading a:hover {
    background-size: 170% 170%; 
    background-position: 100% 100%;
}

/* Dark Gradient for Dark BGs */
.gradient-dark .ha-gradient-heading a {
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-color: transparent;
    background-image: linear-gradient(90deg, #003366 25%, #0033cc 100%) !important;
    background-size: 100% 100%;
    background-position: 100% 100%;
    transition: background-position 1s ease, background-size 1s ease;
}
.gradient-dark .ha-gradient-heading a:hover {
    background-size: 250% 250%; 
    background-position: 100% 100%;
}


/* *****************************
 * LARGE DIVIDER TEXT Like Featured and Testimonials 
 * *************************** */
.h2-lg-divider-text.elementor-widget-heading {
	display: flex;	
    justify-content: center;
}
.h2-lg-divider-text.nowrap.elementor-widget-heading {
	display: flex;	
    justify-content: center;
	white-space: nowrap;
}

/* *****************************
 * VERTICAL TIMELINE
 * *************************** */
.jet-timeline-item .timeline-item__card-inner {
	background-image: linear-gradient(150deg, #003366 25%, #6685E0 100%);
}
.jet-timeline-item .timeline-item__card-content .timeline-item__meta-content {
	color: #ccccff !important;
}

@media (min-width: 1024px) {
	.jet-timeline-item:nth-child(odd) .timeline-item__card-arrow {
		background-color: #5477CB !important;
	}
}


/* TIMELINE ENTRANCE ANIMATION */
@media (min-width: 430px) {
    .jet-timeline-item--animated .timeline-item__card {
        -webkit-animation-duration:1s;
        animation-duration: 1s;
        -webkit-animation-fill-mode: both;
        animation-fill-mode: both;
        opacity: 0
    }

    @keyframes card-animation-right-fade {
        0% {
            opacity: 0;
            transform: translateX(10px)
        }

        100% {
            opacity: 1;
            transform: translateX(0)
        }
    }

.card-animation-right,
.jet-timeline--align-left .jet-timeline-item--animated.is--show .timeline-item__card,
.jet-timeline--align-center .jet-timeline-item--animated.is--show:nth-child(even) .timeline-item__card {
        -webkit-animation-name: card-animation-right-fade !important;
        animation-name: card-animation-right-fade !important;
    }

    @keyframes card-animation-left-fade {
        0% {
            opacity: 0;
            transform: translateX(-10px)
        }

        100% {
            opacity: 1;
            transform: translateX(0)
        }
    }

.card-animation-left,
.jet-timeline--align-center .jet-timeline-item--animated.is--show:nth-child(odd) .timeline-item__card,
.jet-timeline--align-right .jet-timeline-item--animated.is--show .timeline-item__card {
        -webkit-animation-name: card-animation-left-fade !important;
        animation-name: card-animation-left-fade  !important;
    }
}



/* *****************************
 * MODAL POPUP
 * *************************** */
.ha-modal-popup-content-wrapper.ha-modal-fullscreen.ha-modal-show {
    flex-direction: column;
}
.ha-modal-popup-content-wrapper.ha-modal-fullscreen.ha-modal-show .ha-modal-animation {
    height: fit-content;
    max-height: 60vh;
	padding: 3rem !important;	
}
.ha-modal-popup-content-close {
	position: relative !important;
	top: 50px !important;
	right: 0 !important;
	left: 38% !important;
	width: 40px !important;
	transition: all 1s ease;
	transform: scale(0) !important;	
}
.ha-modal-popup-content-wrapper.ha-modal-show .ha-modal-popup-content-close {
	transform: scale(1) !important;
}
.ha-modal-popup-content-close svg {
	height: 40px;
    width: 40px;
	fill: #003366;
	transition: all .5s ease;	
}
.ha-modal-popup-content-close svg:hover {
    width: 40px;
	fill: #0033cc !important;
}


@media (min-width: 769px) {
	/* TEAM POPUP */
	.ha-modal-inner-content {
	  display: grid;
	  grid-template-columns: 1fr 2fr; /* Two Col Flex Width */
	  grid-template-areas:
  	  "image title"
  	  "image description"; /* Grid template with the image on the left and title/description on the right */
	  gap: 0rem 2rem;
	  padding-bottom: 3rem !important;
	  align-content: center;
	}
	.ha-modal-content__image {
	  grid-area: image; /* Places the image in the 'image' grid area */
	}
	.ha-modal-content__title {
	  grid-area: title; /* Places the title in the 'title' grid area */
	  align-items: flex-start;
	  display: flex;
	  flex-direction: column;
	  justify-content: flex-end;
	  align-content: flex-start;
	}
	.ha-modal-content__description {
	  grid-area: description; /* Places the description in the 'description' grid area */
	  margin: 0 !important;
	  padding: 0 !important;
	}
}

/* Modal Content */
.ha-modal-content__image {
  display: inline;
  float: left;
  margin: 0 2rem 0 0 !important;
}
.ha-modal-content__description {
  padding-bottom: 20px;
}

@media (max-width: 768px) {
	.ha-modal-inner-content {
		display: flex;
		flex-direction: column;
		align-items: center;
		align-content: center;
	}
	.ha-modal-content__image {
	  display: flex;
	  margin: 0 0 30px !important;
	  width: 100%;
	  justify-content: center;
	}
	.ha-modal-content__title,
	.ha-modal-content__description {
		text-align: center;
	}
}

@media (max-width: 500px) {
	.ha-modal-popup-content-wrapper.ha-modal-fullscreen.ha-modal-show .ha-modal-animation {
	    height: fit-content;
	    max-height: 55vh !important;
    	width: 90vw !important;		
		padding: 2rem !important;
	}	
}


/* Disable background scrolling when modal is open */
body.modal-open {
    overflow: hidden !important;
}



/* *****************************
 * LEARN TO DIVE STICKY BUTTON
 * *************************** */
.shop-dive-class .elementor-button {
	min-width: 300px;
}