:root {
    --color-pink: #d40f7d;
    --color-blue: #009fdf;
    --color-yellow: #fae100;
    --color-black: #2c2a29;
    --color-text: #1d2939;
    --color-text-light: #667085;
    --color-light-grey: #f6f6f8;
    --color-hover-pink: #8a044f;
    --color-background-grey: #e9e9e9;
    --danger-red: #e81911;

    --radius-default: 8px;
    --color-outline: hsl(218, 30%, 78%);
}

@font-face {
    font-family: 'Lexend';
    font-style: normal;
    font-weight: 400;
    src: url('/0/Handler/Picture/GU/F/ThemeFonts/Lexend-normal-400.ttf') format('truetype')
}

body {
  font-family: 'Lexend' !important;
}

h1 {
    &.page-title {
        font-size: 48px !important;
        margin: 1.5rem 0 !important;
    }
}

a {
    &:hover {
        color: var(--color-hover-pink);
    }
}

input[type="text"],
input[type="textarea"],
.catfish-input {
    border-radius: 10px;
    color: var(--color-text-light);
    border-color: var(--color-outline);
}

.content p:not(:last-child),
.content dl:not(:last-child),
.content ol:not(:last-child),
.content ul:not(:last-child),
.content blockquote:not(:last-child),
.content pre:not(:last-child),
.content table:not(:last-child) {
    margin-bottom: 0.75em !important;
}
.box {
    border-radius: var(--radius-default);
}
.has-text-custom-1 {
    color: var(--color-pink) !important;
}

.has-text-custom-2 {
    color: var(--color-text-light) !important;
}

.marginless-text p {
    margin-bottom: 0px;
}

div#contentrow {
    padding-top: 2rem;
}

/** old css **/
.multipartUi-V2-Validation .button.is-light {
    display: none;
}
/** end **/

.button,
.catfish-button,
.account-page--order-details #order_details_v2 .od_print_button {
    border-radius: var(--radius-default);
    padding: 0 16px;
    font-size: 1rem !important;
}

.catfish-select,
input,
.attribute-value-item label {
    border-radius: var(--radius-default);
    /* height: 40px; */
    padding: 0 16px;
    &:checked + label.button {
        border-radius: var(--radius-default) !important;
        height: 40px !important;
        padding: 0 16px !important;
        color: white !important;
        background: black !important;
        border: 1px solid black !important;
    }
}

.tooltip-html-container {
    border-radius: var(--radius-default) !important;
    padding: 12px !important;
}

select {
    appearance: none !important;
    -webkit-appearance: none;
    -moz-appearance: none;
    background: url(/0/Handler/CSSOverride/GetImage/4/down-chevron-svgrepo-com.svg)
        no-repeat right center;
    background-size: 12px 12px;
    background-position: calc(100% - 16px);
}

select:not(.catfish-button),
input:not(.catfish-button),
label:not(.catfish-button) {
    color: black !important;
    border-color: black !important;
}

.has-background-light-grey-colour {
    background: var(--color-light-grey);
    background-color: var(--color-light-grey);
}

.legal-text {
    color: var(--color-text-light) !important;
    font-size: 14px;
}

.legal-link-list {
    display: flex !important;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 29px;
    margin: 0px !important;

    li {
        margin-top: 0px !important;
    }
}

.footer-section-main {
    padding-bottom: 1rem;
    z-index: 1;
    display: inline-block;
    .content li + li {
        margin-top: 0px;
    }

    span {
        color: black !important;
    }

    /* i {
        color: var(--color-pink);
    } */

    .footer-payment-icons,
    .social-icons {
        gap: 10px;
        .fa {
            font-size: 16px;
        }
    }
    .social-icons {
        .icon {
            height: fit-content;
            width: fit-content;
            .fa {
                font-size: 22px;
            }
        }
    }
    .footer-logo-section {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
        & > div {
            margin-bottom: 10px !important;
            width: 50px;
            padding-right: 10px;
            &:first-of-type {
                width: 100%;
            }
            &:last-of-type {
                width: 100%;
                img {
                    width: 136px;
                }
            }
        }

        .footer-logo {
            img {
                height: 71px;
            }
        }
    }
    .stripe-footer {
        display: flex;
        align-items: center;
        gap: 10px;
    }
}

.footer-list-column-short li {
    margin-bottom: 12px;
}

.header-links-wrapper {
    display: none;
}

