/* HTML5 display-role reset for older browsers */

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block;
}

body {
    line-height: 1;
}

ol,
ul {
    list-style: none;
}

blockquote,
q {
    quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: '';
    content: none;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

/* Box-sizing override */

html {
    box-sizing: border-box;
}

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

body {
    max-width: 1920px;
}

.datalayer {
    display: none;
}

#skipToMainContent {
    position: absolute;
    left: -10000px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

#skipToMainContent:focus {
    top: 10px;
    left: 10px;
    width: auto;
    height: auto;
    background-color: white;
    color: black;
    z-index: 99999;
    padding: 10px;
}

@media (min-width: 1460px) {
    .container {
        width: 1430px;
    }
}

body {
    background-color: white;
    font-family: "Times New Roman", Times, serif;
    font-size: 15px;
    color: #5A5A5A;
    line-height: 18px;
    text-rendering: optimizeLegibility;
    margin: 0 auto;
}

a,
a:hover,
a:focus {
    color: #5A5A5A;
}

p {
    line-height: 22px;
}

b {
    font-weight: bold;
}

.positionStatic {
    position: static
}

.owl-carousel {
    touch-action: manipulation;
}

.btn.disabled, .btn[disabled], fieldset[disabled] .btn {
    opacity: .7;
}

/* Cookie Policy */

#cookie-message {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 25px;
    background-color: rgba(16, 14, 14, 0.85);
    color: white;
    font-size: 0.933em;
    letter-spacing: 0.05em;
    line-height: 1.571em;
    z-index: 999;
}

#cookie-accept {
    background-color: #a6182e;
    line-height: 40px;
    font-size: 0.857em;
    display: inline-block;
    text-align: center;
    min-width: 150px;
    cursor: pointer;
}

#cookie-message a {
    color: white;
    text-decoration: underline;
    max-width: 1920px;
}

/* Alerts */

.alert {
    padding: 10px 15px;
    margin-bottom: 0;
    text-align: center;
    color: black;
    border-radius: 0;
    border: none;
    font-size: 0.933em;
}

.alert-dismissable .close, .alert-dismissible .close {
    right: 0;
    top: 0;
    color: black;
    opacity: 1;
    font-size: 18px;
}

.alert-success, .alert-info {
    background-color: #eff5e7;
}

.alert-warning {
    background-color: #fff7d9;
}

.alert-danger {
    background-color: #fbeded;
}

.alert:before {
    content: "";
    font-family: Font Awesome\ 5 Pro;
    margin-right: 5px;
}

.alert-info:before, .alert-success:before {
    content: "\f00c";
    font-weight: 900;
}

.alert-warning:before {
    content: "\f06a";
    font-weight: 900;
}

.alert-danger:before {
    content: "\f071";
    font-weight: 900;
}

/* General */

.loadingSpinner {
    position: relative;
    color: transparent;
}

.loadingSpinner:after {
    position: absolute;
    top: calc(50% - 0.5em);
    left: calc(50% - 0.5em);
    font-family: Font Awesome\ 5 Pro;
    content: "\f110";
    animation: spin 2s infinite linear;
    display: inline-block;
    transform: translate3d(-50%, -50%, 0);
    border-radius: 50%;
    transform-origin: center;
    width: 1em;
    will-change: transform;
    height: 1em;
    text-align: center;
    line-height: 1em;
    font-size: 1em;
    color: #5A5A5A;
}

button[type=submit].loadingSpinner {
    color: transparent !important;
    opacity: 0.8;
}

button[type=submit] {
    -webkit-transition: opacity 0.5s ease-out;
    -moz-transition: opacity 0.5s ease-out;
    -o-transition: opacity 0.5s ease-out;
    transition: opacity 0.5s ease-out;
}

button[type=submit].loadingSpinner:after {
    color: white;
    font-size: 1.5em;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

.breadcrumb > li + li:before {
    content: "/";
}

textarea:focus,
input:focus {
    outline: none;
}

pslStoreInfo
    /* Header */
.promoBar {
    background-color: #eceee1;
    color: #4a3242;
    text-align: center;
    padding: 10px;
    font-size: 1em;
    line-height: normal;
    position: relative;
}

.promoBlock {
    position: initial;
    line-height: 35px;
}

.promoBlock i.fa-times {
    position: absolute;
    right: 15px;
    font-size: 30px;
    top: 0;
    line-height: 35px;
}

.promoBlock i.fa-times:before {
    display: inline-block;
    cursor: pointer;
}

.header {
    color: #4a3242;
}

.upperHeader {
    position: relative;
    padding: 6px 15px;
    font-size: 0.9em;
    z-index: 10;
    text-decoration: none;
    text-transform: capitalize;
}

.upperHeader a,
.topHeader a:hover,
topHeader a:focus {
    text-decoration: none;
}

.upperHeader a.pull-left {
    margin-right: 15px;
}

.upperHeader a.pull-right {
    margin-left: 15px;
}

.middleHeader {
    height: 70px;
    margin-bottom: 15px;
}

.middleHeader img.rolexImage {
    height: 40px;
    margin-top: 5px;
}

.middleHeader .shopping-bag {
    float: right;
    margin-top: 10px;
    margin-left: 10px;
    height: 42px;
    width: 40px;
    text-align: center;
    position: relative;
    border: 1px solid #fff;
}

.middleHeader .shopping-bag i {
    font-size: 2em;
    color: #5A5A5A;
    margin-top: 8px;
}

.middleHeader .shopping-bag.headerCartNotEmpty i {
    font-size: 1.5em;
}

.middleHeader .siteLogo img {
    max-width: 180px;
    max-height: 70px;
    margin: auto;
    display: block;
}

.middleHeader .searchAndCartContainer {
    text-align: right;
}

.middleHeader .search-form {
    display: inline-block;
    border: 1px solid #d9d7d7;
    margin-top: 10px;
    position: relative;
    z-index: 9;
}

.middleHeader .search-bar {
    height: 40px;
    padding: 0 10px 0 8px;
    width: 120px;
    border: 0;
    -webkit-transition: width 0.5s;
    transition: width 0.5s;
}

.middleHeader .search-bar:focus {
    width: 200px;
}

.middleHeader .search-clear {
    position: absolute;
    line-height: 40px;
    width: 10px;
    text-align: center;
    top: 0;
    right: 40px;
    cursor: pointer;
    display: none;
}

.middleHeader .hasTerm .search-clear {
    display: block;
}

.middleHeader .search-button {
    height: 40px;
    background-color: white;
    border: 0;
    font-size: 20px;
    padding: 0 10px;
    vertical-align: bottom;
}

.middleHeader span.cartTotal {
    position: absolute;
    background-color: #4a3242;
    color: white;
    width: 18px;
    height: 18px;
    border-radius: 9px;
    line-height: 18px;
    right: 4px;
    bottom: 3px;
    display: none;
    font-size: 12px;
}

.middleHeader .headerCartNotEmpty span.cartTotal {
    display: block;
}

.middleHeader .mobileHeaderIcon.shopping-bag a.headerCartBlock {
    text-decoration: none !important;
    position: relative;
    width: 50px;
    height: 42px;
    display: inline-block;
    float: right;
}

.middleHeader .mobileHeaderIcon.shopping-bag.headerCartNotEmpty a.headerCartBlock {
    text-align: center;
}

.navigationBar {
    text-align: center;
    position: relative;
    border-bottom: 1px solid #eee;
}

.navigationBar .mainNav {
    padding: 0 20px;
    margin: 0;
    border-top: 1px solid #eee;
}

.navigationBar .mainNav > ul {
    list-style: none;
    display: inline-block;
    font-size: 0;
    margin: 0;
    padding: 0;
}

.navigationBar .mainNav > ul > li {
    display: inline-block;
    padding: 12px 0;
    font-size: 16px;
    color: #333;
    line-height: 18px;
}

.navigationBar .mainNav > ul > li > a {
    position: relative;
    padding: 0 20px;
}

.navigationBar .mainNav > ul > li > a:hover,
.navigationBar .mainNav > li > a:focus {
    text-decoration: none;
}

.open-nav .navigationBar .mainNav > ul > li.nav-hover > a:after,
.navigationBar .mainNav > ul > li:focus-within > a:after {
    background-color: #4a3242;
    content: '';
    bottom: -12px;
    width: 100%;
    height: 5px;
    left: 0;
    margin-bottom: -1px;
    position: absolute;
}

.navigationBar .dropdown-nav {
    display: none;
    position: absolute;
    width: 100%;
    left: 0;
    background-color: white;
    border-bottom: 1px solid #d9d7d7;
    border-top: 1px solid #d9d7d7;
    padding: 60px 30px;
    text-align: left;
    z-index: 9;
    top: 42px;
}

.open-nav .navigationBar li.nav-hover .dropdown-nav {
    display: block;
}

.navigationBar li.nav-hover .dropdown-nav {
    display: none;
}

.navigationBar li.nav-hover .dropdown-nav h3,
.navigationBar li:focus-within .dropdown-nav h3 {
    font-size: 1.5em;
    color: #aaa;
    height: 55px;
    line-height: 1em;
    padding-bottom: 10px;
}

.navigationBar li.nav-hover .dropdown-nav a,
.navigationBar li:focus-within .dropdown-nav a {
    line-height: 2em;
}

.navigationBar .dropdownHtmlBlock {
    float: right;
}

.navigationBar.navigationBarFixed {
    position: fixed;
    width: 100%;
    top: 0;
    z-index: 10;
    background-color: white;
    max-width: 1920px;
}

.navigationBar.navigationBarFixed ul.mainNav {
    border-top: none;
}

.grey-overlay {
    position: fixed;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    display: none;
    z-index: 9;
}

.open-nav .grey-overlay {
    display: block;
}

.header {
    position: relative;
    z-index: 10;
    background-color: white;
}

.header.checkoutHeader {
    z-index: 8;
}

#mobile-navigation {
    display: none
}

.searchSuggestions {
    position: absolute;
    top: 100%;
    right: -1px;
    width: 350px;
    background-color: #fff;
    border: 1px solid #e5e1f2;
    -webkit-box-shadow: 0 5px 10px #e5e1f2;
    -moz-box-shadow: 0 5px 10px #e5e1f2;
    box-shadow: 0 5px 10px #e5e1f2;
    display: none;
}

.searchSuggestions.hoverOn {
    display: block !important;
}

.header .searchSuggestions a {
    color: #000;
}

.searchSuggestions h4 {
    background-color: #eceee1;
    color: #4a3242;
    margin: 0;
    padding: 5px;
    font-size: 14px;
    text-align: right;
}

.searchSuggestionsKeywords ul {
    margin: 0;
    padding: 0;
}

.searchSuggestionsKeywords ul li {
    line-height: 2em;
    padding-left: 10px;
    border-bottom: 1px solid #e0e0e0;
}

.searchSuggestionsProductsRow {
    float: left;
    width: 100%;
}

.searchSuggestionsProduct {
    width: 23%;
    float: left;
    margin: 10px 1%;
}

.searchSuggestionsProduct img {
    max-width: 100%;
}

.searchSuggestionsProductDetails {
    font-size: 14px;
    text-align: center;
}

.searchSuggestionsProductDetails h3 {
    font-size: 12px;
    margin: 5px 0;
}

.searchSuggestionsProductDetails > span {
    margin: 10px 0 0;
    display: inline-block;
}

.page-search .facet-priceValue {
    display: none;
}

.productGrid .search-results-highlight {
    font-style: normal;
    font-weight: bold;
}

/* Mini Cart Dropdown */

@media (min-width: 992px) {
    .mobileHeaderIcon.shopping-bag.pull-right.headerCartNotEmpty {
        width: 160px;
        border: none;
    }

    .middleHeader .mobileHeaderIcon.shopping-bag.headerCartNotEmpty a.headerCartBlock {
        border: 1px solid #d9d7d7;
        float: left;
    }

    .middleHeader .mobileHeaderIcon.shopping-bag a.headerCartBlock {
        text-align: right;
    }
}

.headerCartNotEmpty .headerCheckoutBlock.miniCartButton {
    width: 110px;
    margin: 0;
    font-size: 0.8em;
    line-height: 42px;
    display: inline-block;
}

.headerCheckoutBlock.miniCartButton {
    display: none;
}

.headerCartNotEmpty.miniCartHover .miniCartExpanded {
    display: block !important;
}

.wishlistHover .wishlistExpanded {
    display: block !important;
}

.wishlistExpanded {
    display: none;
    position: absolute;
    width: 369px;
    top: 35px;
    background: #fff;
    z-index: 20;
    border: 1px solid #d9d7d7;
    -webkit-box-shadow: 0px 5px 10px -2px rgba(136, 136, 136, 1);
    -moz-box-shadow: 0px 5px 10px -2px rgba(136, 136, 136, 1);
    box-shadow: 0px 5px 10px -2px rgba(136, 136, 136, 1);
    color: #100e0e;
}

.wishlistCursorBridge {
    position: absolute;
    right: 35px;
    top: -14px;
    width: 52px;
    height: 30px;
    z-index: 21;
}

.wishlistLoggedOut {
    right: 115px;
}

.wishlistExpandedRows {
    z-index: 10;
}

.wishlistExpanded .wishlistExpandedTotalsRow,
.wishlistExpanded .wishlistExpandedRow {
    clear: both;
    margin: 0 5%;
    padding: 15px 0;
    float: left;
    width: 328px;
    border-bottom: 1px solid #d9d7d7;
    z-index: 11;
}

.wishlistExpanded .wishlistImage {
    width: 90px;
    height: 90px;
    float: left;
}

.wishlistExpanded .wishlistDetails {
    width: 70%;
    float: right;
    padding-top: 10px;
    text-transform: none;
    letter-spacing: 0.5px;
    font-size: 1.2em;
}

.wishlistTitle {
    font-family: 'Nunito Sans';
    width: 85%;
    float: left;
    text-align: left;
    margin-bottom: 15px;
    color: black;
    font-size: 1.2em;
}

.wishlistTitle span.wishlistBrandName {
    -webkit-line-clamp: 1;
    font-size: 14px;
    height: 1.4em;
    font-weight: bold;
}

.wishlistTitle span {
    display: block;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-size: 14px;
    color: #100e0e;
}

.wishlistEntryPriceRow {
    float: left;
    width: 100%;
    clear: both;
}

.wishlistEntryPrice {
    float: left;
    font-size: 14px;
}

.wishlistExpanded .wishlistExpandedTotalsRow.noBorder {
    border-bottom: none;
}

.wishlistEntryRemove {
    float: right;
    text-decoration: underline;
    cursor: pointer;
    font-size: 14px;
    color: black;
    margin-right: 10px;
}

.wishlistExpandedTotalsRow .wishlistExpandedTotalsRowValue,
.wishlistExpandedTotalsRow .wishlisttExpandedTotalsRowLabel {
    float: right;
    width: 30%;
    font-size: 0.933em;
    text-align: right;
}

.wishlistExpandedTotalsRow .wishlistExpandedTotalsRowLabel {
    width: 50%;
}

.wishlistExpandedTotalsRow .wishlistExpandedTotalsRowValue.wishlistSubtotal {
    font-weight: bold;
}

.wishlistAccountMessage {
    text-transform: none;
    text-decoration: none;
    font-size: 14px;
    text-align: center;
    padding-top: 15px;
    padding-bottom: 15px;
    display: inline-block;
}

#wishlistRemoveBtn {
    height: 40px;
    background-color: #dfdfdf;
    border: 0;
    color: black;
    border-radius: 0;
    display: inline-block;
    width: 29%;
    line-height: 40px;
    margin-top: 12px;
}

#guestWishlistRemoveBtn {
    height: 40px;
    background-color: #dfdfdf;
    border: 0;
    color: black;
    border-radius: 0;
    display: inline-block;
    width: 16%;
    line-height: 40px;
    margin-top: 12px;
}

.accountWishlistInfo {
    margin-bottom: 30px;
}

.wishlistAddToCartBtn {
    display: inline-block;
    margin-top: 12px;
    height: 40px;
    background-color: #4a3242;
    line-height: normal;
    border: 0;
    color: white;
    border-radius: 0;
    width: 16%;
}

#wishlistAddToCartBtn {
    width: 29%;
    line-height: normal;
}

#guestWishlistAddToCartBtn {
    width: 16%;
    line-height: normal;
}

.addToWishlistButton {
    display: inline-block;
    background-color: #dfdfdf;
    border: 0;
    color: black;
    width: 15%;
    margin-left: 3%;
    line-height: 0.933em;
    font-size: 14px;
    text-transform: uppercase;
    text-align: center;
    padding: 12px;
    height: 40px;
}

.addToWishlistButton:hover {
    text-decoration: none;
    cursor: pointer;
}

#wishlistSignInButton {
    display: inline-block;
    background-color: #dfdfdf;
    border: 0;
    color: black;
    width: 42%;
    margin: 0px 10px 4% 17px;
    line-height: 3.667em;
    font-size: 12px;
    text-transform: uppercase;
    font-weight: bold;
    text-align: center;
}

.wishlistCreateAccButton {
    display: inline-block;
    border: 0;
    color: white;
    width: 42%;
    margin: 0px 0px 4% 10px;
    line-height: 3.667em;
    font-size: 12px;
    text-transform: uppercase;
    font-weight: bold;
    text-align: center;
    margin-left: 14px;
    margin-right: 14px;
}

.wishlistDropdownArrow {
    position: absolute;
    right: 16px;
    top: -14px;
    width: 20px;
    z-index: 21;
    border-left: 9px solid transparent;
    border-right: 9px solid transparent;
    border-bottom: 14px solid white;
}

.wishlistLoggedIn {
    right: 197px;
}

.wishlistViewListButton {
    display: block;
    border: 0;
    width: 100%;
    line-height: 3.667em;
    font-size: 12px;
    text-transform: uppercase;
    font-weight: bold;
    text-align: center;
}

.wishlistButton:hover {
    color: white;
    text-decoration: none;
}

.wishlistActions {
    font-family: 'Nunito Sans';
    text-transform: none;
    text-decoration: none;
    font-size: 14px;
    text-align: center;
}

.accountReturnOrderBtn {
    width: 100%;
    height: 40px;
    display: inline-block;
    clear: both;
    background-color: #dfdfdf;
    border: 0;
    color: black;
    border-radius: 0;
    font-size: 0.8em;
    text-transform: uppercase;
    font-weight: bold;
    line-height: 30px;
    margin-top: 20px;
    margin-bottom: 40px;
}

/* RETURNS */

.returnOrderTop {
    text-align: center;
    margin-top: 20px;
    margin-bottom: 20px;
}

.returnOrderTop h1 {
    font-size: 1.333em;
    text-transform: uppercase;
    letter-spacing: 0.13em;
}

.returnOrderTop .returnOrderDetails {
    font-size: 0.933em;
    display: inline-block;
    margin-top: 10px;
    line-height: 2em;
}

.returnOrderTopDetails {
    font-size: 0.933em;
    display: inline-block;
    margin-top: 10px;
    line-height: 2em;
}

.returnOrderTopDetails a, .returnOrderTopDetails strong {
    color: black;
    font-weight: bold;
    text-decoration: none !important;
}

.returnOrderHeaderBlock {
    margin: 0px auto 25px;
}

.returnOrderHeaderBlock h1 {
    font-size: 1.333em;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    text-align: center;
    margin-bottom: 20px;
}

.returnOrderInfoBlock h3 {
    font-size: 0.9333em;
    text-transform: uppercase;
    font-weight: bold;
    display: block;
    text-align: left;
    margin: 25px 0;
}

.returnOrderInfoBlock p {
    text-align: left;
    margin-top: 30px;
    margin-bottom: 30px;
}

.returnOrderSummary {
    border-top: 1px solid #ddd;
    border-right: 1px solid #ddd;
    border-left: 1px solid #ddd;
    margin-bottom: 20px;
}

.returnOrderSummary h2 {
    font-size: 0.9333em;
    font-weight: bold;
    text-transform: uppercase;
    margin: 0;
    line-height: 40px;
    background-color: #f5f5f5;
    border-bottom: 1px solid #ddd;
    padding-left: 20px;
}

.returnOrderSummaryProductsRow {
    display: flex;
    width: 100%;
    border-bottom: 1px solid #ddd;
    padding: 21px 25px;
}

.returnOrderSummaryProductImage {
    width: 160px;
    display: inline-block;
    float: left;
    margin-right: 22px;
    height: 100%;
}

.returnOrderSummaryProductImage img {
    float: left;

}

.returnOrderSummaryProductImage img {
    display: inline-block;
    width: 160px;
}

.returnOrderSummaryProductDetails {
    flex: 1;
}

.returnOrderSummaryProductDetails div {
    margin-bottom: 10px;
}

.returnOrderSummaryPrice {
    float: right;
}

.returnFormItemInputBlock {
    margin-top: 17px;
    width: 75%;
    display: inline-block;
}

.returnOrderSummaryReason {
    height: 40px;
    line-height: 38px;
    border-radius: 4px;
    border: 1px solid #ccc;
    -webkit-box-shadow: none;
    padding: 0 5px;
    background-color: white;
    width: 50%;
    align-content: center;
    margin-top: 10px;
}

.returnStatus, .rmaValue, .shippingDateValue {
    font-weight: bold;
    margin-bottom: 10px;
}

select:required:invalid {
    color: gray;
}

.returnOrderCommentBLock {
    margin-top: 17px;
    width: 75%;
}

.returnOrderComment {
    width: 100%;
    height: 120px;
    border: 1px solid #ccc;
    border-radius: 4px;
    resize: none;
    padding: 10px 10px;
}

.returnOrderCommentLettersLeft {
    display: inline-block;
    float: right;
}

.returnOrderSummaryPriceBlock {
    display: inline-block;
    width: 100%;
    border-bottom: 1px solid #ddd;
    padding: 18px 25px;
}

.returnOrderSummaryPriceRow {
    margin: 0px 0px 15px 0px;
}

.returnOrderSummaryPriceLabel {
    display: inline-block;
}

.returnOrderSummaryPriceValue {
    float: right;
}

.returnOrderSummaryFinalPriceRow {
    margin-bottom: 0px;
}

.returnOrderSummaryTotalPriceValue {
    font-weight: bold;
}

.returnOrderContinueButton, .returnOrderContinueButton:hover, .returnOrderContinueButton:focus {
    display: inline-block;
    height: 40px;
    line-height: normal;
    border: 0;
    border-radius: 0;
    text-transform: uppercase;
    border-radius: 2px;
    color: white;
    font-weight: bold;
    font-size: 0.8em;
    float: right;
    width: 300px;
}

.returnOrderBackButton, .returnOrderBackButton:hover, .returnOrderBackButton:focus {
    display: inline-block;
    height: 40px;
    line-height: normal;
    border: 0;
    border-radius: 0;
    text-transform: uppercase;
    border-radius: 2px;
    font-weight: bold;
    font-size: 0.8em;
    background-color: #dfdfdf;
    color: black;
    float: left;
    width: 300px;
}

.returnOrderPrintButton, .returnOrderPrintButton:hover, .returnOrderPrintButton:focus {
    display: inline-block;
    height: 40px;
    line-height: normal;
    border: 0;
    border-radius: 0;
    text-transform: uppercase;
    border-radius: 2px;
    color: white;
    font-weight: bold;
    font-size: 0.8em;
    width: 300px;
    margin-right: 35px;
}

.returnOrderDownloadButton, .returnOrderDownloadButton:hover, .returnOrderDownloadButton:focus {
    display: inline-block;
    height: 40px;
    line-height: normal;
    border: 0;
    border-radius: 0;
    text-transform: uppercase;
    border-radius: 2px;
    color: white;
    font-weight: bold;
    font-size: 0.8em;
    width: 300px;
}

.returnOrderPrintButton i, .returnOrderDownloadButton i {
    padding-right: 5px;
}

.returnOrderButtonBlock {
    margin-top: 30px;
    margin-bottom: 100px;
}

.returnOrderRmaBlock {
    background-color: #f5f5f5;
    height: 200px;
    width: 100%;
    border: 1px solid #dfdfdf;
    margin-bottom: 20px;
}

.returnOrderRmaDetails {
    text-align: center;
    margin-top: 65px;
    margin-bottom: 65px;
}

.returnOrderFormActions {
    width: fit-content;
    margin: 0 auto 10px;
}

.returnOrderDetailsContact {
    margin-top: 20px;
    margin-bottom: 20px;
}

.returnOrderShippingMobile {
    float: right;
    display: inline-block;
    margin-right: 20px;
}

.returnOrderRMAMobile {
    float: left;
    display: inline-block;
    margin-left: 20px;
}

.miniCartExpanded {
    display: none;
    position: absolute;
    width: 332px;
    right: 0;
    top: 50px;
    background: #fff;
    z-index: 20;
    border: 1px solid #d9d7d7;
    -webkit-box-shadow: 0px 5px 10px -2px rgba(136, 136, 136, 1);
    -moz-box-shadow: 0px 5px 10px -2px rgba(136, 136, 136, 1);
    box-shadow: 0px 5px 10px -2px rgba(136, 136, 136, 1);
}

.miniCartShapingBlock {
    position: absolute;
    right: -1px;
    top: -9px;
    width: 160px;
    height: 9px;
    z-index: 21;
    background-color: white;
    border-left: 1px solid #d9d7d7;
    border-right: 1px solid #d9d7d7;
}

.miniCartExpanded .miniCartExpandedTotalsRow,
.miniCartExpanded .miniCartExpandedRow {
    clear: both;
    margin: 0 5%;
    padding: 15px 0;
    float: left;
    width: 90%;
    border-bottom: 1px solid #d9d7d7;
}

.miniCartExpanded .miniCartExpandedTotalsRow.noBorder {
    border-bottom: none;
}

.miniCartExpanded .miniCartImage {
    width: 30%;
    float: left;
}

.miniCartExpanded .miniCartDetails {
    width: 70%;
    float: right;
    padding-top: 10px;
}

.miniCartTitle {
    width: 85%;
    float: left;
    text-align: left;
    margin-bottom: 15px;
}

.miniCartTitle span {
    display: block;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    height: 2.4em;
    overflow: hidden;
    font-size: 0.933em;
}

.miniCartTitle span.miniCartBrandName {
    -webkit-line-clamp: 1;
    height: 1.2em;
    font-weight: bold;
}

.miniCartQuantity {
    width: 15%;
    float: right;
}

.miniCartEntryPriceRow {
    float: left;
    width: 100%;
    clear: both;
}

.miniCartEntryPrice {
    float: left;
    font-size: 0.933em;
}

.miniCartEntryRemove {
    float: right;
    text-decoration: underline;
    cursor: pointer;
    font-size: 0.875em;
    margin-right: 10px;
}

.miniCartExpandedTotalsRow .miniCartExpandedTotalsRowValue,
.miniCartExpandedTotalsRow .miniCartExpandedTotalsRowLabel {
    float: right;
    width: 30%;
    font-size: 0.933em;
    text-align: right;
}

.miniCartExpandedTotalsRow .miniCartExpandedTotalsRowLabel {
    width: 50%;
}

.miniCartExpandedTotalsRow .miniCartExpandedTotalsRowValue.miniCartSubtotal {
    font-weight: bold;
}

.miniCartButton {
    display: inline-block;
    background-color: #4a3242;
    border: 0;
    color: white;
    width: 90%;
    margin: 0 5% 25px;
    line-height: 3.667em;
    font-size: 0.8em;
    text-transform: uppercase;
    font-weight: bold;
}

.miniCartButton:hover {
    color: white;
    text-decoration: none;
}

.miniCartGiftWraps {
    float: right;
    width: 70%;
    text-align: left;
    margin-top: 5px;
}

.miniCartGiftWrapPrice {
    float: right;
}

.miniCartGiftWrapName {
    float: left;
}

.miniCartGiftWrapMessage {
    clear: both;
}

/* Breadcrumbs */

.breadcrumb {
    padding: 8px 0;
    background-color: transparent;
    margin-top: 10px;
}


/* Footer */

.footer {
    background-color: #f7f7f7;
    padding: 80px 0;
}

.footer h3 {
    font-size: 1.5em;
    color: #aaa;
    height: 55px;
    line-height: 1em;
}

.footer ul {
    padding-left: 0;
    list-style: none;
}

.footer li {
    line-height: 2em;
}

.footer .footer-social h3 {
    height: 40px;
}

.footer .footer-social a {
    margin-right: 5px;
    margin-bottom: 35px;
    display: inline-block;
}

.footer .footer-social i {
    height: 40px;
    width: 40px;
    text-align: center;
    padding-top: 11px;
    font-size: 1.25em;
    border-radius: 100px;
    background-color: #716677;
    color: white;
    transition: all 0.1s ease-out;
}

.footer .footer-social i:hover {
    background-color: #eceee1;
    color: #716677;
}

.footer .footer-social p {
    margin-bottom: 10px;
}

.footer .footer-social input[type="text"] {
    height: 40px;
    width: 70%;
    padding-left: 10px;
    border: 1px solid #d1d1d1;
    border-right: 0;
}

.footer .footer-social input[type="submit"] {
    height: 40px;
    width: 30%;
    background-color: #4a3242;
    border: 0;
    color: white;
    float: right;
}

.footer .footer-copyright {
    margin-top: 80px;
    line-height: 28px;
}

.footer .footer-payment {
    margin-top: 80px;
}

.footer .footer-payment img {
    max-height: 28px;
    max-width: 100%;
}

/* Store Finder Page */

.storeFinderContainer {
    position: relative;
}

#storeFinderMap {
    height: 750px;
    width: 100%;
    z-index: 1;
}

#findAStoreSearchBox {
}

#findAStoreSearchBox h1 {
    font-size: 1.5em;
    line-height: 1em;
    text-transform: uppercase;
}

#findAStoreSearchBox p {
    margin: 1.5em 0;
    line-height: 1.25em;
    font-size: 0.9em;
}

#findAStoreSearchBox .selectOuter {
    display: inline-block;
    position: relative;
    overflow: hidden;
    height: 2.25em;
    width: 40%;
    float: left
}

#findAStoreSearchBox .selectOuter #storeFinderBrandSelector {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 0;
    height: 2.25em;
    font-size: 1em;
}

#findAStoreSearchBox .selectOuter:after {
    content: "\f078";
    font-family: Font Awesome\ 5 Pro;
    position: absolute;
    right: 5px;
    top: 0;
    height: 100%;
    z-index: 1;
    pointer-events: none;
    box-sizing: border-box;
    text-align: center;
    color: #D7D7D7;
    line-height: 2.25em;
}

#findAStoreSearchBox input#pac-input {
    width: 50%;
    float: left;
    border-radius: 0;
    margin-left: -1px;
    font-size: 1em;
    height: 2.25em;
    padding-right: 20px;
}

.useMyLocationStoreLookupButton {
    position: absolute;
    margin-left: -22px;
    border: none;
    height: 33px;
    line-height: 33px;
    background-color: transparent;
    padding: 0;
    width: 20px;
}

#findAStoreSearchBox button#findAStoreSearchButton {
    width: 10%;
    text-align: center;
    padding: 0;
    line-height: 2.25em;
    border-radius: 0;
    background-color: #5b414d;
    border-color: #5b414d;
}


.findAStoreSearchBoxResult .storeFinderOpeningHourDay {
    width: 70px;
    display: inline-block;
}

/* Store Finder Woos */

ul.woosPredictions {
    padding: 0 20px;
    text-align: left;
    margin-top: 20px;
    border-top: 1px solid #dbdbdb;
    margin-left: -20px;
    width: calc(100% + 40px);
    display: none;
}

ul.woosPredictions > li {
    border-bottom: 1px solid #dbdbdb;
    padding-top: 5px;
    line-height: 30px;
    cursor: pointer;
}

ul.woosPredictions > li:last-child {
    border: none;
}

.findAStoreSearchBoxSearch ul.woosPredictions {
    padding: 0 40px;
}

.pickUpPopupSearchBlock ul.woosPredictions {
    margin: 0;
    float: left;
    border-top: 0;
    width: 100%;
    padding: 0 5px;
}

#clickAndCollectFormComponent ul.woosPredictions {
    border-top: none;
    margin: 5px 0 20px;
    padding: 0;
    width: 100%;
}

/*Store Details Page*/

h1.detailSectionHeadline {
    font-size: 2.5em;
    color: #4a3242;
    padding: 10px 0;
    line-height: 1em;
}

h1.detailSectionHeadline img {
    height: 1.25em;
    float: left;
    margin-right: 15px;
}

.openingHoursBlockHeader:before {
    content: "";
    width: 100%;
    border-top: 1px solid #eceee1;
    display: block;
}

.openingHoursBlockHeader h2 {
    font-weight: bold;
    margin: 2em 0;
}

.openHoursRow {
    display: block;
    line-height: 1.75em;
}

.openHoursDay,
.openHoursTimes {
    display: inline-block;
}

.openHoursToday {
    font-weight: bold;
}

.openHoursTimes {
    float: right;
    text-transform: lowercase;
    word-spacing: -0.25em;
}

p.openingHoursMessage {
    margin: 2em 0;
    font-size: 0.75em;
    line-height: 1.25em;
}

.storeDetailsLinks {
    display: inline-block;
}

.storeDetailsLinks a {
    text-decoration: underline;
    padding: 0 0.5em;
    display: inline-block;
}

.storeDetailsLinks a.contactStoreLink {
    margin-left: 1.5em;
    text-transform: capitalize;
}

.storeDetailsLinks > * {
    float: left;
}

.storeDetailsLinks > a,
.storeDetailsLinks > span {
    line-height: 40px;
}

.storeDetailsLinks span.verticalDivider {
    display: inline-block;
}

ul.storeDetailsList li i {
    color: #4a3242;
    position: absolute;
    left: -2em;
    line-height: 1.75em;
}

ul.storeDetailsList li {
    line-height: 1.75em;
    position: relative;
    margin-left: 2em;
}

ul.storeDetailsList {
    margin: 2em 0;
}

#storeDetailsMap {
    height: 500px;
    width: 100%;
    z-index: 1;
}

.storeBrandsCarousel.owl-carousel {
    width: calc(100% - 60px);
    margin: 50px 30px;
}

.storeBrandsCarousel.owl-carousel .owl-stage {
    margin: 0 auto;
}

.storeBrandsCarousel.owl-carousel .owl-nav {
    display: block;
}

.storeBrandsCarousel.owl-carousel .owl-nav button {
    font-size: 0;
    position: absolute;
    top: calc(50% - 15px);
    height: 30px;
    width: 30px;
    opacity: 0.3;
    -webkit-transition: opacity 0.3s ease;
    -moz-transition: opacity 0.3s ease;
    -o-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
}

.storeBrandsCarousel.owl-carousel .owl-nav button.disabled,
.storeBrandsCarousel.owl-carousel .owl-nav button span {
    display: none;
}


.storeBrandsCarousel.owl-carousel .owl-nav button:hover {
    opacity: 0.7;
}

.storeBrandsCarousel.owl-carousel .owl-nav .owl-prev {
    left: -30px;
    background: url(../images/arrow-left.png);
    cursor: pointer;
}

.storeBrandsCarousel.owl-carousel .owl-nav .owl-next {
    right: -30px;
    background: url(../images/arrow-right.png);
    cursor: pointer;
}

.storeBrandsContainer {
    display: flex;
    justify-content: center;
}

.storeBrandsContainer .storeBrandBlock {
    width: 13.5%;
    margin: 0 0.5%;
}

.storeBrandsContainer .storeBrandBlock img {
    width: 100%;
    margin: 50px auto;
}

.storeDescriptionRow {
    background-color: #f7f7f7;
    padding: 4em 0;
}

.storeDescriptionRow h2 {
    text-transform: uppercase;
    font-size: 1.5em;
}

.storeDescriptionRow .col-md-6 > h2 {
    margin-bottom: 1.25em;
}

.storeDescriptionRow .col-md-6 > p {
    margin-bottom: 1.5em;
}

.storeDescriptionRow .col-md-6 > ul {
    padding-left: 1.75em;
}

.storeDescriptionRow .col-md-6 > ul li {
    position: relative;
    line-height: 1.75em;
}

.storeDescriptionRow .col-md-6 > ul li:before {
    content: "\f00c";
    font-family: Font Awesome\ 5 Pro;
    position: absolute;
    left: -1.75em;
}

.storeDescriptionRow .storeDescriptionRowClickAndCollect a {
    text-decoration: underline;
}


.showroomImage {
    padding: 3em 0;
    text-align: center;
}

.showroomImage img {
    max-width: 100%;
}

.storePageForms .formBlock {
    padding-bottom: 15px;
}

.storePageForms .radio-inline input[type=radio] {
    margin-top: 8px;
}

.formBlock i.chevronOpen {
    display: none;
}

