/* ============================================
   ABHAYA CAKES LIMITED — Design tokens
   Espresso + cream + gold, patisserie-luxe
   ============================================ */
:root{
  --espresso:#1a1410;
  --espresso-soft:#241b15;
  --cream:#f7f3ec;
  --paper:#fdfbf7;
  --gold:#c9a876;
  --gold-soft:#e3cda0;
  --caramel:#8b6f47;
  --line:rgba(201,168,118,0.25);
  --shadow:0 30px 60px -30px rgba(26,20,16,0.45);

  --font-display:'Fraunces', serif;
  --font-body:'Inter', sans-serif;

  --container:1240px;
  --radius:2px;
}

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

::selection{background:var(--gold-soft);color:var(--espresso);}

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

.eyebrow{
  font-family:var(--font-body);
  font-size:0.72rem;
  font-weight:600;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--caramel);
  margin-bottom:1rem;
  display:block;
}

h1,h2,h3{
  font-family:var(--font-display);
  font-weight:500;
  letter-spacing:-0.01em;
  color:var(--espresso);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:1.05rem 2.1rem;
  font-size:0.85rem;
  font-weight:600;
  letter-spacing:0.04em;
  text-transform:uppercase;
  border-radius:var(--radius);
  transition:transform .35s cubic-bezier(.2,.8,.2,1), background .35s, color .35s, box-shadow .35s;
}
.btn-primary{
  background:var(--espresso);
  color:var(--cream);
}
.btn-primary:hover{
  background:var(--gold);
  color:var(--espresso);
  transform:translateY(-2px);
  box-shadow:0 16px 30px -12px rgba(201,168,118,0.55);
}
.btn-ghost{
  background:transparent;
  color:var(--espresso);
  border:1px solid var(--espresso);
}
.btn-ghost:hover{
  background:var(--espresso);
  color:var(--cream);
  transform:translateY(-2px);
}
.btn-wide{width:100%;}

/* ============================================
   HEADER
   ============================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:1.25rem 0;
  background:rgba(26,20,16,0.85);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(247,243,236,0.08);
  transition:background .4s, padding .4s, box-shadow .4s, border-color .4s;
}
.site-header.scrolled{
  background:rgba(247,243,236,0.94);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  padding:0.85rem 0;
  box-shadow:0 1px 0 var(--line);
  border-bottom-color:transparent;
}
.header-inner{
  max-width:var(--container);
  margin:0 auto;
  padding:0 1.75rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.brand{
  display:flex;
  align-items:center;
  gap:0.85rem;
}
.brand-mark{
  width:46px;height:46px;
  object-fit:cover;
  border-radius:50%;
  border:1px solid var(--line);
  box-shadow:0 2px 8px rgba(26,20,16,0.1);
}
.brand-text{
  font-family:var(--font-display);
  font-size:1.15rem;
  font-weight:600;
  letter-spacing:0.04em;
  display:flex;
  flex-direction:column;
  line-height:1.1;
  color:var(--paper);
  transition:color .4s;
}
.site-header.scrolled .brand-text{color:var(--espresso);}
.brand-sub{
  font-family:var(--font-body);
  font-size:0.55rem;
  font-weight:600;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--gold-soft);
  transition:color .4s;
}
.site-header.scrolled .brand-sub{color:var(--gold);}
.main-nav{
  display:flex;
  align-items:center;
  gap:2.3rem;
}
.main-nav a{
  font-size:0.82rem;
  font-weight:500;
  letter-spacing:0.02em;
  position:relative;
  padding:0.3rem 0;
  color:var(--paper);
  transition:color .4s;
}
.main-nav a:not(.nav-cta)::after{
  content:'';
  position:absolute;left:0;bottom:0;
  width:0;height:1px;
  background:var(--gold-soft);
  transition:width .3s;
}
.main-nav a:not(.nav-cta):hover::after{width:100%;}
.main-nav a.nav-active::after{width:100%;}

/* Desktop-only: scrolled header darkens nav links to espresso on cream bg */
@media (min-width:761px){
  .site-header.scrolled .main-nav a{color:var(--espresso);}
  .site-header.scrolled .main-nav a:not(.nav-cta)::after{background:var(--gold);}
}
.btn-light{
  color:var(--paper);
  border-color:rgba(247,243,236,0.5);
}
.btn-light:hover{
  background:var(--paper);
  color:var(--espresso);
  border-color:var(--paper);
}
.main-nav a.nav-cta{
  background:var(--gold-soft);
  color:var(--espresso) !important;
  padding:0.6rem 1.3rem;
  font-size:0.78rem;
  font-weight:600;
  letter-spacing:0.04em;
  text-transform:uppercase;
  border-radius:var(--radius);
  transition:background .3s,color .3s;
}
/* Desktop-only: scrolled CTA flips to dark bg */
@media (min-width:761px){
  .site-header.scrolled .main-nav a.nav-cta{background:var(--espresso);color:var(--cream) !important;}
}
.main-nav a.nav-cta:hover{background:var(--gold);color:var(--espresso) !important;}

