.type-product main {
    display: flex;
    gap: 5rem;
    flex-direction: column;
    align-items: stretch;
}

.woocommerce-error,
.woocommerce-info,
.woocommerce-message {
    background-color: var(--grey);
    color: var(--primary);
    /* background-color: var(--primary);
  color: var(--menucolor); */
    /* padding: 1rem 2rem 1rem 5rem; */
    /* border-left: 1rem solid var(--primary);
  border-top: none; */
    display: flex;
    gap: 0.5em;
    flex-wrap: wrap;
    width: 100%;
    justify-content: space-between;
}

.woocommerce-error li ~ li {
    width: 100%;
}

.wooco_alert {
    display: none !important;
}

.woocommerce-error > .button,
.woocommerce-info > .button,
.woocommerce-message > .button {
    float: none;
    margin-left: auto;
    order: 1;
}

.woocommerce-error span:empty,
.woocommerce-info span:empty,
.woocommerce-message span:empty {
    display: none;
}

:focus-visible {
    outline: none;
}
.woocommerce-message:focus-visible {
    outline: none;
}

.account-payment-methods-table {
    margin-top: 0;
}

.wooco_components
    .wooco_component.wooco_component_required
    .wooco_component_name:after,
.woocommerce form .form-row .required {
    content: none;
    color: var(--secondary);
}

.woocommerce-message {
    border-top-color: var(--primary);
}

.woocommerce-message::before {
    content: '\e015';
    color: var(--primary);
}

.wooco_components {
    transition: 0.2s ease all;

    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: flex-start;
    flex-direction: column;
}

.wooco-wrap .wooco_components {
    display: table;
    width: 100%;
    margin: 0;
    vertical-align: middle;
    position: relative;
}

.wooco-wrap .wooco_components > * {
    display: table-row;
    vertical-align: inherit;
}

.wooco-wrap .wooco_components > * > * {
    display: table-cell;
    padding-bottom: 0.5rem;
    vertical-align: inherit;
}

.wooco-wrap .wooco_components > * > :first-child {
    width: max-content;
    vertical-align: middle;
}

.wooco-wrap .wooco_components > * > :last-child {
    /* width: 75%; */
}

.wooco-wrap .wooco_components > * > :not(:last-child) {
    padding-right: 2rem;
}

.wooco_component_product > div {
    padding: 0;
}

.wooco_component_product .wooco_component_product_selection p {
    /* background-color: var(--grey); */
    width: 100%;
    font-family: inherit;
    font-size: 100%;
    margin: 0;
    padding: 0.5rem 1.66rem;
    border: 1px solid var(--grey);
    font-weight: normal;
    color: fieldtext;
}

.wooco_component_product_selection [type='checkbox'] {
    display: block;
    width: 0 !important;
    height: 0;
    overflow: hidden;
    opacity: 0;
    margin: 0;
}

.wooco_component_product_selection
    [type='checkbox']:focus-visible
    + label:before {
    outline: 2px solid var(--secondary);
}

.wooco_component_product_selection [type='checkbox'] + label {
    position: relative;
    padding-left: 3em;
    width: 100%;
    transition: all 0.3s ease;

    font-family: inherit;
    font-size: 100%;
    margin: 0;
    padding: 0.5rem 1.66rem 0.5rem 3em;
    border: 1px solid transparent;
    font-weight: normal;
    color: fieldtext;
}

.wooco_component_product_select option.hidden {
    display: none !important;
}

.wooco_component_product_selection [type='checkbox']:not(:checked) + label {
    color: transparent;
}

.wooco_component_product_selection [type='checkbox'] + label:after {
    content: '';
    width: 2em;
    height: 1em;
    color: transparent;
    display: inline-block;
    background-color: darkred;
    cursor: pointer;
    border-radius: 0.5em;
    /* border: 1px solid var(--primary); */
    position: absolute;
    overflow: visible;
    margin-right: auto;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    transition: all 0.3s ease;
}

.wooco_component_product_selection [type='checkbox']:checked + label:after {
    background-color: var(--grey);
}
.wooco_component_product_selection [type='checkbox'] + label:before {
    content: '';
    display: block;
    position: absolute;
    left: 0.5em;
    top: 0;
    width: max-content;
    background-color: var(--grey);
    font-size: 0.8em;
    display: block;
    width: 1.5em;
    height: 1.5em;
    top: 50%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    transition: all 0.3s ease;
    box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.7);
    z-index: 1;
    cursor: pointer;
}

.wooco_component_product_selection [type='checkbox']:checked + label:before {
    left: 2em;
    background-color: var(--primary);
}

.wooco_components.disabled {
    opacity: 0.6;
    pointer-events: none;
}

.woocommerce .cart-note {
    width: 20rem;
    flex-grow: 1;
}

form.cart .button.toggler {
    flex-shrink: 0;
}

.woocommerce .cart-note:not(.discount) ~ .quantity,
.woocommerce .cart-note:not(.discount) ~ .single_add_to_cart_button {
    display: none !important;
}

.woocommerce div.product {
    display: flex;
    flex-direction: row-reverse;
    gap: 4rem;
    align-items: flex-start;

    display: grid;
    grid-template-columns: 1fr 40rem;
    grid-auto-flow: dense;
}

.woocommerce #content div.product div.summary,
.woocommerce div.product div.summary,
.woocommerce-page #content div.product div.summary,
.woocommerce-page div.product div.summary {
    float: none;
    width: 100%;
    margin: 0;
    display: flex;
    /* flex-direction: column; */
    gap: 1em;
    align-items: stretch;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: baseline;
    grid-row-end: span 2;
}

.serial_number_ajax_load {
    width: 100%;
}

.wooco_components .wooco_component {
    /* padding: 1rem; */
    /* border: 1px solid #ddd; */
    flex-grow: 1;
    /* background-color: var(--menucolor); */
    border: none;
}

.wooco_components .wooco_component select,
.wooco_components .wooco_component input[type='text'] {
    min-width: 10rem;
    padding-top: 0;
    padding-bottom: 0;
    margin: 0;
    width: 100%;
}

.woocommerce .quantity .qty:focus-visible,
.wooco_components .wooco_component select:focus-visible,
.wooco_components .wooco_component input:focus-visible {
    outline: 2px solid var(--secondary);
}

.woocommerce div.product form.cart .button:focus-visible {
    color: var(--menucolor);
    background-color: var(--primary);
}

.wooco-wrap {
    /* background-color: var(--grey); */
    /* padding: 5rem; */

    border-top: 2px solid var(--grey);
    border-bottom: 2px solid var(--grey);
    padding: 2rem 0;
}

.wooco-wrap .wooco-summary {
    padding: 2rem 0 0;
    margin: 2rem 0 0;
    border-top: 2px solid var(--grey);
}