.headermenu {
    .impersonate-show {
        display: none;
    }
    .is-impersonated {
        .impersonate-show {
            display: block;
        }
        .impersonate-hide {
            display: none;
        }
    }
    .content {
        margin-bottom: 0px;
    }
    .two-tier-menu {
        box-shadow: 0 2px 10px rgba(10, 10, 10, 0.1);
    }
    .nav-search-container {
        top: 1.2rem !important;
        input#btn-small-search {
            height: auto !important;
        }
    }
    .hidden-mobile-menu {
        .navbar-item {
            color: var(--color-pink);
            font-weight: bold;

            &.has-dropdown {
                margin-bottom: 0.75rem;
                color: var(--color-pink);

                .navbar-link {
                    color: var(--color-pink);
                    font-weight: bold;
                }
            }
        }
        .navbar-burger {
            span {
                background: var(--color-pink);
            }
        }
        .vat-check-toggle {
            .control-label {
                font-size: 14px;
                padding: 0 0 0 0.75rem;
                color: var(--color-pink);
            }
        }
    }
    .top-menu-split {
        padding: 1.25rem 0.75rem;
        .navbar-start {
            align-items: center;
        }
        .fal,
        .fa,
        .fas {
            color: var(--color-pink);
            font-size: 25px;
        }
        .admin-link {
            background: white !important;
            font-size: 16px !important;
        }
        .level-right {
            .my-account-dropdown-link,
            .vat-check-toggle {
                height: 50px !important;
                border: 1px solid transparent;
                border-radius: 8px;
                padding: 10px 14px;
                font-size: 14px;
                color: var(--color-pink) !important;
            }
            .navbar-item {
                align-items: center !important;

                &.login-link {
                    height: 50px !important;
                    border: 1px solid transparent;
                    border-radius: 8px;
                    padding: 10px 14px;
                    font-size: 14px;
                    color: var(--color-pink) !important;
                }
                &.my-account-dropdown {
                    &:hover {
                        .my-account-dropdown-link {
                            /* border: 1px solid var(--color-pink); */
                        }
                        .navbar-link:not(.is-arrowless)::after {
                            border-color: var(--color-pink);
                        }
                    }
                    .my-account-dropdown-link {
                        padding-right: 2.25rem;
                    }
                    .navbar-dropdown {
                        .navbar-item {
                            color: var(--color-pink);
                            &:hover {
                                background: var(--color-pink) !important;
                                color: white !important;
                            }
                        }
                        border-radius: 8px;
                        border: 1px solid var(--color-pink);
                        padding: 0 0 0.5rem;
                        overflow: hidden;
                    }
                }
                .buttons {
                    gap: 8px;
                    .button {
                        margin: 0px !important;
                        padding: 0px 6px !important;
                        width: 50px;
                        background: transparent !important;
                    }
                    .navbar-link {
                        color: var(--color-pink);
                    }
                }
                &.vat-check-toggle {
                    padding: 0px 1rem;
                    margin-right: 15px;

                    .control-label {
                        font-size: 14px;
                        padding: 0 0 0 0.75rem;
                        color: var(--color-pink);
                    }

                    .control {
                        font-size: unset;
                    }

                    .switch {
                        input[type="checkbox"] {
                            & + * .check,
                            & + .check {
                                width: 36px;
                                height: 20px;
                                &:before {
                                    width: 17px;
                                    height: 17px;
                                }
                            }
                            &:checked + * .check:before,
                            &:checked + .check:before {
                                transform: translate3d(80%, 0, 0);
                            }
                        }
                    }
                }
            }
        }
    }
    .bottom-menu-split {
        border-top: none;
        padding: 0 0 1rem 0;
        #bottom-splitmenu {
            .navbar {
                .navbar-item {
                    color: var(--color-pink);
                    .navbar-link {
                        color: var(--color-pink);
                    }
                    &:nth-child(1) {
                        .navbar-link {
                            padding-left: 0;
                        }
                    }
                }
                .navbar-dropdown {
                    border: 0;
                    border-bottom-left-radius: 8px;
                    border-bottom-right-radius: 8px;
                    padding: 1.5rem 1rem;
                    &.first-column {
                        border-bottom-left-radius: 8px;
                        border-top-right-radius: 8px;
                    }
                    &.second-column {
                        border-top-right-radius: 8px;
                        border-bottom-right-radius: 8px;
                        border-left: none;
                    }
                }
            }
            .column-title {
                font-size: 1.1rem;
                font-weight: bold;
            }
        }
    }
    .content-field-navbar .navbar-link:not(.is-arrowless)::after {
        border-color: var(--color-pink) !important;
    }
    span.current-basket-quantity {
        margin: 0px !important;
        top: -13px;
        right: 0;
        background: var(--color-pink);
        border-radius: 8px;
        padding: 2px 5px;
        font-size: 12px;
        color: white;
    }

    .badge {
        background: transparent;
    }

    a.navbar-item:focus,
    a.navbar-item:focus-within,
    a.navbar-item:hover,
    a.navbar-item.is-active,
    .navbar-link:focus,
    .navbar-link:focus-within,
    .navbar-link:hover,
    .navbar-link.is-active {
        color: var(--color-text) !important;
    }
}

#logorow .navbar .navbar-item.has-dropdown:focus .navbar-link,
#logorow .navbar .navbar-item.has-dropdown:hover .navbar-link,
#logorow .navbar .navbar-item.has-dropdown.is-active .navbar-link {
    background-color: transparent;
}

.bento-box-section {
    .bento-box-column {
        position: relative;
        height: 490px;
        .block {
            &.inner-container {
                position: relative;
                height: 100%;
                width: 100%;
                border-radius: 32px;
                overflow: hidden;
                padding: 2rem;
                display: flex;
                flex-direction: column;
                justify-content: flex-end;
                .block:not(.marketing-block .block) {
                    &:first-of-type {
                        position: absolute;
                        right: 0;
                        bottom: 0;
                        height: 100%;
                        width: 100%;
                        z-index: -2;
                        margin: 0px !important;
                        * {
                            position: absolute;
                            top: 0;
                            left: 0;
                            right: 0;
                            bottom: 0;
                            height: 100%;
                            width: 100%;
                            object-fit: cover;
                        }
                    }
                }
            }
        }
        &:hover {
            .bento-box-hover-show {
                visibility: visible;
                pointer-events: all;
                opacity: 1;
            }
        }
        .bento-box-attribute {
            margin: 0px !important;
        }

        .button {
            width: 216px;
            border: 2px solid transparent;
            &:hover {
                background: white;
                color: var(--color-pink);
                border: 2px solid var(--color-pink);
            }
        }
        &.marketing-block {
            &:hover {
                & .inner-container {
                    &:before {
                        content: "";
                        display: none;
                    }
                }
            }

            .inner-container {
                background: var(--color-light-grey);
            }

            .marketing-icon {
                color: var(--color-pink);
                width: 44px !important;
                padding: 10px;
                border-radius: 100%;
                text-align: center;
                margin-bottom: 1rem !important;
                &:before {
                    content: "";
                    background: var(--color-pink);
                    height: 100%;
                    width: 100%;
                    display: block;
                    position: absolute;
                    opacity: 0.1;
                    border-radius: 100%;
                    top: 0;
                    left: 0;
                }
            }
        }
    }
}