.nav-toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  width:28px;
  z-index:1001;
}
.nav-toggle span{
  height:2px;width:100%;
  background:var(--paper);
  transition:transform .3s, opacity .3s, background .4s;
}
.site-header.scrolled .nav-toggle span{background:var(--espresso);}
/* when the mobile menu itself is open, the panel is always dark, so force light bars */
.nav-toggle.active span{background:var(white);}
.nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle.active span:nth-child(2){opacity:0;}
.nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ============================================
   HERO
   ============================================ */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  overflow:hidden;
  padding:7rem 1.75rem 4rem;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
}
.hero-bg img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(0.85) brightness(0.55);
}
.hero-veil{
  position:absolute;inset:0;
  background:linear-gradient(115deg, rgba(26,20,16,0.92) 0%, rgba(26,20,16,0.75) 40%, rgba(26,20,16,0.35) 75%);
}
.hero-content{
  position:relative;z-index:2;
  max-width:var(--container);
  margin:0 auto;
  width:100%;
}
.hero-title{
  font-size:clamp(2.6rem, 7vw, 5.6rem);
  line-height:1.04;
  color:var(--paper);
}
.hero-title .line{
  display:block;
  opacity:0;
  transform:translateY(24px);
  animation:riseIn .9s cubic-bezier(.2,.8,.2,1) forwards;
}
.hero-title .line:nth-child(1){animation-delay:.1s;}
.hero-title .line:nth-child(2){animation-delay:.28s;}
.hero-title .line:nth-child(3){animation-delay:.46s;}
.hero-title .accent{
  font-style:italic;
  color:var(--gold-soft);
}
@keyframes riseIn{to{opacity:1;transform:translateY(0);}}

.hero-lede{
  margin-top:1.75rem;
  max-width:480px;
  font-size:1.05rem;
  color:rgba(247,243,236,0.82);
  opacity:0;
  animation:riseIn .9s cubic-bezier(.2,.8,.2,1) forwards;
  animation-delay:.62s;
}
.hero-actions{
  margin-top:2.5rem;
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
  opacity:0;
  animation:riseIn .9s cubic-bezier(.2,.8,.2,1) forwards;
  animation-delay:.78s;
}
.hero .btn-ghost{
  color:var(--paper);
  border-color:rgba(247,243,236,0.5);
}
.hero .btn-ghost:hover{
  background:var(--paper);
  color:var(--espresso);
  border-color:var(--paper);
}

/* signature swirl — piping motif, animates like icing being piped */
.hero-swirl{
  position:absolute;
  right:6%;
  bottom:10%;
  width:170px;
  z-index:2;
  opacity:0.9;
  display:none;
}
.swirl-svg{width:100%;height:100%;}
.swirl-path{
  fill:none;
  stroke:var(--gold-soft);
  stroke-width:3;
  stroke-linecap:round;
  stroke-dasharray:400;
  stroke-dashoffset:400;
  animation:pipe 2.4s cubic-bezier(.3,.7,.3,1) forwards;
  animation-delay:1s;
}
@keyframes pipe{to{stroke-dashoffset:0;}}

