/* ============================================================
   BePink shared design system — pink · Fraunces + Poppins
   (matches the Figma-derived cinematic build)
   ============================================================ */
:root{
  --pink-50:#FFF5FA;--pink-100:#FFE7F2;--pink-200:#FFD0E6;--pink-300:#FCAFD3;
  --pink-400:#F87FB8;--pink-500:#EC4899;--pink-600:#DB2777;--pink-700:#BE185D;
  --ink:#3B1F2E;--ink-soft:#8A6677;--cream:#FFF8FC;--line:#F4D9E8;
  --grad:linear-gradient(135deg,#F87FB8 0%,#DB2777 100%);
  --shadow:0 18px 50px -22px rgba(219,39,119,.45);
  --shadow-sm:0 8px 28px -16px rgba(219,39,119,.4);
  --r:22px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Poppins',sans-serif;color:var(--ink);background:var(--cream);-webkit-font-smoothing:antialiased;
  opacity:0;animation:pageIn .5s ease forwards;}
@keyframes pageIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
h1,h2,h3{font-family:'Fraunces',serif;font-weight:600;line-height:1.08;letter-spacing:-.01em;}
.wrap{max-width:1240px;margin:0 auto;padding:0 24px;}
.eyebrow{font-family:'Poppins';font-size:12px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--pink-600);}
.muted{color:var(--ink-soft);}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:600;font-size:15px;
  border-radius:40px;padding:14px 28px;transition:transform .25s,box-shadow .25s,background .25s,color .25s;white-space:nowrap;}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--shadow);}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 26px 60px -22px rgba(219,39,119,.6);}
