/* ============================================================
   ISTANA KAMERA — Main Stylesheet v2 (Cleaned)
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
    --bg:#111111;--bg2:#181818;--bg3:#1e1e1e;--bg4:#242424;
    --gray:#4A4AAA;--gray-light:#888;
    --orange:#FF8A00;--orange-dk:#cc6e00;--orange-lt:#ffaa44;
    --white:#FFFFFF;--text:#e0e0e0;--text-muted:#888;
    --border:rgba(255,255,255,0.08);--shadow:0 4px 24px rgba(0,0,0,0.5);
    --radius:10px;--radius-lg:16px;--transition:.22s ease;
    --header-h:72px;--topbar-h:36px;--catnav-h:48px;
    --font-display:'Bebas Neue',sans-serif;
    --font-head:'Rajdhani',sans-serif;
    --font-body:'Inter',sans-serif;
}

html, body {
    max-width: 100%;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:15px;line-height:1.6;overflow-x:hidden;}

/* ── Input Number: hilangkan panah naik-turun ── */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0;}
input[type=number]{-moz-appearance:textfield;}

/* ── Input Date: warna putih + ikon kalender ── */
input[type=date]{color:var(--white);}
input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer;}

a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{cursor:pointer;border:none;background:none;font-family:inherit;}
ul{list-style:none;}
.container{max-width:1320px;margin:0 auto;padding:0 20px;}

