/* ============================================================
   HONG HONG BAKERY v2 — "BUN ATLAS / BAKERY COOKBOOK"
   Long-form bilingual cookbook aesthetic
   ============================================================ */

:root{
  --cream:      #F5EDD8;  /* aged parchment */
  --cream-hi:   #FBF6E9;  /* warm cream highlight */
  --ink:        #2A1E12;  /* deep ink brown */
  --ink-soft:   #5b4a38;
  --red:        #B23E2E;  /* red lacquer */
  --red-deep:   #8f2f22;
  --amber:      #C9954A;  /* amber gold */
  --green:      #5A7842;  /* sesame green */
  --rule:       rgba(42,30,18,.22);
  --rule-soft:  rgba(42,30,18,.12);

  --f-display: "Bodoni Moda", Georgia, serif;
  --f-body:    "Newsreader", Georgia, serif;
  --f-tc:      "Noto Serif TC", "Newsreader", serif;
  --f-script:  "Caveat", cursive;
  --f-mono:    "IBM Plex Mono", ui-monospace, monospace;

  --maxw: 1240px;
  --gut: clamp(20px, 5vw, 64px);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--f-body);
  color:var(--ink);
  background-color:var(--cream);
  background-image:
    radial-gradient(circle at 18% 12%, rgba(201,149,74,.06), transparent 38%),
    radial-gradient(circle at 82% 78%, rgba(90,120,66,.05), transparent 42%),
    url("paper.svg");
  background-attachment: fixed, fixed, scroll;
  font-size:18px;
  line-height:1.62;
  overflow-x:hidden;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }

/* ---- hand-drawn rule ---- */
.rule-hand{
  height:8px; width:100%;
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='1200' height='8'><path d='M0 5 C 120 2, 240 7, 360 4 S 600 7, 720 4 S 960 2, 1080 5 1200 4' fill='none' stroke='%232A1E12' stroke-width='1.4' opacity='0.5'/></svg>") repeat-x center / 1200px 8px;
}

/* ---- chapter eyebrow ---- */
.eyebrow{
  font-family:var(--f-mono);
  font-size:13px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--red); font-weight:500;
  display:flex; align-items:center; gap:.7em;
}
.eyebrow .tc{ font-family:var(--f-tc); letter-spacing:.05em; }

/* ---- section header (chapter style) ---- */
.chapter{ margin-bottom: clamp(28px,5vw,52px); }
.chapter h2{
  font-family:var(--f-display);
  font-weight:800;
  font-size:clamp(34px, 6vw, 64px);
  line-height:1.02;
  margin:.28em 0 0;
  letter-spacing:-.01em;
}
.chapter h2 .ital{ font-style:italic; font-weight:500; }
.chapter h2 .tc{ font-family:var(--f-tc); font-weight:700; }
.underline-hand{
  display:inline-block; height:14px; width:min(280px,46%); margin-top:6px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='280' height='14'><path d='M2 7 C 60 13, 120 2, 180 7 S 260 12, 278 6' fill='none' stroke='%23B23E2E' stroke-width='2.4' stroke-linecap='round'/></svg>") no-repeat left center / contain;
}
.chapter .lede{
  max-width:54ch; margin-top:1.1em; font-size:clamp(18px,2.1vw,21px);
  color:var(--ink-soft); text-wrap:pretty;
}

/* ---- buttons ---- */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--f-mono); font-size:14px; font-weight:500;
  letter-spacing:.06em; text-transform:uppercase; text-decoration:none;
  padding:15px 22px; border-radius:2px; min-height:48px;
  transition:transform .15s ease, background .2s ease, box-shadow .2s ease;
  cursor:pointer; border:1.5px solid var(--ink);
}
.btn-red{
  background:var(--red); color:var(--cream-hi); border-color:var(--red-deep);
  box-shadow:3px 3px 0 var(--red-deep);
}
.btn-red:hover{ transform:translate(-1px,-1px); box-shadow:5px 5px 0 var(--red-deep); }
.btn-red:active{ transform:translate(2px,2px); box-shadow:1px 1px 0 var(--red-deep); }
.btn-ghost{
  background:transparent; color:var(--ink); border-color:var(--ink);
}
.btn-ghost:hover{ background:var(--ink); color:var(--cream-hi); }

