@import url("https://fonts.googleapis.com/css?family=Open+Sans:300,400,700");
@import url('https://fonts.googleapis.com/css2?family=Rock+Salt&display=swap');
/* The above import directives are aggregated from content. */
@font-face {
    font-family: "Gotham Bold";
    src: url("../../frontend/Knapheide/storefront/en_US/fonts/gotham-bold.otf");
}
@font-face {
    font-family: "Gotham Light";
    src: url("../../frontend/Knapheide/storefront/en_US/fonts/gotham-light.otf");
}

.gotham-bold {
    font-family: "Gotham Bold", Gotham, serif;
}
.gotham-light {
    font-family: "Gotham Light", Gotham, serif;
}

/** might not need - including for now */
.rock-salt {
    font-family: "Rock Salt", cursive;
    font-weight: 400;
    font-style: normal;
}

*, *:before, *:after {
    box-sizing: border-box;
}

body {
    font-family: 'Open Sans', sans-serif;
}

a, .alink {
    color: #df1e36;
    text-decoration: none;
}

a:visited, .alink:visited {
    color: #df1e36;
    text-decoration: none;
}

a:hover {
    color: #df1e36;
}

.sr-only {
    position: absolute;
    left: -10000px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

/** Accounts */
.account.page-layout-2columns-left .column.main {
    width: 77.7% !important;
    float: right;
    -ms-flex-order: 2;
    -webkit-order: 2;
    order: 2;
}

@media (max-width: 768px) {

    .account .block-collapsible-nav .title {
        border-top: 1px solid #cccccc;
        cursor: pointer;
        margin-bottom: 0;
        position: relative;
        border-bottom: 1px solid #cccccc;
        padding: 10px 40px 10px 15px;
        display: block;
        text-decoration: none;
        background-color: #eaeaea;
    }

    .account .block-collapsible-nav {
        left: 0;
        position: absolute;
        top: -8px;
        width: 100%;
        z-index: 5;
    }

    .account .block-collapsible-nav .item.current a, .block-collapsible-nav .item.current > strong {
        border-color: #df1e36;
        color: #000000;
        font-weight: 600;
    }
}

/** Button 1e */
button.action.primary, button.action-primary {
    overflow: hidden;
    background-color: #df1e36;
    color: #fff;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    position: relative;
    border: none !important;
    border-radius: 0;
}

button.action.primary:focus, .action.primary:active, button.action-primary:focus, button.action-primary:active {
    background: #df1e36;
    border: none;
    color: #ffffff;
}

button.action-secondary {
    overflow: hidden;
    border: none !important;
    border-radius: 0;
}

button.action.primary span {
    position: relative;
    z-index: 10;
}

button.action.primary:after,
button.action.primary:focus:after,
button.action.primary:active:after {
    width: 100%;
    height: 0;
    top: 50%;
    left: 50%;
    background: #000;
    color: #fff;
    opacity: 0;
    -webkit-transform: translateX(-50%) translateY(-50%) rotate(45deg);
    -moz-transform: translateX(-50%) translateY(-50%) rotate(45deg);
    -ms-transform: translateX(-50%) translateY(-50%) rotate(45deg);
    transform: translateX(-50%) translateY(-50%) rotate(45deg);
    content: '';
    position: absolute;
    z-index: 0;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
}

button.action.primary:hover,
button.action.tocart:active {
    color: #fff;
    background-color: #df1e36;
}

button.action.primary:hover:after {
    height: 260%;
    opacity: 1;
}

button.action.primary:active:after,
button.action.primary:focus:after {
    height: 400%;
    opacity: 1;
}

img {
    max-width: 100%;
    height: auto;
}

.interior-page-top {
    background: url("../../frontend/Knapheide/storefront/en_US/images/black-grill.jpg");
    background-size: 800px;
    text-align: center;
    margin-bottom: 10px;
}

@media only screen and (max-width: 768px) {
    .magestore-bannerslider-standard {
        width: 100% !important;
    }
}

/** Header */
.page-header .header.panel {
    padding-bottom: 5px;
    padding-top: 5px;
}

.page-header .header.panel .header-left-area, .page-header .header.panel .header-center-area {
    float: none;
    width: 100%;
    text-align: center;
    font-weight: bold;
}

.page-header .header.panel .header-left-area h4 {
    margin: 3px 0 0;
}

.header.content .nav-toggle {
    display: none;
}

@media (min-width: 768px) {
    .page-header .header.panel .header-left-area {
        float: left;
        width: 25%;
        text-align: left;
    }

    .page-header .header.panel .header-center-area {
        width: 50%;
        margin: auto;
        display: inline-block;
        text-align: center;
    }
}

.logo {
    float: left;
    margin: 10px 0 10px 0;
    max-width: 50%;
    position: relative;
    z-index: 5;
}

.logo:hover {
    text-decoration: none;
}

#logoSubtext {
    text-align: center;
    margin-top: 5px;
}
#logoSubtext > b {
    margin-left: -15px;
    font-size: 11px;
    color: #282428;
}

