:root {
    --bg:          #F7F2EC;
    --primary:     #1a0f08;
    --surface:     #2e1c0e;
    --surface2:    #3d2a1c;
    --accent:      #C97B2B;
    --accent-lt:   #E09A4A;
    --accent-dk:   #a05e1a;
    --amber:       #F5C842;
    --text:        #f7f2ec;
    --text-on-bg:  #1a0f08;
    --text-muted:  #9b7e60;
    --border:      rgba(201,123,43,0.18);
    --card-shadow: 0 2px 12px rgba(26,15,8,0.10);
    --card-hover:  0 16px 48px rgba(201,123,43,0.22);
    --nav-h:       68px;
    --filter-h:    60px;
    --radius-lg:   20px;
    --radius-md:   14px;
    --radius-sm:   8px;
    --grad:        linear-gradient(135deg,#C97B2B 0%,#E09A4A 100%);
    --grad-h:      linear-gradient(135deg,#d98c3a 0%,#ebb05a 100%);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
    font-family:'DM Sans',system-ui,sans-serif;
    background:var(--bg);
    color:var(--text-on-bg);
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
}

/* ── Scroll progress ── */
#scrollProgress{
    position:fixed;top:0;left:0;height:3px;width:0;
    background:var(--grad);z-index:9999;
    box-shadow:0 0 8px rgba(201,123,43,0.6);
    transition:width 0.1s linear;
}

/* ═══════════════════════════════════
    NAVBAR — with collapsible mobile menu
═══════════════════════════════════ */
.navbar{
    position:sticky;top:0;z-index:1000;
    height:var(--nav-h);
    background:rgba(26,15,8,0.97);
    backdrop-filter:blur(24px) saturate(180%);
    -webkit-backdrop-filter:blur(24px) saturate(180%);
    border-bottom:1px solid rgba(201,123,43,0.20);
    display:flex;align-items:center;
    padding:0 clamp(16px,4vw,60px);
    gap:12px;
    box-shadow:0 4px 24px rgba(0,0,0,0.35);
}

.navbar-logo{display:flex;align-items:center;flex-shrink:0;text-decoration:none;}
.navbar-logo img{height:50px;}

/* Desktop links */
.navbar-links{
    display:flex;align-items:center;gap:4px;
    margin-left:auto;
}

.nav-link{
    color:rgba(240,220,190,0.75);
    text-decoration:none;
    font-weight:500;font-size:14px;
    padding:8px 14px;border-radius:50px;
    transition:all .25s ease;white-space:nowrap;
}
.nav-link:hover{color:#fff;background:rgba(255,255,255,0.08);}

.user-chip{
    display:flex;align-items:center;gap:7px;
    color:var(--accent-lt);font-size:13px;font-weight:600;
    padding:7px 14px;
    background:rgba(201,123,43,0.15);
    border:1.5px solid rgba(201,123,43,0.30);
    border-radius:50px;white-space:nowrap;
    cursor:pointer;
    
}

/* USER DROPDOWN */
.user-dropdown{
    position:relative;
}

.drop-icon{
    font-size:11px;
    transition:transform .25s ease;
}

.user-menu{
    position:absolute;
    top:120%;
    right:0;
    background:#2e1c0e;
    border:1px solid rgba(201,123,43,0.25);
    border-radius:12px;
    min-width:170px;
    padding:8px 0;
    box-shadow:0 12px 30px rgba(0,0,0,0.35);

    opacity:0;
    transform:translateY(10px);
    pointer-events:none;
    transition:.25s ease;
    z-index:999;
}

.dropdown-link{
    display:flex;
    align-items:center;
    gap:8px;
    padding:10px 16px;
    text-decoration:none;
    font-size:13px;
    color:rgba(240,220,190,0.85);
    transition:.2s;
}

.dropdown-link:hover{
    background:rgba(255,255,255,0.06);
    color:#fff;
}

.dropdown-link.logout{
    color:#ff6b6b;
}

/* SHOW ON CLICK */
.user-dropdown.open .user-menu{
    opacity:1;
    transform:translateY(0);
    pointer-events:auto;
}

.user-dropdown.open .drop-icon{
    transform:rotate(180deg);
}

@media(max-width:700px){
    .user-menu{
        position:static;
        transform:none;
        opacity:1;
        pointer-events:auto;
        display:none;
        margin-top:8px;
    }

    .user-dropdown.open .user-menu{
        display:block;
    }
}


/* Cart button */
.cart-btn{
    position:relative;
    background:var(--grad);border:none;cursor:pointer;
    width:44px;height:44px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-size:17px;
    box-shadow:0 4px 14px rgba(201,123,43,0.45);
    transition:all .3s cubic-bezier(.4,0,.2,1);flex-shrink:0;
}
.cart-btn:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 8px 24px rgba(201,123,43,0.6);}
.cart-badge{
    position:absolute;top:-5px;right:-5px;
    background:#e63946;color:#fff;
    min-width:19px;height:19px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:10px;font-weight:800;
    border:2px solid #1a0f08;
    animation:badgePulse 2s ease-in-out infinite;
}
@keyframes badgePulse{0%,100%{transform:scale(1);}50%{transform:scale(1.2);}}

/* ── Hamburger toggle ── */
.nav-toggle{
    display:none;
    flex-direction:column;justify-content:center;align-items:center;
    gap:5px;
    background:transparent;border:none;cursor:pointer;
    padding:8px;border-radius:8px;
    margin-left:auto;
    transition:background .2s;
    z-index:1002;
}
.nav-toggle:hover{background:rgba(255,255,255,0.07);}
.nav-toggle span{
    display:block;width:22px;height:2px;
    background:var(--accent-lt);border-radius:2px;
    transition:all .35s cubic-bezier(.4,0,.2,1);
    transform-origin:center;
}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ── Mobile dropdown drawer ── */
@media(max-width:700px){
    .nav-toggle{display:flex;}

    .navbar-links{
        position:fixed;
        top:var(--nav-h);left:0;right:0;
        background:rgba(20,10,4,0.98);
        backdrop-filter:blur(24px);
        -webkit-backdrop-filter:blur(24px);
        flex-direction:column;align-items:stretch;
        gap:0;padding:12px 20px 20px;
        border-bottom:1px solid rgba(201,123,43,0.20);
        box-shadow:0 16px 40px rgba(0,0,0,0.5);
        max-height:0;overflow:hidden;
        transition:max-height .4s cubic-bezier(.4,0,.2,1),
                    padding .3s ease,
                    opacity .3s ease;
        opacity:0;
        pointer-events:none;
        margin-left:0;
    }
    .navbar-links.open{
        max-height:420px;
        opacity:1;
        pointer-events:auto;
    }
    .nav-link{
        display:block;
        padding:13px 16px;
        border-radius:12px;
        font-size:15px;font-weight:600;
        border-bottom:1px solid rgba(201,123,43,0.08);
    }
    .nav-link:last-of-type{border-bottom:none;}
    .user-chip{
        margin:8px 0 4px;
        justify-content:center;
    }
    .cart-btn{
        /* stays in navbar row — don't move into drawer */
        order:10;
    }
}

/* ═══════════════════════════════════
    HERO
═══════════════════════════════════ */
.hero{
    background:linear-gradient(160deg,#1a0f08 0%,#3d2a1c 55%,#1a0f08 100%);
    padding:clamp(48px,8vw,100px) clamp(20px,5vw,80px) clamp(56px,9vw,110px);
    text-align:center;position:relative;overflow:hidden;
}
.hero::before{
    content:'';position:absolute;
    width:700px;height:700px;
    background:radial-gradient(circle,rgba(201,123,43,0.18) 0%,transparent 65%);
    border-radius:50%;top:-300px;right:-200px;
    animation:drift 20s ease-in-out infinite alternate;
}
.hero::after{
    content:'';position:absolute;
    width:500px;height:500px;
    background:radial-gradient(circle,rgba(245,200,66,0.10) 0%,transparent 65%);
    border-radius:50%;bottom:-250px;left:-150px;
    animation:drift 25s ease-in-out infinite alternate-reverse;
}
@keyframes drift{from{transform:translate(0,0);}to{transform:translate(30px,-30px);}}

.hero-eyebrow{
    display:inline-flex;align-items:center;gap:8px;
    background:rgba(201,123,43,0.18);border:1px solid rgba(201,123,43,0.35);
    color:var(--accent-lt);font-size:12px;font-weight:700;
    letter-spacing:2px;text-transform:uppercase;
    padding:6px 16px;border-radius:50px;margin-bottom:20px;
    position:relative;z-index:1;animation:fadeUp .6s ease both;
}
.hero h1{
    font-family:'Playfair Display',serif;
    font-size:clamp(40px,8vw,86px);font-weight:900;
    color:var(--text);letter-spacing:-2px;line-height:1.05;
    position:relative;z-index:1;animation:fadeUp .7s .1s ease both;
}
.hero h1 em{
    font-style:italic;
    background:var(--grad);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    background-clip:text;
}
.hero-sub{
    color:rgba(247,242,236,0.55);font-size:clamp(15px,2vw,18px);
    max-width:520px;margin:16px auto 0;line-height:1.7;
    position:relative;z-index:1;animation:fadeUp .8s .2s ease both;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px);}to{opacity:1;transform:translateY(0);}}