/* ── Flash ── */
.flash-toast{position:fixed;top:80px;right:20px;z-index:9999;padding:14px 20px;border-radius:var(--radius);display:flex;align-items:center;gap:12px;font-weight:500;font-size:14px;animation:slideIn .3s ease;box-shadow:var(--shadow);}
.flash-success{background:#1a3a1a;border:1px solid #2e7d32;color:#69f09e;}
.flash-error{background:#3a1a1a;border:1px solid #7d2e2e;color:#f06969;}
.flash-info{background:#1a2a3a;border:1px solid #1565c0;color:#64b5f6;}
.flash-toast button{color:inherit;opacity:.7;font-size:16px;}
@keyframes slideIn{from{transform:translateX(120%);opacity:0}to{transform:translateX(0);opacity:1}}

/* ── Top Bar ── */
.topbar{background:var(--bg2);border-bottom:1px solid var(--border);height:var(--topbar-h);}
.topbar-inner{max-width:1320px;margin:0 auto;padding:0 20px;height:100%;display:flex;align-items:center;gap:16px;font-size:12.5px;color:var(--text-muted);}
.topbar-inner a{color:var(--orange);transition:opacity var(--transition);}
.topbar-inner a:hover{opacity:.8;}

/* ── Main Header ── */
.main-header{position:sticky;top:var(--topbar-h);z-index:1000;background:rgba(17,17,17,.96);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);height:var(--header-h);transition:box-shadow var(--transition);}
.main-header.scrolled{box-shadow:0 4px 32px rgba(0,0,0,.6);}
.header-inner{max-width:1320px;margin:0 auto;padding:0 20px;height:100%;display:flex;align-items:center;gap:24px;}
.header-logo{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.logo-text{display:flex;flex-direction:column;line-height:1;}
.logo-main{font-family:var(--font-head);font-weight:400;font-size:22px;letter-spacing:.05em;color:var(--white);}
.logo-main strong{color:var(--orange);font-weight:700;}
.logo-sub{font-size:8.5px;letter-spacing:.3em;color:var(--orange);opacity:.85;margin-top:1px;font-weight:500;}

/* Search */
.header-search{flex:1;max-width:580px;position:relative;}
.header-search input{width:100%;height:44px;background:var(--bg3);border:1.5px solid var(--border);border-radius:100px;padding:0 52px 0 22px;color:var(--white);font-family:var(--font-body);font-size:14px;transition:border-color var(--transition),background var(--transition);outline:none;}
.header-search input::placeholder{color:var(--text-muted);}
.header-search input:focus{border-color:var(--orange);background:var(--bg4);}
.header-search button{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:var(--orange);color:var(--white);display:flex;align-items:center;justify-content:center;transition:background var(--transition);}
.header-search button:hover{background:var(--orange-dk);}
.search-suggestions{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:none;z-index:100;}
.search-suggestions.open{display:block;}
.suggestion-item{padding:10px 18px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:background var(--transition);font-size:13px;}
.suggestion-item:hover{background:var(--bg4);}
.suggestion-item img{width:36px;height:36px;object-fit:cover;border-radius:6px;}

/* Header Actions */
.header-actions{display:flex;align-items:center;gap:4px;flex-shrink:0;}
.action-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 10px;border-radius:var(--radius);color:var(--text-muted);transition:color var(--transition),background var(--transition);position:relative;cursor:pointer;}
.action-btn:hover{color:var(--white);background:var(--bg3);}
.action-label{font-size:10.5px;font-weight:500;}
.cart-badge{position:absolute;top:4px;right:4px;background:var(--orange);color:var(--white);font-size:10px;font-weight:700;line-height:1;min-width:18px;height:18px;border-radius:100px;padding:0 4px;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg);}
.user-menu{position:relative;}
.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);min-width:180px;box-shadow:var(--shadow);display:none;z-index:200;overflow:hidden;}
.user-dropdown.open{display:block;}
.user-dropdown a{display:block;padding:11px 16px;font-size:13.5px;transition:background var(--transition);}
.user-dropdown a:hover{background:var(--bg4);color:var(--orange);}
.user-dropdown hr{border-color:var(--border);}
.logout-link{color:#ff6b6b!important;}

/* ── Category Nav ── */
.category-nav {
    position: sticky;
    top: calc(var(--topbar-h) + var(--header-h));
    z-index: 999999;
    background: var(--bg2);
    border-bottom: 1px solid var(--border);
    height: var(--catnav-h);
    display: flex;
    align-items: center;
}
@media (min-width: 769px) {
    .category-nav { padding: 0 45px; }
}

/* Scroll buttons */
.cat-scroll-btn {
    width: 36px;
    height: 100%;
    display: none;
    align-items: center;
    justify-content: center;
    background: #181818;
    color: var(--orange);
    cursor: pointer;
    z-index: 1005;
    position: absolute;
    top: 0;
    border: none;
    transition: color var(--transition);
}
.cat-scroll-btn:hover { color: var(--white); }
.cat-scroll-left  { left: 0;  border-right: 1px solid var(--border); box-shadow: 6px 0 12px rgba(0,0,0,0.7); }
.cat-scroll-right { right: 0; border-left:  1px solid var(--border); box-shadow: -6px 0 12px rgba(0,0,0,0.7); }
.category-nav.has-overflow .cat-scroll-btn { display: flex; }

/* Nav wrapper & track */
.cat-nav-wrapper {
    flex: 1;
    overflow-x: auto;
    overflow-y: hidden;
    height: 100%;
    display: flex;
    align-items: center;
    scrollbar-width: none;
}
.cat-nav-wrapper::-webkit-scrollbar { display: none; }

.cat-nav-track {
    display: flex;
    align-items: center;
    gap: 4px;
    width: max-content;
    height: 100%;
    padding: 0 8px;
    scroll-behavior: smooth;
}

/* Cat items */
.cat-item-wrap { display: inline-flex; align-items: center; }
.cat-item{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:100px;font-family:var(--font-head);font-size:13.5px;font-weight:600;color:var(--text-muted);white-space:nowrap;transition:color var(--transition),background var(--transition);border:1.5px solid transparent;}
.cat-item:hover{color:var(--white);background:var(--bg3);}
.cat-item.active{color:var(--orange);border-color:var(--orange);background:rgba(255,138,0,.1);}
.cat-arrow{font-size:10px;margin-left:2px;transition:transform .2s;}
.cat-item-wrap:hover .cat-arrow{transform:rotate(180deg);}

/* Portal dropdown (fixed, bebas overflow) */
.cat-dropdown-portal {
    position: fixed;
    top: calc(var(--header-h) + var(--topbar-h) + var(--catnav-h));
    left: 0;
    width: 100%;
    height: 0;
    pointer-events: none;
    z-index: 1000000000;
}
.cat-dropdown-portal.active { pointer-events: auto; }

.cat-submenu-panel {
    position: absolute;
    top: 2px;
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    min-width: 210px;
    box-shadow: 0 12px 36px rgba(0,0,0,0.9);
    padding: 6px;
    display: none;
    opacity: 0;
    transform: translateY(-8px);
    transition: opacity 0.15s ease, transform 0.15s ease;
}
.cat-submenu-panel.open {
    display: block;
    opacity: 1;
    transform: translateY(0);
}
.cat-submenu-panel a {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 9px 12px;
    font-size: 13px;
    color: var(--text);
    transition: background var(--transition), color var(--transition);
    white-space: nowrap;
    border-radius: 6px;
    width: 100%;
}
.cat-submenu-panel a:hover { background: var(--bg4); color: var(--orange); }

/* Helper classes (dipakai JS/PHP) */
.submenu-scroll-container { display: flex; flex-direction: column; gap: 4px; width: 100%; }
.submenu-items-wrapper     { display: flex; flex-direction: column; gap: 2px; }

/* ── Hero Slider Boxed Responsive ── */

/* 1. Section terluar: full-width, hitam */
.hero-slider.hero-slider-boxed {
    width: 100% !important;
    max-width: 100% !important;
    background: #0d0d0d !important;
    padding: 0 !important;
    overflow: hidden !important;
    position: relative !important;
}

/* 2. Shield: kotak tengah max 1240px, overflow hidden — satu-satunya kunci potong */
.hero-slider-boxed .slider-overflow-shield {
    max-width: 1240px !important;
    width: 100% !important;
    margin: 0 auto !important;
    padding: 0 !important;
    position: relative !important;
    background: #0d0d0d !important;
    overflow: hidden !important;
}

/* 3. Container di dalam shield: 100% lebar shield, TIDAK tambah max-width */
.hero-slider-boxed .container {
    max-width: 100% !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    position: static !important;
    background: transparent !important;
    overflow: visible !important;
}

/* 4. Track: flex row tanpa gap */
.hero-slider-boxed .slider-track {
    display: flex !important;
    width: 100% !important;
    flex-wrap: nowrap !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: 0 !important;
    transition: transform .55s cubic-bezier(.25,.46,.45,.94) !important;
    will-change: transform !important;
    font-size: 0 !important;
    line-height: 0 !important;
}

/* 5. Slide: aspect-ratio berlaku di SEMUA ukuran layar
   — tidak ada height fixed, jadi tinggi selalu proporsional dengan lebar
   — max-height 480px mencegah terlalu tinggi di layar sangat lebar */
.slide.slide-responsive {
    flex-shrink: 0 !important;
    flex-grow: 0 !important;
    min-width: 100% !important;
    max-width: 100% !important;
    width: 100% !important;
    aspect-ratio: 1240 / 480 !important;
    max-height: 480px !important;
    position: relative !important;
    overflow: hidden !important;
    background: #0d0d0d !important;
    display: block !important;
    font-size: initial !important;
    line-height: initial !important;
}

/* 6. Link wrapper: full ukuran slide */
.slide.slide-responsive > a {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    line-height: 0 !important;
}

/* 7. Gambar: cover penuh slide */
.slide-responsive img {
    width: 100% !important;
    height: 100% !important;
    max-height: 480px !important;
    display: block !important;
    border-radius: 0 !important;
    object-fit: cover !important;
    object-position: center center !important;
    margin: 0 !important;
    padding: 0 !important;
    vertical-align: bottom !important;
}

/* Aturan Tampilan Navigasi Panah Slider */
.slider-prev, .slider-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(255,255,255,.1) !important;
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,.15) !important;
    color: var(--white) !important;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    transition: background var(--transition);
}
.slider-prev { left: 30px; }
.slider-next { right: 30px; }
.slider-prev:hover, .slider-next:hover { background: var(--orange) !important; }

