/* ============================================
   LAKSHANA DHIVYAM FOODS — GLOBAL STYLESHEET
   ============================================ */

/* ===== CSS VARIABLES ===== */
:root {
    --clr-primary:      #8B4513;
    --clr-primary-dk:   #6B3410;
    --clr-secondary:    #D2691E;
    --clr-accent:       #F4C430;
    --clr-accent-lt:    #F7D560;
    --clr-bg:           #FFF8F0;
    --clr-bg-alt:       #FFF2E0;
    --clr-white:        #FFFFFF;
    --clr-text:         #2B2B2B;
    --clr-text-lt:      #666666;
    --clr-text-muted:   #999999;
    --clr-black:        #1A1A1A;

    --sh-sm:  0 2px 10px rgba(139,69,19,.08);
    --sh-md:  0 6px 24px rgba(139,69,19,.12);
    --sh-lg:  0 12px 48px rgba(139,69,19,.16);
    --sh-xl:  0 20px 70px rgba(139,69,19,.22);

    --r-sm: 8px;
    --r-md: 14px;
    --r-lg: 22px;
    --r-xl: 50px;

    --tr: all .3s cubic-bezier(.4,0,.2,1);
    --tr-sl: all .55s cubic-bezier(.4,0,.2,1);

    --nav-h: 76px;
}

/* ===== RESET ===== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; scroll-padding-top:var(--nav-h); }
body {
    font-family:'Poppins',sans-serif;
    background:var(--clr-bg);
    color:var(--clr-text);
    line-height:1.7;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
}
a { text-decoration:none; color:inherit; transition:var(--tr); }
img { max-width:100%; height:auto; display:block; }
button { border:none; outline:none; cursor:pointer; font-family:inherit; }
ul { list-style:none; }

/* ===== CONTAINER ===== */
.container { max-width:1200px; margin:0 auto; padding:0 24px; }

/* ===== SECTION SPACING ===== */
.section { padding:100px 0; }

/* ===== SECTION HEADER ===== */
.section-head { text-align:center; margin-bottom:56px; }
.sec-badge {
    display:inline-flex; align-items:center; gap:7px;
    background:linear-gradient(135deg,rgba(139,69,19,.09),rgba(210,105,30,.09));
    color:var(--clr-primary); padding:8px 20px; border-radius:var(--r-xl);
    font-size:.8rem; font-weight:600; letter-spacing:1.2px;
    text-transform:uppercase; margin-bottom:14px;
}
.sec-title {
    font-family:'Playfair Display',serif;
    font-size:clamp(1.9rem,3.8vw,2.7rem);
    font-weight:700; color:var(--clr-primary-dk); line-height:1.25;
    margin-bottom:12px;
}
.sec-title-left { text-align:left; }
.sec-sub { font-size:1rem; color:var(--clr-text-lt); max-width:560px; margin:0 auto 6px; }
.sec-deco {
    display:flex; align-items:center; justify-content:center;
    gap:14px; margin-top:18px;
}
.deco-line {
    width:55px; height:2px;
    background:linear-gradient(90deg,var(--clr-accent),var(--clr-secondary));
    border-radius:2px;
}
.sec-deco i { color:var(--clr-accent); font-size:1rem; }

/* ===== SCROLL REVEAL ===== */
.reveal-up, .reveal-left, .reveal-right {
    opacity:0; transition:opacity .7s ease, transform .7s ease;
}
.reveal-up    { transform:translateY(40px); }
.reveal-left  { transform:translateX(-50px); }
.reveal-right { transform:translateX(50px); }
.reveal-up.in, .reveal-left.in, .reveal-right.in {
    opacity:1; transform:translate(0);
}

/* ============================================
   NAVBAR
   ============================================ */
.navbar {
    position:fixed; top:0; left:0; width:100%;
    z-index:9999;
    background:rgba(255,248,240,.94);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    border-bottom:1px solid transparent;
    transition:var(--tr);
    height:var(--nav-h);
}
.navbar.scrolled {
    background:rgba(255,248,240,.98);
    box-shadow:var(--sh-md);
    border-bottom:1px solid rgba(139,69,19,.09);
}
.nav-container {
    max-width:1280px; margin:0 auto; padding:0 24px;
    height:100%;
    display:flex; align-items:center; justify-content:space-between; gap:20px;
    width:100%;
}

/* Logo */
.nav-logo {
    display:flex; align-items:center; gap:11px; flex-shrink:0; z-index:10001;
    transition:var(--tr);
}
.nav-logo:hover {
    transform:translateY(-2px);
}
.logo-icon {
    width:44px; height:44px;
    background:linear-gradient(135deg,var(--clr-primary),var(--clr-secondary));
    border-radius:11px; display:flex; align-items:center; justify-content:center;
    color:var(--clr-white); font-size:1.15rem; transform:rotate(-5deg);
    flex-shrink:0; transition:var(--tr);
    box-shadow:var(--sh-md);
}
.nav-logo:hover .logo-icon {
    transform:rotate(0deg) scale(1.05);
    box-shadow:var(--sh-lg);
}
.logo-text { display:flex; flex-direction:column; line-height:1; }
.logo-main {
    font-family:'Playfair Display',serif; font-weight:700;
    font-size:1.05rem; color:var(--clr-primary-dk); white-space:nowrap;
}
.logo-sub {
    font-size:.6rem; font-weight:700; letter-spacing:4px;
    color:var(--clr-secondary); text-transform:uppercase; margin-top:2px;
}