/* ═══════════════════════════════════
    FILTER BAR
═══════════════════════════════════ */
.filter-bar{
    position:sticky;top:var(--nav-h);z-index:900;
    background:rgba(247,242,236,0.97);
    backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border-bottom:1px solid var(--border);
    box-shadow:0 2px 16px rgba(26,15,8,0.08);
}
.filter-inner{
    display:flex;align-items:center;gap:10px;
    padding:0 clamp(16px,4vw,60px);
    height:var(--filter-h);
    max-width:1400px;margin:0 auto;
}

.search-toggle{
    flex-shrink:0;background:transparent;
    border:1.5px solid var(--border);
    width:38px;height:38px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    color:var(--accent);font-size:14px;cursor:pointer;
    transition:all .25s ease;
}
.search-toggle:hover,.search-toggle.open{background:var(--grad);border-color:transparent;color:#fff;}

.search-wrap{
    width:0;overflow:hidden;opacity:0;
    transition:width .4s cubic-bezier(.4,0,.2,1),opacity .3s ease;
    flex-shrink:0;position:relative;
}
.search-wrap.open{width:260px;opacity:1;}
@media(max-width:480px){.search-wrap.open{width:calc(100vw - 120px);}}

.search-wrap input{
    width:100%;height:38px;padding:0 34px 0 36px;
    border:1.5px solid var(--border);border-radius:50px;
    background:#fff;font-family:'DM Sans',sans-serif;
    font-size:14px;font-weight:500;color:var(--text-on-bg);
    transition:border-color .25s,box-shadow .25s;
}
.search-wrap input::placeholder{color:#bba88a;}
.search-wrap input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(201,123,43,0.15);}
.search-wrap .s-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--accent);font-size:12px;pointer-events:none;}
.search-clear{position:absolute;right:9px;top:50%;transform:translateY(-50%);background:none;border:none;color:#bba88a;cursor:pointer;font-size:13px;display:none;padding:4px;}
.search-clear:hover{color:var(--accent);}

.tabs-wrap{flex:1;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;}
.tabs-wrap::-webkit-scrollbar{display:none;}
.tabs{display:flex;gap:6px;min-width:max-content;padding:0 2px;}
.tab{
    flex-shrink:0;padding:8px 16px;border-radius:50px;
    background:transparent;border:1.5px solid var(--border);
    font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;
    color:#7a5c3a;cursor:pointer;white-space:nowrap;
    transition:all .25s cubic-bezier(.4,0,.2,1);
}
.tab:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px);}
.tab.active{background:var(--grad);border-color:transparent;color:#fff;box-shadow:0 4px 14px rgba(201,123,43,0.35);}

/* ═══════════════════════════════════
    PRODUCTS GRID
═══════════════════════════════════ */
.products-section{
    max-width:1400px;margin:0 auto;
    padding:clamp(28px,5vw,60px) clamp(16px,4vw,60px) 100px;
}
.section-label{
    font-family:'Playfair Display',serif;
    font-size:clamp(26px,4vw,42px);font-weight:900;letter-spacing:-1px;
    color:var(--text-on-bg);margin-bottom:6px;
}
.section-sub{color:var(--text-muted);font-size:14px;margin-bottom:32px;}

.products-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));
    gap:clamp(14px,2.5vw,26px);
}
@media(max-width:500px){.products-grid{grid-template-columns:1fr;}}
@media(min-width:501px) and (max-width:800px){.products-grid{grid-template-columns:repeat(2,1fr);}}

