/*
 Theme Name:   STACKING.NYC Child Theme
 Author:       MSonder
 Template:     twentynineteen
version: 1.2.3
*/

* {
	-webkit-box-sizing: border-box; /* Safari/Chrome, other WebKit */
	-moz-box-sizing: border-box;    /* Firefox, other Gecko */
	box-sizing: border-box;         /* Opera/IE 8+ */
}

html, body {  
	margin: 0px;
	
	border: 0px;
	padding: 0px;
	margin-top: 0px !important;
	
	text-align: left;

	-webkit-font-smoothing: antialiased; /* Fix for webkit rendering */
    -webkit-text-size-adjust: none;
	text-rendering: optimizelegibility;

	color: #000;
	font-family: "Outfit", sans-serif;
	font-size: 20px;
	line-height: 26px;

	background: #fff;
}

body:not(.custom-background-image).admin-bar::before {top: 0px;}
body:not(.custom-background-image)::before, body:not(.custom-background-image)::after {height: 0px;}

body.admin-bar {
  padding-top: 32px;
}

@media screen and (max-width: 782px) {
  body.admin-bar {
    padding-top: 46px;
  }
}



a {outline:none;}

ul {padding-top: 0px; margin-top: 0px;}

:root {overflow-y: scroll !important;}
::-moz-selection {
    background: #393939;
	color: #6a6a6a;
    text-shadow: none;
}

::selection {
    background: #393939;
	color: #6a6a6a;
    text-shadow: none;
}

.right {float:right !important;}
.left {float:left !important;}
.clear {clear:both;}
img.right {float:right !important; margin:0 0 20px 20px !important;}
img.left {float:left !important; margin:0 20px 20px 0 !important;}
img {border: none;}

img.alignright {float:right; margin:0 0 1em 1em;}
img.alignleft {float:left; margin:0 1em 1em 0;}
img.aligncenter {display: block; margin-left: auto; margin-right: auto;}
.alignright {float:right; }
.alignleft {float:left; }
.aligncenter {display: block; margin-left: auto; margin-right: auto;}

.responsive {width: 90%;}

