/* ============================================================
   assets/css/responsive.css
   MPAY - Mobile Responsive Overrides
   Breakpoints:
     xs  : < 480px   (HP kecil)
     sm  : < 640px   (HP)
     md  : < 768px   (Tablet portrait)
     lg  : < 1024px  (Tablet landscape)
   ============================================================ */

/* ── RESET BASE MOBILE ────────────────────────────────────── */
*{-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%}
img{max-width:100%;height:auto}
table{border-collapse:collapse;width:100%}

/* ============================================================
   NAVBAR MOBILE
   ============================================================ */
@media(max-width:768px){
  .navbar-inner{padding:10px 16px;gap:10px;flex-wrap:nowrap}
  .logo-text small{display:none}
  .logo-text{font-size:16px}
  .logo-icon{width:34px;height:34px;font-size:16px}

  /* Sembunyikan search bar di mobile — ganti dengan icon */
  .search-bar{display:none}

  /* Nav actions compact */
  .nav-actions{gap:6px}
  .nav-btn{padding:7px 10px;font-size:12px}
  .nav-btn span:not(.cart-badge){display:none} /* sembunyikan label teks */

  /* Hamburger toggle untuk dropdown */
  .nav-dropdown .dropdown-menu{right:-8px;min-width:180px}
}

@media(max-width:480px){
  .navbar-inner{padding:8px 12px}
  /* Sembunyikan tombol Daftar di HP kecil */
  .nav-btn.primary:not(:last-child){display:none}
}

/* ── MOBILE SEARCH BAR (muncul di bawah navbar) ── */
.mobile-search{display:none}
@media(max-width:768px){
  .mobile-search{
    display:flex;align-items:center;
    background:white;border-bottom:1px solid var(--gray-200);
    padding:8px 16px;gap:8px;
  }
  .mobile-search form{display:flex;flex:1;background:var(--gray-100);border-radius:8px;overflow:hidden}
  .mobile-search input{flex:1;border:none;background:transparent;padding:9px 12px;font-size:14px;outline:none}
  .mobile-search button{padding:8px 14px;background:var(--green-500);border:none;color:white;cursor:pointer}
}

/* ============================================================
   FLASH MESSAGES
   ============================================================ */
@media(max-width:768px){
  .flash-alert{margin:8px 12px 0;border-radius:8px;font-size:13px}
}

/* ============================================================
   TAGLINE STRIP
   ============================================================ */
@media(max-width:480px){
  .tagline-strip{display:none}
}

/* ============================================================
   HERO SECTION
   ============================================================ */
@media(max-width:1024px){
  .hero h1{font-size:32px}
}
@media(max-width:768px){
  .hero{padding:0 16px}
  .hero-inner{flex-direction:column;padding:28px 0 24px;gap:20px;text-align:center}
  .hero h1{font-size:24px;margin-bottom:10px}
  .hero-badge{margin-bottom:10px}
  .hero p{font-size:13px}
  .hero-btns{justify-content:center;gap:10px}
  .hero-btn{padding:11px 20px;font-size:13px}
  .hero-visual{width:100%;padding:16px}
  .hero-balance{font-size:22px}
  .hero-chips{justify-content:center}
}
@media(max-width:480px){
  .hero h1{font-size:20px}
  .hero-btns{flex-direction:column;gap:8px}
  .hero-btn{width:100%;text-align:center}
}

/* ============================================================
   KATEGORI GRID
   ============================================================ */
@media(max-width:1024px){.cat-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:640px) {.cat-grid{grid-template-columns:repeat(3,1fr);gap:10px}}
@media(max-width:380px) {.cat-grid{grid-template-columns:repeat(2,1fr)}}

@media(max-width:640px){
  .cat-card{padding:14px 8px}
  .cat-icon{width:44px;height:44px;font-size:20px}
  .cat-name{font-size:11px}
}

/* ============================================================
   PROMO BANNER
   ============================================================ */
@media(max-width:768px){
  .promo-grid{grid-template-columns:1fr;gap:10px}
  .promo-card{min-height:110px}
  .promo-card h3{font-size:16px}
}

/* ============================================================
   PRODUK GRID
   ============================================================ */
@media(max-width:1024px){.produk-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px) {.produk-grid,.produk-grid-full{grid-template-columns:repeat(2,1fr);gap:10px}}
@media(max-width:380px) {.produk-grid,.produk-grid-full{grid-template-columns:1fr}}