.woocommerce-Price-amount.amount {
    font-weight: 500;
}

.woocommerce-thankyou-order-details .woocommerce-Price-amount.amount {
    font-weight: inherit;
}

.woocommerce_product_prices_overview {
    overflow: hidden;
}

.woocommerce_product_prices_overview > div {
    position: relative;
}

.woocommerce_product_prices_overview.loading > div:before {
    content: '';
    position: absolute;
    left: 50%;
    top: 1em;
    height: 0.75em;
    width: 1em;
    margin: 0 -0.25em;
    display: block;
    background-color: var(--secondary);
    /* border-radius: 50%; */
    transform-origin: center;
    /* animation: loading_price 1s linear 0s infinite forwards both; */
    animation-duration: 2s;
    animation-timing-function: linear;
    animation-delay: 0s;
    animation-iteration-count: infinite;
    animation-name: loading_price;
    animation-fill-mode: both;
    animation-direction: alternate;
}

@keyframes loading_price {
    0% {
        /* transform: scale(1) translateX(.5rem); */
        transform: skewX(-11.5deg);
        background-color: var(--secondary);
    }
    100% {
        /* transform: scale(1.6) translateX(.5rem); */
        transform: skewX(0deg);
        background-color: var(--grey);
    }
}

.woocommerce_product_prices_overview .price {
    transition: all 0.3s ease;
}

.woocommerce_product_prices_overview.loading .price {
    opacity: 0.1;
}

.cart_totals .woocommerce-Price-amount.amount,
.woocommerce ul#shipping_method .amount {
    font-weight: inherit;
}

tr.order-tax > * {
    border-top: none !important;
    padding-top: 0 !important;
    font-weight: 300 !important;
}

.order-tax td:empty + td:empty {
    display: none;
}

.woocommerce table.shop_table tfoot td,
.order-tax .woocommerce-Price-amount.amount {
    font-weight: inherit;
}

#add_payment_method .wc-proceed-to-checkout,
.woocommerce-cart .wc-proceed-to-checkout,
.woocommerce-checkout .wc-proceed-to-checkout {
    padding-bottom: 0;
}

.woocommerce-ResetPassword,
div.create-account,
.woocommerce-billing-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper,
.woocommerce div.product form.cart {
    display: flex;
    justify-content: flex-end;
    gap: 1rem;
    width: 100%;
    max-width: 100%;
    margin-bottom: 0;
    flex-wrap: wrap;
    align-items: flex-start;
}

.woocommerce-ResetPassword > *,
div.create-account > *,
.woocommerce-billing-fields__field-wrapper > *,
.woocommerce-shipping-fields__field-wrapper > * {
    flex-grow: 1;
}

.woocommerce-ResetPassword > p {
    width: 100%;
}

.woocommerce-ResetPassword .clear,
div.create-account .clear {
    display: none;
}

.woocommerce-ResetPassword .clear + p {
    width: 100%;
}

.woocommerce-ResetPassword .button {
    align-self: flex-end;
}

.woocommerce-password-hint,
.woocommerce-password-strength {
    font-size: 0.8em;
    width: 100%;
    text-align: left;
}

.create-account .form-row {
    width: 100%;
    flex-grow: 1;
    align-self: flex-start;
}

.woocommerce div.product form.cart .button {
    float: none;
}

.woocommerce div.product form.cart::after,
.woocommerce div.product form.cart::before {
    content: none;
}

.woocommerce .quantity .qty {
    border: 1px solid var(--primary);
    background-color: var(--menucolor);
    margin: 0;
    padding-right: 0.5em;
    padding-left: 0.5em;
    min-width: 8rem;
}

.woocommerce div.product form.cart div.quantity {
    float: none;
    margin: 0;
}

.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    #respond
    input#submit,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    a.button,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    button.button,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    input.button,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    #respond
    input#submit,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    a.button,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    button.button,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    input.button,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    #respond
    input#submit.alt.disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    #respond
    input#submit.alt.disabled:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    #respond
    input#submit.alt:disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    #respond
    input#submit.alt:disabled:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    #respond
    input#submit.alt:disabled[disabled],
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    #respond
    input#submit.alt:disabled[disabled]:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    a.button.alt.disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    a.button.alt.disabled:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    a.button.alt:disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    a.button.alt:disabled:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    a.button.alt:disabled[disabled],
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    a.button.alt:disabled[disabled]:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    button.button.alt.disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    button.button.alt.disabled:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    button.button.alt:disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    button.button.alt:disabled:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    button.button.alt:disabled[disabled],
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    button.button.alt:disabled[disabled]:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    input.button.alt.disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    input.button.alt.disabled:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    input.button.alt:disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    input.button.alt:disabled:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    input.button.alt:disabled[disabled],
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    input.button.alt:disabled[disabled]:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    #respond
    input#submit.alt.disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    #respond
    input#submit.alt.disabled:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    #respond
    input#submit.alt:disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    #respond
    input#submit.alt:disabled:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    #respond
    input#submit.alt:disabled[disabled],
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    #respond
    input#submit.alt:disabled[disabled]:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    a.button.alt.disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    a.button.alt.disabled:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    a.button.alt:disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    a.button.alt:disabled:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    a.button.alt:disabled[disabled],
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    a.button.alt:disabled[disabled]:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    button.button.alt.disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    button.button.alt.disabled:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    button.button.alt:disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    button.button.alt:disabled:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    button.button.alt:disabled[disabled],
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    button.button.alt:disabled[disabled]:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    input.button.alt.disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    input.button.alt.disabled:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    input.button.alt:disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    input.button.alt:disabled:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    input.button.alt:disabled[disabled],
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    input.button.alt:disabled[disabled]:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    #respond
    input#submit.alt,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    a.button.alt,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    button.button.alt,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    input.button.alt,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    #respond
    input#submit.alt,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    a.button.alt,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    button.button.alt,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    input.button.alt,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    #respond
    input#submit.alt:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    a.button.alt:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    button.button.alt:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    input.button.alt:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    #respond
    input#submit.alt:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    a.button.alt:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    button.button.alt:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    input.button.alt:hover {
    background-color: var(--secondary);
    color: var(--menucolor);
    display: inline-block;
    padding: 1rem 2rem;
    margin: 0;
    min-width: 10rem;
    text-align: center;
    font-weight: 700;
    border-radius: 0;
    width: auto;
    align-self: stretch;
    width: fit-content;
    max-width: 100%;
}

#add_payment_method #payment,
.woocommerce-cart #payment,
.woocommerce-checkout #payment {
    background-color: var(--grey);
    border-radius: 0;
    margin: 0;
}