.customer-welcome button.action.switch {
    color: black;
}

/** Page titles */
.page-title-wrapper {
    /*background-color: #df1e36;*/
    padding-top: 20px;
    padding-bottom: 6px;
}

.checkout-cart-index .page-title-wrapper,
.catalogsearch-result-index .page-title-wrapper {
    padding-bottom: 20px;
}

.page-title-wrapper h1.page-title {
    font-family: 'Open Sans', sans-serif;
    font-size: 48px;
    font-weight: 600;
    text-transform: uppercase;
    margin-bottom: 0;
    color: #fff;
}

@media (min-width: 768px) {
    .page-title-wrapper h1.page-title {
        font-size: 68px;
    }
}

.category-description {
    /*background-color: #df1e36;*/
    color: #fff;
    font-size: 18px;
    text-transform: uppercase;
    font-weight: 300;
    margin-bottom: 0;
}

@media (min-width: 768px) {
    .category-description {
        font-size: 24px;
    }
}

div.interior-page-top div:only-child {
    padding-bottom: 15px;
    margin-bottom: 0;
}

div.interior-page-top .category-description {
    padding-bottom: 15px;
    margin-bottom: 0;
}

/** Product listing styles */
.product-items {
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
}

.column.main li.product-item {
    width: inherit !important;
    flex: 1 0 21%;
    max-width: 235px;
    margin-right: 5px;
}

@media (min-width: 768px), print {
    .column.main li.product-item {
        text-align: left;
    }
}

.product-item-info {
    width: 100% !important;
    padding: 0;
}

.product-item .price-box {
    margin: 0;
}

.products-grid .product-item-info:hover, .products-grid .product-item-info.active {
    background: inherit;
    box-shadow: none;
    border: none;
    margin: 0 !important;
    padding: 0;
    position: relative;
    z-index: 2;
}

.mp-product-item-name {
    height: 40px !important;
    text-transform: uppercase;
    font-weight: 300;
    font-size: 16px;
}

.mp-product-item-name a {
    color: #000;
}

.action.primary {
    background-image: none;
    background: #df1e36;
    border: 1px solid #df1e36;
    color: #fff;
    cursor: pointer;
    display: inline-block;
    font-family: 'Open Sans','Helvetica Neue',Helvetica,Arial,sans-serif;
    font-weight: 300;
    padding: 10px 20px;
    font-size: 1.4rem;
    box-sizing: border-box;
    vertical-align: middle;
    text-transform: uppercase;
}

.product-item-actions,
.product-item-actions .actions-primary {
    /*  display: block;
    */

    margin-top: 0;
}

.product-item .price-box .price {
    font-weight: 700;
    white-space: nowrap;
    font-size: 22px;
    color: #df1e36;
}

.product-item .old-price {
    display: block;
    margin: 0;
}

.product-item .old-price .price {
    font-weight: normal;
    font-size: 14px;
    color: #000;
}

.products-grid .product-item-inner {
    background: transparent;
    box-shadow: none;
    border: none;
    border-top: none;
    margin: 0;
    padding: 0;
    right: auto;
}

.abs-visually-hidden-desktop-s, .products-grid .product-item-info:not(:hover):not(.active) .product-item-inner {
    border: 0;
    clip: inherit;
    height: auto;
    margin: 0;
    overflow: visible;
    padding: 0;
    position: relative;
    width: auto;
}

.products-grid .product-item-info:not(:hover):not(.active) .product-item-inner {
    border: 0;
    clip: inherit;
    height: auto;
    margin: 0;
    overflow: visible;
    padding: 0;
    position: relative;
    width: auto;
}

.products-grid .product-item-info a {
    display: inline-block;
}

.products-grid .product-item-actions {
    margin: 0 !important;
}

