/* quick overrides, find homes for these later */

.page-header {
    /* get rid of white border on mobile */
    border-bottom: 0;
}

/* fixes issue with dropdowns going behind positioned elements in the content area */
.page-sections {
    position: relative;
    z-index: 0;
}

.magnifier-preview {
    /* just something to make it "pop" a little. */
    box-shadow: -4px 8px 12px rgba(0, 0, 0, .3);
}


.magnifier-preview.force-position-50 {
    top: 0 !important;
    left: calc(100% + 50px) !important;
    bottom: auto !important;
    right: auto !important
}

.magnifier-preview.force-position-20 {
    top: 0 !important;
    left: calc(100% + 20px) !important;
    bottom: auto !important;
    right: auto !important
}


.fotorama__stage__frame .magnify-lens {
    background: rgb(66, 168, 226, .2);
    border: 1px solid #000;
}

.section-product-button {
    box-sizing: border-box;
    width: 100%;
    text-align: center;
}
.section-product-button button.action {
    width: 100%;
    padding: 10px 0;
    text-align: center;
}

@media (min-width: 1024px), print {
    .section-product-button {
        width: 95%;
    }
    .product-item .product-item-details {
        width: 95%;
    }
}

.product-item .product-item-details {
    min-height: 100px;
    height: auto;
    padding-bottom: 0;
}

/* requested name bold, price normal:  2022-02-17 */
.product-item-name, .product.name a {
    font-weight: bold;
}
.product-items .product-item .price-box .price {
    font-weight: normal;
}

.section-product-button button.action:hover {
    background: #c5420e;
    border: 1px solid #000;
}

.page-products .product-item-info {
    margin-bottom: 0px;
}

/* little zoom in thing on product images */
.product-item a.product-item-photo .product-image-wrapper {

    overflow: hidden;
}

.product-item a.product-item-photo .product-image-wrapper img {
    /* transition: top .2s linear, left .2s linear, width .2s linear, height .2s linear; */
    transition: all .2s linear;
}

.product-item a.product-item-photo:hover .product-image-wrapper img {
    top: -2.5%;
    left: -2.5%;
    width: 105%;
    max-width: 105%;
    height: 105%;
    max-height: 105%;
}

/* make leadtimes (lead times) not show up for giftcard products. */
.page-product-giftcard #backorder_msg .notice {
    display: none;
}

.lead-time-details {
    cursor: pointer;
}

.lead-time-details .lead-time-msg-txt {
    display: none;

    color: #000;
    font-style: normal;
    padding: 20px 0px;
    font-size: 1.25rem;
}

.out-of-stock-notice .notice .instock {
    color: #0c0;
}

/*
This was previously requested.
Another request came in to revert it (The actual request was to change from absolute to relative)
.product-items.list .product-item .price-box {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 40px;
}
*/
.product-items.list .product-item .price-box {
    position: relative;
    text-align: left;
}

.prod_list_num_left {
    font-style: italic;
    color: #f00;
    padding-top: 5px;
    font-weight: bold;
}

.prod_num_left {
    margin: 20px 0px 5px 0px;
    padding: 10px 15px;
    color: #fff;
    background: #c5420e;
    display: inline-block;
    font-weight: bold;
    font-style: italic;
}

/* crosssell items */

.block.crosssell {
    margin: 20px 0 0 0;
}

.products-crosssell > .products.list.items {
    margin: 0;
}

.products-crosssell > .products.list.items li {
    margin: 0 10px 0 0;
    width: auto;
}

.products-crosssell > .products.list.items li .product-item-link {
    white-space: normal;
}


/*
    FIX MISSING STYLES MINICART.  Disabling mini-cart breaks the main cart
    Couple other older styles in here as well.
*/

/* ui-slider is not position relative... handle was blown out */
.ui-slider {
    position: relative;
    height: 10px;
}
/*
Not sure why this one wasn't defined
Must have been defined in the tracker module that I disabled.
*/
.smile-es-range-slider .ui-slider-handle {
    position: absolute;
}

