﻿/* ===== moved from: application/modules/home/views/home/produk_by_kategori.php ===== */
/* Scoped Styles — produk_by_kategori */

.pbk-section {
    padding: 0.5rem 0;
}

.pbk-wrapper {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.06);
    overflow: hidden;
    margin-bottom: 12px;
    border: 1px solid rgba(212, 165, 116, 0.1);
}

.pbk-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px 12px;
    border-bottom: 1px solid #f0ebe5;
}

.pbk-header__left {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.pbk-header__icon-ring {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(212,165,116,0.15), rgba(212,165,116,0.08));
    color: var(--vintage-rose, #d4a574);
    font-size: 1rem;
    flex-shrink: 0;
    transition: all 0.3s ease;
}

.pbk-wrapper:hover .pbk-header__icon-ring {
    background: linear-gradient(135deg, var(--vintage-rose, #d4a574), var(--primary-dark, #c19660));
    color: #fff;
    transform: scale(1.05);
}

.pbk-header__title {
    font-size: 1rem;
    font-weight: 700;
    color: #2c2c2c;
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    letter-spacing: -0.01em;
}

.pbk-header__link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--vintage-rose, #d4a574);
    text-decoration: none;
    white-space: nowrap;
    flex-shrink: 0;
    padding: 6px 12px;
    border-radius: 20px;
    transition: all 0.25s ease;
}

.pbk-header__link:hover {
    background: rgba(212,165,116,0.1);
    color: var(--primary-dark, #c19660);
}

.pbk-header__link i {
    font-size: 0.7rem;
    transition: transform 0.25s ease;
}

.pbk-header__link:hover i {
    transform: translateX(3px);
}

.pbk-slider-container {
    position: relative;
    padding: 14px 16px 18px;
}

.pbk-slide {
    width: 160px;
    height: auto;
}

.pbk-card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid #f0f0f0;
    height: 100%;
    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    position: relative;
}

.pbk-card:hover {
    border-color: rgba(212,165,116,0.3);
}

/* ===== moved from: application/modules/home/views/home/produk_terbaru.php ===== */
.pbk-grid-container {
    padding: 14px 16px 18px;
}

.pbk-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

@media (min-width: 576px) {
    .pbk-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 768px) {
    .pbk-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (min-width: 1200px) {
    .pbk-grid {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }
}

.pbk-grid__item {
    min-width: 0; /* Mencegah overflow grid item */
}

/* Empty state */
.pbk-empty {
    text-align: center;
    padding: 48px 16px;
    color: #999;
}

.pbk-empty i {
    font-size: 2.5rem;
    opacity: 0.35;
    display: block;
    margin-bottom: 8px;
}

.pbk-empty p {
    font-size: 0.875rem;
    margin: 0;
}

@media (max-width: 575.98px) {
    .pbk-grid-container {
        padding: 10px 12px 14px;
    }
    .pbk-grid {
        gap: 10px;
    }
}

/* ── Overlay Coming Soon: stack overlay-text + estimasi_release ── */
.pbk-card__overlay-block {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}
.pbk-card__overlay-meta {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px;
    background: rgba(255,255,255,.18);
    border: 1px solid rgba(255,255,255,.28);
    border-radius: 999px;
    color: #fff;
    font-size: .65rem;
    font-weight: 600;
    letter-spacing: .02em;
    backdrop-filter: blur(2px);
    line-height: 1.3;
    white-space: nowrap;
}
.pbk-card__overlay-meta i {
    font-size: .7rem;
    opacity: .9;
}
@media (max-width: 575.98px) {
    .pbk-card__overlay-meta {
        font-size: .6rem;
        padding: 3px 8px;
    }
}

[theme="dark"] .pbk-empty {
    color: #888;
}

/* ============================================================
   home.css — Global styles untuk home_view.php layout
   ============================================================ */

/* ── CSS Variables (theme) ── */
:root {
    --bs-primary: #d4a574;
    --bs-primary-rgb: 212, 165, 116;
    --primary-dark: #c19660;
    --primary-light: #e6d4b8;
    --bs-secondary: #8b7355;
    --bs-secondary-rgb: 139, 115, 85;
    --vintage-rose: #d4a574;
    --vintage-cream: #f5e6d3;
    --vintage-brown: #8b6f47;
    --vintage-mauve: #c8b6db;
    --vintage-teal: #7a9e9f;
    --vintage-sage: #a4b494;
    --demo-bar-height: 3.25rem;
}

/* ── Demo mode bar (top_header.php) — style ada inline di view, lihat top_header.php ── */

/* ── Buttons ── */
.btn-outline-success {
    --bs-btn-hover-bg: var(--vintage-rose) !important;
    --bs-btn-active-bg: var(--vintage-brown) !important;
    --bs-btn-border-color: var(--vintage-rose) !important;
    --bs-btn-color: var(--vintage-rose) !important;
}
.btn-primary {
    background-color: var(--vintage-rose);
    border-color: var(--vintage-rose);
    color: #fff;
    font-weight: 500;
    border-radius: 6px;
}
.btn-primary:hover {
    background-color: var(--primary-dark);
    border-color: var(--primary-dark);
    color: #fff;
}
.btn-secondary {
    background-color: var(--vintage-brown);
    border-color: var(--vintage-brown);
    color: #fff;
}
.btn-secondary:hover {
    background-color: var(--bs-secondary);
    border-color: var(--bs-secondary);
    color: #fff;
}
.btn-outline-success:active {
    background-color: var(--bg-color) !important;
    color: #1455ac !important;
    --bs-btn-border-color: #1455ac !important;
}

/* ── Disable click on mailto/tel links ── */
a[href^="mailto:"],
a[href^="tel:"] {
    pointer-events: none;
}
a[href^="mailto:"]::after,
a[href^="tel:"]::after {
    content: '';
    display: none;
}

/* ── Google / Social login button ── */
.google-btn-wrapper {
    display: flex;
    justify-content: center;
    margin-bottom: 1.5rem;
}
.social-login-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    padding: 10px 16px;
    border: 1px solid #dadce0;
    border-radius: 8px;
    background-color: #ffffff;
    color: #3c4043;
    font-family: 'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.25px;
    text-decoration: none;
    transition: background-color 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
    cursor: pointer;
}
.social-login-button:hover {
    background-color: #f8f9fa;
    border-color: #d2d5d9;
    box-shadow: 0 1px 2px 0 rgba(60,64,67,0.1), 0 1px 3px 1px rgba(60,64,67,0.08);
}
.social-login-button:active {
    background-color: #f1f3f4;
}
.social-icon-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}
.social-icon {
    width: 100%;
    height: 100%;
    display: block;
}

/* ── Login modal typography ── */
.welcome-message { margin-bottom: 10px; }
.login-heading {
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--bs-gray-800);
    margin-bottom: 8px;
}
.login-description {
    color: var(--bs-gray-600);
    font-size: 0.95rem;
    margin: 0;
}

/* ============================================================
   Banner Section
   ============================================================ */

/* ── Main slider ── */
.banner-main-slider {
    border: 1px solid rgba(var(--bs-primary-rgb), 0.12);
}

/* Swiper pagination dots — warna brand */
.banner-pagination .swiper-pagination-bullet {
    background: var(--vintage-brown);
    opacity: .35;
    width: 7px;
    height: 7px;
    transition: all .25s ease;
}
.banner-pagination .swiper-pagination-bullet-active {
    background: var(--vintage-rose);
    opacity: 1;
    width: 20px;
    border-radius: 4px;
}

/* Nav arrow hover */
.banner-prev:hover,
.banner-next:hover {
    background: rgba(255,255,255,1) !important;
    color: var(--vintage-rose) !important;
    box-shadow: 0 4px 12px rgba(0,0,0,.18) !important;
}

/* ── Sub-banner hover zoom ── */
.banner-sub-item {
    border: 1px solid rgba(var(--bs-primary-rgb), 0.1);
}
.banner-sub-item:hover img {
    transform: scale(1.04);
}

/* ============================================================
   Unggulan / Feature Section
   ============================================================ */
.unggulan-section {
    padding: 0 0 1.5rem;
}

.unggulan-wrapper {
    background: #fff;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.12);
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 2px 16px rgba(var(--bs-primary-rgb), 0.07);
}

/* ── Each item ── */
.unggulan-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.35rem 1.5rem;
    border-right: 1px solid rgba(var(--bs-primary-rgb), 0.1);
    transition: background .25s ease;
    height: 100%;
}
.unggulan-item--last {
    border-right: none;
}
.unggulan-item:hover {
    background: rgba(var(--bs-primary-rgb), 0.04);
}

/* divider between rows on mobile */
@media (max-width: 991px) {
    .unggulan-item {
        border-right: none;
        border-bottom: 1px solid rgba(var(--bs-primary-rgb), 0.1);
    }
    .unggulan-item--last {
        border-bottom: none;
    }
}
@media (min-width: 576px) and (max-width: 991px) {
    /* 2-col grid: remove right border on even items */
    .col-sm-6:nth-child(even) .unggulan-item {
        border-right: none;
    }
    .col-sm-6:nth-child(odd) .unggulan-item {
        border-right: 1px solid rgba(var(--bs-primary-rgb), 0.1);
    }
    /* last row has no bottom border */
    .col-sm-6:nth-last-child(-n+2) .unggulan-item {
        border-bottom: none;
    }
}

/* ── Icon ring ── */
.unggulan-icon-wrap {
    flex-shrink: 0;
    /* fixed size so icon never shifts */
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.unggulan-icon-ring {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    /* default — rose */
    background: rgba(var(--bs-primary-rgb), 0.12);
    color: var(--vintage-rose);
    font-size: 1.35rem;
    line-height: 1;
    transition: transform .25s ease, background .25s ease;
}

/* colour variants */
.unggulan-icon-ring--2 {
    background: rgba(139, 115, 85, 0.1);
    color: var(--vintage-brown);
}
.unggulan-icon-ring--3 {
    background: rgba(200, 182, 219, 0.2);
    color: #9b7ec8;
}
.unggulan-icon-ring--4 {
    background: rgba(122, 158, 159, 0.15);
    color: var(--vintage-teal);
}

/* hover: scale ring + fill */
.unggulan-item:hover .unggulan-icon-ring {
    transform: scale(1.1);
    background: var(--vintage-rose);
    color: #fff;
}
.unggulan-item:hover .unggulan-icon-ring--2 {
    background: var(--vintage-brown);
}
.unggulan-item:hover .unggulan-icon-ring--3 {
    background: #9b7ec8;
}
.unggulan-item:hover .unggulan-icon-ring--4 {
    background: var(--vintage-teal);
}

/* ── Text ── */
.unggulan-body {
    min-width: 0; /* prevent text overflow */
}
.unggulan-title {
    font-size: .875rem;
    font-weight: 700;
    color: var(--title-color);
    margin-bottom: .2rem;
    white-space: nowrap;
}
.unggulan-desc {
    font-size: .75rem;
    color: var(--secondary-body-color);
    margin: 0;
    line-height: 1.4;
}

/* MENU ATAS */

:root {
    --mh-primary    : #d4a574;
    --mh-primary-dk : #b8874f;
    --mh-dark       : #1a1a2e;
    --mh-text       : #3d3d3d;
    --mh-muted      : #888;
    --mh-bg-hover   : #fdf6ef;
    --mh-radius     : 10px;
    --mh-transition : .22s cubic-bezier(.4,0,.2,1);
}

/* ── Wrapper ── */
.hdr-main-inner {
    width: 100%;
}

/* ═══════════════════
   CATEGORY BUTTON
   ═══════════════════ */
.cat-dropdown-wrap { position: relative; }

.cat-toggle-btn {
    background: linear-gradient(135deg, var(--mh-primary), var(--mh-primary-dk));
    color: #fff;
    border: none;
    border-radius: 0 var(--mh-radius) var(--mh-radius) 0;
    padding: 10px 18px 10px 14px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .3px;
    cursor: pointer;
    transition: background var(--mh-transition), box-shadow var(--mh-transition);
    height: 44px;
    gap: 8px;
}
.cat-toggle-btn:hover {
    background: linear-gradient(135deg, var(--mh-primary-dk), #a07040);
    box-shadow: 0 4px 16px rgba(212,165,116,.35);
}

.cat-toggle-lines {
    display: flex;
    flex-direction: column;
    gap: 4px;
    width: 18px;
}
.cat-toggle-lines span {
    display: block;
    height: 2px;
    width: 100%;
    background: #fff;
    border-radius: 2px;
    transition: var(--mh-transition);
}
.cat-toggle-btn[aria-expanded="true"] .cat-toggle-lines span:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
}
.cat-toggle-btn[aria-expanded="true"] .cat-toggle-lines span:nth-child(2) {
    opacity: 0;
}
.cat-toggle-btn[aria-expanded="true"] .cat-toggle-lines span:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
}

.cat-toggle-text { font-size: 13px; }
.cat-toggle-chevron {
    font-size: 10px;
    transition: transform var(--mh-transition);
    margin-left: 2px;
}
.cat-toggle-btn[aria-expanded="true"] .cat-toggle-chevron {
    transform: rotate(180deg);
}

/* ── Category Dropdown ── */
.cat-dropdown-menu {
    min-width: 280px;
    max-width: 320px;
    max-height: min(70vh, 520px);
    overflow-y: auto;
    overflow-x: hidden;
    padding: 8px !important;
    border: 1px solid rgba(212,165,116,.15) !important;
    top: calc(100% + 6px) !important;
    left: 0 !important;
    scrollbar-width: thin;
    scrollbar-color: rgba(212,165,116,.3) transparent;
}
.cat-dropdown-menu::-webkit-scrollbar { width: 6px; }
.cat-dropdown-menu::-webkit-scrollbar-track { background: transparent; }
.cat-dropdown-menu::-webkit-scrollbar-thumb {
    background: rgba(212,165,116,.3);
    border-radius: 3px;
}
.cat-dropdown-menu::-webkit-scrollbar-thumb:hover {
    background: rgba(212,165,116,.5);
}

