/* ============================================================
   MEWA — Hand-Sorted Dry Fruits & Spices
   Design tokens
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,500&family=Outfit:wght@300;400;500;600;700&display=swap');

:root{
  /* ---- colour: Tayyibaat logo — deep emerald border, calligraphy red, warm cream ---- */
  --walnut-950:#006b3e;
  --walnut-900:#123A26;
  --walnut-800:#1C4A30;
  --walnut-700:#2B6B45;
  --saffron-600:#8F323A;
  --saffron-500:#B5414B;
  --saffron-400:#CB6E76;
  --gold-500:#3FA34D;
  --gold-300:#9FE3A0;
  --pistachio-600:#2E6B3E;
  --pistachio-500:#3FA34D;
  --cream-100:#FAF8EF;
  --cream-200:#F1EEDD;
  --cream-300:#E3DEC4;
  --ink-900:#16241B;
  --ink-700:#44574A;
  --white:#FFFFFF;

  --font-display:'Fraunces', serif;
  --font-body:'Outfit', sans-serif;

  --container:1280px;
  --radius-s:6px;
  --radius-m:14px;
  --radius-l:28px;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important;}
}
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--cream-100);
  color:var(--ink-900);
  -webkit-font-smoothing:antialiased;
  font-size:16px;
  line-height:1.6;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;list-style:none;}
button{font-family:inherit;cursor:pointer;}
h1,h2,h3,h4{font-family:var(--font-display);margin:0;font-weight:600;letter-spacing:-0.01em;color:var(--ink-900);}
p{margin:0;}
.container{max-width:var(--container);margin:0 auto;padding:0 32px;}
@media (max-width:720px){.container{padding:0 20px;}}

:focus-visible{outline:2px solid var(--saffron-500);outline-offset:3px;border-radius:4px;}

/* ---------- type utilities ---------- */
.eyebrow{
  font-family:var(--font-body);
  font-size:12px;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--saffron-600);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:"";
  width:16px;height:1px;background:currentColor;display:inline-block;
}
.eyebrow.on-dark{color:var(--gold-300);}

.section-head{display:flex;flex-direction:column;gap:14px;margin-bottom:44px;}
.section-head .eyebrow{margin-bottom:2px;}
.section-head h2{font-size:clamp(28px,3.6vw,44px);max-width:640px;}
.section-head p{color:var(--ink-700);max-width:520px;font-size:16px;}
.section-head.split{flex-direction:row;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:20px;}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:15px 30px;border-radius:999px;border:1px solid transparent;
  font-family:var(--font-body);font-weight:600;font-size:14px;letter-spacing:.02em;
  transition:transform .35s var(--ease), background .25s, color .25s, border-color .25s, box-shadow .25s;
  white-space:nowrap;
}
.btn-primary{background:var(--saffron-500);color:var(--cream-100);box-shadow:0 10px 24px -10px rgba(181,65,75,.7);}
.btn-primary:hover{background:var(--saffron-600);transform:translateY(-2px);}
.btn-ghost{background:transparent;border-color:rgba(36,21,8,.22);color:var(--ink-900);}
.btn-ghost:hover{border-color:var(--ink-900);transform:translateY(-2px);}
.btn-ghost.on-dark{border-color:rgba(251,247,240,.35);color:var(--cream-100);}
.btn-ghost.on-dark:hover{border-color:var(--gold-300);color:var(--gold-300);}
.btn-line{
  display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;
  border-bottom:1px solid currentColor;padding-bottom:3px;color:var(--saffron-600);
  transition:gap .3s var(--ease), color .2s;
}
.btn-line:hover{gap:14px;}
.btn-sm{padding:10px 20px;font-size:13px;}

/* ============================================================
   Saffron-thread divider — signature element
   ============================================================ */
