:root{
  --cream:#F2E9D8;
  --oxblood:#6E2230;
  --oxblood-deep:#5A1A26;
  --linen:#FBF6EC;
  --espresso:#241F1B;
  --cellar:#2E3B2C;
  --cellar-deep:#243024;
  --amber:#D9A441;
  --amber-deep:#C68F2E;
  --nav-bg:#3a131d; /* deep oxblood for deli strip + notch; literal hex reused on html/body/nav */
  --maxw:1240px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{background-color:#3a131d;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background-color:#3a131d;
  padding-top:env(safe-area-inset-top,0px);
  font-family:'Newsreader',Georgia,serif;
  font-size:1.125rem;line-height:1.6;color:var(--espresso);
  background-image:none;
  overflow-x:hidden;
}
/* page surface (cream paper) sits above body bg */
.page{background:var(--cream);position:relative;z-index:1}
/* menu-card paper noise overlay */
.page::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:2;opacity:0.05;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

h1,h2,h3,h4,.display{font-family:'Hepta Slab',Georgia,serif;font-weight:800;line-height:1.0;letter-spacing:-0.01em;color:var(--espresso)}
h1{font-size:clamp(2.4rem,5.4vw,3.8rem);font-weight:900}
h2{font-size:clamp(1.9rem,3.6vw,2.6rem);font-weight:800}
h3{font-size:clamp(1.35rem,2.2vw,1.6rem);font-weight:700}
p{margin:0 0 1rem}
a{color:inherit}
.lead{font-size:clamp(1.2rem,2.2vw,1.35rem);font-style:italic;line-height:1.5}
.label{font-family:'Syne Mono',monospace;font-size:0.8rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--amber-deep)}
.ink-cream{color:var(--cream)}
img{display:block;max-width:100%}

/* ============ DELI-TICKET UTILITY STRIP (Tier 1) ============ */
.deli-strip{
  background-color:#3a131d;color:var(--cream);
  font-family:'Syne Mono',monospace;font-size:0.78rem;letter-spacing:0.08em;
  padding:9px calc(1.5rem + env(safe-area-inset-right,0px)) 9px calc(1.5rem + env(safe-area-inset-left,0px));
  display:flex;justify-content:center;align-items:center;gap:1.5rem;flex-wrap:wrap;text-align:center;
  border-bottom:1px solid rgba(217,164,65,0.25);
}
.deli-strip .amber{color:var(--amber)}
.deli-strip a{color:var(--cream);text-decoration:none;transition:color .2s ease-out}
.deli-strip a:hover{color:var(--amber)}
.deli-strip .sep{opacity:0.4}

/* ============ COUNTER HEADER (Tier 2, static) ============ */
.counter-header{
  background:var(--cream);position:relative;z-index:5;
  border-bottom:1px solid rgba(36,31,27,0.12);
}
.counter-nav{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;
  padding:1.1rem 1.5rem;
}
.nav-group{display:flex;gap:1.6rem;align-items:center}
.nav-group.left{justify-content:flex-end}
.nav-group.right{justify-content:flex-start}
.nav-group a{
  font-family:'Hepta Slab',serif;font-weight:600;font-size:0.98rem;color:var(--espresso);
  text-decoration:none;position:relative;padding:2px 0;letter-spacing:0.01em;
}
.nav-group a::after{
  content:'';position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--oxblood);
  transform:scaleX(0);transform-origin:left;transition:transform .25s ease-out;
}
.nav-group a:hover::after,.nav-group a[aria-current="page"]::after{transform:scaleX(1)}
.nav-group a[aria-current="page"]{color:var(--oxblood)}
.logo-lockup{display:flex;flex-direction:column;align-items:center;text-decoration:none;gap:4px}
.logo-lockup .seal-img{width:60px;height:60px}
.logo-lockup .wordmark{font-family:'Hepta Slab',serif;font-weight:900;font-size:1.02rem;letter-spacing:0.02em;color:var(--espresso);line-height:1;text-align:center}
.logo-lockup .sub{font-family:'Syne Mono',monospace;font-size:0.62rem;letter-spacing:0.22em;color:var(--amber-deep);text-transform:uppercase}

/* mobile expandable nav (replaces hamburger drawer) */
.mobile-toggle{display:none}
.mobile-menu{display:none}

