/*
Theme Name: WeBotanix
Theme URI: https://camposemantico.es
Version: 1.0
Description: Tema hijo de generatepress personalizado para WeBotanix.
Author: Alejandro Fernández Aparicio
Author URI: https://camposemantico.es
Template: generatepress
*/

/* https: //www.svgrepo.com/collection/solar-broken-line-icons/ */

*,
*:after,
*:before {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    text-decoration: none;
}

:root {
    --primary: #3e4f4f;
    --woocommerce: var(--primary);
    --wc-primary: var(--primary);
    --secondary: #2fc3cc;
    --light: rgba(47, 195, 204, .15);
    --light-2: rgba(47, 195, 204, .075);
    --background: #fff;
    --shadow-md: 0 0 .5rem rgba(0, 0, 0, 0.2);

    --secondary-background: #f9f9f9;

    --list_element_width: 240px;
    --list_product_width: calc(240px + 1rem);
}

@font-face {
    font-family: 'Bree';
    src: url('../webotanix/assets/font/Bree\ Regular.otf') format("opentype");
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'QuickSand';
    src: url('../webotanix/assets/font/Quicksand-VariableFont_wght.ttf') format("truetype");
    font-style: normal;
    font-weight: 500 600 700;
    font-display: swap;
}


html,
body {
    width: 100%;
    background: var(--background);
    color: var(--primary);
    line-height: 1.2;
    font-size: 17px;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 500;
    font-family: 'QuickSand';
    letter-spacing: 0;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-text-size-adjust: 100%;
}

pre,
.site-main>pre {
    width: 100%;
    font-size: .8rem;
    color: orangered;
    background: rgba(255, 0, 0, 0.1);
    font-family: monospace;
    margin: 0;
    padding: .5rem;
}

.edit-link {
    font-size: .8rem;
    position: absolute;
}

.hidden {
    display: none;
}

a.button,
a.button:hover,
.button {
    text-transform: uppercase;
    font-weight: 500;
    font-size: 1rem;
    font-family: 'QuickSand';
    background-color: var(--primary);
    color: var(--background);
    text-align: center;
    transition: all .3s ease-in-out;

    &:hover {
        color: var(--background);
    }
}

.site a {
    text-decoration: none;
    color: var(--secondary);
}

h1,
.h1 {
    font-weight: 600;
    font-size: 2rem;
    font-family: 'Bree';
    letter-spacing: 0;
}

h2,
.h2 {
    font-weight: 500;
    font-size: 1.75rem;
    font-family: 'Bree';
    letter-spacing: -.5px;
}

h3,
.h3 {
    font-weight: 600;
    font-size: 1.25rem;
    letter-spacing: -.5px;
    font-family: 'QuickSand';
}

h4,
.h4 {
    font-weight: 500;
    font-size: 1.05rem;
    letter-spacing: -.5px;
    font-family: 'QuickSand';
}

strong {
    font-weight: 600;
}

h2 strong,
.h2 strong {
    letter-spacing: .25px;
}

.inside-header.grid-container {
    display: flex;
    padding: .25rem .75rem;
}

.spaced-container {
    width: 100%;
    max-width: 1200px;
    margin: auto;
}

.separate-containers .inside-article {
    background: none;
    padding: 1rem 1.5rem;
}

.separate-containers .page-header {
    padding: 1.5rem;
}

#breadcrumbs {
    padding: .5rem 1.5rem;
    margin: 0 auto;
    font-size: .85rem;
}

#breadcrumbs strong {
    font-weight: 700;
}


.entry-content .alignwide,
body:not(.no-sidebar) .entry-content .alignfull {
    width: 100%;
    max-width: 100%;
    margin: 0;
}


.top-bar {
    width: 100%;
    flex-direction: row;
    gap: 0 1rem;
    background: var(--light);
    color: var(--primary);
    display: flex;
    text-align: center;
    justify-content: center;
    font-size: .9rem;
}

.top-bar strong {
    font-weight: 700;
}

.top-bar a {
    color: var(--secondary);
}

.top-bar .inside-top-bar {
    width: 100%;
    padding: .75rem 1rem;
    text-align: center;
}

.top-bar .widget,
.top-bar .textwidget {
    width: 100%;
    text-align: center;
    font-size: .8rem;
    font-weight: 500;

}

.top-bar-align-right .widget:first-child {
    margin: 0;

}