.woocommerce .product_details {
    display: flex;
    width: 100%;
    flex-direction: column;
    gap: 5rem;
    align-items: stretch;
}

.woocommerce .related.products {
    padding: 2rem 0 0;
    border-top: 2px solid var(--grey);
}

.woocommerce:where(body:not(.woocommerce-uses-block-theme))
    ul.products
    li.product
    .price,
.woocommerce:where(body:not(.woocommerce-uses-block-theme)) div.product p.price,
.woocommerce:where(body:not(.woocommerce-uses-block-theme))
    div.product
    span.price {
    color: var(--secondary);
}

.archive.woocommerce main {
    padding: 3rem calc(100vw / 12);
    position: relative;
}

.woocommerce .products ul::after,
.woocommerce .products ul::before,
.woocommerce ul.products::after,
.woocommerce ul.products::before {
    content: none;
}

.woocommerce ul.products {
    padding-top: 2.5rem;
    padding-right: 5rem;
    display: grid;
    flex-wrap: wrap;
    gap: 7rem;
    justify-content: flex-start;
    align-items: stretch;
    width: 100%;
    grid-template-columns: repeat(auto-fill, minmax(35rem, 1fr));
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    bottom: auto;
    padding: 5rem 3rem 3rem;
    margin: 0;
    background-color: var(--grey);
    width: 100%;

    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.woocommerce ul.products li.product > a.button,
.woocommerce-page ul.products li.product > a.button {
    align-self: center;
}

.woocommerce ul.products li.product > a:not(.button),
.woocommerce-page ul.products li.product > a:not(.button) {
    align-self: stretch;
}

.woocommerce ul.products li.product .woocommerce-loop-category__title,
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h3,
.woocommerce-loop-product__title {
    position: absolute !important;
    top: -2.5rem;
    right: -5rem;
    width: 80%;
    background-color: var(--primary);
    color: var(--menucolor);
    z-index: 1;
    display: block;
    text-align: left;
    padding-left: 2rem;
    padding-right: 2rem;
    font-weight: 700;
    font-size: 2rem;
    hyphens: auto;
}

.woocommerce-loop-product__title:before {
    content: '';
    transform: skew(-11.5deg, 0deg) translateX(-50%);
    height: 101%;
    width: 100%;
    z-index: -1;
    position: absolute;
    left: 50%;
    top: 0;
    transform-origin: top;
    background-color: inherit;
}

.woocommerce .product p.wc-gzd-additional-info {
    margin: 0;
    align-self: flex-end;
}

.woocommerce .product .wc-gzd-additional-info.delivery-time-info {
    line-height: 1.2;
    margin-left: auto;
}

.products.related .wc-gzd-additional-info.delivery-time-info {
    display: none;
}

.woocommerce .product .price {
    margin: 0;
    flex-grow: 1;
}

.woocommerce .summary h1 {
    margin-top: 0;
}

.woocommerce .product .cta {
    padding: 3rem 2rem;
    background-color: var(--grey);
    display: flex;
    flex-direction: column;
    gap: 1em;
    margin-top: auto;
    grid-column-start: 2;
}

.woocommerce .product .cta .h3 {
    margin: 0;
    width: 100%;
}

.woocommerce .product .cta p + p {
    margin-top: 0;
}

.cta .wpcf7-list-item {
    margin: 0;
}

.cta form .h2 {
    margin-top: 0 !important;
}

.cta form p {
    color: inherit;
    font: inherit;
    font-size: 1em;
}
.individual_request {
    position: fixed;
    right: 0;
    top: 50%;
    max-height: 100vh;
    transform: translateY(-50%);
    height: auto;
    padding: 1rem 0 1rem 0;
    z-index: 200;
}

.cta .wpcf7 form .wpcf7-response-output {
    background-color: var(--menucolor);
    margin: 0;
    padding: 1rem 2rem;
    color: var(--primary);
}

.cta .wpcf7 form.send .wpcf7-response-output {
    color: var(--primary);
}

.entry-content ul[class^='woocommerce'] {
    margin-left: 0;
}

/* .individual_request:after {
  content: '';
  z-index: -1;
  display: block;
  position: absolute;
  right: 0;
  top: 50%;
  height: 90vh;
  transform: translateY(-50%);
  background-color: var(--grey);
  width: 20vw;
  pointer-events: none;
} */

.individual_request form {
    padding: 5rem;
    background: var(--primary);
    color: var(--menucolor);
    max-height: 100%;
    overflow: auto;
    position: relative;
    z-index: 1;
    max-width: 50rem;

    display: flex;
    flex-direction: column;
    gap: 0.5em;
    align-items: stretch;
}

.individual_request .close {
    position: absolute;
    background-color: var(--grey);
    display: block;
    top: 0;
    right: 0;
    padding: 0.5rem 2rem;
    cursor: pointer;
    z-index: 2;
    text-decoration: none;
}

.individual_request .close:before {
    z-index: -1;
}

.individual_request .close:focus-visible {
    color: var(--menucolor);
    background-color: var(--secondary);
}

.individual_request .checkbox,
.individual_request .checkbox > p {
    display: flex;
    align-items: first baseline;
    gap: 0.5em;
}

.individual_request .checkbox input {
    width: auto;
    flex-shrink: 0;
}

.individual_request textarea {
    height: 10rem;
    border: 1px solid var(--primary);
}

.individual_request input.wpcf7-not-valid,
.individual_request textarea.wpcf7-not-valid,
.individual_request select.wpcf7-not-valid {
    border-color: var(--secondary);
}

.individual_request input[type='submit']:focus {
    border: 1px solid var(--secondary);
}

.individual_request input[type='submit']:focus-visible {
    outline: 2px solid var(--menucolor);
}

.individual_request .wpcf7-not-valid-tip {
    color: var(--menucolor);
    background-color: var(--secondary);
    display: block;
    padding: 0.25em 1em;
    margin: -0.75em 1em 0 auto;
    z-index: 1;
    position: relative;
    width: fit-content;
    max-width: 100%;
}

.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles))
    a.button.toggler {
    margin: auto;
    display: block;
    width: fit-content;
    max-width: 100%;
    padding: 1.4rem 2rem;
}

.woocommerce div.product div.images {
    float: none;
    width: 100%;
    margin: 0;
}

.woocommerce div.product .image_wrapper {
    align-self: stretch;
    display: flex;
    flex-direction: column;
    gap: 2rem;
    align-items: stretch;
    max-width: 40rem;
    justify-content: flex-start;
    grid-column-start: 2;
}

.woocommerce-notices-wrapper:empty {
    display: none;
}

.woocommerce-notices-wrapper {
    width: 100%;
}

.woocommerce div.product div.images img {
    object-fit: contain;
}

