/* Storefront-specific tweaks */
/* Ensure Mazer sidebar spacing doesn't apply on /store */
body.storefront #sidebar,
body.storefront .sidebar-wrapper{
  display: none !important;
}
body.storefront #main{
  margin-left: 0 !important;
}
body.storefront #main.layout-navbar{
  padding-left: 1.5rem !important;
  padding-right: 1.5rem !important;
}
@media (min-width: 1200px){
  body.storefront #main.layout-navbar{
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
}
    /* Force primary buttons to brand (store/portal checkout) */
    .portal .btn-primary,
    .portal .btn.btn-primary{
      background-color: var(--nifa-primary) !important;
      border-color: var(--nifa-primary) !important;
      color: #fff !important;
    }
    .portal .btn-info,
    .portal .btn.btn-info{
      background-color: var(--nifa-primary) !important;
      border-color: var(--nifa-primary) !important;
      color: #fff !important;
    }

    /* Reuse portal button consistency (storefront tetap premium) */
    .portal .btn{border-radius:12px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:.35rem}
    .portal .btn.btn-sm{border-radius:10px}
    .portal .btn.btn-lg{border-radius:14px}
    .portal .btn-primary{box-shadow:0 10px 26px rgba(var(--brand-accent-rgb),.14)}
    .portal .btn-light.border{box-shadow:0 6px 18px rgba(0,0,0,.05)}
    .portal .btn:focus{box-shadow:0 0 0 .2rem rgba(var(--brand-accent-rgb),.18)}
    .portal .btn .bi{flex:0 0 auto}
    .bi{display:inline-block;line-height:1;vertical-align:-.125em}

    /* Hard-override primary/info buttons in store (last-resort) */
    body.storefront .btn-primary,
    body.storefront .btn.btn-primary,
    body.storefront .btn-info,
    body.storefront .btn.btn-info,
    body.storefront .portal .btn-primary,
    body.storefront .portal .btn.btn-primary,
    body.storefront .portal .btn-info,
    body.storefront .portal .btn.btn-info{
      background-color: var(--brand-accent) !important;
      border-color: var(--brand-accent) !important;
      color: #fff !important;
      background-image: none !important;
    }
    body.storefront .btn-primary:hover,
    body.storefront .btn.btn-primary:hover,
    body.storefront .btn-info:hover,
    body.storefront .btn.btn-info:hover{
      background-color: var(--nifa-primary-hover, var(--brand-accent)) !important;
      border-color: var(--nifa-primary-hover, var(--brand-accent)) !important;
    }
    body.storefront .btn-primary:active,
    body.storefront .btn.btn-primary:active,
    body.storefront .btn-info:active,
    body.storefront .btn.btn-info:active{
      background-color: var(--nifa-primary-active, var(--brand-accent)) !important;
      border-color: var(--nifa-primary-active, var(--brand-accent)) !important;
    }

    /* u16yc3 — Badge "*-lt" (soft pills) harus kebaca di Mazer/Bootstrap.
       Beberapa theme membuat .badge text putih, sementara background "lt" itu terang.
       Ini juga bikin warna seragam di mobile + desktop (cart/checkout/orders). */
    .badge.bg-secondary-lt,
    .badge.bg-azure-lt,
    .badge.bg-indigo-lt,
    .badge.bg-cyan-lt,
    .badge.bg-success-lt{
      border-radius:999px;
      font-weight:700;
      border:1px solid rgba(0,0,0,.08);
      color:rgba(0,0,0,.85) !important;
    }
    .badge.bg-secondary-lt{background:rgba(0,0,0,.05) !important;}
    .badge.bg-azure-lt{background:rgba(var(--brand-accent-rgb),.10) !important;border-color:rgba(var(--brand-accent-rgb),.16) !important;color:var(--bs-primary) !important;}
    .badge.bg-success-lt{background:rgba(25,135,84,.12) !important;border-color:rgba(25,135,84,.18) !important;color:var(--bs-success) !important;}
    .badge.bg-indigo-lt{background:rgba(102,16,242,.10) !important;border-color:rgba(102,16,242,.16) !important;color:rgba(60,24,130,.95) !important;}
    .badge.bg-cyan-lt{background:rgba(13,202,240,.14) !important;border-color:rgba(13,202,240,.18) !important;color:rgba(11,114,133,.98) !important;}

    /* p10d4t4 — Marketplace header/topbar */
    .sf-topstrip{font-size:.85rem;background:#fff}
    .sf-topstrip a{text-decoration:none}
    .sf-topstrip a:hover{text-decoration:underline}
    .sf-topbar{background:#fff; box-shadow:0 8px 20px rgba(0,0,0,.05)}
    .sf-topbar .navbar-brand{gap:.55rem}
    .sf-topbar .navbar-brand img{height:30px;width:auto}
    .sf-searchbar .form-control,
    .sf-searchbar .input-group-text{border-radius:999px}
    .sf-searchbar .input-group-text{background:rgba(0,0,0,.03)}
    .sf-searchbar .form-control{padding-left:.2rem}
    .sf-nav-icon{width:40px;height:38px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:12px}
    .sf-badge{font-size:.65rem;line-height:1;padding:.35em .45em}
    .sf-muted{opacity:.75}
    .sf-lang-btn{border-radius:999px}
    .sf-divider{width:1px;height:18px;background:rgba(0,0,0,.1)}

    /* p10d4u13b — Sticky header (menu tetap terlihat, compact saat scroll) */
    .sf-header-sticky{position:fixed;top:0;left:0;right:0;width:100%;z-index:2000;background:#fff}
    .sf-header-spacer{height:0}
    .sf-header-sticky .sf-topstrip,
    .sf-header-sticky .sf-ann{transition:opacity .18s ease, max-height .18s ease, transform .18s ease, padding .18s ease}

    /* Jangan hilangkan menu/topstrip — cukup dipadatkan */
    .sf-header-sticky.is-scrolled .sf-topstrip{opacity:1;max-height:52px;overflow:hidden;transform:none;pointer-events:auto;padding-top:.25rem !important;padding-bottom:.25rem !important}
    .sf-header-sticky.is-scrolled .sf-topstrip .sf-divider{display:none !important}
    .sf-header-sticky.is-scrolled .sf-topstrip a,
    .sf-header-sticky.is-scrolled .sf-topstrip span{font-size:.825rem}

    /* Announcement tetap ada, tapi compact */
    .sf-header-sticky.is-scrolled .sf-ann{opacity:1;max-height:46px;overflow:hidden;transform:none;pointer-events:auto;padding-top:.25rem !important;padding-bottom:.25rem !important}
    .sf-header-sticky.is-scrolled .sf-ann .sf-ann-link{display:none !important}

    .sf-header-sticky.is-scrolled .sf-topbar{box-shadow:0 14px 36px rgba(0,0,0,.10)}
    @supports ((-webkit-backdrop-filter: blur(8px)) or (backdrop-filter: blur(8px))) {
      .sf-header-sticky.is-scrolled .sf-topbar{background:rgba(255,255,255,.88);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}
    }


    /* p10d4u1 — Notif/Chat dropdown placeholder (premium & consistent) */
    .sf-dd-toggle.dropdown-toggle::after{display:none}
    .sf-dd-menu{min-width:340px;max-width:92vw;border-radius:18px;overflow:hidden;padding:0;border:1px solid rgba(0,0,0,.08);box-shadow:0 18px 46px rgba(0,0,0,.12)}
    .sf-dd-head{padding:.85rem 1rem;background:rgba(var(--brand-accent-rgb),.06);border-bottom:1px solid rgba(0,0,0,.06)}
    .sf-dd-head .badge{border-radius:999px}
    .sf-dd-empty{padding:1rem}
    .sf-dd-empty .small{line-height:1.35}
    .sf-dd-actions{display:flex;gap:.5rem;align-items:center;padding:.6rem .6rem .7rem;border-top:1px solid rgba(0,0,0,.06);background:#fff}
    .sf-dd-actions .btn{border-radius:12px;font-weight:700}
    .sf-dd-link{padding:.6rem 1rem .75rem}
    .sf-dd-link a{text-decoration:none}
    .sf-dd-link a:hover{text-decoration:underline}
    .sf-dd-footer{padding:.6rem .8rem;border-top:1px solid rgba(0,0,0,.06);background:#fff}
    .sf-dd-footer a{display:block;text-align:center;text-decoration:none;font-weight:800;font-size:.9rem}
    .sf-dd-footer a:hover{text-decoration:underline}
    .sf-chat-dd-body{max-height:360px;overflow:auto;background:#fff}
    .sf-chat-item{padding:.7rem .9rem;border-left:0;border-right:0}
    .sf-chat-item:hover{background:rgba(var(--brand-accent-rgb),.04)}
    .sf-chat-item.is-unread{background:rgba(var(--brand-accent-rgb),.06)}
    .sf-chat-avatar{width:34px;height:34px;border-radius:10px;background:rgba(var(--brand-accent-rgb),.12);color:var(--brand-accent,#17B8C6);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex:0 0 auto}
    .sf-chat-dot{width:6px;height:6px;border-radius:999px;background:var(--brand-accent,#17B8C6);display:inline-block}
    .sf-chat-status{font-size:.62rem;letter-spacing:.01em;border-radius:999px;padding:.2rem .45rem}
    .sf-chat-time{white-space:nowrap}
    /* u21b6c — Desktop notifications dropdown (Tokopedia-like) */
    .sf-notif-dd-menu{width:380px;max-width:92vw}
    .sf-notif-dd-body{max-height:68vh;overflow:auto;background:#fff}
    .sf-notif-dd-body .list-group-item{border-left:0;border-right:0}
    .sf-notif-dd-menu .sf-dd-head .btn{border-radius:12px;font-weight:700}
    .sf-notif-dd-footer{position:sticky;bottom:0;background:#fff;border-top:1px solid rgba(0,0,0,.06)}
    .sf-notif-dd-footer-link{display:block;padding:.65rem 1rem;text-align:center;text-decoration:none;font-weight:800;font-size:.9rem;color:inherit}
    .sf-notif-dd-footer-link:hover{text-decoration:underline}
    .sf-notif-group{padding:.55rem 1rem;font-size:.72rem;letter-spacing:.02em;text-transform:uppercase;color:rgba(0,0,0,.55);background:rgba(0,0,0,.02);border-top:1px solid rgba(0,0,0,.04);border-bottom:1px solid rgba(0,0,0,.04)}
    .nifa-notif-item{position:relative}
    .nifa-notif-unread{background:rgba(0,0,0,.02)}
    .nifa-notif-unread:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--brand-accent,#17B8C6);opacity:.85}
    .nifa-notif-dot{display:inline-block;width:8px;height:8px;border-radius:999px;background:var(--brand-accent,#17B8C6);opacity:.9}
    .sf-notif-dd-menu .nifa-notif-item .nifa-notif-body{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
    .sf-notif-dd-menu .nifa-notif-item{padding-top:.55rem;padding-bottom:.55rem}


    /* u16d — Checkout/cart mode: simpler header like marketplace checkout */
    .store-checkout .sf-header-sticky{position:fixed;top:0;box-shadow:0 10px 26px rgba(0,0,0,.07)}
    .sf-checkoutbar{background:#fff}
    .sf-checkoutbar .navbar-brand{gap:.55rem}
    .sf-checkout-steps{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
    .sf-step{display:inline-flex;align-items:center;gap:.45rem;padding:.35rem .7rem;border-radius:999px;border:1px solid rgba(0,0,0,.08);font-weight:700;font-size:.85rem;background:#fff}
    .sf-step i{opacity:.85}
    .sf-step.is-active{border-color:rgba(var(--brand-accent-rgb),.35);box-shadow:0 10px 22px rgba(var(--brand-accent-rgb),.10)}
    .sf-step.is-done{background:rgba(var(--brand-accent-rgb),.06);border-color:rgba(var(--brand-accent-rgb),.18)}
    .sf-step-sep{opacity:.35}
    .sf-step.is-future{opacity:.6}
    .sf-step .badge{border-radius:999px;font-weight:900}
    .sf-bottombar .btn{transition:transform .12s ease, box-shadow .12s ease}
    .sf-bottombar .btn:hover{transform:translateY(-1px);box-shadow:0 12px 26px rgba(0,0,0,.12)}
    .sf-bottombar .btn:active{transform:translateY(0) scale(.99)}
    .sf-bottombar .btn-primary .badge{border-radius:999px;font-weight:900}    @media (max-width: 991.98px){
      .sf-checkout-steps{justify-content:flex-start}
    }

    @media (max-width: 575.98px){
      .sf-nav-icon{width:42px;height:40px}
    }

    /* Tiny hint (no JS tooltip) */
    .sf-hint{position:relative}
    .sf-hint[data-hint]:hover:after,
    .sf-hint[data-hint]:focus:after{
      content:attr(data-hint);
      position:absolute;
      bottom:-36px;
      left:50%;
      transform:translateX(-50%);
      background:#111827;
      color:#fff;
      font-size:.75rem;
      padding:.35rem .5rem;
      border-radius:10px;
      white-space:nowrap;
      z-index:20;
      box-shadow:0 10px 28px rgba(0,0,0,.18);
      opacity:.96;
    }
    .sf-ann{font-size:13px; border-bottom:1px solid rgba(20,30,40,.08);}
    .sf-ann a{color:inherit; text-decoration:none;}
    .sf-ann .sf-ann-link{margin-left:10px; font-weight:700; text-decoration:underline;}
    .sf-ann .sf-ann-close{padding:2px 8px; line-height:1; border-radius:10px;}
    .sf-ann--info{background:rgba(var(--brand-accent-rgb),.08);}
    .sf-ann--success{background:rgba(47,179,68,.10);}
    .sf-ann--warning{background:rgba(245,159,0,.12);}
    .sf-ann--danger{background:rgba(214,57,57,.10);}
    .sf-ann--brand{background:rgba(98,105,242,.10);}

        /* p10d4u13g — Mobile navbar cleanup (offcanvas menu + layout rapi) */
    @media (max-width: 767.98px){
      /* Hide topstrip on mobile (biar header nggak kepanjangan & lebih rapi) */
      .sf-topstrip{display:none !important}
  /* When the mobile search/actions panel opens, add a tiny top padding so the first row isn't visually clipped */
  .sf-header-sticky.mobile-open{padding-top:8px;}

      /* u16r — Tokopedia-like compact sticky search on scroll (mobile only) */
      .sf-header-sticky.is-scrolled .sf-topbar{padding-top:.35rem !important;padding-bottom:.35rem !important}
      .sf-header-sticky.is-scrolled .sf-searchbar--mobile .input-group-text{padding:.38rem .6rem !important}
      .sf-header-sticky.is-scrolled .sf-searchbar--mobile .form-control{padding:.38rem .6rem !important;font-size:.88rem !important}
      .sf-header-sticky.is-scrolled .sf-searchbtn{padding:.38rem .7rem !important}
      .sf-header-sticky.is-scrolled .sf-topbar .sf-actions .sf-nav-icon{width:36px;height:36px}
      .sf-header-sticky.is-scrolled .sf-topbar .sf-actions .sf-nav-icon i{font-size:17px}

      /* u16u — hide search on scroll, keep quick search icon */
      .sf-m-searchbtn{display:none}
      .sf-header-sticky.sf-hide-m-search-on-scroll.is-scrolled:not(.sf-m-search-open) .sf-searchbar--mobile{display:none !important}
      .sf-header-sticky.sf-hide-m-search-on-scroll.is-scrolled:not(.sf-m-search-open) .sf-m-searchbtn{display:inline-flex !important}
      .sf-header-sticky.is-scrolled:not(.sf-m-search-open) .sf-topbar{padding-top:.28rem !important;padding-bottom:.28rem !important}
      .sf-header-sticky.is-scrolled:not(.sf-m-search-open) .sf-topbar .navbar-brand img{height:26px}
      .sf-header-sticky.sf-m-search-open .sf-m-searchbtn{display:none !important}
      .sf-header-sticky.sf-m-search-open .sf-searchbar--mobile{display:block !important}


      .sf-topbar .container-fluid{flex-wrap:wrap; gap:.5rem}
      .sf-topbar .navbar-brand{gap:.45rem}
      .sf-topbar .navbar-brand img{height:28px}
      .sf-topbar .navbar-brand span{display:none}

      .sf-topbar .sf-actions{gap:.35rem; flex-wrap:nowrap}
      .sf-topbar .sf-actions .sf-nav-icon{width:38px;height:38px}
      .sf-topbar .sf-actions .sf-nav-icon{display:inline-flex; align-items:center; justify-content:center; padding:0}
      .sf-topbar .sf-actions .sf-nav-icon i{font-size:18px; display:block; line-height:1}
      .sf-topbar .sf-actions .btn.btn-sm{border-radius:12px}

	      /* Mobile panel (search + CTA) — default compact, open via toggle */
	      .sf-mobile-panel{order:99; display:none}
	      .sf-header-sticky.mobile-open .sf-mobile-panel{display:block}
	      .sf-mobile-panel .sf-searchbar{padding-bottom:2px}
	      .sf-mobile-panel .input-group .input-group-text{border-radius:14px 0 0 14px}
	      .sf-mobile-panel .input-group .form-control{border-radius:0 14px 14px 0}
	      .sf-mobile-panel .input-group .form-control{padding-top:.55rem;padding-bottom:.55rem}
	      .sf-mobile-cta{flex-wrap:nowrap}
	      .sf-mobile-cta .btn{height:40px;border-radius:14px;white-space:nowrap}
	      .sf-mobile-cta .btn i{margin-right:6px}

	      /* Toggle (always visible on mobile) */
	      .sf-mobile-toggle{display:inline-flex !important}
	      .sf-header-sticky.mobile-open .sf-mobile-toggle{background:rgba(13,110,253,.08);border-color:rgba(13,110,253,.18)}

      /* Offcanvas menu (mobile) */
      #sfMobileMenu.sf-mobile-menu{width:86vw;max-width:340px;border-top-right-radius:18px;border-bottom-right-radius:18px}
      #sfMobileMenu.sf-mobile-menu .offcanvas-header{padding:.9rem 1rem;border-bottom:1px solid rgba(0,0,0,.06)}
      #sfMobileMenu.sf-mobile-menu .offcanvas-body{padding:.9rem 1rem 1rem}
      #sfMobileMenu.sf-mobile-menu .list-group-item{border:0;border-radius:12px;padding:.7rem .75rem;margin-bottom:.25rem}
      #sfMobileMenu.sf-mobile-menu .list-group-item i{width:20px}
      #sfMobileMenu.sf-mobile-menu .btn{border-radius:12px}

      /* Ensure menu overlay is above sticky header */
      .sf-mobile-menu{z-index:2600}
      .offcanvas-backdrop.show{z-index:2590}

      /* dropdown notif/chat jangan maksa min-width 340px di layar kecil */
      .sf-dd-menu{min-width:0 !important;width:92vw !important}
    }


  
      /* Mobile sticky bottom summary bar (marketplace style) */
      .sf-bottombar{
        position:fixed;left:0;right:0;bottom:0;
        z-index:2500;
        background:rgba(255,255,255,.98);
        backdrop-filter:saturate(180%) blur(10px);
        border-top:1px solid rgba(0,0,0,.08);
        padding:.75rem .75rem calc(.75rem + env(safe-area-inset-bottom));
        box-shadow:0 -0.75rem 1.5rem rgba(0,0,0,.08);
      }
      .sf-bottombar .sf-bottombar-inner{
        max-width:1140px;
        margin:0 auto;
        display:flex;
        align-items:center;
        justify-content:space-between;
        gap:.75rem;
      }
      .sf-bottombar .sf-bottombar-total{min-width:0}
      .sf-bottombar .sf-bottombar-total .lbl{font-size:.78rem;opacity:.7;font-weight:700}
      .sf-bottombar .sf-bottombar-total .val{font-size:1.05rem;font-weight:900;line-height:1.1;white-space:nowrap}
      .sf-bottombar .sf-bottombar-total .sub{font-size:.78rem;opacity:.7}
      .sf-bottombar .sf-bottombar-actions{display:flex;align-items:center;gap:.5rem;flex:0 0 auto}
      .sf-bottombar .btn{border-radius:14px;font-weight:900}
      .sf-bottombar .btn-outline-secondary{border-color:rgba(0,0,0,.12)}
      @media (max-width: 991.98px){
        .store-checkout .page-content{padding-bottom:106px;}
      }



    /* u16h — toast + submit loading */

    /* u16k — SweetAlert2 center toast (Shopee style) */
    .sf-swal-toast.swal2-popup{width:min(460px, calc(100vw - 24px)) !important;border-radius:18px !important;box-shadow:0 20px 60px rgba(0,0,0,.22) !important;}
    .sf-swal-toast .swal2-title{margin:0 !important;font-size:.98rem !important;font-weight:800 !important;line-height:1.2 !important;}
    .sf-swal-toast .swal2-icon{margin:0 .6rem 0 0 !important;}
    .sf-swal-container{backdrop-filter: blur(1px);} 


    .sf-toast{position:fixed;left:50%;bottom:16px;transform:translate(-50%, 18px);opacity:0;pointer-events:none;z-index:1080;
      min-width:min(520px, calc(100vw - 24px));max-width:min(520px, calc(100vw - 24px));
      border-radius:999px;padding:10px 12px;display:flex;align-items:center;gap:10px;
      box-shadow:0 18px 42px rgba(0,0,0,.18);border:1px solid rgba(0,0,0,.06);
      backdrop-filter:saturate(140%) blur(6px);background:rgba(255,255,255,.92);
      transition:transform .18s ease, opacity .18s ease;}
    .sf-toast.is-show{transform:translate(-50%, 0);opacity:1;pointer-events:auto}
    .sf-toast-body{font-weight:700;font-size:.95rem;line-height:1.2;flex:1 1 auto;}
    .sf-toast-close{border:0;background:transparent;font-size:1.2rem;line-height:1;color:rgba(0,0,0,.55);padding:0 6px;}
    .sf-toast--success{border-color:rgba(40,167,69,.18)}
    .sf-toast--warning{border-color:rgba(255,193,7,.22)}
    .sf-toast--danger{border-color:rgba(220,53,69,.22)}
    .sf-toast--info{border-color:rgba(13,202,240,.22)}
    @media (min-width: 768px){
      .sf-toast{left:auto;right:16px;bottom:auto;top:16px;transform:translateY(-12px);min-width:360px;max-width:420px;border-radius:18px;}
      .sf-toast.is-show{transform:translateY(0)}
    }

    .sf-loading-overlay{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:1090;
      background:rgba(0,0,0,.22);backdrop-filter:blur(2px);padding:16px;}
    .sf-loading-overlay.is-show{display:flex}
    .sf-loading-card{background:#fff;border-radius:18px;box-shadow:0 22px 56px rgba(0,0,0,.22);
      width:min(520px, 92vw);padding:16px 16px 14px;border:1px solid rgba(0,0,0,.06)}
    .sf-loading-title{font-weight:800;letter-spacing:-.01em;margin:0 0 2px}
    .sf-loading-sub{font-size:.9rem;color:rgba(0,0,0,.55);margin:0 0 10px}
    .sf-skel{height:10px;border-radius:999px;background:rgba(0,0,0,.08);overflow:hidden;position:relative}
    .sf-skel:before{content:'';position:absolute;inset:0;transform:translateX(-60%);
      background:linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent);
      animation:sfShimmer 1.1s infinite}
    .sf-skel.sm{height:8px;opacity:.85}


    /* u16p — Mobile shell: compact topbar + bottom nav (desktop untouched) */
    /* Safety: prevent accidental horizontal scroll from fixed elements */
    html{overflow-x:hidden}
    body.storefront{overflow-x:hidden}
    .sf-searchbar--mobile{max-width:100%;min-width:0}
    .sf-searchbar--mobile .input-group{border-radius:14px; overflow:hidden}
    .sf-searchbar--mobile .input-group-text{border-radius:14px 0 0 14px; padding:.45rem .65rem}
    .sf-searchbar--mobile .form-control{border-radius:0 14px 14px 0; padding:.45rem .65rem; font-size:.9rem; min-width:0}
    .sf-searchbar--mobile .form-control::placeholder{opacity:.7}
    .sf-searchbtn{font-weight:800;font-size:.85rem;padding:.45rem .85rem;background:rgba(0,0,0,.03);border:0;white-space:nowrap;border-left:1px solid rgba(0,0,0,.06)}

    .sf-mnav{display:none}
    .sf-mnav-item{
      flex:1;
      display:flex;
      flex-direction:column;
      align-items:center;
      justify-content:center;
      gap:.15rem;
      padding:.48rem .25rem .38rem;
      text-decoration:none;
      color:inherit;
      font-size:.72rem;
      font-weight:800;
      background:transparent;
      border:0;
      cursor:pointer;
    }
    .sf-mnav-item span{display:block; line-height:1.05; margin-top:1px}
    .sf-mnav-item i{font-size:20px; line-height:1; transition:transform .12s ease}
    .sf-mnav-item:active i{transform:translateY(-1px) scale(.94)}
    .sf-mnav-item.is-active{color:rgba(var(--brand-accent-rgb),1)}
    .sf-mnav-item.is-active i{transform:translateY(-1px)}
    .sf-mnav-icon-wrap{
      position:relative;
      width:24px;
      height:24px;
      display:flex;
      align-items:center;
      justify-content:center;
    }
    .sf-mnav-badge{
      position:absolute;
      top:-6px;
      right:-10px;
      min-width:14px;
      height:14px;
      padding:0 3px;
      border-radius:999px;
      background:#d63939;
      color:#fff;
      font-size:.55rem;
      font-weight:700;
      display:inline-flex;
      align-items:center;
      justify-content:center;
      line-height:14px;
      padding-top:0;
      transform:translateY(1px);
      box-shadow:0 10px 20px rgba(0,0,0,.18);
    }
    .sf-mnav-badge-text{display:block;transform:translateY(1px)}

    @media (max-width: 991.98px){
      body.storefront:not(.store-checkout){padding-bottom:calc(64px + env(safe-area-inset-bottom));}
      .sf-mnav{
        display:flex;
        position:fixed;
        left:0; right:0; bottom:0;
        z-index:2400;
        background:rgba(255,255,255,.98);
        backdrop-filter:saturate(180%) blur(10px);
        border-top:1px solid rgba(0,0,0,.08);
        padding:.35rem .25rem calc(.35rem + env(safe-area-inset-bottom));
      }
    }

    /* u16w4d — Stronger alignment for mobile topbar icons + bottom nav labels (desktop untouched) */
    @media (max-width: 991.98px){
      /* Topbar icon buttons: true center for Bootstrap Icons */
      .sf-topbar .sf-actions .sf-nav-icon{display:inline-flex;align-items:center;justify-content:center;padding:0}
      .sf-topbar .sf-actions .sf-nav-icon i{display:flex;align-items:center;justify-content:center;width:100%;height:100%;line-height:0}
      .sf-topbar .sf-actions .sf-nav-icon i.bi{vertical-align:0}

      /* Bottom nav: consistent vertical rhythm between icon + label */
      .sf-mnav{padding:.42rem .5rem calc(.45rem + env(safe-area-inset-bottom));}
      .sf-mnav-item{height:52px;padding:0;gap:3px;font-size:11px;}
      .sf-mnav-item i{display:flex;align-items:center;justify-content:center;width:24px;height:24px;line-height:0}
      .sf-mnav-item i.bi{vertical-align:0}
      .sf-mnav-item span{margin:0;line-height:1;transform:translateY(1px)}
    }

    /* u16v1b — Fix blocked taps: offcanvas sheets must be above sticky header + bottom nav */
    @media (max-width: 991.98px){
      .offcanvas{z-index:2600;}
      .offcanvas-backdrop{z-index:2590;}
    }

    @media (max-width: 767.98px){
      /* Keep the new mobile topbar in a single row (Tokopedia-ish) */
      .sf-topbar .container-fluid{flex-wrap:nowrap !important}
    }