.formBlock.closed i.chevronClose {
    display: none;
}

.formBlock.closed i.chevronOpen {
    display: inline-block;
}

.formBlockHeader {
    padding: 1em;
    width: 100%;
    line-height: 2em;
    cursor: pointer;
    border-top: 1px solid #eceee1;
}

.formBlockHeader i {
    float: right;
    line-height: 2em;
}

.formBlockHeader h2 {
    display: inline-block;
}


.formBlock.closed .formBlockInner {
    display: none;
}

.formBlockInner .storeFormInput {
    width: 100%;
    height: 2.5em;
    padding: 0 0.5em;
    margin: 0.75em 0;
}

.formBlockInner textarea.storeFormInput.requestsInput {
    height: 14.5em;
    line-height: 1.5em;
    padding-top: 0.5em;
}

.formBlockInner textarea.storeFormInput.storeMessageInput {
    height: 18.5em;
    line-height: 1.5em;
    padding-top: 0.5em;
}

.formBlockInner .contactMethodRadios,
.formBlockInner .signUpCheckbox {
    text-align: center;
    line-height: 2em;
}

.formBlockInner .contactMethodRadios span {
    margin-right: 2em;
}

.formBlockInner button.btn,
button.btn.bookAnAppointment {
    height: 40px;
    background-color: #a6182e;
    border: 0;
    color: white;
    border-radius: 0;
    padding-left: 1.5em;
    padding-right: 1.5em;
}

#appointmentRecaptcha, #contactStoreRecaptcha {
    float: right;
    margin-bottom: 15px;
}

.storeMessageForm {
    margin-bottom: 30px;
}


.ui-datepicker .ui-datepicker-prev span:after,
.ui-datepicker .ui-datepicker-next span:after {
    font-family: "Font Awesome\ 5 Pro";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    text-indent: 1px;
    text-align: center;
}

.ui-datepicker .ui-datepicker-prev span:after {
    content: "\f0d9";
}

.ui-datepicker .ui-datepicker-next span:after {
    content: "\f0da";
}


.storeFormPopupBackground {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background-color: rgba(255, 255, 255, 0.6);
    z-index: 2;
}

.storeFormPopupBackground.hasPopup {
    cursor: pointer;
}

.page-storeFinderPage .formBlockInner {
    position: relative;
}

.page-storeFinderPage .alert.alert-dismissable {
    margin-bottom: -1px;
    border: none;
    border-radius: 0;
}

.storeFormSpinner {
    animation: 1.5s linear infinite spin;
    border: solid 5px #eee;
    border-bottom-color: #4a3242;
    border-radius: 50%;
    content: "";
    height: 50px;
    width: 50px;
    top: 40%;
    left: 50%;
    opacity: inherit;
    position: absolute;
    transform: translate3d(-50%, -50%, 0);
    transform-origin: center;
    will-change: transform;
    z-index: 3;
}

.storeFormPopup {
    position: absolute;
    background-color: white;
    z-index: 4;
    top: 30%;
    height: 30%;
    width: 40%;
    left: 30%;
    padding: 20px;
    border: 1px solid #ccc;
    border-radius: 5px;
    min-height: 150px;
}

.storeFormPopup span {
    text-align: center;
    display: inline-block;
    width: 100%;
}

.storeFormPopup .storePopupCloseButton {
    position: absolute;
    bottom: 15px;
    width: 30%;
    left: 35%;
    text-align: center;
    line-height: 40px;
    background-color: #a6182e;
    color: white;
    cursor: pointer;
}

/* Product Page */

.productSpecification h2 {
    font-size: 1.5em;
    margin-top: 1em;
}

.productSpecification ul.productSpecs {
    margin: 1em 0;
    overflow: auto;
}

.productSpecification ul.productSpecs li {
    line-height: 1.5em;
    padding: 0.5em 0;
    clear: both;
}

.productSpecification ul.productSpecs li .specLabel,
.productSpecification ul.productSpecs li .specValue {
    float: right;
    width: 50%;
}

.productSpecification ul.productSpecs li .specLabel {
    font-weight: bold;
    width: 50%;
    display: inline-block;
    float: left;
}

.productSpecification a#productSpecReadMore {
    font-size: 1.125em;
    margin-bottom: 2em;
    display: block;
    line-height: 3em;
}

.productSpecification a#productSpecReadMore:hover {
    text-decoration: none;
}

.productSpecification a#productSpecReadMore span {
    text-decoration: underline;
}

.productDetails {
    margin-bottom: 15px;
}

.productDetails > span {
    display: block;
}

.productDetails h1.productTitle {
    font-size: 1.75em;
    display: block;
    margin-bottom: 10px;
    line-height: 1.25em;
}

.productDetails h1.productTitle span {
    font-size: 1.125em;
}

.productDetails h1.productTitle span:first-child {
    display: block;
}

.productDetails h1.productTitle span.productManCode {
    color: #aaa;
    font-size: 0.722em;
    margin-top: 1.2em;
    display: block;
}

.productDetails span.productPrice {
    font-size: 2em;
    margin: 1em 0 0.5em;
    font-weight: 600;
}

.productDetails span.productPrice.salePrice {
    color: #ff6060;
}

.productDetails span.productPrice .productWasPrice {
    text-decoration: line-through;
    font-size: 0.7em;
    font-weight: 400;
    color: #aaa;
    margin-left: 5px;
}

.productDetails span.productDeliveryMessage {
    font-weight: bold;
    font-size: 0.875em;
    margin: 3em 0 1.5em;
}

.productDetails .add_to_cart_form {
    width: 100%;
    display: inline-block;
}

.productDetails .add_to_cart_form button.addToCartButton {
    height: 40px;
    background-color: #4a3242;
    border: 0;
    color: white;
    border-radius: 0;
    display: inline-block;
    width: 80%;
}

#productPhoneCTA {
    line-height: 40px;
    background-color: #4a3242;
    border: 0;
    color: white;
    border-radius: 0;
    display: block;
    padding: 0;
}

#productPhoneCTA i {
    margin-right: 2px;
}

.productDetails button.addToWishlist {
    display: inline-block;
    float: right;
    line-height: 36px;
    width: 40px;
    padding: 4px 0 0 1px;
    border: none;
    border-radius: 20px;
    font-weight: bold;
    font-size: 1.15em;
}

/* Product Page - Stock Locator */

.productStoreLocatorBox {
    border: 1px solid #d7d7d7;
    margin: 1.5em 0;
    padding-bottom: 15px;
    position: relative;
}

.productStoreLocatorBox > div {
    width: 100%;
    display: inline-block;
    line-height: 3em;
    padding: 0 5%;
    position: relative;
    font-size: 0.875em;
}

.productStoreLocatorBox > div > * {
    display: block;
}

.productStoreLocatorBox > div > span {
    font-size: 0.85em;
}

.productStoreLocatorBox > div > span > i {
    margin-right: 5px;
}

.productStoreLocatorBoxHeader {
    background-color: #e6e6e6;
    text-align: center;
}

.productStoreLocatorBoxHeader > i {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
}


.pslOpeningHoursSummary > span {
    max-width: 75%;
    display: inline-block;
}

.pslResultsHeader > div {
    max-width: 65%;
    display: inline-block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.seeMoreStyles
.pslResultsHeader > * {
    line-height: 1.5em;
}

.productStoreLocatorBoxResults {
    border: 1px solid #e6e6e6;
    font-size: 0.733em;
    margin: 1.5em 0;
}

.pslResultsHeader,
.pslResultsStore {
    padding: 1em 1.5em;
    border-bottom: 1px solid #e6e6e6;
}

.pslResultsHeader {
    line-height: 1.25em;
}

.pslResultsStore.pslResultsStoreFirst {
    background-color: #eee;
}

.pslResultsHeader .pslChangeStore,
.pslOpeningHoursSummary .pslStoreInfo {
    float: right;
    cursor: pointer;
}

.pslResultsStore .pslStoreName {
    font-weight: bold;
    line-height: 2em;
}

.pslResultsStore .pslStoreName span {
    font-weight: normal;
    color: #5A5A5A;
    margin-left: 5px;
}

.pslResultsStore .pslOpeningHoursSummary {
    font-size: 0.875em;
    line-height: 2em;
}

.pslOpeningHoursSummary .pslStoreInfo:after {
    font-family: Font Awesome\ 5 Pro;
    content: "\f107";
    margin-left: 3px;
}

.pslOpeningHoursSummary .pslStoreInfo.closeInfo:after {
    content: "\f106";
}

.pslResultsHeader .pslChangeStore,
.pslOpeningHoursSummary .pslStoreInfo span {
    text-decoration: underline;
}

.pslStoreAdditionalInfo .pslAddress {
    padding: 1.5em 0;
}

.pslStoreAdditionalInfo ul.pslOpeningHours {
    padding-left: 0;
    line-height: 2em;
}

.pslStoreAdditionalInfo ul.pslOpeningHours li.pslToday {
    font-weight: bold;
}

.pslStoreAdditionalInfo ul.pslOpeningHours li span {
    width: 35%;
    display: inline-block;
}

.pslCollect .pslCollectButton {
    float: right;
    background-color: #a6182e;
    color: white;
    width: 50%;
    text-align: center;
    font-size: 1.125em;
    -webkit-box-shadow: 0px 3px 3px 0px rgba(204, 204, 204, 1);
    -moz-box-shadow: 0px 3px 3px 0px rgba(204, 204, 204, 1);
    box-shadow: 0px 3px 3px 0px rgba(204, 204, 204, 1);
}

.pslCollect {
    line-height: 3em;
}

.pslCollect .pslCollectDate {
    color: #aaa;
}

.pslActions {
    clear: both;
    margin-top: 10px;
}

.pslActions a {
    text-decoration: underline;
}

.pslActions a:last-child {
    float: right;
}

.productStoreLocatorBox > div.productStoreLocatorOverlay {
    position: absolute;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.3);
    top: 0;
    left: 0;
    z-index: 7;
}

.productStoreLocatorBox > div.productStoreLocatorOverlay > i {
    display: inline-block;
    position: absolute;
    left: calc(50% - 0.5em);
    top: calc(50% - 0.5em);
    color: #5A5A5A;
}

.pslStock {
    width: 100%;
    height: 25px;
}

.pslStock.pslOutOfStock {
    color: #d9534f;
}

.pslStock.pslInStock {
    color: #5cb85c;
}

.pslStock > * {
    display: block;
    float: left;
    line-height: 25px;
}

.pslStock > i {
    font-size: 1.75em;
    margin-right: 5px;
}

.pslStock > span {
    font-size: 1.25em;
    font-weight: bold;
}

/* Styles here also used on cart page */

.productStoreLocatorBox input {
    border-radius: 0;
    line-height: 38px;
    height: 40px;
    padding: 0 30px 0 12px;
    width: 85%;
    display: inline-block;
}

.productStoreLocatorBox button#findStockSearchButton {
    width: 15%;
    float: right;
    line-height: 40px;
    padding: 0;
    border: none;
    border-radius: 0;
    background-color: #d7d7d7;
    color: inherit;
}

#useMyLocationStockLookup {
    margin: 0;
    top: 0;
    right: 60px;
    height: 40px;
    line-height: 40px;
    width: 30px;
    font-size: 14px;
    padding-top: 1px;
}

/* See More Styles */

.seeMoreStyles {
    width: 80%;
}

.seeMoreStylesHeader {
    font-weight: bold;
    margin-top: 0;
    margin-bottom: 10px;
    font-size: 1em;
}

.seeMoreStyles .owl-dots {
    display: none;
}

.seeMoreStyles .owl-nav {
    display: block !important;
}

.seeMoreStyles .owl-nav button {
    font-size: 0;
    position: absolute;
    top: calc(50% - 10px);
    height: 20px;
    width: 30px;
    opacity: 0.3;
    -webkit-transition: opacity 0.3s ease;
    -moz-transition: opacity 0.3s ease;
    -o-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
}

.seeMoreStyles .owl-nav button:hover {
    background: none;
    opacity: 0.7
}

.seeMoreStyles .owl-nav button.disabled {
    opacity: 0;
}

.seeMoreStyles .owl-nav .owl-prev,
.seeMoreStyles .owl-nav .owl-prev:hover {
    left: -25px;
    background-image: url(../images/arrow-left.png) !important;
    background-color: transparent;
    z-index: 2;
    cursor: pointer;
}

.seeMoreStyles .owl-nav .owl-next,
.seeMoreStyles .owl-nav .owl-next:hover {
    right: -25px;
    background-image: url(../images/arrow-right.png) !important;
    background-color: transparent;
    z-index: 2;
    cursor: pointer;
}

.seeMoreStyles a {
    padding: 3px;
    display: block;
}

.seeMoreStyles img {
    border: 1px solid #ddd;
}

/* Product Image Carousels */

.productImageGallery .heroCarousel {
    max-width: 640px;
    margin: auto;
}

.productImageGallery .owlThumbs {
    text-align: center;
    margin-top: 20px;
    margin-bottom: 30px;
}

.productImageGallery .owlThumbs button {
    width: 60px;
    height: 60px;
    padding: 0;
    margin: 3px;
    border: 0;
    border: 1px solid #ddd;
    outline: none;
}

.productImageGallery .owlThumbs button.active {
    border-color: #aaa;
}

.productImageGallery .owlThumbs button img {
    width: 100%;
}

.productImageGallery .owl-dots {
    display: none;
}

.productDetailsRow {
    position: relative;
}

.productImageGallery {
    position: initial;
}

.productImageGallery .heroCarousel {
    max-width: 640px;
    margin: auto;
}


.productImageGallery .owl-dots {
    display: none;
}

.productImageGallery .owl-lazy.pan,
.productImageGallery img.zoomImg {
    cursor: url(../images/zoom-cursor.png), auto;
}


.productImageGallery img.zoomImg {
    background-color: white;
}

.productImageGallery .owl-nav {
    display: block !important;
}

.productImageGallery .owl-nav div {
    font-size: 0;
    position: absolute;
    top: calc(50% - 15px);
    height: 30px;
    width: 30px;
    opacity: 0.3;
    -webkit-transition: opacity 0.3s ease;
    -moz-transition: opacity 0.3s ease;
    -o-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
}

.productImageGallery .owl-nav div:hover {
    opacity: 0.7;
}

.productImageGallery .owl-nav .owl-prev,
.productImageGallery .owl-nav .owl-prev:hover {
    left: -5px;
    background-image: url(../images/arrow-left.png) !important;
    background-color: transparent;
    z-index: 2;
    cursor: pointer;
}

.productImageGallery .owl-nav .owl-next,
.productImageGallery .owl-nav .owl-next:hover {
    right: -5px;
    background-image: url(../images/arrow-right.png) !important;
    background-color: transparent;
    z-index: 2;
    cursor: pointer;
}

.owl-carousel.singleImage .owl-dots,
.owl-carousel.singleImage .owl-nav {
    display: none !important;
}

div#galleryPopupBackground {
    position: fixed;
    z-index: 30;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #333;
    opacity: 0.6;
}

div#galleryPopup {
    position: absolute;
    z-index: 31;
    top: 0;
    left: calc(50% - 500px);
    width: 100%;
    max-width: 1000px;
    background-color: white;
    padding: 20px 20px 0;
}

div#galleryPopup #galleryPopupClose {
    position: absolute;
    top: 5px;
    right: 5px;
    height: 20px;
    width: 16px;
    cursor: pointer;
    font-size: 20px;
}

div#videoPopup {
    position: absolute;
    z-index: 7;
    top: 0;
    left: calc(50% - 500px);
    width: 100%;
    max-width: 1000px;
    background-color: white;
    padding: 25px;
}

div#videoPopup #videoPopupClose {
    position: absolute;
    top: 5px;
    right: 5px;
    height: 20px;
    width: 20px;
    cursor: pointer;
    font-size: 20px;
}

#productPopupImageGallery .owl-lazy {
    opacity: 1;
}

.productPageCollapsibleSection {
    padding-right: 0;
    padding-left: 0;
}

.productPageCollapsibleSection > div:first-child {
    border-top: 1px solid #ddd;
}

.productPageCollapsibleSection > * {
    padding-right: 30px;
    padding-left: 30px;
}

.productPageCollapsibleSectionHeader {
    cursor: pointer;
}

.productPageCollapsibleSectionHeader > * {
    font-size: 1.5em;
    line-height: 2.5em;
}

.productPageCollapsibleSectionHeader > i {
    float: right;
}

.productPageCollapsibleSection .productPageCollapsibleSectionHeader i.fa-chevron-right {
    display: inline-block;
}

.productPageCollapsibleSection .productPageCollapsibleSectionHeader i.fa-chevron-down {
    display: none;
}

.productPageCollapsibleSection.productPageCollapsibleSectionOpen .productPageCollapsibleSectionHeader i.fa-chevron-right {
    display: none;
}

.productPageCollapsibleSection.productPageCollapsibleSectionOpen .productPageCollapsibleSectionHeader i.fa-chevron-down {
    display: inline-block;
}


.productPageCollapsibleSection .productPageCollapsibleSectionBody {
    display: none;
    height: 0;
}

.productPageCollapsibleSection .productPageCollapsibleSectionBody > .row {
    margin-top: 15px;
}

.productPageCollapsibleSection .productPageCollapsibleSectionBody img {
    max-width: 100%;
}


.productPageCollapsibleSection.productPageCollapsibleSectionOpen .productPageCollapsibleSectionBody {
    display: block;
    height: auto;
    padding-bottom: 20px;
}

.productFinanceComponent .productPageCollapsibleSection:after {
    content: "";
    border-bottom: 1px solid #ddd;
    width: 100%;
    float: left;
}


/* - Product Details - Variant Dropdowns */

.variantDropdownsContainer {
    width: 100%;
    height: 23px;
    margin-bottom: 15px;
}

.variantDropdownsContainer select#ringMetalTypeDropdown {
    width: 39%;
    margin-right: 2.5%;
}

.variantDropdownsContainer select#stoneWeightDropdown {
    width: 28%;
    margin-right: 2.5%;
}

.variantDropdownsContainer select#ringSizeDropdown {
    width: 28%;
}

.variantDropdownsContainer select.variantDropdown {
    float: left;
    line-height: 1.5em;
    height: 1.5em;
}

/* Product Page - You May Also Like Carousel */
.youMayAlsoLike {
    background-color: #f2f2f2;
}

.youMayAlsoLike, .recentlyViewed {
    padding: 50px 0;
    margin: 30px 0;
}

.youMayAlsoLike .youMayAlsoLikeHeader, .recentlyViewed .recentlyViewedHeader {
    font-size: 1.5em;
    line-height: 2.5em;
    padding-left: 10px;
    margin: 0;
}

.recentlyViewedCarousel .owl-stage {
    margin: auto;
}

.youMayAlsoLikeBlock, .recentlyViewedBlock {
    margin-top: 5px;
    margin-bottom: 5px;
}

.youMayAlsoLikeBlock a, .recentlyViewed a {
    display: block;
    margin: auto 15px;
    padding: 10px;
    background-color: white;
}

.youMayAlsoLikeBlock a {
    border: 1px solid #d5d5d5;
    -webkit-box-shadow: 0px 3px 3px 0px rgba(204, 204, 204, 1);
    -moz-box-shadow: 0px 3px 3px 0px rgba(204, 204, 204, 1);
    box-shadow: 0px 3px 3px 0px rgba(204, 204, 204, 1);
}

.youMayAlsoLikeBlock a:hover, .recentlyViewed a:hover {
    text-decoration: none !important;
}

.youMayAlsoLikeBlock .youMayAlsoLikeImg, .recentlyViewedBlock .recentlyViewedImg {
    position: relative;
}

.youMayAlsoLikeBlock img, .recentlyViewed img {
    width: 100%;
    margin-bottom: 15px;
}

.youMayAlsoLikeBlock .productPageAltImage, .recentlyViewedBlock .productPageAltImage {
    position: absolute;
    opacity: 0 !important;
    top: 0;
    left: 0;
    z-index: 2;
    transition: all 0.2s ease-out;
    border-radius: 20px;
}

.youMayAlsoLikeBlock .productPageAltImage:hover, .recentlyViewedBlock .productPageAltImage:hover {
    opacity: 1 !important;
}

.youMayAlsoLikeBlock a > * {
    text-decoration: none !important;
}

.youMayAlsoLikeBlock a > h4 {
    font-size: 1em;
    margin: 0;
}

.youMayAlsoLikeBlock .youMayAlsoLikeBrandName {
    font-weight: bold;
}

.youMayAlsoLikeBlock .youMayAlsoLikeProductName {
    margin: 8px auto;
}

.youMayAlsoLikeBlock .youMayAlsoLikePrice {
    font-weight: bold;
}

.youMayAlsoLikeCarousel.owl-carousel .owl-dots {
    display: none;
}

.youMayAlsoLikeCarousel.owl-carousel .owl-nav {
    display: block !important;
}

.youMayAlsoLikeCarousel.owl-carousel .owl-nav div {
    font-size: 0;
    position: absolute;
    top: calc(50% - 10px);
    height: 20px;
    width: 30px;
    opacity: 0.3;
    -webkit-transition: opacity 0.3s ease;
    -moz-transition: opacity 0.3s ease;
    -o-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
}

.youMayAlsoLikeCarousel.owl-carousel .owl-nav div:hover {
    background: none;
    opacity: 0.7;
}

.youMayAlsoLikeCarousel.owl-carousel .owl-nav div.disabled {
    opacity: 0;
}

.youMayAlsoLikeCarousel.owl-carousel .owl-nav .owl-prev,
.youMayAlsoLikeCarousel.owl-carousel .owl-nav .owl-prev:hover {
    left: -30px;
    background: url(../images/arrow-left.png);
    background-color: transparent;
    z-index: 2;
    cursor: pointer;
}

.youMayAlsoLikeCarousel.owl-carousel .owl-nav .owl-next,
.youMayAlsoLikeCarousel.owl-carousel .owl-nav .owl-next:hover {
    right: -30px;
    background: url(../images/arrow-right.png);
    background-color: transparent;
    z-index: 2;
    cursor: pointer;
}

/* Product Listing Page */

.plpContainer {
    position: relative;
    margin-bottom: 50px;
}

.gridBlock {
    width: 100%;
    float: left;
    display: -webkit-flex; /* Safari */
    -webkit-flex-wrap: wrap; /* Safari */
    display: flex;
    flex-wrap: wrap;
    -webkit-align-content: flex-start;
    align-content: flex-start;
}

.productTile {
    padding: 0;
    margin-bottom: 25px;
    display: -webkit-box; /* OLD - iOS 6-, Safari 3.1-6 */
    display: -moz-box; /* OLD - Firefox 19- (buggy but mostly works) */
    display: -ms-flexbox; /* TWEENER - IE 10 */
    display: -webkit-flex;
    display: flex;
    width: 24.9%;
    position: relative;
}

.productTile a {
    text-decoration: none !important;
    width: 100%;
    position: relative;
    margin-bottom: 30px;
}

.productTile img {
    width: 100%;
    margin-bottom: 15px;
}

.productTile .productTileBrand {
    font-weight: 600;
    margin-bottom: 10px;
}

.productTile .productTileName {
    height: 36px;
    overflow: hidden;
    margin-bottom: 10px;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.productTile .productTileWishlist {
    position: absolute;
    z-index: 3;
    top: 20px;
    right: 20px;
    height: 30px;
    width: 30px;
    background: url(https://d30y9cdsu7xlg0.cloudfront.net/png/25848-200.png);
    background-size: cover;
    opacity: 0.15;
    cursor: pointer;
}

.productTile .productTileWishlist.wishlist-selected {
    opacity: 1;
}

.productTilePrice {
    font-weight: 600;
    font-size: 1.4em;
    height: 25px;
}

.productTilePrice.salePrice {
    color: #ff6060;
}

.productTilePrice .productTileWasPrice {
    text-decoration: line-through;
    font-size: 0.7em;
    font-weight: 400;
    color: #aaa;
    margin-left: 5px;
}

.productTilePrice .rrp-price {
    font-size: 0.7em;
    font-weight: 400;
    color: #aaa;
}

.productTilePrice .productTilePriceFrom {
    text-transform: lowercase;
    font-size: 14px;
}

.productTextHidden .productTileText {
    display: none !important;
}

.productTile .productListerSecondary {
    position: absolute;
    opacity: 0;
    top: 0;
    left: 0;
    z-index: 2;
    transition: all 0.2s ease-out;
}

.productTile .productListerSecondary:hover {
    opacity: 1;
}


.productSort {
    margin: 20px 0;
}

.productSort:after {
    content: '';
    display: block;
    clear: both;
}

.productSort .hideGridFacets {
    cursor: pointer;
    float: left;
    line-height: 38px;
    margin-right: 20px;
    width: 100%;
    text-align: center;
    border-radius: 4px;
    border: 1px solid #ccc;
    -webkit-box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.1);
}

.productSort .hideGridFacets:after {
    content: '';
    display: block;
    clear: both;
}

.productSort .hideProductText {
    cursor: pointer;
    float: right;
    line-height: 38px;
    margin-left: 20px;
    width: auto;
    text-align: center;
    border-radius: 4px;
    border: 1px solid #ccc;
    -webkit-box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.1);
    padding: 0 20px;
}

.productSort .productItemNumber {
    float: right;
    line-height: 40px;
}

.productSort-mobile {
    display: none;
}


.appliedFiltersHeader span:first-child {
    font-weight: bold;
}

.appliedFiltersHeader .clearFacets {
    float: right;
    cursor: pointer;
}

.appliedFilters .appliedFilter {
    line-height: 2em;
    margin-top: 10px;
    padding: 0 10px;
    background-color: #f7f7f7;
}

.appliedFilters .appliedFilter i {
    float: right;
    line-height: 2em;
    min-width: 12px;
    text-align: center;
    cursor: pointer;
}

.gridFacets {
    position: relative;
    position: sticky;
    top: 62px;
    transition: all 0.2s ease-out;
}

.facetOptions {
    height: 0;
    overflow: hidden;
    display: none;
}

.facetItem {
    overflow: hidden;
}

.facetItem.facetOpen .facetOptions {
    height: auto;
    max-height: 210px;
    overflow-y: auto;
    margin-bottom: 15px;
    margin-top: 10px;
    display: block;
}

.facetTitle {
    white-space: nowrap;
    position: relative;
    font-weight: 600;
    padding: 7px 0;
    cursor: pointer;
    outline: none;
}

.facetOptions li {
    white-space: nowrap;
    padding: 4px 0;
    cursor: pointer;
    outline: none;
}

.facetOptions li:hover {
    text-decoration: underline;
}

.facetOptions li:before {
    content: '';
    width: 12px;
    height: 12px;
    margin-top: 3px;
    border: 1px solid #ccc;
    display: block;
    float: left;
    margin-right: 8px;
}

.facetOptions li > div {
    width: 90%;
    white-space: normal;
    padding-left: 19px;
    line-height: 1.5em;
}

.facetOptions li.filterSelected:before {
    background-color: #4a3242;
    border-color: #4a3242;
}

.facetItem .facetTitle:after {
    content: '\f054';
    font-family: "Font Awesome\ 5 Pro";
    position: absolute;
    right: 0;
    color: #ccc;
    font-size: 0.8em;
}

.facetItem.facetOpen .facetTitle:after {
    content: '\f078';
}


.facetOptions li:focus:before, .facetItem .facetTitle:focus:after, li.paginationAction:focus span {
    outline-width: 2px;
    outline-style: solid;
    outline-color: rgba(210, 48, 54, 0.75) !important;
    outline-offset: -2px;
}

.productTileIfc {
    font-size: 14px;
    line-height: 18px;
    border: 1px solid #ddd;
    background-color: #f7f7f7;
    color: #000;
    padding: 10px 15px;
    margin-top: 10px;
}

.productTileIfc b {
    text-decoration: underline;
}

/* Price Slider */

.facetItems-priceSlider .facetItem.facetOpen .facetOptions {
    overflow-y: visible;
    padding: 15px 10px 0;
    height: 80px;
    display: block;
}

.facetItems-priceSlider:focus-within {
    position: relative;
    z-index: 8;
}

#priceSlider {
    height: 4px;
    border-color: #d7d7d7;
}

#priceSlider .noUi-connect {
    background: #888;
    height: 4px;
    top: -1px;
}

#priceSlider .noUi-connects {
    overflow: visible;
}

html:not([dir=rtl]) #priceSlider.noUi-horizontal .noUi-handle {
    width: 20px;
    height: 20px;
    border-radius: 10px;
    top: -8px;
    right: -10px;
    border-color: #888;
}

#priceSlider .noUi-handle:after,
#priceSlider .noUi-handle:before {
    height: 6px;
    top: 6px;
    left: 7px;
    background-color: #888;
}

#priceSlider .noUi-handle:after {
    left: 10px;
}

#priceSliderValues {
    margin: 15px -7px 0;
    font-size: 0.85em;
}

#priceSliderValues > div {
    width: 50%;
    display: inline-block;
}

.priceValueInputBlock {
    width: 96%;
    display: inline-block;
    position: relative;
}

.priceValueInputLabel {
    position: absolute;
    top: 3px;
    left: 6px;
    font-size: 12px;
    font-weight: bold;
}

.priceValueInputCurrency {
    position: absolute;
    top: 22px;
    left: 6px;
}

.priceValueInputBlock > input {
    width: 100%;
    padding-top: 20px;
    padding-left: 12px;
}

.priceValueInputBlock > input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

#priceSliderValues .toPrice {
    float: right;
    text-align: right;
}

.gridFacetsHidden .gridFacets {
    width: 0;
    padding: 0;
    opacity: 0;
}

.gridFacetsHidden .productGrid {
    width: 100%;
}

.productGrid {
    transition: all 0.2s ease-out;
}

.product-tile-wishlist,
.productCarouselWishlist {
    cursor: pointer;
    position: absolute;
    top: 0;
    right: 0;
    width: 30px;
    height: 30px;
    text-align: center;
    line-height: 30px;
    z-index: 3;
}

.productCarouselWishlist {
    top: 15px;
    right: 15px;
}

/* width */

::-webkit-scrollbar {
    width: 10px;
}

/* Track */

::-webkit-scrollbar-track {
    background: #f1f1f1;
}

/* Handle */

::-webkit-scrollbar-thumb {
    background: #888;
}

/* Handle on hover */

::-webkit-scrollbar-thumb:hover {
    background: #5A5A5A;
}


.sortSelect {
    height: 40px;
    border-radius: 4px;
    border: 1px solid #ccc;
    -webkit-box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.1);
    padding: 0 5px;
}

.paginationBottom {
    text-align: center;
    clear: both;
}

.paginationBottom .paginationAction {
    cursor: pointer;
}

.pagination-prev.disabled,
.pagination-next.disabled {
    opacity: 0.6;
}

.pagination > li > a,
.pagination > li > span {
    border: none;
    padding: 4px;
    color: inherit;
}

.pagination > .active > a,
.pagination > .active > a:focus,
.pagination > .active > a:hover,
.pagination > .active > span,
.pagination > .active > span:focus,
.pagination > .active > span:hover {
    color: inherit;
    background-color: transparent;
    font-weight: bold;
}

.pagination > li > a,
.pagination > li > a:focus,
.pagination > li > a:hover,
.pagination > li > span,
.pagination > li > span:focus,
.pagination > li > span:hover {
    color: inherit;
    background-color: transparent;
}

.pagination-LoadMorePrevBlock {
    float: left;
    width: 100%;
    text-align: center;
    margin-bottom: 15px;
}

.productStyleBuilderResultsPrevPagePaginationContainer .pagination-LoadMorePrevBlock {
    float: none;
}

.pagination-LoadMorePrevBlock > div {
    display: inline-block;
    padding: 15px 35px;
    border: 1px solid #ddd;
    cursor: pointer;
    text-transform: uppercase;
    font-size: 14px;
    font-weight: bold;
}

.pagination-viewedCount {
    float: left;
    width: 100%;
    text-align: center;
}

.pagination-viewedCountMessage {
    font-size: 11px;
}

.pagination-viewedCountBarOuter {
    width: 150px;
    height: 2px;
    background-color: #ccc;
    margin: 7px auto 12px;
    position: relative;
}

.pagination-viewedCountBarInner {
    position: absolute;
    top: 0;
    left: 0;
    height: 2px;
    background-color: #a6182e;
}

.listingPageOverlay {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 7;
    background-color: rgba(255, 255, 255, 0.5);
}

.listingPageOverlay i {
    position: fixed;
    top: 50%;
    left: 50%;
    opacity: 0.8;
}

/* Cart Page */

.cartTop {
    text-align: center;
    margin-top: 20px;
    margin-bottom: 60px;
}

.cartTop h1 {
    font-size: 1.333em;
    text-transform: uppercase;
    letter-spacing: 0.13em;
}

.cartTop .cartNortonSealMobile {
    display: none;
}

.cartTop .cartTopDetails {
    font-size: 0.933em;
    display: inline-block;
    margin-top: 10px;
    line-height: 2em;
}

.cartTop .cartTopDetails a, .cartTop .cartTopDetails strong {
    color: black;
    font-weight: bold;
    text-decoration: none !important;
}

.cartPage button.btn-block.btn--continue-checkout {
    line-height: 3.667em;
    width: 250px;
    background-color: #4a3242;
    border: 0;
    color: white;
    float: right;
    border-radius: 0;
    margin: 1.3em 0;
    font-size: 0.8em;
    text-transform: uppercase;
    padding: 0;
    font-weight: bold;
}

.cartProductListHeader table {
    float: right;
    margin-top: 8px;
    margin-right: 20px;
}

.cartProductListHeader .cartNortonSeal {
    max-height: 60px;
    float: right;
    margin-right: 20px;
}

.cartPage .cartProductListHeader button.btn-block.btn--continue-checkout {
    margin: 8px 0;
}

.cartProductListHeader > div {
    padding: 0;
}

.cartProductListHeader a {
    line-height: 60px;
    display: inline-block;
    text-decoration: underline;
    text-transform: uppercase;
    color: #5A5A5A;
    font-size: 0.8em;
}

.cartProductListHeader {
    padding: 15px 0;
    border-top: 1px solid #ddd;
}

.cartProductList .bagID {
    line-height: 4.5em;
    font-size: 1.125em;
    margin-left: 1em;
}

.cartProductList .cartProductHeader {
    line-height: 3.143em;
}

.cartProductList .cartProductHeader, button.btn.cartProductPlusMinus {
    background-color: #f5f5f5;
}

.cartProductList .cartProductHeader > div {
    text-align: center;
    text-transform: uppercase;
    font-size: 0.8em;
    font-weight: bold;
}

.cartProductList .cartProductHeader > div.cartProductDetails {
    text-align: left;
    padding-left: 30px;
}

.cartProductList .cartProductHeader > div.cartProductSubtotal,
.cartProductList .cartProductRow .cartProductSubtotal {
    text-align: right;
    padding-right: 30px;
}

.cartProductList .cartProductRow {
    border-bottom: 1px solid #ddd;
    padding: 1.25em 0;
}

.cartProductList .cartProductDetails > * {
    float: left;
}

.cartProductList .cartProductDetailsInfo {
    display: inline-block;
    width: calc(100% - 110px);
    font-size: 0.933em;
    padding-left: 15px;
}

.cartProductList .cartProductDetailsInfo a {
    display: inline-block;
    text-decoration: none;
    color: #000;
}

.cartProductList .cartProductDetailsInfo a > * {
    display: block;
    margin-bottom: 7px;
}

.cartProductList .cartProductDetailsInfo a > strong {
    text-transform: uppercase;
}

.cartProductList .cartProductDetailsInfo > span {
    display: block;
    color: #aaa;
    margin-bottom: 8px;
}

.cartProductList .cartProductDetailsInfo > span.cartVariantValue {
    color: initial;
}

.cartProductList .cartProductDetailsInfo > span.cartProductDetailsInfoLinks {
    margin: 20px 0 10px;
}

.cartProductList .cartProductDetailsInfo > span.cartProductDetailsInfoLinks a {
    padding: 0 15px;
    text-decoration: underline;
    border-left: 1px solid #d7d7d7;
    float: left;
    text-transform: uppercase;
    color: #888;
}

.cartProductList .cartProductDetailsInfo > span.cartProductDetailsInfoLinks a:first-child {
    border-left: none;
    padding-left: 0;
}

.cartProductList .cartProductQuantityBlock {
    width: 7.5em;
    margin: auto;
    display: block;
    min-height: 40px;
}

.cartProductList .cartProductQuantityBlock > * {
    line-height: 2.5em;
    width: 2.5em;
    height: 2.5em;
    display: inline-block;
    text-align: center;
    padding: 0;
    margin: 0;
    border: 1px solid #d7d7d7;
    font-size: 0.933em;
    float: left;
    border-radius: 0;
}