.product-card{
    background:#fff;border-radius:var(--radius-lg);overflow:hidden;
    box-shadow:var(--card-shadow);border:1.5px solid transparent;
    transition:transform .35s cubic-bezier(.4,0,.2,1),
                box-shadow .35s cubic-bezier(.4,0,.2,1),
                border-color .25s;
    cursor:pointer;display:flex;flex-direction:column;position:relative;
}
.product-card:hover{transform:translateY(-8px);box-shadow:var(--card-hover);border-color:rgba(201,123,43,0.25);}
.card-stripe{height:3px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.4,0,.2,1);}
.product-card:hover .card-stripe{transform:scaleX(1);}

.card-img-wrap{position:relative;overflow:hidden;aspect-ratio:4/3;}
.card-img{width:100%;height:100%;object-fit:cover;background:#f0e8de;transition:transform .55s cubic-bezier(.4,0,.2,1);}
.product-card:hover .card-img{transform:scale(1.07);}
.card-category{
    position:absolute;top:12px;left:12px;
    background:rgba(26,15,8,0.65);backdrop-filter:blur(8px);
    color:rgba(247,242,236,0.9);font-size:10px;font-weight:700;
    letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;border-radius:50px;
}

.card-body{padding:18px 18px 14px;flex:1;display:flex;flex-direction:column;}
.card-name{
    font-family:'Playfair Display',serif;
    font-size:clamp(16px,2.5vw,19px);font-weight:700;color:var(--text-on-bg);
    margin-bottom:7px;line-height:1.25;
}
.card-desc{
    font-size:13px;color:#8a6e54;line-height:1.65;flex:1;margin-bottom:14px;
    display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;overflow:hidden;
}
.card-footer{
    display:flex;align-items:center;justify-content:space-between;
    border-top:1px solid rgba(201,123,43,0.12);padding-top:12px;gap:8px;
}
.card-price{
    font-family:'Playfair Display',serif;
    font-size:clamp(18px,2.5vw,22px);font-weight:900;color:var(--accent);letter-spacing:-0.5px;
}
.card-price small{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--text-muted);font-weight:500;}
.card-meta-row{
    display:flex;align-items:center;justify-content:space-between;
    margin-top:8px;gap:6px;flex-wrap:wrap;
}
.card-available-badge{
    font-size:11px;color:#8a6e54;font-family:'DM Sans',sans-serif;
    display:flex;align-items:center;gap:4px;white-space:nowrap;
}
.card-available-badge i{color:var(--accent-lt);}
.card-sizes-badge{
    font-size:11px;color:#8a6e54;font-family:'DM Sans',sans-serif;
    white-space:nowrap;letter-spacing:0.2px;
}
.modal-available{
    display:flex;align-items:center;gap:6px;
    font-size:13px;color:#8a6e54;font-family:'DM Sans',sans-serif;
    margin-top:-8px;
}
.card-add{
    background:var(--grad);border:none;cursor:pointer;
    color:#fff;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;
    padding:9px 16px;border-radius:50px;
    display:flex;align-items:center;gap:5px;
    box-shadow:0 3px 12px rgba(201,123,43,0.35);
    transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap;flex-shrink:0;
}
.card-add:hover{background:var(--grad-h);transform:translateY(-2px);box-shadow:0 6px 18px rgba(201,123,43,0.45);}