.homebanners {
    .row__container {
        margin: 0 auto;
        max-width: 1672px;
        padding-left: 64px;
        padding-right: 64px;
    }
}
.infigo-slider {
    padding-bottom: 5.5rem !important;
    .slides {
        & > li {
            border-radius: 32px;
            overflow: hidden;
            height: 400px;
        }
    }
    .flex-control-paging {
        li {
            a {
                background: var(--color-text-light);
                outline: transparent;
                outline-offset: 2px;
                &.flex-active {
                    background: var(--color-pink);
                    outline: 2px solid var(--color-pink);
                }
            }
        }
    }

    .flex-direction-nav {
        display: none;
    }
    .align-bottom-slider {
        .columns {
            align-items: stretch !important;
        }
    }
    .remove-inline {
        * {
            display: block !important;
        }
    }
    .container {
        max-width: 100%;
        padding: 0px;
    }

    .hero-banner {
        .ict-left-column {
            display: flex;
            align-items: end;
            img {
                height: 380px;
            }
        }
        .ict-right-column {
            justify-content: space-around;
            display: flex;
            flex-direction: column;
            align-items: center;
            margin-bottom: 2rem;
        }
        .hero-top-cta-image {
            max-width: 350px;
        }
        .hero-title {
            font-size: 2rem;
            font-weight: bold;
            font-style: italic;
        }
    }
}

.arone-product-landing-page {
    .product-variant-list {
        .cancelEdit {
            background: var(--danger-red);
            color: white;
            border: var(--danger-red);
        }
    }

    .product-intro-section {
        padding-bottom: 4rem;
        padding-top: 2rem;
        .hero-body {
            background: var(--color-light-grey);
            border-radius: 30px;
            padding: 2rem 3rem !important;

            h1 {
                font-size: 48px !important;
                font-weight: bold;
                margin-bottom: 0px;
                line-height: normal;
            }
        }
    }

    #delivery-countdown-banner {
        border-radius: 10px;
        .hero-body {
            padding: 1rem;
            .level-item {
                & > div {
                    display: flex;
                    flex-direction: row;
                    align-items: center;
                    justify-content: center;
                    font-size: 16px;

                    p {
                        font-size: 0.9rem;
                        margin: 0px;
                        padding: 0 10px;
                    }
                }
            }
        }
    }
    .picture {
        .bigpicture,
        .thumb {
            img {
                border-radius: 20px;
            }
        }

        .thumb {
            max-width: 20%;
        }
    }
    .productspec-box {
        .title {
            color: var(--color-pink);
            font-size: 1.5rem;
            font-weight: bold;
        }
        .productspec-list {
            tr {
                background: transparent !important;
            }
        }
    }

    .additional-description-section {
        padding: 0px;
    }

    .full-description-wrapper {
        padding-top: 1rem;
        margin-bottom: 0px !important;
    }
}

.rounded-edge-image {
    img {
        border-radius: 10px;
    }
}

.related-products-section {
    background: white !important;
    .title {
        color: var(--color-black) !important;
        font-weight: bold;
        text-align: center;
        padding-bottom: 1rem;
    }
}

.listWrapper {
    gap: 20px;
    justify-content: center;

    @media (max-width: 767px) {
        .listItem {
            width: 100%;
        }
    }

    @media (min-width: 768px) {
        .listItem {
            width: calc(50% - 10px);
        }
    }

    @media (min-width: 1080px) {
        .listItem {
            width: calc(33% - 10px);
        }
    }

    .listItem {
        background: white;
        box-shadow: 0 2px 10px rgba(10, 10, 10, 0.1);
        padding: 1.5rem 1.5rem 1rem 1.5rem;
        border-radius: 10px;

        .product-item--image {
            img {
                border-radius: 10px;
            }
        }

        .product-item--info {
            text-align: center;

            .product-title {
                padding: 1.5rem 0;
                margin: 0px;
                font-size: 1.5rem;
                a {
                    color: var(--color-pink) !important;
                }
            }

            .add-info,
            .alternate--prices,
            .description {
                display: none !important;
            }
        }
    }
}

.category-intro-wrapper {
    padding-top: 0px !important;
    .subtitle {
        display: none;
    }
    .category-header {
        .subtitle {
            display: block;
        }
        .category-top-image {
            padding: 0 2rem 0 0;

            img {
                border-radius: 10px;
            }
        }
    }
}

.warning-box,
.notification,
#quantitiesChangedWarning {
    border-radius: 14px !important;
    padding: 1.25rem !important;
    font-size: 1rem !important;
}