.cartProductList .cartProductQuantityBlock > button {
    background-color: #f7f7f7;
    color: #aaa;
}

.cartProductList .cartProductQuantityBlock > button i {
    font-size: 0.8em;
}

.cartProductList .cartProductQuantityBlock > *:nth-child(2) {
    border-left: none;
    border-right: none;
}

.cartProductList .cartProductQuantityBlock input.cartProductQuantity[type='number'] {
    -moz-appearance: textfield;
    background-color: white;
}

.cartProductList .cartProductQuantityBlock input.cartProductQuantity::-webkit-outer-spin-button,
.cartProductList .cartProductQuantityBlock input.cartProductQuantity::-webkit-inner-spin-button {
    -webkit-appearance: none;
}

.cartPageOverlay {
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 7;
    background-color: rgba(255, 255, 255, 0.5);
}

.cartPageOverlay i {
    position: fixed;
    top: 50%;
    left: 50%;
    opacity: 0.8;
}

.cartProductMessage {
    text-align: center;
}

.cartProductMessage.cartProductOutOfStockMessage {
    color: #aaaaaa;
}

.cartProductMessage.cartProductLowStockMessage, .cartProductMessage.cartProductUnavailableMessage {
    color: #d9534f;
}

.cartProductList .cartProductRow .cartProductItemPrice,
.cartProductList .cartProductRow .cartProductSubtotal {
    font-size: 0.933em;
    line-height: 2.857em;
}

.cartProductList .cartProductRow .cartProductItemPrice {
    text-align: center;
}

.cartProductList .cartProductRow .cartProductDetailsImg {
    max-width: 100px;
}

.cartPromotionBlock h2 {
    font-size: 0.933em;
    text-transform: uppercase;
    font-weight: bold;
    line-height: 2.5em;
}

.cartPromotionBlock .promotionInputBlock {
    margin-bottom: 1em;
    width: 60%;
    display: inline-block;
}

.cartPromotionBlock .promotionInputBlock > * {
    float: left;
    border-radius: 0;
}

.cartPromotionBlock .promotionInputBlock input.promotionCode {
    font-size: 0.933em;
    line-height: 2.857em;
    width: 80%;
    padding: 0;
    padding-left: 10px;
    border: 1px solid #ddd;
    border-right: 0;
}

.cartPromotionBlock .promotionInputBlock button.promotionCodeSubmit {
    font-size: 0.8em;
    line-height: 3.333em;
    padding: 0;
    width: 20%;
    background-color: black;
    border: 1px solid black;
    color: white;
    text-transform: uppercase;
    font-weight: bold;
}

.cartPromotionBlock .promotionInputBlock button.promotionCodeSubmit::placeholder {
    color: #aaa;
}

.cartPromotionBlock .promotionInputBlock > .alert {
    width: 100%;
    margin-top: 10px;
    margin-bottom: 0;
    line-height: 18px;
    padding: 9px 10px;
    font-size: 0.933em;
    color: black;
    position: relative;
}

.cartPromotionBlock .promotionInputBlock > .alert span {
    width: calc(100% - 25px);
    display: inline-block;
}

.cartPromotionBlock .promotionInputBlock > .alert.alert-success {
    background-color: #eff5e7;
    border-color: #eff5e7;
}

.cartPromotionBlock .promotionInputBlock > .alert.alert-danger {
    background-color: #f5e7ef;
    border-color: #f5e7ef;
}

.cartPromotionBlock .promotionInputBlock .alert > .closeAlert {
    line-height: 18px;
    cursor: pointer;
    width: 15px;
    text-align: center;
    position: absolute;
    right: 10px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}

.deliveryOptionBlock {
    margin-top: 2.5em;
    display: inline-block;
    width: 100%;
    position: relative;
}

.deliveryOptionBlockSpinnerOverlay {
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background-color: rgba(0, 0, 0, 0.2);
    position: absolute;
    z-index: 2;
}

#deliveryOptionBlockSpinner {
    position: absolute;
    top: calc(50% - 25px);
    left: calc(50% - 25px);
    font-size: 50px;
    color: white;
}

.deliveryOptionBlock .deliveryOptionTab {
    width: 50%;
    display: inline-block;
    text-align: center;
    line-height: 3em;
    border: 1px solid #ddd;
    color: #aaa;
    float: left;
    z-index: 2;
    position: relative;
    cursor: pointer;
    font-size: 0.933em;
    text-transform: uppercase;
    font-weight: bold;
}

.deliveryOptionBlock .deliveryOptionTab.deliveryOptionTabCollect {
    border-left: none;
}

.deliveryOptionBlock .deliveryOptionTab.active {
    background-color: #f5f5f5;
    color: black;
    border-bottom: none;
}

.deliveryOptionBlock .deliveryOptionMain {
    width: 100%;
    background-color: #f5f5f5;
    float: left;
    padding: 20px 15px;
    border: 1px solid #ddd;
    z-index: 1;
    border-top: none;
    margin-top: -1px;
    font-size: 0.933em;
}


.deliveryOptionBlock .deliveryOptionMain .shippingRow {
    margin-bottom: 1em;
}

.deliveryOptionBlock .deliveryOptionMain .zipCodeRow {
    margin-bottom: 0.5em;
}

.deliveryOptionBlock .deliveryOptionMain .zipCodeRow input,
.deliveryOptionBlock .deliveryOptionMain select,
.deliveryOptionMainCollect input {
    border-radius: 0;
    line-height: 45px;
    height: 45px;
    padding: 0;
    padding-left: 0.5em;
    font-size: inherit;
    color: #000000;
}

#deliveryOptionsPostcode, .deliveryOptionMainCollect input {
    width: calc(100% - 45px);
    display: inline-block;
}

.deliveryOptionMainCollect input, #pac-input-pickup {
    padding-right: 30px;
}

#useMyLocationClickAndCollectLookup, #useMyLocationClickAndCollectPopupLookup {
    height: 45px;
    line-height: 45px;
    width: 30px;
    margin-left: -32px;
}

#deliveryOptionsPostcodeButton, .deliveryOptionMainCollect button#findAStoreSearchButton {
    width: 45px;
    float: right;
    height: 45px;
    padding: 0;
    border-radius: 0;
    background-color: black;
    border-color: black;
    color: white;
}

.totalsRow .deliveryOptionsValue {
    font-weight: bold;
}

.deliveryOptionsTitle i {
    font-size: 0.75em;
}

.deliveryOptionBlock .deliveryOptionMain hr {
    margin: 10px 0;
    border-top: 1px solid #ddd;
}

.deliveryOptionsTitle, .deliveryOptionsValue {
    line-height: 2.25em;
}

.deliveryOptionsValue {
    text-align: right;
}

.findAStoreSearchCol {
    margin: 15px 0;
}

.zipCodeRow .deliveryOptionsValue, .shippingRow .deliveryOptionsValue {
    margin-top: 2.25em;
}

/* Cart Page - Gift Wrap */

.showGiftWrapOptionsBlock,
.giftWrapDetailsBlock > div,
.giftWrapAppliedBlock > div {
    margin-top: 20px;
}

.showGiftWrapOptionsBlock, .giftWrapImageAndType {
    padding-left: 130px;
}

.showGiftWrapOptions, .showGiftWrapOptions:hover {
    font-size: 0.933em;
    color: black;
    text-decoration: none;
}

.showGiftWrapOptions span {
    text-decoration: underline;
}

.showGiftWrapOptions i {
    font-size: 12px;
}

.invalidMessage .giftWrapMessageLetterCount {
    color: #ff1010;
}

.invalidMessage .giftWrapSaveButton {
    cursor: default;
    opacity: 0.7;
    pointer-events: none;
}

/* CMS Components */

.cmsContainer {
    margin-top: 75px;
}

.cmsContainer:first-child {
    margin-top: 0;
}

.cmsContainer:last-child {
    margin-bottom: 75px;
}

.cmsContainer .row > .containerTitleSection > h2 {
    text-align: center;
    margin-bottom: 30px;
    margin-top: 30px;
    text-transform: uppercase;
    font-size: 1.4em;
}

.cmsContainer .row > .containerTitleSection > p {
    text-align: center;
    margin: 0 auto;
    margin-bottom: 30px;
    max-width: 500px;
    width: 80%;
}

.cmsContainer.removeMarginTop {
    margin-top: 0;
}

.cmsContainer.titlesLeftAligned .containerTitleSection {
    text-align: left;
}

.containerBorderTop {
    border-top: 1px solid #f2f2f2;
    padding-top: 75px;
}

.containerFullWidth,
.cmsBannerCarouselComponent {
    width: 100%;
}

.cmsBannerCarouselComponent {
    padding-left: 0;
    padding-right: 0;
}

.cmsBannerCarouselComponentItem {
    position: relative;
}


.containerFullWidth > .row .col-md-12 {
    padding-left: 0;
    padding-right: 0;
}

.containerNarrow {
    max-width: 1200px;
}

.containerExtraNarrow {
    max-width: 1000px;
}

.cmsBannerCarouselComponent .owl-nav {
    display: block !important;
}

.cmsBannerCarouselComponent .owl-theme .owl-nav [class*=owl-] {
    font-size: 30px;
    position: absolute;
    top: calc(50% - 25px);
    line-height: 50px;
    width: 30px;
    opacity: 0.7;
    -webkit-transition: opacity 0.3s ease;
    -moz-transition: opacity 0.3s ease;
    -o-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
}

.cmsBannerCarouselComponent .owl-theme .owl-nav [class*=owl-]:hover {
    opacity: 1;
}

.cmsBannerCarouselComponent .owl-nav .owl-prev,
.productImageGallery .owl-nav .owl-prev:hover {
    left: 5px;
    background-color: transparent !important;
    z-index: 2;
    cursor: pointer;
}

.cmsBannerCarouselComponent .owl-nav .owl-next,
.productImageGallery .owl-nav .owl-next:hover {
    right: 5px;
    background-color: transparent !important;
    z-index: 2;
    cursor: pointer;
}

.cmsBannerCarouselComponent .owl-dots {
    display: block;
    margin-top: -40px;
    position: absolute;
    z-index: 9;
    width: 100%;
}

.cmsBannerCarouselComponent .owl-dot span {
    display: inline-block !important;
    height: 10px !important;
    width: 10px !important;
    background-color: white !important;
    border: 1px solid #aaa;
    border-radius: 100px !important;
    margin: 0 3px !important;
}

.cmsBannerCarouselComponent .owl-dot.active span {
    background-color: #aaa !important;
    border-color: white !important;
}

.imageFill {
    width: 100%;
}

.containerTitleSection {
    min-height: 0px;
    text-align: center;
}

.blockComponentContainer {
    display: flex;
    flex-wrap: wrap;
    align-content: flex-start;
    width: 100%;
    clear: both;
}

.blockComponent {
    float: none;
}

.componentBlockText h3 {
    text-transform: uppercase;
    font-size: 1.2em;
    margin-left: auto;
    margin-right: auto;
}

.componentBlockText a.blockComponentHeaderLink {
    font-size: 1em;
    border: none;
    display: block;
    color: initial;
    padding: 0;
    transition: none;
    margin: 0;
    text-decoration: none
}

.componentBlockText a.blockComponentHeaderLink:hover {
    color: initial;
}

.componentBlockText span ~ a.blockComponentHeaderLink h3,
.componentBlockText span ~ h3{
    margin-top: 5px;
}

.componentBlockText p {
    margin-top: 15px;
    max-width: 350px;
    margin-left: auto;
    margin-right: auto;
}

.componentBlockText a {
    display: inline-block;
    margin: 15px;
    text-decoration: underline;
}

.productCarouselTextTitle {
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    line-height: 22px;
    height: 44px;
    overflow: hidden;
}

.bannerContent {
    position: absolute;
    width: 100%;
}

.bannerContentInner {
    display: inline-block;
    text-align: center;
}

.contentTop {
    top: 25%;
    transform: translateY(-50%);
}

.contentMiddle {
    top: 50%;
    transform: translateY(-50%);
}

.contentBottom {
    top: 70%;
    transform: translateY(-50%);
}

.contentLeft .bannerContentInner {
    float: left;
    margin-left: 10%;
}

.contentCenter {
    text-align: center;
}

.contentRight .bannerContentInner {
    float: right;
    margin-right: 10%;
}

a.bannerOuterLink {
    font-family: initial;
}

.bannerContentInner h1,
.bannerContentInner h2 {
    text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.5);
    font-size: 2.4em;
    text-transform: uppercase;
    line-height: normal !important;
    margin-bottom: 0px;
}

.bannerContent .bannerContentInner span ~ h1,
.bannerContent .bannerContentInner span ~ a h1,
.bannerContent .bannerContentInner span ~ h2,
.bannerContent .bannerContentInner span ~ a h2,
.containerTitleSection span ~ h2,
.contentCarouselComponent .containerTitleSection span ~ h2,
.uspBar span ~ h3,
.containerTitleSection span ~ h1, .containerTitleSection span ~ h2{
    margin-top: 5px;
}

.containerFullWidth .bannerContentInner h1,
.containerFullWidth .bannerContentInner h2 {
    font-size: 3.6em;
}

.bannerContentInner p {
    text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.5);
    margin-bottom: 20px;
    font-size: 1.3em;
}

.bannerContentInner span.bannerLinkButton {
    padding: 10px 30px;
    display: inline-block;
    color: inherit;
}


.uspBarMobile {
    display: none;
}

.uspBar {
    text-align: center;
    border-bottom: 1px solid #f2f2f2;
    margin-bottom: 30px;
    margin-top: 0;
    padding-top: 15px;
    padding-bottom: 15px;
}

.uspBar h3 {
    font-size: 1.2em;
    margin-bottom: 3px;
    line-height: normal;
}

.uspBar p {
    font-size: 0.9em;
    color: #aaa;
}

/* contentCarouselComponent */

.contentCarousel,
.productCarousel.owl-carousel {
    margin: 0 auto;
    padding: 0 30px;
    margin-bottom: 30px;
}

.contentCarousel.owl-carousel .contentCarouselBlock,
.productCarousel.owl-carousel .productCarouselBlock {
    padding: 15px;
}

.productCarousel.owl-carousel .productCarouselBlock {
    position: relative;
}

.contentCarousel.owl-carousel .contentCarouselBlock a h4 {
    padding-bottom: 10px;
    padding-top: 10px;
    text-align: center;
    font-size: 1em;
    margin: 0;
}

.contentCarousel.owl-carousel .contentCarouselBlock a,
.productCarousel.owl-carousel .productCarouselBlock a {
    display: block;
}

.contentCarousel.owl-carousel .contentCarouselBlock a {
    background-color: white;
    -webkit-box-shadow: 0px 3px 3px 0px rgba(204, 204, 204, 1);
    -moz-box-shadow: 0px 3px 3px 0px rgba(204, 204, 204, 1);
    box-shadow: 0px 3px 3px 0px rgba(204, 204, 204, 1);
}

.contentCarousel.owl-carousel .owl-nav,
.contentCarousel.owl-carousel .owl-nav.disabled,
.productCarousel.owl-carousel .owl-nav,
.productCarousel.owl-carousel .owl-nav.disabled {
    display: block;
}

.contentCarousel.owl-carousel .owl-nav button,
.productCarousel.owl-carousel .owl-nav button {
    font-size: 0;
    position: absolute;
    top: calc(50% - 15px);
    height: 30px;
    width: 30px;
    opacity: 0.3;
    -webkit-transition: opacity 0.3s ease;
    -moz-transition: opacity 0.3s ease;
    -o-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
}

.contentCarousel.owl-carousel .owl-nav button span,
.productCarousel.owl-carousel .owl-nav button span {
    display: none;
}


.contentCarousel.owl-carousel .owl-nav button:hover,
.productCarousel.owl-carousel .owl-nav button:hover {
    opacity: 0.7;
}

.contentCarousel.owl-carousel .owl-nav .owl-prev, .productCarousel.owl-carousel .owl-nav .owl-prev {
    left: -30px;
    background: url(../images/arrow-left.png);
    cursor: pointer;
}

.contentCarousel.owl-carousel .owl-nav .owl-next, .productCarousel.owl-carousel .owl-nav .owl-next {
    right: -30px;
    background: url(../images/arrow-right.png);
    cursor: pointer;
}

.containerFullWidth .contentCarousel.owl-carousel, .containerFullWidth .productCarousel.owl-carousel {
    padding: 0 35px;
}

.containerFullWidth .contentCarousel.owl-carousel .owl-nav .owl-prev, .containerFullWidth .productCarousel.owl-carousel .owl-nav .owl-prev {
    left: 0;
}

.containerFullWidth .contentCarousel.owl-carousel .owl-nav .owl-next, .containerFullWidth .productCarousel.owl-carousel .owl-nav .owl-next {
    right: 0;
}

.invertArrowColour .contentCarousel.owl-carousel .owl-nav .owl-prev,
.invertArrowColour .productCarousel.owl-carousel .owl-nav .owl-prev {
    left: -30px;
    background: url(../images/arrow-left-invert.png);
    cursor: pointer;
}

.invertArrowColour .contentCarousel.owl-carousel .owl-nav .owl-next,
.invertArrowColour .productCarousel.owl-carousel .owl-nav .owl-next {
    right: -30px;
    background: url(../images/arrow-right-invert.png);
    cursor: pointer;
}

.contentCarouselLink,
.productCarouselLink {
    text-align: center;
    margin-bottom: 30px;
    clear: both;
    width: 100%;
}

.contentCarouselLink a,
.productCarouselLink a {
    text-decoration: underline;
}

h4.componentBlockText, .componentBlockText {
    font-size: 1em;
    background-color: white;
    text-align: center;
    padding-right: 40px;
    padding-bottom: 0;
    padding-left: 20px;
    padding-right: 20px;
    margin: 0;
}

.componentBlockPrice {
    display: inline-block;
    width: 100%;
    text-align: center;
    margin-top: 10px;
}

/* Information Pages */

.informationPage {
    padding-top: 30px;
    padding-bottom: 30px;
}

.informationPage .informationPageContent h1 {
    font-size: 2em;
    margin-bottom: 30px;
}

.informationPage .informationPageContent h2 {
    font-size: 1.375em;
    margin-bottom: 30px;
}

.informationPage .informationPageContent p {
    margin-bottom: 30px;
    font-size: 0.875em;
    line-height: 1.75em;
}

.informationPage .informationPageContent img {
    margin-bottom: 30px;
}

@media (min-width: 992px) {

    #findAStoreSearchBox {
        position: absolute;
        z-index: 2;
        width: 400px;
        background-color: white;
        text-align: center;
        padding: 0;
        top: 50px;
        -webkit-box-shadow: 0px 0px 10px 0px rgba(136, 136, 136, 1);
        -moz-box-shadow: 0px 0px 10px 0px rgba(136, 136, 136, 1);
        box-shadow: 0px 0px 10px 0px rgba(136, 136, 136, 1);
    }

}

@media only screen and (min-width: 992px) {
    .wishlistMobile {
        display: none;
    }
}

@media (max-width: 992px) {
    .wishlistMobile {
        position: fixed;
        width: 100%;
        height: 100px;
        background-color: #F5F5F5;
        bottom: 0px;
        left: 0px;
        z-index: 8;
        display: none;
    }
}

.findAStoreSearchBoxSearch {
    padding: 20px;
}

.findAStoreSearchBoxResult {
    padding: 20px 40px 20px 20px;
    text-align: left;
    position: relative;
    border-top: 1px solid #ddd;
    background-color: #f7f7f7;
}

.findAStoreSearchBoxResult.closed {
    background-color: inherit;
}

.findAStoreSearchBoxResult.findAStoreSearchBoxResultHighlight {
    background-color: #f7f7f7;
}

.findAStoreSearchBoxResult h2 {
    display: inline-block;
    font-size: 1.15em;
    font-weight: bold;
    margin-right: 5px;
    margin-bottom: 0.75em;
}

.findAStoreSearchBoxResult hr {
    border-color: #ccc;
}

.findAStoreSearchBoxResult .storeFinderFormattedDistance {
    font-size: 1.15em;
    margin-bottom: 0.75em;
}

.findAStoreSearchBoxResult .storeFinderSpan,
.findAStoreSearchBoxResult.closed .storeFinderSpan.storeFinderOpeningHours {
    display: table;
    line-height: 1.5em;
    clear: both;
}

.findAStoreSearchBoxResult .storeFinderOpeningHour {
    float: left;
    width: 50%;
    padding-right: 8%;
}

.findAStoreSearchBoxResult .storeFinderOpeningHourTime {
    float: right;
}

.findAStoreSearchBoxResult .storeFinderOpeningHourToday {
    font-weight: bold;
}

.findAStoreSearchBoxResult .storeFinderOurOpeningHours {
    margin-bottom: 20px;
}

.findAStoreSearchBoxResult .storeFinderMoreDetails > div {
    overflow: auto;
}

.findAStoreSearchBoxResult .storeFinderSpan a {
    text-decoration: underline;
}

.findAStoreSearchBoxResult .storeFinderSpan a:first-child {
    padding-right: 10px;
    border-right: 1px solid #5A5A5A;
}

.findAStoreSearchBoxResult .storeFinderSpan a:last-child {
    padding-left: 10px;
}

.findAStoreSearchBoxResult i.openClose {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 20px;
    line-height: 20px;
    text-align: center;
    font-size: 1.25em;
    cursor: pointer;
}

.findAStoreSearchBoxResult .openClose.openArrow {
    display: none;
}

.findAStoreSearchBoxResult .openClose.closeArrow {
    display: block;
}

.findAStoreSearchBoxResult.closed .openClose.closeArrow {
    display: none;
}

.findAStoreSearchBoxResult.closed .openClose.openArrow {
    display: block;
}

.findAStoreSearchBoxResult .storeFinderMoreDetails,
.findAStoreSearchBoxResult.closed .storeFinderOpeningHours {
    display: block;
}

.findAStoreSearchBoxResult.closed .storeFinderMoreDetails,
.findAStoreSearchBoxResult .storeFinderOpeningHours {
    display: none;
}

.findAStoreSearchBoxResults.hidden-xs.hidden-sm {
    max-height: 450px;
    overflow: auto;
}

.findAStoreSearchBoxResults {
    position: relative;
}

/* Sign in / Register */
.signInRegister > h1,
.signInRegister > p,
.forgottenPassword > h2,
.forgottenPasswordSuccess > h2 {
    text-align: center;
}

.signInRegister > h1,
.forgottenPassword > h2,
.forgottenPasswordSuccess > h2 {
    font-size: 1.33em;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    margin-bottom: 20px;
}

.signInRegister > h1 {
    margin: 70px auto 30px;
}

.signInRegister > p {
    margin: 0 0 50px;
    font-size: 0.933em;
}

.signInRegister > p > a {
    font-weight: bold;
}

.signInRegister button.btn,
#forgottenPwdForm button.btn,
.termsAndConditionsPopup button.btn {
    border-radius: 0;
    height: 40px;
    font-size: 0.8em;
    font-weight: bold;
    background-color: #f5f5f5;
    border-color: #f5f5f5;
    text-transform: uppercase;
}

.signInRegister button.btn.btn-primary,
#forgottenPwdForm button.btn.btn-primary,
.forgottenPasswordSuccess button.btn.btn-primary,
.termsAndConditionsPopup button.btn.btn-primary {
    background-color: #a6182e;
    border-color: #a6182e;
}

.forgottenPasswordSuccess .description {
    text-align: center;
    margin: 25px auto;
}

button#forgottenPasswordSuccessClose {
    width: 150px;
    margin: auto;
    line-height: 30px;
}

.loginForm,
.registerForm,
.loginToRegisterBlock,
.registerToLoginBlock {
    padding: 25px;
    border: 1px solid #ddd;
    margin-bottom: 35px
}

.loginForm h2,
.registerForm h2,
.loginToRegisterBlock h2,
.registerToLoginBlock h2 {
    font-size: 0.933em;
    margin-bottom: 20px;
    margin-top: 0;
    text-transform: uppercase;
    font-weight: bold;
}

.loginForm .control-label,
.registerForm .control-label,
#forgottenPwdForm .control-label {
    font-weight: normal;
    color: #747474;
    font-size: 0.933em;
}

.loginForm .form-control,
.registerForm .form-control {
    border-radius: 0;
    border-color: #ddd;
    line-height: 44px;
}

.signInRegister .forgotten-password {
    text-align: center;
    margin: 20px auto 0;
    text-decoration: underline;
}

form#registerForm .help-block {
    font-size: 0.933em;
    color: black;
}

.registerForm .control-label.registerTermsAndConditions {
    color: black;
    line-height: 22px;
}

.registerForm .control-label.registerTermsAndConditions a {
    color: #5A5A5A;
}

/* My Account */

.accountHeaderBlock {
    margin: 40px auto 25px;
}

.accountHeaderBlock h1 {
    font-size: 1.333em;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    text-align: center;
    margin-bottom: 20px;
}

.accountHeaderBlock span {
    font-size: 0.933em;
}

.accountMenu {
    width: 100%;
}

.accountMenu a {
    display: block;
    text-decoration: none;
    line-height: 3em;
    background-color: #f5f5f5;
    border-top: 1px solid #eee;
}

.accountMenu a:first-child {
    border: none;
}

.accountMenu a i {
    width: 20%;
    text-align: center;
    color: black;
    font-size: 1.25em;
    line-height: 2.4em;
}

.accountMenu.overviewActive .accountOverviewLink,
.accountMenu.overviewActive .accountOverviewLink i,
.accountMenu.ordersActive .accountOrdersLink,
.accountMenu.ordersActive .accountOrdersLink i,
.accountMenu.valuationsActive .accountValuationsLink,
.accountMenu.valuationsActive .accountValuationsLink i,
.accountMenu.wishlistActive .accountWishlistLink,
.accountMenu.wishlistActive .accountWishlistLink i,
.accountMenu.profileActive .accountProfileLink,
.accountMenu.profileActive .accountProfileLink i,
.accountMenu.passwordActive .accountUpdatePasswordLink,
.accountMenu.passwordActive .accountUpdatePasswordLink i,
.accountMenu.addressActive .accountAddressBookLink,
.accountMenu.addressActive .accountAddressBookLink i,
.accountMenu.contactActive .accountContactLink,
.accountMenu.contactActive .accountContactLink i {
    color: white !important;
    background-color: black;
}

.accountMainSectionOuter {
    border-top: 1px solid #ddd;
    margin-bottom: 25px;
}

.accountMainSectionHeader {
    padding-bottom: 10px;
    margin-bottom: 20px;
}

.accountMainSectionHeader h2 {
    color: black;
    line-height: 30px;
    max-width: 50%;
    display: inline-block;
    font-size: 0.933em;
    text-transform: uppercase;
}

.accountMainSectionHeader i.rightIcon {
    line-height: 30px;
    float: right;
    margin-top: 20px;
}


.accountMainSectionInner .row {
    margin-bottom: 40px;
}

.accountMainSectionInner:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border: none;
}

.accountMainSectionInner .accountLabel,
.accountMainSectionInner .control-label {
    display: block;
    color: #aaa;
    line-height: 1.5em;
    clear: both;
    font-size: 0.933em;
    margin-bottom: 5px;
    font-weight: normal;
}

.accountMainSectionInner .accountValue {
    display: block;
    line-height: 1.5em;
    clear: both;
    font-size: 0.933em;
}

.accountOrderDetailBlock {
    display: inline-block;
}

.accountOrderDetailBlock .accountWishlistDetailBlock .accountValue {
    margin-bottom: 3px;
}

.accountOrderDetailBlock .accountWishlistDetailBlock .accountValue.accountOrderCode {
    color: #aaa;
}

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

.accountMainSectionInner .accountValue > strong {
    font-weight: bold;
    text-transform: uppercase;
}

.accountMainSectionInner .accountValue.accountOrderPrice {
    margin-top: 20px;
}

.accountReturnDetailsMobile {
    width: 100%;
    display: none;
    margin-bottom: 100px;
}

.accountMainSectionInner .accountValue.accountValueFullWidth {
    margin-bottom: 20px;
}

.accountMainSectionInner .accountMainOrderImage {
    width: 100%;
}

.accountMainSectionInner .accountMainWishlistImage {
    width: 100%;
}

.accountMainSectionInner > .row {
    position: relative;
}

.accountMainSectionInner .accountMainAction {
    position: initial;
}

.accountMainSectionInner .accountMainAction > a {
    position: absolute;
    line-height: 40px;
    text-align: center;
    color: white;
    text-decoration: none;
    top: 50%;
    margin-top: -20px;
    right: 0;
}

.accountMainSectionInner .accountMainAction .accountMainActionSubmit {
    background-color: #a6182e;
    font-weight: bold;
    font-size: 0.8em;
    text-transform: uppercase;
    line-height: 44px;
    padding: 0 25px;
    color: white;
}

.accountMainSectionInner .accountMainSectionWishlist.accountMainAction > a:first-child {
    top: calc(50% - 30px);
}

.accountMainSectionInner .accountMainSectionWishlist.accountMainAction > a:last-child {
    top: calc(50% + 30px);
}

.accountMainSectionInner .accountMainAction > a.accountMainActionRemove {
    background-color: #ccc;
    color: #4a3242;
}

.accountInputField {
    display: block;
    clear: both;
    margin-top: 3px;
    margin-bottom: 10px;
    line-height: 38px;
    height: 42px;
    border: 1px solid #ddd;
    float: none;
    font-size: 0.933em;
}

accountInputField-hidden {
    display: none;
}

select.accountInputField {
    height: 44px;
}

.accountProfileActions {
    padding: 0;
    margin-top: 15px;
}

.accountProfileActions > a {
    min-width: 150px;
}

.accountProfileActions .accountMainProfileSubmit {
    line-height: 35px;
    text-align: center;
    color: white;
    text-decoration: none;
    background-color: #4a3242;
    display: inline-block;
    padding: 0 20px;
}

.accountProfileActions .accountMainDeleteCancel {
    line-height: 35px;
    text-align: center;
    color: white;
    text-decoration: none;
    color: #4a3242;
    display: inline-block;
    padding: 0 20px;
    background-color: #ccc;
    margin-left: 15px;
}

.accountProfileActions .accountMainProfileDelete {
    display: inline-block;
    float: right;
    padding: 0 15px;
    text-decoration: underline;
}

.accountProfileActions .accountMainProfileDelete > i {
    margin-left: 6px;
}

.deleteAccountConfirmationPopup {
    position: fixed;
    top: 250px;
    left: 50%;
    width: 800px;
    background-color: white;
    margin-left: -400px;
    z-index: 21;
    padding: 25px;
}

.deleteAccountConfirmationPopupBackground {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 20;
    cursor: pointer;
}

.deleteAccountConfirmationPopup h2 {
    color: black;
    font-size: 1.5em;
    text-align: center;
    margin-bottom: 20px;
}

.deleteAccountConfirmationPopup span.closePopup {
    position: absolute;
    right: 0;
    top: 0;
    line-height: 30px;
    width: 30px;
    text-align: center;
    cursor: pointer;
}

.accountPasswordChangeBlock .accountValue {
    margin-bottom: 5px;
}

.accountPasswordChangeBlock #updatePasswordForm {
    margin-top: 15px;
}

.accountPasswordChangeBlock #updatePasswordForm .accountLabel {
    margin-top: 5px;
    display: inline-block;
    width: 100%;
}

.accountArea .btn.btn-primary, .accountAddNewAddress, .addressFormDeleteButton {
    width: auto;
    display: inline-block;
    clear: both;
    line-height: 3.667em;
    background-color: #a6182e;
    border: 0;
    color: white;
    border-radius: 0;
    margin-top: 25px;
    font-size: 0.8em;
    text-transform: uppercase;
    font-weight: bold;
    padding: 0 25px;
}

#accountAddressForm .addressFormDeleteButton, #accountOrderButtonOptions > a {
    background-color: #f5f5f5;
    color: black;
    margin-left: 20px;
    vertical-align: middle;
}

#accountAddressForm .addressFormDeleteButton:hover, #accountOrderButtonOptions > a:hover {
    text-decoration: none;
}

.accountAddNewAddress:hover {
    text-decoration: none;
    color: white;
}

.orderShippingDetails span, .accountAddressListMain .accountValue {
    margin-bottom: 5px;
}

.accountValue-defaultAddress {
    color: #aaa;
}

.accountOrderTotalsRow > div {
    width: 50%;
    display: inline-block;
}

.accountOrderTotalsRow .accountOrderTotalsValue {
    float: right;
    text-align: right;
}

.accountOrderTotalsRow {
    margin-bottom: 10px;
}

.accountOrderTotalsRow:last-child .accountOrderTotalsValue {
    font-weight: bold;
}

.accountOrderListHeader:before {
    content: "";
    border-top: 2px solid #ddd;
    width: calc(100% - 15px);
    margin-left: 15px;
    position: absolute;
    top: -20px;
}


.accountMainSectionInner label.add-address-left-label {
    line-height: 26px;
    padding-left: 23px;
}

.accountMobileOverview {
    margin-bottom: 20px;
}

.accountVerified {
    text-align: center;
    margin: 40px 0;
    display: inline-block;
    width: 100%;
}

.accountVerified h1 {
    text-transform: uppercase;
    font-size: 1.5em;
    letter-spacing: 0.1em;
}

.accountVerified .accountMainSectionInner .accountMainAction .accountMainActionSubmit {
    text-decoration: none;
    display: inline-block;
    margin: auto 10px;
}

.accountMainActionVerified {
    margin-top: 25px;
}

.addressListActions > a {
    font-size: 0.933em;
    display: block;
    margin-bottom: 10px;
    text-align: right;
}

.addressListActions > a:hover {
    text-decoration: none;
}

.addressListActions > a > span {
    text-decoration: underline;
}

.has-error .accountInputField, #updatePasswordForm .has-error, #guestRegisterForm .has-error {
    border-color: #d9534f !important;
}

#accountAddressForm .help-block, #updatePasswordForm .error-block {
    font-size: 0.933em;
    color: #d9534f;
}

#returnExpiredOrderPopupBackground, #cancelOrderPopupBackground {
    position: fixed;
    top: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.7);
    width: 100%;
    height: 100%;
    z-index: 9;
    overflow-y: auto;
}

#returnExpiredOrderPopup, #cancelOrderPopup {
    position: relative;
    background-color: white;
    width: 1400px;
    max-width: 100%;
    margin: 200px auto 0;
    padding: 40px 30px;
}

.returnExpiredOrderPopupClose, .cancelOrderPopupClose {
    position: absolute;
    top: 5px;
    right: 10px;
    font-size: 20px;
    padding: 5px;
    cursor: pointer;
}

#returnExpiredOrderPopup .returnExpiredOrderPopupText, #cancelOrderPopup .cancelOrderPopupText {
    width: 100%;
    text-align: center;
    margin-bottom: 25px;
}

/* Checkout Styles */

/* Checkout Login */

.checkoutLoginForm {
    padding: 25px;
    border: 1px solid #ddd;
    margin-bottom: 35px;
}

.checkoutLoginForm input {
    padding-left: 15px;
}

.checkoutLoginForm input::placeholder {
    color: #aaa;
}

.checkoutLoginForm button[type=submit] {
    line-height: 3.667em;
    width: 100%;
    background-color: #a7192f;
    border: 0;
    color: white;
    border-radius: 0;
    margin: 1.5em 0;
    font-size: 0.8em;
    text-transform: uppercase;
    padding: 0;
    font-weight: bold;
}

.checkoutLoginForm button.btn-primary[disabled]:hover, .checkoutLoginForm button.btn-primary:active {
    background-color: #a7192f;
    border-color: #a7192f;
}

.doYouHaveAPasswordBlock h2 {
    font-family: 'Nunito Sans', sans-serif;
    font-size: 0.933em;
    font-weight: bold;
    text-transform: uppercase;
    margin-top: 0;
}

.checkoutLoginForm .form-group {
    margin-bottom: 0;
}

.doYouHaveAPasswordBlockOption {
    position: relative;
    font-size: 0.933em;
    line-height: 1.5em;
    padding: 0.5em 0 0.5em 35px;
    cursor: pointer;
}

.doYouHaveAPasswordBlock {
    margin-bottom: 15px;
}

.doYouHaveAPasswordBlockOption:before {
    content: "";
    width: 18px;
    height: 18px;
    border: 1px solid #ddd;
    position: absolute;
    left: 6px;
    top: 8px;
    border-radius: 9px;
    z-index: 1;
}

form#loginForm .doYouHaveAPasswordBlockOption.doYouHaveAPasswordBlockOption-user:after,
form#guestForm .doYouHaveAPasswordBlockOption.doYouHaveAPasswordBlockOption-guest:after {
    content: "";
    width: 8px;
    height: 8px;
    background-color: black;
    position: absolute;
    left: 11px;
    top: 13px;
    border-radius: 8px;
    z-index: 2;
}