/*	--------------------------------------------------
	:: Structure
	-------------------------------------------------- */

		#header-wrapper {
			width: 100%;
			height: auto;
			background: #000000;
			border-bottom: 3px solid #353535;
		}
		#header {
			width: 90%; 
			height: auto;
			margin: 0 auto;
			display: flex;
			align-items: center;
			justify-content: space-between;
			flex-wrap: nowrap;
		}

		#logo {flex: 0 1 auto;}
		#logo img {
			max-width: 320px;
			width: 100%;
		}
		.menu-content {
			flex: 1;
			display: flex;
			justify-content: flex-end;
		}
 				
			/* Options - Social */
			ul.social-media-icons {width: 30%; list-style: none; text-align: right !important; margin: 0 !important; padding: 0;}
			ul.social-media-icons li {display: inline; padding: 2px 5px 0px 0px; margin: 0 !important;}
			ul.social-media-icons a i {
				font-size: 18px;
				width: 35px;
				height: 35px;
				line-height: 35px;
				text-align: center;
				background: #083d62;
				color: #91f8fc;
				border-radius: 6px;
			}
			ul.social-media-icons li a:hover {opacity: 0.8; text-decoration: none !important;}


		.content-wrapper {
			width: 100%;
			height: auto;
			margin: 0px auto;
            overflow-x: hidden !important;
		}
		.content-wrapper a {color: #DF0202; text-decoration: underline; line-height: 20px;}
		.content-wrapper .has-link-color a {color: inherit;}
		.content-wrapper a:hover {color: #BE0303; text-decoration: none;}
				
		
		.wp-block-cover.alignfull {
			max-width: 100vw;
			width: auto;
			padding: 80px 0 60px 0;
            overflow-x: hidden !important;
		}
		.alignfull .wp-block-cover__inner-container {max-width: 1200px;}

        .wp-block-columns.is-layout-flex {gap: 2em !important;}

		.wp-block-cover.has-parallax,
        .wp-block-cover__image-background.has-parallax {background-attachment: fixed !important;}

        .cta {
            background: #ffffff;
            -webkit-box-shadow: 0 0 20px 0 rgba(0,0,0,.2);
            box-shadow: 0 0 20px 0 rgba(0,0,0,.2);
            padding: 20px;
			border-radius: 6px;
        }

        .darkcta {
            background: #151515;
            border: 2px solid #353535;
            padding: 20px;
			border-radius: 6px;
        }

		.home ul.wc-block-product-categories-list {
			display: flex;
			flex-wrap: wrap;
			gap: 20px;
			list-style: none;
			margin: 0;
			padding: 0;
		}

		.home ul.wc-block-product-categories-list > li.wc-block-product-categories-list-item {
			width: calc(20% - 16px); /* 5 col w/ gap */
			margin: 0;
			text-align: center;
		}

		.home ul.wc-block-product-categories-list > li a {
			display: block;
			padding: 20px 10px;
			background: #151515;
			border: 2px solid #353535;
			border-radius: 6px;
			text-decoration: none;
			color: inherit;
			font-size: 14px; 
			text-transform: uppercase;
			font-weight: 500;
			transition: all 0.2s ease;
		}
		.home ul.wc-block-product-categories-list > li a:hover {background: #eeeeee; color: #DF0202; transform: translateY(-5px);}

		@media (max-width: 1024px) {
		  .home ul.wc-block-product-categories-list > li {width: calc(33.333% - 14px) !important;}
		}
		@media (max-width: 681px) {
		  .home ul.wc-block-product-categories-list > li {width: calc(50% - 10px) !important;}
		}
		@media (max-width: 381px) {
		  .home ul.wc-block-product-categories-list > li {width: calc(100% - 0px) !important;}
		}




/*	--------------------------------------------------
	:: Navigation (FULL CSS w/ DROPS)
	-------------------------------------------------- */
		
	button#menuToggle {display: none;}

	ul.menu {margin: 0; padding: 0px 0 0 0;}
	
	ul.menu li {list-style: none; position: relative; float: left;}
	ul.menu li:last-child a {
		background: #df0202 !important;
		font-family: "Oswald", sans-serif;
		letter-spacing: 1px;
		font-size: 16px;
		color: #fff !important;
		padding: 0 15px;
		margin-left: 10px;
	}
	ul.menu li:last-child a:hover {background: #bd0000; color: #f7e9e9 !important;}

	ul.menu li:nth-last-child(2) a {
		line-height: 46px;
		font-family: "Oswald", sans-serif;
		letter-spacing: 1px;
		font-size: 16px;
		color: #fff !important;
		border: 2px solid #fff;
		padding: 0 15px;
	}
	ul.menu li:nth-last-child(2) a i {font-size: 14px; padding-right: 4px; vertical-align: center;}
	ul.menu li:nth-last-child(2) a:hover {color: #f83c3c !important; border: 2px solid #f41919;}

	ul.menu li:hover {cursor: default;}
	ul.menu li a {
		display: block;
		line-height: 50px;
		font-size: 15px;
		font-weight: 500;
	  	text-align: center;
		padding: 0 10px;
		width: 100%;
		color: #fff;
		text-transform: uppercase;
		text-decoration: none;
			-webkit-transition: all 0.25s ease-in-out;
			-moz-transition: all 0.25s ease-in-out;
			-o-transition: all 0.25s ease-in-out;
			transition: all 0.25s ease-in-out;
		}
	ul.menu li a:hover, ul.menu li.current-menu-item a, ul.menu li a:focus {background: #181818; transform: translateY(-3px);}

    ul.menu li.menu-item-has-children a:after {
        content: '\f0d7';
        font-family: "Font Awesome 6 Pro";
        font-style: normal;
        font-weight: 600;
        padding-left: 10px;
        font-size: 14px;
        color: #df0202;
    }
	ul.menu li ul {
		position: absolute;
		left: -9999em;
		width: auto;
		margin: 0;
		padding: 0;
		list-style-type: none;
		white-space: nowrap;
	}

    ul.menu li:hover ul {
        left: 0;
        -webkit-box-shadow: -10px 0px 13px -7px #c7c7c7, 10px 0px 13px -7px #c7c7c7, 5px 5px 7px 5px rgba(181, 181, 181, 0);
        box-shadow: -10px 0px 13px -7px #c7c7c7, 10px 0px 13px -7px #c7c7c7, 5px 5px 7px 5px rgba(181, 181, 181, 0);
    }
    ul.menu li:hover ul li {
        float: none;
        width: 100%;
        position: relative;
        z-index: 9999;
    }
    ul.menu li:hover ul li a,
	ul.menu li:last-child:hover ul li a {
        display: block;
        line-height: 45px;
        font-size: 18px;
        font-weight: 500;
        text-transform: none;
        text-shadow: none;
        text-align: left !important;
        padding: 0 30px 0 10px;
        background: #fff;
        border-bottom: 2px solid #fff;
        width: 100%;
        color: #000;
        text-decoration: none;
    }
    ul.menu li:hover ul li a:hover {
        background: #eeeeee;
        border-bottom: 2px solid #ebeef3;
    }

     /* sub menu fix */
	ul.menu li:hover ul li:last-child a,
	ul.menu li:hover ul li:nth-last-child(2) a {
		background: #fff !important;
		color: #000 !important;
		text-transform: none;
		font-family: "Outfit", sans-serif; 
		font-weight: 500;
		margin-left: 0px;
		border-radius: 0px;
	}
	ul.menu li:hover ul li:last-child a:hover,
	ul.menu li:hover ul li:nth-last-child(2) a:hover {background: #eeeeee !important; border: none; border-bottom: 2px solid #ebeef3;}

   ul.menu li.menu-item-has-children:hover ul li a:after {
        content: '';
        display: none;
    }


	/* === CART MENU ITEM - START === */
	li.ez-cart-menu-item a.ez-cart-link {
		display: flex !important;
		align-items: center;
		/*gap: 8px;  space between "Cart", icon, and count badge */
	}
	li.ez-cart-menu-item .fa-cart-shopping {font-size: 14px; padding-right:4px;}
	li.ez-cart-menu-item .ez-cart-count {
		background: #fff;
		color: #df0202;
		font-size: 12px;
		font-weight: 700;
		line-height: 1;
		min-width: 18px;
		height: 18px;
		border-radius: 50%;
		display: flex;
		align-items: center;
		justify-content: center;
		padding: 2px;
		margin-left: 5px;
		
	}
	/* === CART MENU ITEM - END === */



/*	--------------------------------------------------
	:: Footer
	-------------------------------------------------- */


		#footer-wrapper {
			height: auto; 
			width: 100%;
			background: #000000;
		}		
		#footer {
			height: auto; 
			width: 90%;
			margin: 0 auto;
			padding: 30px 0;
			background: #000000;
			font-family: "Outfit", sans-serif;
			font-size: 14px; 
			line-height: 22px; 
			color: #ffffff;
			
			display: flex;
			align-items: center;
			gap: 10px;
		}
		#footer a {color: #ffffff; text-decoration: none;}
		#footer a:hover {color: #cfcfcf; text-decoration: underline;}

		#footer .right-group {
			margin-left: auto;
			display: flex;
			flex-direction: row;
			gap: 80px;
			align-items: flex-start;
		}

			/* Options - Footer Social */
			#footer ul.social-icons {list-style: none; margin: 0 !important; padding: 0;}
			#footer ul.social-icons li {display: inline; padding: 0px; margin: 2px !important;}
			#footer ul.social-icons a i {
				font-size: 22px !important;
				width: 45px;
				height: 45px;
				line-height: 45px;
				border-radius: 150px;
				text-align: center;
				color: #fff;
				background: #df0202;
			}
			#footer ul.social-icons li a:hover {opacity: 0.8; text-decoration: none !important;}


	        .footer-heading {
                color: #fff;
                font-family: "Outfit", sans-serif;
                font-size: 22px;
                line-height: 30px;
                font-weight: 700;
                margin: 0px;
                padding: 0px;
                margin-bottom: 15px;
            }
            ul.footer-menu {
              width: 100%;
              list-style: none;
              margin: 0 !important;
              padding: 0;
            }
            ul.footer-menu li {
              padding: 0px;
              font-size: 18px;
              margin: 0px;
            }
            ul.footer-menu li:hover {opacity: 0.8; text-decoration: none !important;}
            ul.footer-menu li a { font-size: 18px; font-weight: 500; color: #9b9b9b !important; text-decoration: none !important;}
            ul.footer-menu li a:hover {color: #c0c0c0 !important; text-decoration: underline !important;}


	
		#copyright-wrapper {
			height: auto; 
			width: 100%;
			background: #181818;
		}	
		#copyright {
			height: auto; 
			width: 90%;
			margin: 0 auto;
			padding: 30px 0;
			background: #181818;
			font-family: "Outfit", sans-serif; 
			font-size: 14px; 
			line-height: 18px; 
			color: #888888;
		}
		#copyright a {color: #888888; text-decoration: none;}
		#copyright a:hover {color: #888888; text-decoration: underline;}
				
        #copyright .g50:nth-child(2) {text-align: right !important;}






/*	--------------------------------------------------
	:: Elements
	-------------------------------------------------- */
	ul.checkmark {
		--icon-space: 1.3em;
		list-style: none;
		padding: 0;
	}
	ul.checkmark li {padding-left: var(--icon-space);}

	ul.checkmark li:before {
		content: "\f00c"; 
		color: #bb964e;
        font-family: "Font Awesome 6 Pro";
		font-weight: 700;
		display: inline-block;
		margin-left: calc( var(--icon-space) * -1 );
		width: var(--icon-space);
		padding-right: 15px;
	}

h1:not(.site-title)::before, h2::before{
	background: none !important;
	content: none !important;
	height: 0px !important;
	margin: 0 !important;
	width: 0 !important;
}
	
.home h1, .home .wp-block-cover h1:not(.has-text-color) {
	color: #fff;
	text-shadow: 0 0 20px #000000;
}
.home h1 mark {
	font-size: 48px;
	text-transform: uppercase;
}

h1, .wp-block-cover h1:not(.has-text-color) {
	color: #000;
	font-family: "Outfit", sans-serif;
	font-size: 60px;
	line-height: 72px;
	margin: 0px;
	padding: 0px;
	margin-bottom: 25px;
}

h2, .wp-block-cover h2:not(.has-text-color) {
	color: #000;
	font-family: "Outfit", sans-serif;
	font-size: 48px;
	line-height: 52px;
	margin: 0px;
	padding: 0px;
	margin-bottom: 25px;
}

h3, .wp-block-cover h3:not(.has-text-color) {
	color: #df0202;
	font-family: "Outfit", sans-serif;
	font-size: 36px;
	margin: 0px;
	padding: 0px;
	line-height: 40px;
	margin-bottom: 25px;
}


p {
	margin: 0px;
	padding: 0px 0px 15px 0px;
}

hr,
hr.is-style-wide {
	border: 0; 
	height: 4px; 
	background: #dadada;
	text-align: center;
	line-height: 4px;
	font-size: 26px;
	border-bottom: 0px;
	margin: 30px 0 45px 0;
}

hr.wp-block-separator:not(.is-style-wide) { 
	border: 0; 
	height: 4px; 
	background: #dadada;
	text-align: left;
	line-height: 4px;
	font-size: 26px;
	border-bottom: 0px;
	margin: 30px 0 45px 0;
}

	blockquote {	
		border-left: 12px solid #df0202 !important;
		background: #E3E3E3;
		padding: 20px 10px 20px 40px !important;
		hyphens: none;
	}
	blockquote p {padding: 0;}
	
	blockquote cite {
		font-size: 16px; 
		text-transform: uppercase; 
		color: #575757; 
		font-style: italic;
	}


	a.wp-block-button__link {
		display: inline-block;
		background: #df0202;
		font-family: "Oswald", sans-serif;
		letter-spacing: 1px;
		text-transform: uppercase;
		color: #fff !important;
		font-size: 20px;
		font-weight: 500;
		margin: 10px 0;
		padding: 25px 35px;
		border-radius: 6px;
		text-decoration: none !important;
			-webkit-transition: all 0.25s ease-in-out;
			-moz-transition: all 0.25s ease-in-out;
			-o-transition: all 0.25s ease-in-out;
			transition: all 0.25s ease-in-out;
	}
	a.wp-block-button__link:hover {background: #bd0000; color: #f7e9e9 !important; transform: translateY(-5px);}



/*	--------------------------------------------------
	:: Blog Styles
	-------------------------------------------------- */

.hentry {padding: 0px !important;}

.sidebar .entry-header, .sidebar .entry-content, .sidebar .entry-summary, .sidebar .entry-meta {
    max-width: 1040px;
    padding: 0 0px 0 0px !important;
}

.widget {
    background-color: #ececec;
	border: 1px solid #d2d2d2;
	font-size: 18px;
    margin: 0 0 24px;
    padding: 10px;
	border-radius: 6px;
}

.widget li {
    padding: 10px 15px;
	background: #c2ccd4;
	margin: 0 0 10px;
	font-family: "Outfit", sans-serif;
}
.widget li:hover {background: #a4b7c7;}


.widget li a {
	color: #0b304c !important;
    line-height: 20px;
    text-decoration: underline;
	font-size: 16px;
	/*text-transform: uppercase !important;*/
}

.widget .widget-title {
	font-family: "Outfit", sans-serif;
    margin: 0 0 10px !important;
    padding: 5px 10px !important;
	background: #2e74a9 !important;
	color: #fff !important;
	font-style: normal !important;
	text-transform: uppercase !important;
}




/*	--------------------------------------------------
	:: WooCommerce Styles
	-------------------------------------------------- */


.wc_payment_methods img {width: auto !important; height: auto;}

nav.woocommerce-breadcrumb {margin: 30px 0 !important; }

.woocommerce-info a, .woocommerce-error a {color: #fff !important; } 

.woocommerce-terms-and-conditions-wrapper {display: none;}

ul.products li.product .woocommerce-loop-product__title {
	line-height: 25px !important;
	display: block;
	min-height: 100px;
}

.woocommerce-page.product-template-default .entry {
	margin-top: 50px !important;
}


/* WooCommerce buttons — Twenty Nineteen theme */

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #place_order {
	background: #df0202 !important;
	color: #fff !important;
}

/* Hover state */
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce #place_order:hover {
	background: #bd0000; color: #f7e9e9 !important;
}

ul.products  {
	padding: 20px 0 !important;
}

a.remove {
	color: #fff;
	line-height: 17px !important;
	text-decoration: none !important;
}
/* 
.woocommerce-checkout-review-order ul {
	list-style: none;
}
*/

.woocommerce ul.products li.product, .woocommerce-page ul.products li.product {
  border: 1px solid #d2d2d2;
  text-align: center;
  padding: 5px 5px 15px 5px;
  border-radius: 6px;
}


.facetwp-facet-price .facetwp-slider-reset {display: none !important; }

#woo-sidebar h3 {
	font-size: 24px;
	line-height: normal;
	margin-bottom: 10px !important; 
}

input.facetwp-search {background-color: #fff !important;}

/* === TWENTY NINETEEN - WOOCOMMERCE OVERRIDES - START === */

/* Remove Twenty Nineteen's blog-width constraint */
.woocommerce .content-area .site-main,
.woocommerce-page .content-area .site-main {
    max-width: 100% !important;
    width: 100% !important;
}

/* Clearfix - .g100 contains floated children (.g25 and .g75)
   without this the .g100 wrapper collapses to zero height */
.g100::after {
    content: "";
    display: table;
    clear: both;
}

/* === TWENTY NINETEEN - WOOCOMMERCE OVERRIDES - END === */


/* === WOOCOMMERCE PRODUCT TABS - START === */

/* Remove default WooCommerce tab styling */
.woocommerce div.product .woocommerce-tabs ul.tabs {
    padding: 0 !important;
    margin: 0 !important;
    list-style: none;
    display: flex;
    gap: 4px;
    border-bottom: 3px solid #df0202 !important;
}

/* Remove the default ::before squiggle line WooCommerce adds */
.woocommerce div.product .woocommerce-tabs ul.tabs::before {
    display: none !important;
    border: none !important;
}

/* Each tab */

.woocommerce-tabs.wc-tabs-wrapper h2 {
	display: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
    background: #e8e8e8 !important;
    border: 1px solid #d0d0d0 !important;
    border-bottom: none !important;
    border-radius: 6px 6px 0 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    position: relative;
    bottom: -1px;
}

/* Tab link */
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    display: block;
    padding: 10px 20px !important;
    font-size: 15px;
    font-weight: 600;
    color: #444 !important;
    text-decoration: none !important;
    text-transform: none;
    white-space: nowrap;
}

/* Tab hover */
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
    color: #df0202 !important;
    background: transparent;
}

/* Active tab */
.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
    background: #df0202 !important;
    border-color: #df0202 !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
    color: #fff !important;
}

/* Tab content panel - border on 3 sides to match the tab line */
.woocommerce div.product .woocommerce-tabs .panel {
    border: 1px solid #d0d0d0 !important;
    border-top: none !important;
    padding: 20px !important;
    margin: 0 !important;
}

/* === WOOCOMMERCE PRODUCT TABS - END === */


/* === WOOCOMMERCE INPUT AND BUTTON RESET - START ===
   Scoping to .woocommerce and .woocommerce-page undoes the generic
   styles above for ALL WooCommerce elements without listing every
   WooCommerce class individually. Add WooCommerce-specific styles
   here rather than in the generic block above. */

.woocommerce button:not(.dgwt-wcas-search-submit),
.woocommerce input[type="submit"],
.woocommerce input[type="button"],
.woocommerce-page button:not(.dgwt-wcas-search-submit),
.woocommerce-page input[type="submit"],
.woocommerce-page input[type="button"] {
    background: #df0202 linear-gradient(to bottom, #df0202 0%, #df0202 100%) !important;
    font-family: "Outfit", sans-serif;
}

.woocommerce button:not(.dgwt-wcas-search-submit):hover,
.woocommerce button:not(.dgwt-wcas-search-submit):focus,
.woocommerce input[type="submit"]:hover,
.woocommerce input[type="submit"]:focus,
.woocommerce-page button:not(.dgwt-wcas-search-submit):hover,
.woocommerce-page button:not(.dgwt-wcas-search-submit):focus,
.woocommerce-page input[type="submit"]:hover,
.woocommerce-page input[type="submit"]:focus {
    background: #bd0000 linear-gradient(to bottom, #bd0000 0%, #bd0000 100%) !important;
}

.woocommerce input:not([type="submit"]):not([type="button"]):not([type="checkbox"]):not([type="radio"]):not(.min):not(.max):not(.facetwp-slider-reset):not(.facetwp-search),
.woocommerce textarea,
.woocommerce select,
.woocommerce-page input:not([type="submit"]):not([type="button"]):not([type="checkbox"]):not([type="radio"]):not(.min):not(.max):not(.facetwp-slider-reset):not(.facetwp-search),
.woocommerce-page textarea,
.woocommerce-page select {
    background: #efefef !important;
    border: 2px solid #e7e7e7 !important;
    padding: 10px !important;
    width: 100%;
    font-family: inherit;
}

.woocommerce select,
.woocommerce-page select {
    padding: 14px !important;
}


.wc-block-product-filter-price-slider .text input[type="text"] {
	max-width: 75px !important;
}

/* === WOOCOMMERCE INPUT AND BUTTON RESET - END === */

/* Revert my previous flex changes - let FiboSearch
   use its own absolute positioning system */
.dgwt-wcas-search-form {
    display: block !important;
    position: relative !important;
}

/* Input fills the full width with padding-right
   to leave room for the icon */
.dgwt-wcas-search-input {
    width: 100% !important;
    padding-right: 40px !important;
    order: unset !important;
    box-sizing: border-box !important;
}

/* Pin the icon to the right, vertically centered */
button.dgwt-wcas-search-submit {
    position: absolute !important;
    right: 8px !important;
    left: auto !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    float: none !important;
    order: unset !important;
}

/* === FIBOSEARCH - ICON POSITION RIGHT - END === */

/* Breadcrumb + FiboSearch row */
.ezm-breadcrumb-search-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 16px;
}