/* Nav Menu */
.nav-menu {
    display:flex; align-items:center; justify-content:center;
    gap:8px; margin:0 auto; flex:1;
    position:static; right:auto; bottom:auto; height:auto;
    background:transparent; padding:0; box-shadow:none;
    width:auto; max-width:none; overflow:visible;
}
.nav-link {
    padding:9px 18px; font-size:.9rem; font-weight:500;
    color:var(--clr-text); border-radius:var(--r-md);
    position:relative; white-space:nowrap; display:inline-flex;
    align-items:center; justify-content:center;
    transition:var(--tr);
}
.nav-link::after {
    content:''; position:absolute; bottom:6px; left:50%;
    transform:translateX(-50%); width:0; height:2px;
    background:linear-gradient(90deg,var(--clr-primary),var(--clr-secondary));
    border-radius:2px; transition:var(--tr);
}
.nav-link:hover {
    color:var(--clr-primary);
    background:rgba(139,69,19,.05);
}
.nav-link.active {
    color:var(--clr-primary);
}
.nav-link:hover::after, .nav-link.active::after { width:65%; }

/* Nav Actions */
.nav-actions {
    display:flex; align-items:center; gap:6px; flex-shrink:0;
}
.nav-icon-btn {
    width:42px; height:42px; border-radius:50%;
    background:transparent; color:var(--clr-text); font-size:1rem;
    display:flex; align-items:center; justify-content:center; position:relative;
    transition:var(--tr);
    cursor:pointer;
}
.nav-icon-btn:hover {
    background:rgba(139,69,19,.1); color:var(--clr-primary);
    transform:scale(1.1);
}
.cart-count {
    position:absolute; top:0px; right:0px;
    width:20px; height:20px;
    background:var(--clr-secondary); color:var(--clr-white);
    font-size:.65rem; font-weight:700; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    transition:var(--tr);
    border:2px solid var(--clr-bg);
}

/* Hamburger */
.hamburger {
    display:none; flex-direction:column; gap:5px;
    background:transparent; border:none; padding:8px;
    cursor:pointer; z-index:10001; width:auto;
    align-items:flex-end; border-radius:8px;
    transition:var(--tr);
}
.hamburger:hover {
    background:rgba(139,69,19,.1);
}
.hamburger:active {
    transform:scale(0.95);
}
.bar {
    width:26px; height:3px; background:var(--clr-primary);
    border-radius:3px; transition:var(--tr); display:block;
    transform-origin:center;
}
.hamburger.open .bar:nth-child(1) {
    transform:rotate(45deg) translate(8px,8px);
    background:var(--clr-primary);
}
.hamburger.open .bar:nth-child(2) {
    opacity:0;
    transform:translateX(-12px);
}
.hamburger.open .bar:nth-child(3) {
    transform:rotate(-45deg) translate(8px,-8px);
    background:var(--clr-primary);
}

/* ============================================
   HERO  — Full Viewport, Single Screen
   ============================================ */
.hero {
    position:relative;
    width:100%;
    height:100vh;           /* EXACTLY ONE SCREEN */
    min-height:600px;
    max-height:1000px;
    display:flex;
    flex-direction:column;
    overflow:hidden;
}

/* BG image */
.hero-bg {
    position:absolute; inset:0; z-index:0;
}
.hero-bg-img {
    width:100%; height:100%; object-fit:cover; object-position:center;
}
.hero-overlay {
    position:absolute; inset:0;
    background:linear-gradient(
        135deg,
        rgba(43,15,5,.82) 0%,
        rgba(90,35,10,.72) 50%,
        rgba(139,69,19,.45) 100%
    );
}

/* Content */
.hero-content {
    position:relative; z-index:2;
    flex:1;
    display:flex; align-items:center;
    padding:var(--nav-h) 24px 0;
    max-width:1200px; margin:0 auto; width:100%;
}
.hero-text-block { max-width:640px; }

.hero-tag {
    display:inline-flex; align-items:center; gap:8px;
    background:rgba(244,196,48,.15);
    border:1px solid rgba(244,196,48,.35);
    color:var(--clr-accent); padding:9px 20px; border-radius:var(--r-xl);
    font-size:.82rem; font-weight:600; margin-bottom:22px;
    animation:pulse-glow 2.5s infinite;
}
@keyframes pulse-glow {
    0%,100% { box-shadow:0 0 0 0 rgba(244,196,48,.2); }
    50%      { box-shadow:0 0 0 10px rgba(244,196,48,.0); }
}

.hero-heading {
    font-family:'Playfair Display',serif;
    font-size:clamp(2.4rem,5.5vw,4rem);
    font-weight:800; color:var(--clr-white);
    line-height:1.15; margin-bottom:20px;
}
.hero-heading-accent {
    font-family:'Dancing Script',cursive;
    font-size:clamp(2.8rem,6.5vw,4.8rem);
    color:var(--clr-accent); display:block;
}