.forgotten-password {
    text-align: left;
    font-size: 0.933em;
    color: #5A5A5A;
    margin: 0 auto 15px;
}

.forgottenPassword .description,
.forgottenPasswordSuccess .description {
    font-size: 0.933em;
}

#signupRecaptcha {
    margin-left: auto;
    margin-right: auto;
    height: 78px;
    width: 304px;
    margin-bottom: 20px;
}

.passwordResetDescription {
    text-align: center;
    margin-top: 20px;
}

/* Checkout Address Page */

.header.checkoutHeader img {
    position: absolute;
    top: 50%;
}

.header.checkoutHeader a {
    float: left;
    line-height: 100px;
}

.header.checkoutHeader .col-md-4 {
    height: 100px;
}

.header.checkoutHeader .checkoutHeaderLogo {
    width: 200px;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
}

.header.checkoutHeader .checkoutHeaderNortonSeal {
    width: 95px;
    right: 50px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -o-transform: translateY(-50%);
}

.footer.checkoutFooter {
    height: 156px;
    padding: 0;
}

.footer.checkoutFooter .checkoutFooterRow {
    height: 70px;
    line-height: 70px;
}

.footer.checkoutFooter .checkoutFooterRow a {
    margin-right: 15px;
}

.footer.checkoutFooter .checkoutFooterRow span {
    float: right;
}

.checkoutHeaderContainer h1, .checkoutOrderConfirmation h1 {
    text-align: center;
    font-size: 1.333em;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    margin: 40px auto 35px;
}

.checkoutHeaderContainer h2, .checkoutOrderConfirmation h2 {
    text-align: center;
    font-size: 0.933em;
    margin-bottom: 55px;
    line-height: 24px;
}

.checkoutHeaderContainer h2 a {
    color: black;
    font-weight: bold;
}

.checkoutHeaderContainer h2 a:hover {
    text-decoration: none;
}

.checkoutProgress {
    width: 100%;
    text-align: center;
    border-bottom: 1px solid #ddd;
    margin-bottom: 42px;
}

.checkoutStep {
    display: inline-block;
    width: 32.5%;
    max-width: 214px;
    text-transform: uppercase;
    font-size: 0.8em;
    color: #aaa;
    line-height: 1em;
}

.checkoutStep.active {
    color: black;
}

.checkoutStep.active:after {
    content: "";
    display: block;
    width: 100%;
    border-bottom: 3px solid black;
    margin-top: 12px;
}

.checkoutCartSummaryMobile {
    display: none;
}

.orderConfirmationOrderSummary .checkoutCartSummaryMobile {
    margin-top: 20px;
}


#checkoutPopupBackground {
    position: fixed;
    top: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.7);
    width: 100%;
    height: 100%;
    z-index: 11;
    overflow-y: auto;
}

.addressVerificationPopup, #pickUpFromStorePopup, .addressPickerPopup, #cancelOrderPopup {
    position: relative;
    background-color: white;
    width: 1400px;
    max-width: 100%;
    margin: 200px auto 0;
    padding: 40px 30px;
}

#pickUpFromStorePopup {
    margin-top: 50px;
}

.checkoutPopupClose {
    position: absolute;
    top: 5px;
    right: 10px;
    font-size: 20px;
    padding: 5px;
    cursor: pointer;
}

.pickUpPopupInner {
    display: inline-block;
    width: 100%;
}

.pickUpPopupInnerHalf {
    width: 50%;
    float: left;
    padding: 15px;
}

.noStoresFound {
    width: 100%;
    text-align: center;
}

#pickUpStoreMap {
    width: 100%;
    height: 650px;
}

.shippingPickUpSwitcher {
    display: inline-block;
    width: 100%;
}

.shippingPickUpSwitcherOption {
    color: #aaa;
    line-height: 3.143em;
    width: 50%;
    display: inline-block;
    border: 1px solid #ddd;
    background-color: white;
    float: left;
    text-align: center;
    font-size: 0.933em;
    cursor: pointer;
    text-transform: uppercase;
}

.shippingPickUpSwitcherOption:first-child {
    border-right: none;
}

.shippingPickUpSwitcherOption.active {
    color: black;
    background-color: #f5f5f5;
    font-weight: bold;
}

.shippingPickUpSwitcherOption-disabled {
    cursor: not-allowed;
}

.shippingPickUpBlock h3, .checkoutOrderConfirmation h3 {
    font-size: 0.9333em;
    text-transform: uppercase;
    font-weight: bold;
    display: inline-block;
    margin: 30px 0;
}


.shippingPickUpBlock .requiredNotice {
    float: right;
    margin: 30px 0;
    font-size: 0.8em;
}

.shippingPickUpBlock form {
    display: inline-block;
    width: 100%;
}

.checkoutFormInput {
    font-size: 0.9333em;
    border: 1px solid #ddd;
    margin-bottom: 20px;
    line-height: 42px;
    height: 44px;
    padding: 0 5px;
    color: black;
    width: 100%;
}

.checkoutFormInput::placeholder {
    color: #aaa;
}

.checkoutFormInputBlock-HalfWidth {
    width: 49%;
}

.checkoutFormInputBlock-HalfWidthLeft {
    float: left;
    clear: both;
}

.checkoutFormInputBlock-HalfWidthRight {
    float: right;
}

.checkoutFormInputBlock-FullWidth {
    width: 100%;
    clear: both;
    float: left;
}

.checkoutFormInputBlock {
    position: relative;
}

.checkoutFormInputBlock.errorBlock .checkoutFormInput {
    margin-bottom: 40px;
    border-color: #d9534f;
}

.checkoutFormInputBlock.errorBlock .checkoutFormInputBlockError {
    position: absolute;
    bottom: 18px;
    left: 2px;
    display: block !important;
    font-size: 0.933em;
    color: #d9534f;
}

.checkoutFormInputBlock.errorBlock.errorBlockOneOf .checkoutFormInput {
    margin-bottom: 5px;
}

.checkoutFormInput-oneOfRequiredErrorBlock {
    float: left;
    width: 100%;
    font-size: 0.933em;
    color: #d9534f;
    margin-bottom: 10px;
}

.shippingPickUpBlock input::placeholder,
.shippingPickUpBlock input::-webkit-input-placeholder
.shippingPickUpBlock input:-ms-input-placeholder,
.shippingPickUpBlock input::-ms-input-placeholder,
.shippingPickUpBlock input:-moz-placeholder,
.shippingPickUpBlock input::-moz-placeholder {
    color: #aaa;
}

select.placeholder {
    color: #aaa;
}

.shippingPickUpBlock input[type=checkbox], .orderConfirmationCreateAccountForm input[type=checkbox] {
    clear: both;
    float: left;
    height: 18px;
    width: 18px;
    margin: 0;
    background-color: white;
}

#accountAddressForm input[type=checkbox] {
    height: 18px;
    width: 18px;
    margin-left: -23px;
}


span.checkoutFormCheckboxLabel {
    float: left;
    margin-left: 5px;
    font-size: 0.933em;
    line-height: 20px;
}

.orderConfirmationCreateAccountForm form {
    position: relative;
    display: inline-block;
    width: 100%;
}

.shippingPickUpBlock form button, .orderConfirmationCreateAccountForm form button, .orderConfirmationAction, .csDiscountFormAction {
    float: left;
    clear: both;
    width: 100%;
    margin: 30px auto 90px;
    padding: 0;
    line-height: 44px;
    border: none;
    background-color: #a6182e;
    color: white;
    text-transform: uppercase;
    font-size: 0.8em;
    font-weight: bold;
    border-radius: 2px;
}

.orderConfirmationCreateAccountForm form button, .orderConfirmationAction, .csDiscountFormAction {
    margin: 30px auto 0;
}

#orderConfirmationCreateAccountFormSpinnerBackground {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background-color: rgba(255, 255, 255, 0.3);
    z-index: 2;
}

#orderConfirmationCreateAccountFormSpinner {
    position: absolute;
    top: calc(50% - 25px);
    left: calc(50% - 25px);
    font-size: 50px;
    color: #aaa;
}

.orderConfirmationAction, .csDiscountFormAction  {
    text-align: center;
}

.orderConfirmationAction:hover, .csDiscountFormAction:hover {
    color: white;
    text-decoration: none;
}

.orderConfirmationActionSecondary {
    background-color: black;
}

.orderConfirmationCreateAccount, .orderConfirmationCreateAccountComplete {
    margin-bottom: 30px;
}

select.isoCode {
    display: none;
}

.editAddress {
    float: right;
    font-size: 0.8em;
    color: #5A5A5A;
    text-transform: uppercase;
    margin: 30px 0;
    line-height: 1em;
    cursor: pointer;
    text-decoration: underline;
}

.viewAddressBookContainer {
    display: inline-block;
    margin-left: 3px;
}

.viewAddressBook {
    display: inline-block;
    font-size: 0.8em;
    color: #5A5A5A;
    text-transform: uppercase;
    cursor: pointer;
    text-decoration: underline;
    line-height: 1em;
    margin: 30px 0;
    vertical-align: middle;
    padding-bottom: 3px;
}


.addressSummaryRow {
    font-size: 0.933em;
    line-height: 1.714em;
    text-overflow: ellipsis;
    overflow: hidden;
}

.shippingPickUpBlock-ShippingSummary, .shippingPickUpBlock-BillingSummary, .shippingPickUpBlock-store {
    padding-bottom: 30px;
    border-bottom: 1px solid #ddd;
}

.shippingPickUpBlock-confirmEmail[data-is-guest-account*="false"] {
    display: none;
}

.asmWESDetailsBlock {
    padding-bottom: 30px;
    border-bottom: 1px solid #ddd;
}


.addressVerificationPopup h2, .addressPickerPopup h2, #cancelOrderPopup h2 {
    margin: 0;
    font-size: 1.333em;
    text-transform: uppercase;
    letter-spacing: 0.13em;
    text-align: center;
    margin-bottom: 30px;
}

.addressVerificationPopup p, .addressPickerPopup p {
    margin: 30px auto 50px;
    width: 100%;
    text-align: center;
    font-size: 0.933em;
}

.addressPickerPopupBlock {
    width: calc(50% - 17px);
    display: inline-block;
    border: 1px solid #ddd;
    padding: 20px;
    position: relative;
    margin-bottom: 15px;
}

.addressVerificationPopupBlock {
    width: 100%;
    display: inline-block;
    border: 1px solid #ddd;
}

.addressPickerPopupBlock:nth-child(2n-1) {
    margin-right: 29px;
}

.addressPickerPopupBlock div[class*="Action"] {
    cursor: pointer;
}

.addressPickerPopupBlock .addressPickerPopupDefaultBlock .addressPickerPopupSetDefaultAction {
    display: inline-block;
}

.addressPickerPopupBlock .addressPickerPopupDefaultBlock span {
    display: none;
}

.addressPickerPopupBlock .addressPickerPopupDefaultBlock.isDefault .addressPickerPopupSetDefaultAction {
    display: none;
}

.addressPickerPopupBlock .addressPickerPopupDefaultBlock.isDefault span {
    display: inline-block;
}

.addressPickerPopupBlock .addressPickerPopupRemoveAction {
    position: absolute;
    top: 20px;
    right: 20px;
    text-transform: uppercase;
    color: #5A5A5A;
    text-decoration: underline;
    font-size: 0.8em;
}

.addressPickerPopupBlock .addressPickerPopupRemoveAction.isDefault {
    display: none;
}

.addressPickerPopupBlock .addressPickerPopupEditAction,
.addressPickerPopupBlock .addressPickerPopupDefaultBlock {
    width: 50%;
    display: inline-block;
    font-size: 0.8em;
    line-height: 60px;
    color: #5A5A5A;
    text-transform: uppercase;
}

.addressPickerPopupBlock .addressPickerPopupDefaultBlock {
    text-align: right;
    float: right;
}


.addressPickerPopupBlock .addressPickerPopupDefaultBlock div {
    text-decoration: underline;
}

.addressPickerPopupBlock .addressPickerPopupDefaultBlock.isDefault span {
    color: #aaa;
    text-decoration: none;
}

.addressPickerPopupRow {
    font-size: 0.933em;
    line-height: 1.6em;
}

.addressPickerPopupBlock .addressPickerPopupSelectAction {
    clear: both;
    width: 100%;
    padding: 0;
    line-height: 44px;
    border: none;
    background-color: #a6182e;
    color: white;
    text-transform: uppercase;
    font-size: 0.8em;
    font-weight: bold;
    border-radius: 2px;
}

.addressPickerPopup .addNewDeliveryAddressBlock, .addressPickerPopup .addNewBillingAddressBlock {
    margin-top: 50px;
}

.addressPickerPopup .addNewDeliveryAddressBlock .addNewDeliveryAddressAction, .addressPickerPopup .addNewBillingAddressBlock .addNewBillingAddressAction {
    padding: 0;
    line-height: 44px;
    border: none;
    background-color: #f5f5f5;
    color: black;
    text-transform: uppercase;
    font-size: 0.8em;
    font-weight: bold;
    border-radius: 2px;
    margin: auto;
    width: 100%;
    max-width: 250px;
    display: block;
}

.addressVerificationPopupBlockFirst {
    margin-right: 30px;
    float: left;
}

.addressVerificationPopupBlock h3 {
    line-height: 40px;
    margin: 0;
    background-color: #f5f5f5;
    border-bottom: 1px solid #ddd;
    font-size: 0.8em;
    text-transform: uppercase;
    font-weight: bold;
    padding-left: 20px;
}

.addressVerificationDetails {
    margin: 10px 0;
    font-size: 0.933em;
}

.addressVerificationDetails input,
.addressVerificationDetails-RecommendedValue {
    width: 100%;
    margin-top: 5px;
    border: none;
    pointer-events: none;
}

.addressVerificationSelect {
    text-align: right;
}

.addressVerificationPopupBlock button,
.addressVerificationPopupBlock .useRecommendedDeliveryAddress,
.addressVerificationPopupBlock .useRecommendedBillingAddress {
    font-size: 0.8em;
    display: inline-block;
    width: calc(100% - 40px);
    max-width: 300px;
    margin: 20px 0;
    padding: 0;
    line-height: 44px;
    text-transform: uppercase;
    font-weight: bold;
    border: none;
    background-color: #a6182e;
    color: white;
    text-align: center;
    cursor: pointer;
}

.addressVerificationPopupBlock button {
    background-color: black;
}

#shippingAddressVerificationPopup, #billingAddressVerificationPopup {
    height: 100%;
    max-height: 850px;
    top: 50%;
    left: 50%;
    margin: 0;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    overflow: hidden;
    padding: 40px 15px;
}

.addressVerificationPopupBlockContainer {
    overflow: auto;
    max-height: calc(100% - 40px);
    padding-left: 13px;
    padding-right: 13px;
}

.addressVerificationSelect {
    text-align: right;
}

.recommendedAddressListBlock > .row:after {
    content: "";
    width: calc(100% - 30px);
    margin-left: 15px;
    border-top: 1px solid #ddd;
}

.recommendedAddressListBlock > .row:last-child:after {
    display: none;
}

.addressVerificationPopupBlock-DeliveryRecommended, .addressVerificationPopupBlock-BillingRecommended {
    margin-top: 25px;
}

.addressVerificationEdit {
    font-size: 0.8em;
    display: inline-block;
    color: #5A5A5A;
    text-transform: uppercase;
    width: 100%;
    max-width: 300px;
    line-height: 1em;
    cursor: pointer;
    text-decoration: underline;
    text-align: center;
}

.noRecommendedAddressesBlock {
    margin: 10px 13px;
    padding: 10px;
    font-size: 0.933em;
    background-color: #fbeded;
    color: #d9534f;
}

.noRecommendedAddressesBlock span {
    display: inline-block;
    width: calc(100% - 20px);
}

.noRecommendedAddressesBlock i {
    vertical-align: top;
    margin-top: 2px;
    font-size: 12px;
}

.checkoutCartSummary, .checkoutCartASMWESSummary {
    border: 1px solid #ddd;
}

.checkoutCartASMWESSummary {
    margin-top: 10px;
}

.checkoutCartSummary h2, .checkoutCartSummary h3, .checkoutCartASMWESSummary h2, .checkoutCartASMWESSummary h3 {
    font-size: 0.9333em;
    font-weight: bold;
    text-transform: uppercase;
    margin: 0;
    line-height: 40px;
    background-color: #f5f5f5;
    border-bottom: 1px solid #ddd;
    padding-left: 20px;
}

.checkoutCartSummaryProducts, .checkoutCartSummarySubTotals, .checkoutCartASMWESSummaryDetails {
    border-bottom: 1px solid #ddd;
    padding: 20px;
    font-size: 0.933em;
}

.checkoutCartSummaryProductsRow {
    display: inline-block;
    width: 100%;
}


.checkoutCartSummaryProductImage {
    width: 22%;
    display: inline-block;
    float: left;
    margin-right: 3%;
}

.checkoutCartSummaryProductImage img {
    width: 100%;
}

.checkoutCartSummaryProductDetails {
    width: 75%;
    display: inline-block;
    float: left;
}

.checkoutCartSummaryProductBrand, .returnOrderSummaryProductBrand {
    text-transform: uppercase;
    font-weight: bold;
    margin-bottom: 5px;
}

.checkoutCartSummaryProductName, .returnOrderSummaryProductName {
    margin-bottom: 5px;
}

.checkoutCartSummaryProductCode {
    color: #aaa;
    margin-bottom: 25px;
}

.returnOrderSummaryProductCode {
    color: #aaa;
}

.returnOrderSummaryReasonTitle, .returnOrderSummaryCommentTitle {
    color: #aaa;
    margin-top: 15px;
    margin-bottom: 0px
}

.returnOrderSummaryReasonValue {
    margin-bottom: 25px;
}

.returnOrderSummaryReasonInfo {
    float: left;
}

.returnStatusMobile {
    margin-left: 20px;
    font-weight: bold;
}

.checkoutCartSummaryProductPriceQty span {
    float: right;
}

.checkoutCartSummarySubTotals > *, .checkoutCartASMWESSummaryDetails > * {
    margin-bottom: 10px;
}

.checkoutCartSummarySubTotals > *:last-child, .checkoutCartASMWESSummaryDetails > *:last-child {
    margin-bottom: 0;
}

.checkoutCartSummarySubTotalsValue, .checkoutCartASMWESSummaryStoreIDValue, .checkoutCartASMWESSummaryPayrollValue, .checkoutCartASMWESSummaryRemove a {
    float: right;
}

.checkoutCartASMWESSummaryRemove {
    height: 20px;
}

.checkoutCartASMWESSummaryRemove a {
    text-decoration: underline;
    cursor: pointer;
}

.checkoutCartSummaryTotal {
    padding: 15px 20px;
}

.checkoutCartSummaryTotal .checkoutCartSummarySubTotalsValue {
    font-weight: bold;
    font-size: 1.067em;
}

.pickUpPopupInner.noSearch
.pickUpPopupInnerStoreList {
    width: 100%;
}

.pickUpPopupInner.noSearch .pickUpPopupInnerMap {
    display: none;
}

#pac-input-pickup {
    width: calc(100% - 44px);
    display: inline-block;
    float: left;
    border-radius: 0;
    height: 44px;
}

.orderConfirmationYourDetails p, .orderConfirmationCreateAccountText li {
    font-size: 0.933em;
    line-height: 2em;
}

.orderConfirmationYourDetails p {
    margin-bottom: 20px;
}

.orderConfirmationCreateAccountText ul {
    padding-left: 25px;
}

.orderConfirmationCreateAccountText li {
    position: relative;
}

.orderConfirmationCreateAccountText li:before {
    content: "\f00c";
    font-family: Font Awesome\ 5 Pro;
    font-weight: bold;
    position: absolute;
    left: -25px;
}

.orderConfirmationCreateAccountForm input.enterPassword {
    width: 100%;
}

.contactPreferencesBlock {
    display: inline-block;
    margin: 10px 0 10px 20px;
}

.contactPreferencesBlock label {
    margin-left: 10px;
    font-weight: normal;
}

.contactPreferencesBlock:first-child {
    margin-left: 0;
}

.findAStoreShowMoreLess {
    font-size: 0.875em;
    letter-spacing: 0.08em;
    background-color: #dfdfdf;
    color: black;
    text-transform: uppercase;
    text-align: center;
    margin-top: 4%;
    margin-bottom: 4%;
    font-weight: 600;
    padding: 14px;
    cursor: pointer;
}

#pickUpStoreSearchButton {
    width: 44px;
    height: 44px;
    float: left;
    border-radius: 0;
    background-color: #a6182e;
}

.pickUpPopupSearchBlock {
    position: relative;
    margin-bottom: 80px;
}

#pickUpPopupResultsBlock .findAStoreSearchBoxResult {
    font-size: 0.933em;
}

#pickUpPopupResultsBlock .findAStoreSearchBoxResult > * {
    max-width: 80%;
}

#pickUpPopupResultsBlock .storeFinderSelectBlock {
    position: absolute;
    right: 20px;
    top: 25px;
    width: 20%;
}

#pickUpPopupResultsBlock .storeFinderSelectBlock .collectionDate {
    color: #5cb85c;
}

#pickUpPopupResultsBlock .storePickUpSelect {
    background-color: #a6182e;
    color: white;
    text-align: center;
    text-transform: uppercase;
    font-size: 0.857em;
    line-height: 34px;
    margin-top: 15px;
    cursor: pointer;
}

#pickUpPopupResultsBlock .findAStoreSearchBoxResult h4 {
    display: inline-block;
    font-weight: bold;
    font-size: 1em;
}

#pickUpPopupResultsBlock .findAStoreSearchBoxResult.active {
    background: #f7f7f7;
}

#pickUpPopupResultsBlock .findAStoreSearchBoxResult .storeFinderViewMoreLess,
#pickUpPopupResultsBlock .findAStoreSearchBoxResult.findAStoreSearchBoxResultOpen .storeFinderMoreDetails {
    display: block;
}

#pickUpPopupResultsBlock .findAStoreSearchBoxResult.findAStoreSearchBoxResultOpen .storeFinderViewMore {
    display: none;
}

#pickUpPopupResultsBlock .findAStoreSearchBoxResult .storeFinderViewMoreLess {
    color: #5A5A5A;
    font-size: 0.857em;
    text-transform: uppercase;
    margin: 10px 0;
    cursor: pointer;
}

#pickUpPopupResultsBlock .findAStoreSearchBoxResult .storeFinderViewMoreLess span {
    text-decoration: underline;
    margin-right: 5px;
}

#pickUpPopupResultsBlock .findAStoreSearchBoxResult .storeFinderOurOpeningHours {
    margin-top: 15px;
}

#pickUpPopupResultsBlock .findAStoreSearchBoxResult .storeFinderOpeningHours {
    margin-bottom: 0.5em;
}

#pickUpPopupResultsBlock .findAStoreSearchBoxResult .storeFinderOpeningHour {
    width: 50%;
}

#pickUpFromStorePopup h2 {
    text-align: center;
    font-size: 1.333em;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    margin: 40px auto 35px;
}

#pickUpFromStorePopup h3, #pickUpFromStorePopup h4 {
    font-size: 0.933em;
    margin: 15px 0;
    display: inline-block;
}

#pickUpFromStorePopup #pickUpPopupResultsBlock h3 {
    margin-top: 25px;
    text-transform: capitalize;
}

#pickUpFromStorePopup .pickUpPopupInnerHalf > h3 {
    margin-top: 0;
}

.deliveryOptionButton {
    width: 100%;
    display: block;
    background-color: white;
    box-sizing: unset;
    border: 1px solid #ddd;
    margin-bottom: 20px;
    font-size: 0.933em;
    padding: 10px 0;
}

.deliveryOptionButton.selected {
    background-color: #eff5e7;
}

.deliveryOptionButton .deliveryRadioBlock {
    width: 40px;
    display: inline-block;
    height: 48px;
    float: left;
    position: relative;
}

.deliveryOptionButton .deliveryDetailsTitle {
    font-weight: bold;
    text-transform: uppercase;
}

.deliveryOptionButton .deliveryDetailsBlock {
    width: calc(100% - 40px);
    display: inline-block;
    text-align: left;
}

.deliveryOptionButton .deliveryDetailsBlock > * {
    line-height: 1.75em;
}

.deliveryOptionButton .deliveryRadioBlock:before, .deliveryOptionButton .deliveryRadioBlock:after {
    content: "";
    position: absolute;
    left: 50%;
    top: 12px;
    display: block;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

.deliveryOptionButton .deliveryRadioBlock:before {
    z-index: 1;
    width: 14px;
    border: 1px solid #ddd;
    height: 14px;
    border-radius: 7px;
    background-color: white;
}

.deliveryOptionButton .deliveryRadioBlock:after {
    display: none;
}

.deliveryOptionButton.selected .deliveryRadioBlock:after {
    display: block;
    z-index: 2;
    width: 8px;
    height: 8px;
    background-color: black;
    border-radius: 4px;
}

.deliveryOptionMainCollect .chosenPickUpStoreDetails {
    margin: 25px 0 0;
}

.chosenPickUpStoreDetails {
    position: relative;
    font-size: 0.933em;
    line-height: 1.5em;
}

.chosenPickUpStoreDetails .chosenPickUpStoreDetails-when {
    display: inline-block;
    position: absolute;
    right: 0;
    top: 0;
    color: #5cb85c;
}

.chosenPickUpStoreDetails .chosenPickUpStoreDetails-name, .chosenPickUpStoreDetails .chosenPickUpStoreDetails-distance {
    display: inline-block;
}

.chosenPickUpStoreDetails .chosenPickUpStoreDetails-name {
    font-weight: bold;
}

.chosenPickUpStoreDetails .chosenPickUpStoreDetails-distance {
    color: #aaa;
}

#aboutYouSubmit:disabled {
    cursor: not-allowed;
    opacity: 0.4;
}

#orderStoreMap {
    width: 100%;
    height: 260px;
}

.orderConfirmationSelectedStore > div {
    font-size: 0.933em;
    line-height: 1.75em;
}

.orderConfirmationSelectedStore .orderStoreName {
    font-weight: bold;
}

.orderConfirmationSelectedStore > h3 {
    margin-bottom: 20px;
}

.orderConfirmationSelectedStore .orderStoreAddress {
    margin-bottom: 20px;
}

.orderConfirmationSelectedStore .orderStorePhone {
    margin: 20px auto;
}

.orderConfirmationSelectedStore .orderStoreDirections {
    font-size: 0.8em;
    text-transform: uppercase;
    margin: 15px 0;
    display: block;
    width: 100%;
    line-height: 44px;
    text-align: center;
    color: white;
    background-color: black;
    font-weight: bold;
}

.orderConfirmationSelectedStore .orderStoreDirections:hover {
    color: white;
    text-decoration: none;
}

#checkoutSpinnerBackground {
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 99999;
}

#checkoutSpinner {
    position: absolute;
    top: calc(50% - 25px);
    left: calc(50% - 25px);
    font-size: 50px;
    color: white;
}

.checkoutActionLocked {
    opacity: 0.7;
    pointer-events: none;
}

#guestRegisterForm .form-control.password-strength.checkoutFormInput.enterPassword {
    border-radius: 0;
}

#guestRegisterForm .form-control.password-strength.checkoutFormInput.enterPassword {
    border-color: #ddd;
    outline: 0;
    -webkit-box-shadow: none;
    box-shadow: none;
}

/* Forgotten Password Form and T&Cs popup*/

.forgottenPasswordBackground,
.termsAndConditionsPopupBackground,
.giftwrapPickupWarningBackground,
.giftwrapUnsavedWarningBackground,
.forgottenPasswordSuccessBackground {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
    z-index: 999;
}

.forgottenPassword,
.forgottenPasswordSuccess,
.termsAndConditionsPopup {
    position: absolute;
    width: 100%;
    max-width: 800px;
    left: 50%;
    top: 50%;
    transform: translateX(-50%) translateY(-50%);
    background-color: white;
    padding: 25px;
    z-index: 1000;
}

.termsAndConditionsPopup {
    max-width: 950px;
    max-height: 90%;
    overflow-y: auto;
}

.termsAndConditionsPopup .informationPage {
    padding: 0;
}

.forgottenPasswordPopupClose,
.forgottenPasswordSuccessPopupClose,
.termsAndConditionsPopupClose,
.giftwrapInformationPopupClose {
    position: absolute;
    right: 10px;
    top: 10px;
    font-size: 20px;
    cursor: pointer;
    padding: 5px;
}

#closePasswordResetBtn {
    margin-top: 30px;
    width: 150px;
    margin-left: auto;
    margin-right: auto;
    background-color: #a6182e;
    border-color: #a6182e;
    text-transform: uppercase;
    font-family: 'Nunito Sans', sans-serif;
    font-size: 0.8em;
    border-radius: 0px;
    padding-top: 10px;
    padding-bottom: 10px;
}

#forgottenPwdForm {
    margin-top: 25px;
}

#paypal-button-container {

    /* 	float: right; */
    /* 	margin: 17px 30px 17px 0px; */
    /* 	height: 44px; */
}

#paypal-button-container iframe {
    z-index: 4 !important;
}

.paypalPickupWarning {
    color: red;
}

#confirmationPaypalIcon {
    margin-right: 10px;
}

.confirmationPaymentInfoBlock {
    margin-bottom: 40px;
}

.cartPaymentButtonsBlock {
    width: 250px;
    float: right;
}

.pickupWarningExclamation {
    margin-right: 5px;
}

.paypalCreditModalScroll {
    overflow-y: auto;
    overflow-x: hidden;
    width: 100%;
    position: absolute;
    top: 60px;
    bottom: 0px;
}

.paypalCreditModalContent {
    width: 100%;
    float: left;
    height: 100%;
    box-sizing: border-box;
}

.paypalCreditInformationContent {
    padding: 28px;
}

.productListPaypalCreditBlock {
    display: flex;
    margin-top: 10px;
    overflow: auto;
    min-height: 35px;
}

.paypalCreditModalContainer {
    z-index: 9;
    background-color: #fff;
    width: 600px;
    height: 600px;
    overflow: hidden;
    position: fixed;
    left: 50%;
    margin-left: -300px;
    margin-bottom: 5%;
    transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
    top: 50%;
    display: none;
}

.paypalCreditModalTitle {
    height: 60px;
    position: relative;
    padding: 20px;
    border-bottom: 1px solid #ddd;
}

.paypalCreditModalClose a {
    float: right;
    position: relative;
    top: -25px;
    right: 0px;
    font-size: 26px;
}


.paypalCreditModalTitle h2 {
    width: 100%;
    text-align: center;
    text-transform: uppercase;
    font-size: 17px;
    letter-spacing: 5px;
    line-height: normal;
    margin: 0 !important;
}

#paypalCreditFindOut {
    cursor: pointer;
    text-decoration: underline;
}

.paypalCreditModalTitle {

}

.productTileAffirmFinance {
    font-size: 0.85em;
    bottom: 0px;
    position: absolute;
    width: 100%;
    padding-left: 30px;
    padding-right: 30px;
}

.productPagePaypalCreditBlock {
    width: 100%;
    background-color: #F1EFED;
    margin-top: 18px;
    margin-bottom: 18px;
    color: black;
    display: flex;
    overflow: auto;
    min-height: 70px;
    padding: 17px 5px 17px 5px;
}

.productListPaypalCreditImageBlock {
    width: 33%;
    border: 1px solid #ddd;
    background-color: white;
    display: flex;
}

.productPagePaypalCreditImageBlock {
    width: 63px;
    display: flex;
}

#productListPaypalCreditImage, #productPagePaypalCreditImage {
    display: block;
    height: auto;
    vertical-align: middle;
    margin: auto;
    width: 100%
}

.productListPaypalCreditDetailsBlock {
    width: 67%;
    min-height: 35px;
    height: 100%;
    border: 1px solid;
    background: #fafafa;
    border-color: #eaeaea;
    font-size: 10px;
    text-align: center;
    display: block;
    vertical-align: middle;
    padding: 11px;
    overflow: auto;
    line-height: 12px;
}

.productPagePaypalCreditDetailsBlock {
    font-size: 12px;
    line-height: 16px;
}

#reviewOrderAdditionalInfoBlock {
    float: left;
}

#reviewOrderProductBlock {
    float: right;
    margin-bottom: 40px;
}

.lock-scroll {
    overflow: hidden !important;
}

#forgottenPwdForm {
    margin-top: 25px;
}

/* Product Builder */

.productBuilderContainer {
    width: 1095px !important;
}

.productBuilderOuterContainer {
    margin: 25px auto;
    position: relative;
    min-height: 250px;
}

.productBuilderStageOuter {
    margin-bottom: 10px;
}

.productBuilderStageHeader {
    border: 1px solid #ddd;
    line-height: 48px;
    padding-left: 20px;
    cursor: pointer;
    background-color: #ffffff;
}

.productBuilderStageHeader.productBuilderStageHeaderSelected {
    background-color: #f3f3f3;
}

.productBuilderStageHeaderTitle {
    font-size: 14px;
    font-weight: bold;
}

.productBuilderStageHeaderValue {
    font-size: 14px;
    margin-left: 10px;
}

.productBuilderStageHeaderActions {
    float: right;
}

.productBuilderStageHeaderActions > * {
    display: inline-block;
    margin-right: 15px;
    line-height: 48px;
    vertical-align: middle;
}

.productBuilderStageHeaderActions i {
    font-size: 22px;
    color: #25AE88;
}

.productBuilderStageEdit {
    text-decoration: underline;
}

.productBuilderStageOptions {
    padding-left: 40px;
    display: none;
    height: 0px;
    flex-wrap: wrap;
    align-content: flex-start;
    overflow: hidden;
    border: 1px solid #ddd;
    border-top: none;
    overflow-y: auto;
    background-color: #fbfbfb;
}

.productBuilderFacetOption {
    cursor: pointer;
    border: 1px solid #ddd;
    width: 144px;
    height: 180px;
    margin: 15px 10px 0;
    position: relative;
    border-radius: 7px;
}

.productBuilderFacetOptionFooter {
    width: 100%;
    height: 15px;
}

.productBuilderFacetOption.productBuilderFacetOptionSelected {
    border: 2px solid #a6182e;
    border-radius: 7px;
}

.productBuilderFacetOption img {
    width: 90%;
    margin-left: 5%;
}

.productBuilderFacetOption span {
    position: absolute;
    bottom: 0;
    left: 0;
    display: block;
    font-size: 14px;
    padding: 0 2px;
    width: 100%;
    text-align: center;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    text-overflow: ellipsis;
    height: 42px;
    display: -webkit-box;
    overflow: hidden;
}

.productBuilderReset {
    font-size: 14px;
    font-weight: bold;
    display: inline-block;
    float: right;
    clear: both;
    color: #555;
    cursor: pointer;
    padding: 10px 0;
}

.productBuilderReset span {
    display: inline-block;
    margin-left: 5px;
    text-decoration: underline;
}

.productBuilderProductContainerTitle h2 {
    font-size: 18px;
    font-weight: bold;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    text-align: center;
}

.productBuilderProductContainerTitle h2:after {
    content: "";
    display: block;
    border-bottom: 1px solid #ddd;
    width: 100%;
    max-width: 440px;
    margin: 20px auto;
}

.productBuilderProductContainerInner .productMobileSpecificationComponent.hidden-lg {
    display: block !important;
}

.productBuilderProductContainerInner .productFinanceComponent,
.productBuilderProductContainerInner .youMayAlsoLike,
.productBuilderProductContainerInner .recentlyViewed {
    display: none;
}

.productBuilderOverlay {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 3;
    background-color: rgba(255, 255, 255, 0.5);
}

.productBuilderOverlay i.fas.fa-spinner {
    position: absolute;
    top: 50%;
    left: 50%;
    opacity: 0.8;
}

.productBuilderSaveMySelection, .productBuilderSavePopupBlockSubmit {
    font-size: 0.933em;
    text-transform: uppercase;
    background-color: #dfdfdf;
    border-radius: 2px;
    color: black;
    text-align: center;
    font-weight: bold;
    line-height: 40px;
    margin-top: 10px;
    cursor: pointer;
}

.productBuilderSavePopupBlockSubmit.productBuilderSavePopupBlockSubmit-account {
    background-color: #a6182e;
    color: white;
}

.productBuilderProductContainerInner .productDetails .add_to_cart_form button.addToCartButton {
    width: 100%;
}

.productBuilderProductContainerInner .addToWishlistButton {
    display: none;
}