.product-image-photo {
    bottom: 0;
    display: block;
    height: auto;
    left: 0;
    margin: auto;
    max-width: 98%;
    position: absolute;
    right: 0;
    top: 0;
    box-shadow: 0px 0px 5px -1px rgba(234, 234, 234, 1);
}

img.product-image-photo:hover {
    border-bottom: 3px solid #df1e36;
    margin-top: 2px;
}

a.product.photo.product-item-photo {
    display: inline-block;
}

/** Top Bar*/
header.page-header {
    margin-bottom: 0;
}

header.page-header .panel.wrapper {
    background-color: #e1e1e1;
    color: #000;
    text-transform: uppercase;
}

header.page-header .panel.wrapper .header.links li a {
    color: #000;
}

@media (min-width: 768px), print {
    header.page-header .panel.wrapper {
        border-bottom: 1px solid #e8e8e8;
        background-color: #e1e1e1;
    }
}

.fotorama__stage__frame .fotorama__img {
    box-shadow: 0px 0px 5px -1px rgba(234, 234, 234, 1);
}


.width100 {
    width: 100%;
}


/* Homepage Slider */
.cms-home .custom-slider .owl-stage-outer,
.cms-home .custom-slider {
    padding: 0 !important;
}

.cms-home .custom-slider .owl-theme .owl-nav {
    margin-top: 0;
}

.cms-home .message.success {
    margin: 0 !important;
}

/* Page Structure */

.cms-home .columns .column.main {
    order: inherit;
    padding-bottom: 0;
}

.cms-home .block-content {
    box-sizing: border-box;
    margin-left: auto;
    margin-right: auto;
    padding-left: 20px;
    padding-right: 20px;
    width: auto;
}

.cms-home #maincontent.page-main {
    max-width: inherit;
    width: 100%;
    padding-left: 0;
    padding-right: 0;
}

.field.search .control {
    text-align: center;
}

/* Featured Product Sliders */
h2.mp-product-slider-title {
    font-size: 4.5rem;
    margin: 0 0 30px;
    text-align: center;
    text-transform: uppercase;
    font-weight: 600;
    padding-top: 50px;
}

@media (min-width: 1200px), print {
    h2.mp-product-slider-title {
        padding-top: 0;
    }
}

/* Product Category Callout */
div.product-category-callout {
    position: relative;
    margin: 0;
    display: block;
    float: left;
    width: 100%;
    overflow: hidden;
}

@media (min-width: 620px), print {
    div.product-category-callout {
        width: 50%;
        margin: 0;
    }

    div.product-category-callout:nth-of-type(5n+1) {
        width: 100%;
        margin-bottom: 0;
    }
}

@media (min-width: 800px), print {
    div.product-category-callout {
        width: 33.333%;
        margin: 0;
    }

    div.product-category-callout:nth-of-type(5n) {
        width: 50%;
        margin-bottom: 0;
    }

    div.product-category-callout:nth-of-type(5n+1) {
        width: 50%;
        margin-bottom: 0;
    }
}

@media (min-width: 1200px), print {
    div.product-category-callout {
        width: 20%;
        margin: 0 0 50px 0;
    }

    div.product-category-callout:nth-of-type(5n),
    div.product-category-callout:nth-of-type(5n+1) {
        width: 20%;
    }
}

/* Interior page category parts */

.page-products .category-cms {
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
}

.page-products div.product-category-callout {
    position: relative;
    margin: 0 20px 50px 0;
    flex: 0 1 100%;
}

@media (min-width: 700px), print {
    .page-products div.product-category-callout {
        margin: 0 20px 50px 0;
        flex: 0 1 45%;
    }
}

@media (min-width: 1024px), print {
    .page-products div.product-category-callout {
        width: inherit;
        margin: 0 20px 50px 0;
        flex: -1 1 27%;
    }
}

@media (min-width: 1200px), print {
    .page-products div.product-category-callout {
        width: inherit;
        margin: 0 20px 50px 0;
        flex: 0 1 30%;
    }
}

.product-category-callout p:empty {
    display: none;
}

.product-category-callout img.img-bg {
    position: absolute;
    z-index: -1;
    width: 100%;
}

.product-category-callout .content-area {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    color: #fff;
    padding: 9% 8%;
    display: block;
}