.scroll-cue{
  position:absolute;
  left:50%;
  bottom:2.2rem;
  transform:translateX(-50%);
  z-index:2;
  width:1px;height:46px;
  background:rgba(247,243,236,0.35);
}
.scroll-cue span{
  position:absolute;top:0;left:-2.5px;
  width:6px;height:6px;
  border-radius:50%;
  background:var(--gold-soft);
  animation:scrollDot 2s ease-in-out infinite;
}
@keyframes scrollDot{
  0%{top:0;opacity:1;}
  90%{opacity:1;}
  100%{top:42px;opacity:0;}
}

/* ============================================
   STORY
   ============================================ */
.story{
  padding:7.5rem 1.75rem;
  background:var(--cream);
}
.story-grid{
  max-width:var(--container);
  margin:0 auto;
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:5rem;
  align-items:start;
}
.story-copy h2{
  font-size:clamp(2rem, 3.6vw, 2.9rem);
  line-height:1.18;
  margin-bottom:1.75rem;
}
.story-text{
  color:var(--espresso-soft);
  max-width:520px;
  margin-bottom:1.2rem;
  font-size:1rem;
  opacity:0.85;
}
.signature-block{
  margin-top:2rem;
  padding-top:1.5rem;
  border-top:1px solid var(--line);
  display:flex;
  flex-direction:column;
}
.signature-name{
  font-family:var(--font-display);
  font-style:italic;
  font-size:1.4rem;
}
.signature-role{
  font-size:0.78rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--caramel);
  margin-top:0.3rem;
}

.story-stats{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.2rem;
}
.stat-card{
  background:var(--paper);
  border:1px solid var(--line);
  padding:2rem 1.5rem;
  display:flex;
  flex-direction:column;
  gap:0.6rem;
  transition:transform .35s, box-shadow .35s, border-color .35s;
}
.stat-card:hover{
  transform:translateY(-5px);
  box-shadow:var(--shadow);
  border-color:var(--gold);
}
.stat-num{
  font-family:var(--font-display);
  font-size:1.7rem;
  font-weight:600;
}
.stat-label{
  font-size:0.72rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--caramel);
}

/* wavy piped divider, echoes the logo's icing line */
.divider{
  width:100%;
  height:30px;
  color:var(--gold);
  opacity:0.5;
}
.divider svg{width:100%;height:100%;}
.divider path{
  fill:none;
  stroke:currentColor;
  stroke-width:2;
}

/* ============================================
   MENU
   ============================================ */
.menu{
  padding:6rem 1.75rem 7.5rem;
  background:var(--cream);
}
.section-head{
  max-width:var(--container);
  margin:0 auto 3.5rem;
}
.section-head h2{
  font-size:clamp(2rem, 3.6vw, 2.9rem);
  margin-bottom:1rem;
}
.section-lede{
  max-width:560px;
  color:var(--espresso-soft);
  opacity:0.85;
}
.menu-grid{
  max-width:var(--container);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1.5rem;
}
.menu-card{
  background:var(--paper);
  border:1px solid var(--line);
  padding:0 0 1.8rem;
  overflow:hidden;
  transition:transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s;
  display:flex;
  flex-direction:column;
}
.menu-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow);
}
.menu-img{
  width:100%;
  aspect-ratio:4/3;
  overflow:hidden;
}
.menu-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s cubic-bezier(.2,.8,.2,1);
}
.menu-card:hover .menu-img img{transform:scale(1.08);}
.menu-card h3{
  font-size:1.25rem;
  margin:1.5rem 1.6rem 0.6rem;
}
.menu-card p{
  margin:0 1.6rem;
  font-size:0.9rem;
  color:var(--espresso-soft);
  opacity:0.8;
  flex-grow:1;
}
.menu-tag{
  margin:1.1rem 1.6rem 0;
  font-size:0.75rem;
  font-weight:600;
  letter-spacing:0.05em;
  text-transform:uppercase;
  color:var(--caramel);
}
.section-cta{
  max-width:var(--container);
  margin:3rem auto 0;
  text-align:center;
}

/* ============================================
   PROCESS
   ============================================ */