/* ============ HERO — counter spread (3 uneven columns) ============ */
.hero{
  max-width:var(--maxw);margin:0 auto;padding:0 1.5rem;
  min-height:min(86vh,760px);display:flex;align-items:center;
}
.hero-grid{
  display:grid;grid-template-columns:1.05fr 1.25fr 0.55fr;gap:0;align-items:center;width:100%;
}
.hero-type{position:relative;z-index:3;padding:2.5rem 0;}
.hero-type .label{margin-bottom:1.2rem;display:inline-flex;align-items:center;gap:0.7rem}
.hero-type .label::before{content:'';width:36px;height:1px;background:var(--amber-deep);display:inline-block}
.hero-type h1{margin-bottom:1.4rem}
.hero-type h1 .amber{color:var(--oxblood)}
.hero-type .lead{max-width:30ch;margin-bottom:1.8rem;color:#3a322c}
.shop-inline{
  font-family:'Hepta Slab',serif;font-weight:700;font-size:1.05rem;color:var(--oxblood);
  text-decoration:none;display:inline-flex;align-items:center;gap:0.4rem;
  border-bottom:2px solid var(--oxblood);padding-bottom:3px;transition:gap .2s ease-out,border-color .2s ease-out;
}
.shop-inline:hover{gap:0.75rem;border-color:var(--amber-deep)}
.ext-ico{width:0.85em;height:0.85em;flex-shrink:0}
.hero-platter{
  position:relative;z-index:2;margin-left:-3rem;
  aspect-ratio:1/1;border-radius:50%;overflow:hidden;
  box-shadow:0 24px 60px -24px rgba(36,31,27,0.5);
  border:10px solid var(--linen);
}
.hero-platter img{width:100%;height:100%;object-fit:cover}
.hero-store{
  position:relative;z-index:1;margin-left:-1.5rem;
  aspect-ratio:9/16;max-height:480px;overflow:hidden;border-radius:6px;
  box-shadow:0 16px 36px -18px rgba(36,31,27,0.45);
}
.hero-store img{width:100%;height:100%;object-fit:cover;object-position:center}

/* ============ section scaffolding ============ */
section{position:relative}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 1.5rem}
.band{padding:7rem 0}
.band-tight{padding:4.5rem 0}
.cream{background:var(--cream)}
.linen{background:var(--linen)}
.cellar-band{background-color:var(--cellar);color:var(--cream)}
.cellar-band h1,.cellar-band h2,.cellar-band h3{color:var(--cream)}
.oxblood-band{background-color:var(--oxblood);color:var(--cream)}
.oxblood-band h1,.oxblood-band h2,.oxblood-band h3{color:var(--cream)}
.dark-noise::before{
  content:'';position:absolute;inset:0;pointer-events:none;opacity:0.07;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* wax seal motif */
.wax-seal{width:64px;height:64px;flex-shrink:0}

/* intro band */
.intro{display:grid;grid-template-columns:auto 1fr;gap:1.8rem;align-items:start;max-width:880px}
.intro p{font-size:1.3rem;line-height:1.55}
.intro .label{margin-bottom:0.8rem;display:block}

/* ============ COUNTER STRIP (signature) ============ */
.counter-strip-sec{padding:4rem 0;overflow:hidden;background:var(--cream);border-top:1px solid rgba(36,31,27,0.1);border-bottom:1px solid rgba(36,31,27,0.1)}
.counter-strip-head{max-width:var(--maxw);margin:0 auto 2rem;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:0.5rem}
.counter-strip-head .label{display:flex;align-items:center;gap:0.6rem}
.counter-strip-head .label::before{content:'';width:30px;height:1px;background:var(--amber-deep)}
.marquee{position:relative;width:100%;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.marquee-track{display:flex;gap:1.5rem;width:max-content;will-change:transform;animation:marquee 52s linear infinite;animation-play-state:paused}
.marquee.scroll-on .marquee-track{animation-play-state:running}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticket{
  flex:0 0 auto;width:248px;text-decoration:none;color:var(--espresso);
  background:var(--linen);border-radius:6px;overflow:hidden;
  border:1px solid rgba(36,31,27,0.12);box-shadow:0 8px 22px -16px rgba(36,31,27,0.4);
  display:flex;flex-direction:column;
}
.ticket-photo{position:relative;aspect-ratio:4/3;overflow:hidden}
.ticket-photo img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease-out}
.ticket-photo.swatch{display:flex;align-items:center;justify-content:center;background:var(--cellar)}
.ticket:hover .ticket-photo img{transform:scale(1.03)}
.ticket-seal{position:absolute;top:8px;right:8px;width:38px;height:38px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transition:filter .25s ease-out}
.ticket:hover .ticket-seal{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3)) brightness(0.86)}
.ticket-body{padding:0.9rem 1rem 1.05rem}
.ticket-body .cat{font-family:'Hepta Slab',serif;font-weight:800;font-size:1.18rem;line-height:1.05;margin-bottom:0.35rem}
.ticket-body .tag{font-family:'Syne Mono',monospace;font-size:0.7rem;letter-spacing:0.06em;color:var(--amber-deep);text-transform:uppercase}

