:root{
  --cream:#F7EFDE;
  --cream-2:#F1E6D0;
  --paper:#FCF7EC;
  --turmeric:#E0A21B;
  --turmeric-deep:#C0860F;
  --gold-soft:#F4C26A;
  --terracotta:#A8432A;
  --terracotta-deep:#822F1C;
  --ink:#2B2620;
  --ink-soft:#5C5247;
  --leaf:#5E7B3A;
  --line:rgba(43,38,32,0.14);
  --shadow-soft:0 22px 46px -28px rgba(90,50,22,0.5);
  --shadow-card:0 14px 30px -20px rgba(90,50,22,0.45);
  --ease-soft:cubic-bezier(.22,.61,.36,1);
  --font-serif:'Fraunces',Georgia,serif;
  --font-sans:'Mulish',system-ui,sans-serif;
  --font-hand:'Caveat',cursive;
  --nav-h:78px;
}

*,*::before,*::after{box-sizing:border-box;}
*{margin:0;}

html{
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
  scroll-behavior:smooth;
  scroll-padding-top:calc(var(--nav-h) + 12px);
}

body{
  background-color:var(--cream);
  color:var(--ink);
  font-family:var(--font-sans);
  font-weight:400;
  font-size:clamp(16px,1.05vw,17.5px);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  min-height:100vh;
}

img,svg,picture,video,canvas{display:block;max-width:100%;}
input,button,textarea,select{font:inherit;color:inherit;}
button{cursor:pointer;background:none;border:none;}
a{color:inherit;text-decoration:none;}
ul,ol{list-style:none;padding:0;}

h1,h2,h3,h4,h5,h6{
  font-family:var(--font-serif);
  font-weight:600;
  line-height:1.08;
  letter-spacing:-0.01em;
  color:var(--ink);
  text-wrap:balance;
}

p{text-wrap:pretty;}

::selection{background:var(--turmeric);color:var(--ink);}

:focus-visible{
  outline:2.5px solid var(--terracotta);
  outline-offset:3px;
  border-radius:4px;
}

/* ---------- Layout container ---------- */
.wrap{
  width:100%;
  max-width:1180px;
  margin-inline:auto;
  padding-inline:clamp(20px,5vw,64px);
}

/* ---------- Paper grain + vignette overlay ---------- */
.paper-overlay{
  position:fixed;
  inset:0;
  width:100vw;
  height:100vh;
  pointer-events:none;
  z-index:9999;
  opacity:0.05;
  mix-blend-mode:multiply;
}
.paper-overlay__svg{display:block;width:100%;height:100%;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0.5em;
  font-family:var(--font-sans);
  font-weight:700;
  font-size:0.95rem;
  letter-spacing:0.005em;
  line-height:1;
  padding:0.92em 1.55em;
  border-radius:999px;
  border:1.6px solid transparent;
  cursor:pointer;
  text-align:center;
  white-space:nowrap;
  transition:transform .5s var(--ease-soft),
             box-shadow .5s var(--ease-soft),
             background-color .5s var(--ease-soft),
             color .5s var(--ease-soft),
             border-color .5s var(--ease-soft);
}

.btn--primary{
  background:var(--terracotta);
  color:var(--cream);
  border-color:var(--terracotta);
  box-shadow:var(--shadow-card);
}
.btn--primary:hover{
  background:var(--terracotta-deep);
  border-color:var(--terracotta-deep);
  transform:translateY(-2px);
  box-shadow:var(--shadow-soft);
}
.btn--primary:active{transform:translateY(0);}

.btn--ghost{
  background:transparent;
  color:var(--ink);
  border-color:var(--ink);
}
.btn--ghost:hover{
  background:var(--ink);
  color:var(--cream);
  transform:translateY(-2px);
  box-shadow:var(--shadow-card);
}
.btn--ghost:active{transform:translateY(0);}

/* ---------- Reveal utility ---------- */
.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .9s var(--ease-soft) var(--d,0ms),
             transform .9s var(--ease-soft) var(--d,0ms);
  will-change:opacity,transform;
}
.reveal.is-visible{opacity:1;transform:none;}

/* ---------- Word-by-word utility ---------- */
.word{
  display:inline-block;
  opacity:0;
  transform:translateY(.35em);
  transition:opacity .55s var(--ease-soft),
             transform .55s var(--ease-soft);
  will-change:opacity,transform;
}
.word.is-in{opacity:1;transform:none;}

/* ---------- Site navigation ---------- */
.site-nav{
  position:sticky;
  top:0;
  z-index:1000;
  width:100%;
  background:linear-gradient(to bottom,rgba(247,239,222,0.92),rgba(247,239,222,0.82));
  -webkit-backdrop-filter:saturate(135%) blur(9px);
  backdrop-filter:saturate(135%) blur(9px);
  border-bottom:1px solid transparent;
  transition:box-shadow .5s var(--ease-soft),
             background-color .5s var(--ease-soft),
             border-color .5s var(--ease-soft),
             padding .45s var(--ease-soft);
}
.site-nav::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:0.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.17 0 0 0 0 0.15 0 0 0 0 0.12 0 0 0 0.05 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}

.site-nav__inner{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:clamp(16px,3vw,40px);
  min-height:var(--nav-h);
  padding-block:14px;
  transition:min-height .45s var(--ease-soft),padding-block .45s var(--ease-soft);
}

.site-nav.is-scrolled{
  background:linear-gradient(to bottom,rgba(247,239,222,0.96),rgba(247,239,222,0.9));
  box-shadow:0 10px 30px -22px rgba(90,50,22,0.65);
  border-bottom-color:var(--line);
}
.site-nav.is-scrolled .site-nav__inner{
  min-height:62px;
  padding-block:8px;
}

.site-nav__brand{
  display:inline-flex;
  align-items:center;
  gap:11px;
  flex-shrink:0;
}
.site-nav__mark{
  display:inline-flex;
  transition:transform .6s var(--ease-soft);
}
.site-nav__brand:hover .site-nav__mark{transform:rotate(-6deg);}
.site-nav__mark svg{transition:width .45s var(--ease-soft),height .45s var(--ease-soft);}
.site-nav.is-scrolled .site-nav__mark svg{width:32px;height:32px;}

.site-nav__wordmark{
  font-family:var(--font-serif);
  font-weight:600;
  font-size:clamp(1.22rem,2vw,1.5rem);
  letter-spacing:-0.015em;
  color:var(--ink);
  line-height:1;
  white-space:nowrap;
}

.site-nav__links{
  display:flex;
  align-items:center;
  gap:clamp(14px,2.4vw,32px);
  margin-inline:auto;
}
.site-nav__link{
  position:relative;
  font-family:var(--font-sans);
  font-weight:600;
  font-size:0.95rem;
  color:var(--ink-soft);
  padding:4px 2px;
  transition:color .4s var(--ease-soft);
}
.site-nav__link::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-2px;
  height:2px;
  background:var(--turmeric);
  border-radius:2px;
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .45s var(--ease-soft);
}
.site-nav__link:hover{color:var(--ink);}
.site-nav__link:hover::after{transform:scaleX(1);}

.site-nav__cta{
  flex-shrink:0;
  padding:0.72em 1.3em;
  font-size:0.9rem;
}
.site-nav.is-scrolled .site-nav__cta{padding:0.62em 1.2em;}

@media (max-width:760px){
  .site-nav__links{display:none;}
  .site-nav__inner{justify-content:space-between;}
  .site-nav__wordmark{font-size:1.22rem;}
}
@media (max-width:380px){
  .site-nav__cta{padding:0.62em 1.05em;font-size:0.82rem;}
  .site-nav__wordmark{font-size:1.1rem;}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{
    animation-duration:0.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.001ms !important;
    scroll-behavior:auto !important;
  }
  .reveal{opacity:1;transform:none;}
  .word{opacity:1;transform:none;}
  .btn:hover,.site-nav__brand:hover .site-nav__mark{transform:none;}
}