.product-category-callout:before {
    content: '';
    position: absolute;
    top: 0;
    left: -20%;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    -webkit-transform-origin: 100% 0;
    -ms-transform-origin: 100% 0;
    transform-origin: 100% 0;
    -webkit-transform: skewX(-33deg);
    -ms-transform: skewX(-33deg);
    transform: skewX(-33deg);
    z-index: 0;
    -webkit-transition: all 0.3s linear;
    -moz-transition: all 0.3s linear;
    -o-transition: all 0.3s linear;
    -ms-transition: all 0.3s linear;
    transition: all 0.3s linear;
}

.product-category-callout:hover:before {
    left: -300%;
}

.product-category-callout:hover:after {
    right: 20%;
}

.product-category-callout:after {
    content: '';
    position: absolute;
    top: 0;
    right: -180%;
    width: 100%;
    height: 100%;
    background: rgba(425, 59, 52, 0.8);
    -webkit-transform-origin: 100% 0;
    -ms-transform-origin: 100% 0;
    transform-origin: 100% 0;
    -webkit-transform: skewX(-33deg);
    -ms-transform: skewX(-33deg);
    transform: skewX(-33deg);
    z-index: -1;
    -webkit-transition: all 0.3s linear;
    -moz-transition: all 0.3s linear;
    -o-transition: all 0.3s linear;
    -ms-transition: all 0.3s linear;
    transition: all 0.3s linear;
}

.product-category-callout .content-area h2 {
    font-family: 'Open Sans', sans-serif;
    font-size: 44px;
    font-weight: 300;
    line-height: 1;
    text-transform: uppercase;
    margin-bottom: 0;
    color: #fff;
    padding-top: 0;
    margin-top: 0;
}

@media (min-width: 620px) {
    .product-category-callout .content-area h2 {
        font-size: 38px;
    }
}

@media (min-width: 768px) {
    .product-category-callout .content-area h2 {
        font-size: 38px;
    }
}

@media (min-width: 1500px) {
    .product-category-callout .content-area h2 {
        font-size: 44px;
    }
}

.product-category-callout:hover .content-area h2 {
    color: #000;
}

.product-category-callout .content-area h2 span {
    display: inline;
}

@media (min-width: 620px) {
    .product-category-callout .content-area h2 span {
        display: block;
    }
}

@media (min-width: 1900px) {
    .product-category-callout .content-area h2 span {
        display: inline;
    }
}

.product-category-callout .content-area h2 span.bolder {
    font-weight: 700;
}

.product-category-callout .content-area button {
    border-radius: 0;
    background-color: #f20038;
    color: #fff;
    text-transform: uppercase;
    border: none;
    box-shadow: none;
    padding: 20px;
    margin-top: 20px;
    font-size: 18px;
    font-weight: 300;
}

@media (min-width: 1024px) {
    .product-category-callout .content-area button {
        padding: 15px 20px;
        margin-top: 20px;
    }
}

@media (min-width: 1200px) {
    .product-category-callout .content-area button {
        margin-top: 15px;
    }
}

@media (min-width: 1900px) {
    .product-category-callout .content-area button {
        padding: 20px 40px;
        margin-top: 30px;
    }
}

.product-category-callout:hover .content-area button {
    background-color: #000;
}

/* Product Banner Callout */
.product-banner-callout {
    position: relative;
    margin: 50px 0 0;
    height: 450px;
    overflow: hidden;
}

@media (min-width: 1200px) {
    .product-banner-callout {
        margin: 0;
    }
}

.product-banner-callout .img-bg {
    position: relative;
    z-index: -1;
    background-size: cover;
    background-position: center center;
    width: 100%;
}

.product-banner-callout .content-area {
    width: 54%;
    height: 450px;
    padding: 20px;
    position: relative;
    top: -460px;
}

@media (min-width: 768px) {
    .product-banner-callout .content-area {
        padding: 40px 40px 40px 80px;
    }
}

@media (min-width: 1260px) {
    .product-banner-callout .content-area {
        width: 40%;
    }
}

.product-banner-callout .content-area:after {
    background: rgba(223, 30, 54, 0.8);
    bottom: 0;
    content: '';
    display: block;
    height: inherit;
    left: -175px;
    position: absolute;
    transform: skewX(150.5deg);
    transform-origin: 104%;
    z-index: -1;
    width: 102%;
}

@media (min-width: 500px) {
    .product-banner-callout .content-area:after {
        width: 80%;
    }
}