/* ============ Plan a platter band ============ */
.platter-band{position:relative;overflow:hidden;text-align:center;padding:6rem 0}
.platter-band .wrap{position:relative;z-index:3;display:flex;flex-direction:column;align-items:center}
.platter-band .label{color:var(--amber);margin-bottom:1rem}
.platter-band h2{max-width:18ch;margin:0 auto 1.3rem}
.platter-band p{max-width:54ch;margin:0 auto 2rem;color:rgba(242,233,216,0.9);font-size:1.2rem}
.platter-wheel{
  width:118px;height:118px;border-radius:50%;overflow:hidden;margin:0 auto 2rem;
  border:6px solid rgba(242,233,216,0.85);box-shadow:0 16px 40px -16px rgba(0,0,0,.5);
  transform:rotate(-12deg);transition:transform .8s cubic-bezier(.16,.84,.44,1);
}
.platter-wheel img{width:100%;height:100%;object-fit:cover}
.reveal.in .platter-wheel{transform:rotate(0deg)}

/* ============ buttons / CTAs ============ */
.btn{
  display:inline-flex;align-items:center;gap:0.5rem;
  font-family:'Hepta Slab',serif;font-weight:700;font-size:1rem;letter-spacing:0.01em;
  text-decoration:none;padding:0.95rem 1.7rem;border-radius:4px;cursor:pointer;border:none;
  transition:background-color .2s ease-out,transform .1s ease-out,color .2s ease-out;
}
.btn-oxblood{background-color:var(--oxblood);color:var(--cream)}
.btn-oxblood:hover{background-color:var(--oxblood-deep)}
.btn-oxblood:active{transform:translateY(1px)}
.btn-amber{background-color:var(--amber);color:var(--espresso)}
.btn-amber:hover{background-color:var(--amber-deep)}
.btn-amber:active{transform:translateY(1px)}
.btn-cream{background-color:var(--cream);color:var(--oxblood)}
.btn-cream:hover{background-color:#fff}
.btn-outline-cream{background:transparent;color:var(--cream);border:1.5px solid rgba(242,233,216,0.6)}
.btn-outline-cream:hover{background:rgba(242,233,216,0.12);border-color:var(--cream)}
:focus-visible{outline:3px solid var(--amber);outline-offset:3px;border-radius:2px}

/* ============ Meet Heather strip ============ */
.heather{display:grid;grid-template-columns:0.85fr 1.15fr;gap:3.5rem;align-items:center}
.heather-photo{aspect-ratio:4/5;max-height:560px;overflow:hidden;border-radius:6px;box-shadow:0 20px 48px -22px rgba(36,31,27,0.5)}
.heather-photo img{width:100%;height:100%;object-fit:cover;object-position:60% center}
.heather .label{display:flex;align-items:center;gap:0.6rem;margin-bottom:1rem}
.heather .label::before{content:'';width:30px;height:1px;background:var(--amber-deep)}
.heather blockquote{
  font-family:'Hepta Slab',serif;font-weight:600;font-size:1.5rem;line-height:1.2;
  color:var(--oxblood);margin:1.4rem 0;padding-left:1.2rem;border-left:3px solid var(--amber);
}
.heather .link-more{margin-top:1.4rem;display:inline-block}

/* ============ Classes teaser ============ */
.class-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:start}
.class-tile{
  background:var(--linen);border-radius:6px;padding:1.8rem;border:1px solid rgba(36,31,27,0.12);
  border-top:4px solid var(--oxblood);
}
.class-tile:nth-child(2){border-top-color:var(--cellar);margin-top:1.5rem}
.class-tile:nth-child(3){border-top-color:var(--amber-deep)}
.class-tile .num{font-family:'Syne Mono',monospace;font-size:0.72rem;color:var(--amber-deep);letter-spacing:0.1em}
.class-tile h3{margin:0.6rem 0 0.7rem}
.class-tile p{font-size:1rem;margin-bottom:0}