.site-header {
    border-bottom: 1px solid var(--light);
}

#header_search,
#header_search .search-form {
    width: 100%;
    display: flex;
    justify-content: center;
}

#header_search {
    padding: 1rem 2rem;
    display: none;
}

#header_search.archive {
    display: block;
}

#header_search .search-form label,
#header_search .search-form .search-field {
    width: 100% !important;
    background: var(--background);
}

#header_search .search-form .search-submit {
    background: var(--primary);
}


#modal-minicart {
    position: fixed;
    display: none;
    top: 0;
    left: 0;
    z-index: 9999999998;
    width: 100%;
    height: 100%;
    background: var(--light-2);
    transition: all .5s ease;
}

#modal-minicart.show {
    display: block;
    backdrop-filter: blur(1px);
}

#minicart-container {
    position: fixed;
    z-index: 9999999999;
    top: 0;
    right: 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 360px;
    max-width: 90%;
    height: 100%;
    box-shadow: var(--shadow-md);
    background: var(--background);
    padding: 1.5rem;
    margin-right: -360px;
    transition: all .5s ease;
}

#minicart-container.show {
    margin-right: 0;
}

.minicart {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 100%;
    height: 100%;
}

.minicart .btn-close {
    position: absolute;
    display: flex;
    align-items: center;
    gap: .25rem;
    font-size: .9rem;
    cursor: pointer;
    transition: all .3 ease;

    &:hover {
        color: var(--secondary);
    }
}

.minicart .h2 {
    text-align: right;
    font-size: 1.5rem;
}

.minicart .woocommerce-mini-cart__empty-message {
    margin-bottom: auto;
    padding: 1rem 0;
    font-size: .9rem;
}

.minicart ul.cart_list {
    width: 100%;
    padding: 1rem 0;
    margin: 0;
}

.minicart ul.cart_list li,
.minicart ul.product_list_widget li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap;
    gap: .5rem;
    margin-bottom: .75rem;

    &:before {
        display: none;
    }

    &:after {
        display: none;
    }
}

.minicart li.mini_cart_item .product-data {
    width: 100%;
    display: flex;
    gap: .75rem;
    align-items: center;
    text-decoration: none;
    font-size: .85rem;
    font-weight: 500;
    line-height: 1.1;
    color: var(--primary);
}

.minicart li.mini_cart_item .product-data img {
    min-width: 48px;
    width: 48px;
    height: 48px;
    aspect-ratio: 1/1;
    margin: 0;
}

.minicart li.mini_cart_item .quantity {
    width: 150px;
    font-size: .95rem;
}

.minicart li.mini_cart_item .remove.remove_from_cart_button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.5rem;
    height: 1.5rem;
    color: var(--secondary) !important;
    transition: all .3s ease;

    &:hover {
        background: none !important;
        color: red !important;
    }
}

.minicart .btn-close svg,
.minicart li.mini_cart_item .remove svg {
    width: 1.25rem;
    height: 1.25rem;
}

.minicart .total {
    text-align: right;
    border-top: 1px solid #eee;
    padding: 1rem 0;
    margin: 0;
    font-weight: 600;
}

.minicart .buttons {
    display: flex;
    flex-direction: column;
    gap: .75rem;
    margin-top: auto;
    margin-bottom: 0;
}

.minicart .buttons .button.wc-forward {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    background: var(--secondary);
    color: var(--primary);
    font-weight: 600;
    font-size: .9rem;

    &:hover {
        color: var(--primary);
    }
}

.minicart .buttons .button.checkout {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    background: var(--primary);
    color: var(--background);
    font-weight: 600;
    font-size: .9rem;

    &:hover {
        color: var(--background);
    }
}

.inside-header .logo {
    height: fit-content;
    height: 22px;
    display: block;
    position: relative;
    color: var(--primary);
}

.has-inline-mobile-toggle #site-navigation.toggled {
    margin: 0;
    background: var(--light);
}

.main-navigation .menu-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    width: 32px;
    height: 32px;
    background: none !important;

}

.main-navigation .menu-toggle svg {
    width: 20px;
    height: 20px;
    fill: var(--primary);
}

