/*
 * HTML5 Boilerplate
 *
 * What follows is the result of much research on cross-browser styling.
 * Credit left inline and big thanks to Nicolas Gallagher, Jonathan Neal,
 * Kroc Camen, and the H5BP dev community and team.
 */

/* ==========================================================================
   Base styles: opinionated defaults
   ========================================================================== */

html,
button,
input,
select,
textarea {
    color: #000;
}

body {
	background-color:#000;
	color: #000;
	font-family: 'Akkurat', sans-serif;
	font-size:16px;
	font-weight:400;
    line-height: 1.4;
}

/*
 * Remove text-shadow in selection highlight: h5bp.com/i
 * These selection declarations have to be separate.
 * Customize the background color to match your design.
 */

::-moz-selection {
    background: #b3d4fc;
    text-shadow: none;
}

::selection {
    background: #b3d4fc;
    text-shadow: none;
}

/*
 * A better looking default horizontal rule
 */

hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ccc;
    margin: 1em 0;
    padding: 0;
}

/*
 * Remove the gap between images and the bottom of their containers: h5bp.com/i/440
 */

img {
    vertical-align: middle;
}

/*
 * Remove default fieldset styles.
 */

fieldset {
    border: 0;
    margin: 0;
    padding: 0;
}

/*
 * Allow only vertical resizing of textareas.
 */

textarea {
    resize: vertical;
}

/* ==========================================================================
   Chrome Frame prompt
   ========================================================================== */

.chromeframe {
    margin: 0.2em 0;
    background: #ccc;
    color: #000;
    padding: 0.2em 0;
}

/* ==========================================================================
   Coordinate Styles
   ========================================================================== */

#site-wrapper {
	transition:transform 0.5s linear;
}
#site-wrapper.menu-open {
	transform:translateX(-100%);
}
main { overflow:hidden; }

/*
 * Top Bar / Navigation / Bottom Bar
 */

/** Top Bar **/
#top-bar { background-color:#000; padding-bottom:1.875rem; padding-top:1.875rem; position:relative; z-index:10; }
body.floating-top-bar #top-bar { background-color:transparent; position:absolute; top:0; left:0; right:0; z-index:20; }

#top-bar h1 { height:40px; float:left; margin:0; width:160px; }
#top-bar h1 a { background:url(../img/svg/grtr-logo.svg) no-repeat 0 0; background-size:contain; border:none; display:block; height:100%; width:100%; }

#top-bar .header-functions { float:right; }
#top-bar .header-functions .show-for-medium { float: left;}
#top-bar .header-functions a { color:#fff; font-weight:600; text-decoration:none; }
#top-bar .header-functions a:hover span.link-text { border-bottom:2px solid #fff; }
#top-bar .header-functions a.cart-btn { display:inline-block; height:36px; line-height:36px; padding:0 2.875rem 0 0; position:relative; }
#top-bar .header-functions a.cart-btn span.cart-amount { background-color:#fff; border-radius:36px; color:#000; display:block; font-weight:600; height:36px; position:absolute; top:0; right:0; text-align:center; width:36px; }
#top-bar .header-functions span.menu-divider { display:inline-block; color:#fff; font-weight:600; padding-left:0.3125rem; padding-right:0.3125rem; }

button.menu-button { background-color:transparent; border:none; display:block; float:right; height:20px; margin-top:10px; margin-left:1.875rem; padding:0; position:relative; width:30px; z-index:30;
	transition: all 0.3s ease-out;
}
button.menu-button:hover { background-color:transparent; outline:none; }
button.menu-button:focus { background-color:transparent; outline:none; }
button.menu-button span { background-color:#fff; display:block; margin-top:-1px; position:absolute; left:50%; margin-left:-15px; height:3px; width:30px;
	transform-origin:center;
}
button.menu-button span:first-child { margin-top:-10px; top:50%; width:22px; }
button.menu-button span:last-child { margin-top:8px; top:50%; width:22px; }
button.menu-button:hover span:first-child,
button.menu-button:hover span:last-child { width:30px; }

button.menu-button.closed span {  
	transition:transform 0.3s ease-out, opacity 0.3s ease-out 0.3s, margin-top 0.3s ease-out 0.3s, width 0.3s ease-out;
}
button.menu-button.open span { width:30px;
	-webkit-transition: margin-top 0.3s ease-out, opacity 0.3s ease-out, -webkit-transform 0.3s ease-out 0.3s, width 0.3s ease-out; 
}

button.menu-button.open span:first-child { margin-top:-1px;
	transform: rotate(45deg); 
}
button.menu-button.open span:nth-child(2) { opacity:0; }
button.menu-button.open span:last-child { margin-top:-1px;
	transform: rotate(-45deg); 
}

/** Navigation **/
#site-navigation { background-color:#000; background-clip:padding-box; overflow-y:scroll; opacity:0; padding-bottom: 115px; padding-top:100px; position:fixed; top:0; bottom:0; left:100%; z-index:-1; width:100%;
	-webkit-transition: z-index 0s 0.75s linear, opacity 0.5s linear, right 0.5s linear, left 0.5s linear;
	-o-transition: z-index 0s 0.75s linear, opacity 0.5s linear, right 0.5s linear, left 0.5s linear;
	transition: z-index 0s 0.75s linear, opacity 0.5s linear, right 0.5s linear, left 0.5s linear;
	-webkit-overflow-scrolling:touch;
} 
#site-navigation.visible { left:0; right:auto; z-index:30; opacity:1;
	-webkit-transition: opacity 0.5s linear, left 0.5s linear, right 0.5s linear;
	-o-transition: opacity 0.5s linear, left 0.5s linear, right 0.5s linear;
	transition: opacity 0.5s linear, left 0.5s linear, right 0.5s linear;
}

#site-navigation button.menu-button { position:absolute; top:30px; right:15px; }

#site-navigation .nav-functions { padding-bottom: 1.875rem; }
#site-navigation .nav-functions a { color:#fff; font-weight:600; text-decoration:none; }
#site-navigation .nav-functions a:hover span.link-text { border-bottom:2px solid #fff; }
#site-navigation .nav-functions a.cart-btn { display:inline-block; height:36px; line-height:36px; padding:0 2.875rem 0 0; position:relative; }
#site-navigation .nav-functions a.cart-btn span.cart-amount { background-color:#fff; border-radius:36px; color:#000; display:block; font-weight:600; height:36px; position:absolute; top:0; right:0; text-align:center; width:36px; }
#site-navigation .nav-functions span.menu-divider { display:inline-block; color:#fff; font-weight:600; padding-left:0.3125rem; padding-right:0.3125rem; }

#site-navigation nav ul { list-style:none; margin:0; padding:0; }
#site-navigation nav ul li { /*border-top:1px solid #222;*/ padding:0.625rem 0; }
#site-navigation nav ul li:first-child { border-top:none; padding-top:0; }
#site-navigation nav ul li:last-child { padding-bottom:0; }
#site-navigation nav ul li::before { display:none; }
#site-navigation nav ul li a { color:#fff; font-family:itc-avant-garde-gothic-pro, sans-serif; font-size:1.875em; font-weight:700; position:relative; text-decoration:none !important; }
#site-navigation nav ul li a:hover,
#site-navigation nav ul li.current_page_item a,
#site-navigation nav ul li.current-page-ancestor a { border-bottom:2px solid #fff; color:#fff; }

