/* ═══════════════════════════════════════════════
   ROOT & RESET
═══════════════════════════════════════════════ */
:root{
  /* Palettes */
  --choco-dark:   #1a0d06;
  --choco:        #2c1508;
  --choco-mid:    #3d1e0b;
  --choco-warm:   #5a2e12;
  --caramel:      #c07828;
  --caramel2:     #d4922e;
  --gold:         #d4a84b;
  --gold2:        #e8c96a;
  --cream:        #faf5ed;
  --cream2:       #f3ead8;
  --cream3:       #e8dcc4;
  --parchment:    #f7f0e0;
  --sand:         #ede2cc;
  --leaf:         #4a6535;
  --leaf2:        #5a7a42;

  /* Text */
  --t-dark:       #1a0d06;
  --t-mid:        #5a3a1a;
  --t-light:      #9a7250;
  --t-ghost:      rgba(250,245,237,.55);

  /* UI */
  --border:       #e4d5b8;
  --border2:      #d0be9a;
  --shadow-sm:    0 2px 12px rgba(26,13,6,.08);
  --shadow-md:    0 8px 40px rgba(26,13,6,.14);
  --shadow-lg:    0 20px 70px rgba(26,13,6,.22);
}

*, *::before, *::after{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ background:var(--cream); color:var(--t-dark); font-family:'Jost',sans-serif; overflow-x:hidden; }

/* ── UTILITY ── */
.wrap{ max-width:1360px; margin:0 auto; padding:0 48px; }
@media(max-width:768px){ .wrap{ padding:0 20px; } }

/* ── FONT HELPERS ── */
.serif{ font-family:'Playfair Display',serif; }

/* ═══════════════════════════════════════════════
   TOPBAR
═══════════════════════════════════════════════ */
.topbar{
  background: var(--choco-dark);
  padding: 9px 0;
  font-size: 12.5px;
  color: var(--t-ghost);
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.topbar-inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.topbar-left{ display:flex; gap:18px; }
.topbar-left a{ color:rgba(255,255,255,.5); font-size:11.5px; text-decoration:none; transition:color .2s; }
.topbar-left a:hover{ color:var(--gold2); }
.topbar-center{
  display:flex; align-items:center; gap:8px;
  font-size:12px; color:rgba(255,255,255,.6);
}
.tc-pill{
  background:var(--caramel); color:#fff;
  font-size:10px; font-weight:700; letter-spacing:.8px;
  padding:3px 10px; border-radius:20px;
}
.topbar-right{ display:flex; gap:16px; align-items:center; }
.topbar-right a{ color:rgba(255,255,255,.5); font-size:11.5px; text-decoration:none; transition:color .2s; }
.topbar-right a:hover{ color:var(--gold2); }
@media(max-width:768px){ .topbar-left,.topbar-right{display:none;} .topbar-inner{justify-content:center;} }

/* ═══════════════════════════════════════════════
   HEADER
═══════════════════════════════════════════════ */
header{
  background: var(--cream);
  border-bottom: 1px solid var(--border);
  position: sticky; top:0; z-index:900;
  box-shadow: var(--shadow-sm);
}
.header-inner{
  display:flex; align-items:center;
  height:78px; gap:28px;
}

/* LOGO */
.logo{ display:flex; align-items:center; gap:11px; text-decoration:none; flex-shrink:0; }
.logo-emblem{
  width:46px; height:46px;
  background: var(--choco);
  border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:22px;
  position:relative; overflow:hidden;
  box-shadow: 0 3px 14px rgba(44,21,8,.3);
}
.logo-emblem::after{
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 60%);
}
.logo-text-wrap{}
.logo-name{
  font-family:'Playfair Display',serif;
  font-size:22px; font-weight:700;
  color:var(--choco); line-height:1;
  letter-spacing:-0.3px;
}
.logo-name span{ color:var(--caramel); }
.logo-tagline{
  font-size:9.5px; font-weight:500;
  letter-spacing:2.5px; text-transform:uppercase;
  color:var(--t-light); margin-top:2px;
}

/* SEARCH */
.srch-wrap{ flex:1; max-width:560px; position:relative; }
.srch-box{
  display:flex; align-items:center;
  background:var(--parchment);
  border:1.5px solid var(--border);
  border-radius:6px; overflow:hidden;
  transition:all .25s;
}
.srch-box:focus-within{
  border-color:var(--caramel);
  background:#fff;
  box-shadow:0 0 0 3px rgba(192,120,40,.12);
}
.srch-cat{
  padding:0 14px; height:48px;
  display:flex; align-items:center; gap:5px;
  font-size:12.5px; color:var(--t-mid); font-weight:500;
  border-right:1.5px solid var(--border);
  cursor:pointer; white-space:nowrap;
}
.srch-cat svg{ width:11px; height:11px; }
.srch-input{
  flex:1; background:transparent; border:none; outline:none;
  font-family:'Jost',sans-serif; font-size:14px;
  color:var(--t-dark); height:48px; padding:0 16px;
}
.srch-input::placeholder{ color:var(--t-light); }
.srch-img{
  display:flex; align-items:center; gap:6px;
  padding:0 14px; height:48px;
  font-size:12px; color:var(--t-light);
  border-right:1.5px solid var(--border);
  cursor:pointer; white-space:nowrap; font-weight:500;
  transition:color .2s;
}
.srch-img:hover{ color:var(--caramel); }
.srch-img svg{ width:17px; height:17px; }
.srch-go{
  background:var(--choco); border:none;
  height:48px; width:50px;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:#fff; transition:background .2s;
}
.srch-go:hover{ background:var(--choco-warm); }
.srch-go svg{ width:18px; height:18px; }