/* CART & CHECKOUT */

.woocommerce-account article .entry-content,
.woocommerce-cart article .entry-content,
.woocommerce-checkout article .entry-content {
    width: 100%;
}

.checkout.woocommerce-checkout,
.woocommerce-cart-form {
    width: 100%;
    max-width: 100%;
}

.woocommerce table.shop_table {
    border-radius: 0;
    border: none;
}

.shop_table thead th,
.woocommerce-cart-form thead th {
    background-color: var(--primary);
    color: var(--menucolor);
}

.woocommerce-account tr > *,
.order_details tr > *,
.woocommerce-checkout-review-order-table tr > *,
.woocommerce-cart-form tr > * {
    background: var(--menucolor);
}

.woocommerce-account tbody tr:nth-child(even) > *,
.order_details tbody tr:nth-child(even) > *,
.woocommerce-checkout-review-order-table tbody tr:nth-child(even) > *,
.woocommerce-cart-form tr:nth-child(even) > * {
    background-color: var(--focus);
}

.woocommerce table.shop_table td {
    border-top: 0;
}

.woocommerce table.shop_table td.product-serial-number .variations,
.woocommerce table.shop_table .delivery-time-info {
    font-size: 90%;
}

.shop_table.woocommerce-checkout-review-order-table .variations {
    font-size: 95%;
}

.woocommerce table.shop_table td.actions {
    background: none;
    /* border-top: 2px solid var(--grey); */
}

.woocommerce .woocommerce-checkout table.shop_table td.actions {
    padding-left: 0.5em;
    padding-right: 0.5em;
}

.woocommerce a.remove {
    color: var(--secondary) !important;
    line-height: 0.8;
}

.woocommerce a.remove:hover {
    background-color: var(--secondary);
}

.woocommerce .cart-collaterals,
.woocommerce-page .cart-collaterals,
.woocommerce .col2-set,
.woocommerce-page .col2-set {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    grid-auto-flow: dense;
    align-items: start;
}

.woocommerce .cart-collaterals,
.woocommerce-page .cart-collaterals > * {
    width: 100% !important;
}

.woocommerce .cart-collaterals > * {
    padding: 2rem;
    border: 2px solid var(--grey);
}

.woocommerce .cart-collaterals > * h2 {
    margin-top: 0;
}

.woocommerce .cart-collaterals .shipping_calculator,
.woocommerce-page .cart-collaterals .shipping_calculator,
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-page .cart-collaterals .cart_totals {
    float: none;
}

.woocommerce .cart-collaterals::after,
.woocommerce .cart-collaterals::before,
.woocommerce-page .cart-collaterals::after,
.woocommerce-page .cart-collaterals::before {
    content: none;
}

@media (min-width: 769px) {
    #add_payment_method .cart-collaterals .cart_totals tr td,
    #add_payment_method .cart-collaterals .cart_totals tr th,
    .woocommerce-cart .cart-collaterals .cart_totals tr td,
    .woocommerce-cart .cart-collaterals .cart_totals tr th,
    .woocommerce-checkout .cart-collaterals .cart_totals tr td,
    .woocommerce-checkout .cart-collaterals .cart_totals tr th,
    .woocommerce table.shop_table tbody th,
    .woocommerce table.shop_table tfoot td,
    .woocommerce table.shop_table tfoot th {
        border-top: 2px solid var(--grey);
    }

    main.product .wooco-wrap .wooco-summary {
        display: none !important;
    }
}
@media (max-width: 768px) {
    #add_payment_method .cart-collaterals .cart_totals tr td,
    #add_payment_method .cart-collaterals .cart_totals tr th,
    .woocommerce-cart .cart-collaterals .cart_totals tr td,
    .woocommerce-cart .cart-collaterals .cart_totals tr th,
    .woocommerce-checkout .cart-collaterals .cart_totals tr td,
    .woocommerce-checkout .cart-collaterals .cart_totals tr th,
    .woocommerce table.shop_table tbody th,
    .woocommerce table.shop_table tfoot td,
    .woocommerce table.shop_table tfoot th {
        border-top: none;
    }
}

.wc-saved-payment-methods label {
    color: var(--menucolor);
}

.woocommerce .col2-set,
.woocommerce-page .col2-set {
    width: 100%;
    padding: 0;
}

.woocommerce .col2-set::after,
.woocommerce .col2-set::before,
.woocommerce-page .col2-set::after,
.woocommerce-page .col2-set::before {
    content: none;
}

.woocommerce .col2-set .col-1,
.woocommerce-page .col2-set .col-1,
.woocommerce .col2-set .col-2,
.woocommerce-page .col2-set .col-2 {
    float: none;
    width: 100%;
}

article.page input[type='text'],
article.page input[type='email'],
article.page input[type='tel'],
article.page select,
article.page textarea,
.select2-container--default .select2-selection--single {
    border: 1px solid var(--primary);
    padding: 0.5rem 1.5rem;
    border-radius: 0;
    max-width: 100%;
}

.woocommerce select {
    -webkit-appearance: none;
    background-image: url(../img/arrow-down.svg);
    background-repeat: no-repeat;
    background-position: calc(100% - 1rem) 50%;
    background-size: 1em;
    border-radius: 0;
    padding-right: 4rem;
}

#add_payment_method #payment ul.payment_methods,
.woocommerce-cart #payment ul.payment_methods,
.woocommerce-checkout #payment ul.payment_methods {
    background-color: var(--grey);
    border-radius: 0;
    border: none;
}

#add_payment_method #payment div.payment_box,
.woocommerce-cart #payment div.payment_box,
.woocommerce-checkout #payment div.payment_box {
    background-color: var(--primary);
    color: var(--menucolor);
}

.payment_method_ppcp-gateway div.payment_box {
    display: none !important;
}

.ppc-button-wrapper {
    margin: 2em auto 0;
}

#add_payment_method #payment div.payment_box .wc-credit-card-form,
.woocommerce-cart #payment div.payment_box .wc-credit-card-form,
.woocommerce-checkout #payment div.payment_box .wc-credit-card-form,
#payment div.payment_box fieldset.wc-payment-form {
    color: var(--primary);
    background-color: var(--menucolor) !important;
    padding: 2rem;
    margin: 0 0 1em;

    display: flex;
    flex-wrap: wrap;
    gap: 1em;
}

#add_payment_method #payment div.payment_box .form-row,
.woocommerce-cart #payment div.payment_box .form-row,
.woocommerce-checkout #payment div.payment_box .form-row {
    margin: 0;
    padding: 0;
    flex-grow: 1;
}

.woocommerce #payment div.payment_box .clear {
    display: none;
}

.stripe-source-errors:empty {
    display: none;
}