.thread{
  position:relative;
  width:100%;
  height:34px;
  overflow:hidden;
}
.thread svg{position:absolute;left:50%;top:0;width:max(1280px,140%);transform:translateX(-50%);}
.thread path{
  fill:none;stroke:var(--gold-500);stroke-width:1.4;stroke-linecap:round;
  stroke-dasharray:1 9;
}
.thread.dark path{stroke:var(--gold-300);}
.thread .stigma{fill:var(--saffron-500);}
.thread.dark .stigma{fill:var(--gold-300);}

/* ============================================================
   Header
   ============================================================ */
.topbar{background:var(--walnut-950);color:var(--cream-300);font-size:13px;}
.topbar .container{display:flex;align-items:center;justify-content:space-between;height:38px;}
.topbar .ticker{display:flex;gap:28px;letter-spacing:.02em;}
.topbar a:hover{color:var(--gold-300);}

.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(251,247,240,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(36,21,8,.08);
}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:84px;gap:24px;}
.logo{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-size:26px;font-weight:700;letter-spacing:.01em;color:var(--ink-900);}
.logo .mark{width:60px;height:60px;border-radius:11px;object-fit:cover;flex:none;box-shadow:0 2px 8px -2px rgba(14,42,28,.35);}
.logo small{display:block;font-family:var(--font-body);font-size:10px;letter-spacing:.24em;font-weight:600;color:var(--ink-700);text-transform:uppercase;}

.main-nav{display:flex;gap:34px;}
.main-nav a{
  position:relative;font-size:14.5px;font-weight:500;color:var(--ink-900);padding:6px 0;
}
.main-nav a::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;background:var(--saffron-500);
  transition:right .3s var(--ease);
}
.main-nav a:hover::after,.main-nav a.active::after{right:0;}
.main-nav a.active{color:var(--saffron-600);}

.header-actions{display:flex;align-items:center;gap:18px;}
.icon-btn{
  width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:transparent;border:1px solid rgba(36,21,8,.14);color:var(--ink-900);position:relative;
  transition:border-color .25s,background .25s, transform .25s;
}
.icon-btn:hover{border-color:var(--saffron-500);background:var(--cream-200);transform:translateY(-1px);}
.icon-btn svg{width:18px;height:18px;}
.icon-btn .badge{
  position:absolute;top:-5px;right:-5px;width:18px;height:18px;border-radius:50%;
  background:var(--saffron-500);color:#fff;font-size:10px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
.nav-toggle{display:none;}
@media (max-width:980px){
  .main-nav{display:none;}
  .nav-toggle{display:flex;}
}

/* ============================================================
   HERO + slider
   ============================================================ */
.hero{
  position:relative;background:
    radial-gradient(900px 500px at 88% -10%, rgba(63,163,77,.18), transparent 60%),
    linear-gradient(180deg, var(--walnut-900), var(--walnut-950));
  color:var(--cream-100);
  overflow:hidden;
}
.hero .container{
  display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;
  padding-top:84px;padding-bottom:64px;min-height:640px;
}
.hero-copy{position:relative;z-index:2;}
.hero-copy h1{
  font-size:clamp(40px,5.4vw,68px);line-height:1.04;color:var(--cream-100);margin:18px 0 22px;
}
.hero-copy h1 em{font-style:italic;color:var(--gold-300);font-weight:500;}
.hero-copy p.lead{color:rgba(251,247,240,.72);font-size:17px;max-width:480px;margin-bottom:34px;}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:40px;}
.hero-meta{display:flex;gap:32px;flex-wrap:wrap;}
.hero-meta div{display:flex;flex-direction:column;gap:2px;}
.hero-meta strong{font-family:var(--font-display);font-size:24px;color:var(--gold-300);}
.hero-meta span{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:rgba(251,247,240,.55);}

