/* ===== Self-hosted fonts (merged from fonts.css to cut a render-blocking request) ===== */
/* vietnamese */
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 300 900;
  font-display: swap;
  src: url(Assets/fonts/6NUT8FyLNQOQZAnv9ZwNpOQkzO1A.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 300 900;
  font-display: swap;
  src: url(Assets/fonts/6NUT8FyLNQOQZAnv9ZwNpOUkzO1A.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 300 900;
  font-display: swap;
  src: url(Assets/fonts/6NUT8FyLNQOQZAnv9ZwNpOskzA.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 300 900;
  font-display: swap;
  src: url(Assets/fonts/6NUV8FyLNQOQZAnv9ZwHlOk8yA.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 300 900;
  font-display: swap;
  src: url(Assets/fonts/6NUV8FyLNQOQZAnv9ZwGlOk8yA.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 300 900;
  font-display: swap;
  src: url(Assets/fonts/6NUV8FyLNQOQZAnv9ZwIlOk.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: italic;
  font-weight: 400 600;
  font-display: swap;
  src: url(Assets/fonts/ieVl2YZDLWuGJpnzaiwFXS9tYtpY19-7DRs5.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: italic;
  font-weight: 400 600;
  font-display: swap;
  src: url(Assets/fonts/ieVl2YZDLWuGJpnzaiwFXS9tYtpY1927DRs5.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: italic;
  font-weight: 400 600;
  font-display: swap;
  src: url(Assets/fonts/ieVl2YZDLWuGJpnzaiwFXS9tYtpY19y7DRs5.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: italic;
  font-weight: 400 600;
  font-display: swap;
  src: url(Assets/fonts/ieVl2YZDLWuGJpnzaiwFXS9tYtpY19K7DQ.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 300 800;
  font-display: swap;
  src: url(Assets/fonts/ieVn2YZDLWuGJpnzaiwFXS9tYtpQ59CjCQ.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 300 800;
  font-display: swap;
  src: url(Assets/fonts/ieVn2YZDLWuGJpnzaiwFXS9tYtpS59CjCQ.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 300 800;
  font-display: swap;
  src: url(Assets/fonts/ieVn2YZDLWuGJpnzaiwFXS9tYtpT59CjCQ.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 300 800;
  font-display: swap;
  src: url(Assets/fonts/ieVn2YZDLWuGJpnzaiwFXS9tYtpd59A.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* =====================================================================
   KULCHA EXPRESS — "Ink & Ember"
   Near-black base · deep oxblood surfaces · cream text · sparing gold
   No bright red in the UI; warmth comes from maroon depth.
   ===================================================================== */

:root{
  --ink:        #14100d;   /* base, dominant */
  --ink-2:      #1b1511;   /* raised cards on ink */
  --ink-3:      #221a14;   /* hover */
  --oxblood:    #3a0f12;   /* second surface */
  --oxblood-2:  #4a151a;   /* raised / hover oxblood */
  --oxblood-3:  #2c0c0e;   /* deep edge */

  --cream:      #eae0ce;   /* text + headlines */
  --cream-dim:  rgba(234,224,206,.70);
  --cream-faint:rgba(234,224,206,.42);

  --gold:       #c9a24e;   /* sparing accent */
  --gold-bright:#ddb968;
  --gold-faint: rgba(201,162,78,.22);

  --sage:       #a9bd7e;   /* open status */
  --clay:       #cf9a72;   /* closed status */

  --line:       rgba(234,224,206,.10);
  --line-gold:  rgba(201,162,78,.24);

  /* light "sweet counter" panel */
  --paper:      #e7dcc4;
  --paper-2:    #f1e8d6;
  --ink-text:   #1a130d;
  --ink-dim:    rgba(26,19,13,.7);
  --gold-dark:  #876427;
  --paper-line: rgba(40,18,10,.16);

  --maxw: 1200px;
  --pad: clamp(18px, 5vw, 76px);
  --radius: 12px;

  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans: "Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --ease: cubic-bezier(.2,.7,.2,1);
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0; background:var(--ink); color:var(--cream);
  font-family:var(--sans); font-weight:400; line-height:1.62;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ margin:0; line-height:1.04; font-weight:600; }
p{ margin:0; }
ul,ol{ margin:0; padding:0; list-style:none; }
::selection{ background:var(--gold); color:var(--ink); }

.skip{ position:absolute; left:-999px; top:0; z-index:200;
  background:var(--cream); color:var(--ink); padding:12px 18px; border-radius:0 0 10px 0; font-weight:700; }
.skip:focus{ left:0; }

/* ---------- shared type ---------- */
.eyebrow{
  display:flex; align-items:center; gap:.7em;
  font-size:.72rem; font-weight:700; letter-spacing:.3em; text-transform:uppercase;
  color:var(--gold); margin:0 0 1.1rem;
}
.eyebrow .rule{ width:42px; height:1px; background:var(--gold); display:inline-block; }
.eyebrow-light, .eyebrow-dark{ color:var(--gold); }

.section-title{
  font-family:var(--serif); font-weight:330;
  font-size:clamp(2.05rem, 5.3vw, 4rem); letter-spacing:-.012em; color:var(--cream);
  font-variation-settings:"opsz" 100, "SOFT" 20, "WONK" 0;
}
.section-title em{
  font-style:italic; color:var(--gold);
  font-variation-settings:"opsz" 120, "SOFT" 50, "WONK" 1;
}

.section-lede{ margin-top:1.1rem; max-width:48ch; color:var(--cream-dim); font-size:1.05rem; }

.link-arrow{
  display:inline-flex; align-items:center; gap:.4em; font-weight:700; color:var(--gold);
  border-bottom:1px solid transparent; padding-bottom:2px;
  transition:gap .3s var(--ease), border-color .3s var(--ease), color .3s var(--ease);
}
.link-arrow:hover{ gap:.8em; border-color:var(--gold); color:var(--gold-bright); }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  font-weight:700; font-size:.95rem; letter-spacing:.01em;
  padding:.9em 1.5em; border-radius:100px; border:1px solid transparent; cursor:pointer;
  transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.btn-sm{ padding:.62em 1.1em; font-size:.85rem; }
/* primary = cream fill, ink text (keeps gold sparing) */
.btn-red{ background:var(--cream); color:var(--ink); box-shadow:0 12px 30px -16px rgba(0,0,0,.9); }
.btn-red:hover{ background:var(--gold-bright); transform:translateY(-2px); }
.btn-line{ background:transparent; color:var(--cream); border-color:rgba(234,224,206,.34); }
.btn-line:hover{ border-color:var(--cream); transform:translateY(-2px); }
.btn .dot{ width:7px; height:7px; border-radius:50%; background:currentColor; opacity:.85; }

/* =====================================================================
   HEADER
   ===================================================================== */
.site-head{
  position:sticky; top:0; z-index:100;
  background:linear-gradient(to bottom, rgba(20,16,13,.96), rgba(20,16,13,.8) 72%, rgba(20,16,13,0));
  backdrop-filter:saturate(1.1) blur(9px);
}
.head-inner{ max-width:var(--maxw); margin:0 auto; padding:.8rem var(--pad);
  display:flex; align-items:center; gap:1.4rem; }
.brand{ display:flex; align-items:center; }
.brand img{ height:42px; width:auto; }
.brand-mark{ display:none; }
.nav{ display:flex; gap:1.5rem; margin-left:auto; }
.nav a{ position:relative; font-weight:600; font-size:.93rem; color:var(--cream-dim); padding:.2em 0;
  transition:color .25s var(--ease); }
.nav a::after{ content:""; position:absolute; left:0; bottom:-3px; height:1px; width:0; background:var(--gold);
  transition:width .3s var(--ease); }
.nav a:hover, .nav a.active{ color:var(--cream); }
.nav a:hover::after, .nav a.active::after{ width:100%; }
.head-cta{ margin-left:.3rem; }

.burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; padding:8px; margin-left:auto; cursor:pointer; }
.burger span{ width:26px; height:2px; background:var(--cream); transition:.3s var(--ease); }
.burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.mobile-nav{ display:none; flex-direction:column; padding:0 var(--pad); max-height:0; overflow:hidden;
  background:var(--ink-2); transition:max-height .4s var(--ease), padding .4s var(--ease); }
.mobile-nav a{ padding:1rem 0; border-bottom:1px solid var(--line); font-weight:600; font-size:1.08rem; }
.mobile-nav .m-cta{ color:var(--gold); border-bottom:0; }
.mobile-nav.open{ max-height:430px; padding:.4rem var(--pad) 1.4rem; }

/* =====================================================================
   TICKER — slim oxblood bar, cream text, gold marks
   ===================================================================== */
.ticker{ background:var(--oxblood); color:var(--cream); overflow:hidden; white-space:nowrap;
  border-top:1px solid var(--line-gold); border-bottom:1px solid var(--line-gold); }
.ticker-track{ display:inline-flex; align-items:center; padding:.5rem 0; animation:scroll-x 42s linear infinite;
  font-family:var(--serif); font-style:italic; font-weight:400; font-size:.98rem; }
.ticker-track i{ font-style:normal; color:var(--gold); font-size:.6rem; }
.ticker-track span{ padding:0 1.4rem; }
@keyframes scroll-x{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }
@media (prefers-reduced-motion: reduce){ .ticker-track{ animation:none; } }

/* =====================================================================
   HERO — single clean scrim, one accent word, slim trust line
   ===================================================================== */
.hero{ position:relative; isolation:isolate; min-height:min(90vh, 840px);
  display:flex; align-items:flex-end; padding:var(--pad); overflow:hidden; }
.hero-img, .hero-img img{ position:absolute; inset:0; width:100%; height:100%; }
.hero-img img{ object-fit:cover; object-position:center 44%; z-index:-3; }
.hero-scrim{ position:absolute; inset:0; z-index:-2;
  background:
    linear-gradient(72deg, rgba(15,10,7,.96) 0%, rgba(15,10,7,.74) 32%, rgba(15,10,7,.18) 60%, rgba(15,10,7,0) 82%),
    linear-gradient(to top, rgba(15,10,7,.86) 0%, rgba(15,10,7,.12) 52%, rgba(15,10,7,0) 72%);
}
.hero-grain{ position:absolute; inset:0; z-index:-1; pointer-events:none; opacity:.22; mix-blend-mode:overlay;
  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.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E"); }

.hero-body{ position:relative; max-width:720px; padding-bottom:2.4rem; }
.hero-title{
  font-family:var(--serif); font-weight:300;
  font-size:clamp(2.8rem, 8.2vw, 6.2rem); letter-spacing:-.02em; line-height:.96; color:var(--cream);
  text-shadow:0 4px 36px rgba(0,0,0,.5);
  font-variation-settings:"opsz" 144, "SOFT" 0, "WONK" 0;
}
.hero-title em{ font-style:italic; color:var(--gold);
  font-variation-settings:"opsz" 144, "SOFT" 60, "WONK" 1; }
.hero-sub{ margin-top:1.4rem; max-width:46ch; font-size:clamp(1rem,1.5vw,1.16rem); color:var(--cream);
  text-shadow:0 2px 16px rgba(0,0,0,.6); }
.hero-sub strong{ color:var(--gold); font-weight:600; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:.9rem; margin-top:2rem; }

.hero-trust{
  display:flex; align-items:center; gap:1rem; flex-wrap:wrap; margin-top:2.2rem;
  padding-top:1.3rem; border-top:1px solid rgba(234,224,206,.16);
}
.hero-trust img{ width:38px; height:38px; object-fit:contain; filter:drop-shadow(0 2px 6px rgba(0,0,0,.6)); }
/* The Prestige logo is a wide (5:1) wordmark — give it width so it stays legible instead of shrinking into a 38px box. */
.hero-trust img.award-wide{ width:96px; height:auto; }
.hero-trust .t-text{ font-size:.86rem; color:var(--cream); line-height:1.4; }
.hero-trust .t-text b{ color:var(--gold); font-weight:700; }
.hero-trust .t-sep{ width:1px; height:30px; background:rgba(234,224,206,.2); }

.hero-scroll{ position:absolute; left:50%; bottom:1rem; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:.35rem;
  font-size:.64rem; letter-spacing:.3em; text-transform:uppercase; color:var(--cream-faint); }
.hero-scroll svg{ animation:bob 1.9s var(--ease) infinite; }
@keyframes bob{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(6px);} }
@media (prefers-reduced-motion: reduce){ .hero-scroll svg{ animation:none; } }

/* =====================================================================
   NUMBERS — thali tray of compartments (now ink, gold hairlines)
   ===================================================================== */
.numbers{ padding:clamp(3.2rem,7vw,5.5rem) var(--pad); }
.thali-tray{
  max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:1.5fr 1fr 1fr; grid-auto-rows:minmax(146px,auto);
  gap:1px; background:var(--line-gold); border:1px solid var(--line-gold);
  border-radius:16px; overflow:hidden; box-shadow:0 40px 90px -60px #000;
}
.compartment{ background:var(--ink-2); padding:1.9rem 1.7rem;
  display:flex; flex-direction:column; justify-content:center; }
.compartment.c-lead{ grid-row:span 2; justify-content:flex-start; gap:.3rem; background:var(--oxblood); }
.numbers-h{ font-family:var(--serif); font-weight:330; font-size:clamp(1.7rem,3vw,2.5rem);
  letter-spacing:-.01em; color:var(--cream); }
.numbers-h em{ font-style:italic; color:var(--gold); }
.numbers-note{ margin-top:.8rem; color:var(--cream-dim); font-size:.94rem; max-width:32ch; }
.stat-num{ font-family:var(--serif); font-weight:380; font-variation-settings:"opsz" 144,"SOFT" 0;
  font-size:clamp(2.5rem,5vw,3.9rem); line-height:1; color:var(--cream); letter-spacing:-.02em; }
.stat-num i{ font-style:normal; color:var(--gold); font-size:.58em; vertical-align:.14em; }
.stat-label{ margin-top:.55rem; font-size:.78rem; letter-spacing:.06em; text-transform:uppercase;
  font-weight:600; color:var(--cream-dim); }

/* =====================================================================
   SIGNATURE FOOD
   ===================================================================== */
.signature{ padding:clamp(3.2rem,8vw,6rem) var(--pad); max-width:var(--maxw); margin:0 auto; }
.feature{ margin-top:2.8rem; display:grid; grid-template-columns:1.1fr .9fr; align-items:center;
  gap:clamp(1.5rem,4vw,4rem); }
.feature-media{ position:relative; }
.feature-media img{ width:100%; border-radius:var(--radius); aspect-ratio:3/2; object-fit:cover;
  box-shadow:0 50px 90px -50px #000, 0 0 0 1px var(--line); }
.feature-tag{ position:absolute; top:1rem; left:1rem; background:var(--ink); color:var(--gold);
  border:1px solid var(--line-gold); font-weight:700; font-size:.7rem; letter-spacing:.16em;
  text-transform:uppercase; padding:.5em .9em; border-radius:100px; }
.feature-index{ font-family:var(--serif); font-style:italic; font-size:1.05rem; color:var(--gold); letter-spacing:.08em; }
.feature-name{ font-family:var(--serif); font-weight:330; font-size:clamp(1.9rem,3.4vw,2.9rem);
  margin:.4rem 0 1rem; letter-spacing:-.01em; color:var(--cream);
  font-variation-settings:"opsz" 100,"SOFT" 30; }
.feature-text p{ color:var(--cream-dim); font-size:1.05rem; max-width:42ch; margin-bottom:1.5rem; }

.dish-grid{ margin-top:clamp(2.4rem,6vw,4rem); display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; border-radius:16px; overflow:hidden; background:var(--line-gold); border:1px solid var(--line-gold); }
.dish{ background:var(--ink-2); padding:0 0 1.7rem; position:relative; transition:background .3s var(--ease); }
.dish:hover{ background:var(--ink-3); }
.dish-media{ overflow:hidden; }
.dish-media img{ width:100%; aspect-ratio:3/2; object-fit:cover; transition:transform .6s var(--ease); }
.dish:hover .dish-media img{ transform:scale(1.05); }
.dish-index{ display:inline-block; margin:1.25rem 1.6rem .15rem; font-family:var(--serif); font-style:italic;
  color:var(--gold); font-size:.98rem; }
.dish-name{ font-family:var(--serif); font-weight:360; font-size:1.45rem; color:var(--cream);
  margin:0 1.6rem .55rem; letter-spacing:-.01em; }
.dish p{ color:var(--cream-dim); font-size:.94rem; margin:0 1.6rem; }

/* =====================================================================
   MITHAI — rebuilt on oxblood, asymmetric counter grid
   ===================================================================== */
.mithai{ position:relative; background:var(--paper); color:var(--ink-text);
  padding:clamp(3.2rem,8vw,6rem) 0; border-top:6px solid var(--oxblood); border-bottom:6px solid var(--oxblood); }
.mithai-grain{ position:absolute; inset:0; pointer-events:none; opacity:.5; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n2'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n2)' opacity='0.06'/%3E%3C/svg%3E"); }
.mithai-head{ position:relative; max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
  display:grid; grid-template-columns:1fr auto; align-items:end; gap:1.5rem; }
.mithai-head .eyebrow{ color:var(--gold-dark); }
.mithai-head .eyebrow .rule{ background:var(--gold-dark); }
.mithai-head .section-title{ color:var(--ink-text); }
.mithai-head .section-title em{ color:var(--oxblood); }
.mithai-head .section-lede{ margin-top:.6rem; color:var(--ink-dim); }
.mithai-count{ font-family:var(--serif); font-style:italic; color:var(--oxblood); font-size:.95rem; white-space:nowrap; }

.mithai-grid{
  position:relative; max-width:var(--maxw); margin:0 auto; padding:2.4rem var(--pad) 0;
  display:grid; grid-template-columns:1.5fr 1fr 1fr; grid-auto-rows:auto; gap:1.1rem;
}
.sweet{ position:relative; border-radius:14px; overflow:hidden; background:var(--paper-2);
  border:1px solid var(--paper-line);
  box-shadow:0 16px 36px -28px rgba(40,18,10,.6);
  transition:transform .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease); }
.sweet:hover{ transform:translateY(-5px); border-color:var(--oxblood); box-shadow:0 26px 46px -28px rgba(40,18,10,.55); }
.sweet img{ width:100%; height:100%; object-fit:cover; }
.sweet picture{ display:block; position:absolute; inset:0; }
.sweet-cap{ position:absolute; left:0; right:0; bottom:0; z-index:2;
  padding:1.5rem 1.2rem 1.1rem;
  background:linear-gradient(to top, rgba(20,8,9,.92) 18%, rgba(20,8,9,.55) 60%, transparent);
  display:flex; align-items:flex-end; justify-content:space-between; gap:.6rem; }
.sweet-cap h3{ font-family:var(--serif); font-weight:380; font-size:1.18rem; color:var(--cream); letter-spacing:-.01em; }
.sweet-cap .idx{ font-family:var(--serif); font-style:italic; font-size:.85rem; color:var(--gold); }
.sweet.is-feature{ grid-row:span 2; }
.sweet.is-feature .sweet-cap{ padding:2rem 1.6rem 1.4rem; }
.sweet.is-feature h3{ font-size:1.6rem; }
.sweet.is-feature .sweet-desc{ display:block; margin-top:.4rem; color:var(--cream-dim); font-size:.9rem; max-width:30ch; }
.sweet-desc{ display:none; }
/* Sweets 02–05: taller (4:3) so each tray is shown more fully, less crop than the old wide cells.
   The feature (01) spans these two auto rows, so it stays roughly square alongside them. */
.sweet:not(.is-feature){ aspect-ratio:5 / 4; }

.mithai-foot{ position:relative; max-width:var(--maxw); margin:1.8rem auto 0; padding:0 var(--pad);
  color:var(--ink-dim); font-size:.96rem; }
.mithai-foot a{ color:var(--oxblood); font-weight:700; border-bottom:1px solid rgba(58,15,18,.35); }
.mithai-foot a:hover{ border-color:var(--oxblood); }

/* =====================================================================
   STORY / TIMELINE
   ===================================================================== */
.story{ padding:clamp(3.2rem,8vw,6rem) var(--pad); max-width:var(--maxw); margin:0 auto; }
.story-head .section-lede{ max-width:52ch; }

/* photo treatment — tone bright snapshots into the palette */
.toned{ position:relative; overflow:hidden; border-radius:var(--radius);
  border:1px solid var(--line-gold); background:var(--oxblood-3); }
.toned picture{ position:absolute; inset:0; z-index:0; display:block; }
.toned img{ width:100%; height:100%; object-fit:cover; display:block;
  filter:saturate(.7) contrast(1.07) brightness(.97); }
.toned::after{ content:""; position:absolute; inset:0; pointer-events:none; z-index:1;
  background:
    linear-gradient(178deg, rgba(58,15,18,.34) 0%, rgba(20,16,13,.20) 38%, rgba(20,16,13,.66) 100%);
  mix-blend-mode:multiply; }
.toned::before{ content:""; position:absolute; inset:0; pointer-events:none; z-index:1; opacity:.5;
  mix-blend-mode:soft-light;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='ng'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23ng)' opacity='0.5'/%3E%3C/svg%3E"); }

.story-layout{ margin-top:2.8rem; display:grid; grid-template-columns:.82fr 1.18fr; gap:clamp(2rem,5vw,4rem); align-items:start; }

.story-photo{ position:sticky; top:88px; aspect-ratio:4/5; box-shadow:0 50px 90px -55px #000; }
.story-photo figcaption{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:1.3rem 1.4rem;
  font-family:var(--serif); font-style:italic; color:var(--cream); font-size:.96rem; }
.story-photo figcaption span{ display:block; font-style:normal; font-weight:800; letter-spacing:.18em;
  font-size:.7rem; color:var(--gold); margin-bottom:.35rem; }

/* editorial timeline */
.timeline{ display:flex; flex-direction:column; }
.timeline li{ display:grid; grid-template-columns:78px 1fr; gap:1.5rem; align-items:start;
  padding:1.5rem 0; border-top:1px solid var(--line); }
.timeline li:first-child{ border-top:0; padding-top:.3rem; }
.tl-yr{ font-family:var(--serif); font-weight:430; font-style:italic; font-size:1.85rem; color:var(--gold);
  line-height:1; padding-top:.1rem; }
.tl-body{ position:relative; border-left:1px solid var(--line-gold); padding-left:1.7rem; }
.tl-body::before{ content:""; position:absolute; left:-5px; top:.42rem; width:9px; height:9px; border-radius:50%;
  background:var(--ink); border:2px solid var(--gold); }
.tl-body h3{ font-family:var(--serif); font-weight:400; font-size:1.32rem; color:var(--cream); letter-spacing:-.005em; }
.tl-body p{ color:var(--cream-dim); font-size:.99rem; margin-top:.35rem; max-width:44ch; }
.timeline li.is-mark .tl-yr{ color:var(--gold-bright); }
.timeline li.is-mark .tl-body::before{ background:var(--gold); box-shadow:0 0 0 4px rgba(201,162,78,.16); }
.timeline li.is-mark .tl-body h3{ color:var(--gold-bright); }

/* community impact band */
.impact-band{ margin-top:clamp(2.6rem,6vw,4rem); display:grid; grid-template-columns:.7fr 1.3fr;
  gap:clamp(1.4rem,4vw,3rem); align-items:center;
  background:var(--oxblood); border:1px solid var(--line-gold); border-radius:16px;
  padding:clamp(1.3rem,3vw,2.2rem); }
.impact-photo{ aspect-ratio:3/4; }
.impact-text .eyebrow{ margin-bottom:.9rem; }
.impact-text h3{ font-family:var(--serif); font-weight:380; font-size:clamp(1.4rem,2.4vw,1.9rem); color:var(--cream); letter-spacing:-.01em; }
.impact-text p{ color:var(--cream-dim); font-size:.98rem; margin-top:.7rem; max-width:52ch; }
.impact-foot{ display:flex; align-items:center; gap:1.8rem; flex-wrap:wrap;
  margin-top:1.3rem; padding-top:1.2rem; border-top:1px solid var(--line); }
.impact-callout b{ font-family:var(--serif); font-weight:430; font-size:2.1rem; color:var(--gold); display:block; line-height:1; }
.impact-callout span{ font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; color:var(--cream-dim); }
.awards-row{ display:flex; gap:.9rem; margin-left:auto; }
.awards-row img{ width:46px; height:46px; object-fit:contain; }

/* =====================================================================
   LOCATIONS
   ===================================================================== */
.locations{ padding:clamp(3.2rem,8vw,6rem) var(--pad); max-width:var(--maxw); margin:0 auto; }
.loc-filters{ display:flex; flex-wrap:wrap; gap:.6rem; margin:1.9rem 0 2.2rem; }
.chip{ font-weight:600; font-size:.88rem; padding:.58em 1.15em; border-radius:100px; cursor:pointer;
  background:transparent; color:var(--cream-dim); border:1px solid var(--line); transition:all .25s var(--ease); }
.chip:hover{ color:var(--cream); border-color:rgba(234,224,206,.35); }
.chip.is-active{ background:var(--gold); color:var(--ink); border-color:var(--gold); font-weight:700; }

.loc-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(min(318px,100%),1fr)); gap:1.2rem; }
.loc-card{ position:relative; background:var(--ink-2); border:1px solid var(--line); border-radius:16px;
  padding:1.5rem 1.5rem 1.4rem; display:flex; flex-direction:column; gap:.85rem;
  transition:transform .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease); }
.loc-card:hover{ transform:translateY(-4px); border-color:var(--line-gold); box-shadow:0 30px 60px -45px #000; }
.loc-top{ display:flex; justify-content:space-between; align-items:flex-start; gap:1rem; }
.loc-name{ font-family:var(--serif); font-weight:380; font-size:1.45rem; color:var(--cream); letter-spacing:-.01em; }
.loc-area{ font-size:.74rem; letter-spacing:.13em; text-transform:uppercase; color:var(--gold); font-weight:700; margin-top:.25rem; }

.status{ flex:0 0 auto; display:inline-flex; align-items:center; gap:.45em; font-size:.72rem; font-weight:700;
  letter-spacing:.04em; padding:.4em .72em; border-radius:100px; white-space:nowrap; }
.status .ind{ width:7px; height:7px; border-radius:50%; }
.status.open{ background:rgba(169,189,126,.14); color:var(--sage); }
.status.open .ind{ background:var(--sage); box-shadow:0 0 0 0 rgba(169,189,126,.6); animation:pulse-g 2.2s infinite; }
.status.closed{ background:rgba(207,154,114,.12); color:var(--clay); }
.status.closed .ind{ background:var(--clay); }
@keyframes pulse-g{ 0%{ box-shadow:0 0 0 0 rgba(169,189,126,.5);} 70%{ box-shadow:0 0 0 6px rgba(169,189,126,0);} 100%{ box-shadow:0 0 0 0 rgba(169,189,126,0);} }

.loc-addr{ color:var(--cream-dim); font-size:.93rem; line-height:1.45; }
.loc-badges{ display:flex; flex-wrap:wrap; gap:.4rem; }
.badge{ font-size:.71rem; font-weight:700; letter-spacing:.03em; padding:.34em .68em; border-radius:6px;
  border:1px solid var(--line-gold); color:var(--cream-dim); }
.badge.veg{ color:var(--sage); border-color:rgba(169,189,126,.45); }
.badge.bar{ color:var(--gold); border-color:var(--line-gold); }
.badge.takeaway{ color:var(--clay); border-color:rgba(207,154,114,.4); }

.loc-hours{ border-top:1px dashed var(--line); padding-top:.85rem; margin-top:.15rem;
  display:flex; align-items:baseline; gap:.5rem; flex-wrap:wrap; }
.loc-hours .today-label{ font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--cream-faint); font-weight:700; }
.loc-hours .today-time{ font-family:var(--serif); font-size:1.02rem; color:var(--cream); font-weight:500; }
.loc-actions{ display:flex; gap:.65rem; margin-top:.25rem; flex-wrap:wrap; }
.loc-actions a{ flex:1 1 auto; text-align:center; justify-content:center; display:inline-flex; align-items:center; gap:.4em;
  font-weight:700; font-size:.85rem; padding:.68em 1em; border-radius:9px; transition:all .25s var(--ease); }
.loc-actions .a-call{ background:var(--cream); color:var(--ink); }
.loc-actions .a-call:hover{ background:var(--gold-bright); }
.loc-actions .a-dir{ border:1px solid var(--line); color:var(--cream); }
.loc-actions .a-dir:hover{ border-color:var(--gold); color:var(--gold); }
.loc-empty{ margin-top:2rem; color:var(--cream-dim); }
.loc-empty button{ background:none; border:0; cursor:pointer; }

/* =====================================================================
   CATERING
   ===================================================================== */
.catering{ position:relative; isolation:isolate; padding:clamp(3.2rem,9vw,6.5rem) var(--pad);
  background:linear-gradient(160deg, var(--oxblood-2), var(--oxblood) 50%, var(--oxblood-3)); }
.catering::before{ content:""; position:absolute; inset:0; z-index:-1; opacity:.35; mix-blend-mode:soft-light;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='170' height='170'%3E%3Cfilter id='n3'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n3)' opacity='0.5'/%3E%3C/svg%3E"); }
.catering-grid{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1.15fr .85fr;
  gap:clamp(1.8rem,4vw,3.5rem); align-items:center; }
.catering-h{ font-family:var(--serif); font-weight:330; font-size:clamp(2.1rem,5vw,3.8rem); color:var(--cream);
  letter-spacing:-.015em; line-height:1; }
.catering-h em{ font-style:italic; color:var(--gold); font-variation-settings:"opsz" 120,"SOFT" 50,"WONK" 1;
  margin-right:.07em; }
.catering-sub{ margin-top:1.2rem; max-width:46ch; color:var(--cream-dim); font-size:1.06rem; }
.catering-tags{ display:flex; flex-wrap:wrap; gap:.6rem; margin-top:1.7rem; }
.catering-tags li{ font-size:.82rem; font-weight:600; color:var(--cream);
  border:1px solid var(--line-gold); padding:.42em .95em; border-radius:100px; }

.catering-card{ background:rgba(18,9,8,.5); border:1px solid var(--line-gold); border-radius:18px;
  padding:clamp(1.5rem,3vw,2.1rem); box-shadow:0 40px 80px -50px #000; }
.catering-card h3{ font-family:var(--serif); font-weight:380; font-size:1.5rem; color:var(--cream); }
.catering-card > p{ color:var(--cream-dim); font-size:.96rem; margin:.55rem 0 1.5rem; }
.catering-card .btn-red{ width:100%; justify-content:center; }
.catering-or{ display:flex; align-items:center; gap:1rem; margin:1.1rem 0; color:var(--cream-faint);
  font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; }
.catering-or::before, .catering-or::after{ content:""; flex:1; height:1px; background:var(--line); }
.catering-phone{ display:flex; flex-direction:column; gap:.25rem; text-align:center;
  padding:.95rem 1.1rem; border:1px solid var(--line); border-radius:11px; transition:border-color .25s var(--ease); }
.catering-phone:hover{ border-color:var(--gold); }
.catering-phone span{ font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--cream-faint); }
.catering-phone b{ font-family:var(--serif); font-weight:500; font-size:1.45rem; color:var(--gold); }

/* =====================================================================
   FOOTER
   ===================================================================== */
.site-foot{ background:var(--ink); padding:clamp(3rem,7vw,4.5rem) var(--pad) 2rem; border-top:1px solid var(--line); }
.foot-top{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:2.4rem; }
.foot-brand img{ height:86px; width:auto; }
.foot-tag{ margin-top:1rem; max-width:34ch; color:var(--cream-dim); font-family:var(--serif); font-style:italic; font-size:1.02rem; }
.socials{ display:flex; flex-wrap:wrap; gap:1.1rem; margin-top:1.3rem; }
.socials a{ font-weight:600; font-size:.9rem; color:var(--cream-dim); border-bottom:1px solid transparent; padding-bottom:2px; transition:.25s var(--ease); }
.socials a:hover{ color:var(--gold); border-color:var(--gold); }
.foot-col h4{ font-size:.76rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:1rem; font-weight:800; }
.foot-col a{ display:block; color:var(--cream-dim); padding:.33rem 0; font-size:.93rem; transition:color .2s var(--ease); }
.foot-col a:hover{ color:var(--cream); }
.foot-note{ margin-top:.7rem; color:var(--cream-faint); font-size:.84rem; }
.foot-bottom{ max-width:var(--maxw); margin:2.4rem auto 0; padding-top:1.4rem; border-top:1px solid var(--line);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; color:var(--cream-faint); font-size:.84rem; }
.foot-built{ font-family:var(--serif); font-style:italic; color:var(--cream-dim); }

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

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
/* keep anchored headings clear of the sticky header on jump-to-section */
#numbers, #signature, #mithai, #story, #locations, #catering{ scroll-margin-top:74px; }

@media (max-width: 980px){
  .nav{ display:none; }
  .head-cta{ margin-left:auto; }       /* Order button stays in the bar, pushed right */
  .burger{ display:flex; margin-left:.4rem; }
  .mobile-nav{ display:flex; }
  .mobile-nav .m-cta{ display:none; }  /* duplicate — Order button already in the bar */
  .feature{ grid-template-columns:1fr; }
  .feature-media{ order:-1; }
  .story-layout{ grid-template-columns:1fr; }
  .story-photo{ position:static; aspect-ratio:16/10; }
  .story-photo figcaption{ font-size:1rem; }
  .impact-band{ grid-template-columns:1fr; }
  .impact-photo{ aspect-ratio:16/10; max-height:340px; }
  .catering-grid{ grid-template-columns:1fr; }
  .mithai-grid{ grid-template-columns:1fr 1fr; }
  /* Feature no longer spans 2 rows here, so give it its own ratio (wide for the platter). */
  .sweet.is-feature{ grid-column:1 / -1; grid-row:auto; aspect-ratio:3 / 2; }
  .sweet.is-feature .sweet-desc{ display:none; }
  .foot-top{ grid-template-columns:1fr 1fr; }
  .foot-brand{ grid-column:1 / -1; }
}
@media (max-width: 760px){
  .thali-tray{ grid-template-columns:1fr 1fr; }
  .compartment.c-lead{ grid-column:1 / -1; grid-row:auto; }
  .dish-grid{ grid-template-columns:1fr; }
  .impact-foot{ gap:1.2rem; }
  .awards-row{ margin-left:0; }
  .mithai-head{ grid-template-columns:1fr; }
  .mithai-count{ display:none; }
  .foot-top{ grid-template-columns:1fr; }
  .foot-bottom{ justify-content:flex-start; }
  /* hero: tighter on phones, give the headline room to breathe */
  .hero{ min-height:min(86vh,760px); }
  .hero-body{ padding-bottom:1.6rem; }
  .hero-sub{ margin-top:1.1rem; }
  .hero-actions{ margin-top:1.6rem; }
  .hero-trust{ margin-top:1.7rem; padding-top:1.1rem; }
  /* On phones the hero content sits flush at the bottom and the trust row wraps,
     so the absolutely-positioned bobbing scroll cue overlaps the awards/reviews
     snippets. The cue is a desktop affordance only — hide it here to avoid the clash. */
  .hero-scroll{ display:none; }
}

/* phones: stack hero CTAs, ease tap targets, shrink brand mark */
@media (max-width: 560px){
  .head-inner{ gap:1rem; }
  .brand img{ height:36px; }
  .burger{ padding:10px; }
  .hero-actions{ width:100%; gap:.7rem; }
  .hero-actions .btn{ flex:1 1 46%; justify-content:center; }
  .hero-trust .t-sep{ display:none; }
  .hero-trust{ gap:.6rem 1rem; }
  .mithai-grid{ grid-template-columns:1fr 1fr; }
  /* On phones every sweet image container is square. */
  .sweet:not(.is-feature){ aspect-ratio:1 / 1; }
  .sweet.is-feature{ aspect-ratio:1 / 1; }
  .impact-callout b{ font-size:1.8rem; }
  .catering-card .catering-phone b{ font-size:1.28rem; }
  .mobile-nav.open{ max-height:480px; }
}

@media (max-width: 480px){
  /* space is tight with the Order button in the bar — switch to the logomark */
  .brand-word{ display:none; }
  .brand-mark{ display:block; height:40px; }
  .thali-tray{ grid-template-columns:1fr; }
  .mithai-grid{ grid-template-columns:1fr; }
  .loc-actions{ gap:.5rem; }
  .loc-card{ padding:1.3rem 1.25rem 1.2rem; }
}

/* very small phones (≤360px): single-column CTAs, trim chrome */
@media (max-width: 380px){
  .brand img{ height:32px; }
  .hero-actions{ flex-direction:column; }
  .hero-actions .btn{ flex:1 1 auto; width:100%; }
  .loc-actions{ flex-direction:column; }
  .loc-actions a{ width:100%; }
  .chip{ font-size:.82rem; padding:.52em 1em; }
}

/* =====================================================================
   CHOREOGRAPHY — progressive enhancement (Lenis + GSAP)
   Hidden states apply ONLY when JS is on and motion is allowed, so the
   page is fully visible with JS disabled; script.js reveals everything
   if the motion libraries fail to load.
   ===================================================================== */

/* hero headline lines (simple, robust fade — no overflow mask) */
.hero-title .line{ display:block; }
.hero-title .line-i{ display:block; }

/* served-thali compartments */
.compartment{ position:relative; overflow:hidden; }
.comp-inner{ position:relative; z-index:2; display:flex; flex-direction:column; }
.c-lead .comp-inner{ gap:.35rem; }
.comp-fill{ position:absolute; inset:0; z-index:3; pointer-events:none;
  background:linear-gradient(180deg, var(--gold-bright), var(--gold));
  transform:scaleY(0); transform-origin:bottom; opacity:0; }

/* FOUC-safe initial hidden states */
html.js:not(.reduce) .hero-title .line-i{ opacity:0; }
html.js:not(.reduce) .hero .eyebrow,
html.js:not(.reduce) .hero-sub,
html.js:not(.reduce) .hero-actions,
html.js:not(.reduce) .hero-trust,
html.js:not(.reduce) .hero-scroll{ opacity:0; }
html.js:not(.reduce) .comp-inner{ opacity:0; }
html.js:not(.reduce) .comp-fill{ transform:scaleY(1); opacity:1; }

/* let GSAP own .reveal motion (avoid CSS-transition double-easing) */
html.gsap .reveal{ transition:none; }

/* micro-typography */
.hero-title, .section-title, .numbers-h, .feature-name, .catering-h,
.impact-text h3, .tl-body h3, .loc-name, .feature-text p, .section-lede{ text-wrap:balance; }
p{ text-wrap:pretty; }

/* failsafe reveal — if motion libs never boot, force everything visible */
html.no-motion .hero-title .line-i{ opacity:1; }
html.no-motion .hero .eyebrow,
html.no-motion .hero-sub,
html.no-motion .hero-actions,
html.no-motion .hero-trust,
html.no-motion .hero-scroll{ opacity:1; }
html.no-motion .comp-inner{ opacity:1; }
html.no-motion .comp-fill{ opacity:0; transform:scaleY(0); }