.ezm-breadcrumb-wrap {
    flex: 1 1 auto;
}

.ezm-fibosearch-wrap {
    flex: 0 0 auto;
    min-width: 220px;
    max-width: 340px;
    width: 100%;
}

/* Optional: keep the search input from overflowing */
.ezm-fibosearch-wrap .dgwt-wcas-search-wrapp {
    width: 100%;
}

/* Responsive: stack on small screens */
@media ( max-width: 600px ) {
    .ezm-breadcrumb-search-bar {
        flex-direction: column;
        align-items: flex-start;
    }

    .ezm-fibosearch-wrap {
        min-width: 100%;
        max-width: 100%;
    }
}




/*	--------------------------------------------------
	:: Grid 
	-------------------------------------------------- */

div.content > div img {width: 100%;}
 /* Override */.no-full {width: auto !important;}
 

.g10, .g20, .g30, .g40, .g50, .g60, .g70, .g80, .g90, .g100, .g33, .g25, .g75 {
	height:auto;
	float:left;
}
.g10 {width:10%;}
.g20 {width:20%;}
.g30 {width:30%;}
.g40 {width:40%;}
.g50 {width:50%;}
.g60 {width:60%;}
.g70 {width:70%;}
.g80 {width:80%;}
.g90 {width:90%;}
.g100 {width:100%;}