/* ---- rubber stamp ---- */
.stamp{
  font-family:var(--f-mono); font-weight:600;
  font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--red); border:2px solid var(--red); border-radius:3px;
  padding:7px 11px; display:inline-flex; gap:.5em; align-items:center;
  transform:rotate(-7deg); opacity:.88;
  box-shadow:inset 0 0 0 1px rgba(178,62,46,.25);
}
.stamp .tc{ font-family:var(--f-tc); }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:sticky; top:0; z-index:50;
  background:color-mix(in srgb, var(--cream) 92%, transparent);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--rule-soft);
}
.nav-inner{
  max-width:var(--maxw); margin:0 auto; padding:14px var(--gut);
  display:flex; align-items:center; gap:24px;
}
.wordmark{ text-decoration:none; line-height:1; }
.wordmark .name{
  font-family:var(--f-display); font-weight:800; font-size:23px; letter-spacing:-.01em;
}
.wordmark .sub{
  font-family:var(--f-mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-soft); margin-top:3px; display:block;
}
.wordmark .sub .tc{ font-family:var(--f-tc); letter-spacing:.04em; }
.nav-links{
  display:flex; gap:26px; margin-left:auto; align-items:center;
}
.nav-links a{
  font-family:var(--f-mono); font-size:13px; letter-spacing:.04em; text-transform:uppercase;
  text-decoration:none; color:var(--ink); padding:6px 0; position:relative;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1.5px; width:0; background:var(--red);
  transition:width .22s ease;
}
.nav-links a:hover::after{ width:100%; }
.nav-phone{
  font-family:var(--f-mono); font-weight:600; font-size:13px; letter-spacing:.04em;
  text-decoration:none; color:var(--cream-hi); background:var(--red);
  padding:9px 14px; border-radius:2px; border:1.5px solid var(--red-deep);
  box-shadow:2px 2px 0 var(--red-deep); white-space:nowrap;
}
.nav-phone:hover{ transform:translate(-1px,-1px); }
.nav-toggle{ display:none; }
.nav-stamp{ display:none; }

/* hamburger */
.burger{
  display:none; margin-left:auto; background:none; border:1.5px solid var(--ink);
  width:46px; height:46px; border-radius:3px; cursor:pointer; padding:0;
  flex-direction:column; gap:5px; align-items:center; justify-content:center;
}
.burger span{ width:20px; height:2px; background:var(--ink); display:block; transition:.2s; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; padding-top:clamp(36px,6vw,72px); padding-bottom:clamp(40px,7vw,90px); }
.hero-grid{
  display:grid; grid-template-columns: 1.12fr .88fr; gap:clamp(36px,5vw,72px);
  align-items:center;
}
.hero h1{
  font-family:var(--f-display); font-weight:800;
  font-size:clamp(46px, 6.4vw, 78px); line-height:.96; letter-spacing:-.02em;
  margin:.32em 0 0;
}
.hero h1 .ital{ font-style:italic; font-weight:500; color:var(--ink); display:block; }
.hero .lede{
  font-size:clamp(18px,2.3vw,22px); color:var(--ink-soft); max-width:46ch;
  margin:1.3em 0 0; text-wrap:pretty;
}
.hero .lede b{ color:var(--ink); font-weight:600; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:1.8em; }
.hero-stamps{ display:flex; gap:14px; align-items:center; margin-top:1.6em; flex-wrap:wrap; }
.stars{ font-family:var(--f-mono); font-size:14px; color:var(--ink-soft); display:flex; gap:.5em; align-items:center; }
.stars b{ color:var(--ink); }
.stars .amber{ color:var(--amber); letter-spacing:.05em; }

