﻿:root{--icona-black:#000000;--icona-wine:#8f4144;--icona-white:#FFFFFF;--icona-wine-light:#CA8083;--icona-wine-medium:#AD5A5E;--icona-gray-dark:#2c2c2c;--icona-gray-medium:#666666;--icona-gray-light:#f5f5f5;--icona-gold:#daa520;--icona-gold-star:#ffd700;--font-tundra:'TUNDRA',Georgia,serif;--font-clarika:'Clarika',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;--spacing-xs:8px;--spacing-sm:15px;--spacing-md:25px;--spacing-lg:40px;--spacing-xl:60px;--spacing-xxl:80px;--radius-sm:12px;--radius-md:20px;--radius-lg:25px;--radius-xl:40px;--shadow-sm:0 4px 12px rgba(0,0,0,.1);--shadow-md:0 8px 25px rgba(0,0,0,.1);--shadow-lg:0 10px 30px rgba(0,0,0,.15);--transition-fast:.3s ease;--transition-medium:.5s ease;--bg-pos-y:50%;--bg-scale:1}



/* Local OTF font files provided by the project */

/* --- Mobile FAQ alignment fixes (appended) --- */
@media (max-width: 767px) {
    .faq-section { padding: 26px 18px; box-sizing: border-box; }
    .faq-content { grid-template-columns: 1fr !important; gap: 28px !important; align-items: stretch; }
    .faq-header { padding-right: 0 !important; text-align: center; }
    .faq-title { font-size: 34px; margin-bottom: 12px; }
    .faq-description { margin: 0 auto 16px; max-width: 520px; }
    .faq-learn-more { display: inline-block; margin: 12px auto 18px; text-align: center; }
    .faq-questions { padding: 0; }
    .faq-item { width: 100%; box-sizing: border-box; transform: none; }
    .faq-item:not(:last-child) { margin-bottom: 12px; }
    .faq-item:hover { transform: none; }
}

@font-face {
    font-family: 'Clarika';
    src: url('../fonts/clarika-regular.otf') format('opentype');
    /* original file used weight 200 per designer intent */
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

/* Heavier Clarika variant (if available) to cover font-weight:600 usages */
@font-face {
    font-family: 'Clarika';
    src: url('../fonts/clarika-regular1.otf') format('opentype');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

/* If there's an alternative heavier file, you can add an additional face like this
@font-face {
    font-family: 'Clarika';
    src: url('../fonts/clarika-bold.otf') format('opentype');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}
*/

@font-face {
    font-family: 'TUNDRA';
    src: url('../fonts/tundra-regular.otf') format('opentype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

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

/* prevent horizontal scroll on most devices */
html, body { overflow-x: hidden; }

body{font-family:var(--font-clarika);color:var(--icona-white);min-height:100vh;display:flex;flex-direction:column}


.main-container {
    position: relative;
    flex: 1 0 auto; /* fill available vertical space so footer is pushed to bottom */
    min-height: 0; /* allow flex to manage height */
    border-radius: var(--radius-xl);
    overflow: hidden;
    margin: 0; /* avoid extra 1px gap that may show background */
    display: flex;
    flex-direction: column;
}

/* If JS sets --app-height, prefer it over 100vh for mobile correctness */
@supports (height: 100dvh) {
    .main-container { min-height: 100dvh; }
}
@supports (--css: variables) {
    .main-container { min-height: var(--app-height, 100vh); }
}


.bg-image {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 20%;
    transform-origin: center 35%;
    transform: scale(1); 
    z-index: -1;
    filter: brightness(0.5);
    transition: transform 0.35s var(--transition-fast), object-position 0.35s var(--transition-fast);
    will-change: transform, object-position;
}

/* Ensure fixed background image doesn't introduce horizontal scroll on mobile */
@media (max-width: 767px) {
    .bg-image {
        left: 0;
        right: 0;
        transform: none;
        width: 100%;
        max-width: 100%;
        object-position: 50% 0%;
    }
    html, body, .main-container { overflow-x: hidden !important; }
}


.content-wrapper {
    position: relative;
    z-index: 2;
    flex: 1 0 auto; /* allow wrapper to grow and push footer down */
    display: flex;
    flex-direction: column;
    padding: 50px 70px;
}


header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-xxl);
}


.main-content {
    display: flex;
    flex: 1;
    align-items: center;
}

.left-content {
    flex: 1;
    max-width: 600px;
}

.main-title {
    font-size: 130px;
    font-weight: 400;
    line-height: 0.9;
    letter-spacing: -2px;
    font-family: var(--font-tundra);
    margin-bottom: 100px;
    text-transform: lowercase;
    color: var(--icona-white);
}

.subtitle {
    font-size: 25px;
    letter-spacing: 1px;
    margin-bottom: var(--spacing-md);
    font-family: var(--font-clarika);
    color: var(--icona-white);
}

.description {
    font-size: 20px;
    line-height: 1.6;
    opacity: 0.9;
    max-width: 400px;
    font-weight: 300;
    letter-spacing: 0.3px;
    font-family: var(--font-clarika);
    color: var(--icona-white);
}


.logo-image {
    height: 100px;
    width: auto;
    object-fit: contain;
    transition: var(--transition-fast);
    margin-top: 20px;
}


header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-xxl);
    height: 60px; 
    overflow: visible; 
}

@media (max-width: 1023px) {
    .logo-image {
        height: 80px;
    }
    
    header {
        height: 80px;
    }
}

@media (max-width: 767px) {
    .logo-image {
        height: 65px;
    }
    
    header {
        height: 65px;
    }
}


@media (max-width: 767px) {
    
    .faq-content {
        display: block !important;
        padding: 0 12px;
    }

    .faq-header {
        padding: 0 0 18px 0;
        text-align: center;
    }

    .faq-title { font-size: 34px; margin-bottom: 12px; }
    .faq-description { font-size: 15px; margin: 0 auto 18px; max-width: 520px; }

    
    .faq-questions {
        display: flex;
        flex-direction: column;
        gap: 12px;
        max-width: 520px;
        margin: 0 auto;
        padding: 6px 0 30px;
    }

    .faq-item {
        width: 100%;
        padding: 14px 18px;
        border-radius: 14px;
        background: rgba(143,65,68,0.08);
        transform: none !important; 
    }

    .faq-question { align-items: center; }
    .faq-icon { font-size: 18px; margin-right: 8px; }
    .question-text { font-size: 15px; }
}

@media (max-width: 480px) {
    .logo-image {
        height: 70px;
    }
}


.right-content {
    position: absolute;
    bottom: 3px;
    right: 50px;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.featured-card {
    width: 480px;
    background: rgba(143, 65, 68, 0.6);
    backdrop-filter: blur(20px);
    border-radius: var(--radius-lg);
    padding: 14px;
}

.main-card {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
}

.featured-image {
    width: 50%;
    height: 230px;
    border-radius: var(--spacing-sm);
    overflow: hidden;
    flex-shrink: 0;
    transition: transform var(--transition-fast);
}

.featured-image:hover {
    transform: scale(1.03);
}

.featured-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

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

.card-title {
    font-size: 28px;
    font-weight: 400;
    margin-bottom: 14px;
    line-height: 1.3;
    text-transform: uppercase;
    font-family: var(--font-tundra);
    color: var(--icona-white);
}

.view-more-btn {
    background: var(--icona-white);
    color: var(--icona-wine);
    padding: 10px 30px;
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    transition: transform var(--transition-fast);
    font-family: var(--font-clarika);
    display: inline-block;
    text-align: center;
    text-decoration: none;
}

.view-more-btn:hover {
    transform: scale(1.05);
}


.products-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-xs);
}

