/*!
Theme Name:   A. Sousa WooCommerce v
Theme URI:    https://blisq.pt/
Author:       Blisq Creative
Author URI:   https://blisq.pt/
Description:  Tema WooCommerce integrado com layout A. Sousa e compatibilidade com WooCommerce Request List.
Version:      1.0.0
License:      GNU General Public License v2 or later
License URI:  https://www.gnu.org/licenses/gpl-2.0.html
Text Domain:  starter-woocommerce
Tags:         e-commerce, woocommerce, starter-theme
 */

/* =========================================================
   Fontes externas usadas no layout público.
   Estão neste ficheiro para manter apenas um CSS customizado.
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Archivo:ital,wght@0,100..900;1,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300..700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Work+Sans:ital,wght@0,100..900;1,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100..900;1,100..900&display=swap');

/* =========================================================
   Base WordPress/WooCommerce do starter.
   Mantém compatibilidade com estrutura, menus e componentes WP.
   ========================================================= */
:root {
	--color-dark: #212121;
	--color-blue: #0074BC;
	--color-grey: #EDEDED;
}

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

::selection {
	background-color: var(--color-grey);
	color: var(--color-blue);
}

html {
	overflow-x: hidden;
	scroll-behavior: smooth;
}

body {
	counter-reset: count-section;
}


/* =========================================================
   Ajustes de integração WordPress/WooCommerce
   ========================================================= */

.header-logo .custom-logo-link,
.header-logo .custom-logo {
    display: block;
}

.header-logo .custom-logo {
    max-height: 80px;
    width: auto;
}

.nav-cta-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    margin-left: 8px;
    padding: 0 6px;
    border-radius: 999px;
    background: var(--color-orange-soft);
    color: var(--color-blue-deep);
    font-size: 12px;
    font-weight: 700;
}

.catalog-filter-form {
    display: block;
}

.filters-apply {
    width: 100%;
    border: 0;
    cursor: pointer;
    border-radius: 999px;
    padding: 14px 18px;
    margin-top: 16px;
    color: var(--color-cream);
    background: var(--color-blue-deep);
    font-weight: 700;
}

.filters-clear {
    display: inline-flex;
    justify-content: center;
    width: 100%;
    margin-top: 10px;
}
.filter-group-sublist {
    margin: 8px 0 0 18px;
    padding: 0;
    list-style: none;
}

.filter-group-sublist .filter-checkbox {
    opacity: 0.9;
}

.filter-checkbox--depth-1 {
    padding-left: 8px;
}

.filter-checkbox--depth-2 {
    padding-left: 16px;
}

.filter-checkbox--depth-3 {
    padding-left: 24px;
}
.woocommerce-pagination,
.pagination {
    margin-top: 48px;
}

.woocommerce-pagination ul {
    display: flex;
    gap: 8px;
    list-style: none;
    justify-content: center;
    margin: 0 auto;
}

.woocommerce-pagination a,
.woocommerce-pagination span {
    display: inline-flex;
    min-width: 38px;
    height: 38px;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: #fff;
    color: var(--color-blue-deep);
    font-weight: 700;
}

.woocommerce-pagination span.current {
    background: var(--color-orange-soft);
}

.woocommerce-info,
.woocommerce-message,
.woocommerce-error {
    list-style: none;
    margin: 24px auto;
    max-width: 1480px;
    padding: 16px 20px;
    border-radius: 18px;
    background: #fff;
    color: var(--color-blue-deep);
}

.woocommerce-error {
    border-left: 4px solid #b42318;
}

.woocommerce-message {
    border-left: 4px solid var(--color-orange-soft);
}

.product-card .added_to_cart {
    display: none !important;
}

.product-add-form {
    margin: 28px 0 18px;
}

.product-add-form .product-add-btn,
.product-add-btn-wrap .single_add_to_cart_button,
.product-add-btn-wrap .button {
    border: 0;
    cursor: pointer;
}

.product-add-btn-wrap form.cart {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.product-add-btn-wrap .quantity {
    display: flex;
}

.product-add-btn-wrap input.qty {
    width: 96px;
    min-height: 48px;
    border: 1px solid rgba(0, 50, 68, 0.18);
    border-radius: 999px;
    padding: 0 16px;
}

.product-attributes-list {
    display: grid;
    gap: 8px;
    padding-left: 18px;
}

.checkout.woocommerce-checkout.myproducts__container {
    align-items: flex-start;
}

.myproducts__left #order_review {
    width: 100%;
}

.myproducts__grid .shop_table {
    width: 100%;
}

.asousa-review-order {
    display: grid;
    gap: 20px;
}

.asousa-checkout-payment,
#payment {
    margin-top: 0;
    width: 100%;
}

#payment ul {
    list-style: none;
}

#payment .place-order {
    margin-top: 0;
}

#payment button,
#place_order,
.checkout-button,
.woocommerce-cart-form button[name="update_cart"] {
    border: 0;
    cursor: pointer;
}

.myproducts-form .woocommerce-billing-fields h3,
.myproducts-form .woocommerce-shipping-fields h3,
.myproducts-form .woocommerce-additional-fields h3 {
    display: none;
}

.myproducts-form .form-row,
.myproducts-form__group {
    margin-bottom: 16px;
}

.myproducts-form label {
    display: block;
    margin-bottom: 8px;
    color: var(--color-blue-deep);
    font-weight: 700;
}

.myproducts-form input[type="text"],
.myproducts-form input[type="email"],
.myproducts-form input[type="tel"],
.myproducts-form input[type="number"],
.myproducts-form input[type="password"],
.myproducts-form select,
.myproducts-form textarea {
    width: 100%;
    min-height: 48px;
    border: 1px solid rgba(0, 50, 68, 0.16);
    border-radius: 14px;
    padding: 12px 14px;
    background: #fff;
    color: var(--color-blue-deep);
}

.myproducts-form textarea {
    min-height: 130px;
    resize: vertical;
}

.myproducts-card .variation {
    margin-top: 12px;
    color: var(--color-brown-gray);
    font-size: 14px;
}

.myproducts-card .variation dt,
.myproducts-card .variation dd {
    display: inline;
    margin: 0;
}

.myproducts-card .variation dd::after {
    content: "";
    display: block;
}

.product-remove-btn {
    border: 0;
    cursor: pointer;
}

.common-container {
    max-width: 1180px;
    margin: 0 auto;
    padding: clamp(120px, 12vw, 190px) 24px 80px;
}

.common-container p,
.common-container li {
    line-height: 1.65;
}

.common-container ul,
.common-container ol {
    padding-left: 22px;
}

.banner-common + .common-container {
    padding-top: 80px;
}

@media (max-width: 900px) {
    .checkout.woocommerce-checkout.myproducts__container,
    .woocommerce-cart-form.myproducts__container {
        grid-template-columns: 1fr;
    }

    .myproducts__right {
        width: 100%;
    }
}

/* =========================================================
   Layout A. Sousa.
   CSS migrado do HTML original e consolidado em style.css.
   ========================================================= */
/* =========================================================
   TIPOGRAFIA
   ========================================================= */

/* =========================================================
   VARIAVEIS E RESETS
   ========================================================= */

:root {
    --white: #FFF;
    --black: #000;
    --color-cream: #F4F1EA;
    --color-orange-soft: #F49B5C;
    --color-blue-deep: #003244;
    --color-black-soft: #0A0A0A;
    --color-brown-gray: #555147;
    --color-off-white: #FFFDF7;
    --color-olive-dark: #504B3D;
    --color-sand: #B2AC9E;
    --color-navy-dark: #101828;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    overflow-x: hidden;
    position: relative;
    display: block;
    background-color: var(--color-cream);
}

body {
    font-family: "Inter", sans-serif;
    position: relative;
    display: block;
    background-color: transparent;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

figure {
    margin: 0;
    padding: 0;
    width: 100%;
    height: 100%;
    display: block;
}

h1 {
    color: var(--color-cream);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(40px, 6vw, 85px);
    font-style: normal;
    font-weight: 700;
    line-height: 98%;
    letter-spacing: -3.4px;
    text-wrap: balance;
}

h2 {
    color: var(--color-navy-dark);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(18px, 2.5vw, 22px);
    font-style: normal;
    font-weight: 700;
    line-height: 85%;
    letter-spacing: -0.88px;
}

h3 {
    color: var(--color-black-soft);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(16px, 2vw, 20px);
    font-style: normal;
    font-weight: 700;
    line-height: 20px;
}

a {
    color: inherit;
    text-decoration: none;
}

::selection {
    background-color: #E2DED3;
}

.block {
    display: block;
}

.none {
    display: none;
}

html.menu-is-open {
    overflow: hidden;
}

/* =========================================================
   HEADER
   ========================================================= */
.site-header {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
}

.header-container {
    display: flex;
    align-items: stretch;
    max-width: 1878px;
    margin: 0 auto;
    padding: 0 35px;
}

.header-wrapped {
    position: relative;
    display: flex;
}

.header-wrapped::before {
    content: '';
    position: absolute;
    right: -70px;
    top: 0;
    width: 40px;
    height: 40px;
    background-image: url('assets/masks/corner-banner.svg');
    rotate: 180deg;
    display: block;
}

.header-wrapped::after {
    content: '';
    position: absolute;
    left: -16px;
    bottom: -49px;
    width: 40px;
    height: 40px;
    background-image: url('assets/masks/corner-banner.svg');
    rotate: 180deg;
    display: block;
}

.header-logo {
    display: flex;
    align-items: center;
    position: relative;
    z-index: 1;
}

.header-logo::before {
    content: '';
    position: absolute;
    left: -40px;
    bottom: -9px;
    width: calc(100% + 70px);
    height: calc(100% + 26px);
    background-color: #f4f1ea;
    display: block;
    z-index: -1;
    border-radius: 0 0 30px 0;
}

.header-logo img {
    height: auto;
    width: 100%;
    padding-left: 17px;
}

.site-nav {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    transform: translateY(17px);
}

.site-nav .menu {
    display: flex;
    align-items: center;
    gap: clamp(20px, 2.08vw, 40px);
    list-style: none;
    margin-left: auto;
}

.site-nav .menu-item a {
    color: #FFFDF7;
    font-size: clamp(14px, 0.83vw, 16px);
    font-style: normal;
    font-weight: 500;
    line-height: 140%;
    position: relative;
    padding-bottom: 6px;
}

.single-produto .site-nav .menu-item a,
.privacy-policy .site-nav .menu-item a {
    color: var(--color-brown-gray);
}

.single-produto .site-nav .hamburger-btn span,
.privacy-policy .site-nav .menu-item a {
    color: var(--color-brown-gray);
}

.site-nav .menu-item a::after {
    content: '';
    position: absolute;
    bottom: -6px;
    left: 50%;
    transform: translateX(-50%) scale(0);
    width: 4px;
    height: 4px;
    background-color: var(--color-orange-soft);
    border-radius: 50%;
    transition: transform 0.2s ease;
}

.site-nav .menu-item a:hover::after {
    transform: translateX(-50%) scale(1);
}

.nav-cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: clamp(12px, 0.89vw, 17px) clamp(16px, 1.25vw, 24px);
    color: var(--color-navy-dark);
    background-color: var(--color-orange-soft);
    border-radius: clamp(20px, 2.03vw, 39px);
    font-size: clamp(14px, 0.83vw, 16px);
    font-style: normal;
    font-weight: 600;
    line-height: 140%;
    white-space: nowrap;
    align-self: center;
    margin-left: auto;
    transition: opacity 0.2s ease, background-color 0.3s ease, color 0.3s ease;
}

.nav-cta:hover {
    background-color: #2C7894;
    color: var(--white);
}

.nav-cta::after {
    content: '';
    display: inline-block;
    width: 25px;
    height: 25px;
    background-image: url('assets/icons/basket.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    transition: filter 0.3s ease;
}

.nav-cta:hover::after {
    filter: invert(1);
}

/* Hamburguer — escondido por defeito */
.hamburger-btn {
    display: none;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px;
    width: 44px;
    height: 44px;
    background: none;
    border: none;
    cursor: pointer;
    align-self: center;
    margin-left: auto;
    padding: 8px;
    z-index: 200;
}

.hamburger-btn span {
    display: block;
    width: 24px;
    height: 2px;
    background-color: var(--color-off-white);
    border-radius: 2px;
    transition: transform 0.3s ease, opacity 0.3s ease, width 0.3s ease;
    transform-origin: center;
}

/* Animação X */
.hamburger-btn.is-open span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}

.hamburger-btn.is-open span:nth-child(2) {
    opacity: 0;
    width: 0;
}

.hamburger-btn.is-open span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

.menu-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(4px);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease;
    z-index: 140;
}

.menu-overlay.is-open {
    opacity: 1;
    visibility: visible;
}

/* =========================================================
   HERO
   ========================================================= */