/* ===================== */

.hero {
  position: relative;
  overflow: hidden;
  min-height: 94vh;
  display: flex;
  align-items: center;
  background: var(--cream);
  padding-block: clamp(76px, 10vw, 148px);
  isolation: isolate;
}

/* Warm radial glow */
.hero__glow {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(58% 60% at 68% 38%, rgba(224, 162, 27, 0.22), rgba(224, 162, 27, 0) 60%),
    radial-gradient(70% 70% at 22% 78%, rgba(168, 67, 42, 0.10), rgba(168, 67, 42, 0) 62%),
    radial-gradient(120% 100% at 50% 0%, rgba(252, 247, 236, 0.9), rgba(247, 239, 222, 0) 55%);
  pointer-events: none;
}

/* Subtle paper grain */
.hero__grain {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: 0.5;
  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='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E");
}

.hero__wrap {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  align-items: center;
  gap: clamp(32px, 5vw, 80px);
  width: 100%;
}

/* ---------- Text column ---------- */
.hero__text {
  max-width: min(560px, 100%);
}

.hero__kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 18px;
  font-family: var(--font-hand);
  font-size: clamp(1.25rem, 2.4vw, 1.65rem);
  line-height: 1;
  color: var(--terracotta);
  letter-spacing: 0.01em;
}

.hero__kicker-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--turmeric);
  box-shadow: 0 0 0 4px rgba(224, 162, 27, 0.22);
  flex: none;
}

.hero__title {
  margin: 0 0 22px;
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: clamp(2.4rem, 5.6vw, 4.3rem);
  line-height: 1.04;
  letter-spacing: -0.015em;
  color: var(--ink);
  text-wrap: balance;
}

.hero__title-em {
  font-style: italic;
  font-weight: 500;
  color: var(--terracotta);
  position: relative;
}

.hero__title-em::after {
  content: "";
  position: absolute;
  left: -2%;
  right: -2%;
  bottom: 0.06em;
  height: 0.5em;
  z-index: -1;
  background: linear-gradient(180deg, rgba(224, 162, 27, 0) 52%, rgba(224, 162, 27, 0.38) 52%);
  border-radius: 2px;
}

.hero__sub {
  margin: 0 0 32px;
  max-width: 40ch;
  font-family: var(--font-sans);
  font-size: clamp(1.02rem, 1.5vw, 1.16rem);
  line-height: 1.62;
  color: var(--ink-soft);
}

/* ---------- CTAs ---------- */
.hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-bottom: 26px;
}

.hero .btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 0.92em 1.5em;
  border-radius: 999px;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 1rem;
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  border: 1.5px solid transparent;
  transition:
    transform 0.6s var(--ease-soft),
    box-shadow 0.6s var(--ease-soft),
    background-color 0.6s var(--ease-soft),
    color 0.6s var(--ease-soft);
}

.hero .btn--primary {
  background: var(--terracotta);
  color: var(--paper);
  box-shadow: var(--shadow-card);
}

.hero .btn--primary:hover {
  background: var(--terracotta-deep);
  transform: translateY(-3px);
  box-shadow: var(--shadow-soft);
}

.hero .btn--ghost {
  background: transparent;
  color: var(--terracotta);
  border-color: var(--line);
}

.hero .btn--ghost:hover {
  background: var(--cream-2);
  border-color: var(--terracotta);
  transform: translateY(-3px);
}

.hero__cta-arrow {
  transition: transform 0.6s var(--ease-soft);
}

.hero .btn--primary:hover .hero__cta-arrow {
  transform: translateX(4px);
}

.hero .btn:focus-visible {
  outline: 3px solid var(--turmeric);
  outline-offset: 3px;
}

/* ---------- Trust line ---------- */
.hero__trust {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin: 0;
  font-family: var(--font-sans);
  font-size: 0.86rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

.hero__trust-sep {
  color: var(--turmeric-deep);
}

/* ---------- Art column ---------- */
.hero__art {
  display: flex;
  justify-content: center;
}

.hero__figure {
  position: relative;
  margin: 0;
  width: min(100%, 460px);
  filter: drop-shadow(0 30px 40px rgba(90, 50, 22, 0.18));
}

.hero__tiffin {
  width: 100%;
  height: auto;
  display: block;
  animation: hero__bob 7.5s var(--ease-soft) infinite;
}

@keyframes hero__bob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-9px); }
}

/* Handwritten price/note tag */
.hero__tag {
  position: absolute;
  right: -6px;
  bottom: 12%;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 14px 18px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 14px 14px 14px 4px;
  box-shadow: var(--shadow-card);
  transform: rotate(5deg);
  font-family: var(--font-hand);
  font-size: 1.4rem;
  line-height: 1.05;
  color: var(--terracotta);
}

.hero__tag-line {
  display: block;
}

/* ---------- Steam animation ---------- */
.hero__wisp {
  opacity: 0;
  transform-box: fill-box;
  transform-origin: bottom center;
  will-change: transform, opacity;
}

.hero__wisp--1 { animation: hero__rise 7s var(--ease-soft) infinite; animation-delay: 0s; }
.hero__wisp--2 { animation: hero__rise 8.5s var(--ease-soft) infinite; animation-delay: 1.4s; }
.hero__wisp--3 { animation: hero__rise 7.8s var(--ease-soft) infinite; animation-delay: 2.8s; }
.hero__wisp--4 { animation: hero__rise 9s var(--ease-soft) infinite; animation-delay: 4.1s; }
.hero__wisp--5 { animation: hero__rise 8s var(--ease-soft) infinite; animation-delay: 5.3s; }

@keyframes hero__rise {
  0%   { opacity: 0; transform: translateY(10px) scale(0.85); }
  18%  { opacity: 0.5; }
  60%  { opacity: 0.28; }
  100% { opacity: 0; transform: translateY(-70px) scale(1.35); }
}

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .hero {
    min-height: auto;
  }
  .hero__wrap {
    grid-template-columns: 1fr;
    gap: clamp(28px, 6vw, 56px);
    text-align: center;
  }
  .hero__text {
    max-width: 46ch;
    margin-inline: auto;
    order: 1;
  }
  .hero__sub {
    margin-inline: auto;
  }
  .hero__art {
    order: 2;
  }
  .hero__kicker,
  .hero__ctas,
  .hero__trust {
    justify-content: center;
  }
  .hero__figure {
    width: min(100%, 360px);
  }
}

@media (max-width: 480px) {
  .hero__ctas {
    flex-direction: column;
    align-items: stretch;
  }
  .hero .btn {
    justify-content: center;
  }
  .hero__figure {
    width: min(100%, 290px);
  }
  .hero__tag {
    right: -2px;
    font-size: 1.2rem;
    padding: 11px 14px;
  }
  .hero__trust {
    font-size: 0.78rem;
  }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  .hero__tiffin {
    animation: none;
  }
  .hero__wisp {
    animation: none !important;
    opacity: 0.16;
    transform: none;
  }
  .hero .btn,
  .hero__cta-arrow {
    transition: none;
  }
  .hero .btn--primary:hover,
  .hero .btn--ghost:hover {
    transform: none;
  }
}

/* ===================== */

.week{
  position:relative;
  padding-block:clamp(76px,10vw,148px);
  background:var(--cream);
  color:var(--ink);
  overflow:hidden;
}
.week::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.5;
  background-image:radial-gradient(rgba(43,38,32,0.05) 1px, transparent 1px);
  background-size:5px 5px;
}