.process{
  background:var(--espresso);
  display:grid;
  grid-template-columns:0.9fr 1.1fr;
}
.process-img{
  position:relative;
  min-height:480px;
  overflow:hidden;
}
.process-img img{
  width:100%;height:100%;
  object-fit:cover;
  position:absolute;inset:0;
  filter:saturate(0.9) brightness(0.8);
}
.process-copy{
  padding:6rem 4rem 6rem 4rem;
  color:var(--cream);
}
.process-copy h2{
  font-size:clamp(2rem, 3.4vw, 2.7rem);
  color:var(--paper);
  margin-bottom:3rem;
  line-height:1.18;
}
.process .eyebrow{color:var(--gold-soft);}
.process-step{
  display:grid;
  grid-template-columns:90px 1fr;
  gap:1.5rem;
  padding:1.6rem 0;
  border-top:1px solid rgba(247,243,236,0.14);
}
.process-step:last-child{border-bottom:1px solid rgba(247,243,236,0.14);}
.step-mark{
  font-family:var(--font-display);
  font-style:italic;
  color:var(--gold-soft);
  font-size:1rem;
  padding-top:0.15rem;
}
.process-step h3{
  color:var(--paper);
  font-size:1.1rem;
  margin-bottom:0.4rem;
}
.process-step p{
  font-size:0.92rem;
  color:rgba(247,243,236,0.68);
  max-width:440px;
}

/* ============================================
   ORDER FORM
   ============================================ */
.order{
  padding:7.5rem 1.75rem;
  background:var(--cream);
  display:flex;
  justify-content:center;
}
.order-inner{
  max-width:680px;
  width:100%;
  text-align:center;
}
.order h2{
  font-size:clamp(2rem, 3.6vw, 2.9rem);
  margin-bottom:1.1rem;
  line-height:1.18;
}
.order-lede{
  color:var(--espresso-soft);
  opacity:0.85;
  max-width:480px;
  margin:0 auto 2.8rem;
}
.order-form{
  text-align:left;
  display:flex;
  flex-direction:column;
  gap:1.2rem;
}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.2rem;
}
.form-field{
  display:flex;
  flex-direction:column;
  gap:0.5rem;
}
.form-field label{
  font-size:0.72rem;
  font-weight:600;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--caramel);
}
.form-field input,
.form-field textarea{
  font-family:var(--font-body);
  font-size:0.95rem;
  padding:0.9rem 1rem;
  border:1px solid var(--line);
  background:var(--paper);
  color:var(--espresso);
  border-radius:var(--radius);
  outline:none;
  transition:border-color .25s, box-shadow .25s;
  resize:vertical;
}
.form-field input:focus,
.form-field textarea:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(201,168,118,0.18);
}
.form-note{
  font-size:0.85rem;
  color:var(--caramel);
  min-height:1.2rem;
  text-align:center;
}

/* ============================================
   FOOTER
   ============================================ */
.site-footer{
  background:var(--espresso);
  color:var(--cream);
  padding:5rem 1.75rem 2rem;
}
.footer-grid{
  max-width:var(--container);
  margin:0 auto;
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:3rem;
  padding-bottom:3rem;
  border-bottom:1px solid rgba(247,243,236,0.12);
}
.footer-logo{
  width:54px;height:54px;
  object-fit:cover;
  border-radius:50%;
  margin-bottom:1.2rem;
  border:1px solid rgba(247,243,236,0.25);
  box-shadow:0 4px 14px rgba(0,0,0,0.3);
}
.footer-brand p{
  color:rgba(247,243,236,0.6);
  font-size:0.9rem;
  max-width:280px;
}
.footer-col h4{
  font-family:var(--font-body);
  font-size:0.74rem;
  font-weight:600;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--gold-soft);
  margin-bottom:1rem;
}
.footer-col p{
  font-size:0.9rem;
  color:rgba(247,243,236,0.65);
  margin-bottom:0.5rem;
  line-height:1.6;
}
.footer-col a:hover{color:var(--gold-soft);}
.footer-bottom{
  max-width:var(--container);
  margin:0 auto;
  padding-top:2rem;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:1rem;
  font-size:0.78rem;
  letter-spacing:0.04em;
  color:rgba(247,243,236,0.45);
}