#add_payment_method
    #payment
    ul.payment_methods
    li:not(.woocommerce-notice)::after,
.woocommerce-cart
    #payment
    ul.payment_methods
    li:not(.woocommerce-notice)::after,
.woocommerce-checkout
    #payment
    ul.payment_methods
    li:not(.woocommerce-notice)::after {
    content: none;
}

#add_payment_method #payment div.payment_box p,
.woocommerce-cart #payment div.payment_box p,
.woocommerce-checkout #payment div.payment_box p {
    color: inherit;
}

#add_payment_method #payment div.payment_box::before,
.woocommerce-cart #payment div.payment_box::before,
.woocommerce-checkout #payment div.payment_box::before {
    border-bottom-color: var(--primary);
}

body.woocommerce.shop-inactive .wc-gzd-additional-info {
    display: none;
}

.woocommerce form .form-row .input-checkbox,
input[type='checkbox'],
input[type='radio'] {
    width: auto;
    flex-shrink: 0;
}

table.woocommerce-checkout-review-order-table
    tr.wc-gzd-cart-item-has-thumbnail
    .wc-gzd-cart-item-name-wrapper {
    justify-content: flex-start;
}

table.woocommerce-checkout-review-order-table
    tr.wc-gzd-cart-item-has-thumbnail
    td.product-name {
    min-width: 35rem;
}

.order_details tr > :last-child,
.woocommerce-checkout-review-order-table tr > :last-child {
    text-align: right;
}

.woocommerce-checkout-review-order > :empty {
    display: none;
}

.wc-gzd-checkbox-placeholder + :not(.wc-gzd-checkbox-placeholder),
.woocommerce table.shop_table {
    margin-top: 3rem;
}

.woocommerce form .form-row {
    padding: 0;
}

:where(body:not(.woocommerce-block-theme-has-button-styles))
    .woocommerce
    button.button.alt {
    margin-left: auto !important;
    display: block !important;
    width: fit-content !important;
}

.select2-container .select2-selection--single {
    height: auto;
}

.select2-dropdown {
    border-color: var(--primary);
}

.product-name a {
    text-decoration: none;
}

.pswp__bg {
    opacity: 0.8 !important;
}

span.cart_item_name {
    flex-grow: 1;
    font-weight: 700;
}

section.shipping-calculator-form,
section.woocommerce-order-details,
section.woocommerce-shipment-details,
section.woocommerce-customer-details,
section.woocommerce-shipment-address-details,
section.woocommerce-shipment-address-details > section {
    padding: 0;
}

section.shipping-calculator-form {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.5em;
    text-align: left;
}

.select2-container .select2-selection--single .select2-selection__rendered {
    padding: 0;
}

.woocommerce form .shipping-calculator-form p.form-row,
section.shipping-calculator-form > p {
    clear: both;
    margin: 0 0 0 auto;
    padding: 0;
}

form section.shipping-calculator-form .form-row-first,
form section.shipping-calculator-form .form-row-last {
    flex-grow: 1;
}

.woocommerce-cart .cart-collaterals .shipping-calculator-button {
    display: block;
    width: fit-content;
    max-width: 100%;
    margin-left: auto;
}

.woocommerce ul.order_details {
    margin: 2em 0 3em;
    padding: 1rem 2rem;
    background-color: var(--grey);
}

.woocommerce ul.order_details li {
    margin-bottom: 0;
}

.woocommerce-thankyou-order-received {
    font-size: 2em;
    font-weight: 700;
}

.woocommerce form.checkout_coupon,
.woocommerce form.login,
.woocommerce form.register {
    border-radius: 0;
    border: none;
    padding: 0;

    display: flex;
    flex-direction: column;
    gap: 1em;
    align-items: stretch;
    width: 100%;
}

#customer_login .col-1,
#customer_login .col-2 {
    background-color: var(--grey);
    padding: 2rem 6rem;
    transform: skewX(-11.5deg);
    align-self: stretch;
}

#customer_login .col-1 > *:not(form),
#customer_login .col-2 > *:not(form),
#customer_login .col-1 > form > *,
#customer_login .col-2 > form > * {
    transform: skewX(11.5deg);
}

#customer_login h2 {
    font-weight: 700;
    text-align: center;
}

.woocommerce .woocommerce-form-login .woocommerce-form-login__rememberme {
    display: flex;
    gap: 1em;
    justify-content: flex-start;
}

.woocommerce .woocommerce-form-login .woocommerce-form-login__submit,
.woocommerce .woocommerce-form-register .button {
    float: none;
    margin-left: auto;
    display: block;
    width: fit-content;
}

.woocommerce form .form-row label {
    line-height: inherit;
}

.woocommerce-account section header {
    margin: 0;
    padding: 0;
}

.woocommerce-account .addresses .title h3 {
    float: none;
    margin: 0;
}

.entry-content .woocommerce-MyAccount-navigation ul {
    list-style: none;
    margin: 0;
}

.entry-content .woocommerce-MyAccount-navigation a {
    text-decoration: none;
    font-weight: 400;
}

.entry-content .woocommerce-MyAccount-navigation .is-active a {
    font-weight: 700;
}

.woocommerce-account .entry-content > .woocommerce {
    display: flex;
    gap: 2rem;
    align-items: flex-start;
    flex-wrap: wrap;
}

.woocommerce-account .woocommerce::after,
.woocommerce-account .woocommerce::before {
    content: none;
}

.woocommerce-account .woocommerce-MyAccount-navigation {
    float: none;
    width: auto;
    min-width: 20rem;
}

.woocommerce-account .woocommerce-MyAccount-content {
    float: none;
    flex-grow: 1;
    width: auto;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 1em;
    width: calc(100% - 22rem);
    min-width: 30rem;
    padding-left: 2rem;
    border-left: 2px solid var(--grey);
    align-self: stretch;
}

.woocommerce-MyAccount-content h3 {
    margin-top: 0;
}

.woocommerce-MyAccount-content
    form
    .woocommerce-address-fields
    > .woocommerce-address-fields__field-wrapper,
.woocommerce-MyAccount-content form {
    display: flex;
    gap: 1em 2rem;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: flex-start;
    width: 100%;
}

.woocommerce-MyAccount-content
    form
    .woocommerce-address-fields
    > .woocommerce-address-fields__field-wrapper
    > *,
.woocommerce-MyAccount-content form > *,
.woocommerce-MyAccount-content form fieldset > * {
    flex-grow: 1;
}

.woocommerce-MyAccount-content form .clear {
    display: none;
}

.form-row-wide {
    width: 100%;
}
.woocommerce-MyAccount-content form fieldset {
    width: 100%;
    display: flex;
    flex: inherit;
    flex-wrap: inherit;
    gap: inherit;
    align-items: inherit;
    justify-content: inherit;
    padding: 2rem;
    background-color: var(--grey);
}