@media(max-width:640px){
  .produk-img{height:90px;font-size:36px}
  .produk-body{padding:10px}
  .produk-name{font-size:12px}
  .produk-price{font-size:14px}
  .add-cart-btn{padding:6px 10px;font-size:11px}
}

/* ============================================================
   KEUNGGULAN
   ============================================================ */
@media(max-width:768px){.keunggulan-grid{grid-template-columns:repeat(2,1fr);gap:12px}}
@media(max-width:480px){.keunggulan-grid{grid-template-columns:1fr}}

/* ============================================================
   SECTIONS
   ============================================================ */
@media(max-width:768px){
  .section{padding:20px 16px}
  .section-title{font-size:18px}
}

/* ============================================================
   PAGE HEADER
   ============================================================ */
@media(max-width:768px){
  .page-header{padding:16px}
  .page-header h1{font-size:20px}
  .page-header p{font-size:12px}
}

/* ============================================================
   PRODUK PAGE LAYOUT (dengan sidebar)
   ============================================================ */
@media(max-width:900px){
  .produk-page-layout{grid-template-columns:1fr;padding:16px}
  .sidebar{display:none} /* Sidebar disembunyikan, ganti ke filter bar */
  .produk-main{min-width:0}
}

/* ============================================================
   FILTER TOP BAR (ftb)
   ============================================================ */
@media(max-width:768px){
  .ftb{top:58px}
  .ftb-inner{
    padding:8px 12px;
    gap:8px;
    flex-wrap:wrap;
  }
  .ftb-search{max-width:100%;flex:1;min-width:0}
  .ftb-sort{flex-wrap:wrap;gap:6px}
  .ftb-sort-label{display:none}
  .ftb-sort-chips{gap:4px}
  .ftb-chip{padding:5px 10px;font-size:11px}
  .ftb-cats{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}
  .ftb-cat{font-size:11px;padding:5px 10px}

  /* Dropdown di mobile: full-width, arah ke bawah */
  .ftb-dropdown-menu{
    left:0;right:0;min-width:100%;max-width:100%;
    position:fixed;top:auto;bottom:0;
    border-radius:16px 16px 0 0;
    max-height:70vh;overflow-y:auto;
    box-shadow:0 -4px 24px rgba(0,0,0,0.15);
  }
  .ftb-dd-list{max-height:45vh}
  .ftb-dropdown-wrap{position:static}
}

@media(max-width:480px){
  .produk-grid-full{grid-template-columns:repeat(2,1fr);gap:10px}
  .ftb-active-tags{padding:6px 12px}
}

/* ============================================================
   CART
   ============================================================ */
@media(max-width:768px){
  .cart-layout{
    grid-template-columns:1fr;
    padding:16px;
    gap:16px;
  }
  .cart-summary{position:static;border-radius:var(--radius-md)}
  .cart-item{flex-wrap:wrap;gap:10px;padding:14px 12px}
  .cart-item-icon{width:50px;height:50px;font-size:28px}
}

/* ============================================================
   CHECKOUT
   ============================================================ */
@media(max-width:900px){
  .checkout-layout{grid-template-columns:1fr;padding:16px;gap:16px}
  /* Summary naik ke atas di mobile */
  .checkout-layout > div:last-child{order:-1}
  .cart-summary{position:static}
}
@media(max-width:480px){
  .checkout-card{padding:14px}
  .pay-method{padding:10px 12px;gap:8px}
  .pay-method-name{font-size:12px}
  .pay-method-desc{font-size:11px}
}

/* ============================================================
   PEMBAYARAN
   ============================================================ */
@media(max-width:640px){
  .pembayaran-wrap{padding:0 12px;margin:20px auto}
  .pay-amount{font-size:26px}
  .va-number{font-size:18px;letter-spacing:1px}
  .pay-card-header{padding:20px 16px}
  .pay-card-body{padding:16px}
}

/* ============================================================
   RESULT (SUCCESS/FAILED)
   ============================================================ */
@media(max-width:640px){
  .result-wrap{padding:0 12px;margin:30px auto}
  .result-card{padding:24px 16px}
  .result-title{font-size:20px}
}

/* ============================================================
   AUTH (LOGIN/REGISTER)
   ============================================================ */
@media(max-width:768px){
  .auth-wrap{grid-template-columns:1fr;min-height:100vh}
  .auth-left{display:none}
  .auth-right{padding:24px 16px;align-items:flex-start}
  .auth-form-wrap{max-width:100%;padding-top:20px}
  .auth-title{font-size:22px}
}