/* ---- header ---- */
.week__head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:clamp(20px,4vw,48px);
  flex-wrap:wrap;
  margin-bottom:clamp(34px,4vw,54px);
}
.week__kicker{
  font-family:var(--font-hand);
  color:var(--terracotta);
  font-size:clamp(1.35rem,2.4vw,1.7rem);
  line-height:1;
  margin:0 0 .2em;
  transform:rotate(-2deg);
}
.week__title{
  font-family:var(--font-serif);
  font-weight:600;
  color:var(--ink);
  font-size:clamp(2.4rem,5.6vw,4rem);
  line-height:1.02;
  letter-spacing:-.01em;
  margin:0;
}
.week__sub{
  font-family:var(--font-hand);
  color:var(--ink-soft);
  font-size:clamp(1.15rem,2vw,1.45rem);
  margin:.35em 0 0;
}

/* ---- toggle ---- */
.week__toggle{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:999px;
  box-shadow:var(--shadow-card);
}
.week__toggle-label{
  font-family:var(--font-hand);
  color:var(--ink-soft);
  font-size:1.1rem;
  padding:0 6px 0 10px;
}
.week__toggle-btn{
  appearance:none;
  border:0;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:9px 16px;
  border-radius:999px;
  font-family:var(--font-sans);
  font-weight:700;
  font-size:.92rem;
  letter-spacing:.01em;
  color:var(--ink-soft);
  background:transparent;
  transition:background .5s var(--ease-soft), color .5s var(--ease-soft), box-shadow .5s var(--ease-soft);
}
.week__toggle-dot{
  width:11px;height:11px;border-radius:50%;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.6);
}
.week__toggle-dot--veg{background:var(--leaf);}
.week__toggle-dot--jain{background:var(--turmeric-deep);}
.week__toggle-btn.is-on{
  color:var(--paper);
  background:var(--terracotta);
  box-shadow:0 6px 14px -8px rgba(168,67,42,.9);
}
.week__toggle-btn.is-on .week__toggle-dot{box-shadow:inset 0 0 0 2px rgba(255,255,255,.85);}
.week__toggle-btn:focus-visible{
  outline:2px solid var(--terracotta-deep);
  outline-offset:2px;
}

/* ---- strip ---- */
.week__strip-shell{position:relative;}
.week__hint{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-hand);
  color:var(--ink-soft);
  font-size:1.15rem;
  margin:0 0 16px;
}
.week__hint-arrow{
  display:inline-flex;
  color:var(--terracotta);
  animation:week-nudge 2.2s var(--ease-soft) infinite;
}
@keyframes week-nudge{
  0%,100%{transform:translateX(0);}
  50%{transform:translateX(7px);}
}

.week__strip{
  list-style:none;
  margin:0;
  padding:8px 4px 28px;
  display:flex;
  gap:clamp(18px,2.4vw,30px);
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  -ms-overflow-style:none;
  scroll-padding-left:4px;
  -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 26px, #000 calc(100% - 46px), transparent 100%);
          mask-image:linear-gradient(90deg, transparent 0, #000 26px, #000 calc(100% - 46px), transparent 100%);
}
.week__strip::-webkit-scrollbar{display:none;width:0;height:0;}

.week__cell{
  flex:0 0 auto;
  scroll-snap-align:start;
  width:clamp(240px,72vw,288px);
}

/* ---- card / flip ---- */
.week__card{
  display:block;
  width:100%;
  height:clamp(330px,46vw,372px);
  padding:0;
  border:0;
  background:transparent;
  cursor:pointer;
  perspective:1400px;
  font:inherit;
  color:inherit;
  text-align:left;
}
.week__card:focus-visible{outline:none;}
.week__card:focus-visible .week__face{
  box-shadow:var(--shadow-soft), 0 0 0 3px var(--turmeric);
}

.week__inner{
  position:relative;
  display:block;
  width:100%;
  height:100%;
  transform-style:preserve-3d;
  transition:transform 1s var(--ease-soft);
}
.week__card.is-flipped .week__inner{
  transform:rotateY(180deg);
}
/* pointer users get a hover preview; the click/keyboard toggle pins it open */
@media (hover:hover) and (pointer:fine){
  .week__card:hover .week__inner{
    transform:rotateY(180deg);
  }
}

.week__face{
  position:absolute;
  inset:0;
  -webkit-backface-visibility:hidden;
          backface-visibility:hidden;
  border-radius:18px;
  background:var(--paper);
  border:1px solid var(--line);
  box-shadow:var(--shadow-card);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:box-shadow .6s var(--ease-soft);
}

/* ---- front ---- */
.week__front{
  align-items:center;
  justify-content:space-between;
  padding:26px 22px 24px;
  text-align:center;
  background:
    radial-gradient(120% 80% at 50% 0%, var(--cream) 0%, var(--paper) 60%);
}
.week__front::after{
  content:"";
  position:absolute;
  left:18px;right:18px;top:14px;height:0;
  border-top:1px dashed var(--line);
}
.week__day{display:flex;flex-direction:column;align-items:center;gap:2px;}
.week__day-hand{
  font-family:var(--font-hand);
  color:var(--terracotta);
  font-size:1.55rem;
  line-height:1;
  transform:rotate(-2deg);
}
.week__day-name{
  font-family:var(--font-serif);
  font-style:italic;
  font-weight:500;
  color:var(--ink-soft);
  font-size:.92rem;
  letter-spacing:.04em;
}
.week__motif{
  display:flex;
  align-items:center;
  justify-content:center;
  margin:4px 0;
  filter:drop-shadow(0 6px 10px rgba(90,50,22,.16));
}
.week__dish{
  font-family:var(--font-serif);
  font-weight:600;
  color:var(--ink);
  font-size:1.32rem;
  line-height:1.16;
  max-width:15ch;
}
.week__chip{
  display:inline-flex;
  align-items:center;
  gap:7px;
  font-family:var(--font-sans);
  font-weight:700;
  font-size:.72rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--leaf);
  background:rgba(94,123,58,.12);
  border:1px solid rgba(94,123,58,.3);
  padding:6px 13px;
  border-radius:999px;
}
.week__leaf{
  width:12px;height:12px;flex:0 0 auto;
  background:var(--leaf);
  border-radius:0 50% 0 50%;
  transform:rotate(45deg);
}

/* ---- back (recipe card) ---- */
.week__back{
  transform:rotateY(180deg);
  padding:22px 22px 20px;
  background:
    linear-gradient(var(--paper),var(--paper)) padding-box,
    repeating-linear-gradient(var(--cream-2),var(--cream-2));
  background-color:var(--paper);
}
.week__back::before{
  content:"";
  position:absolute;
  top:0;bottom:0;left:38px;
  width:1px;
  background:rgba(168,67,42,.35);
}
.week__back-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:8px;
  padding-bottom:10px;
  margin-bottom:8px;
  border-bottom:2px solid var(--line);
}
.week__back-day{
  font-family:var(--font-serif);
  font-weight:600;
  font-size:1.28rem;
  color:var(--terracotta);
}
.week__back-tag{
  font-family:var(--font-hand);
  color:var(--ink-soft);
  font-size:1.05rem;
}
.week__list{
  list-style:none;
  margin:0;
  padding:0;
  counter-reset:thali;
}
.week__list li{
  position:relative;
  font-family:var(--font-sans);
  font-size:.86rem;
  line-height:1.5;
  color:var(--ink);
  padding:5px 2px 5px 24px;
  border-bottom:1px solid var(--line);
}
.week__list li::before{
  content:"";
  position:absolute;
  left:6px;top:50%;
  width:6px;height:6px;
  margin-top:-3px;
  border-radius:50%;
  background:var(--turmeric);
  box-shadow:0 0 0 2px rgba(224,162,27,.25);
}
.week__list li:last-child{border-bottom:0;}
.week__list em{
  font-style:italic;
  color:var(--ink-soft);
  font-size:.92em;
}

