/* =============================================
   catalog.css — WhatsApp Catalog SaaS
   Mobile-first + Desktop Shopify-style
   ============================================= */

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}

body{
  font-family:var(--font);background:var(--bg);color:var(--tx);
  margin:0 auto;padding-bottom:80px;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  font-size:14px;line-height:1.4;
}
button,a,[tabindex]{-webkit-tap-highlight-color:transparent;touch-action:manipulation}
:focus-visible{outline:2.5px solid var(--ac);outline-offset:2px;border-radius:4px}
::selection{background:var(--ac);color:#fff}

/* ── HEADER (mobile) ── */
.hdr{
  padding:10px 12px;display:flex;align-items:center;gap:8px;
  border-bottom:1px solid var(--bd-s);background:var(--bg);
  position:sticky;top:0;z-index:50;
  transition:box-shadow .2s;
}
.hdr.is-scrolled{box-shadow:0 2px 12px rgba(0,0,0,.06);border-bottom-color:transparent}
.hdr-left{display:flex;align-items:center;gap:10px;flex-shrink:0;min-width:0;flex:1}
.hdr-logo{
  width:38px;height:38px;border-radius:10px;background:var(--tx);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:900;color:var(--bg);flex-shrink:0;overflow:hidden;
}
.hdr-logo img{width:100%;height:100%;object-fit:cover}
.hdr-brand{min-width:0}
.hdr-name{font-size:15px;font-weight:800;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hdr-sub{font-size:10px;color:var(--tx-m);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}

.hdr-center{flex:0 1 auto;display:flex;padding:0 4px;min-width:0;max-width:240px}
.srch-w{position:relative;width:100%}
.srch-i{
  width:100%;height:34px;padding:0 8px 0 28px;
  border:1.5px solid var(--bd);border-radius:9px;
  font-size:12px;font-family:var(--font);background:var(--bg-s);
  outline:0;transition:border-color .12s;color:var(--tx);
}
.srch-i::placeholder{color:var(--tx-m)}.srch-i:focus{border-color:var(--tx);background:var(--bg)}
.srch-ic{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:var(--tx-m);pointer-events:none}
.srch-x{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:22px;height:22px;border:0;border-radius:50%;background:var(--bd);color:var(--tx-m);font-size:10px;cursor:pointer;display:none;align-items:center;justify-content:center;padding:0;line-height:1}
.srch-x:hover{background:var(--tx-m);color:var(--bg)}

.hdr-right{display:flex;align-items:center;flex-shrink:0}
.hdr-right .hdr-tags{display:none}
.hdr-cart{
  position:relative;width:34px;height:34px;border:0;border-radius:0;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--tx);background:none;
}
.hdr-cart-count{
  position:absolute;top:-2px;right:-2px;width:16px;height:16px;border-radius:50%;
  background:var(--ac);color:#fff;font-size:9px;font-weight:800;
  display:none;align-items:center;justify-content:center;
}
.hdr-cart-total{display:none}
.hdr-cart svg{width:19px;height:19px}

/* ── CATEGORIES ── */
.cats{
  padding:8px 0 4px;overflow-x:auto;white-space:nowrap;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;
}
.cats::-webkit-scrollbar{display:none}
.cats-in{display:inline-flex;gap:5px;padding:0 14px}
.cat{
  display:inline-flex;align-items:center;height:32px;padding:0 13px;
  border-radius:100px;font-size:12px;font-weight:600;font-family:var(--font);
  cursor:pointer;transition:all .15s;border:1.5px solid var(--bd);
  background:var(--bg);color:var(--tx-s);user-select:none;
  -webkit-tap-highlight-color:transparent;white-space:nowrap;flex-shrink:0;
}
.cat:hover{border-color:var(--tx);color:var(--tx)}
.cat:active{transform:scale(.95)}
.cat.on{background:var(--tx);color:var(--bg);border-color:var(--tx)}



/* ── FEATURED HERO PRODUCT ── */
.hero{margin:8px 12px;border-radius:14px;overflow:hidden;position:relative;cursor:pointer}
.hero-img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.hero-over{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 60%);
  display:flex;align-items:flex-end;justify-content:space-between;padding:14px;
}
.hero-text{flex:1;min-width:0}
.hero-badge-tag{font-size:10px;font-weight:700;color:#fff;background:rgba(0,0,0,.85);backdrop-filter:blur(8px);display:inline-block;padding:4px 12px;border-radius:8px;margin-bottom:8px}
.hero-name{font-size:18px;font-weight:800;color:#fff;line-height:1.15}
.hero-desc{font-size:11px;color:rgba(255,255,255,.6);margin-top:2px}
.hero-price-row{display:flex;align-items:baseline;gap:8px;margin-top:6px}
.hero-price{font-size:22px;font-weight:900;color:#fff}
.hero-price .cur{font-size:11px;font-weight:500;opacity:.7}
.hero-old{font-size:12px;color:rgba(255,255,255,.5);text-decoration:line-through}
.hero-btn{
  width:44px;height:44px;border-radius:12px;background:var(--ac);border:0;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:#fff;gap:6px;transition:transform .15s;
}
.hero-btn:active{transform:scale(.9)}
.hero-btn svg{width:20px;height:20px}
.hero-btn-text{display:none}

/* ── GRID ── */
.prods{padding:6px 12px}
.prods-t{font-size:10px;font-weight:700;color:var(--tx-m);text-transform:uppercase;letter-spacing:1px;padding:0 2px 8px}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}

/* ── CARD ── */
.card{
  background:var(--bg);border-radius:14px;overflow:hidden;
  box-shadow:0 1px 3px rgba(0,0,0,.04),0 0 0 1px var(--bd-s);
  transition:box-shadow .25s,transform .25s;cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  animation:cardIn .4s both cubic-bezier(.16,1,.3,1);
}
@keyframes cardIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes badgePop{0%{transform:scale(1)}50%{transform:scale(1.35)}100%{transform:scale(1)}}
.card:active{transform:scale(.97)}
.card-iw{width:100%;aspect-ratio:.88;position:relative;overflow:hidden;background:var(--bg-s)}
.card-iw img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s}
.card-noimg{width:100%;height:100%;background:linear-gradient(135deg,var(--bg-s) 0%,var(--bg-m) 100%)}
@media(hover:hover){.card:hover{box-shadow:0 8px 28px rgba(0,0,0,.08),0 0 0 1px var(--bd);transform:translateY(-2px)}.card:hover .card-iw img{transform:scale(1.05)}}
.card-vb{
  position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:50%;
  background:rgba(0,0,0,.5);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;z-index:2;cursor:pointer;
}
.card-badge{
  position:absolute;top:8px;left:8px;
  background:rgba(0,0,0,.85);backdrop-filter:blur(8px);color:#FFFFFF;
  font-size:9px;font-weight:700;padding:4px 10px;border-radius:8px;z-index:2;
}
.card-pf{
  position:absolute;bottom:8px;left:8px;
  background:rgba(0,0,0,.85);backdrop-filter:blur(8px);
  padding:6px 12px;border-radius:8px;z-index:2;transition:opacity .2s;
  display:flex;align-items:baseline;gap:6px;
}
@media(hover:hover){.card:hover .card-pf{opacity:0}}
.card-pf-p{font-size:14px;font-weight:800;letter-spacing:-.2px;line-height:1;white-space:nowrap;color:#FFFFFF}
.card-pf-c{font-size:10px;font-weight:600;color:#FFFFFF}
.card-pf-o{font-size:10px;color:rgba(255,255,255,.6);text-decoration:line-through;white-space:nowrap;font-weight:400}
.card-info{padding:8px 9px 9px;display:flex;align-items:flex-start;gap:5px}
.card-txt{flex:1;min-width:0;cursor:pointer}
.card-nm{font-size:12px;font-weight:600;line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-colors{display:flex;gap:2px;margin-top:4px;align-items:center}
.card-colors span{width:8px;height:8px;border-radius:50%;border:1px solid rgba(0,0,0,.08);display:block;flex-shrink:0}
.card-colors-m{font-size:8px;color:var(--tx-m);margin-left:2px}
.card-sizes{font-size:9px;color:var(--tx-m);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.abtn{
  width:38px;height:38px;border-radius:10px;background:var(--ac);border:0;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:transform .15s,opacity .15s;
  -webkit-tap-highlight-color:transparent;flex-shrink:0;
}
.abtn:active{transform:scale(.82)}
.abtn:hover{opacity:.9}
.abtn svg{color:var(--ac-t);width:17px;height:17px}
.qc{display:flex;align-items:center;background:var(--tx);border-radius:10px;height:38px;padding:0 2px;flex-shrink:0}
.qb{width:30px;height:34px;border-radius:8px;border:0;background:0;color:var(--bg);font-size:16px;font-weight:600;font-family:var(--font);cursor:pointer;display:flex;align-items:center;justify-content:center}
.qn{font-size:12px;font-weight:700;color:var(--bg);min-width:16px;text-align:center}

/* ── DETAIL MODAL (mobile bottom sheet) ── */
.det-ov{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:300;display:flex;align-items:flex-end;justify-content:center}
.det{background:var(--bg);width:100%;max-width:480px;max-height:92vh;border-radius:20px 20px 0 0;overflow:hidden;display:flex;flex-direction:column;animation:su .2s cubic-bezier(.16,1,.3,1)}
@keyframes su{from{transform:translateY(100%)}to{transform:translateY(0)}}
.det-close{position:absolute;top:10px;right:10px;width:34px;height:34px;border-radius:50%;background:rgba(0,0,0,.4);border:0;color:#fff;font-size:14px;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;font-family:var(--font)}
.det-slider{position:relative;width:100%;aspect-ratio:1;overflow:hidden;background:var(--bg-s)}
.det-slides{display:flex;transition:transform .3s;height:100%}
.det-slides img{width:100%;height:100%;object-fit:cover;flex-shrink:0}
.det-dots{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);display:flex;gap:5px}
.det-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer}
.det-dot.on{background:#fff;transform:scale(1.2)}
.det-arrows{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;padding:0 8px;pointer-events:none}
.det-arr{width:32px;height:32px;border-radius:50%;background:rgba(0,0,0,.3);border:0;color:#fff;font-size:14px;cursor:pointer;pointer-events:auto;font-family:var(--font)}
.det-body{flex:1;overflow-y:auto;padding:14px 16px}
.det-name{font-size:20px;font-weight:800;line-height:1.15}
.det-desc{font-size:13px;color:var(--tx-s);margin-top:4px}
.det-price-row{display:flex;align-items:baseline;gap:8px;margin-top:12px;flex-wrap:wrap}
.det-price{font-size:26px;font-weight:900}
.det-price-old{font-size:14px;color:var(--tx-m);text-decoration:line-through}
.det-price-save{font-size:12px;font-weight:700;color:#E11D48;background:#FEE2E2;padding:2px 8px;border-radius:100px}
.det-section{margin-top:16px}
.det-label{font-size:10px;font-weight:700;color:var(--tx-m);text-transform:uppercase;letter-spacing:.7px;margin-bottom:6px}
.det-sizes{display:flex;gap:6px;flex-wrap:wrap}
.det-size{height:36px;min-width:44px;padding:0 12px;border-radius:9px;border:1.5px solid var(--bd);background:var(--bg);font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s}
.det-size:hover{border-color:var(--tx)}.det-size.on{background:var(--tx);color:var(--bg);border-color:var(--tx)}
.det-colors{display:flex;gap:8px;flex-wrap:wrap}
.det-color{width:32px;height:32px;border-radius:50%;border:2.5px solid var(--bd);cursor:pointer;position:relative;transition:all .12s}
.det-color:hover{transform:scale(1.1)}.det-color.on{border-color:var(--tx);transform:scale(1.1)}
.det-color.on::after{content:'✓';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5)}
.det-foot{padding:10px 16px;padding-bottom:max(10px,env(safe-area-inset-bottom));display:flex;gap:8px;border-top:1px solid var(--bd-s)}
.det-share{width:48px;height:48px;border-radius:12px;border:1.5px solid var(--bd);background:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--tx)}
.det-addbtn{flex:1;height:48px;border-radius:12px;background:var(--ac);border:0;color:var(--ac-t);font-size:15px;font-weight:700;font-family:var(--font);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}
.det-addbtn:active{transform:scale(.98)}

/* ── DETAIL PAGE (hidden on mobile - uses modal instead) ── */
.det-page{display:none}
.det-back{background:0;border:0;font-family:var(--font);font-size:13px;font-weight:600;color:var(--tx-s);cursor:pointer;padding:8px 0;margin-bottom:12px;transition:color .12s}
.det-back:hover{color:var(--tx)}
.det-layout{display:block}
.det-gallery{display:none}
.det-img-feed{display:none}
.det-main-img{border-radius:14px;overflow:hidden;background:var(--bg-s);aspect-ratio:1}
.det-main-img img{width:100%;height:100%;object-fit:cover;display:block}
.det-thumbs{display:flex;gap:8px;margin-top:10px}
.det-thumb{width:64px;height:64px;border-radius:10px;object-fit:cover;cursor:pointer;border:2px solid var(--bd);transition:border-color .12s;opacity:.6}
.det-thumb.on{border-color:var(--tx);opacity:1}
.det-thumb:hover{opacity:1}
.det-info-panel{}
.det-badge{display:inline-block;background:var(--bg-s);border:1px solid var(--bd);padding:4px 12px;border-radius:100px;font-size:11px;font-weight:700;margin-bottom:10px}
.det-title{font-size:26px;font-weight:900;line-height:1.1;letter-spacing:-.3px}
.det-description{font-size:14px;color:var(--tx-s);margin-top:6px;line-height:1.5}
.det-price-block{display:flex;align-items:baseline;gap:10px;margin-top:16px}
.det-big-price{font-size:30px;font-weight:900;letter-spacing:-.5px}
.det-old-price{font-size:15px;color:var(--tx-m);text-decoration:line-through}
.det-discount{font-size:12px;font-weight:700;color:#E11D48;background:#FEE2E2;padding:3px 10px;border-radius:100px}
.det-divider{height:1px;background:var(--bd);margin:20px 0}
.det-option{margin-bottom:18px}
.det-option-label{font-size:11px;font-weight:700;color:var(--tx-m);text-transform:uppercase;letter-spacing:.7px;margin-bottom:8px}
.det-option-chips{display:flex;gap:6px;flex-wrap:wrap}
.det-chip{height:40px;min-width:48px;padding:0 16px;border-radius:10px;border:1.5px solid var(--bd);background:var(--bg);font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all .12s}
.det-chip:hover{border-color:var(--tx)}.det-chip.on{background:var(--tx);color:var(--bg);border-color:var(--tx)}
.det-option-colors{display:flex;gap:10px}
.det-colorcircle{width:36px;height:36px;border-radius:50%;border:2.5px solid var(--bd);cursor:pointer;position:relative;transition:all .12s}
.det-colorcircle:hover{transform:scale(1.08)}.det-colorcircle.on{border-color:var(--tx);transform:scale(1.08)}
.det-colorcircle.on::after{content:'✓';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5)}
.det-video-btn{background:0;border:1.5px solid var(--bd);border-radius:10px;padding:12px 16px;font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;color:var(--tx);width:100%;margin-bottom:18px;transition:border-color .12s}
.det-video-btn:hover{border-color:var(--tx)}
.det-actions{display:flex;gap:8px}
.det-add-btn{flex:1;height:52px;border-radius:12px;background:var(--ac);border:0;color:#fff;font-size:16px;font-weight:700;font-family:var(--font);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:opacity .12s}
.det-add-btn:hover{opacity:.9}
.det-share-btn{width:52px;height:52px;border-radius:12px;border:1.5px solid var(--bd);background:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--tx);flex-shrink:0;transition:border-color .12s}
.det-share-btn:hover{border-color:var(--tx)}

/* ── FOOTER (mobile) ── */
.site-footer{
  display:block;margin-top:32px;
  background:#FAFAFA;border-top:1px solid var(--bd-s);
  padding:20px 16px 24px;
}
.footer-inner{
  display:flex;flex-direction:column;gap:14px;
  max-width:1100px;margin:0 auto;
}
.footer-brand{display:flex;align-items:center;gap:10px}
.footer-logo{
  width:36px;height:36px;border-radius:10px;
  background:var(--tx);display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:900;color:var(--bg);overflow:hidden;flex-shrink:0;
}
.footer-logo img{width:100%;height:100%;object-fit:cover}
.footer-name{font-size:14px;font-weight:700}
.footer-desc{font-size:11px;color:var(--tx-m);margin-top:1px}
.footer-info{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--tx-s)}
.footer-info svg{vertical-align:-1px;opacity:.4}
.footer-wa-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  background:#25D366;color:#fff;border:0;border-radius:10px;
  padding:12px 20px;font-size:14px;font-weight:700;font-family:var(--font);
  cursor:pointer;text-decoration:none;transition:opacity .12s;
}
.footer-wa-btn:hover{opacity:.9}
.footer-bottom{
  font-size:10px;color:var(--tx-m);text-align:center;margin-top:4px;
  display:flex;flex-direction:column;gap:2px;
}

/* ── VIDEO MODAL ── */
.vid-ov{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:600;display:none;align-items:center;justify-content:center;padding:14px}
.vid-ov.show{display:flex}
.vid-m{width:100%;max-width:480px;background:#0a0a0a;border-radius:18px;overflow:hidden;animation:vi .2s cubic-bezier(.16,1,.3,1);position:relative}
@keyframes vi{from{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}
.vid-x{position:absolute;top:10px;right:10px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.1);border:0;color:#fff;font-size:14px;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;font-family:var(--font)}
.vid-p{width:100%;aspect-ratio:9/16;max-height:62vh;position:relative;background:#000;overflow:hidden}
.vid-p video{width:100%;height:100%;object-fit:cover}
.vid-yt{position:absolute;bottom:10px;right:10px;display:flex;align-items:center;gap:5px;background:rgba(255,0,0,.85);color:#fff;font-size:10px;font-weight:700;padding:5px 10px;border-radius:100px;text-decoration:none;z-index:5}
.vid-sound{position:absolute;bottom:10px;left:10px;background:rgba(0,0,0,.5);backdrop-filter:blur(6px);color:#fff;font-size:10px;font-weight:600;padding:5px 10px;border-radius:100px;border:0;cursor:pointer;z-index:5}
.vid-info{padding:12px 14px;display:flex;align-items:center;gap:10px}
.vid-th{width:44px;height:44px;border-radius:10px;object-fit:cover;flex-shrink:0}
.vid-nm{font-size:14px;font-weight:700;color:#fff}.vid-pr{font-size:12px;color:rgba(255,255,255,.4)}
.vid-acts{display:flex;gap:6px;padding:0 14px 14px}
.vid-add{flex:1;height:46px;background:var(--ac);border:0;color:#fff;font-size:14px;font-weight:700;font-family:var(--font);cursor:pointer;border-radius:11px;display:flex;align-items:center;justify-content:center;gap:7px}
.vid-side{} /* wrapper for desktop layout */

/* SAFE AREA */
@supports(padding-bottom:env(safe-area-inset-bottom)){
  .det-foot,body{padding-bottom:max(80px,env(safe-area-inset-bottom))}
  .fc{padding-bottom:max(8px,env(safe-area-inset-bottom))}
}
@media(min-width:960px){
  @supports(padding-bottom:env(safe-area-inset-bottom)){
    body{padding-bottom:0}
  }
}
/* REDUCED MOTION */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* ── FLOATING CART (mobile) ── */
.fc{
  position:fixed;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:480px;padding:8px 10px;
  padding-bottom:max(8px,env(safe-area-inset-bottom));
  background:rgba(255,255,255,.85);backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-top:1px solid var(--bd-s);z-index:100;
  transition:transform .2s,opacity .2s;border-radius:14px 14px 0 0;
}
.fc.hide{transform:translateX(-50%) translateY(100%);opacity:0;pointer-events:none}
.fc-btn{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  background:var(--ac);color:var(--ac-t);border:0;border-radius:12px;height:50px;padding:0 14px;
  font-size:14px;font-weight:700;font-family:var(--font);cursor:pointer;
}
.fc-btn:active{transform:scale(.98)}
.fc-l{display:flex;align-items:center;gap:8px}
.fc-c{background:rgba(255,255,255,.2);width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800}
.fc-t{font-size:16px;font-weight:800}

/* ── CART MODAL ── */
.cm-ov{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;display:none;align-items:flex-end;justify-content:center}
.cm-ov.show{display:flex}
.cm{background:var(--bg);width:100%;max-width:480px;max-height:86vh;border-radius:20px 20px 0 0;overflow:hidden;display:flex;flex-direction:column;animation:su .2s cubic-bezier(.16,1,.3,1)}
.cm-handle{width:36px;height:3.5px;background:var(--bd);border-radius:100px;margin:8px auto 3px}
.cm-hdr{padding:4px 16px 10px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--bd-s)}
.cm-title{font-size:17px;font-weight:800}
.cm-x{width:30px;height:30px;border-radius:50%;border:0;background:var(--bg-s);cursor:pointer;font-size:12px;color:var(--tx-s);font-family:var(--font);font-weight:600;display:flex;align-items:center;justify-content:center;transition:background .12s}
.cm-x:hover{background:var(--bd)}
.cm-body{flex:1;overflow-y:auto;padding:4px 0}
.ci{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid var(--bd-s)}
.ci:last-of-type{border-bottom:0}
.ci-img{width:48px;height:48px;border-radius:10px;object-fit:cover;flex-shrink:0}
.ci-info{flex:1;min-width:0}
.ci-nm{font-size:13px;font-weight:700;line-height:1.2}
.ci-pr{font-size:11px;color:var(--tx-m);margin-top:1px}
.ci-var{font-size:10px;color:var(--ac);font-weight:600;margin-top:1px}
.ci-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}
.ci-sub{font-size:14px;font-weight:800;white-space:nowrap}
.ci-q-wrap{display:flex;align-items:center;background:var(--bg-s);border-radius:7px;height:28px;padding:0 1px}
.ci-q-btn{width:26px;height:26px;border-radius:6px;border:0;background:0;color:var(--tx);font-size:14px;font-weight:700;font-family:var(--font);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s}
.ci-q-btn:active{background:var(--bd)}
.ci-q{font-size:11px;font-weight:700;min-width:16px;text-align:center}
.cm-sum{display:flex;justify-content:space-between;align-items:center;padding:12px 16px 6px;border-top:1.5px solid var(--bd);margin-top:4px}
.cm-sum-info{display:flex;flex-direction:column;gap:1px}
.cm-sum-l{font-size:15px;font-weight:800;color:var(--tx)}
.cm-sum-count{font-size:10px;color:var(--tx-m);font-weight:500}
.cm-sum-t{font-size:22px;font-weight:900;letter-spacing:-.3px}
.cm-form{padding:12px 16px 0;border-top:1px solid var(--bd-s)}
.fg{margin-bottom:10px}
.fl{font-size:9px;font-weight:700;color:var(--tx-m);text-transform:uppercase;letter-spacing:.7px;margin-bottom:4px;display:flex;align-items:center;gap:4px}
.fl svg{opacity:.4;flex-shrink:0}
.fi{width:100%;height:42px;padding:0 12px;border:1.5px solid var(--bd);border-radius:10px;font-size:13px;font-family:var(--font);outline:0;color:var(--tx);transition:border-color .12s,box-shadow .12s;background:var(--bg)}
.fi::placeholder{color:var(--tx-m)}
.fi:focus{border-color:var(--tx);box-shadow:0 0 0 3px rgba(0,0,0,.04)}
.cm-foot{padding:8px 16px;padding-bottom:max(10px,env(safe-area-inset-bottom))}
.wa-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:#25D366;color:#fff;border:0;border-radius:12px;height:50px;font-size:14px;font-weight:700;font-family:var(--font);cursor:pointer;transition:opacity .12s,transform .12s;box-shadow:0 2px 8px rgba(37,211,102,.25)}
.wa-btn:hover{opacity:.9}
.wa-btn:active{transform:scale(.97)}

/* TOAST */
.toast{position:fixed;top:14px;left:50%;transform:translateX(-50%) translateY(-80px);background:var(--tx);color:var(--bg);padding:8px 18px;border-radius:9px;font-size:12px;font-weight:700;z-index:700;transition:transform .2s cubic-bezier(.16,1,.3,1);pointer-events:none}
.toast.show{transform:translateX(-50%) translateY(0)}
.empty{text-align:center;padding:28px 16px;grid-column:1/-1}

/* =============================================
   TABLET — 640px+
   ============================================= */
@media(min-width:640px){
  .grid{grid-template-columns:repeat(3,1fr);gap:10px}
  .prods{padding:8px 18px}
  .hero{margin:10px 18px}
  .cats-in{padding:0 18px}
}

/* =============================================
   DESKTOP — 960px+ (Shopify-style)
   ============================================= */
@media(min-width:960px){
  body{max-width:1100px;margin:0 auto;padding-bottom:0;background:#fff}

  /* HEADER DESKTOP */
  .hdr{
    padding:0 28px;height:64px;
    border-bottom:1px solid var(--bd);
    display:flex;align-items:center;gap:0;
  }
  .hdr-left{display:flex;align-items:center;gap:12px;flex:0 0 auto;margin-right:24px;max-width:280px;min-width:0}
  .hdr-logo{width:42px;height:42px;border-radius:12px;font-size:15px}
  .hdr-brand{min-width:0}
  .hdr-name{font-size:18px;font-weight:900;letter-spacing:-.3px;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .hdr-sub{display:block;font-size:11px;color:var(--tx-m);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

  .hdr-center{flex:1 1 auto;display:flex;min-width:0;max-width:none}
  .srch-w{position:relative;width:100%;max-width:420px;margin:0 auto}
  .srch-i{
    width:100%;height:40px;padding:0 14px 0 38px;
    border:1.5px solid var(--bd);border-radius:10px;
    font-size:14px;font-family:var(--font);background:var(--bg-s);
    outline:0;transition:border-color .12s;color:var(--tx);
  }
  .srch-i::placeholder{color:var(--tx-m)}.srch-i:focus{border-color:var(--tx);background:var(--bg)}
  .srch-ic{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--tx-m);pointer-events:none}

  .hdr-right{display:flex;align-items:center;flex-shrink:0;margin-left:auto;gap:14px}
  .hdr-right .hdr-tags{display:flex;gap:8px}
  .hdr-tag{font-size:11px;color:var(--tx-s);display:flex;align-items:center;gap:4px}
  .hdr-tag svg{flex-shrink:0;opacity:.4}

  .hdr-cart{
    height:40px;border:0;border-radius:0;
    transition:opacity .15s;padding:0;gap:8px;
    display:flex;align-items:center;cursor:pointer;
    white-space:nowrap;background:none;
  }
  .hdr-cart:hover{opacity:.6}
  .hdr-cart svg{width:18px;height:18px;flex-shrink:0;color:var(--tx)}
  .hdr-cart-total{font-size:13px;font-weight:700;color:var(--tx);display:inline}
  .hdr-cart-count{
    position:static;width:auto;height:auto;border-radius:4px;
    background:var(--ac);color:#fff;font-size:10px;font-weight:800;
    padding:2px 6px;flex-shrink:0;
  }

  /* CATEGORIES: inline with header */
  .cats{
    padding:0;overflow-x:auto;white-space:nowrap;
    scrollbar-width:none;
    border-bottom:1px solid var(--bd);
    height:40px;display:flex;align-items:center;
  }
  .cats::-webkit-scrollbar{display:none}
  .cats-in{display:flex;gap:0;padding:0 24px}
  .cat{
    height:40px;padding:0 16px;font-size:12px;
    border-radius:0;border:0;border-bottom:2px solid transparent;
    background:none;color:var(--tx-m);
  }
  .cat:hover{color:var(--tx);border-bottom-color:var(--bd)}
  .cat.on{color:var(--tx);border-bottom-color:var(--tx);background:none}

  /* FEATURED HERO: wider, better proportioned */
  .hero{margin:10px 24px;border-radius:16px}
  .hero-img{aspect-ratio:2.5/1}
  .hero-over{padding:24px 28px}
  .hero-name{font-size:28px;max-width:50%}
  .hero-desc{font-size:13px;max-width:45%}
  .hero-price{font-size:30px}
  .hero-btn{width:auto;padding:0 20px;height:48px;border-radius:12px;gap:8px}
  .hero-btn-text{display:inline;font-size:14px;font-weight:700}

  /* GRID: 4 columns */
  .prods{padding:8px 24px}
  .grid{grid-template-columns:repeat(4,1fr);gap:14px}
  .card{border-radius:12px}
  .card-iw{aspect-ratio:.9}
  .card-nm{font-size:13px}
  .card-badge{font-size:10px;padding:5px 12px}
  .card-pf{padding:7px 14px}
  .card-pf-p{font-size:16px}
  .card-pf-c{font-size:11px}
  .card-pf-o{font-size:11px}
  .abtn{width:40px;height:40px;border-radius:11px}

  /* DETAIL PAGE: inline, not modal */
  .det-page{display:block;padding:0 24px}
  .det-layout{gap:28px}

  /* FOOTER: full desktop footer */
  .site-footer{
    margin-top:48px;
    background:#FAFAFA;border-top:1px solid var(--bd);
    padding:0;
  }
  .footer-inner{
    max-width:1100px;margin:0 auto;
    padding:32px 28px;
    display:grid;grid-template-columns:1fr auto auto;
    align-items:center;gap:24px;
  }
  .footer-brand{display:flex;align-items:center;gap:12px}
  .footer-logo{
    width:40px;height:40px;border-radius:10px;
    background:var(--tx);display:flex;align-items:center;justify-content:center;
    font-size:14px;font-weight:900;color:var(--bg);overflow:hidden;flex-shrink:0;
  }
  .footer-logo img{width:100%;height:100%;object-fit:cover}
  .footer-name{font-size:15px;font-weight:700}
  .footer-desc{font-size:11px;color:var(--tx-m);margin-top:1px}
  .footer-info{
    display:flex;flex-direction:column;gap:4px;
    font-size:12px;color:var(--tx-s);
  }
  .footer-info svg{vertical-align:-1px;opacity:.4}
  .footer-wa-btn{
    display:flex;align-items:center;gap:8px;
    background:#25D366;color:#fff;border:0;border-radius:10px;
    padding:12px 22px;font-size:14px;font-weight:700;font-family:var(--font);
    cursor:pointer;text-decoration:none;transition:opacity .12s;
    white-space:nowrap;
  }
  .footer-wa-btn:hover{opacity:.9}
  .footer-bottom{
    max-width:1100px;margin:0 auto;
    padding:12px 28px;border-top:1px solid var(--bd);
    font-size:10px;color:var(--tx-m);
    display:flex;justify-content:space-between;
  }

  /* FLOATING CART: hidden on desktop (use header cart icon) */
  .fc{display:none!important}

  /* CART: Side panel from right (Shopify-style) */
  .cm-ov{
    align-items:stretch;justify-content:flex-end;
    padding:0;background:rgba(0,0,0,.35);
  }
  .cm{
    max-width:420px;width:100%;max-height:none;height:100vh;
    border-radius:0;
    animation:slideRight .25s cubic-bezier(.16,1,.3,1);
    box-shadow:-8px 0 32px rgba(0,0,0,.1);
    display:flex;flex-direction:column;
  }
  @keyframes slideRight{from{transform:translateX(100%)}to{transform:translateX(0)}}
  @keyframes fd{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
  .cm-handle{display:none}
  .cm-hdr{
    padding:20px 24px 16px;
    border-bottom:1px solid var(--bd);
  }
  .cm-title{font-size:18px;font-weight:800}
  .cm-x{width:34px;height:34px;font-size:14px}
  .cm-body{
    flex:1;overflow-y:auto;padding:4px 0;
  }
  .ci{padding:14px 24px;gap:12px}
  .ci-img{width:56px;height:56px;border-radius:11px}
  .ci-nm{font-size:14px}
  .ci-pr{font-size:12px;margin-top:2px}
  .ci-var{font-size:11px}
  .ci-sub{font-size:16px}
  .cm-sum{padding:14px 24px 8px}
  .cm-sum-l{font-size:16px}
  .cm-sum-count{font-size:11px}
  .cm-sum-t{font-size:24px}
  .cm-form{
    padding:16px 24px 0;
    border-top:1px solid var(--bd);
  }
  .fg{margin-bottom:12px}
  .fl{font-size:10px;margin-bottom:5px}
  .fi{height:44px;font-size:14px;border-radius:10px}
  .cm-foot{
    padding:16px 24px 24px;
  }
  .wa-btn{height:54px;font-size:16px;border-radius:12px}

  /* VIDEO MODAL: side by side */
  .vid-m{max-width:560px;display:flex;flex-direction:row;border-radius:16px;box-shadow:0 16px 48px rgba(0,0,0,.2)}
  .vid-p{width:280px;flex-shrink:0;border-radius:16px 0 0 16px}
  .vid-side{flex:1;display:flex;flex-direction:column;justify-content:space-between}
  .vid-info{padding:18px 16px 10px}
  .vid-nm{font-size:15px}
  .vid-acts{padding:0 16px 18px}
  .vid-add{height:48px;font-size:15px;border-radius:12px}

  /* ========================================
     DETAIL PAGE - H&M Exact Structure
     All uses var(--font), var(--tx), var(--bg)
     ======================================== */
  .det-page{
    display:block;
    padding:0 40px 60px;
    max-width:1100px;
    margin:0 auto;
  }

  /* ── BACK BUTTON: aligned with left edge of photo ── */
  .det-back{
    margin-bottom:16px;font-size:12px;color:var(--tx-m);
    display:inline-flex;align-items:center;gap:4px;
    background:0;border:0;cursor:pointer;
    font-family:var(--font);font-weight:400;
    padding:6px 0;transition:color .12s;
    letter-spacing:.3px;
  }
  .det-back:hover{color:var(--tx)}

  /* ── TWO COLUMNS: 58/42, more gap ── */
  .det-layout{
    display:grid;
    grid-template-columns:58fr 42fr;
    gap:56px;
    align-items:start;
  }

  /* ── LEFT: GALLERY - vertical feed, H&M style ── */
  .det-gallery{
    display:block;
    position:relative;
  }
  .det-img-feed{
    display:flex;flex-direction:column;gap:4px;
  }

  /* Badge: hidden, now inside first image */
  .det-img-badge{display:none}
  .det-feed-badge{
    position:absolute;top:10px;left:10px;
    background:rgba(0,0,0,.85);backdrop-filter:blur(8px);color:#fff;
    font-size:10px;font-weight:700;padding:5px 12px;border-radius:8px;
    z-index:2;
  }

  .det-feed-item{
    width:100%;overflow:hidden;
  }
  .det-feed-item img{
    width:100%;display:block;
    object-fit:cover;aspect-ratio:.82;
  }

  /* Video item in feed */
  .det-feed-video{
    aspect-ratio:16/9;
    background:var(--tx);
    display:flex;flex-direction:column;
    align-items:center;justify-content:center;gap:8px;
    cursor:pointer;transition:opacity .15s;
  }
  .det-feed-video:hover{opacity:.85}
  .det-feed-play{
    width:64px;height:64px;border-radius:50%;
    background:rgba(255,255,255,.15);
    display:flex;align-items:center;justify-content:center;
  }
  .det-feed-video span{
    color:rgba(255,255,255,.6);font-size:12px;
    font-weight:500;letter-spacing:1px;text-transform:uppercase;
  }

  /* Hide old thumbnails/main-img on desktop */
  .det-main-img{display:none}
  .det-thumbs{display:none}
  .det-thumb{display:none}
  .det-thumb-vid{display:none}

  /* ── RIGHT: INFO PANEL (sticky while scrolling photos) ── */
  .det-info-panel{
    padding:8px 0 0 0;
    display:flex;flex-direction:column;gap:0;
    position:sticky;top:72px;
    max-height:calc(100vh - 90px);
    overflow-y:auto;
    scrollbar-width:none;
  }
  .det-info-panel::-webkit-scrollbar{display:none}
  .det-badge{display:none}

  /* Title: 26px, light weight, clean */
  .det-title{
    font-size:26px;font-weight:300;
    letter-spacing:-.2px;line-height:1.2;
    margin-bottom:0;
  }

  /* Description: 13px, muted */
  .det-description{
    font-size:13px;color:var(--tx-s);
    line-height:1.6;margin-top:8px;
  }

  /* Price: 20px, weight 400 */
  .det-price-block{
    display:flex;align-items:baseline;gap:10px;
    margin-top:16px;
  }
  .det-big-price{font-size:20px;font-weight:400;letter-spacing:0}
  .det-old-price{font-size:14px;color:var(--tx-m);text-decoration:line-through;font-weight:300}
  .det-discount{
    font-size:10px;font-weight:600;color:#E11D48;
    background:none;padding:0;
  }

  /* Divider */
  .det-divider{height:1px;background:#eee;margin:24px 0}

  /* ── OPTIONS: 24px between each ── */
  .det-option{margin-bottom:24px}

  /* Labels: uppercase, thin, elegant spacing */
  .det-option-label{
    font-size:11px;font-weight:400;color:var(--tx);
    text-transform:uppercase;letter-spacing:1.5px;
    margin-bottom:12px;
  }
  .det-option-value{
    font-weight:400;text-transform:none;letter-spacing:0;
    color:var(--tx-s);margin-left:8px;font-size:11px;
  }

  /* Colors: circles, double-ring on select, no overflow */
  .det-option-colors{display:flex;gap:14px;padding:4px}
  .det-colorcircle{
    width:28px;height:28px;border-radius:50%;
    border:1px solid #ddd;cursor:pointer;
    position:relative;transition:all .15s;
    flex-shrink:0;
  }
  .det-colorcircle:hover{transform:scale(1.06)}
  .det-colorcircle.on{
    border-color:var(--ac);
    box-shadow:0 0 0 2px var(--bg),0 0 0 3.5px var(--ac);
  }
  .det-colorcircle.on::after{content:'';display:none}

  /* Sizes: rounded to match system style */
  .det-option-grid,
  .det-option-chips{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(56px,1fr));
    gap:8px;
    max-width:340px;
  }
  .det-chip{
    height:44px;min-width:0;padding:0 4px;
    border-radius:10px;border:1.5px solid var(--bd);
    background:var(--bg);font-size:14px;font-weight:500;
    font-family:var(--font);cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    transition:all .12s;
  }
  .det-chip:hover{border-color:var(--ac)}
  .det-chip.on{background:var(--ac);color:#fff;border-color:var(--ac)}

  /* ── CTA SECTION ── */
  .det-cta-section{
    margin-top:28px;
    display:flex;flex-direction:column;gap:0;
  }

  /* Main CTA: accent color, consistent with mobile */
  .det-add-btn{
    width:100%;height:auto;padding:16px 0;border-radius:12px;
    background:var(--ac);border:0;color:#fff;
    font-size:14px;font-weight:700;font-family:var(--font);
    cursor:pointer;display:flex;align-items:center;justify-content:center;
    letter-spacing:1px;text-transform:uppercase;
    transition:opacity .15s;
  }
  .det-add-btn:hover{opacity:.85}

  /* Share row */
  .det-share-row{
    margin-top:20px;padding-top:20px;
    border-top:1px solid var(--bd);
    display:flex;align-items:center;gap:14px;
  }
  .det-share-label{
    font-size:11px;font-weight:500;color:var(--tx-m);
    text-transform:uppercase;letter-spacing:1.2px;
    flex-shrink:0;
  }
  .det-share-icons{display:flex;gap:10px}
  .det-share-icon{
    width:38px;height:38px;border-radius:50%;
    border:0;background:var(--bg-s);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;transition:all .15s;
    color:var(--tx);
  }
  .det-share-icon:hover{background:var(--tx);color:var(--bg)}
  .det-share-icon svg{fill:currentColor}

  /* Hide old wa button */
  .det-wa-btn{display:none}
  .det-wa-btn:hover{color:var(--tx)}
  .det-wa-btn svg{opacity:.4;width:14px;height:14px}

  /* Accordion-style extra links */
  .det-extra-link{
    padding:16px 0;
    border-top:1px solid #eee;
    font-size:13px;font-weight:400;color:var(--tx);
    cursor:pointer;display:flex;align-items:center;
    justify-content:space-between;
    transition:color .12s;letter-spacing:.3px;
    margin-top:0;
  }
  .det-extra-link:hover{color:var(--tx-s)}
  .det-extra-link svg{opacity:.3}

  /* Hide mobile detail elements on desktop */
  .det-actions{display:none}
  .det-share-btn{display:none}
  .det-video-btn{display:none}
}

/* =============================================
   LARGE DESKTOP — 1280px+
   ============================================= */
@media(min-width:1280px){
  body{max-width:1140px}
  .hdr-center{max-width:400px}
  .det-layout{gap:36px}
  .det-title{font-size:30px}
  .det-big-price{font-size:34px}

  .grid{gap:16px}
}