.slider{position:relative;border-radius:var(--radius-l);overflow:hidden;aspect-ratio:5/5.4;box-shadow:0 50px 90px -40px rgba(0,0,0,.65);}
.slide{
  position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .9s var(--ease);
  display:flex;align-items:flex-end;padding:30px;
}
.slide.is-active{opacity:1;visibility:visible;z-index:1;}
.slide .art{position:absolute;inset:0;}
.slide .tag{
  position:relative;
  z-index:2;
  background:rgba(30,18,11,.62);
  backdrop-filter:blur(6px);
  border:1px solid rgba(251,247,240,.18);
  border-radius:var(--radius-m);
  padding:18px 22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  width:100%;
}
.slide .tag h3{color:var(--cream-100);font-size:20px;margin-bottom:4px;}
.slide .tag p{color:var(--gold-300);font-size:13px;letter-spacing:.04em;}
.slide .tag a{
  flex:none;width:46px;height:46px;border-radius:50%;background:var(--saffron-500);color:#fff;
  display:flex;align-items:center;justify-content:center;transition:transform .3s var(--ease),background .25s;
}
.slide .tag a:hover{transform:scale(1.08) rotate(8deg);background:var(--gold-500);}
.slide .tag a svg{width:18px;height:18px;}

.slider-dots{position:absolute;left:30px;bottom:108px;z-index:3;display:flex;gap:8px;}
.slider-dots button{
  width:22px;height:4px;border-radius:3px;border:none;background:rgba(251,247,240,.35);transition:background .3s, width .3s;
}
.slider-dots button.is-active{background:var(--gold-300);width:34px;}