/* ===== moved from: application/modules/home/views/home/top_header.php ===== */
.demo-bar--fixed {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1020;
    background: linear-gradient(105deg, #6b5438 0%, #8b6f4e 38%, #a88458 72%, #d4a574 100%);
    color: #fff;
    box-shadow: 0 2px 12px rgba(44, 36, 24, 0.18);
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

/* Saat modal Bootstrap aktif, demo bar tetap visible tapi non-interactive */
body.modal-open .demo-bar--fixed {
    pointer-events: none;
}

.demo-bar__container { max-width: 100%; }

.demo-bar__inner {
    display: flex;
    align-items: center;
    gap: 0.75rem 1rem;
    min-height: var(--demo-bar-height);
    padding: 0.4rem 0;
}

.demo-bar__lead {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
}

.demo-bar__pulse {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #ffe08a;
    box-shadow: 0 0 0 0 rgba(255, 224, 138, 0.7);
    animation: demo-pulse 2s ease-in-out infinite;
}
@keyframes demo-pulse {
    0%   { box-shadow: 0 0 0 0   rgba(255, 224, 138, 0.65); }
    70%  { box-shadow: 0 0 0 8px rgba(255, 224, 138, 0); }
    100% { box-shadow: 0 0 0 0   rgba(255, 224, 138, 0); }
}

.demo-bar__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    background: rgba(0, 0, 0, 0.22);
    border: 1px solid rgba(255, 255, 255, 0.3);
    color: #fff;
    font-size: 0.68rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 0.28rem 0.7rem;
    border-radius: 100px;
    white-space: nowrap;
    backdrop-filter: blur(2px);
}
.demo-bar__badge i { font-size: 0.8rem; }

.demo-bar__text {
    flex: 1;
    margin: 0;
    min-width: 0;
    font-size: 0.8125rem;
    line-height: 1.4;
    color: rgba(255, 255, 255, 0.94);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.demo-bar__text strong {
    font-weight: 700;
    color: #fff;
}

.demo-bar__tags {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    flex-shrink: 0;
}
.demo-bar__tag {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.68rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.92);
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 6px;
    padding: 0.2rem 0.55rem;
    white-space: nowrap;
}
.demo-bar__tag i { font-size: 0.75rem; opacity: 0.9; }

/* Ruang konten & offset header sticky saat mode demo aktif */
body.demo-mode-active {
    padding-top: var(--demo-bar-height);
}
body.demo-mode-active .header .love-sticky.sticky {
    top: var(--demo-bar-height);
}

/* Mobile responsive */
@media (max-width: 991.98px) {
    :root {
        --demo-bar-height: 3.5rem;
    }
    .demo-bar__inner {
        flex-wrap: nowrap;
        align-items: center;
        gap: 0.4rem 0.6rem;
        padding: 0.4rem 0;
    }
    .demo-bar__text {
        font-size: 0.7rem;
        white-space: nowrap;
    }
    .demo-bar__tags { display: none; }
}

@media (max-width: 575.98px) {
    .demo-bar__badge {
        font-size: 0.6rem;
        padding: 0.2rem 0.5rem;
        letter-spacing: 0.06em;
    }
    .demo-bar__text {
        font-size: 0.6875rem;
    }
}

/* ===== moved from: application/modules/home/views/home/search.php ===== */
.search-card.search-result-box {
    max-height: 480px;
    overflow-y: auto;
    border-radius: 12px;
    border: 1px solid rgba(212, 165, 116, 0.18);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12);
    margin-top: 6px;
    padding: 0;
}
.search-card.search-result-box::-webkit-scrollbar { width: 6px; }
.search-card.search-result-box::-webkit-scrollbar-thumb {
    background: rgba(212, 165, 116, 0.35);
    border-radius: 3px;
}

/* ── State message (hint, error, empty, warning) ── */
.search-state {
    padding: 24px 16px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}
.search-state__icon {
    font-size: 1.6rem;
    opacity: 0.55;
}
.search-state__text {
    font-size: 0.875rem;
    line-height: 1.4;
}
.search-state__hint {
    font-size: 0.75rem;
    color: #999;
    margin-top: 2px;
}