/* fix images not showing in cart */
@media (min-width: 1024px), print {
    .cart.table-wrapper .cart.item .product-item-photo {
        position: static;
        display: inline-block;
        max-width: 100%;
        width: 120px;
    }

    .cart.table-wrapper .cart.item .product-item-details {
        display: inline-block;
        width: auto;
    }

    .cart.table-wrapper .item .col.item {
        padding-left: 0;
    }

    .cart.table-wrapper .item .product-item-details {
        margin-left: 20px;
    }

    /* not sure how this one got broken... */
    .nav-toggle {
        display: none;
    }

    /* column main and sidebar were reversed */

    .columns.category-columns.left-active .column.main {
        order: 2 !important;
    }

    .columns .column.main {
        order: 2 !important;
    }

}

@media (max-width: 1023px), print {

    .cart.table-wrapper .item .col.item {
        display: block;
    }

    .cart.table-wrapper .col.qty, .cart.table-wrapper .col.price, .cart.table-wrapper .col.subtotal, .cart.table-wrapper .col.msrp {
        box-sizing: border-box;
        display: block;
        float: left;
        text-align: center;
        white-space: nowrap;
        width: 33%;
    }
}

@media (max-width: 460px), print {
    .checkout-cart-index .cart.table-wrapper .col.qty .qty-control {
        display: none;
    }
}

/* looks weird with the buttons now */
.cart.table-wrapper .col.qty {
    text-align: center;
    white-space: nowrap;
}



/*
    END FIX MISSING STYLES MINICART
*/




.video-wrapper {
	text-align: center;
}
@media (max-width: 992px) {
	/* responsive youtube embeds */
	.video-wrapper {
		position: relative;
		padding-bottom: 56.25%;
		height: 0;
		overflow: hidden;
	}
	.video-wrapper iframe {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
        max-width: 100%;
	}
}

/* blog changes */
@media (min-width: 768px) {
    .blog-listing-wrapper {
        display: flex;
        flex-direction: row;
        width: 100%;
    }

    .blog-listing-wrapper > div {
        box-sizing: border-box;
        width: 50%;
    }
    .blog-listing-wrapper > div:first-child {
        margin-right: 20px;
    }
    .blog-listing-wrapper > div:last-child {
        margin-left: 20px;
    }

    .blog-listing-content {
        height: 100%;
        display: relative;
    }

    .blog-listing-wrapper .blog-post-author {
        background: none;
        border: 0;
        border-top: 1px solid #ccc;
        padding-left: 0;
        margin-left: 0;
    }
}

.category-image {
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0;
    line-height: 0;
    overflow: hidden;
}

.category-image img {
    display: block;
    margin: 0;
    padding: 0;
    border: 0;

    object-fit: cover;
    width: 100%;
}

@media (max-width: 540px) {
	.category-image img {
        object-fit: cover;
        width: auto;
    }
}

@media (min-width: 480px) {
    .category-image img.pagebuilder-mobile-hidden {
        display: block !important;
    }

    .category-image img.pagebuilder-mobile-only {
        display: none !important;
    }
}

@media (max-width: 480px) {
    .category-image img.pagebuilder-mobile-hidden {
        display: none !important;
    }
    .category-image img.pagebuilder-mobile-only {
        display: block !important;
    }
}

/* bundle property value changes */

.ar500-bundle-options .fieldset-bundle-options {
    min-width: 0;
    max-width: 100%;
}

.ar500-bundle-options .ar-bopt-property {
    display: block;
}

.ar500-bundle-options .ar-bopt-property-values {
    white-space: nowrap;
    overflow-x: hidden;
    max-width: 100%;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;

}

.ar-bopt-property-value.swiper-slide {
    width: auto;
    height: auto;
    line-height: normal;
}

/* have to add some padding to the bottom because of the sliders */
.ar-bopt-property-name {
    padding-bottom: 5px;
}

.bundle-summary .subtitle {
    display: inline-block;
    font-size: 20px;
    padding-bottom: 5px;
}

/* hack to move the qty button to above the *Required Fields text that's at the bottom of the previous major block */
/* It would take some work to make this the real layout... I would argue that would be a mistake though */
/* semantically, the qty button should absolutely be directly next to the add to cart button. */
/* I think this will quickly become apparent, so let's go with the quick method to make it easy to rollback */

.ar500-bundle-options.bundle-options-container {
    /* margin-bottom: 90px; */
}