/* Image search dropdown */
.img-drop{
  position:absolute; top:calc(100% + 10px); left:0; right:0;
  background:#fff; border:1.5px solid var(--border);
  border-top:2px solid var(--caramel);
  border-radius:0 0 10px 10px; padding:22px;
  display:none; z-index:300;
  box-shadow:var(--shadow-lg);
}
.img-drop.open{ display:block; }
.img-drop-title{
  font-family:'Playfair Display',serif;
  font-size:17px; color:var(--choco); margin-bottom:4px;
}
.img-drop-sub{ font-size:12px; color:var(--t-light); margin-bottom:16px; }
.img-zone{
  border:1.5px dashed var(--border2); border-radius:8px;
  padding:28px 20px; text-align:center; cursor:pointer;
  transition:all .2s; background:var(--parchment);
}
.img-zone:hover{ border-color:var(--caramel); background:rgba(192,120,40,.04); }
.img-zone svg{ width:38px; height:38px; color:var(--caramel); opacity:.55; margin-bottom:10px; }
.img-zone p{ font-size:13px; color:var(--t-mid); line-height:1.7; }
.img-zone span{ color:var(--caramel); font-weight:600; }
.img-chips{ display:flex; gap:8px; flex-wrap:wrap; margin-top:14px; }
.img-chip{
  background:var(--cream2); color:var(--t-mid);
  font-size:11.5px; font-weight:600;
  padding:5px 12px; border-radius:20px; cursor:pointer;
  transition:all .15s; border:1px solid var(--border);
}
.img-chip:hover{ background:var(--caramel); color:#fff; border-color:var(--caramel); }

/* HEADER ACTIONS */
.h-acts{ margin-left:auto; display:flex; align-items:center; gap:4px; flex-shrink:0; }
.hbtn{
  display:flex; align-items:center; flex-direction:column; gap:2px;
  padding:7px 10px; border-radius:8px; cursor:pointer;
  font-size:10px; font-weight:600; letter-spacing:.6px; text-transform:uppercase;
  color:var(--t-light); background:transparent; border:none;
  text-decoration:none; transition:all .2s; font-family:'Jost',sans-serif;
}
.hbtn svg{ width:21px; height:21px; }
.hbtn:hover{ color:var(--choco); background:var(--cream2); }
.hbtn.rel{ position:relative; }
.badge{
  position:absolute; top:2px; right:4px;
  background:var(--caramel); color:#fff;
  font-size:9px; font-weight:700;
  min-width:16px; height:16px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}
.cart-btn{
  display:flex; align-items:center; gap:9px;
  padding:11px 22px; background:var(--choco); color:#fff;
  border:none; border-radius:6px;
  font-family:'Jost',sans-serif; font-size:13.5px; font-weight:600;
  cursor:pointer; transition:all .2s; white-space:nowrap;
  letter-spacing:.3px;
}
.cart-btn:hover{ background:var(--choco-warm); transform:translateY(-1px); box-shadow:0 6px 20px rgba(44,21,8,.25); }
.cart-btn svg{ width:18px; height:18px; }
.cart-sep{ width:1px; height:16px; background:rgba(255,255,255,.2); }
@media(max-width:900px){ .srch-wrap{display:none;} }
@media(max-width:600px){ .hbtn span{display:none;} .logo-tagline{display:none;} }

/* ═══════════════════════════════════════════════
   NAV
═══════════════════════════════════════════════ */
nav{ background:var(--parchment); border-bottom:1px solid var(--border); }
.nav-inner{ display:flex; align-items:center; height:50px; }
.ni{ position:relative; height:100%; display:flex; align-items:center; }
.nl{
  display:flex; align-items:center; gap:5px;
  padding:0 18px; height:100%;
  font-size:13.5px; font-weight:500; color:var(--t-mid);
  text-decoration:none; border:none; background:none;
  cursor:pointer; font-family:'Jost',sans-serif;
  transition:color .15s; white-space:nowrap; letter-spacing:.2px;
}
.nl:hover,.ni:hover>.nl{ color:var(--choco); }
.nl.active{ color:var(--caramel); font-weight:600; }
.nl.hot{ color:var(--caramel); font-weight:600; }
.nl svg{ width:11px; height:11px; transition:transform .2s; }
.ni:hover .nl svg{ transform:rotate(180deg); }
.nl-bar{
  position:absolute; bottom:0; left:18px; right:18px;
  height:2px; background:var(--caramel);
  transform:scaleX(0); transform-origin:left;
  transition:transform .25s cubic-bezier(.4,0,.2,1);
}
.ni:hover .nl-bar{ transform:scaleX(1); }
@media(max-width:768px){ nav{ display:none; } }

/* ── MEGA MENU ── */
.mega{
  position:absolute; top:100%; left:0;
  background:#fff; border:1.5px solid var(--border);
  border-top:3px solid var(--caramel);
  padding:32px; display:none; gap:32px;
  min-width:680px; z-index:800;
  box-shadow:var(--shadow-lg);
  border-radius:0 0 12px 12px;
}
.ni:hover .mega{ display:flex; }
.mc{ flex:1; }
.mc-hd{
  font-size:10.5px; font-weight:700; letter-spacing:2.5px;
  text-transform:uppercase; color:var(--caramel);
  margin-bottom:16px; padding-bottom:10px;
  border-bottom:1px solid var(--border);
}
.ml{
  display:flex; align-items:center; gap:10px;
  padding:7px 0; font-size:13.5px; color:var(--t-mid);
  text-decoration:none; transition:all .15s;
}
.ml:hover{ color:var(--choco); padding-left:6px; }
.ml-ic{
  width:30px; height:30px; background:var(--cream2);
  border-radius:6px; display:flex; align-items:center;
  justify-content:center; font-size:15px; flex-shrink:0;
  transition:background .15s;
}
.ml:hover .ml-ic{ background:var(--sand); }
.ml-badge{
  font-size:10px; background:var(--cream2); color:var(--caramel);
  padding:2px 8px; border-radius:20px; font-weight:700;
  margin-left:auto;
}
.mega-feat{
  width:200px; flex-shrink:0;
  background:var(--choco); border-radius:10px;
  overflow:hidden;
}
.mf-img{
  height:140px; display:flex; align-items:center;
  justify-content:center; font-size:58px;
  background:linear-gradient(135deg,var(--choco-mid),var(--choco-warm));
}
.mf-bd{ padding:16px; }
.mf-tag{ font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--gold2); }
.mf-name{ font-family:'Playfair Display',serif; font-size:16px; color:#fff; margin:6px 0 6px; line-height:1.3; }
.mf-price{ font-size:15px; font-weight:700; color:var(--caramel2); }
.mf-cta{
  display:inline-flex; align-items:center; gap:5px;
  font-size:12px; font-weight:600; color:rgba(255,255,255,.7);
  text-decoration:none; margin-top:10px; transition:color .15s;
}
.mf-cta:hover{ color:#fff; }

/* ═══════════════════════════════════════════════
   HERO — SPLIT DESIGN
═══════════════════════════════════════════════ */
.hero{
  position:relative; overflow:hidden;
  min-height:680px; display:flex; align-items:stretch;
}

/* Left: dark chocolate side */
.hero-dark{
  flex:1; min-width:0;
  background: var(--choco-dark);
  position:relative; overflow:hidden;
  display:flex; flex-direction:column; justify-content:center;
  padding: 90px 70px 90px 0;
}
/* Cocoa texture dots */
.hero-dark::before{
  content:'';
  position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 20% 50%, rgba(192,120,40,.12) 0%, transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(90,46,18,.4) 0%, transparent 40%),
    radial-gradient(circle at 60% 80%, rgba(212,168,75,.06) 0%, transparent 40%);
}
/* Grain overlay */
.hero-dark::after{
  content:'';
  position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.07'/%3E%3C/svg%3E");
  opacity:.4; pointer-events:none;
}
.hero-dark-content{ position:relative; z-index:2; }
.hero-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-size:11px; font-weight:600; letter-spacing:3px;
  text-transform:uppercase; color:var(--gold2);
  margin-bottom:24px;
}
.hero-eyebrow::before{ content:''; width:32px; height:1px; background:var(--gold); opacity:.6; }
.hero-h1{
  font-family:'Playfair Display',serif;
  font-size:clamp(44px,4.8vw,68px);
  font-weight:700; line-height:1.08;
  color:#fff; margin-bottom:22px;
}
.hero-h1 em{ font-style:italic; color:var(--gold2); }
.hero-h1 .outline{
  -webkit-text-stroke:1.5px rgba(255,255,255,.35);
  color:transparent; display:block;
}
.hero-p{
  font-size:15.5px; color:rgba(255,255,255,.6);
  line-height:1.85; font-weight:300;
  margin-bottom:36px; max-width:400px;
}
.hero-btns{ display:flex; gap:14px; flex-wrap:wrap; }
.btn-gold{
  display:inline-flex; align-items:center; gap:9px;
  padding:14px 30px; background:var(--gold);
  color:var(--choco-dark); font-size:14px; font-weight:700;
  text-decoration:none; border-radius:4px;
  letter-spacing:.3px; transition:all .2s;
}
.btn-gold:hover{ background:var(--gold2); transform:translateY(-1px); box-shadow:0 8px 24px rgba(212,168,75,.35); }
.btn-ghost-light{
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 24px; color:rgba(255,255,255,.75);
  border:1.5px solid rgba(255,255,255,.2); border-radius:4px;
  font-size:14px; font-weight:500; text-decoration:none;
  transition:all .2s;
}
.btn-ghost-light:hover{ border-color:rgba(255,255,255,.5); color:#fff; background:rgba(255,255,255,.06); }

/* Floating cocoa bean decorations */
.cocoa-float{
  position:absolute; pointer-events:none;
  font-size:var(--fs); opacity:var(--op);
  left:var(--x); top:var(--y);
  animation: floatBean var(--dur) ease-in-out infinite alternate;
  filter:drop-shadow(0 4px 12px rgba(0,0,0,.4));
  z-index:1;
}
@keyframes floatBean{
  0%{ transform:translateY(0) rotate(var(--r1)); }
  100%{ transform:translateY(-14px) rotate(var(--r2)); }
}

.hero-metrics{
  display:flex; gap:0; margin-top:44px;
  padding-top:32px; border-top:1px solid rgba(255,255,255,.1);
}
.metric{
  flex:1; padding-right:24px;
  border-right:1px solid rgba(255,255,255,.1);
  margin-right:24px;
}
.metric:last-child{ border:none; padding:0; margin:0; }
.metric-val{
  font-family:'Playfair Display',serif;
  font-size:32px; font-weight:700; color:var(--gold2); line-height:1;
}
.metric-lbl{ font-size:11px; color:rgba(255,255,255,.4); margin-top:4px; letter-spacing:.5px; font-weight:500; }

/* Right: cream/light product side */
.hero-light{
  width:42%; flex-shrink:0;
  background:var(--parchment);
  position:relative; overflow:hidden;
  padding:60px 0 60px 60px;
  display:flex; flex-direction:column; gap:16px; justify-content:center;
}
/* Subtle bg pattern */
.hero-light::before{
  content:'';
  position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 90% 10%, rgba(192,120,40,.08) 0%,transparent 50%),
    radial-gradient(circle at 10% 90%, rgba(192,120,40,.05) 0%,transparent 40%);
  pointer-events:none;
}
.hero-light-inner{ position:relative; z-index:1; padding-right:60px; }