.btn-primary:active{transform:translateY(-1px) scale(.99);}
.btn-ghost{background:#fff;color:var(--pink-700);border:1.5px solid var(--pink-200);}
.btn-ghost:hover{background:var(--pink-50);border-color:var(--pink-400);transform:translateY(-2px);}
.btn-block{width:100%;}
.btn-sm{padding:11px 20px;font-size:14px;}

/* ---- HEADER (bigger logo + tagline) ---- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,248,252,.86);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:box-shadow .3s,border-color .3s;}
.site-header.scrolled{box-shadow:0 6px 30px -18px rgba(219,39,119,.45);border-color:var(--line);}
.nav{display:flex;align-items:center;justify-content:space-between;height:84px;gap:20px;}
.brand{display:flex;flex-direction:column;line-height:1;}
.brand .bw{font-family:'Fraunces',serif;font-weight:700;font-size:40px;letter-spacing:-.02em;color:var(--ink);}
.brand .bw b{color:var(--pink-500);}
.brand .tagline{font-family:'Poppins';font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin-top:3px;}
.menu{display:flex;gap:28px;list-style:none;}
.menu a{font-size:14.5px;font-weight:500;position:relative;padding:6px 0;transition:color .2s;}
.menu a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--grad);border-radius:2px;transition:width .25s;}
.menu a:hover{color:var(--pink-600);} .menu a:hover::after,.menu a.active::after{width:100%;}
.hicons{display:flex;align-items:center;gap:14px;}
.hicons a,.hicons button{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;color:var(--ink);transition:.2s;position:relative;}
.hicons a:hover,.hicons button:hover{background:var(--pink-100);color:var(--pink-600);}
.hicons svg{width:22px;height:22px;}
.cart-count{position:absolute;top:2px;right:2px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;
  background:var(--pink-600);color:#fff;font-size:11px;font-weight:700;display:grid;place-items:center;}
.burger{display:none;}

/* ---- section heads ---- */
.shead{text-align:center;max-width:680px;margin:0 auto 44px;}
.shead h2{font-size:clamp(28px,3.6vw,46px);margin:12px 0 12px;}
.shead p{color:var(--ink-soft);font-size:16px;line-height:1.6;}
section.block{padding:70px 0;}
.bg-pink{background:linear-gradient(180deg,var(--pink-50),#fff);}

/* ---- category strip ---- */
.cat-row{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;}
.cat-card{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:3/4;box-shadow:var(--shadow-sm);
  display:flex;align-items:flex-end;color:#fff;transition:transform .35s,box-shadow .35s;cursor:pointer;background:var(--grad);}
.cat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.cat-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.9;}
.cat-card .cc-tint{position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(60,10,34,.72));}
.cat-card .cc-body{position:relative;padding:18px;z-index:2;}
.cat-card .cc-body h3{font-size:20px;color:#fff;}
.cat-card .cc-body span{font-size:12px;opacity:.85;}

/* ---- product grid ---- */
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.pcard{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .35s,box-shadow .35s;display:flex;flex-direction:column;position:relative;}
.pcard:hover{transform:translateY(-8px);box-shadow:var(--shadow);}
.pcard .ph{position:relative;aspect-ratio:4/5;background:linear-gradient(160deg,var(--pink-100),var(--pink-200));overflow:hidden;}
.pcard .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s;}
.pcard:hover .ph img{transform:scale(1.06);}
.pcard .tag{position:absolute;top:14px;left:14px;background:#fff;color:var(--pink-700);font-size:11px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;padding:6px 12px;border-radius:20px;box-shadow:var(--shadow-sm);}
.pbody{padding:18px;display:flex;flex-direction:column;gap:6px;flex:1;}
.stars{color:#F5B301;font-size:13px;letter-spacing:1px;}
.pbody .pname{font-weight:600;font-size:16px;line-height:1.25;}
.pbody .pblurb{font-size:12.5px;color:var(--ink-soft);line-height:1.45;}
.prow{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:10px;}
.price{font-family:'Fraunces';font-size:19px;font-weight:600;color:var(--pink-700);}
.addbtn{background:var(--grad);color:#fff;border-radius:40px;padding:10px 18px;font-size:13.5px;font-weight:600;
  box-shadow:var(--shadow-sm);transition:transform .2s;}
.addbtn:hover{transform:translateY(-2px) scale(1.03);}

/* ---- cart / checkout ---- */
.cart-wrap{display:grid;grid-template-columns:1.6fr 1fr;gap:40px;align-items:start;}
.cart-list{display:flex;flex-direction:column;gap:14px;}
.cart-item{display:flex;gap:16px;background:#fff;border-radius:18px;padding:14px;box-shadow:var(--shadow-sm);align-items:center;}
.cart-item .ci-img{width:84px;height:96px;border-radius:14px;overflow:hidden;flex:0 0 84px;background:var(--pink-100);}
.cart-item .ci-img img{width:100%;height:100%;object-fit:cover;}
.cart-item .ci-info{flex:1;}
.cart-item .ci-info b{font-weight:600;}
.cart-item .ci-opt{font-size:12px;color:var(--ink-soft);}
.qty{display:inline-flex;align-items:center;gap:10px;border:1.5px solid var(--line);border-radius:30px;padding:5px 10px;margin-top:8px;}
.qty button{width:24px;height:24px;border-radius:50%;background:var(--pink-100);color:var(--pink-700);font-weight:700;display:grid;place-items:center;}
.qty span{min-width:18px;text-align:center;font-weight:600;}
.ci-price{font-family:'Fraunces';font-weight:600;color:var(--pink-700);}
.ci-rm{font-size:12px;color:var(--ink-soft);cursor:pointer;margin-top:6px;display:inline-block;}
.ci-rm:hover{color:var(--pink-600);}
.summary{background:#fff;border-radius:var(--r);padding:26px;box-shadow:var(--shadow);position:sticky;top:104px;}
.summary h3{font-size:22px;margin-bottom:18px;}
.sum-row{display:flex;justify-content:space-between;margin-bottom:10px;font-size:14.5px;color:var(--ink-soft);}
.sum-total{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);margin-top:14px;padding-top:16px;font-weight:600;}
.sum-total b{font-family:'Fraunces';font-size:24px;color:var(--pink-700);}
.empty{text-align:center;padding:80px 0;color:var(--ink-soft);}

/* ---- forms ---- */
.field{margin-bottom:16px;}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--ink);}
.field input,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:14px;padding:13px 16px;
  font-family:'Poppins';font-size:15px;color:var(--ink);background:#fff;transition:border-color .2s,box-shadow .2s;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--pink-400);box-shadow:0 0 0 4px var(--pink-100);}
.field .hint{font-size:12px;color:var(--ink-soft);margin-top:6px;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.pay-card{background:linear-gradient(135deg,var(--pink-600),var(--pink-700));border-radius:18px;padding:20px;color:#fff;margin-bottom:18px;
  box-shadow:var(--shadow);}
.pay-card .demo{display:inline-block;background:rgba(255,255,255,.22);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  padding:4px 10px;border-radius:20px;margin-bottom:14px;font-weight:600;}
.pay-card .num{font-family:'Fraunces';font-size:22px;letter-spacing:2px;}
.fill-test{font-size:12.5px;color:var(--pink-600);cursor:pointer;font-weight:600;}

/* ---- toast ---- */
#bp-toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(16px);background:var(--ink);color:#fff;
  padding:13px 24px;border-radius:30px;font-size:14px;font-weight:500;opacity:0;pointer-events:none;transition:.32s;z-index:200;box-shadow:var(--shadow);}
#bp-toast.show{opacity:1;transform:translateX(-50%);}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);}
.reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.reveal{transition:none;opacity:1;transform:none;}body{animation:none;opacity:1;}}

/* ---- footer ---- */
.site-footer{background:#2A0E1C;color:#fff;padding:54px 0 26px;margin-top:30px;}
.site-footer .fg{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;}
.site-footer .bw{font-family:'Fraunces';font-weight:700;font-size:30px;color:#fff;}
.site-footer .bw b{color:var(--pink-400);}
.site-footer p{color:rgba(255,255,255,.6);font-size:14px;line-height:1.7;margin:12px 0;max-width:280px;}
.site-footer h4{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--pink-300);margin-bottom:14px;}
.site-footer a.fl{display:block;color:rgba(255,255,255,.72);font-size:14px;margin-bottom:9px;}
.site-footer a.fl:hover{color:#fff;}
.fbottom{border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding-top:20px;color:rgba(255,255,255,.5);font-size:13px;text-align:center;}

/* ---- mobile menu drawer ---- */
#mdrawer{position:fixed;inset:0;z-index:120;visibility:hidden;}
#mdrawer .ov{position:absolute;inset:0;background:rgba(40,8,24,.5);opacity:0;transition:.3s;}
#mdrawer .panel{position:absolute;top:0;right:0;height:100%;width:78%;max-width:320px;background:var(--cream);
  transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);padding:24px;display:flex;flex-direction:column;gap:6px;}
#mdrawer.show{visibility:visible;} #mdrawer.show .ov{opacity:1;} #mdrawer.show .panel{transform:none;}
#mdrawer a{font-family:'Fraunces';font-size:24px;padding:12px 0;border-bottom:1px solid var(--line);}

/* ============== RESPONSIVE ============== */
@media(max-width:1024px){
  .cat-row{grid-template-columns:repeat(3,1fr);}
  .pgrid{grid-template-columns:repeat(2,1fr);}
  .cart-wrap{grid-template-columns:1fr;}
  .summary{position:static;}
  .site-footer .fg{grid-template-columns:1fr 1fr;gap:28px;}
}
@media(max-width:680px){
  .menu,.hicons .d-only{display:none;}
  .burger{display:grid;}
  .nav{height:68px;}
  .brand .bw{font-size:30px;} .brand .tagline{font-size:10px;letter-spacing:.18em;}
  section.block{padding:48px 0;}
  /* swipeable carousels on mobile */
  .cat-row,.pgrid{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;padding-bottom:10px;scrollbar-width:none;}
  .cat-row::-webkit-scrollbar,.pgrid::-webkit-scrollbar{display:none;}
  .cat-row>*{flex:0 0 60%;scroll-snap-align:start;}
  .pgrid>*{flex:0 0 72%;scroll-snap-align:start;}
  .row2{grid-template-columns:1fr;}
  .site-footer .fg{grid-template-columns:1fr;}
  /* lively mobile micro-interactions */
  .pcard:active{transform:scale(.98);}
  .addbtn:active{transform:scale(.95);}
}

/* ---- video hero + showcase ---- */
.vhero{position:relative;height:74vh;min-height:520px;overflow:hidden;display:flex;align-items:center;}
.vhero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.vhero .vtint{position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(60,10,34,.6) 0%,rgba(60,10,34,.25) 45%,transparent 75%);}
.vhero .vin{position:relative;z-index:2;color:#fff;max-width:620px;}
.vhero .eyebrow{color:#FFD0E6;}
.vhero h1{font-size:clamp(40px,5.4vw,72px);color:#fff;margin:14px 0 16px;text-shadow:0 4px 30px rgba(80,10,40,.4);}
.vhero h1 em{font-style:italic;color:var(--pink-200);}
.vhero p{font-size:17px;line-height:1.6;color:rgba(255,255,255,.92);max-width:460px;margin-bottom:26px;}
.showcase{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.showcase video{width:100%;border-radius:var(--r);box-shadow:var(--shadow);display:block;}
.showcase h2{font-size:clamp(28px,3.4vw,42px);margin:12px 0 14px;}
@media(max-width:820px){
  .vhero{height:88vh;}
  .showcase{grid-template-columns:1fr;gap:24px;}
  .showcase video{max-width:420px;margin:0 auto;}
}