/* DWS credit — a small wax-seal style badge, distinct from a plain text line */
.dws-seal{
  display:inline-flex;
  align-items:center;
  gap:0.65rem;
  text-decoration:none;
}
.dws-seal-ring{
  position:relative;
  width:30px;height:30px;
  border-radius:50%;
  border:1px solid rgba(227,205,160,0.55);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  transition:transform .5s cubic-bezier(.2,.8,.2,1), border-color .35s, box-shadow .35s;
}
.dws-seal-ring::before{
  content:'';
  position:absolute;
  inset:-4px;
  border-radius:50%;
  border:1px dotted rgba(227,205,160,0.3);
  transition:opacity .35s;
}
.dws-seal-text{
  font-family:var(--font-display);
  font-size:0.55rem;
  font-weight:700;
  letter-spacing:0.04em;
  color:var(--gold-soft);
}
.dws-seal-caption{
  font-size:0.7rem;
  letter-spacing:0.06em;
  color:rgba(247,243,236,0.45);
  transition:color .35s;
}
.dws-seal:hover .dws-seal-ring{
  transform:rotate(18deg);
  border-color:var(--gold-soft);
  box-shadow:0 0 0 3px rgba(227,205,160,0.12);
}
.dws-seal:hover .dws-seal-caption{color:var(--gold-soft);}

/* floating CTA */
.float-cta{
  position:fixed;
  bottom:1.6rem;
  right:1.6rem;
  z-index:900;
  background:var(--espresso);
  color:var(--cream);
  padding:0.95rem 1.6rem;
  font-size:0.78rem;
  font-weight:600;
  letter-spacing:0.04em;
  text-transform:uppercase;
  border-radius:40px;
  box-shadow:0 14px 30px -10px rgba(26,20,16,0.5);
  transition:transform .3s, background .3s, color .3s, opacity .35s;
  opacity:0;
  pointer-events:none;
}
.float-cta.visible{opacity:1;pointer-events:auto;}
.float-cta:hover{
  background:var(--gold);
  color:var(--espresso);
  transform:translateY(-3px);
}

/* ============================================
   PAGE HERO (used on About / Menu / Order / Contact)
   ============================================ */
.page-hero{
  background:var(--espresso);
  padding:9.5rem 1.75rem 4.5rem;
  text-align:center;
}
.page-hero-inner{
  max-width:760px;
  margin:0 auto;
}
.page-hero .eyebrow{color:var(--gold-soft);}
.page-hero h1{
  font-size:clamp(2.3rem, 5vw, 3.6rem);
  color:var(--paper);
  line-height:1.14;
}
.accent-italic{
  font-style:italic;
  color:var(--gold-soft);
}
.page-hero-lede{
  margin-top:1.4rem;
  color:rgba(247,243,236,0.78);
  font-size:1.05rem;
  max-width:540px;
  margin-left:auto;
  margin-right:auto;
}

/* ============================================
   ABOUT PAGE
   ============================================ */
.about-main{
  padding:6.5rem 1.75rem;
  background:var(--cream);
}
.about-grid{
  max-width:var(--container);
  margin:0 auto;
  display:grid;
  grid-template-columns:0.9fr 1.1fr;
  gap:4rem;
  align-items:center;
}
.about-img{
  border-radius:var(--radius);
  overflow:hidden;
  aspect-ratio:4/5;
}
.about-img img{width:100%;height:100%;object-fit:cover;}
.about-copy h2{
  font-size:clamp(2rem, 3.6vw, 2.8rem);
  margin:0.4rem 0 1.6rem;
  line-height:1.16;
}

.values{
  padding:6.5rem 1.75rem 7rem;
  background:var(--cream);
}
.values-grid{
  max-width:var(--container);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.8rem;
}
.value-card{
  background:var(--paper);
  border:1px solid var(--line);
  padding:2.4rem 2rem;
  transition:transform .35s, box-shadow .35s, border-color .35s;
}
.value-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow);
  border-color:var(--gold);
}
.value-mark{
  font-family:var(--font-display);
  font-style:italic;
  font-size:1.6rem;
  color:var(--gold);
  display:block;
  margin-bottom:1rem;
}
.value-card h3{
  font-size:1.15rem;
  margin-bottom:0.7rem;
}
.value-card p{
  font-size:0.92rem;
  color:var(--espresso-soft);
  opacity:0.82;
}

.company-strip{
  background:var(--espresso-soft);
  padding:3rem 1.75rem;
}
.company-strip-inner{
  max-width:var(--container);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1.5rem;
}
.strip-item{display:flex;flex-direction:column;gap:0.4rem;}
.strip-label{
  font-size:0.68rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--gold-soft);
}
.strip-value{
  font-family:var(--font-display);
  font-size:1.15rem;
  color:var(--paper);
}