/* ============================================================
   PROFILE
   ============================================================ */
@media(max-width:768px){
  .profile-layout{grid-template-columns:1fr;padding:16px;gap:16px}
  .profile-sidebar{padding:16px}
  .profile-avatar{width:56px;height:56px;font-size:22px}
  .profile-content{padding:16px}
  /* Stats mini: 3 kolom jadi 3 kolom tapi lebih compact */
}
@media(max-width:480px){
  /* Stats mini: 2 kolom */
  .profile-content > div[style*="grid-template-columns:repeat(3,1fr)"]{
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
  }
}

/* ============================================================
   CONTACT
   ============================================================ */
@media(max-width:768px){
  .contact-layout{grid-template-columns:1fr;padding:20px 16px;gap:20px}
}

/* ============================================================
   CARA PEMBAYARAN
   ============================================================ */
@media(max-width:768px){
  .cara-layout{padding:20px 16px}
  .cara-tabs{flex-wrap:wrap;gap:8px}
  .cara-tab{font-size:12px;padding:8px 14px}
}

/* ============================================================
   MODAL
   ============================================================ */
@media(max-width:640px){
  .modal-overlay{padding:0;align-items:flex-end}
  .modal-box{
    border-radius:16px 16px 0 0;
    max-width:100%;
    width:100%;
    margin-bottom:0;
  }
  .modal-header,.modal-body,.modal-footer{padding:16px}
}

/* ============================================================
   FOOTER
   ============================================================ */
@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:20px}
  footer{padding:30px 16px 16px}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr;gap:16px}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center}
  .payment-icons{flex-wrap:wrap;justify-content:center}
}

/* ============================================================
   PAGINATION
   ============================================================ */
@media(max-width:480px){
  .pagination{gap:4px;flex-wrap:wrap;justify-content:center}
  .page-btn{padding:6px 10px;font-size:12px}
}

/* ============================================================
   FORMS
   ============================================================ */
@media(max-width:640px){
  .form-row{grid-template-columns:1fr}
  .form-input{font-size:16px} /* Prevent zoom on iOS */
}

/* ============================================================
   ARTICLE PAGES
   ============================================================ */
@media(max-width:900px){
  .article-detail-layout{grid-template-columns:1fr;padding:20px 16px;gap:24px}
  .article-sidebar{order:-1} /* CTA naik ke atas */
  .sidebar-card{position:static;display:none} /* Sembunyikan kategori sidebar */
}
@media(max-width:768px){
  .article-page-hero{padding:32px 16px}
  .article-hero-inner h1{font-size:24px}
  .articles-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .featured-grid{grid-template-columns:1fr}
  .featured-main .featured-img{height:220px}
  .article-cat-bar{padding:10px 16px}
  .article-page-layout{padding:20px 16px}
}
@media(max-width:480px){
  .articles-grid{grid-template-columns:1fr}
  .article-title{font-size:22px}
  .article-content{font-size:14px}
  .article-share-btns{grid-template-columns:1fr 1fr;display:grid;gap:8px}
  .share-btn{text-align:center}
  .article-hero-inner h1{font-size:20px}
}

/* ============================================================
   PRODUK DETAIL
   ============================================================ */
@media(max-width:768px){
  .detail-layout{grid-template-columns:1fr;padding:16px;gap:16px}
  .detail-order-card{position:static}
  .detail-img-wrap{height:180px}
  .detail-name{font-size:18px}
  .detail-price{font-size:26px}
}

/* ============================================================
   EMPTY STATE
   ============================================================ */
@media(max-width:480px){
  .empty-state{padding:30px 16px}
  .empty-state h3{font-size:16px}
}

/* ============================================================
   TOAST
   ============================================================ */
@media(max-width:480px){
  #mpayToast{
    left:12px;right:12px;bottom:16px;
    transform:none;
    width:calc(100% - 24px);
    text-align:center;
    justify-content:center;
  }
}

/* ============================================================
   UTILS MOBILE
   ============================================================ */
@media(max-width:768px){
  .hide-mobile{display:none!important}
  .show-mobile{display:block!important}
}
@media(min-width:769px){
  .show-mobile{display:none!important}
}

/* Mencegah horizontal scroll global */
body{overflow-x:hidden}
/* JANGAN tambahkan overflow ke .navbar - akan memotong dropdown absolut */
.ftb{overflow-x:hidden}
.article-cat-bar{overflow-x:hidden}