.main-navigation .main-nav ul li:not([class*="current-menu-"]):hover>a,
.main-navigation .main-nav ul li:not([class*="current-menu-"]):focus>a,
.main-navigation .main-nav ul li.sfHover:not([class*="current-menu-"])>a,
.main-navigation .menu-bar-item:hover>a,
.main-navigation .menu-bar-item.sfHover>a,
.main-navigation .main-nav ul li:not([class*="current-menu-"])>a,
.main-navigation .main-nav ul li[class*="current-menu-"]>a {
    color: var(--primary);
    font-weight: 600;
    font-size: 1rem;
    display: block;
}

#primary-menu ul ul {
    background: var(--light);
}

#primary-menu .menu-products {
    display: none;

}

.icon_menu {
    cursor: pointer;
    position: relative;
    padding: .5rem;
}

.icon_menu a,
.icon_menu #minicart-btn {
    width: 100%;
    width: 24px;
    height: 24px;
    position: relative;
    display: flex;
    align-items: center;
    text-decoration: none;
    color: var(--primary) !important;
    padding: 0 !important;
}

.icon_menu svg {
    width: 24px;
    height: 24px;
}

.icon_search svg {
    fill: var(--primary);
    width: 20px;
    height: 20px;
}

.icon_menu .cart-counter {
    width: 1rem;
    height: 1rem;
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--secondary);
    border-radius: 50%;
    color: var(--background);
    font-weight: 500;
    top: -.5rem;
    right: -.5rem;
    line-height: 1;
    font-size: .75rem;
}


.woocommerce div.products[class*=columns-] {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
    gap: 1.5rem;
    margin: 1.5rem auto;
    user-select: none;
}

.woocommerce div.products[class*=columns-]::before {
    display: none !important;
}

.woocommerce div.products[class*=columns-] div.product,
.woocommerce-page div.products[class*=columns-] div.product {
    width: 100%;
    float: none;
    display: flex;
    flex-direction: column;
    gap: .5rem;
    box-shadow: 0 0 .5rem rgba(0, 0, 0, 0.2);
    background: var(--background);
    padding: 0 1rem 1rem 1rem;
    margin: 0 !important;
    border-radius: .5rem;
    overflow: hidden;
}

.woocommerce div.products div.product .woocommerce-loop-product__link {
    display: flex !important;
    flex-direction: column;
    gap: .25rem;
    color: var(--primary);
}

.woocommerce div.products div.product .attachment-woocommerce_thumbnail {
    width: 100%;
    aspect-ratio: 1/1;
    overflow: hidden;
    margin: 0;
}

.single-product .site .label,
.woocommerce div.products div.product .label {
    position: absolute;
    z-index: 10;
    top: .5rem;
    left: .5rem;
    padding: .2rem .5rem .25rem .5rem;
    text-transform: uppercase;
    font-size: .8rem;
    font-weight: 700;
    border: 1px solid var(--primary);
    background: var(--background);
    border-radius: .25rem;
    line-height: 1;
}

.woocommerce div.products div.product .label.new {
    color: var(--secondary);
    border: 1px solid var(--secondary);
}

.woocommerce div.products div.product .woocommerce-loop-product__title,
.woocommerce div.products div.product .woocommerce-loop-product__title a {
    font-weight: 500;
    font-size: 1.25rem;
    line-height: 1.1;
    height: 2.75rem;
    overflow: hidden;
    padding: 0;
    margin: 0;
}

.woocommerce div.products div.product .add_to_cart_inline {
    border: none !important;
    padding: 0 !important;
}

.woocommerce div.products div.product a {
    color: var(--primary);
}

.woocommerce div.products div.product .price {
    color: var(--secondary);
    font-weight: 600;
    margin: 0;
    font-size: 1.15rem;
}

.woocommerce div.products div.product .price del {
    font-size: .95rem;
    text-decoration: line-through;
}

.woocommerce div.products div.product .excerpt {
    max-height: 2rem;
    overflow: hidden;
    font-size: .85rem;
    line-height: 1.1;
}

.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) button.button.alt,
.woocommerce div.products div.product .button {
    display: flex !important;
    align-items: center;
    justify-content: center;
    margin-top: 0;
    font-weight: 600;
    font-size: 1rem;
    background-color: var(--primary);
    color: var(--background);
}

.woocommerce a.added_to_cart {
    display: none;
}

.single-product .woocommerce-product-rating,
.woocommerce div.products div.product .star-rating {
    display: none;
}

.product .entry-summary .trustedShopsWidget,
.woocommerce div.products div.product .trustedShopsWidget {
    pointer-events: none;
    font-size: .85rem;
    font-family: 'QuickSand';
    display: flex;
    justify-content: flex-start;
    padding: 0;
    height: 1.15rem;
    line-height: 1.15rem;
}