/* ============ Reviews line ============ */
.reviews{text-align:center}
.stars{font-family:'Hepta Slab',serif;font-weight:900;font-size:clamp(2.6rem,6vw,4rem);color:var(--amber);line-height:1}
.reviews .sub{font-family:'Syne Mono',monospace;font-size:0.85rem;letter-spacing:0.1em;color:rgba(242,233,216,0.8);text-transform:uppercase;margin:0.6rem 0 2.5rem}
.review-quotes{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;max-width:880px;margin:0 auto}
.review-q{
  background:rgba(242,233,216,0.06);border:1px solid rgba(242,233,216,0.18);border-radius:6px;
  padding:1.6rem 1.7rem;text-align:left;position:relative;
}
.review-q p{font-family:'Newsreader',serif;font-style:italic;font-size:1.15rem;color:var(--cream);margin-bottom:0.7rem}
.review-q .by{font-family:'Syne Mono',monospace;font-size:0.7rem;letter-spacing:0.08em;color:var(--amber);text-transform:uppercase}

/* ============ FOOTER — oversized visit block + thin legal strip ============ */
.footer-visit{background-color:var(--cellar);color:var(--cream);position:relative;overflow:hidden;padding:5.5rem 0 4rem}
.footer-visit .wrap{position:relative;z-index:3}
.fv-top{display:flex;align-items:center;gap:1.1rem;margin-bottom:2.2rem}
.fv-top .wax-seal{width:58px;height:58px}
.fv-top h2{font-size:clamp(2.2rem,5vw,3.3rem);margin:0}
.fv-grid{display:grid;grid-template-columns:1fr 1fr 1.2fr;gap:3rem}
.fv-col .label{color:var(--amber);display:block;margin-bottom:0.9rem}
.fv-col address{font-style:normal;font-size:1.15rem;line-height:1.6}
.fv-col a{color:var(--cream);text-decoration:none;border-bottom:1px solid rgba(242,233,216,0.3);transition:border-color .2s ease-out,color .2s ease-out}
.fv-col a:hover{color:var(--amber);border-color:var(--amber)}
.hours-table{width:100%;border-collapse:collapse;font-size:1.02rem}
.hours-table td{padding:0.32rem 0;border-bottom:1px solid rgba(242,233,216,0.14)}
.hours-table td:last-child{text-align:right;font-family:'Syne Mono',monospace;font-size:0.85rem;color:rgba(242,233,216,0.9)}
.hours-table tr.closed td{color:rgba(242,233,216,0.55)}
.fv-map{width:100%;height:100%;min-height:240px;border:0;border-radius:6px;filter:saturate(0.9) contrast(0.95);box-shadow:0 14px 32px -16px rgba(0,0,0,.5)}
.fv-links{display:flex;flex-wrap:wrap;gap:0.5rem 1.4rem;margin-top:1.1rem;font-family:'Syne Mono',monospace;font-size:0.82rem;letter-spacing:0.04em}
.fv-links a{display:inline-flex;align-items:center;gap:0.3rem}
.legal-strip{
  background-color:#243024;color:rgba(242,233,216,0.7);
  font-family:'Syne Mono',monospace;font-size:0.74rem;letter-spacing:0.04em;
  padding:1.1rem calc(1.5rem + env(safe-area-inset-right,0px)) calc(1.1rem + env(safe-area-inset-bottom,0px)) calc(1.5rem + env(safe-area-inset-left,0px));
  display:flex;justify-content:center;align-items:center;gap:1rem;flex-wrap:wrap;text-align:center;
}
.legal-strip a{color:rgba(242,233,216,0.85);text-decoration:underline;text-underline-offset:2px}
.legal-strip a:hover{color:var(--amber)}