/* margin bun doodles — corner motifs, not floating mid-canvas */
.hero-doodle{ position:absolute; opacity:.45; pointer-events:none; }
.hero-doodle.d1{ top:2%; right:1%; width:58px; transform:rotate(-12deg); }
.hero-doodle.d2{ bottom:4%; left:0; width:64px; transform:rotate(8deg); }

/* tray svg holder */
.tray-stage{ position:relative; max-width:520px; margin-left:auto; }
.tray-stage svg{ width:100%; height:auto; overflow:visible; }
.tray-cap{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-soft); text-align:center; margin-top:14px;
}

/* pastry settle animation handled via JS transforms */
.pastry{ transition:none; }
.pastry .plabel{ font-family:var(--f-script); font-size:21px; fill:var(--ink); }
.pastry .plabel-tc{ font-family:var(--f-tc); font-size:15px; fill:var(--red); font-weight:700; }
.lead-line{ stroke:var(--ink); stroke-width:1; opacity:.5; }

/* ============================================================
   SECTION SHELL
   ============================================================ */
section.band{ padding:clamp(56px,9vw,110px) 0; position:relative; }
.band.alt{ background:color-mix(in srgb, var(--cream-hi) 60%, transparent); }

/* ---- THE BUNS recipe-card list ---- */
.buns-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(20px,3vw,40px) clamp(36px,6vw,80px);
}
.bun-item{
  display:grid; grid-template-columns:auto 1fr; gap:14px; align-items:start;
  padding-bottom:22px; border-bottom:1px dotted var(--rule);
}
.bun-star{ color:var(--red); font-size:22px; line-height:1; margin-top:6px; }
.bun-head{ display:flex; align-items:baseline; gap:12px; flex-wrap:wrap; }
.bun-tc{ font-family:var(--f-tc); font-weight:700; font-size:clamp(24px,3vw,32px); color:var(--ink); }
.bun-en{ font-family:var(--f-display); font-weight:600; font-size:clamp(18px,2vw,22px); }
.bun-note{ font-family:var(--f-script); font-size:20px; color:var(--green); margin-top:4px; line-height:1.25; }
.bun-note.red{ color:var(--red); }