.productBuilderSaveBackground {
    position: fixed;
    top: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.7);
    width: 100%;
    height: 100%;
    z-index: 9;
    overflow-y: auto;
}

.productBuilderSavePopup {
    position: relative;
    background-color: white;
    width: 1400px;
    max-width: 100%;
    margin: 200px auto 0;
    padding: 40px 0;
}

.productBuilderPopupClose {
    position: absolute;
    top: 5px;
    right: 10px;
    font-size: 20px;
    padding: 5px;
    cursor: pointer;
}

.productBuilderSavePopup h2 {
    text-align: center;
    font-size: 1.333em;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    margin: 0 auto 35px;
    line-height: 30px;
}

.productBuilderSavePopupBlock {
    width: calc(49.5% - 2px);
    display: inline-block;
    padding: 0 30px;
}

.productBuilderSavePopupBlock:first-child {
    border-right: 1px solid #ddd;
}

.productBuilderSavePopupBlock > * {
    text-align: center;
}

.productBuilderSavePopupBlockIcon {
    font-size: 30px;
    color: #a6182e;
    margin-bottom: 10px;
}

.productBuilderSavePopupBlockTitle {
    font-size: 14px;
    font-weight: bold;
    text-transform: uppercase;
    margin-bottom: 10px;
}

input.productBuilderSavePopupBlockField {
    line-height: 38px;
    width: 100%;
    font-size: 14px;
    text-align: left;
    padding-left: 10px;
    border: 1px solid #ddd;
    color: #000;
    margin: 10px 0;
}

input.productBuilderSavePopupBlockField::placeholder {
    color: #aaa;
}

.productBuilderSavePopupMobileDivider {
    margin: 40px 30px;
}

.productBuilderSavePopupMobileDivider div {
    display: inline-block;
    width: calc(50% - 19px);
    border-bottom: 1px solid #ddd;
    height: 15px;
    vertical-align: top;
}

.productBuilderSavePopupMobileDivider span {
    display: inline-block;
    width: 30px;
    text-align: center;
    line-height: 30px;
    text-transform: lowercase;
}

.productBuilderSavePopup p {
    width: 100%;
    text-align: center;
    margin: 30px;
}

.productBuilderSavePopup-saveConfirmation .productBuilderSavePopupBlockSubmit, .productBuilderSavePopup-delete .productBuilderSavePopupBlockSubmit {
    margin: 15px 30px;
    width: calc(50% - 47px);
    display: inline-block;
}

.productBuilderSavePopup-saveConfirmation .productBuilderSavePopupBlockSubmit-close, .productBuilderSavePopup-delete .productBuilderSavePopupBlockSubmit-deleteNo {
    margin-right: 15px;
}

.productBuilderSavePopup-saveConfirmation .productBuilderSavePopupBlockSubmit-myAccount, .productBuilderSavePopup-delete .productBuilderSavePopupBlockSubmit-deleteYes {
    margin-left: 15px;
    background-color: #a6182e;
    color: white;
}

.productBuilderSavePopup-emailConfirmation .productBuilderSavePopupBlockSubmit {
    max-width: 400px;
    margin: 10px auto 0;
    color: white;
    background-color: #a6182e;
}

.productBuilderProductContainerInner .variantDropdownsContainer select#stoneWeightDropdown {
    display: none;
}

.productBuilderProductContainerInner .variantDropdownsContainer select#ringMetalTypeDropdown {
    display: none;
}

.productBuilderProductContainerInner .variantDropdownsContainer select#ringSizeDropdown {
    width: 100%;
}

.removeSavedProductBuilder {
    margin-top: 31px;
}

.accountViewProductBuilder {
    top: auto !important;
}

.accountProductBuilderActions {
    margin-top: 25px;
}

#sendPaymentLinkBtn, #addCreditPaymentBtn, #startWESSession {
    margin-bottom: 15px;
}

.asmRestrictionContent {
    text-align: center;
    margin: 0 auto;
    max-width: 400px;
    padding: 90px 30px;
}

.asmRestrictionSubHeading {
    font-size: 1em;
    text-transform: uppercase;
    font-weight: 700;
    letter-spacing: 1px;
}

.asmRestrictionTitle {
    font-size: 2em;
    letter-spacing: 6px;
    text-transform: uppercase;
}

.asmRestrictionMessage {
    padding: 0 15px 25px 15px;
    margin-bottom: 0 !important;
}

.asmPaymentBlockError {
    color: red;
}

.asmPaymentBlockWarning {
    color: orange;
}

.cardBalanceMessage {
    color: blue;
}

.paymentLinkEmailSummaryMsg {
    color: green;
}

@media (max-width: 1460px) {
    .productBuilderContainer {
        width: 1060px !important;
    }

    .productBuilderStageOptions {
        padding-left: 25px;
    }

    .productBuilderFacetOption {
        width: 116px;
        height: 160px;
    }

    .productBuilderFacetOption img {
        width: 100%;
        margin-left: 0;
    }

    .productTile a {
        margin-bottom: 50px;
    }
}

@media (max-width: 1200px) {
    .productBuilderStageOptions {
        padding-left: 10px;
    }

    .productBuilderFacetOption {
        width: 111px;
        height: 150px;
    }

    .productBuilderFacetOption span {
        font-size: 12px;
        height: 38px;
    }

    .productTile a {
        margin-bottom: 70px;
    }
}

@media (max-width: 992px) {
    .productBuilderContainer {
        width: 750px !important;
    }

    .productBuilderFacetOption {
        width: calc(20% - 22px);
        height: auto;
        padding-bottom: 40px;
    }

    .productBuilderSavePopupBlock {
        width: 100%;
        display: inline-block;
        padding: 0 30px;
    }

    .productBuilderSavePopupBlock:first-child {
        border-right: none;
    }

    .productBuilderSavePopup {
        margin: 0 auto;
        top: 0;
        height: 100%;
        width: 100%;
        overflow-x: hidden;
        overflow-y: auto;
    }

    .productBuilderSavePopup-saveConfirmation .productBuilderSavePopupBlockSubmit, .productBuilderSavePopup-delete .productBuilderSavePopupBlockSubmit {
        margin: 10px 30px;
        width: calc(100% - 60px);
        display: inline-block;
    }

    .productBuilderSavePopup h2 {
        margin: 0 25px 35px;
    }

    .productBuilderSavePopup p,
    .productBuilderSavePopup-emailConfirmation .productBuilderSavePopupBlockSubmit {
        width: calc(100% - 60px);
    }

    .productTile a {
        margin-bottom: 30px;
    }
}


@media (max-width: 768px) {
    .productBuilderContainer {
        width: 100% !important;
    }

    .productBuilderFacetOption {
        width: calc(25% - 22px);
    }

    .paypalCreditModalContainer {
        transform: none;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        margin-left: 0;
        margin-bottom: 0;
    }
}

@media (max-width: 600px) {
    .productBuilderContainer {
        width: 100% !important;
    }

    .productBuilderFacetOption {
        width: calc(33% - 22px);
    }

    .productBuilderStageHeaderValue {
        max-width: 127px;
        display: inline-flex;
        font-size: 10px;
        white-space: nowrap;
    }
}

@media (max-width: 544px) {
    .productTile a {
        margin-bottom: 50px;
    }
}


@media (max-width: 425px) {
    .productBuilderFacetOption {
        width: calc(50% - 22px);
    }
}

@media (max-width: 350px) {
    .productBuilderStageHeaderValue {
        font-size: 8px;
    }

}

@media (min-width: 992px) {

    .mobileGuttering {
        padding-left: 0;
        padding-right: 0;
    }

    .orderConfirmationOrderSummary .checkoutCartSummaryMobile {
        display: block;
        border-left: none;
        border-right: none;
        border-bottom: none;
    }

    .orderConfirmationOrderSummary .checkoutCartSummaryMobile h2 {
        border: none;
        text-align: left;
        background-color: transparent;
        line-height: 60px;
        padding: 0;
    }

    .orderConfirmationOrderSummary .checkoutCartSummaryMobile .checkoutCartSummaryProducts,
    .orderConfirmationOrderSummary .checkoutCartSummaryMobile .checkoutCartSummarySubTotals,
    .orderConfirmationOrderSummary .checkoutCartSummaryMobile .checkoutCartSummaryTotal {
        padding: 20px 0;
    }

}

@media (max-width: 991px) {

    /* Cookie Policy */
    #cookie-message {
        text-align: center;
    }

    #cookie-message .col-md-10 {
        margin-bottom: 20px
    }

    #cookie-accept {
        width: 100%;
    }

    /* General */
    body.hasPromo {
        padding-top: 90px;
    }

    body {
        padding-top: 50px;
    }

    /* Header */
    .header > .container {
        width: 100%;
    }

    .header {
        position: fixed;
        top: 0;
        width: 100%;
    }

    .middleHeader {
        margin-bottom: 0;
        height: 38px;
    }

    .middleHeader .col-xs-4 {
        padding: 0;
    }

    .middleHeader .mobileHeaderIcon {
        transition: all 0.2s ease-out;
        float: right;
        margin-top: 0;
        margin-left: 5px;
        margin-right: 5px;
        height: 50px;
        line-height: 50px;
        width: 40px;
        text-align: center;
        position: relative;
        border: 1px solid #fff;
        cursor: pointer;
    }

    .middleHeader .mobileHeaderIcon i {
        font-size: 1.5em;
        color: #5A5A5A;
        margin-top: 8px;
    }

    .middleHeader .siteLogo img {
        max-width: none;
        max-height: 30px;
        display: block;
        line-height: 38px;
        margin-top: 7px;
    }

    .middleHeader .headerSearchForm-MobileHide {
        display: none;
    }

    .middleHeader .mobileHeaderIcon.headerSearchForm {
        position: absolute;
        left: 0;
        top: 50px;
        width: 100%;
        margin: 0;
        height: 60px;
        padding-top: 0;
        z-index: 9;
        background-color: #eee;
    }

    .hasPromo .mobileHeaderIcon.search-form.headerSearchForm.pull-right.solrSearch {
        top: 85px;
    }

    .row.middleHeader > * {
        position: initial;
    }

    .middleHeader .search-bar {
        width: 95% !important;
        height: 40px;
        margin: 10px 0;
    }

    .middleHeader .search-button {
        position: absolute;
        right: 2.5%;
        top: 10px;
        height: 40px;
    }

    .middleHeader .mobileHeaderIcon i {
        font-size: 1.25em;
    }

    .middleHeader .mobileHeaderIcon i.fal.fa-search {
        font-size: 1.375em;
    }

    .middleHeader .shopping-bag {
        margin-top: 0;
    }

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

    .mobile-nav-visible #mobile-navigation {
        display: block;
    }

    #mobile-navigation {
        transform: translateX(-100%);
        width: calc(100% - 100px);
        height: 100vh;
        position: fixed;
        top: 0;
        left: 0;
        background-color: #fff;
        z-index: 99999;
        transition: all 0.25s ease-out;
    }

    body.mobile-nav-visible {
        overflow: hidden;
    }

    body.mobile-nav-visible #mobile-navigation {
        transform: translateX(0%);
    }

    .mobile-nav-page-overlay {
        display: none;
        opacity: 0;
        background-color: rgba(0, 0, 0, 0);
        transition: all 0.2s ease-out;
    }

    body.mobile-nav-visible .mobile-nav-page-overlay {
        display: block;
        opacity: 1;
        position: fixed;
        display: block;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-color: rgba(0, 0, 0, 0.3);
        z-index: 99998;
    }

    .mobile-navigation-header {
        height: 50px;
        border-bottom: 1px solid #d9d7d7;
        line-height: 50px;
    }

    .mobile-navigation-header .col-sm-6 i {
        margin-right: 5px;
    }

    .mobile-navigation-body {
        left: 0;
        position: absolute;
        width: 100%;
        height: calc(100vh - 50px);
        overflow-y: auto;
        overflow-x: hidden;
        transition: all 0.2s ease-out;
    }

    .mobile-navigation-body .top-level-menu,
    .mobile-navigation-body .sub-menu {
        padding-left: 0;
    }

    .mobile-navigation-close {
        display: none;
        width: 100px;
        height: 50px;
        background-color: rgba(255, 255, 255, 0);
        top: 0;
        right: 0;
        position: fixed;
        margin-right: -100px;
        border-bottom: 1px solid #d9d7d7;
        border-left: 1px solid #d9d7d7;
        opacity: 0;
        transition: opacity 1s ease;
        text-align: center;
    }

    .mobile-navigation-close i {
        font-size: 2em;
        margin-top: 8px;
    }

    body.mobile-nav-visible .mobile-navigation-close {
        cursor: pointer;
        display: block;
        opacity: 1;
        background-color: rgba(255, 255, 255, 1)
    }


    .sub-menu {
        position: absolute;
        background-color: #fff;
        left: 100%;
        position: absolute;
        width: 100%;
        height: calc(100vh - 50px);
        top: 0;
        overflow-y: auto;
        transition: all 0.25s ease-out;
        overflow-x: hidden;
    }

    .sub-menu-active > .sub-menu {
        left: 0;
        box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.5);
    }

    .mobile-navigation-body.show-sub-menu .top-level-menu {
        left: -100%;
    }

    .mobile-navigation-body li.home-menu {
        padding: 15px;
        border-bottom: 1px solid #d9d7d7;
        background-color: #eee;
    }

    .mobile-navigation-body li.back-menu {
        cursor: pointer;
        padding: 15px;
        border-bottom: 1px solid #d9d7d7;
        background-color: #eee;
    }

    .mobile-navigation-body li.back-menu:before {
        content: '\f060';
        font-family: Font Awesome\ 5 Pro;
        margin-right: 15px;
    }

    .mobile-navigation-body li a {
        display: block;
        padding: 15px;
        border-bottom: 1px solid #d9d7d7;
    }

    .mobile-navigation-body li.has-sub-menu > a:after {
        content: '\f054 ';
        font-family: Font Awesome\ 5 Pro;
        float: right;
        margin-left: 0px;
    }

    #mobile-navigation .mobile-navigation-header div.col-sm-6.col-xs-6 {
        padding-right: 5px;
    }

    /* Breadcrumbs */
    .breadcrumb {
        margin-left: 0;
        margin-top: 0;
    }

    /* Footer */
    .footer {
        padding: 35px 0;
    }

    .footerColumns ul {
        height: 0;
        overflow: hidden;
        transition: all 0.2s ease-out;
        margin-bottom: 0;
    }

    .footerColumns .footerColumn:nth-child(1) h3 {
        border-top: 0;
    }

    .footerColumns .footerColumn h3 {
        position: relative;
        cursor: pointer;
        font-size: 1.2em;
        border-top: 1px solid #d1d1d1;
        height: auto;
        padding: 20px 0;
        margin: 0;
    }

    .footerColumns .footerColumn h3:after {
        content: '\f054 ';
        font-family: Font Awesome\ 5 Pro;
        font-size: 0.8em;
        display: block;
        position: absolute;
        right: 10px;
        top: 18px;
    }

    .footerColumns .footerColumn.footer-menu-open h3:after {
        content: '\f078'
    }

    .footerColumns .footerColumn.footer-menu-open ul {
        height: auto;
        padding-bottom: 20px;
        margin: 10px;
    }

    .footer .footer-social.pull-right {
        float: none !important;
        margin-bottom: 35px;
    }

    .footer .footer-payment {
        margin-top: 35px;
        text-align: center;
    }

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

    .footer .footer-payment,
    .footer .footer-copyright {
        margin-top: 20px;
        float: none !important;
    }

    .footer .footer-payment img {
        height: auto;
        max-width: 300px;
        width: 80%;
    }

    /* Store Finder Page */
    .findAStoreSearchBoxSearch {
        padding-left: 0;
        padding-right: 0;
        margin: auto -15px;
    }

    .findAStoreSearchBoxResult {
        padding: 20px;
    }

    /* Store Details Page */
    h1.detailSectionHeadline {
        font-size: 2em;
    }

    .storeDetailsLinks > a,
    .storeDetailsLinks > span {
        margin: 1em 0 1.5em;
    }

    .storeDetailsLinks a.contactStoreLink {
        margin-left: 0;
        clear: both;
        padding-left: 0;
    }

    .formBlockInner .contactMethodRadios,
    .formBlockInner .signUpCheckbox {
        margin-bottom: 5px;
    }

    .formBlockInner .contactMethodRadios span {
        margin-right: 0.5em;
    }

    .formBlockInner button.btn {
        width: 100%;
    }

    .storeFormPopup {
        left: 5%;
        width: 90%;
        top: 50%;
    }

    .storeFormSpinner {
        left: calc(50% - 25px);
        top: 65%;
    }

    .storeFormPopup .storePopupCloseButton {
        left: 10%;
        width: 80%;
    }

    .storeBrandsContainer .storeBrandBlock {
        width: 33%;
        margin: 0;
    }

    /* Product Details Page */
    .productImageGallery {
        padding-right: 0;
        padding-left: 0;
        position: relative;
    }

    .productImageGallery .owlThumbs {
        display: none;
    }

    .productImageGallery .owl-dots {
        display: block;
        margin-top: -30px;
        position: absolute;
        z-index: 9;
        width: 100%;
    }

    .productImageGallery .owl-dot span {
        display: inline-block !important;
        height: 12px !important;
        width: 12px !important;
        background-color: white !important;
        border: 1px solid #aaa;
        border-radius: 100px !important;
        margin: 0 3px !important;
    }

    .productImageGallery .owl-dot.active span {
        background-color: #aaa !important;
        border-color: white !important;
    }

    .productImageGallery .owl-nav {
        display: none !important;
    }

    .productUnderImageText {
        position: absolute;
        bottom: 25px;
        z-index: 1;
    }

    .seeMoreStylesContainer {
        margin-left: -30px;
        margin-right: -30px;
    }

    .seeMoreStylesHeader {
        margin-left: 30px;
        margin-right: 30px;
    }

    .seeMoreStyles {
        width: 100%;
    }

    .seeMoreStyles .owl-nav {
        display: none !important;
    }

    .seeMoreStyles a {
        padding: 3px 5px;
    }

    .seeMoreStylesContainer {
        margin-top: 15px;
        margin-bottom: 15px;
    }

    .youMayAlsoLikeCarousel.owl-carousel .owl-nav {
        display: none !important;
    }

    .productPageCollapsibleSection .productPageCollapsibleSectionBody .productInfoImage {
        text-align: center;
    }

    .productPageCollapsibleSection {
        padding-right: 15px;
        padding-left: 15px;
    }

    .productPageCollapsibleSection > * {
        padding-right: 0;
        padding-left: 0;
    }


    .productImageGallery {
        margin-left: -15px;
        margin-right: -15px;
        width: calc(100% + 30px);
    }

    #galleryPopupBackground,
    #galleryPopup {
        display: none !important;
    }

    #useMyLocationStockLookup {
        right: 20%;
    }

    /* Product Listing Page */
    /* - Facet Filters */
    .plpContainer {
        position: static;
        margin-bottom: 50px;
    }

    .gridFacets {
        position: fixed;
        background-color: white;
        height: 100%;
        top: 0;
        width: 100%;
        z-index: 8;
        padding: 0;
    }

    .gridFacets .facetsOuterContainer {
        position: fixed;
        top: 0;
        left: 0;
        height: 100%;
        width: 100%;
        padding-top: 30px;
        padding-bottom: 50px;
    }

    .gridFacets .facetsInnerContainer {
        height: 100%;
        overflow-y: auto;
    }

    .gridFacets .mobileFacetsTopper,
    .gridFacets .mobileFacetsFooter {
        position: fixed;
        left: 0;
        width: 100%;
        margin: 0;
        z-index: 9;
        background-color: white;
    }

    .gridFacets .mobileFacetsTopper {
        top: 0;
        border-bottom: 1px solid #d1d1d1;
        height: 30px;
    }

    .gridFacets .mobileFacetsFooter {
        bottom: 0;
        background-color: #f7f7f7;
        height: 50px;
        border-top: 1px solid #d1d1d1;
    }

    .gridFacets .mobileFacetsTopper i {
        float: right;
        font-size: 1.5em;
        line-height: 30px;
        color: #d1d1d1;
        margin-right: 15px;
    }

    .gridFacets .mobileFacetsFooter > span {
        display: inline-block;
        width: 40%;
        line-height: 34px;
        cursor: pointer;
        margin-top: 7px;
        border: 1px solid #d1d1d1;
        float: left;
        background-color: white;
        text-align: center;
    }

    .gridFacets .mobileFacetsFooter > span.clearFacets {
        margin-left: 9%;
        margin-right: 2%;
    }

    .gridFacets .facetItem {
        border-top: 1px solid #d1d1d1;
        padding-left: 30px;
        padding-right: 30px;
    }

    .gridFacets .facetItem:first-child {
        border-top: none;
    }

    .gridFacets .facetItem.facetOpen .facetOptions {
        max-height: none;
    }

    .facetOptions li > div {
        width: 100%;
    }

    .mobileSortFilter {
        width: 100%;
        position: relative;
    }

    .mobileSortFilter .sortClickThrough,
    .mobileSortFilter .sortSelect,
    .mobileSortFilter .showFilters {
        height: 40px;
        line-height: 38px;
        border-radius: 4px;
        border: 1px solid #ccc;
        -webkit-box-shadow: none;
        padding: 0 5px;
        position: absolute;
        top: 0;
        z-index: 2;
        background-color: white;
        width: 48%;
    }

    .appliedFiltersContainer {
        padding-left: 30px;
        padding-right: 30px;
        margin-top: 10px;
        padding-bottom: 10px;
        border-bottom: 1px solid #d1d1d1;
    }

    .mobileSortFilter .sortClickThrough {
        pointer-events: none;
    }

    .mobileSortFilter .sortClickThrough,
    .mobileSortFilter .sortSelect {
        left: 0;
    }

    .mobileSortFilter .showFilters {
        right: 0;
    }

    .mobileSortFilter .sortClickThrough {
        z-index: 3;
    }

    .mobileSortFilter .sortClickThrough,
    .mobileSortFilter .showFilters {
        padding-left: 5px;
        padding-right: 5px;
        text-overflow: ellipsis;
        white-space: nowrap;
        overflow: hidden;
        text-align: center;
    }

    .mobileSortFilter .sortClickThrough i,
    .mobileSortFilter .showFilters i {
        margin-right: 5px;
    }

    .productItemNumber {
        margin-top: 45px;
        width: 100%;
        float: none;
        border-bottom: 1px solid #d1d1d1;
    }

    .productItemNumber .page-count-links,
    .productItemNumber .mobileListingOption {
        float: right;
    }

    .productItemNumber .mobileListingOption i {
        margin-left: 10px;
        line-height: 23px;
        text-align: center;
        width: 25px;
        border: 1px solid #d1d1d1;
        border-radius: 5px;
        -webkit-box-shadow: 0px 0px 1px 0px rgba(136, 136, 136, 1);
        -moz-box-shadow: 0px 0px 1px 0px rgba(136, 136, 136, 1);
        box-shadow: 0px 0px 1px 0px rgba(136, 136, 136, 1);
    }

    .productTile {
        width: 49.5%;
    }

    .mobileSingleItem .productTile {
        width: 100%;
        margin: auto;
    }

    .categoryHero {
        display: none;
    }

    /* CMS Components */
    .contentCarousel,
    .productCarousel,
    .col-mobileCarousel {
        padding: 0;
    }

    .col-mobileCarousel {
        margin-left: -15px;
        margin-right: -15px;
    }

    .productCarousel.stagePadding .productCarouselBlock {
        padding: 0;
    }

    .contentCarousel.owl-carousel .owl-nav,
    .productCarousel.owl-carousel .owl-nav {
        display: none;
    }

    .bannerContent h2,
    .bannerContent h1 {
        font-size: 2.4em;
    }

    .containerFullWidth .bannerContent,
    .containerFullWidth .mobileContentCenter .bannerContentInner {
        width: 100%;
        margin-left: 0;
        margin-right: 0;
    }

    .containerFullWidth .mobileContentLeft .bannerContentInner {
        float: left;
        margin-left: 2.5%;
        margin-right: 0;
        width: 75%;
    }

    .containerFullWidth .mobileContentRight .bannerContentInner {
        float: right;
        margin-left: 0;
        margin-right: 2.5%;
        width: 75%;
    }

    .mobileContentTop {
        top: 25%;
        transform: translateY(-50%);
    }

    .mobileContentMiddle {
        top: 50%;
        transform: translateY(-50%);
    }

    .mobileContentBottom {
        top: 70%;
        transform: translateY(-50%);
    }

    .uspBar {
        margin-bottom: 0;
        margin-top: 0;
    }

    .uspBarMobile {
        display: block;
    }

    .uspBarDesktop {
        display: none;
    }

    .cmsContainer .blockComponent {
        margin-top: 0px;
        margin-bottom: 30px;
    }

    .cmsContainer .blockComponent:first-child {
        margin-top: 0;
    }

    .cmsContainer .blockComponent:last-child {
        margin-bottom: 0px;
    }

    /* Account Login / Register */
    .signInRegister h1 {
        margin: 50px auto 30px;
        font-size: 1.333em;
    }

    .signInRegister p {
        font-size: 0.875em;
        margin-bottom: 20px;
    }

    .loginForm,
    .registerForm,
    .loginToRegisterBlock,
    .registerToLoginBlock {
        padding: 25px 0 0 0;
        border: none;
    }

    .loginToRegisterBlock,
    .registerToLoginBlock {
        border-top: 1px solid #d9d7d7;
    }

    .termsAndConditionsPopup {
        max-height: 100%;
        height: 100%;
    }

    .forgottenPassword,
    .forgottenPasswordSuccess {
        top: 25%;
        transform: none;
        left: 0;
    }

    .forgottenPassword > h2,
    .forgottenPasswordSuccess > h2 {
        font-size: 1.2em;
    }

    /* Checkout Styles */
    .header.checkoutHeader .col-md-4 {
        height: 50px;
    }

    .header.checkoutHeader a {
        line-height: 1.2em;
        font-size: 0.8em;
        max-width: 75px;
        margin-top: 10px;
    }

    .header.checkoutHeader .checkoutHeaderLogo {
        width: 100%;
    }

    .header.checkoutHeader .checkoutHeaderNortonSeal {
        right: 15px;
        width: 100%;
        max-width: 80px;

    }

    .footer.checkoutFooter {
        margin-top: 25px;
        height: auto;
        padding-bottom: 20px;
    }

    .footer.checkoutFooter .checkoutFooterRow {
        text-align: center;
        height: 50px;
    }

    .footer.checkoutFooter .checkoutFooterRow {
    }

    .footer.checkoutFooter .checkoutFooterRow span {
        float: none;
    }

    .checkoutFormInputBlock-HalfWidth {
        width: 100%;
    }

    .checkoutFormInputBlock-HalfWidth {
        width: 100%;
    }

    .addressVerificationPopup, #pickUpFromStorePopup, #returnExpiredOrderPopup {
        margin: 0;
        height: 100%;
        overflow: scroll;
        padding: 20px 0;
    }

    .addressVerificationPopup {
        padding: 20px;
    }

    .addressVerificationPopupBlockContainer {
        padding-left: 10px;
        padding-right: 10px;
    }

    #shippingAddressVerificationPopup, #billingAddressVerificationPopup {
        padding: 40px 0;
    }

    .addressVerificationPopupBlock button, .addressVerificationPopupBlock .useRecommendedDeliveryAddress {
        width: 100%;
        max-width: none;
        margin-bottom: 15px;
    }

    .addressVerificationEdit {
        margin-bottom: 15px;
    }

    .addressPickerPopupBlock {
        width: 100%;
        margin-bottom: 30px;
    }

    .shippingPickUpBlock form button, .orderConfirmationCreateAccountForm form button {
        margin: 30px 0;
    }

    .checkoutProgress {
        margin-bottom: 30px;
    }

    .addressVerificationPopup h2, .addressPickerPopup h2, #returnExpiredOrderPopup h2 {
        font-size: 16px;
        line-height: 24px;
    }

    /* Cart Page Mobile */
    .cartProductListHeader, .cartProductHeader {
        display: none;
    }

    .cartTop {
        margin-bottom: 20px;
    }

    .cartTop h1 {
        width: 80%;
        margin: 5px auto;
        font-size: 1em;
    }

    .cartTop .cartNortonSealMobile {
        display: block;
        width: 15%;
        position: absolute;
        top: -20px;
        right: 0;
    }

    .cartProductList .cartProductRow:before {
        content: "";
        width: calc(100% - 30px);
        border-top: 1px solid #ddd;
        margin: -15px 15px 15px;
    }

    .cartProductList > div:last-child:after {
        content: "";
        width: calc(100% - 30px);
        border-top: 1px solid #ddd;
        margin: 15px 15px 0;
    }

    .cartProductList .cartProductRow {
        border: none;
        padding-bottom: 15px;
    }

    .checkoutCartSummaryDesktop h2, .checkoutCartSummaryDesktop .checkoutCartSummaryProducts {
        display: none;
    }

    .checkoutCartSummaryDesktop {
        border: none;
    }

    .checkoutCartSummaryDesktop .checkoutCartSummarySubTotals, .checkoutCartSummaryDesktop .checkoutCartSummaryTotal {
        padding: 15px 5px;
    }

    .checkoutCartSummaryMobile {
        display: block;
        background-color: #f5f5f5;
        margin-bottom: 30px;
        border-left: none;
        border-right: none;
    }

    .checkoutCartSummaryMobile .checkoutCartSummarySubTotals, .checkoutCartSummaryMobile .checkoutCartSummaryTotal {
        display: none;
    }

    .checkoutCartSummaryMobile .checkoutCartSummaryProducts {
        border-bottom: none;
        display: none;
    }

    .checkoutCartSummaryMobile h2 {
        border-bottom: none;
        cursor: pointer;
    }

    .checkoutCartSummaryMobile h2:after {
        content: "\f054";
        font-family: Font Awesome\ 5 Pro;
        float: right;
        margin-right: 15px;
    }

    .checkoutCartSummaryMobile.open h2:after {
        content: "\f078";
    }

    .checkoutCartSummaryMobile.open .checkoutCartSummaryProducts {
        display: block;
    }

    .cartProductItemPrice {
        display: none;
    }

    .cartProductQuantityBlock {
        display: inline-block;
    }

    .cartProductList .cartProductDetailsInfo > span.cartProductDetailsInfoLinks a {
        border: none;
        font-size: 0.667em;
        padding: 0 15px 0 0;
    }

    .cartProductDetailsInfo {
        margin-bottom: 25px;
    }

    .cartProductList .cartProductRow .cartProductQuantityCol {
        display: inline-block;
        margin-left: 100px;
        width: calc(60% - 50px);
    }

    .cartProductList .cartProductRow .cartProductSubtotal {
        display: inline-block;
        width: calc(40% - 50px);
        padding-right: 15px;
        padding-left: 0;
        float: right;
    }

    .cartProductList .cartProductRow .cartProductDetails {
        display: inline-block;
    }

    .cartPromotionBlock .promotionInputBlock.hiddenMobile {
        display: none;
    }

    .cartPromotionBlock .promotionInputBlock {
        width: 100%;
    }

    .cartPromotionBlock h2 {
        text-align: right;
        margin-top: 0;
        margin-bottom: 15px;
        line-height: 1.25em;
    }

    .cartPromotionBlock {
        border-bottom: 1px solid #ddd;
        margin-bottom: 10px;
    }

    .cartSummary .cartPromotionBlock h2 {
        margin-top: 15px;
    }

    .cartSummary .cartPromotionBlock {
        border-top: 1px solid #ddd;
    }

    .showGiftWrapOptionsBlock {
        padding-left: 15px;
    }

    .giftWrapWrappedOptions {
        position: absolute;
        bottom: -35px;
        left: 15px;
    }

    .giftWrapTypeDetailsBlock {
        min-height: 100px;
        margin-bottom: 50px;
    }

    .giftWrapMessageUndertext {
        font-size: 12px;
    }

    .giftWrapAddButton {
        width: 100%;
    }

    .giftWrapSubtotal span {
        line-height: 40px;
    }

    .giftWrapAppliedBlockActions a {
        font-size: 10px;
        margin-left: 10px;
    }

    .giftWrapAppliedBlockActions a:first-child {
        padding-right: 10px;
    }

    .giftWrapAppliedBlock .giftWrapSubtotal {
        padding: 0;
        margin: 0;
        width: auto;
        position: absolute;
        bottom: -5px;
        right: 15px;
    }

    .giftWrapAppliedBlock .giftWrapTypeDetailsBlock {
        margin-bottom: 10px;
    }

    .giftWrapAppliedBlock .giftWrapSubtotal span {
        line-height: initial;
    }

    .giftWrapDetailsBlock .giftWrapSave,
    .giftWrapDetailsBlock .giftWrapSubtotal {
        margin-top: 0;
    }

    .deliveryOptionBlock .deliveryOptionMain {
        padding: 20px 0;
        border-left: none;
        border-right: none;
    }

    .deliveryOptionBlock {
        margin: 2.5em -15px;
        width: calc(100% + 30px);
    }

    .deliveryOptionBlock .deliveryOptionTabShipping {
        border-left: none;
    }

    .deliveryOptionBlock .deliveryOptionTabCollect {
        border-right: none;
    }

    .deliveryOptionsValue {
        padding-left: 0;
        white-space: nowrap;
    }

    .cartPage button.btn-block.btn--continue-checkout {
        width: 100%;
    }

    .cartProductList .cartProductDetailsInfo > span.cartProductDetailsInfoLinks a:last-child {
        padding: 0;
    }

    .orderConfirmationOrderSummary {
        margin: auto -15px;
    }

    .pickUpPopupInnerMap {
        display: none;
    }

    .pickUpPopupInnerStoreList {
        width: 100%;
    }

    #pickUpFromStorePopup h2 {
        font-size: 1.2em;
    }

    #pickUpPopupResultsBlock .findAStoreSearchBoxResult > * {
        max-width: 100%;
    }

    #pickUpPopupResultsBlock .storeFinderSelectBlock {
        left: 0;
        top: initial;
        bottom: 10px;
        padding: 0 20px;
        width: 100%;
    }

    #pickUpPopupResultsBlock .findAStoreSearchBoxResult {
        padding-bottom: 64px;
    }

    .findAStoreSearchBoxResult .storeFinderOpeningHourDay {
        width: 45px;
    }

    #pickUpPopupResultsBlock .collectionDate {
        width: 60%;
        float: left;
        line-height: 34px;
    }

    #pickUpPopupResultsBlock .storePickUpSelect {
        float: right;
        margin: 0;
        width: 40%;
        text-align: center;
        padding: 0;
    }

    .checkoutLoginForm {
        padding: 0;
        border: none;
    }

    .checkoutStep {
        width: 32.4%;
        font-size: 0.667em;
    }

    .shippingPickUpSwitcherOption {
        font-size: 0.8em;
    }

    #checkoutPopupBackground {
        overflow-y: initial;
    }

    .addressVerificationPopup, #pickUpFromStorePopup, .addressPickerPopup {
        padding: 30px 20px;
        margin: 0 auto;
        top: 0;
        height: 100%;
        width: 100%;
        overflow-x: hidden;
        overflow-y: auto;
    }

    /* Account Area */
    .accountHeaderBlock {
        margin-top: 30px;
    }

    .accountHeaderBlock h1 {
        margin-bottom: 30px;
    }

    .accountMenu,
    .accountMenu.overviewActive .accountOverviewLink {
        display: none;
    }

    .accountMenu.overviewActive {
        display: block;

    }

    .accountMobileOverview {
        padding: 0;
    }

    .accountHeaderBlock span, .accountMobileHeaderMessage {
        text-align: center;
        display: inline-block;
        width: 100%;
    }

    .accountMobileHeaderMessage {
        line-height: 4em;
    }

    .accountMainSectionHeader h2 {
        width: 100%;
        max-width: 100%;
        text-align: center;
    }

    .accountMainSectionHeader {
        position: relative;
    }

    .accountMobileBackButton {
        position: absolute;
        top: 20px;
        line-height: 30px;
        display: block;
        width: 30px;
        text-align: center;
        font-size: 0.933em;
    }

    .accountMainSectionInner .accountMainAction > a {
        position: initial;
        display: block;
        margin-top: 15px;
    }

    .accountMainSectionInner .row.accountOrderListBody {
        margin-bottom: 60px;
    }

    .accountOrderListHeader:before {
        width: calc(100% - 30px);
    }

    .accountMainSectionInner .row.accountWishlistListBody {
        margin-bottom: 60px;
    }

    .accountArea .btn.btn-primary, .accountAddNewAddress, #accountAddressForm .addressFormDeleteButton {
        width: 100%;
        text-align: center;
    }

    .accountVerified h1 {
        font-size: 1em;
        line-height: 1.5em;
    }

    .accountVerified .accountMainSectionInner .accountMainAction .accountMainActionSubmit {
        width: 100%;
        margin: 10px 0 0 0;
    }

    #accountAddressForm .addressFormDeleteButton {
        margin-left: 0;
        margin-top: 20px;
    }

    #wishlistAddToCartBtn, #wishlistRemoveBtn,
    #guestWishlistAddToCartBtn, #guestWishlistRemoveBtn {
        width: calc(100% - 30px);
        margin-left: 15px;
    }

    .orderListReturnHeader {
        border-bottom: 1px solid #ddd;
        margin: 0 2% 30px 2%;
    }

    .orderSummaryContainer {
        padding: 0px;
        width: 100%;
    }

    .returnOrderSummary {
        border-bottom: 0px;
    }

    .returnOrderSummaryProductImage, .returnOrderSummaryProductImage img {
        width: 120px;
        height: auto;
    }

    .returnOrderSummaryPrice {
        clear: both;
    }

    .returnOrderSummaryReason {
        width: 100%;
        align-content: center;
        margin-top: 20px;
    }

    .returnOrderComment {
        width: 100%;
        margin-left: 0px;
    }

    .returnOrderCommentLettersLeft {
        float: right;
    }

    .returnOrderSummaryPriceBlock {
        border-top: 0px;
        border-bottom: 0px;
    }

    .returnOrderSummaryTotalPriceBlock {
        padding-top: 0px;
    }

    .returnOrderBackButton, .returnOrderBackButton:hover, .returnOrderBackButton:focus,
    .returnOrderContinueButton, .returnOrderContinueButton:hover, .returnOrderContinueButton:focus {
        width: 100%;
        float: none;
        margin-bottom: 25px;
        height: 50px;
    }

    .returnOrderButtonBlock {
        margin-left: 25px;
        margin-right: 25px;
    }

    .returnOrderFormActions {
        width: 100%;
    }

    .returnOrderPrintButton, .returnOrderPrintButton:hover, .returnOrderPrintButton:focus,
    .returnOrderDownloadButton, .returnOrderDownloadButton:hover, .returnOrderDownloadButton:focus {
        width: 100%;
        height: 50px;
        margin-bottom: 20px;
    }

    .returnFormItemInputBlock {
        width: 100%;
        margin-top: 0;
    }

    .returnOrderSummaryReason, .returnOrderCommentBLock {
        width: 100%;
    }

    .accountReturnDetailsMobile {
        display: block;
    }

    .accountReturnDetailsDesktop {
        display: none;
    }

    #paypal-button-container {
        margin: 0px 0px 17px 0px;
        width: 100%;
    }
}

