/* ===== WonderKey Storefront — pixel match ke mockup ===== */
:root{
  --bg:#ffffff; --ink:#0d0d0d; --panel:#f4f4f4; --line:#ececec;
  --muted:#9a9a9a; --accent:#0d0d0d; --accent-ink:#ffffff;
  --ok:#1f8a4c; --out:#b23b3b;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{font-family:"Inter","Helvetica Neue",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  background:var(--bg);color:var(--ink);font-size:15px;line-height:1.45;-webkit-font-smoothing:antialiased;
  padding-bottom:calc(185px + env(safe-area-inset-bottom))}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1120px;margin:0 auto;padding:0 16px}

/* ===== Header gelap (ramping) ===== */
.shead{background:var(--ink);color:#fff;position:sticky;top:0;z-index:50}
.shead-in{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 8px;max-width:1120px;margin:0 auto}
.brandbox{display:flex;align-items:center;gap:9px;min-width:0}
.brandbox img{height:33px;width:auto;filter:invert(1) brightness(1.7);mix-blend-mode:screen}
.brandbox .bt{font-weight:900;letter-spacing:.5px;font-size:16px;line-height:1}
.brandbox .bt small{display:block;font-size:7px;letter-spacing:3.5px;color:#8f8f8f;font-weight:600;margin-top:4px}
.hicons{display:flex;gap:18px;align-items:center;font-size:16px}
.hicons a{color:#fff;position:relative;line-height:1}
.hicons .cart .cbadge{position:absolute;top:-9px;right:-9px;background:#fff;color:#000;font-size:10px;font-weight:800;min-width:17px;height:17px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 3px}

/* search bar (toggle, tersembunyi default) */
.searchbar{background:var(--ink);max-height:0;overflow:hidden;transition:max-height .25s ease}
.searchbar.open{max-height:80px}
.searchbar form{display:flex;gap:8px;padding:0 18px 14px}
.searchbar input{flex:1;border:1px solid #333;background:#1a1a1a;color:#fff;border-radius:10px;padding:11px 14px;font-size:16px}
.searchbar button{border:0;background:#fff;color:#000;border-radius:10px;padding:0 16px;font-weight:700}

/* ===== Pills kategori ===== */
.pills{display:flex;gap:8px;overflow-x:auto;margin-top:-1px;padding:6px 14px 14px;background:var(--ink);scrollbar-width:none}
.pills::-webkit-scrollbar{display:none}
.pill-cat{flex:0 0 auto;border:1px solid #2c2c2c;color:#d2d2d2;background:transparent;border-radius:30px;
  padding:7px 15px;font-size:11.5px;font-weight:600;white-space:nowrap;letter-spacing:.4px}
.pill-cat.active{background:#fff;color:#000;border-color:#fff}

/* ===== Hero banner (full-bleed hitam, nyambung dgn header) ===== */
.banner-wrap{padding:0;margin:0}
.banner{position:relative;height:186px;overflow:hidden;background:#0d0d0d}
.slides{display:flex;height:100%;transition:transform .45s ease;touch-action:pan-y}
.slide{flex:0 0 100%;position:relative;height:100%;padding:0 18px;color:#fff;
  display:flex;flex-direction:column;justify-content:center;
  background:
    linear-gradient(180deg,#0d0d0d 0%, rgba(13,13,13,0) 16%),
    radial-gradient(52% 72% at 78% 50%, rgba(255,255,255,.16) 0%, rgba(255,255,255,0) 50%),
    radial-gradient(150% 135% at 70% 26%, #343434 0%, #151515 44%, #050505 100%)}
.slide::before{content:"";position:absolute;inset:0;opacity:.30;mix-blend-mode:overlay;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.slide::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(125% 120% at 50% 45%, transparent 52%, rgba(0,0,0,.6) 100%)}
.slide .eyebrow{position:relative;z-index:2;font-size:9.5px;letter-spacing:2px;color:#d3d3d3;text-transform:uppercase;margin-bottom:8px}
.slide h2{position:relative;z-index:2;font-size:27px;font-weight:900;letter-spacing:-.5px;margin:0 0 9px;line-height:.96}
.slide p{position:relative;z-index:2;color:#c4c4c4;font-size:11.5px;line-height:1.4;max-width:58%;margin:0}
.slide .blogo{position:absolute;z-index:2;right:-6px;top:50%;transform:translateY(-50%);height:150px;width:auto;
  filter:invert(1) brightness(1.85) contrast(1.05);mix-blend-mode:screen;pointer-events:none}
@media(max-width:380px){.banner{height:170px}.slide h2{font-size:23px}.slide .blogo{height:128px}.slide p{max-width:60%;font-size:11px}}
.dots{position:absolute;bottom:14px;left:0;right:0;display:flex;gap:7px;justify-content:center;z-index:2}
.dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.38);border:0;padding:0;cursor:pointer;transition:width .2s}
.dot.active{background:#fff;width:20px;border-radius:4px}

/* ===== Toolbar KOLEKSI ===== */
.col-head{display:flex;align-items:center;justify-content:space-between;padding:18px 14px 12px;max-width:1120px;margin:0 auto}
.col-head .ttl{font-size:15px;font-weight:900;letter-spacing:.6px}
.col-head .ttl small{color:var(--muted);font-weight:700;font-size:10px;margin-left:6px;letter-spacing:.8px}
.tools{display:flex;gap:7px;align-items:center}
details.sort{position:relative}
details.sort>summary{list-style:none;cursor:pointer;border:1px solid var(--line);border-radius:9px;
  padding:8px 11px;font-size:10px;font-weight:700;letter-spacing:.6px;background:#fff;display:flex;gap:8px;align-items:center}
details.sort>summary i{font-size:10px;color:var(--muted)}
details.sort>summary::-webkit-details-marker{display:none}
.sort-menu{position:absolute;right:0;top:calc(100% + 6px);background:#fff;border:1px solid var(--line);
  border-radius:12px;box-shadow:0 12px 32px rgba(0,0,0,.14);min-width:180px;z-index:30;overflow:hidden}
.sort-menu a{display:block;padding:12px 15px;font-size:13px}
.sort-menu a.active{background:var(--panel);font-weight:700}
.viewtoggle{display:flex;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.viewtoggle a{padding:7px 9px;background:#fff;color:#c2c2c2;font-size:12px;line-height:1}
.viewtoggle a.active{background:var(--ink);color:#fff}

/* ===== Grid produk (2 kolom) ===== */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-width:1120px;margin:0 auto 22px}
@media(min-width:760px){.grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1040px){.grid{grid-template-columns:repeat(4,1fr)}}
.product{background:var(--panel);border-radius:14px;overflow:hidden;position:relative}
.product-link{display:block;color:inherit}
.product .ph{aspect-ratio:1/1;background:#fff;position:relative;overflow:hidden}
.product .ph img{width:100%;height:100%;object-fit:cover}
.product .ph .noimg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#d2d2d2;font-size:26px}
.product .badge{position:absolute;top:10px;left:10px;background:var(--ink);color:#fff;font-size:9px;font-weight:800;
  letter-spacing:.8px;padding:5px 10px;border-radius:7px}
.product .body{padding:11px 12px 13px;padding-right:42px}
.product .name{font-weight:800;font-size:13.5px;line-height:1.25}
.product .meta{display:flex;align-items:center;margin-top:6px}
.product .price{font-size:13px;font-weight:600}
.product .price .from{color:var(--muted);font-size:11px;font-weight:500}
.product>.heart,.product>.wish-form{position:absolute;bottom:8px;right:8px;z-index:2;margin:0}
.heart{display:flex;align-items:center;justify-content:center;width:32px;height:32px;font-size:17px;color:var(--ink);background:none;border:0;cursor:pointer;border-radius:50%}
.heart.on{color:#e0245e}
/* list view */
.grid.list{grid-template-columns:1fr;gap:12px}
.grid.list .product{display:flex}
.grid.list .product .ph{width:128px;flex:0 0 128px;aspect-ratio:1/1}
.grid.list .product .body{flex:1;display:flex;flex-direction:column;justify-content:center}

/* ===== Pagination ===== */
.pagination{display:flex;justify-content:center;gap:8px;padding:26px 16px 8px;flex-wrap:wrap}
.pagination a,.pagination span{min-width:36px;height:36px;border-radius:10px;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;background:#fff;color:var(--ink)}
.pagination .active{background:var(--ink);color:#fff;border-color:var(--ink)}
.pagination .disabled{opacity:.35;pointer-events:none}

.empty{text-align:center;color:var(--muted);padding:60px 20px}
.empty .big{font-size:42px;margin-bottom:14px;color:#d4d4d4}

/* ===== Floating FILTER | SORT (melayang di atas bottom nav) ===== */
.float-fs{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(102px + env(safe-area-inset-bottom));z-index:48;
  background:var(--ink);color:#fff;border-radius:40px;display:flex;align-items:center;
  box-shadow:0 14px 34px rgba(0,0,0,.34)}
.float-fs button,.float-fs a{background:none;border:0;color:#fff;font-weight:700;letter-spacing:1px;font-size:11.5px;
  display:flex;gap:8px;align-items:center;padding:12px 22px;cursor:pointer}
.float-fs .sep{width:1px;height:18px;background:#3a3a3a}

/* ===== Bottom nav (tinggi, sudut atas membulat, hitam penuh) ===== */
.snav{position:fixed;bottom:0;left:0;right:0;z-index:49;background:var(--ink);
  border-radius:18px 18px 0 0;display:flex;justify-content:space-around;
  padding:10px 8px calc(10px + env(safe-area-inset-bottom));box-shadow:0 -6px 24px rgba(0,0,0,.18)}
.snav a{color:#7c7c7c;font-size:9px;letter-spacing:.8px;font-weight:600;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:5px}
.snav a .ic{font-size:17px;line-height:1}
.snav a.active{color:#fff}

/* ===== Product detail (product.php) ===== */
.back{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:12px;letter-spacing:1px;text-transform:uppercase;margin:16px 0}
.back:hover{color:var(--ink)}
.pd{display:grid;gap:24px;padding:8px 0 30px}
@media(min-width:760px){.pd{grid-template-columns:1.05fr 1fr;gap:48px;align-items:start}}
.gallery .main{aspect-ratio:1/1;background:var(--panel);border-radius:16px;overflow:hidden}
.gallery .main img{width:100%;height:100%;object-fit:cover}
.gallery .thumbs{display:flex;gap:8px;margin-top:10px;overflow-x:auto;padding-bottom:4px}
.gallery .thumbs img{width:62px;height:62px;object-fit:cover;border-radius:10px;border:2px solid transparent;cursor:pointer;flex:0 0 auto;opacity:.6}
.gallery .thumbs img.sel{border-color:var(--ink);opacity:1}
.pd-info h1{font-size:24px;font-weight:900;letter-spacing:-.3px;margin:0 0 10px}
.pd-price{font-size:20px;font-weight:800;margin-bottom:8px}
.stock-line{font-size:12px;letter-spacing:.5px;margin-bottom:22px;display:flex;align-items:center;gap:7px;text-transform:uppercase}
.stock-line i{font-size:7px}
.stock-line.in{color:var(--ok)}.stock-line.out{color:var(--out)}
.opt-group{margin-bottom:20px}
.opt-group label{display:block;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.opts{display:flex;flex-wrap:wrap;gap:8px}
.opt{border:1px solid var(--line);border-radius:9px;padding:10px 16px;font-size:13px;cursor:pointer;background:#fff;user-select:none;min-width:48px;text-align:center}
.opt.sel{border-color:var(--ink);background:var(--ink);color:#fff}
.opt.disabled{opacity:.3;cursor:not-allowed;text-decoration:line-through}
.desc{font-size:14px;color:#555;white-space:pre-line;margin:22px 0;border-top:1px solid var(--line);padding-top:22px}
.buy{position:sticky;bottom:calc(90px + env(safe-area-inset-bottom));background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-top:1px solid var(--line);
  padding:14px 16px;display:flex;gap:12px;align-items:center;z-index:30}
@media(min-width:760px){.buy{position:static;border:0;padding:0;backdrop-filter:none}}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;background:var(--accent);color:var(--accent-ink);
  border:1px solid var(--accent);border-radius:10px;padding:15px 22px;font-weight:800;font-size:14px;cursor:pointer;width:100%;letter-spacing:1px;text-transform:uppercase}
.btn:active{transform:translateY(1px)}
.btn:disabled{background:#dcdcd7;border-color:#dcdcd7;color:#9a9a93;cursor:not-allowed}
.note{font-size:12px;color:var(--muted);text-align:center;margin-top:12px}

/* ===== Tombol Login di header ===== */
.login-btn{background:#F44336;color:#000;border-radius:22px;padding:8px 18px;font-size:12px;font-weight:800;letter-spacing:.5px}

/* ===== Auth (login/daftar) & Akun ===== */
.auth-wrap{max-width:420px;margin:0 auto;padding:34px 18px 20px}
.auth-wrap h1{font-size:23px;font-weight:900;margin:0 0 6px;text-align:center;letter-spacing:-.3px}
.auth-wrap .sub{color:var(--muted);font-size:13px;text-align:center;margin:0 0 22px}
.auth-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px}
.field{margin-bottom:14px}
.field label{display:block;font-size:11px;font-weight:700;letter-spacing:.6px;color:var(--muted);margin-bottom:6px;text-transform:uppercase}
.field input{width:100%;border:1px solid var(--line);border-radius:10px;padding:13px 14px;font-size:16px;background:#fafafa;color:var(--ink)}
.field input:focus{outline:none;border-color:var(--ink);background:#fff}
.auth-btn{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;background:var(--ink);color:#fff;border:1px solid var(--ink);
  border-radius:10px;padding:15px;font-weight:800;letter-spacing:1px;text-transform:uppercase;font-size:13px;cursor:pointer;text-decoration:none}
.auth-btn:active{transform:translateY(1px)}
.auth-btn.ghost{background:#fff;color:var(--ink);margin-top:14px}
.auth-btn.wa{background:#1faf53;border-color:#1faf53;margin-top:4px}
.auth-alt{text-align:center;margin-top:16px;font-size:13px;color:var(--muted)}
.auth-alt a{color:var(--ink);font-weight:700}
.flash-err{background:#fdecec;border:1px solid #f5c6c6;color:#b23b3b;padding:11px 14px;border-radius:10px;font-size:13px;margin-bottom:14px;display:flex;gap:8px;align-items:center}
.acc-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);font-size:14px}
.acc-row span{color:var(--muted);display:flex;align-items:center;gap:9px}
.acc-link{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:15px 16px;margin-top:12px;font-weight:700;font-size:14px}
.acc-link span{display:flex;align-items:center;gap:11px}
.acc-badge{background:var(--ink);color:#fff;min-width:22px;height:22px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:12px;padding:0 6px}

/* ===== Keranjang ===== */
.cart-wrap{max-width:620px;margin:0 auto;padding:20px 16px 8px}
.cart-title{font-size:21px;font-weight:900;letter-spacing:.5px;margin:0 0 16px}
.cart-item{display:flex;gap:12px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px;margin-bottom:12px}
.ci-ph{width:78px;height:78px;flex:0 0 78px;background:var(--panel);border-radius:10px;overflow:hidden;display:flex;align-items:center;justify-content:center;color:#cfcfcf;font-size:22px}
.ci-ph img{width:100%;height:100%;object-fit:cover}
.ci-info{flex:1;min-width:0}
.ci-name{font-weight:800;font-size:14px;line-height:1.25}
.ci-var{color:var(--muted);font-size:12px;margin-top:2px}
.ci-price{font-size:13px;margin-top:4px}
.ci-actions{display:flex;align-items:center;gap:14px;margin-top:10px}
.qty{display:flex;align-items:center;gap:0;border:1px solid var(--line);border-radius:9px;overflow:hidden}
.qty button{width:34px;height:32px;border:0;background:#fff;font-size:17px;cursor:pointer;color:var(--ink)}
.qty span{min-width:34px;text-align:center;font-weight:700;font-size:14px}
.ci-del{border:0;background:none;color:var(--muted);font-size:16px;cursor:pointer}
.ci-line{font-weight:800;font-size:14px;align-self:flex-start;white-space:nowrap}
.cart-summary{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;margin-top:4px}
.cs-row{display:flex;align-items:center;justify-content:space-between;font-size:16px;margin-bottom:6px}
.cs-row b{font-size:19px;font-weight:900}
.cs-note{color:var(--muted);font-size:12px;margin:6px 0 14px}

/* textarea sama gaya dgn input */
.field textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:13px 14px;font-size:16px;background:#fafafa;color:var(--ink);font-family:inherit;resize:vertical}
.field textarea:focus{outline:none;border-color:var(--ink);background:#fff}

.ok-banner{background:#eef5ef;border:1px solid #cfe6d6;color:#1f8a4c;padding:11px 14px;border-radius:10px;font-size:13px;margin-bottom:14px;display:flex;gap:9px;align-items:flex-start}
.acc-h2{font-size:13px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin:24px 0 12px}

/* ===== Pesanan (pelanggan) ===== */
.ord-card{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:12px}
.ord-no{font-weight:800;font-size:14px}
.ord-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--line);font-size:14px}
.ord-item:last-child{border-bottom:0}
.ord-status{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.5px;padding:5px 11px;border-radius:20px}
.st-pending{background:#fff4e5;color:#b26a00}
.st-paid{background:#e8f0fe;color:#1a56db}
.st-shipped{background:#eafaf1;color:#1f8a4c}
.st-done{background:#eef5ef;color:#1f8a4c}
.st-cancel{background:#fdecec;color:#b23b3b}