/* ---- veg / jain visibility ---- */
.week__diet--jain{display:none;}
.week.week--jain .week__diet--veg{display:none;}
.week.week--jain .week__diet--jain{display:block;}
.week.week--jain .week__chip--veg{
  color:var(--turmeric-deep);
  background:rgba(192,134,15,.12);
  border-color:rgba(192,134,15,.32);
}
.week.week--jain .week__leaf{background:var(--turmeric-deep);}

/* ---- responsive ---- */
@media (max-width:760px){
  .week__head{align-items:flex-start;}
  .week__toggle{order:2;}
}
@media (max-width:430px){
  .week__cell{width:min(82vw,300px);}
  .week__toggle-label{display:none;}
  /* longer Jain lists need more room at the narrowest widths */
  .week__card{height:clamp(380px,116vw,460px);}
  .week__back{overflow-y:auto;}
}

/* hover affordance only where real hover exists */
@media (hover:hover){
  .week__card:hover .week__face{box-shadow:var(--shadow-soft);}
}

/* ---- reduced motion ---- */
@media (prefers-reduced-motion:reduce){
  .week__inner{transition:none;}
  .week__hint-arrow{animation:none;}
}

/* ===================== */

.story{
  position:relative;
  background:var(--cream);
  padding-block:clamp(76px,10vw,148px);
  overflow:hidden;
}
/* subtle paper grain */
.story::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.5;
  background-image:radial-gradient(rgba(43,38,32,0.05) 1px,transparent 1.4px);
  background-size:5px 5px;
}
.story__wrap{position:relative;z-index:1;}

.story__grid{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);
  gap:clamp(36px,6vw,84px);
  align-items:center;
}

/* ---------- LEFT: art ---------- */
.story__art{
  margin:0;
  position:relative;
}
.story__scene{
  display:block;
  width:100%;
  height:auto;
  border-radius:24px;
  background:var(--paper);
  box-shadow:var(--shadow-soft);
  border:1px solid var(--line);
}
.story__caption{
  margin-top:14px;
  text-align:center;
  font-family:var(--font-hand);
  font-size:clamp(1.15rem,2vw,1.45rem);
  color:var(--ink-soft);
  line-height:1.2;
}

/* gentle ambient motion inside the scene */
.story__glow{transform-origin:178px 150px;animation:story-breathe 9s var(--ease-soft) infinite;}
.story__rays{animation:story-rayfade 7s var(--ease-soft) infinite;}
.story__sun{animation:story-breathe 9s var(--ease-soft) infinite;}
.story__flame{transform-origin:174px 488px;animation:story-flicker 1.6s var(--ease-soft) infinite;}
.story__steam-1{stroke-dasharray:90;stroke-dashoffset:90;animation:story-steam 4.2s var(--ease-soft) infinite;}
.story__steam-2{stroke-dasharray:90;stroke-dashoffset:90;animation:story-steam 4.2s var(--ease-soft) .9s infinite;}
.story__ladle{transform-origin:top center;animation:story-sway 6s var(--ease-soft) infinite;animation-delay:calc(var(--lswing,0) * .9s);}

@keyframes story-breathe{
  0%,100%{opacity:.85;transform:scale(1);}
  50%{opacity:1;transform:scale(1.04);}
}
@keyframes story-rayfade{
  0%,100%{opacity:.4;}
  50%{opacity:.62;}
}
@keyframes story-flicker{
  0%,100%{transform:scale(1) translateY(0);opacity:1;}
  45%{transform:scale(1.08,.94) translateY(1px);opacity:.92;}
  70%{transform:scale(.95,1.07) translateY(-1px);opacity:1;}
}
@keyframes story-steam{
  0%{stroke-dashoffset:90;opacity:0;}
  25%{opacity:.5;}
  100%{stroke-dashoffset:-30;opacity:0;}
}
@keyframes story-sway{
  0%,100%{transform:rotate(-2.2deg);}
  50%{transform:rotate(2.2deg);}
}

/* ---------- RIGHT: copy ---------- */
.story__copy{max-width:52ch;}

.story__kicker{
  font-family:var(--font-hand);
  font-size:clamp(1.5rem,3vw,2rem);
  color:var(--terracotta);
  line-height:1;
  margin:0 0 .35em;
}
.story__kicker::after{
  content:"";
  display:block;
  width:54px;
  height:3px;
  margin-top:.45em;
  border-radius:3px;
  background:var(--turmeric);
}

.story__title{
  font-family:var(--font-serif);
  font-weight:600;
  font-size:clamp(1.7rem,3.6vw,2.85rem);
  line-height:1.12;
  color:var(--ink);
  margin:0 0 .85em;
  letter-spacing:-.01em;
}
.story__title em{
  font-style:italic;
  color:var(--terracotta);
}

.story__para{
  font-family:var(--font-sans);
  font-size:clamp(1rem,1.25vw,1.12rem);
  line-height:1.78;
  color:var(--ink-soft);
  margin:0 0 1.15em;
}

.story__pull{
  position:relative;
  margin:1.6em 0 1.3em;
  padding:18px 22px 18px 26px;
  background:var(--paper);
  border-left:4px solid var(--turmeric);
  border-radius:0 14px 14px 0;
  box-shadow:var(--shadow-card);
}
.story__pull-mark{
  position:absolute;
  top:-2px;
  left:10px;
  font-family:var(--font-serif);
  font-size:3rem;
  line-height:1;
  color:var(--turmeric);
  opacity:.55;
}
.story__pull-text{
  display:block;
  font-family:var(--font-serif);
  font-style:italic;
  font-size:clamp(1.05rem,1.6vw,1.3rem);
  line-height:1.45;
  color:var(--ink);
  padding-left:30px;
}

.story__sign{
  font-family:var(--font-hand);
  font-size:clamp(1.4rem,2.4vw,1.85rem);
  color:var(--terracotta-deep);
  line-height:1.1;
  margin:0;
}

/* focus-visible */
.story a:focus-visible,
.story__scene:focus-visible{
  outline:3px solid var(--terracotta);
  outline-offset:3px;
  border-radius:8px;
}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .story__grid{
    grid-template-columns:1fr;
    gap:clamp(30px,6vw,48px);
  }
  .story__copy{max-width:60ch;margin-inline:auto;}
  .story__art{order:-1;max-width:560px;margin-inline:auto;width:100%;}
}
@media (max-width:480px){
  .story__pull{padding:16px 16px 16px 20px;}
  .story__pull-text{padding-left:24px;}
  .story__caption{font-size:1.1rem;}
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  .story__glow,
  .story__rays,
  .story__sun,
  .story__flame,
  .story__steam-1,
  .story__steam-2,
  .story__ladle{
    animation:none !important;
  }
  .story__steam-1,
  .story__steam-2{stroke-dashoffset:0;opacity:.4;}
}

/* ===================== */

.tiers{
  position:relative;
  background:var(--cream);
  padding-block:clamp(76px,10vw,148px);
  color:var(--ink);
}

.tiers__head{
  text-align:center;
  max-width:640px;
  margin-inline:auto;
  margin-bottom:clamp(40px,6vw,72px);
}
.tiers__kicker{
  font-family:var(--font-hand);
  color:var(--terracotta);
  font-size:clamp(1.4rem,2.6vw,1.85rem);
  line-height:1;
  margin:0 0 .35em;
}
.tiers__title{
  font-family:var(--font-serif);
  font-weight:600;
  color:var(--ink);
  font-size:clamp(2.1rem,5vw,3.4rem);
  line-height:1.04;
  letter-spacing:-0.01em;
  margin:0;
}
.tiers__sub{
  font-family:var(--font-hand);
  color:var(--ink-soft);
  font-size:clamp(1.2rem,2.2vw,1.6rem);
  margin:.55em 0 0;
}