@media (min-width: 768px) {
    .product-banner-callout .content-area:after {
        width: 75%;
    }
}

@media (min-width: 1260px) {
    .product-banner-callout .content-area:after {
        width: 49%;
    }
}

.product-banner-callout:hover .content-area:after {
    background: rgba(0, 0, 0, 0.6);
}

.product-banner-callout h2 {
    font-family: 'Open Sans', sans-serif;
    font-size: 65px;
    font-weight: 300;
    line-height: 1;
    text-transform: uppercase;
    margin-bottom: 0;
    color: #000;
    padding-top: 10px;
    margin-top: 10px;
}

@media (min-width: 710px) {
    .product-banner-callout h2 {
        font-size: 75px;
        margin-top: 0;
        padding-top: 10px;
    }
}

@media (min-width: 940px) {
    .product-banner-callout h2 {
        padding-top: 20px;
        margin-top: 20px;
    }
}

.product-banner-callout:hover h2 {
    color: #fff;
}

.product-banner-callout h2 span.bolder {
    font-weight: 700;
}

.product-banner-callout p {
    text-transform: uppercase;
    font-weight: 300;
    font-size: 35px;
    text-transform: uppercase;
    color: #fff;
}

@media (min-width: 768px) {
    .product-banner-callout p {
        font-size: 40px;
    }
}

.catalog-product-view .page-title-wrapper {
    background-color: #fff;
    padding-top: 0;
}

.catalog-product-view .page-title-wrapper h1.page-title {
    font-size: 38px;
    color: #000;
}

.product-info-price .price-box .price-container .price {
    color: #df1e36;
}

/*Product Info Details Tabs */

.catalog-product-view .product.info.detailed {
    background-color: #eaeaea;
}

.catalog-product-view .product.data.items > .item.content {
    background: #eaeaea;
    margin-top: 43px;
    padding: 35px 35px 35px 35px;
    border-top: 2px solid #ccc;
    border-right: 0;
    border-left: 0;
    border-bottom: 0;
}

.product.data.items > .item.title > .switch {
    font-weight: 400;
    line-height: 40px;
    font-size: 1.4rem;
    color: #6d6d6d;
    text-decoration: none;
    background: #eaeaea !important;
    border-top: 4px solid #df1e36 !important;
    border-bottom: none !important;
    border-right: 0 !important;
    border-left: 0 !important;
    height: 40px;
    padding: 1px 35px 1px 35px;
}

.product.data.items > .item.title:not(.disabled) > .switch:active, .product.data.items > .item.title.active > .switch, .product.data.items > .item.title.active > .switch:focus, .product.data.items > .item.title.active > .switch:hover {
    background: #eaeaea;
    color: #333333;
}

.data.item.title .data.switch {
    text-transform: uppercase;
    font-family: 'Open Sans', sans-serif;
    font-size: 1.8rem;
}

/* Breadcrumbs */

.breadcrumbs {
    padding-left: 0 !important;
    margin-bottom: 50px;
}

.breadcrumbs .item {
    text-transform: uppercase;
}

.breadcrumbs .items {
    margin: 20px 0 0 0;
}

.breadcrumbs a {
    color: #df1e36;
    text-decoration: none;
}

.breadcrumbs a:visited {
    color: #df1e36;
    text-decoration: none;
}

.breadcrumbs .item:not(:last-child):after {
    margin: 0 5px;
    font-weight: bold;
}

.cms-home .block-wishlist, .cms-contact-us .block-wishlist {
    display: none !important;
}

/* Page Layout */
@media (min-width: 768px), print {
    .page-layout-2columns-left .column.main {
        /*width: 100% !important;*/
        float: right;
        -ms-flex-order: 2;
        -webkit-order: 2;
        order: 2;
    }
}

/** checkout form - fix gray backgrounds */
input.input-text[type=text], select.select[name=region_id] {
    background: rgb(255, 255, 255) !important;
}
/** checkout form - remove wonky tooltip */
div.multicarrier_shipping_attributes span.field-tooltip-action {
    display: none;
}
/** "Sign In" button */
button.action-auth-toggle span {
    color: #df1e36;
}
div.authentication-wrapper > button:hover > span {
    text-decoration: underline;
    text-underline-color: #df1e36;
}

.billing-address-same-as-shipping-block {
    font-size: x-large;
    font-weight: bold;
}