/* Aturan Titik Navigasi Bawah Slider */
.slider-dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 12px;
}
.slider-dots .dot {
    width: 8px;
    height: 8px;
    background: rgba(255,255,255,0.3) !important;
    border-radius: 50%;
    cursor: pointer;
    transition: all var(--transition);
}
.slider-dots .dot.active { 
    background: var(--orange) !important; 
    width: 24px; 
}

/* Placeholder Lembut Jika Gambar Belum Diunggah */
.banner-placeholder {
    width: 100%;
    aspect-ratio: 1920 / 480;
    background: linear-gradient(135deg, #1a1a1a, #111);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 20px;
}

/* ══════════════════════════════════════════════════════════ */
/*  PEMBERSIHAN TOTAL ELEMEN TEKS & TOMBOL LAMA               */
/* ══════════════════════════════════════════════════════════ */
.slide-content, 
.slide-btn, 
.slide-bg::after, 
.slide-eyebrow, 
.slide-title, 
.slide-desc {
    display: none !important; /* 🔒 Mematikan dan membuang semua sisa teks/tombol agar tidak mengacaukan layout */
}

/* ── Ads Grid ── */
.ads-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.ad-card { border-radius: var(--radius); overflow: hidden; position: relative; aspect-ratio: 3/1; background: var(--bg3); cursor: pointer; transition: transform var(--transition); }
.ad-card:hover { transform: translateY(-3px); }
.ad-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.ad-card:hover img { transform: scale(1.04); }
.ad-card-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.5) 0%, transparent 60%); }
.ad-card-label { position: absolute; bottom: 12px; left: 14px; font-family: var(--font-head); font-size: 14px; font-weight: 700; color: var(--white); }
.ad-placeholder { width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; background: linear-gradient(135deg, var(--bg3), var(--bg4)); font-size: 12px; color: var(--text-muted); padding: 12px; text-align: center; }