@media (max-width: 499px) {
    .returnOrderSummaryProductDetails {
        width: 38%;
    }

    .returnOrderSummaryReason, .returnOrderComment {
        font-size: 0.87em;

    }
}

@media (max-width: 700px) {
    .giftwrapWarning {
        position: absolute;
        width: 100%;
        height: 100%;
        top: 0;
        background-color: white;
        padding: 25px;
        z-index: 9;
        transform: none;
        left: 0;
    }

    .giftwrapWarningMessage {
        text-align: left;
        position: relative;
        padding-left: 48px;
        padding-right: 24px;
        font-size: 0.95em;
        line-height: 24px;
    }

    .cartPaymentButtonsBlock {
        width: 100%;
        float: none;
    }

    .productTileAffirmFinance {
        padding-left: 15px;
        padding-right: 15px;
    }
}

/* IE 10+ */
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
    select.sortSelect::-ms-expand {
        border: none;
        background: #fff;
    }

    .middleHeader .hasTerm .search-clear {
        display: none;
    }

    #storeFinderBrandSelector::-ms-expand {
        display: none;
    }
}

.middleHeader .search-form input::-ms-clear {
    display: none;
}

/* ASM Styling */

body #_asm .ASM_header .first-top-row {
    margin: 0 -2em 10px -4em;
    padding: 0 1em 0 4em;
}

body #_asm .collapseBtn-wrapper {
    right: 0;
}

ul#customer-360-tabs li[value*='storeLocationsSection'],
ul#customer-360-tabs li[value*='feedbackSection'] {
    display: none;
}

.asm__customer360, .js-customer-list-modal-content {
    padding: 15px;
    margin-bottom: 5px;
}

/* Single Page Checkout */

#spCheckoutContainer {
    letter-spacing: 0.03em;
}


.spCheckoutPanel {
    max-width: 390px;
    margin: 0 auto 75px;
}

.checkoutSignInBlockForm {
    display: none;
}

.checkoutSignInBlockForm-active {
    display: block;
}

.spCheckoutShowPassword {
    display: none;
}

.hasContent ~
.spCheckoutShowPassword,
.focus-visible ~
.spCheckoutShowPassword {
    display: block;
    position: absolute;
    right: 15px;
    top: 0;
    line-height: 60px;
    cursor: pointer;
    font-size: 20px;
}

#spCheckoutLoadingBlock,
#basketLoadingBlock {
    position: fixed;
    top: 0;
    left: -999%;
    height: 100%;
    width: 100%;
    z-index: 999;
    background-color: rgba(0, 0, 0, 0.5);
}

#spCheckoutLoadingBlock.show,
#basketLoadingBlock.show {
    left: 0;
}

#spCheckoutLoadingInnerBlock,
#basketLoadingInnerBlock {
    width: 100px;
    height: 100px;
    font-size: 50px;
    line-height: 100px;
    position: absolute;
    top: 50%;
    left: 50%;
    color: white;
    text-align: center;
    transform: translate(-50px, -50px);
}

#spCheckoutPopupBlock,
#spCheckoutPopupBlockBackground,
.slideInPopup, .slideInPopupBackground {
    opacity: 0;
    position: fixed;
    height: 100%;
    top: 0;
    width: 100%;
    max-width: 500px;
    background-color: white;
    z-index: -999;
}

#spCheckoutPopupBlockBackground,
.slideInPopupBackground {
    pointer-events: none;
}

#spCheckoutPopupBlock,
.slideInPopup {
    right: -500px;
    transition: right ease 500ms 100ms;
    -moz-transition: right ease 500ms 100ms;
    -o-transition: right ease 500ms 100ms;
    -webkit-transition: right ease 500ms 100ms;
}

#spCheckoutPopupBlockBackground,
.slideInPopupBackground {
    min-width: 100%;
    right: 0;
    background-color: rgba(0, 0, 0, 0.3);
}

#spCheckoutPopupBlock.spCheckoutPopupBlock-show,
.slideInPopup.slideInPopup-show {
    z-index: 999;
    right: 0;
    opacity: 1;
    overflow-y: auto;
}

#spCheckoutPopupBlock.spCheckoutPopupBlock-hide,
.slideInPopup.slideInPopup-hide {
    z-index: 999;
    right: -500px;
    opacity: 1;
    overflow-y: auto;
}

#spCheckoutPopupBlock.spCheckoutPopupBlock-show ~ #spCheckoutPopupBlockBackground,
.slideInPopup.slideInPopup-show ~ .slideInPopupBackground,
#spCheckoutPopupBlock.spCheckoutPopupBlock-hide ~ #spCheckoutPopupBlockBackground,
.slideInPopup.slideInPopup-hide ~ .slideInPopupBackground {
    z-index: 998;
    opacity: 1;
    pointer-events: initial;
}

.spCheckoutPopupHeader, .slideInPopupHeader {
    position: relative;
    line-height: 60px;
    font-size: 1.375em;
    text-align: center;
    border-bottom: 1px solid #C2C2C2;
}

.spCheckoutPopupClose,
.slideInPopupClose,
.spCheckoutPopupBack {
    position: absolute;
    right: 10px;
    top: 10px;
    line-height: 40px;
    font-size: 26px;
    width: 40px;
    cursor: pointer;
}

.spCheckoutPopupBack {
    right: unset;
    left: 10px;
}

.spCheckoutPopupContent {
    padding: 0 20px;
}

#spCheckoutCardSubmitButton {
    display: none;
}

#spCheckoutPaymentErrorContainer {
    display: none;
    height: 92px;
    border: 3px solid #FF0000;
    max-width: 927px;
    margin: 30px auto;
    padding: 13px 18px;
}

#spCheckoutPaymentErrorImage {
    width: 60px;
    height: 60px;
    float: left;
    display: inline-block;
    margin-right: 15px;
}

#spCheckoutPaymentErrorMessage {
    display: table-cell;
    vertical-align: middle;
    text-align: left;
}

#spCheckoutPaymentErrorReason {
    font-weight: bold;
}


.singlePageCheckoutLoginContainer h1, h2.spCheckoutDeliveryTitle {
    font-size: 1.625em;
    font-weight: bold;
    text-align: center;
    margin: 25px auto;
    line-height: 28px;
}

.singlePageCheckoutLoginContainer h1 {
    border-bottom: 1px solid #eee;
    padding-bottom: 20px;
}

.checkoutSignInBlock {
    max-width: 390px;
    margin: 50px auto;
}

.checkoutSignInBlockOptions, .checkoutDeliveryChoiceOptions {
    display: flex;
    flex-wrap: wrap;
}

.checkoutDeliveryChoiceOptions {
    max-width: 390px;
    margin: 13px auto 10px;
}

.checkoutSignInBlockOption, .checkoutDeliveryChoiceOption {
    display: flex;
    width: 50%;
    border: 1px solid #BCBCBC;
    height: 78px;
    justify-content: center;
    align-items: center;
    font-weight: bold;
    text-align: center;
    cursor: pointer;
    text-transform: capitalize;
}

.checkoutDeliveryChoiceOption-disabled {
    display: flex;
    width: 50%;
    border: 1px solid #BCBCBC;
    height: 78px;
    justify-content: center;
    align-items: center;
    font-weight: bold;
    text-align: center;
    cursor: no-drop;
    color: #D9D9D9;
    background-color: #F3F3F3;
}

.checkoutDeliveryChoiceOptions.noneSelected .checkoutSignInBlockOption:first-child,
.checkoutDeliveryChoiceOptions.noneSelected .checkoutDeliveryChoiceOption:first-child {
    border-right: none;
}

.checkoutSignInBlockOption.checkoutSignInBlockOption-guest, .checkoutDeliveryChoiceOption.checkoutDeliveryChoiceOption-delivery {
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
}

.checkoutSignInBlockOption.checkoutSignInBlockOption-signIn, .checkoutDeliveryChoiceOption.checkoutDeliveryChoiceOption-collect {
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
}

.checkoutSignInBlockOption-guest {
    border-right: none;
}

.checkoutSignInBlockOption-signIn {
    border-left: none;
}

.checkoutSignInBlockOption.selected, .checkoutDeliveryChoiceOption.selected {
    border: 2px solid black;
}

.spGuestFormEmailConfirmBlock {
    letter-spacing: 0.03em;
    position: relative;
    padding-left: 18px;
    margin-top: 25px;
}

.spGuestFormEmailConfirmBlock div {
    font-size: 1.375em;
    font-weight: bold;
    margin-top: 9px;
    line-height: 28px;
    overflow-wrap: break-word;
}

.spGuestFormEmailConfirmBlock:before {
    content: "";
    position: absolute;
    display: block;
    height: 100%;
    top: 0;
    left: 0;
    width: 5px;
    background: #C4C4C4;
}

.checkoutSignInDescription {
    margin-top: 15px;
    font-size: 1.125em;
    margin-bottom: 25px;
}

.spForgottenPassword {
    color: black;
    text-decoration: underline;
    margin-top: 10px;
    display: inline-block;
}

.spCheckoutFormGroup {
    width: 100%;
    min-height: 60px;
    position: relative;
    margin-top: 10px;
}

.spCheckoutFormGroup-termsCheck {
    padding-left: 30px;
}

.spCheckoutFormGroup-termsCheck input#termsCheck {
    position: absolute;
    left: 0;
}

.spCheckoutFormGroup.spCheckoutFormGroupCheckbox {
    min-height: 30px;
}

.spCheckoutFormInput {
    display: block;
    width: 100%;
    height: 60px;
    padding: 20px 0 0 18px;
    line-height: 21px;
    border: 1px solid #BCBCBC;
}

.spCheckoutFormLabel {
    font-size: 0.875em;
    line-height: 18px;
    position: absolute;
    top: 22px;
    left: 20px;
    pointer-events: none;
    transition: 0.2s ease all;
    text-transform: capitalize;
}

select.spCheckoutFormInput {
    -webkit-appearance: none;
    -moz-appearance: none;
    background: #fff url(/_ui/responsive/common/images/dropdown-chevron.png) no-repeat right 15px center;
}

.spCheckoutFormInput:focus ~ .spCheckoutFormLabel,
.spCheckoutFormInput.hasContent ~ .spCheckoutFormLabel,
.spFormError .spCheckoutFormInput ~ .spCheckoutFormLabel {
    top: 5px;
    font-size: 11px;
    line-height: 14px;
}

.spCheckoutFormGroupSubText {
    color: #282828;
    font-size: 13px;
    line-height: 24px;
    height: 24px;
    margin-top: 10px;
}

.singlePageStatusHeader {
    display: flex;
    max-width: 922px;
    margin: auto
}

.spCheckoutStatus {
    display: flex;
    width: 33.3%;
    padding: 25px 0;
    position: relative;
    font-size: 0.938em;
    color: #7b7b7b;
    line-height: 19px;
}

.spCheckoutStatus span {
    width: 100%;
    display: inline-block;
    text-align: center;
}

.spCheckoutStatus span:after {
    content: "";
    position: absolute;
    bottom: 0;
    width: 100%;
    left: 0;
    border-bottom: 5px solid #cccccc;
}

.spCheckoutStatus.active span:after {
    border-color: black;
}

input#pacInputPickup::placeholder {
    color: white;
}

#spCheckoutUseMyCurrentLocation {
    font-size: 0.875em;
    margin-top: 7px;
    line-height: 18px;
    text-decoration: underline;
    cursor: pointer;
    display: inline-block;
}

.spCheckoutPanel button[type=submit],
.basketPromotionCodeSubmit,
.spAddressBookNewAddressButton,
#spEditAddressForm button[type=submit],
#createAccountSubmit,
.spCheckoutAddressesBlockAction-select,
.spCheckoutPopupContentFPForm button[type=submit] {
    line-height: 60px;
    padding: 0;
    width: 100%;
    border-radius: 0;
    margin-top: 30px;
    border-color: transparent;
    font-size: 1.125em;
    color: #000;
    font-weight: bold;
    text-transform: capitalize;
}

.spCheckoutPanel button[type=submit], .basketPromotionCodeSubmit,
.spAddressBookNewAddressButton, #spEditAddressForm button[type=submit],
#createAccountSubmit, .spCheckoutAddressesBlockAction-select,
.spCheckoutPopupContentFPForm button[type=submit], .spCheckoutCollectStoreSelect,
#adyenDummyPaymentButton, .spFinancePaymentContainer div#v12FinanceDepositEditUpdate,
#spFinanceV12Button, button.adyen-checkout__button, .giftWrapSaveButton, #paypalReviewPayNow {
    background-color: #A6182E;
    color: white;
    text-transform: capitalize;
}

.spCheckoutAddressesBlockAction-select {
    text-align: center;
    cursor: pointer;
    margin-top: 20px;
}

.basketPromotionCodeSubmit {
    margin-top: 10px;
    width: 84px;
    display: inline-block;
    float: right;
    height: 60px;
    line-height: 55px;
}

.basketPromotionInputBlock .spCheckoutFormGroup {
    width: calc(100% - 84px);
    display: inline-block;
}

.basketPromotionInputBlock .spCheckoutFormGroup input {
    border-right: none;
}

#spEditAddressForm button[type=submit] {
    margin-top: 15px;
    margin-bottom: 50px;
}

#createAccountSubmit {
    margin-top: 20px;
    -webkit-transition: opacity 0.5s ease-out;
    -moz-transition: opacity 0.5s ease-out;
    -o-transition: opacity 0.5s ease-out;
    transition: opacity 0.5s ease-out;
}

#createAccountSubmit[disabled] {
    cursor: not-allowed;
    filter: alpha(opacity=65);
    -webkit-box-shadow: none;
    box-shadow: none;
    opacity: .65;
}

#spCheckoutUseSavedShowrooms {
    border: 1px solid #c4c4c4;
    background-color: transparent;
    margin-top: 10px;
    color: black;
}

.spCheckoutSectionTitle {
    font-size: 1.125em;
    font-weight: bold;
    line-height: 60px;
    position: relative;
}

.spCheckoutSectionTitleRequired {
    font-size: 13px;
    font-weight: normal;
    position: absolute;
    top: 0;
    right: 0;
}

.spCheckoutCollectNoResults {
    font-size: 1.125em;
    font-weight: bold;
    line-height: 60px;
    text-align: center;
    margin-top: 25px;
}

.spCheckoutCollectStore {
    border: 1px solid #BCBCBC;
    box-sizing: border-box;
    border-radius: 5px;
    padding: 20px 15px;
    position: relative;
    margin-bottom: 15px;
}

.spCheckoutCollectStore.spCheckoutCollectSelectedStore {
    background-color: #EBEBEB;
    border-color: #EBEBEB;
}

.spCheckoutChangeStore {
    font-size: 0.875em;
    text-decoration: underline;
    line-height: 20px;
    cursor: pointer;
    display: inline-block;
}

.spCheckoutCollectStoreName, .spCheckoutCollectStoreDistance {
    font-size: 1.125em;
    font-weight: bold;
    line-height: 24px;
    display: block;
}

.spCheckoutCollectStoreDistance {
    position: absolute;
    right: 30px;
    top: 20px;
}

.spCheckoutCollectStoreLeadTime {
    font-size: 0.875em;
    line-height: 20px;
    margin: 10px auto;
}

.spCheckoutCollectStoreShowMap,
.spCheckoutSaveShowroom,
.spCheckoutRemoveShowroom {
    display: inline-block;
    font-size: 0.875em;
    text-decoration: underline;
    cursor: pointer;
}

.spCheckoutSaveShowroom,
.spCheckoutRemoveShowroom {
    margin-left: 7px;
    border-left: 1px solid #BCBCBC;
    padding: 0 0 0 12px;
}

.spCheckoutSaveShowroom ~ .spCheckoutSaveShowroomCheck {
    display: none;
}

.spCheckoutSaveShowroom.saved ~ .spCheckoutSaveShowroomCheck {
    display: inline-block;
}

.spCheckoutSaveShowroom.saved {
    cursor: default;
}

.spCheckoutCollectStoreSelect {
    display: block;
    width: 135px;
    line-height: 40px;
    margin-top: 15px;
    background-color: #C4C4C4;
    text-align: center;
    font-size: 0.875em;
    font-weight: bold;
    cursor: pointer;
}

.spCheckoutStoreName {
    font-size: 1.375em;
    font-weight: bold;
    line-height: 60px;
    text-align: center;
}

#spCheckoutStoreDetailsMap {
    width: 100%;
    height: 160px;
    margin-bottom: 20px;
}

.spCheckoutStoreName {
    font-size: 1.375em;
    font-weight: bold;
    line-height: 60px;
    text-align: center;
}

.spCheckoutStoreDetailsSubTitle {
    font-size: 1.125em;
    font-weight: bold;
    line-height: 22px;
    margin-bottom: 15px;
    text-align: center;
}

.spCheckoutStoreDetailsSection {
    text-align: center;
    line-height: 1.5em;
    margin-bottom: 25px;
}

.spCheckoutStoreDetailsDay,
.spCheckoutStoreDetailsHours {
    display: inline-block;
}

.spCheckoutStoreDetailsDay {
    width: 50px;
    text-align: left;
    margin-left: 25px;
}

.spCheckoutStoreDetailsHours {
    width: 150px;
    text-align: left;
}

.spCheckoutCollectStoreSelect.spCheckoutCollectStorePopupSelect {
    width: 100%;
    line-height: 60px;
    font-size: 1em;
    cursor: pointer;
}

.spCheckoutPaymentPanelBlock {
    max-width: 922px;
    margin: 30px auto auto;
}

.spCheckoutDesktopCartSummary {
    width: 445px;
    padding: 20px 25px;
    background-color: #F9F9F9;
    float: right;
}

.spCheckoutPaymentPanelBlock:after {
    content: "";
    display: block;
    height: 0;
    clear: both;
}

.spCheckoutDesktopCartSummary h2 {
    font-size: 1.125em;
    font-weight: bold;
    line-height: 23px;
    margin: 0;
}

.spCheckoutMobileCartSummary {
    margin: 30px auto 15px;
}

.spCheckoutMobileCartSummary .spCheckoutMobileCartSummaryRow {
    line-height: 35px;
}

.spCheckoutMobileCartSummary .spCheckoutMobileCartSummaryRow.spCheckoutMobileCartSummaryRow-total {
    border-top: 1px solid #B0B0B0;
    border-bottom: 1px solid #B0B0B0;
    margin: 10px auto;
    line-height: 45px;
}

.spCheckoutMobileCartSummary .spCheckoutMobileCartSummaryRowValue {
    float: right;
    font-weight: bold;
}

.spCheckoutCartSummaryProducts {
    margin-top: 30px;
}

.spCheckoutCartSummaryProductsRow {
    display: inline-block;
    width: 100%;
    margin-bottom: 25px;
}

.spCheckoutCartSummaryProductImage {
    width: 29%;
    display: inline-block;
    float: left;
    margin-right: 3%;
}

.spCheckoutCartSummaryProductImage img {
    width: 100%;
}

.spCheckoutCartSummaryProductDetails {
    width: 68%;
    display: inline-block;
    float: left;
    font-size: 0.938em;
    line-height: 19px;
    height: 115px;
    position: relative;
}

.spCheckoutCartSummaryProductBrand {
    font-weight: bold;
}

.spCheckoutCartSummaryProductCode {
    color: #606060;
}

.spCheckoutCartSummaryProductPriceQty {
    position: absolute;
    bottom: 0;
    width: 100%;
    left: 0;
}

.spCheckoutCartSummaryProductPriceQty span {
    float: right;
}

.spCheckoutCartSummarySubTotals,
.spCheckoutCartSummaryTotalsAndTax {
    border-top: 1px solid #EEE;
    margin-top: 10px;
}

.spCheckoutPopupContent .spCheckoutCartSummarySubTotals,
.spCheckoutPopupContent .spCheckoutCartSummaryTotalsAndTax {
    border-top: none;
    margin-top: 0;
    border-bottom: 1px solid #EEE;
    margin-bottom: 10px;
}

.spCheckoutCartSummarySubTotals > div,
.spCheckoutCartSummaryTotalsAndTax > div {
    font-size: 16px;
    margin: 9px auto;
    line-height: 21px;
}

.spCheckoutCartSummarySubTotals > div > span,
.spCheckoutCartSummaryTotalsAndTax > div > span {
    float: right;
}

.spCheckoutPopupContent .spCheckoutCartSummarySubTotals > div > span,
.spCheckoutPopupContent .spCheckoutCartSummaryTotalsAndTax > div > span {
    font-weight: bold;
}

.spCheckoutPopupContent .spCheckoutCartSummaryTotalsAndTax {
    margin-bottom: 40px;
}

.spCheckoutPopupContentParagraph {
    line-height: 24px;
    margin: 25px 20px;
    text-align: center;
}

.spCheckoutMobileOrderSummaryBar {
    background-color: #F9F9F9;
    border-bottom: 1px solid #DEDEDE;
    padding: 0 23px;
    font-size: 0.938em;
    etter-spacing: 0.03em;
    line-height: 60px;
    max-width: 922px;
    margin: auto;
}

.spCheckoutMobileOrderSummaryBar div {
    float: right;
    cursor: pointer;
    text-decoration: underline;
    font-weight: bold;
}

.spCheckoutSectionOrderDetails {
    background-color: #EBEBEB;
    padding: 15px 15px 15px 10px;
}

.spCheckoutSectionOrderRowQuantity {
    display: inline-block;
    width: 25px;
    text-align: right;
}

.spCheckoutSectionOrderRowName {
    display: inline-block;
}

.spCheckoutSectionOrderRowPrice {
    display: inline-block;
    float: right;
    width: 80px;
    text-align: right;
}

.spCheckoutSectionOrderRowCode {
    padding-left: 30px;
    font-size: 0.75em;
    line-height: 15px;
    color: #606060;
    margin-bottom: 10px;
}


.spCheckoutSectionOrderRowQuantity,
.spCheckoutSectionOrderRowName,
.spCheckoutSectionOrderRowPrice {
    font-size: 0.875em;
    line-height: 25px;
    font-weight: bold;
}

.spCheckoutSectionOrderDetails.spCheckoutSectionOrderStoreDetails {
    padding: 15px;
    margin-bottom: 15px;
}

.spCheckoutOrderDetailsRow {
    font-size: 0.875em;
    line-height: 22px;
}

.spCheckoutSectionOrderStoreName,
.spCheckoutSectionOrderStoreDeliveryPrice {
    display: inline-block;
    font-weight: bold;
    line-height: 24px;
    margin-bottom: 10px;
}

.spCheckoutSectionOrderStoreDeliveryPrice {
    float: right;
}

.spCheckoutSectionOrderStoreAddress,
.spCheckoutSectionOrderStorePhone {
    font-size: 0.875em;
    line-height: 22px;
}

.spCheckoutSectionOrderStorePhone {
    margin-bottom: 10px;
}

.spCheckoutEditOrder,
.spCheckoutEditClickAndCollect,
.spCheckoutEditDelivery {
    font-size: 13px;
    font-weight: normal;
    position: absolute;
    top: 0;
    right: 0;
    text-decoration: underline;
    color: #000;
}

.spCheckoutPaymentOptionsBlock,
.spCheckoutPaymentBlock,
#spSecure3dComponent {
    max-width: 360px;
    width: 100%;
    float: left;
    position: relative;
    letter-spacing: 0.03em;
}

.spCheckoutPaymentOptionsBlock h3,
.spCheckoutPaymentBlock h3 {
    font-size: 1em;
    line-height: 21px;
    color: #969696;
    margin-top: 0;
}

.spCheckoutPaymentOptionBlock,
.spCheckoutPaymentOptionTopBlock {
    width: 100%;
    height: 80px;
    margin-bottom: 15px;
    border: 1px solid #BCBCBC;
    box-sizing: border-box;
    border-radius: 5px;
    padding: 15px 20px;
    position: relative;
    cursor: pointer;
}

.spCheckoutPaymentOptionTopBlock {
    border: 2px solid #000000;
}

.spCheckoutPaymentOptionBlockName {
    line-height: 50px;
    font-weight: bold;
}

.spCheckoutPaymentOptionBlockSubtext {
    font-size: 0.938em;
    line-height: 25px;
    position: absolute;
    bottom: 15px;
    left: 20px;
}

.spCheckoutPaymentOptionBlockSubtext ~ .spCheckoutPaymentOptionBlockName {
    line-height: 25px;
}

.spCheckoutPaymentOptionBlock + h3 {
    margin-top: 30px;
}

.spCheckoutBackToPaymentOptions {
    font-size: 0.875em;
    text-decoration: underline;
    position: absolute;
    right: 0;
    top: 0;
    cursor: pointer;
}

.spShowGiftOrInsuranceCard {
    font-size: 0.875em;
    text-decoration: underline;
    line-height: 18px;
    margin-bottom: 10px;
    cursor: pointer;
}

.spHallmarkPinMessage {
    margin-top: 10px;
    font-size: 0.85em;
}

.spAddGiftCardInput {
    padding-top: 10px;
    text-align: right;
    margin-left: 50%;
}

.cartPage {
    letter-spacing: 0.03em;
}

.basketTop h1 {
    font-size: 26px;
    font-weight: bold;
    line-height: 78px;
    text-align: center;
    border-bottom: 1px solid #EEEEEE;
    margin: 0 0 35px;
}

.basketBottom,
.checkoutBottom {
    line-height: 78px;
    text-align: center;
    border-top: 1px solid #EEEEEE;
    margin-top: 20px;
    letter-spacing: 0.03em;
    clear: both;
}

.basketBottom a,
.checkoutBottom a {
    color: #000000;
    font-weight: bold;
    text-decoration: none;
}

.basketProducts {
    display: inline-block;
    width: calc(100% - 500px);
}

.basketProductRow {
    position: relative;
    margin: 31px 0 34px;
}

.basketProductRow > a, .basketProductRow img.cartProductDetailsImg {
    position: absolute;
    left: 0;
    top: 0;
    display: inline-block;
    width: 150px;
    height: 150px;
    z-index: 1;
}

.basketProductDetailsInfo {
    display: inline-block;
    margin-left: 185px;
    padding-top: 5px;
    position: relative;
    width: calc(100% - 185px);
}

.basketProductDetailsTitle {
    max-width: 70%;
    font-size: 1.125em;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    line-height: 23px;
    max-height: 46px;
    overflow: hidden;
    color: #000;
    font-weight: bold;
}

.basketProductDetailsTitle:hover {
    color: #000;
    text-decoration: none;
}

.basketProductDetailsInfo > span.basketProductCode {
    display: block;
    font-size: 0.75em;
    color: #606060;
    line-height: 15px;
    margin-top: 8px;
}

.basketProductDetailsPrice {
    font-size: 1.125em;
    line-height: 23px;
    color: #000;
    font-weight: bold;
    text-align: right;
    position: absolute;
    top: 5px;
    right: 0;
}

.basketProductDetail-outOfStock {
    margin-top: 10px;
    font-size: 0.875em;
    color: #ff1010;
    line-height: 1.5em;
}

.basketProductDetailActionsBlock {
    height: 72px;
    width: 100%;
    margin-top: 10px;
}

.basketProductDetailActionsBlock > span {
    font-size: 0.875em;
    font-weight: bold;
    line-height: 18px;
}

.basketProductDetailActionsBlock > div {
    height: 41px;
    margin-top: 10px;
}

.basketProductDetailActionsBlock > .basketProductGiftWrapActions {
    margin-top: 28px;
}

.basketProductDetailActions {
    width: calc(100% - 65px);
    float: right;
    padding-top: 20px;
    display: flex;
    justify-content: flex-end;
}

.basketProductDetailQuantityBlock {
    display: inline-block;
}

select.basketProductQuantity {
    height: 41px;
    width: 61px;
    padding-left: 5px;
}

.basketProductDetailActions > a {
    display: inline-block;
    line-height: 21px;
    text-align: center;
    border-left: 1px solid #EEE;
}

.basketProductDetailActions > a > span {
    text-decoration: underline;
    margin: 0 12px;
}

.basketProductDetailActions > a:first-child {
    border: none;
}

.basketProductDetailActions > a:last-child > span {
    margin-right: 0;
}

.basketProducts hr {
    margin: 0;
    border-color: #eee;
}

.basketProducts hr:first-child {
    display: none;
}

.basketProductDeliveryMessageBlock {
    margin-top: 10px;
}

.basketActions {
    width: 446px;
    display: inline-block;
    float: right;
    border: 1px solid #EEEEEE;
    padding: 26px 37px;
}

button.btn.btn-primary.btn-block.btn--continue-checkout.js-continue-checkout-button.basketButtonContinue {
    float: none;
    width: 100%;
    margin: 0 0 12px;
    line-height: 60px;
    font-size: 1.125em;
    text-transform: initial;
}

.basketSummaryBlock h2 {
    font-size: 1.125em;
    font-weight: bold;
    line-height: 23px;
    margin: 0 0 14px;
}

.basketSummarySubtotal, .basketSummaryTotal {
    font-size: 1.125em;
    font-weight: bold;
    line-height: 23px;
    margin-bottom: 14px;
    margin-top: 20px;
}

.basketSummarySubtotal, .basketSummaryTotal span {
    float: right;
}

.basketSummarySubtotal, .basketSummaryTotal div {
    display: inline-block;
}

.basketSummarySubtotalSubtext, .basketSummaryTotalSubtext {
    font-size: 0.875em;
    margin-top: -10px;
    margin-bottom: 15px;
}

.basketRemovePromotion {
    text-decoration: underline;
    cursor: pointer;
    margin-bottom: 15px;
}

.basketAppliedPromotionMessage {
    margin-bottom: 20px;
}

.basketAppliedPromotionSubtotal {
    font-size: 0.875em;
    font-weight: bold;
    border-bottom: 1px solid #eeeeee;
    padding-bottom: 10px;
}

.basketAppliedPromotionProduct {
    margin-top: 20px;
}

.basketAppliedPromotionSubtotal span {
    float: right;
}

.basketActions hr {
    margin-top: 15px;
    margin-bottom: 15px;
    border-top: 1px solid #eee;
}

.basketGotAPromotionBlock,
.basketPromotionBlock h2 {
    font-size: 1em;
    font-weight: normal;
}

.basketGotAPromotionBlock {
    cursor: pointer;
    text-decoration: underline;
}

.giftWrapSelectionBlock:after {
    content: "";
    clear: both;
    display: block;
}

.giftWrapSelectionBlock span {
    display: inline-block;
    width: 100%;
    text-align: center;
    font-size: 1.125em;
    font-weight: bold;
    line-height: 23px;
    margin-bottom: 25px;
}

.giftWrapSelectionBlock .giftWrapSelection {
    width: 50%;
    display: inline-block;
    border: 1px solid #BCBCBC;
    margin: 0;
    float: left;
    height: 80px;
    cursor: pointer;
}

.giftWrapSelectionBlock .giftWrapSelection.giftWrapSelectionEven {
    border-bottom-right-radius: 5px;
    border-top-right-radius: 5px;
}

.giftWrapSelectionBlock .giftWrapSelection.giftWrapSelectionOdd {
    border-right: none;
    border-bottom-left-radius: 5px;
    border-top-left-radius: 5px;
}

.giftWrapSelectionBlock
.giftWrapSelection.giftWrapSelection-selected {
    border: 2px solid #000000 !important;
}

.giftWrapSelectionBlock .giftWrapSelection.giftWrapSelection-selected ~ .giftWrapSelection.giftWrapSelectionEven {
    border-left: none;
}

.giftWrapSelectionName,
.giftWrapSelectionPrice {
    font-weight: bold;
    line-height: 21px;
    letter-spacing: 0.03em;
    text-align: center;
}

.giftWrapSelectionName {
    margin-top: 19px;
}

.giftWrapSelectionBlock .giftWrapSelection.giftWrapSelection-selected .giftWrapSelectionName {
    margin-top: 18px;
}

.giftWrapSelectionsOddNumber .giftWrapSelection:last-child {
    width: 100%;
    border-right: 1px solid #BCBCBC;
    border-radius: 5px;
}

.spCheckoutPopupContentParagraph.giftWrapDescription {
    margin: 15px 0;
    text-align: left;
    letter-spacing: 0.03em;
    line-height: 24px;
}

.giftWrapImage {
    max-height: 158px;
    margin: auto;
    max-width: 100%;
}

.giftWrapMessage {
    margin-bottom: 30px;
}

.giftWrapMessage > * {
    display: block;
    width: 100%;
}

.giftWrapSectionHeadingMessage {
    line-height: 23px;
    font-weight: bold;
    font-size: 1.125em;
    margin: 20px 0;
}

.giftWrapMessageBox {
    font-size: 0.875em;
    font-weight: bold;
    line-height: 18px;
    height: 100px;
    padding: 13px 23px 0;
}

.giftWrapMessageLetterCount {
    font-size: 0.875em;
    line-height: 17px;
    margin-top: 7px;
}

.giftWrapPleaseWrapBlock {
    padding-left: 40px;
    position: relative;
}

.giftWrapPleaseWrap {
    position: absolute;
    left: 0;
    top: 5px;
    border: 1px solid #414141;
    width: 22px;
    height: 22px;
    cursor: pointer;
    z-index: 1;
}

.giftWrapPleaseWrap.giftWrapPleaseWrap-checked:after {
    font-family: "Font Awesome 5 Pro";
    content: "\f00c";
    display: block;
    font-size: 18px;
    font-weight: 400;
    line-height: 20px;
    width: 20px;
    text-align: center;
}

.giftWrapPleaseWrapMessages {
    line-height: 24px;
    margin-bottom: 20px;
}

.giftWrapPleaseWrapMessages div {
    font-weight: bold;
}

.giftWrapSaveButton {
    width: 100%;
    cursor: pointer;
    text-align: center;
    line-height: 60px;
    font-weight: bold;
}

.spCheckoutFormInput.spAddressLookup {
    padding: 0 20px;
    line-height: 60px;
    font-size: 16px;
    border-radius: 0;
}

.spCheckoutFormInput.spAddressLookup::placeholder {
    font-size: 0.875em;
}

.spCheckoutFormGroup .afd-typeahead-list, .valuationsAddressBlock-postcodeLookup .afd-typeahead-list {
    margin: 0;
    padding: 0;
    border-radius: 0;
    border-top: none;
}