.shoppingcart__wrapper {
    padding-top: 3rem;
    padding-bottom: 1rem;

    form#cartform {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;

        .checkoutAttributesWrapper {
            width: 70%;
        }
        .common-buttons-container {
            width: 30%;
            align-content: flex-end;
        }
    }

    input#updatecart {
        margin: 0px;
    }
    .common-buttons {
        margin: 0px !important;
        padding: 0;
    }
    .cart-footer__container {
        padding: 3rem 0 !important;
    }

    .cartTableWrapper {
        width: 100%;
        tr.cart-item-row {
            background: var(--color-light-grey);
            border-radius: 14px;

            &:not(last-child) {
                margin-bottom: 1rem;
            }

            br {
                display: none;
            }

            .product.cart--productinfo {
                .summaryShortDescription {
                    display: none;
                }
                .rawAttributeInfo {
                    display: flex;
                    flex-direction: row;
                    gap: 18px;
                    flex-wrap: wrap;

                    .rawAttributeInfo__item {
                        span.value {
                            width: fit-content;
                            float: none;
                            font-weight: bold;
                        }
                        .title {
                            margin-top: 0px !important;
                        }
                    }
                }
                .product__title {
                    margin-bottom: 0.5rem;
                    a {
                        font-size: 1.5rem;
                    }
                }
            }
            td.cart--unitprice {
            }
            .cart--quantity {
            }
            .cart--actions {
                .cart--actions__buttons {
                    margin-top: 0px;
                    padding-right: 1rem;
                }
            }
            .end.cart--itemtotal {
                color: var(--color-pink);
            }
        }
    }

    .checkout-attributes {
        border: none;
        padding-top: 1rem;
        .checkout_attribute_title {
            padding: 0px !important;
        }

        .checkout_attribute_item {
            padding: 1rem;

            &:last-of-type {
                padding-bottom: 0px;
            }

            .options-list {
                flex-direction: row;
                gap: 20px;
                flex-wrap: wrap;
                margin: 0px;
                .option-item {
                    padding: 0px !important;
                    width: calc(33% - 20px);

                    input {
                        visibility: hidden;
                        height: 0.01em;

                        &:checked + label {
                            background: black !important;
                            border-color: black !important;
                            color: white !important;

                            &:before {
                                border-color: black !important;
                                background: black !important;
                                outline-color: black !important;
                            }
                        }
                    }
                    label {
                        width: 100%;
                        padding: 8px;
                        text-align: center;
                        border: 1px solid black;
                        border-radius: var(--radius-default);
                        cursor: pointer;
                        display: block;
                        position: relative;

                        &:before {
                            display: none;
                        }
                        &:hover {
                            background: var(--color-light-grey);
                        }
                    }
                }
            }
        }
    }
    .cart-collaterals {
        padding-top: 0px;
        .deals {
            padding: 1rem;

            .coupon-box__wrapper {
                margin-bottom: 0px !important;
            }
        }
    }

    div#cartTotals {
        padding: 1rem;

        h3.cart_total--title {
            /* display: block !important; */
            font-weight: bold;
        }

        .cart_total--order-total {
            .cart_total_right {
                color: var(--color-pink);
            }
            .cart_total_left {
                font-weight: bold;
            }
        }
    }
    .cart-kit-item {
        .end.cart--itemtotal {
            padding-top: 1rem !important;
        }
    }
}

.deliveryModuleContainer {
    max-width: 1672px;
    margin: 0 auto;
    padding: 3rem 64px 6rem 64px;

    #OrderDay,
    #DispatchDay,
    #DeliveryDay {
        text-align: center;
        padding: 6rem 0 0 0;
        position: relative;

        &:before {
            content: "";
            height: 1px;
            background: var(--color-text-light);
            display: block;
            top: 2rem;
            position: absolute;
            z-index: -1;
        }

        &:after {
            content: "\f466";
            font-family: "FontAwesome";
            border: 1px solid var(--color-text-light);
            padding: 5px;
            font-size: 2rem;
            border-radius: 16px;
            position: absolute;
            top: 0;
            left: 50%;
            transform: translate(-50%, 0);
            width: 62px;
            color: var(--color-pink);
            background: white;
        }

        h3 {
            span {
                font-size: 1rem !important;
            }
        }
        h5 {
            span {
                color: var(--color-pink);
                font-size: 1.5rem;

                &.date {
                    font-weight: bold;
                }
            }
        }
        p {
            color: var(--color-text-light);
        }
    }

    #OrderDay {
        &:before {
            width: 50%;
            right: 0;
        }
    }

    #DispatchDay {
        &:before {
            width: 100%;
        }

        &:after {
            content: "\f0d1";
        }
    }

    #DeliveryDay {
        &:before {
            width: 50%;
        }

        &:after {
            content: "\f467";
        }
    }
}

.one-page-checkout {
    .checkout-page {
        .step-title {
            font-weight: bold;
            color: var(--color-pink);
        }
        .vue-component-wrapper-shipping-address,
        tr.cart-item-row.parent-sci {
            border-radius: var(--radius-default);
        }
        .payment-methods {
            border-radius: var(--radius-default) !important;
            padding: 2rem !important;
        }
        .selected-checkout-attributes {
            .box {
                border-radius: var(--radius-default);
            }
        }
    }
}

.postCoder {
    border-radius: var(--radius-default);
    .postCoder__form {
        input {
            border-radius: var(--radius-default);
        }
    }
}

.layout--columnsOneE {
    #contentrow {
        padding-top: 0px;
    }
}
.grey-box-rounded {
    .container {
        .columns {
            background: var(--color-light-grey);
            padding: 2rem;
            border-radius: 32px;

            h1 {
                font-size: 4rem;
            }
            .small-text-top {
                font-size: 1rem;
                margin-bottom: 0;
            }
            .icon-top {
                text-align: center;
                display: flex;
                align-items: center;
                justify-content: center;
                .ict-embed {
                    border: 1px solid var(--color-text-light);
                    padding: 10px 15px;
                    font-size: 1.5rem;
                    border-radius: 16px;
                    color: var(--color-pink);
                    text-align: center;
                    margin-top: 1rem;
                    width: fit-content;
                }
            }
        }
    }
}

.grey-default-box {
    background: var(--color-light-grey);
    border-radius: 32px;
    padding: 2rem;
}

.page-customer-login {
    .register-customer-wrapper {
        display: none;
    }
    div#contentrow {
        padding-top: 0;
    }
}

.page-customer-register {
    #contentiInnerRow {
        .grid_3.column.is-3-desktop {
            display: none;
        }
        .grid_9.column.is-9-desktop {
            width: 100%;
        }
    }
    .registration-page {
        background: var(--color-light-grey);
        padding: 2rem;
        border-radius: var(--radius-default);
        margin: 2rem auto;
        input#register-button {
            width: 100%;
        }
        .table-container {
            &:last-of-type {
                margin-bottom: 0;
            }
        }
        .table-container--company {
            margin-bottom: 0;
            margin-top: 1.25rem;
            tr {
                padding-bottom: 1.25rem;
            }
        }
    }
    .login-button-bottom {
        max-width: 45.75rem !important;
        margin: 0 auto;
    }
}

