/* =============================================
   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,transform .25s;
}
.hdr.hdr-hidden{transform:translateY(-100%);box-shadow:none}
.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{display:none}

.hdr-center{flex:1 1 auto;display:flex;padding:0 6px;min-width:0}
.srch-w{position:relative;width:100%}
.srch-i{
  width:100%;height:38px;padding:0 8px 0 28px;
  border:1.5px solid var(--bd);border-radius:9px;
  font-size:16px;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:3/4;position:relative;overflow:hidden;background:var(--bg-s);border-radius:10px 10px 0 0}
.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:44px;height:44px;border-radius:12px;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;
}
.abtn:active{transform:scale(.82)}
.abtn:hover{opacity:.9}
.abtn svg{color:var(--ac-t);width:18px;height:18px}
.qc{display:flex;align-items:center;background:var(--tx);border-radius:12px;height:44px;padding:0 3px;flex-shrink:0}
.qb{width:36px;height:40px;border-radius:9px;border:0;background:0;color:var(--bg);font-size:18px;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:44px;height:44px;border-radius:50%;background:rgba(0,0,0,.4);border:0;color:#fff;font-size:16px;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-slides>div{width:100%;height:100%;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)}

/* Mobile: reviews + trust badges */
.det-reviews{display:flex;align-items:center;gap:6px}
.det-stars{display:flex;gap:1px}
.det-reviews-text{font-size:11px;color:var(--tx-m);font-weight:600}
.det-desc-inline{display:none}
.det-mob-policies{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
.det-mob-pol{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:var(--tx-s);background:var(--bg-s);padding:6px 10px;border-radius:8px}
.det-mob-pol svg{flex-shrink:0}
.det-policies{display:none}
.det-wa-direct{display:none}
.det-share-row{display:none}

/* ── 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;
  border-top:1px solid var(--bd);
  padding:20px 16px;
}
.footer-inner{
  display:flex;flex-direction:column;align-items:center;gap:12px;
  max-width:1400px;margin:0 auto;
}
.footer-brand{display:flex;align-items:center;gap:8px}
.footer-logo{
  width:28px;height:28px;border-radius:8px;
  background:var(--tx);display:flex;align-items:center;justify-content:center;
  font-size:10px;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:13px;font-weight:700;color:var(--tx)}
.footer-social-icons{display:flex;gap:6px}
.footer-social-icon{width:32px;height:32px;border-radius:50%;background:var(--bg-s);display:flex;align-items:center;justify-content:center;color:var(--tx-m);transition:all .15s;text-decoration:none}
.footer-social-icon:hover{background:var(--ac);color:#fff;transform:scale(1.05)}
.footer-bottom{
  font-size:10px;color:var(--tx-m);
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:5px;
}
.footer-powered{color:var(--tx-m);text-decoration:none;transition:color .15s}
.footer-powered:hover{color:var(--ac)}
.footer-powered strong{color:var(--tx-s)}
.footer-cloud{color:var(--tx-m)}
.footer-sep{color:var(--bd);font-size:6px}

/* ── 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-btn.ci-q-dis,.ci-q-btn:disabled{opacity:.3;cursor:not-allowed}
.ci-q{font-size:11px;font-weight:700;min-width:16px;text-align:center}
.ci-del{width:28px;height:28px;border:0;border-radius:7px;background:0;color:var(--tx-m);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s;margin-top:2px}
.ci-del:hover{background:#FEE2E2;color:#E11D48}
.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)}
.fi-sel{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239CA3AF' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer}
.fi-sel:disabled{opacity:.45;cursor:not-allowed;background-color:var(--bg-s)}
.fg-row{display:flex;gap:8px}
.fg-half{flex:1;min-width:0}
.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:1400px;margin:0 auto;padding-bottom:0;background:#fff}

  /* HEADER DESKTOP — clean 3-section layout */
  .hdr{
    padding:0 40px;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;min-width:0}
  .hdr-logo{width:38px;height:38px;border-radius:10px;font-size:14px}
  .hdr-brand{min-width:0}
  .hdr-name{font-size:17px;font-weight:800;letter-spacing:-.3px;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .hdr-sub{display:none}

  .hdr-center{flex:1 1 auto;display:flex;min-width:0;max-width:none;padding:0 32px}
  .srch-w{position:relative;width:100%;max-width:none;margin:0}
  .srch-i{
    width:100%;height:42px;padding:0 16px 0 40px;
    border:1.5px solid var(--bd);border-radius:100px;
    font-size:14px;font-family:var(--font);background:var(--bg-s);
    outline:0;transition:border-color .15s,box-shadow .15s;color:var(--tx);
  }
  .srch-i::placeholder{color:var(--tx-m)}
  .srch-i:focus{border-color:var(--tx);background:var(--bg);box-shadow:0 0 0 3px rgba(0,0,0,.04)}
  .srch-ic{position:absolute;left:14px;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:0}
  .hdr-right .hdr-tags{display:none}

  .hdr-cart{
    height:42px;border:0;border-radius:100px;
    transition:all .15s;padding:0 16px;gap:8px;
    display:flex;align-items:center;cursor:pointer;
    white-space:nowrap;background:var(--bg-s);
  }
  .hdr-cart:hover{background:var(--bg-m)}
  .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;max-width:120px;overflow:hidden;text-overflow:ellipsis}
  .hdr-cart-count{
    position:static;width:auto;height:auto;border-radius:100px;
    background:var(--ac);color:#fff;font-size:10px;font-weight:800;
    padding:2px 7px;flex-shrink:0;
  }

  /* CATEGORIES: centered nav */
  .cats{
    padding:0;overflow-x:auto;white-space:nowrap;
    scrollbar-width:none;
    border-bottom:1px solid var(--bd);
    height:44px;display:flex;align-items:center;
    justify-content:center;
  }
  .cats::-webkit-scrollbar{display:none}
  .cats-in{display:flex;gap:4px;padding:0 36px;justify-content:center}
  .cat{
    height:44px;padding:0 20px;font-size:13px;font-weight:500;
    border-radius:0;border:0;border-bottom:2.5px solid transparent;
    background:none;color:var(--tx-m);
    transition:color .15s,border-color .15s;letter-spacing:.2px;
  }
  .cat:hover{color:var(--tx);border-bottom-color:var(--bd)}
  .cat.on{color:var(--tx);border-bottom-color:var(--ac);background:none;font-weight:700}

  /* FEATURED HERO: wider, better proportioned */
  .hero{margin:16px 36px;border-radius:20px}
  .hero-img{aspect-ratio:2.8/1}
  .hero-over{padding:32px 36px}
  .hero-name{font-size:32px;max-width:50%;letter-spacing:-.5px}
  .hero-desc{font-size:14px;max-width:45%;line-height:1.5}
  .hero-price{font-size:32px}
  .hero-btn{width:auto;padding:0 28px;height:52px;border-radius:14px;gap:10px}
  .hero-btn-text{display:inline;font-size:15px;font-weight:700}

  /* GRID: 4 columns */
  .prods{padding:12px 36px}
  .prods-t{font-size:13px;color:var(--tx-m);margin-bottom:8px}
  .grid{grid-template-columns:repeat(4,1fr);gap:16px}
  .card{border-radius:14px;transition:transform .15s,box-shadow .15s}
  .card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.08)}
  .card-iw{aspect-ratio:.85}
  .card-nm{font-size:13px}
  .card-badge{font-size:10px;padding:5px 12px}
  .card-pf{padding:8px 14px}
  .card-pf-p{font-size:16px}
  .card-pf-c{font-size:11px}
  .card-pf-o{font-size:11px}
  .abtn{width:42px;height:42px;border-radius:12px}

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

  /* FOOTER: desktop */
  .site-footer{
    margin-top:48px;
    padding:20px 40px;
  }
  .footer-inner{
    flex-direction:row;justify-content:center;align-items:center;gap:20px;
  }
  .footer-bottom{margin-top:0}

  /* 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:1300px;
    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 ── */
  /* Reviews */
  .det-reviews{display:flex;align-items:center;gap:8px;margin-top:8px}
  .det-stars{display:flex;gap:1px}
  .det-reviews-text{font-size:12px;color:var(--tx-m);font-weight:500}

  /* Description inline */
  .det-desc-inline{font-size:14px;color:var(--tx-s);line-height:1.7;margin:16px 0 4px}

  .det-cta-section{
    margin-top:24px;
    display:flex;flex-direction:column;gap:10px;
  }

  /* Main CTA */
  .det-add-btn{
    width:100%;height:auto;padding:16px 0;border-radius:14px;
    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:10px;
    letter-spacing:.3px;
    transition:all .15s;
  }
  .det-add-btn:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.15)}

  /* WhatsApp direct button */
  .det-wa-direct{
    width:100%;height:auto;padding:14px 0;border-radius:14px;
    background:transparent;border:1.5px solid var(--bd);color:var(--tx);
    font-size:14px;font-weight:600;font-family:var(--font);
    cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;
    transition:all .15s;
  }
  .det-wa-direct:hover{border-color:var(--tx);background:var(--bg-s)}

  /* Trust policies */
  .det-policies{
    margin-top:24px;padding-top:24px;
    border-top:1px solid var(--bd);
    display:flex;flex-direction:column;gap:16px;
  }
  .det-policy{display:flex;align-items:flex-start;gap:12px}
  .det-policy svg{flex-shrink:0;margin-top:1px}
  .det-policy-title{font-size:13px;font-weight:600;color:var(--tx);line-height:1.3}
  .det-policy-sub{font-size:11px;color:var(--tx-m);margin-top:1px}

  /* 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:1px;
    flex-shrink:0;
  }
  .det-share-icons{display:flex;gap:8px}
  .det-share-icon{
    width:36px;height:36px;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-m);
  }
  .det-share-icon:hover{background:var(--tx);color:var(--bg)}
  .det-share-icon svg{fill:currentColor}

  /* Hide mobile elements on desktop */
  .det-wa-btn{display:none}
  .det-mob-policies{display:none}
  .det-desc-inline{display:block}

  /* 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:1400px}
  .hdr{padding:0 40px}
  .hdr-center{max-width:none}
  .grid{grid-template-columns:repeat(5,1fr);gap:18px}
  .prods{padding:16px 40px}
  .hero{margin:18px 40px}
  .det-layout{gap:48px}
  .det-title{font-size:32px}
  .det-big-price{font-size:36px}
  .cats-in{gap:6px}
  .cat{padding:0 24px;font-size:13px}
}