.tiers__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:clamp(22px,3vw,38px);
  align-items:stretch;
}

/* ---- card ---- */
.tiers__card{
  position:relative;
  display:flex;
  flex-direction:column;
  isolation:isolate;
  transition:transform .9s var(--ease-soft);
  will-change:transform;
}
.tiers__card--featured{
  transform:translateY(-16px);
  z-index:2;
}

/* the paper body */
.tiers__paper{
  position:relative;
  flex:1;
  display:flex;
  flex-direction:column;
  background:
    repeating-linear-gradient(
      to bottom,
      transparent 0,
      transparent 33px,
      rgba(43,38,32,0.07) 33px,
      rgba(43,38,32,0.07) 34px
    ),
    var(--paper);
  padding:clamp(26px,3.4vw,40px) clamp(22px,3vw,34px);
  box-shadow:var(--shadow-card);
}
.tiers__card--featured .tiers__paper{
  background:
    repeating-linear-gradient(
      to bottom,
      transparent 0,
      transparent 33px,
      rgba(168,67,42,0.10) 33px,
      rgba(168,67,42,0.10) 34px
    ),
    var(--paper);
  box-shadow:var(--shadow-soft);
}

/* faint grain wash + left margin rule like a recipe sheet */
.tiers__paper::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(rgba(43,38,32,0.045) 1px,transparent 1.4px);
  background-size:5px 5px;
  opacity:.55;
  pointer-events:none;
  mix-blend-mode:multiply;
}
.tiers__paper::after{
  content:"";
  position:absolute;
  top:0;bottom:0;
  left:clamp(16px,2.4vw,26px);
  width:1.5px;
  background:rgba(168,67,42,0.28);
  pointer-events:none;
}

/* torn deckled edges */
.tiers__torn{
  display:block;
  height:16px;
  line-height:0;
  position:relative;
  z-index:1;
}
.tiers__torn svg{
  display:block;
  width:100%;
  height:100%;
}
.tiers__torn path{ fill:var(--paper); }
.tiers__card--featured .tiers__torn path{ fill:var(--paper); }
.tiers__torn--top{
  margin-bottom:-1px;
  filter:drop-shadow(0 -3px 5px rgba(90,50,22,0.10));
}
.tiers__torn--bottom{
  margin-top:-1px;
  filter:drop-shadow(0 4px 7px rgba(90,50,22,0.16));
}

/* ---- content ---- */
.tiers__plan{
  font-family:var(--font-serif);
  font-weight:600;
  font-size:clamp(1.55rem,2.6vw,1.95rem);
  color:var(--terracotta);
  margin:0;
  line-height:1.05;
}
.tiers__card--featured .tiers__plan{ color:var(--terracotta-deep); }
.tiers__for{
  font-family:var(--font-hand);
  font-size:clamp(1.15rem,1.9vw,1.35rem);
  color:var(--ink-soft);
  margin:.15em 0 0;
}

.tiers__pricerow{
  display:flex;
  align-items:baseline;
  gap:.18em;
  margin:clamp(16px,2.2vw,22px) 0 clamp(18px,2.4vw,26px);
  padding-bottom:clamp(16px,2.2vw,22px);
  border-bottom:1px solid var(--line);
}
.tiers__rupee{
  font-family:var(--font-hand);
  font-size:clamp(1.7rem,3vw,2.3rem);
  color:var(--turmeric-deep);
  line-height:1;
  transform:translateY(-0.12em);
}
.tiers__price{
  font-family:var(--font-serif);
  font-weight:700;
  font-size:clamp(2.6rem,5.4vw,3.5rem);
  color:var(--ink);
  line-height:.9;
  letter-spacing:-0.01em;
}
.tiers__period{
  font-family:var(--font-sans);
  font-weight:600;
  font-size:clamp(.85rem,1.4vw,1rem);
  color:var(--ink-soft);
}

.tiers__list{
  list-style:none;
  margin:0 0 clamp(24px,3vw,32px);
  padding:0;
  display:flex;
  flex-direction:column;
}
.tiers__feat{
  display:flex;
  align-items:flex-start;
  gap:11px;
  font-family:var(--font-sans);
  font-size:clamp(.94rem,1.5vw,1.02rem);
  line-height:1.45;
  color:var(--ink);
  padding:11px 0;
  border-bottom:1px dashed var(--line);
}
.tiers__feat:first-child{ padding-top:0; }
.tiers__feat:last-child{ border-bottom:none; }

.tiers__tick{
  flex:0 0 auto;
  width:22px;height:22px;
  margin-top:1px;
  border-radius:50%;
  background:rgba(94,123,58,0.14);
  display:grid;
  place-items:center;
}
.tiers__tick svg{ width:15px;height:15px;display:block; }
.tiers__tick path{ stroke:var(--leaf); stroke-width:2.4; }
.tiers__card--featured .tiers__tick{ background:rgba(224,162,27,0.18); }
.tiers__card--featured .tiers__tick path{ stroke:var(--turmeric-deep); }

/* CTA */
.tiers__cta{
  margin-top:auto;
  align-self:stretch;
  text-align:center;
}

/* ---- MOST LOVED stamp ---- */
.tiers__stamp{
  position:absolute;
  top:-26px;
  right:-14px;
  width:clamp(86px,9vw,108px);
  height:clamp(86px,9vw,108px);
  z-index:5;
  transform:rotate(-13deg);
  pointer-events:none;
  opacity:.92;
  filter:drop-shadow(0 6px 10px rgba(90,50,22,0.22));
}
.tiers__stamp svg{ width:100%;height:100%;display:block;overflow:visible; }
.tiers__stamp-ring{
  fill:none;
  stroke:var(--terracotta);
  opacity:.85;
}
.tiers__stamp-ring--out{ stroke-width:3.5; stroke-dasharray:2 3.2; }
.tiers__stamp-ring--in{ stroke-width:1.4; opacity:.6; }
.tiers__stamp-arc{
  font-family:var(--font-sans);
  font-weight:700;
  font-size:15.5px;
  letter-spacing:.14em;
  fill:var(--terracotta);
  opacity:.9;
}
.tiers__stamp-arc--bot{
  font-size:9px;
  letter-spacing:.16em;
  opacity:.7;
}
.tiers__stamp-star{
  font-size:21px;
  fill:var(--terracotta);
  opacity:.85;
}

.tiers__foot{
  text-align:center;
  font-family:var(--font-sans);
  font-size:clamp(.86rem,1.4vw,.96rem);
  color:var(--ink-soft);
  margin:clamp(36px,5vw,58px) 0 0;
}

/* hover lift */
@media (hover:hover){
  .tiers__card:hover{ transform:translateY(-10px); }
  .tiers__card--featured:hover{ transform:translateY(-24px); }
  .tiers__cta{ transition:transform .5s var(--ease-soft); }
}

/* focus visibility */
.tiers__cta:focus-visible{
  outline:2.5px solid var(--terracotta);
  outline-offset:3px;
}

/* ---- responsive ---- */
@media (max-width:920px){
  .tiers__grid{
    grid-template-columns:1fr;
    max-width:460px;
    margin-inline:auto;
    gap:clamp(34px,7vw,46px);
  }
  .tiers__card--featured{ transform:none; order:-1; }
  @media (hover:hover){
    .tiers__card--featured:hover{ transform:translateY(-10px); }
  }
}

@media (max-width:420px){
  .tiers__stamp{ top:-22px; right:-8px; width:80px;height:80px; }
}

