/* ═══════════════════════════════════════════════════════════
   BELCANTO HoReCa — LUXURY EDITORIAL SKIN 2026
   Entirely new design. Placeholder-ready.
   ═══════════════════════════════════════════════════════════ */

/* ── GOOGLE FONTS (loaded in _header.php) ── */
/* Cormorant Garamond (display) + Outfit (body) */

/* ── CSS CUSTOM PROPERTIES ── */
:root {
    /* Brand palette — dark luxury */
    --bg-deep:       #0B0B0F;
    --bg-card:       #141419;
    --bg-elevated:   #1C1C24;
    --bg-surface:    #232330;
    --bg-warm:       #F6F2ED;
    --bg-cream:      #FAF8F5;

    --c-gold:        #C9A55C;
    --c-gold-light:  #E4CC8A;
    --c-gold-dark:   #A07D3A;
    --c-accent:      #D4443B;
    --c-success:     #4CAF7D;

    --c-text:        #E8E6E3;
    --c-text-soft:   #9E9BA4;
    --c-text-dark:   #2C2C34;
    --c-text-muted:  #6B6878;

    --c-border:      rgba(255,255,255,.06);
    --c-border-gold: rgba(201,165,92,.25);

    /* Typography */
    --f-display:     'Cormorant Garamond', 'Georgia', serif;
    --f-body:        'Outfit', 'Helvetica Neue', sans-serif;
    --f-mono:        'JetBrains Mono', monospace;

    /* Spacing & sizing */
    --radius-sm:     8px;
    --radius-md:     14px;
    --radius-lg:     22px;
    --radius-xl:     32px;

    --shadow-card:   0 4px 24px rgba(0,0,0,.35);
    --shadow-hover:  0 12px 48px rgba(0,0,0,.55);
    --shadow-glow:   0 0 40px rgba(201,165,92,.12);

    --tr-fast:       .2s cubic-bezier(.4,0,.2,1);
    --tr-med:        .4s cubic-bezier(.4,0,.2,1);
    --tr-slow:       .7s cubic-bezier(.22,1,.36,1);

    --container-max: 1400px;
    --nav-h:         72px;
}

/* ── RESET & BASE ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}
body{
    font-family:var(--f-body);
    background:var(--bg-deep);
    color:var(--c-text);
    line-height:1.6;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit;transition:color var(--tr-fast)}
ul,ol{list-style:none}
button{font-family:var(--f-body);cursor:pointer;border:none;background:none}
input,select,textarea{font-family:var(--f-body)}
::selection{background:var(--c-gold);color:var(--bg-deep)}

.container{
    width:100%;
    max-width:var(--container-max);
    margin:0 auto;
    padding:0 clamp(16px,3vw,40px);
}

/* ── REVEAL ANIMATIONS (Intersection Observer) ── */
.reveal{
    opacity:0;
    transform:translateY(40px);
    transition:opacity .8s cubic-bezier(.22,1,.36,1), transform .8s cubic-bezier(.22,1,.36,1);
}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-60px);transition:opacity .8s ease,transform .8s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(60px);transition:opacity .8s ease,transform .8s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.92);transition:opacity .7s ease,transform .7s ease}
.reveal-scale.visible{opacity:1;transform:scale(1)}

/* stagger children */
.stagger > *:nth-child(1){transition-delay:.05s}
.stagger > *:nth-child(2){transition-delay:.12s}
.stagger > *:nth-child(3){transition-delay:.19s}
.stagger > *:nth-child(4){transition-delay:.26s}
.stagger > *:nth-child(5){transition-delay:.33s}
.stagger > *:nth-child(6){transition-delay:.40s}
.stagger > *:nth-child(7){transition-delay:.47s}
.stagger > *:nth-child(8){transition-delay:.54s}

/* ═══════════════════════════════════════════════════════════
   TOP BAR (announcement)
   ═══════════════════════════════════════════════════════════ */
.top-bar{
    background:var(--c-gold);
    color:var(--bg-deep);
    text-align:center;
    font-size:12px;
    font-weight:600;
    letter-spacing:.8px;
    text-transform:uppercase;
    padding:8px 16px;
    position:relative;
    z-index:1100;
}
.top-bar a{color:var(--bg-deep);text-decoration:underline;font-weight:700}
.top-bar .close-bar{
    position:absolute;right:16px;top:50%;transform:translateY(-50%);
    font-size:16px;cursor:pointer;opacity:.6;transition:opacity .2s;
    background:none;border:none;color:var(--bg-deep);
}
.top-bar .close-bar:hover{opacity:1}

