/* =================================================================
   HONGYEE — shared styles
   ================================================================= */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@500;600;700;800;900&family=Poppins:wght@400;500;600;700&display=swap');

@font-face{
  font-family:'Worchester';
  font-style:italic;
  font-weight:600;
  font-display:swap;
  src:url('fonts/worchester.woff2') format('woff2');
}

:root{
  --green:#004538;
  --green-2:#1f4e3d;
  --coral:#ff828a;
  --coral-soft:#ff9ea1;
  --coral-deep:#f06f78;
  --cream:#fff8f4;
  --ink:#143028;
  --white:#fff;

  --f-display:'Montserrat',system-ui,sans-serif;
  --f-body:'Poppins',system-ui,sans-serif;
  --f-script:'Worchester','Times New Roman',serif;

  --pat-green:url('img/pattern-green.svg');
  --pat-coral:url('img/pattern-coral.svg');

  --maxw:1180px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--f-body);color:var(--ink);line-height:1.6;
  -webkit-font-smoothing:antialiased;background:#fff;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font-family:inherit;border:0;background:none;cursor:pointer}
ul{list-style:none}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--f-display);font-weight:700;letter-spacing:.02em;
  border-radius:999px;padding:.85em 2.4em;font-size:clamp(15px,4vw,18px);
  color:#fff;cursor:pointer;transition:background-color .2s ease,transform .2s ease;min-height:48px;
}
.btn--green{background:var(--green)}
.btn--green:hover{background:#00372c}
.btn--coral{background:var(--coral)}
.btn--coral:hover{background:var(--coral-deep)}

/* ---------- ornamental notched frame (SVG 9-slice border) ---------- */
.frame{
  position:relative;border-radius:0;
  border:30px solid transparent;
  border-image:url('img/frame-white.svg') 30 / 30px / 0 stretch;
}
.frame--coral{border-image-source:url('img/frame-coral.svg')}

/* =================================================================
   HEADER
   ================================================================= */
.header{
  position:sticky;top:0;z-index:50;background:#fff;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px;box-shadow:0 1px 0 rgba(0,69,56,.08);
}
.logo{display:flex;align-items:center}
.logo img{height:46px;width:auto}
.nav{display:none}
.nav a{font-family:var(--f-display);font-weight:600;color:var(--green);font-size:16px;padding:8px 2px;position:relative;transition:color .2s}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:2px;height:2px;background:var(--coral);transition:right .25s ease}
.nav a:hover,.nav a[aria-current="page"]{color:var(--coral)}
.nav a:hover::after,.nav a[aria-current="page"]::after{right:0}

.burger{display:flex;flex-direction:column;gap:6px;width:44px;height:44px;align-items:center;justify-content:center}
.burger span{display:block;width:30px;height:4px;border-radius:4px;background:var(--coral);transition:transform .3s ease,opacity .2s ease}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(10px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-10px) rotate(-45deg)}