/* ── Empty state ── */
.empty-state{
    grid-column:1/-1;display:flex;flex-direction:column;align-items:center;
    padding:80px 20px;color:var(--text-muted);text-align:center;
}
.empty-state i{font-size:48px;margin-bottom:16px;opacity:.3;}
.empty-state h3{font-size:20px;font-weight:700;margin-bottom:8px;color:var(--text-on-bg);}

/* ═══════════════════════════════════
    PRODUCT MODAL
═══════════════════════════════════ */
.modal-overlay{
    display:none;position:fixed;inset:0;
    background:rgba(15,8,4,0.82);
    backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    z-index:2000;align-items:center;justify-content:center;
    padding:clamp(12px,3vw,24px);
}
.modal-overlay.open{display:flex;}

.modal-box{
    background:#fff;border-radius:24px;
    width:100%;max-width:860px;
    max-height:92dvh;overflow:hidden;
    display:flex;flex-direction:column;position:relative;
    animation:modalIn .4s cubic-bezier(.34,1.56,.64,1) both;
    box-shadow:0 32px 80px rgba(0,0,0,0.55);
}
@keyframes modalIn{from{opacity:0;transform:scale(.88) translateY(32px);}to{opacity:1;transform:scale(1) translateY(0);}}

.modal-close{
    position:absolute;top:14px;right:14px;
    background:rgba(255,255,255,0.92);backdrop-filter:blur(8px);
    border:none;cursor:pointer;width:40px;height:40px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:18px;color:var(--text-on-bg);z-index:10;
    box-shadow:0 2px 12px rgba(0,0,0,0.18);transition:all .25s ease;
}
.modal-close:hover{background:var(--accent);color:#fff;transform:rotate(90deg) scale(1.1);}

.modal-inner{display:grid;grid-template-columns:1fr 1fr;overflow-y:auto;flex:1;}
@media(max-width:640px){.modal-inner{grid-template-columns:1fr;}}

.modal-img-col{position:relative;min-height:200px;}
.modal-img{width:100%;height:100%;min-height:260px;object-fit:cover;}
@media(max-width:640px){.modal-img{height:210px;min-height:unset;}}

.modal-details{
    padding:clamp(20px,4vw,40px);
    display:flex;flex-direction:column;gap:18px;overflow-y:auto;
}
.modal-cat{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent-lt);}
.modal-name{font-family:'Playfair Display',serif;font-size:clamp(22px,4vw,34px);font-weight:900;color:var(--text-on-bg);line-height:1.15;}
.modal-desc{font-size:14px;color:#7a5c3a;line-height:1.75;}
.modal-price{font-family:'Playfair Display',serif;font-size:clamp(26px,4vw,38px);font-weight:900;color:var(--accent);letter-spacing:-1px;}

.form-group{display:flex;flex-direction:column;gap:8px;}
.form-group > label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);}
.size-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.size-opt{display:none;}
.size-label{
    display:flex;flex-direction:column;align-items:center;
    padding:11px 6px;border:1.5px solid var(--border);border-radius:var(--radius-sm);
    cursor:pointer;font-weight:600;font-size:13px;transition:all .2s ease;color:#7a5c3a;background:#fff;
}
.size-label span{font-size:11px;color:var(--text-muted);margin-top:3px;}
.size-opt:checked + .size-label{border-color:var(--accent);background:rgba(201,123,43,0.08);color:var(--accent);box-shadow:0 0 0 2px rgba(201,123,43,0.25);}