/* ═══════════════════════════════════════════════════════════
   NAVIGATION
   ═══════════════════════════════════════════════════════════ */
.main-nav{
    position:sticky;top:0;z-index:1000;
    background:rgba(11,11,15,.88);
    backdrop-filter:blur(20px) saturate(1.4);
    -webkit-backdrop-filter:blur(20px) saturate(1.4);
    border-bottom:1px solid var(--c-border);
    height:var(--nav-h);
    transition:background var(--tr-med),box-shadow var(--tr-med);
}
.main-nav.scrolled{
    background:rgba(11,11,15,.96);
    box-shadow:0 2px 32px rgba(0,0,0,.5);
}
.nav-inner{
    display:flex;align-items:center;justify-content:space-between;
    height:var(--nav-h);gap:24px;
}

/* Logo */
.nav-logo{
    font-family:var(--f-display);
    font-size:26px;font-weight:700;
    color:#fff;letter-spacing:1px;
    white-space:nowrap;
    position:relative;
}
.nav-logo span{color:var(--c-gold);font-weight:400;font-style:italic;margin-left:6px;font-size:16px;vertical-align:middle}

/* Search */
.nav-search{
    flex:1;max-width:480px;position:relative;
}
.nav-search input{
    width:100%;height:44px;
    background:var(--bg-elevated);
    border:1px solid var(--c-border);
    border-radius:100px;
    padding:0 44px 0 20px;
    color:var(--c-text);font-size:14px;
    transition:border-color var(--tr-fast),box-shadow var(--tr-fast);
}
.nav-search input::placeholder{color:var(--c-text-muted)}
.nav-search input:focus{
    outline:none;border-color:var(--c-gold);
    box-shadow:0 0 0 3px rgba(201,165,92,.15);
}
.nav-search button{
    position:absolute;right:4px;top:50%;transform:translateY(-50%);
    width:36px;height:36px;border-radius:50%;
    background:var(--c-gold);color:var(--bg-deep);
    display:flex;align-items:center;justify-content:center;
    font-size:14px;transition:background var(--tr-fast);
}
.nav-search button:hover{background:var(--c-gold-light)}

