/* =================================================================
   MOLY'S KITCHEN — Nature's Wellness, Jarred
   A warm apothecary-kitchen world derived from the mk mark.
   ================================================================= */

:root{
  /* paper & ink */
  --paper:      #F1E7D5;   /* warm bone */
  --paper-2:    #EADCC4;   /* deeper cream */
  --paper-card: #FAF4E8;   /* label cream */
  --ink:        #221C15;   /* warm near-black */
  --ink-soft:   #5C5142;   /* muted ink */
  --line:       rgba(34,28,21,.16);

  /* edible accents (the colour-relativity journey) */
  --honey:  #C68A3E;   /* amber */
  --honey-d:#A86E27;
  --olive:  #7C7A4E;   /* sage-olive */
  --fig:    #6E2F3C;   /* deep plum */
  --broth:  #E3CE9F;   /* broth cream */
  --green:  #5E6B47;

  --accent: var(--honey);
  --prod-hue: var(--honey);  /* live-tinted by JS in the range */

  /* type */
  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --script:"Allura", cursive;
  --arab:  "IBM Plex Sans Arabic", var(--sans);

  /* metrics */
  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --r: 16px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* RTL: swap body face */
html[dir="rtl"]{ --sans: var(--arab); --serif: var(--arab); }
html[dir="rtl"] .hero__title,
html[dir="rtl"] h2,
html[dir="rtl"] h3{ font-family: var(--arab); font-weight:600; }

*{ box-sizing:border-box; margin:0; padding:0 }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; background:var(--paper) }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto } }

body{
  font-family: var(--sans);
  background: transparent;       /* the living environment shows through */
  color: var(--ink);
  line-height: 1.6;
  overflow-x: clip;              /* clip, not hidden — keeps sticky alive */
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* =================================================================
   MOLY'S ENVIRONMENT — a continuous living light field, no flat blocks
   ================================================================= */
.env{ position:fixed; inset:0; z-index:-2; overflow:hidden; pointer-events:none }
.env__base{
  position:absolute; inset:-16%;
  background:
    radial-gradient(70% 50% at 50% -8%, color-mix(in srgb,var(--honey) 26%, transparent), transparent 60%),
    radial-gradient(80% 60% at 100% 108%, color-mix(in srgb,var(--fig) 16%, transparent), transparent 62%),
    linear-gradient(180deg, #F6EDDD 0%, var(--paper) 30%, #ECDFC8 62%, #E7D9BF 100%);
}
.env__blob{ position:absolute; border-radius:50%; filter:blur(60px); opacity:.5; will-change:transform; mix-blend-mode:multiply }
.env__blob--honey{ width:46vw; height:46vw; top:6%;  left:-6%;  background:radial-gradient(circle, color-mix(in srgb,var(--honey) 80%, transparent), transparent 70%); animation:envFloat 26s ease-in-out infinite }
.env__blob--amber{ width:38vw; height:38vw; top:38%; right:-8%; background:radial-gradient(circle, color-mix(in srgb,#E0A85A 78%, transparent), transparent 70%); animation:envFloat 32s ease-in-out infinite -6s }
.env__blob--olive{ width:40vw; height:40vw; top:60%; left:-10%; background:radial-gradient(circle, color-mix(in srgb,var(--olive) 70%, transparent), transparent 70%); animation:envFloat 30s ease-in-out infinite -12s }
.env__blob--fig{   width:50vw; height:50vw; top:78%; right:-12%; background:radial-gradient(circle, color-mix(in srgb,var(--fig) 60%, transparent), transparent 70%); animation:envFloat 34s ease-in-out infinite -18s }
.env__blob--broth{ width:34vw; height:34vw; top:20%; left:42%; background:radial-gradient(circle, color-mix(in srgb,var(--broth) 90%, transparent), transparent 70%); animation:envFloat 28s ease-in-out infinite -3s }
.env__vignette{
  position:absolute; inset:0;
  background:radial-gradient(120% 90% at 50% 40%, transparent 55%, rgba(40,28,18,.14) 100%);
}
@keyframes envFloat{
  0%,100%{ transform:translate(0,0) scale(1) }
  33%{ transform:translate(4%,-5%) scale(1.08) }
  66%{ transform:translate(-3%,4%) scale(.96) }
}
@media (prefers-reduced-motion: reduce){ .env__blob{ animation:none } }
@media (max-width:700px){ .env__blob{ filter:blur(42px); opacity:.42 } .env__blob--broth{ display:none } }
img,svg{ display:block; max-width:100% }
a{ color:inherit; text-decoration:none }
h1,h2,h3{ font-family:var(--serif); font-weight:400; line-height:1.04; letter-spacing:-.01em }
section{ position:relative }

/* film grain */
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.05; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.scroll-progress{ position:fixed; top:0; left:0; right:0; height:2px; z-index:60 }
.scroll-progress span{ display:block; height:100%; width:0; background:var(--accent); transition:width .1s linear }
html[dir="rtl"] .scroll-progress{ transform:scaleX(-1) }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--sans); font-weight:600; font-size:.94rem; letter-spacing:.01em;
  padding:.85em 1.5em; border-radius:999px; cursor:pointer; border:1.5px solid transparent;
  transition:transform .35s var(--ease), background .3s, color .3s, border-color .3s; white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px) }
.btn--solid{ background:var(--ink); color:var(--paper) }
.btn--solid:hover{ background:var(--honey-d) }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line) }
.btn--ghost:hover{ border-color:var(--ink) }
.btn--pill{ background:var(--ink); color:var(--paper); padding:.6em 1.2em; font-size:.85rem }
.btn--wa{ background:#1f7a4d }
.btn--wa:hover{ background:#19613d }

.eyebrow{
  font-family:var(--sans); font-weight:600; font-size:.74rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--accent);
}
html[dir="rtl"] .eyebrow{ letter-spacing:0 }

/* ---------- reveal ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .9s var(--ease), transform .9s var(--ease) }
.reveal.in{ opacity:1; transform:none }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none } }

/* =================================================================
   NAV
   ================================================================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between; gap:1.5rem;
  padding:.85rem var(--gutter);
  background:color-mix(in srgb, var(--paper) 78%, transparent);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent; transition:border-color .3s, padding .3s, background .3s;
}
.nav.scrolled{ border-color:var(--line); padding-top:.6rem; padding-bottom:.6rem }
.nav__brand{ display:flex; align-items:center; gap:.6rem; font-family:var(--serif); font-size:1.12rem }
.nav__name{ letter-spacing:-.01em }
.mark{ color:var(--ink) }
.mark--sm{ width:34px; height:34px }
.nav__links{ display:flex; gap:1.7rem; margin-inline-start:auto; margin-inline-end:1.2rem }
.nav__links a{ font-size:.9rem; font-weight:500; color:var(--ink-soft); position:relative; padding:.2em 0 }
.nav__links a::after{ content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:0; background:var(--accent); transition:width .35s var(--ease) }
.nav__links a:hover{ color:var(--ink) }
.nav__links a:hover::after{ width:100% }
.nav__actions{ display:flex; align-items:center; gap:.9rem }
.lang-toggle{
  background:none; border:1px solid var(--line); border-radius:999px; cursor:pointer;
  font-family:var(--sans); font-weight:600; font-size:.78rem; color:var(--ink-soft);
  padding:.4em .7em; letter-spacing:.04em; transition:border-color .3s,color .3s;
}
.lang-toggle:hover{ border-color:var(--ink); color:var(--ink) }
.lang-toggle__sep{ opacity:.4; margin:0 .25em }
html[lang="ar"] .lang-toggle__ar{ color:var(--accent) }
html[lang="en"] .lang-toggle__en{ color:var(--accent) }

.nav__burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px }
.nav__burger span{ width:24px; height:1.8px; background:var(--ink); transition:transform .3s, opacity .3s }
.nav__burger[aria-expanded="true"] span:first-child{ transform:translateY(6.5px) rotate(45deg) }
.nav__burger[aria-expanded="true"] span:last-child{ transform:translateY(-6.5px) rotate(-45deg) }

.mobilemenu{
  position:fixed; inset:0 0 auto 0; z-index:45; top:0; padding:6rem var(--gutter) 2.5rem;
  background:var(--paper); display:flex; flex-direction:column; gap:1.3rem;
  border-bottom:1px solid var(--line); animation:slideDown .4s var(--ease);
}
.mobilemenu[hidden]{ display:none }
.mobilemenu a{ font-family:var(--serif); font-size:1.6rem }
.mobilemenu .btn{ font-family:var(--sans); font-size:1rem; align-self:flex-start; margin-top:.5rem }
@keyframes slideDown{ from{ transform:translateY(-12px); opacity:0 } to{ transform:none; opacity:1 } }

/* =================================================================
   HERO
   ================================================================= */
.hero{
  min-height:100svh; display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:7rem var(--gutter) 3rem; position:relative; overflow:hidden;
  background:transparent;
}
.hero__field{ position:absolute; inset:0; z-index:0; pointer-events:none }
.float{ position:absolute; color:var(--ink); opacity:.13; animation:drift 16s ease-in-out infinite }
.float--fig{    width:120px; top:16%; left:8%;  animation-delay:-2s }
.float--garlic{ width:104px; top:62%; left:13%; animation-delay:-7s }
.float--olive{  width:170px; top:22%; right:7%; animation-delay:-4s }
.float--dipper{ width:46px;  top:60%; right:14%; animation-delay:-10s }
@keyframes drift{ 0%,100%{ transform:translateY(0) rotate(-2deg) } 50%{ transform:translateY(-22px) rotate(3deg) } }
@media (prefers-reduced-motion: reduce){ .float{ animation:none } }

.hero__inner{ position:relative; z-index:2; max-width:880px; display:flex; flex-direction:column; align-items:center; gap:1.4rem }
.mark--hero{ width:108px; height:108px; margin-bottom:.2rem }
.hero__title{ font-size:clamp(2.9rem, 9vw, 6.4rem); display:flex; flex-direction:column; gap:.05em }
.hero__title--accent{ font-style:italic; color:var(--honey-d) }
.hero__lede{ font-size:clamp(1.05rem,2vw,1.32rem); max-width:42ch; color:var(--ink-soft); line-height:1.55 }
.hero__cta{ display:flex; gap:.8rem; flex-wrap:wrap; justify-content:center; margin-top:.6rem }
.hero__scroll{
  position:absolute; bottom:1.6rem; left:50%; transform:translateX(-50%); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:.4rem;
  font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-soft);
}
.hero__scroll svg{ width:11px; animation:bob 2s ease-in-out infinite }
@keyframes bob{ 0%,100%{ transform:translateY(0) } 50%{ transform:translateY(5px) } }