.hero {
    position: relative;
    width: 100%;
    min-height: calc(100vh - 128px);
    border-radius: 40px;
    background-image: url('assets/images/bg-hero.webp');
    background-size: cover;
    background-position: center top;
    margin: 40px auto 0;
    max-width: 1840px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero-content {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    align-items: flex-end;
    padding: 47px 41px;
    gap: 4.4%;
}

.hero-left {
    max-width: 41.3%;
}

.hero-left h1 strong {
    color: var(--color-orange-soft);
    font-weight: inherit;
}

.hero-right {
    max-width: 24.3%;
    display: flex;
    flex-direction: column;
    gap: clamp(24px, 4vw, 61px);
}

.hero-desc {
    color: var(--color-off-white);
    font-size: clamp(16px, 1.5vw, 20px);
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
}

.hero-link {
    color: var(--color-cream);
    font-size: clamp(13px, 1.2vw, 17px);
    font-style: normal;
    font-weight: 600;
    line-height: 140%;
    transition: color 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.hero-link::after {
    content: '→';
    transition: transform 0.2s ease;
}

.hero-link:hover::after {
    transform: scaleX(1.25);
}

.hero-corner {
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 2;
    background-color: var(--color-cream);
    border-top-left-radius: 37px;
    padding: 16px 5px 9px 16px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero-corner::before {
    content: '';
    height: 40px;
    width: 40px;
    background-image: url('assets/masks/corner-banner.svg');
    position: absolute;
    left: -39px;
    bottom: 0;
}

.hero-corner::after {
    content: '';
    height: 40px;
    width: 40px;
    background-image: url('assets/masks/corner-banner.svg');
    position: absolute;
    right: 0;
    top: -40px;
}

.hero-cta {
    display: inline-flex;
    align-items: center;
    padding: 17px 24px;
    background-color: var(--color-blue-deep);
    color: var(--white);
    border-radius: 39px;
    font-size: clamp(13px, 1vw, 15px);
    font-weight: 500;
    white-space: nowrap;
    transition: opacity 0.2s ease;
}

.hero-cta:hover {
    opacity: 0.85;
}

/* =========================================================
   SECÇÕES GERAIS
   ========================================================= */
.section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: clamp(18px, 1.6vw, 30px);
    flex-wrap: wrap;
    gap: 10px 20px;
}

.section-link {
    color: #8D887D;
    font-size: clamp(13px, 1.2vw, 15px);
    font-style: normal;
    font-weight: 500;
    line-height: 140%;
    transition: color 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.section-link::after {
    content: '→';
    transition: transform 0.2s ease;
}

.section-link:hover::after {
    transform: scaleX(1.25);
}

/* =========================================================
   ÚLTIMAS NOVIDADES
   ========================================================= */
.section-news {
    max-width: 1640px;
    margin: clamp(40px, 4vw, 80px) auto 0;
}

.products-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: clamp(40px, 4vw, 80px);
}

.product-card {
    background-color: transparent;
    border-radius: 18px;
    padding: clamp(15px, 3vw, 55px) 0 clamp(15px, 1.35vw, 26px);
    transition: all 0.4s ease;
    text-align: center;
    position: relative;
}

.product-card:hover {
    background-color: var(--color-off-white);
}

.product-img {
    display: flex;
    align-items: center;
    justify-content: center;
    
    padding-bottom: clamp(20px, 2vw, 38px);
}

.product-btn-add {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 41px;
    height: 41px;
    background-color: #E3DFD5;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: scale(0);
    transform-origin: center;
    transition: opacity 0.25s ease, transform 0.25s ease;
}

.product-card:hover .product-btn-add {
    opacity: 1;
    transform: scale(1);
}

.product-btn-add img {
    width: 16px;
    height: 16px;
}

.product-img img {
    max-width: 100%;
    height: auto;
    object-fit: contain;
    transition: transform 0.4s ease;
    transform-origin: center;
}

.product-card:hover .product-img img {
    transform: scale(1.1);
}

.product-name {
    padding-bottom: 11px;
}

.product-desc {
    color: var(--color-brown-gray);
    text-align: center;
    font-size: clamp(14px, 1.5vw, 17px);
    font-style: normal;
    font-weight: 300;
    line-height: 16px;
}

.product-card-link {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 0px 30px 0px 30px;
}

/* =========================================================
   MARCAS EM DESTAQUE
   ========================================================= */
.section-brands {
    max-width: 1640px;
    margin: clamp(40px, 4.17vw, 80px) auto 0;
}

.brands-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: clamp(15px, 1.3vw, 25px);
}

.brand-card {
    background-color: var(--color-off-white);
    border-radius: 12px;
    padding: clamp(20px, 1.82vw, 35px) clamp(30px, 2.81vw, 54px);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform 0.2s ease;
    gap: clamp(12px, 1.09vw, 21px);
}

.brand-logo {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.brand-logo img {
    max-width: 100%;
    height: auto;
    object-fit: contain;
}

.brand-products {
    width: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.brand-products img {
    max-width: 100%;
    height: auto;
    object-fit: contain;
    transition: transform 0.4s ease;
}

.brand-card:hover .brand-products img {
    transform: scale(1.1);
}

.brand-category {
    color: #6A6352;
    text-align: center;
    font-size: clamp(13px, 0.78vw, 15px);
    font-style: normal;
    font-weight: 300;
    line-height: 14.545px;
}

/* =========================================================
   COMO FUNCIONA
   ========================================================= */
.section-how {
    max-width: 1640px;
    margin: clamp(40px, 4.17vw, 80px) auto 0;
    display: grid;
    grid-template-columns: 56.9% 1fr;
    gap: clamp(7px, 2.66vw, 51px);
    align-items: center;
}

.section-how-img {
    width: 100%;
    border-radius: 28px;
    overflow: hidden;
}

.section-how-img img {
    width: 100%;
    height: auto;
    object-fit: contain;
    display: block;
}

.section-how-steps {
    display: flex;
    flex-direction: column;
}

.step {
    padding: clamp(10px, 1.82vw, 35px);
    display: flex;
    flex-direction: column;
    gap: clamp(10px, 0.78vw, 15px);
    border-radius: 20px;
    transition: all 0.3s ease;
}

.step:hover {
    background-color: var(--white);
}

.step-desc {
    color: var(--color-olive-dark);
    font-size: clamp(15px, 0.94vw, 18px);
    font-style: normal;
    font-weight: 300;
    line-height: 28px;
    max-width: 538px;
}

/* =========================================================
   CTA
   ========================================================= */
.section-cta {
    max-width: 1370px;
    margin: clamp(40px, 4.17vw, 80px) auto;
    border-radius: 20px;
    overflow: hidden;
    position: relative;
    background-image: url('assets/images/cta.webp');
    background-size: cover;
    background-position: center;
    padding: clamp(30px, 2.86vw, 55px) 0 clamp(30px, 2.86vw, 55px) clamp(40px, 4.43vw, 85px);
}

.section-cta::before {
    content: '';
    position: absolute;
    top: 28%;
    right: -5.9%;
    width: 25%;
    height: 125%;
    background-image: url(assets/images/symbol.webp);
    background-repeat: no-repeat;
    background-size: contain;
}

.section-cta-content {
    position: relative;
    z-index: 1;
    max-width: 420px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.cta-title {
    color: var(--color-navy-dark);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(28px, 1.98vw, 38px);
    font-style: normal;
    font-weight: 700;
    line-height: 102%;
    letter-spacing: -1.52px;
    text-wrap: balance;
}

.cta-desc {
    color: #7E7559;
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(16px, 0.99vw, 19px);
    font-style: normal;
    font-weight: 400;
    line-height: 140%;
    letter-spacing: -0.76px;
    margin-bottom: clamp(5px, 1.3vw, 25px);
}

.cta-btn {
    display: inline-flex;
    align-items: center;
    align-self: flex-start;
    padding: clamp(12px, 0.89vw, 17px) clamp(16px, 1.25vw, 24px);
    background-color: #034D69;
    color: var(--white);
    border-radius: 100px;
    font-size: clamp(13px, 1.2vw, 15px);
    font-style: normal;
    font-weight: 600;
    line-height: 140%;
    transition: color 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.cta-btn::after {
    content: '→';
    transition: transform 0.2s ease;
}

.cta-btn:hover::after {
    transform: scaleX(1.25);
}

/* =========================================================
    FOOTER
========================================================= */
.footer {
    padding: 0 clamp(16px, 2.5vw, 30px) clamp(25px, 2.08vw, 40px);
    position: relative;
}

.footer-inner {
    background-color: #EAE7DE;
    background-image: url('assets/images/logo-footer_bg.webp');
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 70.8%;
    border-radius: 20px;
    padding: 40px 40px 25px;
    position: relative;
    max-width: 1840px;
    margin: 0 auto;
}

.footer-corner {
    position: absolute;
    top: 0;
    background-color: var(--color-cream);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    transition: all 0.2s ease;
}

.corner-left {
    left: 0;
}

.footer-corner.corner-left {
    width: 50px;
    height: auto;
    max-height: 133px;
    border-bottom-right-radius: 20px;
    padding: 8px 12px 18px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.footer-corner.corner-left::before {
    content: '';
    position: absolute;
    right: -20px;
    top: 0;
    width: 20px;
    height: 20px;
    background-image: url('assets/masks/corner-footer.svg');
    rotate: 180deg;
    display: block;
}

.footer-corner.corner-left::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: -20px;
    width: 20px;
    height: 20px;
    background-image: url('assets/masks/corner-footer.svg');
    rotate: 180deg;
    display: block;
}

.social-icons-col {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 18px;
}

.social-icons-col a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
}

.social-icons-col img {
    width: 100%;
    height: auto;
    display: block;
}

.corner-right {
    right: 0;
}

.footer-corner.corner-right {
    width: 90px;
    height: 90px;
    background-color: var(--color-cream);
    border-bottom-left-radius: 20px;
    padding: 0;
}

.footer-corner.corner-right::before {
    content: '';
    position: absolute;
    left: -20px;
    top: 0px;
    width: 20px;
    height: 20px;
    background-image: url('assets/masks/corner-footer.svg');
    rotate: -90deg;
    display: block;
}

.footer-corner.corner-right::after {
    content: '';
    position: absolute;
    right: 0px;
    bottom: -20px;
    width: 20px;
    height: 20px;
    background-image: url('assets/masks/corner-footer.svg');
    rotate: -90deg;
    display: block;
}

.back-to-top-btn {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: transparent;
    position: relative;
    border: none;
    background-color: transparent;
    cursor: pointer;
}

.back-to-top-btn::before {
    content: '';
    position: absolute;
    width: 70px;
    height: 70px;
    background-color: var(--color-blue-deep);
    border-radius: 50%;
    z-index: 1;
    transition: transform 0.3s ease;
}

.back-to-top-btn:hover::before {
    transform: scale(0.83);
}

.back-to-top-btn img {
    position: relative;
    z-index: 2;
    width: 16px;
    height: 16px;
}

/* Layout em 3 Colunas Principais */
.footer-main {
    display: grid;
    grid-template-columns: 36.2% 41% 12.7%;
    gap: 30px;
    padding-bottom: clamp(35px, 6.30vw, 121px);
    position: relative;
    z-index: 5;
}

.footer-main::after {
    content: '';
    position: absolute;
    bottom: 0;
    width: calc(100% + 80px);
    height: 1px;
    background-color: #C8C1AC;
    left: -40px;
}

/* Coluna 1 - Logo e Info */
.footer-brand .footer-logo {
    margin-bottom: clamp(70px, 7.03vw, 135px);
}

.footer-brand .footer-logo img {
    max-width: 222px;
    height: auto;
    margin-left: 48px;
}

.footer-brand p {
    color: var(--color-olive-dark);
    font-family: "Work Sans", sans-serif;
    font-size: clamp(14px, 0.885vw, 17px);
    font-style: normal;
    font-weight: 400;
    line-height: 140%;
    max-width: 273px;
    margin-bottom: 31px;
    text-wrap: balance;
}

.footer-brand address {
    color: var(--color-navy-dark);
    font-family: "Work Sans", sans-serif;
    font-size: clamp(14px, 0.833vw, 16px);
    font-style: normal;
    font-weight: 600;
    line-height: 130%;
}

.footer-nav {
    padding-top: 15px;
}

.footer-nav>.menu-footer {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.footer-nav>.menu-footer>.menu-item {
    margin: 0;
}

.footer-nav>.menu-footer>.menu-item>a {
    display: block;
    color: var(--color-navy-dark);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(13px, 0.78vw, 15px);
    font-weight: 700;
    line-height: 85%;
    letter-spacing: -0.6px;
    margin-bottom: 24px;
    text-decoration: none;
}

.footer-nav .sub-menu {
    list-style: none;
    margin: 0;
    padding: 0;
}

.footer-nav .sub-menu .menu-item {
    margin-bottom: 23px;
    line-height: 85%;
}

.footer-nav .sub-menu .menu-item a {
    color: var(--color-olive-dark);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(14px, 0.94vw, 18px);
    font-weight: 400;
    letter-spacing: -0.72px;
    text-decoration: none;
}

.footer-nav .menu-item a:hover {
    color: var(--color-orange-soft);
}

.footer-nav .menu-item-has-children>a {
    pointer-events: none;
    cursor: default;
    user-select: none;
}

/* Garantir que os submenus continuam clicáveis */
.footer-nav .sub-menu .menu-item a {
    pointer-events: auto;
    cursor: pointer;
}

/* Coluna 3 - Contactos */
.footer-contact .title {
    margin-bottom: 4px;
    padding-top: 15px;
    color: var(--color-navy-dark);
    font-family: "Work Sans", sans-serif;
    font-size: clamp(14px, 0.83vw, 16px);
    font-style: normal;
    font-weight: 600;
    line-height: 130%;
}

.footer-contact .contact-email {
    display: block;
    margin-bottom: 12px;
    color: var(--color-olive-dark);
    font-family: "Work Sans", sans-serif;
    font-size: clamp(14px, 0.83vw, 16px);
    font-style: normal;
    font-weight: 400;
    line-height: 130%;
    transition: color 0.2s;
}

.footer-contact .contact-email:hover {
    color: var(--color-orange-soft);
}

.phone-block {
    margin-bottom: 12px;
}

.phone-block strong {
    display: block;
    color: var(--color-olive-dark);
    font-family: "Work Sans", sans-serif;
    font-size: clamp(14px, 0.83vw, 16px);
    font-style: normal;
    font-weight: 400;
    line-height: 130%;
}

.footer-contact .phone-block strong:hover {
    color: var(--color-orange-soft);
}

.phone-block small {
    color: var(--color-sand);
    font-family: "Work Sans", sans-serif;
    font-size: clamp(10px, 0.68vw, 13px);
    font-style: normal;
    font-weight: 400;
    line-height: 130%;
    text-transform: uppercase;
    text-wrap: nowrap;
}

/* Footer Bottom  */
.footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: clamp(16px, 1.30vw, 25px);
    position: relative;
    z-index: 5;
    gap: 20px;
}

.legal-nav .menu {
    display: flex;
    gap: clamp(30px, 3.65vw, 70px);
    list-style: none;
    margin: 0;
    padding: 0;
}

.legal-nav .menu-item a {
    color: var(--color-navy-dark);
    font-family: "Work Sans", sans-serif;
    font-size: clamp(12px, 0.73vw, 14px);
    font-style: normal;
    font-weight: 400;
    line-height: 130%;
    transition: color 0.2s;
}

.legal-nav .menu-item a:hover {
    color: var(--color-orange-soft);
}

.footer__blisq figure {
    margin: 0;
    width: auto;
    height: auto;
}

.footer__blisq img {
    width: 100%;
}

/* =========================================================
   BANNER CATALOG / commom
   ========================================================= */
.banner {
    position: relative;
    width: 100%;
    border-radius: 40px;
    background-color: #034C67;
    margin: 40px auto 0;
    max-width: 1840px;
    min-height: 264px;
    display: flex;
    align-items: flex-end;
    padding: 32px 35px;
}

.banner.banner--catalog {
    background-image: url('assets/images/banner_catalogo.webp');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    position: relative;
}

.banner-content {
    display: flex;
    flex-direction: column;
    gap: 12px;
    max-width: 486px;
}

.banner-title {
    color: #F4F1EA;
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(24px, 4vw, 48px);
    font-style: normal;
    font-weight: 700;
    line-height: 98%;
    letter-spacing: -0.96px;
}

.banner-desc {
    color: #E5DFD3;
    font-size: clamp(14px, 1.5vw, 18px);
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
    max-width: 88%;
    text-wrap: balance;
}

.banner-btn {
    padding: clamp(12px, 1.2vw, 17px) clamp(20px, 2.5vw, 43px);
}

/*BANNER COMMON*/
.banner-common .banner-content {
    gap: 9px;
    max-width: 632px;
}

.banner-common .banner-desc {
    color: #93B5C2;
    font-size: clamp(14px, 1.2vw, 18px);
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
    max-width: 632px;
}

/* =========================================================
   CATÁLOGO — PÁGINA
   ========================================================= */

.catalog-page {
    max-width: 1774px;
    margin: 0 auto;
    padding: clamp(20px, 2vw, 30px) 0 clamp(40px, 4vw, 60px);
}

/* Search */
.catalog-search {
    display: flex;
    align-items: center;
    background-color: transparent;
    border: 1px solid #D6D3CB;
    border-radius: 52px;
    padding: clamp(12px, 1.2vw, 16px) clamp(24px, 3vw, 48px);
    position: relative;
    transition: border-color 0.2s ease;
    margin-bottom: clamp(12px, 1.2vw, 17px);
}

.catalog-search:hover {
    background-color: #EAE7DE;
    border: 1px solid transparent;
}

.catalog-search:focus-within {
    border-color: var(--color-navy-dark);
}

.catalog-search::before {
    content: '';
    width: 20px;
    height: 20px;
    background-image: url('assets/icons/search.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    flex-shrink: 0;
    position: absolute;
    left: clamp(10px, 1vw, 20px);
}

.catalog-search input {
    flex: 1;
    border: none;
    background: transparent;
    color: #555147;
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(12px, 1vw, 14px);
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    outline: none;
}

.catalog-search input::placeholder {
    color: #555147;
}

.catalog-search:hover input::placeholder {
    color: #8B877C;
}

.catalog-search input::-webkit-search-cancel-button {
    -webkit-appearance: none;
    appearance: none;
}

/* Layout */
.catalog-layout {
    display: grid;
    grid-template-columns: 17.8% 1fr;
    gap: 15px;
    align-items: start;
}

/* Filtros */
.catalog-filters {
    background-color: var(--color-off-white);
    border-radius: 20px;
    padding: clamp(14px, 1.5vw, 20px) clamp(12px, 1.2vw, 18px);
    position: sticky;
    top: 20px;
	max-height: 90vh;
    overflow-y: scroll;    
}

.filters-title {
    color: var(--color-navy-dark);
    font-family: "Roboto", sans-serif;
    font-size: clamp(14px, 1.5vw, 18px);
    font-style: normal;
    font-weight: 700;
    line-height: 28px;
    margin-bottom: 10px;
}

.filter-group {
    border-bottom: 1px solid #E5E7EB;
    padding: clamp(8px, 1vw, 10px) 0 clamp(10px, 1.5vw, 15px);
}

.filter-group:first-of-type {
    border-top: none;
}

.filter-group-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(12px, 1vw, 14px);
    font-weight: 700;
    color: var(--color-navy-dark);
    gap: 10px;
}

.filter-group-header::after {
    content: '';
    width: 16px;
    height: 16px;
    background-image: url('assets/icons/chevronDown.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    transition: transform 0.2s ease;
    flex-shrink: 0;
}

.filter-group-header[aria-expanded="false"]::after {
    transform: rotate(-90deg);
}

.filter-group-list {
    list-style: none;
    margin-top: 10px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.filter-checkbox {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-size: clamp(12px, 1vw, 14px);
    color: var(--color-brown-gray);
    margin-bottom:8px;
}

.filter-checkbox input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    border-radius: 4px;
    border: 0.5px solid #8D887D;
    cursor: pointer;
    flex-shrink: 0;
    transition: all 0.2s ease;
    position: relative;
}

.filter-checkbox input[type="checkbox"]:checked {
    background-color: #0A1D38;
    border-color: #0A1D38;
}

.filter-checkbox input[type="checkbox"]:checked::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 8px;
    height: 8px;
    background-image: url('assets/icons/check.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}

.filter-checkbox input[type="checkbox"]:hover:not(:checked) {
    background-color: #E8E4DB;
}

.filters-clear {
    width: 100%;
    margin-top: 20px;
    padding: clamp(7px, 1vw, 9px) clamp(24px, 3vw, 43px);
    background: none;
    border: 1px solid transparent;
    border-radius: 100px;
    color: #8D887D;
    text-align: center;
    font-size: clamp(13px, 1vw, 15px);
    font-style: normal;
    font-weight: 500;
    line-height: 140%;
    cursor: pointer;
    transition: all 0.2s ease;
    background-color: #F4F1EA;
}

.filters-clear:hover {
    background-color: #E2DDCF;
}

.catalog-count {
    color: #555147;
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(10px, 0.625vw, 12px);
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    margin-bottom: clamp(14px, 1.5vw, 18px);
    padding-left: 22px;
}

.products-grid--catalog {
    gap: 15px;
}

/* Paginação */
.pagination {
    display: flex;
    justify-content: center;
    margin-top: 20px;
    grid-column: 1 / -1;
}

.nav-links {
    display: flex;
    align-items: center;
}

.page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    font-size: clamp(11px, 0.677vw, 13px);
    color: var(--color-brown-gray);
    transition: all 0.2s ease;
}

.page-numbers:hover {
    background-color: var(--color-off-white);
    color: var(--color-black-soft);
}

.page-numbers.current {
    background-color: var(--color-off-white);
    color: var(--color-brown-gray);
}

.page-numbers.prev,
.page-numbers.next {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background-color: #E3DED1;
    padding: 0;
    border: none;
    color: transparent;
    font-size: 0;
}

.page-numbers.prev {
    margin-right: 7px;
}

.page-numbers.next {
    margin-left: 7px;
}

.page-numbers.prev::before,
.page-numbers.next::before {
    content: '';
    width: 16px;
    height: 16px;
    background-image: url('assets/icons/chevronDown.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    display: block;
    transition: transform 0.2s ease;
}

.page-numbers.prev:hover,
.page-numbers.next:hover {
    transform: scale(1.3);
}

.page-numbers.prev::before {
    transform: rotate(90deg);
}

.page-numbers.next::before {
    transform: rotate(-90deg);
}

.screen-reader-text {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
}

/*BTN filtros mobile*/
/* Botão de abrir filtros - escondido por defeito */
.catalog-filters-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    background-color: transparent;
    border: 1px solid #D6D3CB;
    border-radius: 50%;
    cursor: pointer;
    border: none;
    transition: all 0.2s ease;
}

.catalog-filters-toggle:hover {
    background-color: #E8E4DB;
    transform: scale(1.05);
}

.catalog-filters-toggle img {
    width: 22px;
    height: 22px;
}

/* Overlay - escondido por defeito */
.catalog-filters-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(3px);
    z-index: 90;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.catalog-filters-overlay.is-open {
    opacity: 1;
    visibility: visible;
}

/* Botão fechar filtros */
.catalog-filters__close {
    display: none;
    position: absolute;
    top: 15px;
    right: 15px;
    background: none;
    border: none;
    font-size: 28px;
    cursor: pointer;
    color: var(--color-navy-dark);
    width: 40px;
    height: 40px;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: background-color 0.2s;
    z-index: 101;
}

.catalog-filters__close:hover {
    background-color: #E8E4DB;
}

/* =========================================================
    Single dos produtos
   ========================================================= */
.banner--single {
    background-color: #EAE7DE;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: clamp(16px, 1.198vw, 23px);
    min-height: calc(100vh - 199px);
}

.hero-corner--empty {
    pointer-events: none;
    min-width: 200px;
    min-height: 80px;
}

.breadcrumb {
    align-self: flex-start;
    margin-top: 105px;
}

.breadcrumb ol {
    display: flex;
    align-items: center;
    gap: clamp(10px, 0.677vw, 13px);
    list-style: none;
    padding: 0;
    margin: 0;
    flex-wrap: wrap;
}

.breadcrumb li {
    display: flex;
    align-items: center;
    gap: clamp(10px, 0.677vw, 13px);
    color: #888372;
    font-size: clamp(12px, 1vw, 14px);
    font-style: normal;
    font-weight: 400;
    line-height: 20px;
}

.breadcrumb li:first-child a::before {
    content: '';
    display: inline-block;
    width: 10px;
    height: 12px;
    background-image: url('assets/icons/home.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    vertical-align: middle;
    margin-right: 5px;
}

.breadcrumb li::after {
    content: '';
    display: inline-block;
    width: 16px;
    height: 16px;
    background-image: url('assets/icons/chevronRight.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}

.breadcrumb li:last-child::after {
    display: none;
}

.breadcrumb a {
    color: var(--color-brown-gray);
    transition: color 0.2s ease;
}

.breadcrumb a:hover {
    color: var(--color-black-soft);
}

/* Product Details */
.product-details {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0 auto;
    max-width: 1250px;
}

.product-details-card {
    display: grid;
    grid-template-columns: 53.84% 1fr;
    column-gap: 4%;
    align-items: center;
}

/* Galeria */
.gallery {
    display: grid;
    grid-template-columns: 85px 1fr;
    gap: clamp(14px, 1.042vw, 20px);
    max-height: 568px;
}

.gallery.no-thumbs {
    grid-template-columns: 100%;
    margin-left: 105px;
    max-height: fit-content;
}

.thumbs {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
    overflow-y: auto;
    scrollbar-width: none;
    overflow: auto;
    cursor: grab;
}

.thumbs figure:first-child {
    margin-top: auto;
    margin-left: auto;
}

.thumbs figure:last-child {
    margin-bottom: auto;
    margin-right: auto;
}

.thumbs figure {
    height: 85px;
    background-color: #DEDBD2;
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    border: 1px solid transparent;
}

.thumbs.active {
    cursor: grabbing;
}

.thumbs.active>figure {
    pointer-events: none;
}

.thumbs::-webkit-scrollbar {
    display: none;
}

.thumbs img {
    width: fit-content;
    height: 70px;
    object-fit: contain;
}

.thumbs figure:hover,
.thumbs figure.active {
    border-color: var(--color-orange-soft);
}

.main-image-wrap {
    border-radius: 20px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    max-height: 100%;
    aspect-ratio: 1 / 1;
    background-color: var(--color-cream);
    min-height: 568px;
    width: 100%;
}

.main-image-wrap img {
    width: fit-content;
    height: 81.9%;
    object-fit: contain;
    display: block;
    transition: opacity 0.3s ease, transform 0.35s ease;
}

.main-image-wrap img.fade-out {
    opacity: 0;
    transform: scale(0.97);
}

/* right column */
.product-info-panel {
    display: flex;
    flex-direction: column;
    gap: clamp(14px, 1.042vw, 20px);
}

/* Marca */
.product-brand {
    display: inline-flex;
    align-self: flex-start;
    padding: 7px 8px;
    background-color: #FFFDF7;
    border-radius: 8px;
    color: var(--color-olive-dark);
    font-family: "Open Sans", sans-serif;
    font-size: clamp(10px, 0.625vw, 12px);
    font-style: normal;
    font-weight: 400;
    line-height: 20px;
    text-transform: uppercase;
    margin-bottom: -10px;
}

/* Título */
.product-single-title {
    color: #0A1D38;
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(20px, 1.458vw, 28px);
    font-style: normal;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: normal;
    margin-bottom: -10px;
    padding: 4px 0;
}

/* Descrição */
.product-single-desc p {
    color: #555147;
    font-size: clamp(12px, 0.781vw, 15px);
    font-style: normal;
    font-weight: 300;
    line-height: 150%;
    border-top: 1px solid #BDB7A8;
    border-bottom: 1px solid #BDB7A8;
    padding: 20px 0;
}

/* Quantidade */
.product-quantity {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: clamp(9px, 0.625vw, 12px);
}

.product-quantity-label {
    color: var(--color-olive-dark);
    font-family: "Roboto", sans-serif;
    font-size: clamp(11px, 0.729vw, 14px);
    font-style: normal;
    font-weight: 600;
    line-height: 20px;
}

.product-quantity-controls {
    display: flex;
    align-items: center;
    background-color: var(--color-off-white);
    border-radius: 51px;
    padding: 8px 11px;
}

.quantity-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.2s ease;
}

.quantity-btn:hover {
    background-color: #E3DFD5;
}

.quantity-btn--minus::before {
    content: '';
    width: 16px;
    height: 16px;
    background-image: url('assets/icons/minus.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    display: block;
}

.quantity-btn--plus::before {
    content: '';
    width: 16px;
    height: 16px;
    background-image: url('assets/icons/plusCount.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    display: block;
}

.quantity-value {
    color: var(--color-black-soft);
    text-align: center;
    font-family: "Open Sans", sans-serif;
    font-size: clamp(12px, 0.833vw, 16px);
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    width: 74px;
    text-align: center;
    border: none;
    background: transparent;
    outline: none;
    appearance: textfield;
    -moz-appearance: textfield;
}

.quantity-value::-webkit-outer-spin-button,
.quantity-value::-webkit-inner-spin-button {
    -webkit-appearance: none;
}

/* Referências */
.product-refs {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.product-ref {
    color: var(--color-brown-gray);
    font-family: "Open Sans", sans-serif;
    font-size: clamp(11px, 0.729vw, 14px);
    font-style: normal;
    font-weight: 400;
    line-height: 20px;
}

.product-ean {
    color: #8D8573;
    font-family: "Open Sans", sans-serif;
    font-size: clamp(10px, 0.625vw, 12px);
    font-style: normal;
    font-weight: 400;
    line-height: 16px;
}

/* Categorias */
.product-categories {
    display: flex;
    align-items: center;
    gap: clamp(14px, 1.042vw, 20px);
    flex-wrap: wrap;
    margin-bottom: 20px;
}

.product-categories-label {
    color: var(--color-olive-dark);
    font-family: "Roboto", sans-serif;
    font-size: clamp(11px, 0.729vw, 14px);
    font-style: normal;
    font-weight: 600;
    line-height: 20px;
}

.product-categories-tags {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.product-tag {
    display: inline-flex;
    align-self: flex-start;
    padding: 7px 8px;
    background-color: #FFFDF7;
    border-radius: 8px;
    color: var(--color-brown-gray);
    font-family: "Open Sans", sans-serif;
    font-size: clamp(10px, 0.625vw, 12px);
    font-style: normal;
    font-weight: 400;
    line-height: 20px;
    text-transform: uppercase;
}

/* CTA */
.product-add-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: clamp(10px, 0.781vw, 15px);
    border-radius: 75px;
    background-color: var(--color-blue-deep);
    color: var(--white);
    font-size: clamp(12px, 0.833vw, 17px);
    font-style: normal;
    font-weight: 600;
    line-height: 140%;
    transition: background 0.2s ease;
        width: 100%;
}

.product-add-btn:hover {
    background-color: #002736;
}

.product-add-btn::before {
    content: '';
    width: 20px;
    height: 20px;
    background-image: url('assets/icons/orangePlus.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    display: block;
    transition: transform 0.2s ease;
}

.product-add-btn:hover::before {
    transform: scale(1.4);
}

/* Nota */
.product-note {
    color: #8D887D;
    font-family: "Open Sans", sans-serif;
    font-size: clamp(12px, 0.781vw, 13px);
    font-style: normal;
    font-weight: 600;
    line-height: 106.667%;
    text-align: center;
    margin-top: -5px;
}

.product-note strong {
    font-size: clamp(14px, 0.833vw, 15px);
    font-weight: 700;
}

.product-info {
    max-width: 1220px;
    margin: clamp(40px, 3.125vw, 60px) auto;
}

/* AVISO */
.product-alert {
    display: flex;
    align-items: flex-start;
    background-color: #FFFDF7;
    border-radius: 10px;
    padding: clamp(18px, 1vw, 18px) clamp(20px, 2vw, 20px);
    margin-bottom: 15px;
}

.product-alert-text {
    position: relative;
    padding-left: 43px;
}

.product-alert-text::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 28px;
    height: 28px;
    background-image: url('assets/icons/alert.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}

.product-alert-text strong {
    color: var(--color-olive-dark);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(12px, 1vw, 14px);
    font-style: normal;
    font-weight: 700;
    line-height: 20px;
}

.product-alert-text p {
    color: #8D887D;
    font-size: clamp(12px, 1vw, 14px);
    font-style: normal;
    font-weight: 400;
    line-height: 20px;
}

/* ACORDEÃO single */
.product-accordion {
    display: flex;
    flex-direction: column;
    gap: clamp(12px, 0.781vw, 15px);
}

.accordion-body {
    display: none;
}

.accordion-item {
    background-color: #EAE7DE;
    border-radius: 10px;
    overflow: hidden;
    transition: background-color 0.25s ease-in-out;
}

.accordion-item:hover {
    background-color: #FFFDF7;
}

.accordion-header {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: clamp(14px, 1.5vw, 20px) clamp(16px, 2vw, 30px) clamp(14px, 1.5vw, 20px) clamp(16px, 2vw, 24px);
    background: none;
    border: none;
    cursor: pointer;
    color: var(--color-black-soft);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(14px, 1vw, 16px);
    font-style: normal;
    font-weight: 500;
    line-height: 20px;
    text-align: left;
}

.accordion-header::after {
    content: '';
    width: 16px;
    height: 16px;
    background-image: url('assets/icons/chevronDown.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    flex-shrink: 0;
    transition: transform 0.2s ease;
}

.accordion-header[aria-expanded="true"]::after {
    transform: rotate(180deg);
}

.accordion-body {
    padding: 9px clamp(16px, 2vw, 20px) 0;
    font-size: clamp(13px, 1vw, 15px);
    color: var(--color-brown-gray);
    font-style: normal;
    font-weight: 300;
    line-height: 150%;
    background-color: var(--color-cream);
}

/* Section de outros produtos*/
.section-news.single {
    margin-bottom: clamp(40px, 4vw, 80px);
}

/* =========================================================
    MARCAS
   ========================================================= */

.brand-section {
    max-width: 910px;
    margin: clamp(28px, 2.083vw, 40px) auto 0;
}

.brand-cards {
    display: flex;
    flex-direction: column;
    gap: clamp(20px, 1.563vw, 30px);
}

.brand-card-custom {
    background-color: var(--color-off-white);
    border-radius: 18px;
    display: flex;
    align-items: center;
    padding: clamp(18px, 1.302vw, 25px);
    gap: clamp(16px, 1.198vw, 23px);
    text-align: left;
}

.brand-logo-custom {
    flex: 0 0 254px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.brand-details-custom {
    flex: 1;
    padding: 10px 0;
}

.brand-title {
    color: #0A1D38;
    font-size: clamp(16px, 0.99vw, 19px);
    font-style: normal;
    font-weight: 600;
    line-height: 76.552%;
    margin-bottom: 15px;
}

.brand-description {
    color: #6A6352;
    font-size: clamp(13px, 0.78125vw, 15px);
    font-style: normal;
    font-weight: 300;
    line-height: 170%;
    margin-bottom: 20px;
}

.brand-categories-custom {
    margin-bottom: 20px;
}

.category-label-custom {
    color: #8D887D;
    font-size: clamp(11px, 0.62vw, 12px);
    font-style: normal;
    font-weight: 500;
    line-height: 121.207%;
    margin-bottom: 10px;
}

.categories-list-custom {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.category-item-custom {
    background-color: var(--color-cream);
    padding: 5px 8px;
    border-radius: 8px;
    color: var(--color-brown-gray);
    font-family: "Open Sans", sans-serif;
    font-size: clamp(10px, 0.57vw, 11px);
    font-style: normal;
    font-weight: 400;
    line-height: 181.818%;
    text-transform: uppercase;
}

.product-quantity-custom {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 10px;
}

.product-quantity-custom span {
    color: #6A6352;
    font-size: clamp(12px, 0.68vw, 13px);
    font-style: normal;
    font-weight: 300;
    line-height: 111.883%;
}

.product-quantity-custom span strong {
    font-weight: 500;
    color: var(--black);
}

.view-products-btn-custom {
    color: #8D887D;
    font-size: clamp(14px, 0.781vw, 15px);
    font-style: normal;
    font-weight: 500;
    line-height: 140%;
}

.view-products-btn-custom::after {
    content: '→';
    transition: transform 0.2s ease;
    display: inline-block;
}

.view-products-btn-custom:hover::after {
    transform: scale(1.25);
}

/* =========================================================
   QUEM SOMOS — ABOUT
   ========================================================= */
.section-about {
    max-width: 1380px;
    margin: clamp(24px, 6.25vw, 120px) auto;
    display: grid;
    grid-template-columns: 56.7% 1fr;
    gap: 5%;
    align-items: center;
}

.about-images {
    display: flex;
    align-items: center;
    gap: 15px
}

.about-img {
    overflow: hidden;
    flex: 1;
}

.about-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.about-img--bottom {
    animation: toLeft 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
    z-index: 1;
}

.about-img--middle {
    z-index: 2;
}

.about-img--top {
    animation: toRight 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
    z-index: 3;
}

@keyframes toLeft {
    0% {
        transform: translateX(calc(100% + 15px));
    }

    100% {
        transform: translateX(0);
    }
}

@keyframes toRight {
    0% {
        transform: translateX(calc(-100% - 15px));
    }

    100% {
        transform: translateX(0);
    }
}

.about-content {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.about-text--highlight {
    color: var(--color-navy-dark);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(20px, 1.25vw, 24px);
    font-style: normal;
    font-weight: 700;
    line-height: 130%;
    letter-spacing: -0.96px;
    max-width: 491px;
}

.about-text {
    color: var(--color-olive-dark);
    font-size: clamp(15px, 0.89vw, 17px);
    font-style: normal;
    font-weight: 300;
    line-height: 164.706%;
    max-width: 517px;
}

/* How it works */
.how-it-works {
    border-bottom: 1px solid #CDC7B7;
}

.how-it-works_container {
    margin: clamp(24px, 6.25vw, 120px) auto clamp(24px, 4.95vw, 95px);
    max-width: 1340px;
}

.how-it-works__title {
    margin-bottom: clamp(12px, 1.56vw, 30px);
    display: flex;
    justify-content: center;
}

.how-it-works__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.card {
    display: flex;
    flex-direction: column;
}

.card__figure {
    margin: 0;
    width: 100%;
    height: auto;
    overflow: hidden;
    border-radius: 13px;
    margin-bottom: 22px;
}

.card__figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.card__title {
    color: var(--color-navy-dark);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(16px, 1.77vw, 34px);
    font-style: normal;
    font-weight: 700;
    line-height: 102%;
    letter-spacing: -1.36px;
    margin-bottom: 9px;
}

.card__desc {
    color: var(--color-brown-gray);
    font-size: clamp(14px, 0.94vw, 18px);
    font-style: normal;
    font-weight: 400;
    line-height: 140%;
    margin-bottom: 24px;
}

.card__link {
    color: #8D887D;
    font-size: clamp(13px, 0.78vw, 15px);
    font-style: normal;
    font-weight: 500;
    line-height: 140%;
    transition: color 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.card__link::after {
    content: '→';
    transition: transform 0.2s ease;
}

.card__link:hover::after {
    transform: scaleX(1.25);
}

/* Serviços */
.services-section {
    padding: clamp(40px, 5vw, 80px) 0 clamp(20px, 3vw, 35px);
}

.services-header {
    text-align: center;
    max-width: 472px;
    margin: 0 auto clamp(20px, 4vw, 40px);
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.services-title {
    color: #0A2140;
    text-align: center;
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(16px, 2vw, 22px);
    font-style: normal;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: -0.88px;
}

.services-description {
    color: var(--color-olive-dark);
    text-align: center;
    font-size: clamp(14px, 2vw, 18px);
    font-style: normal;
    font-weight: 300;
    line-height: 155.556%;
}

/* GRID */
.services-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: clamp(40px, 6vw, 100px);
    text-align: center;
    max-width: 1352px;
    margin: 0 auto clamp(40px, 6vw, 80px);
}

.services-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
}

.services-icon img {
    width: 100%;
    height: auto;
    object-fit: contain;
}

.services-text {
    color: #0A2140;
    text-align: center;
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(14px, 1.2vw, 17px);
    font-style: normal;
    font-weight: 600;
    line-height: 125%;
}

/* HIGHLIGHT BOX */
.services-highlight {
    background: #EAE7DE;
    padding: clamp(35px, 6vw, 120px) clamp(25px, 5vw, 105px);
    border-radius: 30px;
    text-align: center;
    max-width: 1640px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
}

.services-highlight-text {
    color: var(--color-navy-dark);
    text-align: center;
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(20px, 2.5vw, 32px);
    font-style: normal;
    font-weight: 600;
    line-height: 125%;
    letter-spacing: -1.28px;
    max-width: 1030px;
}

.services-highlight-subtext {
    color: var(--color-olive-dark);
    text-align: center;
    font-size: clamp(14px, 1.2vw, 18px);
    font-style: normal;
    font-weight: 300;
    line-height: 28px;
    max-width: 550px;
}

/* =========================================================
    Meus produtos
   ========================================================= */

.myproducts {
    margin: clamp(10px, 3vw, 30px) auto;
    max-width: 1780px;
}

.myproducts__container {
    display: grid;
    grid-template-columns: 66.9% 1fr;
    gap: clamp(20px, 3vw, 60px);
    align-items: start;
}

.myproducts__header {
    display: flex;
    flex-direction: column;
    margin-bottom: 10px;
    gap: 4px;
}

.myproducts__header-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}

.myproducts__title {
    color: var(--color-black-soft);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(16px, 1.5vw, 22px);
    font-style: normal;
    font-weight: 700;
    line-height: 136.364%;
}

.myproducts__subtitle {
    color: #887D5B;
    font-size: clamp(12px, 1vw, 15px);
    font-style: normal;
    font-weight: 300;
    line-height: 126.667%;
}

.myproducts__count {
    color: #101828;
    font-size: clamp(12px, 1vw, 15px);
    font-style: normal;
    font-weight: 700;
    line-height: 200%;
    white-space: nowrap;
}

.myproducts__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: clamp(10px, 2vw, 25px);
}

.myproducts-card {
    border-radius: 17px;
    border: 1px solid #D3C9AD;
    padding: clamp(12px, 2vw, 26px);
    transition: all 0.3s ease;
}

.myproducts-card:hover {
    background-color: var(--color-off-white);
    border: 1px solid transparent;
}

/* LINHA DE CIMA */
.myproducts-card__top {
    display: flex;
    align-items: flex-start;
    gap: clamp(8px, 1.5vw, 15px);
}

/* IMAGEM */
.myproducts-card__image {
    flex: 0 0 165px;
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
}

.myproducts-card__image img {
    max-height: 85%;
}

/* CONTEÚDO DIREITA */
.myproducts-card__content {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.product-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 9px;
    margin-bottom: 8px;
}

.product-header__info {
    display: flex;
    flex-direction: column;
    gap: 11px;
}

.product-remove-btn {
    width: 41px;
    height: 41px;
    background-color: transparent;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    transition: background-color 0.2s ease;
    align-self: center;
}

.product-remove-btn:hover {
    background-color: #E3DFD5;
    cursor: pointer;
}

.product-remove-btn img {
    width: 24px;
    height: 24px;
}

/* Brand */
.myproduct-brand {
    display: inline-flex;
    align-self: flex-start;
    color: var(--color-brown-gray);
    font-family: "Open Sans", sans-serif;
    font-size: clamp(10px, 0.8vw, 12px);
    font-style: normal;
    font-weight: 400;
    line-height: 166.667%;
    text-transform: uppercase;
    padding: 7px 8px;
    background-color: var(--color-off-white);
    border-radius: 8px;
    transition: all 0.3s ease;
}

.myproducts-card:hover .myproduct-brand {
    background-color: #F2F0E9;
}

/* TITLE */
.myproduct-title {
    color: var(--color-black-soft);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(16px, 1.6vw, 23px);
    font-style: normal;
    font-weight: 700;
    line-height: 86.957%;
}

/* REFS */
.myproducts-card__refs {
    font-size: clamp(10px, 0.8vw, 12px);
    color: #777;
}

/* NOTES (linha de baixo) */
.myproducts-card__notes {
    margin-top: 10px;
}

.myproducts-card__notes label {
    display: block;
    margin-bottom: 5px;
    color: #665F48;
    font-size: clamp(12px, 1vw, 14px);
    font-style: normal;
    font-weight: 500;
    line-height: 114.286%;
}

.myproducts-card__notes input {
    width: 100%;
    padding: 12px;
    border-radius: 20px;
    border: none;
    font-family: "Inter", sans-serif;
    background: #EAE7DE;
    color: #7B7154;
    font-size: clamp(11px, 0.9vw, 13px);
    font-style: normal;
    font-weight: 400;
    line-height: normal;
}

/*right column*/
.myproducts__right {
    background: #FFFDF7;
    padding: clamp(12px, 2vw, 25px) clamp(15px, 2.5vw, 30px) clamp(15px, 2.5vw, 30px);
    border-radius: 20px;
    position: sticky;
    top: 20px;
    overflow: hidden;
}

/* FORM */
.myproducts-form__header {
    position: relative;
    padding-bottom: 20px;
}

.myproducts-form__header::after {
    content: '';
    position: absolute;
    bottom: 0;
    width: calc(100% + 60px);
    height: 1px;
    background-color: #EAE7DE;
    left: -30px;
}

.myproducts-form__title {
    color: #0A0A0A;
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(16px, 1.5vw, 22px);
    font-style: normal;
    font-weight: 700;
    line-height: 136.364%;
    margin-bottom: 4px;
}

.myproducts-form__subtitle {
    color: #887D5B;
    font-size: clamp(12px, 1vw, 15px);
    font-style: normal;
    font-weight: 300;
    line-height: 126.667%;
}

.myproducts-form__form {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-top: 16px;
}

.myproducts-form__group label {
    color: #0A0A0A;
    font-size: clamp(12px, 1vw, 14px);
    font-style: normal;
    font-weight: 700;
    line-height: 142.857%;
    margin-bottom: 5px;
    display: block;
    cursor: pointer;
}

.myproducts-form__group input,
.myproducts-form__group textarea {
    width: 100%;
    padding: 14px 20px;
    border-radius: 56px;
    border: 1px solid #E5DDC9;
    outline: none;
    background-color: transparent;
    color: #555147;
    font-size: clamp(12px, 1vw, 14px);
    font-family: "Inter", sans-serif;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    transition: all 0.2s ease;
}

.myproducts-form__group textarea {
    min-height: 131px;
    resize: none;
    padding: 20px;
    border-radius: 25px;
}

/* Hover - só muda a cor da borda */
.myproducts-form__group input:hover,
.myproducts-form__group textarea:hover {
    border-color: transparent;
    background: #F5F1E6;
}

/* Focus - quando clicas/ativas o campo */
.myproducts-form__group input:focus,
.myproducts-form__group textarea:focus {
    border: 1px solid #EBE3CE;
}

/* Placeholder apenas no estado focus */
.myproducts-form__group input:focus::placeholder,
.myproducts-form__group textarea:focus::placeholder {
    color: #AEA180;
}

/* Focus E com texto inserido */
.myproducts-form__group input:not(:placeholder-shown),
.myproducts-form__group textarea:not(:placeholder-shown) {
    border-color: transparent;
    background: #F5F1E6;
}

/* CHECKBOX */
.myproducts-form__checkbox {
    font-size: 12px;
    display: flex;
    gap: 10px;
    align-items: flex-start;
}

/* Estilizar o checkbox */
.myproducts-form__checkbox input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    border-radius: 4px;
    border: 1.5px solid #D3C9AD;
    cursor: pointer;
    flex-shrink: 0;
    transition: all 0.2s ease;
    position: relative;
    margin-top: 0;
}

.myproducts-form__checkbox input[type="checkbox"]:checked {
    background-color: #0A1D38;
    border-color: #0A1D38;
}

.myproducts-form__checkbox input[type="checkbox"]:checked::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 10px;
    height: 10px;
    background-image: url('assets/icons/check.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}

/* Hover no checkbox */
.myproducts-form__checkbox input[type="checkbox"]:hover:not(:checked) {
    background-color: #E8E4DB;
}

/* Label */
.myproducts-form__checkbox label {
    color: #887D5B;
    font-size: clamp(11px, 0.9vw, 13px);
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
    cursor: pointer;
    user-select: none;
}

/* Links dentro do label */
.myproducts-form__checkbox label a {
    color: #887D5B;
    font-size: clamp(11px, 0.9vw, 13px);
    font-style: normal;
    font-weight: 700;
    line-height: 150%;
    transition: color 0.2s ease;
}

.myproducts-form__checkbox label a:hover {
    color: var(--color-orange-soft);
}

/* BUTTON */
#place_order {
    background: #003244;
    color: var(--white);
    padding: clamp(10px, 2vw, 15px);
    border-radius: 75px;
    border: none;
    cursor: pointer;
    font-size: clamp(12px, 1.2vw, 17px);
    font-style: normal;
    font-weight: 600;
    line-height: 140%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 17px;
    transition: background-color 0.2s ease;
    width: 100%;
}

#place_order::before {
    content: '';
    display: inline-block;
    width: 20px;
    height: 20px;
    background-image: url('assets/icons/send.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    transition: transform 0.3s ease;
}

#place_order:hover {
    background: #002736;
}

#place_order:hover::before {
    transform: translate(10px, -3px);
}

/* =========================================================
    CONTACTOS
   ========================================================= */

.banner-contacts {
    position: relative;
    overflow: visible;
}

.banner-contacts .banner-content {
    max-width: 571px;
}

.banner-contacts .banner-title {
    color: var(--color-cream);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(28px, 3vw, 48px);
    font-style: normal;
    font-weight: 700;
    line-height: 98%;
    letter-spacing: -0.96px;
}

.banner-contacts .banner-desc {
    color: #E5DFD3;
    font-size: clamp(14px, 1.3vw, 18px);
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
}

.banner-contacts .banner-figure {
    position: absolute;
    right: 1.1%;
    bottom: 14%;
    margin: 0;
    padding: 0;
    pointer-events: none;
    display: inline-block;
    width: auto;
    height: auto;
}

.banner-contacts .banner-figure img {
    display: block;
    max-width: none;
    width: auto;
    height: auto;
}

.section-contact {
    max-width: 1840px;
    margin: clamp(10px, 2vw, 16px) auto clamp(20px, 4vw, 40px);
    display: grid;
    grid-template-columns: 30.6% 64.15%;
    gap: 5.3%;
    align-items: center;
}

/* Info */
.contact-info {
    display: flex;
    flex-direction: column;
    margin-left: clamp(16px, 3vw, 40px);
    gap: clamp(10px, 2vw, 20px);
}

.contact-item {
    padding: 0 clamp(12px, 2vw, 20px) clamp(12px, 2vw, 20px);
    border-bottom: 1px solid #C6B995;
}

.contact-item-label {
    display: block;
    color: var(--color-orange-soft);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(13px, 1.1vw, 16px);
    font-style: normal;
    font-weight: 700;
    line-height: 98%;
    letter-spacing: -0.32px;
    margin-bottom: 3px;
}

.contact-item-content {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 9px;
}

.contact-item-value {
    display: block;
    color: #003447;
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(15px, 1.4vw, 20px);
    font-style: normal;
    font-weight: 600;
    line-height: 140%;
    margin-bottom: 3px;
}

.contact-item-value span {
    display: block;
}

.contact-item-note {
    color: #A19676;
    font-size: clamp(13px, 1.1vw, 16px);
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
}

.contact-copy-btn {
    width: clamp(24px, 4vw, 36px);
    height: clamp(24px, 4vw, 36px);
    background: none;
    border: none;
    cursor: pointer;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.2s ease;
}

.contact-copy-btn:hover {
    opacity: 0.6;
}

.contact-copy-btn::before {
    content: '';
    width: clamp(20px, 3vw, 32px);
    height: clamp(20px, 3vw, 32px);
    background-image: url('assets/icons/clipboard.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    display: block;
}

/* Formulário */
.contact-form-wrap {
    background-color: var(--color-blue-deep);
    border-radius: 20px;
    padding: clamp(16px, 2.5vw, 32px) clamp(18px, 2.8vw, 36px) clamp(18px, 2.8vw, 36px) clamp(20px, 3vw, 43px);
}

.contact-form-title {
    color: var(--color-orange-soft);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(16px, 1.6vw, 23px);
    font-style: normal;
    font-weight: 600;
    line-height: 140%;
    margin-bottom: 10px;
}

.contact-form {
    display: flex;
    flex-direction: column;
}

.contact-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
}

.form-field {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.form-field label {
    font-size: clamp(12px, 1vw, 14px);
    color: var(--color-cream);
    font-style: normal;
    font-weight: 700;
    line-height: 20px;
}

.form-field label span {
    color: #769FAE;
    font-size: clamp(11px, 0.9vw, 13px);
    font-style: normal;
    font-weight: 400;
    line-height: 19.5px;
}

.contact-message {
    margin-top: 15px;
}

.form-field input,
.form-field textarea {
    background: transparent;
    border: 1px solid #19556B;
    border-radius: 56px;
    padding: clamp(10px, 1.2vw, 14px) clamp(16px, 1.5vw, 20px);
    font-family: "Inter", sans-serif;
    color: #769FAE;
    font-size: clamp(12px, 1vw, 14px);
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    outline: none;
    transition: border-color 0.2s ease;
    width: 100%;
}

.form-field textarea {
    border-radius: 25px;
    resize: none;
    min-height: clamp(100px, 15vh, 133px);
    padding: clamp(16px, 1.5vw, 20px);
}

/* Hover nos campos */
.form-field input:hover,
.form-field textarea:hover {
    border-color: rgba(255, 255, 255, 0.4);
    background-color: rgba(255, 255, 255, 0.03);
}

.form-field input::placeholder,
.form-field textarea::placeholder {
    color: rgba(255, 255, 255, 0.4);
}

.form-field input:focus,
.form-field textarea:focus {
    border-color: rgba(255, 255, 255, 0.6);
}

.form-field input:not(:placeholder-shown),
.form-field textarea:not(:placeholder-shown) {
    border-color: rgba(255, 255, 255, 0.6);
}

/* Checkbox */
.form-field--checkbox {
    flex-direction: row;
    align-items: center;
    margin: 8px 0;
}

.form-checkbox {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    font-size: clamp(12px, 1vw, 14px);
    color: rgba(255, 255, 255, 0.7);
}

.form-checkbox input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 21px;
    height: 21px;
    border-radius: 5px;
    border: 1px solid #19556B;
    cursor: pointer;
    flex-shrink: 0;
    transition: all 0.2s ease;
    position: relative;
    padding: 0;
}

.form-checkbox input[type="checkbox"]:checked {
    background-color: var(--color-orange-soft);
    border-color: var(--color-orange-soft);
}

.form-checkbox input[type="checkbox"]:checked::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 10px;
    height: 10px;
    background-image: url('assets/icons/check.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}

.form-checkbox a {
    font-weight: 700;
}

.form-checkbox a:hover {
    color: var(--color-orange-soft);
}

/* Submit */
.contact-submit {
    max-width: 458px;
    width: 100%;
    background: #044760;
    color: var(--white);
    padding: clamp(10px, 1.5vw, 15px) clamp(20px, 5vw, 50px);
    border-radius: 100px;
    border: none;
    cursor: pointer;
    font-family: "Inter", sans-serif;
    font-size: clamp(14px, 1.2vw, 17px);
    font-style: normal;
    font-weight: 600;
    line-height: 140%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: clamp(10px, 1.5vw, 17px);
    transition: background-color 0.2s ease, opacity 0.2s ease;
    align-self: flex-end;
}

.contact-submit::before {
    content: '';
    display: inline-block;
    width: 20px;
    height: 20px;
    background-image: url('assets/icons/send.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    transition: transform 0.3s ease;
}

.contact-submit:hover {
    background: #002736;
}

.contact-submit:hover::before {
    transform: translate(10px, -3px);
}

/*Animação da copia do clipboard*/
.contact-copy-btn {
    position: relative;
}

.copy-tooltip {
    position: absolute;
    top: -35px;
    left: 50%;
    transform: translateX(-50%);
    background: #003244;
    color: white;
    padding: 6px 12px;
    border-radius: 30px;
    font-size: 12px;
    font-weight: 500;
    white-space: nowrap;
    pointer-events: none;
    z-index: 10;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.copy-tooltip::after {
    content: '';
    position: absolute;
    bottom: -5px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 6px solid #003244;
}

.copy-tooltip.error {
    background: #d32f2f;
}

.copy-tooltip.error::after {
    border-top-color: #d32f2f;
}

/* =========================================================
    COMMON PAGE
   ========================================================= */
.common-container {
    max-width: 815px;
    margin: 40px auto;
    padding: clamp(80px, 7vw, 125px) 16px 0;
}

.common-title {
    color: #D1C8B0;
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(28px, 4vw, 42px);
    font-style: normal;
    font-weight: 700;
    line-height: 85%;
    letter-spacing: -1.68px;
}

.common-content {
    margin-top: clamp(16px, 2vw, 25px);
}

.common-content h2 {
    color: var(--color-navy-dark);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(16px, 2vw, 22px);
    font-style: normal;
    font-weight: 700;
    line-height: 85%;
    letter-spacing: -0.88px;
    padding: clamp(12px, 1.5vw, 15px) 0 clamp(12px, 1.5vw, 15px) 0;
}

.common-content p {
    color: var(--color-olive-dark);
    font-size: clamp(14px, 1.5vw, 17px);
    font-style: normal;
    font-weight: 300;
    line-height: 160%;
    padding-bottom: 10px;
}

.common-content ul {
    list-style: none;
    padding-left: 9px;
}

.common-content li {
    position: relative;
    padding-left: 16px;
    margin-bottom: 8px;
    color: var(--color-olive-dark);
    font-size: clamp(14px, 1.5vw, 17px);
    font-style: normal;
    font-weight: 300;
    line-height: 160%;
}

.common-content li::before {
    content: "•";
    position: absolute;
    left: 0;
    color: var(--color-olive-dark);
}

.common-content table {
    width: 100%;
    border-collapse: collapse;
    margin: 10px 0;
    display: block;
    overflow-x: auto;
}

.common-content thead th {
    text-align: left;
    overflow: hidden;
    color: var(--color-navy-dark);
    text-overflow: ellipsis;
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(12px, 3vw, 14px);
    font-style: normal;
    font-weight: 500;
    line-height: 128.571%;
    letter-spacing: -0.28px;
    padding-bottom: 18px;
    padding: 0 15px 18px;
}

.common-content thead th:first-child {
    padding-left: 0;
}

.common-content tbody td {
    padding: 9px 15px 5px 15px;
    color: #666453;
    font-size: clamp(14px, 12px + 0.5vw, 17px);
    font-style: normal;
    font-weight: 300;
    line-height: 164.706%;
    letter-spacing: -0.51px;
    border-bottom: 1px solid #B4B4B4;
}

.last-update {
    color: var(--color-olive-dark);
    font-size: clamp(13px, 3.3vw, 15px);
    font-style: normal;
    font-weight: 500;
    line-height: 150%;
    margin-top: 25px;
}


/* =========================================================
    404 PAGE
   ========================================================= */
.banner-404 {
    background-color: #003447;
    background-image: url('assets/images/logo-bg-404.webp');
    background-size: 71%;
    background-position: right 11%;
    background-repeat: no-repeat;
    min-height: calc(100vh - 131px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 clamp(20px, 5vw, 60px) clamp(20px, 5vw, 60px);
    margin-bottom: clamp(20px, 4vw, 40px);
}

.banner.banner-common.banner-404 {
    margin-bottom: clamp(20px, 4vw, 40px);
}

.banner-404__content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    max-width: 855px;
    margin: 0 auto;
}

.banner-404__gif {
    padding: 0;
    max-width: 306px;
    height: auto;
}

.banner-404__gif img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.banner-404__error {
    color: #EAE7DE;
    text-align: center;
    font-size: clamp(13px, 1.1vw, 16px);
    font-style: normal;
    font-weight: 500;
    line-height: 85%;
    letter-spacing: 0.16px;
    text-transform: uppercase;
    margin-bottom: 10px;
    margin-top: -45px;
}

.banner-404__title {
    color: var(--color-orange-soft);
    text-align: center;
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(28px, 4vw, 52px);
    font-style: normal;
    font-weight: 700;
    line-height: 105%;
    letter-spacing: -1.04px;
    margin-bottom: 10px;
    text-wrap: balance;
}

.banner-404__desc {
    color: #F6EBE3;
    text-align: center;
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(16px, 2vw, 24px);
    font-style: normal;
    font-weight: 400;
    line-height: 105%;
    letter-spacing: -0.48px;
    margin-bottom: 25px;
}

.banner-404__btn {
    display: inline-flex;
    padding: clamp(12px, 1.2vw, 16px) clamp(14px, 2vw, 24px);
    background-color: #EAE7DE;
    color: var(--color-navy-dark);
    font-size: clamp(14px, 1.2vw, 17px);
    font-style: normal;
    font-weight: 600;
    line-height: 140%;
    border-radius: 39px;
    transition: all 0.2s ease;
    align-items: center;
    gap: 6px;
}

.banner-404__btn:hover {
    background-color: #e08a4e;
}

.banner-404__btn::after {
    content: '→';
    transition: transform 0.2s ease;
}

.banner-404__btn:hover::after {
    transform: scaleX(1.25);
}
/* =========================================================
 	WOOCOMMERCE FIX
 ==========================================================*/
.woocommerce-notices-wrapper {
    display: none;
}
/* ==========================================================
   Checkout / Pedido de Informação - compatibilidade WooCommerce
   Faz os campos WooCommerce herdarem o layout do HTML original.
   ========================================================== */

.myproducts-form__form #customer_details,
.myproducts-form__form .checkout-customer-details,
.myproducts-form__form .woocommerce-billing-fields,
.myproducts-form__form .woocommerce-additional-fields,
.myproducts-form__form .woocommerce-billing-fields__field-wrapper,
.myproducts-form__form .woocommerce-additional-fields__field-wrapper,
.myproducts-form__form .wcrl-extra-fields {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.myproducts-form__form .woocommerce-shipping-fields {
    display: none;
}

.myproducts-form .form-row {
    float: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.myproducts-form .form-row label,
.myproducts-form .woocommerce-billing-fields label,
.myproducts-form .woocommerce-additional-fields label {
    color: #0A0A0A;
    font-size: clamp(12px, 1vw, 14px);
    font-style: normal;
    font-weight: 700;
    line-height: 142.857%;
    margin: 0 0 5px;
    display: block;
    cursor: pointer;
}

.myproducts-form .woocommerce-input-wrapper {
    display: block;
    width: 100%;
}

.myproducts-form input[type="text"],
.myproducts-form input[type="email"],
.myproducts-form input[type="tel"],
.myproducts-form input[type="number"],
.myproducts-form input[type="password"],
.myproducts-form select,
.myproducts-form textarea {
    width: 100%;
    min-height: 48px;
    padding: 14px 20px;
    border-radius: 56px;
    border: 1px solid #E5DDC9;
    outline: none;
    background-color: transparent;
    color: #555147;
    font-size: clamp(12px, 1vw, 14px);
    font-family: "Inter", sans-serif;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    box-shadow: none;
    transition: all 0.2s ease;
}

.myproducts-form textarea,
.myproducts-form #order_comments {
    min-height: 131px;
    resize: none;
    padding: 20px;
    border-radius: 25px;
}

.myproducts-form input:hover,
.myproducts-form select:hover,
.myproducts-form textarea:hover {
    border-color: transparent;
    background: #F5F1E6;
}

.myproducts-form input:focus,
.myproducts-form select:focus,
.myproducts-form textarea:focus {
    border: 1px solid #EBE3CE;
    background: #F5F1E6;
    box-shadow: none;
}

.myproducts-form input:focus::placeholder,
.myproducts-form textarea:focus::placeholder {
    color: #AEA180;
}

.myproducts-form input:not(:placeholder-shown),
.myproducts-form textarea:not(:placeholder-shown) {
    border-color: transparent;
    background: #F5F1E6;
}

/* Select2 do país WooCommerce */
.myproducts-form .select2-container {
    width: 100% !important;
}

.myproducts-form .select2-container--default .select2-selection--single {
    height: 48px;
    border-radius: 56px;
    border: 1px solid #E5DDC9;
    background-color: transparent;
    display: flex;
    align-items: center;
    padding: 0 20px;
}

.myproducts-form .select2-container--default .select2-selection--single .select2-selection__rendered {
    color: #555147;
    font-size: clamp(12px, 1vw, 14px);
    line-height: normal;
    padding: 0;
}

.myproducts-form .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 48px;
    right: 16px;
}

/* Checkbox da política de privacidade */
.myproducts-form #wcrl_privacy_field {
    margin-top: 0 !important;
}

.myproducts-form #wcrl_privacy_field .woocommerce-input-wrapper {
    display: block;
}

.myproducts-form #wcrl_privacy_field label.checkbox {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: #887D5B;
    font-size: clamp(11px, 0.9vw, 13px);
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
    cursor: pointer;
    user-select: none;
}

.myproducts-form input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 18px;
    min-width: 18px;
    height: 18px;
    min-height: 18px;
    padding: 0;
    border-radius: 4px;
    border: 1.5px solid #D3C9AD;
    background: transparent;
    cursor: pointer;
    flex-shrink: 0;
    transition: all 0.2s ease;
    position: relative;
    margin: 0;
}

.myproducts-form input[type="checkbox"]:checked {
    background-color: #0A1D38;
    border-color: #0A1D38;
}

.myproducts-form input[type="checkbox"]:checked::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 10px;
    height: 10px;
    transform: translate(-50%, -50%);
    background-image: url('assets/icons/check.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}

.myproducts-form input[type="checkbox"]:hover:not(:checked) {
    background-color: #E8E4DB;
}

.myproducts-form #wcrl_privacy_field label a,
.myproducts-form .privacy-link,
.myproducts-form .terms-link {
    color: #887D5B;
    font-size: clamp(11px, 0.9vw, 13px);
    font-weight: 700;
    text-decoration: none;
}

.myproducts-form #wcrl_privacy_field label a:hover,
.myproducts-form .privacy-link:hover,
.myproducts-form .terms-link:hover {
    color: var(--color-orange-soft);
}

/* Honeypot do plugin */
.myproducts-form .wcrl-honeypot {
    display: none !important;
}

/* Área de submissão do WooCommerce */
.checkout-submit-area {
    margin-top: 0;
}

.checkout-submit-area #payment,
.myproducts-form #payment {
    background: transparent;
    margin: 0;
    padding: 0;
    border: 0;
}

.checkout-submit-area #payment .place-order {
    margin: 0;
    padding: 0;
}

.checkout-submit-area #payment ul.payment_methods {
    display: none;
}

.checkout-submit-area #place_order {
    width: 100%;
    background: #003244;
    color: var(--white);
    padding: clamp(10px, 2vw, 15px);
    border-radius: 75px;
    border: none;
    cursor: pointer;
    font-size: clamp(12px, 1.2vw, 17px);
    font-style: normal;
    font-weight: 600;
    line-height: 140%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 17px;
    transition: background-color 0.2s ease;
    box-shadow: none;
}

.checkout-submit-area #place_order::before {
    content: '';
    display: inline-block;
    width: 20px;
    height: 20px;
    background-image: url('assets/icons/send.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    transition: transform 0.3s ease;
}

.checkout-submit-area #place_order:hover {
    background: #002736;
}

.checkout-submit-area #place_order:hover::before {
    transform: translate(10px, -3px);
}
/* ==========================================================
   WooCommerce Thank You / Pedido recebido
   ========================================================== */
.woocommerce-order-received .site-header{ 
	display: none;
}
.asousa-thankyou {
    width: min(100%, 1480px);
    margin: clamp(40px, 5vw, 80px) auto;
    padding: 0 clamp(18px, 3vw, 40px);
}

.asousa-thankyou__hero {
    position: relative;
    overflow: hidden;
    border-radius: 32px;
    background: #00566B;
    color: #fff;
    padding: clamp(36px, 6vw, 76px);
    margin-bottom: clamp(22px, 3vw, 40px);
}

.asousa-thankyou__hero::after {
    content: '';
    position: absolute;
    right: -80px;
    bottom: -110px;
    width: 360px;
    height: 360px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.08);
    pointer-events: none;
}

.asousa-thankyou__hero--failed {
    background: #8A3A2A;
}

.asousa-thankyou__icon {
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background: #FF9B54;
    position: relative;
    margin-bottom: 24px;
}

.asousa-thankyou__icon::before {
    content: '';
    position: absolute;
    left: 18px;
    top: 14px;
    width: 16px;
    height: 24px;
    border-right: 4px solid #fff;
    border-bottom: 4px solid #fff;
    transform: rotate(45deg);
}

.asousa-thankyou__hero--failed .asousa-thankyou__icon::before {
    left: 16px;
    top: 25px;
    width: 24px;
    height: 4px;
    border: 0;
    background: #fff;
    transform: rotate(45deg);
}

.asousa-thankyou__hero--failed .asousa-thankyou__icon::after {
    content: '';
    position: absolute;
    left: 16px;
    top: 25px;
    width: 24px;
    height: 4px;
    background: #fff;
    transform: rotate(-45deg);
}

.asousa-thankyou__eyebrow {
    margin: 0 0 10px;
    color: #FF9B54;
    font-size: clamp(12px, 1vw, 14px);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.asousa-thankyou__title {
    margin: 0;
    max-width: 820px;
    color: #fff;
    font-size: clamp(34px, 5vw, 72px);
    font-weight: 800;
    line-height: 0.95;
    letter-spacing: -0.04em;
}

.asousa-thankyou__text {
    max-width: 760px;
    margin: 22px 0 0;
    color: rgba(255, 255, 255, 0.88);
    font-size: clamp(15px, 1.2vw, 18px);
    line-height: 1.65;
}

.asousa-thankyou__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 30px;
}

.asousa-thankyou__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    padding: 14px 26px;
    border-radius: 999px;
    background: #FF9B54;
    color: #061B2F;
    font-size: 14px;
    font-weight: 800;
    text-decoration: none;
    transition: transform 0.2s ease, background-color 0.2s ease;
}

.asousa-thankyou__btn:hover {
    transform: translateY(-2px);
    background: #ffad71;
}

.asousa-thankyou__btn--secondary {
    background: rgba(255, 255, 255, 0.16);
    color: #fff;
}

.asousa-thankyou__btn--secondary:hover {
    background: rgba(255, 255, 255, 0.24);
}

.asousa-thankyou__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(18px, 2vw, 28px);
    margin-bottom: clamp(18px, 2vw, 28px);
}

.asousa-thankyou__card {
    border-radius: 26px;
    background: #F5F1E6;
    padding: clamp(22px, 3vw, 36px);
}

.asousa-thankyou__card + .asousa-thankyou__card {
    margin-top: clamp(18px, 2vw, 28px);
}

.asousa-thankyou__card h2 {
    margin: 0 0 20px;
    color: #061B2F;
    font-size: clamp(19px, 1.5vw, 26px);
    font-weight: 800;
    letter-spacing: -0.03em;
}

.asousa-thankyou__meta {
    display: grid;
    gap: 16px;
    margin: 0;
}

.asousa-thankyou__meta div {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(6, 27, 47, 0.08);
}

.asousa-thankyou__meta div:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.asousa-thankyou__meta dt {
    color: #887D5B;
    font-size: 13px;
    font-weight: 700;
}

.asousa-thankyou__meta dd {
    margin: 0;
    color: #061B2F;
    font-size: 14px;
    font-weight: 800;
    text-align: right;
}

.asousa-thankyou__contact p,
.asousa-thankyou__contact address {
    margin: 0 0 10px;
    color: #061B2F;
    font-size: 15px;
    line-height: 1.55;
    font-style: normal;
}

.asousa-thankyou__contact address span {
    display: block;
}

.asousa-thankyou__contact a {
    color: #061B2F;
    text-decoration: none;
    font-weight: 700;
}

.asousa-thankyou__section-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 20px;
}

.asousa-thankyou__section-header h2 {
    margin-bottom: 0;
}

.asousa-thankyou__section-header span {
    color: #887D5B;
    font-size: 14px;
    font-weight: 800;
}

.asousa-thankyou__table-wrap {
    overflow-x: auto;
}

.asousa-thankyou__table {
    width: 100%;
    border-collapse: collapse;
}

.asousa-thankyou__table th {
    padding: 0 0 14px;
    color: #887D5B;
    font-size: 12px;
    font-weight: 800;
    text-align: left;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border-bottom: 1px solid rgba(6, 27, 47, 0.08);
}

.asousa-thankyou__table th:last-child,
.asousa-thankyou__table td:last-child {
    width: 140px;
    text-align: right;
}

.asousa-thankyou__table td {
    padding: 18px 0;
    border-bottom: 1px solid rgba(6, 27, 47, 0.08);
    color: #061B2F;
    vertical-align: middle;
}

.asousa-thankyou__table tr:last-child td {
    border-bottom: 0;
}

.asousa-thankyou__product {
    display: flex;
    align-items: center;
    gap: 16px;
}

.asousa-thankyou__product figure {
    width: 72px;
    height: 72px;
    margin: 0;
    border-radius: 16px;
    background: #fff;
    overflow: hidden;
    flex: 0 0 72px;
}

.asousa-thankyou__product img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.asousa-thankyou__product strong {
    display: block;
    color: #061B2F;
    font-size: 15px;
    font-weight: 800;
}

.asousa-thankyou__product small {
    display: block;
    margin-top: 4px;
    color: #887D5B;
    font-size: 12px;
    font-weight: 600;
}

.asousa-thankyou__note {
    color: #061B2F;
    font-size: 15px;
    line-height: 1.65;
}

.asousa-thankyou__note p {
    margin: 0;
}

/* Esconde resíduos do WooCommerce caso algum plugin reimprima totais */
.asousa-thankyou .woocommerce-order-overview,
.asousa-thankyou .woocommerce-table--order-details,
.asousa-thankyou .woocommerce-order-details,
.asousa-thankyou .woocommerce-customer-details,
.asousa-thankyou .order_details,
.asousa-thankyou tfoot {
    display: none !important;
}

@media (max-width: 900px) {
    .asousa-thankyou__grid {
        grid-template-columns: 1fr;
    }

    .asousa-thankyou__meta div {
        display: block;
    }

    .asousa-thankyou__meta dd {
        margin-top: 4px;
        text-align: left;
    }

    .asousa-thankyou__section-header {
        display: block;
    }

    .asousa-thankyou__section-header span {
        display: block;
        margin-top: 6px;
    }
}

@media (max-width: 560px) {
    .asousa-thankyou {
        padding-inline: 14px;
    }

    .asousa-thankyou__hero,
    .asousa-thankyou__card {
        border-radius: 22px;
    }

    .asousa-thankyou__product {
        align-items: flex-start;
    }

    .asousa-thankyou__product figure {
        width: 58px;
        height: 58px;
        flex-basis: 58px;
    }

    .asousa-thankyou__table th:last-child,
    .asousa-thankyou__table td:last-child {
        width: 90px;
    }
}
/* =========================================================
    RESPONSIVO
   ========================================================= */
@media screen and (min-width: 1981px) {}

@media screen and (max-width: 1880px) {

    .hero,
    .banner.banner--catalog,
    .banner.banner--single,
    .banner-common {
        max-width: 100%;
        margin: 40px 20px 0;
        width: calc(100% - 40px);
    }

    .catalog-page {
        max-width: 100%;
        margin: 0 auto;
        padding: clamp(20px, 2vw, 30px) clamp(16px, 2.5vw, 30px) clamp(40px, 4vw, 60px);
    }

    .product-info {
        padding: 0 clamp(16px, 2.5vw, 30px);
    }

    .section-news,
    .section-brands,
    .section-how,
    .brand-section,
    .section-about,
    .how-it-works,
    .services-section,
    .myproducts,
    .section-contact {
        padding-left: 20px;
        padding-right: 20px;
    }
}

@media screen and (max-width: 1680px) {}

@media screen and (max-width: 1500px) {}

@media screen and (max-width: 1440px) {

    .section-cta {
        margin: clamp(40px, 4.17vw, 80px) clamp(16px, 2.5vw, 30px);
    }

    .footer-corner.corner-right {
        width: 70px;
        height: 70px;
    }

    .back-to-top-btn::before {
        width: 50px;
        height: 50px;
    }

    .product-details {
        min-height: auto;
    }

    .header-wrapped::before {
        right: -69px;
    }

}

@media screen and (max-width: 1420px) {
    .myproducts-card__image {
        flex: 0 0 140px;
    }

    .quantity-value {
        width: 55px;
    }

    .product-quantity-controls {
        padding: 5px 5px;
    }
}

@media screen and (max-width: 1350px) {
    .footer-main {
        grid-template-columns: 27% 48% 1fr;
    }

    .myproducts-card__top {
        display: flex;
        align-items: center;
        flex-direction: column;
        gap: 0;
    }

    .myproducts-card__content {
        width: 100%;
    }

    .myproducts-card__image {
        max-height: 200px;
    }

    .myproducts__container {
        display: grid;
        grid-template-columns: 60.9% 1fr;
    }

    .myproducts-card {
        position: relative;
    }

    .product-remove-btn {
        position: absolute;
        top: 20px;
        right: 20px;
    }

    .banner-404 {
        background-size: 75%;
        background-position: right 11%;
    }
}

@media screen and (max-width: 1240px) {
    .products-grid {
        gap: clamp(20px, 2vw, 40px);
    }

    .brands-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .section-how {
        grid-template-columns: 1fr 1fr;
    }
}

@media screen and (max-width: 1200px) {
    .catalog-layout {
        grid-template-columns: 22% 1fr;
        gap: 12px;
    }

    .products-grid.products-grid--catalog {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
    }


    .product-details-card {
        display: grid;
        grid-template-columns: 45% 1fr;
        column-gap: 30px;
        align-items: start;
    }

    .gallery {
        display: flex;
        flex-direction: column;
        gap: 15px;
        overflow: hidden;
    }

    .main-image-wrap {
        order: 1;
        width: 100%;
        min-height: unset;
    }

    .gallery.no-thumbs {
        margin-left: 0;
    }

    .thumbs {
        order: 2;
        display: flex;
        flex-direction: row;
        gap: 10px;
        overflow-x: auto;
        overflow-y: hidden;
        padding: 5px 0;
        min-height: 65px;
    }

    .thumbs img {
        height: 100%;
    }

    .thumbs figure {
        flex: 0 0 85px;
    }

    .product-info-panel {
        max-width: 100%;
    }
}

@media screen and (max-width: 1160px) {
    .footer-brand .footer-logo img {
        max-width: 190px;
        height: auto;
        margin-left: 48px;
    }

    .catalog-search {
        padding: clamp(12px, 1.2vw, 16px) 36px;
    }

    .section-about {
        grid-template-columns: 48.7% 1fr;
    }

    .banner-404 {
        background-position: right 0%;
    }
}

@media screen and (max-width: 1024px) {

    /* Header */
    .site-nav .menu {
        gap: clamp(16px, 2vw, 30px);
    }

    /* Hero */
    .hero {
        min-height: 70vh;
    }

    .hero-right {
        max-width: 35%;
    }

    /* Novidades */
    .products-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .product-img img {
        max-height: 150px;
    }

    /* Marcas */
    .brands-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    /* Como Funciona */
    .section-how {
        grid-template-columns: 1fr;
    }

    .section-how-img {
        max-width: 600px;
        margin: 0 auto;
    }

    /* Footer */
    .footer-main {
        grid-template-columns: 36.2% 1fr;
        grid-template-rows: auto auto;
    }

    .footer-brand {
        grid-column: 1;
        grid-row: 1;
    }

    .footer-nav {
        grid-column: 2;
        grid-row: span 2;
        align-self: self-end;
    }

    .footer-contact {
        grid-column: 1;
        grid-row: 2;
    }

    .footer-nav>.menu-footer {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }

    .footer-nav>.menu-footer>.menu-item:last-child {
        grid-column: span 2;
    }

    .catalog-layout {
        grid-template-columns: 25% 1fr;
    }

    .products-grid--catalog {
        gap: 12px;
    }

    .catalog-filters {
        padding: clamp(12px, 1.5vw, 16px) clamp(10px, 1.2vw, 14px);
    }

    .filter-group-list {
        gap: 6px;
    }

    section.banner.banner--single>.hero-corner.hero-corner--empty {
        display: none;
    }

    .section-contact {
        grid-template-columns: 300px 1fr;
    }

    .banner-404 {
        background-size: 90%;
        background-position: 210px 0%;
    }
}

@media screen and (max-width: 960px) {
    .section-about {
        grid-template-columns: 41.7% 1fr;
    }

    .how-it-works .how-it-works__grid,
    .services-section .services-grid {
        display: flex;
        overflow-x: auto;
        scroll-behavior: smooth;
        scrollbar-width: none;
        -ms-overflow-style: none;
    }

    .how-it-works .how-it-works__grid::-webkit-scrollbar,
    .services-section .services-grid::-webkit-scrollbar {
        display: none;
    }

    .how-it-works .card {
        flex: 0 0 40%;
        flex-shrink: 0;
        min-width: 150px;
    }

    .how-it-works__grid,
    .services-section .services-grid {
        margin-left: -20px;
        margin-right: -20px;
    }

    .how-it-works .card:first-of-type,
    .services-item:first-of-type {
        margin-left: 20px;
    }

    .how-it-works .card:last-of-type,
    .services-item:last-of-type {
        margin-right: 20px;
    }

    .how-it-works {
        margin-top: 50px;
    }

    .how-it-works .card__figure {
        max-height: 300px;
        aspect-ratio: 1;
    }

    .services-section .services-item {
        flex-shrink: 0;
        flex: 0 0 24%;
    }
}

@media screen and (max-width: 950px) {
    .catalog-layout {
        grid-template-columns: 29% 1fr;
    }

    .products-grid.products-grid--catalog {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
    }

    .myproducts__container {
        display: grid;
        grid-template-columns: 1fr;
    }

    .myproducts__grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: clamp(10px, 2vw, 25px);
    }

    .myproducts-form__form {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 16px;
        margin-top: 16px;
    }

    .myproducts-form__group-textarea {
        grid-column: span 2;
    }

    #place_order {
        grid-column: span 2;
    }
}