/* Nav actions */
.nav-actions{display:flex;align-items:center;gap:6px}
.nav-act{
    width:42px;height:42px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:18px;color:var(--c-text-soft);
    transition:color var(--tr-fast),background var(--tr-fast);
    position:relative;
}
.nav-act:hover{color:#fff;background:var(--bg-elevated)}
.nav-act .badge{
    position:absolute;top:2px;right:2px;
    width:18px;height:18px;border-radius:50%;
    background:var(--c-accent);color:#fff;
    font-size:10px;font-weight:700;
    display:flex;align-items:center;justify-content:center;
    line-height:1;
}

/* Mobile toggle */
.nav-toggle{display:none;width:42px;height:42px;border-radius:50%;align-items:center;justify-content:center;font-size:20px;color:#fff}

/* ── Category ribbon (below nav) ── */
.cat-ribbon{
    background:var(--bg-card);
    border-bottom:1px solid var(--c-border);
    overflow:hidden;
}
.cat-ribbon-inner{
    display:flex;align-items:center;gap:0;
    overflow-x:auto;scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
    padding:0;
}
.cat-ribbon-inner::-webkit-scrollbar{display:none}
.cat-ribbon-link{
    flex-shrink:0;
    padding:13px 22px;
    font-size:13px;font-weight:500;
    color:var(--c-text-muted);
    text-transform:uppercase;letter-spacing:.6px;
    white-space:nowrap;
    transition:color var(--tr-fast),background var(--tr-fast);
    border-right:1px solid var(--c-border);
}
.cat-ribbon-link:first-child{border-left:1px solid var(--c-border)}
.cat-ribbon-link:hover,.cat-ribbon-link.active{
    color:var(--c-gold);background:rgba(201,165,92,.06);
}

/* ═══════════════════════════════════════════════════════════
   HERO — CINEMATIC FULLSCREEN
   ═══════════════════════════════════════════════════════════ */
.hero{
    position:relative;
    min-height:85vh;
    display:flex;align-items:center;
    overflow:hidden;
    background:var(--bg-deep);
}
.hero-bg{
    position:absolute;inset:0;
    background:linear-gradient(135deg, #1a1520 0%, #0d1117 40%, #0f0f18 100%);
}
.hero-bg::after{
    content:'';position:absolute;inset:0;
    background:
        radial-gradient(ellipse 80% 60% at 70% 40%, rgba(201,165,92,.08) 0%, transparent 60%),
        radial-gradient(ellipse 50% 50% at 20% 80%, rgba(212,68,59,.05) 0%, transparent 50%);
}
/* Decorative grid pattern */
.hero-grid{
    position:absolute;inset:0;
    background-image:
        linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
    background-size:60px 60px;
    mask-image:radial-gradient(ellipse 70% 70% at 60% 50%, black, transparent);
    -webkit-mask-image:radial-gradient(ellipse 70% 70% at 60% 50%, black, transparent);
}

.hero-content{
    position:relative;z-index:2;
    display:grid;grid-template-columns:1fr 1fr;gap:60px;
    align-items:center;width:100%;
    padding:80px 0;
}
.hero-text{max-width:600px}
.hero-badge{
    display:inline-flex;align-items:center;gap:8px;
    background:rgba(201,165,92,.1);border:1px solid var(--c-border-gold);
    border-radius:100px;padding:6px 16px;
    font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;
    color:var(--c-gold);margin-bottom:24px;
}
.hero-badge i{font-size:10px}
.hero h1{
    font-family:var(--f-display);
    font-size:clamp(40px,5.5vw,76px);
    font-weight:300;line-height:1.08;
    color:#fff;margin-bottom:20px;
    letter-spacing:-1px;
}
.hero h1 em{
    font-style:italic;font-weight:600;
    background:linear-gradient(135deg,var(--c-gold),var(--c-gold-light));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
}
.hero-sub{
    font-size:17px;line-height:1.7;
    color:var(--c-text-soft);max-width:440px;
    margin-bottom:36px;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}

/* Buttons — global */
.btn-gold{
    display:inline-flex;align-items:center;gap:10px;
    padding:14px 32px;border-radius:100px;
    background:var(--c-gold);color:var(--bg-deep);
    font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1px;
    transition:all var(--tr-fast);
    box-shadow:0 4px 20px rgba(201,165,92,.25);
}
.btn-gold:hover{
    background:var(--c-gold-light);
    box-shadow:0 8px 32px rgba(201,165,92,.35);
    transform:translateY(-2px);
}
.btn-ghost{
    display:inline-flex;align-items:center;gap:10px;
    padding:14px 32px;border-radius:100px;
    background:transparent;color:#fff;
    border:1px solid rgba(255,255,255,.2);
    font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:1px;
    transition:all var(--tr-fast);
}
.btn-ghost:hover{border-color:var(--c-gold);color:var(--c-gold)}

/* Hero visual (right side) */
.hero-visual{
    position:relative;display:flex;
    justify-content:center;align-items:center;
}
.hero-card-stack{
    position:relative;width:380px;height:460px;
}
.hero-card{
    position:absolute;
    width:280px;height:360px;
    border-radius:var(--radius-lg);
    overflow:hidden;
    box-shadow:var(--shadow-card);
    transition:transform .6s cubic-bezier(.22,1,.36,1);
}
.hero-card img{width:100%;height:100%;object-fit:cover}
.hero-card:nth-child(1){top:0;left:0;z-index:3;transform:rotate(-4deg)}
.hero-card:nth-child(2){top:30px;left:80px;z-index:2;transform:rotate(3deg)}
.hero-card:nth-child(3){top:60px;left:40px;z-index:1;transform:rotate(-1deg);opacity:.7}
.hero-card-stack:hover .hero-card:nth-child(1){transform:rotate(-8deg) translateX(-20px)}
.hero-card-stack:hover .hero-card:nth-child(2){transform:rotate(6deg) translateX(20px)}

/* Hero stats bar */
.hero-stats{
    display:flex;gap:40px;margin-top:48px;
    padding-top:28px;border-top:1px solid var(--c-border);
}
.hero-stat{text-align:left}
.hero-stat strong{
    display:block;font-family:var(--f-display);
    font-size:32px;font-weight:700;color:var(--c-gold);
    line-height:1;
}
.hero-stat span{font-size:12px;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:4px;display:block}


/* ═══════════════════════════════════════════════════════════
   SECTION HEADERS (reusable)
   ═══════════════════════════════════════════════════════════ */
.sec{padding:80px 0}
.sec-header{margin-bottom:44px;display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px}
.sec-header h2{
    font-family:var(--f-display);
    font-size:clamp(28px,3.5vw,44px);
    font-weight:400;color:#fff;
    line-height:1.15;
}
.sec-header h2 em{font-style:italic;color:var(--c-gold)}
.sec-header p{font-size:14px;color:var(--c-text-muted);max-width:400px}
.sec-link{
    font-size:13px;font-weight:600;text-transform:uppercase;
    letter-spacing:.8px;color:var(--c-gold);
    display:inline-flex;align-items:center;gap:8px;
    transition:gap var(--tr-fast);
}
.sec-link:hover{gap:14px;color:var(--c-gold-light)}

/* ═══════════════════════════════════════════════════════════
   MARQUEE / BRANDS TICKER
   ═══════════════════════════════════════════════════════════ */
.marquee-wrap{
    border-top:1px solid var(--c-border);
    border-bottom:1px solid var(--c-border);
    padding:28px 0;overflow:hidden;
    background:var(--bg-card);
}
.marquee-track{
    display:flex;gap:60px;
    animation:marquee 30s linear infinite;
    width:max-content;
}
.marquee-item{
    flex-shrink:0;
    font-family:var(--f-display);
    font-size:22px;font-weight:600;
    color:var(--c-text-muted);
    text-transform:uppercase;letter-spacing:3px;
    opacity:.4;white-space:nowrap;
}
.marquee-item span{color:var(--c-gold);margin:0 20px;font-size:10px;vertical-align:middle}
@keyframes marquee{
    0%{transform:translateX(0)}
    100%{transform:translateX(-50%)}
}

/* ═══════════════════════════════════════════════════════════
   CATEGORY CARDS (scrollable)
   ═══════════════════════════════════════════════════════════ */
.cat-scroll{
    display:flex;gap:20px;
    overflow-x:auto;scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
    padding-bottom:8px;
    scroll-snap-type:x mandatory;
}
.cat-scroll::-webkit-scrollbar{display:none}
.cat-card{
    flex-shrink:0;
    width:240px;
    position:relative;
    border-radius:var(--radius-lg);
    overflow:hidden;
    scroll-snap-align:start;
    cursor:pointer;
    transition:transform var(--tr-med);
}
.cat-card:hover{transform:translateY(-6px)}
.cat-card-img{
    width:100%;height:320px;
    object-fit:cover;
    transition:transform .6s ease;
}
.cat-card:hover .cat-card-img{transform:scale(1.08)}
.cat-card-overlay{
    position:absolute;inset:0;
    background:linear-gradient(to top, rgba(0,0,0,.75) 0%, transparent 50%);
    display:flex;flex-direction:column;justify-content:flex-end;
    padding:24px 20px;
}
.cat-card-name{
    font-family:var(--f-display);
    font-size:20px;font-weight:600;color:#fff;
}
.cat-card-count{font-size:12px;color:var(--c-gold);margin-top:4px;text-transform:uppercase;letter-spacing:.6px}

/* ═══════════════════════════════════════════════════════════
   PRODUCT CARDS
   ═══════════════════════════════════════════════════════════ */
.products-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(270px, 1fr));
    gap:24px;
}
.prod-card{
    background:var(--bg-card);
    border:1px solid var(--c-border);
    border-radius:var(--radius-md);
    overflow:hidden;
    transition:transform var(--tr-med),box-shadow var(--tr-med),border-color var(--tr-med);
    position:relative;
    display:flex;flex-direction:column;
}
.prod-card:hover{
    transform:translateY(-6px);
    box-shadow:var(--shadow-hover);
    border-color:var(--c-border-gold);
}
.prod-card-img{
    position:relative;
    width:100%;aspect-ratio:1/1;
    overflow:hidden;
    background:var(--bg-elevated);
}
.prod-card-img img{
    width:100%;height:100%;object-fit:cover;
    transition:transform .5s ease;
}
.prod-card:hover .prod-card-img img{transform:scale(1.06)}

/* Badges on product */
.prod-badge{
    position:absolute;top:12px;left:12px;
    padding:4px 12px;border-radius:100px;
    font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;
    z-index:2;
}
.prod-badge--new{background:var(--c-gold);color:var(--bg-deep)}
.prod-badge--sale{background:var(--c-accent);color:#fff}
.prod-badge--hot{background:#FF6B35;color:#fff}

/* Wishlist heart */
.prod-wish{
    position:absolute;top:12px;right:12px;
    width:36px;height:36px;border-radius:50%;
    background:rgba(0,0,0,.4);backdrop-filter:blur(8px);
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-size:14px;z-index:2;
    opacity:0;transform:scale(.8);
    transition:opacity var(--tr-fast),transform var(--tr-fast),background var(--tr-fast);
    cursor:pointer;
}
.prod-card:hover .prod-wish{opacity:1;transform:scale(1)}
.prod-wish:hover{background:var(--c-accent)}
.prod-wish.liked{opacity:1;transform:scale(1);background:var(--c-accent)}

/* Quick-add overlay */
.prod-quick{
    position:absolute;bottom:0;left:0;right:0;
    padding:12px;
    background:linear-gradient(to top,rgba(0,0,0,.7),transparent);
    transform:translateY(100%);
    transition:transform var(--tr-med);
}
.prod-card:hover .prod-quick{transform:translateY(0)}
.prod-quick button{
    width:100%;padding:10px;border-radius:var(--radius-sm);
    background:var(--c-gold);color:var(--bg-deep);
    font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;
    transition:background var(--tr-fast);
}
.prod-quick button:hover{background:var(--c-gold-light)}

/* Card body */
.prod-card-body{
    padding:18px 18px 20px;
    flex:1;display:flex;flex-direction:column;
}
.prod-card-cat{
    font-size:11px;color:var(--c-text-muted);
    text-transform:uppercase;letter-spacing:.8px;
    margin-bottom:6px;
}
.prod-card-name{
    font-family:var(--f-display);
    font-size:17px;font-weight:600;color:#fff;
    line-height:1.3;margin-bottom:auto;
    transition:color var(--tr-fast);
}
.prod-card:hover .prod-card-name{color:var(--c-gold)}
.prod-card-footer{
    display:flex;align-items:center;justify-content:space-between;
    margin-top:14px;padding-top:12px;
    border-top:1px solid var(--c-border);
}
.prod-price{font-size:18px;font-weight:700;color:var(--c-gold)}
.prod-price-old{font-size:13px;color:var(--c-text-muted);text-decoration:line-through;margin-right:8px}
.prod-rating{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--c-gold)}
.prod-rating i{font-size:11px}

/* ═══════════════════════════════════════════════════════════
   FEATURED BANNER (split)
   ═══════════════════════════════════════════════════════════ */
.feat-banner{
    display:grid;grid-template-columns:1fr 1fr;
    min-height:500px;overflow:hidden;
    border-radius:var(--radius-lg);
    background:var(--bg-card);
    border:1px solid var(--c-border);
}
.feat-banner-img{
    position:relative;overflow:hidden;
}
.feat-banner-img img{width:100%;height:100%;object-fit:cover;transition:transform 8s ease}
.feat-banner:hover .feat-banner-img img{transform:scale(1.05)}
.feat-banner-content{
    display:flex;flex-direction:column;justify-content:center;
    padding:60px 56px;
}
.feat-banner-tag{
    font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;
    color:var(--c-gold);margin-bottom:16px;
}
.feat-banner h3{
    font-family:var(--f-display);
    font-size:clamp(28px,3vw,42px);
    font-weight:400;color:#fff;
    line-height:1.15;margin-bottom:16px;
}
.feat-banner h3 em{font-style:italic;color:var(--c-gold)}
.feat-banner p{font-size:15px;color:var(--c-text-soft);line-height:1.7;margin-bottom:28px;max-width:420px}

/* ═══════════════════════════════════════════════════════════
   BENEFITS BAR
   ═══════════════════════════════════════════════════════════ */
.benefits{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:1px;
    background:var(--c-border);
    border-radius:var(--radius-md);
    overflow:hidden;
}
.benefit{
    background:var(--bg-card);
    padding:36px 28px;
    text-align:center;
    transition:background var(--tr-fast);
}
.benefit:hover{background:var(--bg-elevated)}
.benefit-icon{
    width:52px;height:52px;border-radius:50%;
    background:rgba(201,165,92,.1);
    display:flex;align-items:center;justify-content:center;
    margin:0 auto 16px;
    font-size:20px;color:var(--c-gold);
}
.benefit h5{font-size:14px;font-weight:700;color:#fff;margin-bottom:6px}
.benefit p{font-size:12px;color:var(--c-text-muted);line-height:1.5}

/* ═══════════════════════════════════════════════════════════
   TESTIMONIALS / REVIEWS
   ═══════════════════════════════════════════════════════════ */
.testimonials-track{
    display:flex;gap:24px;
    overflow-x:auto;scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory;
    padding-bottom:8px;
}
.testimonials-track::-webkit-scrollbar{display:none}
.testi-card{
    flex-shrink:0;width:380px;
    background:var(--bg-card);
    border:1px solid var(--c-border);
    border-radius:var(--radius-md);
    padding:32px;
    scroll-snap-align:start;
    transition:border-color var(--tr-fast);
}
.testi-card:hover{border-color:var(--c-border-gold)}
.testi-stars{color:var(--c-gold);font-size:13px;margin-bottom:16px;letter-spacing:2px}
.testi-text{font-size:14px;line-height:1.7;color:var(--c-text-soft);margin-bottom:20px;font-style:italic}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-avatar{
    width:40px;height:40px;border-radius:50%;
    background:var(--bg-elevated);
    display:flex;align-items:center;justify-content:center;
    font-weight:700;font-size:14px;color:var(--c-gold);
}
.testi-name{font-size:13px;font-weight:600;color:#fff}
.testi-role{font-size:11px;color:var(--c-text-muted)}

/* ═══════════════════════════════════════════════════════════
   INSTAGRAM / GALLERY MOSAIC
   ═══════════════════════════════════════════════════════════ */
.gallery-mosaic{
    display:grid;
    grid-template-columns:repeat(6,1fr);
    gap:4px;
}
.gallery-item{
    position:relative;overflow:hidden;
    aspect-ratio:1/1;cursor:pointer;
}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease,filter .5s ease}
.gallery-item:hover img{transform:scale(1.1);filter:brightness(.7)}
.gallery-item::after{
    content:'\f16d';font-family:'Font Awesome 6 Brands';
    position:absolute;inset:0;
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-size:24px;
    opacity:0;transition:opacity .3s ease;
}
.gallery-item:hover::after{opacity:1}

/* ═══════════════════════════════════════════════════════════
   NEWSLETTER — REDESIGNED
   ═══════════════════════════════════════════════════════════ */
.nl-section{
    padding:0;
    background:transparent;
}
.nl-wrap{
    display:grid;grid-template-columns:1fr 1fr;
    background:linear-gradient(135deg, #1a1520, #14111e);
    border:1px solid var(--c-border);
    border-radius:var(--radius-xl);
    overflow:hidden;
    max-width:var(--container-max);
    margin:0 auto;
    position:relative;
}
.nl-wrap::before{
    content:'';position:absolute;inset:0;
    background:radial-gradient(circle at 80% 20%, rgba(201,165,92,.08), transparent 50%);
    pointer-events:none;
}
.nl-img{
    width:100%;height:100%;min-height:360px;
    object-fit:cover;display:block;
}
.nl-content{
    padding:56px 48px;
    display:flex;flex-direction:column;justify-content:center;
    position:relative;z-index:1;
}
.nl-content h2{
    font-family:var(--f-display);
    font-size:clamp(26px,3vw,38px);
    font-weight:400;color:#fff;
    margin-bottom:8px;line-height:1.2;
}
.nl-content h2 em{font-style:italic;color:var(--c-gold)}
.nl-content p{font-size:14px;color:var(--c-text-soft);margin-bottom:24px;font-style:italic}
.nl-form-row{display:flex;gap:0}
.nl-form-row input{
    flex:1;height:52px;padding:0 20px;
    background:var(--bg-elevated);
    border:1px solid var(--c-border);
    border-right:none;
    border-radius:var(--radius-sm) 0 0 var(--radius-sm);
    color:var(--c-text);font-size:14px;
    transition:border-color var(--tr-fast);
}
.nl-form-row input::placeholder{color:var(--c-text-muted)}
.nl-form-row input:focus{outline:none;border-color:var(--c-gold)}
.nl-form-row button{
    height:52px;padding:0 28px;
    background:var(--c-gold);color:var(--bg-deep);
    font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;
    border-radius:0 var(--radius-sm) var(--radius-sm) 0;
    transition:background var(--tr-fast);white-space:nowrap;
}
.nl-form-row button:hover{background:var(--c-gold-light)}
.nl-legal{margin-top:14px;font-size:11px;color:var(--c-text-muted);line-height:1.7}
.nl-legal a{color:var(--c-gold);text-decoration:underline}

/* ═══════════════════════════════════════════════════════════
   FOOTER — REDESIGNED
   ═══════════════════════════════════════════════════════════ */
.site-ft{
    background:var(--bg-deep);
    color:var(--c-text-soft);
    padding-top:64px;
    font-size:14px;
    border-top:1px solid var(--c-border);
}
.site-ft a{color:var(--c-text-soft);transition:color var(--tr-fast)}
.site-ft a:hover{color:var(--c-gold)}
.ft-heading{
    color:#fff;font-size:12px;font-weight:700;
    text-transform:uppercase;letter-spacing:1.5px;
    margin-bottom:20px;
    position:relative;
    padding-bottom:12px;
}
.ft-heading::after{
    content:'';position:absolute;bottom:0;left:0;
    width:24px;height:2px;background:var(--c-gold);
    border-radius:2px;
}
.ft-links li+li{margin-top:10px}
.ft-links a{font-size:13px;display:inline-flex;align-items:center;gap:6px}
.ft-links a::before{
    content:'';width:0;height:1px;
    background:var(--c-gold);
    transition:width var(--tr-fast);
}
.ft-links a:hover::before{width:12px}
.ft-contact{padding-left:32px;border-left:1px solid var(--c-border)}
.ft-contact__txt{margin:10px 0 2px;font-size:12px;color:var(--c-text-muted)}
.ft-contact__big{
    font-family:var(--f-display);
    color:var(--c-gold);font-size:22px;font-weight:600;
    display:block;
}
.ft-contact__small{font-size:12px;color:var(--c-text-muted);line-height:1.7}
.ft-social{display:flex;gap:10px;margin-top:16px}
.ft-social a{
    width:38px;height:38px;border-radius:50%;
    border:1px solid var(--c-border);
    display:flex;align-items:center;justify-content:center;
    font-size:14px;color:var(--c-text-soft);
    transition:all var(--tr-fast);
}
.ft-social a:hover{
    border-color:var(--c-gold);color:var(--c-gold);
    background:rgba(201,165,92,.08);
}
.site-ft__bottom{
    border-top:1px solid var(--c-border);
    margin-top:48px;padding:20px 0;
    font-size:11px;text-align:center;color:var(--c-text-muted);
    letter-spacing:.3px;
}
.site-ft__bottom a{color:var(--c-gold)}

/* ═══════════════════════════════════════════════════════════
   SCROLL-TO-TOP
   ═══════════════════════════════════════════════════════════ */
.scroll-top{
    position:fixed;bottom:28px;right:28px;
    width:44px;height:44px;border-radius:50%;
    background:var(--c-gold);color:var(--bg-deep);
    display:flex;align-items:center;justify-content:center;
    font-size:16px;z-index:999;
    opacity:0;transform:translateY(20px);
    transition:opacity var(--tr-fast),transform var(--tr-fast),background var(--tr-fast);
    box-shadow:0 4px 16px rgba(0,0,0,.4);
}
.scroll-top.vis{opacity:1;transform:translateY(0)}
.scroll-top:hover{background:var(--c-gold-light);transform:translateY(-3px)}

/* ═══════════════════════════════════════════════════════════
   COUNTDOWN / PROMO TIMER
   ═══════════════════════════════════════════════════════════ */
.promo-timer{
    display:flex;gap:16px;margin-top:20px;
}
.timer-box{
    text-align:center;
    background:rgba(255,255,255,.06);
    border:1px solid var(--c-border);
    border-radius:var(--radius-sm);
    padding:12px 16px;min-width:64px;
}
.timer-box .num{
    font-family:var(--f-display);
    font-size:28px;font-weight:700;
    color:var(--c-gold);display:block;line-height:1;
}
.timer-box .lbl{font-size:9px;text-transform:uppercase;letter-spacing:1px;color:var(--c-text-muted);margin-top:4px;display:block}

/* ═══════════════════════════════════════════════════════════
   RECENTLY VIEWED (horizontal scroll)
   ═══════════════════════════════════════════════════════════ */
.recent-scroll{
    display:flex;gap:16px;
    overflow-x:auto;scrollbar-width:none;
    padding-bottom:4px;
}
.recent-scroll::-webkit-scrollbar{display:none}
.recent-item{
    flex-shrink:0;width:160px;
    text-align:center;cursor:pointer;
}
.recent-item img{
    width:160px;height:160px;
    object-fit:cover;border-radius:var(--radius-sm);
    border:1px solid var(--c-border);
    transition:border-color var(--tr-fast);
}
.recent-item:hover img{border-color:var(--c-gold)}
.recent-item p{font-size:12px;color:var(--c-text-soft);margin-top:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ═══════════════════════════════════════════════════════════
   MOBILE DRAWER
   ═══════════════════════════════════════════════════════════ */
.mobile-drawer{
    position:fixed;inset:0;z-index:2000;
    pointer-events:none;
}
.mobile-drawer.open{pointer-events:all}
.drawer-overlay{
    position:absolute;inset:0;
    background:rgba(0,0,0,.6);
    opacity:0;transition:opacity .3s ease;
}
.mobile-drawer.open .drawer-overlay{opacity:1}
.drawer-panel{
    position:absolute;top:0;left:0;bottom:0;
    width:min(340px,85vw);
    background:var(--bg-card);
    transform:translateX(-100%);
    transition:transform .35s cubic-bezier(.22,1,.36,1);
    overflow-y:auto;
    display:flex;flex-direction:column;
}
.mobile-drawer.open .drawer-panel{transform:translateX(0)}
.drawer-head{
    display:flex;align-items:center;justify-content:space-between;
    padding:20px 24px;border-bottom:1px solid var(--c-border);
}
.drawer-head .nav-logo{font-size:22px}
.drawer-close{font-size:22px;color:var(--c-text-soft);cursor:pointer}
.drawer-links{padding:20px 24px;flex:1}
.drawer-links a{
    display:block;padding:14px 0;
    font-size:15px;font-weight:500;color:var(--c-text);
    border-bottom:1px solid var(--c-border);
    transition:color var(--tr-fast);
}
.drawer-links a:hover{color:var(--c-gold)}
.drawer-foot{padding:20px 24px;border-top:1px solid var(--c-border)}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════ */
@media(max-width:1199.98px){
    .hero-content{grid-template-columns:1fr;gap:40px}
    .hero-visual{display:none}
    .feat-banner{grid-template-columns:1fr}
    .feat-banner-img{min-height:300px}
}
@media(max-width:991.98px){
    :root{--nav-h:64px}
    .nav-search{display:none}
    .nav-toggle{display:flex}
    .benefits{grid-template-columns:repeat(2,1fr)}
    .nl-wrap{grid-template-columns:1fr}
    .nl-img{min-height:240px;max-height:300px}
    .nl-content{padding:32px 24px}
    .ft-contact{border-left:none;padding-left:0;margin-top:20px}
    .gallery-mosaic{grid-template-columns:repeat(3,1fr)}
    .hero-stats{gap:24px}
    .hero-stat strong{font-size:26px}
}
@media(max-width:575.98px){
    .sec{padding:48px 0}
    .hero{min-height:70vh}
    .hero h1{font-size:clamp(32px,8vw,48px)}
    .hero-actions{flex-direction:column;gap:10px}
    .hero-actions .btn-gold,.hero-actions .btn-ghost{width:100%;justify-content:center}
    .hero-stats{flex-wrap:wrap;gap:16px 32px}
    .benefits{grid-template-columns:1fr}
    .products-grid{grid-template-columns:repeat(2,1fr);gap:12px}
    .prod-card-body{padding:12px}
    .prod-card-name{font-size:14px}
    .prod-price{font-size:15px}
    .cat-card{width:180px}
    .cat-card-img{height:240px}
    .testi-card{width:300px}
    .feat-banner-content{padding:32px 24px}
    .nl-form-row{flex-direction:column;gap:10px}
    .nl-form-row input{border-radius:var(--radius-sm);border-right:1px solid var(--c-border);height:50px;font-size:16px}
    .nl-form-row button{border-radius:var(--radius-sm);height:50px}
    .gallery-mosaic{grid-template-columns:repeat(2,1fr)}
}