/* ── Product Card ── */
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
@media(max-width:1200px){.product-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:900px){.product-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:540px){.product-grid{grid-template-columns:1fr 1fr;gap:12px;}}

.product-card {
    background: var(--bg2);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    overflow: hidden;
    padding: 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
    position: relative;
}
.product-card:hover{transform:translateY(-5px);border-color:rgba(255,138,0,.3);box-shadow:0 12px 40px rgba(0,0,0,.5);}

.product-img {
    position: relative;
    width: 130px;
    height: 130px;
    overflow: hidden;
    background: var(--bg3);
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 10px;
}
.product-img img{max-width:100%;max-height:100%;object-fit:contain;}
.product-card:hover .product-img img{transform:scale(1.06);}

.product-badges{position:absolute;top:10px;left:10px;display:flex;gap:5px;flex-wrap:wrap;}
.badge{padding:3px 9px;border-radius:100px;font-size:11px;font-weight:700;letter-spacing:.03em;}
.badge-sale{background:var(--orange);color:var(--white);}
.badge-new{background:#1e3a5f;color:#64b5f6;}
.badge-hot{background:#3a1a1a;color:#ff6b6b;}
.badge-expire{background:#2a1a0a;color:#ffaa44;font-size:10px;}
.product-wish{position:absolute;top:10px;right:10px;width:34px;height:34px;border-radius:50%;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:16px;transition:all var(--transition);opacity:0;}
.product-card:hover .product-wish{opacity:1;}
.product-wish:hover{background:var(--orange);color:var(--white);}
.product-wish.active{opacity:1;color:#ff6b6b;background:rgba(255,107,107,.15);}

.product-info { width: 100%; padding: 4px 0 0 0; }
.product-brand{font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--orange);text-transform:uppercase;margin-bottom:4px;}
.product-name {
    font-family: var(--font-head);
    font-size: 14px;
    font-weight: 600;
    color: var(--white);
    margin-bottom: 6px;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    height: 36px;
}
.product-rating{display:flex;align-items:center;gap:6px;margin-bottom:10px;}
.stars{display:flex;gap:1px;font-size:12px;}
.star.full{color:#ffc107;}.star.half{color:#ffc107;}.star.empty{color:#444;}
.rating-count{font-size:11px;color:var(--text-muted);}
.product-price{display:flex;align-items:center;gap:8px;margin-bottom:4px;}
.price-current{font-family:var(--font-head);font-size:17px;font-weight:700;color:var(--orange);}
.price-original{font-size:12px;color:var(--text-muted);text-decoration:line-through;}
.price-label-grosir{font-size:10px;color:var(--text-muted);font-style:italic;display:block;margin-top:2px;}
.promo-end{font-size:10.5px;color:#ffaa44;margin-bottom:10px;}
.product-actions{display:flex;gap:8px;}
.btn-cart{flex:1;height:38px;border-radius:100px;background:var(--orange);color:var(--white);font-family:var(--font-head);font-size:13.5px;font-weight:700;transition:background var(--transition);letter-spacing:.03em;}
.btn-cart:hover{background:var(--orange-dk);}
.btn-detail{width:38px;height:38px;border-radius:50%;border:1.5px solid var(--border);color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:all var(--transition);font-size:14px;}
.btn-detail:hover{border-color:var(--orange);color:var(--orange);}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:100px;font-family:var(--font-head);font-weight:700;font-size:14.5px;letter-spacing:.04em;transition:all var(--transition);cursor:pointer;}
.btn-primary{background:var(--orange);color:var(--white);}
.btn-primary:hover{background:var(--orange-dk);transform:translateY(-2px);}
.btn-outline{border:2px solid var(--orange);color:var(--orange);}
.btn-outline:hover{background:var(--orange);color:var(--white);}
.btn-ghost{border:1.5px solid var(--border);color:var(--text-muted);}
.btn-ghost:hover{border-color:var(--white);color:var(--white);}
.btn-block{width:100%;justify-content:center;}

/* ── Forms ── */
.form-group{margin-bottom:18px;}
.form-label{display:block;font-size:12.5px;font-weight:700;margin-bottom:7px;color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;}
.form-control{width:100%;height:46px;padding:0 16px;background:var(--bg3);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--white);font-family:var(--font-body);font-size:14px;transition:border-color var(--transition);outline:none;}
.form-control::placeholder{color:var(--text-muted);}
.form-control:focus{border-color:var(--orange);}
textarea.form-control{height:auto;min-height:90px;padding:12px 16px;resize:vertical;line-height:1.5;overflow-y:auto;}
select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;}

/* ── Breadcrumb ── */
.breadcrumb{display:flex;align-items:center;gap:8px;padding:16px 0;font-size:13px;color:var(--text-muted);}
.breadcrumb a{color:var(--text-muted);transition:color var(--transition);}
.breadcrumb a:hover{color:var(--orange);}
.breadcrumb-sep{opacity:.4;}

/* ── Pagination ── */
.pagination{display:flex;gap:6px;justify-content:center;margin-top:40px;}
.page-btn{width:38px;height:38px;border-radius:var(--radius);background:var(--bg3);border:1px solid var(--border);color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:13.5px;font-weight:600;transition:all var(--transition);}
.page-btn:hover,.page-btn.active{background:var(--orange);color:var(--white);border-color:var(--orange);}

/* ── Footer ── */
.site-footer{background:#0d0d0d;margin-top:60px;}
.footer-top{padding:56px 0 40px;border-top:1px solid var(--border);}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1.2fr 1.2fr;gap:48px;}
.footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:18px;}
.footer-logo-name{font-family:var(--font-head);font-size:18px;font-weight:400;color:var(--white);}
.footer-logo-name strong{color:var(--orange);font-weight:700;}
.footer-logo-sub{font-size:8px;letter-spacing:.25em;color:var(--orange);opacity:.7;}
.footer-desc{font-size:13.5px;color:var(--text-muted);line-height:1.8;margin-bottom:20px;}
.footer-socials{display:flex;gap:8px;}
.social-btn{width:36px;height:36px;border-radius:50%;background:var(--bg3);border:1px solid var(--border);color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:all var(--transition);}
.social-btn:hover{background:var(--orange);color:var(--white);border-color:var(--orange);}
.footer-heading{font-family:var(--font-head);font-size:15px;font-weight:700;color:var(--white);margin-bottom:18px;letter-spacing:.08em;text-transform:uppercase;}
.footer-heading::after{content:'';display:block;width:32px;height:2px;background:var(--orange);margin-top:6px;border-radius:1px;}
.footer-links li{margin-bottom:10px;}
.footer-links a{font-size:13.5px;color:var(--text-muted);transition:color var(--transition),padding-left var(--transition);}
.footer-links a:hover{color:var(--orange);padding-left:4px;}
.footer-contact{margin-bottom:20px;}
.footer-contact li{display:flex;gap:10px;margin-bottom:12px;font-size:13px;color:var(--text-muted);}
.contact-icon{font-size:14px;margin-top:1px;flex-shrink:0;}
.footer-contact a{color:var(--text-muted);transition:color var(--transition);}
.footer-contact a:hover{color:var(--orange);}
.footer-hours{font-size:12px;color:var(--text-muted);line-height:1.8;}
.footer-hours strong{color:var(--white);}
.footer-ecom-desc{font-size:12.5px;color:var(--text-muted);margin-bottom:14px;}
.footer-marketplace{display:flex;flex-direction:column;gap:10px;margin-bottom:24px;}
.marketplace-btn{display:flex;align-items:center;gap:10px;padding:9px 14px;border-radius:var(--radius);background:var(--bg3);border:1px solid var(--border);font-size:13.5px;font-weight:600;color:var(--text);transition:all var(--transition);}
.marketplace-btn:hover{border-color:var(--orange);color:var(--white);transform:translateX(4px);}
.footer-payment p{font-size:12px;color:var(--text-muted);margin-bottom:10px;}
.payment-icons{display:flex;flex-wrap:wrap;gap:6px;}
.pay-badge{padding:3px 9px;background:var(--bg3);border:1px solid var(--border);border-radius:4px;font-size:11px;font-weight:700;color:var(--text-muted);}
.footer-bottom{border-top:1px solid var(--border);padding:18px 0;text-align:center;font-size:13px;color:var(--text-muted);}

/* ── Back to Top ── */
.back-to-top{position:fixed;bottom:24px;right:24px;z-index:999;width:44px;height:44px;border-radius:50%;background:var(--orange);color:var(--white);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(255,138,0,.35);opacity:0;pointer-events:none;transition:opacity var(--transition),transform var(--transition);transform:translateY(10px);}
.back-to-top.visible{opacity:1;pointer-events:auto;transform:translateY(0);}
.back-to-top:hover{transform:translateY(-3px);}

/* WA Float Button */
.wa-float{position:fixed;bottom:76px;right:22px;z-index:998;width:50px;height:50px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(37,211,102,.4);transition:transform var(--transition);}
.wa-float:hover{transform:scale(1.1);}
.wa-float-mascot{width:100%;height:100%;border-radius:50%;object-fit:cover;}

/* ── Auth ── */
.auth-page{min-height:calc(100vh - var(--header-h) - var(--topbar-h));display:flex;align-items:center;justify-content:center;padding:40px 20px;background:radial-gradient(ellipse at 30% 40%,rgba(255,138,0,.07) 0%,transparent 60%);}
.auth-card{width:100%;max-width:460px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;}
.auth-title{font-family:var(--font-head);font-size:28px;font-weight:700;color:var(--white);margin-bottom:6px;}
.auth-sub{font-size:14px;color:var(--text-muted);margin-bottom:32px;}
.auth-switch{text-align:center;font-size:13.5px;color:var(--text-muted);}
.auth-switch a{color:var(--orange);font-weight:600;}

/* ── Cart ── */
.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:28px;align-items:start;}
.cart-item{display:flex;gap:16px;padding:18px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;}
.cart-item-img{width:90px;height:90px;border-radius:8px;object-fit:cover;flex-shrink:0;}
.cart-item-name{font-family:var(--font-head);font-size:15px;font-weight:600;color:var(--white);}
.qty-control{display:flex;align-items:center;background:var(--bg3);border-radius:100px;border:1px solid var(--border);width:fit-content;}
.qty-btn{width:32px;height:32px;border-radius:100px;color:var(--text-muted);font-size:18px;display:flex;align-items:center;justify-content:center;transition:color var(--transition);}
.qty-btn:hover{color:var(--orange);}
.qty-val{min-width:32px;text-align:center;font-weight:600;font-size:14px;}
.cart-summary{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;position:sticky;top:140px;}
.summary-title{font-family:var(--font-head);font-size:18px;font-weight:700;margin-bottom:20px;}
.summary-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;font-size:14px;border-bottom:1px solid var(--border);}
.summary-row.total{font-family:var(--font-head);font-size:18px;font-weight:700;color:var(--orange);border:none;padding-top:16px;}