@media screen and (max-width: 900px) {
    .header-wrapped::before {
        right: -68px;
        border-top-right-radius: 16px;
    }

    .hero-corner::before {
        left: -39px;
        border-top-right-radius: 13px;
    }

    /* Mostra hamburguer */
    .hamburger-btn {
        display: flex;
    }

    .header-wrapped::after {
        left: -16px;
        bottom: -48px;
    }

    /* Esconde nav original */
    .site-nav {
        position: fixed;
        top: 0;
        left: 25%;
        right: 0;
        bottom: 0;
        background-color: var(--color-blue-deep);
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 32px;
        transform: translateX(100%);
        transition: transform 0.4s ease;
        z-index: 150;
    }

    .nav-cta {
        margin-left: 0;
    }

    .site-nav.is-open {
        transform: translateX(0);
    }

    /* Menu vertical */
    .site-nav .menu {
        flex-direction: column;
        align-items: center;
        gap: 24px;
        margin-left: 0;
    }

    .site-nav .menu-item a {
        font-size: clamp(20px, 5vw, 32px);
        color: var(--color-off-white);
    }

    .section-cta::before {
        top: 40%;
        right: -5.9%;
    }

    .banner-404 {
        background-size: 104%;
        background-position: 210px 0%;
    }
}

@media screen and (max-width: 850px) {

    /* Hero */
    .hero-content {
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-end;
        gap: 20px;
    }

    .hero-left,
    .hero-right {
        max-width: 100%;
    }

    /* CTA */
    .section-cta {
        padding: clamp(30px, 4vw, 55px) clamp(20px, 3vw, 40px);
    }

    /* Footer */
    .legal-nav .menu {
        flex-wrap: wrap;
        gap: clamp(12px, 2vw, 24px);
    }

    .banner-contacts .banner-figure {
        position: relative;
    }

    .banner-contacts .banner-figure img {
        width: 100%;
        height: 100%;
    }

    .banner-404 {
        background-size: 104%;
    }
}