.page-cta{
  padding:6rem 1.75rem;
  text-align:center;
  background:var(--cream);
}
.page-cta h2{
  font-size:clamp(1.8rem, 3.4vw, 2.5rem);
  margin-bottom:2rem;
  line-height:1.2;
}

/* ============================================
   MENU PAGE
   ============================================ */
.menu-jump{
  position:sticky;
  top:64px;
  z-index:90;
  background:rgba(247,243,236,0.95);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
  display:flex;
  justify-content:center;
  gap:2.2rem;
  padding:1rem 1.5rem;
  flex-wrap:wrap;
}
.menu-jump a{
  font-size:0.78rem;
  font-weight:600;
  letter-spacing:0.04em;
  text-transform:uppercase;
  color:var(--caramel);
  padding:0.3rem 0;
  position:relative;
}
.menu-jump a::after{
  content:'';
  position:absolute;left:0;bottom:0;
  width:0;height:1px;
  background:var(--gold);
  transition:width .3s;
}
.menu-jump a:hover::after{width:100%;}

.menu-section{
  padding:6rem 1.75rem;
  background:var(--cream);
}
.menu-section.reverse{background:var(--paper);}
.menu-section-grid{
  max-width:var(--container);
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:center;
}
.menu-section.reverse .menu-section-grid{
  grid-template-columns:1fr 1fr;
}
.menu-section.reverse .menu-section-img{order:2;}
.menu-section.reverse .menu-section-copy{order:1;}
.menu-section-img{
  border-radius:var(--radius);
  overflow:hidden;
  aspect-ratio:4/3;
}
.menu-section-img img{width:100%;height:100%;object-fit:cover;}
.menu-section-copy h2{
  font-size:clamp(1.9rem, 3.2vw, 2.4rem);
  margin:0.3rem 0 1.1rem;
}
.menu-section-copy p{
  color:var(--espresso-soft);
  opacity:0.85;
  margin-bottom:1.3rem;
}
.menu-detail-list{
  list-style:none;
  margin-bottom:1.8rem;
  display:flex;
  flex-direction:column;
  gap:0.65rem;
}
.menu-detail-list li{
  padding-left:1.4rem;
  position:relative;
  font-size:0.92rem;
  color:var(--espresso-soft);
}
.menu-detail-list li::before{
  content:'';
  position:absolute;left:0;top:0.5em;
  width:7px;height:7px;
  border-radius:50%;
  background:var(--gold);
}

.dietary-note{
  max-width:760px;
  margin:0 auto;
  padding:4rem 1.75rem 6rem;
  text-align:center;
}
.dietary-note p:not(.eyebrow){
  font-size:0.9rem;
  color:var(--espresso-soft);
  opacity:0.8;
}

/* ============================================
   ORDER PAGE
   ============================================ */
.order-page{
  padding:5.5rem 1.75rem 7rem;
  background:var(--cream);
}
.order-page-grid{
  max-width:var(--container);
  margin:0 auto;
  display:grid;
  grid-template-columns:1.5fr 1fr;
  gap:3.5rem;
  align-items:start;
}
.order-page .order-form{
  background:var(--paper);
  border:1px solid var(--line);
  padding:2.5rem;
}
.order-sidebar{
  display:flex;
  flex-direction:column;
  gap:1.5rem;
}
.sidebar-card{
  background:var(--espresso);
  color:var(--cream);
  padding:2.2rem;
}
.sidebar-card .eyebrow{color:var(--gold-soft);}
.sidebar-steps{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:1rem;
  counter-reset:step;
}
.sidebar-steps li{
  font-size:0.9rem;
  color:rgba(247,243,236,0.78);
  padding-left:2rem;
  position:relative;
  counter-increment:step;
}
.sidebar-steps li::before{
  content:counter(step);
  position:absolute;left:0;top:0;
  width:1.4rem;height:1.4rem;
  border:1px solid var(--gold-soft);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:0.72rem;
  color:var(--gold-soft);
}
.sidebar-steps li strong{color:var(--paper);}
.sidebar-contact{font-size:0.95rem;margin-bottom:0.5rem;}
.sidebar-contact a:hover{color:var(--gold-soft);}
.sidebar-note{
  font-size:0.82rem;
  color:rgba(247,243,236,0.6);
  margin-top:0.8rem;
}

