/* ============================================================
   POLYMER HANDS — storefront design system
   Cream paper · deep purple · bright pink · clay craft
   ============================================================ */

/* ---- Fonts ---- */

/* ---- Tokens ---- */
:root{
  /* palette — defaults match the logo exactly */
  --purple:#4A1668;
  --purple-deep:#36104B;
  --purple-mid:#5D2080;
  --pink:#EC1E72;
  --pink-bright:#FF3D8E;
  --pink-soft:#F8A8C3;
  --pink-pale:#FDD9E6;
  --cream:#F2E6CC;
  --cream-light:#F8EFDC;
  --cream-deep:#EBDDBB;
  --yellow:#F5C84B;
  --ink:#2A0F3D;
  --white:#FFFFFF;

  /* type — default pairing: condensed display + Poppins body */
  --f-display:"Big Shoulders Display","Anton",sans-serif;
  --f-script:"Caveat Brush",cursive;
  --f-body:"Poppins",system-ui,sans-serif;
  --f-urdu:"Noto Nastaliq Urdu",serif;

  --maxw:1240px;
  --radius:20px;
  --radius-sm:12px;
  --shadow:0 18px 50px -22px rgba(74,22,104,.45);
  --shadow-soft:0 12px 30px -18px rgba(74,22,104,.40);
  --ring:rgba(74,22,104,.10);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--cream-light);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--pink-bright);outline-offset:2px;border-radius:4px}

/* paper texture overlay applied to cream sections */
.paper{position:relative;background:
  radial-gradient(120% 90% at 50% 0%, var(--cream-light) 0%, var(--cream) 58%, var(--cream-deep) 100%);}
.paper::before{
  content:"";position:absolute;inset:0;pointer-events:none;mix-blend-mode:multiply;opacity:.05;
  background-image:url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHdpZHRoPScxNjAnIGhlaWdodD0nMTYwJz48ZmlsdGVyIGlkPSduJz48ZmVUdXJidWxlbmNlIHR5cGU9J2ZyYWN0YWxOb2lzZScgYmFzZUZyZXF1ZW5jeT0nMC44JyBudW1PY3RhdmVzPScyJy8+PC9maWx0ZXI+PHJlY3Qgd2lkdGg9JzEwMCUnIGhlaWdodD0nMTAwJScgZmlsdGVyPSd1cmwoI24pJy8+PC9zdmc+");
}