@media (prefers-reduced-motion:reduce){
  .tiers__card,
  .tiers__card--featured,
  .tiers__cta{
    transition:none !important;
  }
  .tiers__card:hover,
  .tiers__card--featured:hover{
    transform:translateY(0) !important;
  }
  .tiers__card--featured{ transform:translateY(-16px); }
  @media (max-width:920px){
    .tiers__card--featured{ transform:none; }
  }
}

/* ===================== */

.cater {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: var(--terracotta);
  color: var(--cream);
  padding-block: clamp(76px, 10vw, 148px);
}

/* warm depth + subtle paper grain via layered radial washes */
.cater::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(120% 90% at 18% 0%, rgba(224, 162, 27, 0.18), transparent 55%),
    radial-gradient(130% 110% at 90% 100%, rgba(130, 47, 28, 0.55), transparent 60%),
    var(--terracotta);
  pointer-events: none;
}
.cater::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  opacity: 0.06;
  pointer-events: none;
  background-image:
    repeating-linear-gradient(0deg, rgba(247, 239, 222, 0.6) 0 1px, transparent 1px 3px),
    repeating-linear-gradient(90deg, rgba(247, 239, 222, 0.5) 0 1px, transparent 1px 4px);
  mix-blend-mode: overlay;
}

/* hairline edges so the band reads as a distinct slab */
.cater {
  border-top: 1px solid rgba(247, 239, 222, 0.16);
  border-bottom: 1px solid rgba(130, 47, 28, 0.5);
}

/* ----- parallax ingredient field ----- */
.cater__field {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  overflow: hidden;
}
.cater__ing {
  position: absolute;
  display: block;
  width: clamp(64px, 8vw, 120px);
  height: auto;
  opacity: 0.5;
  will-change: transform;
  transform: translate3d(0, 0, 0);
  filter: drop-shadow(0 10px 18px rgba(90, 50, 22, 0.25));
}

/* scattered placements — kept off the central text column on wide screens */
.cater__ing--turmeric { top: 8%;  left: 4%;  width: clamp(80px, 9vw, 132px); }
.cater__ing--chilli   { top: 14%; right: 7%; }
.cater__ing--anise    { top: 60%; left: 8%; }
.cater__ing--cardamom { bottom: 9%; right: 12%; }
.cater__ing--curry    { top: 2%;  left: 63%; width: clamp(96px, 11vw, 150px); opacity: 0.34; }
.cater__ing--cinnamon { bottom: 12%; left: 16%; }
.cater__ing--marigold { top: 30%; right: 3%;  width: clamp(86px, 9vw, 128px); }
.cater__ing--mustard  { bottom: 28%; left: 2%; opacity: 0.45; }

/* ----- foreground content ----- */
.cater__inner {
  max-width: 720px;
  position: relative;
  z-index: 1;
}
.cater__kicker {
  font-family: var(--font-hand);
  font-size: clamp(1.5rem, 1rem + 1.6vw, 2.1rem);
  line-height: 1;
  color: var(--gold-soft);
  margin: 0 0 0.4rem;
  letter-spacing: 0.01em;
}
.cater__title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: clamp(2.1rem, 1.2rem + 3.6vw, 3.6rem);
  line-height: 1.06;
  letter-spacing: -0.012em;
  margin: 0 0 1.15rem;
  color: var(--paper);
  text-wrap: balance;
}
.cater__title em {
  font-style: italic;
  font-weight: 400;
  color: var(--turmeric);
}
.cater__lede {
  font-family: var(--font-sans);
  font-size: clamp(1rem, 0.92rem + 0.45vw, 1.16rem);
  line-height: 1.7;
  color: rgba(247, 239, 222, 0.88);
  margin: 0 0 2rem;
  max-width: 60ch;
}
.cater__lede strong {
  font-weight: 700;
  color: var(--paper);
}
.cater__lede em {
  font-style: italic;
  color: var(--turmeric);
  font-weight: 600;
}

.cater__cta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem 1.6rem;
}
/* local guarantee of .btn look in case foundation .btn is restyled per-section */
.cater__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: 0.01em;
  color: var(--ink);
  background: var(--turmeric);
  padding: 0.85em 1.7em;
  border-radius: 999px;
  text-decoration: none;
  box-shadow: var(--shadow-soft);
  transition: transform 0.6s var(--ease-soft), background-color 0.6s var(--ease-soft), box-shadow 0.6s var(--ease-soft);
}
.cater__btn:hover {
  background: var(--paper);
  transform: translateY(-2px);
  box-shadow: 0 26px 48px -24px rgba(90, 50, 22, 0.6);
}
.cater__btn:focus-visible {
  outline: 3px solid var(--paper);
  outline-offset: 3px;
}
.cater__secondary {
  font-family: var(--font-hand);
  font-size: clamp(1.15rem, 0.9rem + 0.7vw, 1.4rem);
  line-height: 1.1;
  color: rgba(247, 239, 222, 0.94);
  margin: 0;
}

/* ----- responsive ----- */
@media (max-width: 768px) {
  .cater__inner { max-width: 100%; }
  .cater__ing--curry,
  .cater__ing--cinnamon,
  .cater__ing--cardamom {
    display: none; /* declutter mid-screen */
  }
  .cater__ing--turmeric { top: 5%;  left: 2%; }
  .cater__ing--chilli   { top: 7%;  right: 4%; }
  .cater__ing--anise    { bottom: 6%; right: 6%; top: auto; left: auto; }
  .cater__ing--marigold { bottom: 7%; left: 4%; top: auto; right: auto; }
  .cater__ing--mustard  { top: auto; bottom: 8%; left: auto; right: 6%; }
  .cater__ing { opacity: 0.38; }
}
@media (max-width: 420px) {
  /* keep only a light scatter at the corners on the smallest screens */
  .cater__ing--mustard,
  .cater__ing--anise { display: none; }
  .cater__ing--turmeric { width: 76px; }
  .cater__ing--marigold { width: 80px; }
  .cater__cta { gap: 0.9rem; }
}

/* ----- reduced motion: static, no drift, no reveal transforms ----- */
@media (prefers-reduced-motion: reduce) {
  .cater__ing {
    transform: none !important;
    transition: none;
  }
  .cater__btn {
    transition: none;
  }
  .cater__btn:hover {
    transform: none;
  }
}

/* ===================== */