/* ---- THE RECIPES menu ---- */
.recipe-cols{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,80px); }
.recipe-col h3{
  font-family:var(--f-display); font-weight:700; font-size:clamp(22px,3vw,28px);
  margin:0 0 4px; display:flex; align-items:baseline; gap:12px;
}
.recipe-col h3 .tc{ font-family:var(--f-tc); color:var(--red); font-size:.8em; }
.recipe-col .colcap{ font-family:var(--f-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:18px; }
.menu-row{
  display:grid; grid-template-columns:1fr auto; align-items:baseline;
  gap:6px; padding:11px 0; cursor:default; transition:color .15s;
}
.menu-row .mr-name{ display:flex; align-items:baseline; gap:9px; }
.menu-row .mr-name .tc{ font-family:var(--f-tc); font-weight:700; }
.menu-row .mr-name .en{ font-family:var(--f-body); font-size:17px; }
.menu-row .leader{ flex:1; border-bottom:1.5px dotted var(--rule); transform:translateY(-4px); margin:0 4px; }
.menu-row .mr-price{ font-family:var(--f-mono); font-size:15px; font-weight:500; color:var(--ink); }
.menu-row:hover{ color:var(--red); }
.menu-row:hover .mr-price{ color:var(--red); }
.menu-row:hover .pico path, .menu-row:hover .pico circle, .menu-row:hover .pico ellipse{ stroke:var(--red); }
.pico{ width:30px; height:24px; flex:0 0 auto; transform:translateY(3px); opacity:.85; transition:transform .2s; }
.menu-row:hover .pico{ transform:translateY(3px) scale(1.18) rotate(-6deg); }

/* ---- THE BAKERY ---- */
.bakery-grid{ display:grid; grid-template-columns:1.2fr .8fr; gap:clamp(30px,5vw,70px); align-items:center; }
.bakery-copy p{ font-size:clamp(18px,2vw,20px); margin:0 0 1em; max-width:52ch; text-wrap:pretty; }
.bakery-copy .script{ font-family:var(--f-script); font-size:clamp(28px,4vw,40px); color:var(--red); line-height:1.15; margin:.4em 0; }
.bakery-aside{ text-align:center; }
.bakery-aside svg{ width:min(220px,70%); height:auto; margin:0 auto; }
.bakery-aside .cap{ font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin-top:14px; }

/* pull quote */
.pull{
  font-family:var(--f-script); color:var(--red);
  font-size:clamp(30px,6vw,58px); line-height:1.08; text-align:center;
  max-width:18ch; margin:clamp(30px,5vw,50px) auto 0;
}

/* ---- GALLERY ---- */
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.gcell{ position:relative; aspect-ratio:4/5; overflow:hidden; border:1px solid var(--rule); background:var(--cream-hi); }
.gcell.wide{ grid-column:span 1; }
.gcell img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.gcell:hover img{ transform:scale(1.05); }
.gcell .gtag{
  position:absolute; left:10px; bottom:10px;
  font-family:var(--f-mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--cream-hi); background:rgba(42,30,18,.72); padding:5px 9px; border-radius:2px;
}
.gcell .gtag .tc{ font-family:var(--f-tc); }
/* owner-to-supply drop card */
.drop{
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px;
  text-align:center; padding:20px;
  background:
    repeating-linear-gradient(45deg, rgba(42,30,18,.05) 0 10px, transparent 10px 20px),
    var(--cream-hi);
  border:1.5px dashed var(--rule);
}
.drop .dtc{ font-family:var(--f-tc); font-weight:700; font-size:30px; color:var(--ink); }
.drop .den{ font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); }
.drop .pending{
  font-family:var(--f-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--red); border:1.5px solid var(--red); padding:4px 9px; border-radius:2px; margin-top:4px;
  transform:rotate(-4deg);
}
.drop .pending .tc{ font-family:var(--f-tc); }
/* image fallback (now baking) */
.img-fallback{
  width:100%; height:100%; display:flex; align-items:center; justify-content:center;
  background:repeating-linear-gradient(45deg, rgba(42,30,18,.06) 0 12px, transparent 12px 24px), var(--cream-hi);
  font-family:var(--f-tc); font-weight:700; font-size:26px; color:var(--ink-soft);
}