@media screen and (max-width: 820px) {
    .section-about {
        grid-template-columns: 1fr;
        max-width: 650px;
    }

    .about-text,
    .about-text--highlight {
        max-width: 100%;
        text-wrap: pretty;
    }

    .myproducts__grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: clamp(10px, 2vw, 25px);
    }

    .contact-form-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 15px;
    }

    .contact-info {
        position: sticky;
        top: 20px;
    }

    .section-contact {
        align-items: flex-start;
        gap: 25px;
    }
}

@media screen and (max-width: 770px) {
    .banner.banner--catalog::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.25);
        z-index: 1;
        border-radius: 40px;
    }

    .banner-content {
        z-index: 2;
    }

    .catalog-filters-toggle {
        display: flex;
        position: absolute;
    }

    .catalog-filters {
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        width: 85%;
        max-width: 350px;
        z-index: 100;
        background-color: var(--color-off-white);
        border-radius: 0 20px 20px 0;
        padding: 25px 15px 20px;
        transform: translateX(-100%);
        transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
        overflow-y: auto;
        box-shadow: 2px 0 15px rgba(0, 0, 0, 0.1);
    }

    .catalog-filters.is-open {
        transform: translateX(0);
    }

    .catalog-filters-overlay {
        display: block;
    }

    .catalog-filters__close {
        display: flex;
    }

    .catalog-layout {
        grid-template-columns: 1fr;
        position: relative;
    }

    .catalog-search {
        margin-left: 50px;
        padding: 12px 0 12px 45px;
    }

    .products-grid.products-grid--catalog {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
    }

    /*===== PAGE DETAILS =====*/
    .product-details {
        min-height: auto;
    }

    .product-details-card {
        display: flex;
        flex-direction: column;
        gap: 25px;
        width: 100%;
    }

    /* LEFT COLUMN - GALLERY */
    .gallery {
        display: grid;
        grid-template-columns: 85px 1fr;
        gap: 15px;
        max-height: 267px;
        align-items: normal;
        width: 100%;
    }

    .main-image-wrap {
        width: 100%;
        order: 1;
        height: 100%;
        max-height: 300px;
    }

    .thumbs img {
        width: 100%;
        height: 100%;
        flex-shrink: 0;
    }

    .thumbs figure {
        flex: 0 0 43px;
    }

    .thumbs::-webkit-scrollbar {
        display: none;
    }

    .thumbs {
        order: 1;
        display: flex;
        flex-direction: column;
        overflow-x: hidden;
        overflow-y: scroll;
    }

    /* RIGHT COLUMN - INFO */
    .product-info-panel {
        order: 3;
        max-width: 100%;
        gap: 15px;
        margin-bottom: 5px;
    }

    .quantity-btn {
        width: 25px;
        height: 25px;
    }

    .product-single-desc p {
        padding: 15px 0;
    }

    .brand-logo-custom {
        flex: 0 0 180px;
        aspect-ratio: 1;
    }

    .common-content table {
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        white-space: nowrap;
        scrollbar-width: none;
        -ms-overflow-style: none;
    }

    .common-content table::-webkit-scrollbar {
        display: none;
    }

    .common-content thead,
    .common-content tbody,
    .common-content tr,
    .common-content th,
    .common-content td {
        white-space: nowrap;
    }

    .common-content th,
    .common-content td {
        display: table-cell;
    }
}