/* I know they are going to want the hole filled now that the qty is gone */
.bundle-options-container, .ar-bopt-container:last-child {
    margin-bottom: 0;
}

.product-add-form .block-bundle-summary .content {
    position: relative;
}

/* update to hack... the new solution is to delete the qty button */
/* later... new staff since the above note, new staff wants a qty button */
/*
.product-add-form .block-bundle-summary .field.qty {
    display: none !important;
    position: absolute;
    top: -130px;
    left: 0;
}
*/
/* they do want buttons... but not like this, they want fancy ones. like this: ( [-btn] [field] [+btn] )*/
/*
.product-info-main .box-tocart .input-text.qty::-webkit-inner-spin-button,
.product-info-main .box-tocart .input-text.qty::-webkit-outer-spin-button {
    -webkit-appearance: inner-spin-button !important;
}
.product-info-main .box-tocart .input-text.qty {
    -moz-appearance: spinner-textfield !important;
}
*/
.qty-control {
    position: relative;
    box-sizing: border-box;
    width: 36px;
    height: 36px;
    display: inline-block;
    padding: 3px;
    font-size: 18px;
    font-weight: bold;
    border: 1px solid #ccc;
    background: #c5420e;
    color: #fff;
    vertical-align: baseline;
    text-align: center;
    user-select: none;
}
.qty-minus {
    margin-right: 15px;
}
.qty-plus {
    margin-left: 15px;
}

.qty-control.is_min_qty {
    opacity: .4;
}

.cart.item .qty-control {
    top: 1px;
    width: 30px;
    height: 30px;
    padding: 1px;
}
.cart.item .qty-minus {
    margin-right: 5px;
}
.cart.item .qty-plus {
    margin-left: 5px;
}

.product-add-form .block-bundle-summary .box-tocart {
    margin-top: 0;
}

.product-add-form .block-bundle-summary .box-tocart .actions{
    padding-top: 15px;
}

.product-add-form .block-bundle-summary .price-as-configured {
    margin-top: 20px;
}

.page-header {
    position: relative;
}
.page-header .panel.wrapper {
    position: absolute;
    top: 0;
    right: 0;
}
@media screen and (min-width: 1024px), print {
    .header.panel > .header.links > li:last-child {
        margin: 0;
    }
}


.breadcrumbs {
    /* there's a product specific stylesheet that's overriding these */
    margin: 5px auto !important;
    max-width: 1440px;
    width: 100%;
    padding: 0 20px !important;
    text-align: left !important;
}

/* product listing focal elements (sales and stuff) */

.product-items .product-item-photo {
    display: block;
    position: relative;
    overflow: hidden;
}

.ar500-product-promo {
    position: absolute;
    z-index: 100;
    left: -18.5%;
    top: 11%;
    width: 75%;

    box-sizing: border-box;

    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
    padding: 10px;
    color: #fff;
    font-weight: 700;
    text-transform: uppercase;
    -webkit-box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.75);
    -moz-box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.75);
    box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.75);
    pointer-events: none;
    text-align: center;
}

.ar500-product-discount {
    position: absolute;
    z-index: 100;
    bottom: 22px;
    right: 30px;

    padding: 3px 5px;
    color: #c5420e;
    font-weight: 700;
    -webkit-box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.75);
    -moz-box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.75);
    box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.75);
    background-color: #fff;
    border: 1px solid #c5420e;
    pointer-events: none;
    margin-left: 5px;
}

/* hide the minicart dropdown and go straight to the cart... logic in ar500-theme-global.js */
/*
Actually, we want this to happen in the js so we don't have to rebuild.
.block-minicart.ui-dialog-content {
    display: none !important;
}
*/
/* the dropdown will still show if the javascript is a stale version */
/* IF they have the new js, then the dropdown will still show (which is ok for the short term) */
.block-minicart.disabled {
    display: none !important;
}

/* "clean up" cart page task... */
@media (max-width: 1023px) {
    .product-item-details {
        min-height: 0;
        padding-bottom: 0;
    }

    .cart.main.actions button.action.update{
        margin-bottom: 30px;
    }


    .stay-in-the-fight {
        text-align: center;
    }
}
@media (min-width: 1024px) {
    .stay-in-the-fight {
        text-align: left;
        overflow: hidden;
    }
    .stay-in-the-fight img {
        margin: 30px auto 10px -33px;
        position: relative;
    }
}