/* ── Result list ── */
.search-result-list {
    display: flex;
    flex-direction: column;
}
.search-result-list__header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    font-size: 0.75rem;
    color: #888;
    background: #faf6f1;
    border-bottom: 1px solid #f0e7da;
    position: sticky;
    top: 0;
    z-index: 2;
}
.search-result-list__header strong {
    color: var(--vintage-rose, #b88a5e);
    font-weight: 700;
}

.search-result-list__footer {
    display: block;
    padding: 12px 14px;
    text-align: center;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--vintage-rose, #d4a574);
    text-decoration: none;
    border-top: 1px solid #f0e7da;
    background: #fff;
    transition: all 0.2s ease;
    position: sticky;
    bottom: 0;
}
.search-result-list__footer:hover {
    background: #faf3eb;
    color: #b88a5e;
}
.search-result-list__footer i { transition: transform 0.2s ease; }
.search-result-list__footer:hover i { transform: translateX(3px); }

/* ── Result item ── */
.search-result-item {
    display: flex;
    align-items: stretch;
    gap: 12px;
    padding: 10px 14px;
    border-bottom: 1px solid #f5f0e8;
    text-decoration: none;
    color: inherit;
    transition: background 0.15s ease;
}
.search-result-item:last-of-type { border-bottom: none; }
.search-result-item:hover { background: #faf6f1; color: inherit; }
.search-result-item--disabled { opacity: 0.65; }

.search-result-item__img {
    position: relative;
    width: 56px;
    height: 56px;
    flex-shrink: 0;
    border-radius: 8px;
    overflow: hidden;
    background: #faf3eb;
}
.search-result-item__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.search-result-item__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
    justify-content: center;
}
.search-result-item__title {
    font-size: 0.875rem;
    font-weight: 600;
    color: #333;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.search-result-item__meta {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    font-size: 0.6875rem;
    color: #888;
    line-height: 1.4;
}
.search-result-item__category {
    display: inline-flex;
    align-items: center;
    gap: 3px;
}
.search-result-item__category i {
    font-size: 0.6rem;
    color: var(--vintage-rose, #d4a574);
}

/* ── Highlight ── */
.search-hl {
    background: #fff3d6;
    color: #8a6a00;
    padding: 0 1px;
    border-radius: 2px;
}

/* ── Status badge on image ── */
.search-badge {
    position: absolute;
    bottom: 4px;
    left: 4px;
    right: 4px;
    text-align: center;
    font-size: 0.5625rem;
    font-weight: 700;
    padding: 1px 4px;
    border-radius: 3px;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    line-height: 1.4;
    backdrop-filter: blur(2px);
}
.search-badge--ready    { background: rgba(232,245,233,0.95); color: #2e7d32; }
.search-badge--po       { background: rgba(255,248,225,0.95); color: #f57f17; }
.search-badge--habis    { background: rgba(255,235,238,0.95); color: #c62828; }
.search-badge--soon     { background: rgba(227,242,253,0.95); color: #1565c0; }
.search-badge--clearance{ background: rgba(252,228,236,0.95); color: #ad1457; }

/* ── Rating ── */
.search-rating {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-weight: 700;
    color: #333;
}
.search-rating i { font-size: 0.625rem; color: #ffc107; }
.search-rating__count { color: #999; font-weight: 500; }

/* ── Price ── */
.search-price {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    margin-top: 4px;
}
.search-price__current {
    font-size: 0.9375rem;
    font-weight: 800;
    color: var(--vintage-rose, #d4a574);
    letter-spacing: -0.01em;
}
.search-price__old {
    font-size: 0.6875rem;
    color: #aaa;
    text-decoration: line-through;
}
.search-price__flash {
    font-size: 0.625rem;
    font-weight: 800;
    padding: 2px 6px;
    border-radius: 4px;
    background: linear-gradient(135deg, #ff6d00, #ff9100);
    color: #fff;
    display: inline-flex;
    align-items: center;
    gap: 3px;
}
.search-price__flash i { font-size: 0.6rem; }

/* ── Dark Theme ── */
[theme="dark"] .search-card.search-result-box {
    background: #1e1e2d !important;
    border-color: rgba(255,255,255,0.06);
}
[theme="dark"] .search-result-list__header {
    background: #252536;
    border-bottom-color: rgba(255,255,255,0.06);
    color: #aaa;
}
[theme="dark"] .search-result-list__footer {
    background: #1e1e2d;
    border-top-color: rgba(255,255,255,0.06);
}
[theme="dark"] .search-result-list__footer:hover { background: #252536; }
[theme="dark"] .search-result-item {
    border-bottom-color: rgba(255,255,255,0.04);
}
[theme="dark"] .search-result-item:hover { background: #252536; }
[theme="dark"] .search-result-item__title { color: #e0e0e0; }
[theme="dark"] .search-result-item__img { background: #2a2a3a; }
[theme="dark"] .search-rating { color: #ddd; }
[theme="dark"] .search-hl { background: #4a3d1a; color: #ffd966; }



/* Appended styles moved from home_view.php inline <style> */
.hover-lift {
    transition: transform .25s ease, box-shadow .25s ease;
}
.hover-lift:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 25px rgba(0,0,0,.12) !important;
}
.section-num {
    width: 32px;
    height: 32px;
    min-width: 32px;
    border-radius: 50%;
    background: linear-gradient(135deg, #d4a574, #c19660);
    color: #fff;
    font-weight: 700;
    font-size: .8rem;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 6px rgba(212,165,116,.4);
}
/* ── Form inputs ── */
.contact-input {
    background: #fdf6ef !important;
    border: 1px solid #e8d5c0 !important;
    border-radius: 8px !important;
    color: #555 !important;
    transition: border-color .2s ease, box-shadow .2s ease;
}
.contact-input:focus {
    border-color: #d4a574 !important;
    box-shadow: 0 0 0 .2rem rgba(212,165,116,.2) !important;
}
/* ── Social icons ── */
.social-icon-btn {
    transition: transform .2s ease, box-shadow .2s ease;
    box-shadow: 0 2px 6px rgba(0,0,0,.1);
}
.social-icon-btn:hover {
    transform: scale(1.15);
    box-shadow: 0 4px 12px rgba(0,0,0,.2);
}

/* Utility classes added to replace inline styles in views */
.modal-max-460 { max-width: 460px; }
.modal-max-900 { max-width: 900px; }
.modal-max-400 { max-width: 400px; }
.modal-max-460, .modal-max-900, .modal-max-400 { max-width: 100%; }
.icon-48 { width: 48px; height: 48px; }
.logo-70 { width: 70px; height: 70px; object-fit: cover; }
.logo-circle-70 { width: 70px; height: 70px; backdrop-filter: blur(5px); }
.rounded-20 { border-radius: 20px !important; }
.btn-close-opacity { opacity: 0.8; }
.login-modal-header { background: linear-gradient(135deg, var(--primary-dark) 0%, var(--vintage-rose) 100%); padding: 40px 20px; }
.login-subtitle { opacity: .9; font-size: .9rem; }
.icon-24 { width: 24px; height: 24px; display: inline-block; }
.section-num{display:inline-flex}

/* Reset bootstrap default li styling agar konsisten */
.cat-dropdown-menu > .cat-menu-item {
    list-style: none;
    margin: 0;
    padding: 0;
}
.cat-dropdown-menu > .cat-menu-item + .cat-menu-item {
    margin-top: 2px;
}

.cat-menu-item {
    position: relative;
    border-radius: 8px;
    transition: background var(--mh-transition);
}

/* ── Parent link (kategori utama) ── */
.cat-menu-link {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 8px;
    padding: 10px 12px;
    font-size: 13px;
    font-weight: 600;
    color: var(--mh-text);
    text-decoration: none;
    border-radius: 8px;
    transition: background var(--mh-transition),
                color var(--mh-transition);
    line-height: 1.35;
    /* PENTING: izinkan wrap, no overflow */
    white-space: normal;
    word-break: break-word;
}
.cat-menu-link:hover,
.cat-menu-link:focus-visible {
    background: var(--mh-bg-hover);
    color: var(--mh-primary);
    outline: none;
}

.cat-menu-name {
    flex: 1 1 auto;
    min-width: 0;
    line-height: 1.35;
}

/* Counter pill kecil di sebelah panah jika perlu */
.cat-menu-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 18px;
    padding: 0 6px;
    border-radius: 10px;
    background: rgba(212,165,116,.12);
    color: var(--mh-primary-dk);
    font-size: 10px;
    font-weight: 700;
    flex-shrink: 0;
}

/* Chevron expand/collapse — bukan flyout lagi, tapi tree */
.cat-sub-arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 6px;
    background: rgba(212,165,116,.08);
    color: var(--mh-primary);
    font-size: 11px;
    flex-shrink: 0;
    transition: transform var(--mh-transition),
                background var(--mh-transition),
                color var(--mh-transition);
}
.cat-menu-link:hover .cat-sub-arrow {
    background: var(--mh-primary);
    color: #fff;
}
/* Saat parent dalam state "open", panah berputar 90° (menunjuk bawah) */
.cat-menu-item.is-open > .cat-menu-link .cat-sub-arrow {
    transform: rotate(90deg);
    background: var(--mh-primary);
    color: #fff;
}
.cat-menu-item.is-open > .cat-menu-link {
    background: var(--mh-bg-hover);
    color: var(--mh-primary);
}

/* ═══════════════════════════════════════
   SUB-MENU sebagai TREE inline (bukan flyout)
   — rapih, tidak ter-clip, hierarki jelas
   Override aturan global .dropdown-menu li ul / .sub-menu di style.css
   ═══════════════════════════════════════ */
.cat-dropdown-menu .cat-sub-menu {
    /* override Bootstrap & global theme defaults */
    position: static !important;
    inset: auto !important;
    transform: none !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    visibility: visible !important;
    pointer-events: auto !important;
    /* Hapus efek opacity dari rule global .main-menu .sub-menu / submenu-opacity */
    opacity: 1 !important;
    --submenu-opacity: 1 !important;

    /* Smooth collapse via max-height (lebih reliable cross-browser) */
    max-height: 0;
    overflow: hidden;
    transition: max-height .32s cubic-bezier(.4,0,.2,1),
                margin .25s ease,
                padding .25s ease,
                border-color .25s ease;

    margin-left: 14px !important;
    margin-right: 4px !important;
    /* Garis vertical di kiri untuk visual tree (transparan saat collapsed) */
    border-left: 1px dashed transparent !important;
    padding-left: 6px !important;

    min-width: 0 !important;
    width: auto !important;
    inline-size: auto !important;
    min-inline-size: 0 !important;
}

/* Saat parent open → expand sub-menu */
.cat-dropdown-menu .cat-menu-item.is-open > .cat-sub-menu {
    max-height: 1200px; /* cukup besar untuk semua subkategori */
    margin-top: 4px !important;
    margin-bottom: 6px !important;
    border-left-color: rgba(212,165,116,.35) !important;
}

/* Inner content of sub-menu — hilangkan padding global .dropdown-menu li */
.cat-dropdown-menu .cat-sub-menu .cat-sub-inner {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    /* Tampilkan link sub sebagai column */
    display: flex !important;
    flex-direction: column !important;
    gap: 1px !important;
    /* Hapus border-bottom global */
    border-bottom: none !important;
}

/* Override .dropdown-menu li padding global agar tidak menyebabkan layout aneh */
.cat-dropdown-menu .cat-menu-item {
    padding: 0 !important;
    border-bottom: none !important;
}

.cat-dropdown-menu .cat-sub-link {
    display: flex !important;
    align-items: center !important;
    gap: 8px;
    padding: 7px 10px !important;
    margin: 0 !important;
    font-size: 12.5px !important;
    font-weight: 500 !important;
    /* Color eksplisit dengan specificity tinggi agar tidak ter-override */
    color: var(--mh-text) !important;
    text-decoration: none !important;
    border-radius: 6px !important;
    transition: background var(--mh-transition),
                color var(--mh-transition),
                padding-left var(--mh-transition);
    line-height: 1.4 !important;
    white-space: normal !important;
    word-break: break-word !important;
    position: relative !important;
    /* Pastikan visible apapun state parent */
    opacity: 1 !important;
    visibility: visible !important;
    background: transparent;
}

/* Bullet titik kecil untuk visual tree */
.cat-dropdown-menu .cat-sub-link::before {
    content: '';
    flex-shrink: 0;
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: rgba(212,165,116,.55);
    transition: background var(--mh-transition),
                transform var(--mh-transition);
}

.cat-dropdown-menu .cat-sub-link:hover,
.cat-dropdown-menu .cat-sub-link:focus-visible {
    background: var(--mh-bg-hover) !important;
    color: var(--mh-primary) !important;
    padding-left: 14px !important;
    outline: none;
}
.cat-dropdown-menu .cat-sub-link:hover::before,
.cat-dropdown-menu .cat-sub-link:focus-visible::before {
    background: var(--mh-primary);
    transform: scale(1.6);
}

/* ═══════════════════
   MAIN NAV LINKS
   ═══════════════════ */
.main-menu { gap: 0 !important; padding-left: 8px; }

.nav-item { position: relative; }

.nav-link-item {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 0 14px;
    height: 56px;
    font-size: 13.5px;
    font-weight: 600;
    color: var(--mh-text);
    text-decoration: none;
    cursor: pointer;
    white-space: nowrap;
    border-bottom: 3px solid transparent;
    transition: color var(--mh-transition), border-color var(--mh-transition);
    user-select: none;
    position: relative;
}
.nav-link-item::after {
    content: '';
    position: absolute;
    bottom: -3px;
    left: 14px;
    right: 14px;
    height: 3px;
    background: linear-gradient(90deg, var(--mh-primary), var(--mh-primary-dk));
    border-radius: 3px 3px 0 0;
    transform: scaleX(0);
    transition: transform var(--mh-transition);
}
.nav-item:hover > .nav-link-item,
.nav-item.active > .nav-link-item,
.nav-item.active .nav-link-item {
    color: var(--mh-primary);
}
.nav-item:hover > .nav-link-item::after,
.nav-item.active > .nav-link-item::after,
.nav-item.active .nav-link-item::after {
    transform: scaleX(1);
}

.nav-item-icon { font-size: 14px; opacity: .7; }
.nav-chevron { font-size: 9px; opacity: .6; margin-left: 1px; transition: transform var(--mh-transition); }
.nav-item:hover .nav-chevron { transform: rotate(180deg); }

/* ═══════════════════
   MEGA MENU
   ═══════════════════ */
.has-mega-menu { position: static !important; }

.mega-menu {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    border-top: 3px solid var(--mh-primary);
    border: 1px solid rgba(212,165,116,.15);
    border-top: 3px solid var(--mh-primary);
    border-radius: 0 0 16px 16px;
    z-index: 999;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: opacity var(--mh-transition), visibility var(--mh-transition), transform var(--mh-transition);
    pointer-events: none;
    min-width: 700px;
}
.has-mega-menu:hover .mega-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: all;
}

.mega-menu-inner {
    display: grid;
    grid-template-columns: 1.5fr 1fr auto;
    gap: 0;
}

/* Mega Columns */
.mega-col {
    padding: 20px 20px;
    border-right: 1px solid #f5ede3;
}
.mega-col:last-child { border-right: none; }

.mega-col-title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .8px;
    color: var(--mh-muted);
    margin-bottom: 12px;
    padding-bottom: 8px;
    border-bottom: 1px dashed #eee;
}

/* Mega List Items */
.mega-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }

.mega-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 10px;
    text-decoration: none;
    color: var(--mh-text);
    transition: background var(--mh-transition), transform var(--mh-transition);
}
.mega-link:hover {
    background: var(--mh-bg-hover);
    transform: translateX(3px);
}

.mega-link-icon {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    flex-shrink: 0;
    transition: transform var(--mh-transition);
}
.mega-link:hover .mega-link-icon { transform: scale(1.1); }

.bg-soft-primary { background: rgba(212,165,116,.12); color: var(--mh-primary); }
.bg-soft-danger   { background: rgba(239,68,68,.1);   color: #ef4444; }
.bg-soft-success  { background: rgba(34,197,94,.1);   color: #22c55e; }
.bg-soft-warning  { background: rgba(245,158,11,.1);  color: #f59e0b; }
.bg-soft-info     { background: rgba(59,130,246,.1);  color: #3b82f6; }
.bg-soft-purple   { background: rgba(139,92,246,.1);  color: #8b5cf6; }

.mega-link-text {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 1px;
}
.mega-link-text strong { font-size: 13px; font-weight: 600; color: #2d2d2d; }
.mega-link-text small  { font-size: 11px; color: var(--mh-muted); }

.mega-badge {
    font-size: 9px;
    font-weight: 800;
    padding: 2px 7px;
    border-radius: 20px;
    letter-spacing: .5px;
    text-transform: uppercase;
    flex-shrink: 0;
}
.mega-badge-danger  { background: #fef2f2; color: #ef4444; border: 1px solid rgba(239,68,68,.2); }
.mega-badge-warning { background: #fffbeb; color: #f59e0b; border: 1px solid rgba(245,158,11,.2); }
.mega-badge-info    { background: #eff6ff; color: #3b82f6; border: 1px solid rgba(59,130,246,.2); }
.mega-badge-purple  { background: #f5f3ff; color: #8b5cf6; border: 1px solid rgba(139,92,246,.2); }

/* Mega Category Column */
.mega-col-cat { min-width: 180px; }
.mega-cat-list { gap: 2px !important; }
.mega-cat-link {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 7px 10px;
    font-size: 13px;
    font-weight: 500;
    color: var(--mh-text);
    text-decoration: none;
    border-radius: 8px;
    transition: background var(--mh-transition), color var(--mh-transition), padding-left var(--mh-transition);
}
.mega-cat-link:hover {
    background: var(--mh-bg-hover);
    color: var(--mh-primary);
    padding-left: 14px;
}
.mega-cat-arrow { font-size: 9px; opacity: .4; transition: opacity var(--mh-transition), color var(--mh-transition); }
.mega-cat-link:hover .mega-cat-arrow { opacity: 1; color: var(--mh-primary); }

/* Mega Promo Card */
.mega-promo-col { min-width: 200px; max-width: 220px; }
.mega-promo-card {
    background: linear-gradient(135deg, #d4a574 0%, #c19660 50%, #a07040 100%);
    border-radius: 14px;
    padding: 20px 16px;
    text-align: center;
    color: #fff;
    position: relative;
    overflow: hidden;
    height: 100%;
    min-height: 200px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
}
.mega-promo-card::before {
    content: '';
    position: absolute;
    top: -30px; right: -30px;
    width: 100px; height: 100px;
    border-radius: 50%;
    background: rgba(255,255,255,.08);
}
.mega-promo-card::after {
    content: '';
    position: absolute;
    bottom: -20px; left: -20px;
    width: 80px; height: 80px;
    border-radius: 50%;
    background: rgba(255,255,255,.05);
}
.mega-promo-badge {
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1px;
    background: rgba(255,255,255,.2);
    padding: 3px 10px;
    border-radius: 20px;
    backdrop-filter: blur(4px);
}
.mega-promo-icon { font-size: 2.2rem; opacity: .9; }
.mega-promo-title { font-size: 16px; font-weight: 800; line-height: 1.2; }
.mega-promo-desc { font-size: 11px; opacity: .85; line-height: 1.4; }
.mega-promo-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: rgba(255,255,255,.25);
    color: #fff;
    text-decoration: none;
    font-size: 11px;
    font-weight: 700;
    padding: 6px 14px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.3);
    transition: background var(--mh-transition);
    backdrop-filter: blur(4px);
    margin-top: 4px;
}
.mega-promo-btn:hover {
    background: rgba(255,255,255,.4);
    color: #fff;
}

/* ═══════════════════
   RIGHT: USER ACTIONS
   ═══════════════════ */
.hdr-actions { gap: 4px !important; }

.hdr-action-item { display: flex; align-items: center; }

/* ═══════════════════════════════════════════════════
   USER DROPDOWN — selaras menu_header (vintage rose)
   Struktur: header gradient + menu items + divider + logout
   ═══════════════════════════════════════════════════ */
.hdr-user-btn {
    position: relative;
    display: inline-flex !important;
    align-items: center;
    gap: 8px;
    padding: 4px 8px 4px 4px !important;
    background: transparent !important;
    border: none !important;
    border-radius: 999px;
    cursor: pointer;
    transition: background var(--mh-transition);
}
.hdr-user-btn:hover { background: var(--mh-bg-hover) !important; }
.hdr-user-btn::after {
    /* Default Bootstrap caret diganti dengan ikon sendiri lebih halus */
    display: none !important;
}
.hdr-user-btn[aria-expanded="true"] { background: var(--mh-bg-hover) !important; }

.hdr-avatar {
    flex-shrink: 0;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid rgba(212,165,116,.5);
    background: var(--mh-bg-hover);
    transition: border-color var(--mh-transition), transform var(--mh-transition);
    display: inline-block;
}
.hdr-user-btn:hover .hdr-avatar,
.hdr-user-btn[aria-expanded="true"] .hdr-avatar {
    border-color: var(--mh-primary);
    transform: scale(1.04);
}
.hdr-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.hdr-user-name {
    max-width: 110px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 13px;
    font-weight: 600;
    color: #555;
    line-height: 1.2;
}

/* ── Dropdown Container ── */
.profile-dropdown {
    position: relative !important;
}

.hdr-user-dropdown {
    --bs-dropdown-min-width: 260px;
    width: 260px;
    padding: 0 !important;
    border: 1px solid rgba(212,165,116,.18) !important;
    border-radius: 14px !important;
    box-shadow: 0 16px 40px rgba(0,0,0,.12) !important;
    overflow: hidden;
    /* Override Bootstrap data-bs-display="static" — pakai positioning manual
       agar dropdown selalu menempel ke trigger (anti-stuck saat scroll/sticky) */
    position: absolute !important;
    top: 100% !important;
    right: 0 !important;
    left: auto !important;
    bottom: auto !important;
    margin-top: 12px !important;
    transform: none !important;
    inset: auto 0 auto auto !important;
    animation: dropFadeIn .18s ease;
}
.hdr-user-dropdown.show {
    /* Pastikan visible saat Bootstrap toggle */
    display: block !important;
}

/* Saat header sticky (love-sticky.sticky), dropdown tetap menempel ke trigger
   karena positioning relatif ke .profile-dropdown parent yang ikut fixed */
.love-sticky.sticky .hdr-user-dropdown {
    position: absolute !important;
}

/* Mobile: dropdown lebar full minus margin, tetap menempel ke kanan */
@media (max-width: 575.98px) {
    .hdr-user-dropdown {
        width: calc(100vw - 24px) !important;
        max-width: 320px !important;
        right: 0 !important;
    }
}

/* Reset: hilangkan padding global .dropdown-menu li dari style.css */
.hdr-user-dropdown li,
.hdr-user-dropdown ul {
    list-style: none;
    margin: 0;
    padding: 0;
    border: none !important;
}

/* ── Header (info user dengan gradient) ── */
.hud-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 14px;
    background: linear-gradient(135deg, var(--mh-primary), var(--mh-primary-dk));
    color: #fff;
    position: relative;
    overflow: hidden;
}
.hud-header::before {
    content: '';
    position: absolute;
    top: -30px; right: -30px;
    width: 90px; height: 90px;
    border-radius: 50%;
    background: rgba(255,255,255,.08);
}
.hud-avatar {
    flex-shrink: 0;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid rgba(255,255,255,.45);
    background: rgba(255,255,255,.15);
    z-index: 1;
}
.hud-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }

.hud-info {
    flex: 1;
    min-width: 0;
    z-index: 1;
}
.hud-name {
    font-size: .875rem;
    font-weight: 700;
    line-height: 1.3;
    color: #fff;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.hud-email {
    font-size: .6875rem;
    line-height: 1.4;
    margin-top: 2px;
    opacity: .9;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ── Menu items ── */
.hud-menu {
    display: flex;
    flex-direction: column;
    padding: 6px;
}

.hud-item {
    display: flex !important;
    align-items: center;
    gap: 10px;
    padding: 9px 10px !important;
    font-size: 13px;
    font-weight: 500;
    color: #3d3d3d !important;
    text-decoration: none !important;
    border-radius: 8px;
    transition: background var(--mh-transition),
                color var(--mh-transition),
                padding-left var(--mh-transition);
    line-height: 1.35;
    background: transparent;
}
.hud-item + .hud-item { margin-top: 1px; }

.hud-item:hover,
.hud-item:focus-visible {
    background: var(--mh-bg-hover) !important;
    color: var(--mh-primary) !important;
    padding-left: 14px !important;
    outline: none;
}

.hud-item__icon {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    background: rgba(212,165,116,.1);
    color: var(--mh-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    flex-shrink: 0;
    transition: background var(--mh-transition), color var(--mh-transition);
}
.hud-item:hover .hud-item__icon {
    background: var(--mh-primary);
    color: #fff;
}

.hud-item__label {
    flex: 1;
    min-width: 0;
}

/* ── Divider ── */
.hud-divider {
    height: 1px;
    background: rgba(212,165,116,.15);
    margin: 4px 10px;
}

/* ── Logout (danger variant) ── */
.hud-item--danger {
    color: #ef4444 !important;
    margin: 0 6px 6px 6px !important;
}
.hud-item--danger .hud-item__icon {
    background: rgba(239,68,68,.1);
    color: #ef4444;
}
.hud-item--danger:hover,
.hud-item--danger:focus-visible {
    background: #fef2f2 !important;
    color: #dc2626 !important;
}
.hud-item--danger:hover .hud-item__icon {
    background: #ef4444;
    color: #fff;
}

@keyframes dropFadeIn {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── Login Button (guest) ── */
.hdr-login-btn { cursor: pointer; }
.hdr-login-icon {
    width: 34px;
    height: 34px;
    background: rgba(212,165,116,.12);
    color: var(--mh-primary);
    border-radius: 50%;
    transition: background var(--mh-transition), transform var(--mh-transition);
}
.hdr-login-btn:hover .hdr-login-icon {
    background: rgba(212,165,116,.22);
    transform: scale(1.08);
}

/* Icon Buttons (Wishlist etc.) */
.hdr-icon-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: transparent;
    color: #555;
    text-decoration: none;
    transition: background var(--mh-transition), color var(--mh-transition), transform var(--mh-transition);
    position: relative;
}
.hdr-icon-btn:hover {
    background: rgba(212,165,116,.12);
    color: var(--mh-primary);
    transform: scale(1.08);
}

/* Badges */
.hdr-badge {
    position: absolute;
    top: -2px;
    right: -2px;
    background: linear-gradient(135deg, #ef4444, #dc2626);
    color: #fff;
    font-size: 9px;
    font-weight: 800;
    min-width: 16px;
    height: 16px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 3px;
    border: 1.5px solid #fff;
    line-height: 1;
}

/* ═══════════════════
   ANIMATIONS
   ═══════════════════ */
@keyframes dropFadeIn {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0);    }
}

/* ═══════════════════
   DARK THEME
   ═══════════════════ */
[theme="dark"] .nav-link-item,
[theme="dark"] .hdr-user-name  { color: #d0d0d0 !important; }
[theme="dark"] .cat-toggle-btn { background: linear-gradient(135deg, #5a3d1f, #6e4c25); }
[theme="dark"] .mega-menu,
[theme="dark"] .cat-dropdown-menu { background: #1e1e2d; border-color: rgba(255,255,255,.08); }
[theme="dark"] .cat-menu-link,
[theme="dark"] .mega-link,
[theme="dark"] .mega-cat-link  { color: #ccc; }
[theme="dark"] .cat-menu-link:hover,
[theme="dark"] .mega-link:hover,
[theme="dark"] .mega-cat-link:hover { background: rgba(255,255,255,.06); }
[theme="dark"] .mega-link-text strong { color: #e0e0e0; }
[theme="dark"] .mega-col { border-color: rgba(255,255,255,.06); }
[theme="dark"] .mega-col-title { border-color: rgba(255,255,255,.06); }
[theme="dark"] .hdr-icon-btn { color: #bbb; }
[theme="dark"] .hdr-login-icon { color: var(--mh-primary); }
[theme="dark"] .hdr-user-name { color: #d0d0d0; }
[theme="dark"] .hdr-user-btn:hover,
[theme="dark"] .hdr-user-btn[aria-expanded="true"] { background: rgba(212,165,116,.12) !important; }
[theme="dark"] .hdr-user-dropdown {
    background: #1e1e2d !important;
    border-color: rgba(255,255,255,.06) !important;
}
[theme="dark"] .hud-item { color: #d8d8d8 !important; }
[theme="dark"] .hud-item:hover { background: rgba(212,165,116,.12) !important; color: var(--mh-primary) !important; }
[theme="dark"] .hud-item--danger { color: #ff6b6b !important; }
[theme="dark"] .hud-item--danger:hover { background: rgba(239,68,68,.12) !important; color: #ff7878 !important; }
[theme="dark"] .hud-divider { background: rgba(255,255,255,.06); }


/* MENU MOBILE */

:root {
    --mm-primary    : #d4a574;
    --mm-primary-dk : #b8874f;
    --mm-text       : #3d3d3d;
    --mm-muted      : #888;
    --mm-bg-hover   : #fdf6ef;
    --mm-border     : rgba(212,165,116,.12);
    --mm-radius     : 10px;
    --mm-transition : .22s cubic-bezier(.4,0,.2,1);
}

/* ═══════════════════════════════════════════════════
   OVERRIDE ASIDE — drawer full-height, content scrollable
   Mengatasi style.css yang men-set aside-body max-height: 60vh
   sehingga menu bawah terpotong saat di-scroll.
   ═══════════════════════════════════════════════════ */
.aside {
    /* Dynamic viewport height (akurat di mobile dengan address bar) */
    block-size: 100dvh !important;
    block-size: 100vh; /* fallback untuk browser lama */
    display: flex !important;
    flex-direction: column !important;
}

@supports (height: 100svh) {
    .aside { block-size: 100svh; }
    .aside { block-size: 100dvh !important; }
}

/* Pembungkus tengah tanpa class (struktur asli home_view.php):
   <aside.aside>
     <div.aside-close>X</div>
     <div>                       <-- direct child, no class
       <div.aside-body>...
   Pastikan div pembungkus itu juga ikut flex agar aside-body bisa expand. */
.aside > div:not(.aside-close) {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden;
}

.aside .aside-body {
    /* Hapus batas 60vh dari style.css */
    max-block-size: none !important;
    max-height: none !important;
    block-size: auto !important;
    height: auto !important;
    /* Flexbox flex-grow agar mengisi sisa ruang aside */
    flex: 1 1 auto !important;
    min-height: 0 !important;
    /* Scroll vertical dalam aside */
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-y: contain;
    /* Padding bawah aman dari notch / home indicator iOS */
    padding: 0 !important;
    padding-bottom: calc(28px + env(safe-area-inset-bottom, 0px)) !important;
    /* Smooth scrollbar */
    scrollbar-width: thin;
    scrollbar-color: rgba(212, 165, 116, .3) transparent;
}
.aside .aside-body::-webkit-scrollbar { width: 4px; }
.aside .aside-body::-webkit-scrollbar-track { background: transparent; }
.aside .aside-body::-webkit-scrollbar-thumb {
    background: rgba(212, 165, 116, .3);
    border-radius: 2px;
}
.aside .aside-body::-webkit-scrollbar-thumb:hover {
    background: rgba(212, 165, 116, .5);
}

/* Tombol close (X) tetap visible di atas — tidak sticky karena di luar scroll container */
.aside .aside-close {
    flex-shrink: 0;
    background: #fff;
    border-bottom: 1px solid var(--mm-border);
    margin: 0;
    z-index: 5;
}

/* Lebar drawer yang lebih nyaman di mobile e-commerce */
@media (max-width: 575.98px) {
    .aside { inline-size: min(88vw, 360px) !important; }
}
@media (min-width: 576px) and (max-width: 1199.98px) {
    .aside { inline-size: min(420px, 90vw) !important; }
}

/* Lock body scroll saat aside aktif (cegah background ikut scroll) */
body.aside-open {
    overflow: hidden;
}

/* Modern browser: lock pakai :has() */
@supports selector(:has(*)) {
    body:has(.aside.active) { overflow: hidden; }
}

/* Saat modal login tampil di atas drawer, sembunyikan drawer agar tidak tumpang-tindih */
body.modal-open .aside.active {
    transform: translateX(100%) !important;
    visibility: hidden !important;
    opacity: 0 !important;
}

/* Wrapper full-width inside aside */
.mm-wrapper {
    display: flex;
    flex-direction: column;
    gap: 14px;
    /* Top padding 0 karena .sm-wrapper di atasnya sudah memberi padding 14px;
       gunakan margin-top kecil sebagai pemisah dari search bar */
    padding: 0 12px 32px;
    margin-top: 14px;
}

/* ═══════════════════
   USER / LOGIN CARD
   ═══════════════════ */
.mm-user-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 14px;
    background: linear-gradient(135deg, var(--mm-primary), var(--mm-primary-dk));
    border-radius: 14px;
    color: #fff;
    position: relative;
    overflow: hidden;
}
.mm-user-card::before {
    content: '';
    position: absolute;
    top: -30px; right: -30px;
    width: 100px; height: 100px;
    border-radius: 50%;
    background: rgba(255,255,255,.08);
}
.mm-user-card::after {
    content: '';
    position: absolute;
    bottom: -25px; left: -25px;
    width: 80px; height: 80px;
    border-radius: 50%;
    background: rgba(255,255,255,.06);
}
.mm-user-avatar {
    flex-shrink: 0;
    width: 48px; height: 48px;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid rgba(255,255,255,.4);
    background: rgba(255,255,255,.15);
    z-index: 1;
}
.mm-user-avatar img { width: 100%; height: 100%; object-fit: cover; }
.mm-user-info {
    flex: 1;
    min-width: 0;
    z-index: 1;
}
.mm-user-name {
    font-weight: 700;
    font-size: .9375rem;
    line-height: 1.3;
    color: #fff;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.mm-user-email {
    font-size: .75rem;
    opacity: .85;
    margin-top: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.mm-user-link {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: rgba(255,255,255,.18);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-size: 1rem;
    z-index: 1;
    transition: background var(--mm-transition), transform var(--mm-transition);
}
.mm-user-link:hover { background: rgba(255,255,255,.3); transform: translateX(2px); color: #fff; }

/* Login (guest) card */
.mm-login-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px;
    background: #fff;
    border: 1px dashed var(--mm-primary);
    border-radius: 14px;
    flex-wrap: wrap;
}
.mm-login-icon {
    width: 44px; height: 44px;
    border-radius: 50%;
    background: var(--mm-bg-hover);
    color: var(--mm-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    flex-shrink: 0;
}
.mm-login-text { flex: 1; min-width: 0; }
.mm-login-title {
    font-weight: 700;
    font-size: .875rem;
    color: var(--mm-text);
    line-height: 1.3;
}
.mm-login-subtitle {
    font-size: .75rem;
    color: var(--mm-muted);
    margin-top: 2px;
    line-height: 1.4;
}
.mm-login-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: linear-gradient(135deg, var(--mm-primary), var(--mm-primary-dk));
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: .8125rem;
    font-weight: 700;
    cursor: pointer;
    transition: all var(--mm-transition);
}
.mm-login-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(212,165,116,.4);
}

/* ═══════════════════
   QUICK ACTIONS GRID
   ═══════════════════ */
.mm-quick-actions {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 6px;
    padding: 10px 6px;
    background: #fff;
    border: 1px solid var(--mm-border);
    border-radius: 12px;
}
.mm-quick-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 8px 4px;
    border-radius: 8px;
    text-decoration: none;
    color: var(--mm-text);
    transition: background var(--mm-transition);
}
.mm-quick-item:hover { background: var(--mm-bg-hover); color: var(--mm-text); }

.mm-quick-icon {
    position: relative;
    width: 38px; height: 38px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    transition: transform var(--mm-transition);
}
.mm-quick-item:hover .mm-quick-icon { transform: scale(1.06); }

.mm-quick-icon--primary { background: rgba(212,165,116,.12); color: var(--mm-primary); }
.mm-quick-icon--rose    { background: rgba(255,82,82,.1);    color: #ff5252; }
.mm-quick-icon--success { background: rgba(34,197,94,.1);    color: #22c55e; }
.mm-quick-icon--info    { background: rgba(59,130,246,.1);   color: #3b82f6; }

.mm-quick-badge {
    position: absolute;
    top: -4px; right: -4px;
    min-width: 16px; height: 16px;
    padding: 0 4px;
    border-radius: 8px;
    background: #ff5252;
    color: #fff;
    font-size: 9px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.mm-quick-label {
    font-size: .6875rem;
    font-weight: 600;
    color: var(--mm-text);
    text-align: center;
    line-height: 1.2;
}

/* ═══════════════════
   MAIN NAVIGATION
   ═══════════════════ */
.mm-nav {
    background: #fff;
    border: 1px solid var(--mm-border);
    border-radius: 12px;
    overflow: hidden;
}
.mm-list {
    list-style: none;
    margin: 0;
    padding: 4px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.mm-item {
    list-style: none;
    margin: 0;
    padding: 0 !important;
    border: none !important;
}
.mm-item + .mm-item { border-top: 1px solid #f5ede1; }

/* Link */
.mm-link {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    padding: 12px 12px;
    font-size: .875rem;
    font-weight: 600;
    color: var(--mm-text);
    text-decoration: none;
    background: transparent;
    border: none;
    border-radius: 8px;
    text-align: left;
    cursor: pointer;
    transition: background var(--mm-transition), color var(--mm-transition);
    line-height: 1.3;
}
.mm-link:hover,
.mm-link:focus-visible {
    background: var(--mm-bg-hover);
    color: var(--mm-primary);
    outline: none;
}
.mm-item.active > .mm-link { color: var(--mm-primary); background: var(--mm-bg-hover); }

.mm-link-icon {
    width: 36px; height: 36px;
    border-radius: 8px;
    background: rgba(212,165,116,.1);
    color: var(--mm-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    flex-shrink: 0;
    transition: background var(--mm-transition), color var(--mm-transition), transform var(--mm-transition);
}
.mm-link:hover .mm-link-icon,
.mm-item.active > .mm-link .mm-link-icon {
    background: var(--mm-primary);
    color: #fff;
    transform: scale(1.04);
}

.mm-link-text { flex: 1; min-width: 0; }
.mm-link-chevron {
    font-size: .75rem;
    color: var(--mm-muted);
    transition: transform var(--mm-transition);
}

.mm-link--secondary { font-weight: 500; font-size: .8125rem; }
.mm-link--secondary .mm-link-icon {
    width: 32px; height: 32px;
    font-size: .9rem;
    background: #f5f0e8;
    color: var(--mm-muted);
}
.mm-link--secondary:hover .mm-link-icon { background: var(--mm-primary); color: #fff; }

/* ═══════════════════
   COLLAPSE GROUP
   ═══════════════════ */
.mm-collapse {
    max-height: 0;
    overflow: hidden;
    transition: max-height .35s cubic-bezier(.4,0,.2,1);
}
.mm-item--group.is-open > .mm-link--toggle .mm-link-chevron {
    transform: rotate(-180deg);
    color: var(--mm-primary);
}
.mm-item--group.is-open > .mm-collapse { max-height: 4000px; }
.mm-item--group.is-open > .mm-link--toggle {
    background: var(--mm-bg-hover);
    color: var(--mm-primary);
}
.mm-item--group.is-open > .mm-link--toggle .mm-link-icon {
    background: var(--mm-primary);
    color: #fff;
}

/* ═══════════════════
   SECTION (di dalam group Produk)
   ═══════════════════ */
.mm-section {
    padding: 6px 4px 10px;
    border-top: 1px dashed #f0e2cc;
}
.mm-section-title {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 10px 6px;
    font-size: .6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--mm-muted);
}
.mm-section-title i { color: var(--mm-primary); font-size: .75rem; }

.mm-sublist,
.mm-cat-list {
    list-style: none;
    margin: 0;
    padding: 0 4px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

/* Sub Link (offer types) */
.mm-sublink {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 8px;
    border-radius: 8px;
    text-decoration: none;
    color: var(--mm-text);
    transition: background var(--mm-transition), transform var(--mm-transition);
}
.mm-sublink:hover {
    background: var(--mm-bg-hover);
    color: var(--mm-text);
    transform: translateX(2px);
}

.mm-sublink-icon {
    width: 36px; height: 36px;
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    flex-shrink: 0;
    transition: transform var(--mm-transition);
}
.mm-sublink:hover .mm-sublink-icon { transform: scale(1.06); }

.mm-icon-soft-primary  { background: rgba(212,165,116,.12); color: var(--mm-primary); }
.mm-icon-soft-danger   { background: rgba(239,68,68,.1);    color: #ef4444; }
.mm-icon-soft-success  { background: rgba(34,197,94,.1);    color: #22c55e; }
.mm-icon-soft-warning  { background: rgba(245,158,11,.1);   color: #f59e0b; }
.mm-icon-soft-info     { background: rgba(59,130,246,.1);   color: #3b82f6; }
.mm-icon-soft-purple   { background: rgba(139,92,246,.1);   color: #8b5cf6; }

.mm-sublink-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 1px;
    min-width: 0;
}
.mm-sublink-body strong {
    font-size: .8125rem;
    font-weight: 600;
    color: var(--mm-text);
    line-height: 1.3;
}
.mm-sublink-body small {
    font-size: .6875rem;
    color: var(--mm-muted);
    line-height: 1.3;
}

.mm-badge {
    font-size: 9px;
    font-weight: 800;
    padding: 2px 7px;
    border-radius: 12px;
    letter-spacing: .5px;
    text-transform: uppercase;
    flex-shrink: 0;
}
.mm-badge-danger  { background: #fef2f2; color: #ef4444; border: 1px solid rgba(239,68,68,.2); }
.mm-badge-warning { background: #fffbeb; color: #f59e0b; border: 1px solid rgba(245,158,11,.2); }
.mm-badge-info    { background: #eff6ff; color: #3b82f6; border: 1px solid rgba(59,130,246,.2); }
.mm-badge-purple  { background: #f5f3ff; color: #8b5cf6; border: 1px solid rgba(139,92,246,.2); }

/* ═══════════════════
   KATEGORI (with toggle)
   ═══════════════════ */
.mm-cat-item {
    list-style: none;
    margin: 0;
    padding: 0;
}
.mm-cat-row {
    display: flex;
    align-items: stretch;
    gap: 0;
}
.mm-cat-link {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 9px 10px;
    border-radius: 8px;
    text-decoration: none;
    color: var(--mm-text);
    font-size: .8125rem;
    font-weight: 500;
    transition: background var(--mm-transition), color var(--mm-transition), padding-left var(--mm-transition);
    line-height: 1.35;
    white-space: normal;
    word-break: break-word;
}
.mm-cat-link:hover {
    background: var(--mm-bg-hover);
    color: var(--mm-primary);
    padding-left: 14px;
}
.mm-cat-icon {
    color: var(--mm-primary);
    font-size: .875rem;
    opacity: .65;
    flex-shrink: 0;
}

.mm-cat-toggle {
    width: 36px;
    border: none;
    background: transparent;
    color: var(--mm-primary);
    font-size: .75rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    transition: background var(--mm-transition), transform var(--mm-transition);
    flex-shrink: 0;
}
.mm-cat-toggle:hover { background: rgba(212,165,116,.12); }
.mm-cat-item.is-open > .mm-cat-row .mm-cat-toggle {
    transform: rotate(180deg);
    background: var(--mm-primary);
    color: #fff;
}
.mm-cat-item.is-open > .mm-cat-row .mm-cat-link {
    background: var(--mm-bg-hover);
    color: var(--mm-primary);
}

.mm-cat-sub {
    list-style: none;
    margin: 0 0 0 14px;
    padding-left: 6px;
    border-left: 1px dashed rgba(212,165,116,.35);
    max-height: 0;
    overflow: hidden;
    transition: max-height .3s ease, margin-top .25s ease, margin-bottom .25s ease;
}
.mm-cat-item.is-open > .mm-cat-sub {
    max-height: 1000px;
    margin-top: 4px;
    margin-bottom: 6px;
}

.mm-cat-sub-link {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 7px 10px;
    font-size: .75rem;
    font-weight: 500;
    color: var(--mm-text);
    text-decoration: none;
    border-radius: 6px;
    transition: background var(--mm-transition), color var(--mm-transition), padding-left var(--mm-transition);
    line-height: 1.4;
}
.mm-cat-sub-link i {
    color: var(--mm-primary);
    opacity: .55;
    font-size: .9rem;
    line-height: 1;
}
.mm-cat-sub-link:hover {
    background: var(--mm-bg-hover);
    color: var(--mm-primary);
    padding-left: 14px;
}
.mm-cat-sub-link:hover i { opacity: 1; transform: scale(1.4); }

/* ═══════════════════
   SECTION DIVIDER (label antar grup)
   ═══════════════════ */
.mm-section-divider {
    padding: 6px 12px;
    font-size: .6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--mm-muted);
    margin-top: 2px;
}

/* ═══════════════════
   FOOTER (logout / cta)
   ═══════════════════ */
.mm-footer {
    margin-top: 6px;
    padding: 4px;
}

.mm-logout-btn,
.mm-cta-btn {
    width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 16px;
    border: none;
    border-radius: 12px;
    font-size: .875rem;
    font-weight: 700;
    cursor: pointer;
    transition: all var(--mm-transition);
}
.mm-logout-btn {
    background: #fff5f5;
    border: 1px solid rgba(239,68,68,.2);
    color: #ef4444;
}
.mm-logout-btn:hover {
    background: #ef4444;
    color: #fff;
    border-color: #ef4444;
    box-shadow: 0 4px 12px rgba(239,68,68,.3);
}
.mm-cta-btn {
    background: linear-gradient(135deg, var(--mm-primary), var(--mm-primary-dk));
    color: #fff;
}
.mm-cta-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(212,165,116,.45);
}

/* ═══════════════════
   OVERRIDE GLOBAL (.aside, .main-nav)
   Pastikan tidak ter-override style.css yang men-set
   sub-menu jadi flyout absolute / opacity 0
   ═══════════════════ */
.aside .mm-wrapper .mm-cat-sub,
.aside .mm-wrapper .mm-collapse,
.aside .mm-wrapper .mm-sublist {
    position: static !important;
    transform: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    inset: auto !important;
    --submenu-opacity: 1 !important;
}
.aside .mm-wrapper .mm-cat-sub {
    border-left: 1px dashed rgba(212,165,116,.35) !important;
}
.aside .mm-list li,
.aside .mm-list .mm-item {
    padding: 0 !important;
    border-bottom: none !important;
}

/* ═══════════════════
   DARK THEME
   ═══════════════════ */
[theme="dark"] .mm-nav,
[theme="dark"] .mm-quick-actions {
    background: #1e1e2d;
    border-color: rgba(255,255,255,.06);
}
[theme="dark"] .mm-link { color: #d8d8d8; }
[theme="dark"] .mm-link:hover { background: rgba(212,165,116,.12); color: var(--mm-primary); }
[theme="dark"] .mm-link--secondary { color: #b8b8b8; }
[theme="dark"] .mm-quick-label { color: #d0d0d0; }
[theme="dark"] .mm-sublink-body strong { color: #e0e0e0; }
[theme="dark"] .mm-sublink-body small { color: #999; }
[theme="dark"] .mm-cat-link { color: #d0d0d0; }
[theme="dark"] .mm-cat-sub-link { color: #c0c0c0; }
[theme="dark"] .mm-section { border-top-color: rgba(255,255,255,.05); }
[theme="dark"] .mm-item + .mm-item { border-top-color: rgba(255,255,255,.04); }
[theme="dark"] .mm-login-card {
    background: #252536;
    border-color: rgba(212,165,116,.4);
}
[theme="dark"] .mm-login-title { color: #e0e0e0; }
[theme="dark"] .mm-login-subtitle { color: #999; }
[theme="dark"] .mm-logout-btn {
    background: rgba(239,68,68,.08);
    color: #ff6b6b;
    border-color: rgba(239,68,68,.3);
}


/* ════════════════════════════════════════════════════════════
   SEARCH MOBILE — selaras dengan menu_header (vintage rose)
   ════════════════════════════════════════════════════════════ */
:root {
    --sm-primary    : #d4a574;
    --sm-primary-dk : #b8874f;
    --sm-text       : #3d3d3d;
    --sm-muted      : #888;
    --sm-bg-hover   : #fdf6ef;
    --sm-border     : rgba(212,165,116,.18);
    --sm-radius     : 12px;
    --sm-transition : .22s cubic-bezier(.4,0,.2,1);
}

/* Wrapper agar sejajar dengan .mm-wrapper (padding sama) */
.sm-wrapper {
    padding: 14px 12px 0;
    /* mm-wrapper punya padding-top: 14px juga, jadi search akan rapat
       di atasnya, lalu menu mulai 14px di bawah search */
}

.sm-form {
    margin: 0;
    position: relative;
}

/* ── Search Bar Container ── */
.sm-search {
    display: flex;
    align-items: stretch;
    background: #fff;
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius);
    /* overflow: hidden DIHILANGKAN agar dropdown kategori tidak ter-clip.
       Rounded corner tetap terjaga karena children (button, input) sudah
       di-clip oleh border-radius parent saat overflow visible berkat
       isolation/clip-path bawaan border-radius. */
    box-shadow: 0 2px 8px rgba(0,0,0,.04);
    transition: border-color var(--sm-transition), box-shadow var(--sm-transition);
    height: 46px;
    position: relative; /* anchor untuk z-index stacking */
}
.sm-search:focus-within {
    border-color: var(--sm-primary);
    box-shadow: 0 4px 14px rgba(212,165,116,.18);
}

/* Children radius supaya rounded corner tetap rapi tanpa overflow:hidden */
.sm-search > *:first-child .sm-cat-toggle {
    border-top-left-radius: var(--sm-radius);
    border-bottom-left-radius: var(--sm-radius);
}
.sm-search__submit {
    border-top-right-radius: var(--sm-radius);
    border-bottom-right-radius: var(--sm-radius);
}

/* ── Category Dropdown Toggle ── */
.sm-search__cat {
    display: flex;
    /* Jadi anchor positioning untuk .sm-cat-menu absolute */
    position: relative;
}
.sm-cat-toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 0 10px;
    background: transparent;
    border: none;
    border-right: 1px solid var(--sm-border);
    font-size: .75rem;
    font-weight: 600;
    color: var(--sm-text);
    cursor: pointer;
    white-space: nowrap;
    transition: background var(--sm-transition), color var(--sm-transition);
    height: 100%;
}
.sm-cat-toggle:hover {
    background: var(--sm-bg-hover);
    color: var(--sm-primary);
}
.sm-cat-toggle > i:first-child {
    color: var(--sm-primary);
    font-size: .85rem;
}
.sm-cat-toggle__label {
    max-width: 70px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.sm-cat-toggle__chevron {
    font-size: .65rem;
    opacity: .65;
    transition: transform var(--sm-transition);
}
.sm-cat-toggle[aria-expanded="true"] .sm-cat-toggle__chevron {
    transform: rotate(180deg);
}

/* ── Category Dropdown Menu (custom, bukan Bootstrap) ── */
.sm-cat-menu {
    /* Positioning relatif ke .sm-search__cat (parent button toggle) */
    position: absolute;
    /* Tepat di bawah search bar (.sm-search punya height 46px), jadi pakai
       calc agar muncul tepat di bawah container search bar dengan sedikit gap */
    top: calc(100% + 6px);
    left: 0;
    z-index: 1050; /* di atas .sm-result-box (default) dan .sm-quick */
    min-width: 220px;
    max-height: 60vh;
    overflow-y: auto;
    overflow-x: hidden;
    margin: 0;
    padding: 6px;
    list-style: none;
    background: #fff;
    border: 1px solid var(--sm-border);
    border-radius: 10px;
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
    /* Animasi reveal */
    opacity: 0;
    visibility: hidden;
    transform: translateY(-4px);
    transition: opacity .18s ease, transform .18s ease, visibility .18s;
    scrollbar-width: thin;
    scrollbar-color: rgba(212,165,116,.3) transparent;
}
.sm-cat-menu[hidden] { display: none !important; }
.sm-cat-menu.is-open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.sm-cat-menu::-webkit-scrollbar { width: 4px; }
.sm-cat-menu::-webkit-scrollbar-thumb {
    background: rgba(212,165,116,.3);
    border-radius: 2px;
}
.sm-cat-menu li {
    list-style: none;
    padding: 0;
    border: none;
    margin: 0;
}
.sm-cat-option {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 9px 10px;
    font-size: .8125rem;
    font-weight: 500;
    color: var(--sm-text);
    background: transparent;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    text-align: left;
    transition: background var(--sm-transition), color var(--sm-transition), padding-left var(--sm-transition);
    line-height: 1.35;
}
.sm-cat-option i {
    color: var(--sm-primary);
    opacity: .7;
    font-size: .8125rem;
    flex-shrink: 0;
}
.sm-cat-option:hover {
    background: var(--sm-bg-hover);
    color: var(--sm-primary);
    padding-left: 14px;
}
.sm-cat-option.active {
    background: var(--sm-bg-hover);
    color: var(--sm-primary);
}
.sm-cat-option.active i { opacity: 1; }

/* ── Input ── */
.sm-search__input-wrap {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
    min-width: 0;
}
.sm-search__icon {
    position: absolute;
    left: 12px;
    color: var(--sm-muted);
    font-size: .9rem;
    pointer-events: none;
    transition: color var(--sm-transition);
}
.sm-search:focus-within .sm-search__icon { color: var(--sm-primary); }

.sm-search__input {
    width: 100%;
    border: none;
    outline: none;
    padding: 0 36px 0 36px;
    font-size: .875rem;
    color: var(--sm-text);
    background: transparent;
    height: 100%;
    line-height: 1.4;
}
.sm-search__input::placeholder { color: var(--sm-muted); opacity: .8; }
/* Hilangkan default cancel-x bawaan browser */
.sm-search__input::-webkit-search-cancel-button { display: none; }
.sm-search__input::-webkit-search-decoration   { display: none; }

/* Shake animation saat submit < 3 karakter */
.sm-search__input--shake { animation: sm-shake .42s cubic-bezier(.36,.07,.19,.97); }
@keyframes sm-shake {
    10%, 90% { transform: translate3d(-1px, 0, 0); }
    20%, 80% { transform: translate3d(2px, 0, 0); }
    30%, 50%, 70% { transform: translate3d(-3px, 0, 0); }
    40%, 60% { transform: translate3d(3px, 0, 0); }
}

.sm-search__clear {
    position: absolute;
    right: 6px;
    width: 26px;
    height: 26px;
    border: none;
    border-radius: 50%;
    background: rgba(212,165,116,.1);
    color: var(--sm-muted);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: .9rem;
    transition: all var(--sm-transition);
}
.sm-search__clear:hover {
    background: var(--sm-primary);
    color: #fff;
    transform: rotate(90deg);
}

/* ── Submit Button ── */
.sm-search__submit {
    width: 50px;
    border: none;
    background: linear-gradient(135deg, var(--sm-primary), var(--sm-primary-dk));
    color: #fff;
    font-size: 1rem;
    cursor: pointer;
    transition: filter var(--sm-transition), transform var(--sm-transition);
}
.sm-search__submit:hover {
    filter: brightness(1.06);
    transform: scale(1.02);
}
.sm-search__submit:active { transform: scale(.97); }

/* ── Result Box (live search) ── */
.sm-result-box {
    margin-top: 8px;
    background: #fff;
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius);
    box-shadow: 0 4px 16px rgba(0,0,0,.06);
    overflow: hidden;
    max-height: 420px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: rgba(212,165,116,.3) transparent;
}
.sm-result-box::-webkit-scrollbar { width: 4px; }
.sm-result-box::-webkit-scrollbar-thumb {
    background: rgba(212,165,116,.3);
    border-radius: 2px;
}
.sm-result-box[hidden] { display: none !important; }

/* ── Quick Suggestions Section ── */
.sm-quick {
    margin-top: 14px;
    padding: 12px;
    background: #fff;
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius);
}
.sm-quick[hidden] { display: none !important; }

.sm-quick__title {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 10px;
    font-size: .6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--sm-muted);
}
.sm-quick__title--top { margin-top: 14px; }
.sm-quick__title i { color: var(--sm-primary); font-size: .75rem; }

.sm-quick__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.sm-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 6px 10px;
    background: #faf6f1;
    color: var(--sm-text);
    text-decoration: none;
    border-radius: 999px;
    border: 1px solid transparent;
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.3;
    transition: all var(--sm-transition);
}
.sm-chip:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 10px rgba(0,0,0,.06);
}
.sm-chip i { font-size: .75rem; }

/* Tone variants — selaras dengan badge mega menu */
.sm-chip--neutral {
    background: #faf6f1;
    color: var(--sm-text);
    border-color: var(--sm-border);
}
.sm-chip--neutral:hover {
    background: var(--sm-primary);
    color: #fff;
    border-color: var(--sm-primary);
}
.sm-chip--neutral i { color: var(--sm-primary); }
.sm-chip--neutral:hover i { color: #fff; }

.sm-chip--danger  { background: #fef2f2; color: #ef4444; border-color: rgba(239,68,68,.2); }
.sm-chip--danger:hover  { background: #ef4444; color: #fff; border-color: #ef4444; }

.sm-chip--warning { background: #fffbeb; color: #f59e0b; border-color: rgba(245,158,11,.25); }
.sm-chip--warning:hover { background: #f59e0b; color: #fff; border-color: #f59e0b; }

.sm-chip--success { background: #f0fdf4; color: #22c55e; border-color: rgba(34,197,94,.22); }
.sm-chip--success:hover { background: #22c55e; color: #fff; border-color: #22c55e; }

.sm-chip--info    { background: #eff6ff; color: #3b82f6; border-color: rgba(59,130,246,.22); }
.sm-chip--info:hover    { background: #3b82f6; color: #fff; border-color: #3b82f6; }

.sm-chip--purple  { background: #f5f3ff; color: #8b5cf6; border-color: rgba(139,92,246,.22); }
.sm-chip--purple:hover  { background: #8b5cf6; color: #fff; border-color: #8b5cf6; }

/* ── Dark Theme ── */
[theme="dark"] .sm-search,
[theme="dark"] .sm-quick,
[theme="dark"] .sm-result-box {
    background: #1e1e2d;
    border-color: rgba(255,255,255,.08);
}
[theme="dark"] .sm-cat-toggle,
[theme="dark"] .sm-search__input { color: #d8d8d8; }
[theme="dark"] .sm-search__input::placeholder { color: #888; }
[theme="dark"] .sm-cat-menu {
    background: #1e1e2d !important;
    border-color: rgba(255,255,255,.08) !important;
}
[theme="dark"] .sm-cat-option { color: #d8d8d8 !important; }
[theme="dark"] .sm-chip--neutral {
    background: #252536;
    color: #d8d8d8;
    border-color: rgba(255,255,255,.06);
}


/* ════════════════════════════════════════════════════════════
   BOTTOM NAV (.bn-*) — selaras menu_header / cart vintage rose
   ════════════════════════════════════════════════════════════ */
:root {
    --bn-primary    : #d4a574;
    --bn-primary-dk : #b8874f;
    --bn-text       : #555;
    --bn-muted      : #999;
    --bn-bg-hover   : #fdf6ef;
    --bn-radius     : 14px;
    --bn-transition : .22s cubic-bezier(.4,0,.2,1);
    --bn-height     : 64px;
}

/* Override .app-bar global agar lebih modern */
.bn-bar.app-bar {
    position: fixed;
    inset-block-end: 0;
    inset-inline: 0;
    z-index: 999;
    background: #fff;
    border-top: 1px solid rgba(212,165,116,.12);
    box-shadow: 0 -4px 20px rgba(0,0,0,.06);
    padding-bottom: env(safe-area-inset-bottom, 0px);
}

.bn-list {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0;
    list-style: none;
    margin: 0;
    padding: 0;
    height: var(--bn-height);
    align-items: stretch;
}

.bn-item {
    display: flex;
    align-items: center;
    justify-content: center;
    list-style: none;
    margin: 0;
    padding: 0;
}

/* ── Standard link ── */
.bn-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    width: 100%;
    height: 100%;
    padding: 6px 4px;
    color: var(--bn-text);
    text-decoration: none;
    transition: color var(--bn-transition);
    position: relative;
}
.bn-link:active { transform: scale(.96); }

.bn-icon {
    position: relative;
    width: 26px;
    height: 26px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: var(--bn-text);
    transition: color var(--bn-transition), transform var(--bn-transition);
}
.bn-icon i { line-height: 1; }

.bn-label {
    font-size: .6875rem;
    font-weight: 600;
    color: var(--bn-text);
    line-height: 1.2;
    letter-spacing: .02em;
    transition: color var(--bn-transition);
}

/* Active state */
.bn-item.is-active .bn-link,
.bn-item.is-active .bn-icon,
.bn-item.is-active .bn-label {
    color: var(--bn-primary-dk);
}
.bn-item.is-active .bn-icon { transform: translateY(-1px); }

/* Active indicator (top bar) */
.bn-item.is-active .bn-link::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 28px;
    height: 3px;
    background: linear-gradient(90deg, var(--bn-primary), var(--bn-primary-dk));
    border-radius: 0 0 6px 6px;
}

/* Hover (desktop) */
.bn-link:hover .bn-icon,
.bn-link:hover .bn-label {
    color: var(--bn-primary);
}

/* Badge counter di atas icon (wishlist) */
.bn-icon__badge {
    position: absolute;
    top: -4px;
    right: -8px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 9px;
    background: linear-gradient(135deg, #ff5252, #ef4444);
    color: #fff;
    font-size: 9px;
    font-weight: 800;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 2px solid #fff;
    box-shadow: 0 1px 4px rgba(239,68,68,.4);
}

/* ── Avatar variant ── */
.bn-icon--avatar {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid transparent;
    transition: border-color var(--bn-transition);
    background: var(--bn-bg-hover);
}
.bn-icon--avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.bn-item.is-active .bn-icon--avatar {
    border-color: var(--bn-primary);
}

/* ════════════════════════════════════════════════════════════
   FAB (Center) — Cart button menonjol
   ════════════════════════════════════════════════════════════ */
.bn-item--center {
    position: relative;
}
.bn-fab {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    text-decoration: none;
    color: var(--bn-text);
    /* Naik supaya FAB inner menonjol di atas bar */
    transform: translateY(-14px);
    transition: transform var(--bn-transition);
    width: 100%;
    padding: 0;
}
.bn-fab:active { transform: translateY(-12px) scale(.96); }

.bn-fab__inner {
    position: relative;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--bn-primary), var(--bn-primary-dk));
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    box-shadow: 0 6px 18px rgba(212,165,116,.45),
                0 2px 4px rgba(0,0,0,.06);
    border: 4px solid #fff;
    transition: box-shadow var(--bn-transition), transform var(--bn-transition);
}
.bn-fab:hover .bn-fab__inner,
.bn-fab.is-active .bn-fab__inner {
    box-shadow: 0 8px 22px rgba(212,165,116,.55),
                0 2px 4px rgba(0,0,0,.08);
    transform: scale(1.04);
}
.bn-fab__inner i { line-height: 1; }

.bn-fab__badge {
    position: absolute;
    top: -2px;
    right: -2px;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 10px;
    background: linear-gradient(135deg, #ff5252, #ef4444);
    color: #fff;
    font-size: 10px;
    font-weight: 800;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 2px solid #fff;
    box-shadow: 0 2px 6px rgba(239,68,68,.45);
}

.bn-fab__label {
    font-size: .6875rem;
    font-weight: 700;
    color: var(--bn-primary-dk);
    line-height: 1.2;
    letter-spacing: .02em;
}

/* ════════════════════════════════════════════════════════════
   Cart Dropdown (existing component) — adjust posisi agar muncul
   di atas FAB dengan rapi
   ════════════════════════════════════════════════════════════ */
.bn-cart-dropdown.cart-dropdown-mobile-view {
    inset-block-end: calc(var(--bn-height) + 8px) !important;
    inset-inline-start: 50% !important;
    transform: translateX(-50%) !important;
    width: calc(100vw - 24px);
    max-width: 420px;
    margin: 0 !important;
    border-radius: 16px !important;
    border: 1px solid rgba(212,165,116,.18) !important;
    box-shadow: 0 -8px 32px rgba(0,0,0,.16) !important;
}

/* ── Hide trigger area di desktop ── */
@media (min-width: 1200px) {
    .bn-bar.app-bar { display: none !important; }
}

/* ── Tablet / large mobile fine-tune ── */
@media (min-width: 576px) and (max-width: 1199.98px) {
    .bn-bar.app-bar {
        max-width: 540px;
        margin: 0 auto;
        right: 50%;
        transform: translateX(50%);
        border-radius: 18px 18px 0 0;
        left: auto;
    }
}

/* ── Body padding agar konten tidak ke-cover bar ── */
@media (max-width: 1199.98px) {
    body {
        padding-bottom: calc(var(--bn-height) + env(safe-area-inset-bottom, 0px));
    }
    /* Halaman detil produk tidak menampilkan bottom nav (di-hide via PHP),
       jadi tidak butuh padding-bottom ekstra. Halaman ini sudah punya
       padding-bottom sendiri di .pd-page untuk sticky CTA. */
    body:has(.pd-page) {
        padding-bottom: 0;
    }
    /* Footer existing back-to-top button — sesuaikan posisi */
    .back-to-top {
        bottom: calc(var(--bn-height) + 16px) !important;
    }
    body:has(.pd-page) .back-to-top {
        bottom: 16px !important;
    }
}

/* ── Dark Theme ── */
[theme="dark"] .bn-bar.app-bar {
    background: #1e1e2d;
    border-top-color: rgba(255,255,255,.06);
    box-shadow: 0 -4px 20px rgba(0,0,0,.4);
}
[theme="dark"] .bn-link,
[theme="dark"] .bn-icon,
[theme="dark"] .bn-label { color: #c8c8c8; }
[theme="dark"] .bn-item.is-active .bn-link,
[theme="dark"] .bn-item.is-active .bn-icon,
[theme="dark"] .bn-item.is-active .bn-label { color: var(--bn-primary); }
[theme="dark"] .bn-fab__inner { border-color: #1e1e2d; }
[theme="dark"] .bn-icon__badge,
[theme="dark"] .bn-fab__badge { border-color: #1e1e2d; }
[theme="dark"] .bn-fab__label { color: var(--bn-primary); }
[theme="dark"] .bn-cart-dropdown.cart-dropdown-mobile-view {
    background: #1e1e2d;
    border-color: rgba(255,255,255,.08) !important;
}
[theme="dark"] .bn-icon--avatar { background: #2a2a3a; }

/* QUICK VIEW */

#quickViewModal .modal-dialog {
    max-width: 920px;
    margin: 1.5rem auto;
}
#quickViewModal .modal-content {
    border: none;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 24px 60px rgba(0,0,0,.18);
}
#quickViewModal .modal-header {
    padding: 12px 16px !important;
    border-bottom: 1px solid #f0e7d8 !important;
    background: linear-gradient(135deg, #fff 0%, #faf6f1 100%);
}
#quickViewModal .modal-header .modal-title {
    font-size: .9375rem;
    font-weight: 700;
    color: #5a4a3a;
}
#quickViewModal .modal-header .btn-close {
    padding: 8px;
    margin: -8px -8px -8px auto;
    border-radius: 50%;
    transition: background .2s, transform .2s;
}
#quickViewModal .modal-header .btn-close:hover {
    background: #fef2f2;
    transform: rotate(90deg);
}
#quickViewModal .modal-body {
    padding: 0 !important;
    background: #fff !important;
    max-height: calc(100vh - 120px);
    overflow-y: auto;
}

/* ── Content reset ── */
#qvContent {
    padding: 0 !important;
    background: #fff !important;
    min-height: auto !important;
}
#qvContent.pd-page { padding: 0 !important; min-height: auto !important; }
#qvContent .pd-card {
    box-shadow: none;
    border: none;
    margin: 0;
    background: transparent;
}

/* ── Layout 2 kolom ── */
#qvContent .row.g-0 > div {
    padding: 14px !important;
}
#qvContent .border-start-md {
    border-left: 1px solid #f5ede1;
}

/* ── Gallery ── */
#qvContent .pd-gallery {
    position: sticky !important;
    top: 0 !important;
}
#qvContent .pd-gallery__main {
    position: relative;
    border-radius: 10px !important;
    overflow: hidden;
    background: #faf6f1;
    aspect-ratio: 1 / 1;
}
#qvContent .pd-gallery__main img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
#qvContent .pd-gallery__thumbs {
    margin-top: 8px !important;
}
#qvContent .pd-gallery__thumbs .swiper-slide {
    border: 1.5px solid transparent !important;
    border-radius: 8px !important;
    overflow: hidden;
    transition: border-color .2s;
    cursor: pointer;
}
#qvContent .pd-gallery__thumbs .swiper-slide:hover,
#qvContent .pd-gallery__thumbs .swiper-slide-thumb-active {
    border-color: #d4a574 !important;
}
#qvContent .pd-gallery__thumbs img {
    border-radius: 6px !important;
    width: 100%;
    height: auto;
    aspect-ratio: 1/1;
    object-fit: cover;
}

/* Floating actions on gallery */
#qvContent .pd-gallery__badges {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 5;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
#qvContent .pd-gallery__actions {
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 5;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
#qvContent .pd-floating-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #fff;
    color: #666;
    border: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    box-shadow: 0 2px 10px rgba(0,0,0,.12);
    transition: all .25s ease;
    cursor: pointer;
    font-size: .9rem;
}
#qvContent .pd-floating-btn:hover {
    background: #d4a574;
    color: #fff;
    transform: scale(1.08);
}
#qvContent .pd-floating-btn.pbk-action-btn--active,
#qvContent .pd-floating-btn.pbk-action-btn--active:hover {
    background: #ff5252;
    color: #fff;
}

/* Flash + discount badges */
#qvContent .pd-flash-badge,
#qvContent .pd-discount-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 9px;
    border-radius: 6px;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: #fff;
    line-height: 1.3;
    box-shadow: 0 2px 6px rgba(0,0,0,.12);
}
#qvContent .pd-flash-badge {
    background: linear-gradient(135deg, #ff6d00, #ff9100);
}
#qvContent .pd-flash-badge i { font-size: 11px; animation: qv-flash-pulse 1.6s ease-in-out infinite; }
@keyframes qv-flash-pulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: .55; }
}
#qvContent .pd-discount-badge {
    background: linear-gradient(135deg, #ff5252, #ef4444);
}

/* ── Title ── */
#qvContent .pd-title {
    font-size: 1.0625rem !important;
    font-weight: 700;
    margin: 0 0 6px 0 !important;
    line-height: 1.35 !important;
    color: #2c2c2c;
}
#qvContent .pd-title .badge {
    font-size: 9px !important;
    padding: 3px 8px !important;
    border-radius: 4px !important;
    letter-spacing: .04em;
    text-transform: uppercase;
    font-weight: 700;
}

/* ── Meta row (rating, sold, viewed) ── */
#qvContent .pd-meta-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px !important;
    margin: 0 0 10px 0 !important;
    padding-bottom: 10px !important;
    font-size: .75rem !important;
    color: #888;
    border-bottom: 1px dashed #f0e7d8 !important;
}
#qvContent .pd-meta-row__star {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: #ffc107;
    font-weight: 700;
}
#qvContent .pd-meta-row__rating { color: #2c2c2c; }
#qvContent .pd-meta-row__sep { color: #ddd; }
#qvContent .pd-meta-row i { font-size: .8rem; }

/* ── Status alert (PO / Cuci Gudang) ── */
#qvContent .pd-status-alert {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin: 0 0 12px 0 !important;
    padding: 10px 12px !important;
    border-radius: 8px !important;
    font-size: .75rem !important;
    line-height: 1.45;
}
#qvContent .pd-status-alert i { font-size: 1rem; flex-shrink: 0; margin-top: 1px; }
#qvContent .pd-status-alert--po {
    background: #fff8e6;
    border: 1px solid rgba(245,158,11,.25);
    color: #92660a;
}
#qvContent .pd-status-alert--clearance {
    background: #fef2f2;
    border: 1px solid rgba(239,68,68,.25);
    color: #b53a3a;
}

/* ── Price box ── */
#qvContent .pd-price-box {
    margin-bottom: 12px !important;
    padding: 12px 14px !important;
    border-radius: 10px !important;
    background: linear-gradient(135deg, #faf6f1 0%, #f7eedf 100%);
    border: 1px solid rgba(212,165,116,.18);
}
#qvContent .pd-price-box__main {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 8px !important;
    margin: 0 !important;
}
#qvContent .pd-price {
    font-size: 1.5rem !important;
    font-weight: 800;
    color: #b8874f;
    letter-spacing: -.02em;
    line-height: 1.2;
}
#qvContent .pd-price-old {
    font-size: .8125rem !important;
    color: #999;
    text-decoration: line-through;
}
#qvContent .pd-price-box__main .pd-discount-badge {
    box-shadow: none;
    padding: 3px 7px;
    font-size: 10px;
}

/* ── Flash sale countdown ── */
#qvContent .pd-flash-countdown {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px !important;
    padding: 8px 12px !important;
    margin-bottom: 12px !important;
    border-radius: 8px !important;
    background: linear-gradient(135deg, #fff5eb, #ffeacc);
    border: 1px solid rgba(255,109,0,.2);
}
#qvContent .pd-flash-countdown__title {
    font-size: .75rem !important;
    font-weight: 700;
    color: #c75800;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
#qvContent .pd-flash-countdown__title i { font-size: .85rem; }
#qvContent .pd-flash-countdown__pills {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
#qvContent .pd-flash-countdown__pills .badge {
    background: linear-gradient(135deg, #ff6d00, #ff9100) !important;
    color: #fff !important;
    font-size: .7rem !important;
    font-weight: 700;
    padding: 4px 8px !important;
    border-radius: 4px !important;
    line-height: 1.3;
}

/* ── Variant blocks ── */
#qvContent .variant-selector-container {
    margin-bottom: 12px !important;
}
#qvContent .pd-variant-block {
    margin-bottom: 12px !important;
}
#qvContent .pd-variant-label {
    font-size: .8125rem !important;
    font-weight: 600;
    color: #444;
    margin-bottom: 6px !important;
}
#qvContent .pd-variant-selected {
    color: #b8874f;
    font-weight: 700;
    margin-left: 4px;
}

/* Color buttons */
#qvContent .color-btn {
    min-width: 60px !important;
    max-width: 80px !important;
    padding: 4px !important;
    gap: 4px !important;
    border-radius: 8px !important;
    border: 2px solid #e8e0d0 !important;
    background: #fff;
    transition: all .2s;
    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: pointer;
}
#qvContent .color-btn:hover {
    border-color: #d4a574 !important;
    transform: translateY(-1px);
}
#qvContent .color-btn.active,
#qvContent .color-btn.selected {
    border-color: #d4a574 !important;
    background: #fdf6ef;
    box-shadow: 0 4px 10px rgba(212,165,116,.2);
}
#qvContent .color-btn img {
    width: 38px !important;
    height: 38px !important;
    border-radius: 6px !important;
    object-fit: cover;
}
#qvContent .color-name {
    font-size: 9.5px !important;
    font-weight: 600;
    color: #555;
    max-width: 70px !important;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.2;
}

/* Size buttons */
#qvContent .size-btn {
    min-width: 48px !important;
    height: 32px !important;
    padding: 0 10px !important;
    font-size: .8125rem !important;
    font-weight: 600;
    border-radius: 6px !important;
    border: 1.5px solid #e8e0d0 !important;
    background: #fff;
    color: #555;
    cursor: pointer;
    transition: all .2s;
}
#qvContent .size-btn:hover:not(:disabled) {
    border-color: #d4a574 !important;
    color: #b8874f;
}
#qvContent .size-btn.active,
#qvContent .size-btn.selected {
    background: #d4a574;
    border-color: #d4a574 !important;
    color: #fff;
    box-shadow: 0 4px 10px rgba(212,165,116,.3);
}
#qvContent .size-btn:disabled {
    opacity: .4;
    cursor: not-allowed;
    background: #f5f5f5;
}

/* Variant info box */
#qvContent #variant-info-box {
    padding: 10px 12px !important;
    margin-top: 8px !important;
    border-radius: 8px !important;
    background: #f0f9f4;
    border: 1px solid rgba(34,197,94,.2);
}
#qvContent #variant-info-box small { color: #888; }
#qvContent #variant-info-box strong { color: #2e7d32; font-size: .8125rem; }

/* ── Quantity row ── */
#qvContent .pd-qty-row {
    display: flex;
    align-items: center;
    gap: 12px !important;
    margin: 12px 0 !important;
    flex-wrap: wrap;
}
#qvContent .pd-qty-label {
    font-size: .8125rem !important;
    font-weight: 600;
    color: #444;
}
#qvContent .quantity.quantity--style-two {
    width: 110px !important;
    height: 36px !important;
    border-radius: 8px !important;
    border: 1.5px solid #e8e0d0 !important;
    background: #fff;
    overflow: hidden;
    display: inline-flex !important;
    align-items: stretch !important;
}
#qvContent .quantity__minus,
#qvContent .quantity__plus {
    width: 32px !important;
    height: 100% !important;
    border: none !important;
    background: #faf6f1 !important;
    color: #555 !important;
    cursor: pointer;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background .2s, color .2s;
    padding: 0 !important;
    border-radius: 0 !important;
    font-size: .9rem;
}
#qvContent .quantity__minus { border-right: 1px solid #e8e0d0 !important; }
#qvContent .quantity__plus  { border-left: 1px solid #e8e0d0 !important; }
#qvContent .quantity__minus:hover,
#qvContent .quantity__plus:hover {
    background: #d4a574 !important;
    color: #fff !important;
}
#qvContent .product_quantity__qty {
    font-size: .875rem !important;
    font-weight: 700 !important;
    color: #2c2c2c !important;
    text-align: center;
    border: none !important;
    background: transparent !important;
    width: 100% !important;
    padding: 0 !important;
    -moz-appearance: textfield;
}
#qvContent .product_quantity__qty::-webkit-outer-spin-button,
#qvContent .product_quantity__qty::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
#qvContent .pd-qty-row .text-muted { font-size: .75rem !important; }
#qvContent #info_stok { color: #b8874f !important; }

/* ── Stock meter ── */
#qvContent .pd-stock-meter {
    margin: 8px 0 12px !important;
}
#qvContent .pd-stock-meter__top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 4px !important;
    font-size: .7rem !important;
}
#qvContent .pd-stock-meter__bar {
    height: 5px !important;
    background: #f0e7d8;
    border-radius: 999px;
    overflow: hidden;
}
#qvContent .pd-stock-meter__fill {
    height: 100%;
    border-radius: 999px;
    transition: width .4s ease;
}

/* ── Subtotal tile ── */
#qvContent .pd-info-grid {
    margin: 10px 0 14px !important;
}
#qvContent .pd-info-tile {
    padding: 10px 14px !important;
    border-radius: 10px !important;
    background: linear-gradient(135deg, #fdf6ef, #faf6f1);
    border: 1px solid rgba(212,165,116,.18);
    display: flex;
    align-items: center;
    justify-content: space-between;
}
#qvContent .pd-info-tile__label {
    font-size: .75rem !important;
    color: #888;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
}
#qvContent .pd-info-tile__value {
    font-size: 1.125rem !important;
    font-weight: 800;
    color: #b8874f !important;
    letter-spacing: -.02em;
}

/* ── CTA buttons ── */
#qvContent .mx-w {
    max-width: none !important;
    width: 100% !important;
}
#qvContent .mx-w .btn {
    width: 100%;
    height: 44px !important;
    font-size: .9375rem !important;
    font-weight: 700;
    border-radius: 10px !important;
    padding: 0 16px !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    transition: all .25s ease;
}
#qvContent .mx-w .btn-primary {
    background: linear-gradient(135deg, #d4a574, #b8874f);
    border: none;
    box-shadow: 0 4px 12px rgba(212,165,116,.35);
}
#qvContent .mx-w .btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(212,165,116,.5);
}
#qvContent .mx-w .btn-warning {
    background: linear-gradient(135deg, #f59e0b, #d97706);
    border: none;
    color: #fff;
    box-shadow: 0 4px 12px rgba(245,158,11,.35);
}
#qvContent .mx-w .btn-warning:hover { color: #fff; transform: translateY(-1px); }
#qvContent .mx-w .btn-danger {
    background: linear-gradient(135deg, #ef4444, #dc2626);
    border: none;
    box-shadow: 0 4px 12px rgba(239,68,68,.35);
}
#qvContent .mx-w .btn-danger:hover { transform: translateY(-1px); }