@media screen and (max-width: 740px) {
    .section-cta::before {
        top: 50%;
    }

    /* Footer */
    .footer-main {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto auto;
    }

    .footer-brand {
        grid-row: 1;
    }

    .footer-nav {
        grid-row: 2;
        align-self: self-end;
        grid-column: span 2;
    }

    .footer-contact {
        grid-column: 2;
        grid-row: 1;
        align-self: flex-end;
    }

    .footer-nav>.menu-footer {
        grid-template-columns: repeat(3, 1fr);
        gap: 20px;
        grid-row: auto;
    }

    .footer-nav>.menu-footer>.menu-item:last-child {
        grid-column: auto;
    }

    .phone-block:last-child {
        margin-bottom: 0;
    }

    .footer-brand .footer-logo {
        margin-bottom: 60px;
    }

    .product-tag {
        padding: 5px 8px;
    }
}

@media screen and (max-width: 700px) {

    .banner-common .banner-desc {
        font-size: clamp(14px, 1.2vw, 18px);
        font-style: normal;
        font-weight: 400;
        line-height: 150%;
        max-width: 330px;
    }

    .services-section .services-grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        overflow: visible;
    }

    .services-section .services-item {
        flex: unset;
    }

    .services-section .services-grid {
        margin-left: 0;
        margin-right: 0;
    }
}

