/* ═══════════════════════════════════════════════════════════════
   withluv.in — Store CSS v10.0
   Font: Plus Jakarta Sans (body) + Cormorant Garamond (display)
   Palette: Warm white · Rose primary · Slate dark · Clean greys
   ═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600&display=swap');

:root {
  --primary:        #E8194B;
  --primary-dark:   #C0103A;
  --primary-light:  rgba(232,25,75,.07);
  --primary-border: rgba(232,25,75,.18);
  --shadow-p:       0 6px 20px rgba(232,25,75,.28);

  --dark:  #171520;
  --dark2: #2A2740;
  --mid:   #6B6882;
  --dim:   #9C9AB5;
  --light: #F4F3FA;
  --bg:    #F9F8FD;
  --line:  #ECEAF4;
  --white: #FFFFFF;
  --success: #0D9461;
  --green-light: rgba(13,148,97,.08);

  --r-xs:  4px;
  --r-sm:  8px;
  --r:     12px;
  --r-lg:  18px;
  --r-xl:  24px;
  --r-2xl: 32px;

  --shadow-xs: 0 1px 2px rgba(23,21,32,.05);
  --shadow-sm: 0 2px 8px rgba(23,21,32,.06), 0 1px 3px rgba(23,21,32,.04);
  --shadow:    0 4px 20px rgba(23,21,32,.08), 0 2px 6px rgba(23,21,32,.04);
  --shadow-lg: 0 16px 48px rgba(23,21,32,.12), 0 4px 14px rgba(23,21,32,.06);
  --shadow-xl: 0 32px 80px rgba(23,21,32,.16), 0 8px 24px rgba(23,21,32,.08);

  --font-d: 'Cormorant Garamond', Georgia, serif;
  --font-b: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --ease:   cubic-bezier(.25,.1,.25,1);
  --spring: cubic-bezier(.34,1.56,.64,1);
  --t:      .18s var(--ease);
}

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:var(--font-b);
  background:#fff;
  color:var(--dark);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.6;
}
::-webkit-scrollbar       { width:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--line); border-radius:4px; }
::-webkit-scrollbar-thumb:hover { background:var(--dim); }
a { text-decoration:none; color:inherit; }
img { max-width:100%; display:block; }
button,input,select,textarea { font-family:var(--font-b); }

/* ── Promo bar ─────────────────────────────────────────────── */
#promoBar {
  background:var(--dark);
  padding:9px 16px;
  text-align:center;
  position:relative;
  z-index:1100;
}
#promoBar p {
  color:rgba(255,255,255,.82);
  font-size:12.5px;
  font-weight:500;
  letter-spacing:.15px;
}