/* ---- Layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:96px 0;position:relative}
.section.tight{padding:64px 0}
@media(max-width:720px){.section{padding:64px 0}.wrap{padding:0 20px}}

/* ---- Type helpers ---- */
.display{
  font-family:var(--f-display);font-weight:900;line-height:.9;
  letter-spacing:-.01em;text-transform:uppercase;color:var(--purple);
  margin:0;
}
.script{font-family:var(--f-script);color:var(--pink);line-height:1;font-weight:400}
.eyebrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--f-body);font-weight:600;font-size:13px;letter-spacing:.28em;
  text-transform:uppercase;color:var(--purple);
}
.eyebrow::before,.eyebrow::after{content:"";width:22px;height:2px;background:var(--pink);border-radius:2px}
.eyebrow.solo::after{display:none}
.urdu{font-family:var(--f-urdu);direction:rtl;line-height:2.1}
.lead{font-size:clamp(17px,2vw,20px);line-height:1.7;color:#5b4a63;max-width:62ch}
.muted{color:#7a6c82}

/* section heading block */
.head{display:flex;flex-direction:column;gap:14px;margin-bottom:48px}
.head .display{font-size:clamp(40px,6vw,76px)}
.head.center{align-items:center;text-align:center}
.head.center .lead{margin-inline:auto}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:12px;border:0;border-radius:999px;
  font-family:var(--f-body);font-weight:600;font-size:15px;letter-spacing:.02em;
  padding:15px 26px;transition:transform .18s cubic-bezier(.34,1.4,.5,1),box-shadow .2s,background .2s;
  white-space:nowrap;line-height:1;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-primary{background:var(--purple);color:var(--white);box-shadow:0 14px 30px -12px rgba(74,22,104,.7)}
.btn-primary:hover{background:var(--purple-deep);transform:translateY(-2px);box-shadow:0 20px 38px -14px rgba(74,22,104,.8)}
.btn-pink{background:var(--pink);color:#fff;box-shadow:0 14px 30px -12px rgba(236,30,114,.6)}
.btn-pink:hover{background:var(--pink-bright);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--purple);box-shadow:inset 0 0 0 2px var(--purple)}
.btn-ghost:hover{background:var(--purple);color:#fff}
.btn-light{background:#fff;color:var(--purple);box-shadow:var(--shadow-soft)}
.btn-light:hover{transform:translateY(-2px)}
.btn .arrow{display:grid;place-items:center;width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.2)}
.btn-light .arrow,.btn-ghost .arrow{background:var(--purple);color:#fff}
.btn .ig{width:18px;height:18px}

/* instagram gradient pill for header */
.ig-pill{
  background:linear-gradient(135deg,#7d3bbd 0%,var(--pink) 55%,#ff7eb3 100%);
  color:#fff;box-shadow:0 12px 26px -12px rgba(236,30,114,.8);
}
.ig-pill:hover{filter:brightness(1.05);transform:translateY(-2px)}

/* ---- Header ---- */
.site-header{position:sticky;top:0;z-index:200;
  background:rgba(248,239,220,.82);backdrop-filter:blur(18px) saturate(150%);
  border-bottom:1px solid rgba(74,22,104,.10);}
.nav{display:flex;align-items:center;gap:18px;height:78px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--f-display);
  font-weight:900;font-size:22px;letter-spacing:.01em;color:var(--purple);text-transform:uppercase}
.brand img{width:46px;height:46px;filter:drop-shadow(0 6px 12px rgba(74,22,104,.25))}
.brand small{display:block;font-family:var(--f-script);font-size:14px;color:var(--pink);
  letter-spacing:0;text-transform:none;line-height:.8;margin-top:2px}
.nav-links{display:flex;align-items:center;gap:2px;margin-left:auto}
.nav-links a{padding:8px 11px;border-radius:999px;font-weight:500;font-size:14px;color:#4a3b52;white-space:nowrap;
  transition:background .15s,color .15s}
.nav-links a:hover{background:rgba(74,22,104,.08);color:var(--purple)}
.nav-links a.active{color:var(--purple);background:rgba(236,30,114,.10)}
.nav-actions{display:flex;align-items:center;gap:10px}
.cart-btn{position:relative;display:grid;place-items:center;width:46px;height:46px;border-radius:50%;
  background:#fff;box-shadow:var(--shadow-soft);border:0;color:var(--purple)}
.cart-btn:hover{transform:translateY(-2px);transition:transform .18s}
.cart-count{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;
  background:var(--pink);color:#fff;font-size:11px;font-weight:700;display:grid;place-items:center;
  font-family:var(--f-body);transform:scale(0);transition:transform .2s cubic-bezier(.34,1.5,.5,1)}
.cart-count.show{transform:scale(1)}
.burger{display:none;width:46px;height:46px;border-radius:50%;background:#fff;border:0;
  box-shadow:var(--shadow-soft);place-items:center;color:var(--purple)}
.nav .header-cta{}
/* compact icon-only IG button on mid-width screens so the 9-item nav fits */
@media(max-width:1440px){
  .header-cta .label-full{display:none}
  .btn.ig-pill.header-cta{width:46px;height:46px;padding:0;gap:0;justify-content:center}
}
@media(max-width:1280px){
  .nav-links{position:fixed;inset:78px 0 auto 0;flex-direction:column;align-items:stretch;gap:2px;
    background:var(--cream-light);padding:16px 20px 24px;box-shadow:0 24px 40px -20px rgba(74,22,104,.5);
    transform:translateY(-130%);transition:transform .3s cubic-bezier(.4,1,.5,1);margin:0;
    border-bottom:1px solid rgba(74,22,104,.12);max-height:calc(100vh - 78px);overflow:auto}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:13px 14px;font-size:16px}
  .nav-actions{margin-left:auto}
  .burger{display:grid}
}
@media(max-width:520px){
  .header-cta{display:none}
  .brand small{display:none}
}

/* ---- Placeholder image system ---- */
.ph{position:relative;overflow:hidden;border-radius:var(--radius-sm);
  background:
    repeating-linear-gradient(135deg, var(--cream-deep) 0 14px, var(--cream) 14px 28px);
  display:grid;place-items:center;color:var(--purple);isolation:isolate}
.ph::after{content:attr(data-label);font-family:"Work Sans",monospace;font-size:11px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:rgba(74,22,104,.5);
  background:rgba(248,239,220,.85);padding:6px 12px;border-radius:999px;
  box-shadow:0 2px 8px rgba(74,22,104,.12)}
.ph.purple{background:repeating-linear-gradient(135deg,#5a2480 0 14px,#4a1668 14px 28px)}
.ph.purple::after{color:rgba(255,255,255,.8);background:rgba(54,16,75,.6)}
.ph.pink{background:repeating-linear-gradient(135deg,#ff5ea0 0 14px,#ec1e72 14px 28px)}
.ph.pink::after{color:#fff;background:rgba(180,20,80,.45)}

/* ---- Product card ---- */
.grid{display:grid;gap:26px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:980px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}

.card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
  display:flex;flex-direction:column;transition:transform .22s cubic-bezier(.34,1.3,.5,1),box-shadow .22s;
  border:1px solid rgba(74,22,104,.05)}
.card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -28px rgba(74,22,104,.55)}
.card .media{position:relative;aspect-ratio:1/1}
.card .media .ph{position:absolute;inset:0;border-radius:0;height:100%}
.card .tag{position:absolute;top:14px;left:14px;z-index:2;font-family:var(--f-body);font-weight:700;
  font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:6px 12px;border-radius:999px;
  background:var(--yellow);color:var(--purple);box-shadow:0 4px 10px rgba(74,22,104,.2)}
.card .tag.best{background:var(--pink);color:#fff}
.card .tag.custom{background:var(--purple);color:#fff}
.card .body{padding:20px 20px 22px;display:flex;flex-direction:column;gap:8px;flex:1}
.card h3{margin:0;font-family:var(--f-display);font-weight:800;font-size:24px;color:var(--purple);
  text-transform:uppercase;letter-spacing:-.01em;line-height:.95}
.card .desc{font-size:13.5px;color:#7a6c82;line-height:1.55;flex:1}
.card .row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:8px}
.price{font-family:var(--f-display);font-weight:800;font-size:26px;color:var(--ink)}
.price small{font-family:var(--f-body);font-weight:600;font-size:12px;color:#9a8aa3;letter-spacing:.04em}
.add{display:inline-flex;align-items:center;gap:8px;border:0;border-radius:999px;background:var(--purple);
  color:#fff;font-weight:600;font-size:13.5px;padding:11px 16px;transition:background .18s,transform .18s}
.add:hover{background:var(--pink);transform:translateY(-2px)}
.add.added{background:#2e8b57}
.add svg{width:16px;height:16px}

/* ---- Chips / filters ---- */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{border:0;background:#fff;color:var(--purple);font-weight:600;font-size:13.5px;
  padding:10px 18px;border-radius:999px;box-shadow:var(--shadow-soft);transition:all .16s}
.chip:hover{transform:translateY(-2px)}
.chip.on{background:var(--purple);color:#fff}

/* ---- Cart drawer ---- */
.scrim{position:fixed;inset:0;background:rgba(42,15,61,.45);backdrop-filter:blur(3px);
  opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;z-index:300}
.scrim.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(420px,100%);background:var(--cream-light);
  z-index:301;transform:translateX(100%);transition:transform .34s cubic-bezier(.4,1,.4,1);
  display:flex;flex-direction:column;box-shadow:-20px 0 60px -20px rgba(42,15,61,.5)}
.drawer.open{transform:translateX(0)}
.drawer-hd{display:flex;align-items:center;justify-content:space-between;padding:24px;
  border-bottom:1px solid rgba(74,22,104,.12)}
.drawer-hd h3{margin:0;font-family:var(--f-display);font-weight:900;font-size:30px;color:var(--purple);text-transform:uppercase}
.drawer-close{width:40px;height:40px;border-radius:50%;border:0;background:#fff;color:var(--purple);
  display:grid;place-items:center;box-shadow:var(--shadow-soft)}
.drawer-body{flex:1;overflow:auto;padding:8px 24px}
.cart-line{display:flex;gap:14px;padding:18px 0;border-bottom:1px solid rgba(74,22,104,.08)}
.cart-line .thumb{width:64px;height:64px;border-radius:12px;flex:none}
.cart-line .info{flex:1;min-width:0}
.cart-line h4{margin:0 0 2px;font-size:14.5px;font-weight:600;color:var(--ink)}
.cart-line .meta{font-size:12px;color:#9a8aa3}
.qty{display:inline-flex;align-items:center;gap:0;margin-top:8px;background:#fff;border-radius:999px;
  box-shadow:var(--shadow-soft)}
.qty button{width:28px;height:28px;border:0;background:transparent;color:var(--purple);font-size:16px;
  display:grid;place-items:center;border-radius:50%}
.qty button:hover{background:rgba(74,22,104,.08)}
.qty span{min-width:24px;text-align:center;font-weight:600;font-size:13px}
.cart-line .lp{font-family:var(--f-display);font-weight:800;font-size:18px;color:var(--purple);text-align:right}
.cart-line .rm{background:none;border:0;color:#b7a7bf;font-size:11px;margin-top:6px;text-align:right;
  width:100%;text-decoration:underline}
.cart-line .rm:hover{color:var(--pink)}
.cart-empty{text-align:center;padding:60px 20px;color:#9a8aa3}
.cart-empty .em-ic{width:64px;height:64px;margin:0 auto 16px;opacity:.5}
.drawer-foot{padding:22px 24px;border-top:1px solid rgba(74,22,104,.12);background:var(--cream)}
.drawer-foot .tot{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.drawer-foot .tot .display{font-size:34px}
.drawer-foot .note{font-size:12px;color:#7a6c82;margin:2px 0 16px;line-height:1.5}
.drawer-foot .btn{width:100%;justify-content:center}

/* ---- Decorative clay blobs (sparingly used) ---- */
.sparkle{position:absolute;pointer-events:none;z-index:1}
.blob{position:absolute;border-radius:50%;filter:blur(2px);opacity:.5;pointer-events:none;z-index:0}

/* ---- Testimonials ---- */
.t-card{background:#fff;border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-soft);
  display:flex;flex-direction:column;gap:14px;border:1px solid rgba(74,22,104,.05)}
.stars{display:flex;gap:3px;color:var(--yellow)}
.t-card p{margin:0;font-size:15.5px;line-height:1.65;color:#4a3b52}
.t-card .who{display:flex;align-items:center;gap:12px;margin-top:auto}
.t-card .av{width:44px;height:44px;border-radius:50%;background:var(--pink-pale);display:grid;place-items:center;
  font-family:var(--f-display);font-weight:800;color:var(--pink);font-size:18px}
.t-card .who b{display:block;font-size:14px;color:var(--ink)}
.t-card .who span{font-size:12px;color:#9a8aa3}

/* ---- Process timeline ---- */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;position:relative}
@media(max-width:900px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.steps{grid-template-columns:1fr}}
.step{background:#fff;border-radius:var(--radius);padding:26px 22px;box-shadow:var(--shadow-soft);
  position:relative;border:1px solid rgba(74,22,104,.05)}
.step .n{width:46px;height:46px;border-radius:50%;background:var(--purple);color:#fff;display:grid;
  place-items:center;font-family:var(--f-display);font-weight:900;font-size:22px;margin-bottom:16px}
.step:nth-child(2) .n{background:var(--pink)}
.step:nth-child(4) .n{background:var(--pink)}
.step h4{margin:0 0 6px;font-size:17px;font-weight:600;color:var(--purple)}
.step p{margin:0;font-size:13.5px;color:#7a6c82;line-height:1.55}

/* ---- Feature/why grid ---- */
.feat{display:flex;gap:16px;align-items:flex-start;padding:24px;background:#fff;border-radius:var(--radius);
  box-shadow:var(--shadow-soft);border:1px solid rgba(74,22,104,.05)}
.feat .ic{flex:none;width:52px;height:52px;border-radius:14px;display:grid;place-items:center;
  background:var(--pink-pale);color:var(--pink)}
.feat .ic svg{width:26px;height:26px}
.feat h4{margin:0 0 4px;font-size:17px;font-weight:600;color:var(--purple)}
.feat p{margin:0;font-size:14px;color:#7a6c82;line-height:1.55}

/* ---- Collection card ---- */
.coll{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);min-height:340px;
  display:flex;flex-direction:column;justify-content:flex-end;color:#fff;isolation:isolate}
.coll .ph{position:absolute;inset:0;border-radius:0;height:100%;z-index:-1}
.coll .scr{position:absolute;inset:0;background:linear-gradient(to top,rgba(42,15,61,.85) 8%,rgba(42,15,61,.05) 60%);z-index:0}
.coll .ct{position:relative;z-index:1;padding:26px}
.coll h3{margin:0 0 6px;font-family:var(--f-display);font-weight:900;font-size:30px;text-transform:uppercase;line-height:.95}
.coll p{margin:0 0 16px;font-size:14px;opacity:.9;line-height:1.5;max-width:32ch}
.coll .explore{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:#fff}
.coll .explore svg{width:18px;height:18px;transition:transform .2s}
.coll:hover .explore svg{transform:translateX(4px)}

/* ---- Trust badges ---- */
.trust{display:flex;flex-wrap:wrap;gap:12px}
.trust .tb{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.7);
  border:1px solid rgba(74,22,104,.10);padding:9px 16px;border-radius:999px;font-size:13px;font-weight:600;color:var(--purple)}
.trust .tb svg{width:16px;height:16px;color:var(--pink)}

/* ---- Footer ---- */
.site-footer{background:var(--purple-deep);color:#e9dcf2;padding:72px 0 28px;position:relative;overflow:hidden}
.site-footer .wrap{position:relative;z-index:1}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:40px}
@media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}
.foot-brand{display:flex;align-items:center;gap:12px;margin-bottom:16px;font-family:var(--f-display);
  font-weight:900;font-size:24px;color:#fff;text-transform:uppercase}
.foot-brand img{width:54px;height:54px}
.site-footer p{font-size:14px;line-height:1.7;color:#c9b5d9}
.foot-col h5{font-family:var(--f-body);font-weight:700;font-size:13px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--pink-soft);margin:0 0 16px}
.foot-col a{display:block;font-size:14.5px;color:#d8c7e6;padding:6px 0;transition:color .15s,transform .15s}
.foot-col a:hover{color:#fff;transform:translateX(4px)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);font-size:13px;color:#b9a3cb}
.foot-bottom .script{color:var(--pink-soft);font-size:22px}

/* ---- Instagram grid ---- */
.ig-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
@media(max-width:900px){.ig-grid{grid-template-columns:repeat(3,1fr)}}
.ig-tile{aspect-ratio:1/1;border-radius:14px;overflow:hidden;position:relative;cursor:pointer}
.ig-tile .ph{position:absolute;inset:0;border-radius:0;height:100%}
.ig-tile .ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(125,59,189,.0),rgba(236,30,114,.0));
  display:grid;place-items:center;opacity:0;transition:opacity .2s;z-index:2}
.ig-tile:hover .ov{opacity:1;background:linear-gradient(135deg,rgba(125,59,189,.6),rgba(236,30,114,.6))}
.ig-tile .ov svg{width:34px;height:34px;color:#fff}

/* ---- Care / info cards ---- */
.info-card{background:#fff;border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-soft);
  border:1px solid rgba(74,22,104,.05)}
.info-card h4{margin:0 0 8px;font-size:18px;color:var(--purple);font-weight:600;display:flex;align-items:center;gap:10px}
.info-card h4 svg{width:22px;height:22px;color:var(--pink)}
.info-card p{margin:0;font-size:14px;color:#7a6c82;line-height:1.6}

/* ---- FAQ accordion ---- */
.faq-list{display:flex;flex-direction:column;gap:12px;max-width:840px;margin:0 auto}
.faq-item{background:#fff;border-radius:16px;box-shadow:var(--shadow-soft);overflow:hidden;
  border:1px solid rgba(74,22,104,.05)}
.faq-q{width:100%;text-align:left;border:0;background:none;padding:22px 26px;display:flex;
  align-items:center;justify-content:space-between;gap:16px;font-family:var(--f-body);font-weight:600;
  font-size:17px;color:var(--purple)}
.faq-q .pm{flex:none;width:30px;height:30px;border-radius:50%;background:var(--pink-pale);color:var(--pink);
  display:grid;place-items:center;font-size:20px;transition:transform .25s,background .2s,color .2s}
.faq-item.open .pm{transform:rotate(45deg);background:var(--pink);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-a p{margin:0;padding:0 26px 24px;font-size:15px;line-height:1.7;color:#6a5b72}

/* ---- Forms ---- */
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.field label{font-weight:600;font-size:14px;color:var(--purple)}
.field input,.field select,.field textarea{
  font-family:var(--f-body);font-size:15px;color:var(--ink);background:#fff;
  border:2px solid rgba(74,22,104,.12);border-radius:14px;padding:14px 16px;transition:border .18s,box-shadow .18s}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--pink);box-shadow:0 0 0 4px rgba(236,30,114,.12)}
.field textarea{resize:vertical;min-height:110px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:560px){.field-row{grid-template-columns:1fr}}

/* ---- Hero ---- */
.hero{position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;
  padding:72px 0 88px}
@media(max-width:940px){.hero-grid{grid-template-columns:1fr;gap:36px;padding:52px 0 64px}}
.hero h1{font-family:var(--f-display);font-weight:900;text-transform:uppercase;color:var(--purple);
  font-size:clamp(48px,8.5vw,104px);line-height:.86;letter-spacing:-.015em;margin:14px 0 0}
.hero h1 .pk{color:var(--pink)}
.hero .script-line{font-family:var(--f-script);color:var(--pink);font-size:clamp(34px,5vw,56px);
  line-height:.9;display:block;margin:6px 0 2px;transform:rotate(-2deg)}
.hero .lead{margin:24px 0 30px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:28px}
.hero-visual{position:relative;aspect-ratio:4/5;border-radius:28px;overflow:hidden;box-shadow:var(--shadow);}
.hero-visual .ph{position:absolute;inset:0;border-radius:0;height:100%}
.hero-badge{position:absolute;z-index:5;background:#fff;border-radius:18px;box-shadow:var(--shadow);
  padding:14px 18px;display:flex;align-items:center;gap:12px}
.hero-badge .em{font-family:var(--f-display);font-weight:900;font-size:30px;color:var(--pink);line-height:1}
.hero-badge small{font-size:12px;color:#7a6c82;font-weight:500;line-height:1.3}
.hero-logo{position:absolute;top:18px;right:18px;width:96px;z-index:5;filter:drop-shadow(0 10px 22px rgba(74,22,104,.35))}

/* ---- Page banner (interior pages) ---- */
.banner{padding:64px 0 56px;position:relative;overflow:hidden}
.banner .display{font-size:clamp(46px,8vw,96px)}
.banner .script-line{font-family:var(--f-script);color:var(--pink);font-size:clamp(28px,4vw,44px);
  transform:rotate(-2deg);display:inline-block;margin-bottom:6px}
.crumbs{font-size:13px;color:#9a8aa3;margin-bottom:18px;display:flex;gap:8px;align-items:center}
.crumbs a:hover{color:var(--pink)}

/* ---- CTA band ---- */
.cta-band{background:linear-gradient(120deg,var(--purple) 0%,var(--purple-mid) 60%,var(--pink) 130%);
  border-radius:32px;padding:60px;color:#fff;position:relative;overflow:hidden;text-align:center}
.cta-band h2{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:clamp(36px,5vw,60px);
  margin:0 0 10px;line-height:.95}
.cta-band p{margin:0 auto 26px;max-width:54ch;font-size:17px;color:#f3e6fb;line-height:1.6}
.cta-band .btn-light{margin:0 4px}
@media(max-width:600px){.cta-band{padding:40px 26px}}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.8,.3,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* toast */
.toast{position:fixed;bottom:24px;left:50%;translate:-50% 30px;
  background:var(--purple-deep);color:#fff;padding:14px 22px;border-radius:999px;font-size:14px;font-weight:600;
  box-shadow:0 20px 40px -16px rgba(42,15,61,.7);z-index:400;opacity:0;visibility:hidden;
  transition:opacity .25s,translate .25s;display:flex;align-items:center;gap:10px}
.toast.show{opacity:1;visibility:visible;translate:-50% 0}
.toast svg{width:18px;height:18px;color:#7Cf0a5}

/* helpers */
.center{text-align:center}
.mt-s{margin-top:14px}.mt-m{margin-top:28px}.mt-l{margin-top:48px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:32px}}
.pill-tag{display:inline-flex;align-items:center;gap:8px;background:var(--pink-pale);color:var(--pink);
  font-weight:700;font-size:12px;letter-spacing:.06em;text-transform:uppercase;padding:7px 14px;border-radius:999px}

/* ---- Blog ---- */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:920px){.posts{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.posts{grid-template-columns:1fr}}
.post{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;
  flex-direction:column;border:1px solid rgba(74,22,104,.05);transition:transform .22s cubic-bezier(.34,1.3,.5,1),box-shadow .22s}
.post:hover{transform:translateY(-6px);box-shadow:0 30px 60px -28px rgba(74,22,104,.55)}
.post .media{position:relative;aspect-ratio:16/10}
.post .media .ph{position:absolute;inset:0;border-radius:0;height:100%}
.post .pcat{position:absolute;top:14px;left:14px;z-index:2;background:#fff;color:var(--pink);font-weight:700;
  font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:6px 12px;border-radius:999px;box-shadow:0 4px 10px rgba(74,22,104,.18)}
.post .body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1}
.post .pdate{font-size:12px;color:#9a8aa3;font-weight:500;letter-spacing:.02em}
.post h3{margin:0;font-family:var(--f-display);font-weight:800;font-size:23px;line-height:1;color:var(--purple);text-transform:uppercase}
.post .excerpt{font-size:14px;color:#7a6c82;line-height:1.6;flex:1}
.post .read{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:13.5px;color:var(--pink);margin-top:4px}
.post .read svg{width:16px;height:16px;transition:transform .2s}
.post:hover .read svg{transform:translateX(4px)}

/* featured post */
.post-feature{display:grid;grid-template-columns:1.15fr 1fr;background:#fff;border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(74,22,104,.05);margin-bottom:40px}
@media(max-width:820px){.post-feature{grid-template-columns:1fr}}
.post-feature .media{position:relative;min-height:340px}
.post-feature .media .ph{position:absolute;inset:0;border-radius:0;height:100%}
.post-feature .pcat{position:absolute;top:18px;left:18px;z-index:2;background:#fff;color:var(--pink);font-weight:700;
  font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:6px 12px;border-radius:999px;box-shadow:0 4px 10px rgba(74,22,104,.18)}
.post-feature .body{padding:42px;display:flex;flex-direction:column;gap:14px;justify-content:center}
.post-feature h2{margin:0;font-family:var(--f-display);font-weight:900;font-size:clamp(30px,4vw,46px);line-height:.95;color:var(--purple);text-transform:uppercase}
.post-feature .excerpt{font-size:16px;color:#6a5b72;line-height:1.65}
@media(max-width:820px){.post-feature .media{min-height:240px}.post-feature .body{padding:30px}}

/* ---- Product detail ---- */
.pd{display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:start}
@media(max-width:900px){.pd{grid-template-columns:1fr;gap:32px}}
.pd-gallery{position:sticky;top:100px;display:flex;flex-direction:column;gap:14px}
@media(max-width:900px){.pd-gallery{position:static}}
.pd-main{position:relative;aspect-ratio:1/1;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);
  display:grid;place-items:center;transition:background .35s ease}
.pd-main .sheen{position:absolute;inset:0;background:radial-gradient(60% 50% at 32% 26%,rgba(255,255,255,.5),transparent 60%);
  transition:opacity .35s;pointer-events:none}
.pd-main.matte .sheen{opacity:0}
.pd-main .mug-label{position:relative;z-index:1;font-family:"Work Sans",monospace;font-size:12px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;padding:8px 16px;border-radius:999px;
  background:rgba(255,255,255,.85);color:rgba(74,22,104,.65);box-shadow:0 4px 14px rgba(74,22,104,.18)}
.pd-main .mug-label.on-dark{background:rgba(0,0,0,.35);color:rgba(255,255,255,.92)}
.pd-finish-badge{position:absolute;top:16px;left:16px;z-index:2;font-family:var(--f-body);font-weight:700;
  font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:7px 14px;border-radius:999px;
  background:var(--purple);color:#fff;box-shadow:0 4px 12px rgba(74,22,104,.25)}
.pd-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.pd-thumb{aspect-ratio:1/1;border-radius:14px;overflow:hidden;border:2px solid transparent;cursor:pointer;
  position:relative;transition:border .15s,transform .15s}
.pd-thumb .ph{position:absolute;inset:0;border-radius:0;height:100%}
.pd-thumb.on{border-color:var(--pink)}
.pd-thumb:hover{transform:translateY(-2px)}

.pd-info h1{font-family:var(--f-display);font-weight:900;text-transform:uppercase;color:var(--purple);
  font-size:clamp(34px,4.4vw,50px);line-height:1.05;margin:12px 0 14px;max-width:12ch}
.pd-rating{display:flex;align-items:center;gap:10px;color:#7a6c82;font-size:13.5px;font-weight:500;margin:0 0 18px;white-space:nowrap}
.pd-rating .stars{color:var(--yellow)}
.pd-price{font-family:var(--f-display);font-weight:800;font-size:40px;color:var(--ink);line-height:1;margin-bottom:4px}
.pd-price small{font-family:var(--f-body);font-weight:600;font-size:13px;color:#9a8aa3;margin-left:6px}
.pd-desc{font-size:15.5px;line-height:1.7;color:#5b4a63;margin:16px 0 26px;max-width:52ch}

.opt-block{margin-bottom:24px}
.opt-block .opt-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px}
.opt-block .opt-head h4{margin:0;font-weight:600;font-size:14px;letter-spacing:.04em;text-transform:uppercase;color:var(--purple)}
.opt-block .opt-head .opt-val{font-size:14px;color:#7a6c82;font-weight:600}

/* segmented finish toggle */
.seg{display:inline-flex;background:#fff;border-radius:999px;padding:5px;box-shadow:var(--shadow-soft);gap:4px}
.seg button{border:0;background:transparent;font-family:var(--f-body);font-weight:600;font-size:14.5px;color:var(--purple);
  padding:11px 26px;border-radius:999px;transition:background .18s,color .18s}
.seg button.on{background:var(--purple);color:#fff}

/* colour swatches */
.swatches{display:flex;flex-wrap:wrap;gap:12px}
.swatch{position:relative;width:46px;height:46px;border-radius:50%;border:0;cursor:pointer;padding:0;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.12),0 4px 10px rgba(74,22,104,.14);transition:transform .15s}
.swatch:hover{transform:translateY(-3px)}
.swatch::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:2px solid transparent;transition:border .15s}
.swatch.on::after{border-color:var(--pink)}
.swatch[data-sheen="gloss"]{background-image:radial-gradient(60% 50% at 34% 28%,rgba(255,255,255,.55),transparent 60%)}

.qty-row{display:flex;align-items:center;gap:16px;margin:26px 0}
.qty-stepper{display:inline-flex;align-items:center;background:#fff;border-radius:999px;box-shadow:var(--shadow-soft)}
.qty-stepper button{width:42px;height:42px;border:0;background:transparent;color:var(--purple);font-size:20px;border-radius:50%}
.qty-stepper button:hover{background:rgba(74,22,104,.08)}
.qty-stepper span{min-width:34px;text-align:center;font-weight:700;font-size:16px}
.pd-actions{display:flex;flex-wrap:wrap;gap:12px}
.pd-actions .btn{flex:1;min-width:200px;justify-content:center}
.pd-meta-list{display:flex;flex-direction:column;gap:10px;margin-top:26px;padding-top:24px;border-top:1px solid rgba(74,22,104,.12)}
.pd-meta-list div{display:flex;align-items:center;gap:10px;font-size:13.5px;color:#6a5b72;font-weight:500}
.pd-meta-list svg{width:18px;height:18px;color:var(--pink);flex:none}

/* spec accordion reuse .faq styles; tabs */
.spec{max-width:none;margin-top:8px}
