:root{
  --primary:#00AA5B; --primary-dark:#008548; --primary-light:#e8f7ef;
  --primary-grad:linear-gradient(120deg,#00AA5B 0%,#22c47a 100%);
  --ink:#12161c; --muted:#6b7280; --line:#e9ecf1; --bg:#f4f6f8; --card:#fff;
  --green:#26aa56; --radius:18px; --radius-sm:12px; --radius-lg:24px;
  --shadow:0 12px 40px rgba(18,22,28,.10); --shadow-sm:0 2px 10px rgba(18,22,28,.06);
  --ring:0 0 0 3px rgba(0,170,91,.18);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:'Plus Jakarta Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--bg);line-height:1.55}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 16px}
.muted{color:var(--muted)}
.small{font-size:13px}
.link{color:var(--primary);font-weight:600}
.hot{color:var(--primary)}

/* ===== Top bar ===== */
.topbar{position:sticky;top:0;z-index:50;background:var(--primary-grad);box-shadow:var(--shadow-sm)}
.topbar-inner{display:flex;align-items:center;gap:16px;padding:12px 16px}
.brand{display:flex;align-items:center;gap:8px;color:#fff;font-weight:800;font-size:20px;white-space:nowrap}
.brand-logo{font-size:24px}
.searchbar{flex:1;display:flex;background:#fff;border-radius:10px;overflow:hidden;max-width:640px}
.searchbar input{flex:1;border:0;padding:11px 14px;font-size:15px;outline:none;font-family:inherit}
.searchbar button{border:0;background:var(--primary-dark);color:#fff;padding:0 18px;font-size:17px;cursor:pointer}
.topnav{display:flex;align-items:center;gap:8px}
.nav-btn{color:#fff;padding:8px 14px;border-radius:9px;font-weight:600;font-size:14px;transition:.15s;white-space:nowrap}
.nav-btn:hover{background:rgba(255,255,255,.18)}
.nav-btn.primary{background:#fff;color:var(--primary)}
.user-menu{position:relative}
.dropdown{position:absolute;right:0;top:115%;background:#fff;border-radius:12px;box-shadow:var(--shadow);min-width:200px;padding:8px;display:none;z-index:60}
.dropdown.open{display:block}
.dropdown-head{padding:10px 12px;border-bottom:1px solid var(--line);font-weight:700;font-size:14px;margin-bottom:6px}
.dropdown a{display:block;padding:9px 12px;border-radius:8px;font-size:14px;color:var(--ink)}
.dropdown a:hover{background:var(--bg)}
.dropdown a.danger{color:var(--primary)}
.catbar{background:rgba(255,255,255,.12);backdrop-filter:blur(4px)}
.catbar-inner{display:flex;gap:8px;overflow-x:auto;padding:9px 16px;scrollbar-width:none}
.catbar-inner::-webkit-scrollbar{display:none}
.chip{background:rgba(255,255,255,.92);color:var(--ink);padding:6px 13px;border-radius:20px;font-size:13px;font-weight:600;white-space:nowrap;transition:.15s}
.chip:hover{background:#fff;transform:translateY(-1px)}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:0;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:.15s;text-align:center}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--primary-grad);color:#fff;box-shadow:0 4px 14px rgba(0,170,91,.32)}
.btn-ghost{background:#fff;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}
.btn-buy{background:linear-gradient(90deg,#25D366,#128C7E);color:#fff;box-shadow:0 4px 14px rgba(37,211,102,.32)}
.btn-danger{background:#fee2e2;color:#b91c1c}
.btn-block{width:100%}
.btn-lg{padding:13px 24px;font-size:15px}
.btn-sm{padding:8px 14px;font-size:13px}
.btn-xs{padding:5px 9px;font-size:12px;border-radius:8px}

/* ===== Hero ===== */
.hero{background:var(--primary-grad);color:#fff;margin-bottom:8px}
.hero-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:42px 16px}
.hero-text h1{font-size:clamp(26px,4vw,42px);margin:0 0 12px;line-height:1.15;font-weight:800}
.hero-text h1 span{background:#fff;color:var(--primary);padding:0 8px;border-radius:8px}
.hero-text p{font-size:16px;opacity:.95;max-width:480px;margin:0 0 22px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-art{font-size:96px;filter:drop-shadow(0 8px 20px rgba(0,0,0,.2))}

/* ===== Sections ===== */
.page{padding-bottom:80px}
.section-title{font-size:20px;font-weight:800;margin:26px 0 14px}
.section-head{display:flex;align-items:center;justify-content:space-between;margin:26px 0 14px;gap:12px;flex-wrap:wrap}
.section-head .section-title{margin:0}

/* Categories */
.cat-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:10px}
.cat-tile{background:var(--card);border-radius:var(--radius);padding:18px 8px;text-align:center;font-size:13px;font-weight:600;box-shadow:var(--shadow-sm);transition:.15s;display:flex;flex-direction:column;gap:8px;align-items:center}
.cat-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.cat-ico{font-size:30px}

/* Product grid */
.product-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.pcard{background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.18s;display:flex;flex-direction:column;border:1px solid transparent}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#b6e3c9}
.pcard-img{position:relative;aspect-ratio:1;background:#f3f4f6;overflow:hidden}
.pcard-img img{width:100%;height:100%;object-fit:cover}
.disc-tag{position:absolute;top:0;right:0;background:#ffeb3b;color:var(--primary-dark);font-weight:800;font-size:12px;padding:3px 7px;border-bottom-left-radius:8px}
.pcard-body{padding:9px 11px 12px;display:flex;flex-direction:column;gap:5px}
.pcard-title{font-size:13.5px;line-height:1.35;height:2.7em;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.pcard-price{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}
.price{color:var(--primary);font-weight:800;font-size:16px}
.price-old{color:var(--muted);text-decoration:line-through;font-size:12px}
.pcard-meta{display:flex;justify-content:space-between;font-size:11.5px;color:var(--muted);gap:6px}
.pcard-meta span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Breadcrumb */
.breadcrumb{font-size:13px;color:var(--muted);padding:16px 0;display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.breadcrumb a{color:var(--primary)}

/* Product detail */
.product-detail{display:grid;grid-template-columns:420px 1fr;gap:28px;background:var(--card);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm)}
.pd-gallery img{width:100%;border-radius:12px;aspect-ratio:1;object-fit:cover;background:#f3f4f6}
.pd-info h1{font-size:24px;margin:0 0 12px;font-weight:800}
.pd-stats{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--muted);padding-bottom:14px;border-bottom:1px solid var(--line)}
.pd-price-box{display:flex;align-items:center;gap:12px;background:#e8f7ef;border-radius:12px;padding:16px;margin:16px 0}
.pd-price{color:var(--primary);font-size:32px;font-weight:800}
.store-row{display:flex;align-items:center;gap:12px;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:16px}
.store-ava,.store-hero-ava{width:48px;height:48px;border-radius:50%;object-fit:cover;background:#f3f4f6}
.store-name{font-weight:700}
.pd-actions{display:flex;gap:12px}
.pd-actions .btn{flex:1}
.pd-desc{margin:22px 0}
.pd-desc h3{margin-top:0}

/* Reviews */
.review-item{padding:12px 0;border-top:1px solid var(--line)}
.review-item:first-child{border-top:0}
.review-head{display:flex;gap:10px;align-items:baseline;justify-content:space-between;flex-wrap:wrap}
.review-stars{margin:6px 0 2px;font-size:14px}
.review-comment{color:var(--ink);font-size:14px}

/* Cards / tables */
.card{background:var(--card);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);margin-bottom:18px}
.card h3{margin:0 0 14px;font-size:16px}
.table-wrap{overflow-x:auto}
.table{width:100%;border-collapse:collapse;font-size:13.5px}
.table th{text-align:left;color:var(--muted);font-weight:600;padding:10px 12px;border-bottom:2px solid var(--line);white-space:nowrap}
.table td{padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
.table tr:hover td{background:#fafbfc}
.cell-prod{display:flex;align-items:center;gap:10px;min-width:200px}
.cell-prod img{width:40px;height:40px;border-radius:8px;object-fit:cover;background:#f3f4f6}
.actions{display:flex;gap:6px;white-space:nowrap}

/* Badges */
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:11.5px;font-weight:700}
.badge-red{background:#fee2e2;color:#b91c1c}.badge-purple{background:#ede9fe;color:#6d28d9}
.badge-orange{background:#e8f7ef;color:#008548}.badge-blue{background:#e0f2fe;color:#0369a1}
.badge-green{background:#dcfce7;color:#15803d}.badge-gray{background:#eceef1;color:#64748b}

/* Alerts */
.alert{padding:13px 16px;border-radius:11px;margin:16px 0;font-size:14px;font-weight:600}
.alert-success{background:#dcfce7;color:#15803d}
.alert-error{background:#fee2e2;color:#b91c1c}

/* Forms */
.form label{display:block;font-size:13.5px;font-weight:600;margin:12px 0 5px}
.form input,.form select,.form textarea{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:11px 13px;font-size:14.5px;font-family:inherit;outline:none;transition:.15s;background:#fff}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,170,91,.12)}
.form-grid{display:grid;grid-template-columns:1fr 280px;gap:24px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-actions{display:flex;gap:12px;margin-top:18px}
.form-card{max-width:900px}
.img-upload img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:12px;background:#f3f4f6;margin-bottom:10px;border:1px solid var(--line)}

/* Auth */
.auth-wrap{display:flex;justify-content:center;padding:40px 16px}
.auth-card{background:var(--card);border-radius:18px;padding:32px;box-shadow:var(--shadow);width:100%;max-width:440px}
.auth-card h1{margin:0 0 6px;font-size:26px}
.auth-alt{text-align:center;margin-top:18px;font-size:14px}
.auth-alt a{color:var(--primary);font-weight:700}
.demo-box{margin-top:20px;background:#e8f7ef;border:1px dashed #95d8b3;border-radius:12px;padding:14px;font-size:12.5px;display:flex;flex-direction:column;gap:4px;color:var(--muted)}
.demo-box b{color:var(--ink)}
.role-switch{display:flex;gap:10px;margin-bottom:8px}
.role-opt{flex:1;border:1.5px solid var(--line);border-radius:10px;padding:12px;text-align:center;font-weight:600;cursor:pointer;font-size:14px}
.role-opt input{width:auto;margin-right:5px}

/* Banner / store hero */
.page-banner{display:flex;align-items:center;gap:16px;background:var(--card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);margin:16px 0}
.big-ico{font-size:46px}
.page-banner h1{margin:0;font-size:24px}
.store-hero{display:flex;align-items:center;gap:18px;background:var(--primary-grad);color:#fff;border-radius:var(--radius);padding:24px;margin:16px 0;flex-wrap:wrap}
.store-hero-ava{width:72px;height:72px;border:3px solid #fff}
.store-hero-info{flex:1;min-width:200px}
.store-hero-info h1{margin:0 0 4px;font-size:24px}
.store-hero-info .muted{color:rgba(255,255,255,.9)}
.store-hero-stats{display:flex;gap:18px;margin-top:8px;font-size:14px}

.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.search-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-top:18px}
.search-head h1{font-size:22px;margin:0}
.sort-form{display:flex;align-items:center;gap:8px;font-size:13px}
.sort-form select{border:1.5px solid var(--line);border-radius:8px;padding:7px 10px;font-family:inherit}
.inline-search{display:flex;gap:8px}
.inline-search input{border:1.5px solid var(--line);border-radius:9px;padding:8px 12px;font-family:inherit;min-width:220px}

/* ===== Panel (dashboard) ===== */
.panel-body{background:var(--bg)}
.panel{display:flex;min-height:100vh}
.sidebar{width:248px;background:#fff;border-right:1px solid var(--line);padding:18px 14px;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;z-index:40;transition:.25s}
.sb-brand{display:flex;align-items:center;gap:8px;font-weight:800;font-size:19px;padding:6px 8px 16px;color:var(--primary)}
.sb-user{display:flex;align-items:center;gap:10px;background:var(--bg);border-radius:12px;padding:12px;margin-bottom:16px;font-size:13px}
.sb-ava{width:40px;height:40px;border-radius:50%;background:var(--primary-grad);display:flex;align-items:center;justify-content:center;font-size:20px}
.sb-nav{display:flex;flex-direction:column;gap:4px}
.sb-nav a{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:10px;font-weight:600;font-size:14px;color:var(--ink);transition:.12s}
.sb-nav a span{font-size:17px}
.sb-nav a:hover{background:var(--bg)}
.sb-nav a.active{background:#e8f7ef;color:var(--primary)}
.sb-nav a.danger{color:var(--primary)}
.panel-main{flex:1;margin-left:248px;display:flex;flex-direction:column;min-width:0}
.panel-top{display:flex;align-items:center;gap:14px;background:#fff;padding:14px 22px;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}
.panel-top h1{font-size:19px;margin:0;flex:1}
.hamburger{display:none;border:0;background:transparent;font-size:22px;cursor:pointer}
.panel-content{padding:22px;flex:1}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.quick-actions{display:flex;gap:12px;flex-wrap:wrap}
.mini-select{border:1px solid var(--line);border-radius:8px;padding:5px 8px;font-family:inherit;font-size:12.5px}

/* Stat cards */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:18px}
.stat-card{background:var(--card);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:14px}
.stat-ico{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff}
.stat-card.c1 .stat-ico{background:#00AA5B}.stat-card.c2 .stat-ico{background:#3b82f6}
.stat-card.c3 .stat-ico{background:#22c55e}.stat-card.c4 .stat-ico{background:#a855f7}
.stat-card.c5 .stat-ico{background:#f59e0b}.stat-card.c6 .stat-ico{background:#06b6d4}
.stat-num{font-size:24px;font-weight:800;line-height:1}
.stat-lbl{font-size:12.5px;color:var(--muted);margin-top:4px}

/* Modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;align-items:center;justify-content:center;z-index:100;padding:16px}
.modal.open{display:flex}
.modal-box{background:#fff;border-radius:16px;padding:24px;width:100%;max-width:420px}
.add-user summary{cursor:pointer;list-style:none}
.add-user summary::-webkit-details-marker{display:none}

/* Footer */
.sitefoot{background:#fff;border-top:1px solid var(--line);margin-top:40px;padding-top:34px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px;padding-bottom:24px}
.foot-grid h4{margin:0 0 12px;font-size:14px}
.foot-grid a{display:block;color:var(--muted);font-size:13.5px;padding:3px 0}
.foot-grid a:hover{color:var(--primary)}
.foot-bottom{border-top:1px solid var(--line);text-align:center;padding:16px;font-size:13px;color:var(--muted)}

/* Bottom nav (mobile) */
.bottomnav{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--line);z-index:45;justify-content:space-around;padding:6px 0 max(6px,env(safe-area-inset-bottom))}
.bottomnav a{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:11px;color:var(--muted);font-weight:600;padding:3px 12px}
.bottomnav a span{font-size:20px}
.bottomnav a:active{color:var(--primary)}

.pwa-install{position:fixed;right:16px;bottom:74px;z-index:48;background:var(--primary-grad);color:#fff;border:0;border-radius:30px;padding:12px 18px;font-weight:700;font-size:14px;box-shadow:0 6px 18px rgba(0,170,91,.4);cursor:pointer;font-family:inherit}

/* Toasts */
#toast-root{position:fixed;top:16px;left:50%;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:8px}
.toast{background:#1f2328;color:#fff;padding:11px 18px;border-radius:30px;font-size:14px;box-shadow:var(--shadow);animation:slideIn .3s}
@keyframes slideIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1}}

/* ===== Responsive ===== */
@media(max-width:1024px){
  .cat-grid{grid-template-columns:repeat(4,1fr)}
  .product-grid{grid-template-columns:repeat(4,1fr)}
  .product-detail{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .brand-name{display:none}
  .topnav .nav-btn{padding:8px 10px}
  .grid-2{grid-template-columns:1fr}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .cat-grid{grid-template-columns:repeat(4,1fr)}
  .hero-art{display:none}
  .foot-grid{grid-template-columns:1fr 1fr}
  .bottomnav{display:flex}
  .page{padding-bottom:80px}
  /* sidebar drawer */
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0);box-shadow:var(--shadow)}
  .panel-main{margin-left:0}
  .hamburger{display:block}
}
@media(max-width:480px){
  .product-grid{grid-template-columns:repeat(2,1fr);gap:9px}
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .pd-price{font-size:26px}
  .auth-card{padding:24px 20px}
}


/* =====================================================================
   2026 MODERN REFRESH — lapisan modernisasi (nama class dipertahankan)
   ===================================================================== */
html{scroll-behavior:smooth}
body{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
::selection{background:rgba(0,170,91,.18)}

/* Logo brand (gambar) */
.brand-img{height:30px;width:auto;max-width:160px;object-fit:contain;display:block;border-radius:6px;background:rgba(255,255,255,.0)}
.sitefoot .brand-img{height:28px}

/* Topbar kaca + lebih lembut */
.topbar{backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);box-shadow:0 4px 22px rgba(0,120,70,.16)}
.searchbar{border-radius:14px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.35)}
.searchbar input{padding:12px 16px}
.searchbar button{transition:.15s}
.searchbar button:hover{filter:brightness(1.08)}
.nav-btn{border-radius:12px}

/* Catbar chips: scroll mulus tanpa scrollbar di mobile */
.catbar-inner{overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}
.catbar-inner::-webkit-scrollbar{display:none}
.chip{border-radius:999px;transition:.15s}

/* Kartu & tombol lebih halus */
.btn{border-radius:14px;letter-spacing:.1px}
.btn:active{transform:translateY(0) scale(.98)}
.btn-primary{box-shadow:0 8px 22px rgba(0,170,91,.26)}
.btn-primary:hover{box-shadow:0 10px 28px rgba(0,170,91,.34)}

/* Kartu produk & kategori */
.pcard{border:1px solid #eef1f4}
.pcard:hover{transform:translateY(-6px)}
.pcard-img img{transition:transform .35s ease}
.pcard:hover .pcard-img img{transform:scale(1.05)}
.cat-tile{border:1px solid #eef1f4}
.disc-tag{border-radius:0 0 0 10px;background:linear-gradient(90deg,#ff5252,#ff1744);color:#fff}

/* Hero modern */
.hero{position:relative;overflow:hidden;border-radius:0 0 28px 28px}
.hero::after{content:"";position:absolute;right:-80px;top:-80px;width:300px;height:300px;background:radial-gradient(circle,rgba(255,255,255,.22),transparent 70%);pointer-events:none}
.section-title{letter-spacing:-.3px}

/* Panel dashboard */
.sidebar{border-right:0;box-shadow:1px 0 0 var(--line)}
.sb-nav a.active{box-shadow:inset 3px 0 0 var(--primary)}
.panel-top{backdrop-filter:blur(6px)}
.stat-card{transition:.18s}
.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}

/* Notifikasi grace KTP */
.ktp-note{display:flex;gap:10px;align-items:flex-start;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:14px;padding:14px 16px;margin:14px 0;font-size:14px;font-weight:600}
.ktp-note.urgent{background:#fef2f2;border-color:#fecaca;color:#b91c1c}
.ktp-note .ico{font-size:20px;line-height:1}

/* Aksesibilitas: focus ring */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none;box-shadow:var(--ring);border-radius:8px}

/* Bottom nav: pill mengambang ala 2026 */
@media(max-width:768px){
  .bottomnav{left:12px;right:12px;bottom:10px;border:1px solid var(--line);border-radius:22px;box-shadow:0 10px 30px rgba(18,22,28,.16);padding:8px 0 max(8px,env(safe-area-inset-bottom))}
  .bottomnav a.active{color:var(--primary)}
  .page{padding-bottom:98px}
  .pwa-install{bottom:98px}
  .btn{padding:12px 18px}
}
@media(max-width:480px){
  .nav-btn{padding:9px 12px}
}

/* Hormati preferensi gerakan minimal */
@media(prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important;scroll-behavior:auto!important}
}

/* ===================================================================
   LAUNCH VIRAL PACK (v21) — share, FOMO, live, referral, push
   =================================================================== */

/* Share buttons */
.share-row{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin:14px 0}
.share-row .share-lbl{font-size:13px;color:var(--muted);font-weight:600}
.share-btn{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;padding:7px 12px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--ink);cursor:pointer;text-decoration:none;transition:transform .12s ease,box-shadow .12s ease}
.share-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.share-btn.wa{background:#e8f7ef;border-color:#bdebd2;color:#0b7a43}
.share-btn.copy{background:var(--primary-light);border-color:#bdebd2;color:var(--primary-dark)}

/* FOMO / countdown */
.fomo-box{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:linear-gradient(120deg,#fff4f0,#ffe9ef);border:1px solid #ffd4c2;border-radius:var(--radius-sm);padding:10px 12px;margin:12px 0}
.fomo-box .fomo-ic{font-size:18px}
.fomo-box .fomo-lbl{font-size:13px;color:#b23a18;font-weight:700}
.countdown{font-variant-numeric:tabular-nums;font-weight:800;color:#e23a2e;background:#fff;border:1px solid #ffd4c2;border-radius:8px;padding:3px 10px;letter-spacing:.5px}
.countdown.ended{color:var(--muted)}
.fomo-badges{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0}
.fomo-chip{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;padding:3px 9px;border-radius:999px;background:var(--primary-light);color:var(--primary-dark)}
.fomo-chip.low{background:#fff1f0;color:#e23a2e}
.fomo-chip.sold{background:#fff7e6;color:#b97400}
.pcard-flags{position:absolute;left:8px;top:8px;display:flex;flex-direction:column;gap:4px;z-index:2}
.pcard-flags .flag{font-size:10px;font-weight:800;padding:2px 7px;border-radius:6px;color:#fff;box-shadow:0 2px 6px rgba(0,0,0,.15)}
.pcard-flags .flag.low{background:#e23a2e}
.pcard-flags .flag.hot{background:#f59e0b}
.pcard-mini-count{font-size:11px;font-weight:800;color:#e23a2e;margin-top:3px;font-variant-numeric:tabular-nums}

/* Live Jualan */
.live-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:14px}
.live-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.live-card .live-embed{aspect-ratio:16/9;background:#000}
.live-card .live-embed iframe{width:100%;height:100%;border:0;display:block}
.live-card .live-body{padding:12px 14px;display:flex;flex-direction:column;gap:6px}
.live-card .live-title{font-weight:700;line-height:1.3}
.live-now-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#e23a2e;margin-right:5px;animation:livePulse 1.2s infinite}
@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(226,58,46,.6)}70%{box-shadow:0 0 0 8px rgba(226,58,46,0)}100%{box-shadow:0 0 0 0 rgba(226,58,46,0)}}

/* Referral */
.ref-box{background:var(--primary-light);border:1px solid #bdebd2;border-radius:var(--radius);padding:16px;margin:14px 0}
.ref-link-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.ref-link-row input{flex:1;min-width:200px;padding:9px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:13px}
.ref-stat{display:inline-flex;align-items:baseline;gap:6px;font-weight:800;font-size:22px;color:var(--primary-dark)}
.lead-table{width:100%;border-collapse:collapse}
.lead-table th,.lead-table td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left}
.lead-rank{font-weight:800;color:var(--primary-dark)}

/* Tombol notifikasi */
.push-btn{display:inline-flex;align-items:center;gap:6px}


/* ===== v24: Kupon, FAQ, Skor Toko, Blog ===== */
.coupon-row{display:flex;flex-wrap:wrap;gap:12px;margin:10px 0 4px}
.coupon-card{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1.5px dashed var(--primary,#e1306c);border-radius:12px;background:#fff;padding:12px 14px;min-width:240px;flex:1 1 260px;max-width:360px}
.coupon-left{display:flex;flex-direction:column;gap:3px}
.coupon-val{font-weight:800;color:var(--primary,#e1306c);font-size:16px}
.coupon-desc{font-size:13px;color:#444}
.coupon-min{font-size:12px;color:#888}
.coupon-code{cursor:pointer;border:1px dashed var(--primary,#e1306c);background:#fff0f5;color:var(--primary,#e1306c);border-radius:8px;padding:8px 12px;font-family:monospace;font-weight:700;letter-spacing:.5px;font-size:13px;white-space:nowrap}
.coupon-code:hover{background:var(--primary,#e1306c);color:#fff}
.coupon-form label{display:block;font-size:13px;font-weight:600;margin:8px 0 4px}

.faq-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.faq-item{border:1px solid #eee;border-radius:10px;padding:10px 14px;background:#fafafa}
.faq-item summary{cursor:pointer;font-weight:600;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::before{content:'\002B';margin-right:8px;color:var(--primary,#e1306c);font-weight:800}
.faq-item[open] summary::before{content:'\2212'}
.faq-ans{margin-top:8px;color:#444;font-size:14px;line-height:1.6}

.store-score{margin:14px 0}
.store-score .section-head{display:flex;align-items:center;justify-content:space-between}
.score-pct{font-weight:800;color:var(--primary,#e1306c)}
.score-bar{height:10px;border-radius:999px;background:#eee;overflow:hidden;margin:8px 0}
.score-fill{height:100%;background:linear-gradient(90deg,#f59e0b,#22c55e);transition:width .4s}
.score-todo{list-style:none;padding:0;margin:6px 0;display:flex;flex-direction:column;gap:4px;font-size:14px;color:#555}
.ok-text{color:#16a34a;font-weight:600}

.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-top:14px}
.blog-card{display:flex;flex-direction:column;border:1px solid #eee;border-radius:14px;overflow:hidden;background:#fff;text-decoration:none;color:inherit;transition:box-shadow .2s,transform .2s}
.blog-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.08);transform:translateY(-2px)}
.blog-cover{aspect-ratio:16/9;background:#f4f4f8;overflow:hidden}
.blog-cover img{width:100%;height:100%;object-fit:cover}
.blog-body{padding:12px 14px;display:flex;flex-direction:column;gap:6px}
.blog-title{font-weight:700;line-height:1.3}
.blog-excerpt{font-size:13px;color:#666;line-height:1.5}
.blog-meta{font-size:12px;color:#999;margin-top:auto}
.article-wrap{max-width:760px}
.article-title{margin:10px 0 6px;line-height:1.25}
.article-meta{font-size:13px;margin-bottom:14px}
.article-cover{width:100%;border-radius:14px;margin-bottom:16px}
.article-body{font-size:16px;line-height:1.8;color:#222}

/* ===== Viral share + FOMO + foto ulasan (v31) ===== */
.viral-share{margin:14px 0;padding:14px;border:1px solid #e5e7eb;border-radius:14px;background:#f9fafb}
.viral-share .vs-title{font-weight:800;margin-bottom:10px;font-size:14px}
.viral-share .vs-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}
.viral-share .share-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:10px;font-size:13px;font-weight:600;text-decoration:none;border:1px solid #e5e7eb;background:#fff;color:#111827;cursor:pointer;line-height:1}
.viral-share .share-btn.wa{background:#dcfce7;border-color:#86efac;color:#166534}
.viral-share .share-btn.card{background:#eef2ff;border-color:#c7d2fe;color:#3730a3}
.viral-share .vs-reward{font-size:12px;color:#6b7280;margin-top:4px}
.viral-share .vs-reward a{color:#4f46e5;font-weight:600}
.review-photo{height:90px;border-radius:8px;margin-top:8px;object-fit:cover;border:1px solid #e5e7eb;display:inline-block}
.fomo-pop{position:fixed;left:16px;bottom:84px;z-index:60;max-width:300px;pointer-events:none;opacity:0;transform:translateY(12px);transition:opacity .35s ease,transform .35s ease}
.fomo-pop.show{opacity:1;transform:translateY(0)}
.fomo-pop .fp-card{display:flex;gap:10px;align-items:flex-start;background:#fff;border:1px solid #e5e7eb;box-shadow:0 8px 24px rgba(0,0,0,.12);border-radius:12px;padding:10px 12px;font-size:12.5px;line-height:1.35}
.fomo-pop .fp-dot{width:10px;height:10px;border-radius:50%;background:#22c55e;margin-top:4px;flex:0 0 auto;box-shadow:0 0 0 4px rgba(34,197,94,.18)}
.fomo-pop .fp-prod{color:#111827;font-weight:600}
.fomo-pop .fp-ago{color:#9ca3af}
@media(max-width:600px){.fomo-pop{left:10px;right:10px;max-width:none;bottom:74px}}


/* =====================================================================
   v32 — STOREFRONT GLOW-UP  (tampilan publik lebih mentereng & mudah dinavigasi)
   Hanya menambah/menimpa gaya; semua nama class lama dipertahankan.
   ===================================================================== */
:root{
  --accent:#ff5b2e; --accent-2:#ff8a00;
  --accent-grad:linear-gradient(120deg,#ff7a18,#ff3d6e);
}

/* ---------- Topbar & search lebih menonjol ---------- */
.searchbar{box-shadow:0 6px 16px rgba(0,0,0,.12),inset 0 0 0 1px rgba(255,255,255,.4)}
.searchbar input::placeholder{color:#9aa3ad}
.catbar-inner{padding-top:8px;padding-bottom:11px}
.chip{box-shadow:0 2px 6px rgba(0,0,0,.06)}
.chip:hover{box-shadow:0 6px 14px rgba(0,0,0,.14)}

/* ---------- Tombol khusus hero (kontras di atas hijau) ---------- */
.btn-light{background:#fff;color:var(--primary-dark);box-shadow:0 8px 20px rgba(0,0,0,.18)}
.btn-light:hover{box-shadow:0 12px 28px rgba(0,0,0,.24)}
.btn-ghost-light{background:rgba(255,255,255,.14);color:#fff;border:1.5px solid rgba(255,255,255,.65);backdrop-filter:blur(4px)}
.btn-ghost-light:hover{background:rgba(255,255,255,.26)}

/* ---------- HERO baru ---------- */
.hero{background:linear-gradient(120deg,#00AA5B 0%,#04b765 45%,#1ed47f 100%)}
.hero::before{content:"";position:absolute;left:-60px;bottom:-90px;width:280px;height:280px;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 70%);pointer-events:none}
.hero-inner{padding:46px 16px 52px;align-items:center}
.hero-pill{display:inline-block;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.4);color:#fff;font-weight:700;font-size:13px;padding:6px 14px;border-radius:999px;margin-bottom:14px;backdrop-filter:blur(4px)}
.hero-text{max-width:560px}
.hero-search{display:flex;gap:8px;background:#fff;border-radius:16px;padding:7px;box-shadow:0 14px 36px rgba(0,0,0,.18);max-width:520px;margin:8px 0 18px}
.hero-search input{flex:1;border:0;outline:none;padding:10px 14px;font-size:15px;font-family:inherit;border-radius:12px;background:transparent}
.hero-search .btn{white-space:nowrap}
.hero-art{position:relative;width:280px;height:240px;flex:0 0 auto}
.hero-blob{position:absolute;inset:0;margin:auto;width:208px;height:208px;background:rgba(255,255,255,.16);border-radius:42% 58% 60% 40%/45% 45% 55% 55%;animation:blobMove 9s ease-in-out infinite}
.hero-emoji{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:108px;filter:drop-shadow(0 12px 24px rgba(0,0,0,.28))}
.hero-float{position:absolute;font-size:40px;filter:drop-shadow(0 6px 14px rgba(0,0,0,.22));animation:floaty 4s ease-in-out infinite}
.hero-float.f1{top:6px;right:14px;animation-delay:.2s}
.hero-float.f2{bottom:16px;left:2px;animation-delay:1s}
.hero-float.f3{bottom:34px;right:24px;animation-delay:1.6s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes blobMove{0%,100%{border-radius:42% 58% 60% 40%/45% 45% 55% 55%}50%{border-radius:58% 42% 40% 60%/55% 55% 45% 45%}}

/* ---------- USP / trust strip ---------- */
.usp-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:18px 0 6px}
.usp{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid #eef1f4;border-radius:16px;padding:14px;box-shadow:var(--shadow-sm);transition:.18s}
.usp:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.usp-ic{flex:0 0 auto;width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:22px;background:var(--primary-light)}
.usp b{display:block;font-size:13.5px;line-height:1.25}
.usp small{color:var(--muted);font-size:12px}

/* ---------- Judul section dengan aksen ---------- */
.section-title{display:flex;align-items:center;gap:10px}
.section-title::before{content:"";width:5px;height:22px;border-radius:6px;background:var(--primary-grad);display:inline-block;flex:0 0 auto}

/* ---------- Kategori: lingkaran warna ala marketplace ---------- */
.cat-tile{padding:16px 8px;border-radius:18px}
.cat-tile .cat-ico{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.04);transition:.18s}
.cat-tile:hover .cat-ico{transform:scale(1.08)}
.cat-grid .cat-tile:nth-child(8n+1) .cat-ico{background:#e8f7ef}
.cat-grid .cat-tile:nth-child(8n+2) .cat-ico{background:#fff1e6}
.cat-grid .cat-tile:nth-child(8n+3) .cat-ico{background:#e7f0ff}
.cat-grid .cat-tile:nth-child(8n+4) .cat-ico{background:#fde8ef}
.cat-grid .cat-tile:nth-child(8n+5) .cat-ico{background:#f1e9ff}
.cat-grid .cat-tile:nth-child(8n+6) .cat-ico{background:#fff7da}
.cat-grid .cat-tile:nth-child(8n+7) .cat-ico{background:#e6faf6}
.cat-grid .cat-tile:nth-child(8n) .cat-ico{background:#eef1f4}

/* ---------- Kartu produk lebih hidup ---------- */
.pcard{border-radius:16px}
.pcard:hover{box-shadow:0 16px 36px rgba(18,22,28,.14);border-color:#b6e3c9}
.pcard-img::after{content:"\1F6D2";position:absolute;right:8px;bottom:8px;width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;box-shadow:0 6px 16px rgba(0,170,91,.42);opacity:0;transform:translateY(8px) scale(.8);transition:.2s;pointer-events:none}
.pcard:hover .pcard-img::after{opacity:1;transform:translateY(0) scale(1)}
.price{font-size:17px}
.pcard-meta span{display:inline-flex;align-items:center;gap:3px}

/* ---------- Flash sale band yang mencolok ---------- */
.fs-band{background:var(--accent-grad);border-radius:22px;padding:8px 16px 18px;margin-top:24px;color:#fff;box-shadow:0 14px 34px rgba(255,70,80,.26)}
.fs-band .section-head{margin:14px 0}
.fs-band .section-title{color:#fff}
.fs-band .section-title::before{background:#fff}
.fs-band .section-head .link{color:#fff;text-decoration:underline}
.fs-band .pcard{background:#fff}

/* ---------- Tombol kembali ke atas ---------- */
.to-top{position:fixed;right:16px;bottom:78px;z-index:47;width:44px;height:44px;border-radius:50%;border:0;background:#fff;color:var(--primary);font-size:20px;font-weight:800;box-shadow:var(--shadow);cursor:pointer;display:none;align-items:center;justify-content:center}
.to-top.show{display:flex}

/* ---------- Responsive ---------- */
@media(max-width:1024px){ .usp-strip{grid-template-columns:repeat(2,1fr)} }
@media(max-width:768px){
  .hero-art{display:none}
  .hero-inner{padding:30px 16px 36px}
  .hero-search{max-width:none}
  .to-top{bottom:96px}
}
@media(max-width:480px){
  .usp-strip{grid-template-columns:1fr 1fr;gap:9px}
  .usp{padding:11px;gap:9px}
  .usp-ic{width:38px;height:38px;font-size:19px;border-radius:11px}
  .usp b{font-size:12.5px}
  .cat-tile .cat-ico{width:50px;height:50px;font-size:24px}
  .fs-band{border-radius:18px}
}


/* ============================================================
   v33 — NATIVE-APP MINIMAL SKIN (floating nav + install card)
   ============================================================ */
/* Floating native bottom nav with center FAB */
.bottomnav .bn-fab{ position:relative }
.bottomnav .bn-fab span{ width:48px;height:48px;margin-top:-22px;border-radius:50%;background:var(--primary-grad);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 8px 18px rgba(0,170,91,.45);font-weight:700 }
.bottomnav .bn-fab i{ font-style:normal;font-size:11px;margin-top:2px }
/* Inline PWA install card (mobile-first, native add-to-home prompt feel) */
.pwa-card{ display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:13px 15px;box-shadow:var(--shadow-sm);margin:14px 0 }
.pwa-card .pwa-ic{ width:46px;height:46px;border-radius:14px;background:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:24px;flex:0 0 auto }
.pwa-card .pwa-tx{ flex:1;min-width:0 }
.pwa-card .pwa-tx b{ display:block;font-size:14.5px;line-height:1.2 }
.pwa-card .pwa-tx span{ color:var(--muted);font-size:12.5px }
.pwa-card .pwa-card-btn{ flex:0 0 auto }
@media(min-width:880px){ .pwa-card{ display:none } }
/* Dashboard flash-sale countdown badge */
.badge[data-countdown]{ font-variant-numeric:tabular-nums;letter-spacing:.3px }

/* Hero photo (replaces emoji art when an image is set) */
.hero-art.has-photo{ display:flex;align-items:center;justify-content:center;position:relative }
.hero-art.has-photo .hero-photo{ position:relative;z-index:2;max-width:100%;width:auto;max-height:300px;border-radius:22px;box-shadow:0 18px 40px rgba(18,22,28,.20);object-fit:cover }
.hero-art.has-photo .hero-blob{ z-index:1 }