/* the mk mark draw-on */
.mk-ring,.mk-sweep{ stroke-dasharray:1; stroke-dashoffset:1; pathLength:1 }
.mark--hero .mk-ring,.mark--hero .mk-sweep{ animation:draw 2.4s var(--ease) forwards }
.mark--hero .mk-ring--2{ animation-delay:.25s }
.mark--hero .mk-sweep{ animation-delay:.5s }
@keyframes draw{ to{ stroke-dashoffset:0 } }
.mk-letters{ font-family:var(--script); font-size:46px; fill:currentColor }
.mark--hero .mk-letters{ opacity:0; animation:fadeIn .9s ease 1.1s forwards }
@keyframes fadeIn{ to{ opacity:1 } }
@media (prefers-reduced-motion: reduce){
  .mk-ring,.mk-sweep{ stroke-dashoffset:0; animation:none }
  .mk-letters{ opacity:1; animation:none }
}

/* =================================================================
   STORY STRIP
   ================================================================= */
.story{
  padding:clamp(4.5rem,11vw,9rem) var(--gutter);
  max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:1.6fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:end;
}
.story__line p{ font-family:var(--serif); font-size:clamp(1.5rem,3.4vw,2.5rem); line-height:1.28; color:var(--ink) }
.story__big{ font-style:italic; color:var(--honey-d); display:inline }
.story__marks{ list-style:none; display:flex; flex-direction:column; gap:1.4rem }
.story__marks li{ border-top:1px solid var(--line); padding-top:.9rem }
.story__marks strong{ font-family:var(--serif); font-size:1.7rem; display:block; line-height:1 }
.story__marks span{ font-size:.92rem; color:var(--ink-soft) }

/* =================================================================
   THE RANGE — sticky filling jar
   ================================================================= */
.range{ padding:clamp(3rem,8vw,6rem) 0 0; background:transparent }
.range__head{ max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter) 1rem; text-align:center }
.range__head h2{ font-size:clamp(2rem,5vw,3.4rem); margin-top:.4rem }
.range__stage{
  max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter);
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem);
}
.range__jarwrap{ position:relative }
.jarviz{
  position:sticky; top:0; height:100svh; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1rem;
}
.jarviz__svg{ width:min(74%,360px); height:auto; filter:drop-shadow(0 24px 36px rgba(34,28,21,.16)) }
#jarFill{ transition:transform .5s var(--ease); transform:translateY(0) }
.jarviz__label text{ font-family:var(--sans); fill:var(--ink) }
.jarviz__mk{ font-family:var(--script); font-size:30px }
.jarviz__brand{ font-size:9px; font-weight:700; letter-spacing:1.4px }
.jarviz__sub{ font-size:5.4px; font-weight:600; letter-spacing:1px; fill:var(--ink-soft) }
.jarviz__caption{ font-family:var(--serif); font-style:italic; font-size:1.5rem; color:var(--prod-hue); transition:color .6s }