.product-thumb {
    height: 220px;
    border-radius: var(--radius-sm);
    overflow: hidden;
    cursor: pointer;
    transition: transform var(--transition-fast);
}

.product-thumb:hover {
    transform: scale(1.03);
}

.product-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}


.section-two,
.section-three,
.section-four {
    /* make these sections full-bleed so the background color/strip reaches the
       viewport edges and avoids centered white gutters on wide screens */
    background: var(--icona-gray-light);
    color: var(--icona-wine);
    /* keep vertical spacing but handle horizontal full-bleed separately */
    padding: 55px 0;

    /* full-bleed technique: make element span viewport width and offset it
       so it visually aligns with the page even when inside a centered container */
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    box-sizing: border-box;
}

.section-two {
    /* avoid forcing full viewport height which can cause overlap on mobile */
    padding-top: 0;
}


.features-wrapper {
    background-color: rgba(143, 65, 68, 0.1);
    /* avoid 100vw + negative calc which can create horizontal scroll on some mobile browsers */
    width: 100%;
    box-sizing: border-box;
    padding: 20px;
    margin: 0 auto 95px;
}


.features-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    max-width: 1375px;
    margin-left: auto;
    margin-right: auto;
    padding: 0 var(--spacing-lg); 
}

.feature-item {
    text-align: center;
    padding: var(--spacing-md) var(--spacing-lg); 
    position: relative;
}

.feature-item:not(:last-child)::after {
    content: '';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    height: 70%; 
    width: 1px;
    background-color: var(--icona-wine);
    opacity: 0.4; 
}

.feature-icon {
    font-size: 48px;
    margin-bottom: var(--spacing-md);
    background: var(--icona-wine);
    width: 80px;
    height: 80px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto var(--spacing-md);
    color: var(--icona-white);
}

.feature-title {
    font-family: var(--font-clarika);
    font-size: 20px;
    font-weight: 500;
    margin-bottom: var(--spacing-sm);
    color: var(--icona-wine);
}

.feature-description {
    font-family: var(--font-clarika);
    font-size: 14px;
    line-height: 1.5;
    color: var(--icona-wine);
    opacity: 0.8;
}


.section-two-content {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--spacing-xl);
    align-items: center;
    max-width: 1400px;
    margin: 0 auto;
}


.main-image-card {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--icona-white);
    box-shadow: var(--shadow-md);
}

.rating-badge {
    position: absolute;
    top: var(--spacing-md);
    left: var(--spacing-md);
    background: rgba(255, 255, 255, 0.95);
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    z-index: 2;
    backdrop-filter: blur(10px);
}

.stars {
    color: var(--icona-gold-star);
    font-size: 14px;
}

.rating-text {
    font-family: var(--font-clarika);
    font-size: 12px;
    color: var(--icona-black);
    font-weight: 500;
}

.main-product-image {
    height: 490px;
    width: 100%;
    align-items: center;
    justify-content: center;
}


.content-center {
    padding: 0 var(--spacing-md);
}


.section-title,
.collection-title,
.type-title,
.featured-product-title,
.faq-title {
    font-family: var(--font-tundra);
    font-size: 48px;
    font-weight: 400;
    line-height: 1.2;
    margin-bottom: 30px;
    color: var(--icona-wine);
}


.section-description,
.collection-description,
.type-description,
.product-description,
.faq-description {
    font-family: var(--font-clarika);
    font-size: 16px;
    line-height: 1.6;
    margin-bottom: var(--spacing-lg);
    color: var(--icona-wine);
    opacity: 0.8;
}


.learn-more-btn,
.see-more-btn,
.learn-more-featured,
.faq-learn-more {
    background: transparent;
    color: var(--icona-wine);
    border: 2px solid var(--icona-wine);
    padding: 12px 30px;
    border-radius: var(--radius-lg);
    font-family: var(--font-clarika);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: var(--transition-fast);
    text-decoration: none; /* remove underline for link-styled buttons */
}

.learn-more-btn:hover,
.see-more-btn:hover,
.learn-more-featured:hover,
.faq-learn-more:hover {
    background: var(--icona-wine);
    color: var(--icona-white);
}

/* Ensure link elements styled as buttons don't show underline on hover */
.learn-more-btn:hover,
.see-more-btn:hover {
    text-decoration: none;
}


.product-images-stack {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.product-image-item {
    height: 380px;
    width: 290px;
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-md);  
}

.product-image-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}



.section-three {
    background: var(--icona-gray-light);
    padding: 80px 55px;
    
}

.collection-section {
    max-width: 1400px;
    margin: 0 auto;
}

.collection-container {
    background: rgba(143, 65, 68, 0.1);
    border-radius: 30px;
    padding: 60px;
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 80px;
    align-items: center;
}


.collection-header {
    max-width: 400px;
}

.collection-title {
    font-family: var(--font-tundra);
    font-size: 48px;
    font-weight: 400;
    color: var(--icona-wine);
    margin-bottom: 20px;
    line-height: 1.2;
}