/* Product card hero */
.hero-prod{
  background:#fff; border-radius:14px; overflow:hidden;
  box-shadow:var(--shadow-md); border:1px solid var(--border);
}
.hp-img{
  height:270px; position:relative;
  background:linear-gradient(145deg,var(--cream2),var(--sand));
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
/* hp-img-emoji replaced with real image */
.hp-lbl{
  position:absolute; top:14px; left:14px;
  background:var(--choco); color:#fff;
  font-size:11px; font-weight:700;
  padding:5px 14px; border-radius:20px; letter-spacing:.5px;
}
.hp-fav{
  position:absolute; top:14px; right:14px;
  width:38px; height:38px; background:rgba(255,255,255,.92);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  border:none; cursor:pointer; color:var(--t-light);
  box-shadow:0 2px 12px rgba(0,0,0,.12); transition:all .2s;
}
.hp-fav:hover{ color:var(--caramel); }
.hp-fav svg{ width:16px; height:16px; }
.hp-img-tag{
  position:absolute; bottom:14px; right:14px;
  background:var(--caramel); color:#fff;
  font-size:12px; font-weight:700; padding:5px 14px;
  border-radius:20px;
}
.hp-body{ padding:22px; }
.hp-cat{ font-size:10.5px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--caramel); margin-bottom:5px; }
.hp-name{ font-family:'Playfair Display',serif; font-size:21px; color:var(--choco); margin-bottom:4px; }
.hp-desc{ font-size:13px; color:var(--t-light); margin-bottom:16px; line-height:1.6; font-weight:300; }
.hp-size{ display:flex; gap:7px; flex-wrap:wrap; margin-bottom:16px; }
.sz-btn{
  padding:4px 12px; border:1.5px solid var(--border);
  border-radius:20px; font-size:12px; color:var(--t-mid);
  cursor:pointer; background:none; font-family:'Jost',sans-serif;
  transition:all .15s;
}
.sz-btn.ac,.sz-btn:hover{ border-color:var(--caramel); color:var(--caramel); background:rgba(192,120,40,.06); }
.hp-foot{ display:flex; align-items:center; justify-content:space-between; }
.hp-price{ font-size:26px; font-weight:700; color:var(--choco); }
.hp-price small{ font-size:12px; color:var(--t-light); font-weight:400; display:block; text-decoration:line-through; }
.add-btn{
  display:flex; align-items:center; gap:8px;
  padding:11px 22px; background:var(--caramel); color:#fff;
  border:none; border-radius:4px; font-family:'Jost',sans-serif;
  font-size:13px; font-weight:700; cursor:pointer; transition:all .2s;
  letter-spacing:.3px;
}
.add-btn:hover{ background:var(--caramel2); }
.add-btn svg{ width:16px; height:16px; }

