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

/* *****************************
 * BUTTON ADDITIONAL STYLING
 * *************************** */
a.elementor-button-link.elementor-button  {
  background: linear-gradient(90deg, #353931, transparent) #353931 !important;
  transition: all 1s ease !important;
  background-size: 100% auto !important;
}
a.elementor-button-link.elementor-button:hover, a.elementor-button-link.elementor-button:focus {
  background-color: #1D1513 !important;
  background-position: right center !important;
  background-size: 200% auto !important;	
}
.btn-brown a.elementor-button-link.elementor-button  {
  background: linear-gradient(90deg, #1D1513, transparent) #1A1311 !important;
  transition: all 1s ease !important;
  background-size: 100% auto !important;
}
.btn-lt-green a.elementor-button-link.elementor-button {
  background-color: #62725F !important;
  background-position: right center !important;
 background-size: 200% auto !important;	
}	
.btn-cat a.elementor-button-link.elementor-button {
  background-position: right center !important;
 background-size: 250% auto !important;	
}	
.btn-cat:hover a.elementor-button-link.elementor-button {
  background-position: right center !important;
 background-size: 150% auto !important;	
}	
.btn-cat.trailer a.elementor-button-link.elementor-button {
  background-color: #D2CDB1 !important;
  color: #1D1513 !important;
}	
.btn-cat.manual a.elementor-button-link.elementor-button {
  background-color: #C1B9AE !important;
}	
.btn-cat.rv a.elementor-button-link.elementor-button {
  background-color: #354A37 !important;
}	
.btn-cat.windlass a.elementor-button-link.elementor-button {
  background-color: #04343A !important;
}	
.btn-hover-brown a.elementor-button-link.elementor-button:hover, .btn-hover-brown a.elementor-button-link.elementor-button:focus {
  background-color: #1D1513 !important;
  background-position: right center !important;
  background-size: 200% auto !important;	
}
.btn-hover-lt-green a.elementor-button-link.elementor-button:hover, .btn-hover-lt-green a.elementor-button-link.elementor-button:focus {
  background-color: #62725F !important;
  background-position: right center !important;
  background-size: 200% auto !important;	
}
.btn-hover-green a.elementor-button-link.elementor-button:hover, .btn-hover-green a.elementor-button-link.elementor-button:focus {
  background-color: #354A37 !important;
  background-position: right center !important;
  background-size: 200% auto !important;	
}
.btn-hover-blue a.elementor-button-link.elementor-button:hover, .btn-hover-blue a.elementor-button-link.elementor-button:focus {
  background-color: #04343A !important;
  background-position: right center !important;
  background-size: 200% auto !important;	
}
.btn-hover-tan a.elementor-button-link.elementor-button:hover, .btn-hover-tan a.elementor-button-link.elementor-button:focus {
  background-color: #D2CDB1 !important;
  background-position: right center !important;
  background-size: 200% auto !important;	
} 

/* GRADIENT BUTTON STYLE ELEMENT - like Heading Button in Home Hero */
.gradient-button-brown-green .elementor-widget-container {
    background-color: transparent !important;
}
.gradient-button-brown-green .elementor-widget-container:before {
	position: absolute;
	content: "";
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: -1;
	opacity: 0;
	background-image: linear-gradient(90deg, #353931 10%, #354A37 100%);
	transition: all 0.5s ease-in-out !important;
	z-index: 0;
	border-radius: inherit;	
}
.gradient-button-brown-green:hover .elementor-widget-container:before {
	opacity: 1 !important;
}
.round-right .elementor-widget-container {
	border-radius: 0rem 5rem 5rem 0rem !important;	
}
.round-left .elementor-widget-container {
	border-radius: 5rem 0rem 0rem 5rem !important;	
}


/* ******************************
 * 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: 768px) {
	/* 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; 
} */


/* ******************************
 * 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: 768px) {
	/* 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: 768px) {
	/* 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
 * *************************** */
@media (max-width: 768px) {
	.mobile-center .elementor-icon-list-item,
	.mobile-center .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: #EEEEEE !important;
}
.jx-ac-inactive .jx-single-accordion-header {
    border-color: transparent !important;
}

/* Toggle Icons */
.jupiterx-single-advanced-accordion-wrapper.jx-ac-inactive i.jx-ac-icon-body-closed {
	display: block !important;
    transition: all .5s ease-in-out;
    transform: rotate(0deg);
}
.jupiterx-advanced-accordion-wrapper .jupiterx-advanced-accordion-inner-wrapper .jx-ac-active .jx-ac-icon-body-closed {
	display: block !important;
}
.jupiterx-single-advanced-accordion-wrapper.jx-ac-active i {
    transition: all .5s ease-in-out;
    transform: rotate(90deg);
}



/* *****************************
 * 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;    
}
 
/* TESTIMONIALS - SWIPER PAGINATION BULLET */
.testimonials span.swiper-pagination-bullet.swiper-pagination-bullet-active {
    border: 2px solid #fff !important;
}


/* *****************************
 * LARGE CENTERED TEXT
 * *************************** */
.centered-text h2 {
    font-size: 10vw;
    white-space: nowrap;
    text-align: center;
    margin: 0 !important; 
    position: absolute !important;
    left: 50% !important;
    transform: translate(-50%, -35%) !important;
}


/* *****************************
 * ACCORDION
 * *************************** */
.elementor-widget-n-accordion .e-n-accordion-item .e-n-accordion-item-title-icon i:before {
    transition: all .5s ease;
}
body:not(.woocommerce) .elementor-widget-n-accordion .e-n-accordion-item-title {
  background: linear-gradient(90deg, #353931 2%, transparent) #353931 !important;
  transition: all 1s ease !important;
  background-size: 300% auto !important;
  background-position: right center !important;	
}
body:not(.woocommerce) .elementor-widget-n-accordion .e-n-accordion-item-title:hover,
body:not(.woocommerce) .elementor-widget-n-accordion .e-n-accordion-item-title:focus {
  background-color: #1D1513 !important;
  background-position: right center !important;
  background-size: 150% auto !important;	
}

body:not(.woocommerce) .elementor-widget-n-accordion.acc-trailer .e-n-accordion-item-title {
  background: linear-gradient(90deg, #9E9A85, transparent) #D2CDB1 !important;
  transition: all 1s ease !important;
  background-size: 250% auto !important;
  background-position: right center !important;	
  color: #1D1513 !important;	
}
body:not(.woocommerce) .elementor-widget-n-accordion.acc-trailer .e-n-accordion-item-title:hover,
body:not(.woocommerce) .elementor-widget-n-accordion.acc-trailer .e-n-accordion-item-title:focus {
  background-color: #D2CDB1 !important;	
  background-size: 100% auto !important;	
}	

body:not(.woocommerce) .elementor-widget-n-accordion.acc-manual .e-n-accordion-item-title {
  background: linear-gradient(90deg, #9A948B, transparent) #C1B9AE !important;
  transition: all 1s ease !important;
  background-size: 250% auto !important;
  background-position: right center !important;	
  color: #1D1513 !important;	
}
body:not(.woocommerce) .elementor-widget-n-accordion.acc-manual .e-n-accordion-item-title:hover,
body:not(.woocommerce) .elementor-widget-n-accordion.acc-manual .e-n-accordion-item-title:focus {
  background-color: #C1B9AE  !important;	
  background-size: 100% auto !important;	
}	

body:not(.woocommerce) .elementor-widget-n-accordion.acc-rv .e-n-accordion-item-title {
  background: linear-gradient(90deg, #1D291E, transparent) #354a37 !important;
  transition: all 1s ease !important;
  background-size: 250% auto !important;
  background-position: right center !important;	
}
body:not(.woocommerce) .elementor-widget-n-accordion.acc-rv .e-n-accordion-item-title:hover,
body:not(.woocommerce) .elementor-widget-n-accordion.acc-rv .e-n-accordion-item-title:focus {
  background-color: #354A37  !important;	
  background-size: 100% auto !important;	
}


body:not(.woocommerce) .elementor-widget-n-accordion.acc-windlass .e-n-accordion-item-title {
  background: linear-gradient(90deg, #021A1D, transparent) #04343A !important;
  transition: all 1s ease !important;
  background-size: 250% auto !important;
  background-position: right center !important;	
}
body:not(.woocommerce) .elementor-widget-n-accordion.acc-windlass .e-n-accordion-item-title:hover,
body:not(.woocommerce) .elementor-widget-n-accordion.acc-windlass  .e-n-accordion-item-title:focus {
  background-color: #04343A  !important;	
  background-size: 100% auto !important;	
}




/* *****************************
 * WST TABLE
 * *************************** */
:root {
    --bg-table-stripe: #f6f6f5;
    --b-table: #e3e3e2;
    --header-bg: #1D1513;
    --header-text: #E2E1DD;
}

.dcf-overflow-x-auto {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    width: 100%;
}

/* Base table styling */
.dcf-table {
    background-color: transparent;
    border-collapse: collapse;
    width: 100%;
}
.dcf-table-bordered, .dcf-table-bordered td, .dcf-table-bordered th {
    border: 1px solid var(--b-table);
}
.dcf-table thead {
    background-color: var(--header-bg);
    color: var(--header-text);
    font-size: max(15px, 1.25rem);
	font-weight: bold;
}
.dcf-table tbody {
    border-bottom: 1px solid var(--b-table);
    border-top: 1px solid var(--b-table);
    font-size: max(15px, 1.13rem);
}
.dcf-table th {
    padding: .75em;
    text-align: left;
}
.dcf-table td {
    padding: .5em;
    text-align: left;
    vertical-align: top;
}
.dcf-table tr:not(:last-child) {
    border-bottom: 1px solid var(--b-table);
}

/* Dark first column (th in tbody) with white text */
.dcf-table th[scope="row"] {
    background-color: var(--header-bg);
    color: var(--header-text);
}

/* Striped rows (desktop and mobile) on TDs */
.dcf-table-striped tbody tr:nth-of-type(2n) td {
    background-color: var(--bg-table-stripe);
}
.dcf-table-striped tbody tr:nth-of-type(2n+1) td {
    background-color: #ffffff;
}

/* Desktop Styling (1441px and above) - Horizontal Scrollbar */
@media (min-width: 1441px) {
    .dcf-table {
        overflow-x: auto;
    }
}

/* Mobile/Tablet Styling (Below 1440px) - Vertical Stacking, No Horizontal Scrollbars, with Striping on TDs */
@media (max-width: 1440px) {
    .dcf-overflow-x-auto .dcf-table thead {
        clip: rect(0 0 0 0);
        -webkit-clip-path: inset(50%);
        clip-path: inset(50%);
        height: 1px;
        overflow: hidden;
        position: absolute;
        width: 1px;
        white-space: nowrap;
    }
	.dcf-table th {
		font-size: max(18px, 1.15rem) !important;
	}	
    .dcf-overflow-x-auto .dcf-table tr {
        display: block;
        margin-bottom: .75em;
    }
    .dcf-overflow-x-auto .dcf-table th[scope="row"], .dcf-overflow-x-auto .dcf-table td {
        display: block;
        width: 100%;
        -webkit-column-gap: 0;
        -moz-column-gap: 0;
        column-gap: 0;
        text-align: left !important;
        border-top-width: 0;
        padding-right: 0;
    }
    .dcf-overflow-x-auto .dcf-table th[scope="row"]:before {
        content: "MODEL: ";
        float: left;
        font-weight: 700;
        padding-right: 1.78em;
    }
    .dcf-overflow-x-auto .dcf-table td:before {
        content: attr(data-label) ": ";
        float: left;
        font-weight: 700;
        padding-right: 1.78em;
    }
    .dcf-overflow-x-auto .dcf-table.dcf-table-bordered, .dcf-overflow-x-auto .dcf-table.dcf-table-bordered thead th {
        border-width: 0;
    }
    .dcf-overflow-x-auto .dcf-table.dcf-table-bordered tbody td {
        border-top-width: 0;
    }
    .dcf-overflow-x-auto .dcf-table:not(.dcf-table-bordered) tbody tr {
        padding-bottom: .75em;
    }
    .dcf-overflow-x-auto .dcf-table:not(.dcf-table-bordered) tbody td {
        padding-bottom: 0;
    }
    .dcf-overflow-x-auto .dcf-table:not(.dcf-table-bordered):not(.dcf-table-striped) tbody td {
        padding-right: 0;
    }
    .dcf-overflow-x-auto .dcf-table.dcf-table-bordered tbody tr:last-child td:last-child {
        border-bottom-width: 0;
    }

    /* Final striping colors (uncomment or replace test colors after verifying) */
    .dcf-overflow-x-auto .dcf-table.dcf-table-striped tbody tr td:nth-of-type(2n) {
        background-color: var(--bg-table-stripe) !important;
    }
    .dcf-overflow-x-auto .dcf-table.dcf-table-striped tbody tr td:nth-of-type(2n+1) {
        background-color: #ffffff !important;
    }
}