.range__list{ display:flex; flex-direction:column }
.prod{
  min-height:78svh; display:flex; flex-direction:column; justify-content:center; gap:.5rem;
  padding:3rem 0; border-bottom:1px solid var(--line); position:relative;
}
.prod:last-child{ border-bottom:0 }
.prod__idx{ font-family:var(--serif); font-size:.9rem; color:var(--prod-hue); letter-spacing:.1em }
.prod.active .prod__idx{ color:var(--prod-hue) }
.prod h3{ font-size:clamp(1.9rem,4.4vw,3rem) }
.prod__tag{ font-family:var(--sans); font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft) }
html[dir="rtl"] .prod__tag{ letter-spacing:0 }
.prod p:last-child{ font-size:clamp(1rem,1.7vw,1.18rem); color:var(--ink-soft); max-width:44ch; margin-top:.4rem }
.prod{ opacity:.4; transition:opacity .5s var(--ease) }
.prod.active{ opacity:1 }
@media (prefers-reduced-motion: reduce){ .prod{ opacity:1 } }

/* =================================================================
   THE RITUAL
   ================================================================= */
.ritual{
  position:relative; color:var(--paper);
  padding:clamp(5.5rem,12vw,10rem) var(--gutter);
  background:
    radial-gradient(70% 55% at 72% 26%, color-mix(in srgb,var(--honey) 16%, transparent), transparent 60%),
    linear-gradient(180deg, transparent 0%, rgba(24,16,11,.94) 13%, rgba(22,14,10,.95) 87%, transparent 100%);
}
.ritual__head{ max-width:var(--maxw); margin:0 auto 3.5rem }
.ritual__head .eyebrow{ color:var(--broth) }
.ritual__head h2{ font-size:clamp(2rem,5vw,3.6rem); max-width:14ch; margin-top:.5rem; color:var(--paper) }
.ritual__steps{ list-style:none; max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.5rem,4vw,3.5rem) }
.ritual__steps li{ border-top:1.5px solid rgba(241,231,213,.22); padding-top:1.4rem }
.ritual__num{ font-family:var(--serif); font-size:1rem; color:var(--broth); letter-spacing:.1em }
.ritual__steps h3{ font-size:1.5rem; margin:.6rem 0 .6rem; color:var(--paper) }
.ritual__steps p{ color:rgba(241,231,213,.72); font-size:1rem }

/* =================================================================
   PROOF
   ================================================================= */
.proof{ padding:clamp(4.5rem,11vw,9rem) var(--gutter); text-align:center; background:transparent }
.proof__inner{ max-width:920px; margin:0 auto; display:flex; flex-direction:column; align-items:center; gap:1.3rem }
.proof__quote{ font-family:var(--serif); font-style:italic; font-size:clamp(1.8rem,4.6vw,3.2rem); line-height:1.2; color:var(--ink) }
.proof__sub{ max-width:54ch; color:var(--ink-soft); font-size:1.05rem }
.proof__stats{ display:flex; flex-wrap:wrap; gap:clamp(1.5rem,5vw,4rem); justify-content:center; margin-top:1.5rem }
.proof__stats strong{ font-family:var(--serif); font-size:2.6rem; display:block; color:var(--honey-d); line-height:1 }
.proof__stats span{ font-size:.9rem; color:var(--ink-soft) }

/* =================================================================
   THE CELLAR — loyalty
   ================================================================= */
.cellar{
  position:relative; overflow:hidden; color:var(--paper);
  padding:clamp(5.5rem,12vw,10rem) var(--gutter);
  background:
    linear-gradient(180deg, transparent 0%, rgba(44,22,28,.93) 12%, rgba(27,15,18,.96) 88%, transparent 100%);
}
.cellar::before{
  content:""; position:absolute; width:62vw; height:62vw; top:-22%; inset-inline-end:-12%;
  background:radial-gradient(circle, color-mix(in srgb,var(--honey) 24%, transparent), transparent 62%);
  pointer-events:none;
}
.cellar__inner{
  position:relative; z-index:1; max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,4.5rem); align-items:start;
}
.cellar .eyebrow{ color:var(--honey) }
.cellar h2{ color:var(--paper); font-size:clamp(2rem,4.6vw,3.2rem); max-width:15ch; margin-top:.5rem }
.cellar__lede{ color:rgba(241,231,213,.75); font-size:1.08rem; max-width:46ch; margin-top:1rem }
.cellar__earn{ list-style:none; display:flex; flex-direction:column; gap:.65rem; margin:1.8rem 0 2.4rem }
.cellar__earn li{ display:flex; align-items:baseline; gap:.7rem; color:rgba(241,231,213,.86); font-size:.98rem }
.ce-amt{ font-family:var(--serif); font-size:1.3rem; color:var(--honey); min-width:2.6ch; font-weight:500 }

