@import url('https://fonts.googleapis.com/css2?family=Urbanist:ital,wght@0,100..900;1,100..900&display=swap');

:root {
  --dark: rgba(30,34,40, .7);
	--blue: #1b75ba;
	--orange: #e48a45;
}

*{ margin:0; padding:0; list-style: none; outline: 0; }

html { scroll-behavior: smooth; }
body { color: var(--dark); background: #fff; font: 500 18px "Urbanist", sans-serif; }
a { color: var(--orange); text-decoration: none; transition: all 0.2s ease-in-out; cursor: pointer; }

h1 { margin: 0 0 20px 0; font-weight: 600; font-size: 76px; line-height: 1.24em; color: rgba(30,34,40, .9); }
h2 { margin: 0 0 20px 0; font-weight: 800; font-size: 42px; line-height: 1.4em; color: var(--blue); }
h3 { margin: 0 0 20px 0; font-weight: 600; font-size: 40px; line-height: 1.4em; color: rgba(30,34,40, .9); }
h4 { font-weight: 600; font-size: 30px; line-height: 1.4em; color: rgba(30,34,40, .9); }
p { margin: 0 0 20px; line-height: 1.8em; }

input, textarea, select { font: 500 18px "Urbanist", sans-serif; }

em { text-decoration-line: underline; text-decoration-color: #f4f3ed; text-decoration-style: wavy; text-decoration-thickness: 2px; line-height: 3; }

.x:before, .x:after { content: " "; display: table; }  
.x:after { clear: both; }  

.text-center { text-align: center; }

.top { background: var(--blue); font-size: 15px; color: rgba(255,255,255, .6); padding: 10px 0; }
.top p { margin: 0; }
.top p.phone { float: right; }

.animate { opacity: 0; transform: translateY(50px); transition: all 0.5s ease-out; }
.animate.appear { opacity: 1; transform: translateY(0px); }

.slide-up { animation: slide-up 1.4s ease both; animation-delay: .1s; }
.slide-up-slow { animation: slide-up 1s ease both; animation-delay: .5s; }
@keyframes slide-up {
  0% { opacity: 0; transform: translateY(100px); }
  100% { opacity: 1; transform: translateY(0); }
}

.c { clear: both; position: relative; margin: 0 auto; max-width: 1350px; }

.header-wrap {  }
header { position: relative; background-image: linear-gradient(rgba(30,34,40,.7), rgba(30,34,40,.5)), url(pharma5.jpg); background-size: cover; background-position: center; }

.header-overlay { position: absolute; bottom: -5px; width: 100%; }
.header-overlay svg { width: 100%; display: block; }

.top-line { }

.logo { float: left; width: 150px; }
.logo img { box-shadow: 0px 0px 35px 0px #000; }

nav { transition: all 0.3s ease-out 0s; padding: 25px 0 0; height: 145px; z-index: 100; }
nav .c { width: 1400px; max-width: 1350px; }

.toggle-menu { float: left; margin: 8px 0 0 30px; color: #000; }

.menu { float: right; margin: 47px auto 0; }
.menu li { display: inline; font-size: 17px; font-weight: 600; }
.menu li a { float: left; padding: 10px 15px; color: #777; border-bottom: 1px solid transparent; transition: all ease .5s; }
.menu li.active a, .menu li a:hover { color: var(--orange); }

.menu li a.account, .menu li a.quote, .menu li a.cart { float: right; color: #fff; border-radius: 25px; margin: 0 0 0 10px; }
.menu li a.account:hover, .menu li a.quote:hover, .menu li a.cart:hover { transform: scale(1.02); box-shadow: 0px 24px 25px -10px rgba(0,0,0, .3); }
.menu li a.quote { background: var(--orange); background-size: 16px; margin: 0 0 0 40px; }
.menu li a.account { background: var(--orange) url(account.svg) no-repeat 20px 13px; background-size: 16px; padding-left: 46px; }
.menu li a.cart { background: var(--orange) url(cart.svg) no-repeat 20px 12px; background-size: 20px; padding-left: 48px; }
.menu li a.cart #cart-btn-qty span { float: right; display: inline-block; background: var(--blue); color: #fff; border-radius: 100%; width: 19px; line-height: 19px; margin: 0 0 0 10px; padding: 1px 0 0; text-align: center; font-size: 13px; font-weight: 700; }

.line { clear: both; padding: 10px 0 0; margin: 0 0 30px; border-bottom: 1px dotted #ddd; }

.white {  padding: 100px 0 30px; }

.shadowed { background: #fff; box-shadow: 0px 24px 25px -10px rgba(182, 194, 240, 0.54); border-radius: 15px; }

.black { padding: 50px 200px; background-image: linear-gradient(210deg, #000 0%, #338CF5 260%); color: #fff; }
.black h3 { color: #fff; }

/* pitch */
.pitch { clear: both; padding: 150px 0 170px; text-align: left; }
.pitch h1 { font-size: 64px; font-weight: 800; line-height: 1.3em; margin: 0 10% 80px 0; color: #fff; }
.pitch h1 span { font-size: 76px; letter-spacing: -2.7px; }


.pitch p { margin: 0 0 1em; color: rgba(255,255,255, .7); font-size: 24px; }
.flag { float: left; width: 200px; margin: 0 40px 40px 0; }
.pitch p.backdrop-caption { float: left; color: #fff; font-size: 26px; font-weight: 800; padding: 0; }
.pitch p.backdrop-caption span { font-weight: 500; color: rgba(255,255,255, .7); font-size: 24px; }

.button { display: inline-block; box-sizing: border-box; background: var(--orange); color: #fff; border: 0; padding: 15px 40px; border-radius: 35px; box-shadow: 0px 24px 25px -10px rgba(0,0,0, .2); font-size: 18px; cursor: pointer; }
.button.blue { }
.button.outline { margin: 0 0 0 20px; border: 2px solid #fff; color: #fff; background: transparent; padding: 14px 40px; }
.button:hover { transform: scale(1.02); box-shadow: 0px 24px 25px -10px rgba(0,0,0, .3); }


/* inner */

body.inner header { background-image: none; }
body.inner .header-overlay { position: absolute; }

body.inner .pitch { padding: 100px 0; text-align: center; background: var(--blue) url(blue-backdrop.png) no-repeat center center; background-size: 140%; }
body.inner .pitch h1 { margin: 0 0 20px; color: #fff; }
body.inner .pitch h1.small { font-size: 35px; color: rgba(255,255,255, .5); }
body.inner .pitch p.breadcrumbs { font-size: 22px; color: rgba(255,255,255, .5); }
body.inner .pitch p.breadcrumbs a { color: #fff; border-bottom: 1px solid rgba(255,255,255, .2); }
body.inner .pitch p { color: rgba(255,255,255, .7); }


/* section caption */
p.caption { font-size: 26px; font-weight: 300; margin: 0 0 45px; text-align: center; color: #536976; }
h2.caption { font-size: 36px; text-align: center; margin: 0 15% 45px; }

.intro-text { margin: 0 10% 120px; text-align: center; }

.features { margin: 0 0 80px; padding: 40px 0 30px; background: #f4f4f4; }

ul.better-choices { float: left; width: 48%; }
ul.better-choices:last-of-type { float: right; }

ul.better-choices li { text-align: left; margin: 0 0 25px 200px; padding: 0 0 0 32px; color: var(--orange); font-weight: 600; background: url(check.svg) no-repeat left center; background-size: 20px; }
ul.better-choices:last-of-type li { margin-left: 0; }

.products-section { margin: 0 0 150px; }
.sbox { text-align: center; float: left; width: 33.3%; font-size: 18px; padding: 40px 0; margin: 0 0 30px; border-radius: 20px; }
.sbox span { font-size: 60px; font-weight: 800; display: block; color: var(--orange); }

.col-2 { float: left; width: 49%; }
.col-2:last-child { float: right; }

.shadow { box-shadow: 5px 0px 20px 4px rgba(0,0,0, .1); }
.inset { box-shadow: inset 0px -7px 35px 0px rgba(0,0,0,0.2); }

/* testimonials section */
.testimonials { position: relative; padding: 60px 0; margin: 0 0 80px; margin: 30px 0 80px; }
.testimonials h2 { margin: 0 0 40px; }
.cards { display: flex; flex-shrink: 0; padding: 0 0 20px; max-width: 100%; overflow-x: auto; cursor: pointer; transition: all .2s ease; }
.cards::-webkit-scrollbar { height: 5px; }
.cards::-webkit-scrollbar-thumb { background: rgba(30, 34, 40, .1); border: none; }
.cards.active { transform: scale(1.04); cursor: grabbing; }
.card { flex-shrink: 0; min-height: 200px; width: 400px; border: 1px solid rgba(30, 34, 40, .2); background: #fff; margin: 0 30px 0 0; padding: 30px; border-radius: 10px; user-select: none; }
.card:last-child { margin-right: 0; }
.card img { float: left; width: 70px; height: 70px; object-fit: cover; border-radius: 50%; margin: 0 25px 20px 0; }
.card-title { font-size: 20px; font-weight: 800; margin: 5px 0 0; }
.card-subtitle { color: #777; }
.card-text { clear: both; font-size: 16px; }

.contact { position: relative; background-size: cover; color: #fff; padding: 110px 70px 90px; margin: 0 0 80px; border-radius: 20px; z-index: 110; text-align: center; }
.contact h3 { color: #fff; margin: 0 0 15px; }
.contact p { font-size: 29px; }


/* shop */
.shop { padding: 120px 0; }
.shop h1 { }

.cta { font-size: 14px; font-weight: 700; border: 0.15rem solid transparent; transition: all .3s ease-in-out; display: inline-block; background: #1b75ba;  margin: 0 0 0 20px; color: #fff; padding: 18px 30px; border-radius: 25px; }
.cta:hover { background-color: transparent; color: var(--clr-primary); border-color: currentColor; }


/* products */
.product-image { width: 450px; float: left; }
.product-image img { width: 100%; border-radius: 12px; }

#product-image { transition: opacity 0.3s ease, transform 0.3s ease; }
#product-image.fade-out { opacity: 0; transform: scale(0.98); }

.product-thumbnails { display: block; padding: 5px 0 10px; }
.product-thumbnails img { width: calc(31% - 6px); height: 150px; object-fit: cover; margin: 0 3.5% 0 0; border-radius: 10px; border: 3px solid #fff; cursor: pointer; opacity: 0.6; }
.product-thumbnails img:last-of-type { margin: 0; }
 .product-thumbnails img.active { border-color: var(--blue); opacity: 1; }

.product-info { font-size: 16px; background: #f4f4f4; padding: 20px; border-radius: 12px; }

.product-header { float: right; width: calc(100% - 500px); line-height: 1.9; }
.product-header p { margin: 0; }

.product-text { }
.product-text strong { color: var(--blue); }

.attachment a { display: inline-block; color: #111; background: #f4f4f4 url(technical-drawing.svg) no-repeat 30px center; background-size: 22px; border-radius: 12px; padding: 20px 30px 20px 70px; margin: 20px 0 30px; }
.attachment a:hover { background-color: #ddd; }

.price { padding: 15px 0 25px; color: var(--blue); font-size: 20px; font-weight: 600; }

 
.products { clear: both; width: 100%; padding: 30px 0 50px; }
.category-description { margin: 0 0 40px; }

.qty-control { font-size: 22px; padding: 0 7px; cursor: pointer; user-select: none; }
.qty-control:last-of-type { margin-right: 30px; }
.qty { font-size: 19px; font-weight: 600; color: #000; user-select: none; }
.added { margin: 0 20px 0 0; } 
.add-cart, .remove-cart { font-size: 18px; padding: 6px 26px; margin-left: 0; }


/* related-products */
.related-products { padding: 50px 0 0; }
.related-products h3 { color: var(--blue); font-size: 36px; font-weight: 700; margin: 0 0 30px; }
.related-item { float: left; width: 30%; margin: 0 3% 0 0; }
.related-item img { width: 100%; height: 340px; object-fit: cover; }
.related-item h3 { font-size: 24px; }
.related-item h3 a { color: rgba(30,34,40, .9); }


/* Slideshow container */
.slideshow-container { max-width: 100%; height: 330px; position: relative; margin: auto; box-sizing: border-box; padding: 40px 100px; border-radius: 12px; background: rgba(30, 34, 40, .06); }

/* Hide the images by default */
.mySlides { display: none; position: relative; }
.mySlides img { float: left; width: 250px; height: 250px; object-fit: cover; border-radius: 12px; margin: 0 40px 0 0; }
.mySlides h3 { font-size: 26px; font-weight: 700; padding: 30px 0 0; }
.mySlides h3 a { color: rgba(30,34,40, .9); }

/* Next & previous buttons */
.prev, .next {
  cursor: pointer;
  position: absolute;
  top: 150px;
  width: auto;
  margin-top: -22px;
  padding: 16px;
  color: rgba(30,34,40, .9);
  font-weight: bold;
  font-size: 18px;
  transition: 0.6s ease;
  border-radius: 0 3px 3px 0;
  user-select: none;
}

.prev { left: 20px; }
.next { right: 20px; }
.prev:hover, .next:hover { opacity: .5; }

.dots { text-align: center; }
.dot { cursor: pointer; height: 15px; width: 15px; margin: 0 2px; background-color: #bbb; border-radius: 50%; display: inline-block; transition: background-color 0.6s ease; }
.dots .active, .dot:hover { background-color: #717171; }

/* Fading animation */
.fade {
  animation-name: fade;
  animation-duration: 1.5s;
}

@keyframes fade {
  from {opacity: .4}
  to {opacity: 1}
}

/* categories section */
/*
.categories-grid { display: flex; /*grid-template-columns: repeat(auto-fit, minmax(min(100%, 22%), 1fr)); gap: 1.5rem; flex-wrap: wrap; }
.category { flex: 0 0 calc(33.33% - 1rem); position: relative; border-radius: 1.25rem; text-align: center; background: rgba(30, 34, 40, .06); }
.category a { color: rgb(var(--text)); }
.category-image { width: 100%; height: 430px; object-fit: cover; margin: 0 0 20px; border-radius: 12px; }
.category-title { font-size: 24px; font-weight: 700; margin-bottom: 0.5rem; }
.category-text { font-size: 15px; padding: 0 30px; }

*/

.category-header-text { text-align: center; margin: 0 0 80px; }
.category-header-text h2 { font-size: 22px; font-weight: 500; }

/* product listing */
.products-grid { display: flex; /*display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 22%), 1fr));*/ gap: 1.5rem; flex-wrap: wrap; }

.product { flex: 0 0 calc(33.33% - 1rem); position: relative; border-radius: 1.25rem; text-align: center; background: rgba(30, 34, 40, .06); float: left; margin: 0 0 40px; }
.product a { color: rgb(var(--text)); }
.product img { width: 100%; height: 500px; object-fit: cover; margin: 0 0 20px; border-radius: 12px; }
.product h3 { font-size: 24px; font-weight: 700; margin: 0 20px 10px; }
.product p { font-size: 15px; padding: 0 20px; }

.products-grid.category-58mm-jars { grid-template-columns: repeat(auto-fit, minmax(min(100%, 31%), 1fr)); }
.products-grid.category-70mm-jars { grid-template-columns: repeat(auto-fit, minmax(min(100%, 24%), 1fr));  }

.categories-grid.category-caps { grid-template-columns: repeat(auto-fit, minmax(min(100%, 24%), 1fr));  }

.products-grid.category-spice-jars { grid-template-columns: repeat(auto-fit, minmax(min(100%, 31%), 1fr)); }

/*.products-grid.category-70mm-jars .product img, .categories-grid.category-caps .category-image img { height: 434px; }*/


.home-products { margin: 0 0 80px; }


.box img, .category-image, .product img, .product-image img, .mySlides img { background: #121212; background: linear-gradient(190deg, rgba(87, 87, 87, 1) 0%, rgba(30, 30, 30, 1) 100%); }


.contact-box { background: rgba(30, 34, 40, .06); text-align: center; padding: 70px 0 40px; border-radius: 12px; margin: 0 0 50px; }
.contact-box h3 { }
.contact-box p { font-size: 26px; }


#cart-form h3 { margin: 0 0 40px; }

/* quote form */
.contact-details { float: left; width: 48%; }


/* product table */
.cart-products { float: right; width: 48%; }
.products-table { border-collapse: collapse; width: 100%; }
.products-table thead td { color: #000; font-weight: 600; }
.products-table td { border-bottom: 1px solid #ccc; padding: 20px 10px; font-size: 16px; }
.products-table tr:nth-child(even) td { background: #f8f8f8; }
.products-table td.cart-action { width: 50px; white-space: nowrap; }
.products-table td.cart-action .qty { display: inline-block; width: 20px; text-align: center; }
.products-table td.cart-action .cta { padding: 12px 20px; }
.products-table tfoot td { color: #000; font-weight: 600; }
.products-table td:last-of-type { text-align: right; }

#cart-form .cart-products { float: left; width: 60%; }
#cart-form .contact-details { float: right; width: 34%; }

.cart-empty { font-size: 26px; color: var(--blue); padding: 0 10%; }

/* filters horizontal */
.filters { position: relative; background: rgba(30,34,40, .1); padding: 3px 20px; border-radius: 8px; margin: 30px 0 30px; display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 22%), 1fr)); gap: 1rem;; }
.filters label { padding: 10px 0; margin: 0; text-transform: uppercase; font-weight: 600; font-size: 13px; }
.filters select { float: left; clear: none; padding: 8px !important; height: 40px; font-size: 14px; margin: 0 0 18px; }

.page { padding: 80px 14% 150px; line-height: 1.7em; font-size: 19px; }
.page img { width: 100%; margin: 0 0 40px; }
.blog h2 { font-size: 38px; }
.blog h3 { font-size: 32px; margin-top: 30px; }
.blog img { max-width: 100%; margin: 0 0 40px; }
.blog ul { margin: 0 0 20px 20px; }
.blog ul li { list-style-type: disc; }
.blog p { line-height: 1.7em; }
.blog .header-image { max-height: 600px; object-fit: cover; }

/* news items */
.news h2 { margin: 0 0 30px; }
.news-item { position: relative; border-radius: 1.25rem; text-align: center; float: left; margin: 0 3% 40px 0; width: 30%; background: #f4f4f4; }
.news-item:last-item { float: right; margin-right: 0; }
.news-item a { color: rgb(var(--text)); }
.news-item img { width: 100%; height: 310px; object-fit: cover; margin: 0 0 20px; border-radius: 12px; }
.news-item h3 { font-size: 24px; font-weight: 800; margin: 0 25px 20px; }
.news-item p { font-size: 15px; padding: 0 25px; }

/* blog posts */
.news-item.wide { width: 100%; margin: 0 0 40px; text-align: left; border: 0; }
.news-item.wide img { float: left; width: 40%; height: 300px; margin: 0 40px 0 0; }
.news-item.wide h3 { padding: 50px 0 0; }

/* request a quote */
.request_quote_form { margin-top: 40px; text-align: left; background: #f4f4f4; padding: 60px; border-radius: 15px; }
.request_quote_form h3 { font-size: 30px; margin: 0 0 35px; }

/* faq */
.faq { margin: 0 0 120px; }
.faq-item { }
.faq-item label { border-bottom: 1px solid #eee; cursor: pointer; display: block; font-size: 23px; font-weight: 600; color: var(--link); padding: 0 0 25px; margin: 0 0 30px; position: relative; transition: all 0.25s ease-out; }
.faq-item label span { transition: all 0.25s ease-out; display: inline-block; width: calc(100% - 30px); color: #222; }
.faq-item label span:hover { text-decoration: underline; }
.faq-item label::before { float: right; margin: 4px 0 0; border-style: solid; border-color: var(--text-dark); border-width: 1px 1px 0 0; content: " "; height: 10px; width: 10px; position: relative; transform: rotate(135deg); transition: 0.35s ease-in-out; }
.faq-item input[type=checkbox] { display: none; }
.faq-item input[type=checkbox]:checked + label + .faq-answer { max-height: 1000px; }
.faq-item input[type=checkbox]:checked + label::before { margin: 10px 0 0; transform: rotate(-45deg); transition: 0.25s ease-in-out; }
.faq-answer { max-height: 0; overflow: hidden; transition: 0.5s ease-in-out; }
.faq-answer-hold { padding: 0 0 50px; }
.faq-answer-hold ul { margin: 0 0 20px; }
.faq-answer-hold ul li { margin: 0 0 0 20px; list-style-type: square; }

/* forms */
form {  }
.form-element { margin: 0 0 20px; transition: all 0.3s ease-out 0s; }
label { display: block; font-size: .84em; color: #999; margin: 0 0 5px; }
.form-element.mandatory label::after { content: " *"; color: #d3531a; }
input[type=text], input[type=number], input[type=tel], input[type=email], input[type=password], select, textarea { clear: both; font-family: inherit; font-weight: 500; font-size: .9em; background: #fff; padding: 12px; height: 48px; width: 100%; border: 1px solid #ccc; border-radius: 5px; box-sizing: border-box; outline: none; box-shadow: 2px 2px 0 0 rgba(0,0,0, .05); }
textarea { height: 110px; }
.form-element.error input[type=text] { border-color: red; transition: all 1s ease-out; }
input[type=text]:focus, input[type=number]:focus, input[type=tel]:focus, input[type=email]:focus, input[type=password]:focus, textarea:focus, select:focus { outline: 2px solid var(--primary-dark); }
input[type="checkbox"] { /*visibility: hidden;*/ opacity: 0; }
.checkbox { float: left; margin: 0 15px 0 0; position: relative; width: 20px; }
.checkbox input[type=checkbox]:checked + label:after { opacity: 1; }
.checkbox label { position: absolute; background: none repeat scroll 0 0 #fff; border: 1px solid #ccc; cursor: pointer; width: 20px; height: 20px; left: 0; top: 5px; border-radius: 3px; }
.form-element.error .checkbox input[type=checkbox] + label { border-color: red; }
.checkbox label:after { border-style: none none solid solid; content: ""; height: 5px; left: 6px; opacity: 0; position: absolute; top: 5px; transform: rotate(-50deg); width: 6px; }
.checkbox-label { font-size: .84em; color: #999; }
.invalid-feedback { /*display: none;*/ }
.invalid-feedback.is-invalid { display: block; }

.form-element.half { float: left; width: 48.5%; }
.form-element.half.last { float: right; }


/* footer */
.footer-wrap { z-index: 100; position: relative; margin: 0; }
footer { clear: both; padding: 80px 0 60px 0px; font-size: 17px; margin: 0; background: var(--blue); }
footer .logo { float: none; margin: 0 50px 20px 0; clear: both; filter: brightness(0) invert(1); }
footer .copy { float: left; margin: 0 10% 0 0; line-height: 1.7em; color: rgba(255,255,255, .9); }
footer .copy.padded { padding-top: 22px; }
footer .copy.padded.last { margin-right: 0; }

footer .copy.padded a { color: #fff;/* border-bottom: 1px solid rgba(255,255,255, .4);*/ }
footer .copy.icons { float: right; margin: 0; }
footer .copy.icons a { float: left; width: 28px; height: 28px; margin: 0 0 0 20px; }


footer ul { float: left; margin: 0 9% 0 0; }
footer ul li { color: #000; font-weight: 600; line-height: 1.7em; margin-bottom: 10px; }
footer ul li a { color: #707070; font-weight: 400; }
footer ul li:has(a) { margin-bottom: 0; }

.scroll-top { position: fixed; z-index: 100000; bottom: 30px; right: 30px; width: 22px; height: 22px; padding: 8px; transition: all 0.3s ease-out 0s; opacity: 0; background: #fff; border-radius: 8px; box-shadow: 0px 0px 35px 0px #97A7AF55; }
.scroll-top svg { width: 100%; }
.scroll-top.active { opacity: 1; }

/* cookie notice */
p.cookie-bar { position: fixed; visibility: visible; opacity: 1; transition: opacity 1s linear; cursor: auto; z-index: 1000; text-align: center; font-size: 15px; font-weight: 500; color: #000; bottom: 65px; left: 50%; transform: translateX(-50%); width: calc(95% - 60px); padding: 25px 30px 5px; border-radius: 35px; margin: 0; background: #fff; box-shadow: -2px 3px 30px -10px rgb(0 0 0 / 25%); }
.cookie-bar.closed { visibility: hidden; opacity: 0; transition: visibility 0s 1s, opacity 1s linear; }
.cookie-bar.hide { display: none; }
.cookie-icon { display: inline-block; margin: 0 15px 20px 0; vertical-align: -25px; color: #000; background: url(cookie.svg) no-repeat; background-size: 100%; width: 25px; height: 25px; }
.cookie-bar-close { position: absolute; top: 25px; right: 25px; vertical-align: middle; color: #000; background: url(close.svg) no-repeat; background-size: 100%; width: 16px; height: 16px; }



/* MOBILE UI */
@media only screen and (max-width : 640px) {  
	html { width: 100%; }
	
	h2 { font-size: 32px; }
	
	
	.top p:not(.phone) { display: none; }
	.top p.phone { float: none; font-size: 14px; }
	
	header { border-radius: 0; }
	.header-wrap { padding: 0; }
	
	
	
	.logo { clear: both; width: 120px; float: none; margin: 0 0 25px; }
	
	.menu-icon { position: absolute; top: 115px; right: 8%; width: 30px; height: 27px; cursor: pointer; z-index: 300; transition: transform 1s ease-in; }
	.menu-icon span { display: block; position: absolute; height: 1px; right: 0; opacity: 1; transition: 0.25s ease-in-out; background: var(--orange); }
	.menu-icon.active span { background: #fff; }
	.menu-icon span:nth-child(1) { top: 0; width: 50%; }
	.menu-icon span:nth-child(2) { top: 10px; width: 75%; }
	.menu-icon span:nth-child(3) { top: 20px; width: 100%; }
	.menu-icon.active span:nth-child(1) { width: 100%; top: 12px; transform: rotate(135deg); }
	.menu-icon.active span:nth-child(2) { opacity: 0; }
	.menu-icon.active span:nth-child(3) { top: 12px; transform: rotate(-135deg); }
	
	nav { height: auto; }
	
	body.menu-active { position: fixed; width: 100%; }
	
	.menu { position: fixed; left: 0; right: 0; top: 0; bottom: 0; width: 100%; margin: 0; background: var(--blue); padding: 60px 10% 0; opacity: 0; z-index: 20; box-sizing: border-box; pointer-events: none; transition: opacity 0.5s ease-in-out; }
	.menu.active { display: block; opacity: 1; pointer-events: all; }
	.menu li { font-size: 24px; }
	.menu li a:not(.quote, .cart) { float: left; clear: both; margin: 0; padding: 10px 0; color: #fff; text-align: left; }
	
	
	body.inner .menu li a { color: #fff; }
	
	.menu li a.quote, .menu li a.cart { clear: both; float: left; margin: 20px 0 0; font-size: 16px;  }
	  
	.pitch { padding: 80px 0; }
	.pitch h1 { font-size: 33px; letter-spacing: -1px; margin: 0 0 20px 0; }
	.pitch p { font-size: 18px; width: 100%; }
	.pitch p.backdrop-caption { font-size: 18px; font-weight: 800; padding: 0 0 0 55px; width: calc(100% - 55px); background-size: 45px; }
	.pitch .button { margin: 0 15px 20px 0; font-size: 16px; }
	
	body.inner .pitch {  padding: 100px 0; background-size: cover; }
	
	.c, nav .c { position: static; width: 92%; padding: 0 4%; }
	.box, .box.narrow { margin: 0; }
	.ft-left, .ft-right { float: none; width: 100%; padding: 0; }
	.sbox { width: 100%; float: none; } 
	
	
	h2.caption { font-size: 28px; margin: 0 5% 45px; }
	
	.products-section .box { float: left; width: 100%; margin: 0 0 20px; }
	.box-content { padding: 20px 0; }
	.box-content h3 { font-size: 22px; }
	
	ul.better-choices, ul.better-choices:last-of-type { float: none; width: 100%; }
	ul.better-choices li { margin: 0 0 25px; }
	
	.testimonials { margin: 0 0 20px; }
	.card { width: 70%; }
	
	.categories-grid, .products-grid { grid-template-columns: repeat(1, 1fr) !important; }
	
	.page { padding: 50px 0 150px; }
	.blog h2 { font-size: 32px; }
	.blog h3 { font-size: 26px; }
	
	.product-image, .product-header { float: none; clear: both; width: 100%; height: auto; }
	.product-image img { width: 100%; margin: 0 0 30px; }
	.product-header h3 { font-size: 24px; }
	
	.related-products h3 { font-size: 28px; }
	.slideshow-container { height: auto; padding: 40px 30px; }
	.mySlides img { float: left; display: block; width: 100%; height: 250px; object-fit: cover; border-radius: 12px; margin: 0 40px 15px 0; }
	.mySlides h3 { font-size: 20px; margin: 0 0 10px; }
	.mySlides p { font-size: 16px; }
	.prev { left: -10px; }
	.next { right: -10px; }
	
	.news-item { float: none; margin: 0 0 40px 0; width: 100%; padding-bottom: 10px; }
	.news-item.wide img { float: left; width: 100%; height: auto; margin: 0 0 30px; }
	
	.faq { margin: 0 0 20px; }
	.faq .c { width: 80%; padding: 0 10%; }
	.faq-item label { font-size: 19px; }
	.faq-answer { font-size: 18px; }
	
	.contact { margin: 0 0 30px; padding: 60px 40px; text-align: center; background-position: top right; }
	.contact h3 { font-size: 28px; }
	.contact p { font-size: 20px; }
	
	.request_quote_form { padding: 30px; }
	.contact-details { }
	.cart-products { margin: 0 0 30px; }
	.contact-details, .cart-products { float: none; width: 100%; }
	
	.footer-wrap { padding: 0; margin: 0; }
	footer { padding: 70px 5% 100px; }
	footer .logo { width: 90px; }
	footer .copy.icons { display: block; float: left; padding-top: 30px !important; }
	footer .copy.icons a { margin: 0 20px 0 0; }
	
	.button { padding: 10px 25px; }
	.button.outline { padding: 8px 23px; }

}