/* ============ MOBILE BOTTOM ACTION BAR ============ */
.bottom-bar{display:none}

/* ============ scroll reveal ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .5s ease-out,transform .5s ease-out}
.reveal.in{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .marquee-track{animation:none}
  html{scroll-behavior:auto}
}

/* ===================== RESPONSIVE ===================== */
@media (max-width:1024px){
  .hero-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:1.5rem 2rem;align-items:center}
  .hero-type{grid-column:1/3;padding-bottom:0}
  .hero-platter{margin-left:0;aspect-ratio:4/3;border-radius:8px}
  .hero-store{margin-left:0;aspect-ratio:3/4;max-height:none}
  .heather{gap:2.5rem}
  .fv-grid{grid-template-columns:1fr 1fr;gap:2.2rem}
  .fv-map-col{grid-column:1/3}
}
@media (max-width:768px){
  .deli-strip{font-size:0.7rem;gap:0.8rem;padding-left:1rem;padding-right:1rem}
  .deli-strip .hide-sm{display:none}
  .counter-nav{grid-template-columns:1fr auto 1fr;padding:0.8rem 1rem}
  .nav-group.left,.nav-group.right{display:none}
  .mobile-toggle{
    display:flex;align-items:center;gap:0.4rem;justify-self:start;
    background:none;border:none;cursor:pointer;font-family:'Syne Mono',monospace;
    font-size:0.72rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--espresso);padding:0.4rem;
  }
  .mobile-toggle .bars{display:flex;flex-direction:column;gap:3px}
  .mobile-toggle .bars span{width:18px;height:2px;background:var(--espresso);transition:transform .2s ease-out,opacity .2s ease-out}
  .mobile-toggle[aria-expanded="true"] .bars span:nth-child(1){transform:translateY(5px) rotate(45deg)}
  .mobile-toggle[aria-expanded="true"] .bars span:nth-child(2){opacity:0}
  .mobile-toggle[aria-expanded="true"] .bars span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}
  .logo-lockup .seal-img{width:48px;height:48px}
  .logo-lockup .wordmark{font-size:0.9rem}
  .mobile-menu{
    display:block;max-height:0;overflow:hidden;background:var(--linen);
    transition:max-height .3s ease-out;border-bottom:1px solid rgba(36,31,27,0.12);
  }
  .mobile-menu.open{max-height:340px}
  .mobile-menu a{
    display:block;padding:0.85rem 1.5rem;font-family:'Hepta Slab',serif;font-weight:600;
    font-size:1.05rem;color:var(--espresso);text-decoration:none;border-bottom:1px solid rgba(36,31,27,0.08);
  }
  .mobile-menu a[aria-current="page"]{color:var(--oxblood)}
  .hero{min-height:0;padding-top:2.5rem;padding-bottom:2rem}
  .hero-grid{grid-template-columns:1fr;gap:1.5rem}
  .hero-type{grid-column:1;padding:0}
  .hero-platter{aspect-ratio:16/9;border-width:6px}
  .hero-store{aspect-ratio:4/5;max-height:420px}
  .band{padding:4rem 0}
  .band-tight{padding:3rem 0}
  .intro{grid-template-columns:1fr;gap:1rem}
  .intro p{font-size:1.15rem}
  .heather{grid-template-columns:1fr;gap:1.8rem}
  .heather-photo{aspect-ratio:4/3;max-height:380px}
  .class-tiles{grid-template-columns:1fr}
  .class-tile:nth-child(2){margin-top:0}
  .review-quotes{grid-template-columns:1fr}
  .fv-grid{grid-template-columns:1fr;gap:2rem}
  .fv-map-col{grid-column:1}
  .platter-band{padding:4.5rem 0}
  /* bottom bar */
  .bottom-bar{
    display:grid;grid-template-columns:repeat(3,1fr);
    position:fixed;left:0;right:0;bottom:0;z-index:50;
    background-color:#3a131d;
    border-top:1px solid rgba(217,164,65,0.3);
    padding-bottom:env(safe-area-inset-bottom,0px);
  }
  .bottom-bar a{
    display:flex;flex-direction:column;align-items:center;gap:3px;
    padding:0.7rem 0.4rem;text-decoration:none;color:var(--cream);
    font-family:'Syne Mono',monospace;font-size:0.68rem;letter-spacing:0.06em;text-transform:uppercase;
  }
  .bottom-bar a:not(:last-child){border-right:1px solid rgba(217,164,65,0.2)}
  .bottom-bar a svg{width:20px;height:20px;stroke:var(--amber)}
  .bottom-bar a:active{background:rgba(217,164,65,0.12)}
  body{padding-bottom:0}
  .has-bottom-bar{padding-bottom:64px}
  .ticket{width:212px}
}
@media (max-width:480px){
  .ticket{width:188px}
  .stars{font-size:2.6rem}
  .fv-top h2{font-size:1.9rem}
}