/* .page-customer-login {
    .layout--columnsOneC {
        &:after {
            background-image: url("/1841730065/Handler/CSSOverride/GetImage/4/login-page.jpg");
            background-repeat: no-repeat;
            background-position: center;
            background-size: contain;
            width: 60vw;
            right: 0;
            position: absolute;
        }
        &:before {
            width: 40vw;
            background: white;
            left: 0;
            position: absolute;

        }

        &:before, &:after {
            content: '';
            height: 50vh;
            width: 40vw;
            display: block;
            top: 50%;
            bottom: 0;
            transform: translate(0, -50%);
        }

        #BeforeMainContainer {
            .column {
                .buttons {
                    justify-content: center;
                }
            }
            section {
                width: 60vw;
            }
        }
        .login__wrapper {
            padding-top: 0px;
            .page-title {
                display: none;
            }

            .register-customer-wrapper {
                display: none;
            }

            .returning-wrapper,
            .register-customer-wrapper {
                width: 100%;
            }
        }
        div#contentrow {
            width: 60vw;
        }

        button:not(:hover) {
            background: white;
            color: black;
            border: 1px solid black;
            &.active {
                background-color: #D40F7D;
                border-color: transparent;
                color: #fff;
            }
        }
        .login-top-section {
            img {
                width: 150px;
            }
            .title {
                text-align: center;
            }
        }
    }
} */

.login__wrapper {
    .returning-wrapper {
        .returning-wrapper__inner {
            background: transparent;
            padding-bottom: 1.5rem;
            margin-bottom: 1.5rem;
            border-bottom: 1px solid var(--color-text-light);
        }
    }
}

.advanced-select {
    .selected-item {
        border-radius: var(--radius-default);
    }
}

.account-page {
    .address-filter {
        padding-bottom: 1.5rem;
    }
    ul a.active,
    ul a.is-active {
        border-radius: var(--radius-default);
    }
}

.small-header {
    padding-bottom: 3rem !important;
    .subtitle {
        margin-top: 1rem !important;
    }
}

.how-it-works {
    padding: 2rem 0 !important;
    &:nth-child(even) {
        .columns {
            background: var(--color-light-grey);
            align-items: center;
            border-radius: var(--radius-default);
        }
    }
    &:last-of-type {
        padding-bottom: 6rem !important;
    }
}

.faq-blocks {
    .columns {
        gap: 25px;
        align-items: stretch;
        .box {
            margin-bottom: 0px !important;
            flex: 1 1 calc((100% - 50px) / 2);
            background: transparent;
            border: 1px solid var(--color-light-grey);
            box-shadow: 0 2px 10px rgba(10, 10, 10, 0.1);
            padding: 3rem !important;
            min-height: 300px;
        }
    }
}

.faq-container {
    .accordion-item {
        padding: 0.75rem;
        box-shadow: 0 2px 10px rgba(10, 10, 10, 0.1);
        border-radius: 8px;
        margin-bottom: 0.5rem;
        &.is-active {
            background: var(--color-light-grey);
            border-radius: 8px;
            padding: 2rem 1rem 2rem 2rem;
            .accordion-title {
                color: var(--color-pink) !important;
            }
        }
        .accordion-content {
            width: 90%;
            padding: 1rem;
        }
        .button {
            &.accordion-title {
                background: transparent;
                color: black;
                display: flex;
                margin-bottom: 0px !important;
                padding: 0px !important;
                gap: 20px;
                i {
                    border: 2px solid var(--color-pink);
                    padding: 0.25rem !important;
                    border-radius: 100%;
                    color: var(--color-pink) !important;
                }
            }
        }
    }
}

.accordion-item {
    .accordion-title {
        border-radius: var(--radius-default);
    }
}

.split-attribute-columns {
    .attribute {
        width: 50%;
    }
}

.one-page-checkout
    .cartTableWrapper
    .cart
    tr.cart-item-row
    td.cart--productinfo
    .summaryShortDescription {
    display: none !important;
}

@media only screen and (max-width: 1280px) {
    .footer-section-main {
        .empty-column {
            display: none;
        }
        .social-icons {
            width: 100%;
        }
    }
}

@media only screen and (max-width: 1087px) {
    .headermenu {
        .nav-search-container {
            top: 0rem !important;
        }
    }
    .footer-section-main {
        .footer-logo-section {
            align-items: center;
            justify-content: center;
            text-align: center;
        }
        .social-icons {
            justify-content: center;
            margin-bottom: 2rem !important;
        }
    }

    .bento-box-section {
        .bento-box-column {
            .inner-container {
                &:before {
                    content: "";
                    background: linear-gradient(
                        to top,
                        rgb(40 40 40),
                        transparent
                    );
                    position: absolute;
                    bottom: 0;
                    left: 0;
                    right: 0;
                    z-index: -1;
                    height: 45%;
                }
            }
        }
    }

    .container-slider {
        .columns {
            align-items: center !important;
            display: flex;
        }
        .image-side {
            display: none !important;
        }
    }

    .block-account-navigation {
        padding-bottom: 0 !important;
    }

    .shoppingcart__wrapper {
        form#cartform {
            display: block;
            .checkoutAttributesWrapper {
                width: 100%;
                .checkout_attribute_item {
                    width: 50% !important;
                    .option-item {
                        width: 100% !important;
                    }
                }
            }
            .common-buttons-container {
                width: 100%;
                align-content: flex-end;
            }
        }
        .common-buttons {
            padding: 1rem;
        }
        .cart-collaterals {
            padding-top: 1rem;
            width: 100% !important;
            .deals {
                padding: 0;
            }
        }
        div#cartTotals {
            width: 100%;
        }
    }
    #lbOverlay,
    #lbCenter,
    #lbBottomContainer {
        display: none !important;
    }
}

@media only screen and (min-width: 1088px) {
    .bento-box-section {
        .bento-box-hover-show {
            visibility: hidden;
            pointer-events: none;
            transition:
                visibility 0.3s ease-in,
                opacity 0.3s ease-in;
            opacity: 0;
        }
        & .bento-box-column {
            &:hover {
                .bento-box-hover-show {
                    visibility: visible;
                    pointer-events: all;
                    opacity: 1;
                }
                .inner-container {
                    &:before {
                        content: "";
                        background: linear-gradient(
                            to top,
                            rgb(40 40 40 / 70%),
                            transparent
                        );
                        position: absolute;
                        top: 0;
                        bottom: 0;
                        left: 0;
                        right: 0;
                        z-index: -1;
                    }
                }
            }
        }
    }
    span.current-basket-quantity {
        position: absolute;
    }
    .faq-blocks {
        & .columns {
            .box {
                max-width: calc(32% - 12px);
                flex: 1 1 calc((100% - 50px) / 3);
            }
        }
    }
}