.slide-art-1{background:linear-gradient(135deg,#4A1B20,#B5414B 60%,#CB6E76);}
.slide-art-2{background:linear-gradient(135deg,#0E2A1C,#3FA34D 60%,#9FE3A0);}
.slide-art-3{background:linear-gradient(135deg,#123A26,#8F323A 55%,#3FA34D);}
.fruit-motif{position:absolute;inset:0;opacity:.9;}
.fruit-motif svg{position:absolute;}

/* ============================================================
   Catalogue strip
   ============================================================ */
.catalogue{padding:96px 0 88px;background:var(--cream-100);}
.cat-rail{
  display:grid;grid-auto-flow:column;grid-auto-columns:172px;gap:26px;
  overflow-x:auto;padding-bottom:14px;scroll-snap-type:x proximity;
  scrollbar-width:none;
}
.cat-rail::-webkit-scrollbar{display:none;}
.cat-card{scroll-snap-align:start;text-align:center;}
.cat-jar{
  width:172px;height:172px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:var(--cream-200);border:1px solid var(--cream-300);position:relative;margin-bottom:16px;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), background .4s;
}
.cat-jar svg{width:120px;height:120px;color:var(--walnut-700);transition:transform .4s var(--ease);}
.cat-card:hover .cat-jar{transform:translateY(-6px);box-shadow:0 22px 34px -18px rgba(60,36,18,.35);background:var(--cream-100);}
.cat-card:hover .cat-jar svg{transform:scale(1.1) rotate(-6deg);}
.cat-card h4{font-size:15.5px;font-weight:600;margin-bottom:4px;}
.cat-card span{font-size:12px;color:var(--ink-700);letter-spacing:.03em;}
.rail-nav{display:flex;gap:10px;}
.rail-nav button{
  width:40px;height:40px;border-radius:50%;border:1px solid rgba(36,21,8,.16);background:transparent;
  display:flex;align-items:center;justify-content:center;transition:border-color .25s, background .25s;
}
.rail-nav button:hover{border-color:var(--saffron-500);background:var(--cream-200);}
.rail-nav svg{width:16px;height:16px;}

/* ============================================================
   Product cards (tag motif) — used on featured + listing pages
   ============================================================ */
.grid-products{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;}
@media (max-width:1080px){.grid-products{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.grid-products{grid-template-columns:1fr;}}

.ptag{
  position:relative;background:var(--cream-100);border:1px solid var(--cream-300);border-radius:var(--radius-m);
  padding:20px 20px 22px;transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s;
}
.ptag:hover{transform:translateY(-7px);box-shadow:0 30px 46px -28px rgba(60,36,18,.4);border-color:transparent;}
.ptag .hole{
  position:absolute;top:-10px;left:50%;transform:translateX(-50%);width:20px;height:20px;border-radius:50%;
  background:var(--cream-100);border:1px solid var(--cream-300);
}
.ptag .hole::after{content:"";position:absolute;inset:5px;border-radius:50%;background:var(--walnut-950);opacity:.06;}
.ptag .badge-row{position:absolute;top:14px;left:14px;right:14px;display:flex;justify-content:space-between;z-index:2;}
.ptag .pill{
  font-size:11px;font-weight:700;letter-spacing:.05em;padding:5px 10px;border-radius:999px;
  background:var(--saffron-500);color:#fff;text-transform:uppercase;
}
.ptag .pill.alt{background:var(--pistachio-600);}
.ptag .wish{
  width:30px;height:30px;border-radius:50%;background:rgba(251,247,240,.85);display:flex;align-items:center;justify-content:center;
  border:1px solid var(--cream-300);
}
.ptag .wish svg{width:14px;height:14px;color:var(--ink-700);}
.ptag .photo{
  border-radius:var(--radius-s);aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;position:relative;overflow:hidden;
}
.ptag .photo svg{width:46%;height:46%;}
.ptag h3{font-size:17px;margin-bottom:4px;}
.ptag .sub{font-size:12.5px;color:var(--ink-700);margin-bottom:12px;display:block;}
.ptag .stars{display:flex;gap:3px;margin-bottom:10px;}
.ptag .stars svg{width:13px;height:13px;color:var(--saffron-500);}
.ptag .meta-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.weights{display:flex;gap:6px;}
.weights button{
  font-size:11.5px;font-weight:600;padding:5px 9px;border-radius:7px;border:1px solid var(--cream-300);background:transparent;color:var(--ink-700);
  transition:.2s;
}
.weights button.is-active{background:var(--ink-900);color:var(--cream-100);border-color:var(--ink-900);}
.price-row{display:flex;align-items:center;justify-content:space-between;}
.price{font-family:var(--font-display);font-size:20px;font-weight:600;}
.price del{font-family:var(--font-body);font-size:13px;color:var(--ink-700);opacity:.55;font-weight:400;margin-right:6px;}
.add-btn{
  width:44px;height:44px;border-radius:50%;background:var(--ink-900);color:var(--cream-100);border:none;
  display:flex;align-items:center;justify-content:center;transition:background .25s,transform .3s var(--ease);
}
.add-btn:hover{background:var(--saffron-500);transform:rotate(90deg);}
.add-btn svg{width:18px;height:18px;}

/* fruit swatch backgrounds (placeholder "photography") */
.swatch-almond{background:linear-gradient(150deg,#E7CDA0,#C99A5B);}
.swatch-cashew{background:linear-gradient(150deg,#F1E2BD,#D8B978);}
.swatch-pista{background:linear-gradient(150deg,#CBD79B,#8A9A5B);}
.swatch-walnut{background:linear-gradient(150deg,#C8A077,#8C5A33);}
.swatch-date{background:linear-gradient(150deg,#8C5A33,#3B2417);}
.swatch-fig{background:linear-gradient(150deg,#B98A86,#6E3B33);}
.swatch-saffron{background:linear-gradient(150deg,#E0954A,#B8632A);}
.swatch-mix{background:linear-gradient(150deg,#D9C48A,#8A9A5B);}
.swatch-raisin{background:linear-gradient(150deg,#8E6B86,#3E2A3B);}
.swatch-seed{background:linear-gradient(150deg,#D7C9A3,#9C8552);}
.ptag .photo svg{color:rgba(30,18,11,.55);}

/* ============================================================
   Story / stat band
   ============================================================ */
.story{background:var(--walnut-950);color:var(--cream-200);padding:84px 0;position:relative;}
.story .container{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.story h2{color:var(--cream-100);font-size:clamp(26px,3vw,38px);margin-bottom:18px;}
.story p{color:rgba(251,247,240,.68);max-width:460px;margin-bottom:28px;}
.stat-row{display:flex;gap:40px;flex-wrap:wrap;}
.stat-row div strong{display:block;font-family:var(--font-display);font-size:34px;color:var(--gold-300);}
.stat-row div span{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:rgba(251,247,240,.55);}
.story-art{position:relative;aspect-ratio:1/1;border-radius:var(--radius-l);overflow:hidden;background:linear-gradient(150deg,#2B6B45,#0E2A1C);}

/* ============================================================
   Testimonials
   ============================================================ */
.testimonials{padding:96px 0;background:var(--cream-200);}
.t-rail{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(320px,1fr);gap:24px;overflow-x:auto;scrollbar-width:none;padding-bottom:6px;}
.t-rail::-webkit-scrollbar{display:none;}
.t-card{
  background:var(--cream-100);border:1px solid var(--cream-300);border-radius:var(--radius-m);padding:30px 28px;
  display:flex;flex-direction:column;gap:18px;scroll-snap-align:start;
}
.t-card .stars{display:flex;gap:3px;}
.t-card .stars svg{width:14px;height:14px;color:var(--saffron-500);}
.t-card p{font-family:var(--font-display);font-size:17px;line-height:1.5;color:var(--ink-900);}
.t-who{display:flex;align-items:center;gap:12px;margin-top:auto;}
.t-avatar{
  width:42px;height:42px;border-radius:50%;background:var(--saffron-500);color:#fff;display:flex;align-items:center;
  justify-content:center;font-family:var(--font-display);font-weight:600;
}
.t-who strong{display:block;font-size:14px;}
.t-who span{font-size:12px;color:var(--ink-700);}

/* ============================================================
   CTA band
   ============================================================ */
.cta-band{background:linear-gradient(120deg,var(--saffron-600),var(--saffron-500));color:#fff;padding:64px 0;}
.cta-band .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;}
.cta-band h2{color:#fff;font-size:clamp(24px,2.6vw,32px);max-width:480px;}
.cta-band .btn-primary{background:var(--ink-900);}
.cta-band .btn-primary:hover{background:#000;}

/* ============================================================
   Footer
   ============================================================ */
footer{background:var(--walnut-950);color:rgba(251,247,240,.7);padding-top:0;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1.3fr;gap:40px;padding:76px 0 56px;}
@media (max-width:980px){.footer-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr;}}
.footer-grid h4{color:var(--gold-300);font-family:var(--font-body);font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:18px;}
.footer-grid li{margin-bottom:11px;font-size:14px;}
.footer-grid a:hover{color:var(--gold-300);}
.f-brand .logo{color:var(--cream-100);margin-bottom:14px;}
.f-brand .logo .mark{box-shadow:0 0 0 1px rgba(251,247,240,.25), 0 6px 16px -6px rgba(0,0,0,.5);}
.f-brand p{font-size:14px;color:rgba(251,247,240,.6);max-width:280px;margin-bottom:20px;}
.f-social{display:flex;gap:10px;}
.f-social a{
  width:38px;height:38px;border-radius:50%;border:1px solid rgba(251,247,240,.22);display:flex;align-items:center;justify-content:center;
  transition:border-color .25s,background .25s;
}
.f-social a:hover{border-color:var(--gold-300);background:rgba(201,162,39,.12);}
.f-social svg{width:15px;height:15px;}
.f-news{display:flex;margin-top:14px;border-bottom:1px solid rgba(251,247,240,.3);padding-bottom:10px;max-width:280px;}
.f-news input{background:transparent;border:none;color:#fff;font-size:14px;flex:1;outline:none;font-family:var(--font-body);}
.f-news input::placeholder{color:rgba(251,247,240,.45);}
.f-news button{background:none;border:none;color:var(--gold-300);display:flex;}
.f-news svg{width:18px;height:18px;}
.footer-bottom{
  border-top:1px solid rgba(251,247,240,.12);padding:22px 0 30px;display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:14px;font-size:13px;color:rgba(251,247,240,.5);
}
.pay-icons{display:flex;gap:10px;}
.pay-icons span{
  border:1px solid rgba(251,247,240,.18);border-radius:6px;padding:4px 9px;font-size:11px;letter-spacing:.04em;
}

/* ============================================================
   Reveal-on-scroll
   ============================================================ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease), transform .8s var(--ease);}
.reveal.is-visible{opacity:1;transform:translateY(0);}

/* ============================================================
   Breadcrumb / page header (used on catalogue / shop / product)
   ============================================================ */
.page-header{background:var(--walnut-950);color:var(--cream-200);padding:54px 0 50px;}
.crumbs{display:flex;gap:8px;align-items:center;font-size:13px;color:rgba(251,247,240,.55);margin-bottom:14px;}
.crumbs a:hover{color:var(--gold-300);}
.crumbs svg{width:12px;height:12px;}
.page-header h1{color:var(--cream-100);font-size:clamp(30px,4vw,46px);}
.page-header p{color:rgba(251,247,240,.65);max-width:520px;margin-top:10px;}

/* category grid (catalogue page) */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;padding:80px 0 96px;}
@media (max-width:980px){.cat-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.cat-grid{grid-template-columns:1fr;}}
.cat-tile{
  position:relative;border-radius:var(--radius-m);overflow:hidden;aspect-ratio:4/4.6;display:flex;flex-direction:column;
  justify-content:flex-end;padding:24px;color:#fff;transition:transform .45s var(--ease);
}
.cat-tile:hover{transform:translateY(-8px);}
.cat-tile::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(20,12,7,.82));}
.cat-tile .ico{position:absolute;top:22px;left:22px;width:40px;height:40px;color:rgba(255,255,255,.85);z-index:2;}
.cat-tile .body{position:relative;z-index:2;}
.cat-tile h3{color:#fff;font-size:21px;margin-bottom:4px;}
.cat-tile span{font-size:12.5px;color:rgba(255,255,255,.7);letter-spacing:.03em;}
.cat-tile .arrow{
  position:absolute;top:22px;right:22px;width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.4);
  display:flex;align-items:center;justify-content:center;z-index:2;transition:background .3s, transform .3s var(--ease);
}
.cat-tile:hover .arrow{background:var(--saffron-500);border-color:var(--saffron-500);transform:rotate(45deg);}
.cat-tile .arrow svg{width:16px;height:16px;color:#fff;}

/* ============================================================
   Shop / listing layout
   ============================================================ */
.shop-layout{display:grid;grid-template-columns:264px 1fr;gap:44px;padding:64px 0 100px;align-items:flex-start;}
@media (max-width:900px){.shop-layout{grid-template-columns:1fr;}}
.filters{display:flex;flex-direction:column;gap:30px;position:sticky;top:106px;}
@media (max-width:900px){.filters{position:relative;top:0;}}
.filter-block{border-bottom:1px solid var(--cream-300);padding-bottom:22px;}
.filter-block h4{font-size:14px;letter-spacing:.05em;text-transform:uppercase;margin-bottom:16px;}
.f-check{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px;font-size:14.5px;cursor:pointer;}
.f-check input{accent-color:var(--saffron-500);width:16px;height:16px;}
.f-check span.count{color:var(--ink-700);font-size:12.5px;}
.price-slider{display:flex;flex-direction:column;gap:10px;}
.price-slider input[type=range]{accent-color:var(--saffron-500);width:100%;}
.price-slider .vals{display:flex;justify-content:space-between;font-size:13px;color:var(--ink-700);}
.swatches{display:flex;gap:8px;flex-wrap:wrap;}
.swatches button{
  font-size:12.5px;padding:7px 13px;border-radius:999px;border:1px solid var(--cream-300);background:#fff;
  transition:.2s;
}
.swatches button.is-active{background:var(--ink-900);color:#fff;border-color:var(--ink-900);}
.clear-filters{font-size:13px;color:var(--saffron-600);font-weight:600;}

.shop-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:14px;}
.shop-toolbar .count{font-size:14px;color:var(--ink-700);}
.shop-toolbar .sort{display:flex;align-items:center;gap:10px;font-size:14px;}
.shop-toolbar select{
  border:1px solid var(--cream-300);background:#fff;border-radius:999px;padding:9px 16px;font-family:var(--font-body);font-size:13.5px;
}
.view-toggle{display:flex;gap:6px;}
.view-toggle button{width:34px;height:34px;border-radius:8px;border:1px solid var(--cream-300);display:flex;align-items:center;justify-content:center;background:#fff;}
.view-toggle button.is-active{border-color:var(--ink-900);}
.view-toggle svg{width:15px;height:15px;}

.pagination{display:flex;justify-content:center;gap:8px;margin-top:56px;}
.pagination a{
  width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;
  border:1px solid var(--cream-300);
}
.pagination a.is-active{background:var(--ink-900);color:#fff;border-color:var(--ink-900);}
.pagination a:hover:not(.is-active){border-color:var(--saffron-500);}

/* mobile filter trigger */
.mobile-filter-btn{display:none;margin-bottom:20px;}
@media (max-width:900px){.mobile-filter-btn{display:inline-flex;}}

/* ============================================================
   Single product page
   ============================================================ */
.product-view{padding:64px 0 30px;display:grid;grid-template-columns:.85fr 1fr;gap:64px;}
@media (max-width:900px){.product-view{grid-template-columns:1fr;gap:36px;}}
.pv-gallery{display:flex;flex-direction:column;gap:16px;}
.pv-main{border-radius:var(--radius-l);aspect-ratio:1/1;position:relative;overflow:hidden;}
.pv-main .ribbon{
  position:absolute;top:22px;left:22px;background:var(--saffron-500);color:#fff;font-size:12px;font-weight:700;
  padding:7px 14px;border-radius:999px;letter-spacing:.03em;z-index:2;
}
.pv-main svg{width:42%;height:42%;color:rgba(30,18,11,.5);}
.pv-main{display:flex;align-items:center;justify-content:center;}
.pv-thumbs{display:flex;gap:14px;}
.pv-thumbs button{
  width:84px;height:84px;border-radius:var(--radius-s);border:2px solid transparent;display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.pv-thumbs button.is-active{border-color:var(--saffron-500);}
.pv-thumbs svg{width:38%;height:38%;color:rgba(30,18,11,.5);}

.pv-info .sub-cat a{color:var(--saffron-600);font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;}
.pv-info h1{font-size:clamp(28px,3.4vw,38px);margin:10px 0 12px;}
.pv-rating{display:flex;align-items:center;gap:10px;margin-bottom:18px;}
.pv-rating .stars{display:flex;gap:3px;}
.pv-rating .stars svg{width:15px;height:15px;color:var(--saffron-500);}
.pv-rating span{font-size:13.5px;color:var(--ink-700);}
.pv-price{display:flex;align-items:baseline;gap:12px;margin-bottom:6px;}
.pv-price strong{font-family:var(--font-display);font-size:32px;}
.pv-price del{color:var(--ink-700);opacity:.55;font-size:16px;}
.pv-price .save{background:var(--pistachio-500);color:#fff;font-size:11.5px;font-weight:700;padding:4px 9px;border-radius:6px;}
.pv-desc{color:var(--ink-700);font-size:15px;line-height:1.7;margin:18px 0 26px;max-width:480px;}

.opt-block{margin-bottom:24px;}
.opt-block h4{font-size:13px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:12px;color:var(--ink-700);}
.opt-pills{display:flex;gap:10px;flex-wrap:wrap;}
.opt-pills button{
  padding:11px 20px;border-radius:999px;border:1px solid var(--cream-300);background:#fff;font-size:14px;font-weight:500;
  transition:.2s;display:flex;flex-direction:column;align-items:center;gap:1px;
}
.opt-pills button .opt-price{font-size:11.5px;color:var(--ink-700);}
.opt-pills button.is-active{background:var(--ink-900);color:#fff;border-color:var(--ink-900);}
.opt-pills button.is-active .opt-price{color:rgba(255,255,255,.7);}

.qty-row{display:flex;align-items:center;gap:20px;margin-bottom:26px;}
.qty-stepper{display:flex;align-items:center;border:1px solid var(--cream-300);border-radius:999px;overflow:hidden;}
.qty-stepper button{width:42px;height:46px;background:#fff;font-size:18px;}
.qty-stepper button:hover{background:var(--cream-200);}
.qty-stepper input{width:42px;text-align:center;border:none;font-family:var(--font-body);font-weight:600;font-size:15px;}
.pv-cta{display:flex;gap:14px;margin-bottom:30px;}
.pv-cta .btn-primary{flex:1;padding:17px 24px;}
.pv-trust{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;border-top:1px solid var(--cream-300);padding-top:24px;}
.pv-trust div{display:flex;flex-direction:column;gap:8px;font-size:12.5px;color:var(--ink-700);}
.pv-trust svg{width:22px;height:22px;color:var(--saffron-600);}

.pv-tabs{display:flex;gap:36px;border-bottom:1px solid var(--cream-300);margin:88px 0 0;}
.pv-tabs button{
  padding:16px 2px;font-size:15px;font-weight:600;color:var(--ink-700);border-bottom:2px solid transparent;position:relative;top:1px;
}
.pv-tabs button.is-active{color:var(--ink-900);border-color:var(--saffron-500);}
.pv-tabpanel{padding:36px 0 80px;max-width:720px;color:var(--ink-700);font-size:15px;line-height:1.8;}
.pv-tabpanel.hidden{display:none;}
.spec-table{width:100%;border-collapse:collapse;}
.spec-table tr{border-bottom:1px solid var(--cream-300);}
.spec-table td{padding:13px 0;font-size:14.5px;}
.spec-table td:first-child{color:var(--ink-700);width:200px;}
.spec-table td:last-child{font-weight:600;color:var(--ink-900);}

.related{padding:0 0 100px;}

/* badges used in toolbar */
.toast{
  position:fixed;bottom:26px;right:26px;background:var(--ink-900);color:#fff;padding:16px 22px;border-radius:14px;
  display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500;box-shadow:0 20px 40px -16px rgba(0,0,0,.4);
  transform:translateY(20px);opacity:0;transition:.4s var(--ease);z-index:200;
}
.toast.show{transform:translateY(0);opacity:1;}
.toast svg{width:18px;height:18px;color:var(--gold-300);}

/* mobile nav drawer */
.drawer{
  position:fixed;inset:0;z-index:100;visibility:hidden;
}
.drawer.open{visibility:visible;}
.drawer-overlay{position:absolute;inset:0;background:rgba(20,12,7,.5);opacity:0;transition:opacity .35s;}
.drawer.open .drawer-overlay{opacity:1;}
.drawer-panel{
  position:absolute;top:0;right:0;height:100%;width:min(340px,86vw);background:var(--cream-100);
  transform:translateX(100%);transition:transform .4s var(--ease);padding:28px 26px;display:flex;flex-direction:column;gap:6px;
}
.drawer.open .drawer-panel{transform:translateX(0);}
.drawer-panel a{padding:14px 4px;font-size:16px;font-weight:600;border-bottom:1px solid var(--cream-300);}
.drawer-close{align-self:flex-end;width:38px;height:38px;border-radius:50%;border:1px solid var(--cream-300);display:flex;align-items:center;justify-content:center;margin-bottom:10px;}
.drawer-close svg{width:16px;height:16px;}