.woocommerce-message {
    width: 100%;
    background: var(--light);
    outline: none;
    border-color: var(--light);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1em 1em 1em 3.5em;
    font-size: .95rem;
}

.woocommerce-message:before {
    top: initial;
}

.woocommerce-message:after {
    display: none;
}

.woocommerce-message a.button {
    display: flex;
    align-items: center;
    background: var(--primary);
    color: var(--background);
    font-weight: 500;
    font-size: .9rem;
}


.owl-carousel.products .product {
    width: 100% !important;
}

.owl-prev,
.owl-next {
    position: absolute;
    top: 50%;
    transform: translateY(calc(-50% - 1.5rem));
    display: block;
}

.owl-prev.disabled,
.owl-next.disabled {
    display: none !important;
}

.owl-carousel .owl-nav button {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 1rem;
}

.owl-prev {
    left: -1.5rem;
}

.owl-next {
    right: -2rem;
}

.owl-carousel .owl-nav button span {
    display: block;
    width: 2rem;
    height: 2rem;
    border-radius: 1rem;
    text-align: center;
    color: var(--secondary);
    border: 1px solid var(--light);
    background: rgba(255, 255, 255, .7);
    font-size: 2rem;
    line-height: 1.45rem;
    transition: all .3s ease-in-out;
}

.owl-carousel .owl-nav button:hover span {
    background: rgba(255, 255, 255, .85);
    border-color: var(--secondary);
    color: var(--primary);
}

.owl-carousel .owl-dots {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: auto;
}

.owl-carousel .owl-dots .owl-dot {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.owl-carousel .owl-dots .owl-dot span {
    display: block;
    width: 1rem;
    height: 1rem;
    border-radius: 50%;
    overflow: hidden;
    border: 1px solid var(--light) !important;
    background: var(--light);
    transition: all .3s ease-in-out;
}

.owl-carousel .owl-dots .owl-dot.active span {
    background: var(--secondary);
    border: none;
}


#faqs {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: .75rem;
}

#faqs .question {
    font-size: 1.05rem;
    line-height: 1.1;
    padding: .75rem .25rem .75rem .75rem;
    background: var(--light-2);
    border: 1px solid var(--light);
    cursor: pointer;
    margin-top: .75rem;
    border-radius: .25rem;
    transition: all .3s ease;

    &:hover {
        background: var(--light);
        border-color: var(--secondary);
    }

    &::after {
        display: inline;
        content: '+';
        float: right;
        width: 1.5rem;
        height: 1.5rem;
        text-align: center;
        color: var(--secondary);
    }
}

#faqs .faq.active .question {
    background: var(--light);
    border-color: var(--secondary);
}

#faqs .faq.active .question::after {
    content: '-';
    font-weight: 600;
}

#faqs .answer {
    font-size: .9rem;
    line-height: 1.2;
    padding: 1rem 1rem 0 1rem;
    display: none;
}

#faqs .answer p {
    margin: 0;
    padding: 0 0 .5rem 0;
}

#faqs .faq.active .answer {
    display: block;
}

.woocommerce-pagination {
    padding: 2rem 0;
}

.woocommerce nav.woocommerce-pagination ul,
.woocommerce-pagination .page-numbers {
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: .5rem;
    border: none;
}

.woocommerce nav.woocommerce-pagination ul li,
.woocommerce-pagination .page-numbers li {
    border: none;
}

.woocommerce nav.woocommerce-pagination ul li span,
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce-pagination .page-numbers li .page-numbers {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border: none;
    padding: .25rem;
    color: var(--secondary);
    border: 1px solid var(--light);

    &:hover {
        background: none;
        color: var(--secondary)
    }
}

.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce-pagination .page-numbers li .current {
    border: 1px solid var(--secondary);
    color: var(--secondary);
    background: none;
    font-weight: 700;
}

.woocommerce-pagination .page-numbers li .prev,
.woocommerce-pagination .page-numbers li .next {
    border: none;
    color: var(--secondary);
}

.site-footer {
    background: var(--primary);
    color: var(--background);
    font-size: .9rem;
    padding: 3rem 1.5rem 0 1.5rem;
}

.site-footer * {
    background: none;
    color: var(--background);
}

.site-footer .site.grid-container {
    padding: 0 !important;
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    max-width: 1200px;
}