.spCheckoutFormGroup .afd-typeahead-item, .valuationsAddressBlock-postcodeLookup .afd-typeahead-item {
    font-size: 0.875em;
    border-top: none;
}

.spCheckoutFormGroup .afd-typeahead-item:hover, .valuationsAddressBlock-postcodeLookup .afd-typeahead-item:hover {
    background-color: #D3D3D3;
}

#spDeliveryAddressForm.extendedFooterMargin {
    margin-bottom: 250px;
}

.spEnterAddressManually,
.spAddressAddFields,
.spEnterBillingAddressManually {
    font-size: 0.875em;
    text-decoration: underline;
    cursor: pointer;
    line-height: 24px;
    margin-top: 10px;
    margin-bottom: 25px;
    display: inline-block;
}

.spAddressFormMain #deliveryAddressForm-company,
#cardPaymentBillingAddress-company {
    margin-top: 30px;
}

.afd-popup-trigger {
    display: block;
    width: 100%;
    min-height: calc(0.5em * 2 + 1.25rem + 2px);
    background: #fff;
    border: 1px solid #ccc;
    border-radius: 2px 0 0 2px;
    appearance: none;
    box-sizing: border-box;
    padding: 0 20px;
    line-height: 60px;
    font-size: 16px;
    border-radius: 0;
    -webkit-appearance: textfield;
    outline-offset: -2px;
    font-size: 15px;
    color: rgb(85, 85, 85);
    cursor: pointer;
}

.afd-popup-trigger span {
    opacity: 0.54;
    text-overflow: inherit;
    line-height: initial;
    white-space: pre;
    overflow-wrap: normal;
    font: 1em Lato, "Helvetica Neue", Arial, Helvetica, sans-serif;
    font-size: 0.875em;
    letter-spacing: 0.03em;
}

.spCheckoutAddressFinderPopupHeader .spCheckoutPopupClose {
    right: unset;
    left: 20px;
    font-size: 24px;
    line-height: 24px;
    top: 19px;
    z-index: 5;
    width: auto;
}

.spCheckoutAddressFinderPopupHeader .afd-typeahead-field {
    padding-left: 65px;
}

.spCheckoutAddressFinderPopupHeader .afd-typeahead-field input {
    border: none;
    line-height: 22px;
    height: 22px;
    margin: 15px 0 13px;
}

.spCheckoutAddressFinderPopupHeader .afd-typeahead-list, .valuationsAddressBlock-postcodeLookup .afd-typeahead-list {
    position: initial;
    margin: 0;
    border: none;
    font-size: 14px;
    line-height: 36px;
    padding: 0;
}

.spCheckoutAddressFinderPopupHeader .afd-typeahead-list {
    max-height: unset;
}

.spCheckoutAddressFinderPopupHeader .afd-typeahead-list li, .valuationsAddressBlock-postcodeLookup .afd-typeahead-list li {
    border: none;
}

.spCheckoutAddressFinderPopupHeader .afd-typeahead-list li:nth-child(2n), .valuationsAddressBlock-postcodeLookup .afd-typeahead-list li:nth-child(2n) {
    background-color: #F9F9F9;
}

.spCheckoutAddressFinderPopupHeader .afd-typeahead-list li a, .valuationsAddressBlock-postcodeLookup .afd-typeahead-list li a {
    padding: 0 25px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
}

.spCheckoutPopupHeader.spCheckoutAddressFinderPopupHeader.hasResult {
    border-bottom: none;
}

.spCheckoutPopupHeader.spCheckoutAddressFinderPopupHeader.hasResult ~ .spCheckoutAddressFinderPopupContent .spCheckoutAddressFinderPopupContentCMS {
    display: none;
}

.spCheckoutAddressFinderPopupContent-enterAddressManually {
    text-align: center;
    cursor: pointer;
    line-height: 50px;
    text-decoration: underline;
    border-bottom: 1px solid #C2C2C2;
}

.spCheckoutPopupHeader.spCheckoutAddressFinderPopupHeader.hasResult ~ .spCheckoutAddressFinderPopupContent .spCheckoutAddressFinderPopupContent-enterAddressManually {
    text-align: left;
    padding-left: 25px;
    border-bottom: none;
}

.spCheckoutPopupContent.spCheckoutAddressFinderPopupContent {
    padding: 0;
}

.spCheckoutAddressFinderPopupContentCMS {
    margin: 25px auto 0;
    width: 250px;
    text-align: center;
    max-width: 90%;
}

.afd-mobile-clear {
    display: none;
    position: absolute;
    right: 15px;
    top: 13px;
    font-size: 16px;
    line-height: 29px;
    text-decoration: underline;
    cursor: pointer;
    z-index: 2;
}

.afd-typeahead-container.result .afd-mobile-clear,
.hasContent ~ .afd-mobile-clear {
    display: block;
}

.deliveryAddressFormExtraField, .billingAddressFormExtraField {
    display: none;
}

.spAddressFormMain.showExtraFields .deliveryAddressFormExtraField, .showExtraFields .billingAddressFormExtraField {
    display: block;
}

.spCheckoutSectionTitleAction-EditAddress {
    font-size: 13px;
    font-weight: normal;
    position: absolute;
    top: 20px;
    right: 0;
    cursor: pointer;
    text-decoration: underline;
    line-height: 20px;
}

.spCheckoutCartAppliedVouchers, .spCheckoutCartAppliedVoucherRow {
    display: none;
}

.spDeliveryAddressSummary,
.spCheckoutPopupAddressesBlock {
    background: #EBEBEB;
    font-size: 1.125em;
    padding: 25px;
    line-height: 26px;
}

.spCheckoutPopupAddressesBlock {
    font-size: 0.875em;
    margin-bottom: 15px;
}

.spCheckoutPopupAddressesBlock:last-child {
    margin-bottom: 0;
}

.spDeliveryOptionBlock,
.spDeliveryOptionDetails {
    margin-bottom: 12px;
    padding: 20px;
    position: relative;
}

.spDeliveryOptionBlock {
    border: 1px solid #BCBCBC;
    border-radius: 5px;
    cursor: pointer;
}

.spDeliveryOptionDetails {
    background: #EBEBEB;
    margin-top: 10px;
}

.spDeliveryOptionBlock.spDeliveryOptionSelected {
    border: 2px solid #131313;
    padding: 19px;
}

.spDeliveryOptionTitle,
.spDeliveryOptionPrice {
    font-size: 1.125em;
    font-weight: bold;
    line-height: 23px;
}

.spDeliveryOptionPrice {
    position: absolute;
    right: 20px;
    top: 20px;
}

.spDeliveryOptionBlock.spDeliveryOptionSelected .spDeliveryOptionPrice {
    right: 19px;
    top: 19px;
}

.spDeliveryOptionSubtitle {
    margin-top: 15px;
    font-size: 0.875em;
    line-height: 18px;
}

#spCheckoutOpenAddressBook {
    margin-top: 10px;
    background-color: transparent;
    border: 1px solid #c4c4c4;
}

.spCheckoutAddressesBlockAction {
    display: inline-block;
    cursor: pointer;
}

.spCheckoutAddressesBlockAction span {
    padding: 0 10px;
    border-left: 1px solid #ababab;
    text-decoration: underline;
}

.spCheckoutAddressesBlockAction:first-child span {
    padding-left: 0;
    border-left: none;
}

.spCheckoutAddressesBlockActions {
    margin-top: 10px;
}

.spCheckoutAddressesBlockAction .isPreferred {
    display: none;
    cursor: initial;
}

.spCheckoutAddressesBlockAction.preferredAddress span {
    display: none;
}

.spCheckoutAddressesBlockAction.preferredAddress span.isPreferred {
    display: inline;
    font-weight: bold;
    text-decoration: none;
    padding-right: 0;
}


.spCheckoutFormGroup input[type=checkbox] {
    position: relative;
    width: 22px;
    height: 22px;
}

.spCheckoutFormGroup input[type=checkbox]:before {
    content: "";
    position: absolute;
    display: block;
    left: 0;
    top: 0;
    border: 1px solid #414141;
    background-color: white;
    width: 22px;
    height: 22px;
    cursor: pointer;
    z-index: 1;
}

.spCheckoutFormGroup input[type=checkbox][value=true]:checked:after {
    font-family: "Font Awesome 5 Pro";
    content: "\f00c";
    display: block;
    position: absolute;
    left: 1px;
    top: 0;
    font-size: 18px;
    font-weight: 400;
    line-height: 20px;
    width: 20px;
    text-align: center;
    z-index: 2;
    cursor: pointer;
}

.spCheckoutFormGroup input[type=checkbox] ~ label {
    line-height: 27px;
    vertical-align: top;
    margin-top: 2px;
    margin-left: 5px;
    max-width: calc(100% - 35px);
}

.spCheckoutFormGroup .spErrorMessage,
.spCheckoutFormGroup .spLoginErrorMessage {
    display: none;
}

.spCheckoutFormGroup .spErrorMessage span {
    text-transform: lowercase;
}

.spCheckoutFormGroup .spErrorMessage.spErrorMessage-phone span {
    text-transform: none;
}

.spCheckoutFormGroup.spFormError .spErrorMessage,
.basketPromotionInputBlock .promoError,
.spCheckoutFormGroup .error-block span,
.spLoginError .spLoginErrorMessage {
    display: block;
    color: #ff1010;
    line-height: 30px;
}

.spPaymentMethodDisabledBlock {
    position: relative;
    line-height: 20px;
    font-size: 14px;
    padding-left: 25px;
    margin: 20px 0;
}

.spPaymentMethodDisabledBlock i {
    position: absolute;
    left: 0;
    top: 3px;
    font-size: 16px;
}

.spPaymentMethodDisabledBlock a {
    color: initial;
    text-decoration: underline;
}

.spClickAndCollectDisabledLandingText {
    position: relative;
    line-height: 20px;
    font-size: 14px;
    padding-left: 25px;
    max-width: 390px;
    margin: 15px auto 15px;
}

.spClickAndCollectDisabledLandingText i {
    position: absolute;
    left: 0;
    top: 3px;
    font-size: 16px;
}

.basketDisabledPromotionMessage, .basketDisabledClickAndCollectMessage, .basketLeadDeliveryMessage {
    position: relative;
    line-height: 20px;
    font-size: 14px;
    padding-left: 25px;
    max-width: 390px;
    margin: 15px auto 15px;
}

.basketDisabledPromotionMessage i, .basketDisabledClickAndCollectMessage i, .basketLeadDeliveryMessage i {
    position: absolute;
    left: 0;
    top: 3px;
    font-size: 16px;
}

.basketEnabledPromotionMessage, .basketEnabledReturnsMessage {
    position: relative;
    line-height: 20px;
    font-size: 14px;
    padding-left: 25px;
    max-width: 390px;
    margin: 15px auto 15px;
    color: black;
}

.basketEnabledPromotionMessage i, .basketEnabledReturnsMessage i {
    position: absolute;
    left: 0;
    top: 3px;
    font-size: 16px;
}


#spCheckoutErrorBlock {
    max-width: 922px;
    margin: 45px auto 0;
    border: 3px solid #FF0000;
    line-height: 20px;
    padding: 30px 25px 30px 90px;
    position: relative;
}

#spCheckoutErrorBlock i {
    position: absolute;
    line-height: 80px;
    top: 0;
    left: 0;
    width: 90px;
    text-align: center;
    color: #FF0000;
    font-size: 35px;
}

.spCheckoutFormGroup .error-block span {
    line-height: initial;
}

.spCheckoutFormGroup.spFormError input,
.spCheckoutFormGroup.spFormError select,
.spLoginError .spCheckoutFormGroup input {
    border-color: #ff1010;
}

.spGiftOrInsuranceCardBlock p {
    font-size: 14px;
    line-height: 22px;
    letter-spacing: 0.03em;
}

.spPaypalPaymentNotice {
    margin: 10px auto 15px;
}

.spPaypalCreditFooterText, .spFinanceV12FooterText {
    margin-top: 25px;
    text-align: center;
}

.spPaypalCreditFooterText p,
.spFinanceV12FooterText p {
    font-size: 0.75em;
    margin-top: 15px;
    text-align: left;
}

.spPaypalCreditFooterText p a,
.spFinanceV12FooterText p a {
    color: initial;
    text-decoration: underline;
}

.paypalReviewPageContainer-left,
.paypalReviewPageContainer-right {
    display: inline-block;
    margin-bottom: 25px;
}

.paypalReviewPageContainer-left {
    padding-right: 15px;
    width: calc(50% - 15px);
}

.paypalReviewPageContainer-right {
    float: right;
    padding-left: 15px;
    width: 50%;
}

.paypalReviewAccountInfo {
    font-size: 0.875em;
}

.confirmationPageContainer {
    max-width: 922px;
    margin: auto;
}

.confirmationPageContainer h1 {
    font-size: 1.625em;
    text-align: center;
    font-weight: bold;
    margin-top: 35px;
    margin-bottom: 20px;
}

.confirmationPageSubTitle, .confirmationPageReference {
    max-width: 345px;
    text-align: center;
    margin: auto;
    line-height: 1.5em;
    margin-bottom: 15px;
}

.confirmationPageContainer-right {
    float: right;
    padding-left: 15px;
    width: 50%;
}

.confirmationPageContainer-left {
    padding-right: 15px;
    width: 340px;
}

.confirmationPageContainer h2 {
    font-size: 1.125em;
    font-weight: bold;
    line-height: 60px;
    margin: 0;
}

.confirmationPageContainer p {
    line-height: 24px;
}

.confirmationPageDetailsContainer {
    background-color: #EBEBEB;
    padding: 15px 30px;
}

.confirmationPageDetailsContainer .spCheckoutCartSummarySubTotals,
.confirmationPageDetailsContainer .spCheckoutCartSummaryTotalsAndTax,
.confirmationPageDetailsContainer .spCheckoutCartSummarySalesTax {
    border-color: #d5d5d5;
}

.confirmationPageDetailsContainer .spCheckoutCartSummarySubTotals > div > span,
.confirmationPageDetailsContainer .spCheckoutCartSummaryTotalsAndTax > div > span,
.confirmationPageDetailsContainer .spCheckoutCartSummarySalesTax > div > span {
    font-size: 0.875em;
    line-height: 25px;
    font-weight: bold;
}

.confirmationPageDetailsContainer.confirmationPageDetailsContainer-User,
.confirmationPageDetailsContainer.confirmationPageDetailsContainer-Delivery {
    font-size: 0.875em;
    line-height: 22px;
}

.confirmationPageDetailsDeliveryStoreName {
    font-weight: bold;
    margin: 10px auto;
}

.confirmationPageDetailsDeliveryMap {
    text-decoration: underline;
    cursor: pointer;
}

.confirmationPageDetailsContainer .spCheckoutSectionOrderRowQuantity {
    width: 20px;
    float: left;
    margin-right: 5px;
}

.confirmationPageDetailsContainer .spCheckoutSectionOrderRowName {
    width: calc(100% - 105px);
}

.confirmationPageDetailsContainer .spCheckoutSectionOrderRowCode {
    padding-left: 25px;
}

.confirmationPageContainer:after {
    content: "";
    clear: both;
    display: block;
    width: 100%;
}

.confirmationPageDetailsCardNum {
    margin-top: 10px;
}

.confirmationPageDetailsCardImgPaypal {
    width: 30%;
    display: inline-block;
}

.confirmationPageDetailsPaypalText {
    margin-top: 10px;
    display: inline-block;
}

#guestRegisterForm {
    margin-top: 25px;
}

.spOrderConfirmationActionBlock {
    display: inline-block;
    width: 50%;
    float: left;
    padding: 0 10px;
    padding-left: 0;
}

.spOrderConfirmationCreateAccountCompleteActions:after {
    content: "";
    display: block;
    width: 100%;
    clear: both;
}

.spOrderConfirmationAction {
    text-align: center;
    display: block;
    line-height: 50px;
    background-color: #C4C4C4;
    color: black;
    font-weight: bold;
}

.spOrderConfirmationActionBlock:last-child {
    padding-left: 10px;
    padding-right: 0;
}

.spOrderConfirmationCreateAccountCompleteActions {
    margin-top: 25px;
}

.spOrderConfirmationAction:hover {
    color: black;
    text-decoration: none;
}

.spCheckoutPaymentOptionBlock > img,
.spCheckoutPaymentOptionTopBlock > img {
    position: absolute;
    right: 10px;
    top: 50%;
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}

/* Adyen Web Components */

label.adyen-checkout__label,
span.adyen-checkout__input {
    position: relative;
    margin-bottom: 10px;
}

span.adyen-checkout__input {
    height: 62px;
}

span.adyen-checkout__input {
    border: 1px solid #BCBCBC;
    padding-left: 20px;
    color: white;
    padding: 20px 0 0 18px;
}

span.adyen-checkout__input:after {
    content: "";
    display: block;
    height: 58px;
    width: 99%;
    position: absolute;
    background: white;
    top: 1px;
    left: 1px;
    z-index: 1;
    pointer-events: none;
}

label.adyen-checkout__label--filled span.adyen-checkout__input:after,
label.adyen-checkout__label--focused span.adyen-checkout__input:after {
    display: none;
}

label.adyen-checkout__label {
    width: 100%;
}

span.adyen-checkout__label__text {
    font-size: 0.875em;
    line-height: 18px;
    position: absolute;
    top: 22px;
    left: 20px;
    pointer-events: none;
    transition: 0.2s ease all;
    z-index: 2;
    text-transform: capitalize;
}

label.adyen-checkout__label--filled span.adyen-checkout__label__text,
label.adyen-checkout__label--focused span.adyen-checkout__label__text,
span.hasContent.adyen-checkout__label__text,
.adyen-checkout__field--error .adyen-checkout__label__text {
    top: 5px;
    font-size: 11px;
    line-height: 14px;
}

input.adyen-checkout__input {
    display: block;
    width: 100%;
    height: 60px;
    padding: 20px 0 0 18px;
    line-height: 21px;
    border: 1px solid #BCBCBC;
    position: relative;
}

input.adyen-checkout__input::placeholder {
    color: white;
}


label.adyen-checkout__label--filled input.adyen-checkout__input::placeholder,
label.adyen-checkout__label--focused input.adyen-checkout__input::placeholder {
    color: rgb(185, 196, 201);
}

.adyen-checkout__card__cardNumber__brandIcon {
    top: 32px;
    transform: none;
    -webkit-transform: none;
}

#adyenDummyPaymentButton, button.adyen-checkout__button {
    line-height: 60px;
    padding: 0;
    width: 100%;
    border-radius: 0;
    margin-top: 25px;
    background-color: #C4C4C4;
    border-color: transparent;
    font-size: 1.125em;
    color: #000;
    font-weight: bold;
    text-align: center;
    cursor: pointer;
}

#spCheckoutComponentContainer-cardPaymentComponent button.adyen-checkout__button {
    display: none;
}

button.adyen-checkout__button img {
    display: none;
}

.adyen-checkout__fieldset__title {
    line-height: 60px;
    color: #969696;
    font-weight: bold;
}

.adyen-checkout__field--error span.adyen-checkout__input,
.adyen-checkout__field--error input.adyen-checkout__input {
    border-color: #ff1010;
    margin-bottom: 0px;
}

.adyen-checkout-input__inline-validation--invalid span.adyen-checkout__icon {
    display: none;
}

span.adyen-checkout__error-text {
    color: #ff1010;
    font-weight: normal;
    margin-bottom: 7px;
    line-height: 24px;
}

.adyen-checkout__field--country {
    display: none;
}

.adyen-checkout__card-input__form .spCheckoutFormGroup {
    margin-top: 0;
}

.adyen-checkout__card-input__form .spCheckoutFormGroup-useDeliveryAddress {
    margin: 15px 0;
}

.spCheckoutFormGroup-useDeliveryAddress > span {
    display: block;
    margin-left: 30px;
}

#cardPaymentDeliveryAddress.unselected .spCheckoutFormGroup-useDeliveryAddress > span {
    display: none;
}

#useDeliveryAddress-ClickHere {
    text-decoration: underline;
}

span.adyen-checkout-input__inline-validation.adyen-checkout-input__inline-validation--valid {
    position: absolute;
    top: 22px;
    right: 15px;
    fill: #37A825;
}

.adyen-checkout__field--cardNumber span.adyen-checkout-input__inline-validation.adyen-checkout-input__inline-validation--valid {
    display: none;
}

@media (min-width: 923px) {

    .spCheckoutMobileOrderSummaryBar {
        display: none;
    }
}

@media (max-width: 1200px) {

    .basketProducts, .basketActions {
        width: 100%;
        max-width: unset;
    }

    .basketEnabledPromotionMessage,
    .basketEnabledReturnsMessage,
    .basketDisabledClickAndCollectMessage {
        max-width: unset;
    }

    .basketProducts hr:last-child {
        display: block;
    }

    .basketActions {
        border: none;
        padding: 26px 0;
    }

    .basketActions hr {
        display: none;
    }
}

@media (max-width: 922px) {

    .spCheckoutDesktopCartSummary {
        display: none;
    }

    .spCheckoutPaymentOptionsBlock, .spCheckoutPaymentBlock, #spSecure3dComponent {
        float: none;
        margin: auto;
    }

    #spCheckoutPaymentErrorMessage {
        margin: -10px 18px;
    }

    #spCheckoutPaymentErrorContainer {
        height: 119px;
        padding: 26px 18px;
        margin: 30px 3%;
    }

    .confirmationPageContainer, .paypalReviewPageContainerOuter {
        padding: 0 30px;
    }

    .spCheckoutPaymentOptionBlock, .spCheckoutPaymentOptionTopBlock {
        height: 60px;
        padding: 15px 10px;
    }

    .spCheckoutPaymentOptionBlockName {
        line-height: 40px;
    }

}


@media (max-width: 767px) {

    .basketTop h1 {
        border-bottom: none;
        margin-bottom: 0;
    }

    .basketMobileTop {
        padding: 0 15px 35px;
        border-bottom: 1px solid #EEEEEE;
    }

    .cartPage hr {
        width: calc(100% + 30px);
        margin-left: -15px;
    }

    .basketProductRow > a, .basketProductRow img.cartProductDetailsImg {
        width: 69px;
        height: 69px;
    }

    .basketProductDetailsInfo {
        margin-left: 80px;
        width: calc(100% - 80px);
    }

    .basketProductDetailsTitle,
    .basketProductDetailsPrice {
        font-size: 1em;
        max-width: 65%;
    }

    .basketProductRow {
        min-height: 150px;
        height: auto;
    }

    .basketProductDetailActionsBlock {
        height: 85px;
    }

    .basketProductDetailActionsBlock > div {
        height: 100%;
    }

    .basketProductDetailQuantityBlock,
    .basketProductDetailActions {
        width: 100%;
        float: none;
    }

    .basketProductDetailActions {
        float: left;
        width: auto;
    }

    select.basketProductQuantity {
        margin-left: 10px;
    }

    .basketProductDetailActions > a {
        font-size: 0.875em;
    }

    .basketProductDetailActions > a > span {
        margin: 0 8px;
    }

    .basketProductDetailActions > a:first-child > span {
        margin-left: 0;
    }

    #singlePageCheckoutMainContainer, .spCheckoutDeliveryChoice {
        padding: 0 15px;
    }

    .checkoutSignInBlock {
        margin-top: 30px;
    }

    .basketBottom, .checkoutBottom {
        line-height: 21px;
        padding: 30px 20px;
        margin-top: 30px;
    }

    .spCheckoutPanel {
        margin-bottom: 30px;
    }

    #singlePageCheckoutMainContainer .checkoutBottom {
        margin-left: -15px;
        width: calc(100% + 30px);
    }

    .singlePageCheckoutLoginContainer h1 {
        border-bottom: none;
    }

    .confirmationPageContainer-right,
    .confirmationPageContainer-left,
    .paypalReviewPageContainer-left,
    .paypalReviewPageContainer-right {
        width: 100%;
        float: none;
        padding: 0;
        margin-bottom: 25px;
    }

    .confirmationPageContainer h2 {
        margin-bottom: 5px;
    }

    .confirmationPageDetailsDeliveryStoreName {
        margin-top: 0;
    }

    .spCheckoutPopupAddressesBlock {
        padding: 20px;
    }
}

/* IFC Forms */

.financeRowsContainer {
    padding: 0 20px 25px;
    letter-spacing: 0.03em;
}

.financeDepositBlock {
    margin-bottom: 30px;
}

.financeDepositBlock h2 {
    font-size: 1.125em;
    font-weight: bold;
}

.financeDepositBlock span {
    line-height: 24px;
    display: block;
}

.financeDepositBlock span a {
    text-decoration: underline;
}

input#v12FinanceDepositEditInput {
    width: 100%;
    text-align: center;
    line-height: 55px;
    font-size: 22px;
    font-weight: bold;
    -moz-appearance: textfield;
    margin: 15px 0 10px;
}

input#v12FinanceDepositEditInput::-webkit-outer-spin-button,
input#v12FinanceDepositEditInput::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

#v12FinanceDepositEditUpdate, #spFinanceV12Button {
    line-height: 60px;
    border: 1px solid #000000;
    display: inline-block;
    padding: 0 40px;
    margin-top: 10px;
    font-size: 1.125em;
    font-weight: bold;
    cursor: pointer;
}

.financeRow {
    width: calc(100% + 40px);
    margin-left: -20px;
    line-height: 68px;
    border-top: 1px solid #dfdfdf;
    padding: 0 20px;
}

#productFinancePopupBlock .financeRow:last-child {
    border-bottom: 1px solid #dfdfdf;
}

#productFinancePopupBlock .financeRow:focus {
    outline: none;
}

span.financeRowMonthlyPrice {
    font-weight: bold;
}

span.financeRowAPR {
    float: right;
}

.financePopupSubHeaderText {
    letter-spacing: 0.03em;
    line-height: 21px;
    text-align: center;
    padding: 35px 20px;
    background: #E6F4F4;
}

.availableFinanceText {
    line-height: 23px;
    text-align: center;
    font-weight: bold;
    font-size: 1.125em;
    margin: 20px auto;
    letter-spacing: 0.03em;
}

.financeChoiceBlockContainer {
    margin-top: 5px;
    padding: 0 20px;
    letter-spacing: 0.03em;
}

.financeChoiceBlockContainer:after,
.financeChoiceBlock:after {
    content: "";
    display: block;
    width: 100%;
    clear: both;
}

.financeChoiceBlock {
    padding: 15px;
    border: 1px solid #BCBCBC;
    border-radius: 3px;
}

.financeChoiceBlock.financeChoiceBlock-choice {
    width: 50%;
    display: inline-block;
    text-align: center;
    float: left;
    border-radius: 0;
}

.financeChoiceBlock.financeChoiceBlock-choice:first-child {
    border-right: none;
    border-top-left-radius: 3px;
    border-bottom-left-radius: 3px;
}

.financeChoiceBlock.financeChoiceBlock-choice:last-child {
    border-top-right-radius: 3px;
    border-bottom-right-radius: 3px;
    padding-left: 16px;
}

.financeChoiceBlock .financeChoiceBlockDivider {
    width: 50%;
    display: inline-block;
    float: left;
}

.financeChoiceBlock.financeChoiceBlock-choice .financeChoiceBlockDivider {
    width: 100%;
    display: block;
    float: none;
}

.financeChoiceBlock .financeChoiceBlockDivider img {
    max-width: 100%;
    height: 34px;
    margin-top: 5px;
}

.financeChoiceBlock h2 {
    font-size: 1em;
    font-weight: bold;
}

.financeChoiceBlock .financeChoiceBlockPerMonth {
    margin-bottom: 10px;
    display: inline-block;
}

.financeChoiceBlock p {
    text-align: left;
    min-height: 110px;
}

.financeChoiceSeePlansAction {
    display: none;
}

.financeRowsContainerFooter {
    margin: 25px 0;
}

.financeChoiceBlock.financeChoiceBlock-choice .financeChoiceSeePlansAction {
    display: block;
    line-height: 60px;
    background: #C4C4C4;
    border-radius: 3px;
    font-size: 1.125em;
    font-weight: bold;
    margin-top: 10px;
    cursor: pointer;
}

.financePopupSubHeaderText {
    letter-spacing: 0.03em;
    line-height: 21px;
    text-align: center;
    padding: 35px 20px;
    background: #E6F4F4;
}

.availableFinanceText {
    line-height: 23px;
    text-align: center;
    font-weight: bold;
    font-size: 1.125em;
    margin: 20px auto;
    letter-spacing: 0.03em;
}

.financeChoiceBlock.financeChoiceBlock-choice.selected {
    border: 2px solid #000;
    padding: 14px;
}

.financeChoiceBlock.financeChoiceBlock-choice.selected ~ .financeChoiceBlock.financeChoiceBlock-choice {
    border-left: none;
}

.productDetailsFinanceBlock {
    border: 1px solid #C6C6C6;
    padding: 10px 20px 15px;
    letter-spacing: 0.03em;
}

.productDetailsFinanceBlock > * {
    display: block;
}

.productDetailsFinanceBlockValues {
    font-size: 1.063em;
    font-weight: bold;
    line-height: 25px;
}

a.productDetailsFinanceShow {
    font-size: 1.063em;
    color: #11729C;
    font-weight: bold;
    text-decoration: underline;
    line-height: 44px;
}

.productDetailsFinanceBlock > span {
    font-size: 0.750em;
    font-weight: bold;
}

.financeRowsContainer button.addToCartSubmit {
    background-color: #C4C4C4;
    font-size: 1.125em;
    padding: 0;
    color: #000;
    font-weight: bold;
    letter-spacing: 0.03em;
    border: none;
    border-radius: 0;
    line-height: 60px;
    margin-top: 30px;
}

.paypalReviewImage {
    display: block;
    margin-bottom: 10px;
}

.paypalFinanceFormBlock {
    margin-top: 20px;
}

.paypalFinanceFormBlockHidden {
    position: fixed;
    height: 60px;
    width: 360px;
    left: -5000px;
}

/* Checkout Finance */

.spFinancePaymentContainer h2 {
    font-size: 1.125em;
    font-weight: bold;
    line-height: 23px;
}

.spFinancePaymentContainer p {
    line-height: 24px;
}

.v12FinanceDepositEditBlock {
    position: relative;
}

.v12FinanceDepositCurrencySymbol {
    position: absolute;
    top: 16px;
    left: 22px;
    line-height: 55px;
}

.spFinancePaymentContainer input#v12FinanceDepositEditInput {
    border: 1px solid #BCBCBC;
    font-size: 1em;
    text-align: left;
    font-weight: initial;
    padding: 0 30px;
}

.spFinancePaymentContainer div#v12FinanceDepositEditUpdate,
#spFinanceV12Button {
    border: none;
    width: 100%;
    text-align: center;
    margin-top: 0;
    margin-bottom: 15px;
}

#spFinanceV12Button {
    margin-top: 25px;
}

.spFinancePaymentContainer .financeRow {
    width: 100%;
    margin: 0 0 15px;
    border: 1px solid #BCBCBC;
    border-radius: 5px;
    line-height: 35px;
    cursor: pointer;
    padding: 10px 20px;
}

.spFinancePaymentContainer .financeRow.financeRow-selected {
    border: 2px solid #000000;
    padding: 9px 19px;
}

.spFinancePaymentContainer .financeRow .financeRowAPR {
    display: none;
}

.spFinancePaymentContainer .financeRows h2 {
    margin-bottom: 20px;
    font-size: 1em;
}

.spFinanceSelectedTermsRow {
    line-height: 40px;
    letter-spacing: 0.03em;
}

.spFinanceSelectedTermsRowValue {
    float: right;
    font-weight: bold;
}

.spFinanceSelectedTermsRow > * {
    display: inline-block;
}

/* Paypal Review Page */

.paypalReviewPageContainerOuter {
    max-width: 922px;
    margin: 30px auto auto;
}

.paypalReviewPageContainerOuter:after {
    content: "";
    display: block;
    clear: both;
}

.paypalReviewPageContainerOuter h1 {
    font-size: 1.625em;
    font-weight: bold;
    text-align: center;
    margin: 25px auto;
    line-height: 28px;
}

#paypalReviewPayNow, #placeOrderBtn {
    display: block;
    width: 100%;
    line-height: 60px;
    text-align: center;
    background-color: #c4c4c4;
    margin-top: 25px;
    font-weight: bold;
    color: black;
}

#paypalReviewPayNow:hover, #placeOrderBtn:hover {
    text-decoration: none;
}

#placeOrderBtn {
    border: none;
}

/* WES */

div#wesDropInHeader {
    height: 120px;
    -webkit-transition: height 0.5s ease;
    -moz-transition: height 0.5s ease;
    -o-transition: height 0.5s ease;
    -ms-transition: height 0.5s ease;
    transition: height 0.5s ease;
}

div#wesDropInHeader.noShow {
    height: 0;
}

#wesChangeFascia i {
    margin-left: 3px;
}

#wesChangeFascia .fa-angle-up {
    display: none;
    margin-left: 0;
}

#wesChangeFascia.active .fa-angle-up {
    display: inline-block;
    margin-left: 3px;
}

#wesChangeFascia.active .fa-angle-down {
    display: none;
}

#wesPopupBackground, #wesTimeoutPopupBackground {
    position: fixed;
    top: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.7);
    width: 100%;
    height: 100%;
    z-index: 998;
    overflow-y: auto;
}

#wesPopup, #wesTimeoutPopup {
    position: relative;
    background-color: white;
    width: 600px;
    max-width: 100%;
    max-height: 850px;
    top: 150px;
    left: 50%;
    margin: 0;
    transform: translate(-50%, 0);
    -webkit-transform: translate(-50%, 0);
    -moz-transform: translate(-50%, 0);
    -o-transform: translate(-50%, 0);
    erflow: hidden;
    padding: 30px 15px;
}

#wesPopup h2, #wesTimeoutPopupTitle {
    margin: 0 0 30px;
    font-size: 1.333em;
    text-transform: uppercase;
    letter-spacing: 0.13em;
    text-align: center;
}

.wesPopupClose {
    position: absolute;
    top: 5px;
    right: 10px;
    font-size: 20px;
    padding: 5px;
    cursor: pointer;
}

#wesTimeoutPopupTimer {
    text-align: center;
    font-size: 50px;
    display: inline-block;
    width: 100%;
    margin: 15px auto 35px;
    color: #a6182e;
    font-weight: bold;
}

#wesAddColleaguesSave,
#wesAddColleaguesClose,
#wesTimeoutPopupContinue {
    line-height: 44px;
    text-align: center;
    background-color: #a6182e;
    color: white;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    font-weight: bold;
    font-size: 0.933em;
    cursor: pointer;
}

#wesAddColleaguesClose {
    background-color: #dfdfdf;
    color: black;
    margin-top: 20px;
}

.wesPayrollRowHeader {
    color: #aaa;
    margin-bottom: 6px;
}

.wesPayrollRow {
    margin-bottom: 20px;
}

.wesPayrollRow input {
    font-size: 0.9333em;
    border: 1px solid #ddd;
    line-height: 42px;
    height: 44px;
    padding: 0 5px;
    color: black;
    width: calc(100% - 40px);
}

.wesPayrollRow.wesFormError input {
    border-color: #ff1010;
}

.wesAddRow,
.wesRemoveRow {
    line-height: 44px;
    display: inline-block;
    float: right;
    font-size: 22px;
    cursor: pointer;
}

.wesAddRow {
    color: #a6182e;
}

#wesSessionTimer {
    display: inline-block;
}

#wesSessionTimeRemaining {
    color: #A6182E;
}

#wesExtendTime {
    text-transform: initial;
    text-decoration: underline;
    margin-left: 5px;
}

.wesSiteLogo {
    width: 500px;
    margin: auto;
    text-align: center;
    padding: 30px 0;
}

.wesLoginPage h1 {
    font-size: 1.33em;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    margin: 70px auto 30px;
    text-align: center;
}

.wesLoginForm {
    width: 600px;
    padding: 25px;
    border: 1px solid #ddd;
    margin: 75px auto 0;
}

.wesLoginForm h2 {
    font-size: 0.933em;
    margin-bottom: 20px;
    margin-top: 0;
    text-transform: uppercase;
    font-weight: bold;
}

.wesFormGroup {
    width: 100%;
    min-height: 60px;
    position: relative;
    margin-top: 25px;
}


.wesFormInput {
    display: block;
    width: 100%;
    height: 60px;
    padding: 20px 0 0 18px;
    line-height: 21px;
    border: 1px solid #ddd;
}

.wesFormLabel {
    font-size: 0.875em;
    line-height: 18px;
    position: absolute;
    top: 22px;
    left: 20px;
    pointer-events: none;
    transition: 0.2s ease all;
    color: #4B4B4B;
}