.qty-row{display:flex;align-items:center;gap:12px;}
.qty-btn{
    background:var(--grad);border:none;cursor:pointer;
    width:36px;height:36px;border-radius:50%;color:#fff;font-size:19px;font-weight:700;
    display:flex;align-items:center;justify-content:center;transition:all .2s ease;
}
.qty-btn:hover{transform:scale(1.1);box-shadow:0 4px 12px rgba(201,123,43,0.4);}
.qty-val{min-width:36px;text-align:center;font-size:19px;font-weight:800;color:var(--text-on-bg);}

.modal-actions{display:grid;grid-template-columns:1fr 1.4fr;gap:10px;}
@media(max-width:380px){.modal-actions{grid-template-columns:1fr;}}
.btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px 18px;border-radius:var(--radius-md);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;cursor:pointer;border:none;transition:all .25s ease;}
.btn-outline{background:#fff;color:var(--text-on-bg);border:2px solid var(--border);}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 6px 18px rgba(201,123,43,0.35);}
.btn-primary:hover{background:var(--grad-h);transform:translateY(-2px);box-shadow:0 10px 28px rgba(201,123,43,0.45);}

/* ═══════════════════════════════════
    CART MODAL — fixed alignment
═══════════════════════════════════ */
.cart-overlay{
    display:none;position:fixed;inset:0;
    background:rgba(15,8,4,0.80);
    backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    z-index:2000;
    /* always center on desktop; bottom-sheet on mobile */
    align-items:center;
    justify-content:center;
    padding:24px;
}
.cart-overlay.open{display:flex;}

/* Mobile: bottom sheet */
@media(max-width:600px){
    .cart-overlay{
        align-items:flex-end;
        justify-content:stretch;
        padding:0;
    }
}

.cart-box{
    background:#fff;
    border-radius:24px;
    width:100%;max-width:480px;
    max-height:88dvh;
    display:flex;flex-direction:column;
    box-shadow:0 24px 64px rgba(0,0,0,0.45);
    animation:cartIn .4s cubic-bezier(.34,1.2,.64,1) both;
}
@media(max-width:600px){
    .cart-box{
        border-radius:24px 24px 0 0;
        max-width:100%;
        max-height:90dvh;
        animation:cartUp .4s cubic-bezier(.34,1.2,.64,1) both;
    }
}
@keyframes cartIn{from{opacity:0;transform:scale(.9);}to{opacity:1;transform:scale(1);}}
@keyframes cartUp{from{opacity:0;transform:translateY(60px);}to{opacity:1;transform:translateY(0);}}

.cart-head{
    display:flex;align-items:center;justify-content:space-between;
    padding:22px clamp(20px,4vw,32px) 18px;
    border-bottom:1px solid var(--border);flex-shrink:0;
}
.cart-head h2{
    font-family:'Playfair Display',serif;
    font-size:clamp(20px,4vw,26px);font-weight:900;
    color:var(--text-on-bg);display:flex;align-items:center;gap:10px;
}
.cart-close{
    background:rgba(201,123,43,0.10);border:none;cursor:pointer;
    width:36px;height:36px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    color:var(--text-on-bg);font-size:15px;transition:all .25s ease;
}
.cart-close:hover{background:var(--accent);color:#fff;transform:rotate(90deg);}

.cart-items{flex:1;overflow-y:auto;padding:14px clamp(20px,4vw,32px);}

.cart-item{
    display:flex;gap:12px;align-items:center;
    padding:12px;border-radius:var(--radius-md);margin-bottom:10px;
    background:rgba(247,242,236,0.6);border:1.5px solid transparent;transition:all .2s ease;
}
.cart-item:hover{border-color:var(--border);background:rgba(247,242,236,0.9);}
.cart-item-thumb{width:52px;height:52px;border-radius:10px;object-fit:cover;flex-shrink:0;}
.cart-item-info{flex:1;min-width:0;}
.cart-item-name{font-weight:700;font-size:13px;color:var(--text-on-bg);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cart-item-meta{font-size:11px;color:var(--text-muted);}
.cart-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0;}
.cart-item-price{font-weight:800;font-size:14px;color:var(--accent);white-space:nowrap;}
.cart-qty-ctrl{display:flex;align-items:center;gap:5px;}
.cqty-btn{
    background:rgba(201,123,43,0.12);border:none;cursor:pointer;
    width:26px;height:26px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    color:var(--accent);font-size:14px;font-weight:700;transition:all .2s ease;
}
.cqty-btn:hover{background:var(--accent);color:#fff;}
.cqty-val{font-size:13px;font-weight:700;min-width:20px;text-align:center;}
.cart-remove-btn{background:none;border:none;cursor:pointer;color:#ccc;font-size:14px;transition:all .2s ease;padding:4px;flex-shrink:0;}
.cart-remove-btn:hover{color:#e63946;transform:scale(1.2);}

.cart-empty{text-align:center;padding:50px 20px;color:var(--text-muted);}
.cart-empty i{font-size:48px;margin-bottom:14px;opacity:.25;display:block;}
.cart-empty p{font-size:15px;font-weight:600;}

.cart-foot{
    padding:18px clamp(20px,4vw,32px);
    border-top:1px solid var(--border);flex-shrink:0;
}
.cart-total-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px;}
.cart-total-row span{font-size:13px;font-weight:600;color:var(--text-muted);}
.cart-total-amount{font-family:'Playfair Display',serif;font-size:28px;font-weight:900;color:var(--accent);}
.checkout-btn{
    width:100%;padding:16px;background:var(--grad);color:#fff;border:none;cursor:pointer;
    border-radius:var(--radius-md);font-family:'DM Sans',sans-serif;font-size:15px;font-weight:800;
    box-shadow:0 6px 20px rgba(201,123,43,0.4);transition:all .25s ease;
}
.checkout-btn:hover{background:var(--grad-h);transform:translateY(-2px);box-shadow:0 10px 28px rgba(201,123,43,0.5);}
.checkout-btn:disabled{background:#e0d6cc;color:#bba88a;cursor:not-allowed;transform:none;box-shadow:none;}

/* ── Toast ── */
.toast{
    position:fixed;bottom:clamp(20px,4vw,36px);right:24px;
    transform:translateY(20px);
    background:#1a0f08;color:#fff;
    padding:13px 22px;border-radius:50px;font-size:14px;font-weight:600;
    display:flex;align-items:center;gap:9px;
    box-shadow:0 8px 32px rgba(0,0,0,0.4);z-index:4000;
    white-space:nowrap;opacity:0;pointer-events:none;
    transition:opacity .3s ease,transform .3s ease;
}
.toast.show{opacity:1;transform:translateY(0);}
.toast i{color:var(--amber);font-size:15px;}

/* ── Back to top ── */
#backToTop{
    position:fixed;bottom:26px;right:clamp(14px,3vw,30px);
    width:44px;height:44px;border-radius:50%;
    background:var(--grad);color:#fff;border:none;cursor:pointer;
    display:none;align-items:center;justify-content:center;
    font-size:16px;z-index:999;
    box-shadow:0 4px 16px rgba(201,123,43,0.45);transition:all .3s ease;
}
#backToTop:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(201,123,43,0.6);}

/* scrollbar */
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:rgba(201,123,43,0.06);}
::-webkit-scrollbar-thumb{background:var(--grad);border-radius:3px;}
::selection{background:var(--accent);color:#fff;}

/* safe area */
@supports(padding:max(0px)){
    .navbar{
        padding-left:max(clamp(16px,4vw,60px),env(safe-area-inset-left));
        padding-right:max(clamp(16px,4vw,60px),env(safe-area-inset-right));
    }
    .cart-foot{padding-bottom:max(18px,env(safe-area-inset-bottom));}
}

.card-unavailable {
    background: #8B6355 !important;
    cursor: not-allowed !important;
    opacity: 0.85;
}

/* ── Favorites nav button ── */
.fav-btn {
    position: relative;
    background: var(--grad);
    border: none;
    cursor: pointer;
    width: 44px; height: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 17px;
    box-shadow: 0 4px 14px rgba(201,123,43,0.45);
    transition: all .3s cubic-bezier(.4,0,.2,1);
    flex-shrink: 0;
    text-decoration: none;
}
.fav-btn:hover { transform: translateY(-2px) scale(1.05); box-shadow: 0 8px 24px rgba(201,123,43,0.6); }

.fav-badge {
    position: absolute; top: -5px; right: -5px;
    background: #e63946; color: #fff;
    min-width: 19px; height: 19px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 10px; font-weight: 800;
    border: 2px solid #1a0f08;
}

/* ── Card heart button ── */
.card-fav {
    position: absolute;
    top: 10px; right: 10px;
    width: 34px; height: 34px;
    border-radius: 50%;
    background: rgba(26,15,8,0.55);
    backdrop-filter: blur(4px);
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,0.7);
    font-size: 14px;
    transition: all .2s ease;
    z-index: 2;
}
.card-fav:hover { background: rgba(26,15,8,0.75); color: #fff; transform: scale(1.1); }
.card-fav.active { color: #e63946; background: rgba(26,15,8,0.65); }
.card-fav.active:hover { color: #ff4d5e; }