/* Footer link */
#qvContent .mt-1.text-center {
    margin-top: 10px !important;
}
#qvContent .mt-1.text-center a {
    font-size: .8125rem !important;
    color: #b8874f !important;
    font-weight: 700;
}
#qvContent .mt-1.text-center a:hover {
    color: #d4a574 !important;
    text-decoration: underline !important;
}

/* ── Blocking overlay (habis/comingsoon/draft/arsip) ── */
#qvContent .pd-blocking-overlay {
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,.96);
    backdrop-filter: blur(3px);
    z-index: 20;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
}
#qvContent .pd-blocking-overlay .text-center { padding: 24px !important; }
#qvContent .pd-blocking-overlay i {
    font-size: 3.5rem !important;
}
#qvContent .pd-blocking-overlay h4 {
    font-size: 1.125rem !important;
    margin-top: 12px !important;
    margin-bottom: 6px !important;
    font-weight: 700;
}
#qvContent .pd-blocking-overlay p {
    font-size: .875rem !important;
    margin-bottom: 8px !important;
    color: #888;
}

/* ════════════════════════════════════════════════════════════
   RESPONSIVE — Tablet & Mobile
   ════════════════════════════════════════════════════════════ */
@media (max-width: 991.98px) {
    #quickViewModal .modal-dialog {
        max-width: 100%;
        margin: 0;
    }
    #quickViewModal .modal-content {
        border-radius: 0;
        min-height: 100vh;
        min-height: 100dvh;
    }
    #quickViewModal .modal-body {
        max-height: none;
    }
    #qvContent .pd-gallery {
        position: static !important;
    }
    #qvContent .border-start-md {
        border-left: none;
        border-top: 1px solid #f5ede1;
    }
}