@media screen and (max-width: 680px) {
    .section-contact {
        grid-template-columns: 1fr;
    }

    .contact-info {
        position: static;
        margin-left: 0;
    }

    .contact-submit {
        max-width: 100%;
    }
}

@media screen and (max-width: 640px) {
    .section-cta::before {
        top: 70%;
    }
}

@media screen and (max-width: 600px) {
    .site-nav {
        left: 0%;
    }

    /* Hero */
    .hero {
        border-radius: 30px;
        min-height: 80vh;
    }

    .banner.banner--catalog,
    .banner.banner--catalog::before,
    .banner.banner--single,
    .banner.banner--single::before,
    .banner.banner-common,
    .banner.banner-common::before {
        border-radius: 20px;
    }

    .hero-corner {
        border-top-left-radius: 30px;
    }

    /* Novidades */
    .products-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    /* Marcas */
    .brands-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Footer */
    .footer-inner {
        padding: 30px 20px 20px;
    }

    .footer-corner.corner-right {
        width: 70px;
        height: 70px;
    }

    .back-to-top-btn::before {
        width: 54px;
        height: 54px;
    }

    .footer-nav>.menu-footer {
        grid-template-columns: 1fr;
    }

    .footer-main::after {
        content: '';
        position: absolute;
        bottom: 0;
        width: calc(100% + 38px);
        height: 1px;
        background-color: #C8C1AC;
        left: -19px;
    }

    .footer-nav .sub-menu {
        display: flex;
        flex-direction: row;
        gap: 10px 20px;
        flex-wrap: wrap;
    }

    .footer-nav .sub-menu .menu-item {
        margin-bottom: 0;
    }

    .footer-bottom {
        flex-direction: column;
        gap: 16px;
        text-align: center;
    }

    .legal-nav .menu {
        justify-content: center;
    }
}