/* tier ladder */
.tiers{ list-style:none; position:relative; padding-inline-start:1.5rem }
.tiers::before{ content:""; position:absolute; inset-inline-start:4px; top:9px; bottom:14px; width:1.5px; background:rgba(241,231,213,.22) }
.tier{ position:relative; padding-bottom:1.35rem }
.tier:last-child{ padding-bottom:0 }
.tier::before{
  content:""; position:absolute; inset-inline-start:-1.5rem; top:6px; width:11px; height:11px; border-radius:50%;
  background:#241419; box-shadow:0 0 0 1.5px rgba(241,231,213,.42); transition:background .3s, box-shadow .3s;
}
.tier__name{ font-family:var(--serif); font-size:1.22rem; color:var(--paper) }
.tier__seals{ font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(241,231,213,.5); margin-inline-start:.7rem }
html[dir="rtl"] .tier__seals{ letter-spacing:0 }
.tier__perk{ display:block; font-size:.92rem; color:rgba(241,231,213,.72); margin-top:.25rem; max-width:40ch }
.tier.is-current::before{ background:var(--honey); box-shadow:0 0 0 4px color-mix(in srgb,var(--honey) 28%, transparent) }
.tier.is-current .tier__name{ color:var(--honey) }

/* membership card */
.mcard{
  background:linear-gradient(165deg, rgba(250,244,232,.86), rgba(234,221,194,.74)); color:var(--ink);
  backdrop-filter:blur(18px) saturate(1.1); -webkit-backdrop-filter:blur(18px) saturate(1.1);
  border:1px solid rgba(255,250,240,.5);
  border-radius:20px; padding:1.8rem; box-shadow:0 34px 70px rgba(20,10,12,.4); position:relative; overflow:hidden;
}
.mcard::after{ content:""; position:absolute; inset:0; border-radius:20px; box-shadow:inset 0 0 0 1px rgba(34,28,21,.06); pointer-events:none }
.mcard__top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:1.3rem }
.mcard__label{ font-size:.7rem; letter-spacing:.24em; text-transform:uppercase; color:var(--ink-soft) }
html[dir="rtl"] .mcard__label{ letter-spacing:.05em }
.mcard__top .mark{ width:42px; height:42px; color:var(--ink) }
.mcard h3{ font-family:var(--serif); font-size:1.7rem; margin-bottom:.35rem }
.mcard__sub{ color:var(--ink-soft); font-size:.95rem; margin-bottom:1.3rem; line-height:1.5 }
.join{ display:flex; gap:.5rem; flex-wrap:wrap }
.join input{ flex:1; min-width:150px; padding:.85em 1.1em; border:1.5px solid var(--line); border-radius:999px; font-family:var(--sans); font-size:1rem; background:#fff; color:var(--ink) }
.join input:focus{ outline:none; border-color:var(--honey); box-shadow:0 0 0 3px color-mix(in srgb,var(--honey) 20%, transparent) }
.mcard__fine{ font-size:.74rem; color:var(--ink-soft); margin-top:1.1rem; line-height:1.55 }

/* member state */
.mcard__name{ font-family:var(--serif); font-size:1.55rem; line-height:1.1 }
.mcard__code{ font-size:.78rem; letter-spacing:.16em; color:var(--ink-soft); margin-top:.2rem }
.mcard__tierbadge{ display:inline-block; background:var(--ink); color:var(--paper); padding:.34em 1em; border-radius:999px; font-size:.76rem; letter-spacing:.06em; margin-top:.9rem; font-weight:600 }
.mcard__count{ display:flex; align-items:baseline; gap:.4rem; margin:1.2rem 0 .2rem }
.mcard__count b{ font-family:var(--serif); font-size:2.6rem; line-height:1; font-weight:500; color:var(--honey-d) }
.mcard__count span{ font-size:.95rem; color:var(--ink-soft) }
.seals{ display:flex; flex-wrap:wrap; gap:.42rem; margin:1rem 0 .2rem }
.seal{ width:22px; height:22px; border-radius:50%; flex:0 0 auto }
.seal--on{ background:radial-gradient(circle at 36% 30%, #e0a85a, var(--honey-d)); box-shadow:inset 0 -2px 3px rgba(0,0,0,.28), 0 1px 2px rgba(0,0,0,.15) }
.seal--off{ background:transparent; box-shadow:inset 0 0 0 1.5px rgba(34,28,21,.18) }
.progress{ height:7px; background:rgba(34,28,21,.12); border-radius:999px; overflow:hidden; margin:1rem 0 .5rem }
.progress span{ display:block; height:100%; width:0; background:linear-gradient(90deg,var(--honey),var(--honey-d)); border-radius:999px; transition:width .7s var(--ease) }
html[dir="rtl"] .progress{ transform:scaleX(-1) }
.mcard__next{ font-size:.88rem; color:var(--ink-soft) }
.mcard__maxed{ font-size:.9rem; color:var(--honey-d); font-weight:600 }
.mcard__actions{ display:flex; gap:.5rem; flex-wrap:wrap; margin-top:1.4rem }
.mcard__actions .btn{ font-size:.8rem; padding:.62em 1.05em }
.mcard__forget{ background:none; border:0; color:var(--ink-soft); font-size:.76rem; cursor:pointer; text-decoration:underline; margin-top:.9rem; padding:0 }
.mcard__forget:hover{ color:var(--ink) }

/* cart earn line */
.cart__earn{ display:flex; align-items:center; gap:.5rem; background:rgba(241,231,213,.1); border:1px solid rgba(241,231,213,.18); border-radius:12px; padding:.7rem .9rem; margin:.2rem 0 .2rem; font-size:.86rem; color:var(--broth) }
.cart__earn b{ color:var(--honey) }

/* =================================================================
   BUILD YOUR BOX
   ================================================================= */
.box{ padding:clamp(4.5rem,11vw,9rem) var(--gutter); max-width:var(--maxw); margin:0 auto }
.box__head{ text-align:center; margin-bottom:3rem }
.box__head h2{ font-size:clamp(2rem,5vw,3.4rem); margin-top:.4rem }
.box__note{ max-width:56ch; margin:1rem auto 0; color:var(--ink-soft) }
.box__grid{ display:grid; grid-template-columns:1.3fr .9fr; gap:clamp(1.5rem,4vw,3rem); align-items:start }
.box__products{ display:grid; grid-template-columns:1fr 1fr; gap:1rem }
.pcard{
  background:linear-gradient(165deg, rgba(250,244,232,.72), rgba(244,236,220,.5));
  backdrop-filter:blur(12px) saturate(1.05); -webkit-backdrop-filter:blur(12px) saturate(1.05);
  border:1px solid rgba(255,250,240,.55); border-radius:var(--r);
  padding:1.3rem; display:flex; flex-direction:column; gap:.5rem; transition:border-color .3s, transform .3s, box-shadow .3s;
}
.pcard:hover{ transform:translateY(-3px); box-shadow:0 16px 30px rgba(34,28,21,.08); border-color:transparent }
.pcard__top{ display:flex; align-items:center; gap:.8rem }
.pcard__dot{ width:30px; height:30px; border-radius:50%; flex:0 0 auto; box-shadow:inset 0 0 0 1.5px rgba(34,28,21,.12) }
.pcard__name{ font-family:var(--serif); font-size:1.18rem; line-height:1.1 }
.pcard__price{ font-size:.86rem; color:var(--ink-soft); margin-top:.1rem }
.pcard__desc{ font-size:.84rem; color:var(--ink-soft); flex:1 }
.stepper{ display:flex; align-items:center; gap:.5rem; margin-top:.4rem }
.stepper button{
  width:42px; height:42px; border-radius:50%; border:1.5px solid var(--line); background:none; cursor:pointer;
  font-size:1.2rem; line-height:1; color:var(--ink); display:flex; align-items:center; justify-content:center;
  transition:border-color .25s, background .25s, color .25s;
}
.stepper button:hover{ border-color:var(--ink) }
.stepper button:disabled{ opacity:.3; cursor:default }
.stepper .qty{ min-width:2ch; text-align:center; font-weight:600; font-variant-numeric:tabular-nums }
.pcard.in-box{ border-color:var(--accent); box-shadow:0 0 0 1px var(--accent) inset }
.pcard__add{ margin-top:.4rem; align-self:flex-start; font-weight:600; font-size:.86rem; color:var(--honey-d); background:none; border:0; cursor:pointer; padding:.3em 0 }
.pcard__add:hover{ text-decoration:underline }

.cart{ background:rgba(26,18,13,.74); color:var(--paper); border-radius:var(--r); padding:1.6rem; position:sticky; top:90px;
  backdrop-filter:blur(20px) saturate(1.1); -webkit-backdrop-filter:blur(20px) saturate(1.1);
  border:1px solid rgba(241,231,213,.16); box-shadow:0 28px 60px rgba(20,12,8,.32) }
.cart h3{ font-family:var(--serif); font-size:1.4rem; color:var(--paper); margin-bottom:1rem }
.cart__list{ list-style:none; display:flex; flex-direction:column; gap:.7rem; margin-bottom:.6rem }
.cart__list li{ display:flex; justify-content:space-between; gap:1rem; font-size:.92rem; align-items:center; animation:cartIn .3s var(--ease) }
@keyframes cartIn{ from{ opacity:0; transform:translateY(-4px) } to{ opacity:1; transform:none } }
.cart__list .ci-name{ color:rgba(241,231,213,.92) }
.cart__list .ci-name b{ color:var(--broth); font-weight:600 }
.cart__list .ci-price{ color:rgba(241,231,213,.6); font-variant-numeric:tabular-nums; white-space:nowrap }
.cart__list .ci-rm{ background:none; border:0; color:rgba(241,231,213,.5); cursor:pointer; font-size:1.1rem; line-height:1; padding:0 .2em }
.cart__list .ci-rm:hover{ color:var(--broth) }
.cart__empty{ color:rgba(241,231,213,.55); font-size:.92rem; padding:.4rem 0 1rem }
.cart__total{ display:flex; justify-content:space-between; align-items:baseline; border-top:1px solid rgba(241,231,213,.2); padding-top:1rem; margin-top:.4rem }
.cart__total span{ color:rgba(241,231,213,.7); font-size:.9rem }
.cart__total strong{ font-family:var(--serif); font-size:1.7rem; color:var(--paper); font-variant-numeric:tabular-nums }
.cart__actions{ display:flex; flex-direction:column; gap:.6rem; margin-top:1.2rem }
.cart__actions .btn{ width:100% }
.cart__fine{ font-size:.74rem; color:rgba(241,231,213,.45); margin-top:.9rem; line-height:1.5 }

/* =================================================================
   FIND US
   ================================================================= */
.find{
  display:grid; grid-template-columns:1.2fr .8fr; gap:clamp(2rem,5vw,4rem); align-items:center;
  max-width:var(--maxw); margin:0 auto; padding:clamp(4.5rem,11vw,9rem) var(--gutter);
}
.find__col h2{ font-size:clamp(2rem,5vw,3.2rem); margin:.4rem 0 1.8rem; max-width:16ch }
.find__list{ list-style:none; display:flex; flex-direction:column; gap:1.2rem; margin-bottom:2rem }
.find__list li{ border-top:1px solid var(--line); padding-top:1rem; display:flex; flex-direction:column; gap:.2rem }
.find__where{ font-family:var(--serif); font-size:1.3rem }
.find__when{ font-size:.92rem; color:var(--ink-soft) }
.find__cta{ display:flex; gap:.8rem; flex-wrap:wrap }
.find__card{
  background:linear-gradient(160deg,var(--honey),var(--fig));
  border-radius:calc(var(--r) + 6px); aspect-ratio:4/5; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:1rem; color:var(--paper-card); text-align:center; padding:2rem;
  box-shadow:0 30px 60px rgba(110,47,60,.25);
}
.find__card .mark--card{ width:96px; height:96px; color:var(--paper-card) }
.find__cardline{ font-family:var(--serif); font-style:italic; font-size:1.5rem }
.find__cardloc{ font-size:.8rem; letter-spacing:.2em; text-transform:uppercase; opacity:.8 }

/* =================================================================
   FOOTER
   ================================================================= */
.foot{ color:var(--paper); padding:clamp(4rem,8vw,6rem) var(--gutter) 2rem;
  background:linear-gradient(180deg, transparent 0%, rgba(22,15,10,.96) 18%, rgba(17,11,7,.99) 100%); }
.foot__top{ max-width:var(--maxw); margin:0 auto; display:flex; justify-content:space-between; align-items:center; gap:2rem; flex-wrap:wrap; padding-bottom:2rem; border-bottom:1px solid rgba(241,231,213,.18) }
.foot__brand{ display:flex; align-items:center; gap:.7rem; font-family:var(--serif); font-size:1.3rem; color:var(--paper) }
.foot__brand .mark{ color:var(--paper) }
.foot__nav{ display:flex; gap:1.6rem; flex-wrap:wrap }
.foot__nav a{ color:rgba(241,231,213,.72); font-size:.92rem }
.foot__nav a:hover{ color:var(--broth) }
.foot__base{ max-width:var(--maxw); margin:1.5rem auto 0; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.82rem; color:rgba(241,231,213,.55) }
.foot__credit a{ color:var(--broth) }

/* =================================================================
   GLASS helper · INGREDIENTS marquee · ON YOUR TABLE
   ================================================================= */
.glass{
  background:linear-gradient(165deg, rgba(250,244,232,.6), rgba(244,236,220,.4));
  backdrop-filter:blur(14px) saturate(1.06); -webkit-backdrop-filter:blur(14px) saturate(1.06);
  border:1px solid rgba(255,250,240,.55);
  box-shadow:0 22px 50px rgba(60,40,25,.1);
}

/* marquee */
.marquee{ padding:clamp(2.5rem,6vw,4.5rem) 0; overflow:hidden }
.marquee__eyebrow{ text-align:center; font-family:var(--sans); font-weight:600; font-size:.74rem;
  letter-spacing:.22em; text-transform:uppercase; color:var(--accent); margin-bottom:1.5rem }
html[dir="rtl"] .marquee__eyebrow{ letter-spacing:0 }
.marquee__viewport{ overflow:hidden;
  -webkit-mask:linear-gradient(90deg, transparent, #000 11%, #000 89%, transparent);
  mask:linear-gradient(90deg, transparent, #000 11%, #000 89%, transparent) }
.marquee__track{ display:flex; align-items:center; gap:2.2rem; width:max-content;
  animation:marqueeMove 40s linear infinite; will-change:transform }
.marquee:hover .marquee__track{ animation-play-state:paused }
.mq{ font-family:var(--serif); font-style:italic; font-size:clamp(1.5rem,3.8vw,2.7rem); color:var(--ink); white-space:nowrap }
.mq--accent{ color:var(--honey-d) }
.mq__ico{ width:clamp(26px,3.4vw,40px); height:auto; color:var(--olive); opacity:.65; flex:0 0 auto }
.mq__star{ color:var(--accent); font-size:1.1rem; opacity:.7 }
@keyframes marqueeMove{ from{ transform:translateX(0) } to{ transform:translateX(-50%) } }
html[dir="rtl"] .marquee__track{ animation-direction:reverse }
@media (prefers-reduced-motion: reduce){ .marquee__track{ animation:none } }

/* on your table */
.ways{ max-width:var(--maxw); margin:0 auto; padding:clamp(3.5rem,9vw,7rem) var(--gutter) }
.ways__head{ text-align:center; margin-bottom:2.6rem }
.ways__head h2{ font-size:clamp(2rem,5vw,3.2rem); margin-top:.4rem }
.ways__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem }
.way{ border-radius:var(--r); padding:2.1rem 1.7rem; display:flex; flex-direction:column; gap:.7rem;
  transition:transform .45s var(--ease), box-shadow .45s }
.way:hover{ transform:translateY(-6px); box-shadow:0 30px 60px rgba(60,40,25,.16) }
.way__ico{ width:42px; height:50px; color:var(--honey-d); opacity:.85; margin-bottom:.3rem }
.way h3{ font-family:var(--serif); font-size:1.5rem }
.way p{ color:var(--ink-soft); font-size:1rem }

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media (max-width: 960px){
  .nav__links{ display:none }
  .nav__burger{ display:flex }
  .nav__actions .btn--pill{ display:none }
  .story{ grid-template-columns:1fr; align-items:start }
  .range__stage{ grid-template-columns:1fr }
  .range__jarwrap{ display:none }       /* jar viz is desktop signature; mobile leads with copy */
  .prod{ min-height:auto; padding:2.2rem 0; opacity:1 }
  .ritual__steps{ grid-template-columns:1fr; gap:1.8rem }
  .ways__grid{ grid-template-columns:1fr; gap:1rem }
  .cellar__inner{ grid-template-columns:1fr; gap:2.5rem }
  .box__grid{ grid-template-columns:1fr }

  /* ---- mobile jar experience: sticky panel, products scroll beneath ---- */
  .range__stage{ grid-template-columns:1fr; gap:0; position:relative }
  .range__jarwrap{
    display:block; position:sticky; top:50px; z-index:3; height:42svh;
    background:linear-gradient(180deg, var(--paper-2) 0%, var(--paper-2) 58%,
      color-mix(in srgb, var(--paper-2) 0%, transparent) 100%);
  }
  .jarviz{ position:static; height:100%; flex-direction:column; gap:.3rem; padding-top:.4rem }
  .jarviz__svg{ width:min(50%, 188px) }
  .jarviz__caption{ font-size:1.15rem }
  .range__list{ position:relative; z-index:1 }
  .prod{ min-height:58svh; padding:1.4rem 0; opacity:.4 }
  .prod:first-child{ padding-top:.5rem }
  .prod.active{ opacity:1 }
  .cart{ position:static }
  .find{ grid-template-columns:1fr }
  .find__card{ order:-1; aspect-ratio:16/10; max-height:320px }
}
@media (max-width: 560px){
  .box__products{ grid-template-columns:1fr }
  .hero__cta{ width:100%; }
  .hero__cta .btn{ flex:1 }
  .foot__top{ flex-direction:column; align-items:flex-start }
}