@media (max-width: 767.98px) {
    #qvContent .row.g-0 > div { padding: 12px !important; }
    #qvContent .pd-title { font-size: .9375rem !important; }
    #qvContent .pd-price { font-size: 1.25rem !important; }
    #qvContent .pd-info-tile__value { font-size: 1rem !important; }
    #qvContent .mx-w .btn { height: 42px !important; font-size: .875rem !important; }
    #qvContent .pd-floating-btn { width: 32px; height: 32px; font-size: .8rem; }
}

@media (max-width: 575.98px) {
    #qvContent .row.g-0 > div { padding: 10px !important; }
    #qvContent .pd-price { font-size: 1.125rem !important; }
    #qvContent .pd-flash-countdown {
        flex-direction: column;
        align-items: flex-start;
        gap: 6px !important;
    }
    #qvContent .pd-qty-row {
        gap: 8px !important;
    }
    #qvContent .color-btn {
        min-width: 54px !important;
    }
    #qvContent .color-btn img {
        width: 34px !important;
        height: 34px !important;
    }
}
.pbk-section {
    padding: 0.5rem 0;
}

.pbk-wrapper {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.06);
    overflow: hidden;
    margin-bottom: 12px;
    border: 1px solid rgba(212, 165, 116, 0.1);
}

/* ── Header ── */
.pbk-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px 12px;
    border-bottom: 1px solid #f0ebe5;
}