/* ---- VISIT ---- */
.visit-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(24px,4vw,48px); align-items:stretch; }
.visit-card{
  background:var(--cream-hi); border:1px solid var(--rule); padding:clamp(26px,4vw,40px);
  box-shadow:5px 5px 0 rgba(42,30,18,.07);
}
.visit-card .vrow{ padding:16px 0; border-bottom:1px dotted var(--rule); }
.visit-card .vrow:last-child{ border-bottom:none; }
.vlabel{ font-family:var(--f-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:6px; }
.vval{ font-family:var(--f-display); font-weight:600; font-size:clamp(19px,2.3vw,24px); line-height:1.25; }
.vval a{ text-decoration:none; }
.v-phone{
  font-family:var(--f-mono); font-weight:600; font-size:clamp(18px,2.4vw,23px); color:var(--red);
  text-decoration:none; letter-spacing:.02em; border:2px solid var(--red); border-radius:3px;
  padding:8px 14px; display:inline-block; transform:rotate(-1.5deg); box-shadow:inset 0 0 0 1px rgba(178,62,46,.2);
}
.v-phone:hover{ background:var(--red); color:var(--cream-hi); }
.map-wrap{ border:1px solid var(--rule); overflow:hidden; min-height:340px; background:var(--cream-hi); box-shadow:5px 5px 0 rgba(42,30,18,.07); }
.map-wrap iframe{ width:100%; height:100%; min-height:340px; display:block; filter:sepia(.18) saturate(.92); }

/* ---- FOOTER CTA ---- */
.cta-band{
  text-align:center; padding:clamp(56px,9vw,110px) 0;
  background:var(--ink); color:var(--cream-hi);
  background-image:radial-gradient(circle at 50% -10%, rgba(201,149,74,.12), transparent 55%);
}
.cta-band h2{
  font-family:var(--f-display); font-weight:800; font-size:clamp(38px,7vw,76px); line-height:1; margin:0;
}
.cta-band .han{ font-family:var(--f-tc); font-weight:700; letter-spacing:.1em; display:block; margin-top:.3em; font-size:clamp(34px,6vw,64px); color:var(--amber); }
.cta-band .cta-phone{
  font-family:var(--f-mono); font-weight:600; font-size:clamp(18px,2.6vw,26px); letter-spacing:.04em;
  color:var(--cream-hi); text-decoration:none; border:2px solid var(--red); background:var(--red);
  padding:14px 24px; border-radius:3px; display:inline-block; margin-top:1.6em; box-shadow:4px 4px 0 var(--red-deep);
}
.cta-band .cta-phone:hover{ transform:translate(-1px,-1px); }

/* ---- FOOTER ---- */
footer.ftr{ background:var(--ink); color:color-mix(in srgb, var(--cream) 70%, transparent); padding:0 0 48px; }
.ftr-orn{ height:18px; background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='18'><g fill='none' stroke='%23C9954A' stroke-width='1.3' opacity='0.55'><path d='M0 9 H150'/><circle cx='175' cy='9' r='4'/><path d='M168 9 L182 9 M175 2 L175 16'/><path d='M200 9 H400'/></g></svg>") repeat-x center / 400px 18px; margin-bottom:38px; }
.ftr-inner{ display:flex; justify-content:space-between; gap:24px; flex-wrap:wrap; align-items:flex-end; }
.ftr-name{ font-family:var(--f-display); font-weight:800; font-size:26px; color:var(--cream-hi); }
.ftr-name .tc{ font-family:var(--f-tc); font-weight:700; color:var(--amber); margin-left:10px; font-size:.85em; }
.ftr-small{ font-family:var(--f-mono); font-size:11px; letter-spacing:.05em; line-height:1.8; }
.ftr-small a{ color:var(--amber); text-decoration:none; }

/* ============================================================
   MOBILE
   ============================================================ */
@media (max-width: 940px){
  .hero-grid{ grid-template-columns:1fr; }
  .tray-stage{ order:-1; max-width:460px; margin:0 auto; }
  .recipe-cols{ grid-template-columns:1fr; gap:36px; }
  .bakery-grid{ grid-template-columns:1fr; }
  .visit-grid{ grid-template-columns:1fr; }
}
@media (max-width: 760px){
  .buns-grid{ grid-template-columns:1fr; }
}
@media (max-width: 640px){
  body{ font-size:17px; }
  .nav-links{ display:none; }
  .nav-phone{ display:none; }
  .burger{ display:flex; }
  .nav-stamp{ display:none; }
  /* mobile menu drawer */
  .nav.open .mobile-menu{ display:flex; }
  .mobile-menu{
    display:none; flex-direction:column; gap:2px;
    position:fixed; top:72px; left:0; right:0; z-index:49;
    background:var(--cream-hi); border-bottom:1px solid var(--rule);
    padding:14px var(--gut) 22px;
  }
  .mobile-menu a{
    font-family:var(--f-mono); font-size:15px; letter-spacing:.04em; text-transform:uppercase;
    text-decoration:none; color:var(--ink); padding:13px 0; border-bottom:1px dotted var(--rule);
  }
  .mobile-menu .mm-phone{
    margin-top:14px; background:var(--red); color:var(--cream-hi); text-align:center;
    border:1.5px solid var(--red-deep); border-radius:3px; padding:15px; box-shadow:3px 3px 0 var(--red-deep);
    border-bottom:1.5px solid var(--red-deep);
  }
  .gallery{ grid-template-columns:1fr 1fr; gap:10px; }
  .hero-doodle{ display:none; }
  .map-wrap iframe, .map-wrap{ min-height:300px; }
  .hero-cta .btn{ width:100%; justify-content:center; }
}
@media (min-width:641px){
  .mobile-menu{ display:none !important; }
}