.site-footer #content_footer {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 1.5rem;
}

.site-footer .logo {
    color: var(--background);
}

.site-footer #content_footer .column {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: .5rem;
}

.site-footer #content_footer .menu,
.site-footer #content_footer .menu ul {
    display: flex;
    flex-direction: column;
    gap: .25rem;
    margin: 0;
    list-style: none;
}

.site-footer #content_footer .menu a {
    display: block;
    text-decoration: none;
    padding: .15rem .5rem;
    color: var(--background);
    font-family: 'QuickSand';
    transition: all .3s ease;

    &:hover {
        color: var(--secondary);
    }

}

.menu-menu-footer-redes-sociales-container ul {
    width: 100%;
    display: flex;
    flex-direction: row !important;
    gap: .5rem !important;
    list-style: none;
    margin: 0;
    padding: 0;
}

.menu-menu-footer-redes-sociales-container ul .social {
    width: fit-content;
}

.menu-menu-footer-redes-sociales-container ul .social a {
    display: flex !important;
    align-items: center;
    text-indent: -9999px;
    padding: 0 !important;
}

.menu-menu-footer-redes-sociales-container ul .social a::before {
    content: "";
    display: inline-block;
    width: 32px;
    height: 32px;
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}

.menu-menu-footer-redes-sociales-container ul .facebook a::before {
    background-image: url('assets/img/icons/facebook.svg');
}

.menu-menu-footer-redes-sociales-container ul .instagram a::before {
    background-image: url('assets/img/icons/instagram.svg');
}

.menu-menu-footer-redes-sociales-container ul .linkedin a::before {
    background-image: url('assets/img/icons/linkedin.svg');
}

.menu-menu-footer-redes-sociales-container ul .youtube a::before {
    background-image: url('assets/img/icons/youtube.svg');
}

.site-footer #content_footer .column img {
    max-width: 150px;
}

.site-footer #disclaimer_footer {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1rem;
    margin: 1.5rem 0;
}

.site-footer #disclaimer_footer p {
    font-size: .75rem;
    margin: 0;
    opacity: .8;
    font-weight: 400;
}

.site-footer .site-info,
.site-footer .inside-site-info {
    width: 100%;
    padding: .5rem;
    text-align: center;
    font-size: .8rem;
    color: var(--secondary-background);
}

.page-id-383 .row,
.wpcf7-form .row {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.wpcf7-form .col-12,
.wpcf7-form .col-12 p {
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;
}

.page-id-383 #page .social a {
    background: var(--secondary);
    padding: .2rem !important;
    border-radius: 4px;
    transition: all .3s ease;

    &:hover {
        background: var(--primary);
    }
}

.wpcf7-form .wpcf7-form-control {
    width: 100%;
    font-size: .9rem;
    padding: .5rem .75rem;
    margin: 0;
    font-family: var(--font-family);
    color: var(--primary);
    border: 1px solid var(--secondary);
    border-radius: 4px;
    font-weight: 500;
    transition: all .3s ease;

    &::placeholder {
        color: var(--primary);
        font-weight: 500;
        opacity: .8;
    }
}


.wpcf7-form .wpcf7-acceptance,
.wpcf7-form .wpcf7-acceptance span {
    border: none;
    font-size: .85rem;
    padding: 0;
    margin: 0;
}

.wpcf7-form .wpcf7-acceptance {
    width: 100%;
    display: flex;
    align-items: center;
}

.wpcf7-form .wpcf7-not-valid-tip {
    font-size: .8rem;
    font-weight: 400;
    line-height: 1.5;
}

.wpcf7-form .wpcf7-form-control.wpcf7-not-valid {
    box-shadow: 0 0 .5rem rgba(220, 50, 50, .5);
}

.wpcf7-form .submit p {
    text-align: right;
}

.wpcf7-form .button {
    width: fit-content;
    color: var(--background);
    background: var(--primary);
    font-size: .952rem;
}

.contact-info {
    display: flex;
    flex-direction: column;
    gap: .5rem;
    font-size: .95rem;
}

.page .site-content li {
    margin-bottom: .5rem;
}

.page .site-content table {
    font-size: .85rem;
    line-height: 1.2;
    font-weight: 500;
}

.page .site-content table th {
    font-weight: 700;
    font-size: 1rem;
}

.page .site-content table th {
    background: var(--light-2);
    color: var(--secondary);
}