#site-navigation .social-links { position:absolute; bottom:0.9375rem; left:0.9375rem; }

#navigation-overlay { background-color:#000; opacity:0; position:fixed; top:0; bottom:0; left:0; right:0; z-index:-1;
	-webkit-transition: z-index 0s 0.75s linear, opacity 0.5s linear;
	-o-transition: z-index 0s 0.75s linear, opacity 0.5s linear;
	transition: z-index 0s 0.75s linear, opacity 0.5s linear;
} 
#navigation-overlay.visible { z-index:25; opacity:0.65;
	-webkit-transition: opacity 0.5s linear, left 0.5s linear, right 0.5s linear;
	-o-transition: opacity 0.5s linear, left 0.5s linear, right 0.5s linear;
	transition: opacity 0.5s linear, left 0.5s linear, right 0.5s linear;
}

/** Bottom Bar **/
#bottom-bar { background-color:#000; }
#bottom-bar .footer-content { padding-bottom:1.875rem; padding-top:1.875rem; }
#bottom-bar .footer-content h3 { float:left; height:55px; margin:0; width:215px; }
#bottom-bar .footer-content h3 a { background:url(../img/svg/grtr-logo.svg) no-repeat 0 0; background-size:contain; display:block; height:100%; width:100%; }
#bottom-bar .footer-content nav { float:left; }
#bottom-bar .footer-content nav ul { list-style:none; margin:0; padding:0; }
#bottom-bar .footer-content nav ul li { float:left; padding-left:1.875rem; }
#bottom-bar .footer-content nav ul li a { color:#fff; font-weight:600; line-height:55px; text-transform:uppercase; text-decoration:none; }
#bottom-bar .footer-content nav ul li a:hover { border-bottom:2px solid #fff; }
#bottom-bar .footer-content .social-links { display: inline-block; vertical-align: bottom; }

#bottom-bar .legality { border-top:1px solid #4d4d4d; color:#fff; font-size:0.875rem; padding-bottom:0.9375rem; padding-top:0.9375rem; }
#bottom-bar .legality a { color:#fff; text-decoration:none; }
#bottom-bar .legality a:hover { text-decoration:underline; }

.woocommerce-store-notice { background-color: #000; color: #fff; margin: 0; padding: 1em; position: fixed; left: 0; right: 0; bottom: 0; text-align: center; z-index: 10;
	transition: opacity 0.25s ease-out;
}
.woocommerce-store-notice.hide-notice { opacity: 0; pointer-events: none;}

/*
 * Page Rows
 */