@media only screen and (max-width: 768px) {
    .faq-blocks {
        & .columns {
            .box {
                max-width: 100%;
                flex: 1 1 100%;
            }
        }
    }
    .container-slider {
        .hero-top-cta-image {
            max-width: 250px;
        }
        .text-side {
            text-align: center;
            padding: 2rem;
            .ict-paragraph {
                text-align: center !important;
                font-size: 2rem;
            }
        }
        .columns {
            padding: 2rem;
        }
    }
    .split-attribute-columns {
        .attribute {
            width: 100%;
        }
    }
    .category-intro-wrapper {
        & .category-header {
            .category-top-image {
                padding: 0;
            }
        }
    }
    section.category-outro-wrapper {
        padding: 0px;
    }
    .deliveryModuleContainer {
        #OrderDay,
        #DispatchDay,
        #DeliveryDay {
            padding: 5rem 0 3rem 0;
            &:before {
                height: 100%;
            }
            .inner {
                background: white;
                padding: 1rem;
            }
        }
        #OrderDay,
        #DispatchDay {
            &:before {
                width: 1px;
                right: 50%;
                transform: translate(-50%, 0);
            }
        }
        #DeliveryDay {
            padding-bottom: 0;
            &:before {
                display: none;
            }
        }
    }
}

.grecaptcha-badge {
    display: none !important;
}

/*  Header */
.headermenu {

    & .two-tier-menu {
        transition: box-shadow 0.3s ease-in-out;
        box-shadow: 0 0 0 rgba(0, 0, 0, 0);

        &.scrolled {
            box-shadow: 0 2px 10px rgba(10, 10, 10, 0.1);
        }
    }

    & span.current-basket-quantity {
        top: -16px;
        right: unset;
    }

    & .top-menu-split {
        padding: 1.25rem 0;
    }

}

.top-menu-split {

    .navbar-item,
    .navbar-link {
        line-height: 1em;
    }

    .navbar-item:last-child {
        padding-right: 0;
    }

}

/* Content */

.section {
    padding-top: 0;
}

.multipartUi-V2-wrapper {
    padding-top: 32px;
}

.section.bento-box-section {
    padding: 0;
    margin: 0;

    &>DIV.container {
        padding: 0 48px;

    }

    & .bento-box-button {
        .button {
            width: 100%;
        }
    }

}

h1.ict-title,
h2.ict-title {
    margin-bottom: 0 !important;
    ;

    &+DIV {
        padding-top: 1em;
    }
}

.box {
    border-radius: 24px;
    padding: 32px 32px;
}


/* Covers the price, quantity dropdown and start button on the product page to ensure they line up with the columns above and below */
.price-quantity-start-wrapper {

    .column.quantity-wrapper {
        padding-left: 0;
        padding-right: 11px;
    }

    .column:last-of-type {
        padding-right: 0;
    }

}

.columns {
    margin-left: 0;
    margin-right: 0;


    .thumbs {
        padding: 0 !important;
    }

    .column.is-12,
    .column.is-full {
        padding-left: 0;
        padding-right: 0;
    }

    &.is-variable.is-4 {
        margin-left: 0;
        margin-right: 0;
        margin-top: 0;

        .column {
            &:only-child {
                padding: 0;
            }
        }
    }

    & .column:first-child {
        /*  Header */

        .headermenu {

            & .two-tier-menu {
                transition: box-shadow 0.3s ease-in-out;
                box-shadow: 0 0 0 rgba(0, 0, 0, 0);

                &.scrolled {
                    box-shadow: 0 2px 10px rgba(10, 10, 10, 0.1);
                }
            }

            & span.current-basket-quantity {
                top: -16px;
                right: unset;
            }

            & .top-menu-split {
                padding: 1.25rem 0;
            }

        }

        .top-menu-split {

            .navbar-item,
            .navbar-link {
                line-height: 1em;
            }

            .navbar-item:last-child {
                padding-right: 0;
            }

        }

        /* Content */

        .section {
            padding-top: 0;
        }

        .section.multipartUi-V2 {
            padding-top: 32px;
        }

        .section.bento-box-section {
            padding: 0;
            margin: 0;

            &>DIV.container {
                padding: 0 48px;

            }

            & .bento-box-button {
                .button {
                    width: 100%;
                }
            }

        }

        h1.ict-title,
        h2.ict-title {
            margin-bottom: 0 !important;
            ;

            &+DIV {
                padding-top: 1em;
            }
        }

        .box {
            border-radius: 24px;
            padding: 32px 32px;
        }

        .columns {
            margin-left: 0;
            margin-right: 0;

            &.is-variable.is-4 {
                margin-left: 0;
                margin-right: 0;
                margin-top: 0;

                .column {

                    padding-left: 0;
                    padding-right: 0;

                    &.is-12 {
                        padding-left: 0;
                        padding-right: 0;
                    }

                    &:only-child {
                        padding: 0;
                    }
                }
            }

            & .column:first-child {
                padding-left: 0;
            }

            & .column:last-child {
                padding-right: 0;
                margin-bottom: 0;
            }
        }

        .listWrapper .listItem {
            padding: 1.5rem !important;
        }

        .how-it-works .columns {
            padding: 16px;
        }

        .attribute-item.columns .column {
            &:first-of-type {
                padding-left: 0;
            }

            &:last-of-type {
                padding-right: 0;
            }
        }

        .columns.is-variable.is-4:last-child {
            margin-bottom: 0;
        }

        .faq-blocks {
            & .columns {
                & .box {
                    border-radius: 10px;
                    border: 1px solid #B7C3D8;
                    box-shadow: 0 12px 16px -4px rgba(16, 24, 40, 0.08);
                    padding: 48px !important;
                    min-height: 250px;
                    max-width: 100%;

                    UL {
                        margin-top: 0;
                        margin-left: 24px;
                        padding: 0;

                        LI::marker {
                            color: var(--color-pink);
                        }
                    }
                }
            }
        }

        .accordion-item.is-active {
            padding-bottom: 32px;
        }

        /*
        .fa-plus.has-text-dark,
        .fa-minus.has-text-dark {
            color: white !important;
        }
         */

        .discountedPrice text {
            padding-right: 8px;
        }

        .faq-container {
            & .accordion-item {

                margin-bottom: 16px;

                &.is-active {
                    padding: 0.75rem;

                    .accordion-content {
                        padding-left: 48px;
                    }
                }
            }
        }

        .section .container.is-flex>.columns {
            width: 100%;
        }


    }

    & .column:last-child {
        padding-right: 0;
        margin-bottom: 0;
    }
}