.g33 {width:33.33333333%;}
.g25 {width:25%;}
.g75 {width:75%;}

.padding {padding: 10px 15px;}





/*	--------------------------------------------------
	:: Form Styles
	-------------------------------------------------- */

.ginput_container input, .ginput_container textarea, .ginput_container select {width: 100%;}

input:not(.dgwt-wcas-search-input):not(.min):not(.max):not(.facetwp-slider-reset):not(.facetwp-search), textarea, select:not(.dgwt-wcas-search-input) {
	background: #efefef !important;
	border: 2px solid #e7e7e7 !important;
    font-family: inherit;
    padding: 10px !important;
	width: 100%;
}
select:not(.dgwt-wcas-search-input) {padding: 14px !important;}
input[type="checkbox"], input[type="radio"] {
	width: auto;
}
input:not(.dgwt-wcas-search-input):not(.min):not(.max):not(.facetwp-slider-reset):not(.facetwp-search):focus, textarea:focus, select:not(.dgwt-wcas-search-input):focus {
	background: #e7e7e7 !important;
	border: 2px solid #e7e7e7 !important;
    font-family: inherit;
    padding: 10px !important;
}
select:focus {padding: 14px !important;}

    .gform_wrapper.gravity-theme .ginput_container_address span {
		flex: 0 0 100%;
	}
	.ginput_complex.ginput_container_address .address_city {
		width: 32% !important;
        margin: 0px 1% 0px 1% !important;
		padding: 0 !important;
		display: block;
		float: left;
		flex: unset !important;
	}
	.ginput_complex.ginput_container_address .address_state {
		width: 32% !important;
        margin: 0px 1% 0px 0px !important;
		padding: 0 !important;
		display: block;
		float: left;
		flex: unset !important;
	}
	.ginput_complex.ginput_container_address .address_zip {
		width: 33% !important;
        margin: 0px!important;
		padding: 0 !important;
		display: block;
		float: right;
		flex: unset !important;
	}