.cart-summary {
    padding-top: 10px;
}
.cart-summary #block-shipping .title {
    border-top: 0;
}


/* new product sliders... owl getting replaced with sliderjs */

.swiper-container-horizontal.product-items {
    width: 100%;
    flex-wrap: nowrap;
    white-space: nowrap;
    overflow: hidden;
}

.page-products .products-grid .swiper-wrapper .product-item {
    width: 280px;
    min-width: 280px;
    margin: 0px 0px 0px 10px
}
.page-products .products-grid .swiper-wrapper .product-item:last-child {
    margin-right: 10px;
}
.page-products .products-grid .swiper-wrapper .product-item .product-image-container {
    width: 100%;
    max-width: 100%;
}
.page-products .products-grid .swiper-wrapper .product-item .product-image-container img {
    width: 100%;
}
.page-products .swiper-wrapper .product-item-info {
    width: 100%;
}

.page-products .swiper-wrapper .product-item-info .product-image-container img.product-image-photo:hover{
    width: 105%;
}

@media screen and (min-width: 768px) {
    /* page section products with swiperjs (in order to make these stick we have to use important) */
    .page-products .products-grid .swiper-wrapper .product-item {
        width: 300px;
    }
}

@media screen and (min-width: 1024px) {
    /* page section products with swiperjs (in order to make these stick we have to use important) */
    .page-products .products-grid .swiper-wrapper .product-item {
        width: 300px;
        margin: 0px 0px 0px 10px;
    }

    .page-products .products-grid .swiper-wrapper .product-item:nth-child(4n + 1), .page-products .products-grid .swiper-wrapper .product-item:nth-child(3n + 1)  {
        margin-left: 10px;
    }

    .page-products .products-grid .swiper-wrapper .product-item:first-child {
        margin-left: 10px;
    }

    .page-products .products-grid .swiper-wrapper .product-image-container {
        width: 100% !important;
        max-width: 100% !important;
    }
}

@media screen and (min-width: 1320px) {
    .page-products .products-grid .swiper-wrapper .product-item:first-child {
        margin-left: 0px;
    }
}

/* general decrease in padding task */
@media screen and (min-width: 1024px) {
    /* squash header when the site expands out (get rid of top and bottom padding that is default to magento 2... checked my styles) */
    .page-wrapper .header.content {
        padding: 0px 20px;
    }

    .page-wrapper h1 {
        margin-bottom: 20px;
    }
}


/* checkout screen for the large weight disclaimer section */

.large_weight_disclaimer_control {
    margin-top: 40px;

    border: 1px solid #ddd;
    padding: 20px;

    transition: all .2s ease-in;
}

.large_weight_disclaimer_control.mustcheck {
    border: 1px solid #f00;
}

/* end quick (not so quick) overrides (we'll move them where they go when it all settles down) */

.contact-page-top {
    padding-bottom: 20px;
    border-bottom: 1px solid #ccc;
    margin-bottom: 20px;
    font-size: 1.2em;
}

.contact-form-info {
    margin-bottom: 30px;
}

@media screen and (min-width: 860px) {
    .contact-form-container {
        display: flex;
        flex-wrap: nowrap;
        width: 100%;
    }

    .contact-form-info {
        box-sizing: border-box;
        width: 50%;
        padding-right: 30px;
        margin-right: 30px;
        border-right: 1px solid #ccc;

        font-size: 1.2em;
        line-height: 1.2em;
    }

    .contact-form {
        box-sizing: border-box;
        width: 50%;
        margin-left: 20px;
    }
}

@media screen and (min-width: 1024px) {
    .contact-index-index .column:not(.sidebar-additional) .form.contact {
        min-width: 100%;
    }
}
@media screen and (min-width: 1100px) {
    .contact-form-info {
        width: 61.8%;
    }
    .contact-form {
        width: auto;
        flex-grow: 1;
    }
}


/* splash and category headers for sectional content */


.ar500-cms-section {
    position: relative;
}

.ar500-cms-section-center {
    text-align: center;
}