/* ── Admin Layout ── */
.admin-layout{display:flex;min-height:100vh;}
.admin-sidebar{width:240px;background:var(--bg2);border-right:1px solid var(--border);position:fixed;top:0;left:0;height:100vh;overflow-y:auto;padding-top:20px;z-index:100;}
.admin-main{margin-left:240px;padding:28px;flex:1;min-height:100vh;width:calc(100% - 240px);max-width:calc(100vw - 240px);min-width:0;overflow-x:auto;}
.admin-nav-link{display:flex;align-items:center;gap:10px;padding:11px 20px;font-size:14px;font-weight:500;color:var(--text-muted);transition:all var(--transition);}
.admin-nav-link:hover,.admin-nav-link.active{color:var(--orange);background:rgba(255,138,0,.07);}
.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:28px;}
.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;}
.stat-val{font-family:var(--font-head);font-size:26px;font-weight:700;color:var(--orange);}
.stat-label{font-size:12.5px;color:var(--text-muted);margin-top:4px;}

/* Admin scrollbar */
.admin-main::-webkit-scrollbar{height:8px;}
.admin-main::-webkit-scrollbar-track{background:var(--bg);}
.admin-main::-webkit-scrollbar-thumb{background:#333333;border-radius:10px;}
.admin-main::-webkit-scrollbar-thumb:hover{background:var(--orange);}

/* Table */
.data-table{width:100%;border-collapse:collapse;}
.data-table th{text-align:left;padding:12px 16px;background:var(--bg3);font-family:var(--font-head);font-size:12.5px;font-weight:700;letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;}
.data-table td{padding:13px 16px;border-bottom:1px solid var(--border);font-size:13.5px;vertical-align:middle;}
.data-table tr:last-child td{border-bottom:none;}
.data-table tr:hover td{background:var(--bg3);}

/* ── Empty State ── */
.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted);}
.empty-state-icon{font-size:56px;margin-bottom:16px;}
.empty-state h3{font-family:var(--font-head);font-size:22px;color:var(--white);margin-bottom:8px;}
.empty-state p{font-size:14px;max-width:360px;margin:0 auto 24px;}