.wesFormInput:focus ~ .wesFormLabel,
.wesFormInput.hasContent ~ .wesFormLabel,
.wesFormError .wesFormInput ~ .wesFormLabel {
    top: 5px;
    font-size: 11px;
    line-height: 14px;
}

.wesFormGroup .wesFormErrorMessage,
.wesPayrollRow .wesFormErrorMessage {
    display: none;
}

.wesFormGroup.wesFormError .wesFormErrorMessage,
.wesPayrollRow.wesFormError .wesFormErrorMessage {
    display: block;
    color: #ff1010;
    line-height: 30px;
}

#wesLoginFormSubmit {
    margin-top: 25px;
    line-height: 50px;
    background-color: #a6182e;
    border-color: #a6182e;
    font-size: 0.8em;
    font-weight: bold;
    color: white;
    text-align: center;
    text-transform: uppercase;
    cursor: pointer;
}

.checkoutLoginForm.checkoutLoginForm-Wes h2 {
    font-size: 1em;
    text-transform: uppercase;
    font-weight: bold;
    letter-spacing: 0.5px;
    margin: 10px 0;
}

.checkoutLoginForm.checkoutLoginForm-Wes > p {
    font-size: 0.933em;
    display: inline-block;
    margin: 10px 0 25px;
    line-height: 2em;
}

.isWesSession input#deliveryAddressForm-billingAddress,
.isWesSession .checkoutFormCheckboxLabel {
    display: none;
}

.isWesSession .shippingPickUpBlock-Billing,
.isWesSession .shippingPickUpBlock-BillingSummary {
    display: none;
}


.wesCheckoutPaymentPage1, .wesCheckoutPaymentPage2 {
    margin-bottom: 50px;
}

.wesCheckoutPaymentBlock {
    border-bottom: 1px solid #ddd;
    padding: 20px 0;
}

.wesCheckoutPaymentBlock:last-child {
    border-bottom: none;
}

.wesCheckoutPaymentBlock {
    position: relative;
}

.wesCheckoutPaymentBlock h3 {
    font-size: 0.9333em;
    text-transform: uppercase;
    font-weight: bold;
    display: inline-block;
    margin: 10px 0 30px;
}

.wesCheckoutPaymentBlock p {
    font-size: 0.933em;
}

#wesCheckoutEditPayrollNumbers {
    float: right;
    font-size: 0.8em;
    color: #5A5A5A;
    text-transform: uppercase;
    margin: 10px 0 30px;
    line-height: 1em;
    cursor: pointer;
    text-decoration: underline;
}

.wesCheckoutPayrollNumbersHeader,
.wesCheckoutPaymentOptionHeader {
    color: #aaa;
    margin-bottom: 10px;
}

.wesCheckoutPayrollNumbersHeader {
    margin-bottom: 15px;
}

.wesCheckoutPayrollNumber {
    line-height: 1.75em;
}

.wesCheckoutPaymentOption {
    border: 1px solid #ddd;
    line-height: 53px;
    background-color: #EFF5E7;
    padding-left: 10px;
    margin: 15px 0 30px;
}

#wesCheckoutPaymentPage1Action, #wesCheckoutPaymentPage2Action, #wesCheckoutPaymentV12Action, #wesCheckoutPaymentGiftCardAction, #wesCheckoutPaymentInsuranceCardAction {
    cursor: pointer;
}

#wesCheckoutPaymentPage2Action {
    width: 100%;
    margin: 30px auto 90px;
    padding: 0;
    line-height: 44px;
    border: none;
    background-color: #a6182e;
    color: white;
    text-transform: uppercase;
    font-size: 0.8em;
    font-weight: bold;
    border-radius: 2px;
    text-align: center;
}

.wesCheckoutPaymentOption img {
    float: right;
    padding-right: 10px;
    margin-top: 14px;
    max-height: 25px;
}

.wesPayrollUpdateSuccessMessage {
    padding-left: 10px;
    line-height: 40px;
    background-color: #EFF5E7;
    margin-bottom: 15px;
}

.wesPayrollUpdateSuccessMessage i {
    margin-right: 5px;
}

.isWesSession .searchAndCartContainer {
    padding-left: 0;
}

.isWesSession .middleHeader .search-bar,
.isWesSession .middleHeader .search-bar::placeholder {
    width: 90px;
    padding-right: 0;
}

.isWesSession .paypal-button-container,
.isWesSession .productDetailsFinanceBlock,
.isWesSession .cartAddToWishlist,
.isWesSession .product-tile-wishlist,
.isWesSession .productListPaypalCreditBlock,
.isWesSession .productPagePaypalCreditBlock,
.isWesSession .footer-payment > img {
    display: none;
}

#wesYourDetailsForm-continueToPayment {
    float: left;
    clear: both;
    width: 100%;
    margin: 30px auto 90px;
    padding: 0;
    line-height: 44px;
    border: none;
    background-color: #a6182e;
    color: white;
    text-transform: uppercase;
    font-size: 0.8em;
    font-weight: bold;
    border-radius: 2px;
}

.wesCheckoutPaymentChange {
    float: right;
    margin: 10px 0 30px;
    text-decoration: underline;
    cursor: pointer;
}

.wesCheckoutPaymentBlock #reference, .wesCheckoutPaymentBlock #cardNumber, .wesCheckoutPaymentBlock #pin {
    width: 100%;
    line-height: 38px;
    padding-left: 5px;
}

/* Pre Owned - Before Account */

.valuationsPage {
    padding-bottom: 50px;
}

.valuationsBlock {
    width: 50%;
}

.valuationsBlock-left {
    float: left;
}

.valuationsBlock-right {
    float: right;
}

.valuationsContainer h1 {
    font-size: 1.33em;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    margin: 35px auto;
    text-align: center;
}

.valuationsCompleteBlock {
    text-align: center;
}

.valuationsName,
.valuationsPriceBlock,
.valuationsCompleteDetailsBlock {
    font-size: 0.875em
}

.valuationsName {
    margin-bottom: 25px;
}

.valuationsPriceBlock span,
.valuationsCompleteDetailsBlock span {
    display: block;
    margin-bottom: 20px;
}

.valuationsCompleteDetailsBlock a {
    text-decoration: underline;
    color: inherit;
}

.valuationsPriceBlock span.valuationsPrice {
    font-weight: bold;
    font-size: 24px;
    margin-bottom: 25px;
}


.valuationsAddressBlock {
    background-color: #f6f6f6;
    border: 1px solid #e3e3dd;
    padding: 25px;
    font-size: 0.875em;
}

.valuationsAddressBlock input {
    width: 100%;
    padding: 0 15px;
}

.valuationsAddressBlock h2 {
    font-size: 1em;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    text-align: center;
    margin-bottom: 15px;
}

.valuationsAddressBlock-postcodeLookup,
.valuationsAddressBlock-addressForm {
    margin-top: 20px;
}

.valuationsAddressBlock-enterManually {
    text-align: center;
    margin-top: 25px;
}

.valuationsAddressBlock-enterManually span,
.valuationsAddressBlock-searchByPostcode {
    text-decoration: underline;
    cursor: pointer;
}

#valuationsAddress-continue {
    border-radius: 0;
    height: 40px;
    font-size: 0.8em;
    font-weight: bold;
    text-transform: uppercase;
    background-color: #a6182e;
    border-color: #a6182e;
    margin-top: 25px;
}

.valuationsDetailsContainer img {
    max-width: 25%;
    float: left;
}

.valuationsBlockDetails,
.valuationsBlockDetails-specs {
    width: 75%;
    float: right;
    font-size: 0.875em;
}

.valuationsBlockDetails-brand {
    font-weight: bold;
    margin-bottom: 10px;
}

.valuationsBlockDetails-title {
    margin-bottom: 20px;
}

.valuationsBlockDetails-spec {
    color: #888;
    line-height: 22px;
}

.valuationsBlockDetails-spec span {
    color: initial;
}

.valuationsDetailsContainer {
    margin-top: 25px;
}


.valuationsPrintLabelButton {
    margin: 0;
    font-size: 0.8em;
    line-height: 42px;
    display: inline-block;
}

.accountValuationsListBody {
    clear: both;
}

.accountValuationsListBody > div {
    line-height: 40px;
}

.accountMainSectionInner
.accountValuationsListHeader {
    margin-bottom: 20px;
}

.accountValuationsListActionBlock .accountMainAction > a.accountMainActionSubmit {
    top: 0;
    margin-top: 0;
    right: 15px;
    padding: 0px;
    min-width: 110px;
}

.asmSession .paypal-button-container,
.asmSession .productDetailsFinanceBlock,
.asmSession .cartAddToWishlist,
.asmSession .product-tile-wishlist,
.asmSession .productListPaypalCreditBlock,
.asmSession .productPagePaypalCreditBlock,
.asmSession .footer-payment > img,
.asmSession .doYouHaveAPasswordBlock,
.asmSession #paypal-button-container,
.asmSession .headerLoginLink,
.asmSession .addToWishlistButton {
    display: none;
}

@media (max-width: 991px) {

    .valuationsBlock.valuationsBlock-left,
    .valuationsBlock.valuationsBlock-right {
        width: 100%;
        float: none;
    }

    .valuationsBlock.valuationsDetailsContainer {
        float: left;
        border-top: 1px solid #e3e3dd;
        border-bottom: 1px solid #e3e3dd;
        padding: 20px 0;
    }

    .valuationsBlockDetails-specs {
        width: 100%;
        margin-top: 15px;
        clear: both;
    }

    .valuationsDetailsContainerAccordion {
        font-size: 0.875em;
        letter-spacing: 0.2em;
        text-transform: uppercase;
        position: relative;
    }

    .valuationsDetailsContainerAccordionContent {
        margin-top: 20px;
    }

    .valuationsDetailsContainerAccordion > i {
        position: absolute;
        right: 0;
    }


    .valuationsDetailsContainerAccordion > i.fa-chevron-left,
    .valuationsDetailsContainerAccordion.closed > i.fa-chevron-down {
        display: none;
    }


    .valuationsDetailsContainerAccordion.closed > i.fa-chevron-left {
        display: inline-block;
    }

}

/* Pre Owned - Account */

.accountValuationsListHeader:after,
.accountValuationsListBody:after {
    content: "";
    width: calc(100% - 30px);
    border-bottom: 1px solid #ddd;
    margin: 0 15px;
}

.accountValuationsListBody:after {
    margin: 15px;
    clear: both;
    float: left;
}

.accountValuationsListDate,
.accountValuationsBrand,
.accountValuationsName,
.accountValuationsListStatus {
    font-size: 14px;
    display: block;
}

.accountValuationsBrand {
    font-weight: bold;
}

.accountValuationsListStatus, .accountValuationHeaderValueStatus {
    cursor: pointer;
    position: relative;
    display: inline-block;
}

.accountValuationsListStatusBlock:hover .accountValuationsListStatusMessage,
.accountValuationHeaderValueStatus:hover .accountValuationStatusMessage {
    display: block !important;
    position: absolute;
    border: 1px solid #ddd;
    background-color: #eee;
    right: -5px;
    margin-top: 10px;
    padding: 5px;
    line-height: 1.5em;
    width: 200px;
    z-index: 2;
}

.accountValuationsListStatus i,
.accountValuationHeaderValueStatus i {
    margin: 0 5px;
}

.accountValuationsListStatusBlock:hover .accountValuationsListStatusMessage:before,
.accountValuationHeaderValueStatus:hover .accountValuationStatusMessage:before {
    content: "";
    background: #eee;
    height: 15px;
    width: 15px;
    position: absolute;
    top: -8px;
    right: 8px;
    -ms-transform: rotate(45deg); /* IE 9 */
    -ms-transform-origin: 20% 40%; /* IE 9 */
    transform: scaleX(.6) rotate(45deg);
    border-top: 1px solid #ddd;
    border-left: 1px solid #ddd;
}

.accountValuationHeaderValue {
    font-size: 14px;
    font-weight: bold;
}

.accountValuationHeader .accountLabel {
    display: inline-block;
}

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

.accountValuationHeaderValue-ref {
    text-align: right;
}

.accountValuationSelectedPaymentMethodMessage {
    text-align: center;
}

.accountValuationPriceRowContainer {
    background-color: #f5f5f5;
    padding: 25px;
}

.accountValuationPriceRowContainer > * {
    text-align: center;
}

.accountValuationPriceRowContainer h2 {
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    margin-top: 0;
}

.accountValuationPrice {
    font-size: 24px;
    margin: 20px auto;
    font-weight: bold;
}

.accountValuationPriceRowContainer-actionsBlock > a {
    display: inline-block;
    width: 250px;
    margin: 25px 10px 0;
    line-height: 44px;
    background-color: #a6182e;
    font-weight: bold;
    font-size: 0.8em;
    text-transform: uppercase;
    line-height: 44px;
    color: white;
}

.accountValuationPriceRowContainer-actionsBlock > a:hover,
.accountValuationPriceRowContainer-actionsBlock > a:focus {
    text-decoration: none;
    color: white;
}

.accountValuationPaymentSubNote, .accountValuationPriceThanksBlock {
    text-align: center;
    line-height: 1.5em;
}

.accountValuationSwitchLink {
    text-decoration: underline;
}

.accountValuationAccordionBlockHeader {
    width: 100%;
    line-height: 2em;
    cursor: pointer;
    border-top: 1px solid #ddd;
    clear: both;
}

.accountValuationAccordionBlockHeader h2 {
    display: inline-block;
    font-size: 12px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    margin: 0;
    line-height: 50px;
}

.accountValuationAccordionBlockHeader i {
    float: right;
    line-height: 50px;
}

.accountValuationAccordionWatchDetailsImg {
    max-width: 148px;
    width: 25%;
    float: left;
}

.accountValuationAccordionWatchDetailsBlock {
    width: 75%;
    max-width: calc(100% - 200px);
    float: right;
    font-size: 0.875em;
}

.accountValuationAccordionWatchDetailsBlock-spec {
    margin-bottom: 20px;
}

.accountValuationsBlockDetails-brand {
    font-weight: bold;
    margin-bottom: 10px;
}

.accountValuationsBlockDetails-title {
    margin-bottom: 20px;
}

.accountValuationsBlockDetails-spec {
    color: #888;
    line-height: 22px;
    width: 50%;
    float: left;
}

.accountValuationsBlockDetails-spec span {
    color: initial;
}

.accountValuationAccordionBlock.accountValuationAccordionBlock-address {
    clear: both;
    border-bottom: 1px solid #ccc;
}

.accountValuationAccordionBlockInner {
    display: none;
}

.accountValuationAccordionBlock-open .accountValuationAccordionBlockInner {
    display: block;
}

.accountValuationAccordionBlock.accountValuationAccordionBlock-address .accountValuationAccordionBlockInner {
    padding-bottom: 20px;
}

.accountValuationAccordionAddress {
    position: relative;
    font-size: 14px;
    line-height: 24px;
}

.accountValuationAccordionAddress-edit {
    position: absolute;
    right: 0;
    top: 0;
    color: #888;
    text-decoration: underline;
    cursor: pointer;
}

.accountValuationAccordionAddress-edit i {
    text-decoration: none;
    margin-left: 5px;
}

.accountValuationAccordionBlock .chevronClose {
    display: none;
}

.accountValuationAccordionBlock.accountValuationAccordionBlock-open .chevronClose {
    display: block;
}

.accountValuationAccordionBlock.accountValuationAccordionBlock-open .chevronOpen {
    display: none;
}

.accountValuationPriceBACSBlock {
    max-width: 650px;
    width: 100%;
    margin: 20px auto;
    text-align: left;
}

.accountValuationPriceBACSBlock .accountInputField {
    width: 100%;
}

.accountValuationPriceBACSBlock ul {
    list-style: disc;
    padding-left: 20px;
    margin-bottom: 30px;
}

.accountValuationPriceBACSBlock ul li {
    margin-bottom: 10px;
    font-size: 0.875em;
}

.accountValuationErrorBlock {
    margin: 20px auto;
    color: red;
    font-weight: bold;
}

.accountValuationPriceRowContainer-actionsBlock > a.accountValuationsActionBACSContinue {
    width: 100%;
    text-align: center;
    margin: 15px 0 0;
}

.accountValuationAddressActions > a {
    display: inline-block;
    width: 150px;
    line-height: 44px;
    background-color: #a6182e;
    font-weight: bold;
    font-size: 0.8em;
    text-transform: uppercase;
    line-height: 44px;
    color: white;
    text-align: center;
}

.accountValuationAddressActions > a:nth-child(2) {
    float: left;
    margin-right: 10px;
}

.accountValuationAddressActions > a:hover, .accountValuationAddressActions > a:focus {
    text-decoration: none;
}

.accountValuationAddressActions > a.accountValuationsAddressActionCancel {
    background-color: #f5f5f5;
    color: black;
}

.shippingPickUpBlock form button, .orderConfirmationCreateAccountForm form button, .orderConfirmationAction, .csDiscountFormAction  {

    margin: 30px auto 0px;
}


#affirmCheckoutButton {
    float: left;
    clear: both;
    width: 100%;
    margin: 20px auto 20px;
    padding: 0;
    line-height: 44px;
    border: none;
    background-color: white;
    color: black;
    text-transform: uppercase;
    font-size: 0.8em;
    font-weight: bold;
    border-radius: 2px;
    border: 2px solid #E9ECF6;
    border-radius: 8px;
}

.affirmCheckoutButtonLogo {
    margin-right: 5px;
    vertical-align: middle;
    height: 30px;
    padding-bottom: 11px;
}

.affirmDisclaimer {
    color: #5D667E;
    line-height: 1.7em;
    font-size: 0.8em;
}

.affirm-as-low-as {
    font-size: 0.85em;
}

.affirm-modal-trigger:focus {
    text-decoration: none;
}

.affirm-modal-trigger:hover {
    text-decoration: underline;
}

.shippingPickUpBlock form button, .orderConfirmationCreateAccountForm form button, .orderConfirmationAction, .csDiscountFormAction  {
    margin: 30px auto 0px;
}


#affirmCheckoutButton {
    float: left;
    clear: both;
    width: 100%;
    margin: 30px auto 90px;
    padding: 0;
    line-height: 44px;
    border: none;
    background-color: white;
    color: black;
    text-transform: uppercase;
    font-size: 0.8em;
    font-weight: bold;
    border-radius: 2px;
    border: 1px solid black;
    border-radius: 10px;
    border-color: #E9ECF6;
}

.affirmCheckoutButtonLogo {
    margin-right: 5px;
    vertical-align: middle;
    height: 30px;
    padding-bottom: 11px;
}

.affirmFinanceCheckoutBlock {
    display: none;
}

#checkoutErrorMessage {
    line-height: 2.143em;
    width: 100%;
    display: none;
    background-color: #FAF2F8;
    float: left;
    text-align: left;
    font-size: 0.933em;
    cursor: pointer;
    margin: 10px 0px;
    padding: 5px 20px;
    color: #D26671;
}

#checkoutErrorMessage i {
    margin-right: 10px;
}

.checkoutErrorMessageIcon {
    color: #D26671;
}

.shippingPickUpBlock-ContinueToPayment {
    margin-bottom: 20px;
}


.consentBlock {
    padding: 15px 0px;
}

.consentBlock .checkbox .control-label {
    color: black;
    line-height: 22px;
}

.consentTopText {
    display: inline-block;
    font-size: 0.933em;
    color: #0d0f2e;
}

.consentBottomText {
    display: inline-block;

    font-size: 0.933em;
    color: #0d0f2e
}

.consentBottomText a {
    text-decoration: underline;
}

.consentBlock .checkbox {
    display: inline-block;
    padding-right: 10px;
}

@media (max-width: 991px) {


    .accountValuationsListBody {
        position: relative;
    }

    .accountValuationsListDateBlock {
        width: 50%;
        float: left;
    }

    .accountValuationsListWatchBlock {
        width: 100%;
        float: left;
        margin: 15px 0;
    }

    .accountValuationsListStatusBlock {
        width: 50%;
        position: absolute;
        right: 0;
    }

    .accountValuationsListActionBlock {
        width: 100%;
        float: left;
    }

    .accountValuationHeader > div {
        width: 50%;
        float: left;
        margin-bottom: 15px;
    }

    .accountValuationHeaderValue {
        display: block;
    }

    .accountValuationHeaderValue-status, .accountValuationHeaderValue-ref {
        text-align: left;
    }

    .accountValuationAccordionWatchDetailsBlock {
        max-width: unset;
        margin-top: 20px;
    }

    .accountValuationAccordionWatchDetailsBlock-spec {
        width: 100%;
    }

    .accountValuationPriceRowContainer-actionsBlock > a {
        width: 100%;
        margin: 20px 0 0;
    }

    .accountValuationAddressActions > a {
        margin-bottom: 15px;
        width: 100%;
    }

    .accountValuationAddressActions > a:nth-child(2) {
        float: none;
        margin-right: 0;
    }

}


/* ASM Discounts */


.checkoutCartSummary h3 {
    background-color: transparent;
    padding-left: 0;
    border: none;
}

#cassOrderDiscounts {
    padding: 15px 20px;
    border-bottom: 1px solid #ddd;
}

.csDiscountFormBlock {
    margin: 5px 0;
}

.csDiscountFormBlock > * {
    display: inline-block;
}

.csDiscountFormBlock span {
    min-width: 110px;
}

.csDiscountFormBlock input,
.csDiscountFormBlock select {
    line-height: 20px;
    border: 1px solid black;
}

.csDiscountFormAction {
    float: none;
    margin-top: 10px;
}

.checkoutCartSummaryAddProductDiscount-applied {
    margin-top: 15px
}

.checkoutCartSummaryAddProductDiscount:before,
.checkoutCartSummaryAddProductDiscount-applied:before {
    content: "";
    display: block;
    width: calc(100% + 40px);
    border-bottom: 1px solid #ddd;
    margin: 0 0 10px -20px;
}

.checkoutCartSummaryProductDiscountsRow {
    margin-top: 15px;
}

.checkoutCartSummaryProductDiscountsRow:first-of-type {
    margin-top: 0;
}

/* Product Style Builder - TEMP*/

#productStyleBuilderPopup {
    width: 100%;
    height: 100%;
}

#productStyleBuilderPopup:before {
    content: "";
    position: fixed;
    z-index: -1;
    top: 0;
    width: 25%;
    max-width: 480px;
    height: 100%;
    background-color: #f5f5f5;
}

#productStyleBuilderPopupTitle {
    width: 100%;
    text-align: center;
    line-height: 75px;
    text-transform: uppercase;
    font-size: 24px;
}

.productStyleBuilderPopupHeader {
    position: relative;
    border-bottom: 1px solid #dbdbdb;
    z-index: 1;
    background-color: white;
}


.productStyleBuilderPopupClose {
    position: absolute;
    top: 0;
    right: 0;
    width: 50px;
    text-align: center;
    line-height: 75px;
    font-size: 24px;
    cursor: pointer;
}

.productStyleBuilderPopupBody {
    display: flex;
    z-index: 1;
    align-items: stretch;
}

#productStyleBuilderPopupFilterBlock {
    width: 25%;
    height: 100%;
    padding-left: 5%;
    padding-right: 15px;
}

#productStyleBuilderPopupResultsBlock {
    width: 75%;
}

.productStyleBuilderResultsContainer {
    display: flex;
    flex-wrap: wrap;
}

#productStyleBuilderPopupFacets {
    padding-top: 25px;
}

.productStyleBuilderFacetBlock {
    margin-bottom: 20px;
}

.productStyleBuilderFacetBlockTitle {
    text-transform: uppercase;
    font-weight: bold;
    position: relative;
    line-height: 20px;
    font-size: 14px;
}

.productStyleBuilderFacetOptions-Pipe {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    width: 100%;
    margin: 15px 0;
}

.productStyleBuilderFacetOptions-Pipe .productStyleBuilderFacetPipeOption {
    flex: 1;
    text-align: center;
    position: relative;
    font-weight: bold;
    font-size: 12px;
    color: black;
    opacity: 0.5;
}

.productStyleBuilderFacetPipeOption.productStyleBuilderFacetPipeOption-available {
    cursor: pointer;
    opacity: 1;
}

.productStyleBuilderFacetPipeOption.productStyleBuilderFacetPipeOption-available.productStyleBuilderFacetPipeOption-selected {
    color: #a6182e;
}

.productStyleBuilderFacetOptions-Pipe .productStyleBuilderFacetPipeOption:after {
    content: "";
    height: 100%;
    border-right: 1px solid black;
    position: absolute;
    right: 0;
}

.productStyleBuilderFacetOptions-Pipe .productStyleBuilderFacetPipeOption:last-child:after {
    display: none;
}

.productStyleBuilderFacetOptions-Slider, .productStyleBuilderFacetOptions-Price {
    padding: 15px 10px 0;
}

.productStyleBuilderSliderValues, #styleBuilderPriceSliderValues {
    margin: 15px -7px 0;
    font-size: 0.85em;
}

.productStyleBuilderSliderValues > div, #styleBuilderPriceSliderValues > div {
    width: 50%;
    display: inline-block;
}

.productStyleBuilderSliderValueInputBlock, .styleBuilderPriceValueInputBlock {
    width: 96%;
    display: inline-block;
    position: relative;
}

.productStyleBuilderSliderInputLabel, .styleBuilderPriceValueInputLabel {
    position: absolute;
    top: 3px;
    left: 6px;
    font-size: 12px;
    font-weight: bold;
}

.productStyleBuilderSliderValueInputBlock > input, .styleBuilderPriceValueInputBlock > input {
    width: 100%;
    padding-top: 20px;
    padding-left: 4px;
}

.styleBuilderPriceValueInputBlock > input {
    padding-left: 12px;
}

.productStyleBuilderSliderValueInputBlock > input::-webkit-inner-spin-button, .styleBuilderPriceValueInputBlock > input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.productStyleBuilderSliderValues .toPrice, #styleBuilderPriceSliderValues .toPrice {
    float: right;
    text-align: right;
}

.productStyleBuilderSlider, #styleBuilderPriceSlider {
    height: 2px;
    margin: 0 -5px 25px;
}

.productStyleBuilderSlider .noUi-connect, #styleBuilderPriceSlider .noUi-connect {
    background: black;
    height: 2px;
    top: -1px;
}

.productStyleBuilderSlider .noUi-connects, #styleBuilderPriceSlider .noUi-connects {
    overflow: visible;
}

.styleBuilderPriceValueInputCurrency {
    position: absolute;
    top: 22px;
    left: 6px;
}

#productStyleBuilderPopupPriceRange {
    margin-bottom: 25px;
}

html:not([dir=rtl]) #productStyleBuilderPopupFilterBlock .noUi-horizontal .noUi-handle {
    width: 4px;
    height: 20px;
    border-radius: 0;
    border: none;
    top: -10px;
    right: -2px;
    border-color: black;
    background: black;
    box-shadow: none;
}

html:not([dir=rtl]) #productStyleBuilderPopupFilterBlock .noUi-horizontal .noUi-handle:before, html:not([dir=rtl]) #productStyleBuilderPopupFilterBlock .noUi-horizontal .noUi-handle:after {
    content: "";
    position: absolute;
    background-color: transparent;
    height: 20px;
    width: 5px;
    display: block;
    top: 0;
}

html:not([dir=rtl]) #productStyleBuilderPopupFilterBlock .noUi-horizontal .noUi-handle:before {
    top: 0;
    left: -5px;
}

html:not([dir=rtl]) #productStyleBuilderPopupFilterBlock .noUi-horizontal .noUi-handle:after {
    top: 0;
    right: -5px;
    left: unset;
}

html:not([dir=rtl]) #productStyleBuilderPopupFilterBlock .noUi-horizontal .noUi-handle:focus {
    outline: none;
}

#productStyleBuilderPopupFilterBlock .noUi-handle:after, #productStyleBuilderPopupFilterBlock .noUi-handle:before {
    display: none;
}

#productStyleBuilderPopupFilterBlock .noUi-handle:after {
    left: 10px;
}

.productStyleBuilderResultsCountContainer {
    text-align: right;
    padding-right: 10px;
    margin: 20px auto;
}

.productStyleBuilderResultsPaginationContainer {
    margin-bottom: 50px;
}

.productStyleBuilderResultsPaginationContainer > * {
    float: none;
}

.productStyleBuilderPopupOverlay {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    height: 100%;
    width: 100%;
    z-index: 1;
    background-color: rgba(255, 255, 255, 0.5);
}

.productStyleBuilderPopupOverlay i {
    position: fixed;
    top: 50%;
    left: 50%;
    opacity: 0.8;
}

#productStyleBuilderPopupPriceRange:focus-within, .productStyleBuilderFacetBlock-SLIDER:focus-within {
    position: relative;
    z-index: 2;
}

.productStyleBuilderFacetBlock-toggleOpen {
    display: none;
}

#productStyleBuilderClearAllFacets {
    font-size: 0.933em;
    cursor: pointer;
    text-decoration: underline;
    margin-bottom: 15px;
}

.productUnderImageText {
    font-size: 14px;
    text-align: center;
    line-height: 40px;
    width: 100%;
}

.productBuilderResultFacetValue {
    font-size: 14px;
    line-height: 22px;
}

.productBuilderResultFacetValue ~ .productTilePrice {
    margin-top: 10px;
}

.productStyleBuilderPopupText {
    font-size: 14px;
    line-height: 1.5em;
}

.backToStyleProductLink {
    margin: 10px 0;
    display: block;
}

.variantDropdownsContainer.builderProductChild > select {
    display: none;
}

.variantDropdownsContainer.builderProductChild > #ringSizeDropdown {
    display: inline-block;
    width: 100%;
}

#productStyleBuilderPriceDetailsLink {
    font-size: 14px;
    margin-bottom: 15px;
}

#productStyleBuilderPriceDetailsLink a {
    text-decoration: underline;
    color: #5a5a5a;
}

#productStyleBuilderPriceDetailsPopupBackground {
    position: fixed;
    top: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.7);
    width: 100%;
    height: 100%;
    z-index: 11;
    overflow-y: auto;
}

#productStyleBuilderPriceDetailsPopup {
    position: relative;
    background-color: white;
    width: 1400px;
    max-width: 100%;
    margin: 200px auto 0;
    padding: 40px 30px;
}

#productStyleBuilderPriceDetailsPopup .productStyleBuilderPriceDetailsPopupClose {
    position: absolute;
    top: 5px;
    right: 10px;
    font-size: 20px;
    padding: 5px;
    cursor: pointer;
}

#productStyleBuilderPriceDetailsPopup h2 {
    text-align: center;
    font-size: 1.333em;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    margin: 0 auto 35px;
}

#productStyleBuilderPriceDetailsPopup .description {
    text-align: center;
    margin: 25px auto;
}

#productStyleBuilderPriceDetailsPopupClose {
    width: 150px;
    margin: auto;
    line-height: 30px;
    border-radius: 0;
    font-size: 0.8em;
    font-weight: bold;
    background-color: #a6182e;
    border-color: #a6182e;
    text-transform: uppercase;
}

@media (max-width: 991px) {
    #productStyleBuilderPopup:before {
        display: none;
    }

    .productStyleBuilderPopupHeader {
        border-bottom: none;
    }

    .productStyleBuilderPopupBody {
        display: block;
    }

    #productStyleBuilderPopupFilterBlock {
        width: 100%;
        background-color: #f5f5f5;
        padding: 0 30px;
    }

    #productStyleBuilderPopupFacets {
        padding-top: 0;
    }

    .productStyleBuilderPopupText {
        display: none;
    }

    #productStyleBuilderPopupResultsBlock {
        width: 100%;
    }

    .productStyleBuilderFacetBlock {
        border-top: 1px solid #ddd;
    }

    #productStyleBuilderPopupPriceRange {
        border-top: 1px solid #ddd;
        border-bottom: 1px solid #ddd;
    }

    .productStyleBuilderFacetBlock {
        padding: 15px 0;
        margin-bottom: 0;
    }

    .productStyleBuilderFacetBlock-Open .productStyleBuilderFacetBlockTitle {
        margin-bottom: 15px;
    }

    .productStyleBuilderFacetBlock-toggleOpen {
        display: block;
    }

    .productStyleBuilderFacetBlock-toggleOpen:after {
        content: '\f054';
        font-family: "Font Awesome\ 5 Pro";
        position: absolute;
        right: 0;
        top: 0;
        font-size: 0.8em;
        font-weight: 300;
    }

    .productStyleBuilderFacetBlock-Open .productStyleBuilderFacetBlock-toggleOpen:after {
        content: '\f078';
    }

    .productStyleBuilderFacetOptions {
        display: none;
    }

    .productStyleBuilderFacetBlock-Open .productStyleBuilderFacetOptions {
        display: block;
    }

    .productStyleBuilderFacetBlock-Open.productStyleBuilderFacetBlock-PIPE .productStyleBuilderFacetOptions {
        display: flex;
    }

    .productStyleBuilderResultsCountContainer {
        text-align: left;
        line-height: 35px;
        border-bottom: 1px solid #ddd;
        padding: 0 0 15px;
        margin: 0 30px;
    }

    .productStyleBuilderResultsCountContainer .productStyleBuilderMobileListingOption {
        float: right;
    }

    .productStyleBuilderResultsCountContainer .productStyleBuilderMobileListingOption.productStyleBuilderMobileListingOption-two {
        display: none;
    }

    .showOnePerRow .productStyleBuilderResultsCountContainer .productStyleBuilderMobileListingOption.productStyleBuilderMobileListingOption-two {
        display: block;
    }

    .showOnePerRow .productStyleBuilderResultsCountContainer .productStyleBuilderMobileListingOption.productStyleBuilderMobileListingOption-one {
        display: none;
    }

    .productStyleBuilderResultsCountContainer .productStyleBuilderMobileListingOption i {
        margin-left: 10px;
        line-height: 35px;
        text-align: center;
        width: 35px;
        border: 1px solid #d1d1d1;
        border-radius: 5px;
        -webkit-box-shadow: none;
        -moz-box-shadow: none;
        box-shadow: none;
        cursor: pointer;
    }

    .showOnePerRow .productTile {
        width: 100%;
    }

    .productStyleBuilderResultsContainer {
        padding: 15px 30px 0;
    }
}

/* CASS */

.checkoutCassAddDiscountToProduct, .checkoutCassAddDiscountToOrder{
    cursor: pointer;
    color: #a6182e;
    margin-left: 25%;
}

.checkoutCassAddDiscountToProduct{
    margin-top: 10px;
}

#cassDiscountPopupBackground {
    position: fixed;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    background: black;
    opacity: 0.5;
    z-index: 12;
}

.cassDiscountPopup {
    position: fixed;
    width: 100%;
    max-width: 1200px;
    background-color: white;
    z-index: 13;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.cassDiscountPopup h3 {
    font-size: 1em;
    line-height: 62px;
    margin: 0;
    border-bottom: 1px solid #ccc;
    text-align: center;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.cassDiscountPopupClose {
    position: absolute;
    top: 0;
    right: 0;
    font-size: 20px;
    width: 62px;
    line-height: 62px;
    text-align: center;
    cursor: pointer;
}

#cassProductDiscountPopup-ProductDetails {
    display: block;
    width: 100%;
    max-width: 390px;
    margin: 40px auto 20px;
}

.cassDiscountPopup #addProductDiscountForm,
.cassDiscountPopup #addDiscountForm {
    clear: both;
    width: 100%;
    max-width: 390px;
    margin: 20px auto 30px;
}

#cassProductDiscountPopup-ProductDetails .checkoutCartSummaryProductDetails {
    float: none;
}

#cassProductDiscountPopup-ProductDetails .checkoutCartSummaryProductName,
#cassProductDiscountPopup-ProductDetails .checkoutCartSummaryProductCode {
    margin-bottom: 1px;
}

#cassProductDiscountPopup-ProductDetails .checkoutCartSummaryProductPriceQty span {
    float: none;
    display: block;
    margin-top: 2px;
}

.checkoutCassDiscountsRow {
    margin: 10px 0 10px 25%;
    line-height: 24px;
}

.checkoutCassDiscountsRow-discountApplied {
    color: #2f873d;
}

.checkoutCassDiscountsRow-discountedTotal {}

.checkoutCassDiscountsRow > div > span {
    float: right;
}

.checkoutCassDiscountsRow-removeDiscount {
    margin-top: 15px;
}

.checkoutCassDiscountsRow-removeDiscount .removeCassDiscount {
    background-color: transparent;
    border: none;
    padding-left: 0;
    color: #a6182e;
}

.cassDiscountPopup #addProductDiscountForm button,
.cassDiscountPopup #addDiscountForm button {
    line-height: 60px;
    height: 60px;
}