/* ===================== SUBPAGE SHARED ===================== */
.page-head{max-width:760px}
.page-head .label{display:inline-flex;align-items:center;gap:0.6rem;margin-bottom:1rem}
.page-head .label::before{content:'';width:30px;height:1px;background:var(--amber-deep);display:inline-block}
.page-head h1{margin-bottom:1.2rem}
.page-head .lead{max-width:56ch;color:#3a322c}

/* ---- cheese editorial counter rows (1px rule lines = tasting-card) ---- */
.cheese-rows .wrap{display:flex;flex-direction:column}
.cheese-row{
  display:grid;grid-template-columns:0.9fr 1.1fr;gap:3rem;align-items:center;
  padding:2.6rem 0;border-bottom:1px solid rgba(36,31,27,0.16);
}
.cheese-row:first-child{border-top:1px solid rgba(36,31,27,0.16)}
.cheese-row.flip .cr-photo{order:2}
.cheese-row.flip .cr-body{order:1}
.cr-photo{aspect-ratio:5/4;overflow:hidden;border-radius:6px;box-shadow:0 16px 38px -20px rgba(36,31,27,0.45)}
.cr-photo img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .4s ease-out}
.cr-body .label{display:block;margin-bottom:0.7rem}
.cr-body h2{margin-bottom:0.7rem}
.cr-body p{font-size:1.12rem;max-width:46ch;margin-bottom:1rem}
.cr-tag{font-family:'Syne Mono',monospace;font-size:0.74rem;letter-spacing:0.08em;color:var(--amber-deep);text-transform:uppercase;border:1px solid rgba(217,164,65,0.5);border-radius:3px;padding:4px 9px;display:inline-block}

/* ---- accompaniments ---- */
.accomp .label{display:inline-flex;align-items:center;gap:0.6rem;margin-bottom:0.7rem}
.accomp .label::before{content:'';width:30px;height:1px;background:var(--amber-deep);display:inline-block}
.accomp h2{margin-bottom:1.6rem}
.accomp-list{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:0.6rem 2.5rem;max-width:760px}
.accomp-list li{font-family:'Syne Mono',monospace;font-size:0.92rem;letter-spacing:0.02em;padding:0.6rem 0;border-bottom:1px dashed rgba(36,31,27,0.22);color:var(--espresso)}