.drawer{
  position:fixed;inset:0 0 0 auto;width:min(80vw,320px);background:var(--coral);
  transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);
  z-index:60;padding:28px 30px;display:flex;flex-direction:column;gap:6px;box-shadow:-12px 0 40px rgba(0,0,0,.18);
}
.drawer.open{transform:translateX(0)}
.drawer .close{align-self:flex-end;color:#fff;font-size:34px;line-height:1;width:44px;height:44px}
.drawer a{font-family:var(--f-display);font-weight:700;color:#fff;font-size:22px;padding:14px 4px;border-bottom:1px solid rgba(255,255,255,.25)}
.scrim{position:fixed;inset:0;background:rgba(0,0,0,.4);opacity:0;visibility:hidden;transition:.3s;z-index:55}
.scrim.open{opacity:1;visibility:visible}

/* =================================================================
   HERO
   ================================================================= */
.hero{padding:0;background:#fff}
.hero__inner{
  position:relative;border-radius:0;overflow:hidden;
  background-image:url('img/hero.jpg');background-size:cover;background-position:center;
  min-height:70vh;display:flex;align-items:flex-start;justify-content:center;
}
.hero__inner::before{content:"";position:absolute;inset:14px;z-index:2;pointer-events:none;border:30px solid transparent;border-image:url('img/frame-coral.svg') 30 / 30px stretch}
.hero__inner::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(20,30,25,.30) 0%,rgba(20,30,25,0) 45%)}
.hero h1{
  position:relative;z-index:3;margin-top:64px;padding:0 50px;text-align:center;
  font-family:var(--f-script);font-style:italic;font-weight:600;color:#fff;
  font-size:clamp(32px,9vw,58px);line-height:1.12;text-shadow:0 2px 18px rgba(0,0,0,.4);
}

/* =================================================================
   WELCOME
   ================================================================= */
.welcome{background-color:var(--coral-soft);background-image:var(--pat-coral);background-size:230px;padding:34px 14px 40px;text-align:center}
.welcome__box{position:relative;max-width:620px;margin:0 auto;padding:34px 26px 38px}
.welcome__icon{width:64px;margin:0 auto 14px}
.welcome .kicker{font-family:var(--f-script);font-style:italic;color:var(--green);font-size:clamp(26px,7vw,40px);line-height:1;margin-bottom:4px}
.welcome h2{font-family:var(--f-display);font-weight:800;color:var(--green);font-size:clamp(34px,11.5vw,86px);letter-spacing:.02em;line-height:1;margin-bottom:18px}
.welcome p{color:var(--green);font-weight:500;font-size:clamp(15px,4.2vw,18px);max-width:30em;margin:0 auto 26px}

/* =================================================================
   LIFESTYLE IMAGE BANDS
   ================================================================= */
.band{height:72vw;max-height:520px;background-size:cover;background-position:center}
.band--apron{background-image:url('img/apron.jpg');height:60vh;max-height:none;background-position:center 62%}
.band--spread{background-image:url('img/spread.jpg')}

/* =================================================================
   OUR MENU
   ================================================================= */
.menu{background-color:var(--green);background-image:var(--pat-green);background-size:200px;padding:14px}
.menu__box{position:relative;padding:34px 26px 38px;text-align:center}
.menu h2{font-family:var(--f-display);font-weight:800;color:#fff;font-size:clamp(30px,8.5vw,84px);letter-spacing:.04em;margin-bottom:26px;white-space:nowrap}

/* =================================================================
   CATEGORY GRID
   ================================================================= */
.cats{display:grid;grid-template-columns:1fr 1fr;gap:0}
.cat{position:relative;aspect-ratio:2/3;overflow:hidden;background-size:cover;background-position:center;display:flex;align-items:flex-end;justify-content:center;padding:22px;cursor:pointer}
.cat::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 40%,rgba(0,0,0,.22));transition:background .25s}
.cat:hover::after{background:linear-gradient(180deg,rgba(0,0,0,0) 20%,rgba(0,0,0,.34))}
.cat .pill{position:relative;z-index:2;font-family:var(--f-display);font-weight:700;color:#fff;font-size:clamp(15px,4.4vw,20px);padding:.6em 1.8em;border-radius:999px;background:var(--coral);transition:transform .25s ease;letter-spacing:.01em;white-space:nowrap}
.cat .pill--green{background:var(--green)}
.cat:hover .pill{transform:translateY(-4px)}
.cat--kuihchang{background-image:url('img/kuihchang.jpg')}
.cat--partypack{background-image:url('img/partypacks.jpg')}
.cat--beverage{background-image:url('img/beverages.jpg')}

/* Promotion tile = coral-washed high-tea photo + HIGHTEA SET heading */
.cat--promo{
  background-image:linear-gradient(rgba(255,120,128,.68),rgba(255,120,128,.68)),url('img/hightea.jpg');
  background-size:cover,cover;background-position:center;
}
.cat--promo::after{display:none}
.cat__heading{
  position:absolute;top:26px;left:26px;z-index:2;
  font-family:var(--f-display);font-weight:800;color:#fff;line-height:1.04;
  font-size:clamp(26px,7vw,40px);letter-spacing:.02em;text-shadow:0 2px 10px rgba(0,0,0,.18);
}

/* =================================================================
   LOCATIONS
   ================================================================= */
.loc{background-color:var(--coral-soft);background-image:var(--pat-coral);background-size:230px;padding:14px}
.loc__box{position:relative;padding:34px 26px 38px;text-align:center}
.loc h2{font-family:var(--f-display);font-weight:800;color:var(--green);font-size:clamp(30px,8.5vw,72px);letter-spacing:.03em;margin-bottom:22px;white-space:nowrap}

/* =================================================================
   FOOTER
   ================================================================= */
.footer{background:var(--coral);color:#fff;padding:54px 30px 46px}
.footer__logo img{height:62px;width:auto;margin-bottom:26px}
.footer__nav{display:flex;flex-direction:column;gap:10px;margin-bottom:34px}
.footer__nav a{font-family:var(--f-display);font-weight:700;color:#fff;font-size:21px;width:max-content;transition:opacity .2s}
.footer__nav a:hover{opacity:.78}
.social{display:flex;gap:22px;margin-bottom:40px}
.social a{width:44px;height:44px;display:flex;align-items:center;justify-content:center;transition:transform .2s}
.social a:hover{transform:translateY(-3px)}
.social svg{width:30px;height:30px;fill:#fff}
.copy{font-family:var(--f-display);font-weight:600;text-align:center;font-size:18px;line-height:1.5}

/* =================================================================
   DESKTOP
   ================================================================= */
@media(min-width:768px){
  .band{height:46vw;max-height:560px}
  .cats{grid-template-columns:repeat(4,1fr)}
  .welcome__box,.menu__box,.loc__box{max-width:var(--maxw);margin:0 auto}
}
@media(min-width:1024px){
  .header{padding:18px clamp(28px,5vw,64px)}
  .burger{display:none}
  .nav{display:flex;gap:clamp(20px,2.4vw,40px)}
  .logo img{height:54px}

  .hero{padding:0}
  .hero__inner{min-height:0;height:clamp(440px,56vw,680px);max-height:none;align-items:center;border-radius:0}
  .hero h1{margin-top:0}

  .welcome{padding:90px 20px 96px}
  .menu__box{padding:110px 24px}

  .band{height:40vw;max-height:620px}
  .band--apron{height:78vh;max-height:none}

  .cat{aspect-ratio:4/5}

  .footer{padding:70px clamp(40px,8vw,120px) 56px}
  .footer__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;align-items:start}
  .footer__nav{margin-bottom:0}
  .footer__logo img{height:78px}
  .copy{margin-top:48px}
}

@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

/* =================================================================
   BRAND STORY PAGE
   ================================================================= */
.bs-title{font-family:var(--f-display);font-weight:800;color:var(--green);font-size:clamp(26px,7.2vw,60px);letter-spacing:.04em;margin-bottom:22px}
/* founder portrait — quatrefoil shape, no border (baked PNG) */
.bs-founder{display:block;width:clamp(210px,60vw,330px);height:auto;margin:0 auto 26px;
  filter:drop-shadow(0 4px 14px rgba(0,0,0,.12))}
.bs-intro p{color:var(--green);font-weight:500;font-size:clamp(15px,4.2vw,18px);max-width:34em;margin:0 auto 14px}

.band--store{background-image:url('img/storefront.jpg');background-position:center 42%}
.band--counter{background-image:url('img/staff-counter.jpg');background-position:center 18%}

.songket{height:clamp(24px,6.5vw,40px);background-color:#fff;background-image:url('img/songket-border.png');background-repeat:repeat-x;background-position:center;background-size:auto 100%}
.songket--flip{transform:rotate(180deg)}
.songket--overlay{position:absolute;bottom:0;left:0;right:0;background-color:transparent;z-index:2}

.bs-next{position:relative;background:#fff}
.bs-next__inner{text-align:center;padding:50px 22px 44px}
.bs-next__logo{height:52px;width:auto;margin:0 auto 22px;display:block}
.bs-next p{color:var(--green);font-weight:600;font-size:clamp(16px,4.6vw,20px);max-width:32em;margin:0 auto 14px}
.bs-next__sub{font-weight:500;opacity:.88}
.bs-next__figure{display:block;width:clamp(300px,90vw,440px);height:auto;margin:18px auto 0}

.hero--heritage .hero__inner{background-image:url('img/heritage.jpg')}

/* =================================================================
   MENU PAGE
   ================================================================= */
/* hero — green ground (layer 1) + coral frame (layer 2)
   wrapping the image (upper) and intro text (lower) (layer 3). No deco. */
.hero--menu{background-color:var(--green);background-image:var(--pat-green);background-size:210px;padding:14px}
/* the framed box: food image fills the upper region (bleeds to the frame),
   green text panel fills the lower region. One coral frame overlays both. */
.hero--menu .hero__inner{
  position:relative;min-height:0;display:flex;flex-direction:column;align-items:stretch;overflow:hidden;
  background-color:var(--green);background-image:var(--pat-green);background-size:210px;
}
.hero--menu .hero__inner::before{
  content:"";position:absolute;inset:0;z-index:3;pointer-events:none;display:block;
  border:15px solid transparent;border-image:url('img/frame-hero.svg') 30 / 15px stretch;
}
.hero--menu .hero__inner::after{display:none}
.hero--menu .hero__img{
  position:relative;aspect-ratio:1/1;
  background:url('img/menu-hero.jpg') center/cover;
  display:flex;align-items:flex-start;justify-content:center;
  --c:11px;
  -webkit-mask:
    radial-gradient(circle var(--c) at top left,#0000 calc(var(--c) - .6px),#000 var(--c)) top left/51% 51% no-repeat,
    radial-gradient(circle var(--c) at top right,#0000 calc(var(--c) - .6px),#000 var(--c)) top right/51% 51% no-repeat,
    linear-gradient(#000,#000) bottom/100% 50% no-repeat;
  mask:
    radial-gradient(circle var(--c) at top left,#0000 calc(var(--c) - .6px),#000 var(--c)) top left/51% 51% no-repeat,
    radial-gradient(circle var(--c) at top right,#0000 calc(var(--c) - .6px),#000 var(--c)) top right/51% 51% no-repeat,
    linear-gradient(#000,#000) bottom/100% 50% no-repeat;
}
.hero--menu .hero__img::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(20,30,25,.34) 0%,rgba(20,30,25,0) 42%)}
.hero--menu h1{
  position:relative;z-index:1;margin-top:40px;
  font-family:var(--f-display);font-style:normal;font-weight:800;color:#fff;
  letter-spacing:.14em;text-transform:uppercase;
  font-size:clamp(40px,12vw,86px);text-shadow:0 2px 16px rgba(0,0,0,.4);
}
.hero--menu .hero__text{position:relative;text-align:center;padding:32px 26px 40px;
  background-color:var(--green);background-image:var(--pat-green);background-size:210px}
.hero--menu .hero__text p{color:#fff;font-weight:600;font-size:clamp(16px,4.6vw,20px);line-height:1.5;max-width:32em;margin:0 auto}
.hero--menu .hero__text p+p{margin-top:16px;font-weight:500}

/* scalloped divider — sits at the TOP of the kuih chang section */
.m-divider{width:100%;aspect-ratio:3000/310;background:url('img/menu-divider.png') center top/100% 100% no-repeat}

/* section headings (green, uppercase) */
.m-heading{font-family:var(--f-display);font-weight:800;color:var(--green);text-transform:uppercase;
  text-align:center;letter-spacing:.05em;line-height:1.12;font-size:clamp(26px,7.4vw,44px)}

/* ---------- Heritage Kuih Chang banners ---------- */
.m-kc{background:#fff;padding:0 0 30px}
.m-kc .m-heading{margin:38px 0 30px;padding:0 22px}
.kc-list{display:flex;flex-direction:column;gap:0}
.kc-card{position:relative;--kcw:80%}
/* food photo carries the gold concave frame baked in (same as the featured dishes) */
.kc-photo{position:relative;width:var(--kcw);margin:0 auto;line-height:0}
.kc-photo img{display:block;width:100%}
/* name band — same width as the photo, flush below it (no gap) */
.kc-band{position:relative;overflow:hidden;width:var(--kcw);margin:0 auto;
  display:flex;align-items:center;justify-content:center;
  padding:16px 14px;min-height:84px;
  background:linear-gradient(110deg,#06382d 0%,#1e5b49 52%,#0b4636 100%)}
.kc-band h3{font-family:var(--f-display);font-weight:800;color:#fff;text-align:center;line-height:1.12;
  font-size:clamp(18px,5.2vw,26px);letter-spacing:.01em}
/* large quatrefoils, half-cut at the band's left & right edges */
.kc-quad{position:absolute;top:50%;width:clamp(58px,16vw,86px);aspect-ratio:1;
  background:url('img/quad-coral.svg') center/contain no-repeat}
.kc-band .kc-quad:first-child{left:0;transform:translate(-50%,-50%)}
.kc-band .kc-quad:last-child{right:0;transform:translate(50%,-50%)}

/* section divider (white -> pink songket) before the pink sections — full-bleed */
.m-divider2{aspect-ratio:3000/260;background:url('img/menu-divider2.png') center/100% 100.5% no-repeat;
  width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);
  margin-top:-42px;margin-bottom:26px}

/* ---------- pink selection sections ---------- */
.m-sel{background-color:var(--coral-soft);background-image:var(--pat-coral);background-size:230px;
  padding:42px 5.9% 48px}
.m-sel .m-heading{margin-bottom:26px}
.dish{margin:0}
.dish img{width:100%;height:auto;border-radius:clamp(8px,2.6vw,16px);display:block;
  box-shadow:0 4px 14px rgba(20,40,30,.10)}
.dish figcaption{font-family:var(--f-display);font-weight:700;color:var(--green);text-align:center;
  line-height:1.18;font-size:clamp(14px,3.9vw,18px);margin-top:10px}
.dish--feature{width:88%;margin:0 auto 14px}
.dish--feature figcaption{font-size:clamp(16px,4.6vw,22px);margin-top:12px;margin-bottom:8px}
.dish-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,4.5vw,26px) clamp(14px,5vw,30px)}

/* ---------- Menu desktop ---------- */
@media(min-width:768px){
  .m-kc .m-heading,.m-sel .m-heading{font-size:clamp(34px,5vw,52px)}
  .kc-band h3{font-size:clamp(22px,3vw,30px)}
}
@media(min-width:1024px){
  /* desktop hero: image left, text right, one frame around both */
  .hero--menu .hero__inner{flex-direction:row;align-items:stretch;max-width:1200px;margin:0 auto}
  .hero--menu .hero__img{
    aspect-ratio:4/3;width:55%;height:auto;align-items:flex-start;
    --c:15px;
    -webkit-mask:
      radial-gradient(circle var(--c) at top left,#0000 calc(var(--c) - .6px),#000 var(--c)) top left/50% 51% no-repeat,
      radial-gradient(circle var(--c) at bottom left,#0000 calc(var(--c) - .6px),#000 var(--c)) bottom left/50% 51% no-repeat,
      linear-gradient(#000,#000) right/51% 100% no-repeat;
    mask:
      radial-gradient(circle var(--c) at top left,#0000 calc(var(--c) - .6px),#000 var(--c)) top left/50% 51% no-repeat,
      radial-gradient(circle var(--c) at bottom left,#0000 calc(var(--c) - .6px),#000 var(--c)) bottom left/50% 51% no-repeat,
      linear-gradient(#000,#000) right/51% 100% no-repeat;
  }
  .hero--menu h1{margin-top:38px}
  .hero--menu .hero__text{width:45%;display:flex;flex-direction:column;justify-content:center;padding:40px clamp(32px,4vw,60px)}
  .hero--menu .hero__text p{font-size:clamp(17px,1.4vw,21px)}

  .m-kc{padding:72px 0 60px}
  .kc-list{max-width:760px;margin:0 auto;gap:0}
  .kc-card{--kcw:100%}
  .kc-band{padding:22px;min-height:96px}
  .kc-quad{width:clamp(74px,8vw,96px)}

  .m-sel{padding:72px clamp(40px,7vw,110px) 80px}
  .m-sel>.m-heading,.m-sel>.dish--feature,.m-sel>.dish-grid{max-width:1100px;margin-left:auto;margin-right:auto}
  .dish--feature{width:62%;max-width:680px;margin-bottom:30px}
  .dish-grid{gap:34px 30px}
  .dish-grid--3up{grid-template-columns:repeat(3,1fr)}
}

@media(min-width:1024px){
  .bs-next__inner{max-width:1100px;margin:0 auto;padding:56px 40px;display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center;text-align:left}
  .bs-next__left{align-self:center}
  .bs-next__logo{margin:0 0 22px}
  .bs-next p{margin-left:0}
  .bs-next__figure{margin:0;justify-self:center;align-self:center;width:clamp(360px,34vw,520px)}
}