.page .site-content table td {
    min-width: 100px;
}

/* SMARTPHONES PORTRAIT */
@media only screen and (min-width: 300px) {}

/* SMARTPHONES LANDSCAPE */
@media only screen and (min-width: 480px) {

    .woocommerce div.products[class*=columns-] div.product,
    .woocommerce-page div.products[class*=columns-] div.product {
        width: calc(50% - .75rem);
    }
}

/* TABLETS PORTRAIT */
@media only screen and (min-width: 768px) {
    .main-navigation .menu-toggle {
        display: none;
    }

    .main-navigation .main-nav ul li a {
        display: block;
        padding: .5rem;
        margin-right: 1rem;
    }

    .main-navigation {
        width: 100%;
    }

    #primary-menu {
        width: auto;
        margin: auto;
    }

    #primary-menu .menu-item:not([class*="sfHover"])>.sub-menu {
        display: none;
    }

    #primary-menu .menu-item[class*="sfHover"]>.sub-menu {
        display: flex;
    }

    #primary-menu ul ul {
        flex-direction: column;
        position: fixed;
        z-index: 10;
        background: var(--background);
        width: 100dvw;
        height: 60dvh;
        padding: 1rem calc((100% - 1200px) / 2);
        overflow: hidden;
        top: auto;
        margin-top: -1px;
        left: 0;
        transition-delay: 0s;
        transition: none;
    }

    .main-navigation .main-nav ul li a,
    #primary-menu ul ul a {
        font-size: .95rem;
        max-width: calc(1200px / 3);
        line-height: 1.5;
        display: flex;
    }

    .main-navigation .main-nav ul li a span {
        padding: 0 0 0 .25rem;
    }

    #primary-menu ul ul li a:hover {
        background: var(--light);
    }

    #primary-menu .menu-item.menu-item-object-product_brand {
        display: flex;
    }

    #primary-menu ul ul .menu-item-object-product_brand a:after {
        content: '';
        display: block;
        width: 150px;
        height: 1.5rem;
        background-size: contain;
        background-repeat: no-repeat;
    }

    #primary-menu .calmia a:after {
        background: url('assets/img/logos/marcas/calmia.png');
    }

    #primary-menu .cannagyn a:after {
        background: url('assets/img/logos/marcas/cannagyn.png');
    }

    #primary-menu .formula a:after {
        background: url('assets/img/logos/marcas/formula.png');
    }

    #primary-menu .marinecol a:after {
        background: url('assets/img/logos/marcas/marinecol.png');
    }

    #primary-menu .probiotax a:after {
        background: url('assets/img/logos/marcas/probiotax.png');
    }

    #primary-menu .vital-sport a:after {
        background: url('assets/img/logos/marcas/vital-sport.png');
    }

    #primary-menu .menu-products {
        display: flex;
        flex-wrap: wrap;
        position: absolute;
        gap: 1rem;
        z-index: 20;
        top: 1.5rem;
        width: calc((1200px / 3) * 2);
        right: calc((100% - 1200px) / 2);
        padding: 0 1rem;
    }

    #primary-menu .menu-products .h3 {
        width: 100%;
        font-size: .85rem;
        font-weight: 500;
        padding-bottom: .5rem;
        color: var(--secondary);
    }

    #primary-menu .menu-products .menu-product {
        position: relative;
        width: calc(50% - .5rem);
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: .5rem;
        padding: .5rem .75rem;
        color: var(--primary);
        font-weight: 500;
        background: var(--light-2);
        border-radius: .5rem;
        border: 1px solid var(--light);
        transition: all .3s ease;

        &:hover {
            background: var(--light);
            border-color: var(--secondary);
        }
    }

    #primary-menu .menu-products .menu-product .label {
        width: fit-content;
        position: absolute;
        top: -.75rem;
        right: 1rem;
        font-size: .8rem;
        padding: .2rem .75rem;
        border-radius: 1rem;
        background: var(--primary);
        color: var(--background);
    }

    #primary-menu .menu-products .menu-product .trustedShopsWidget,
    #primary-menu .menu-products .menu-product .trustedShopsWidget * {
        max-height: 1.15rem;
        line-height: 1.15rem;
        font-size: .85rem;
        font-family: 'QuickSand';
        line-height: 1.15rem;
        pointer-events: none;
    }

    #primary-menu .menu-products .menu-product a {
        padding: .25rem;
    }

    #primary-menu .menu-products .menu-product picture {
        display: flex;
        align-items: center;
        justify-content: center;
        min-width: 100px;
        width: 100px;
        aspect-ratio: 1/1;
        overflow: hidden;
    }

    #primary-menu .menu-products .menu-product:hover picture img {
        transform: scale(1.05);
    }

    #primary-menu .menu-products .menu-product picture img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center center;
        transition: all .3s ease;
    }

    #primary-menu .menu-products .menu-product .content {
        min-width: calc(100% - 100px);
        display: flex;
        flex-direction: column;
        gap: .25rem;
        background: none;
        font-weight: 500;
        color: var(--primary);

        &:hover {
            background: none;
        }
    }

    #primary-menu .menu-products .menu-product .h4 {
        font-family: 'Bree';
        letter-spacing: 0;
        font-size: 1.1rem;
        line-height: 1.2rem;
        height: 2.4rem;
        overflow: hidden;
        margin: 0;
        padding: 0;
        color: var(--primary);
    }

    #primary-menu .menu-products .menu-product .slogan {
        font-size: .8rem;
        line-height: 1.1;
        padding-right: 3.5rem;
        height: 1.8rem;
        overflow: hidden;
    }

    #primary-menu .menu-products .menu-product .prices {
        width: 100%;
        display: flex;
        align-items: flex-end;
        gap: .5rem;
    }

    #primary-menu .menu-products .menu-product .prices span {
        font-weight: 600;
        font-size: 1rem;
        line-height: 1.1;
        color: var(--secondary);

    }

    #primary-menu .menu-products .menu-product .prices .sale_price {
        color: var(--secondary);
        text-decoration: line-through;
        font-weight: 500;
        font-size: .8rem;
    }


    #primary-menu .menu-products .menu-product .special-button {
        position: absolute;
        right: .75rem;
        bottom: .75rem;
        padding: .2rem;
        width: 1.85rem;
        height: 1.85rem;
        border-radius: 1rem;
        line-height: 1;
        overflow: hidden;
        display: flex;
        align-items: center;
        background: var(--primary);
        color: var(--background);
        cursor: pointer;
        transition: all .3s ease;

        &:hover {
            background: var(--secondary);
        }
    }

    #primary-menu .menu-products .menu-product:hover .special-button {
        width: 85px;
    }

    #primary-menu .menu-products .menu-product .special-button svg {
        position: relative;
        z-index: 1;
        display: block;
        padding: .25rem;
        width: 1.5rem;
        min-width: 1.5rem;
        height: 1.5rem;
        border-radius: 1rem;

    }

    #primary-menu .menu-products .menu-product .special-button span {
        position: absolute;
        left: .25rem;
        z-index: 0;
        padding: 0 .5rem 0 1.5rem;
        line-height: 1.5rem;
        font-size: .85rem;
        border-radius: 1rem;
        display: none;
        transition: all .3s ease;
    }

    #primary-menu .menu-products .menu-product:hover .special-button span {
        display: block;
    }

    .woocommerce div.products[class*=columns-] div.product,
    .woocommerce-page div.products[class*=columns-] div.product {
        width: calc(33.33% - .75rem);
    }
}

/* TABLET LANDSCAPE / DESKTOP */
@media only screen and (min-width: 1024px) {

    .inside-header.grid-container {
        padding: 0;
    }

    .site-header {
        padding: .25rem 0 0 0;
    }

    .woocommerce div.products[class*=columns-] div.product,
    .woocommerce-page div.products[class*=columns-] div.product {
        width: calc(25% - 1.15rem);
    }

    .woocommerce-page div.products[class*=columns-] div.product,
    .woocommerce-shop div.products[class*=columns-] div.product {
        width: calc(25% - 1.15rem);
    }

    .woocommerce div.products div.product .excerpt {
        height: 2rem;
    }


    .site-footer #content_footer .column {
        max-width: calc(33.33% - 1rem);
    }

    .site-footer #disclaimer_footer {
        flex-wrap: nowrap;
        margin: 0;
    }

    .page-id-383 .col-lg-6,
    .wpcf7-form .col-lg-6 {
        width: calc(50% - .5rem);
    }

}


@media only screen and (min-width: 1200px) {
    .separate-containers .inside-article {
        padding: 1rem 0;
    }

    #breadcrumbs {
        padding: .5rem 0;
    }
}