
:root{
  --cream:#fff8ea; --paper:#fffdf7; --ink:#3b2015; --muted:#765342; --accent:#8e3b24; --accent2:#c78948; --line:#ead7bf; --shadow:0 18px 50px rgba(69,34,14,.14);
}
*{box-sizing:border-box} body{margin:0;font-family:Georgia,'Times New Roman',serif;background:var(--cream);color:var(--ink);line-height:1.55} a{color:inherit} img{max-width:100%;display:block}
.site-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px 5vw;background:rgba(255,248,234,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}.brand img{width:74px;max-height:54px;object-fit:contain}.brand-mark{display:grid;place-items:center;width:46px;height:46px;border-radius:50%;background:var(--accent);color:white;font-weight:bold}.brand strong{display:block;font-size:1.18rem}.brand small{display:block;color:var(--muted);font-size:.8rem;letter-spacing:.04em;text-transform:uppercase}
.site-header nav{display:flex;align-items:center;gap:18px}.site-header nav a{text-decoration:none;font-weight:700}.site-header nav .call{padding:10px 16px;border-radius:999px;background:var(--accent);color:white}.nav-toggle{display:none;background:none;border:0;font-size:1.8rem;color:var(--ink)}
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;min-height:72vh;padding:70px 5vw 46px;background:linear-gradient(135deg,#fff8ea 0%,#f6dfbd 100%)}.hero h1{font-size:clamp(2.5rem,6vw,5.5rem);line-height:.96;margin:10px 0 18px}.lead{font-size:1.2rem;color:var(--muted);max-width:62ch}.eyebrow{margin:0;color:var(--accent);font-weight:800;text-transform:uppercase;letter-spacing:.13em;font-size:.78rem}.hero-image img,.feature-image img,.visit-card img{width:100%;height:100%;object-fit:cover;border-radius:28px;box-shadow:var(--shadow)}.hero-image{min-height:420px}.hero-image img{min-height:420px}
.actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}.button{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--accent);padding:12px 18px;border-radius:999px;text-decoration:none;font-weight:800;background:transparent}.button.primary{background:var(--accent);color:white}.text-link{font-weight:800;color:var(--accent);text-decoration:none}
.section{padding:64px 5vw}.section-title{max-width:850px;margin:0 auto 30px;text-align:center}.section-title h2{font-size:clamp(2rem,4vw,3.4rem);line-height:1.05;margin:8px 0}.section-title p{color:var(--muted)}
.menu-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.menu-card{background:var(--paper);border:1px solid var(--line);border-radius:24px;overflow:hidden;text-decoration:none;box-shadow:0 10px 28px rgba(69,34,14,.08);transition:.2s transform,.2s box-shadow}.menu-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.menu-card img{height:160px;width:100%;object-fit:cover}.menu-card span{display:block;padding:16px 16px 2px;font-size:1.25rem;font-weight:900}.menu-card small{display:block;padding:0 16px 18px;color:var(--muted)}
.split,.feature,.visit-card{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center}.split h2,.feature h2,.visit-card h2{font-size:clamp(2rem,4vw,3.5rem);line-height:1.05;margin:10px 0}.split p,.feature p,.visit-card p{color:var(--muted);font-size:1.08rem}.photo-pair{display:grid;grid-template-columns:1fr 1fr;gap:14px}.photo-pair img{height:360px;width:100%;object-fit:cover;border-radius:24px;box-shadow:var(--shadow)}.photo-pair img:nth-child(2){margin-top:42px}.feature{background:#f3dfc5}.feature-image img{height:430px}.visit-card{background:var(--paper);margin:64px 5vw;border-radius:30px;padding:28px;box-shadow:var(--shadow)}.visit-card.section{padding:28px}.visit-card img{height:360px}.hours{list-style:none;padding:0;margin:16px 0 0}.hours li{display:flex;justify-content:space-between;gap:18px;border-bottom:1px solid var(--line);padding:8px 0}.hours span{color:var(--muted)}
.page-hero{text-align:center;padding:76px 5vw 30px;background:linear-gradient(135deg,#fff8ea,#f0d1a8)}.page-hero h1{font-size:clamp(2.6rem,7vw,5.5rem);line-height:.95;margin:12px 0}.page-hero p{max-width:720px;margin:0 auto;color:var(--muted);font-size:1.15rem}.page-hero .actions{justify-content:center}.item-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.item-card{margin:0;background:var(--paper);border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:0 10px 28px rgba(69,34,14,.08)}.item-card img{height:230px;width:100%;object-fit:contain;background:#fff;padding:8px;box-sizing:border-box}.item-card figcaption{padding:14px 16px;font-weight:900;font-size:1.08rem}.empty{text-align:center;color:var(--muted)}
.footer{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:28px;background:#2b160f;color:#fff8ea;padding:48px 5vw 68px;position:relative}.footer p,.footer span{color:#ead7bf}.footer a{color:#fff8ea}.footer .hours li{border-color:rgba(255,255,255,.18)}
@media(max-width:950px){.hero,.split,.feature,.visit-card,.footer{grid-template-columns:1fr}.menu-grid,.item-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.hero{min-height:auto}.site-header nav{display:none;position:absolute;left:0;right:0;top:100%;padding:18px 5vw;background:var(--cream);border-bottom:1px solid var(--line);flex-direction:column;align-items:flex-start}.site-header nav.open{display:flex}.nav-toggle{display:block}}
@media(max-width:560px){.menu-grid,.item-grid{grid-template-columns:1fr}.hero,.section{padding-left:18px;padding-right:18px}.visit-card{margin-left:18px;margin-right:18px}.item-card img,.menu-card img{height:190px}.photo-pair{grid-template-columns:1fr}.photo-pair img:nth-child(2){margin-top:0}.brand img{width:58px}}


/* v8: show the full shop exterior photo instead of cropping it */
.visit-card{grid-template-columns:minmax(300px,.85fr) 1fr;}
.visit-card .shop-photo{background:#fff7e8;border-radius:28px;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.visit-card .shop-photo img{width:100%;height:auto;max-height:560px;object-fit:contain;border-radius:28px;box-shadow:none;}
.visit-card h2{font-size:clamp(2rem,3.4vw,3.9rem);overflow-wrap:normal;}
@media(max-width:950px){.visit-card{grid-template-columns:1fr}.visit-card .shop-photo img{max-height:none;}}

/* v9: show the bakers' full faces in the tradition section */
.photo-pair img{
  height:440px;
  object-fit:contain;
  object-position:center top;
  background:#fff7e8;
  padding:0;
}
@media(max-width:950px){
  .photo-pair img{height:auto;max-height:560px;object-fit:contain;}
}

/* v11: show the full dessert/menu photos instead of cropping/zooming them */
.item-card img{
  height:260px;
  width:100%;
  object-fit:contain;
  object-position:center center;
  background:#fff7e8;
  padding:8px;
}
.menu-card img{
  height:190px;
  width:100%;
  object-fit:contain;
  object-position:center center;
  background:#fff7e8;
  padding:8px;
}
@media(max-width:560px){
  .item-card img,.menu-card img{height:230px;}
}

/* v12: add the new baker photo with the other bakers in one full-width tradition image */
.bakers-trio{
  background:#fff7e8;
  border-radius:28px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.bakers-trio img{
  width:100%;
  height:auto;
  display:block;
  object-fit:contain;
  object-position:center center;
}
@media(max-width:950px){
  .bakers-trio img{max-height:none;}
}


/* v13: use one full family photo for the family tradition section */
.tradition-section{
  display:block;
}
.tradition-copy{
  max-width:850px;
  margin:0 auto 28px;
  text-align:center;
}
.tradition-copy h2{
  font-size:clamp(2rem,4vw,3.5rem);
  line-height:1.05;
  margin:10px 0;
}
.tradition-copy p{
  color:var(--muted);
  font-size:1.08rem;
}
.tradition-section .bakers-trio{
  max-width:1500px;
  margin:0 auto;
}
.tradition-section .bakers-trio img{
  width:100%;
  height:auto;
  object-fit:contain;
  object-position:center center;
}


/* v17: keep all existing menu cards; add Frozen Foods; show full menu item photos */
.food-grid .menu-item-card img,
.menu-page .menu-item-card img {
  object-fit: contain !important;
  background: #fffaf0;
  padding: 8px;
}

.menu-card p {
  margin: 0.45rem 0 0;
  font-size: 0.95rem;
  line-height: 1.45;
  opacity: 0.82;
}


/* v18: uniform Frozen Foods menu layout */
.frozen-food-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
  gap: 1.4rem !important;
  align-items: stretch !important;
  max-width: 1180px;
  margin: 0 auto 4rem !important;
  padding: 0 1.25rem;
}

.frozen-food-grid .menu-item-card {
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  border-radius: 18px !important;
  background: #fffaf0 !important;
  border: 1px solid rgba(69, 39, 28, 0.12) !important;
  box-shadow: 0 14px 35px rgba(69, 39, 28, 0.08) !important;
  min-height: 315px !important;
}

.frozen-food-grid .menu-item-card img {
  width: 100% !important;
  height: 220px !important;
  object-fit: contain !important;
  object-position: center !important;
  background: #fff !important;
  padding: 14px !important;
  display: block !important;
}

.frozen-food-grid .menu-item-card h2 {
  min-height: 70px !important;
  display: flex !important;
  align-items: center !important;
  margin: 0 !important;
  padding: 1rem 1.1rem !important;
  font-size: 1.15rem !important;
  line-height: 1.25 !important;
}

@media (min-width: 1000px) {
  .frozen-food-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}


/* v19: prevent Explore Our Menu card descriptions from being clipped */
.menu-card {
  height: auto !important;
  min-height: 360px !important;
  overflow: visible !important;
}

.menu-card img {
  flex-shrink: 0 !important;
}

.menu-card span,
.menu-card h3 {
  flex-shrink: 0 !important;
}

.menu-card p {
  display: block !important;
  overflow: visible !important;
  white-space: normal !important;
  padding-bottom: 1rem !important;
}


/* v26: header cleanup and tighter Explore Our Menu card descriptions */
.menu-card{
  display:flex !important;
  flex-direction:column !important;
  min-height:360px !important;
  height:auto !important;
}
.menu-card small,
.menu-card p{
  display:block !important;
  padding:0 16px 20px !important;
  margin:0 !important;
  color:var(--muted) !important;
  font-size:.95rem !important;
  line-height:1.45 !important;
  overflow:visible !important;
  white-space:normal !important;
}


/* v27: menu size guides, catering, and banquet pages */
.menu-guide-card{
  max-width: 980px;
  margin: 0 auto 28px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 20px;
  box-shadow: 0 10px 28px rgba(69,34,14,.08);
  padding: 14px;
}
.menu-guide-card img{
  width: 100%;
  height: auto;
  object-fit: contain;
  background: #fff;
  border-radius: 12px;
}
.menu-image-wrap{
  max-width: 980px;
  margin: 0 auto 28px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--shadow);
  padding: 16px;
}
.menu-image-wrap img{
  width:100%;
  height:auto;
  object-fit:contain;
  border-radius:16px;
  background:#fff;
}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  max-width:1180px;
  margin:0 auto;
}
.gallery-grid figure{
  margin:0;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 10px 28px rgba(69,34,14,.08);
}
.gallery-grid img{
  width:100%;
  height:260px;
  object-fit:cover;
}
.gallery-grid figcaption{
  padding:12px 16px;
  font-weight:900;
}
@media(max-width:950px){.gallery-grid{grid-template-columns:1fr}.gallery-grid img{height:auto}}


/* v28: subtle designer credit */
/* v29: social media links */
.social-links{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
}
.social-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:7px 12px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:999px;
  text-decoration:none;
  font-weight:800;
  font-size:.92rem;
  color:#fff8ea;
  background:rgba(255,255,255,.06);
}
.visit-card .social-links{
  margin-top:18px;
}
.visit-card .social-link{
  border-color:var(--line);
  color:var(--accent);
  background:#fff8ea;
}
.footer .social-links{
  margin-top:12px;
}
/* v31: crisp centered grinder size guide — HTML text, not raster image */
.grinder-size-card{
  max-width: 560px;
  margin: 0 auto 30px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: 0 10px 28px rgba(69,34,14,.08);
  padding: 18px 20px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  align-items: baseline;
  text-align: center;
  filter: none !important;
  transform: none !important;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}
.grinder-size-card strong,
.grinder-size-card span{
  font-family: Georgia, 'Times New Roman', serif;
  color: var(--ink);
  line-height: 1.05;
  letter-spacing: .01em;
  text-shadow: none !important;
  filter: none !important;
}
.grinder-size-card strong{
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 900;
}
.grinder-size-card span{
  font-size: clamp(1.65rem, 3.2vw, 2.45rem);
  font-weight: 900;
}
.footer-qr{
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 8px;
  padding-top: 22px;
  border-top: 1px solid rgba(255,255,255,.16);
  text-align: center;
}
.footer-qr img{
  width: 92px;
  height: 92px;
  border-radius: 12px;
  background: #fff8ea;
  padding: 6px;
}
.footer-qr span{
  font-size: .78rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .65;
}
@media(max-width:560px){
  .grinder-size-card{padding: 20px 14px;}
  .footer-qr img{width:82px;height:82px;}
}


/* v31: crisp centered pizza size guide */
.pizza-size-card{
  max-width: 920px;
  margin: 0 auto 30px;
  background: #fffdf7;
  border: 1px solid var(--line);
  border-radius: 20px;
  box-shadow: 0 10px 28px rgba(69,34,14,.08);
  padding: 12px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  overflow: hidden;
  text-align: center;
}
.pizza-size-cell{
  padding: 16px 12px;
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
}
.pizza-size-cell:last-child{border-right:0;}
.pizza-size-cell strong{
  font-family: Georgia, serif;
  font-size: clamp(1.05rem, 2vw, 1.35rem);
  line-height: 1.1;
}
.pizza-size-cell span,
.pizza-size-cell em{
  font-style: normal;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.15;
}
.pizza-size-cell:nth-child(1) strong{color:#377a30;}
.pizza-size-cell:nth-child(2) strong{color:#9b3330;}
.pizza-size-cell:nth-child(3) strong{color:#377a30;}
.pizza-size-cell:nth-child(4) strong{color:#9b3330;}
@media(max-width:700px){
  .pizza-size-card{grid-template-columns: repeat(2, 1fr);}
  .pizza-size-cell:nth-child(2){border-right:0;}
  .pizza-size-cell:nth-child(1), .pizza-size-cell:nth-child(2){border-bottom:1px solid var(--line);}
}


/* v32: replace blurry catering/banquet menu images with crisp readable HTML menus */
.print-menu{
  max-width:1120px;
  margin:0 auto 34px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:26px;
  box-shadow:0 14px 38px rgba(69,34,14,.10);
  padding:clamp(22px,3vw,40px);
}
.print-menu h2{
  text-align:center;
  font-size:clamp(2rem,4vw,3.1rem);
  line-height:1.05;
  margin:0 0 10px;
}
.menu-note{
  max-width:820px;
  margin:0 auto 26px;
  color:var(--muted);
  text-align:center;
  font-weight:700;
}
.print-menu-grid{
  display:grid;
  gap:22px;
}
.print-menu-grid.three-col{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.print-menu section,
.package-card{
  background:#fff8ea;
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px 20px;
}
.print-menu h3{
  margin:0 0 10px;
  color:var(--accent);
  font-size:1.35rem;
  line-height:1.15;
}
.print-menu h4{
  margin:18px 0 8px;
  font-size:1.05rem;
  color:var(--ink);
}
.print-menu ul{
  list-style:none;
  margin:0;
  padding:0;
}
.print-menu li{
  padding:5px 0;
  border-bottom:1px dashed rgba(69,34,14,.16);
}
.print-menu li:last-child{border-bottom:0;}
.package-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
  margin-top:22px;
}
.featured-package{
  max-width:880px;
  margin:0 auto 24px;
  text-align:center;
}
.package-card p{
  margin:0;
  color:var(--muted);
}
.catering-hero-photo{
  max-width:1180px;
}
@media(max-width:900px){
  .print-menu-grid.three-col,
  .package-grid{grid-template-columns:1fr;}
}








/* v42 clean footer credit - works on all pages */
.site-footer,
footer {
  position: relative !important;
}

.cg-credit-clean {
  position: absolute !important;
  right: 64px !important;
  bottom: 28px !important;
  width: auto !important;
  min-width: 260px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  gap: 6px !important;
  z-index: 20 !important;
}

.cg-credit-clean img {
  width: 72px !important;
  height: 72px !important;
  max-width: 72px !important;
  max-height: 72px !important;
  object-fit: contain !important;
  display: block !important;
  margin: 0 auto !important;
}

.cg-credit-clean .cg-credit-text {
  display: block !important;
  white-space: nowrap !important;
  font-size: 11px !important;
  line-height: 1.2 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  color: rgba(255,255,255,0.68) !important;
  font-weight: 400 !important;
}

.cg-credit-clean .cg-credit-text a {
  color: rgba(255,255,255,0.78) !important;
  text-decoration: underline !important;
  font-weight: 600 !important;
}

@media (max-width: 800px) {
  .cg-credit-clean {
    position: static !important;
    margin: 30px auto 0 auto !important;
    min-width: 0 !important;
  }
}


/* v48: keep cake/menu photos from being cropped */
.item-card img {
  object-fit: contain;
  background: #fff;
}


/* v49: prevent cake/menu images from being cropped or cut off */
.item-card img,
.menu-card img {
  object-fit: contain !important;
  background: #fff;
}
.item-card {
  overflow: visible;
}


/* v50: health department allergy disclaimer and cake menu notes */
.allergy-disclaimer,
.menu-bottom-note {
  max-width: 1180px;
  margin: 24px auto;
  padding: 14px 18px;
  border: 1px solid rgba(120, 66, 34, 0.22);
  border-radius: 14px;
  background: #fff8ed;
  color: #3a1b12;
  font-weight: 700;
  text-align: center;
  line-height: 1.4;
  box-shadow: 0 8px 24px rgba(60, 28, 16, 0.08);
}
.menu-bottom-note {
  background: #fffdf7;
}


/* v52: typed menu lists from printed shop menus */
.typed-menu-section {
  max-width: 1180px;
  margin: 28px auto;
  padding: 22px;
  border-radius: 18px;
  background: #fffdf8;
  border: 1px solid rgba(120, 66, 34, 0.18);
  box-shadow: 0 10px 28px rgba(60, 28, 16, 0.08);
}
.typed-menu-section h2 {
  margin: 0 0 14px;
  text-align: center;
}
.typed-menu-intro {
  text-align: center;
  font-weight: 700;
  margin: 0 0 14px;
}
.typed-menu-list {
  columns: 2;
  column-gap: 42px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.typed-menu-list li {
  break-inside: avoid;
  padding: 8px 0;
  border-bottom: 1px dashed rgba(120, 66, 34, 0.2);
  line-height: 1.35;
}
.typed-menu-list strong {
  color: #3a1b12;
}
@media (max-width: 760px) {
  .typed-menu-list {
    columns: 1;
  }
}


/* v56: make Frozen Foods top section match the other menu pages */
.page-hero {
  background: linear-gradient(135deg, #fff4df 0%, #f4d4a3 100%);
  text-align: center;
  padding: 72px 24px 64px;
}
.page-hero .eyebrow {
  letter-spacing: 0.18em;
  font-weight: 800;
  color: #7b3b22;
  margin: 0 0 12px;
}
.page-hero h1 {
  margin: 0;
}
.page-hero-text {
  max-width: 720px;
  margin: 14px auto 0;
}
.page-hero .hero-actions {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 24px;
}


/* v57: Frozen Foods page should match the other menu page headers/buttons */
.page-hero .hero-actions a,
.menu-hero .hero-actions a,
.page-hero .btn,
.menu-hero .btn {
  text-decoration: none !important;
}


/* v58: Frozen Foods cleanup - no duplicate hero, standard intro/button display */
.menu-intro {
  max-width: 1180px;
  margin: 56px auto 24px;
  text-align: center;
  padding: 0 24px;
}
.menu-intro h2 {
  margin-bottom: 10px;
}
.page-hero .button,
.menu-hero .button {
  text-decoration: none !important;
}


/* v59: make all menu page section headings match Frozen Foods style */
.uniform-menu-intro,
.menu-intro {
  max-width: 1180px;
  margin: 42px auto 22px !important;
  text-align: center;
  padding: 0 24px;
}
.uniform-menu-intro h2,
.menu-intro h2 {
  font-size: clamp(1.55rem, 2.2vw, 2rem) !important;
  line-height: 1.15 !important;
  margin: 0 0 14px !important;
  font-family: inherit;
  font-weight: 800;
  color: #3a1b12;
}
.uniform-menu-intro p,
.menu-intro p {
  margin: 0 auto !important;
  font-size: 1rem !important;
  color: #5a2a1a;
  line-height: 1.45;
}


/* v62: typed cake sizes table */
.cake-size-guide {
  max-width: 920px;
  margin: 42px auto 18px;
  padding: 18px;
  border-radius: 18px;
  background: #fffdf8;
  border: 1px solid rgba(120, 66, 34, 0.22);
  box-shadow: 0 10px 28px rgba(60, 28, 16, 0.08);
  text-align: center;
}
.cake-size-guide h2 {
  margin: 0 0 14px;
  font-size: clamp(1.35rem, 2vw, 1.85rem);
  color: #3a1b12;
}
.cake-size-table {
  width: 100%;
  border-collapse: collapse;
  font-size: clamp(0.95rem, 1.45vw, 1.15rem);
  background: #fff;
  overflow: hidden;
  border-radius: 12px;
}
.cake-size-table th,
.cake-size-table td {
  border: 1px solid rgba(120, 66, 34, 0.28);
  padding: 12px 10px;
  text-align: center;
  vertical-align: middle;
}
.cake-size-table th {
  width: 180px;
  background: #fff4df;
  color: #3a1b12;
  font-weight: 800;
}
.cake-size-table td {
  font-weight: 700;
  color: #4a2417;
}
@media (max-width: 760px) {
  .cake-size-guide {
    margin: 28px 14px 14px;
    padding: 12px;
    overflow-x: auto;
  }
  .cake-size-table {
    min-width: 680px;
  }
}


/* v63: added menu photos/items */
.item-card img {
  object-fit: contain;
  background: #fff;
}


/* v64: cake list moved to top with descriptions */
.cake-list-section {
  max-width: 1180px;
  margin: 34px auto 28px;
  padding: 24px;
  border-radius: 18px;
  background: #fffdf8;
  border: 1px solid rgba(120, 66, 34, 0.22);
  box-shadow: 0 10px 28px rgba(60, 28, 16, 0.08);
}
.cake-list-section h2 {
  text-align: center;
  margin: 0 0 8px;
  color: #3a1b12;
  font-size: clamp(1.65rem, 2.5vw, 2.25rem);
}
.cake-list-intro {
  text-align: center;
  margin: 0 auto 20px;
  color: #5a2a1a;
  line-height: 1.45;
}
.cake-description-list {
  list-style: none;
  padding: 0;
  margin: 0;
  columns: 2;
  column-gap: 34px;
}
.cake-description-list li {
  break-inside: avoid;
  padding: 10px 0 12px;
  border-bottom: 1px dashed rgba(120, 66, 34, 0.22);
}
.cake-description-list strong {
  display: block;
  color: #3a1b12;
  font-weight: 800;
  margin-bottom: 4px;
}
.cake-description-list span {
  display: block;
  color: #5a2a1a;
  line-height: 1.4;
}
@media (max-width: 760px) {
  .cake-description-list {
    columns: 1;
  }
  .cake-list-section {
    margin: 24px 14px;
    padding: 18px;
  }
}


/* v67: official pizza pricing SEO note */
.official-menu-note {
  max-width: 820px;
  margin: 0 auto 24px !important;
  padding: 14px 18px;
  border: 1px solid rgba(120, 66, 34, 0.22);
  border-radius: 14px;
  background: #fffdf8;
  color: #4a2417;
  line-height: 1.5;
  font-weight: 600;
}


/* v68: Creme Brulee Tiramisu cake slice */
.item-card img {
  object-fit: contain;
  background: #fff;
}


/* v69: third-party menu/pricing disclaimer */
.third-party-pricing-note {
  max-width: 1180px;
  margin: 22px auto;
  padding: 13px 18px;
  border: 1px solid rgba(120, 66, 34, 0.18);
  border-radius: 14px;
  background: #fffdf8;
  color: #4a2417;
  font-weight: 650;
  text-align: center;
  line-height: 1.45;
  box-shadow: 0 8px 22px rgba(60, 28, 16, 0.06);
}


/* v72: official source line on each public menu page */
.official-menu-source-note {
  max-width: 820px;
  margin: 12px auto 0 !important;
  padding: 11px 16px;
  border-radius: 12px;
  background: #fffdf8;
  color: #4a2417;
  font-weight: 800;
  text-align: center;
  line-height: 1.45;
  border: 1px solid rgba(120, 66, 34, 0.18);
}