.woocommerce-MyAccount-content form fieldset legend {
    font-weight: 700;
    font-size: 1.5em;
    display: contents;
}

.woocommerce .woocommerce-notices-wrapper:empty + table.shop_table {
    margin-top: 0;
}

.woocommerce address {
    font-style: normal;
    margin-bottom: 0;
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-bottom-width: 2px;
    border-right-width: 2px;
    text-align: left;
    width: 100%;
    border-radius: 5px;
    padding: 6px 12px;
    box-sizing: border-box;
}

.woocommerce address p {
    font: inherit;
    font-size: inherit;
}

.woocommerce-info {
    width: 100%;
}

.entry-content .woocommerce-shipping-methods li,
.woocommerce ul#shipping_method li {
    font-size: inherit;
    margin: 0;
}

.calculated_shipping td:last-child {
    text-align: right;
}

.woocommerce-account-fields,
.woocommerce-shipping-fields {
    padding: 2rem;
    background-color: var(--grey);
    margin-bottom: 1em;
    float: none !important;
}

.woocommerce .woocommerce-account-fields h3,
.woocommerce-billing-fields h3,
.woocommerce-shipping-fields h3 {
    margin: 0;
    float: none !important;
}

.woocommerce-account-fields h3 + *,
.woocommerce-billing-fields h3 + *,
.woocommerce-shipping-fields h3 + * {
    margin-top: 1em;
    float: none !important;
}

.woocommerce form .form-row label.checkbox,
.woocommerce-page form .form-row label.checkbox,
.woocommerce-form__label.checkbox {
    display: flex !important;
    gap: 1em;
    justify-content: flex-start;
    cursor: pointer;
    align-items: baseline;
}

.woocommerce form .form-row label.checkbox,
.woocommerce-page form .form-row label.checkbox * {
    order: -1;
    hyphens: auto;
}

.newsletter_signup {
    margin-bottom: 1em;
}

.woocommerce form .form-row label.checkbox input,
.woocommerce-page form .form-row label.checkbox input,
.woocommerce-form__label.checkbox input {
    flex-shrink: 0;
    margin: 0;
}

table tr > [class*='total']:not(:first-child),
table tr > [class*='tax']:not(:first-child),
table tr[class*='total'] td:not(:first-child),
table tr[class*='tax'] td:not(:first-child) {
    text-align: right;
}

.woocommerce table.shop_table td.actions {
    padding-left: 0;
    padding-right: 0;
}

.woocommerce table.shop_table td ul.wc-item-meta {
    margin: 1rem 0 1rem 0;
}

.woocommerce table.shop_table td ul.wc-item-meta li,
.woocommerce table.shop_table td ul.wc-item-meta p {
    font-size: 90%;
    line-height: 12px;
}

.woocommerce table.shop_table td ul.wc-item-meta.custom-built-item-meta li {
    display: flex;
    justify-content: start;
}

.woocommerce
    table.shop_table
    td
    ul.wc-item-meta.custom-built-item-meta
    li
    .wc-item-meta-label {
    margin-right: 0;
}

td.actions button:disabled {
    display: none;
}

.woocommerce ul#shipping_method li label,
.woocommerce-shipping-methods label {
    display: flex;
    justify-content: flex-end;
    width: 100%;
    flex-wrap: wrap;
}

.woocommerce ul#shipping_method .amount {
    min-width: 10rem;
}

.woocommerce-cart table.cart img,
.woocommerce-checkout table.cart img {
    width: 10rem;
}

td.product-remove,
td.product-price,
td.product-quantity,
td.product-subtotal {
    width: 1%;
}

.product-thumbnail {
    width: 10%;
}
.product-name,
.prodcut-serial {
    width: 20%;
    /* width: min-content; */
}

.ddm_login_toggler {
    margin-bottom: 2em;
    display: flex;
    gap: 0;
    width: 100%;
    align-items: flex-start;
    max-width: 100%;
    flex-direction: column;
    align-items: stretch;
}

.ddm_login_toggler .button {
    width: fit-content !important;
    align-self: flex-end !important;
}

.woocommerce-form-login-toggle {
    background-color: var(--grey);
    padding: 2rem;
    display: flex;
    align-items: flex-end;
    gap: 1em;
    justify-content: space-between;
    flex-wrap: wrap;
}

.woocommerce-form-login-toggle h3 {
    margin: 0;
    width: 100%;
}

.ddm_login_toggler form.login {
    border: 2px solid var(--grey);
    padding: 2rem;
    max-width: 100%;
    margin-top: 0;
    flex-direction: row;
    flex-wrap: wrap;
}

.ddm_login_toggler form.login > * {
    flex-grow: 1;
    margin: 0;
}

.ddm_login_toggler form.login > .clear + .form-row {
    flex-grow: 1;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
}

.ddm_login_toggler .button.active {
    display: none;
}

.woocommerce .woocommerce-form-login .woocommerce-form-login__submit {
    margin-right: 0;
}

.woocommerce-form-login-toggle + form.login > .clear {
    width: 100%;
    display: none;
}

.lost_password {
    width: 100%;
    text-align: right;
    margin: 0;
}

.lost_password a {
    text-decoration: none;
    font-size: 0.8em;
}

::placeholder {
    font-size: #999;
    font-size: 1.8rem;
    font-weight: 300;
    line-height: 1.5 !important;
}

#payment li {
    margin-bottom: 0 !important;
}

#payment fieldset {
    margin: 0;
}

.highlights:empty {
    display: none;
}

.related.products img {
    mix-blend-mode: darken;
}

#account_display_name + span {
    display: none;
}

/* .woocommerce-notices-wrapper {
  padding: 1em 2em;
  background-color: darkred;
  color: var(--menucolor);
  font-size: 1.25em;
} */

.woocommerce-notices-wrapper:empty {
    display: none;
}

.woocommerce-table.woocommerce-table--order-details td,
.shop_table.order_details td {
    width: 50%;
}

.woocommerce ul.products li.product a img {
    aspect-ratio: 1.3;
    object-fit: contain;
    /* max-width: 20rem; */
    margin-left: auto;
    margin-right: auto;
}

.woocommerce ul.products li.product .woocommerce-placeholder {
    border: none;
    mix-blend-mode: normal;
}

#call-to-phone-action {
    transition: all 0.3s ease;
}

.woocommerce_product_prices_overview {
    display: flex;
    justify-content: flex-start;
    gap: 1em;
    flex-wrap: wrap;
}

.woocommerce_product_gross_price,
.woocommerce_product_net_price {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
}

.woocommerce_product_prices_overview p {
    margin: 0;
    line-height: 1.2;
}