/* ---- inline CTA ---- */
.inline-cta{text-align:center;max-width:640px;margin:0 auto}
.inline-cta h2{margin-bottom:0.8rem}
.inline-cta p{font-size:1.2rem;margin-bottom:1.6rem;color:#3a322c}
.cta-pair{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap}

/* ---- platters page ---- */
.platter-hero{display:grid;grid-template-columns:1.1fr 0.9fr;gap:3rem;align-items:center}
.platter-hero-photo{aspect-ratio:1/1;border-radius:50%;overflow:hidden;border:10px solid var(--linen);box-shadow:0 24px 60px -24px rgba(36,31,27,0.5)}
.platter-hero-photo img{width:100%;height:100%;object-fit:cover}
.platter-hero .label{display:inline-flex;align-items:center;gap:0.6rem;margin-bottom:1rem}
.platter-hero .label::before{content:'';width:30px;height:1px;background:var(--amber-deep);display:inline-block}
.platter-hero blockquote{font-family:'Newsreader',serif;font-style:italic;font-size:1.3rem;line-height:1.5;color:var(--oxblood);margin-top:1.3rem;padding-left:1.2rem;border-left:3px solid var(--amber)}
.platter-hero blockquote cite{display:block;font-family:'Syne Mono',monospace;font-style:normal;font-size:0.72rem;letter-spacing:0.06em;color:var(--amber-deep);text-transform:uppercase;margin-top:0.8rem}
.howto{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;counter-reset:step}
.howto-step{position:relative;padding-top:1.4rem;border-top:3px solid var(--oxblood)}
.howto-step:nth-child(2){border-top-color:var(--cellar)}
.howto-step:nth-child(3){border-top-color:var(--amber-deep)}
.howto-step .step-n{font-family:'Hepta Slab',serif;font-weight:900;font-size:2.6rem;color:var(--amber-deep);line-height:1;display:block;margin-bottom:0.5rem}
.howto-step h3{margin-bottom:0.6rem}
.howto-step p{font-size:1.05rem;margin-bottom:0}
.policy-panel{background:var(--linen);border:1px solid rgba(36,31,27,0.14);border-left:4px solid var(--amber);border-radius:6px;padding:1.8rem 2rem;max-width:760px}
.policy-panel .label{display:block;margin-bottom:0.7rem}
.policy-panel p{font-family:'Syne Mono',monospace;font-size:0.95rem;line-height:1.7;letter-spacing:0.01em;color:var(--espresso);margin-bottom:0}
/* form */
.inquiry-form{max-width:760px;display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.inquiry-form .full{grid-column:1/3}
.field{display:flex;flex-direction:column;gap:0.4rem}
.field label{font-family:'Syne Mono',monospace;font-size:0.74rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--amber-deep)}
.field input,.field select,.field textarea{
  font-family:'Newsreader',serif;font-size:1.05rem;padding:0.8rem 0.9rem;
  border:1px solid rgba(36,31,27,0.25);border-radius:4px;background:var(--linen);color:var(--espresso);
  transition:border-color .2s ease-out;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--oxblood);outline:none}
.field textarea{resize:vertical;min-height:110px}
.inquiry-form button{justify-self:start}
/* gifts mini */
.gifts{display:grid;grid-template-columns:0.9fr 1.1fr;gap:3rem;align-items:center}
.gifts-photo{aspect-ratio:5/4;overflow:hidden;border-radius:6px;box-shadow:0 16px 38px -20px rgba(36,31,27,0.45)}
.gifts-photo img{width:100%;height:100%;object-fit:cover}
.gifts .label{display:inline-flex;align-items:center;gap:0.6rem;margin-bottom:1rem}
.gifts .label::before{content:'';width:30px;height:1px;background:var(--amber-deep);display:inline-block}

/* ---- about page ---- */
.about-hero{display:grid;grid-template-columns:0.8fr 1.2fr;gap:3rem;align-items:center}
.about-hero-photo{aspect-ratio:3/4;max-height:560px;overflow:hidden;border-radius:6px;box-shadow:0 20px 48px -22px rgba(36,31,27,0.5)}
.about-hero-photo img{width:100%;height:100%;object-fit:cover;object-position:60% center}
.about-hero .label{display:inline-flex;align-items:center;gap:0.6rem;margin-bottom:1rem}
.about-hero .label::before{content:'';width:30px;height:1px;background:var(--amber-deep);display:inline-block}
.story{max-width:680px;margin:0 auto}
.story p{font-size:1.18rem;line-height:1.7;margin-bottom:1.4rem}
.story .pull{
  font-family:'Hepta Slab',serif;font-weight:700;font-size:clamp(1.6rem,3vw,2.1rem);line-height:1.15;
  color:var(--oxblood);margin:2.4rem 0;text-align:center;
}
.apart{max-width:760px;margin:0 auto;display:grid;gap:1.6rem}
.apart blockquote{font-family:'Newsreader',serif;font-style:italic;font-size:1.3rem;line-height:1.5;color:var(--espresso);padding-left:1.3rem;border-left:3px solid var(--amber)}
.apart blockquote cite{display:block;font-family:'Syne Mono',monospace;font-style:normal;font-size:0.72rem;letter-spacing:0.06em;color:var(--amber-deep);text-transform:uppercase;margin-top:0.7rem}
.picks{max-width:680px;margin:0 auto}
.picks .label{display:block;margin-bottom:1rem}
.pick{padding:1.3rem 0;border-bottom:1px solid rgba(36,31,27,0.16)}
.pick:first-of-type{border-top:1px solid rgba(36,31,27,0.16)}
.pick h3{margin-bottom:0.4rem}
.pick p{font-size:1.08rem;font-style:italic;margin-bottom:0;color:#3a322c}

/* ---- classes page ---- */
.class-page-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;align-items:start}
.class-page-tiles .class-tile{display:flex;flex-direction:column}
.class-page-tiles .class-tile .book{margin-top:1.2rem}
.private-line{background:var(--linen);border:1px solid rgba(36,31,27,0.14);border-radius:6px;padding:2rem 2.2rem;max-width:820px;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap}
.private-line .label{display:block;margin-bottom:0.4rem}
.private-line h3{margin-bottom:0.2rem}