/* Mini product row */
.hero-minis{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.hmini{
  background:#fff; border:1px solid var(--border);
  border-radius:10px; padding:14px 16px;
  display:flex; gap:12px; align-items:center;
  cursor:pointer; transition:all .2s;
  box-shadow:0 2px 10px rgba(26,13,6,.05);
}
.hmini:hover{ border-color:var(--caramel); box-shadow:0 6px 20px rgba(26,13,6,.1); }
.hmini-img{
  width:52px; height:52px; border-radius:8px;
  background:var(--cream2); display:flex; align-items:center;
  justify-content:center; font-size:26px; flex-shrink:0;
}
.hmini-cat{ font-size:10px; text-transform:uppercase; letter-spacing:1.5px; color:var(--t-light); font-weight:600; }
.hmini-name{ font-size:13px; font-weight:600; color:var(--choco); margin:2px 0; }
.hmini-price{ font-size:13px; font-weight:700; color:var(--caramel); }

@media(max-width:1024px){
  .hero-light{ width:48%; }
  .hero-dark{ padding:60px 50px 60px 0; }
}
@media(max-width:768px){
  .hero{ flex-direction:column; }
  .hero-dark{ padding:60px 20px; }
  .hero-light{ width:100%; padding:40px 20px; }
  .hero-light-inner{ padding-right:0; }
  .hero-h1{ font-size:44px; }
}

/* ═══════════════════════════════════════════════
   TORN PAPER DIVIDERS
═══════════════════════════════════════════════ */
.torn-divider{ position:relative; height:0px; overflow:hidden; display:block; }
.torn-divider svg{ position:absolute; width:100%; height:100%; }
/* Dark to Light */
.torn-d2l{ background:var(--cream); }
.torn-d2l svg path{ fill:var(--choco-dark); }
/* Light to Dark */
.torn-l2d{ background:var(--choco-dark); }
.torn-l2d svg path{ fill:var(--parchment); }
/* Choco to Sand */
.torn-c2s{ background:var(--sand); }
.torn-c2s svg path{ fill:var(--choco); }
/* Sand to Choco */
.torn-s2c{ background:var(--choco); }
.torn-s2c svg path{ fill:var(--sand); }

/* ═══════════════════════════════════════════════
   TRUST BAND
═══════════════════════════════════════════════ */
.trust-band{ background:var(--choco); padding:20px 0; }
.trust-inner{
  display:flex; align-items:center; justify-content:center;
  gap:48px; flex-wrap:wrap;
}
.ti{
  display:flex; align-items:center; gap:10px;
  font-size:12.5px; color:rgba(255,255,255,.6); font-weight:500;
}
.ti svg{ width:17px; height:17px; color:var(--gold2); }
@media(max-width:768px){ .trust-inner{ gap:20px; justify-content:flex-start; } }

/* ═══════════════════════════════════════════════
   SECTION COMMONS
═══════════════════════════════════════════════ */
.section{ padding:80px 0; }
.section-dark{ background:var(--choco-dark); }
.section-sand{ background:var(--sand); }
.section-choco{ background:var(--choco); }

.sec-head{ display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:52px; }
.sec-eye{
  font-size:11px; font-weight:700; letter-spacing:3px;
  text-transform:uppercase; color:var(--caramel);
  margin-bottom:10px;
  display:flex; align-items:center; gap:10px;
}
.sec-eye::after{ content:''; width:40px; height:1px; background:var(--caramel); opacity:.5; }
.sec-tit{
  font-family:'Playfair Display',serif;
  font-size:36px; font-weight:700; color:var(--choco); line-height:1.1;
}
.sec-tit.light{ color:#fff; }
.sec-tit em{ font-style:italic; }
.see-all{
  display:inline-flex; align-items:center; gap:7px;
  font-size:13px; font-weight:600; color:var(--t-mid);
  text-decoration:none; white-space:nowrap;
  padding:9px 20px; border:1.5px solid var(--border2);
  border-radius:4px; transition:all .2s;
}
.see-all:hover{ border-color:var(--caramel); color:var(--caramel); }
.see-all.light{ color:rgba(255,255,255,.6); border-color:rgba(255,255,255,.2); }
.see-all.light:hover{ color:#fff; border-color:rgba(255,255,255,.5); }
@media(max-width:600px){ .sec-head{flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:28px;} .sec-tit{font-size:28px;} }

/* ═══════════════════════════════════════════════
   CATEGORY CARDS
═══════════════════════════════════════════════ */
.cat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.cat-card{
  position:relative; border-radius:10px; overflow:hidden;
  aspect-ratio:3/4; cursor:pointer; display:block; text-decoration:none;
}
.cat-bg{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-size:80px; transition:transform .5s cubic-bezier(.4,0,.2,1);
}
.cat-card:hover .cat-bg{ transform:scale(1.07); } .cat-card:hover .cat-bg img{ transform:scale(1.07); }
.cat-c1 .cat-bg{ background:linear-gradient(145deg,#f4e8d0,#e4cfb0); }
.cat-c2 .cat-bg{ background:linear-gradient(145deg,#e8d5c0,#d4bb98); }
.cat-c3 .cat-bg{ background:linear-gradient(145deg,#f0e4d0,#dccaaa); }
.cat-c4 .cat-bg{ background:linear-gradient(145deg,#e8dcc8,#d4c0a0); }
.cat-overlay{
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(26,13,6,.8) 0%,rgba(26,13,6,.15) 50%, transparent 100%);
}
.cat-body{ position:absolute; bottom:0; left:0; right:0; padding:22px; }
.cat-pill{
  display:inline-flex; align-items:center;
  background:rgba(255,255,255,.14); backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.8); font-size:10px;
  font-weight:700; letter-spacing:1.5px; text-transform:uppercase;
  padding:4px 10px; border-radius:20px; margin-bottom:8px;
}
.cat-name{ font-family:'Playfair Display',serif; font-size:22px; font-weight:700; color:#fff; margin-bottom:3px; }
.cat-count{ font-size:12px; color:rgba(255,255,255,.55); }
@media(max-width:900px){ .cat-grid{grid-template-columns:1fr 1fr;} }
@media(max-width:480px){ .cat-grid{grid-template-columns:1fr;} }

/* ═══════════════════════════════════════════════
   PRODUCT CARDS
═══════════════════════════════════════════════ */
.prod-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.pcard{
  background:#fff; border:1px solid var(--border);
  border-radius:10px; overflow:hidden;
  transition:all .28s cubic-bezier(.4,0,.2,1);
  cursor:pointer; position:relative;
}
.pcard:hover{
  transform:translateY(-5px);
  box-shadow:var(--shadow-lg);
  border-color:transparent;
}
.pcard-img{
  height:230px; position:relative;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.pc1 .pcard-img{ background:linear-gradient(145deg,#f4e8d0,#e8d4b0); }
.pc2 .pcard-img{ background:linear-gradient(145deg,#e8d5c0,#d4bba0); }
.pc3 .pcard-img{ background:linear-gradient(145deg,#f0e8d0,#e4d0b0); }
.pc4 .pcard-img{ background:linear-gradient(145deg,#ece0c8,#dccaaa); }
.pc-real-img{ width:100%; height:100%; object-fit:contain; padding:16px; transition:transform .35s; }
.pcard:hover .pc-real-img{ transform:scale(1.08); }
.pc-fav{
  position:absolute; top:12px; right:12px;
  width:36px; height:36px; background:rgba(255,255,255,.95);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border); cursor:pointer; color:var(--t-light);
  box-shadow:0 2px 10px rgba(0,0,0,.1); transition:all .2s;
}
.pc-fav:hover{ color:var(--caramel); border-color:var(--caramel); }
.pc-fav svg{ width:15px; height:15px; }
.pc-badge{
  position:absolute; top:12px; left:12px;
  font-size:10.5px; font-weight:700; padding:4px 10px;
  border-radius:4px; letter-spacing:.5px; text-transform:uppercase;
}
.pb-new{ background:var(--choco); color:#fff; }
.pb-sale{ background:var(--caramel); color:#fff; }
.pcard-bd{ padding:20px; }
.pc-cat{ font-size:10.5px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--caramel); margin-bottom:5px; }
.pc-name{ font-family:'Playfair Display',serif; font-size:17px; color:var(--choco); margin-bottom:4px; line-height:1.35; }
.pc-desc{ font-size:12.5px; color:var(--t-light); margin-bottom:12px; line-height:1.55; font-weight:300; }
.pc-sizes{ display:flex; gap:6px; margin-bottom:14px; flex-wrap:wrap; }
.psz{
  padding:4px 10px; border:1.5px solid var(--border);
  border-radius:20px; font-size:11.5px; color:var(--t-mid);
  cursor:pointer; background:none; font-family:'Jost',sans-serif;
  transition:all .15s;
}
.psz.ac,.psz:hover{ border-color:var(--caramel); color:var(--caramel); background:rgba(192,120,40,.06); }
.pc-foot{ display:flex; align-items:center; justify-content:space-between; }
.pc-price{ font-size:20px; font-weight:700; color:var(--choco); }
.pc-price-old{ font-size:11.5px; color:var(--t-light); text-decoration:line-through; display:block; }
.pc-add{
  width:42px; height:42px; background:var(--choco); border:none;
  border-radius:6px; display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:#fff; transition:all .2s;
}
.pc-add:hover{ background:var(--caramel); transform:scale(1.06); }
.pc-add svg{ width:17px; height:17px; }
@media(max-width:1100px){ .prod-grid{grid-template-columns:repeat(3,1fr);} }
@media(max-width:768px){ .prod-grid{grid-template-columns:repeat(2,1fr);} .pcard-img{height:180px;} }
@media(max-width:420px){ .prod-grid{grid-template-columns:1fr;} }

/* ═══════════════════════════════════════════════
   STORY — DARK CHOCOLATE SECTION
═══════════════════════════════════════════════ */
.story-section{
  background:var(--choco-dark); padding:80px 0;
  position:relative; overflow:hidden;
}
.story-section::before{
  content:'';
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 70% 80% at 80% 50%, rgba(90,46,18,.5) 0%,transparent 60%),
    radial-gradient(circle at 15% 70%, rgba(192,120,40,.08) 0%,transparent 40%);
  pointer-events:none;
}
.story-inner{
  display:grid; grid-template-columns:1fr 1fr;
  gap:80px; align-items:center; position:relative; z-index:1;
}
.story-img-col{ position:relative; }
.story-img-frame{ overflow:hidden;
  aspect-ratio:4/5; background:linear-gradient(135deg,var(--choco-mid),var(--choco-warm));
  border-radius:12px; display:flex; align-items:center; justify-content:center;
  font-size:120px; position:relative; overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
}
.story-img-frame::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(26,13,6,.6) 0%,transparent 60%);
}
.story-overlay-text{
  position:absolute; bottom:30px; left:30px; right:30px; z-index:1;
}
.sot-quote{
  font-family:'Playfair Display',serif; font-size:18px;
  font-style:italic; color:rgba(255,255,255,.8); line-height:1.6;
}
.sot-attr{ font-size:12px; color:var(--gold2); margin-top:10px; font-weight:600; letter-spacing:1px; }
.story-badge{
  position:absolute; top:-16px; right:-16px;
  width:80px; height:80px; background:var(--gold);
  border-radius:50%; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  box-shadow:0 8px 24px rgba(212,168,75,.4);
}
.story-badge-num{ font-family:'Playfair Display',serif; font-size:22px; font-weight:700; color:var(--choco-dark); line-height:1; }
.story-badge-lbl{ font-size:8px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--choco-dark); }
.story-text-col{}
.story-kicker{ font-size:11px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--gold2); margin-bottom:18px; }
.story-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(34px,3.5vw,52px); font-weight:700;
  color:#fff; line-height:1.1; margin-bottom:24px;
}
.story-title em{ font-style:italic; color:var(--gold2); }
.story-body{
  font-size:15px; color:rgba(255,255,255,.6);
  line-height:1.9; font-weight:300; margin-bottom:28px;
}
.story-list{ list-style:none; margin-bottom:32px; }
.story-list li{
  display:flex; align-items:flex-start; gap:10px;
  font-size:14px; color:rgba(255,255,255,.65);
  padding:8px 0; border-bottom:1px solid rgba(255,255,255,.06);
}
.story-list li::before{ content:'✦'; color:var(--gold); font-size:10px; margin-top:4px; flex-shrink:0; }
.btn-gold-outline{
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 28px; border:1.5px solid var(--gold);
  color:var(--gold); text-decoration:none;
  font-size:13.5px; font-weight:600; border-radius:4px;
  transition:all .2s; letter-spacing:.3px;
}
.btn-gold-outline:hover{ background:var(--gold); color:var(--choco-dark); }
@media(max-width:768px){ .story-inner{grid-template-columns:1fr;gap:40px;} .story-img-frame{ overflow:hidden;aspect-ratio:16/9;font-size:80px;} }

/* ═══════════════════════════════════════════════
   PROCESS STEPS
═══════════════════════════════════════════════ */
.process-grid{
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:0; margin-top:48px;
  border:1px solid var(--border); border-radius:10px; overflow:hidden;
}
.proc-step{
  padding:32px 28px; background:#fff;
  border-right:1px solid var(--border); position:relative;
  transition:background .2s;
}
.proc-step:last-child{ border-right:none; }
.proc-step:hover{ background:var(--parchment); }
.proc-num{
  font-family:'Playfair Display',serif;
  font-size:48px; font-weight:700; color:var(--cream3);
  line-height:1; margin-bottom:14px;
}
.proc-icon{ font-size:32px; margin-bottom:12px; display:block; }
.proc-title{ font-size:15px; font-weight:700; color:var(--choco); margin-bottom:8px; }
.proc-body{ font-size:12.5px; color:var(--t-light); line-height:1.65; font-weight:300; }
.proc-arrow{
  position:absolute; top:50%; right:-14px;
  transform:translateY(-50%);
  width:28px; height:28px; background:#fff;
  border:1px solid var(--border); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:12px; color:var(--t-light); z-index:1;
}
.proc-step:last-child .proc-arrow{ display:none; }
@media(max-width:768px){ .process-grid{grid-template-columns:1fr 1fr;} .proc-arrow{display:none;} }
@media(max-width:420px){ .process-grid{grid-template-columns:1fr;} }

/* ═══════════════════════════════════════════════
   REVIEWS
═══════════════════════════════════════════════ */
.rev-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.rev-card{
  background:#fff; border-radius:10px; padding:28px;
  border:1px solid var(--border); transition:all .2s;
}
.rev-card:hover{ box-shadow:var(--shadow-md); border-color:transparent; }
.rev-stars{ display:flex; gap:3px; margin-bottom:14px; }
.rs{ color:var(--caramel); font-size:15px; }
.rev-txt{
  font-family:'Playfair Display',serif; font-size:16px;
  font-style:italic; color:var(--t-dark); line-height:1.75; margin-bottom:20px;
}
.rev-auth{ display:flex; align-items:center; gap:12px; }
.rev-av{
  width:40px; height:40px; background:var(--cream3);
  border-radius:50%; display:flex; align-items:center;
  justify-content:center; font-size:20px; flex-shrink:0;
}
.rev-name{ font-size:13.5px; font-weight:600; color:var(--choco); }
.rev-loc{ font-size:11.5px; color:var(--t-light); margin-top:1px; }
@media(max-width:768px){ .rev-grid{grid-template-columns:1fr;} }

/* ═══════════════════════════════════════════════
   NEWSLETTER — DARK CHOCOLATE
═══════════════════════════════════════════════ */
.nl-section{
  background:var(--choco); padding:70px 0;
  position:relative; overflow:hidden;
}
.nl-section::before{
  content:'';
  position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 80% at 20% 50%,rgba(192,120,40,.1) 0%,transparent 60%);
}
.nl-inner{
  display:grid; grid-template-columns:1fr 1fr;
  gap:80px; align-items:center; position:relative; z-index:1;
}
.nl-kicker{ font-size:11px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--gold2); margin-bottom:14px; }
.nl-title{ font-family:'Playfair Display',serif; font-size:34px; font-weight:700; color:#fff; margin-bottom:12px; line-height:1.15; }
.nl-title em{ font-style:italic; color:var(--gold2); }
.nl-sub{ font-size:14px; color:rgba(255,255,255,.55); line-height:1.75; font-weight:300; }
.nl-form{ display:flex; border-radius:6px; overflow:hidden; box-shadow:0 8px 30px rgba(0,0,0,.3); }
.nl-in{
  flex:1; padding:0 20px; height:54px;
  border:none; outline:none; background:#fff;
  font-family:'Jost',sans-serif; font-size:14px; color:var(--t-dark);
}
.nl-in::placeholder{ color:var(--t-light); }
.nl-btn{
  background:var(--gold); color:var(--choco-dark); border:none;
  padding:0 28px; height:54px;
  font-family:'Jost',sans-serif; font-size:13.5px; font-weight:700;
  cursor:pointer; transition:background .2s; white-space:nowrap;
  letter-spacing:.3px;
}
.nl-btn:hover{ background:var(--gold2); }
.nl-perks{ display:flex; gap:20px; margin-top:16px; flex-wrap:wrap; }
.nl-perk{ display:flex; align-items:center; gap:6px; font-size:12.5px; color:rgba(255,255,255,.5); }
.nl-perk::before{ content:'✓'; color:var(--gold2); font-weight:700; }
@media(max-width:768px){ .nl-inner{grid-template-columns:1fr;gap:30px;} .nl-form{flex-direction:column;border-radius:8px;} .nl-in{border-radius:8px 8px 0 0;height:48px;} .nl-btn{border-radius:0 0 8px 8px;height:48px;} }

/* ═══════════════════════════════════════════════
   MEGA FOOTER
═══════════════════════════════════════════════ */
footer{ background:var(--choco-dark); color:rgba(255,255,255,.55); padding-top:60px; }

.f-trust{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.07); }
.ft-item{ display:flex; align-items:center; gap:14px; }
.ft-icon{ width:44px; height:44px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.ft-lbl{ font-size:13.5px; font-weight:600; color:rgba(255,255,255,.8); }
.ft-sub{ font-size:11.5px; color:rgba(255,255,255,.35); margin-top:1px; }
@media(max-width:768px){ .f-trust{grid-template-columns:1fr 1fr;} }
@media(max-width:420px){ .f-trust{grid-template-columns:1fr;} }

.f-main{ display:grid; grid-template-columns:2.2fr 1fr 1fr 1fr 1fr; gap:40px; padding:52px 0; border-bottom:1px solid rgba(255,255,255,.07); }

/* Brand col */
.f-brand-logo{ display:flex; align-items:center; gap:10px; margin-bottom:18px; }
.f-logo-em{ width:42px; height:42px; background:var(--choco-warm); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:20px; }
.f-logo-name{ font-family:'Playfair Display',serif; font-size:22px; font-weight:700; color:#fff; }
.f-logo-name span{ color:var(--caramel2); }
.f-desc{ font-size:13px; color:rgba(255,255,255,.4); line-height:1.85; max-width:280px; margin-bottom:22px; font-weight:300; }
.f-socials{ display:flex; gap:8px; margin-bottom:22px; }
.f-soc{ width:38px; height:38px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:17px; cursor:pointer; text-decoration:none; transition:all .2s; }
.f-soc:hover{ background:var(--caramel); border-color:var(--caramel); }
.f-certs{ display:flex; gap:8px; flex-wrap:wrap; }
.f-cert{ background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); border-radius:4px; padding:5px 12px; font-size:11px; color:rgba(255,255,255,.4); font-weight:700; display:flex; align-items:center; gap:5px; }
.f-cert::before{ content:'✓'; color:var(--gold2); }

/* Cols */
.f-col-title{ font-family:'Playfair Display',serif; font-size:15px; font-weight:700; color:rgba(255,255,255,.8); margin-bottom:20px; letter-spacing:.3px; }
.f-link{ display:flex; align-items:center; gap:7px; font-size:12.5px; color:rgba(255,255,255,.4); text-decoration:none; padding:5px 0; transition:color .2s; line-height:1.4; }
.f-link:hover{ color:var(--gold2); }
.f-link svg{ width:12px; height:12px; opacity:.4; flex-shrink:0; }

/* Contact col */
.f-contact-item{ display:flex; align-items:flex-start; gap:12px; margin-bottom:16px; }
.f-ci-icon{ width:32px; height:32px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:7px; display:flex; align-items:center; justify-content:center; font-size:15px; flex-shrink:0; margin-top:1px; }
.f-ci-top{ font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:rgba(255,255,255,.3); margin-bottom:2px; }
.f-ci-val{ font-size:12.5px; color:rgba(255,255,255,.55); line-height:1.5; }
.f-ci-val a{ color:rgba(255,255,255,.65); text-decoration:none; transition:color .2s; }
.f-ci-val a:hover{ color:var(--gold2); }

/* Map snippet */
.f-map{
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  border-radius:8px; padding:14px; margin-top:14px;
  display:flex; align-items:center; gap:10px;
  cursor:pointer; transition:background .2s;
}
.f-map:hover{ background:rgba(255,255,255,.07); }
.f-map-icon{ font-size:24px; }
.f-map-text{ font-size:11.5px; color:rgba(255,255,255,.4); }
.f-map-text strong{ display:block; color:rgba(255,255,255,.65); font-size:12.5px; }

@media(max-width:1200px){ .f-main{grid-template-columns:1fr 1fr 1fr;} .f-main>:first-child{grid-column:span 3;} }
@media(max-width:768px){ .f-main{grid-template-columns:1fr 1fr;} .f-main>:first-child{grid-column:span 2;} }
@media(max-width:480px){ .f-main{grid-template-columns:1fr;} .f-main>:first-child{grid-column:span 1;} }

/* Footer bottom */
.f-bottom{
  padding:20px 0;
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:14px;
}
.f-copy{ font-size:12px; color:rgba(255,255,255,.25); }
.f-copy a{ color:rgba(255,255,255,.35); text-decoration:none; }
.f-bottom-links{ display:flex; gap:18px; flex-wrap:wrap; }
.f-bottom-links a{ font-size:12px; color:rgba(255,255,255,.3); text-decoration:none; transition:color .2s; }
.f-bottom-links a:hover{ color:rgba(255,255,255,.65); }
.f-pay{ display:flex; gap:6px; }
.fpay{ background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:3px; padding:4px 10px; font-size:10.5px; font-weight:700; color:rgba(255,255,255,.35); }
@media(max-width:600px){ .f-bottom{flex-direction:column;align-items:flex-start;} }

/* ═══════════════════════════════════════════════
   MOBILE NAV
═══════════════════════════════════════════════ */
.mnav{
  display:none; background:#fff;
  border-top:1px solid var(--border);
  position:fixed; bottom:0; left:0; right:0;
  z-index:900; box-shadow:0 -4px 24px rgba(26,13,6,.1);
}
.mnav-inner{ display:flex; }
.mnb{
  display:flex; flex-direction:column; align-items:center;
  gap:4px; flex:1; padding:10px 4px;
  text-decoration:none; font-size:9.5px; font-weight:700;
  letter-spacing:.5px; text-transform:uppercase;
  color:var(--t-light); border:none; background:none;
  cursor:pointer; font-family:'Jost',sans-serif;
  transition:color .15s; position:relative;
}
.mnb svg{ width:22px; height:22px; }
.mnb.act{ color:var(--caramel); }
.mnb-badge{
  position:absolute; top:6px;
  right:calc(50% - 18px);
  background:var(--caramel); color:#fff;
  font-size:8px; font-weight:700;
  width:14px; height:14px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}
@media(max-width:768px){ .mnav{display:block;} body{padding-bottom:64px;} }

/* ═══════════════════════════════════════════════
   SCROLL FADE ANIMATIONS
═══════════════════════════════════════════════ */
.fade{ opacity:1; transform:translateY(0); transition:opacity .7s cubic-bezier(.4,0,.2,1), transform .7s cubic-bezier(.4,0,.2,1); }
.fade.in{ opacity:1; transform:translateY(0); }
.fade-l{ opacity:1; transform:translateX(0); transition:opacity .7s cubic-bezier(.4,0,.2,1), transform .7s cubic-bezier(.4,0,.2,1); }
.fade-l.in{ opacity:1; transform:translateX(0); }
.fade-r{ opacity:1; transform:translateX(0); transition:opacity .7s cubic-bezier(.4,0,.2,1), transform .7s cubic-bezier(.4,0,.2,1); }
.fade-r.in{ opacity:1; transform:translateX(0); }

/* ═══════════════════════════════════════════════
   PARALLAX COCOA BEANS (hero decoration)
═══════════════════════════════════════════════ */
@keyframes drift1{ 0%{transform:translateY(0) rotate(12deg);} 100%{transform:translateY(-18px) rotate(18deg);} }
@keyframes drift2{ 0%{transform:translateY(0) rotate(-8deg);} 100%{transform:translateY(-12px) rotate(-15deg);} }
@keyframes drift3{ 0%{transform:translateY(0) rotate(25deg);} 100%{transform:translateY(-22px) rotate(32deg);} }