.pbk-header__left {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.pbk-header__icon-ring {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(212,165,116,0.15), rgba(212,165,116,0.08));
    color: var(--vintage-rose, #d4a574);
    font-size: 1rem;
    flex-shrink: 0;
    transition: all 0.3s ease;
}

.pbk-wrapper:hover .pbk-header__icon-ring {
    background: linear-gradient(135deg, var(--vintage-rose, #d4a574), var(--primary-dark, #c19660));
    color: #fff;
    transform: scale(1.05);
}

.pbk-header__title {
    font-size: 1rem;
    font-weight: 700;
    color: #2c2c2c;
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    letter-spacing: -0.01em;
}

.pbk-header__link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--vintage-rose, #d4a574);
    text-decoration: none;
    white-space: nowrap;
    flex-shrink: 0;
    padding: 6px 12px;
    border-radius: 20px;
    transition: all 0.25s ease;
}

.pbk-header__link:hover {
    background: rgba(212,165,116,0.1);
    color: var(--primary-dark, #c19660);
}

.pbk-header__link i {
    font-size: 0.7rem;
    transition: transform 0.25s ease;
}

.pbk-header__link:hover i {
    transform: translateX(3px);
}

/* ── Slider Container ── */
.pbk-slider-container {
    position: relative;
    padding: 14px 16px 18px;
}

/* ── Slide Sizing ── */
.pbk-slide {
    width: 160px;
    height: auto;
}

/* ── Product Card ── */
.pbk-card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid #f0f0f0;
    height: 100%;
    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    position: relative;
}

.pbk-card:hover {
    border-color: rgba(212,165,116,0.3);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
    transform: translateY(-4px);
}

.pbk-card--disabled {
    opacity: 0.85;
}

.pbk-card--empty {
    border: 1px dashed #e0d6cc;
    min-height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ── Image Wrapper ── */
.pbk-card__img-wrap {
    position: relative;
    overflow: hidden;
    aspect-ratio: 1 / 1;
    background: #faf8f6;
}

.pbk-card__img-link {
    display: block;
    width: 100%;
    height: 100%;
}

.pbk-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.pbk-card:hover .pbk-card__img {
    transform: scale(1.06);
}

.pbk-card--disabled .pbk-card__img {
    filter: grayscale(30%) brightness(0.85);
}

/* ── Overlay ── */
.pbk-card__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    backdrop-filter: blur(1px);
}

.pbk-card__overlay--soon {
    background: rgba(13, 110, 253, 0.35);
}

.pbk-card__overlay-text {
    color: #fff;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 5px 14px;
    border-radius: 20px;
    background: rgba(0,0,0,0.4);
    border: 1px solid rgba(255,255,255,0.25);
}

/* ── Status Badge ── */
.pbk-badge {
    position: absolute;
    top: 8px;
    left: 8px;
    z-index: 3;
    font-size: 0.625rem;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 4px;
    line-height: 1.3;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.pbk-badge--ready {
    background: #e8f5e9;
    color: #2e7d32;
}

.pbk-badge--po {
    background: #fff8e1;
    color: #f57f17;
}

.pbk-badge--habis {
    background: #ffebee;
    color: #c62828;
}

.pbk-badge--soon {
    background: #e3f2fd;
    color: #1565c0;
}

.pbk-badge--clearance {
    background: #fce4ec;
    color: #ad1457;
}

.pbk-badge--default {
    background: #f5f5f5;
    color: #616161;
}

/* ── Discount Badge ── */
.pbk-discount-badge {
    position: absolute;
    top: 8px;
    right: 8px;
    z-index: 3;
    font-size: 0.6875rem;
    font-weight: 800;
    padding: 2px 7px;
    border-radius: 4px;
    background: linear-gradient(135deg, #ff5252, #f44336);
    color: #fff;
    line-height: 1.4;
}

/* ── Flash Icon ── */
.pbk-flash-icon {
    position: absolute;
    bottom: 8px;
    left: 8px;
    z-index: 3;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: linear-gradient(135deg, #ff6d00, #ff9100);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    box-shadow: 0 2px 6px rgba(255, 109, 0, 0.4);
    animation: pbk-pulse-flash 2s ease-in-out infinite;
}

@keyframes pbk-pulse-flash {
    0%, 100% { box-shadow: 0 2px 6px rgba(255, 109, 0, 0.4); }
    50% { box-shadow: 0 2px 12px rgba(255, 109, 0, 0.7); }
}

/* ── Action Buttons ── */
.pbk-card__actions {
    position: absolute;
    top: 8px;
    right: 8px;
    z-index: 4;
    display: flex;
    flex-direction: column;
    gap: 6px;
    opacity: 0;
    transform: translateX(8px);
    transition: all 0.3s ease;
}

/* Show actions when card is hovered */
.pbk-card:hover .pbk-card__actions {
    opacity: 1;
    transform: translateX(0);
}

/* On mobile: always show actions */
@media (max-width: 767.98px) {
    .pbk-card__actions {
        opacity: 1;
        transform: translateX(0);
    }
}

/* Move discount badge down when actions are visible */
.pbk-card:hover .pbk-discount-badge {
    opacity: 0;
    transition: opacity 0.2s ease;
}

.pbk-discount-badge {
    transition: opacity 0.2s ease;
}

.pbk-action-btn {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #fff;
    color: #666;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    text-decoration: none;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
    transition: all 0.25s ease;
    border: none;
    cursor: pointer;
}

.pbk-action-btn:hover {
    background: var(--vintage-rose, #d4a574);
    color: #fff;
    transform: scale(1.1);
    box-shadow: 0 4px 12px rgba(212, 165, 116, 0.4);
}

.pbk-action-btn--active,
.pbk-action-btn--active:hover {
    background: #ff5252;
    color: #fff;
}

/* ── Card Body ── */
.pbk-card__body {
    padding: 10px 10px 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
}

.pbk-card__title-link {
    text-decoration: none;
    color: inherit;
}

.pbk-card__title {
    font-size: 0.8125rem;
    font-weight: 500;
    color: #333;
    margin: 0;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    transition: color 0.2s ease;
}

.pbk-card__title-link:hover .pbk-card__title {
    color: var(--vintage-rose, #d4a574);
}

/* ── Price ── */
.pbk-card__price-wrap {
    display: flex;
    flex-direction: column;
    gap: 1px;
    margin-top: 4px;
}

.pbk-card__price {
    font-size: 0.9375rem;
    font-weight: 800;
    color: var(--vintage-rose, #d4a574);
    letter-spacing: -0.02em;
    line-height: 1.3;
}

.pbk-card__price-old {
    font-size: 0.6875rem;
    color: #999;
    text-decoration: line-through;
    line-height: 1.3;
}

/* ── Rating ── */
.pbk-card__rating {
    display: flex;
    align-items: center;
    gap: 3px;
    margin-top: 2px;
    padding-top: 6px;
    border-top: 1px solid #f5f2ef;
}

.pbk-card__star {
    font-size: 0.65rem;
    color: #ffc107;
}

.pbk-card__rating-val {
    font-size: 0.6875rem;
    font-weight: 700;
    color: #444;
}

.pbk-card__rating-sep {
    font-size: 0.625rem;
    color: #ddd;
    margin: 0 1px;
}

.pbk-card__rating-count {
    font-size: 0.6875rem;
    color: #999;
}

/* ── Navigation Arrows ── */
.pbk-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #fff;
    border: 1px solid #eee;
    color: #555;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    cursor: pointer;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    transition: all 0.25s ease;
    opacity: 0;
    padding: 0;
}

.pbk-slider-container:hover .pbk-nav {
    opacity: 1;
}

.pbk-nav:hover {
    background: var(--vintage-rose, #d4a574);
    border-color: var(--vintage-rose, #d4a574);
    color: #fff;
    box-shadow: 0 4px 16px rgba(212, 165, 116, 0.4);
    transform: translateY(-50%) scale(1.08);
}

.pbk-nav--prev {
    left: 4px;
}

.pbk-nav--next {
    right: 4px;
}

.pbk-nav.swiper-button-disabled {
    opacity: 0 !important;
    pointer-events: none;
}

/* ── Responsive ── */
@media (max-width: 575.98px) {
    .pbk-section {
        padding: 0.25rem 0;
    }

    .pbk-wrapper {
        border-radius: 8px;
        margin-bottom: 8px;
    }

    .pbk-header {
        padding: 12px 14px 10px;
    }

    .pbk-header__icon-ring {
        width: 30px;
        height: 30px;
        border-radius: 8px;
        font-size: 0.85rem;
    }

    .pbk-header__title {
        font-size: 0.9rem;
    }

    .pbk-header__link {
        font-size: 0.75rem;
        padding: 4px 8px;
    }

    .pbk-slider-container {
        padding: 10px 12px 14px;
    }

    .pbk-slide {
        width: 140px;
    }

    .pbk-card__body {
        padding: 8px 8px 10px;
    }

    .pbk-card__title {
        font-size: 0.75rem;
    }

    .pbk-card__price {
        font-size: 0.8125rem;
    }

    .pbk-card__price-old {
        font-size: 0.625rem;
    }

    .pbk-nav {
        display: none;
    }
}

@media (min-width: 576px) and (max-width: 767.98px) {
    .pbk-slide {
        width: 150px;
    }
}

@media (min-width: 768px) and (max-width: 991.98px) {
    .pbk-slide {
        width: 160px;
    }
}

@media (min-width: 992px) {
    .pbk-slide {
        width: 175px;
    }
}

/* ── Dark Theme Support ── */
[theme="dark"] .pbk-wrapper {
    background: #1e1e2d;
    border-color: rgba(255,255,255,0.06);
    box-shadow: 0 1px 6px rgba(0,0,0,0.3);
}

[theme="dark"] .pbk-header {
    border-bottom-color: rgba(255,255,255,0.06);
}

[theme="dark"] .pbk-header__title {
    color: #e8e8e8;
}

[theme="dark"] .pbk-card {
    background: #252536;
    border-color: rgba(255,255,255,0.06);
}

[theme="dark"] .pbk-card:hover {
    border-color: rgba(212,165,116,0.3);
    box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}

[theme="dark"] .pbk-card__img-wrap {
    background: #1a1a2e;
}

[theme="dark"] .pbk-card__title {
    color: #d8d8d8;
}

[theme="dark"] .pbk-card__rating {
    border-top-color: rgba(255,255,255,0.06);
}

[theme="dark"] .pbk-card__rating-val {
    color: #ccc;
}

[theme="dark"] .pbk-action-btn {
    background: #333;
    color: #ccc;
}

[theme="dark"] .pbk-nav {
    background: #333;
    border-color: #444;
    color: #ccc;
}

[theme="dark"] .pbk-card__overlay-text {
    background: rgba(0,0,0,0.6);
}

/* ── Dark Theme ── */
[theme="dark"] #quickViewModal .modal-content { background: #1e1e2d; }
[theme="dark"] #quickViewModal .modal-header {
    background: linear-gradient(135deg, #1e1e2d, #252536);
    border-bottom-color: rgba(255,255,255,.06) !important;
}
[theme="dark"] #quickViewModal .modal-header .modal-title { color: #e0e0e0; }
[theme="dark"] #qvContent { background: #1e1e2d !important; }
[theme="dark"] #qvContent .pd-title { color: #e0e0e0; }
[theme="dark"] #qvContent .pd-price-box { background: #252536; border-color: rgba(255,255,255,.06); }
[theme="dark"] #qvContent .pd-info-tile { background: #252536; border-color: rgba(255,255,255,.06); }
[theme="dark"] #qvContent .pd-meta-row { border-bottom-color: rgba(255,255,255,.06) !important; }
[theme="dark"] #qvContent .border-start-md { border-left-color: rgba(255,255,255,.06); }
[theme="dark"] #qvContent .color-btn,
[theme="dark"] #qvContent .size-btn { background: #2a2a3a; border-color: rgba(255,255,255,.08) !important; color: #d0d0d0 !important; }
[theme="dark"] #qvContent .color-btn.active,
[theme="dark"] #qvContent .color-btn.selected { background: rgba(212,165,116,.15); }
[theme="dark"] #qvContent .quantity.quantity--style-two { background: #2a2a3a; border-color: rgba(255,255,255,.08) !important; }
[theme="dark"] #qvContent .quantity__minus,
[theme="dark"] #qvContent .quantity__plus { background: #1e1e2d !important; color: #ccc !important; }
[theme="dark"] #qvContent .product_quantity__qty { color: #e0e0e0 !important; }
[theme="dark"] #qvContent .pd-blocking-overlay { background: rgba(30,30,45,.96); }