.ar500-section-heading {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    position: relative;
    width: 100%;
    min-width: 100%;
    max-width: 100%;
}
.ar500-section-heading * {
    box-sizing: border-box;
}

.ar500-section-heading-image {
    position: relative;
    z-index: 10;
    max-width: 100%;
    width: 100%;
    line-height: 0;
}

.ar500-section-heading-image img {
    display: block;
    margin: 0;
    padding: 0;
    border: 0;
    line-height: 0;

    object-fit: cover;
    width: 100%;
    min-height: 120px;
    max-height: 250px;
}

@media (max-width: 540px) {
	.ar500-section-heading-image  img{
        object-fit: cover;
        width: auto;
        min-height: 120px;
    }
}

/* going to need js for the hover to work the way I was hoping.  The children aren't cooperating. */
.ar500-section-heading-overlay {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 20;
    width: 100%;
    height: 100%;
    background-color: transparent;
    /* background: rgba(0, 0, 0, 0); */
    transition: background-color .25s ease-in;
}

/*
.ar500-section-heading-overlay:hover {
    background-color: rgba(0, 0, 0, .25);
}
*/

.ar500-section-heading-content {
    position: absolute;
    display: inline-block;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    z-index: 30;
    width: 90%;
    height: 70px;
    text-align: center;
}

.ar500-section-heading-content *{
    color: #fff;
}

.ar500-section-heading-content > h2, .ar500-section-heading-content > h2 a {
    margin: 0 0 10px 0;
    font-size: 24px;
    font-weight: normal;
    text-decoration: none;
    color: #fff;
}

.ar500-section-heading-button, a.ar500-section-heading-button:visited {
    display: block;
    padding: 2px 20px;
    margin: 0 auto;
    max-width: 128px;
    /* color: #8ac3ee; */
    color: #fff !important;
    border: 2px solid #fff;
    border-radius: 7px;
    font-weight: normal;
    font-size: 16px;
}


.ar500-section-heading-button:hover {
    /* box-shadow: 0px 0px 24px rgba(197, 66, 14, .6); */
    color: #fff;
    background-color: #c5420e;
    text-decoration: none;
}


@media screen and (min-width: 520px) {

    .ar500-section-heading-content {
        height: 80px;
    }

    .ar500-section-heading-button {
        display: inline-block;
    }

    .ar500-section-heading-button {
        display: inline-block;
        padding: 5px 20px;
        margin: 0px 20px;
        color: #1979c3;
        border: 2px solid #fff;
        border-radius: 7px;
        font-weight: normal;
        font-size: 16px;
    }
}

@media screen and (min-width: 768px) {

    .ar500-section-heading-content {
        height: 105px;
    }

    .ar500-section-heading-content > h2, .ar500-section-heading-content > h2 a {
        font-size: 32px;
    }

    .ar500-section-heading-button {
        padding: 10px 20px;
        font-size: 18px;
    }

}

@media screen and (min-width: 1080px) {

    .ar500-section-heading-content {
        height: 135px;
    }

    .ar500-section-heading-content > h2, .ar500-section-heading-content > h2 a {
        font-size: 48px;
        margin-bottom: 20px;
    }

    .ar500-section-heading-button {
        padding: 10px 20px;
        font-size: 24px;
    }

}


.payment-method-content .checkout-agreements-block {
    display: block !important;
}

.payment-method-content .checkout-agreement {
    display: flex;
    flex-wrap: nowrap;
}

.payment-method-content .checkout-agreement label {
    flex-grow: 1;
    margin-left: 20px !important;
    display: flex !important;
}

.payment-method-content .checkout-agreement label span, .payment-method-content .checkout-agreement label button {
    text-align: left;
}

/* move the required * to the front (looks bad on the back for long text) */
.payment-method-content .checkout-agreement > .label:after {
    display: inline-block;
    content: '' !important;
    margin: 0 !important;
}

.payment-method-content .checkout-agreement > .label:before {
    display: inline-block;
    content: '*';
    color: #e02b27;
    font-size: 1.2rem;
    margin: 0 10px 0 0px;
}

@media screen and (min-width: 1280px), print {
    .footer-links * {
        font-size: 16px;
    }
}

.footer-block-list > div[data-content-type="html"] {
    width: 100%;
    position: relative;
}

/* countdown timers */