.hero-desc {
    font-size:clamp(.9rem,1.4vw,1.05rem);
    color:rgba(255,255,255,.8);
    line-height:1.8; max-width:500px;
    margin-bottom:32px;
}

.hero-buttons {
    display:flex; gap:14px; flex-wrap:wrap;
}
.btn-hero-primary {
    display:inline-flex; align-items:center; gap:9px;
    background:linear-gradient(135deg,var(--clr-primary),var(--clr-secondary));
    color:var(--clr-white); padding:14px 32px; border-radius:var(--r-xl);
    font-weight:600; font-size:.95rem;
    box-shadow:0 4px 18px rgba(139,69,19,.4);
    transition:var(--tr);
}
.btn-hero-primary:hover {
    transform:translateY(-3px);
    box-shadow:0 8px 28px rgba(139,69,19,.5);
}
.btn-hero-outline {
    display:inline-flex; align-items:center; gap:9px;
    background:transparent; color:var(--clr-white);
    border:2px solid rgba(255,255,255,.7);
    padding:14px 32px; border-radius:var(--r-xl);
    font-weight:600; font-size:.95rem; transition:var(--tr);
}
.btn-hero-outline:hover {
    background:var(--clr-white); color:var(--clr-primary);
    transform:translateY(-3px);
}

/* Bottom Stats Bar — docked to bottom of hero */
.hero-bottom-bar {
    position:relative; z-index:2;
    display:flex; align-items:center; justify-content:center;
    gap:0;
    background:rgba(255,255,255,.10);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    border-top:1px solid rgba(255,255,255,.15);
    padding:18px 40px;
    width:100%;
    flex-shrink:0;
}
.hero-stat {
    display:flex; flex-direction:column; align-items:center;
    padding:0 36px;
}
.hstat-num {
    font-family:'Playfair Display',serif;
    font-size:1.9rem; font-weight:800;
    color:var(--clr-accent); line-height:1;
}
.hstat-plus {
    font-family:'Playfair Display',serif;
    font-size:1.3rem; font-weight:800;
    color:var(--clr-accent);
    display:inline;
}
.hstat-lbl {
    font-size:.72rem; font-weight:500;
    color:rgba(255,255,255,.65);
    margin-top:4px; white-space:nowrap;
}
.hero-star-icon { color:var(--clr-accent); font-size:1rem; margin-bottom:2px; }
.hero-stat-divider {
    width:1px; height:44px;
    background:rgba(255,255,255,.2);
    flex-shrink:0;
}

/* Scroll hint */
.hero-scroll {
    position:absolute; bottom:90px; left:50%;
    transform:translateX(-50%); z-index:3;
    display:flex; flex-direction:column; align-items:center; gap:6px;
}
.scroll-mouse {
    width:24px; height:38px;
    border:2px solid rgba(255,255,255,.35); border-radius:12px;
    display:flex; justify-content:center; padding-top:7px;
}
.scroll-wheel {
    width:3px; height:7px;
    background:rgba(255,255,255,.6); border-radius:3px;
    animation:wheel 1.5s infinite;
}
@keyframes wheel {
    0%   { opacity:1; transform:translateY(0); }
    100% { opacity:0; transform:translateY(11px); }
}

/* ============================================
   MARQUEE
   ============================================ */
.marquee-wrap {
    background:linear-gradient(135deg,var(--clr-primary),var(--clr-secondary));
    padding:14px 0; overflow:hidden;
}
.marquee-inner { overflow:hidden; }
.marquee-track {
    display:flex; gap:60px;
    animation:marquee-roll 22s linear infinite;
    white-space:nowrap; width:max-content;
}
.marquee-track span {
    display:inline-flex; align-items:center; gap:9px;
    color:var(--clr-white); font-weight:600;
    font-size:.9rem; letter-spacing:.8px;
}
.marquee-track span i { color:var(--clr-accent); }
@keyframes marquee-roll {
    0%   { transform:translateX(0); }
    100% { transform:translateX(-50%); }
}

/* ============================================
   PRODUCTS
   ============================================ */
.products-section { background:var(--clr-bg); }

/* Filter tabs */
.filter-tabs {
    display:flex; justify-content:center; gap:10px;
    flex-wrap:wrap; margin-bottom:44px;
}
.ftab {
    padding:9px 26px; border-radius:var(--r-xl);
    font-size:.88rem; font-weight:500;
    color:var(--clr-text-lt); background:var(--clr-white);
    border:2px solid rgba(139,69,19,.1); transition:var(--tr);
}
.ftab:hover, .ftab.active {
    background:linear-gradient(135deg,var(--clr-primary),var(--clr-secondary));
    color:var(--clr-white); border-color:transparent;
    box-shadow:0 4px 14px rgba(139,69,19,.25);
}

/* Grid */
.products-grid {
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:28px;
}