/* .woocommerce:where(body:not(.woocommerce-uses-block-theme)) */
.summary .woocommerce_product_prices_overview p.price > span {
    font-size: 1.5em;
    width: fit-content;
}

@media screen and (max-width: 450px) {
    .summary .woocommerce_product_prices_overview p.price > span {
        font-size: 1.2em;
    }
}

section .woocommerce_product_prices_overview p {
    font-size: 0.8em;
}

section.woocommerce-bacs-bank-details {
    padding: 0;
}

.place-order.wc-gzd-place-order .button {
    margin-top: 1em !important;
}

.woocommerce .variation {
    line-height: 1.2;
}

.woocommerce td.product-name dl.variation dt,
.woocommerce .variation * {
    display: inline;
    float: none;
}

.woocommerce dd {
    font-weight: 700;
}

.woocommerce dd p {
    font: inherit;
    margin: 0;
    padding: 0;
}

/* Loader */
.wooco_components .shop-loader {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: inline-block;
    border-top: 4px solid var(--secondary);
    border-right: 3px solid transparent;
    box-sizing: border-box;
    animation: loaderRotation 1s linear infinite;
    -webkit-animation: loaderRotation 1s linear infinite;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

@keyframes loaderRotation {
    0% {
        transform: translate(-50%, -50%) rotate(0deg);
    }
    100% {
        transform: translate(-50%, -50%) rotate(360deg);
    }
}

.woocommerce img.pswp__img,
.woocommerce-page img.pswp__img {
    max-height: none;
}

.shipped_via {
    display: block;
}

@media screen and (max-width: 1080px) {
    .woocommerce div.product {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 2rem;
    }

    .woocommerce div.product .image_wrapper {
        margin: auto;
        align-self: center;
    }

    .type-product main {
        gap: 0;
    }

    .type-product main > * {
        margin-bottom: 4rem;
    }

    main.product section {
        /* padding-top: 0; */
    }

    main.product section > :first-child {
        margin-top: 0;
    }

    .woocommerce .product .cta {
        order: 3;
    }
}

@media only screen and (max-width: 768px) {
    .wooco-wrap .wooco_components {
        display: flex;
        flex-direction: column;
        width: 100%;
        align-items: stretch;
        gap: 1em;
    }

    .wooco-wrap .wooco_components > * > * {
        margin: 0;
        padding: 0;
    }

    .wooco-wrap .wooco_components > div {
        padding: 0;
        display: flex;
        flex-direction: column;
        width: 100%;
        align-items: stretch;
        gap: 0.25em;
    }

    .wooco-wrap .wooco_components > * > :last-child {
        width: 100%;
    }
    .wooco-wrap .wooco_components > * > :first-child {
        padding: 0;
    }

    .woocommerce div.product div.images img {
        max-height: 25vh;
    }

    .category .row .value {
        text-align: right;
    }

    .woocommerce ul.products {
        padding-right: 0;
    }

    .woocommerce ul.products {
        grid-template-columns: 1fr;
    }

    .woocommerce ul.products li.product,
    .woocommerce-page ul.products li.product {
        padding: 5rem 2rem;
    }
}

@media only screen and (max-width: 768px) {
    .page-headline h1 {
        font-size: 2.25em;
        font-weight: 700;
        text-align: center;
        width: 100%;
    }

    .woocommerce ul.products[class*='columns-'] li.product,
    .woocommerce-page ul.products[class*='columns-'] li.product {
        width: 100%;
        float: none !important;
        clear: both !important;
        margin: 0;
    }

    .woocommerce .entry-summary h1 {
        font-size: 1.5em;
    }

    .woocommerce .product_details h2 {
        font-size: 2rem;
        font-weight: 700;
    }

    .woocommerce ul.products li.product .woocommerce-loop-category__title,
    .woocommerce ul.products li.product .woocommerce-loop-product__title,
    .woocommerce ul.products li.product h3,
    .woocommerce-loop-product__title {
        right: -1.5rem;
    }

    .woocommerce .cart-collaterals,
    .woocommerce-page .cart-collaterals,
    .woocommerce .col2-set,
    .woocommerce-page .col2-set {
        grid-template-columns: 1fr;
    }

    .woocommerce .cart-collaterals .shipping_calculator,
    .woocommerce-page .cart-collaterals .shipping_calculator,
    .woocommerce .cart-collaterals .cart_totals,
    .woocommerce-page .cart-collaterals .cart_totals {
        grid-column-start: 1;
    }

    .woocommerce table.shop_table_responsive tr,
    .woocommerce-page table.shop_table_responsive tr {
        border: 2px solid var(--grey);
        padding: 0 1rem;
    }

    .woocommerce .cart-collaterals > * {
        padding: 2rem 1rem;
    }

    .woocommerce .cart-collaterals > * h2 {
        font-weight: 700;
        text-align: center;
    }

    .woocommerce table.shop_table_responsive tr:not(:first-child),
    .woocommerce-page table.shop_table_responsive tr:not(:first-child) {
        border-top: none;
    }

    .woocommerce table.shop_table_responsive tr td,
    .woocommerce-page table.shop_table_responsive tr td {
        width: 100%;
        padding: 0.25em 0;
        border: none;
    }

    .woocommerce table.shop_table_responsive tr td:not(:first-of-type),
    .woocommerce-page table.shop_table_responsive tr td:not(:first-of-type) {
        border-top: 1px solid var(--grey);
    }

    .woocommerce table.shop_table_responsive tr:nth-child(even),
    .woocommerce-page table.shop_table_responsive tr:nth-child(even) {
        background-color: rgba(0, 0, 0, 0.025);
    }

    .woocommerce table.shop_table_responsive tr:nth-child(even) td,
    .woocommerce-page table.shop_table_responsive tr:nth-child(even) td {
        background: none;
    }

    .product-remove {
        position: relative;
        background: none !important;
    }
    .product-remove:after {
        content: '';
        display: block;
        background-color: var(--grey);
        position: absolute;
        left: -1rem;
        right: -1rem;
        bottom: -1px;
        top: 0;
        z-index: -1;
    }

    .woocommerce a.remove {
        margin-left: auto;
    }

    .woocommerce .quantity .qty {
        padding: 0 0.5em;
    }

    .breadcrumb:empty {
        display: none;
    }

    .woocommerce #content table.cart td.actions .button,
    .woocommerce table.cart td.actions .button,
    .woocommerce-page #content table.cart td.actions .button,
    .woocommerce-page table.cart td.actions .button {
        display: block;
        width: fit-content;
        max-width: 100%;
        margin-left: auto;
        margin-right: auto;
    }

    .woocommerce table.shop_table {
        margin-top: 0;
    }

    .cart_item {
        margin-bottom: 0.5em;
    }

    .woocommerce table.shop_table_responsive .cart_item + tr:not(:first-child),
    .woocommerce-page
        table.shop_table_responsive
        .cart_item
        + tr:not(:first-child) {
        border-top: 2px solid var(--grey);
    }

    .woocommerce-error::before,
    .woocommerce-info::before,
    .woocommerce-message::before {
        top: 0.5em;
        left: 0.5em;
    }

    .woocommerce-error,
    .woocommerce-info,
    .woocommerce-message {
        padding: 0.5em 0.5em 0.5em 2em;
    }

    .woocommerce-error li ~ li {
        width: 100%;
    }

    .woocommerce-checkout table.shop_table,
    .woocommerce-checkout table.woocommerce-checkout-review-order-table {
        display: block;
        background: none;
        margin: 2em 0;
    }

    .woocommerce-checkout-review-order-table > * {
        width: 100%;
        display: block;
    }

    .woocommerce-checkout-review-order-table tr {
        display: grid;
        width: 100%;
        justify-content: space-between;
        align-items: stretch;
        /* margin: 0; */
        grid-template-columns: 1fr auto;
    }

    .woocommerce-checkout-review-order-table tfoot,
    .woocommerce-checkout-review-order-table tbody tr {
        border: 2px solid var(--grey);
    }

    .woocommerce-checkout-review-order-table thead tr {
        border: none;
        margin-bottom: 0.5em;
    }

    .woocommerce-checkout-review-order-table tr > * {
        flex-grow: 1;
        width: 100%;
    }

    .woocommerce-checkout-review-order-table .product-order-number {
        grid-row-start: 2;
        grid-column-start: 1;
        padding-top: 0 !important;
    }

    .woocommerce-checkout-review-order-table .product-total {
        grid-row-end: span 2;
        align-content: end;
    }

    .woocommerce-checkout-review-order-table tr > :empty {
        display: none;
    }

    .woocommerce-checkout-review-order-table thead {
        /* display: none; */
    }

    #add_payment_method #payment div.payment_box .wc-credit-card-form,
    .woocommerce-cart #payment div.payment_box .wc-credit-card-form,
    .woocommerce-checkout #payment div.payment_box .wc-credit-card-form,
    #payment div.payment_box fieldset.wc-payment-form {
        margin: 1em 0;
    }

    .woocommerce
        form
        .form-row.validate-required
        label.checkbox
        input
        + span:after,
    .woocommerce-page
        form
        .form-row.validate-required
        label.checkbox
        input
        + span:after {
        content: ' *';
        color: var(--secondary);
        font-weight: 700;
    }

    .woocommerce
        form
        .form-row.validate-required
        label.checkbox
        input
        + span
        ~ .required,
    .woocommerce-page
        form
        .form-row.validate-required
        label.checkbox
        input
        + span
        ~ .required {
        display: none;
    }

    #customer_login .col-1,
    #customer_login .col-2 {
        padding: 0 2rem;
        transform: none;
    }
    #customer_login .col-1 > *:not(form),
    #customer_login .col-2 > *:not(form),
    #customer_login .col-1 > form > *,
    #customer_login .col-2 > form > * {
        transform: none;
    }

    .woocommerce .woocommerce-form-login .woocommerce-form-login__rememberme {
        margin-bottom: 1em;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation {
        width: 100%;
        min-width: 0;
    }

    .entry-content .woocommerce-MyAccount-navigation ul {
        display: flex;
        gap: 0.5em;
        flex-wrap: wrap;
    }

    .entry-content .woocommerce-MyAccount-navigation ul li {
        margin: 0;
    }

    .entry-content .woocommerce-MyAccount-navigation ul li a {
        padding: 0.125em 0.5em;
        background: var(--grey);
        display: block;
        width: fit-content;
        max-width: 100%;
    }

    .woocommerce-account .woocommerce-MyAccount-content {
        padding-left: 0;
        border-left: 0;
        padding-top: 1em;
    }

    .woocommerce ul.order_details {
        display: flex;
        flex-direction: column;
        gap: 1em;
    }

    .woocommerce ul.order_details li {
        width: 100%;
        padding-right: 0;
        margin-right: 0;
        border-right: 0;
        line-height: 1.5;
    }

    .woocommerce
        table.shop_table.woocommerce-table--order-details
        tfoot
        tr
        > * {
        border-top: 2px solid var(--grey);
        vertical-align: baseline;
        hyphens: auto;
    }
}