.countdown {
    /* inline style as necessary */
    padding: 0;
    margin: 0;
}
.countdown .product-countdown {
    padding: 20px 0px;
}

.countdown > .countdown-num-block {
    display: inline-block;
    padding: 5px 0px;
    text-align: center;
}

.countdown > .countdown-num-block span {
    background-color: #c5420e;
    color: #fff;
    border: 1px solid #fff;
    min-width: 32px;
    justify-content: baseline;
}

.countdown .countdown-label {
    display: block;
    font-size: 1.6rem;
    padding: 5px 10px;

}

.countdown .countdown-num {
    display: block;
    font-size: 2.4rem;
    padding: 5px 10px;
}

.countdown-inline .countdown-label, .countdown-hannah-style .countdown-label {
    display: none;
}

.countdown-orange > .countdown-num-block span {
    background-color: #c5420e;
}

.countdown-red > .countdown-num-block span {
    background-color: #c00;
}

.countdown-blue > .countdown-num-block span {
    background-color: #00c;
}

.countdown-green > .countdown-num-block span {
    background-color: #070;
}

.countdown-hannah-style > .countdown-num-block {
    margin: 2px;
}
.countdown-hannah-style > .countdown-num-block span {
    border: 0px solid transparent;
}

.countdown-hannah-style > .countdown-num-block > .countdown-num::after {
    /* label inline after the number justified baseline is the style */
    font-size: 1.2rem;
    font-weight: bold;
    margin-left: 2px;
}

.countdown-hannah-style > .countdown-num-block:nth-child(1) > .countdown-num::after {
    content: 'D';
}
.countdown-hannah-style > .countdown-num-block:nth-child(2) > .countdown-num::after {
    content: 'H';
}
.countdown-hannah-style > .countdown-num-block:nth-child(3) > .countdown-num::after {
    content: 'M';
}
.countdown-hannah-style > .countdown-num-block:nth-child(4) > .countdown-num::after {
    content: 'S';
}

/* sezzle all of a sudden started putting itself on bundle selection prices */
.ar-bopt-container .sezzle-shopify-info-button {
    display: none !important;
}

/* fix some issues with the cart shipping estimator */
.checkout-cart-index #co-shipping-method-form > p:first-child {
    display: none !important; /* telling them there are no quotes is useless information */
}

/* if fedex is enabled, we have to show the zip code */
/* we don't have zipcode data in our tablerates (TODO: bring it up in meeting) */
/* .checkout-cart-index .field[name="shippingAddress.region_id"] {
    display: none !important;
}
*/

.checkout-cart-index #block-summary {
    display: block !important;
}


.ar-flex {
    box-sizing: border-box;
    padding: 20px 0px;
}

.ar-flex > * {
    padding: 20px 0px;
}

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