/* Counteract the first/last .column left/right padding above  */
.listWrapper {
    & .listItem {
        padding: 1.5rem !important;
    }
}

/* The Infigo CSS seems to set the selected button height to an important 40px,
   making these buttons shorter than non-checked versions. Restore original 2.75em */
.catfish-select,
input,
.attribute-value-item label {
    &:checked+label.button {
        height: 2.75em !important;
    }
}

/* Product page */
/*
.column.details-wrapper {
    padding-left: 0 !important;
    padding-right: 0 !important;
}
 */

.arone-product-landing-page {

    & .product-intro-section {
        padding-bottom: 32px;
        padding-top: 0;

        & .hero-body {
            border-radius: 24px;
            padding: 32px;
        }
    }

    & .picture.columns {

        padding: 0;
        margin: 0;

        & .bigpicture.column {
            padding: 0;
            line-height: 0;
            margin-bottom: 16px
        }

        & .thumbs-container {
            padding: 0;
            margin: 0;

            & .thumb.column {
                padding: 0;
                line-height: 0;
                margin: 0 16px 0 0;

                &:last-of-type {
                    margin-right: 0;
                }

            }
        }

        & .bigpicture,
        & .thumb {
            & img {
                border-radius: 24px;
            }
        }
    }

    & .product-intro-section {
        padding-bottom: 32px;
        padding-top: 0;
    }

    #delivery-countdown-banner {
        border-radius: 16px;
    }

}

.how-it-works .columns {
    padding: 16px;
}

.attribute-item.columns .column {
    &:first-of-type {
        padding-left: 0;
    }

    &:last-of-type {
        padding-right: 0;
    }

    /* Handle last visible column where columns are hidden using an inline display style.
       Include cases where the style is commented out. */

    &:not([style*="display: none"]):not([style*="display:none"]):not([style*="/*! display: none"]):not([style*="/*!display:none"]) {
        &:not(:has(~ .column:not([style*="display: none"]):not([style*="display:none"]):not([style*="/*! display: none"]):not([style*="/*!display:none"]))) {
            padding-right: 0;
        }
    }
}

.columns.is-variable.is-4:last-child {
    margin-bottom: 0;
}

.faq-blocks {
    & .columns {
        & .box {
            border-radius: 10px;
            border: 1px solid #B7C3D8;
            box-shadow: 0 12px 16px -4px rgba(16, 24, 40, 0.08);
            padding: 48px !important;
            min-height: 250px;
            max-width: 100%;

            UL {
                margin-top: 0;
                margin-left: 24px;
                padding: 0;

                LI::marker {
                    color: var(--color-pink);
                }
            }
        }
    }
}

.accordion-item.is-active {
    padding-bottom: 32px;
}

.fa-plus.has-text-dark,
.fa-minus.has-text-dark {
    color: white !important;
}

.discountedPrice text {
    padding-right: 8px;
}

.faq-container {
    & .accordion-item {

        margin-bottom: 16px;

        &.is-active {
            padding: 0.75rem;

            .accordion-content {
                padding-left: 48px;
            }
        }
    }
}

.section .container.is-flex>.columns {
    width: 100%;
}


/* Footer */


/* Footer */
#footer-section-main,
#footer-section-legal {
    background: var(--color-light-grey);
}

.footer-section-main {

    margin-top: 32px;
    padding-top: 32px;
    padding-bottom: 1rem;
    z-index: 1;
    display: inline-block;

    .column {
        flex: 0 0 auto;
    }

    .columns {
        @media (min-width: 768px) {
            align-items: flex-start
        }
    }

    @media (min-width: 1180px) {
        .columns .column:nth-child(3) {
            flex: 1 0 0;
        }
    }

    .content li+li {
        margin-top: 0;
    }

    span {
        color: black !important;
    }

    .footer-payment-icons,
    .social-icons {
        gap: 10px;

        .fa {
            font-size: 16px;
        }
    }

    .social-icons {

        @media (min-width: 768px) {
            padding-right: 12px;
        }

        .icon {
            height: fit-content;
            width: fit-content;

            .fa {
                font-size: 22px;
            }
        }
    }

    .footer-logo-section {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
        text-align: center;
        justify-content: center;
        flex: 0;

        UL {
            width: unset;
        }

        @media (min-width: 1180px) {
            text-align: right;
            justify-content: flex-end;
            margin-left: 16px;
        }

        &>div {
            margin-bottom: 10px !important;
            width: 50px;
            padding-right: 0;

            &:first-of-type {
                width: unset;
            }

            &:last-of-type {
                width: 100%;

                img {
                    width: 136px;
                }
            }
        }

        .footer-logo {
            img {
                height: 71px;
            }
        }
    }

    .footer-payment-logo-section {
        min-width: 220px;
        max-width: 256px;
        display: flex;
        gap: 16px;
        justify-content: center;
        flex-wrap: wrap;

        @media (max-width: 1180px) {
            flex: 0 0 100%;
            max-width: unset;
        }

        &>div {
            margin-bottom: 0 !important;
            width: 50px;
            display: flex;
            flex-direction: row;
        }

        .footer-payment-logo {
            width: 50px;
            margin: 0;
        }

        .block:last-of-type {
            width: 136px;
        }

        .block:last-of-type * {
            width: 136px;

            @media (min-width: 768px) {
                width: 100%;
            }
        }
    }
}