.collection-description {
    font-family: var(--font-clarika);
    font-size: 16px;
    line-height: 1.6;
    color: var(--icona-wine);
    margin-bottom: 30px;
}

.see-more-btn {
    background: transparent;
    border: 2px solid var(--icona-wine);
    color: var(--icona-wine);
    padding: 12px 35px;
    border-radius: 25px;
    font-family: var(--font-clarika);
    font-size: 16px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
}

.see-more-btn:hover {
    background: var(--icona-wine);
    color: white;
}


.products-showcase {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}

.product-card {
    text-align: center;
}

.product-image {
    position: relative;
    height: 220px;
    width: 100%;
    border-radius: 20px;
    overflow: hidden;
    margin-bottom: 15px;
    background: #F0EDE8;
}

.product-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}


.product-image video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}


.audio-toggle {
    position: absolute;
    right: 10px;
    bottom: 10px;
    background: rgba(0,0,0,0.5);
    color: #fff;
    border: none;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 2;
    transition: background 0.2s ease, transform 0.15s ease;
}

.audio-toggle:active { transform: scale(0.96); }
.audio-toggle i { font-size: 14px; }

.audio-toggle[aria-pressed="true"] { background: rgba(255,255,255,0.9); color: var(--icona-wine); }

.product-name {
    font-family: var(--font-tundra);
    font-size: 18px;
    font-weight: 400;
    color: var(--icona-wine);
    margin-bottom: 8px;
}

.product-price {
    font-family: var(--font-clarika);
    font-size: 16px;
    font-weight: 600;
    color: var(--icona-wine);
}


.icona-type-section {
    background-color: var(--icona-gray-light);
    padding: 80px 0;
    position: relative;
    z-index: 10;
}

.icona-type-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
    align-items: center;
    max-width: 1480px;
    margin: 0 auto;
    padding: 0 40px;
    background-color: var(--icona-gray-light);
}

.icona-video-block {
    position: relative;
    border-radius: 30px;
    overflow: hidden;
    height: 400px;
    background-color: var(--icona-wine);
}

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

/* central play/pause button inside the feature video block */
.icona-play-toggle {
    position: absolute;
    right: 18px;
    bottom: 18px;
    transform: none;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: rgba(255,255,255,0.95);
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 6px 18px rgba(0,0,0,0.12);
    z-index: 4;
    transition: transform 0.18s ease, box-shadow 0.18s ease, opacity 0.2s ease;
}

.icona-play-toggle i { color: var(--icona-wine); font-size: 18px; }

.icona-play-toggle:hover { transform: translateY(-2px); box-shadow: 0 8px 26px rgba(0,0,0,0.16); }

/* Slightly smaller on small screens and keep away from main subject */
@media (max-width: 767px) {
    .icona-play-toggle { right: 12px; bottom: 12px; width: 48px; height: 48px; }
    .icona-play-toggle i { font-size: 16px; }
}

/* style audio-toggle inside feature block to be smaller and in the corner */
/* audio-toggle in the feature block removed; gallery audio toggles still use .audio-toggle */

.icona-play-btn {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 70px;
    height: 70px;
    background-color: rgba(255, 255, 255, 0.95);
    border: none;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

.icona-play-btn svg {
    width: 30px;
    height: 30px;
    color: var(--icona-wine);
    margin-left: 3px;
}

.icona-play-btn:hover {
    transform: translate(-50%, -50%) scale(1.1);
    box-shadow: 0 6px 30px rgba(0, 0, 0, 0.15);
    background-color: var(--icona-white);
}

.icona-type-info {
    padding-left: 20px;
    background-color: var(--icona-gray-light); 
}

.icona-type-heading {
    font-family: var(--font-tundra);
    font-size: 52px;
    font-weight: 400;
    color: var(--icona-wine);
    margin-bottom: 20px;
    line-height: 1.1;
}

.icona-type-text {
    font-family: var(--font-clarika);
    font-size: 16px;
    line-height: 1.6;
    color: var(--icona-wine-light);
    margin-bottom: 50px;
    max-width: 450px;
}

.icona-type-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 35px;
}

.icona-type-item {
    text-align: center;
    cursor: pointer;
    transition: transform 0.3s ease;
}

.icona-type-item:hover {
    transform: translateY(-5px);
}

.icona-type-img-wrap {
    position: relative;
    margin-bottom: 15px;
}

.icona-type-img-box {
    width: 140px;
    height: 180px;
    border-radius: 100px;
    overflow: hidden;
    margin: 0 auto;
    background-color: rgba(143, 65, 68, 0.1);
    position: relative;
}

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

.icona-type-icon {
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 40px;
    height: 40px;
    background-color: var(--icona-wine-light);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    color: #FFFFFF;
    font-weight: bold;
    transition: all 0.3s ease;
}

.icona-type-item:hover .icona-type-icon {
    background-color: var(--icona-wine);
    transform: translateX(-50%) scale(1.1);
}

.icona-type-label {
    font-family: var(--font-tundra);
    font-size: 20px;
    font-weight: 400;
    color: var(--icona-wine);
    margin-top: 20px;
}



.icona-type-grid { grid-template-columns: repeat(3, 1fr); gap: 35px; }


@media (max-width: 1024px) {
    .icona-type-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
    .icona-type-img-box { width: 120px; height: 120px; border-radius: 50%; }
    .icona-type-icon { width: 36px; height: 36px; bottom: -8px; }
    .icona-type-label { font-size: 18px; }
    .icona-type-heading { font-size: 44px; }
    .icona-type-text { max-width: 420px; }
    .icona-video-block { max-height: 320px; }
}


@media (max-width: 767px) {
    .icona-type-grid { grid-template-columns: 1fr; gap: 20px; justify-items: center; }
    .icona-type-img-box { width: 110px; height: 110px; border-radius: 50%; }
    .icona-type-label { font-size: 16px; }
    .icona-type-heading { font-size: 34px; text-align: center; }
    .icona-type-info { text-align: center; padding-left: 12px; padding-right: 12px; }
    .icona-video-block { width: 100%; max-width: 720px; height: auto; }
    .icona-type-wrapper { display: flex; flex-direction: column; gap: 16px; align-items: center; }
}




.product-feature-section {
    max-width: 1400px;
    margin: 0 auto 100px;
    padding: 40px 60px; 
    background-color: rgba(143, 65, 68, 0.1);
    border-radius: 30px;
}