.notes{
  position:relative;
  overflow:hidden;
  padding-block:clamp(76px,10vw,148px);
  background-color:#5a3d22;
  background-image:
    radial-gradient(circle at 18% 22%, rgba(255,224,178,0.10) 0 1.5px, transparent 2px),
    radial-gradient(circle at 62% 14%, rgba(60,34,12,0.34) 0 1.6px, transparent 2.4px),
    radial-gradient(circle at 84% 40%, rgba(255,210,150,0.08) 0 1.4px, transparent 2px),
    radial-gradient(circle at 30% 64%, rgba(58,32,12,0.30) 0 1.6px, transparent 2.4px),
    radial-gradient(circle at 70% 78%, rgba(255,220,170,0.07) 0 1.4px, transparent 2px),
    radial-gradient(circle at 44% 90%, rgba(56,30,12,0.30) 0 1.6px, transparent 2.4px),
    radial-gradient(ellipse 130% 90% at 50% 0%, #6b4a2a 0%, #573a20 46%, #46301a 100%);
  background-size:34px 34px,46px 46px,40px 40px,52px 52px,44px 44px,50px 50px,100% 100%;
  border-block:10px solid #3c2913;
  box-shadow:inset 0 0 0 4px rgba(120,82,44,0.55), inset 0 18px 60px -20px rgba(20,10,2,0.7);
}
.notes__grain{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:0.10;
  mix-blend-mode:multiply;
  pointer-events:none;
}
.notes__wrap{ position:relative; z-index:1; }

/* heading on taped label */
.notes__head{ display:flex; justify-content:center; margin-bottom:clamp(48px,6vw,76px); }
.notes__label{
  position:relative;
  text-align:center;
  padding:clamp(20px,3vw,34px) clamp(28px,5vw,56px);
  background:var(--paper);
  background-image:linear-gradient(180deg, var(--paper), var(--cream-2));
  border-radius:3px;
  box-shadow:var(--shadow-soft);
  transform:rotate(-1.2deg);
}
.notes__tape{
  position:absolute;
  top:-14px;
  width:88px;
  height:30px;
  background:rgba(224,162,27,0.42);
  border:1px solid rgba(192,134,15,0.30);
  box-shadow:0 4px 10px -6px rgba(40,20,5,0.5);
}
.notes__tape--l{ left:14%; transform:rotate(-8deg); }
.notes__tape--r{ right:14%; transform:rotate(7deg); }
.notes__kicker{
  margin:0 0 2px;
  font-family:var(--font-hand);
  font-size:clamp(1.4rem,2.4vw,1.9rem);
  color:var(--terracotta);
  line-height:1;
}
.notes__heading{
  margin:0;
  font-family:var(--font-serif);
  font-weight:600;
  font-size:clamp(2rem,4.6vw,3.3rem);
  line-height:1.04;
  color:var(--ink);
  letter-spacing:-0.01em;
}
.notes__sub{
  margin:8px 0 0;
  font-family:var(--font-hand);
  font-size:clamp(1.05rem,1.9vw,1.4rem);
  color:var(--ink-soft);
  line-height:1.1;
}

/* board layout — relaxed masonry via columns */
.notes__board{
  list-style:none;
  margin:0;
  padding:0;
  column-count:3;
  column-gap:clamp(22px,3.2vw,42px);
}
.notes__note{
  position:relative;
  break-inside:avoid;
  margin:0 0 clamp(30px,4vw,52px);
  padding-top:18px;
}

/* push-pin */
.notes__pin{
  position:absolute;
  top:-6px;
  left:50%;
  width:34px;
  height:44px;
  transform:translateX(-50%);
  z-index:3;
  transition:transform 0.9s var(--ease-soft);
  filter:drop-shadow(0 6px 6px rgba(30,16,4,0.4));
}
.notes__pin svg{ display:block; width:100%; height:100%; }
.notes__pinShadow{ fill:rgba(30,16,4,0.25); }
.notes__pinNeedle{ fill:#9a9088; }
.notes__pinHead{ stroke:rgba(0,0,0,0.18); stroke-width:1; }
.notes__pinHead--terra{ fill:var(--terracotta); }
.notes__pinHead--turmeric{ fill:var(--turmeric); }
.notes__pinHead--leaf{ fill:var(--leaf); }
.notes__pinShine{ fill:rgba(255,255,255,0.42); }

/* paper card */
.notes__card{
  position:relative;
  margin:0;
  padding:clamp(24px,2.6vw,34px) clamp(22px,2.4vw,30px) clamp(20px,2.2vw,28px);
  background:var(--paper);
  border-radius:4px;
  box-shadow:var(--shadow-card);
  transition:transform 1s var(--ease-soft), box-shadow 1s var(--ease-soft);
  will-change:transform;
}
.notes__card::after{
  content:"";
  position:absolute;
  left:14px;
  right:14px;
  bottom:9px;
  height:1px;
  background:var(--line);
}
.notes__quote{
  margin:0;
  font-family:var(--font-hand);
  font-size:clamp(1.4rem,2.1vw,1.72rem);
  line-height:1.32;
  color:var(--ink);
  letter-spacing:0.2px;
}
.notes__sign{
  margin-top:14px;
  font-family:var(--font-hand);
  font-size:clamp(1.2rem,1.8vw,1.5rem);
  color:var(--terracotta-deep);
  text-align:right;
}

/* varied tints + rotations */
.notes__note:nth-child(1) .notes__card{ background:var(--paper);   transform:rotate(-4deg); }
.notes__note:nth-child(2) .notes__card{ background:#FBF1DC;        transform:rotate(3deg);  }
.notes__note:nth-child(3) .notes__card{ background:#FCF7EC;        transform:rotate(-2deg); }
.notes__note:nth-child(4) .notes__card{ background:#F8F0E0;        transform:rotate(5deg);  }
.notes__note:nth-child(5) .notes__card{ background:#FCF4E4;        transform:rotate(-3deg); }

/* calm pin-rotate + lift on hover/focus */
.notes__note:hover .notes__card,
.notes__note:focus-within .notes__card{
  transform:rotate(0.4deg) translateY(-8px);
  box-shadow:var(--shadow-soft);
}
.notes__note:hover .notes__pin,
.notes__note:focus-within .notes__pin{
  transform:translateX(-50%) rotate(-7deg);
}

/* focus visibility for keyboard users */
.notes__card:focus-visible,
.notes__note:focus-visible .notes__card{
  outline:2px solid var(--turmeric-deep);
  outline-offset:4px;
}
.notes__card{ outline-offset:4px; }

/* responsive */
@media (max-width:1024px){
  .notes__board{ column-count:2; }
}
@media (max-width:640px){
  .notes__board{ column-count:1; max-width:440px; margin-inline:auto; }
  /* reduce rotation on mobile for legibility */
  .notes__note:nth-child(1) .notes__card,
  .notes__note:nth-child(2) .notes__card,
  .notes__note:nth-child(3) .notes__card,
  .notes__note:nth-child(4) .notes__card,
  .notes__note:nth-child(5) .notes__card{ transform:rotate(-0.8deg); }
  .notes__note:nth-child(even) .notes__card{ transform:rotate(0.8deg); }
}

@media (prefers-reduced-motion: reduce){
  .notes__card,
  .notes__pin{ transition:none; }
  .notes__note:nth-child(1) .notes__card,
  .notes__note:nth-child(2) .notes__card,
  .notes__note:nth-child(3) .notes__card,
  .notes__note:nth-child(4) .notes__card,
  .notes__note:nth-child(5) .notes__card{ transform:none; }
  .notes__note:hover .notes__card,
  .notes__note:focus-within .notes__card{ transform:none; box-shadow:var(--shadow-soft); }
  .notes__note:hover .notes__pin,
  .notes__note:focus-within .notes__pin{ transform:translateX(-50%); }
}

/* ===================== */

.footer {
  position: relative;
  background: var(--terracotta-deep);
  color: var(--cream);
  overflow: hidden;
  isolation: isolate;
}

.footer__wrap {
  position: relative;
  padding-block: clamp(76px, 10vw, 148px);
}

/* paper grain */
.footer__grain {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: 0.5;
  background-image:
    radial-gradient(rgba(247,239,222,0.05) 1px, transparent 1px),
    radial-gradient(rgba(0,0,0,0.10) 1px, transparent 1px);
  background-size: 7px 7px, 11px 11px;
  background-position: 0 0, 3px 4px;
}
.footer::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--turmeric) 18%, var(--turmeric) 82%, transparent);
  opacity: 0.7;
  z-index: -1;
}

/* layout */
.footer__top {
  display: grid;
  grid-template-columns: 1.15fr 1fr 1fr;
  gap: clamp(36px, 5vw, 72px);
  align-items: start;
}

/* ---- brand ---- */
.footer__brand { position: relative; }

.footer__kicker {
  font-family: var(--font-hand);
  font-size: clamp(1.4rem, 2.4vw, 1.85rem);
  color: var(--gold-soft);
  margin: 0 0 0.1em;
  line-height: 1;
}
.footer__wordmark {
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: clamp(2.3rem, 5vw, 3.4rem);
  line-height: 1.02;
  letter-spacing: -0.01em;
  margin: 0 0 0.45em;
  color: var(--cream);
}
.footer__brandline {
  font-family: var(--font-sans);
  font-size: clamp(0.98rem, 1.4vw, 1.08rem);
  line-height: 1.6;
  color: rgba(247,239,222,0.82);
  max-width: 34ch;
  margin: 0 0 1.1em;
}
.footer__signoff {
  font-family: var(--font-hand);
  font-size: clamp(1.5rem, 2.8vw, 2rem);
  color: var(--turmeric);
  margin: 0 0 1.2em;
  transform: rotate(-2deg);
  transform-origin: left center;
}

.footer__dabba {
  width: clamp(150px, 16vw, 200px);
  height: auto;
  display: block;
  filter: drop-shadow(0 18px 26px rgba(0,0,0,0.32));
}
.footer__steam path {
  fill: none;
  stroke: rgba(247,239,222,0.6);
  stroke-width: 3;
  stroke-linecap: round;
  opacity: 0;
  animation: footer-steam 4s var(--ease-soft) infinite;
}
.footer__steam path:nth-child(2) { animation-delay: 0.7s; }
.footer__steam path:nth-child(3) { animation-delay: 1.4s; }
@keyframes footer-steam {
  0%   { opacity: 0; transform: translateY(8px) scaleY(0.7); }
  35%  { opacity: 0.85; }
  100% { opacity: 0; transform: translateY(-14px) scaleY(1.15); }
}

/* ---- columns ---- */
.footer__heading {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: clamp(1.25rem, 2vw, 1.55rem);
  line-height: 1.2;
  margin: 0 0 0.5em;
  color: var(--cream);
}
.footer__note {
  font-family: var(--font-sans);
  font-size: 0.96rem;
  line-height: 1.6;
  color: rgba(247,239,222,0.78);
  margin: 0 0 1.2em;
  max-width: 36ch;
}

/* ---- pincode form ---- */
.footer__pinform { margin: 0 0 1.1em; }
.footer__label {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--cream);
  margin: 0 0 0.5em;
}
.footer__pinrow {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.footer__input {
  flex: 1 1 140px;
  min-width: 0;
  font-family: var(--font-sans);
  font-size: 1.05rem;
  letter-spacing: 0.18em;
  color: var(--ink);
  background: var(--paper);
  border: 1.5px solid rgba(247,239,222,0.4);
  border-radius: 12px;
  padding: 0.7em 0.9em;
  transition: border-color 0.6s var(--ease-soft), box-shadow 0.6s var(--ease-soft);
}
.footer__input::placeholder {
  color: var(--ink-soft);
  letter-spacing: 0.06em;
  opacity: 0.7;
}
.footer__input:focus-visible {
  outline: none;
  border-color: var(--turmeric);
  box-shadow: 0 0 0 3px rgba(224,162,27,0.35);
}
.footer__input.is-invalid {
  border-color: var(--terracotta);
  box-shadow: 0 0 0 3px rgba(168,67,42,0.55);
}

.footer__btn.btn {
  flex: 0 0 auto;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--ink);
  background: var(--turmeric);
  border: none;
  border-radius: 12px;
  padding: 0.72em 1.3em;
  cursor: pointer;
  transition: transform 0.6s var(--ease-soft), background 0.6s var(--ease-soft), box-shadow 0.6s var(--ease-soft);
  box-shadow: var(--shadow-card);
}
.footer__btn.btn:hover { background: var(--turmeric-deep); transform: translateY(-2px); }
.footer__btn.btn:active { transform: translateY(0); }
.footer__btn.btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--cream), 0 0 0 5px var(--turmeric-deep);
}