/* Product Card */
.pcard {
    background:var(--clr-white);
    border-radius:var(--r-lg);
    overflow:hidden;
    box-shadow:var(--sh-sm);
    transition:var(--tr-sl);
}
.pcard:hover { transform:translateY(-8px); box-shadow:var(--sh-lg); }

.pcard-img-wrap {
    position:relative; overflow:hidden;
    height:230px;
}
.pcard-img-wrap img {
    width:100%; height:100%; object-fit:cover;
    transition:transform .6s cubic-bezier(.4,0,.2,1);
}
.pcard:hover .pcard-img-wrap img { transform:scale(1.1); }

/* Hover action buttons */
.pcard-actions {
    position:absolute; top:12px; right:12px;
    display:flex; flex-direction:column; gap:8px;
    opacity:0; transition:var(--tr);
}
.pcard:hover .pcard-actions { opacity:1; }
.pact-btn {
    width:36px; height:36px; border-radius:50%;
    background:var(--clr-white); color:var(--clr-primary);
    display:flex; align-items:center; justify-content:center;
    font-size:.9rem; box-shadow:var(--sh-sm); transition:var(--tr);
}
.pact-btn:hover { background:var(--clr-primary); color:var(--clr-white); }

/* Badges */
.pbadge {
    position:absolute; top:12px; left:12px;
    padding:5px 12px; border-radius:var(--r-xl);
    font-size:.67rem; font-weight:700; text-transform:uppercase;
    letter-spacing:.5px; z-index:2;
}
.pbadge-hot  { background:#E74C3C; color:#fff; }
.pbadge-new  { background:#27AE60; color:#fff; }
.pbadge-pop  { background:var(--clr-accent); color:var(--clr-primary-dk); }
.pbadge-prem { background:#9B59B6; color:#fff; }
.pbadge-hlth { background:#2ECC71; color:#fff; }

.pweight {
    position:absolute; bottom:12px; right:12px;
    padding:4px 10px; background:rgba(255,255,255,.92);
    border-radius:var(--r-xl); font-size:.72rem;
    font-weight:600; color:var(--clr-primary);
}

/* Card Body */
.pcard-body { padding:20px; }
.pcat {
    font-size:.72rem; font-weight:600;
    color:var(--clr-secondary); text-transform:uppercase; letter-spacing:1px;
}
.pname {
    font-family:'Playfair Display',serif;
    font-size:1.2rem; font-weight:700; color:var(--clr-primary-dk);
    margin:6px 0 6px;
}
.pdesc {
    font-size:.82rem; color:var(--clr-text-lt);
    line-height:1.5; margin-bottom:10px;
}
.prating { display:flex; align-items:center; gap:7px; margin-bottom:14px; }
.pstars { display:flex; gap:2px; }
.pstars i { color:var(--clr-accent); font-size:.8rem; }
.prating-cnt { font-size:.75rem; color:var(--clr-text-muted); }

.pcard-footer {
    display:flex; align-items:center; justify-content:space-between;
    padding-top:14px; border-top:1px solid rgba(139,69,19,.07);
}
.pprice { display:flex; align-items:center; gap:8px; }
.pprice-now {
    font-family:'Playfair Display',serif;
    font-size:1.35rem; font-weight:800; color:var(--clr-primary);
}
.pprice-old {
    font-size:.85rem; color:var(--clr-text-muted);
    text-decoration:line-through;
}
.padd-btn {
    display:inline-flex; align-items:center; gap:5px;
    padding:9px 18px; border-radius:var(--r-xl);
    background:linear-gradient(135deg,var(--clr-primary),var(--clr-secondary));
    color:var(--clr-white); font-size:.82rem; font-weight:600;
    transition:var(--tr);
}
.padd-btn:hover { transform:scale(1.06); box-shadow:0 4px 14px rgba(139,69,19,.3); }

/* View All CTA */
.products-view-all { text-align:center; margin-top:48px; }
.btn-view-all {
    display:inline-flex; align-items:center; gap:9px;
    background:linear-gradient(135deg,var(--clr-primary),var(--clr-secondary));
    color:var(--clr-white); padding:15px 40px; border-radius:var(--r-xl);
    font-weight:600; font-size:.95rem;
    box-shadow:0 4px 16px rgba(139,69,19,.3); transition:var(--tr);
}
.btn-view-all:hover { transform:translateY(-3px); box-shadow:var(--sh-md); }

/* ============================================
   ABOUT
   ============================================ */
.about-section { background:var(--clr-white); }
.about-grid {
    display:grid; grid-template-columns:1fr 1fr;
    gap:72px; align-items:center;
}

/* Images */
.about-imgs { position:relative; padding-bottom:30px; }
.about-img-main {
    border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--sh-lg);
}
.about-img-main img {
    width:100%; height:460px; object-fit:cover;
    transition:transform .6s ease;
}
.about-img-main:hover img { transform:scale(1.04); }

.about-img-sm {
    position:absolute; bottom:-10px; right:-24px;
    width:180px; height:180px;
    border-radius:var(--r-md); overflow:hidden;
    box-shadow:var(--sh-lg); border:5px solid var(--clr-white);
}
.about-img-sm img { width:100%; height:100%; object-fit:cover; }

.about-badge {
    position:absolute; top:-18px; left:24px;
    width:110px; height:110px; border-radius:50%;
    background:linear-gradient(135deg,var(--clr-accent),var(--clr-accent-lt));
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    box-shadow:var(--sh-md);
    animation:float-badge 3s ease-in-out infinite;
}
@keyframes float-badge {
    0%,100% { transform:translateY(0); }
    50%      { transform:translateY(-10px); }
}
.about-badge-num {
    font-family:'Playfair Display',serif;
    font-size:1.8rem; font-weight:800; color:var(--clr-primary-dk); line-height:1;
}
.about-badge-txt {
    font-size:.65rem; font-weight:600;
    color:var(--clr-primary); text-align:center; line-height:1.3; margin-top:3px;
}

/* Content */
.about-para {
    font-size:.96rem; color:var(--clr-text-lt); margin-bottom:14px; line-height:1.8;
}
.about-feats { display:flex; flex-direction:column; gap:18px; margin:26px 0 32px; }
.afeat { display:flex; align-items:center; gap:14px; }
.afeat-icon {
    width:48px; height:48px; min-width:48px; border-radius:var(--r-md);
    background:linear-gradient(135deg,rgba(139,69,19,.09),rgba(210,105,30,.09));
    display:flex; align-items:center; justify-content:center;
    color:var(--clr-primary); font-size:1.15rem; transition:var(--tr);
}
.afeat:hover .afeat-icon {
    background:linear-gradient(135deg,var(--clr-primary),var(--clr-secondary));
    color:var(--clr-white);
}
.afeat h4 { font-size:.92rem; font-weight:600; color:var(--clr-primary-dk); margin-bottom:1px; }
.afeat p  { font-size:.8rem; color:var(--clr-text-muted); }

.btn-primary-solid {
    display:inline-flex; align-items:center; gap:9px;
    background:linear-gradient(135deg,var(--clr-primary),var(--clr-secondary));
    color:var(--clr-white); padding:14px 32px; border-radius:var(--r-xl);
    font-weight:600; font-size:.95rem;
    box-shadow:0 4px 16px rgba(139,69,19,.3); transition:var(--tr);
}
.btn-primary-solid:hover { transform:translateY(-3px); box-shadow:var(--sh-md); }

/* ============================================
   WHY CHOOSE US
   ============================================ */
.whyus-section {
    background:linear-gradient(180deg,var(--clr-bg) 0%,var(--clr-bg-alt) 100%);
}
.whyus-grid {
    display:grid; grid-template-columns:repeat(3,1fr); gap:28px;
}
.why-card {
    background:var(--clr-white); padding:38px 28px;
    border-radius:var(--r-lg); text-align:center;
    box-shadow:var(--sh-sm); transition:var(--tr-sl);
    position:relative; overflow:hidden;
}
.why-card::before {
    content:''; position:absolute; top:0; left:0;
    width:100%; height:4px;
    background:linear-gradient(90deg,var(--clr-primary),var(--clr-accent));
    transform:scaleX(0); transform-origin:left; transition:var(--tr);
}
.why-card:hover { transform:translateY(-9px); box-shadow:var(--sh-lg); }
.why-card:hover::before { transform:scaleX(1); }

.why-icon {
    width:72px; height:72px; margin:0 auto 22px;
    background:linear-gradient(135deg,rgba(139,69,19,.08),rgba(210,105,30,.08));
    border-radius:50%; display:flex; align-items:center; justify-content:center;
    font-size:1.5rem; color:var(--clr-primary); transition:var(--tr);
}
.why-card:hover .why-icon {
    background:linear-gradient(135deg,var(--clr-primary),var(--clr-secondary));
    color:var(--clr-white);
}
.why-card h3 {
    font-family:'Playfair Display',serif; font-size:1.15rem; font-weight:700;
    color:var(--clr-primary-dk); margin-bottom:10px;
}
.why-card p { font-size:.875rem; color:var(--clr-text-lt); line-height:1.7; }
.why-num {
    position:absolute; bottom:-6px; right:14px;
    font-family:'Playfair Display',serif; font-size:3.5rem; font-weight:800;
    color:rgba(139,69,19,.05); line-height:1;
}

/* ============================================
   TESTIMONIALS
   ============================================ */
.testi-section { background:var(--clr-white); }
.testi-slider-wrap { position:relative; overflow:hidden; }
.testi-track {
    display:flex; gap:28px;
    transition:transform .5s cubic-bezier(.4,0,.2,1);
}

/* Each card is half-width on desktop */
.tcard {
    min-width:calc(50% - 14px);
    background:var(--clr-bg); border-radius:var(--r-lg);
    padding:32px; box-shadow:var(--sh-sm);
    border:1px solid rgba(139,69,19,.06); transition:var(--tr);
}
.tcard:hover { box-shadow:var(--sh-md); border-color:rgba(139,69,19,.12); }

.tcard-top {
    display:flex; align-items:center; gap:13px; margin-bottom:14px;
}
.tcard-avatar {
    width:52px; height:52px; border-radius:50%; overflow:hidden;
    border:3px solid var(--clr-accent); flex-shrink:0;
}
.tcard-avatar img { width:100%; height:100%; object-fit:cover; }
.tcard-info h4 { font-size:.95rem; font-weight:600; color:var(--clr-primary-dk); }
.tcard-info span { font-size:.78rem; color:var(--clr-text-muted); }
.tcard-quote { margin-left:auto; color:var(--clr-accent); font-size:1.4rem; opacity:.45; }

.tcard-stars { margin-bottom:12px; }
.tcard-stars i { color:var(--clr-accent); font-size:.85rem; margin-right:1px; }

.tcard-text {
    font-size:.9rem; color:var(--clr-text-lt); line-height:1.8;
    font-style:italic; margin-bottom:12px;
}
.tcard-order { font-size:.77rem; color:var(--clr-text-muted); font-weight:500; }

/* Controls */
.testi-controls {
    display:flex; align-items:center; justify-content:center;
    gap:18px; margin-top:36px;
}
.tslider-btn {
    width:44px; height:44px; border-radius:50%;
    background:var(--clr-white); color:var(--clr-primary);
    border:2px solid rgba(139,69,19,.15); font-size:.95rem;
    display:flex; align-items:center; justify-content:center; transition:var(--tr);
}
.tslider-btn:hover {
    background:var(--clr-primary); color:var(--clr-white); border-color:var(--clr-primary);
}
.tslider-dots { display:flex; gap:7px; }
.tdot {
    width:9px; height:9px; border-radius:50%;
    background:rgba(139,69,19,.2); cursor:pointer; transition:var(--tr);
}
.tdot.active { width:28px; border-radius:5px; background:var(--clr-primary); }

/* ============================================
   GALLERY
   ============================================ */
.gallery-section { background:var(--clr-bg); padding-bottom:100px; }
.gallery-section .container { margin-bottom:40px; }
.gallery-grid {
    display:grid;
    grid-template-columns:repeat(4,1fr);
    grid-auto-rows:220px;
    gap:14px;
    max-width:1280px; margin:0 auto; padding:0 24px;
}
.gitem {
    border-radius:var(--r-md); overflow:hidden; position:relative; cursor:pointer;
}
.gitem img {
    width:100%; height:100%; object-fit:cover;
    transition:transform .6s ease;
}
.gitem:hover img { transform:scale(1.12); }
.goverlay {
    position:absolute; inset:0;
    background:rgba(139,69,19,.55);
    display:flex; align-items:center; justify-content:center;
    opacity:0; transition:var(--tr);
}
.gitem:hover .goverlay { opacity:1; }
.goverlay i { color:var(--clr-white); font-size:1.7rem; }

/* Spanning items */
.gitem-tall  { grid-row:span 2; }
.gitem-wide  { grid-column:span 2; }

/* ============================================
   NEWSLETTER
   ============================================ */
.newsletter-section {
    background:linear-gradient(135deg,var(--clr-primary),var(--clr-secondary));
    padding:72px 0;
}
.nl-wrap {
    display:flex; align-items:center; justify-content:space-between;
    gap:40px; flex-wrap:wrap;
}
.nl-content { color:var(--clr-white); }
.nl-icon { font-size:2.2rem; color:var(--clr-accent); margin-bottom:10px; }
.nl-content h2 {
    font-family:'Playfair Display',serif; font-size:1.8rem; margin-bottom:6px;
}
.nl-content p { color:rgba(255,255,255,.8); font-size:.95rem; }

.nl-form { flex:1; max-width:480px; }
.nl-input-wrap {
    display:flex; background:var(--clr-white);
    border-radius:var(--r-xl); padding:6px; box-shadow:var(--sh-md);
}
.nl-input-wrap input {
    flex:1; border:none; outline:none;
    padding:13px 18px; font-size:.92rem; font-family:inherit;
    background:transparent; color:var(--clr-text);
}
.nl-input-wrap button {
    display:inline-flex; align-items:center; gap:8px;
    background:linear-gradient(135deg,var(--clr-primary),var(--clr-secondary));
    color:var(--clr-white); padding:12px 26px; border-radius:var(--r-xl);
    font-weight:600; font-size:.88rem; white-space:nowrap; transition:var(--tr);
}
.nl-input-wrap button:hover { transform:scale(1.04); }
.nl-note {
    display:flex; align-items:center; gap:6px;
    color:rgba(255,255,255,.6); font-size:.78rem;
    margin-top:10px; padding-left:16px;
}

/* ============================================
   FOOTER
   ============================================ */
.footer { background:var(--clr-black); color:rgba(255,255,255,.65); }
.footer-main { padding:72px 0 48px; }
.footer-grid {
    display:grid; grid-template-columns:1.6fr 1fr 1fr 1.3fr; gap:48px;
}

/* Brand col */
.fcol-brand p {
    font-size:.88rem; line-height:1.8;
    margin:16px 0 22px; color:rgba(255,255,255,.55);
}
.footer-logo {
    display:flex; align-items:center; gap:11px;
}
.footer-logo .logo-icon {
    background:linear-gradient(135deg,var(--clr-accent),var(--clr-secondary));
}
.footer-logo .logo-main { color:var(--clr-white); }
.footer-logo .logo-sub  { color:var(--clr-accent); }
.fsocial { display:flex; gap:10px; }
.fsocial-link {
    width:40px; height:40px; border-radius:50%;
    background:rgba(255,255,255,.07);
    display:flex; align-items:center; justify-content:center;
    color:rgba(255,255,255,.6); font-size:.95rem; transition:var(--tr);
}
.fsocial-link:hover {
    background:var(--clr-accent); color:var(--clr-primary-dk);
    transform:translateY(-3px);
}

/* Link cols */
.fcol-title {
    font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:700;
    color:var(--clr-white); margin-bottom:22px; padding-bottom:10px;
    position:relative;
}
.fcol-title::after {
    content:''; position:absolute; bottom:0; left:0;
    width:30px; height:2px; background:var(--clr-accent); border-radius:2px;
}
.flinks { display:flex; flex-direction:column; gap:10px; }
.flinks a {
    font-size:.88rem; color:rgba(255,255,255,.55);
    display:flex; align-items:center; gap:6px; transition:var(--tr);
}
.flinks a::before { content:'›'; font-size:1.1rem; transition:var(--tr); }
.flinks a:hover { color:var(--clr-accent); padding-left:5px; }

/* Contact col */
.fcontact-list { display:flex; flex-direction:column; gap:16px; }
.fcontact-item { display:flex; align-items:flex-start; gap:12px; }
.fcontact-item i { color:var(--clr-accent); font-size:.95rem; margin-top:3px; }
.fcontact-item span { font-size:.88rem; line-height:1.6; }

/* Footer bottom */
.footer-bottom { border-top:1px solid rgba(255,255,255,.07); padding:22px 0; }
.fbottom-inner {
    display:flex; align-items:center; justify-content:space-between;
    flex-wrap:wrap; gap:14px;
}
.fbottom-inner p { font-size:.82rem; }
.fbottom-links { display:flex; gap:22px; }
.fbottom-links a {
    font-size:.82rem; color:rgba(255,255,255,.45); transition:var(--tr);
}
.fbottom-links a:hover { color:var(--clr-accent); }
.fpay-icons { display:flex; gap:14px; font-size:1.4rem; color:rgba(255,255,255,.35); }

/* ============================================
   BACK TO TOP
   ============================================ */
.btt-btn {
    position:fixed; bottom:28px; right:28px; z-index:9998;
    width:46px; height:46px; border-radius:50%;
    background:linear-gradient(135deg,var(--clr-primary),var(--clr-secondary));
    color:var(--clr-white); font-size:1rem;
    display:flex; align-items:center; justify-content:center;
    box-shadow:var(--sh-md);
    opacity:0; visibility:hidden;
    transform:translateY(16px); transition:var(--tr);
}
.btt-btn.show { opacity:1; visibility:visible; transform:translateY(0); }
.btt-btn:hover { transform:translateY(-4px); box-shadow:var(--sh-lg); }

/* ============================================
   RESPONSIVE
   ============================================ */

/* Tablet ≤ 1024px */
@media (max-width:1024px) {
    .products-grid { grid-template-columns:repeat(2,1fr); }
    .about-grid    { grid-template-columns:1fr; gap:50px; }
    .whyus-grid    { grid-template-columns:repeat(2,1fr); }

    .tcard { min-width:calc(100% - 0px); }

    .gallery-grid {
        grid-template-columns:repeat(2,1fr);
        grid-auto-rows:200px;
    }
    .gitem-tall  { grid-row:span 1; }

    .footer-grid { grid-template-columns:repeat(2,1fr); gap:36px; }

    .hero-stat { padding:0 22px; }
}

/* Mobile ≤ 768px */
@media (max-width:768px) {
    .hamburger { display:flex !important; }

    .nav-menu {
        position:fixed; top:0; right:-100%; bottom:0;
        width:88%; max-width:380px; height:100vh;
        background:var(--clr-bg); flex-direction:column;
        justify-content:flex-start; gap:0; padding:90px 28px 40px 28px;
        box-shadow:var(--sh-xl); transition:right .35s cubic-bezier(.4,0,.2,1);
        z-index:10000; overflow-y:auto;
        flex:none;
    }
    .nav-menu.open { right:0; }
    .nav-link {
        font-size:1.08rem; padding:16px 20px; width:100%;
        display:flex; align-items:center; border-bottom:1px solid rgba(139,69,19,.08);
        white-space:normal; text-align:left;
        border-radius:8px; margin-bottom:4px;
        transition:var(--tr);
    }
    .nav-link:hover {
        background:rgba(139,69,19,.08);
        padding-left:24px;
    }
    .nav-link.active {
        background:rgba(139,69,19,.1);
        border-left:4px solid var(--clr-primary);
        padding-left:16px;
    }
    .nav-link::after { display:none; }
    .nav-link:hover::after, .nav-link.active::after { display:none; }

    .nav-actions { display:none; }

    .hero { max-height:none; }
    .hero-bottom-bar {
        gap:0; padding:14px 12px;
        overflow-x:auto; justify-content:flex-start;
    }
    .hero-stat { padding:0 16px; }
    .hero-stat-divider { height:36px; }
    .hstat-num { font-size:1.5rem; }

    .products-grid { grid-template-columns:1fr; max-width:400px; margin:0 auto; }
    .whyus-grid    { grid-template-columns:1fr; max-width:400px; margin:0 auto; }

    .about-img-sm { width:140px; height:140px; right:-10px; }
    .about-badge  { width:96px; height:96px; top:-14px; }
    .about-badge-num { font-size:1.5rem; }

    .gallery-grid {
        grid-template-columns:repeat(2,1fr);
        grid-auto-rows:170px;
    }
    .gitem-wide { grid-column:span 1; }

    .nl-wrap { flex-direction:column; text-align:center; }
    .nl-form { max-width:100%; }
    .nl-note { justify-content:center; padding-left:0; }

    .footer-grid { grid-template-columns:1fr; gap:36px; }
    .fbottom-inner { flex-direction:column; text-align:center; }

    .hero-scroll { display:none; }
}

/* Small Mobile ≤ 480px */
@media (max-width:480px) {
    .hero-content { padding-top:calc(var(--nav-h) + 10px); }
    .hero-buttons { flex-direction:column; }
    .btn-hero-primary, .btn-hero-outline { width:100%; justify-content:center; }

    .hero-bottom-bar { display:grid; grid-template-columns:1fr 1fr; gap:0; }
    .hero-stat-divider { display:none; }
    .hero-stat { padding:10px; border:1px solid rgba(255,255,255,.1); }

    .gallery-grid { grid-template-columns:1fr; grid-auto-rows:200px; }
    .gitem-tall { grid-row:span 1; }

    .nl-input-wrap { flex-direction:column; border-radius:var(--r-md); gap:8px; padding:10px; }
    .nl-input-wrap button { border-radius:var(--r-md); justify-content:center; }
}

/* ============================================
   HERO REDESIGN OVERRIDES
   ============================================ */
.hero-overlay {
    background:
        linear-gradient(120deg, rgba(25,10,3,.78) 0%, rgba(80,28,6,.62) 45%, rgba(139,69,19,.45) 100%);
}

.hero-shape {
    position: absolute;
    border-radius: 50%;
    filter: blur(0px);
    pointer-events: none;
}

.hero-shape-one {
    width: 360px;
    height: 360px;
    background: radial-gradient(circle, rgba(244,196,48,.24) 0%, rgba(244,196,48,0) 72%);
    top: 6%;
    left: -4%;
}

.hero-shape-two {
    width: 280px;
    height: 280px;
    background: radial-gradient(circle, rgba(255,255,255,.16) 0%, rgba(255,255,255,0) 72%);
    bottom: 6%;
    right: 4%;
}

.hero-content {
    max-width: 1240px;
    display: grid;
    grid-template-columns: 1.1fr .75fr;
    gap: 30px;
    align-items: center;
}

.hero-text-block {
    max-width: 680px;
}

.hero-tag {
    background: rgba(244,196,48,.2);
    border: 1px solid rgba(244,196,48,.45);
}

.hero-heading {
    margin-bottom: 16px;
}

.hero-desc {
    max-width: 560px;
    color: rgba(255,255,255,.88);
}

.hero-highlight-card {
    justify-self: end;
    width: min(360px, 100%);
    background: rgba(255,255,255,.13);
    border: 1px solid rgba(255,255,255,.25);
    border-radius: 24px;
    padding: 24px 24px 22px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    color: var(--clr-white);
    box-shadow: 0 14px 38px rgba(0,0,0,.24);
}

.hero-highlight-badge {
    display: inline-block;
    background: var(--clr-accent);
    color: var(--clr-primary-dk);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .6px;
    text-transform: uppercase;
    border-radius: 999px;
    padding: 5px 12px;
    margin-bottom: 10px;
}

.hero-highlight-card h3 {
    font-family: 'Playfair Display', serif;
    font-size: 1.35rem;
    margin-bottom: 5px;
}

.hero-highlight-card p {
    color: rgba(255,255,255,.8);
    font-size: .9rem;
    margin-bottom: 14px;
}

.hero-highlight-price {
    display: flex;
    align-items: baseline;
    gap: 10px;
    margin-bottom: 15px;
}

.hero-highlight-now {
    font-family: 'Playfair Display', serif;
    font-size: 2rem;
    line-height: 1;
    color: var(--clr-accent);
}

.hero-highlight-old {
    font-size: .95rem;
    text-decoration: line-through;
    color: rgba(255,255,255,.62);
}

.hero-highlight-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    justify-content: center;
    background: linear-gradient(135deg, var(--clr-primary), var(--clr-secondary));
    color: var(--clr-white);
    border-radius: 999px;
    padding: 12px;
    font-weight: 600;
}

.hero-highlight-btn:hover {
    transform: translateY(-2px);
}

@media (max-width: 980px) {
    .hero-content {
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .hero-highlight-card {
        justify-self: start;
        max-width: 380px;
    }
}

@media (max-width: 768px) {
    .hero-highlight-card {
        width: 100%;
        max-width: 100%;
    }
}