.product-feature-content {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--spacing-md); 
    align-items: center;
}

.product-info-left {
    padding-right: var(--spacing-md);
}

.product-rating {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: var(--spacing-md);
    flex-wrap: wrap;
}

.stars-rating {
    color: var(--icona-gold-star);
    font-size: 16px;
}

.rating-count,
.reviews-count {
    font-family: var(--font-clarika);
    font-size: 14px;
    color: var(--icona-wine);
}

.rating-count {
    opacity: 0.8;
}

.reviews-count {
    font-weight: 600;
}

.product-image-center {
    display: flex;
    justify-content: center;
}

.featured-product-image {
    width: 350px;
    height: 350px;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}

.image-placeholder.featured-necklace {
    background: linear-gradient(135deg, var(--icona-gray-dark) 0%, var(--icona-black) 50%, var(--icona-gray-dark) 100%);
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--icona-gold);
    font-family: var(--font-clarika);
    font-weight: 500;
    font-size: 18px;
}

.product-details-right {
    padding-left: var(--spacing-md);
}

.price-section {
    margin-bottom: 30px;
}

.price-label {
    font-family: var(--font-clarika);
    font-size: 16px;
    color: var(--icona-wine);
    display: block;
    margin-bottom: var(--spacing-xs);
}

.price-value {
    font-family: var(--font-tundra);
    font-size: 32px;
    font-weight: 600;
    color: var(--icona-wine);
}

.materials-section {
    margin-bottom: var(--spacing-lg);
}

.materials-title {
    font-family: var(--font-clarika);
    font-size: 16px;
    color: var(--icona-wine);
    margin-bottom: var(--spacing-sm);
    font-weight: 600;
}

.materials-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.material-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.material-dot {
    width: 8px;
    height: 8px;
    background: var(--icona-wine);
    border-radius: 50%;
    opacity: 0.6;
}

.material-name {
    font-family: var(--font-clarika);
    font-size: 14px;
    color: var(--icona-wine);
    opacity: 0.8;
}

.testimonial-section {
    background: rgba(255, 255, 255, 0.5);
    padding: var(--spacing-md);
    border-radius: var(--spacing-sm);
    border-left: 4px solid var(--icona-wine);
}

.testimonial-text {
    font-family: var(--font-clarika);
    font-size: 14px;
    font-style: italic;
    color: var(--icona-wine);
    margin-bottom: var(--spacing-sm);
    line-height: 1.5;
}

.testimonial-author {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.author-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    overflow: hidden;
    background: var(--icona-wine);
}

.avatar-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--icona-white);
    font-family: var(--font-clarika);
    font-weight: 600;
    font-size: 14px;
}

.author-info {
    display: flex;
    flex-direction: column;
}

.author-name {
    font-family: var(--font-tundra);
    font-size: 16px;
    color: var(--icona-wine);
    font-weight: 500;
}

.author-role {
    font-family: var(--font-clarika);
    font-size: 12px;
    color: var(--icona-wine);
    opacity: 0.6;
}


.faq-section {
    max-width: 1400px;
    margin: 0 auto;
}

.faq-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-xxl);
    align-items: flex-start;
}


.faq-section {
    max-width: 1400px;
    margin: 0 auto;
}

.faq-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-xxl);
    align-items: flex-start;
}

.faq-header {
    padding-right: var(--spacing-lg);
}