/* ---- visit page ---- */
.visit-hero{display:grid;grid-template-columns:1.1fr 0.9fr;gap:3rem;align-items:center}
.visit-hero-photo{aspect-ratio:3/4;max-height:520px;overflow:hidden;border-radius:6px;box-shadow:0 20px 48px -22px rgba(36,31,27,0.5)}
.visit-hero-photo img{width:100%;height:100%;object-fit:cover}
.visit-hero .label{display:inline-flex;align-items:center;gap:0.6rem;margin-bottom:1rem}
.visit-hero .label::before{content:'';width:30px;height:1px;background:var(--amber-deep);display:inline-block}
.nap-block{background-color:var(--cellar);color:var(--cream);border-radius:8px;padding:2.6rem;display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
.nap-block .label{color:var(--amber);display:block;margin-bottom:0.8rem}
.nap-block address{font-style:normal;font-size:1.25rem;line-height:1.7}
.nap-block a{color:var(--cream);text-decoration:none;border-bottom:1px solid rgba(242,233,216,0.3)}
.nap-block a:hover{color:var(--amber);border-color:var(--amber)}
.nap-block .note{font-size:1.02rem;color:rgba(242,233,216,0.85);margin-top:1rem}
.visit-map{width:100%;height:420px;border:0;border-radius:8px;filter:saturate(0.92) contrast(0.96);box-shadow:0 16px 40px -18px rgba(36,31,27,0.4)}
.downtown{max-width:680px}
.downtown .visit-links{display:flex;flex-wrap:wrap;gap:0.8rem 1.8rem;margin-top:1.4rem;font-family:'Syne Mono',monospace;font-size:0.86rem;letter-spacing:0.04em}
.downtown .visit-links a{display:inline-flex;align-items:center;gap:0.3rem;color:var(--oxblood);text-decoration:none;border-bottom:2px solid var(--oxblood);padding-bottom:2px}
.downtown .visit-links a:hover{border-color:var(--amber-deep)}

/* ===================== SUBPAGE RESPONSIVE ===================== */
@media (max-width:1024px){
  .platter-hero,.about-hero,.visit-hero,.gifts{grid-template-columns:1fr 1fr;gap:2.2rem}
  .nap-block{grid-template-columns:1fr;gap:1.8rem}
}
@media (max-width:768px){
  .cheese-row,.cheese-row.flip{grid-template-columns:1fr;gap:1.4rem}
  .cheese-row.flip .cr-photo{order:1}
  .cheese-row.flip .cr-body{order:2}
  .cr-photo{aspect-ratio:16/10;max-height:300px}
  .cr-body p{max-width:none}
  .accomp-list{grid-template-columns:1fr}
  .platter-hero,.about-hero,.visit-hero,.gifts{grid-template-columns:1fr;gap:1.6rem}
  .platter-hero-photo{aspect-ratio:16/10;border-radius:8px;border-width:6px}
  .about-hero-photo,.visit-hero-photo{aspect-ratio:4/3;max-height:380px}
  .gifts-photo{aspect-ratio:16/10}
  .howto{grid-template-columns:1fr;gap:1.6rem}
  .inquiry-form{grid-template-columns:1fr}
  .inquiry-form .full{grid-column:1}
  .class-page-tiles{grid-template-columns:1fr}
  .class-page-tiles .class-tile:nth-child(2){margin-top:0}
  .private-line{flex-direction:column;align-items:flex-start}
  .cta-pair{flex-direction:column;gap:1rem;align-items:center}
  .story .pull{font-size:1.5rem}
}