/* ============================================
   CONTACT PAGE
   ============================================ */
.contact-main{
  padding:5.5rem 1.75rem;
  background:var(--cream);
}
.contact-grid{
  max-width:var(--container);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.8rem;
}
.contact-card{
  background:var(--paper);
  border:1px solid var(--line);
  padding:2.5rem 2rem;
  text-align:center;
  transition:transform .35s, box-shadow .35s, border-color .35s;
}
.contact-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow);
  border-color:var(--gold);
}
.contact-icon{
  font-size:1.8rem;
  color:var(--gold);
  display:block;
  margin-bottom:1rem;
}
.contact-card h3{
  font-size:1.1rem;
  margin-bottom:0.6rem;
}
.contact-card p{font-size:0.95rem;}
.contact-card a:hover{color:var(--caramel);}
.contact-meta{
  font-size:0.8rem;
  color:var(--caramel);
  opacity:0.8;
  margin-top:0.5rem;
}

.contact-secondary{
  padding:6rem 1.75rem;
  background:var(--cream);
}
.contact-secondary-grid{
  max-width:var(--container);
  margin:0 auto;
  display:grid;
  grid-template-columns:1.1fr 0.9fr;
  gap:3.5rem;
  align-items:stretch;
}
.map-embed{
  min-height:380px;
  border:1px solid var(--line);
  overflow:hidden;
}
.map-embed iframe{width:100%;height:100%;min-height:380px;}
.company-info h2{
  font-size:clamp(1.8rem, 3vw, 2.3rem);
  margin:0.3rem 0 1.6rem;
}
.info-list{
  display:flex;
  flex-direction:column;
  gap:1.1rem;
}
.info-list div{
  display:flex;
  flex-direction:column;
  gap:0.2rem;
  padding-bottom:1rem;
  border-bottom:1px solid var(--line);
}
.info-list dt{
  font-size:0.7rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--caramel);
}
.info-list dd{
  font-size:1rem;
  color:var(--espresso);
}