.footer__result {
  font-family: var(--font-sans);
  font-size: 0.95rem;
  line-height: 1.55;
  margin: 0.9em 0 0;
  min-height: 0;
  color: rgba(247,239,222,0.9);
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.6s var(--ease-soft), transform 0.6s var(--ease-soft);
}
.footer__result.is-shown { opacity: 1; transform: none; }
.footer__result.is-yes { color: var(--cream); }
.footer__result.is-yes strong { color: var(--turmeric); }
.footer__result.is-soon strong { color: var(--turmeric); }
.footer__result.is-error { color: var(--cream); }
.footer__result.is-error strong { color: var(--gold-soft); }

.footer__servearea {
  font-family: var(--font-hand);
  font-size: 1.2rem;
  color: rgba(247,239,222,0.85);
  margin: 0;
}

/* ---- contact list ---- */
.footer__contactlist {
  list-style: none;
  margin: 0 0 1.4em;
  padding: 0;
  display: grid;
  gap: 1.05em;
}
.footer__contactitem {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  column-gap: 0.85em;
  align-items: center;
}
.footer__ico {
  grid-row: 1 / 3;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: rgba(247,239,222,0.1);
  border: 1px solid rgba(247,239,222,0.22);
  color: var(--turmeric);
}
.footer__ico svg { width: 19px; height: 19px; }
.footer__link {
  font-family: var(--font-sans);
  font-size: 1.04rem;
  font-weight: 600;
  color: var(--cream);
  text-decoration: none;
  align-self: end;
  transition: color 0.6s var(--ease-soft);
}
a.footer__link:hover { color: var(--turmeric); }
a.footer__link:focus-visible {
  outline: 2px solid var(--turmeric);
  outline-offset: 3px;
  border-radius: 3px;
}
.footer__link--static { cursor: default; }
.footer__sub {
  font-family: var(--font-sans);
  font-size: 0.8rem;
  color: rgba(247,239,222,0.82);
  align-self: start;
}

/* ---- social ---- */
.footer__social { display: flex; gap: 12px; }
.footer__sociallink {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  color: var(--cream);
  background: rgba(247,239,222,0.08);
  border: 1px solid rgba(247,239,222,0.24);
  transition: transform 0.6s var(--ease-soft), background 0.6s var(--ease-soft), color 0.6s var(--ease-soft);
}
.footer__sociallink svg { width: 22px; height: 22px; }
.footer__sociallink:hover {
  background: var(--turmeric);
  color: var(--ink);
  transform: translateY(-3px) rotate(-4deg);
}
.footer__sociallink:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--turmeric-deep), 0 0 0 5px var(--turmeric);
}

/* ---- bottom bar ---- */
.footer__bottom {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.6em 1.2em;
  margin-top: clamp(48px, 6vw, 80px);
  padding-top: 1.6em;
  border-top: 1px solid rgba(247,239,222,0.2);
}
.footer__copy {
  font-family: var(--font-sans);
  font-size: 0.86rem;
  letter-spacing: 0.02em;
  color: rgba(247,239,222,0.82);
  margin: 0;
}
.footer__handnote {
  font-family: var(--font-hand);
  font-size: 1.2rem;
  color: var(--gold-soft);
  margin: 0;
}

/* ---- responsive ---- */
@media (max-width: 900px) {
  .footer__top {
    grid-template-columns: 1fr 1fr;
  }
  .footer__brand { grid-column: 1 / -1; }
  .footer__dabba {
    position: absolute;
    top: 0;
    right: 0;
  }
}
@media (max-width: 560px) {
  .footer__top { grid-template-columns: 1fr; }
  .footer__dabba { position: static; margin-top: 1.2em; }
  .footer__pinrow { flex-direction: column; align-items: stretch; }
  .footer__btn.btn { width: 100%; }
  .footer__bottom { flex-direction: column; align-items: flex-start; }
}

/* ---- reduced motion ---- */
@media (prefers-reduced-motion: reduce) {
  .footer__steam path { animation: none; opacity: 0.55; }
  .footer__signoff { transform: none; }
  .footer__btn.btn,
  .footer__sociallink,
  .footer__result,
  .footer__input { transition: none; }
  .footer__btn.btn:hover,
  .footer__sociallink:hover { transform: none; }
}