/* ── Header ────────────────────────────────────────────────── */
#siteHeader {
  position:sticky;
  top:0;
  z-index:900;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(20px) saturate(1.6);
  border-bottom:1px solid transparent;
  transition:border-color var(--t), box-shadow var(--t), background var(--t);
}
#siteHeader.scrolled {
  border-bottom-color:var(--line);
  box-shadow:0 1px 16px rgba(23,21,32,.06);
  background:rgba(255,255,255,.98);
}
.header-inner {
  max-width:1340px;
  margin:0 auto;
  padding:0 28px;
  height:64px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:20px;
}
.logo-wrap { display:flex; align-items:center; gap:9px; text-decoration:none; flex-shrink:0; }
.logo-wrap img { height:38px; object-fit:contain; transition:opacity .2s; }
.logo-text {
  font-family:var(--font-d);
  font-size:26px;
  font-weight:700;
  color:var(--dark);
  letter-spacing:-.3px;
}
.logo-text span { color:var(--primary); }
.header-nav { display:flex; justify-content:center; align-items:center; gap:2px; }
.header-nav a {
  padding:6px 14px;
  border-radius:100px;
  font-size:14px;
  font-weight:500;
  color:var(--mid);
  transition:var(--t);
  white-space:nowrap;
}
.header-nav a:hover { background:var(--light); color:var(--dark); }
.header-nav a.active { color:var(--primary); font-weight:600; }
.header-actions { display:flex; align-items:center; gap:6px; }
.search-wrap {
  display:flex; align-items:center;
  background:var(--light);
  border-radius:var(--r);
  padding:8px 13px;
  gap:8px;
  border:1.5px solid transparent;
  transition:var(--t);
}
.search-wrap:focus-within { border-color:var(--primary); background:#fff; box-shadow:0 0 0 3px var(--primary-light); }
.search-wrap input { border:none; background:none; font-size:13.5px; width:140px; color:var(--dark); outline:none; font-family:var(--font-b); }
.search-wrap input::placeholder { color:var(--dim); }
.btn-icon {
  width:40px; height:40px;
  border-radius:var(--r);
  border:none;
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  background:var(--light);
  transition:var(--t);
  position:relative;
  color:var(--dark);
}
.btn-icon:hover { background:var(--primary-light); color:var(--primary); }
.cart-badge {
  position:absolute; top:-5px; right:-5px;
  background:var(--primary); color:#fff;
  border-radius:50%; width:18px; height:18px;
  font-size:9px; font-weight:800;
  display:none; align-items:center; justify-content:center;
  border:2px solid #fff;
}
.ham-btn {
  display:none; flex-direction:column; gap:4.5px;
  width:40px; height:40px; align-items:center; justify-content:center;
  background:none; border:none; cursor:pointer; border-radius:var(--r);
}
.ham-btn span { display:block; height:2px; background:var(--dark); border-radius:2px; transition:var(--t); }
.ham-btn span:nth-child(1) { width:20px; }
.ham-btn span:nth-child(2) { width:14px; }
.ham-btn span:nth-child(3) { width:20px; }
.ham-btn.is-open span:nth-child(1) { transform:rotate(45deg) translate(4.5px,4.5px); width:20px; }
.ham-btn.is-open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.ham-btn.is-open span:nth-child(3) { transform:rotate(-45deg) translate(4.5px,-4.5px); width:20px; }
@media(max-width:860px) {
  .header-inner { grid-template-columns:44px 1fr 44px; padding:0 14px; height:58px; gap:0; }
  .logo-wrap    { grid-column:2; justify-content:center; }
  .ham-btn      { grid-column:1; display:flex; }
  .header-nav   { display:none !important; }
  .search-wrap  { display:none; }
  .header-actions { grid-column:3; justify-content:flex-end; }
  .header-actions .btn-icon:not(#cartBtn) { display:none; }
  .logo-wrap img { height:32px; }
  .logo-text { font-size:22px; }
}

/* ── Buttons ───────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  border:none; cursor:pointer; font-weight:600;
  border-radius:var(--r);
  transition:var(--t);
  font-family:var(--font-b);
  line-height:1;
  text-decoration:none;
  letter-spacing:-.01em;
}
.btn-primary {
  background:var(--primary); color:#fff;
  box-shadow:var(--shadow-p);
}
.btn-primary:hover {
  background:var(--primary-dark);
  transform:translateY(-1px);
  box-shadow:0 8px 28px rgba(232,25,75,.35);
}
.btn-primary:active { transform:none; box-shadow:var(--shadow-p); }
.btn-outline {
  background:#fff; color:var(--dark);
  border:1.5px solid var(--line);
}
.btn-outline:hover { border-color:var(--primary); color:var(--primary); background:var(--primary-light); }
.btn-dark { background:var(--dark); color:#fff; box-shadow:var(--shadow-sm); }
.btn-dark:hover { background:var(--dark2); transform:translateY(-1px); }
.btn-ghost { background:none; color:var(--mid); border:1.5px solid var(--line); }
.btn-ghost:hover { border-color:var(--primary); color:var(--primary); }
.btn-sm  { padding:8px 16px; font-size:13px; border-radius:var(--r-sm); }
.btn-md  { padding:11px 22px; font-size:14px; }
.btn-lg  { padding:13px 30px; font-size:15px; }
.btn-xl  { padding:16px 38px; font-size:15.5px; border-radius:var(--r-lg); }
.btn:disabled { opacity:.45; cursor:not-allowed; transform:none !important; }

/* ── Overlays & Drawers ────────────────────────────────────── */
.overlay { position:fixed; inset:0; background:rgba(23,21,32,.5); z-index:1900; opacity:0; pointer-events:none; transition:opacity .28s; }
.overlay.open { opacity:1; pointer-events:all; }

/* Cart drawer */
.cart-drawer {
  position:fixed; top:0; right:0; bottom:0; width:min(440px,100vw);
  z-index:2000; background:#fff;
  transform:translateX(102%);
  transition:transform .32s var(--ease);
  display:flex; flex-direction:column;
  box-shadow:-8px 0 48px rgba(23,21,32,.14);
}
.cart-drawer.open { transform:translateX(0); }
.cart-head {
  padding:20px 22px;
  border-bottom:1px solid var(--line);
  display:flex; justify-content:space-between; align-items:center;
  flex-shrink:0;
}
.cart-head h3 { font-size:16px; font-weight:700; }
.cart-body { flex:1; overflow-y:auto; padding:16px 22px; }
.cart-item {
  display:flex; gap:13px;
  background:var(--light); border-radius:var(--r-lg);
  padding:13px; margin-bottom:10px;
}
.cart-item-thumb {
  width:62px; height:62px; border-radius:var(--r);
  background:#fff; display:flex; align-items:center; justify-content:center;
  border:1px solid var(--line); flex-shrink:0; overflow:hidden;
}
.cart-item-thumb img { width:100%; height:100%; object-fit:cover; }
.cart-item-title { font-weight:700; font-size:13.5px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; margin-bottom:3px; }
.cart-item-price { font-size:12.5px; color:var(--primary); font-weight:700; margin-bottom:8px; }
.qty-ctrl { display:flex; align-items:center; background:#fff; border:1px solid var(--line); border-radius:var(--r-sm); overflow:hidden; width:fit-content; }
.qty-ctrl button { width:30px; height:30px; border:none; background:none; cursor:pointer; font-size:16px; color:var(--primary); font-weight:700; transition:var(--t); }
.qty-ctrl button:hover { background:var(--primary-light); }
.qty-ctrl span { width:28px; text-align:center; font-weight:700; font-size:13px; }
.cart-foot { padding:18px 22px; border-top:1px solid var(--line); flex-shrink:0; }
.coupon-row { display:flex; gap:8px; margin-bottom:14px; }
.coupon-row input { flex:1; padding:9px 12px; border-radius:var(--r-sm); border:1.5px solid var(--line); font-size:13px; outline:none; font-family:var(--font-b); transition:var(--t); }
.coupon-row input:focus { border-color:var(--primary); }
.price-row { display:flex; justify-content:space-between; font-size:13px; color:var(--mid); margin-bottom:7px; }
.price-total { font-size:17px; font-weight:800; color:var(--dark); border-top:1.5px solid var(--line); padding-top:12px; margin-top:8px; display:flex; justify-content:space-between; }

/* Nav drawer */
#navDrawer {
  position:fixed; top:0; left:0; bottom:0; width:min(300px,85vw);
  background:#fff; z-index:2000;
  transform:translateX(-102%);
  transition:transform .3s var(--ease);
  box-shadow:var(--shadow-xl);
  display:flex; flex-direction:column;
  overflow-y:auto;
}
#navDrawer.open { transform:translateX(0); }

/* ── Category strip (sticky under header) ──────────────────── */
.cat-strip {
  background:#fff;
  border-bottom:1px solid var(--line);
  position:sticky;
  top:64px;
  z-index:80;
}
.cat-strip-inner {
  max-width:1340px; margin:0 auto;
  padding:0 20px;
  display:flex; gap:0;
  overflow-x:auto;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
}
.cat-strip-inner::-webkit-scrollbar { display:none; }
.cat-strip-item {
  display:flex; flex-direction:column; align-items:center; gap:5px;
  padding:10px 16px;
  cursor:pointer; flex-shrink:0;
  text-decoration:none; color:inherit;
  border-bottom:2px solid transparent;
  transition:border-color var(--t);
  position:relative;
}
.cat-strip-item:hover { border-bottom-color:rgba(232,25,75,.3); }
.cat-strip-item.active { border-bottom-color:var(--primary); }
.cat-strip-emoji {
  width:34px; height:34px; border-radius:9px;
  background:var(--light);
  display:grid; place-items:center;
  font-size:15px;
  transition:background var(--t);
}
.cat-strip-item:hover .cat-strip-emoji { background:var(--primary-light); }
.cat-strip-item.active .cat-strip-emoji { background:var(--primary-light); }
.cat-strip-label {
  font-size:10.5px; font-weight:600;
  color:var(--mid); white-space:nowrap;
  transition:color var(--t);
}
.cat-strip-item:hover .cat-strip-label,
.cat-strip-item.active .cat-strip-label { color:var(--primary); }
@media(max-width:860px) {
  .cat-strip { top:58px; }
  .cat-strip-item { padding:8px 12px; }
}

/* ── Hero ──────────────────────────────────────────────────── */
.hero {
  background:#fff;
  overflow:hidden;
  position:relative;
}
/* Warm gradient blobs in background */
.hero::before {
  content:'';
  position:absolute;
  width:600px; height:600px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(232,25,75,.06) 0%, transparent 70%);
  top:-100px; right:-100px;
  pointer-events:none;
}
.hero-inner {
  max-width:1340px; margin:0 auto;
  padding:72px 28px 80px;
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  gap:72px;
  position:relative; z-index:1;
}
/* Rating pill */
.hero-rating {
  display:inline-flex; align-items:center; gap:9px;
  background:#fff; border:1px solid var(--line);
  border-radius:100px; padding:7px 16px 7px 10px;
  box-shadow:var(--shadow-sm);
  margin-bottom:22px;
}
.hero-rating-stars { display:flex; gap:2px; }
.hero-rating-stars svg { color:#F59E0B; }
.hero-rating-text { font-size:13px; color:var(--mid); font-weight:500; }
.hero-rating-text strong { color:var(--dark); font-weight:700; }
.hero-h1 {
  font-family:var(--font-d);
  font-size:clamp(42px,5.2vw,72px);
  font-weight:700;
  line-height:1.06;
  color:var(--dark);
  margin-bottom:20px;
  letter-spacing:-.5px;
}
.hero-h1 em { color:var(--primary); font-style:italic; }
.hero-sub {
  font-size:16px; color:var(--mid); line-height:1.8;
  margin-bottom:36px; max-width:440px; font-weight:400;
}
.hero-cta { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:44px; }
.hero-stats {
  display:flex; gap:28px; flex-wrap:wrap;
  padding-top:28px; border-top:1px solid var(--line);
}
.hero-stat-num {
  font-size:22px; font-weight:800; color:var(--dark);
  letter-spacing:-.5px; line-height:1;
  font-family:var(--font-d);
}
.hero-stat-lbl { font-size:12px; color:var(--dim); font-weight:500; margin-top:3px; }

/* Hero visual */
.hero-visual { position:relative; }
.hero-card-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.hero-prod-card {
  background:#fff;
  border-radius:var(--r-xl);
  padding:16px;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  cursor:pointer;
  animation:heroIn .5s var(--ease) both;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .2s;
}
.hero-prod-card:nth-child(1) { animation-delay:.1s; }
.hero-prod-card:nth-child(2) { animation-delay:.18s; margin-top:22px; }
.hero-prod-card:nth-child(3) { animation-delay:.14s; }
.hero-prod-card:nth-child(4) { animation-delay:.22s; margin-top:-22px; }
@keyframes heroIn { from { opacity:0; transform:translateY(18px); } to { opacity:1; transform:translateY(0); } }
.hero-prod-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:transparent; }
.hero-prod-img {
  width:100%; aspect-ratio:1;
  border-radius:var(--r);
  background:var(--light);
  overflow:hidden;
  margin-bottom:12px;
  display:flex; align-items:center; justify-content:center;
}
.hero-prod-img img { width:100%; height:100%; object-fit:cover; }
.hero-prod-name { font-weight:600; font-size:12.5px; color:var(--dark); margin-bottom:4px; line-height:1.35; }
.hero-prod-price { font-size:14.5px; font-weight:700; color:var(--primary); }
.hero-badge {
  position:absolute; top:-14px; right:0;
  background:var(--dark); color:#fff;
  border-radius:100px; padding:6px 14px;
  font-size:11.5px; font-weight:700; white-space:nowrap;
  box-shadow:var(--shadow-lg);
}
@media(max-width:1000px) { .hero-inner { gap:48px; padding:60px 22px 72px; } }
@media(max-width:800px) {
  .hero-inner { grid-template-columns:1fr; text-align:center; gap:0; padding:52px 18px 60px; }
  .hero-sub { margin:0 auto 36px; }
  .hero-cta { justify-content:center; }
  .hero-stats { justify-content:center; }
  .hero-visual { display:none; }
  .hero-rating { margin-left:auto; margin-right:auto; }
}

/* ── Marquee trust bar ─────────────────────────────────────── */
.marquee-wrap {
  overflow:hidden; background:var(--dark); padding:11px 0;
  position:relative;
}
.marquee-wrap::before, .marquee-wrap::after {
  content:''; position:absolute; top:0; bottom:0; width:80px; z-index:2; pointer-events:none;
}
.marquee-wrap::before { left:0; background:linear-gradient(to right,var(--dark),transparent); }
.marquee-wrap::after  { right:0; background:linear-gradient(to left,var(--dark),transparent); }
.marquee-track { display:flex; width:max-content; animation:marqueeRoll 30s linear infinite; }
.marquee-track:hover { animation-play-state:paused; }
@keyframes marqueeRoll { 0% { transform:translateX(0); } 100% { transform:translateX(-50%); } }
.marquee-item {
  display:inline-flex; align-items:center; gap:8px;
  padding:0 28px;
  font-size:12px; font-weight:600;
  color:rgba(255,255,255,.7); white-space:nowrap; letter-spacing:.15px;
}
.marquee-item svg { color:rgba(255,255,255,.38); flex-shrink:0; }
.marquee-dot { color:rgba(255,255,255,.18); margin:0 2px; }

/* ── Sections ──────────────────────────────────────────────── */
.section { padding:80px 28px; }
.section-inner { max-width:1340px; margin:0 auto; }
.section-head { text-align:center; margin-bottom:48px; }
.section-tag {
  display:inline-block;
  font-size:10.5px; font-weight:700;
  text-transform:uppercase; letter-spacing:2.5px;
  color:var(--primary); margin-bottom:12px;
}
.section-h2 {
  font-family:var(--font-d);
  font-size:clamp(28px,3.5vw,46px);
  font-weight:700; color:var(--dark);
  margin-bottom:12px; line-height:1.12;
  letter-spacing:-.4px;
}
.section-h2 em { color:var(--primary); font-style:italic; }
.section-sub { font-size:15px; color:var(--mid); max-width:400px; margin:0 auto; line-height:1.75; }
@media(max-width:600px) { .section { padding:60px 18px; } }

/* ── Tabbed product section ────────────────────────────────── */
.tab-section { padding:72px 28px; }
.tab-section .section-inner { max-width:1340px; margin:0 auto; }
.tab-section-head {
  display:flex; justify-content:space-between; align-items:flex-end;
  margin-bottom:24px; flex-wrap:wrap; gap:12px;
}
.tab-bar {
  display:flex; gap:0;
  overflow-x:auto; scrollbar-width:none;
  border-bottom:2px solid var(--line);
  margin-bottom:32px;
}
.tab-bar::-webkit-scrollbar { display:none; }
.tab-btn {
  padding:10px 20px;
  border:none; background:none; cursor:pointer;
  font-size:13.5px; font-weight:600; color:var(--mid);
  white-space:nowrap;
  border-bottom:2px solid transparent; margin-bottom:-2px;
  transition:all .18s; font-family:var(--font-b);
  display:flex; align-items:center; gap:7px;
}
.tab-btn:hover { color:var(--dark); }
.tab-btn.active { color:var(--primary); border-bottom-color:var(--primary); }
.tab-panel { display:none; }
.tab-panel.active { display:block; animation:tabFade .22s var(--ease); }
@keyframes tabFade { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }
@media(max-width:600px) { .tab-section { padding:52px 16px; } .tab-btn { padding:8px 14px; font-size:13px; } }

/* ── Category grid ─────────────────────────────────────────── */
.cat-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:12px; }
.cat-card {
  background:#fff; border:1px solid var(--line);
  border-radius:var(--r-lg); padding:22px 8px 18px;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  cursor:pointer; transition:var(--t); text-align:center;
}
.cat-card:hover { border-color:var(--primary); transform:translateY(-3px); box-shadow:0 8px 24px rgba(232,25,75,.1); }
.cat-icon { width:50px; height:50px; border-radius:13px; background:var(--light); display:flex; align-items:center; justify-content:center; transition:var(--t); }
.cat-card:hover .cat-icon { background:var(--primary); }
.cat-card:hover .cat-icon svg { stroke:#fff; }
.cat-name { font-weight:600; font-size:12px; color:var(--dark); letter-spacing:.05px; }
.cat-count { font-size:10px; color:var(--primary); font-weight:600; }
@media(max-width:900px) { .cat-grid { grid-template-columns:repeat(3,1fr); } }
@media(max-width:500px) { .cat-grid { grid-template-columns:repeat(2,1fr); gap:10px; } }

/* ── Product cards ─────────────────────────────────────────── */
.prod-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.prod-card {
  background:#fff; border-radius:var(--r-xl);
  overflow:hidden; border:1px solid var(--line);
  transition:transform .26s var(--ease), box-shadow .26s var(--ease), border-color .2s;
  cursor:pointer;
}
.prod-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:transparent; }
.prod-img {
  aspect-ratio:1; background:var(--light);
  display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
}
.prod-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s var(--ease); }
.prod-card:hover .prod-img img { transform:scale(1.05); }
.prod-img-overlay {
  position:absolute; inset:0;
  background:rgba(23,21,32,.32);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .22s;
}
.prod-card:hover .prod-img-overlay { opacity:1; }
.prod-img-placeholder {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:8px; color:var(--dim);
  width:100%; height:100%;
}
.prod-img-placeholder span { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.5px; }
.prod-badge { position:absolute; top:10px; left:10px; padding:4px 10px; border-radius:100px; font-size:10px; font-weight:700; color:#fff; letter-spacing:.3px; }
.prod-disc  { position:absolute; top:10px; right:10px; background:var(--dark); color:#fff; padding:4px 9px; border-radius:100px; font-size:10px; font-weight:700; }
.prod-custom-tag { position:absolute; bottom:10px; left:10px; background:rgba(93,63,211,.85); color:#fff; padding:3px 9px; border-radius:100px; font-size:9.5px; font-weight:700; letter-spacing:.3px; }
.prod-body  { padding:14px 16px 16px; }
.prod-meta  { display:flex; align-items:center; margin-bottom:5px; }
.prod-title { font-size:14px; font-weight:600; color:var(--dark); line-height:1.3; margin-bottom:10px; }
.prod-pricing { display:flex; align-items:baseline; gap:7px; }
.prod-price { font-size:17px; font-weight:800; color:var(--primary); }
.prod-orig  { font-size:12px; color:var(--dim); text-decoration:line-through; }
.prod-save-chip { font-size:10px; font-weight:700; color:var(--success); background:var(--green-light); padding:2px 8px; border-radius:100px; }
@media(max-width:1100px) { .prod-grid { grid-template-columns:repeat(3,1fr); } }
@media(max-width:760px)  { .prod-grid { grid-template-columns:repeat(2,1fr); gap:12px; } }
@media(max-width:400px)  { .prod-grid { grid-template-columns:1fr; } }

/* ── How it works ──────────────────────────────────────────── */
.hiw-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; }
.hiw-card {
  background:#fff; padding:36px 24px 32px;
  text-align:center; border:1px solid var(--line);
  position:relative; transition:var(--t);
}
.hiw-card:first-child { border-radius:var(--r-lg) 0 0 var(--r-lg); }
.hiw-card:last-child  { border-radius:0 var(--r-lg) var(--r-lg) 0; }
.hiw-card:hover { background:var(--bg); z-index:1; }
.hiw-num {
  position:absolute; top:16px; right:18px;
  font-family:var(--font-d); font-size:48px; font-weight:700;
  color:var(--line); line-height:1; user-select:none;
}
.hiw-icon { width:50px; height:50px; border-radius:14px; background:var(--primary-light); display:flex; align-items:center; justify-content:center; margin:0 auto 16px; }
.hiw-icon svg { stroke:var(--primary); }
.hiw-title { font-weight:700; font-size:15px; color:var(--dark); margin-bottom:7px; }
.hiw-desc  { font-size:13px; color:var(--mid); line-height:1.75; }
@media(max-width:900px) { .hiw-grid { grid-template-columns:1fr 1fr; gap:12px; } .hiw-card { border-radius:var(--r-lg) !important; } }
@media(max-width:500px) { .hiw-grid { grid-template-columns:1fr; } }

/* ── Testimonials ──────────────────────────────────────────── */
.test-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.test-card {
  background:#fff; border-radius:var(--r-xl);
  padding:26px; border:1px solid var(--line); transition:var(--t);
  position:relative;
}
.test-card:hover { border-color:var(--primary-border); box-shadow:var(--shadow); }
.test-card::before {
  content:'"'; position:absolute; top:16px; right:20px;
  font-family:var(--font-d); font-size:56px; line-height:1;
  color:var(--line); pointer-events:none;
}
.test-quote { font-size:14px; color:var(--dark); line-height:1.7; margin-bottom:18px; }
.test-author { display:flex; align-items:center; gap:10px; }
.test-avatar {
  width:38px; height:38px; border-radius:50%;
  background:var(--primary-light); border:1.5px solid var(--primary-border);
  display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:13px; color:var(--primary); flex-shrink:0;
}
.test-name { font-weight:700; font-size:13px; color:var(--dark); }
.test-loc  { font-size:11px; color:var(--dim); margin-top:1px; }
@media(max-width:900px) { .test-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:560px) { .test-grid { grid-template-columns:1fr; gap:12px; } }

/* ── Trust block ───────────────────────────────────────────── */
.trust-block { padding:52px 28px; background:#fff; }
.trust-block-inner { max-width:1340px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:28px; }
.trust-col { display:flex; flex-direction:column; align-items:center; text-align:center; gap:12px; }
.trust-col-icon { width:54px; height:54px; border-radius:16px; background:var(--primary-light); display:grid; place-items:center; color:var(--primary); }
.trust-col-title { font-weight:700; font-size:14px; color:var(--dark); }
.trust-col-desc  { font-size:12.5px; color:var(--mid); line-height:1.65; max-width:180px; }
@media(max-width:860px)  { .trust-block-inner { grid-template-columns:repeat(2,1fr); gap:24px; } }
@media(max-width:480px)  { .trust-block-inner { grid-template-columns:repeat(2,1fr); gap:18px; } .trust-block { padding:40px 18px; } }

/* ── Newsletter ────────────────────────────────────────────── */
.newsletter-strip { background:var(--dark); padding:52px 28px; }
.newsletter-inner  { max-width:540px; margin:0 auto; text-align:center; }
.newsletter-inner h3 { font-family:var(--font-d); font-size:clamp(22px,2.5vw,32px); font-weight:700; color:#fff; margin-bottom:8px; }
.newsletter-inner p  { font-size:14px; color:rgba(255,255,255,.45); margin-bottom:22px; line-height:1.65; }
.newsletter-form { display:flex; gap:8px; max-width:400px; margin:0 auto; }
.newsletter-form input {
  flex:1; padding:12px 16px; border-radius:var(--r);
  border:1.5px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.08);
  color:#fff; font-size:14px; font-family:var(--font-b); outline:none;
  transition:border-color .2s;
}
.newsletter-form input::placeholder { color:rgba(255,255,255,.3); }
.newsletter-form input:focus { border-color:var(--primary); }
.newsletter-form button {
  padding:12px 20px; background:var(--primary); color:#fff;
  border:none; border-radius:var(--r); font-size:14px; font-weight:700;
  cursor:pointer; font-family:var(--font-b); white-space:nowrap;
  transition:background .15s;
}
.newsletter-form button:hover { background:var(--primary-dark); }
@media(max-width:480px) { .newsletter-form { flex-direction:column; } .newsletter-strip { padding:40px 18px; } }

/* ── Mobile bottom dock ────────────────────────────────────── */
.mobile-dock {
  display:none;
  position:fixed; bottom:0; left:0; right:0;
  background:#fff; border-top:1px solid var(--line);
  z-index:800;
  box-shadow:0 -2px 16px rgba(23,21,32,.08);
  padding-bottom:env(safe-area-inset-bottom);
}
.dock-inner { display:flex; justify-content:space-around; padding:6px 0 4px; }
.dock-btn {
  display:flex; flex-direction:column; align-items:center; gap:3px;
  padding:5px 12px; background:none; border:none; cursor:pointer;
  font-size:9.5px; font-weight:700; color:var(--dim);
  transition:color .15s; text-decoration:none;
  font-family:var(--font-b); min-width:50px;
  text-transform:uppercase; letter-spacing:.4px;
}
.dock-btn.active, .dock-btn:hover { color:var(--primary); }
.dock-cart-rel { position:relative; }
.dock-badge {
  position:absolute; top:-4px; right:-4px;
  background:var(--primary); color:#fff;
  border-radius:50%; width:14px; height:14px;
  font-size:8px; font-weight:800;
  display:none; align-items:center; justify-content:center;
  border:1.5px solid #fff;
}
@media(max-width:767px) {
  .mobile-dock { display:block; }
  body { padding-bottom:calc(58px + env(safe-area-inset-bottom)); }
}

/* ── Footer ────────────────────────────────────────────────── */
.site-footer { background:var(--dark); color:rgba(255,255,255,.55); padding:68px 28px 28px; }
.footer-inner { max-width:1340px; margin:0 auto; }
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:44px; margin-bottom:52px;
  padding-bottom:44px; border-bottom:1px solid rgba(255,255,255,.07);
}
.footer-logo-text { font-family:var(--font-d); font-size:28px; font-weight:700; color:#fff; margin-bottom:14px; letter-spacing:-.3px; }
.footer-about { font-size:13px; line-height:1.75; color:rgba(255,255,255,.4); margin-bottom:22px; max-width:270px; }
.footer-social { display:flex; gap:9px; }
.footer-social a {
  width:35px; height:35px; border-radius:9px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08);
  display:grid; place-items:center;
  color:rgba(255,255,255,.45);
  transition:var(--t);
}
.footer-social a:hover { background:var(--primary); border-color:var(--primary); color:#fff; }
.footer-head { font-size:10px; font-weight:700; color:rgba(255,255,255,.35); text-transform:uppercase; letter-spacing:1.8px; margin-bottom:18px; }
.footer-links { display:flex; flex-direction:column; gap:10px; }
.footer-links a { font-size:13px; color:rgba(255,255,255,.45); transition:color .14s; line-height:1; }
.footer-links a:hover { color:#fff; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px; font-size:12px; color:rgba(255,255,255,.25); }
@media(max-width:860px) { .footer-grid { grid-template-columns:1fr 1fr; gap:28px; } .footer-grid > div:first-child { grid-column:1/-1; } }
@media(max-width:460px) { .footer-grid { grid-template-columns:1fr; } .site-footer { padding:48px 18px 24px; } }

/* ── Form inputs ───────────────────────────────────────────── */
.fi {
  padding:11px 14px; border-radius:var(--r-sm);
  border:1.5px solid var(--line);
  font-size:14px; outline:none;
  transition:border-color .2s, box-shadow .2s;
  font-family:var(--font-b); background:#fff; color:var(--dark);
  width:100%;
}
.fi:focus { border-color:var(--primary); box-shadow:0 0 0 3px var(--primary-light); }
.fi.err   { border-color:#EF4444; }
.fl { display:block; font-size:10.5px; font-weight:700; color:var(--mid); text-transform:uppercase; letter-spacing:.6px; margin-bottom:6px; }
.fg { display:flex; flex-direction:column; gap:5px; margin-bottom:14px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media(max-width:480px) { .form-row { grid-template-columns:1fr; } }

/* ── Product page ──────────────────────────────────────────── */
.prod-page   { max-width:1340px; margin:0 auto; padding:28px 28px 80px; }
.prod-layout { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start; }
.prod-gallery { position:sticky; top:88px; }
.gallery-main { border-radius:var(--r-xl); background:var(--light); aspect-ratio:1; overflow:hidden; border:1px solid var(--line); margin-bottom:10px; }
.gallery-main img { width:100%; height:100%; object-fit:contain; }
.gallery-thumbs { display:grid; grid-template-columns:repeat(4,1fr); gap:9px; }
.gallery-thumb { border-radius:var(--r); background:var(--light); aspect-ratio:1; display:flex; align-items:center; justify-content:center; cursor:pointer; border:2px solid transparent; transition:var(--t); overflow:hidden; }
.gallery-thumb.active { border-color:var(--primary); }
.gallery-thumb img { width:100%; height:100%; object-fit:cover; }
.prod-h1 { font-family:var(--font-d); font-size:clamp(24px,2.6vw,38px); font-weight:700; color:var(--dark); line-height:1.15; margin-bottom:12px; letter-spacing:-.3px; }
.prod-rating { display:flex; align-items:center; gap:8px; margin-bottom:18px; font-size:13px; color:var(--mid); }
.prod-price-block { display:flex; align-items:baseline; gap:10px; margin-bottom:20px; }
.prod-price-main { font-size:30px; font-weight:800; color:var(--primary); }
.prod-price-orig { font-size:16px; color:var(--dim); text-decoration:line-through; }
.prod-save-badge { background:var(--green-light); color:var(--success); padding:3px 10px; border-radius:100px; font-size:11px; font-weight:700; }
.prod-desc { font-size:14.5px; color:var(--mid); line-height:1.8; margin-bottom:22px; }
.custom-field { margin-bottom:18px; }
.custom-field label { display:block; font-size:10.5px; font-weight:700; color:var(--mid); text-transform:uppercase; letter-spacing:.6px; margin-bottom:7px; }
.prod-cta { display:flex; gap:10px; margin-top:22px; }
.prod-cta .btn { flex:1; }
.delivery-strip { display:flex; gap:18px; flex-wrap:wrap; padding:14px 0; margin-top:18px; border-top:1px solid var(--line); }
.delivery-item { display:flex; align-items:center; gap:7px; font-size:12px; font-weight:600; color:var(--mid); }
.delivery-item svg { color:var(--success); }
@media(max-width:900px) { .prod-layout { grid-template-columns:1fr; gap:28px; } .prod-gallery { position:static; } .prod-page { padding:18px 16px 80px; } }

/* ── Shop page ─────────────────────────────────────────────── */
.shop-wrap { max-width:1340px; margin:0 auto; padding:0 28px 80px; }
.shop-toolbar { display:flex; justify-content:space-between; align-items:center; margin-bottom:22px; flex-wrap:wrap; gap:12px; }
.filter-strip { display:flex; gap:7px; flex-wrap:wrap; }
.filter-chip { display:inline-flex; align-items:center; gap:5px; padding:6px 13px; border-radius:100px; font-size:13px; font-weight:600; border:1.5px solid var(--line); cursor:pointer; transition:var(--t); background:#fff; }
.filter-chip:hover, .filter-chip.active { background:var(--primary); border-color:var(--primary); color:#fff; }
.shop-count { font-size:13.5px; color:var(--mid); font-weight:500; }

/* ── Checkout page ─────────────────────────────────────────── */
.checkout-wrap { max-width:1120px; margin:0 auto; padding:32px 28px 80px; display:grid; grid-template-columns:1fr 380px; gap:24px; align-items:start; }
.co-card { background:#fff; border-radius:var(--r-xl); padding:26px; border:1.5px solid var(--line); margin-bottom:18px; }
.co-card h2 { font-family:var(--font-d); font-size:20px; font-weight:700; color:var(--dark); margin-bottom:20px; }
.step-bar { display:flex; align-items:center; margin-bottom:28px; }
.step-node { display:flex; flex-direction:column; align-items:center; gap:5px; }
.step-dot { width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; transition:.2s; }
.step-dot.active { background:var(--primary); color:#fff; box-shadow:0 0 0 4px var(--primary-light); }
.step-dot.done   { background:var(--primary); color:#fff; }
.step-dot.idle   { background:var(--light); color:var(--dim); }
.step-lbl { font-size:10px; font-weight:700; color:var(--dim); text-transform:uppercase; letter-spacing:.5px; }
.step-lbl.active, .step-lbl.done { color:var(--primary); }
.step-line { flex:1; height:2px; background:var(--line); margin:0 8px 16px; transition:background .3s; }
.pay-opt { display:flex; align-items:center; gap:12px; background:var(--bg); border:1.5px solid var(--line); border-radius:var(--r-lg); padding:13px 15px; cursor:pointer; transition:var(--t); margin-bottom:9px; }
.pay-opt:hover { border-color:var(--primary); }
.pay-opt.sel { background:var(--primary-light); border-color:var(--primary); }
.pay-opt-icon { width:40px; height:40px; border-radius:var(--r-sm); background:#fff; display:flex; align-items:center; justify-content:center; border:1px solid var(--line); flex-shrink:0; }
.pay-opt-title { font-weight:700; font-size:14px; color:var(--dark); }
.pay-opt-sub   { font-size:12px; color:var(--mid); margin-top:1px; }
.radio-dot { width:17px; height:17px; border-radius:50%; border:2px solid var(--primary); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.sum-item { display:flex; gap:11px; align-items:center; padding:10px 0; border-bottom:1px solid var(--line); }
.sum-item:last-child { border-bottom:none; }
.sum-thumb { width:46px; height:46px; border-radius:var(--r-sm); background:var(--light); display:flex; align-items:center; justify-content:center; flex-shrink:0; overflow:hidden; }
.sum-thumb img { width:100%; height:100%; object-fit:cover; }
.secure-badge { display:flex; align-items:center; gap:8px; background:var(--light); border-radius:var(--r-sm); padding:10px 13px; margin-top:12px; font-size:12px; font-weight:600; color:var(--mid); }
@media(max-width:860px) { .checkout-wrap { grid-template-columns:1fr; padding:18px 16px 80px; } }

/* ── Success page ──────────────────────────────────────────── */
.success-page { min-height:70vh; display:flex; align-items:center; justify-content:center; text-align:center; padding:60px 24px; }
.success-icon { width:76px; height:76px; border-radius:50%; background:linear-gradient(135deg,var(--primary),#FF6B9D); display:flex; align-items:center; justify-content:center; margin:0 auto 24px; box-shadow:0 10px 30px rgba(232,25,75,.3); }

/* ── Spotify components ────────────────────────────────────── */
.sp-search-wrap { position:relative; }
.sp-box { display:flex; align-items:center; gap:10px; background:#0F0E18; border:1.5px solid #1DB954; border-radius:12px; padding:11px 15px; transition:box-shadow .2s; }
.sp-box:focus-within { box-shadow:0 0 0 3px rgba(29,185,84,.2); }
.sp-inp { flex:1; background:none; border:none; outline:none; color:#fff; font-size:14px; font-family:var(--font-b); }
.sp-inp::placeholder { color:rgba(255,255,255,.35); }
.sp-clr { background:rgba(255,255,255,.1); border:none; color:rgba(255,255,255,.6); width:20px; height:20px; border-radius:50%; cursor:pointer; font-size:11px; display:none; align-items:center; justify-content:center; }
.sp-clr.on { display:flex; }
.sp-drop { position:absolute; top:calc(100%+5px); left:0; right:0; background:#141414; border:1px solid rgba(255,255,255,.1); border-radius:12px; overflow:hidden; box-shadow:0 16px 48px rgba(0,0,0,.7); z-index:200; max-height:340px; overflow-y:auto; display:none; }
.sp-drop.on { display:block; animation:tabFade .16s ease; }
.sp-drop::-webkit-scrollbar { width:3px; } .sp-drop::-webkit-scrollbar-thumb { background:rgba(255,255,255,.1); }
.sp-stat { padding:13px 16px; font-size:13px; color:rgba(255,255,255,.4); display:flex; align-items:center; gap:9px; }
.sp-spin { width:13px; height:13px; border:2px solid rgba(29,185,84,.25); border-top-color:#1DB954; border-radius:50%; animation:spSpin .7s linear infinite; flex-shrink:0; }
@keyframes spSpin { to { transform:rotate(360deg); } }
.sp-row { display:flex; align-items:center; gap:11px; padding:9px 15px; cursor:pointer; border-bottom:1px solid rgba(255,255,255,.04); transition:background .12s; }
.sp-row:last-child { border-bottom:none; } .sp-row:hover { background:rgba(29,185,84,.1); }
.sp-art { width:40px; height:40px; border-radius:6px; object-fit:cover; flex-shrink:0; background:#222; }
.sp-art-ph { width:40px; height:40px; border-radius:6px; background:#222; display:grid; place-items:center; flex-shrink:0; }
.sp-inf { flex:1; min-width:0; }
.sp-nm { font-size:14px; font-weight:600; color:#fff; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sp-mt { font-size:11px; color:rgba(255,255,255,.45); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-top:1px; }
.sp-dur { font-size:11px; color:rgba(255,255,255,.25); flex-shrink:0; }
.sp-card { background:linear-gradient(135deg,#0c1a0f,#091610); border:1.5px solid #1DB954; border-radius:12px; padding:13px 15px; display:flex; align-items:center; gap:12px; margin-top:8px; animation:tabFade .2s ease; }
.sp-card-art { width:50px; height:50px; border-radius:7px; object-fit:cover; flex-shrink:0; }
.sp-card-info { flex:1; min-width:0; }
.sp-card-name { font-size:14px; font-weight:700; color:#fff; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sp-card-artname { font-size:12px; color:rgba(255,255,255,.55); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sp-card-tag { font-size:10px; font-weight:700; color:#1DB954; text-transform:uppercase; letter-spacing:.5px; margin-top:4px; }
.sp-card-mini { display:flex; flex-direction:column; align-items:center; gap:6px; flex-shrink:0; }
.sp-play { width:32px; height:32px; border-radius:50%; background:#1DB954; border:none; color:#fff; display:grid; place-items:center; cursor:pointer; transition:transform .1s; }
.sp-play:hover { transform:scale(1.1); }
.sp-change { font-size:11px; color:rgba(255,255,255,.4); background:none; border:none; cursor:pointer; text-decoration:underline; white-space:nowrap; }
.sp-prog { height:2px; background:rgba(255,255,255,.1); border-radius:1px; margin-top:6px; display:none; }
.sp-prog.on { display:block; }
.sp-prog-bar { height:100%; background:#1DB954; border-radius:1px; width:0%; transition:width .5s linear; }

/* ── Animations ────────────────────────────────────────────── */
@keyframes fadeUp { from { opacity:0; transform:translateY(16px); } to { opacity:1; transform:translateY(0); } }
@keyframes pageFadeIn { from { opacity:0; transform:translateY(4px); } to { opacity:1; transform:translateY(0); } }
@keyframes shimmer { 0% { background-position:200% 0; } 100% { background-position:-200% 0; } }

.hero-rating { animation:fadeUp .4s var(--ease) .05s both; }
.hero-h1     { animation:fadeUp .5s var(--ease) .1s both; }
.hero-sub    { animation:fadeUp .5s var(--ease) .16s both; }
.hero-cta    { animation:fadeUp .5s var(--ease) .22s both; }
.hero-stats  { animation:fadeUp .5s var(--ease) .28s both; }

.fade-in-up { opacity:0; transform:translateY(18px); transition:opacity .5s var(--ease), transform .5s var(--ease); }
.fade-in-up.visible { opacity:1; transform:translateY(0); }

main, .hero, .shop-wrap, .prod-page, .checkout-wrap { animation:pageFadeIn .28s var(--ease) both; }

.skel {
  background:linear-gradient(90deg,#F2F1F7 25%,#E8E7F0 50%,#F2F1F7 75%);
  background-size:200% 100%;
  animation:shimmer 1.4s infinite;
  border-radius:var(--r);
}

/* ── Step builder ──────────────────────────────────────────── */
#stepPanels > div { transition:opacity .2s, transform .2s; }
[id^="upArea_"], [id^="upDrop_"] { transition:border-color .2s, background .2s; }

/* ── Misc utility ──────────────────────────────────────────── */
.section-dark { background:var(--dark); padding:72px 28px; }
.section-dark .section-tag { color:rgba(255,255,255,.4); }
.section-dark .section-h2  { color:#fff; }
.section-dark .section-sub { color:rgba(255,255,255,.45); }
.prod-save-badge { display:inline-block; padding:3px 10px; background:var(--green-light); color:var(--success); border-radius:100px; font-size:11px; font-weight:700; }