@media only screen and (max-width: 550px) {
    .woocommerce-checkout .entry-content h2,
    .woocommerce-checkout .entry-content h3,
    .woocommerce-thankyou-order-received,
    #customer_login h2 {
        font-size: 1.25em;
        margin-top: 2rem;
    }
    .woocommerce h3 + ul.order_details {
        margin-top: 0;
    }
    .woocommerce-checkout .entry-content h3 label {
        font-size: 0.66em;
    }

    .woocommerce .product .wc-gzd-additional-info.delivery-time-info {
        width: 100%;
        margin-left: 0;
    }
}

.related.products
    .wc-gzd-additional-info.delivery-time-info.wc-gzd-additional-info-loop.stronglieferzeitstrong-4-wochen {
    display: none;
}

span.print-order-details {
    background-color: var(--secondary);
    color: var(--menucolor);
    padding: 0.5rem 1rem;
    display: block;
    margin: 0;
    margin-top: -1.5rem;
    min-width: 10rem;
    text-align: center;
    font-size: 12px;
    font-weight: 700;
    border-radius: 0;
    width: auto;
    align-self: stretch;
    width: fit-content;
    max-width: 100%;
    cursor: pointer;
}

span.print-order-details:hover {
    background-color: #dcd7e3;
    text-decoration: none;
    background-image: none;
    color: #515151;
}

.cart_item .wc-gzd-cart-info > p {
    display: none;
}

@media (max-width: 769px) {
    .wc-gzd-cart-item-thumbnail {
        display: none;
    }

    .woocommerce-checkout-review-order-table tbody tr:not(:last-child) {
        grid-template-columns: none;
    }

    .shop_table.woocommerce-checkout-review-order-table td.product-total,
    .shop_table.woocommerce-checkout-review-order-table th.product-total {
        text-align: left;
    }

    .woocommerce ul#shipping_method .amount {
        min-width: 7rem;
    }

    .shop_table.woocommerce-checkout-review-order-table tr {
        margin-bottom: 0.5rem;
    }

    .shop_table.woocommerce-checkout-review-order-table .product-total {
        grid-column: 1 / 1;
    }

    .woocommerce-order-details .print-order-details {
        margin-bottom: 0.5rem;
    }
}

section.woocommerce-order-downloads {
    padding: 0;
    margin: 0;
}