/* ── Utils ── */
.text-orange{color:var(--orange);}.text-muted{color:var(--text-muted);}
.hidden{display:none!important;}
@keyframes cartPop{0%{transform:scale(1)}50%{transform:scale(1.4)}100%{transform:scale(1)}}
.cart-badge.pop{animation:cartPop .3s ease;}

/* ── Tombol toggle sidebar subkategori ── */
.btn-toggle-sidebar-sub{background:var(--bg3);border:1px solid var(--border);color:var(--orange);padding:6px 10px;font-size:11px;font-weight:600;border-radius:4px;cursor:pointer;text-align:left;width:100%;transition:background var(--transition);}
.btn-toggle-sidebar-sub:hover{background:var(--bg4);}
.sidebar-sub-wrapper.collapsed-hide{display:none!important;}

/* ── Top Filter Bar ── */
.top-filter-wrapper {
    position: relative;
    z-index: 50;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 16px;
    margin-bottom: 24px;
}
.top-filter-row{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;}
.filter-item{flex:1;min-width:200px;}
.filter-item label{display:block;font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px;}
.filter-select, .filter-input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px;color:var(--white);font-family:var(--font-body);font-size:13px;outline:none;height:38px;transition:var(--transition);}
.filter-select:focus, .filter-input:focus{border-color:var(--orange);}
select.filter-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://w3.org' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer;}
.price-input-group{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.filter-btn-group{display:flex;gap:8px;align-items:center;}
.btn-filter-apply{background:var(--orange);color:var(--white);border:none;border-radius:var(--radius);padding:0 20px;height:38px;font-family:var(--font-head);font-size:13.5px;font-weight:700;letter-spacing:.04em;cursor:pointer;transition:var(--transition);}
.btn-filter-apply:hover{background:var(--orange-dk);}
.btn-filter-reset{border:1.5px solid #ff6b6b;color:#ff6b6b;background:transparent;border-radius:var(--radius);padding:0 14px;height:38px;font-family:var(--font-head);font-size:13.5px;font-weight:700;letter-spacing:.04em;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;transition:var(--transition);}
.btn-filter-reset:hover{background:#ff6b6b;color:var(--white);}

/* ── Brand Section ── */
.brand-section{margin-top:24px;margin-bottom:24px;}
.brand-section p{font-family:var(--font-head);font-size:16px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--white);}
.brand-section .btn-outline-secondary,.brand-scroll-container .btn-outline-secondary,.brand-scroll-container a{border:none!important;background:transparent!important;box-shadow:none!important;outline:none!important;min-width:auto;height:60px;display:inline-flex;align-items:center;justify-content:center;padding:0 20px;cursor:pointer;transition:var(--transition);}
.brand-section .btn-outline-secondary img,.brand-scroll-container .btn-outline-secondary img,.brand-scroll-container a img{width:auto!important;height:auto!important;max-width:140px!important;max-height:28px!important;object-fit:contain!important;filter:grayscale(0%) brightness(1);opacity:0.9;background:transparent!important;mix-blend-mode:normal!important;display:inline-block!important;transition:var(--transition);}
.brand-section .btn-outline-secondary:hover img,.brand-section .btn-outline-secondary.active-orange img,.brand-scroll-container .btn-outline-secondary:hover img,.brand-scroll-container a:hover img{opacity:1;transform:scale(1.05);}
.brand-section .btn-outline-secondary span{font-family:var(--font-head);font-size:18px;font-weight:700;letter-spacing:.05em;color:var(--text-muted);transition:var(--transition);}
.brand-section .btn-outline-secondary:hover span,.brand-section .btn-outline-secondary.active-orange span{color:var(--orange)!important;}
.brand-section .product-img{background:transparent!important;}

/* ── Responsive ── */
@media(max-width:1024px){
    .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
    .cart-layout{grid-template-columns:1fr;}
    .admin-stats{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:768px){
    html, body{width:100%;max-width:100vw;position:relative;}
    .hero-slider{height:auto !important;}/* biarkan aspect-ratio yang kontrol tinggi */
    .slide-content{padding:0 30px;}
    .ads-grid{grid-template-columns:1fr;}
    .footer-grid{grid-template-columns:1fr;gap:28px;}
    .logo-sub,.action-label{display:none;}
    .admin-sidebar{width:200px;}
    .admin-main{margin-left:200px;width:calc(100% - 200px);max-width:calc(100vw - 200px);}
    .category-nav{display:flex;align-items:center;width:100%;max-width:100vw;overflow:visible;}
    .category-nav .cat-nav-wrapper,#catNavWrapper{display:block;flex:1;width:calc(100vw - 72px);max-width:calc(100vw - 72px);overflow:hidden;}
    .category-nav .cat-nav-track,#catNavTrack{display:flex;align-items:center;gap:6px;padding:0 10px;overflow-x:auto;white-space:nowrap;scrollbar-width:none;}
    .cat-nav-track::-webkit-scrollbar{display:none;}
    .cat-submenu-panel{display:none!important;}
    .top-filter-row{flex-direction:column;align-items:stretch;}
    .filter-item{width:100%;}
    .filter-btn-group{flex-direction:column;align-items:stretch;}
    .btn-filter-apply,.btn-filter-reset{width:100%;text-align:center;}
}
@media(max-width:600px){
    .header-inner{gap:12px;}
    .logo-main{font-size:18px;}
}
/* ── Value Props Grid ── */
.value-props-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    text-align: left;
}
/* HP kecil: tetap 3 kolom tapi lebih compact */
@media (max-width: 480px) {
    .value-props-grid {
        gap: 8px;
    }
    .value-props-grid > div {
        gap: 8px !important;
        align-items: flex-start !important;
    }
    .value-props-grid > div > div:first-child {
        font-size: 22px !important;
        flex-shrink: 0;
    }
    .value-props-grid > div > div:last-child > div:first-child {
        font-size: 11px !important;
    }
    .value-props-grid > div > div:last-child > div:last-child {
        font-size: 10px !important;
    }
}
@media (max-width: 480px) {
    .value-props-section { padding: 16px 0 !important; }
    .value-props-section .container { padding: 0 12px; }
}