@media screen and (max-width: 550px) {
    .footer-main {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto auto;
        gap: 15px;
    }

    .footer-contact {
        grid-column: 1;
        grid-row: 3;
        margin-top: 15px;
    }

    .footer-brand p {
        max-width: 100%;
        margin-bottom: 20px;
        text-wrap: pretty;
        font-size: clamp(14px, 2.9vw, 16px);
    }

    .footer-brand address {
        font-size: clamp(14px, 2.9vw, 16px);
    }

    .footer-contact .title {
        padding-top: 0;
        font-size: clamp(14px, 2.9vw, 16px);
    }

    .footer-nav>.menu-footer>.menu-item>a {
        margin-bottom: 16px;
        font-size: clamp(14px, 2.9vw, 16px);
    }

    .footer-nav .sub-menu .menu-item a {
        font-size: clamp(14px, 2.9vw, 16px);
    }

    .footer-nav>.menu-footer {
        gap: 25px;
    }

    .footer-inner {
        background-size: 100%;
    }

    .footer-contact .contact-email {
        font-size: clamp(14px, 2.9vw, 16px);
    }

    .phone-block strong {
        font-size: clamp(14px, 2.9vw, 16px);
    }

    .products-grid.products-grid--catalog {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
    }

    .banner-common .banner-desc {
        max-width: 300px;
    }

    .services-section .services-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .services-item {
        display: flex;
        flex-direction: row;
    }

    .services-item:first-of-type {
        margin-left: 0;
    }

    .services-item:last-of-type {
        margin-right: 0;
    }

    .services-text {
        text-align: start;
    }

    .services-section .services-icon {
        width: 50px;
        height: 50px;
        display: flex;
        align-items: center;
        justify-content: center;
        flex: 0 0 50px;
    }

    .services-section .services-icon img {
        width: 100%;
        height: 100%;
        object-fit: contain;
    }

    .services-highlight-text,
    .services-highlight-subtext {
        text-align: start;
    }

    .myproducts__grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: clamp(10px, 2vw, 25px);
    }

    .myproducts-form__form {
        display: flex;
    }

    .banner-contacts .banner-figure {
        display: none;
    }

    .banner-contacts.banner-common .banner-desc {
        max-width: 92%;
    }
}