.faq-questions {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.faq-item {
    background:  rgba(143, 65, 68, 0.1);
    border-radius: var(--spacing-sm);
    padding: var(--spacing-md);
    cursor: pointer;
    transition: var(--transition-fast);
}

.faq-item:hover {
    background: rgba(143, 65, 68, 0.2);
    transform: translateX(5px);
}

.faq-question {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.faq-icon {
    font-size: 20px;
    opacity: 0.6;
}

.question-text {
    font-family: var(--font-clarika);
    font-size: 16px;
    color: var(--icona-wine);
    font-weight: 500;
}

/* FAQ answer (hidden by default, revealed on toggle) */
.faq-answer {
    margin-top: 10px;
    font-family: var(--font-clarika);
    font-size: 15px;
    line-height: 1.5;
    color: var(--icona-wine);
    opacity: 0; /* hidden */
    max-height: 0; /* collapse */
    overflow: hidden;
    transition: opacity 0.25s var(--transition-fast), max-height 0.35s var(--transition-fast);
}

.faq-item[aria-expanded="true"] .faq-answer {
    opacity: 1;
    max-height: 200px; /* enough for short answers */
}


.footer {
    background: var(--icona-wine);
    color: var(--icona-white);
    padding: var(--spacing-xxl) 0 0;
}

.footer-content {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 50px;
}

.footer-top {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: var(--spacing-xxl);
    margin-bottom: var(--spacing-xl);
}

.footer-brand {
    max-width: 400px;
}

.footer-logo {
    font-family: var(--font-tundra);
    font-size: 42px;
    font-weight: 400;
    color: var(--icona-white);
    margin-bottom: 10px;
}

.footer-tagline {
    font-family: var(--font-tundra);
    font-size: 18px;
    color: var(--icona-gray-light);
    margin-bottom: var(--spacing-md);
}

.footer-description {
    font-family: var(--font-clarika);
    font-size: 14px;
    line-height: 1.6;
    color: var(--icona-white);
    opacity: 0.8;
    margin-bottom: 30px;
}

.footer-social {
    display: flex;
    gap: var(--spacing-sm);
}

.footer-social-link {
    width: 40px;
    height: 40px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: var(--transition-fast);
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.footer-social-link:hover {
    background: var(--icona-wine);
    transform: translateY(-2px);
}

.footer-social-link span {
    font-size: 18px;
}

.footer-links {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-lg);
}

.footer-column-title {
    font-family: var(--font-tundra);
    font-size: 18px;
    font-weight: 500;
    color: var(--icona-white);
    margin-bottom: var(--spacing-md);
}

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

.footer-menu li {
    margin-bottom: var(--spacing-xs);
}

.footer-link {
    font-family: var(--font-clarika);
    font-size: 14px;
    color: var(--icona-white);
    text-decoration: none;
    opacity: 0.8;
    transition: var(--transition-fast);
}

.footer-link:hover {
    opacity: 1;
    color: var(--icona-wine-light);
    padding-left: 5px;
}

.footer-contact {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.contact-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.contact-icon {
    font-size: 16px;
    width: 20px;
    opacity: 0.8;
}

.contact-text {
    font-family: var(--font-clarika);
    font-size: 14px;
    color: var(--icona-white);
    opacity: 0.8;
}


@media (max-width: 767px) {
    .footer-newsletter {
        background: rgba(255,255,255,0.04);
        padding: 14px;
        border-radius: 18px;
    }
    
    .newsletter-form {
        display: flex;
        gap: 8px;
        align-items: center;
        width: 100%;
        max-width: 520px;
        margin: 0 auto;
        box-sizing: border-box;
    }

    
    .newsletter-input {
        flex: 1 1 auto;
        padding: 12px 18px;
        border: 1px solid rgba(255,255,255,0.12);
        border-right: none;
        border-radius: 28px 0 0 28px;
        background: rgba(255,255,255,0.06);
        color: var(--icona-white);
        font-size: 14px;
    }

    .newsletter-input::placeholder { color: rgba(255,255,255,0.55); }

    
    .newsletter-button {
        flex: 0 0 auto;
        padding: 12px 18px;
        min-width: 110px;
        border-radius: 0 28px 28px 0;
        background: var(--icona-wine);
        color: var(--icona-white);
        border: 1px solid rgba(0,0,0,0.05);
        border-left: none;
        white-space: nowrap;
        cursor: pointer;
        font-size: 14px;
    }

}

@media (max-width: 480px) {
    
    .newsletter-form { flex-direction: column; gap: 10px; max-width: 420px; }
    .newsletter-input { border-radius: var(--radius-lg); border-right: 1px solid rgba(255,255,255,0.12); }
    .newsletter-button { border-radius: var(--radius-lg); width: 100%; }
}


.footer .footer-newsletter {
    max-width: 1100px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 22px;
    padding-right: 22px;
}

.footer .footer-newsletter .newsletter-form {
    min-width: 0 !important;
    max-width: 520px;
    width: 100%;
    box-sizing: border-box;
}

.footer .footer-newsletter .newsletter-input {
    box-sizing: border-box;
}

.footer .footer-newsletter .newsletter-button {
    box-sizing: border-box;
}


.footer-newsletter {
    background: rgba(255, 255, 255, 0.05);
    padding: var(--spacing-lg);
    border-radius: var(--radius-md);
    margin: 30px auto 50px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-lg);
    max-width: 1100px; 
    box-sizing: border-box;
}

.newsletter-title {
    font-family: var(--font-tundra);
    font-size: 24px;
    font-weight: 500;
    color: var(--icona-white);
    margin-bottom: var(--spacing-xs);
}

.newsletter-description {
    font-family: var(--font-clarika);
    font-size: 14px;
    color: var(--icona-white);
    opacity: 0.8;
}


.newsletter-form {
    display: flex;
    gap: var(--spacing-sm);
    min-width: 0; 
    align-items: center;
    width: 100%;
    justify-content: flex-end; 
}

.newsletter-input {
    flex: 1;
    padding: 12px var(--spacing-md);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: var(--radius-lg);
    background: rgba(255, 255, 255, 0.1);
    color: var(--icona-white);
    font-family: var(--font-clarika);
    font-size: 14px;
}

.newsletter-input::placeholder {
    color: rgba(255, 255, 255, 0.6);
}

.newsletter-input:focus {
    outline: none;
    border-color: var(--icona-wine);
    background: rgba(255, 255, 255, 0.15);
}

.newsletter-button {
    background: var(--icona-wine);
    color: var(--icona-white);
    border: none;
    padding: 12px var(--spacing-md);
    border-radius: var(--radius-lg);
    font-family: var(--font-clarika);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: var(--transition-fast);
    white-space: nowrap;
}

.newsletter-button:hover {
    background: var(--icona-wine);
    color: var(--icona-black);
}


@media (max-width: 1024px) {
    .footer-newsletter { padding: 18px; }
    .newsletter-form { max-width: 520px; margin: 0 auto; justify-content: center; }
}

.footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 30px 0;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.copyright {
    font-family: var(--font-clarika);
    font-size: 13px;
    color: var(--icona-white);
    opacity: 0.6;
}

.footer-bottom-right {
    display: flex;
    gap: 30px;
}

.footer-legal {
    font-family: var(--font-clarika);
    font-size: 13px;
    color: var(--icona-white);
    text-decoration: none;
    opacity: 0.6;
    transition: opacity var(--transition-fast);
}

.footer-legal:hover {
    opacity: 1;
}

        
        
        
        
        
        
        
        :root {
            --hamburger-size: 30px;
            --overlay-bg: rgba(0, 0, 0, 0.8);
            --mobile-menu-bg: rgba(143, 65, 68, 0.98);
        }
        
        
        .hamburger-menu {
            display: none;
            flex-direction: column;
            justify-content: space-between;
            width: var(--hamburger-size);
            height: 22px;
            cursor: pointer;
            z-index: 1002;
            transition: var(--transition-fast);
            background: none;
            border: none;
            padding: 0;
        }
        
        .hamburger-line {
            width: 100%;
            height: 3px;
            background: var(--icona-white);
            border-radius: 2px;
            transition: var(--transition-fast);
            transform-origin: center;
        }
        
        .hamburger-menu.active .hamburger-line:nth-child(1) {
            transform: translateY(9.5px) rotate(45deg);
        }
        
        .hamburger-menu.active .hamburger-line:nth-child(2) {
            opacity: 0;
            transform: scaleX(0);
        }
        
        .hamburger-menu.active .hamburger-line:nth-child(3) {
            transform: translateY(-9.5px) rotate(-45deg);
        }
        
        
        .mobile-menu-overlay {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: var(--overlay-bg);
            backdrop-filter: blur(10px);
            z-index: 999;
            opacity: 0;
            visibility: hidden;
            transition: all var(--transition-medium);
        }
        
        .mobile-menu-overlay.active {
            opacity: 1;
            visibility: visible;
        }
        
        
        .mobile-menu {
            position: fixed;
            top: 0;
            right: -100%;
            width: 320px;
            max-width: 85vw;
            height: 100%;
            background: var(--mobile-menu-bg);
            backdrop-filter: blur(30px);
            z-index: 1000;
            transition: right var(--transition-medium);
            overflow-y: auto;
            padding-top: 100px;
            -webkit-overflow-scrolling: touch;
        }
        
        .mobile-menu.active {
            right: 0;
        }
        
        .mobile-nav-container {
            padding: 0 30px;
        }
        
        .mobile-nav-item {
            margin-bottom: 5px;
        }
        
        .mobile-nav-link {
            display: block;
            font-family: var(--font-clarika);
            font-size: 18px;
            font-weight: 500;
            color: var(--icona-white);
            text-decoration: none;
            padding: 18px 0;
            border-bottom: 1px solid rgba(255, 255, 255, 0.1);
            transition: var(--transition-fast);
            position: relative;
        }
        
        .mobile-nav-link:hover,
        .mobile-nav-link.active {
            color: var(--icona-wine-light);
            padding-left: 15px;
        }
        
        .mobile-nav-link.active::before {
            content: '';
            position: absolute;
            left: 0;
            top: 50%;
            transform: translateY(-50%);
            width: 4px;
            height: 20px;
            background: var(--icona-white);
            border-radius: 2px;
        }
        
        
        .mobile-submenu {
            background: rgba(0, 0, 0, 0.2);
            border-radius: var(--radius-sm);
            margin: 10px 0;
            overflow: hidden;
            max-height: 0;
            transition: max-height var(--transition-medium);
        }
        
        .mobile-nav-item.open .mobile-submenu {
            max-height: 200px;
        }
        
        .mobile-submenu-link {
            display: block;
            font-family: var(--font-clarika);
            font-size: 15px;
            color: var(--icona-white);
            text-decoration: none;
            padding: 12px 20px;
            border-bottom: 1px solid rgba(255, 255, 255, 0.05);
            transition: var(--transition-fast);
            opacity: 0.8;
        }
        
        .mobile-submenu-link:hover {
            background: rgba(255, 255, 255, 0.1);
            opacity: 1;
            padding-left: 25px;
        }
        
        .mobile-submenu-link:last-child {
            border-bottom: none;
        }
        
        
        .mobile-nav-link.has-submenu::after {
            content: '+';
            position: absolute;
            right: 0;
            top: 50%;
            transform: translateY(-50%);
            font-size: 24px;
            font-weight: 300;
            transition: var(--transition-fast);
        }
        
        .mobile-nav-item.open .mobile-nav-link.has-submenu::after {
            transform: translateY(-50%) rotate(45deg);
        }
        
        
        .mobile-social {
            padding: 30px;
            border-top: 1px solid rgba(255, 255, 255, 0.1);
            margin-top: 30px;
        }
        
        .mobile-social-title {
            font-family: var(--font-tundra);
            font-size: 20px;
            color: var(--icona-white);
            margin-bottom: 20px;
            text-align: center;
        }
        
        .mobile-social-container {
            display: flex;
            justify-content: center;
            gap: 15px;
            flex-wrap: wrap;
        }
        
        .mobile-social-link {
            width: 45px;
            height: 45px;
            background: rgba(255, 255, 255, 0.1);
            border: 1px solid rgba(255, 255, 255, 0.2);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--icona-white);
            text-decoration: none;
            font-size: 18px;
            transition: var(--transition-fast);
        }
        
        .mobile-social-link:hover {
            background: var(--icona-wine);
            border-color: var(--icona-wine);
            transform: scale(1.1);
        }
        
        
        body.mobile-menu-open {
            overflow: hidden;
            position: fixed;
            width: 100%;
        }
        
        
        .hamburger-menu:focus,
        .mobile-nav-link:focus {
            outline: 2px solid var(--icona-white);
            outline-offset: 2px;
        }

        
        .mobile-menu-close {
            position: absolute;
            top: 18px;
            right: 18px;
            background: transparent;
            color: var(--icona-white);
            border: none;
            font-size: 36px;
            line-height: 1;
            width: 48px;
            height: 48px;
            display: flex;
            align-items: center;
            justify-content: center;
            border-radius: 8px;
            cursor: pointer;
            z-index: 1003;
            transition: background 0.15s ease, transform 0.12s ease;
        }

        .mobile-menu-close:hover {
            background: rgba(255,255,255,0.06);
            transform: scale(1.02);
        }

        
        @media (max-width: 1023px) {
            .mobile-menu-close { color: var(--icona-white); }
        }
        
        
        
        

        
        @media (max-width: 1400px) {
            .content-wrapper { padding: 40px 60px; }
            .main-title { font-size: 160px; margin-bottom: 80px; }
            .featured-card { width: 420px; }
        }

        
        @media (max-width: 1200px) {
            .content-wrapper { padding: 36px 48px; }
            .main-title { font-size: 140px; margin-bottom: 60px; }
            .featured-card { width: 380px; }
            .featured-image { height: 200px; }
            .product-thumb { height: 180px; }
            .right-content { right: 30px; }
            .bg-image { object-position: 50% 30%; }
        }

        
        @media (max-width: 1023px) {
            .content-wrapper { padding: 28px 32px; }
            .main-title { font-size: 110px; margin-bottom: 48px; }
            .left-content { max-width: 520px; }
            .featured-card { width: 340px; }
            .featured-image { height: 180px; }
            .product-thumb { height: 160px; }
            .right-content { right: 22px; }
            
            .hamburger-menu { display: flex; }
            header .nav-container { display: none; }
            header .social-container { display: none; }
            .bg-image { object-position: 50% 25%; }
        }

        
        @media (max-width: 767px) {
            .content-wrapper { padding: 18px 18px; min-height: auto; }
            .main-content { flex-direction: column; align-items: flex-start; gap: 18px; }
            .left-content { width: 100%; max-width: none; }
            .main-title { font-size: 72px; margin-bottom: 18px; line-height: 0.95; }
            .main-title, .collection-title, .section-title { word-break: break-word; }
            .subtitle { font-size: 18px; }
            .description { font-size: 16px; max-width: 100%; }
            .right-content {
                position: static !important;
                right: auto !important;
                bottom: auto !important;
                display: block !important;
                width: 100% !important;
                flex-direction: column !important;
                gap: 12px !important;
                align-items: center !important;
                margin-top: 10px !important;
            }
            .featured-card { width: calc(100% - 32px); max-width: 520px; padding: 12px; }
            .products-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
            .featured-image { height: 160px; }
            .product-thumb { height: 140px; }
            .bg-image { object-position: 50% 12%; filter: brightness(0.45); }
            .hamburger-menu { display: flex; }

            /* Mobile overlap fixes: force header and nav into normal flow and reset transformed/absolute media that can overlap */
            header { position: relative; z-index: 12; }
            /* hide desktop nav that is absolutely positioned and can overlap content */
            .nav-container, header .nav-container, .social-container { display: none !important; }

            /* Ensure image stacks and featured cards don't use transforms or absolute positioning on mobile */
            .image-stack, .image-stack .big-image, .image-stack .small-image, .featured-card, .product-image video {
                /* keep videos/images static to avoid overlap, but keep .product-image relative for audio button context */
                position: static !important;
                transform: none !important;
                max-width: 100% !important;
                width: 100% !important;
                margin: 0 auto 12px !important;
                z-index: auto !important;
            }

            /* keep product-image relative so .audio-toggle can be positioned over the video */
            .product-image { position: relative !important; overflow: hidden !important; }

            /* Make sure embedded videos/images do not overflow their containers */
            .product-image img, .image-stack .big-image img, .image-stack .small-image img, .featured-image img {
                transform: none !important;
                max-height: none !important;
                width: 100% !important;
                height: auto !important;
            }
        }

        
        @media (max-width: 480px) {
            .content-wrapper { padding: 14px 12px; }
            .main-title { font-size: 56px; margin-bottom: 12px; letter-spacing: -1px; }
            .logo-image { height: 65px; }
            .featured-card { width: 100%; padding: 10px; border-radius: 16px; }
            .products-grid { grid-template-columns: 1fr; }
            .product-thumb { height: 120px; }
            .card-title { font-size: 22px; }
            .view-more-btn { padding: 8px 18px; font-size: 13px; }
            .bg-image { object-position: 50% 0%; transform: scale(1.02); }
        }

        
        @media (max-width: 1023px) {
            .mobile-menu { width: 100%; max-width: 100vw; }
        }

        
        @media (max-width: 767px) {
            
            .section-two-content {
                display: flex !important;
                flex-direction: column;
                gap: 20px;
                align-items: stretch;
                padding: 0 12px;
            }

            
            .content-center { order: 1; text-align: center; padding: 0 6px; }

            
            .main-image-card { order: 2; margin: 0 auto; width: 100%; max-width: 820px; }
            .main-product-image { height: 300px; }

            
            .content-right { order: 3; display: flex; justify-content: center; padding: 0 6px; }
                .product-images-stack { flex-direction: row; gap: 14px; justify-content: center; flex-wrap: wrap; align-items: center; }
                .product-image-item { width: 56%; max-width: 360px; height: 200px; margin: 8px auto; border-radius: 18px; display: block; }

            
            .see-more-btn, .view-more-btn { margin: 8px auto 0; }
        }

        
        
        

        
        @media (max-width: 1200px) {
            
            .section-two-content {
                grid-template-columns: 1fr 420px; 
                gap: 36px;
                padding: 0 20px;
                align-items: start;
            }
            .content-left { grid-column: 1 / 2; }
            .content-center { grid-column: 2 / 3; align-self: start; text-align: left; padding-left: 6px; max-width: 420px; }
            .content-right { grid-column: 2 / 3; margin-top: 18px; display: flex; justify-content: flex-start; }
            .main-product-image { height: 420px; }
            .product-image-item { width: 220px; height: 300px; }
        }

        
        @media (min-width: 768px) and (max-width: 1023px) {
            .section-two-content {
                grid-template-columns: 1fr 360px; 
                gap: 28px;
                padding: 0 16px;
                align-items: start;
            }
            .content-center { grid-column: 2 / 3; padding-left: 8px; max-width: 340px; text-align: left; }
            .content-right { grid-column: 2 / 3; margin-top: 14px; display: flex; justify-content: flex-start; }
            .section-title { font-size: 40px; line-height: 1.1; }
            .section-description { font-size: 15px; }
            .main-product-image { height: 380px; }
            .product-image-item { width: 200px; height: 260px; }
        }

        
        @media (min-width: 768px) and (max-width: 1024px) {
            .section-two {
                padding: 36px 18px;
            }
            .section-two-content {
                display: flex !important;
                flex-direction: column;
                gap: 22px;
                align-items: center;
                padding: 0 12px;
            }

            
            .content-center { order: 1; text-align: center; padding: 0 8px; max-width: 720px; }
            .section-title { font-size: 40px; margin-bottom: 12px; }
            .section-description { max-width: 720px; font-size: 15px; }

            
            .main-image-card { order: 2; margin: 0 auto; width: 100%; max-width: 820px; }
            .main-product-image { height: 360px; }

            
            .content-right { order: 3; display: flex; justify-content: center; padding: 0 8px; }
            .product-images-stack { flex-direction: row; gap: 14px; justify-content: center; flex-wrap: wrap; }
            .product-image-item { width: 56%; max-width: 360px; height: 200px; margin: 8px auto; border-radius: 18px; }

            
            .learn-more-btn, .view-more-btn { margin: 12px auto 0; }
        }

        
        @media (max-width: 767px) {
            .section-two {
                padding: 40px 18px;
            }
            .section-two-content {
                display: grid;
                grid-template-columns: 1fr;
                gap: 26px;
                align-items: stretch;
                padding: 0 12px;
            }

            
            .main-image-card {
                margin: 0 auto;
                width: 100%;
                max-width: 820px;
            }
            .main-product-image { height: 320px; }

            
            .content-center { padding: 0; text-align: center; }
            .section-title { font-size: 36px; margin-top: 8px; }
            .section-description { max-width: 100%; }

            
            .product-images-stack { flex-direction: row; gap: 14px; justify-content: center; flex-wrap: wrap; align-items: center; }
            .product-image-item { width: 56%; max-width: 360px; height: 200px; margin: 8px auto; border-radius: 18px; display: block; }
            .product-image-item img { object-position: center; }
        }

        
        @media (max-width: 480px) {
            .section-two { padding: 0; }
            .section-two-content { gap: 18px; }
            .main-product-image { height: 260px; }
            .section-title { font-size: 30px; }
            
            .product-image-item { width: 100%; max-width: 420px; height: 220px; margin: 10px auto; border-radius: 18px; display: block; }
            
            .product-images-stack .product-image-item:first-child {
                transform: translateX(42%);
            }
            .product-images-stack { flex-direction: column; gap: 12px; align-items: center; }
        }

        
        
        
        @media (max-width: 767px) {

            .product-feature-section {
    margin: 0 -42px 24px -42px;
    padding: 16px;
    border-radius: 16px;
    box-sizing: border-box;
    background-color: rgba(143, 65, 68, 0.1);
}

/* Section-two: force simple stacking on smaller screens to avoid overlapping elements */
@media (max-width: 900px) {
    .section-two { padding: 40px 18px; }
    .section-two-content { grid-template-columns: 1fr; gap: 22px; padding: 0 12px; }
    .main-image-card { margin: 0 auto; width: 100%; max-width: 820px; }
    .features-wrapper { margin-bottom: 30px; }
}

/* Fix footer spacing on small screens so it always sits at the bottom with no extra gap */
@media (max-width: 767px) {
    html, body { height: 100%; }
    /* avoid reintroducing 100vh which breaks mobile viewport calculations */
    .main-container { min-height: 0; flex: 1 0 auto; }
    .footer { padding-bottom: 18px; /* keep small bottom padding if needed */ }
    .footer-bottom { padding: 18px 0; }
    /* ensure sticky/absolute elements inside sections don't create extra height */
    .image-stack, .image-stack .big-image { max-height: none; }
}

            
            .product-feature-content {
                max-width: 920px;
                margin: 0 auto;
                display: flex !important;
                flex-direction: column;
                gap: 18px;
                align-items: center;
                padding: 12px;
                box-sizing: border-box;
            }

            
            .product-info-left { order: 1; width: 100%; max-width: 720px; text-align: center; padding: 0; }
            .product-image-center { order: 2; width: 100%; display: flex; justify-content: center; }
            .product-details-right { order: 3; width: 100%; max-width: 720px; padding: 0; }

            
            .featured-product-image { width: 100%; max-width: 480px; height: auto; aspect-ratio: 1/1; }
            .featured-product-image img { width: 100%; height: 100%; object-fit: cover; }

            
            .featured-product-title { font-size: 28px; line-height: 1.15; margin-bottom: 10px; }
            .product-description { font-size: 15px; line-height: 1.6; margin-bottom: 14px; }
            .price-value { font-size: 28px; }

            .learn-more-featured { margin: 10px auto 0; display: inline-block; }
            .testimonial-section { width: 100%; }
        }




@media (max-width: 767px) {
    .section-three { padding: 40px 12px; }

    
    .collection-container {
        display: flex;
        flex-direction: column;
        gap: 18px;
        padding: 28px;
        border-radius: 20px;
        align-items: center;
    }

    .collection-header {
        max-width: 100%;
        margin: 0 auto;
        text-align: center;
        padding: 6px 4px;
    }

    .collection-title {
        font-size: 34px;
        line-height: 1.12;
        margin-bottom: 12px;
    }

    .collection-description { margin: 0 auto 14px; font-size: 15px; }

    .see-more-btn { margin: 12px auto 0; }

    
    .products-showcase {
        display: grid;
        grid-template-columns: 1fr;
        gap: 18px;
        width: 100%;
    }

    .product-image { height: 260px; }
    .product-name, .product-price { text-align: center; }
}

@media (max-width: 480px) {
    .collection-title { font-size: 30px; }
    .collection-container { padding: 20px; border-radius: 16px; }
    .product-image { height: 220px; }
    .collection-description { font-size: 14px; }
}

            
            @media (max-width: 1200px) {
                .features-row {
                    grid-template-columns: repeat(2, 1fr);
                    gap: 24px;
                    padding: 0 24px;
                }
                
                .feature-item:not(:last-child)::after { display: none; }
                .feature-item { padding: 20px 16px; }
                .feature-icon { width: 72px; height: 72px; font-size: 36px; margin-bottom: 12px; }
                .feature-title { font-size: 18px; }
                .feature-description { font-size: 14px; }
            }

            @media (max-width: 767px) {
                .features-row {
                    grid-template-columns: 1fr;
                    gap: 18px;
                    padding: 0 16px;
                }
                .feature-item {
                    text-align: center;
                    padding: 18px;
                    border-radius: 14px;
                    background: rgba(143,65,68,0.04);
                    box-shadow: none;
                }

                
                    .footer-content {
                        padding: 0 20px;
                    }

                    
                    .footer-top {
                        display: flex;
                        flex-direction: column;
                        gap: 20px;
                        align-items: center;
                        text-align: center;
                    }

                    .footer-brand { max-width: 100%; }
                    .footer-links {
                        display: grid;
                        grid-template-columns: repeat(2, 1fr);
                        gap: 18px;
                        width: 100%;
                        justify-items: center;
                    }

                    .footer-column-title { font-size: 16px; }
                    .footer-link { font-size: 14px; }

                    .footer-contact { align-items: center; }

                    
                    .footer-newsletter {
                        flex-direction: column;
                        align-items: stretch;
                        gap: 12px;
                        padding: 16px;
                    }

                    .newsletter-form { min-width: 0; display: flex; gap: 8px; }
                    .newsletter-input { flex: 1; }

                    
                    .footer-bottom {
                        flex-direction: column;
                        gap: 8px;
                        text-align: center;
                        padding: 18px 0;
                    }

                    .footer-bottom-right { gap: 12px; }
                .feature-item:not(:last-child)::after { display: none; }
                .feature-icon { margin: 0 auto 12px; width: 84px; height: 84px; font-size: 40px; border-radius: 50%; }
                .feature-title { font-size: 16px; margin-bottom: 8px; }
                .feature-description { font-size: 15px; line-height: 1.5; max-width: 520px; margin: 0 auto; opacity: 0.9; }

                /* Stack product-feature columns for mobile and fix spacing */
                .product-feature-section { padding: 24px 16px; margin-bottom: 30px; }
                .product-feature-content {
                    display: flex;
                    flex-direction: column;
                    gap: 18px;
                    align-items: center;
                    text-align: center;
                }
                .product-info-left, .product-details-right {
                    width: 100%;
                    padding: 0;
                    max-width: 720px;
                }
                .product-info-left { order: 1; }
                .product-image-center { order: 2; width: 100%; display: flex; justify-content: center; }
                .product-details-right { order: 3; }
                .featured-product-image { width: 100%; max-width: 320px; height: auto; }
                .price-value { font-size: 28px; }
                .product-rating { justify-content: center; }
                .view-more-btn, .learn-more-featured { margin: 0 auto; }
            }