@media (min-width: 768px), print {
    .block-search {
        display: block;
    }

    .block.newsletter {
        max-width: initial;
    }
}

/** fix blue paging buttons */
div.pages li.item:not(.current) span {
    color:black;
}

/** make notices look cleaner */
div.message.notice {
    background: #D7FFE4;
    color: #35824E;
}
div.message.notice > div::before {
    color: #35824E !important;
}
div.message.success {
    background: #D7FFE4;
    color: #35824E;
}
div.message.success > div::before {
    color: #35824E !important;
}

/** hiding "Add to Wishlist" in cart */
div.actions-toolbar a.towishlist {
    display: none !important;
}
/** cart trash can + pencil */
.checkout-cart-index div.actions-toolbar {
    margin-top: -30px;
    padding-bottom: 10px;
}

div.message-system-inner {
    background: #D7FFE4;
}
div.message-system-inner::before {
    color: #35824E;
}

.checkout-cart-index button.action.cancel.primary,
.checkout-cart-index button.action.apply.primary {
    margin-top: -2px;
    color: white !important;
    background: #df1e36 !important;
}

button.action-primary:hover {
    background-color: black !important;
}
/** Navigation*/
.navigation {
    margin-left: 0 !important;
}

.nav-open .nav-sections .header.links li.greet.welcome {
    border-top: none;
    font-weight: 700;
    padding: 0.8rem 20px;
}

.nav-open .nav-sections .header.links {
    margin: 0;
    padding: 0;
    list-style: none none;
    border-bottom: none;
}

.nav-open .nav-sections .header.links li > a {
    border-right: none !important;
    border-left: none !important;
    border-top: none !important;
    border-bottom: #545454 1px solid;
    text-transform: uppercase;
    font-family: 'Open Sans', sans-serif;
    color: #fff;
    font-weight: 300;
}

.nav-open .nav-sections .header.links li > a:hover {
    background-color: #df1e36;
}

.nav-open .nav-sections-item-content {
    padding: 0 !important;
}

.nav-sections-item-title {
    background: #fff;
    border: none !important;
    box-sizing: border-box;
    float: left;
    height: 71px;
    padding-top: 24px;
    text-align: center;
    width: 33.33%;
    font-weight: 300;
    font-size: 18px;
    border: none;
    font-family: 'Open Sans', sans-serif;
    text-transform: uppercase;
}

.nav-sections-item-title a {
    color: #000;
}

.nav-sections-item-title.active a {
    color: #fff;
    font-weight: 300;
}

.nav-sections-item-title.active {
    background-color: #df1e36;
}

.nav-open .nav-sections nav.navigation li {
    border-right: none !important;
    border-left: none !important;
    border-top: none !important;
}

.nav-open .nav-sections nav.navigation li:last-of-type {
    border-bottom: none;
}

.nav-open .nav-sections nav.navigation li a {
    text-transform: uppercase;
    color: #fff;
}

.nav-open .nav-sections nav.navigation .mega-col:hover {
    background: #e8e8e8;
    color: #333333;
    text-decoration: none;
}

.nav-open .nav-sections nav.navigation div a {
    padding-left: 20px;
}

@media (min-width: 768px), print {
    .navigation {
        max-width: 1360px;
    }
    .navigation .level0 .submenu .active>a {
        color: #333;
    }
}

.nav-open .navigation .submenu:not(:first-child) .active > a {
    border-color: #df1e36;
    border-style: solid;
    border-width: 0 0 0 8px;
    padding-left: 7px;
}

.ves-megamenu {
    width: auto;
}

.ves-megamenu .navigation .level0 > a, .ves-megamenu .navigation .content-type-parentcart .level1>a {
    font-size: 14px;
}

.ves-megamenu .nav-item.active>a {
    background: inherit !important;
}

.ves-megamenu li.level0:active > a {
    background: initial;
    color: #FFF;
}

.nav-open .nav-mobile .nav-item.level1 {
    padding-left: 0;
}

.ves-megamenu .level1 .subitems-group {
    font-weight: bold;
}

.block-search .label:before {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 22px;
    line-height: 43px;
    color: #fff;
    content: '\e615';
    font-family: 'luma-icons';
    margin: 0 10px 0 0;
    vertical-align: middle;
    display: inline-block;
    font-weight: normal;
    overflow: hidden;
    speak: none;
    text-align: center;
}

.block-search .label:hover:before {
    color: #df1e36;
}