@media screen and (max-width: 500px) {
    .header-wrapped::after {
        content: '';
        position: absolute;
        left: -25px;
        bottom: -48px;
        width: 40px;
        height: 40px;
        background-image: url(assets/masks/corner-banner.svg);
        rotate: 180deg;
        display: block;
    }

    .hero,
    .banner.banner--catalog,
    .banner.banner--single,
    .banner.banner-common {
        max-width: 100%;
        margin: 20px 10px 0;
        width: calc(100% - 20px);
    }

    .gallery {
        display: flex;
        flex-direction: column;
        gap: 8px;
        max-height: none;
    }

    .thumbs figure:first-child {
        margin-top: 0;
    }

    .product-details-card {
        align-items: normal;
    }

    .thumbs {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        overflow-x: auto;
        gap: 7px;
        width: 100%;
        padding: 5px 0;
        order: 2;
        -webkit-overflow-scrolling: touch;
    }

    .thumbs figure {
        flex: 0 0 65px;
        height: fit-content;
        aspect-ratio: 1 / 1;
    }

    .product-details {
        padding: 15px;
        width: 100%;
    }

    .banner.banner--single {
        padding: 0;
    }

    .breadcrumb {
        margin: 80px 20px 0;
    }

    .brand-card-custom {
        flex-direction: column;
    }
}

@media screen and (max-width: 480px) {

    .hero-corner {
        padding: 6px 4px;
        border-top-left-radius: 20px;
    }

    .hero-content {
        padding: 24px 20px;
    }

    .hero-cta {
        padding: 12px 16px;
        font-size: 12px;
    }

    /* Novidades */
    .products-grid {
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }

    .section-news,
    .section-brands,
    .section-how {
        padding: 0 16px;
    }

    /* Marcas */
    .brands-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px;
    }

    /* CTA */
    .cta-title {
        font-size: clamp(22px, 6vw, 30px);
    }

    .catalog-filters-toggle {
        width: 44px;
        height: 44px;
    }

    .catalog-filters-toggle img {
        width: 20px;
        height: 20px;
    }

    .catalog-filters {
        width: 90%;
        padding: 20px 12px;
    }
}

@media screen and (max-width: 430px) {
    .header-logo::before {
        left: -40px;
        bottom: 0px;
        width: calc(100% + 25px);
        height: calc(100% + 26px);
        background-color: #f4f1ea;
        display: block;
        z-index: -1;
        border-radius: 0 0 30px 0;
    }

    .header-logo {
        padding-bottom: 10px;
    }

    .header-logo img {
        height: auto;
        width: 80%;
        padding-left: 0;
    }

    .header-wrapped::after {
        content: '';
        position: absolute;
        left: -25px;
        bottom: -40px;
        width: 40px;
        height: 40px;
        background-image: url(assets/masks/corner-banner.svg);
        rotate: 180deg;
        display: block;
    }

    .header-wrapped::before {
        right: -19px;
    }

    .banner.banner--catalog,
    .banner.banner-common {
        padding: 20px 15px;
    }

    .banner-desc {
        max-width: 67%;
    }

    .product-note strong {
        display: block;
        margin-bottom: 7px;
    }
}

@media screen and (max-width: 400px) {
    .products-grid.products-grid--catalog .product-img img {
        max-height: 129px;
    }

    .products-grid.products-grid--catalog .product-name {
        padding-bottom: 5px;
        font-size: 14px;
    }

    .products-grid.products-grid--catalog .product-desc {
        font-size: 12px;
    }

    .banner-common .banner-desc {
        max-width: 190px;
    }

    .myproducts__header-bottom {
        flex-direction: column;
    }
}

@media screen and (max-width: 375px) {
    .products-grid {
        grid-template-columns: 1fr;
    }

    .brands-grid {
        grid-template-columns: 1fr;
    }

    .hero-left h1 {
        font-size: 28px;
        letter-spacing: -1px;
    }

    .section-cta::before {
        top: 80%;
    }

    .back-to-top-btn::before {
        width: 34px;
        height: 34px;
    }

    .back-to-top-btn img {
        width: 12px;
        height: 12px;
    }

    .footer-corner.corner-right {
        width: 50px;
        height: 50px;
    }

    .products-grid.product-grid-scroll {
        overflow-x: auto;
        display: flex;
        scrollbar-width: none;
        -ms-overflow-style: none;
        margin-left: -20px;
        margin-right: -20px;
    }

    .products-grid.product-grid-scroll>* {
        flex: 0 0 200px;
    }

    .products-grid.product-grid-scroll::-webkit-scrollbar {
        display: none;
    }

    .products-grid.product-grid-scroll .product-card:first-child {
        margin-left: 20px;
    }

    .products-grid.product-grid-scroll .product-card:last-child {
        margin-right: 20px;
    }

    .header-wrapped::after {
        left: -26px;
        bottom: -39px;
    }

    .header-wrapped::before {
        right: -20px;
        border-top-right-radius: 30px;
        top: -1px;
    }

    .hero-corner::after {
        right: -1px;
        top: -39px;
    }

    .hero-corner::before {
        bottom: -1px;
    }

    .hero-corner {
        bottom: -1px;
        right: -1px;
    }
}

@media screen and (max-width: 350px) {
    .hero-link {
        font-size: 11px;
    }

    .footer-corner.corner-right {
        display: none;
    }
}