/** Banner Row **/
section.banner-row { background-color:#000; color:#fff; height:100vh; position:relative; }
section.banner-row ul.slides { height:100%; list-style:none; margin:0; padding:0; }
section.banner-row ul.slides li { background-position:center; background-repeat:no-repeat; background-size:cover; height:100%; position:relative; }
section.banner-row ul.slides li::after { background-color:#000; content:''; display:block; opacity:0.5; position:absolute; top:0; right:0; bottom:0; left:0; z-index:0; }
section.banner-row ul.slides li .slide-content { position: absolute; top: 50%; left: 0; right: 0; z-index: 5;
	transform: translateY(-50%);
}
section.banner-row ul.slides li h1 { font-size:3em; margin:0 0 1.25rem; }
section.banner-row ul.slides li .banner-buttons { margin-top:1.875rem; }
section.banner-row ul.slides li .banner-buttons a.btn { margin-left:3px; width:calc(50% - 1px); }
section.banner-row ul.slides li .banner-buttons a.btn:first-child { margin-left:0; width:calc(50% - 2px); }
section.banner-row ul.slides li .banner-buttons a.btn:only-child { margin: 0; width: 100%; }

section.banner-row .controls-container { position:absolute; bottom:1.875rem; left:0; right:0; z-index:5; }

section.banner-row--internal { height: auto; min-height: auto !important; max-height: none !important; }
section.banner-row--internal ul.slides li .slide-content { position:relative; top: auto; z-index: 5;
	transform: none;
}

/** Content Row **/
section.content-row { overflow:hidden; }
section.content-row .image-replacement { position:relative; }

/** Tile Row **/
section.tile-row { position:relative; }
section.tile-row::after { content:''; display:block; position:absolute; top:25%; right:0; bottom:0; left:0; z-index:0; }
section.tile-row > .row { position:relative; z-index:5; }
section.tile-row.background-black-to-white { background-color:#000; }
section.tile-row.background-black-to-white::after { background-color:#fff; }
section.tile-row.background-white-to-black { background-color:#fff; }
section.tile-row.background-white-to-black::after { background-color:#000; }

/** Products Row **/
section.products-row .woocommerce { margin-top:-0.9375rem; }

/* ==========================================================================
   Woocommerce
   ========================================================================== */

/** Notices **/
.woocommerce-notices-wrapper { padding-bottom:1.875rem; }
.woocommerce-notices-wrapper:empty { padding-bottom:0; }

.woocommerce-notice,
.woocommerce-Message { background-color:#f5f5f5; border-top:3px solid; list-style:none; margin:1.875rem 0 0; padding:0.9375rem; }
.woocommerce-notice:first-child,
.woocommerce-Message:first-child{ margin-top:0; }

.woocommerce-notice.woocommerce-message,
.woocommerce-Message{ border-top-color:#000; }
.woocommerce-notice.woocommerce-info { border-top-color:#1e85be; }
.woocommerce-notice.woocommerce-error { border-top-color:#b81c23; }

/** Catalog **/
ul.products { align-items:center; display:flex; flex-wrap:wrap; list-style:none; margin:-0.9375rem;; padding:0; }
ul.products li { padding:0.9375rem; width:100%; }
ul.products li a { text-decoration:none; }

/** Catalog - Meals **/
ul.products li.product_cat-meals h2 { font-family:'Akkurat', sans-serif; font-size:1.25em; font-weight:600; line-height:1; margin:0; padding:1rem 0 0; text-transform:none; }
ul.products li.product_cat-meals h2 + span.price { display:block; padding:0.625rem 0; }
ul.products li.product_cat-meals .variations .value { margin-bottom:0.625rem; }
ul.products li.product_cat-meals .variations .value > div input { top:0.625rem; left:0.625rem; }
ul.products li.product_cat-meals .variations .value > div label { padding:0.625rem; }
ul.products li.product_cat-meals h2 + span.price span.from,
ul.products li.product_cat-meals .variations h3,
ul.products li.product_cat-meals .single_variation_wrap .woocommerce-variation-description,
ul.products li.product_cat-meals .single_variation_wrap .woocommerce-variation-availability,
ul.products li.product_cat-meals .single_variation_wrap .woocommerce-variation-price { display:none !important; }
ul.products li.product_cat-meals .single_variation_wrap button { height:44px; max-width:none; }

/** Single Product **/
.variations .value { border:3px solid #000; display: flex; margin-bottom:1.875rem; }
.variations .value > div { float:left; position:relative; width:50%;
	transition:all 0.25s ease-out;
}
.variations .value > div:nth-child(odd) { border-right:3px solid #000; }
.variations .value > div input { position:absolute; top:1.25rem; left:1.25rem; visibility: hidden;
	transition:all 0.25s ease-out;
}
.variations .value > div label { cursor: pointer; display:block; font-size:0.875em; line-height:1; margin:0; padding:1rem 0.5rem; text-align: center;text-transform:uppercase; }
.variations .value > div.checked { background-color:#000; color:#fff; }
.variations .value > div.checked input:checked { background-color:#fff !important; border-color:#fff; }

.single-product .variations { margin-top:3.125rem; }
.single-product .variations h3 { font-size:1.25em; }

.single-product .single_variation_wrap {  }
.single-product .single_variation_wrap .woocommerce-variation.single_variation { padding-bottom: 1.875rem; }
.single-product .single_variation_wrap #wc-stripe-payment-request-wrapper { display: none; }
.single-product .single_variation_wrap .woocommerce-variation-description { display:none; }
.single-product .single_variation_wrap .woocommerce-variation-price { font-family:itc-avant-garde-gothic-pro, sans-serif; font-size:1.875em; font-weight:700; padding-right:1.875rem; }
.single-product .single_variation_wrap .variations_button { display:flex; flex-grow:2; }
.single-product.product_cat-meals .single_variation_wrap .variations_button button[type="submit"] { height: 66px; }
.single-product .first-payment-date { display:none; }
.single-product .pricing-notice { padding-top:1.875rem; }

.single-product table.nutritional-info { font-size:0.875em; width:100%; }
.single-product table.nutritional-info caption { background-color:#000; color:#fff; font-size:1.143em; font-weight:600; line-height:1; padding:0.625rem; text-align:left; }
.single-product table.nutritional-info th,
.single-product table.nutritional-info td { padding:0.3125rem 0.625rem; text-align:right; }
.single-product table.nutritional-info th { text-align:left; }
.single-product table.nutritional-info tr.description td { border-bottom:1px solid #000; border-top:1px solid #000; }
.single-product table.nutritional-info tbody tr:nth-child(even) th,
.single-product table.nutritional-info tbody tr:nth-child(even) td { background-color:#f5f5f5; }

.product-gallery ul { list-style:none; margin:0; padding:0; }
.product-gallery .flex-control-paging { padding-top:1.875rem; text-align:center; }
.product-gallery .flex-control-paging li { display:inline-block; float:none; }
.product-gallery .flex-control-paging li a { border-color:#000; }
.product-gallery .flex-control-paging li a:hover,
.product-gallery .flex-control-paging li a.flex-active { background-color:#000; }

.single-product .image-replacement { background-color:#000; position:relative; }
.single-product .image-replacement .replaced-image { background-position:left center; background-repeat:no-repeat; background-size:cover; position:absolute; top:0; left:0; bottom:0; right: 0; z-index:5; }
.single-product .image-replacement .replaced-image::before { background-color:#000; content:''; display:block; opacity:0.6; position:absolute; top:0; right:0; bottom:0; left:0; }
.single-product .image-replacement .side-content { background-color:transparent !important; padding-left: 0.9375rem; padding-right: 0.9375rem; position:relative; z-index:10; }

/** Cart **/
table.shop_table { width:100%; }
table.shop_table thead th { border-bottom:3px solid #000; font-size:1em; font-weight:600; padding:0 0.625rem 0.625rem; text-align:left; }
table.shop_table tbody td { border-top:1px solid #000; padding:0.625rem; }
table.shop_table tbody tr:first-child td { border-top:none; }
table.shop_table thead th.product-thumbnail,
table.shop_table tbody td.product-thumbnail { display: none; }
table.shop_table tbody td a.remove { font-size:1.25em; }
table.shop_table tbody td a.remove:hover { color:red; }
table.shop_table tbody td h4 { font-size:1.125em; margin-bottom:0.5em; }
table.shop_table tbody td .quantity.buttons_added { margin-right:0; padding-right:25px; width:75px; }
table.shop_table tbody td .quantity.buttons_added input { border-width:2px; font-size:1.25em; height:50px; width:50px; }
table.shop_table tbody td .quantity.buttons_added input.plus,
table.shop_table tbody td .quantity.buttons_added input.minus { font-size:1.125em; height:25px; width:25px; }
table.shop_table tbody td.actions { border-bottom:3px solid #000; border-top:3px solid #000; padding-bottom:0.9375rem; padding-top:0.9375rem; }
table.shop_table tbody td.actions .actions-container { display:flex; justify-content:space-between; }
table.shop_table tbody td.actions .actions-container .coupon { display:flex; width:50%; }
table.shop_table tbody td.actions .actions-container .coupon input { border-right:none; }
table.shop_table tfoot th,
table.shop_table tfoot td { border-top:1px solid #000; font-weight: 600; padding:0.625rem; text-align: left;}
table.shop_table tfoot tr:first-child th,
table.shop_table tfoot tr:first-child td { border-top-width: 3px; }
table.shop_table tfoot tr:last-child th,
table.shop_table tfoot tr:last-child td { border-bottom: 3px solid #000; }

ul.wc-item-meta li p { margin: 0; }

.cart-collaterals table { border-bottom:3px solid #000; border-top:3px solid #000; width:100%; }
.cart-collaterals table th { border-top:1px solid #000; padding:0.625rem; text-align:left; vertical-align:top; }
.cart-collaterals table td { text-align:right; vertical-align:top; width: 100%; }
.cart-collaterals table td ul { list-style:none; margin:0; padding:0; }
.cart-collaterals table td label { font-size:1em; font-weight:400; margin:0; padding:0; }
.cart-collaterals table td input + label { display:block; }
.cart-collaterals table .order-total th,
.cart-collaterals table .order-total td { font-family:itc-avant-garde-gothic-pro, sans-serif; font-size:1.25em; font-weight:700; }
.cart-collaterals .wc-proceed-to-checkout { padding-top:0.9375rem; text-align:right; }
.cart-collaterals .wc-proceed-to-checkout a { max-width:none; }

.shipping-calculator-form {
	background-color: #f5f5f5;
	padding: 15px;
	margin-top: 15px;
	text-align: left;
}
.shipping-calculator-form #calc_shipping_country_field,
.shipping-calculator-form #calc_shipping_city_field {
	display: none !important;
}
.shipping-calculator-form p.form-row {
	margin-bottom: 15px;
}
.shipping-calculator-form button {
	max-width: none;
}

/** Checkout **/
.woocommerce-form-login-toggle,
.woocommerce-form-coupon-toggle { margin-bottom:1.875rem; }
.woocommerce-form-login-toggle form.woocommerce-form-login,
.woocommerce-form-coupon-toggle form.woocommerce-form-coupon { background-color:#f5f5f5; padding:0.9375rem; }

form.woocommerce-form-login p.form-row-last { margin-top:0; }
p.form-row { margin-bottom:1.875rem; margin-top:0; }
p.lost_password { margin-bottom:0; margin-top:1.875rem; }

.woocommerce-checkout .woocommerce-notice.woocommerce-error { margin:0 0 1.875rem; }

.woocommerce-NoticeGroup.woocommerce-NoticeGroup-checkout { padding-bottom:1.875rem; }

.woocommerce-account-fields {
		padding-top: 1.875rem;
}
.woocommerce-password-strength {
	padding-top: 15px;
}

.billing-details .woocommerce-account-fields { clear:both; }

h4#ship-to-different-address { clear:both; line-height:18px; }

.woocommerce-additional-fields { clear:both; }

#order_review { background-color:#f5f5f5; padding:0.9375rem; }
table.woocommerce-checkout-review-order-table { width:100%; }
table.woocommerce-checkout-review-order-table th { text-align:left; }
table.woocommerce-checkout-review-order-table th:last-child,
table.woocommerce-checkout-review-order-table td:last-child { text-align:right; }
table.woocommerce-checkout-review-order-table tfoot th,
table.woocommerce-checkout-review-order-table tfoot td { border-top:1px solid #000; padding:0.9375rem; }
table.woocommerce-checkout-review-order-table tfoot tr:first-child th,
table.woocommerce-checkout-review-order-table tfoot tr:first-child td { border-top:3px solid #000; }
table.woocommerce-checkout-review-order-table tfoot tr:last-child th,
table.woocommerce-checkout-review-order-table tfoot tr:last-child td { border-bottom:3px solid #000; }
table.woocommerce-checkout-review-order-table .order-total th,
table.woocommerce-checkout-review-order-table .order-total td { font-family:itc-avant-garde-gothic-pro, sans-serif; font-size:1.125em; font-weight:700; }
table.woocommerce-checkout-review-order-table ul { list-style:none; margin:0; padding:0; }
table.woocommerce-checkout-review-order-table label { font-size:1em; font-weight:400; margin:0; padding:0; }
table.woocommerce-checkout-review-order-table input + label { display:block; }
.woocommerce-checkout-payment { padding-top:1.875rem; text-align:right; }
.woocommerce-checkout-payment ul { list-style:none; margin:0 0 1.875rem; padding:0; text-align:left; }
.woocommerce-checkout-payment ul li input { display:none; }
.woocommerce-checkout-payment ul li label { padding-left:0 !important; }
.woocommerce-checkout-payment button { max-width:none; }

.wc-saved-payment-methods li {
	padding-top: 10px;
}
.wc-saved-payment-methods li:first-child {
	padding-top: 0;
}
#stripe-payment-data input {
	display: block !important;
}
.woocommerce-terms-and-conditions-wrapper {
	padding-bottom: 15px;
	text-align: left;
}

/** My Account **/
.woocommerce-form.boxed { background-color:#f5f5f5; padding:0.9375rem; }

nav.woocommerce-MyAccount-navigation { }
nav.woocommerce-MyAccount-navigation ul { list-style:none; margin:0; padding:0; }
nav.woocommerce-MyAccount-navigation ul li { border-top:1px solid #eee; padding:0.625rem; }
nav.woocommerce-MyAccount-navigation ul li:first-child { border-top:none; }
nav.woocommerce-MyAccount-navigation ul li a { font-size:1.125em; font-weight:600; text-decoration:none; }
nav.woocommerce-MyAccount-navigation ul li a:hover,
nav.woocommerce-MyAccount-navigation ul li.is-active a { border-bottom:2px solid #000; }

td.download-remaining { font-family: sans-serif; }

ul.payment_methods { list-style: none; margin-bottom: 1.875rem; padding: 0; }
ul.payment_methods .payment_box { margin-top: 0.9375rem; }
ul.payment_methods input[type="checkbox"], 
ul.payment_methods input[type="radio"] { width: 18px !important; }
ul.payment_methods input[type="checkbox"] + label, 
ul.payment_methods input[type="radio"] + label { display: block !important; line-height: 18px; margin: 0;}

/** Video Library **/
.video-link { text-decoration: none !important; }
.video-link,
.video-link span { display:block; position:relative; z-index:5; }
.video-link.active { z-index:0; }
.video-link span.title { font-family:itc-avant-garde-gothic-pro, sans-serif; font-size:1.875em; font-weight:700; margin:1.875rem 0 0.5em; }
.video-link span.image-wrap { z-index:0; }
.video-link span.image-wrap span.hover { background-color:#000; background-color:rgba(0,0,0,0.5); opacity:0; position:absolute; top:0; right:0; bottom:0; left:0; z-index:5;
	-webkit-transition:opacity 0.25s ease-out;
	transition:opacity 0.25s ease-out;
}
.video-link span.image-wrap span.hover span.play-btn { color:#fff; font-size:2.5em; position:absolute; top:50%; right:0; left:0; text-align:center;
	-webkit-transform:translateY(-50%);
	        transform:translateY(-50%);
}
.video-link.active span.image-wrap span.hover,
.video-link:hover span.image-wrap span.hover { opacity:1; }

.video-wrap { position:relative; z-index:5; }
.video-player {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
}

.video-player iframe,  
.video-player object,  
.video-player embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/* ==========================================================================
   Layouts/Graphic Styles
   ========================================================================== */
.content-area { padding-bottom:1.875rem; padding-top:1.875rem; }
.content-area.x2 { padding-bottom:3.75rem; padding-top:3.75rem; }
.content-area.bottom-x0 { padding-bottom:0 !important; }
.content-area.top-x0 { padding-top:0 !important; }

.divider,
.divider-small,
.divider-medium,
.divider-large { padding-top:1.875rem; }

.background-black { background-color:#000; color:#fff; }
.background-black a { color:#fff; }
.background-white { background-color:#fff; color:#000; }
.background-white a { color:#000; }

section.content-area.background-black + section.content-area.background-black,
section.content-area.background-white + section.content-area.background-white { padding-top:0 !important; }

figure { margin:0; padding:0; }

/** Accordion **/
.accordion { padding-top:2.5rem; }
body.woocommerce-account .accordion { padding-top:0; }
.accordion .accordion-panel { }
.accordion .accordion-panel .panel-title { position:relative; }
.accordion .accordion-panel .panel-title:hover { z-index:10; }
.accordion .accordion-panel .panel-title a { border-bottom:none; border-top:3px solid #000; color:#000; display:block; font-family:itc-avant-garde-gothic-pro, sans-serif; font-size:1.875em; font-weight:700; line-height:1; padding:0.6666em 2.5rem 0.6666em 0; position:relative; text-decoration:none; }
.accordion .accordion-panel:first-child .panel-title a { border-top:none; }
.accordion .accordion-panel .panel-title a span { display:block; font-size:1.25em; height:30px; line-height:30px; margin-top:-15px; position:absolute; top:50%; right:0; text-align:center; width:30px;
	transition:transform 0.25s ease-out;
}
.accordion .accordion-panel .panel-title a span i { line-height:30px; }
.accordion .accordion-panel .panel-title a:hover,
.accordion .accordion-panel.open .panel-title a { color:#000; }
.accordion .accordion-panel.open .panel-title a span {
	transform:scaleY(-1);
}
.accordion .accordion-panel .panel-title a:hover span::before,
.accordion .accordion-panel .panel-title a:hover span::after,
.accordion .accordion-panel.open .panel-title a span::before,
.accordion .accordion-panel.open .panel-title a span::after { background-color:#00add8; }
.accordion .accordion-panel.open .panel-title a span::before { opacity:0; }
.accordion .accordion-panel .panel-content { padding-bottom:3.125em; }
body.woocommerce-account .accordion .accordion-panel .panel-content { padding-bottom:0; }

/* ==========================================================================
   Typography
   ========================================================================== */
h1, h2, h3, legend { font-family:itc-avant-garde-gothic-pro, sans-serif; font-weight:700; margin:0.75em 0; }
h1, h2 { font-size:2.5em; text-transform:uppercase; line-height:1; }
h3, legend { font-size:1.5em; line-height: 1.2; }

em.underline { font-style:normal; text-decoration:underline; }
b, strong { font-weight:600; }

blockquote { margin:0; padding:0; }
blockquote p { font-size:1em; }

big { font-size:125%; }
small { font-size:87.5%; }

dl dt { font-weight:600; }
dl dd { margin-left:0; }

abbr[title],
abbr { border-bottom:none; text-decoration:none; }

address { font-style: normal; }

h1:first-child, h2:first-child, h3:first-child, h4:first-child, h5:first-child, p:first-child, ul:first-child, ol:first-child, dl:first-child { margin-top:0 !important; }
h1:last-child, h2:last-child, h3:last-child, h4:last-child, h5:last-child, p:last-child, ul:last-child, ol:last-child, dl:last-child { margin-bottom:0 !important; }

@font-face {
    font-family: 'Akkurat';
    src: url('../fonts/Akkurat-BoldItalic.woff2') format('woff2'),
        url('../fonts/Akkurat-BoldItalic.woff') format('woff');
    font-weight: 600;
    font-style: italic;
}
@font-face {
    font-family: 'Akkurat';
    src: url('../fonts/Akkurat-LightItalic.woff2') format('woff2'),
        url('../fonts/Akkurat-LightItalic.woff') format('woff');
    font-weight: 300;
    font-style: italic;
}
@font-face {
    font-family: 'Akkurat';
    src: url('../fonts/Akkurat-Bold.woff2') format('woff2'),
        url('../fonts/Akkurat-Bold.woff') format('woff');
    font-weight: 600;
    font-style: normal;
}
@font-face {
    font-family: 'Akkurat';
    src: url('../fonts/Akkurat-Light.woff2') format('woff2'),
        url('../fonts/Akkurat-Light.woff') format('woff');
    font-weight: 300;
    font-style: normal;
}
@font-face {
    font-family: 'Akkurat';
    src: url('../fonts/Akkurat.woff2') format('woff2'),
        url('../fonts/Akkurat.woff') format('woff');
    font-weight: 400;
    font-style: normal;
}
@font-face {
    font-family: 'Akkurat';
    src: url('../fonts/Akkurat-Italic.woff2') format('woff2'),
        url('../fonts/Akkurat-Italic.woff') format('woff');
    font-weight: 400;
    font-style: italic;
}

/* ==========================================================================
   Links
   ========================================================================== */
a { color:#000; outline:none; text-decoration:underline;
  -webkit-transition: color 0.25s ease-out, background-color 0.25s ease-out, border-color 0.25s ease-out; 
     -moz-transition: color 0.25s ease-out, background-color 0.25s ease-out, border-color 0.25s ease-out; 
       -o-transition: color 0.25s ease-out, background-color 0.25s ease-out, border-color 0.25s ease-out; 
          transition: color 0.25s ease-out, background-color 0.25s ease-out, border-color 0.25s ease-out;
}
a:hover { text-decoration:none; }

a.btn { background-color:transparent; border:3px solid; display:inline-block; font-size:1em; font-weight:600; line-height:1; max-width: 230px; padding:1em 1.125em; text-align:center; text-decoration:none; text-transform:uppercase; width:100%; }
.background-black a.btn,
.background-black > p a.btn,
a.btn.white { border-color:#fff; color:#fff; }
.background-black a.btn:hover,
.background-black > p a.btn:hover,
a.btn.white:hover { background-color:#e5e5e5; border-color:#e5e5e5; color:#000; }
.background-white a.btn,
.background-white > p a.btn,
a.btn.black { border-color:#000; color:#000; }
.background-white a.btn:hover,
.background-white > p a.btn:hover,
a.btn.black:hover { background-color:#1a1a1a; border-color:#1a1a1a; color:#fff; }

.background-black a.btn.solid,
.background-black > p a.btn.solid,
a.btn.white.solid { background-color:#fff; border-color:#fff; color:#000; }
.background-black a.btn.solid:hover,
.background-black > p a.btn.solid:hover,
a.btn.white.solid:hover { background-color:#e5e5e5; border-color:#e5e5e5; color:#000; }
.background-white a.btn.solid,
.background-white > p a.btn.solid,
a.btn.black.solid { background-color:#000; border-color:#000; color:#fff; }
.background-white a.btn.solid:hover,
.background-white > p a.btn.solid:hover,
a.btn.black.solid:hover { background-color:#1a1a1a; border-color:#1a1a1a; color:#fff; }

p a.btn { margin-top:0.9375rem; }

a.tile-link { color:#fff; display:block; overflow:hidden; position:relative; text-align:center; text-decoration:none; }
a.tile-link .link-content { display:block; padding:1.875rem; position:absolute; top:50%; right:0; left:0; z-index:5;
	transform:translateY(-50%);
}
a.tile-link .link-content span { display:block; line-height:1; }
a.tile-link .link-content span.title { font-size:2.25em; font-family:itc-avant-garde-gothic-pro, sans-serif; font-weight:700; padding-bottom:2.5rem; text-transform:uppercase; }
a.tile-link .link-content span.sub-title { font-family:itc-avant-garde-gothic-pro, sans-serif; font-size:1em; font-weight:500; }
a.tile-link .link-background { background-position:center; background-repeat:no-repeat; background-size:cover; display:block; position:absolute; top:0; right:0; bottom:0; left:0; z-index:0; 
	transition:transform 0.25s ease-out;
}
a.tile-link .link-background::after { background-color:#000; content:''; display:block; opacity:0.30; position:absolute; top:0; right:0; bottom:0; left:0; z-index:0; 
	transition:opacity 0.25s ease-out;
}
a.tile-link:hover .link-background {
	transform:scale(1.1);
}
a.tile-link:hover .link-background::after { opacity:0.5; }

a.tile-link .link-content .more-details { display:block; opacity:0; padding-top:6.25rem; position:relative;
	transition:margin-top 0.25s ease-out 0.25s, opacity 0.25s ease-out;
}
a.tile-link:hover .link-content .more-details { margin-top:0 !important; opacity:1;
	transition:margin-top 0.25s ease-out, opacity 0.25s ease-out 0.25s;
}
a.tile-link .link-content .more-details::before { background-color:#fff; content:''; display:block; height:3px; margin-left:-25px; position:absolute; top:3.125rem; left:50%; width:50px; }
a.tile-link .link-content .more-details .short-description { display:block; font-weight:600; line-height:1.4; padding-bottom:3.125rem; }
a.tile-link .link-content .more-details span.btn { background-color:transparent; border:3px solid #fff; color:#fff; display:inline-block; font-size:1em; font-weight:600; line-height:1; padding:1.125em; max-width:230px; text-align:center; text-decoration:none; text-transform:uppercase; width:100%;
	transition:all 0.25s ease-out;
}
a.tile-link .link-content .more-details span.btn.solid { background-color:#fff; color:#000; }
a.tile-link .link-content .more-details span.btn:hover { background-color:#e5e5e5; border-color:#e5e5e5; color:#000; }

.woocommerce-loop-product__link { display: block; }
.woocommerce-loop-product__link img { display: block; 
	transition: opacity 0.25s ease-out;
}
.woocommerce-loop-product__link:hover img { opacity: 0.75; }

.social-links a { background-color:#000; border:3px solid #fff; border-left:none; color:#fff; display:block; float:left; font-size:1.25em; height:55px; line-height:49px; text-align:center; text-decoration:none; width:52px; }
.social-links a:first-child { border-left:3px solid #fff; width:55px; }
.social-links a:hover { background-color:#fff; color:#000; }

/* ==========================================================================
   Forms
   ========================================================================== */

input, textarea, select, button,
.select2-container--default .select2-selection--single { background-color:transparent; border:3px solid #000; border-radius:0; color:#000; cursor:pointer; display:block; font-size:1em; font-weight:400; height: 58px; margin:0; padding:1em; outline:none; text-shadow:none; width:100%;
  -webkit-appearance: none;
  -webkit-transition: color 0.25s ease-out, background-color 0.25s ease-out, border-color 0.25s ease-out, opacity 0.25s ease-out; 
          transition: color 0.25s ease-out, background-color 0.25s ease-out, border-color 0.25s ease-out, opacity 0.25s ease-out;
}
input:focus, textarea:focus { background-color:#000; color:#fff; }
textarea,
textarea[rows] { height:140px; }

select { /*background-image:url(../img/select-arrow.png); background-position:center right; background-repeat:no-repeat;*/ }
.generatedcontent select { background-image:none; }
.ginput_container_select,
.select2-container { display:block; position:relative; }
.ginput_container_select::before,
.woocommerce-input-wrapper .select2-container::before { content:'\f0d7'; color:#000; display:block; font-size:1.25em; pointer-events:none; position:absolute; top:50%; right:1rem;
  font-family: FontAwesome;
  font-weight: normal;
  font-style: normal;
  text-decoration: inherit;
	-webkit-transform:translateY(-50%);
			transform:translateY(-50%);
}

/* Select 2 */
.select2-container--default .select2-selection--single { height:58px; }
.select2-container--default .select2-selection--single .select2-selection__rendered { line-height:18px; padding:0; }
.select2-container--default .select2-selection--single .select2-selection__arrow { display:none; }

.select2-dropdown { border:3px solid #000; border-radius:0 !important; }
.select2-search--dropdown { display:none !important; }
.select2-results__option[aria-selected], .select2-results__option[data-selected] { outline:none !important; }
.select2-container--default .select2-results__option--highlighted[aria-selected], .select2-container--default .select2-results__option--highlighted[data-selected] { background-color:#f5f5f5; color:#000; }

input[type="checkbox"], input[type="radio"] { border:2px solid #000; float:left; height:18px; margin-right:0.625rem; width:18px;
-webkit-appearance:none;
    -moz-appearance:none;
    appearance:none; }
input[type="radio"] {
 -webkit-border-radius:50%;
    -moz-border-radius:50%;
         border-radius:50%;
}
input:checked { background-color:#000 !important; background-clip:content-box; border-color:#000; outline:none; padding:2px; }

input[type=number]::-webkit-inner-spin-button, 
input[type=number]::-webkit-outer-spin-button { 
  -webkit-appearance: none; 
  margin: 0; 
}

.quantity.buttons_added { margin-right:3px; padding-right:33px; position:relative; width:99px; }
.quantity.buttons_added input { font-family:itc-avant-garde-gothic-pro, sans-serif; font-size:1.875em; font-weight:700; height:66px; padding:0; text-align:center; width:66px; }
.quantity.buttons_added input.plus,
.quantity.buttons_added input.minus { background-color:#000; border:none; color:#fff; font-family:'Akkurat'; font-size:1.5em; font-weight:600; height:33px; padding:0; position:absolute; top:0; right:0; width:33px; }
.quantity.buttons_added input.minus { top:auto; bottom:0; }

label { display:block; font-size:1.125em; font-weight:600; margin-bottom:0.3125rem; }
.woocommerce-form__label-for-checkbox { line-height:18px; margin-bottom:0; }
input + label { display:none; }
.placeholder-support label.checkbox,
.placeholder-support label.inline { display:block; font-size:1.125em; font-weight:500; }

.gform_wrapper ul li .ginput_container_checkbox { }
.gform_wrapper ul li .ginput_container_checkbox li {  margin-bottom:0; margin-top:0.625rem; }
.gform_wrapper ul li .ginput_container_checkbox li input + label { display:block; margin-bottom:0; }

.ginput_container_checkbox::before, .ginput_container_checkbox::after, .ginput_container_checkbox ul::before, .ginput_container_checkbox ul::after {
  content: ' ';
  display: table; }

.ginput_container_checkbox::after, .ginput_container_checkbox ul::after {
  clear: both; }

.gform_footer { clear:both; padding-top:0.9375rem; position:relative; text-align:left; }

button { background-color:#000; border:3px solid #000; color:#fff; display:inline-block; font-size:1em; font-weight:600; height:58px; line-height:1; max-width: 230px; padding:0 1.125em; position: relative; text-align:center; text-decoration:none; text-transform:uppercase; width:100%; }
button:hover,
button:focus { background-color:#1a1a1a; border-color:#1a1a1a; color:#fff; }

button.ajax_add_to_cart.disabled { pointer-events: none; }
button.ajax_add_to_cart::before { background: url("../img/button-spinner@2x.gif") no-repeat 0 0; background-size: contain; content: ''; display: block; height: 32px; opacity: 0; position: absolute; top: 50%; right: 0.3125rem; width: 32px;
	transform: translateY(-50%);
	transition: opacity 0.25s ease-out;
}
button.ajax_add_to_cart::after { content:'\f00c'; display: block; font-size: 1.125em; height: 32px; line-height: 32px; opacity: 0; position: absolute; top: 50%; right: 0.3125rem; width: 32px;
	font-family: FontAwesome;
  	font-weight: normal;
 	 font-style: normal;
	transform: translateY(-50%);
	transition: opacity 0.25s ease-out;
}
button.ajax_add_to_cart.loading::before,
button.ajax_add_to_cart.added::after { opacity: 1; }

.gform_wrapper ul { font-size:1em; list-style:none; margin:0; padding:0; }
.gform_wrapper ul li { margin-bottom:1.875rem; text-align:left; }
#update_all_subscriptions_addresses_field,
.gf_clear { clear:both; }

::-webkit-input-placeholder { color:#000; }
:-moz-placeholder { color: #000; }
::-moz-placeholder { color: #000; }
:-ms-input-placeholder { color: #000; }

/** Warnings **/
.validation_error { display:none; }
.validation_message { display:none !important; }
.gfield_contains_required.gfield_error input,
.gfield_contains_required.gfield_error textarea,
.gfield_contains_required.gfield_error select,
.gfield_contains_required.gfield_error .jcf-select { border-color:#ff0000; }
.gfield_contains_required.gfield_error label { color:#ff0000 !important; }

.gform_confirmation_message { font-size:1.125em; }

img.gform_ajax_spinner { height:32px; position:absolute; right:0; top:50%; width:32px;
	transform:translateY(-50%);
}

.input_left,
.input_right,
.name_first,
.name_last,
.input_mid { display:block; }
.name_first { margin-bottom:0.9375rem; }
.gf_clear { clear:both; }

.gform_body::before, .gfield::before, .clear-multi::before, .gform_body::after, .gfield::after, .clear-multi::after {
  content: ' ';
  display: table; }

.gform_body::after, .gfield::after, .clear-multi::after {
  clear: both; }
 

/* Small screens */
@media only screen { } /* Define mobile styles */

@media only screen and (max-width: 39.99em) {
	
	section.banner-row--internal ul.slides li { padding-top: 100px !important; }
	
	.responsive-table { overflow-x: scroll;
		-webkit-overflow-scrolling:touch;
	}
	.responsive-table table { min-width: 600px; }
	table.shop_table tbody td.actions .actions-container { display: block; text-align: right; }
	table.shop_table tbody td.actions .actions-container .coupon { width: 100%; padding-bottom: 0.9375rem; }
	
} /* max-width 640px, mobile-only styles, use when QAing mobile issues */

/* Medium screens - min-width 640px */
@media only screen and (min-width: 40em) {
	
	#top-bar { padding-bottom:3.125rem; padding-top:3.125rem; }
	#top-bar h1 { height:55px; width:215px; }
	#top-bar .header-functions { padding-top:0.625rem; }
	button.menu-button { margin-top:7px; }
	
	#site-wrapper.menu-open {
		transform:translateX(-400px);
	}

	#site-navigation { padding-bottom: 145px; padding-top:155px; left:auto; right:-400px; width:400px; }
	#site-navigation.visible { right:0; left:auto; }
	#site-navigation .social-links { bottom:3.75rem; }
	#site-navigation button.menu-button { top:60px; right:35px; }
	
	#bottom-bar .footer-content { padding-bottom:3.125rem; padding-top:3.125rem; }
	#bottom-bar .legality { padding-bottom:1.875rem; padding-top:1.875rem; }
	
	section.banner-row { max-height: 700px; min-height: 700px; }
	section.banner-row ul.slides li h1 { font-size:5em; }
	/*section.banner-row ul.slides li p { font-size:1.125em; }*/
	section.banner-row ul.slides li .banner-buttons a.btn { margin-left:1.875rem; width: 100%; }
	section.banner-row ul.slides li .banner-buttons a.btn:first-child { margin-left:0; }
	section.banner-row .controls-container { position:absolute; bottom:3.125rem; left:0; right:0; z-index:5; }
	/*section.banner-row--internal { max-height: 600px; min-height: 600px; }*/
	
	ul.products li { width:50%; }
	ul.products.columns-3 li { width:100%; }
	
	.woocommerce-notice,
	.woocommerce-Message { padding:0.9375rem 1.875rem; }
	.woocommerce-notice a,
	.woocommerce-Message a { float:right; }
	
	.single-product .single_variation_wrap { align-items:center; display:flex; }
	.single-product .single_variation_wrap .woocommerce-variation.single_variation { padding-bottom: 0; }
	
	.variations .value > div label { font-size:1em; padding:1.25rem; }
	.quantity.buttons_added { margin-right:1.875rem; }
	
	.single-product .image-replacement .side-content { padding-left: 1.875rem; padding-right: 1.875rem; }
	
	table.shop_table thead th { font-size:1.125em; padding:0 0.9375rem 0.625rem; }
	table.shop_table tbody td { padding:0.9375rem; }
	table.shop_table thead th.product-thumbnail,
	table.shop_table tbody td.product-thumbnail { display: table-cell; width:130px; }
	table.shop_table tbody td.actions { padding-bottom:1.875rem; padding-top:1.875rem; }
	table.shop_table tfoot th,
	table.shop_table tfoot td { padding:0.9375rem;}
	
	.cart-collaterals table th { padding:0.9375rem; }
	.cart-collaterals table .order-total th,
	.cart-collaterals table .order-total td { font-size:1.25em; }
	.cart-collaterals .wc-proceed-to-checkout { padding-top:1.875rem; }
	
	.woocommerce-form-login-toggle form.woocommerce-form-login,
	.woocommerce-form-coupon-toggle form.woocommerce-form-coupon { padding:1.875rem; }
	#order_review { padding:1.875rem; }
	
	.woocommerce-form.boxed { padding:1.875rem; }
	
	nav.woocommerce-MyAccount-navigation ul li { float: left; width: 50%; }
	nav.woocommerce-MyAccount-navigation ul li:first-child,
	nav.woocommerce-MyAccount-navigation ul li:nth-child(2) { border-top:none; }
	nav.woocommerce-MyAccount-navigation ul li:nth-child(odd) { border-right:1px solid #eee; }
	
	.outer-row { padding-left:0.9375rem; padding-right:0.9375rem; }
	
	.content-area { padding-bottom:3.750rem; padding-top:3.750rem; }
	.content-area.x2 { padding-bottom:7.5rem; padding-top:7.5rem; }
	.content-area.stop-small { padding-bottom:0; padding-top:0; }
	.content-area.stop-medium { padding-bottom:0; padding-top:0; }
	
	.divider,
	.divider-medium,
	.divider-large { padding-top:1.875rem; }
	.divider-small { padding-top:0 !important; }
	
	h1, h2 { font-size:3em; }
	h3, legend { font-size:1.875em; }
	blockquote p { font-size:1.125em; }
	
	a.btn { padding:1.125em; }
	p a.btn { margin-top:1.875rem; }
	a.tile-link .link-content span.title { font-size:3em; }
	a.tile-link .link-content span.sub-title { font-size:1.125em; }
	
	.input_left,
	.input_right,
	.name_first,
	.name_last,
	.input_mid,
	.form-row-first,
	.form-row-last,
	#billing_phone_field,
	#billing_email_field,
	#account_username_field,
	#account_password_field { float:left; width:50%; }
	.input_left,
	.name_first,
	.form-row-first,
	#billing_phone_field,
	#account_username_field { padding-right:0.9375rem !important; }
	.input_right,
	.name_last,
	.form-row-last,
	#billing_email_field,
	#account_password_field { padding-left:0.9375rem !important; }
	.name_first { margin-bottom:0; }
	
	#billing_city_field,
	#billing_state_field,
	#billing_postcode_field,
	#shipping_city_field,
	#shipping_state_field,
	#shipping_postcode_field { float:left; width:33.33%; }
	#billing_city_field,
	#shipping_city_field { padding-right:1.25rem; }
	#billing_state_field,
	#shipping_state_field { padding-left:0.625rem; padding-right:0.625rem; }
	#billing_postcode_field,
	#shipping_postcode_field { padding-left:1.25rem; }
	
	.woocommerce-account-fields {
		padding-top: 0;
}
	.woocommerce-account-fields #account_password_field {
		padding-left: 0 !important;
		padding-right: 0.9375rem !important;
	}
	.woocommerce-account-fields #account_username_field {
		padding-left: 0.9375rem !important;
		padding-right: 0 !important;
	}

} @media only screen and (min-width: 40em) and (max-width: 64em) { } /* min-width 641px and max-width 1024px, use when QAing tablet-only issues */

/* Large screens - min-width 1024px */
@media only screen and (min-width: 64em) {
	
	#site-navigation .social-links { left:45px; }
	#site-navigation button.menu-button { right:45px; }
	
	section.banner-row { max-height: 800px; }
	/*section.banner-row--internal { max-height: 700px; }*/
	section.banner-row ul.slides li h1 { font-size:6.5em; }
	section.banner-row ul.slides li p { max-width: 90%; }
	
	section.content-row > .row { display: flex; }
	section.content-row.image-right > .row { flex-direction: row-reverse; }
	section.content-row .image-replacement .replaced-image { background-position:right center; background-repeat:no-repeat; position:absolute; top:0; right:-1.563em; bottom:0; left:-9999px; }
	section.content-row.image-right .image-replacement .replaced-image { background-position:left center; right:-9999em; left:-1.563em; }
	section.content-row .image-replacement img { opacity:0; max-width:850px; position:relative; z-index:-1; }
	
	section.tile-row::after { top:50%; }
	section.tile-row .tile-container .columns:first-child { padding-right:1.875rem; }
	section.tile-row .tile-container .columns:last-child { padding-left:1.875rem; }
	
	ul.products li { width:33.33%; }
	ul.products.columns-3 li { width:33.33%; }
	
	/** Catalog - Coaching **/
	ul.products li.product_cat-coaching-packages:nth-child(1) { padding-right:1.875rem; }
	ul.products li.product_cat-coaching-packages:nth-child(2) { padding-left:0; padding-right:0; }
	ul.products li.product_cat-coaching-packages:nth-child(3) { padding-left:1.875rem; }
	
	.single-product .image-replacement .replaced-image { right:auto; width:850px; }
	.single-product .image-replacement .side-content { padding-left: 0; padding-right: 0; }
	
	nav.woocommerce-MyAccount-navigation ul li { float: none; width: 100%; }
	nav.woocommerce-MyAccount-navigation ul li:first-child { border-top:none; }
	nav.woocommerce-MyAccount-navigation ul li:nth-child(2) { border-top:1px solid #eee; }
	nav.woocommerce-MyAccount-navigation ul li:nth-child(odd) { border-right:none; }
	
	.outer-row { padding-left:1.875rem; padding-right:1.875rem; }
	
	.content-area { padding-bottom:6.25rem; padding-top:6.25rem; }
	.content-area.x2 { padding-bottom:10rem; padding-top:10rem; }
	.content-area.stop-small { padding-bottom:0; padding-top:0; }
	.content-area.stop-medium { padding-bottom:0; padding-top:0; }
	.content-area.stop-large { padding-bottom:0; padding-top:0; }
	
	.divider-medium { padding-top:0 !important; }
	
	h1, h2 { font-size:3em; }
	blockquote p { font-size:1.25em; }
	
	a.tile-link .link-content span.title { font-size:3em; }

} @media only screen and (min-width: 64em) and (max-width: 90em) { } /* min-width 1025px and max-width 1440px, use when QAing large screen-only issues */

/* XLarge screens - min-width 1440px */
@media only screen and (min-width: 90em) {
	
	section.banner-row { max-height: 1000px; }
	/*section.banner-row--internal { max-height: 900px; }*/
	section.banner-row ul.slides li h1 { font-size:7.5em; }
	
	ul.products li { width:25%; }
	
	h1, h2 { font-size:3.75em; }
	
	a.tile-link .link-content span.title { font-size:3.75em; }
	
} @media only screen and (min-width: 90em) and (max-width: 97.500em) { } /* min-width 1441px and max-width 1560px, use when QAing xlarge screen-only issues */

/* XXLarge screens - min-width 1560px */
@media screen and (min-width: 97.500em) {
	
}


/* ==========================================================================
   Plugin Styles
   ========================================================================== */

/** Slider Controls **/
.flex-direction-nav { height:0; list-style:none; margin:0; padding:0; width:100%; }
.flex-direction-nav li { height:0; width:100%; }
.flex-direction-nav li a { background-color:transparent; border:1px solid #000; color:#000; display:block; height:100%; position:absolute; top:0; overflow:hidden; width:51px; text-align:center; z-index:50;
  -webkit-transition: background-color 0.25s ease-out, width 0.25s ease-out; 
     -moz-transition: background-color 0.25s ease-out, width 0.25s ease-out; 
       -o-transition: background-color 0.25s ease-out, width 0.25s ease-out; 
          transition: background-color 0.25s ease-out, width 0.25s ease-out;
}
.flex-direction-nav li a i { margin-top:-0.5em; position:absolute; top:50%; }
.flex-direction-nav li a.flex-next { border-right:none; right:-50px; }
.flex-direction-nav li a.flex-prev { border-left:none; left:-50px; }
.flex-direction-nav li a.flex-disabled { color:#999; cursor:not-allowed; }

.flex-direction-nav li a:hover { background-color:#000; color:#fff; }
.flex-direction-nav li a.flex-disabled:hover { background-color:transparent; color:#999; }

.flex-control-paging { list-style:none; margin:0; padding:0; }
.flex-control-paging li { display:block; float:left; height:15px; margin-left:0.625rem; width:15px; }
.flex-control-paging li:first-child { margin-left:0; }
.flex-control-paging li a { border:2px solid #fff; background-color:transparent; cursor:pointer; display:block; height:15px; overflow:hidden; text-indent:999px; width:15px;
  -webkit-border-radius: 50%;
          border-radius: 50%; 
  background-clip: border-box;
}
.flex-control-paging li a:hover,
.flex-control-paging li a.flex-active { background-color:#fff; }

/* FlexSlider Necessary Styles
*********************************/
.flexslider {margin: 0; padding: 0;}
.flexslider .slides > li { opacity: 0; } /* Hide the slides before the JS is loaded. Avoids image jumping */
.flexslider .slides img {width: 100%; display: block;}

/* Clearfix for the .slides element */
.slides:after {content: "\0020"; display: block; clear: both; visibility: hidden; line-height: 0; height: 0;}
html[xmlns] .slides {display: block;}
* html .slides {height: 1%;}

/* No JavaScript Fallback */
/* If you are not using another script, such as Modernizr, make sure you
 * include js that eliminates this class on page load */
.no-js .slides > li:first-child {display: block;}

/*!--------------------------------------------------------------------
STYLES "Outdated Browser"
Version:    1.1.0 - 2014
author:     Burocratik
website:    http://www.burocratik.com
* @preserve
-----------------------------------------------------------------------*/
#outdated{
    display: none; position: fixed; top: 0; left: 0; width: 100%; height: 170px;
    text-align: center; text-transform: uppercase; z-index:1500;
    background-color: #f25648; color: #ffffff;
}
* html #outdated{position: absolute;}
#outdated h6{font-size: 25px; line-height: 25px; margin: 30px 0 10px;}
#outdated p{font-size: 12px; line-height: 12px; margin: 0;}
#outdated #btnUpdateBrowser{
    display: block; position: relative; padding: 10px 20px; margin: 30px auto 0; width: 230px; /*need for IE*/
    color: #ffffff; text-decoration: none; border: 2px solid #ffffff; cursor: pointer;
}
#outdated #btnUpdateBrowser:hover{color: #f25648; background-color:#ffffff;}
#outdated .last{position: absolute; top: 10px; right: 25px; width: 20px; height: 20px;}
#outdated #btnCloseUpdateBrowser{ border-bottom:none;
    display: block; position: relative; width: 100%; height: 100%;
    text-decoration: none; color: #ffffff; font-size: 36px; line-height: 36px;
}

/* ==========================================================================
   Helper classes
   ========================================================================== */

/*
 * Image replacement
 */

.ir {
    background-color: transparent;
    border: 0;
    overflow: hidden;
    /* IE 6/7 fallback */
    *text-indent: -9999px;
}

.ir:before {
    content: "";
    display: block;
    width: 0;
    height: 150%;
}

/*
 * Hide from both screenreaders and browsers: h5bp.com/u
 */

.hidden {
    display: none !important;
    visibility: hidden;
}

/*
 * Hide only visually, but have it available for screenreaders: h5bp.com/v
 */

.visuallyhidden {
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}

/*
 * Extends the .visuallyhidden class to allow the element to be focusable
 * when navigated to via the keyboard: h5bp.com/p
 */

.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
    clip: auto;
    height: auto;
    margin: 0;
    overflow: visible;
    position: static;
    width: auto;
}

/*
 * Hide visually and from screenreaders, but maintain layout
 */

.invisible {
    visibility: hidden;
}