button:not(.dgwt-wcas-search-submit), input[type="submit"]:not(.dgwt-wcas-search-submit), input[type="button"]:not(.dgwt-wcas-search-submit), input[type="reset"]
{font-family: "Outfit", sans-serif; background: rgba(0, 0, 0, 0) linear-gradient(to bottom, #df0202 0%, #df0202 100%) repeat scroll 0 0 !important;}
button:not(.dgwt-wcas-search-submit):hover, button:not(.dgwt-wcas-search-submit):focus,
input[type="submit"]:not(.dgwt-wcas-search-submit):hover, input[type="submit"]:not(.dgwt-wcas-search-submit):focus, 
input[type="button"]:not(.dgwt-wcas-search-submit):hover, input[type="button"]:not(.dgwt-wcas-search-submit):focus, 
input[type="reset"]:not(.dgwt-wcas-search-submit):hover, input[type="reset"]:focus
{font-family: "Outfit", sans-serif; background: rgba(0, 0, 0, 0) linear-gradient(to bottom, #bd0000 0%, #bd0000 100%) repeat scroll 0 0 !important;}


button.wp-block-search__button, input.gform_button {
    background: rgba(0, 0, 0, 0) linear-gradient(to bottom, #df0202 0%, #df0202 100%) repeat scroll 0 0 !important;
    border-bottom: 2px solid #df0202 !important;
    color: #eceae0;
    display: inline-block;
    padding: 20px 30px !important;
    font-family: "Outfit", sans-serif;
    text-decoration: none;
	text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 2px;
    font-size: 16px;
    width:auto;
    border-radius: 8px;
}

button.wp-block-search__button:hover, button.wp-block-search__button:focus, 
input.gform_button:hover, input.gform_button:focus
{
    background: rgba(0, 0, 0, 0) linear-gradient(to bottom, #bd0000 0%, #bd0000 100%) repeat scroll 0 0 !important;
    color: #fff !important;
}





/*	--------------------------------------------------
	:: Media Queries
	-------------------------------------------------- */


@media screen and (min-width: 1201px) {
	.responsive {width: 1200px !important;}
	.opensub {display: none;}
} 

@media screen and (max-width: 1200px) {
	
    .alignfull .wp-block-cover__inner-container {max-width: 90%;}

	#header {display: flex;flex-wrap: wrap;}
	#logo {flex: 1;}
	#menuToggle {flex: 0;}
	.menu-content {flex-basis: 100%; /* forces full-width next row */}

	/* ********* Mobile Navigation Styles ********** */
	button#menuToggle {
		display: block;
		border: 0;
		background: #000 !important;
		border-bottom: transparent !important;
		padding: 10px 0;
		width: 100%;
		color: #fff;
		text-align: right;
		font-size: 24px;
		font-weight: 700; 
		border-radius: 0px !important;
	}
	button#menuToggle:hover, #menuToggle:focus {background: #000 !important;}

	.menu-content {display: none;}
	.menu-content .right,
	nav.right {float: none !important;}
	
	ul.menu {background: #000;}
	ul.menu li {float: none; width: 100%;text-align: right;border-bottom: 1px solid #242424;}
	ul.menu li a {color: #fff; text-align: right; font-size: 16px;}
	ul.menu li a:hover,
	ul.menu li.current-menu-item a,
	ul.menu li a:focus {color: #fff; background: #000;}

	/* submenu */
	ul.sub-menu {display: none;}
	ul.menu li ul {
		position: static;
		left: 0;
		width: auto;
	}
	ul.menu li:hover ul li {
		float: none;
		width: 100%;
		position: static;
		text-align: center !important;
	}
	ul.menu li:hover ul li:hover {text-align: center;}
    ul.menu li .opensub {
        color: #fff;
        background: #242424;
        position: absolute;
        left: 0px;
        font-size: 20px;
        top: 0px;
        display: flex;
        align-items: center;
        justify-content: center;
        height: 50px;
        width: 50px;
        cursor: pointer;
    }    
	
	/* sub menu fix */
	ul.menu li:last-child a,
	ul.menu li:nth-last-child(2) a {
		font-family: "Outfit", sans-serif; 
		font-weight: 500;
		margin-left: 0px;
		border-radius: 0px;
		border: none !important;
	}
	
	ul.menu li:last-child a.ez-cart-link {text-align: right !important;}
	ul.menu li:nth-last-child(2) a {color: #df0202 !important;}

   ul.menu li.menu-item-has-children:hover ul li a:after {
        content: '';
        display: none;
    }
	ul.menu li.menu-item-has-children a::after {content: ""}


}

@media screen and (max-width: 800px) {
    	
    #copyright .g50:nth-child(2) {float: none!important; text-align: center;}
	
    #content img.alignright {
        display: block;
        margin: 0px auto;   
        float: none;
        width: auto;
        max-width: 100%;
    }
	
	.g25 {width: 50% !important;}
	.g30 {width: 100% !important;}
	.g33 {width: 100% !important;}
	.g50 {width: 100% !important;}
	.g70 {width: 100% !important;}
	
}

@media screen and (max-width: 600px) {
	.responsive {width: 90% !important;}
}

@media screen and (max-width: 480px) {
	
	.g10 {width: 100% !important;}
	.g20 {width: 100% !important;}
	.g25 {width: 100% !important;}
	.g40 {width: 100% !important;}
	.g60 {width: 100% !important;}
	.g80 {width: 100% !important;}
	.g90 {width: 100% !important;}

}