/* ============================================
   SCROLL REVEAL
   ============================================ */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .8s cubic-bezier(.2,.8,.2,1), transform .8s cubic-bezier(.2,.8,.2,1);
}
.reveal.in-view{
  opacity:1;
  transform:translateY(0);
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (min-width:900px){
  .hero-swirl{display:block;}
}

@media (max-width:980px){
  .story-grid{grid-template-columns:1fr;gap:3rem;}
  .story-stats{grid-template-columns:1fr 1fr;}
  .menu-grid{grid-template-columns:1fr 1fr;}
  .process{grid-template-columns:1fr;}
  .process-img{min-height:340px;}
  .process-copy{padding:4rem 2rem;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem;}

  .about-grid{grid-template-columns:1fr;gap:2.5rem;}
  .about-img{aspect-ratio:16/10;}
  .values-grid{grid-template-columns:1fr 1fr;}
  .company-strip-inner{grid-template-columns:1fr 1fr;gap:2rem;}

  .menu-section-grid,
  .menu-section.reverse .menu-section-grid{grid-template-columns:1fr;gap:2rem;}
  .menu-section.reverse .menu-section-img,
  .menu-section.reverse .menu-section-copy{order:initial;}

  .order-page-grid{grid-template-columns:1fr;gap:2.5rem;}
  .contact-grid{grid-template-columns:1fr 1fr;}
  .contact-secondary-grid{grid-template-columns:1fr;gap:2rem;}
}

@media (max-width:760px){
  .main-nav{
    position:fixed;
    top:0;right:0;
    height:100vh;
    width:min(78vw, 320px);
    background:var(--espresso);
    flex-direction:column;
    justify-content:center;
    align-items:flex-start;
    gap:2rem;
    padding:0 2.5rem;
    transform:translateX(100%);
    transition:transform .45s cubic-bezier(.2,.8,.2,1);
    z-index:1100;
  }
  .main-nav.active{transform:translateX(0);}

  /* Always force light text inside the panel — regardless of scroll state */
  .main-nav a,
  .site-header.scrolled .main-nav a{
    color:var(--cream) !important;
    font-size:1.05rem;
  }
  .main-nav a:not(.nav-cta)::after{background:var(--gold-soft);}

  /* nav-cta inside panel — always gold on dark */
  .main-nav a.nav-cta,
  .site-header.scrolled .main-nav a.nav-cta{
    background:var(--gold-soft) !important;
    color:var(--espresso) !important;
    align-self:flex-start;
  }
  .main-nav a.nav-cta:hover{background:var(--gold) !important;}

  .nav-toggle{display:flex;}
  /* Toggle stays above the nav panel */
  .nav-toggle{z-index:1200;position:relative;}

  .hero{padding:6.5rem 1.25rem 3.5rem;min-height:92vh;}
  .hero-title{font-size:clamp(2.1rem,9vw,2.8rem);}
  .hero-lede{font-size:0.95rem;}

  .story,.menu,.order{padding:4.5rem 1.25rem;}
  .story-stats{grid-template-columns:1fr 1fr;gap:0.9rem;}
  .stat-card{padding:1.4rem 1.1rem;}

  .menu-grid{grid-template-columns:1fr 1fr;gap:1rem;}
  .menu-card h3{font-size:1.05rem;margin:1.1rem 1.1rem 0.4rem;}
  .menu-card p{margin:0 1.1rem;font-size:0.85rem;}
  .menu-tag{margin:0.9rem 1.1rem 0;}

  .form-row{grid-template-columns:1fr;}

  .footer-grid{grid-template-columns:1fr;gap:2.2rem;}
  .footer-bottom{flex-direction:column;align-items:flex-start;}

  .float-cta{
    bottom:1rem;right:1rem;
    padding:0.8rem 1.2rem;
    font-size:0.7rem;
  }

  .page-hero{padding:7.5rem 1.25rem 3.5rem;}
  .page-hero h1{font-size:clamp(2rem, 8vw, 2.6rem);}

  .about-main,.values,.page-cta,.about-img + .about-copy{padding-left:1.25rem;padding-right:1.25rem;}
  .about-main{padding:4rem 1.25rem;}
  .values{padding:4rem 1.25rem 5rem;}
  .values-grid{grid-template-columns:1fr;gap:1.2rem;}
  .company-strip-inner{grid-template-columns:1fr 1fr;gap:1.5rem;}
  .page-cta{padding:4.5rem 1.25rem;}

  .menu-jump{
    top:0;
    gap:1.2rem;
    padding:0.85rem 1rem;
    overflow-x:auto;
    justify-content:flex-start;
    -webkit-overflow-scrolling:touch;
  }
  .menu-jump a{flex:0 0 auto;white-space:nowrap;}
  .menu-section{padding:3.5rem 1.25rem;}

  .order-page{padding:3.5rem 1.25rem 5rem;}
  .order-page .order-form{padding:1.6rem;}
  .sidebar-card{padding:1.8rem;}

  .contact-main{padding:3.5rem 1.25rem;}
  .contact-grid{grid-template-columns:1fr;gap:1.2rem;}
  .contact-secondary{padding:4rem 1.25rem;}
  .map-embed{min-height:280px;}
  .map-embed iframe{min-height:280px;}
}

@media (max-width:480px){
  .menu-grid{grid-template-columns:1fr;}
  .brand-text{font-size:1rem;}
  .brand-mark{width:36px;height:36px;}
}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; scroll-behavior:auto !important;}
}

/* Luxury Select Dropdown */
.form-field select{
  font-family:var(--font-body);
  font-size:0.95rem;
  padding:0.9rem 3rem 0.9rem 1rem;
  border:1px solid var(--line);
  background:var(--paper);
  color:var(--espresso);
  border-radius:var(--radius);
  outline:none;
  cursor:pointer;
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  transition:border-color .25s, box-shadow .25s;

  /* Custom Arrow */
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23c9a876' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 1rem center;
  background-size:16px;
}

.form-field select:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(201,168,118,0.18);
}

/* Dropdown options */
.form-field select option{
  background:var(--paper);
  color:var(--espresso);
  padding:12px;
}