.nav-toggle {
    top: -5px;
}

.nav-open .navigation .level0.active > a:not(.ui-state-active), .navigation .level0.has-active > a:not(.ui-state-active) {
    border: none !important;
}

.nav-sections {
    background: #212428;
    margin-bottom: 0 !important;
    border-bottom: 5px solid #df1e36;
}

.nav-sections {
    background: white !important; /** overwrite the black in the nav-sections above */
}
.ves-megamenu {
    /*margin-top: 126px;*/
    background: #212428;
}
.nav-item:not(:first-child) {
    border-left: 1px solid rgba(255,255,255,0.10);
    border-right: 1px solid rgba(255,255,255,0.10);
}

@media (min-width: 768px), print {
    .nav-sections nav.navigation {
        background: #212428;
        font-weight: 700;
        height: inherit;
        left: auto;
        overflow: inherit;
        padding: 0;
        position: relative;
        top: 0;
        width: 100%;
        z-index: 3;
    }
}

.nav-sections nav.navigation li {
    display: inline-block;
    padding: 0;
    margin-right: 0 !important;
}

.nav-sections nav.navigation li:last-of-type {
    border-right: none;
}

.nav-sections nav.navigation li > a {
    text-transform: uppercase;
    color: #fff !important;
    font-weight: 300;
    padding: 8px 15px;
}

.nav-sections nav.navigation li a {
    text-transform: uppercase;
    color: #fff;
}

.nav-sections nav.navigation li li a {
    color: #000 !important;
}

.nav-sections nav.navigation li:hover {
    background-color: initial;
}

.ves-megamenu li.active > a {
    background: initial;
    color: #FFF !important;
}

.ves-megamenu li.level0:hover > a {
    background: transparent;
    color: #FFF;
}

.ves-megamenu .navigation .level0.current>a {
    background-color: transparent;
}
@media only screen and (max-width: 767px) {
    .ves-menu .navigation .level0 > .submenu {
        padding-left: 10px;
    }

    .ves-megamenu>.navigation {
        background: inherit;
    }

    .navigation .submenu:not(:first-child) {
        font-weight: 100;
    }
}

.nav-sections nav.navigation li:hover li:hover {
    background-color: #fff;
}

/** Header cart area */

.header.content {
    clear: both;
    padding-top: 20px;
    padding-bottom: 20px;
}

@media (min-width: 768px) {
    .header.content {
        padding-top: 10px;
        padding-bottom: 10px;
    }
}

.minicart-wrapper {
    display: block;
    position: relative;
    margin-top: 30px;
    /*top: -84px;*/
    /*right: -40px;*/
    z-index: 500;
}

@media (max-width: 768px) {
    .minicart-wrapper {
        position: initial;
        margin-right: 15%;
        margin-top: 20px;
        top: 0;
    }
    .minicart-wrapper .action.showcart:hover:before, .minicart-wrapper .action.showcart:before, .minicart-wrapper .action.showcart.active:before {
        font-size: 30px;
    }
    .minicart-wrapper.active .block-minicart {
        position: absolute;
        top: 9%;
        left: 106px;
        min-width: auto;
    }
}

.minicart-wrapper .action.showcart:hover:before, .minicart-wrapper .action.showcart.active:hover:before {
    color: #757575;
}

.header.content .minicart-wrapper .action.showcart:before {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 32px;
    line-height: 34px;
    color: #df1e36;
    content: '\e611';
    font-family: 'luma-icons';
    margin: 0;
    vertical-align: top;
    display: inline-block;
    font-weight: normal;
    overflow: hidden;
    speak: none;
    text-align: center;
}

.minicart-wrapper button.action.primary:hover,
.minicart-wrapper button.action.tocart:active {
    color: #fff;
    background-color: #000000;
}

.minicart-wrapper .action.showcart .counter.qty {
    background: #df1e36;
    color: #ffffff;
    height: 24px;
    line-height: 24px;
    border-radius: 2px;
    display: inline-block;
    margin: 3px 0 0;
    min-width: 18px;
    overflow: hidden;
    padding: 0 3px;
    text-align: center;
    white-space: normal;
}

.minicart-wrapper button.action.primary:active:after,
.minicart-wrapper button.action.primary:focus:after {
    display: none !important;
}

.minicart-wrapper button.action.primary:after,
.minicart-wrapper button.action.primary:focus:after,
.minicart-wrapper button.action.primary:active:after {
    display: none !important;
}