/* Basket */

.shoppingcart__wrapper {
    & .cartTableWrapper {

        & th.end.cart--total,
        & td.end.cart--itemtotal {
            text-align: right;
        }

        & th.cart--single-price,
        & th.cart--quantities,
        & th.cart--total {
            width: 0;
            min-width: fit-content;
        }

        & tr.cart-item-row {
            background: unset;

            & .cart--quantity SELECT {
                margin: 0;
            }

            & .product.cart--productinfo {
                & .rawAttributeInfo {
                    flex-direction: column;
                    row-gap: 0;
                }
            }
        }

        & table td {
            padding: 24px 16px;
        }

        & table td:first-child {
            padding-left: 0;
        }

        & table td:last-child {
            padding-right: 0;

            .catfish-select,
            .arone-product-landing-page .attribute input:checked+label.button,
            .button {
                padding: 8px 16px !important;
                height: unset !important;
            }
        }

        /*
        & .basketEditButton.design,
        & .basketEditButton.options {
            display: none;
        }
        */
    }

    & div#cartTotals {
        padding: 0;
    }

    .buttons:not(.is-fullwidth) .catfish-button:not(:last-child) {
        margin-right: 16px;
    }

}


.how-it-works {
    padding: 1rem 0 !important;
}




/* Attempt to hide the product page main image on initial load to allow time for the JS to load
   before potentially switching from the primary image to the secondary image - this is trying to
   avoid a FOUC-style behaviour where one image appears and is rapidly replaced by another with
   an ugly flash. I've added the important modifiers to override any Infigo-set values. */
body:not(.js-loaded) .product-details-info .bigpicture {
    opacity: 0 !important;
    visibility: hidden !important;
}

/* When JS loads, we add the js-loaded class to the body which triggers the big picture fade in */
body.js-loaded .product-details-info .bigpicture {
    opacity: 1;
    visibility: visible;
    transition: opacity .5s ease-out;
}

/* As a fallback, show the image after 10 seconds even if the JS fails to fire. This is arguably
   too long but it's a fallback - the JS should fire in most cases */
@keyframes show-fallback {
    to {
        opacity: 1;
        visibility: visible;
    }
}

body:not(.js-loaded) .product-details-info .bigpicture {
    animation: show-fallback 0s 10s forwards;
}




html.is-safari .headermenu {
    & .hidden-mobile-menu {
        & .navbar-item {
            &.has-dropdown {
                margin-bottom: 1.5rem;
            }
        }
    }
}

.hidden-mobile-menu {

    /* Prevent invisible mega menu dropdown from capturing pointer events... */
    .navbar-item.has-dropdown .navbar-dropdown {
        pointer-events: none;
        padding-left: 1.6rem;
    }

    /* ... and re-enable when parent has is-active */
    .navbar-item.has-dropdown.is-active .navbar-dropdown {
        pointer-events: auto;
    }
    
    .mega-menu-column {
    
        .navbar-item {
            padding-left: 3.2rem;

        }

        .navbar-item.column-title {
            padding-left: 1.6rem;

        }
    }

}



/* Blog Styles */
.blog-page {
    padding-top: 0;
    padding-bottom: 0;

    .page-title H1 {
        border-radius: 24px;
        padding: 32px 32px;
        background-color: #D40F7D !important;
        color: white;
        font-weight: 600;
        line-height: 1.125;
        font-size: 2.488rem;
    }

    .blogsearch {
        display: none;
    }

    .blogposts {
        .blogposts-list .post .post-content {
            background: var(--color-light-grey);
            border-radius: var(--radius-default);
        }

        .columns {
            & .column:last-child {
                padding-right: 0.75rem;
            }
        }

    }
}

.account-page,
.block-account-navigation {
    padding-top: 0;
}

.block-account-navigation .title {
    padding-top: 22px;
    font-size: 1rem;
}

.registration-page {
    .postCoder  {
        padding: 0px;
    }
}

.account-page--addresses {
    .address-filter {
        input {
            margin-bottom: 5px;
        }
    }
}

@media (max-width: 768px) {
    .attribute-item.columns .column {
        padding: 0.75rem 0 !important;
    }
    .price-quantity-start-wrapper {
        .column.quantity-wrapper {
            padding-left: 0px;
            padding-right: 0px;
        }
    }

    .price-quantity-start-wrapper {
        .column:last-of-type {
            padding-right: 0;
            padding-left: 0;
        }
    }

    .full-description-wrapper {
        .ict-left-column, .ict-right-column {
            .button {
                width: 100%;
            }
        }
    }

    .custom-product-form {
         input.input {
            border-radius: var(--radius-default)!important;
        }
        .product-version-list {
            .product-version-controls {
                .field-body {
                    width: 100%;
                }
                select, input {
                    border-radius: var(--radius-default)!important;
                }
            }
        }
    }

    .price-quantity-start-wrapper {
        .action-button-wrapper {
            padding: 0.75rem 0px;
        }
    }

    .shoppingcart__wrapper {
        & .cartTableWrapper {
            & tr.cart-item-row {
                & .cart--actions {
                    padding-right: 0px;
                    .cart--actions__buttons {
                        padding-right: 0px;
                    }
                    .cart--actions {
                        padding: .75rem 0px;
                    }
                }
            }
        }
    }
}

@media (max-width: 459px) {
    /** footer centered **/    
    #footer-section-main {
        .footer-list-column-short {
            h3, ul {
                text-align: center !important;
            }
        }
    }
}