@media screen and (min-width: 992px), print {
    .ar-flex {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    .ar-flex-center {
        justify-content: center;
    }

    .ar-flex-nowrap {
        flex-wrap: nowrap;
    }

    .ar-flex > * {
        box-sizing: border-box;
        padding: 20px;
    }

    .ar-flex-50 > * {
        max-width: 50%;
    }

    .ar-flex-33 > * {
        max-width: 33%;
    }

    .ar-flex-25 > * {
        max-width: 25%;
    }
}


.login-container .g-recaptcha, .form-login .g-recaptcha, .form-edit-account .g-recaptcha, .g-recaptcha {
    margin-bottom: 20px !important;
}

@media screen and (min-width: 1024px) {
    body .login-container .g-recaptcha, .form-login .g-recaptcha, .form-edit-account .g-recaptcha, .g-recaptcha {
        margin-bottom: 30px !important;
    }
}

/* new in m24.  Something with page builder, remove max-width */
[data-content-type='row'][data-appearance='contained'] {
    max-width: 100%;
}

/* get rid of padding on category content (requested, was capped to max width 1280 m2 default) */
.category-description [data-content-type='row'][data-appearance='contained'] > div {
    padding-left: 0 !important;
    padding-right: 0 !important;
}



.lightbox {
    position: fixed;
    display: none;
    overflow: hidden;
    top: 0;
    left: 0;

    width: 100%;
    height: 100%;
    box-sizing: border-box;

    /* just have to keep this under 99999 (listrak) */
    z-index: 100;

    background: #fff;
    background: rgba(255, 255, 255, .5);

}
.lightbox * {
    box-sizing: border-box;
}

.lightbox-content {
    position: absolute;
    top: 0; right: 0; bottom: 0; left: 0;
    margin: auto;
    padding: 0;
    z-index: 1;

    /* defaults, set inline to override */
    width: 100%;
    min-width: 280px;
    max-width: 800px;

    height: 100%;
    min-height: 150px;
    max-height: 800px;

    /* should probably leave this transparent for flexibility */
    /* background: #fff; */
}

/* They already do this another way, leaving here just in case. */
/*
.lightbox .lightbox-mobile
.lightbox .lightbox-desktop
*/

.lightbox-close-x {
    position: absolute;
    z-index: 2;
    top: 20px;
    right: 20px;

    box-sizing: border-box;
    background-color: #C15602;
    border-radius: 50%;
    box-shadow: 3px 3px 5px rgba(0, 0, 0, .3) ;
    box-shadow: 3px 3px 6px 2px rgba(0, 0, 0, .8) ;
    opacity: .01;
    padding: 7px;

    width: 36px;
    height: 36px;

    transition: all .5s ease-in;

    cursor: pointer;
}

.lightbox-close-x span {
    box-sizing: border-box;
    display: block;
    width: 28px;
    height: 5px;
    border-radius: 5px;
    background-color: #C15602;

    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;

    transition: all .4s ease-in;
}
.lightbox-close-x span:first-child {
    background-color: #000;
}

.lightbox-open .lightbox-close-x {
    background-color: #fff;
    opacity: 1;
    z-index: 1;
}
.lightbox.lightbox-open .lightbox-close-x span {
    background-color: #484848;
    transform: rotate(315deg);
}
.lightbox.lightbox-open .lightbox-close-x span:first-child {
    background-color: #484848;
    transform: rotate(-315deg);
}

/* gdpr msg */
.message.global.cookie {
    background: #e5e5e5;
}

.message.global.cookie p {
    margin-right: 55px;
}

.collapse {
position: relative;
box-sizing: border-box;
}
.collapse * {
box-sizing: border-box;
}

/* calls .collapse on each one of these in .collapse */
.collapse-section {
margin: 10px 0px;
}


.collapse-title {
    position: relative;
    font-weight: bold;
    padding: 13px 20px 20px 20px;
    border-bottom: 1px solid #000;
    border-bottom-color: rgba(0, 0, 0, .5);
    cursor: pointer;
}

.collapse-close-x {
    position: absolute;
    z-index: 2;
    top: 8px;
    right: 5px;

    box-sizing: border-box;
    background-color: #bf5700;
    border-radius: 50%;
    box-shadow: 3px 3px 6px 2px rgba(0, 0, 0, .4);
    padding: 7px;

    width: 27px;
    height: 27px;

    transition: all .5s ease-in;

    cursor: pointer;
}

.collapse-close-x span {
    box-sizing: border-box;
    display: block;
    width: 18px;
    height: 5px;
    border-radius: 5px;
    background-color: #000;

    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;

    transition: all .4s ease-in;
}
.collapse-close-x span:first-child {
    background-color: #000;
}

.collapse-section[data-open="1"] .collapse-close-x {
    background-color: #fff;
    opacity: 1;
    z-index: 1;
}
.collapse-section[data-open="1"] .collapse-close-x span {
    background-color: #484848;
    transform: rotate(270deg);
}
.collapse-section[data-open="1"] .collapse-close-x span:first-child {
    background-color: #484848;
    transform: rotate(-180deg);
}

.collapse-content {
    display: none;
    padding: 20px;
    border-bottom: 1px solid #000;
    border-bottom-color: rgba(0, 0, 0, .3);
}

.custom-swiper {
    overflow: hidden;
}

.custom-swiper .swiper-slide {
    width: auto;
    margin-right: 10px;
}

.custom-swiper .swiper-slide img {
    height: 300px;
}

body .product-item-details .product-item-inner {
    position: static !important;
    margin: 0 !important;
}

.stock.unavailable {
    font-weight: bold;
    font-style: italic;
    color: #f00;
}