/* Search */
.block-search .action.search {
    background: #df1e36;
    color: #fff !important;
    padding: 0 10px;
    border-radius: 0;
    opacity: 1 !important;
}

.block-search .action.search:hover {
    background-color: rgba(192, 0, 0, 1);
}

.block-search .action.search:before {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 16px;
    line-height: 32px;
    color: #fff;
    content: '\e615';
    font-family: 'luma-icons';
    margin: 0;
    vertical-align: top;
    display: inline-block;
    font-weight: normal;
    overflow: hidden;
    speak: none;
    text-align: center;
}

/** Search Box */
#search {
    max-width: 265px;
}

.block-search {
    position: relative;
    width: 350px;
    margin-top: 30px;
}
.minicart-wrapper {
    /*top: -100px !important;*/
}
/** End Search Box */

/** Mobile */
@media (max-width: 767px) {
    .block-search input {
        pointer-events: auto; /** clicks "through" any transparent overlapping elements */
        position: relative;
        left: 1%;
        background: transparent;
        /*border: none;*/
        /*color: white;*/
    }
    .block-search .label.active + .control input {
        position: relative;
    }
    div.field.search div.control {
        border-top: none !important;
        padding-right: 0 !important;
    }

    .block.block-search {
        height: 90px;
    }

    /** fix mobile nav white letters clashing with background */
    .mega-col:hover {
        background-color: rgb(33, 36, 40) !important;
    }

    #search {
        margin-top: -25px;
    }
}
/** End Upper-Right Search Box */

.nav-sections nav.navigation li.search-area {
    padding: 0;
    position: absolute;
    right: 0;
    top: 7px;
}

.nav-sections nav.navigation li.search-area > a {
    line-height: 31px;
}

.nav-sections nav.navigation li.search-area:hover {
    background-color: transparent;
}

.nav-sections nav.navigation .ves-megamenu li.level0.search-area:hover > a {
    background: transparent;
}

.nav-sections nav.navigation .ves-megamenu {
    background: transparent;
}

div.header-left-area h4, ul.header.links li a, nav.navigation li.nav-item.level0 > a {
    font-family: "Gotham Bold", Gotham, serif;
}

#footerLower h3, #footerLower a {
    font-family: "Gotham Light", Gotham, serif;
}

/* Shopping Cart */
@media (min-width: 768px) {
    .opc-progress-bar-item._active:before {
        background: #df1e36 !important;
        border-color: #df1e36 !important;
    }

    .opc-progress-bar-item._active > span:before {
        background: #df1e36 !important;
        border-color: #df1e36 !important;
    }
}
#footerContainer {
    color: white;
    & h3 {
        font-size: 1.5em
    }
}

#footerUpper {
    min-height: 700px;
    background:linear-gradient(0deg, rgba(0, 0, 0, 1), rgba(0, 0, 0, 0.3)), url('../../frontend/Knapheide/storefront/en_US/images/footer/wall-of-faith-aerial.jpg');
    background-repeat: no-repeat;
    background-size: cover;
    filter: grayscale(1);
}

#footerLower {
    min-height: 300px;
    background: black;
    display: flex;
    justify-content: space-around;

    & a {
        color: #df1e36;
        text-decoration: none;
        text-underline: none;
    }
}

#footerLower > div {
    padding-left: 20px;
    padding-right: 20px;
}

#footerSignUp {
    height: 320px;
    padding: 20px;
    background-color: white;
    background-image: url('../../frontend/Knapheide/storefront/en_US/images/footer/black-notch.png');
    background-repeat: no-repeat;
    background-size: 40px;
    background-position: right top;
    width: 290px;
}

@media screen and (max-width: 850px) {
    #footerLower {
        flex-direction: column;
    }
}

footer.page-footer {
    margin-top: 10px;
    padding-bottom: 0;
}

div.footer.content {
    max-width: none !important;
    width: 100% !important;
    /*margin: 0 !important;*/
    padding: 0 !important;
}

/** Hubspot */
div.hbspt-form {
    & input {
        border: 1px solid #a9a9ac;
        font-size: 16px;
        padding: 5px;
        width: 100%;
    }
    & input:active, & input:focus {
        border: 1px solid #df1e36 !important;
    }
    & button {
        font-size: 16px;
    }
}

input.hs-input:not([type=file]) {
    background: red !important;
}
