/*
 * The Yemeni Bean Cafe main stylesheet.
 * Generated from modular source files for production delivery.
 */

/* === base/reset.css === */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body { margin: 0; min-width: 320px; background: var(--color-ivory); color: var(--color-text); }
img, picture, video, canvas, svg { display: block; max-width: 100%; }
button, input, textarea, select { font: inherit; }
a { color: inherit; text-decoration: none; }
ul, ol { margin-block-start: 0; }
.screen-reader-text { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.screen-reader-text:focus { z-index: 100000; top: 1rem; left: 1rem; width: auto; height: auto; clip: auto; padding: .75rem 1rem; background: var(--color-white); color: var(--color-espresso); border-radius: var(--radius-sm); box-shadow: var(--shadow-soft); }

/* === base/variables.css === */
:root {
  --color-ivory: #fff8ee;
  --color-cream: #f5e8d6;
  --color-beige: #e8c79d;
  --color-caramel: #c9975b;
  --color-gold: #d8a85b;
  --color-coffee: #3b2416;
  --color-espresso: #21130c;
  --color-burgundy: #6b1111;
  --color-burgundy-hover: #7d1717;
  --color-muted-red: #9e241c;
  --color-text: #1e130d;
  --color-text-muted: #6f5a4a;
  --color-white: #ffffff;
  --color-border: #e6d3b8;
  --color-border-strong: #dcc6a8;
  --shadow-soft: 0 18px 50px rgb(33 19 12 / 0.08);
  --shadow-card: 0 24px 60px rgb(33 19 12 / 0.12);
  --font-heading: "Playfair Display", "Cormorant Garamond", "Libre Baskerville", Georgia, serif;
  --font-body: "Inter", "Manrope", "Poppins", Arial, sans-serif;
  --container-xl: 1440px;
  --container-lg: 1320px;
  --container-md: 1200px;
  --content-width: 760px;
  --radius-sm: 10px;
  --radius-md: 18px;
  --radius-lg: 28px;
  --radius-pill: 999px;
  --transition-fast: 180ms ease;
  --transition-base: 280ms ease;
  --transition-slow: 520ms cubic-bezier(0.22, 1, 0.36, 1);
}

/* === base/typography.css === */
body { font-family: var(--font-body); font-size: 16px; line-height: 1.7; font-weight: 400; }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-heading); line-height: 1.08; color: var(--color-espresso); margin-block: 0 0.75em; }
h1, .yb-page-title { font-size: clamp(2.6rem, 6vw, 6rem); letter-spacing: -0.04em; }
h2 { font-size: clamp(2rem, 4vw, 4rem); letter-spacing: -0.035em; }
h3 { font-size: clamp(1.45rem, 2.2vw, 2.25rem); }
p { margin-block: 0 1.2rem; color: var(--color-text-muted); }
.yb-kicker { font-size: .78rem; letter-spacing: .16em; text-transform: uppercase; color: var(--color-burgundy); font-weight: 700; margin-block-end: .75rem; }
.entry__content a { color: var(--color-burgundy); text-decoration: underline; text-underline-offset: 0.2em; }

/* === base/utilities.css === */
.yb-container { width: min(var(--container-lg), calc(100% - 48px)); margin-inline: auto; }
.yb-content-width { max-width: var(--content-width); }
.yb-section { padding-block: clamp(72px, 9vw, 140px); }
.yb-button-group { display: flex; flex-wrap: wrap; align-items: center; gap: 14px; }
.yb-inline-link { display: inline-flex; align-items: center; gap: 8px; color: var(--color-burgundy); font-weight: 800; text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 0.35em; }
.yb-empty-state { text-align: center; max-width: 720px; margin-inline: auto; }
.yb-post-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }
.yb-grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: clamp(24px, 4vw, 56px); }
.yb-grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }

/* === base/animations.css === */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: 0.001ms !important; }
}

/* === layout/containers.css === */
/* Phase-specific styles will be expanded in upcoming phases. */

/* === layout/grid.css === */
/* Phase-specific styles will be expanded in upcoming phases. */

/* === layout/spacing.css === */
/* Phase-specific styles will be expanded in upcoming phases. */

/* === layout/header.css === */
.site-header { position: sticky; inset-block-start: 0; z-index: 90; background: rgb(255 248 238 / 0.92); backdrop-filter: blur(18px); border-block-end: 1px solid rgb(230 211 184 / 0.72); transition: box-shadow var(--transition-base), background-color var(--transition-base), min-height var(--transition-base); }
.site-header.is-scrolled { box-shadow: 0 16px 42px rgb(33 19 12 / 0.08); background: rgb(255 248 238 / 0.97); }
.site-header__top { border-block-end: 1px solid rgb(230 211 184 / 0.52); background: var(--color-espresso); color: var(--color-ivory); }
.site-header__top-inner { min-height: 30px; display: flex; align-items: center; justify-content: flex-end; gap: 18px; }
.site-header__top-link { display: inline-flex; align-items: center; gap: 7px; font-size: 0.76rem; color: rgb(255 248 238 / 0.84); line-height: 1; }
.site-header__inner { min-height: 68px; display: flex; align-items: center; justify-content: space-between; gap: 22px; padding-block: 6px; }
.site-header__brand { flex: 0 0 auto; display: flex; align-items: center; }
.site-header__logo-link { display: inline-flex; align-items: center; }
.site-header__logo,
.custom-logo { width: min(164px, 31vw); height: auto; }
.site-navigation { flex: 1 1 auto; align-self: stretch; display: flex; align-items: center; justify-content: center; }
.site-navigation__menu,
.mobile-menu__items,
.site-footer__menu { display: flex; align-items: center; gap: 24px; list-style: none; padding: 0; margin: 0; }
.site-navigation__menu { justify-content: center; height: 100%; }
.site-navigation a { position: relative; display: inline-flex; align-items: center; min-height: 34px; font-size: 0.78rem; font-weight: 850; letter-spacing: 0.07em; text-transform: uppercase; color: var(--color-coffee); line-height: 1; }
.site-navigation a::after { content: ''; position: absolute; inset-inline: 0; inset-block-end: 0; height: 2px; transform: scaleX(0); transform-origin: center; background: var(--color-burgundy); transition: transform var(--transition-base); }
.site-navigation a:hover::after,
.site-navigation a:focus-visible::after,
.site-navigation .current-menu-item > a::after { transform: scaleX(1); }
.site-header__actions { display: flex; align-items: center; gap: 10px; }
.site-header__icon-button,
.site-header__cart,
.site-header__toggle { display: inline-grid; place-items: center; width: 40px; height: 40px; border: 1px solid var(--color-border); border-radius: 50%; background: var(--color-white); color: var(--color-espresso); cursor: pointer; transition: transform var(--transition-base), border-color var(--transition-base), background-color var(--transition-base); }
.site-header__icon-button:hover,
.site-header__cart:hover,
.site-header__toggle:hover { transform: translateY(-2px); border-color: var(--color-caramel); }
.site-header__cart { position: relative; }
.site-header__cart-label { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }
.site-header__cart-count { position: absolute; inset-block-start: -6px; inset-inline-end: -6px; min-width: 21px; min-height: 21px; display: inline-grid; place-items: center; border-radius: 50%; background: var(--color-burgundy); color: var(--color-white); font-size: 0.68rem; font-weight: 900; }
.site-header__toggle { display: none; }
.site-header__toggle span:not(.screen-reader-text) { display: block; width: 18px; height: 2px; margin: 2px auto; background: currentColor; transition: transform var(--transition-base), opacity var(--transition-base); }
.is-menu-open .site-header__toggle span:nth-child(1) { transform: translateY(4px) rotate(45deg); }
.is-menu-open .site-header__toggle span:nth-child(2) { opacity: 0; }
.is-menu-open .site-header__toggle span:nth-child(3) { transform: translateY(-4px) rotate(-45deg); }
.mobile-menu { padding: 18px 24px 28px; border-block-start: 1px solid var(--color-border); background: var(--color-ivory); }
.mobile-menu[hidden] { display: none; }
.mobile-menu__inner { width: min(var(--container-lg), calc(100% - 24px)); margin-inline: auto; }
.mobile-menu__items { flex-direction: column; align-items: flex-start; gap: 2px; }
.mobile-menu__items a { display: flex; width: 100%; padding-block: 12px; color: var(--color-espresso); font-weight: 850; font-size: 1.02rem; border-block-end: 1px solid var(--color-border); }
.mobile-menu__actions { display: grid; gap: 12px; margin-block-start: 20px; }

/* Premium compact header polish */
.site-header__top-inner { min-height: 26px; gap: 16px; }
.site-header__top-link { font-size: 0.72rem; letter-spacing: 0.02em; }
.site-header__inner { min-height: 58px; gap: 18px; padding-block: 4px; }
.site-header__logo,
.custom-logo { width: min(138px, 26vw); max-height: 54px; object-fit: contain; }
.site-navigation__menu { gap: clamp(15px, 1.8vw, 22px); }
.site-navigation a { min-height: 30px; font-size: 0.75rem; letter-spacing: 0.065em; }
.site-header__actions { gap: 8px; }
.site-header__icon-button,
.site-header__cart,
.site-header__toggle { width: 36px; height: 36px; }
.site-header__icon-button svg,
.site-header__cart svg { width: 17px; height: 17px; }
.site-header__cart-count { inset-block-start: -5px; inset-inline-end: -5px; min-width: 18px; min-height: 18px; font-size: 0.62rem; }
.site-header__cta { min-height: 38px; padding-inline: 18px; font-size: 0.75rem; }
.mobile-menu { padding: 10px 16px 18px; border-block-start: 1px solid rgb(230 211 184 / 0.72); background: rgb(255 248 238 / 0.98); box-shadow: 0 24px 60px rgb(33 19 12 / 0.13); }
.mobile-menu__inner { width: min(var(--container-lg), 100%); }
.mobile-menu__items { gap: 0; }
.mobile-menu__items a { min-height: 44px; align-items: center; padding-block: 10px; font-size: 0.94rem; letter-spacing: 0.02em; }
.mobile-menu__actions { grid-template-columns: 1fr 1fr; gap: 10px; margin-block-start: 14px; }
.mobile-menu__actions .yb-button { width: 100%; min-height: 42px; padding-inline: 12px; font-size: 0.78rem; }

@media (max-width: 900px) {
  .site-header__inner { min-height: 56px; padding-block: 4px; }
  .site-header__logo,
  .custom-logo { width: 122px; max-height: 48px; }
  .mobile-menu { max-height: calc(100svh - 56px); overflow-y: auto; }
}

@media (max-width: 560px) {
  .site-header__inner { min-height: 54px; gap: 10px; }
  .site-header__logo,
  .custom-logo { width: 108px; max-height: 44px; }
  .site-header__actions { gap: 6px; }
  .site-header__icon-button,
  .site-header__cart,
  .site-header__toggle { width: 34px; height: 34px; }
  .mobile-menu { padding: 8px 12px 14px; }
}

@media (max-width: 390px) {
  .site-header__logo,
  .custom-logo { width: 100px; }
  .site-header__icon-button { display: none; }
  .mobile-menu__actions { grid-template-columns: 1fr; }
}

/* === layout/footer.css === */
.site-footer { background: var(--color-espresso); color: var(--color-ivory); padding-block-start: clamp(72px, 8vw, 112px); }
.site-footer p,
.site-footer address,
.site-footer a { color: rgb(255 248 238 / 0.78); }
.site-footer a:hover,
.site-footer a:focus-visible { color: var(--color-white); }
.site-footer__grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(0, .85fr) minmax(0, .85fr) minmax(0, .75fr); gap: clamp(30px, 5vw, 58px); }
.site-footer__logo { width: 190px; height: auto; margin-block-end: 22px; }
.site-footer__heading { font-family: var(--font-body); color: var(--color-gold); font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.14em; margin-block-end: 18px; }
.site-footer__column { display: grid; align-content: start; gap: 10px; }
.site-footer__link { display: inline-flex; width: fit-content; text-decoration: underline; text-underline-offset: 0.3em; }
.site-footer__menu { display: grid; gap: 10px; align-items: start; }
.site-footer__social { margin-block-start: 24px; color: rgb(255 248 238 / 0.62); font-size: 0.92rem; }
.site-footer__bottom { margin-block-start: 60px; padding-block: 22px; border-block-start: 1px solid rgb(255 248 238 / 0.14); }
.site-footer__bottom-inner { display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.site-footer__bottom p { margin: 0; font-size: 0.9rem; }
.site-footer__social { display: flex; flex-wrap: wrap; gap: 8px; margin-block-start: 22px; color: rgb(255 248 238 / 0.78); font-size: 0.86rem; }
.site-footer__social span { display: inline-flex; padding: 8px 11px; border: 1px solid rgb(255 248 238 / 0.14); border-radius: var(--radius-pill); background: rgb(255 248 238 / 0.07); }

/* Compact premium footer polish */
.site-footer { padding-block-start: clamp(42px, 6vw, 72px); }
.site-footer__grid { gap: clamp(22px, 4vw, 44px); }
.site-footer__logo { width: 150px; margin-block-end: 14px; }
.site-footer__brand p { max-width: 430px; font-size: 0.94rem; line-height: 1.62; }
.site-footer__heading { margin-block-end: 12px; font-size: 0.76rem; }
.site-footer__column { gap: 8px; }
.site-footer__menu { gap: 7px; }
.site-footer__social { margin-block-start: 16px; gap: 7px; }
.site-footer__social span { padding: 6px 9px; font-size: 0.78rem; }
.site-footer__bottom { margin-block-start: 36px; padding-block: 16px; }
.site-footer__bottom p,
.site-footer__bottom a { font-size: 0.84rem; }

@media (max-width: 900px) {
  .site-footer { padding-block-start: 36px; }
  .site-footer__grid { gap: 22px; }
  .site-footer__logo { width: 132px; }
  .site-footer__bottom { margin-block-start: 26px; }
}

@media (max-width: 560px) {
  .site-footer__brand p,
  .site-footer address,
  .site-footer__column p,
  .site-footer__link,
  .site-footer__menu a { font-size: 0.9rem; line-height: 1.55; }
  .site-footer__bottom-inner { gap: 8px; }
}

/* === components/buttons.css === */
.yb-button,
button.yb-button,
input[type="submit"].yb-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  min-height: 48px;
  padding: 0.9rem 1.35rem;
  border: 1px solid transparent;
  border-radius: var(--radius-pill);
  font-family: var(--font-body);
  font-weight: 850;
  line-height: 1;
  letter-spacing: 0.01em;
  text-decoration: none;
  cursor: pointer;
  transition: transform var(--transition-base), background-color var(--transition-base), border-color var(--transition-base), color var(--transition-base), box-shadow var(--transition-base);
}

.yb-button svg { width: 1.05em; height: 1.05em; flex: 0 0 auto; }
.yb-button:hover,
.yb-button:focus-visible { transform: translateY(-2px); text-decoration: none; }
.yb-button:focus-visible { outline: 3px solid rgb(216 168 91 / 0.42); outline-offset: 3px; }
.yb-button--primary { background: var(--color-burgundy); color: var(--color-ivory); box-shadow: 0 14px 34px rgb(107 17 17 / 0.24); }
.yb-button--primary:hover,
.yb-button--primary:focus-visible { background: var(--color-burgundy-hover); color: var(--color-white); }
.yb-button--secondary { background: var(--color-espresso); color: var(--color-ivory); box-shadow: 0 14px 34px rgb(33 19 12 / 0.16); }
.yb-button--secondary:hover,
.yb-button--secondary:focus-visible { background: var(--color-coffee); color: var(--color-white); }
.yb-button--outline { background: transparent; border-color: var(--color-border-strong); color: var(--color-espresso); }
.yb-button--outline:hover,
.yb-button--outline:focus-visible { background: var(--color-cream); border-color: var(--color-caramel); color: var(--color-espresso); }
.yb-button--outline-light { background: rgb(255 248 238 / 0.08); border-color: rgb(255 248 238 / 0.58); color: var(--color-ivory); }
.yb-button--outline-light:hover,
.yb-button--outline-light:focus-visible { background: var(--color-ivory); color: var(--color-espresso); }
.yb-button--ghost { background: transparent; color: var(--color-burgundy); border-color: transparent; }
.yb-button--ghost:hover,
.yb-button--ghost:focus-visible { background: rgb(107 17 17 / 0.08); }
.yb-button--ghost-light { background: transparent; border-color: transparent; color: var(--color-ivory); text-decoration: underline; text-underline-offset: 0.35em; }
.yb-button--ghost-light:hover,
.yb-button--ghost-light:focus-visible { background: rgb(255 248 238 / 0.1); color: var(--color-ivory); }
.yb-button--small { min-height: 40px; padding: 0.7rem 1rem; font-size: 0.88rem; }
.yb-button--large { min-height: 58px; padding: 1.05rem 1.7rem; font-size: 1rem; }
.yb-button-group { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.yb-inline-link { display: inline-flex; align-items: center; gap: 0.4em; color: var(--color-burgundy); font-weight: 850; text-decoration: underline; text-underline-offset: 0.32em; }

/* === components/cards.css === */
.yb-card {
  position: relative;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}

.yb-card__body { padding: clamp(22px, 3vw, 34px); }
.yb-card__eyebrow { color: var(--color-burgundy); font-size: 0.78rem; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; }
.yb-card__title { margin-block: 0.35rem 0.6rem; }
.yb-card__description { color: var(--color-text-muted); }

.yb-content-card { transition: transform var(--transition-slow), box-shadow var(--transition-slow), border-color var(--transition-slow); }
.yb-content-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-card); border-color: var(--color-border-strong); }
.yb-content-card__media { aspect-ratio: 4 / 3; overflow: hidden; background: var(--color-cream); }
.yb-content-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.yb-content-card:hover .yb-content-card__media img { transform: scale(1.045); }
.yb-content-card__body h3,
.yb-post-card__title { font-size: clamp(1.45rem, 2vw, 2rem); }
.yb-post-card__image { display: block; aspect-ratio: 4 / 3; overflow: hidden; background: var(--color-cream); }
.yb-post-card__image img { width: 100%; height: 100%; object-fit: cover; }
.yb-feature-card { padding: clamp(22px, 3vw, 34px); }
.yb-feature-card__icon { width: 54px; height: 54px; display: inline-grid; place-items: center; border-radius: 50%; background: var(--color-cream); color: var(--color-burgundy); margin-block-end: 18px; }
.yb-feature-card__icon svg { width: 24px; height: 24px; }

/* === components/forms.css === */
.yb-form,
.yb-search-form { display: grid; gap: 16px; }
.yb-form-row { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.yb-field label { display: block; margin-block-end: 8px; color: var(--color-espresso); font-weight: 850; font-size: 0.92rem; }
.yb-field input,
.yb-field textarea,
.yb-field select,
.yb-search-form__input,
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="search"],
input[type="url"],
input[type="password"],
textarea,
select {
  width: 100%;
  min-height: 52px;
  padding: 0.9rem 1rem;
  border: 1px solid var(--color-border);
  border-radius: 16px;
  background: var(--color-white);
  color: var(--color-text);
  outline: none;
  transition: border-color var(--transition-base), box-shadow var(--transition-base), background-color var(--transition-base);
}
textarea { min-height: 140px; resize: vertical; }
.yb-field input:focus,
.yb-field textarea:focus,
.yb-field select:focus,
.yb-search-form__input:focus,
input:focus,
textarea:focus,
select:focus { border-color: var(--color-caramel); box-shadow: 0 0 0 4px rgb(201 151 91 / 0.18); }
.yb-field__help { margin-block-start: 6px; color: var(--color-text-muted); font-size: 0.88rem; }
.yb-form__notice { padding: 14px 16px; border-radius: 14px; background: var(--color-cream); color: var(--color-coffee); }
.yb-search-form { grid-template-columns: minmax(0, 1fr) auto; align-items: center; margin-block-start: 28px; }

/* === components/navigation.css === */
.yb-breadcrumbs { margin-block-end: clamp(18px, 3vw, 32px); }
.yb-breadcrumbs__list { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; padding: 0; margin: 0; list-style: none; color: var(--color-text-muted); font-size: 0.88rem; }
.yb-breadcrumbs__list li:not(:last-child)::after { content: '/'; margin-inline-start: 8px; color: var(--color-caramel); }
.yb-breadcrumbs a { color: var(--color-burgundy); font-weight: 800; }
.yb-section-heading { max-width: 760px; margin-block-end: clamp(28px, 5vw, 56px); }
.yb-section-heading--center { margin-inline: auto; text-align: center; }
.yb-section-heading--right { margin-inline-start: auto; text-align: right; }
.yb-section-heading h2 { margin-block: 0.25em 0.35em; }
.yb-section-heading p:last-child { color: var(--color-text-muted); font-size: clamp(1rem, 1.5vw, 1.16rem); }
.yb-cta { padding-block: clamp(52px, 8vw, 90px); }
.yb-cta--cream { background: var(--color-cream); }
.yb-cta--dark { background: var(--color-espresso); color: var(--color-ivory); }
.yb-cta__inner { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: center; gap: clamp(24px, 5vw, 72px); padding: clamp(28px, 5vw, 56px); border-radius: var(--radius-lg); background: var(--color-white); box-shadow: var(--shadow-soft); }
.yb-cta--dark .yb-cta__inner { background: rgb(255 248 238 / 0.08); border: 1px solid rgb(255 248 238 / 0.18); }
.yb-cta__content h2 { margin-block: 0.2em 0.3em; }
.yb-cta__content p { color: var(--color-text-muted); }
.yb-cta--dark .yb-cta__content p { color: rgb(255 248 238 / 0.78); }
.yb-cta__actions { display: flex; flex-wrap: wrap; gap: 12px; justify-content: flex-end; }

/* === components/gallery.css === */
.yb-gallery { display: grid; gap: clamp(14px, 2vw, 24px); }
.yb-gallery--cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.yb-gallery--cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.yb-gallery--cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.yb-gallery__item { position: relative; overflow: hidden; border-radius: var(--radius-lg); background: var(--color-cream); box-shadow: var(--shadow-soft); }
.yb-gallery__item img { width: 100%; height: 100%; min-height: 260px; aspect-ratio: 4 / 3; object-fit: cover; transition: transform var(--transition-slow); }
.yb-gallery__item:hover img { transform: scale(1.045); }
.yb-gallery__item figcaption { position: absolute; inset-inline: 14px; inset-block-end: 14px; padding: 10px 12px; border-radius: 14px; background: rgb(33 19 12 / 0.72); color: var(--color-ivory); font-size: 0.9rem; }

/* === components/accordion.css === */
.yb-accordion { display: grid; gap: 12px; }
.yb-accordion__item { border: 1px solid var(--color-border); border-radius: var(--radius-md); background: var(--color-white); overflow: hidden; box-shadow: var(--shadow-soft); }
.yb-accordion__heading { margin: 0; }
.yb-accordion__button {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 20px 22px;
  border: 0;
  background: transparent;
  color: var(--color-espresso);
  font: inherit;
  font-weight: 850;
  text-align: left;
  cursor: pointer;
}
.yb-accordion__button svg { width: 20px; height: 20px; transition: transform var(--transition-base); }
.yb-accordion__button[aria-expanded="true"] svg { transform: rotate(180deg); }
.yb-accordion__panel { padding: 0 22px 22px; color: var(--color-text-muted); }
.yb-accordion__panel[hidden] { display: none; }

/* === components/modals.css === */
.is-overlay-open,
.is-drawer-open,
.is-modal-open,
.is-menu-open { overflow: hidden; }
.yb-overlay,
.yb-drawer,
.yb-modal { position: fixed; inset: 0; z-index: 999; }
.yb-overlay[hidden],
.yb-drawer[hidden],
.yb-modal[hidden] { display: none; }
.yb-overlay__backdrop,
.yb-drawer__backdrop,
.yb-modal__backdrop { position: absolute; inset: 0; background: rgb(33 19 12 / 0.58); backdrop-filter: blur(4px); }
.yb-overlay__panel,
.yb-modal__panel {
  position: relative;
  z-index: 1;
  width: min(760px, calc(100% - 32px));
  max-height: calc(100svh - 64px);
  overflow: auto;
  margin: min(12vh, 120px) auto;
  padding: clamp(28px, 5vw, 56px);
  border-radius: var(--radius-lg);
  background: var(--color-ivory);
  box-shadow: var(--shadow-card);
}
.yb-modal--small .yb-modal__panel { width: min(520px, calc(100% - 32px)); }
.yb-modal--large .yb-modal__panel { width: min(1040px, calc(100% - 32px)); }
.yb-modal__header { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; margin-block-end: 18px; }
.yb-modal__header h2 { margin: 0; }
.yb-modal__description { color: var(--color-text-muted); }
.yb-overlay__close,
.yb-drawer__close,
.yb-modal__close {
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  width: 44px;
  height: 44px;
  border: 1px solid var(--color-border);
  border-radius: 50%;
  background: var(--color-white);
  color: var(--color-espresso);
  cursor: pointer;
}
.yb-overlay__close { position: absolute; inset-block-start: 18px; inset-inline-end: 18px; }
.yb-drawer__panel {
  position: absolute;
  inset-block: 0;
  inset-inline-end: 0;
  z-index: 1;
  width: min(460px, 100%);
  display: flex;
  flex-direction: column;
  background: var(--color-ivory);
  box-shadow: -28px 0 60px rgb(33 19 12 / 0.16);
}
.yb-drawer--left .yb-drawer__panel { inset-inline: 0 auto; box-shadow: 28px 0 60px rgb(33 19 12 / 0.16); }
.yb-drawer__header { display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; padding: 28px; border-block-end: 1px solid var(--color-border); }
.yb-drawer__header h2 { margin: 0; font-size: clamp(2rem, 4vw, 3rem); }
.yb-drawer__body,
.yb-mini-cart__body { flex: 1; overflow: auto; padding: 24px 28px; }
.yb-search-overlay__panel h2 { max-width: 620px; }

/* === components/timeline.css === */
/* Phase-specific styles will be expanded in upcoming phases. */

/* === pages/base-pages.css === */
/* Phase-specific styles will be expanded in upcoming phases. */

/* === pages/home.css === */
/* Phase 3 Homepage */
.home .site-header,
.front-page .site-header {
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;
  background: linear-gradient(180deg, rgb(33 19 12 / 0.58), rgb(33 19 12 / 0.08));
  border-block-end-color: rgb(255 248 238 / 0.14);
  color: var(--color-ivory);
}

.home .site-header:not(.is-scrolled) .site-header__top,
.front-page .site-header:not(.is-scrolled) .site-header__top {
  background: transparent;
  border-block-end-color: rgb(255 248 238 / 0.12);
}

.home .site-header:not(.is-scrolled) .site-navigation a,
.front-page .site-header:not(.is-scrolled) .site-navigation a,
.home .site-header:not(.is-scrolled) .site-header__top-link,
.front-page .site-header:not(.is-scrolled) .site-header__top-link {
  color: rgb(255 248 238 / 0.9);
}

.home .site-header:not(.is-scrolled) .site-header__icon-button,
.home .site-header:not(.is-scrolled) .site-header__cart,
.home .site-header:not(.is-scrolled) .site-header__toggle,
.front-page .site-header:not(.is-scrolled) .site-header__icon-button,
.front-page .site-header:not(.is-scrolled) .site-header__cart,
.front-page .site-header:not(.is-scrolled) .site-header__toggle {
  background: rgb(255 248 238 / 0.1);
  border-color: rgb(255 248 238 / 0.26);
  color: var(--color-ivory);
}

.home .site-header.is-scrolled,
.front-page .site-header.is-scrolled {
  background: rgb(255 248 238 / 0.96);
}

.yb-front-page {
  position: relative;
  overflow: hidden;
  background: var(--color-ivory);
}

.yb-front-page section {
  position: relative;
}

.yb-front-page [data-yb-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 700ms ease, transform 700ms cubic-bezier(0.22, 1, 0.36, 1);
}

.yb-front-page [data-yb-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

.yb-section-heading--center {
  max-width: 780px;
  margin-inline: auto;
  margin-block-end: clamp(34px, 5vw, 64px);
  text-align: center;
}

.yb-section-heading--compact {
  display: grid;
  justify-items: center;
  max-width: 680px;
  margin-inline: auto;
  margin-block-end: 28px;
  text-align: center;
}

.yb-section-heading p:last-child {
  color: var(--color-text-muted);
  font-size: clamp(1rem, 1.3vw, 1.12rem);
}

.yb-home-section-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  margin-block-start: clamp(34px, 5vw, 58px);
  padding: clamp(24px, 4vw, 38px);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: rgb(255 255 255 / 0.72);
  box-shadow: var(--shadow-soft);
}

.yb-home-section-cta h3 {
  margin: 0;
  font-size: clamp(1.45rem, 2.5vw, 2.35rem);
}

/* Hero */
.yb-home-hero {
  position: relative;
  min-height: 100svh;
  display: grid;
  align-items: center;
  overflow: hidden;
  isolation: isolate;
  background: var(--color-espresso);
  color: var(--color-ivory);
}

.yb-home-hero__media,
.yb-home-hero__overlay,
.yb-home-hero__steam,
.yb-home-hero__particles {
  position: absolute;
  inset: 0;
}

.yb-home-hero__media {
  z-index: -5;
}

.yb-home-hero__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.02);
}

.yb-home-hero__overlay {
  z-index: -4;
  background:
    radial-gradient(circle at 72% 22%, rgb(216 168 91 / 0.28), transparent 30%),
    radial-gradient(circle at 18% 82%, rgb(107 17 17 / 0.28), transparent 36%),
    linear-gradient(90deg, rgb(33 19 12 / 0.92) 0%, rgb(33 19 12 / 0.68) 48%, rgb(33 19 12 / 0.38) 100%),
    linear-gradient(180deg, rgb(33 19 12 / 0.34), rgb(33 19 12 / 0.72));
}

.yb-home-hero__steam {
  z-index: -3;
  opacity: .34;
  background:
    radial-gradient(ellipse at 24% 58%, rgb(255 255 255 / 0.08), transparent 19%),
    radial-gradient(ellipse at 35% 44%, rgb(255 255 255 / 0.055), transparent 18%),
    radial-gradient(ellipse at 18% 36%, rgb(255 255 255 / 0.035), transparent 18%);
  filter: blur(18px);
  animation: yb-steam-drift 24s ease-in-out infinite alternate;
}

.yb-home-hero__particles {
  z-index: -2;
  pointer-events: none;
}

.yb-home-hero__particles span {
  position: absolute;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--color-gold);
  opacity: .18;
  filter: blur(2px);
  animation: yb-particle-drift 18s linear infinite;
}

.yb-home-hero__particles span:nth-child(1) { inset-block-start: 26%; inset-inline-start: 12%; animation-delay: -3s; }
.yb-home-hero__particles span:nth-child(2) { inset-block-start: 46%; inset-inline-start: 44%; animation-delay: -8s; }
.yb-home-hero__particles span:nth-child(3) { inset-block-start: 72%; inset-inline-start: 28%; animation-delay: -12s; }
.yb-home-hero__particles span:nth-child(4) { inset-block-start: 32%; inset-inline-start: 78%; animation-delay: -5s; }

.yb-home-hero__content {
  position: relative;
  z-index: 2;
  max-width: 760px;
  padding-block: clamp(150px, 15vw, 220px) clamp(110px, 10vw, 160px);
  margin-inline-start: min(5vw, 80px);
}

.yb-home-hero .yb-kicker,
.yb-home-heritage .yb-kicker,
.yb-home-final-cta .yb-kicker {
  color: var(--color-gold);
}

.yb-home-hero h1 {
  max-width: 760px;
  color: var(--color-ivory);
  font-size: clamp(3.1rem, 6.7vw, 6.8rem);
  line-height: .93;
  letter-spacing: -.055em;
  margin-block-end: 24px;
}

.yb-home-hero__text {
  max-width: 640px;
  color: rgb(255 248 238 / 0.9);
  font-size: clamp(1.05rem, 1.35vw, 1.25rem);
  line-height: 1.75;
}

.yb-home-hero__actions {
  margin-block-start: 30px;
}

.yb-home-hero__badge {
  width: fit-content;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-block-start: 28px;
  padding: 10px 18px 10px 12px;
  border: 1px solid rgb(255 248 238 / 0.22);
  border-radius: var(--radius-pill);
  background: rgb(255 248 238 / 0.14);
  color: var(--color-ivory);
  box-shadow: 0 18px 40px rgb(0 0 0 / 0.18);
}

.yb-home-hero__badge-icon {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--color-gold);
  color: var(--color-espresso);
}

.yb-home-hero__badge svg {
  width: 16px;
  height: 16px;
}

.yb-home-hero__badge strong {
  position: relative;
  padding-inline-start: 12px;
  color: var(--color-gold);
}

.yb-home-hero__badge strong::before {
  content: '';
  position: absolute;
  inset-inline-start: 0;
  inset-block: 4px;
  width: 1px;
  background: rgb(255 248 238 / 0.28);
}

.yb-home-hero__metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 18px;
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
  color: rgb(255 248 238 / 0.78);
  font-size: .88rem;
  font-weight: 800;
}

.yb-home-hero__metrics li {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.yb-home-hero__metrics li::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--color-gold);
}

.yb-home-hero__scroll {
  position: absolute;
  z-index: 3;
  inset-inline-start: 50%;
  inset-block-end: 30px;
  width: 34px;
  height: 54px;
  border: 1px solid rgb(255 248 238 / 0.54);
  border-radius: 999px;
  transform: translateX(-50%);
}

.yb-home-hero__scroll span {
  position: absolute;
  inset-inline-start: 50%;
  inset-block-start: 10px;
  width: 4px;
  height: 10px;
  border-radius: 999px;
  background: var(--color-gold);
  transform: translateX(-50%);
  animation: yb-scroll-cue 2.5s ease-in-out infinite;
}

.yb-home-hero__directions {
  position: absolute;
  z-index: 3;
  inset-inline-end: clamp(18px, 4vw, 62px);
  inset-block-end: 32px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: rgb(255 248 238 / 0.86);
  font-weight: 850;
}

.yb-home-hero__directions svg {
  width: 18px;
  height: 18px;
  color: var(--color-gold);
}

/* Trust */
.yb-home-trust {
  padding-block: clamp(32px, 4vw, 42px);
  background:
    linear-gradient(90deg, rgb(216 168 91 / 0.18), transparent 18%, transparent 82%, rgb(216 168 91 / 0.16)),
    radial-gradient(circle at 50% 0%, rgb(216 168 91 / 0.18), transparent 38%),
    var(--color-cream);
  border-block-start: 1px solid rgb(216 168 91 / 0.42);
}

.yb-home-trust__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.yb-home-trust__card {
  min-height: 100%;
  padding: 28px;
  text-align: center;
  transition: transform var(--transition-slow), box-shadow var(--transition-slow), border-color var(--transition-base);
}

.yb-home-trust__card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-card);
  border-color: var(--color-border-strong);
}

.yb-home-trust__icon {
  width: 56px;
  height: 56px;
  display: inline-grid;
  place-items: center;
  margin-block-end: 18px;
  border-radius: 50%;
  background: var(--color-cream);
  color: var(--color-burgundy);
  transition: background-color var(--transition-base), color var(--transition-base), transform var(--transition-base);
}

.yb-home-trust__card:hover .yb-home-trust__icon {
  background: var(--color-burgundy);
  color: var(--color-white);
  transform: scale(1.08);
}

.yb-home-trust__icon svg {
  width: 24px;
  height: 24px;
}

.yb-home-trust__card h3 {
  margin-block-end: 10px;
  font-size: clamp(1.25rem, 1.6vw, 1.55rem);
}

.yb-home-trust__card p {
  margin: 0;
  font-size: .95rem;
}

/* About */
.yb-home-about {
  background:
    radial-gradient(circle at 16% 18%, rgb(216 168 91 / 0.14), transparent 26%),
    radial-gradient(circle at 92% 72%, rgb(107 17 17 / 0.08), transparent 26%),
    var(--color-ivory);
}

.yb-home-about__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(320px, .86fr);
  gap: clamp(36px, 6vw, 86px);
  align-items: center;
}

.yb-home-about__media {
  position: relative;
  overflow: hidden;
  border-radius: 32px;
  background: var(--color-cream);
  box-shadow: var(--shadow-card);
}

.yb-home-about__media::before {
  content: '';
  position: absolute;
  inset: -12%;
  z-index: -1;
  background: radial-gradient(circle, rgb(216 168 91 / 0.3), transparent 58%);
}

.yb-home-about__media img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.yb-home-about__media:hover img {
  transform: scale(1.03);
}

.yb-home-about__content {
  max-width: 590px;
}

.yb-home-about__features {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 28px 0 30px;
  padding: 0;
  list-style: none;
}

.yb-home-about__features li {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 46px;
  padding: 10px 12px;
  border: 1px solid var(--color-border);
  border-radius: 16px;
  background: rgb(255 255 255 / 0.62);
  color: var(--color-coffee);
  font-weight: 850;
}

.yb-home-about__features span {
  display: inline-grid;
  place-items: center;
  flex: 0 0 26px;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--color-burgundy);
  color: var(--color-white);
  font-size: .78rem;
}

/* Featured menu */
.yb-home-featured,
.yb-home-categories,
.yb-home-signature,
.yb-home-difference,
.yb-home-gallery,
.yb-home-instagram {
  background:
    radial-gradient(circle at 8% 10%, rgb(216 168 91 / 0.12), transparent 28%),
    radial-gradient(circle at 90% 84%, rgb(201 151 91 / 0.12), transparent 24%),
    var(--color-cream);
}

.yb-home-featured__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
}

.yb-home-filters {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-block: -20px 34px;
  overflow-x: auto;
  padding-block: 10px;
  scroll-snap-type: x proximity;
}

.yb-home-filter {
  flex: 0 0 auto;
  min-height: 42px;
  padding: 0 18px;
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-pill);
  background: rgb(255 255 255 / 0.62);
  color: var(--color-coffee);
  cursor: pointer;
  font-weight: 850;
  transition: background-color var(--transition-base), border-color var(--transition-base), color var(--transition-base), transform var(--transition-base);
  scroll-snap-align: start;
}

.yb-home-filter:hover,
.yb-home-filter:focus-visible {
  transform: translateY(-2px);
  border-color: var(--color-coffee);
}

.yb-home-filter.is-active {
  background: var(--color-burgundy);
  border-color: var(--color-burgundy);
  color: var(--color-white);
}

.yb-home-featured__grid [data-yb-filter-item].is-hidden {
  display: none;
}

.yb-home-product {
  min-height: 100%;
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: 28px;
  background: var(--color-white);
  box-shadow: var(--shadow-soft);
  transition: transform var(--transition-slow), box-shadow var(--transition-slow), border-color var(--transition-base);
}

.yb-home-product:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-card);
  border-color: var(--color-border-strong);
}

.yb-home-product__media {
  position: relative;
  display: block;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: var(--color-cream);
}

.yb-home-product__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.yb-home-product:hover .yb-home-product__media img {
  transform: scale(1.055);
}

.yb-home-product__badge {
  position: absolute;
  z-index: 2;
  inset-block-start: 14px;
  inset-inline-start: 14px;
  padding: 6px 10px;
  border-radius: var(--radius-pill);
  background: var(--color-gold);
  color: var(--color-espresso);
  font-size: .72rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.yb-home-product__body {
  display: grid;
  gap: 10px;
  padding: 24px;
}

.yb-home-product__category {
  margin: 0;
  color: var(--color-burgundy);
  font-size: .76rem;
  font-weight: 950;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.yb-home-product h3 {
  margin: 0;
  font-size: clamp(1.35rem, 2vw, 1.7rem);
}

.yb-home-product p {
  margin: 0;
}

.yb-home-product__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-block-start: 8px;
}

.yb-home-product__price {
  color: var(--color-coffee);
  font-size: 1.25rem;
  font-weight: 950;
}

.yb-home-product__chips,
.yb-home-product__notes {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 6px 0 0;
  padding: 0;
  list-style: none;
}

.yb-home-product__chips li,
.yb-home-product__notes li {
  padding: 6px 10px;
  border-radius: var(--radius-pill);
  background: var(--color-cream);
  color: var(--color-coffee);
  font-size: .82rem;
  font-weight: 800;
}

.yb-home-product__notes li {
  background: rgb(216 168 91 / 0.16);
}

/* Heritage */
.yb-home-heritage {
  overflow: hidden;
  isolation: isolate;
  background: var(--color-espresso);
  color: var(--color-ivory);
}

.yb-home-heritage__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 78% 18%, rgb(216 168 91 / 0.2), transparent 26%),
    radial-gradient(circle at 18% 76%, rgb(107 17 17 / 0.26), transparent 32%),
    repeating-linear-gradient(45deg, rgb(255 248 238 / 0.025) 0 1px, transparent 1px 18px),
    linear-gradient(135deg, var(--color-espresso), var(--color-coffee));
}

.yb-home-heritage__grid {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(320px, 1fr);
  gap: clamp(36px, 6vw, 86px);
  align-items: center;
}

.yb-home-heritage h2,
.yb-home-heritage h3 {
  color: var(--color-ivory);
}

.yb-home-heritage p,
.yb-home-heritage em,
.yb-home-heritage span {
  color: rgb(255 248 238 / 0.78);
}

.yb-home-heritage blockquote {
  position: relative;
  margin: 30px 0;
  padding-inline-start: 26px;
  border-inline-start: 3px solid var(--color-gold);
  color: var(--color-gold);
  font-family: var(--font-heading);
  font-size: clamp(1.55rem, 2.5vw, 2.2rem);
  font-style: italic;
  line-height: 1.2;
}

.yb-home-heritage__timeline {
  display: grid;
  gap: 18px;
  margin: 0;
  padding: 0;
  list-style: none;
  counter-reset: heritage;
}

.yb-home-heritage__timeline li {
  position: relative;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.yb-home-heritage__timeline li > span {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border: 1px solid rgb(216 168 91 / 0.48);
  border-radius: 50%;
  background: rgb(255 248 238 / 0.07);
}

.yb-home-heritage__timeline li > span::before {
  counter-increment: heritage;
  content: counter(heritage);
  color: var(--color-gold);
  font-weight: 950;
}

.yb-home-heritage__timeline strong {
  display: block;
  color: var(--color-ivory);
  font-size: 1.02rem;
}

.yb-home-heritage__timeline em {
  display: block;
  font-style: normal;
  line-height: 1.55;
}

.yb-home-heritage__media {
  position: relative;
}

.yb-home-heritage__media img {
  width: min(100%, 560px);
  margin-inline: auto;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: 32px;
  box-shadow: 0 40px 80px rgb(0 0 0 / 0.32);
}

.yb-home-heritage__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-block-start: -42px;
  padding: 18px;
  border: 1px solid rgb(255 248 238 / 0.16);
  border-radius: 24px;
  background: rgb(33 19 12 / 0.72);
  backdrop-filter: blur(16px);
  box-shadow: 0 28px 70px rgb(0 0 0 / 0.22);
}

.yb-home-heritage__stats div {
  text-align: center;
}

.yb-home-heritage__stats strong {
  display: block;
  color: var(--color-gold);
  font-family: var(--font-heading);
  font-size: clamp(1.75rem, 3vw, 2.6rem);
  line-height: 1;
}

.yb-home-heritage__stats span {
  display: block;
  margin-block-start: 8px;
  font-size: .82rem;
  line-height: 1.35;
}

.yb-home-heritage__cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin-block-start: clamp(44px, 7vw, 80px);
  padding-block-start: 34px;
  border-block-start: 1px solid rgb(255 248 238 / 0.16);
}

.yb-home-heritage__cta h3 {
  margin: 0;
}

/* Categories */
.yb-home-categories__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
}

.yb-home-category {
  position: relative;
  min-height: 380px;
  overflow: hidden;
  border-radius: 28px;
  background: var(--color-espresso);
  box-shadow: var(--shadow-soft);
  transition: transform var(--transition-slow), box-shadow var(--transition-slow);
}

.yb-home-category:hover,
.yb-home-category:focus-visible {
  transform: translateY(-8px);
  box-shadow: var(--shadow-card);
}

.yb-home-category img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.yb-home-category:hover img,
.yb-home-category:focus-visible img {
  transform: scale(1.08);
}

.yb-home-category__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgb(33 19 12 / 0.08), rgb(33 19 12 / 0.76));
}

.yb-home-category__content {
  position: absolute;
  inset-inline: 0;
  inset-block-end: 0;
  display: grid;
  gap: 8px;
  padding: 26px;
}

.yb-home-category__content em {
  color: var(--color-gold);
  font-style: normal;
  font-size: .76rem;
  font-weight: 950;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.yb-home-category__content strong {
  color: var(--color-white);
  font-family: var(--font-heading);
  font-size: clamp(1.65rem, 2.4vw, 2.15rem);
  line-height: 1.05;
}

.yb-home-category__content small {
  color: rgb(255 248 238 / 0.86);
  font-size: .94rem;
  line-height: 1.5;
}

/* Signature showcase */
.yb-home-signature {
  background:
    radial-gradient(circle at 16% 12%, rgb(216 168 91 / 0.12), transparent 30%),
    var(--color-ivory);
}

.yb-home-signature__list {
  display: grid;
  gap: clamp(46px, 7vw, 90px);
}

.yb-home-product--showcase {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, .88fr);
  align-items: center;
  gap: clamp(28px, 5vw, 72px);
  padding: clamp(16px, 2vw, 24px);
  background: transparent;
  border: 0;
  box-shadow: none;
}

.yb-home-signature__item--reverse .yb-home-product--showcase {
  grid-template-columns: minmax(320px, .88fr) minmax(0, 1.02fr);
}

.yb-home-signature__item--reverse .yb-home-product--showcase .yb-home-product__media {
  order: 2;
}

.yb-home-product--showcase:hover {
  transform: none;
  box-shadow: none;
}

.yb-home-product--showcase .yb-home-product__media {
  aspect-ratio: 4 / 5;
  border-radius: 32px;
  box-shadow: var(--shadow-card);
}

.yb-home-product--showcase .yb-home-product__body {
  padding: clamp(18px, 4vw, 38px);
  border: 1px solid var(--color-border);
  border-radius: 32px;
  background: rgb(255 255 255 / 0.72);
  box-shadow: var(--shadow-soft);
}

.yb-home-product--showcase h3 {
  font-size: clamp(2.1rem, 4vw, 3.4rem);
}

.yb-home-product--showcase .yb-home-product__story {
  font-size: 1.05rem;
}

.yb-home-product--showcase .yb-home-product__footer {
  justify-content: flex-start;
  flex-wrap: wrap;
}

/* Difference */
.yb-home-difference {
  background: var(--color-ivory);
}

.yb-home-difference__blocks {
  display: grid;
  gap: clamp(24px, 4vw, 42px);
}

.yb-home-difference__block {
  display: grid;
  grid-template-columns: minmax(220px, .8fr) minmax(0, 1fr);
  gap: clamp(24px, 4vw, 52px);
  align-items: center;
  padding: clamp(18px, 3vw, 28px);
  border: 1px solid var(--color-border);
  border-radius: 32px;
  background: rgb(255 255 255 / 0.64);
  box-shadow: var(--shadow-soft);
}

.yb-home-difference__block--reverse {
  grid-template-columns: minmax(0, 1fr) minmax(220px, .8fr);
}

.yb-home-difference__block--reverse .yb-home-difference__image {
  order: 2;
}

.yb-home-difference__image {
  overflow: hidden;
  border-radius: 28px;
  background: var(--color-cream);
}

.yb-home-difference__image img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.yb-home-difference__block:hover .yb-home-difference__image img {
  transform: scale(1.035);
}

.yb-home-difference__copy span {
  display: inline-flex;
  margin-block-end: 14px;
  color: var(--color-gold);
  font-family: var(--font-heading);
  font-size: 2.4rem;
  line-height: 1;
}

.yb-home-difference__copy h3 {
  margin-block-end: 10px;
}

.yb-home-difference__icon-strip {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
  margin: clamp(34px, 5vw, 58px) 0 0;
  padding: 0;
  list-style: none;
}

.yb-home-difference__icon-strip li {
  display: grid;
  justify-items: center;
  gap: 10px;
  padding: 18px 12px;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: var(--color-white);
  color: var(--color-coffee);
  text-align: center;
  font-size: .88rem;
  font-weight: 850;
}

.yb-home-difference__icon-strip span {
  display: inline-grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: var(--color-cream);
  color: var(--color-burgundy);
}

.yb-home-difference__icon-strip svg {
  width: 18px;
  height: 18px;
}

.yb-home-difference__quote {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  margin-block-start: 28px;
  padding: clamp(24px, 4vw, 42px);
  border-radius: 32px;
  background: var(--color-espresso);
  color: var(--color-ivory);
}

.yb-home-difference__quote p {
  max-width: 720px;
  margin: 0;
  color: var(--color-ivory);
  font-family: var(--font-heading);
  font-size: clamp(1.55rem, 3vw, 2.6rem);
  line-height: 1.16;
}

/* Experience */
.yb-home-experience {
  background:
    radial-gradient(circle at 82% 22%, rgb(216 168 91 / 0.18), transparent 32%),
    var(--color-cream);
}

.yb-home-experience__grid {
  display: grid;
  grid-template-columns: minmax(0, .88fr) minmax(320px, 1.04fr);
  gap: clamp(36px, 6vw, 84px);
  align-items: center;
}

.yb-home-experience__moments {
  display: grid;
  gap: 14px;
  margin-block: 30px;
}

.yb-home-experience__moments article {
  padding: 18px 20px;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: rgb(255 255 255 / 0.68);
}

.yb-home-experience__moments h3 {
  margin-block-end: 6px;
  font-size: 1.3rem;
}

.yb-home-experience__moments p {
  margin: 0;
}

.yb-home-experience__media {
  position: relative;
}

.yb-home-experience__media img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: 32px;
  box-shadow: var(--shadow-card);
}

.yb-home-experience__floating-card {
  position: absolute;
  inset-inline-start: clamp(18px, 4vw, 42px);
  inset-block-end: clamp(18px, 4vw, 42px);
  display: grid;
  gap: 4px;
  width: min(360px, calc(100% - 36px));
  padding: 18px 20px;
  border: 1px solid rgb(255 248 238 / 0.28);
  border-radius: 20px;
  background: rgb(33 19 12 / 0.78);
  color: var(--color-ivory);
  backdrop-filter: blur(14px);
}

.yb-home-experience__floating-card span {
  color: rgb(255 248 238 / 0.78);
}

/* Testimonials */
.yb-home-testimonials {
  background: var(--color-ivory);
}

.yb-home-testimonials__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.yb-home-review {
  display: grid;
  gap: 20px;
  padding: clamp(24px, 3vw, 34px);
}

.yb-home-review__stars {
  color: var(--color-gold);
  letter-spacing: .08em;
}

.yb-home-review p {
  margin: 0;
  color: var(--color-coffee);
  font-family: var(--font-heading);
  font-size: clamp(1.25rem, 1.8vw, 1.62rem);
  line-height: 1.32;
}

.yb-home-review footer {
  display: grid;
  gap: 2px;
}

.yb-home-review strong {
  color: var(--color-espresso);
}

.yb-home-review span {
  color: var(--color-text-muted);
  font-size: .9rem;
}

.yb-home-google-rating {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  width: fit-content;
  margin: 34px auto 0;
  padding: 12px 18px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  background: var(--color-white);
  box-shadow: var(--shadow-soft);
}

.yb-home-google-rating strong {
  color: var(--color-gold);
}

/* Gallery */
.yb-home-gallery__grid {
  display: grid;
  grid-auto-flow: dense;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.yb-home-gallery__item {
  position: relative;
  overflow: hidden;
  min-height: 250px;
  border-radius: 24px;
  background: var(--color-cream);
  box-shadow: var(--shadow-soft);
}

.yb-home-gallery__item.is-wide {
  grid-column: span 2;
}

.yb-home-gallery__item.is-tall {
  grid-row: span 2;
}

.yb-home-gallery__item img {
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
  transition: transform var(--transition-slow), filter var(--transition-slow);
}

.yb-home-gallery__item:hover img,
.yb-home-gallery__item:focus-visible img {
  transform: scale(1.05);
  filter: brightness(.78);
}

/* Instagram */
.yb-home-instagram__inner {
  display: grid;
  grid-template-columns: minmax(280px, .72fr) minmax(0, 1fr);
  gap: clamp(28px, 5vw, 68px);
  align-items: center;
}

.yb-home-instagram__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.yb-home-instagram__post {
  overflow: hidden;
  border-radius: 24px;
  background: var(--color-cream);
  box-shadow: var(--shadow-soft);
}

.yb-home-instagram__post img {
  width: 100%;
  aspect-ratio: 1 / 1.18;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.yb-home-instagram__post:hover img,
.yb-home-instagram__post:focus-visible img {
  transform: scale(1.06);
}

/* Newsletter */
.yb-home-newsletter {
  background: var(--color-ivory);
}

.yb-home-newsletter__inner {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(320px, .72fr);
  gap: clamp(26px, 5vw, 58px);
  align-items: center;
  padding: clamp(28px, 5vw, 56px);
  border: 1px solid var(--color-border);
  border-radius: 34px;
  background:
    radial-gradient(circle at 90% 18%, rgb(216 168 91 / 0.2), transparent 28%),
    var(--color-white);
  box-shadow: var(--shadow-card);
}

.yb-home-newsletter__form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}

.yb-home-newsletter__form input {
  border-radius: var(--radius-pill);
  min-height: 56px;
  padding-inline: 20px;
}

.yb-home-newsletter__note {
  grid-column: 1 / -1;
  margin: 0;
  font-size: .9rem;
}

/* Final CTA */
.yb-home-final-cta {
  overflow: hidden;
  isolation: isolate;
  padding-block: clamp(74px, 9vw, 126px);
  background: var(--color-espresso);
  color: var(--color-ivory);
}

.yb-home-final-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 20% 28%, rgb(216 168 91 / 0.18), transparent 34%),
    radial-gradient(circle at 86% 70%, rgb(107 17 17 / 0.32), transparent 30%),
    repeating-linear-gradient(135deg, rgb(255 248 238 / 0.028) 0 1px, transparent 1px 20px);
}

.yb-home-final-cta__inner {
  max-width: 860px;
  margin-inline: auto;
  text-align: center;
}

.yb-home-final-cta h2 {
  color: var(--color-ivory);
  font-size: clamp(2.4rem, 5.6vw, 5.4rem);
}

.yb-home-final-cta p {
  max-width: 650px;
  margin-inline: auto;
  color: rgb(255 248 238 / 0.82);
  font-size: 1.08rem;
}

.yb-home-final-cta .yb-button-group {
  justify-content: center;
  margin-block-start: 28px;
}

@keyframes yb-scroll-cue {
  0%, 100% { transform: translate(-50%, 0); opacity: .35; }
  50% { transform: translate(-50%, 18px); opacity: 1; }
}

@keyframes yb-steam-drift {
  from { transform: translate3d(0, 18px, 0) scale(1); }
  to { transform: translate3d(24px, -26px, 0) scale(1.08); }
}

@keyframes yb-particle-drift {
  from { transform: translate3d(0, 0, 0); }
  to { transform: translate3d(42px, -120px, 0); }
}

@media (min-width: 1600px) {
  .yb-home-hero {
    min-height: 1040px;
  }
}

@media (max-width: 1200px) {
  .yb-home-featured__grid,
  .yb-home-categories__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .yb-home-difference__icon-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .yb-home-hero__content {
    margin-inline-start: 0;
  }

  .yb-home-trust__grid,
  .yb-home-featured__grid,
  .yb-home-categories__grid,
  .yb-home-testimonials__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .yb-home-about__grid,
  .yb-home-heritage__grid,
  .yb-home-experience__grid,
  .yb-home-instagram__inner,
  .yb-home-newsletter__inner {
    grid-template-columns: 1fr;
  }

  .yb-home-about__media {
    order: -1;
  }

  .yb-home-product--showcase,
  .yb-home-signature__item--reverse .yb-home-product--showcase,
  .yb-home-difference__block,
  .yb-home-difference__block--reverse {
    grid-template-columns: 1fr;
  }

  .yb-home-signature__item--reverse .yb-home-product--showcase .yb-home-product__media,
  .yb-home-difference__block--reverse .yb-home-difference__image {
    order: 0;
  }

  .yb-home-heritage__cta,
  .yb-home-section-cta,
  .yb-home-difference__quote {
    align-items: flex-start;
    flex-direction: column;
  }

  .yb-home-instagram__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .yb-home-hero {
    min-height: 100svh;
  }

  .yb-home-hero__content {
    padding-block: 130px 94px;
  }

  .yb-home-hero__overlay {
    background:
      radial-gradient(circle at 72% 18%, rgb(216 168 91 / 0.22), transparent 28%),
      linear-gradient(180deg, rgb(33 19 12 / 0.9), rgb(33 19 12 / 0.72));
  }

  .yb-home-hero h1 {
    font-size: clamp(2.7rem, 12vw, 4.3rem);
  }

  .yb-home-hero__badge {
    align-items: flex-start;
    flex-direction: column;
    border-radius: 22px;
  }

  .yb-home-hero__badge strong {
    padding-inline-start: 0;
  }

  .yb-home-hero__badge strong::before,
  .yb-home-hero__directions {
    display: none;
  }

  .yb-home-trust__grid,
  .yb-home-featured__grid,
  .yb-home-testimonials__grid,
  .yb-home-gallery__grid {
    grid-template-columns: 1fr;
  }

  .yb-home-categories__grid {
    display: flex;
    gap: 20px;
    overflow-x: auto;
    padding-block-end: 12px;
    scroll-snap-type: x mandatory;
  }

  .yb-home-category {
    flex: 0 0 88%;
    min-height: 420px;
    scroll-snap-align: start;
  }

  .yb-home-gallery__item.is-wide,
  .yb-home-gallery__item.is-tall {
    grid-column: auto;
    grid-row: auto;
  }

  .yb-home-about__features,
  .yb-home-heritage__stats,
  .yb-home-difference__icon-strip,
  .yb-home-newsletter__form {
    grid-template-columns: 1fr;
  }

  .yb-home-product__footer {
    align-items: flex-start;
    flex-direction: column;
  }

  .yb-home-product__footer .yb-button,
  .yb-home-newsletter__form .yb-button {
    width: 100%;
  }

  .yb-home-google-rating {
    align-items: flex-start;
    flex-direction: column;
    border-radius: 20px;
  }
}

@media (max-width: 520px) {
  .yb-front-page .yb-section {
    padding-block: 56px;
  }

  .yb-home-hero__content {
    padding-block: 118px 86px;
  }

  .yb-home-hero__actions .yb-button,
  .yb-home-final-cta .yb-button,
  .yb-home-section-cta .yb-button {
    width: 100%;
  }

  .yb-home-trust__card,
  .yb-home-product__body,
  .yb-home-newsletter__inner {
    padding: 22px;
  }

  .yb-home-category {
    flex-basis: 92%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .yb-front-page [data-yb-reveal] {
    opacity: 1;
    transform: none;
  }

  .yb-home-hero__steam,
  .yb-home-hero__particles span,
  .yb-home-hero__scroll span {
    animation: none;
  }
}

/* Phase 3 Homepage Polish Pass */
.yb-section { padding-block: clamp(56px, 7vw, 96px); }
.yb-section-heading--center { margin-block-end: clamp(26px, 4vw, 42px); }
.yb-section-heading--compact { margin-block-end: 20px; }
.yb-home-section-cta { margin-block-start: clamp(24px, 4vw, 38px); padding: clamp(18px, 3vw, 28px); }
.yb-home-section-cta h3 { font-size: clamp(1.25rem, 2vw, 1.85rem); }
.yb-home-hero { min-height: 92svh; }
.yb-home-hero__content { padding-block: clamp(118px, 12vw, 170px) clamp(82px, 8vw, 120px); }
.yb-home-hero h1 { font-size: clamp(2.85rem, 6vw, 6.2rem); }
.yb-home-trust { padding-block: clamp(28px, 4vw, 52px); }
.yb-home-trust__grid { gap: 16px; }
.yb-home-trust__card { min-height: 100%; padding: 20px; }
.yb-home-trust__card p { font-size: .92rem; line-height: 1.55; }
.yb-home-about { padding-block: clamp(62px, 7vw, 104px); }
.yb-home-about__media { min-height: 420px; }
.yb-home-about__content { max-width: 620px; }
.yb-home-about__features { gap: 10px; margin-block: 22px; }
.yb-home-about__features li { padding: 10px 12px; font-size: .9rem; }
.yb-home-featured,
.yb-home-difference,
.yb-home-gallery { background: var(--color-ivory); }
.yb-home-featured__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.yb-home-filters { margin-block-end: 24px; gap: 8px; }
.yb-home-filter { min-height: 40px; padding: 9px 14px; font-size: .76rem; }
.yb-home-product { height: 100%; border-radius: 22px; }
.yb-home-product__media { aspect-ratio: 1 / .82; }
.yb-home-product__body { display: flex; flex-direction: column; min-height: 220px; padding: 18px; }
.yb-home-product__category { margin-block-end: 6px; font-size: .72rem; }
.yb-home-product h3 { font-size: clamp(1.28rem, 1.7vw, 1.65rem); margin-block-end: 8px; }
.yb-home-product p { font-size: .92rem; line-height: 1.55; }
.yb-home-product__footer { margin-block-start: auto; padding-block-start: 14px; }
.yb-home-heritage { padding-block: clamp(64px, 8vw, 108px); background: var(--color-espresso); color: var(--color-ivory); }
.yb-home-heritage__grid { grid-template-columns: minmax(0, .95fr) minmax(360px, .75fr); align-items: center; gap: clamp(34px, 6vw, 86px); }
.yb-home-heritage__content { max-width: 620px; }
.yb-home-heritage h2 { font-size: clamp(2.2rem, 4.8vw, 4.5rem); color: var(--color-ivory); }
.yb-home-heritage p { color: rgb(255 248 238 / 0.78); }
.yb-home-heritage blockquote { margin: 24px 0; padding: 18px 22px; border-inline-start: 3px solid var(--color-gold); border-radius: 0 18px 18px 0; background: rgb(255 248 238 / 0.07); color: var(--color-ivory); font-size: clamp(1.15rem, 2vw, 1.55rem); line-height: 1.35; }
.yb-home-heritage__timeline,
.yb-home-heritage__cta { display: none; }
.yb-home-heritage__media { display: grid; gap: 16px; }
.yb-home-heritage__image-card { position: relative; overflow: hidden; border-radius: var(--radius-lg); min-height: 420px; border: 1px solid rgb(255 248 238 / 0.18); box-shadow: 0 28px 80px rgb(0 0 0 / 0.22); }
.yb-home-heritage__image-card img { width: 100%; height: 100%; object-fit: cover; }
.yb-home-heritage__image-card span { position: absolute; inset-inline: 18px; inset-block-end: 18px; display: inline-flex; width: fit-content; max-width: calc(100% - 36px); padding: 10px 14px; border-radius: var(--radius-pill); background: rgb(33 19 12 / 0.72); color: var(--color-ivory); font-weight: 850; font-size: .85rem; }
.yb-home-heritage__stats { position: static; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; padding: 0; background: transparent; border: 0; box-shadow: none; }
.yb-home-heritage__stats div { min-height: 112px; padding: 18px 14px; display: grid; align-content: center; border-radius: 20px; background: rgb(255 248 238 / 0.08); border: 1px solid rgb(255 248 238 / 0.16); }
.yb-home-heritage__stats strong { color: var(--color-gold); font-size: clamp(1.2rem, 2vw, 1.55rem); }
.yb-home-heritage__stats span { color: rgb(255 248 238 / 0.72); font-size: .78rem; line-height: 1.35; }
.yb-home-difference__grid { display: grid; grid-template-columns: minmax(360px, .85fr) minmax(0, 1fr); gap: clamp(34px, 6vw, 78px); align-items: center; }
.yb-home-difference__media { position: relative; min-height: 560px; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-card); }
.yb-home-difference__media > img { width: 100%; height: 100%; object-fit: cover; }
.yb-home-difference__media::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 48%, rgb(33 19 12 / .38)); pointer-events: none; }
.yb-home-difference__mini-image { position: absolute; inset-inline-end: 22px; inset-block-end: 22px; width: min(190px, 38%); aspect-ratio: 1; border-radius: 24px; overflow: hidden; border: 8px solid var(--color-ivory); box-shadow: 0 22px 60px rgb(0 0 0 / .18); z-index: 2; }
.yb-home-difference__mini-image img { width: 100%; height: 100%; object-fit: cover; }
.yb-home-difference__content > p { max-width: 660px; }
.yb-home-difference__cards { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; margin-block: 24px 26px; }
.yb-home-difference__card { min-height: 100%; padding: 18px; }
.yb-home-difference__card span { width: 38px; height: 38px; display: inline-grid; place-items: center; border-radius: 50%; background: var(--color-cream); color: var(--color-burgundy); margin-block-end: 12px; }
.yb-home-difference__card svg { width: 18px; height: 18px; }
.yb-home-difference__card h3 { margin-block-end: 8px; font-size: clamp(1.15rem, 1.8vw, 1.45rem); }
.yb-home-difference__card p { font-size: .9rem; line-height: 1.52; margin: 0; }
.yb-home-difference__blocks,
.yb-home-difference__icon-strip,
.yb-home-difference__quote { display: none; }
.yb-home-catering { background: linear-gradient(180deg, var(--color-cream), var(--color-ivory)); }
.yb-home-catering__inner { display: grid; grid-template-columns: minmax(0, .95fr) minmax(360px, .75fr); align-items: center; gap: clamp(32px, 6vw, 82px); }
.yb-home-catering__copy { max-width: 640px; }
.yb-home-checklist { display: grid; gap: 10px; padding: 0; margin: 22px 0 26px; list-style: none; }
.yb-home-checklist li { display: flex; align-items: center; gap: 10px; padding: 11px 14px; border-radius: 16px; background: rgb(255 255 255 / .74); border: 1px solid var(--color-border); font-weight: 750; color: var(--color-coffee); }
.yb-home-checklist span { display: inline-grid; place-items: center; width: 24px; height: 24px; border-radius: 50%; background: var(--color-burgundy); color: var(--color-white); font-size: .78rem; }
.yb-home-catering__media { position: relative; min-height: 500px; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-card); background: var(--color-espresso); }
.yb-home-catering__media > img { width: 100%; height: 100%; object-fit: cover; }
.yb-home-catering__drink-card { position: absolute; inset-inline-start: 22px; inset-block-end: 22px; display: grid; grid-template-columns: 74px minmax(0, 1fr); align-items: center; gap: 12px; max-width: 330px; padding: 12px; border-radius: 22px; background: rgb(255 248 238 / .94); box-shadow: 0 22px 60px rgb(0 0 0 / .18); }
.yb-home-catering__drink-card img { width: 74px; height: 74px; border-radius: 16px; object-fit: cover; }
.yb-home-catering__drink-card strong { color: var(--color-espresso); font-size: .92rem; line-height: 1.3; }
.yb-home-franchise { background: var(--color-espresso); color: var(--color-ivory); }
.yb-home-franchise__inner { display: grid; grid-template-columns: minmax(360px, .82fr) minmax(0, 1fr); align-items: stretch; gap: clamp(26px, 5vw, 58px); padding: clamp(18px, 3vw, 30px); border-radius: var(--radius-lg); background: rgb(255 248 238 / .08); border: 1px solid rgb(255 248 238 / .14); }
.yb-home-franchise__media { min-height: 440px; overflow: hidden; border-radius: 24px; }
.yb-home-franchise__media img { width: 100%; height: 100%; object-fit: cover; }
.yb-home-franchise__copy { display: grid; align-content: center; padding: clamp(14px, 3vw, 38px); }
.yb-home-franchise h2 { color: var(--color-ivory); }
.yb-home-franchise p { color: rgb(255 248 238 / .76); }
.yb-home-franchise .yb-kicker { color: var(--color-gold); }
.yb-home-franchise__stats { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; margin-block: 24px 28px; }
.yb-home-franchise__stats div { min-height: 104px; padding: 16px 12px; display: grid; align-content: center; border-radius: 18px; background: rgb(255 248 238 / .08); border: 1px solid rgb(255 248 238 / .14); }
.yb-home-franchise__stats strong { color: var(--color-gold); font-size: clamp(1rem, 1.5vw, 1.2rem); }
.yb-home-franchise__stats span { color: rgb(255 248 238 / .72); font-size: .78rem; line-height: 1.35; }
.yb-home-testimonials { background: var(--color-cream); }
.yb-home-testimonials__layout { display: grid; grid-template-columns: minmax(320px, .55fr) minmax(0, 1fr); gap: clamp(22px, 4vw, 44px); align-items: stretch; }
.yb-home-testimonials__image { position: relative; min-height: 440px; overflow: hidden; border-radius: var(--radius-lg); box-shadow: var(--shadow-card); background: var(--color-espresso); }
.yb-home-testimonials__image img { width: 100%; height: 100%; object-fit: cover; }
.yb-home-testimonials__grid { grid-template-columns: 1fr; gap: 14px; }
.yb-home-review { min-height: 100%; padding: 20px; }
.yb-home-review p { font-size: .96rem; line-height: 1.58; }
.yb-home-google-rating { position: absolute; inset-inline: 18px; inset-block-end: 18px; width: auto; margin: 0; padding: 14px 16px; border-radius: 20px; background: rgb(255 248 238 / .94); box-shadow: 0 18px 48px rgb(0 0 0 / .16); }
.yb-home-gallery__grid { grid-auto-rows: 190px; gap: 12px; }
.yb-home-gallery__item { border-radius: 20px; }
.yb-home-newsletter { padding-block: clamp(50px, 7vw, 86px); }
.yb-home-newsletter__inner { padding: clamp(24px, 4vw, 42px); }
.yb-home-final-cta { padding-block: clamp(70px, 9vw, 118px); }
.yb-home-final-cta__inner { max-width: 900px; }

@media (max-width: 1200px) {
  .yb-home-featured__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .yb-home-difference__grid,
  .yb-home-catering__inner,
  .yb-home-franchise__inner { grid-template-columns: 1fr; }
  .yb-home-difference__media,
  .yb-home-catering__media,
  .yb-home-franchise__media { min-height: 420px; }
}

@media (max-width: 980px) {
  .yb-home-heritage__grid,
  .yb-home-testimonials__layout { grid-template-columns: 1fr; }
  .yb-home-heritage__image-card { min-height: 360px; }
  .yb-home-testimonials__image { min-height: 360px; }
}

@media (max-width: 760px) {
  .yb-section { padding-block: 52px; }
  .yb-home-featured__grid,
  .yb-home-difference__cards { grid-template-columns: 1fr; }
  .yb-home-heritage__stats,
  .yb-home-franchise__stats { grid-template-columns: 1fr; }
  .yb-home-heritage__stats div,
  .yb-home-franchise__stats div { min-height: auto; }
  .yb-home-catering__media,
  .yb-home-difference__media,
  .yb-home-franchise__media { min-height: 330px; }
  .yb-home-catering__drink-card { inset-inline: 14px; inset-block-end: 14px; max-width: calc(100% - 28px); }
  .yb-home-gallery__grid { grid-template-columns: 1fr 1fr; grid-auto-rows: 150px; }
  .yb-home-gallery__item.is-wide,
  .yb-home-gallery__item.is-tall { grid-column: auto; grid-row: auto; }
}

@media (max-width: 520px) {
  .yb-home-hero { min-height: 86svh; }
  .yb-home-hero__content { padding-block: 112px 70px; }
  .yb-home-product__body,
  .yb-home-review,
  .yb-home-difference__card { padding: 16px; }
  .yb-home-gallery__grid { grid-template-columns: 1fr; }
}

/* Phase 3 premium homepage mobile UI/UX polish */
.yb-front-page { overflow-x: clip; }
.yb-front-page .yb-section { padding-block: clamp(48px, 6vw, 82px); }
.yb-front-page .yb-section-heading--center { max-width: 690px; margin-block-end: clamp(22px, 3.2vw, 34px); }
.yb-front-page .yb-section-heading h2 { margin-block-end: 0.28em; }
.yb-front-page .yb-section-heading p:last-child { max-width: 600px; margin-inline: auto; font-size: clamp(0.94rem, 1.15vw, 1.05rem); line-height: 1.62; }
.yb-front-page .yb-kicker { margin-block-end: 0.55rem; font-size: 0.72rem; letter-spacing: 0.14em; }
.yb-front-page h2 { font-size: clamp(1.95rem, 3.8vw, 3.75rem); }

.home .site-header,
.front-page .site-header { background: linear-gradient(180deg, rgb(33 19 12 / 0.62), rgb(33 19 12 / 0.08)); }
.home .site-header.is-scrolled,
.front-page .site-header.is-scrolled { background: rgb(255 248 238 / 0.97); }

/* Hero: premium but not oversized */
.yb-home-hero { min-height: min(88svh, 880px); }
.yb-home-hero__content { max-width: 700px; padding-block: clamp(108px, 10vw, 152px) clamp(70px, 7vw, 108px); margin-inline-start: min(3vw, 44px); }
.yb-home-hero h1 { max-width: 700px; margin-block-end: 18px; font-size: clamp(2.65rem, 5.4vw, 5.8rem); line-height: 0.96; letter-spacing: -0.052em; }
.yb-home-hero__text { max-width: 560px; font-size: clamp(0.98rem, 1.15vw, 1.12rem); line-height: 1.68; }
.yb-home-hero__actions { margin-block-start: 24px; }
.yb-home-hero__badge { margin-block-start: 22px; padding: 8px 15px 8px 10px; font-size: 0.86rem; }
.yb-home-hero__badge-icon { width: 30px; height: 30px; }
.yb-home-hero__metrics { margin-block-start: 16px; gap: 9px 14px; font-size: 0.8rem; }
.yb-home-hero__scroll { width: 30px; height: 46px; inset-block-end: 20px; opacity: 0.82; }
.yb-home-hero__directions { inset-block-end: 22px; font-size: 0.85rem; }

/* Trust bar: compact conversion strip */
.yb-home-trust { padding-block: clamp(18px, 2.8vw, 30px); }
.yb-home-trust__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.yb-home-trust__card { display: grid; grid-template-columns: auto minmax(0, 1fr); align-items: center; gap: 12px; min-height: auto; padding: 15px 16px; text-align: start; border-radius: 18px; }
.yb-home-trust__icon { width: 38px; height: 38px; margin: 0; }
.yb-home-trust__icon svg { width: 18px; height: 18px; }
.yb-home-trust__card h3 { margin: 0; font-family: var(--font-body); font-size: 0.9rem; letter-spacing: -0.01em; line-height: 1.25; }
.yb-home-trust__card p { grid-column: 2; margin: -3px 0 0; font-size: 0.78rem; line-height: 1.35; }

/* About */
.yb-home-about__grid { grid-template-columns: minmax(0, 0.96fr) minmax(320px, 0.88fr); gap: clamp(28px, 5vw, 68px); }
.yb-home-about__media { min-height: 0; border-radius: 26px; }
.yb-home-about__media img { aspect-ratio: 1.08 / 1; }
.yb-home-about__content p { line-height: 1.62; }
.yb-home-about__features { margin-block: 18px 22px; gap: 9px; }
.yb-home-about__features li { min-height: 40px; padding: 8px 11px; border-radius: 14px; font-size: 0.86rem; line-height: 1.3; }
.yb-home-about__features span { flex-basis: 22px; width: 22px; height: 22px; }

/* Featured menu: fewer, stronger product cards */
.yb-home-featured { background: linear-gradient(180deg, var(--color-cream), var(--color-ivory)); }
.yb-home-featured__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.yb-home-product { border-radius: 20px; box-shadow: 0 14px 36px rgb(33 19 12 / 0.075); }
.yb-home-product:hover { transform: translateY(-4px); }
.yb-home-product__media { aspect-ratio: 1 / 0.88; }
.yb-home-product__badge { inset-block-start: 10px; inset-inline-start: 10px; padding: 5px 8px; font-size: 0.64rem; }
.yb-home-product__body { min-height: 0; padding: 15px; gap: 7px; }
.yb-home-product__category { font-size: 0.66rem; letter-spacing: 0.11em; }
.yb-home-product h3 { font-size: clamp(1.08rem, 1.35vw, 1.34rem); line-height: 1.1; }
.yb-home-product p { font-size: 0.82rem; line-height: 1.42; }
.yb-home-product__footer { gap: 10px; padding-block-start: 9px; margin-block-start: auto; }
.yb-home-product__price { font-size: 1rem; }
.yb-home-product__footer .yb-button { min-height: 34px; padding-inline: 12px; font-size: 0.7rem; white-space: nowrap; }
.yb-home-section-cta { margin-block-start: 24px; padding: 17px 20px; border-radius: 22px; }
.yb-home-section-cta h3 { font-family: var(--font-body); font-size: 1rem; font-weight: 850; letter-spacing: -0.01em; }

/* Heritage */
.yb-home-heritage { padding-block: clamp(52px, 7vw, 88px); }
.yb-home-heritage__grid { grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.72fr); gap: clamp(28px, 5vw, 64px); }
.yb-home-heritage__content { max-width: 590px; }
.yb-home-heritage h2 { font-size: clamp(2rem, 4vw, 4rem); }
.yb-home-heritage__content p { line-height: 1.62; }
.yb-home-heritage blockquote { margin-block: 18px; padding: 15px 18px; font-size: clamp(1.05rem, 1.55vw, 1.35rem); }
.yb-home-heritage__image-card { min-height: 340px; border-radius: 24px; }
.yb-home-heritage__stats { gap: 8px; }
.yb-home-heritage__stats div { min-height: 88px; padding: 13px 10px; border-radius: 16px; }
.yb-home-heritage__stats strong { font-size: clamp(1rem, 1.55vw, 1.32rem); }
.yb-home-heritage__stats span { margin-block-start: 5px; font-size: 0.7rem; }

/* Catering and franchise previews */
.yb-home-catering__inner { grid-template-columns: minmax(0, 0.92fr) minmax(320px, 0.72fr); gap: clamp(26px, 5vw, 64px); }
.yb-home-catering__copy p { line-height: 1.62; }
.yb-home-checklist { margin-block: 18px 22px; gap: 8px; }
.yb-home-checklist li { padding: 9px 12px; border-radius: 14px; font-size: 0.9rem; line-height: 1.35; }
.yb-home-catering__media { min-height: 390px; border-radius: 24px; }
.yb-home-catering__drink-card { grid-template-columns: 58px minmax(0, 1fr); max-width: 285px; padding: 10px; border-radius: 18px; }
.yb-home-catering__drink-card img { width: 58px; height: 58px; border-radius: 13px; }
.yb-home-franchise { padding-block: clamp(50px, 7vw, 84px); }
.yb-home-franchise__inner { grid-template-columns: minmax(320px, 0.72fr) minmax(0, 0.94fr); gap: clamp(22px, 4vw, 48px); padding: clamp(14px, 2.4vw, 24px); border-radius: 26px; }
.yb-home-franchise__media { min-height: 340px; border-radius: 20px; }
.yb-home-franchise__copy { padding: clamp(8px, 2vw, 24px); }
.yb-home-franchise__stats { margin-block: 18px 22px; gap: 8px; }
.yb-home-franchise__stats div { min-height: 78px; padding: 12px 10px; border-radius: 14px; }

/* Customer stories */
.yb-home-testimonials__layout { grid-template-columns: minmax(290px, 0.42fr) minmax(0, 0.58fr); gap: clamp(18px, 3vw, 34px); }
.yb-home-testimonials__image { min-height: 350px; border-radius: 24px; }
.yb-home-testimonials__grid { gap: 12px; }
.yb-home-review { padding: 16px; gap: 12px; border-radius: 18px; }
.yb-home-review p { font-size: 0.9rem; line-height: 1.48; }
.yb-home-google-rating { inset-inline: 14px; inset-block-end: 14px; padding: 11px 13px; border-radius: 16px; font-size: 0.82rem; }

/* Gallery */
.yb-home-gallery { background: var(--color-ivory); }
.yb-home-gallery__grid { grid-template-columns: repeat(6, minmax(0, 1fr)); grid-auto-rows: 150px; gap: 10px; }
.yb-home-gallery__item { min-height: 0; border-radius: 18px; }
.yb-home-gallery__item.is-wide { grid-column: span 2; }
.yb-home-gallery__item.is-tall { grid-row: span 1; }
.yb-home-gallery__item img { min-height: 0; }

/* Combined newsletter/final CTA */
.yb-home-newsletter { padding-block: clamp(46px, 6vw, 78px); background: var(--color-espresso); color: var(--color-ivory); }
.yb-home-newsletter__inner { grid-template-columns: minmax(0, 0.92fr) minmax(300px, 0.62fr); gap: clamp(20px, 4vw, 46px); padding: clamp(22px, 4vw, 42px); border-color: rgb(255 248 238 / 0.16); border-radius: 28px; background: radial-gradient(circle at 85% 18%, rgb(216 168 91 / 0.22), transparent 30%), rgb(255 248 238 / 0.07); box-shadow: 0 24px 70px rgb(0 0 0 / 0.18); }
.yb-home-newsletter .yb-kicker { color: var(--color-gold); }
.yb-home-newsletter h2 { color: var(--color-ivory); font-size: clamp(2rem, 4.4vw, 4.1rem); }
.yb-home-newsletter p { color: rgb(255 248 238 / 0.78); }
.yb-home-newsletter__actions { margin-block-start: 20px; }
.yb-home-newsletter__form { grid-template-columns: 1fr; padding: 18px; border: 1px solid rgb(255 248 238 / 0.16); border-radius: 22px; background: rgb(255 248 238 / 0.08); }
.yb-home-newsletter__form input { min-height: 48px; border: 1px solid rgb(255 248 238 / 0.16); background: rgb(255 248 238 / 0.96); }
.yb-home-newsletter__form .yb-button { width: 100%; min-height: 46px; }
.yb-home-newsletter__note { font-size: 0.8rem; color: rgb(255 248 238 / 0.66); }

@media (max-width: 1260px) {
  .yb-home-featured__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .yb-home-trust__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .yb-home-gallery__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 980px) {
  .yb-home-hero { min-height: 82svh; }
  .yb-home-hero__content { margin-inline-start: 0; }
  .yb-home-about__grid,
  .yb-home-heritage__grid,
  .yb-home-catering__inner,
  .yb-home-franchise__inner,
  .yb-home-testimonials__layout,
  .yb-home-newsletter__inner { grid-template-columns: 1fr; }
  .yb-home-about__media img { aspect-ratio: 16 / 10; }
  .yb-home-catering__media,
  .yb-home-franchise__media,
  .yb-home-testimonials__image { min-height: 310px; }
  .yb-home-heritage__image-card { min-height: 300px; }
  .yb-home-franchise__media { order: -1; }
}

@media (max-width: 768px) {
  .yb-front-page .yb-section { padding-block: 44px; }
  .yb-front-page .yb-section-heading--center { margin-block-end: 20px; }
  .yb-home-hero h1 { font-size: clamp(2.28rem, 9vw, 3.75rem); }
  .yb-home-hero__text { font-size: 0.96rem; line-height: 1.58; }
  .yb-home-hero__badge,
  .yb-home-hero__scroll,
  .yb-home-hero__directions { display: none; }
  .yb-home-hero__metrics { max-width: 340px; }
  .yb-home-trust__grid { grid-template-columns: 1fr 1fr; gap: 9px; }
  .yb-home-trust__card { padding: 12px; gap: 9px; border-radius: 15px; }
  .yb-home-trust__icon { width: 32px; height: 32px; }
  .yb-home-trust__card h3 { font-size: 0.8rem; }
  .yb-home-trust__card p { display: none; }
  .yb-home-featured__grid { grid-template-columns: 1fr; gap: 12px; }
  .yb-home-section-cta { align-items: flex-start; flex-direction: column; gap: 14px; }
  .yb-home-section-cta .yb-button-group { width: 100%; }
  .yb-home-heritage__stats,
  .yb-home-franchise__stats { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .yb-home-heritage__stats div,
  .yb-home-franchise__stats div { min-height: 76px; padding: 10px 7px; }
  .yb-home-catering__media,
  .yb-home-franchise__media,
  .yb-home-testimonials__image { min-height: 280px; }
  .yb-home-gallery__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); grid-auto-rows: 132px; gap: 8px; }
  .yb-home-gallery__item.is-wide { grid-column: span 2; }
  .yb-home-gallery__item.is-tall { grid-row: auto; }
}

@media (max-width: 560px) {
  .yb-front-page .yb-section { padding-block: 38px; }
  .yb-front-page .yb-container { width: min(100% - 24px, 100%); }
  .yb-front-page h2 { font-size: clamp(1.72rem, 8vw, 2.35rem); }
  .yb-front-page .yb-section-heading p:last-child { font-size: 0.9rem; line-height: 1.5; }
  .yb-front-page .yb-button-group { gap: 9px; }
  .yb-front-page .yb-button-group .yb-button { flex: 0 1 auto; }
  .yb-home-hero { min-height: 76svh; }
  .yb-home-hero__content { padding-block: 94px 52px; }
  .yb-home-hero h1 { max-width: 350px; margin-block-end: 12px; font-size: clamp(2.08rem, 10.5vw, 3rem); line-height: 1; letter-spacing: -0.045em; }
  .yb-home-hero__text { max-width: 340px; margin-block-end: 0; font-size: 0.9rem; line-height: 1.5; }
  .yb-home-hero__actions { margin-block-start: 18px; width: min(100%, 340px); }
  .yb-home-hero__actions .yb-button { flex: 1 1 calc(50% - 5px); width: auto; min-height: 42px; padding-inline: 12px; font-size: 0.76rem; }
  .yb-home-hero__metrics { display: none; }
  .yb-home-trust { padding-block: 16px; }
  .yb-home-about__media { border-radius: 20px; }
  .yb-home-about__media img { aspect-ratio: 1.35 / 1; }
  .yb-home-about__features { grid-template-columns: 1fr; margin-block: 15px 18px; }
  .yb-home-about__features li { min-height: 36px; font-size: 0.82rem; }
  .yb-home-product { display: grid; grid-template-columns: 38% minmax(0, 1fr); align-items: stretch; border-radius: 18px; }
  .yb-home-product__media { height: 100%; min-height: 164px; aspect-ratio: auto; }
  .yb-home-product__body { padding: 13px; gap: 5px; }
  .yb-home-product__category { font-size: 0.6rem; }
  .yb-home-product h3 { font-size: 1.02rem; }
  .yb-home-product p { display: none; }
  .yb-home-product__footer { flex-direction: row; align-items: center; gap: 8px; padding-block-start: 6px; }
  .yb-home-product__price { font-size: 0.92rem; }
  .yb-home-product__footer .yb-button { width: auto; min-height: 32px; padding-inline: 10px; font-size: 0.64rem; }
  .yb-home-section-cta { padding: 15px; border-radius: 18px; }
  .yb-home-section-cta .yb-button { width: auto; min-height: 38px; padding-inline: 12px; font-size: 0.72rem; }
  .yb-home-heritage blockquote { padding: 13px 15px; font-size: 1rem; }
  .yb-home-heritage__image-card { min-height: 245px; border-radius: 20px; }
  .yb-home-heritage__image-card span { inset-inline: 12px; inset-block-end: 12px; max-width: calc(100% - 24px); padding: 8px 10px; font-size: 0.72rem; border-radius: 14px; }
  .yb-home-heritage__stats { gap: 7px; }
  .yb-home-heritage__stats strong { font-size: 0.9rem; }
  .yb-home-heritage__stats span { font-size: 0.62rem; line-height: 1.22; }
  .yb-home-catering__media,
  .yb-home-franchise__media,
  .yb-home-testimonials__image { min-height: 235px; border-radius: 20px; }
  .yb-home-checklist li { padding: 8px 10px; font-size: 0.82rem; }
  .yb-home-catering__drink-card { grid-template-columns: 46px minmax(0, 1fr); inset-inline: 10px; inset-block-end: 10px; max-width: calc(100% - 20px); padding: 8px; border-radius: 15px; }
  .yb-home-catering__drink-card img { width: 46px; height: 46px; border-radius: 11px; }
  .yb-home-catering__drink-card strong { font-size: 0.78rem; }
  .yb-home-franchise__inner { padding: 12px; border-radius: 22px; }
  .yb-home-franchise__copy { padding: 4px; }
  .yb-home-franchise__stats div { min-height: 66px; }
  .yb-home-franchise__stats strong { font-size: 0.72rem; }
  .yb-home-franchise__stats span { font-size: 0.6rem; line-height: 1.22; }
  .yb-home-review { padding: 14px; gap: 9px; }
  .yb-home-review p { font-size: 0.84rem; line-height: 1.45; }
  .yb-home-google-rating { padding: 9px 10px; font-size: 0.72rem; }
  .yb-home-gallery__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); grid-auto-rows: 118px; }
  .yb-home-gallery__item { border-radius: 14px; }
  .yb-home-newsletter__inner { padding: 18px; border-radius: 22px; }
  .yb-home-newsletter__actions .yb-button { width: auto; min-height: 40px; padding-inline: 12px; font-size: 0.72rem; }
  .yb-home-newsletter__form { padding: 13px; border-radius: 18px; }
  .yb-home-newsletter__form input { min-height: 44px; }
}

@media (max-width: 414px) {
  .yb-home-hero__actions .yb-button,
  .yb-home-newsletter__actions .yb-button,
  .yb-home-section-cta .yb-button { flex: 1 1 100%; width: 100%; }
  .yb-home-product { grid-template-columns: 36% minmax(0, 1fr); }
  .yb-home-product__media { min-height: 150px; }
  .yb-home-product__body { padding: 11px; }
  .yb-home-product__footer { align-items: flex-start; flex-direction: column; gap: 6px; }
  .yb-home-product__footer .yb-button { width: 100%; }
}

@media (max-width: 390px) {
  .yb-home-hero { min-height: 74svh; }
  .yb-home-hero__content { padding-block-start: 88px; }
  .yb-home-trust__grid { grid-template-columns: 1fr; }
  .yb-home-trust__card { grid-template-columns: auto minmax(0, 1fr); }
  .yb-home-gallery__grid { grid-auto-rows: 108px; }
}

/* === pages/about.css === */
/* Phase-specific styles will be expanded in upcoming phases. */

/* === pages/menu.css === */
/* Phase-specific styles will be expanded in upcoming phases. */

/* === pages/catering.css === */
/* Phase-specific styles will be expanded in upcoming phases. */

/* === pages/locations.css === */
/* Phase-specific styles will be expanded in upcoming phases. */

/* === pages/contact.css === */
/* Phase-specific styles will be expanded in upcoming phases. */

/* === pages/franchise.css === */
/* Phase-specific styles will be expanded in upcoming phases. */

/* === responsive/desktop.css === */
/* Phase-specific styles will be expanded in upcoming phases. */

/* === responsive/laptop.css === */
@media (max-width: 1180px) {
  .site-navigation__menu { gap: 20px; }
  .site-header__cta { display: none; }
  .site-footer__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* === responsive/tablet.css === */
@media (max-width: 900px) {
  .yb-container { width: min(100% - 32px, 100%); }
  .site-header__top { display: none; }
  .site-navigation { display: none; }
  .site-header__toggle { display: inline-grid; }
  .site-header__inner { min-height: 64px; }
  .site-header__logo, .custom-logo { width: 150px; }
  .site-footer__grid,
  .yb-post-grid,
  .yb-grid-2,
  .yb-grid-3 { grid-template-columns: 1fr; }
  .site-footer__bottom-inner { flex-direction: column; align-items: flex-start; }
  .yb-search-form { grid-template-columns: 1fr; }
}

/* === responsive/mobile.css === */
@media (max-width: 560px) {
  .yb-container { width: min(100% - 24px, 100%); }
  .site-header__logo, .custom-logo { width: 150px; }
  .site-header__actions { gap: 8px; }
  .site-header__icon-button,
  .site-header__cart,
  .site-header__toggle { width: 42px; height: 42px; }
  .yb-button-group,
  .yb-button { width: 100%; }
  .yb-overlay__panel { width: calc(100% - 20px); margin-block-start: 72px; padding: 26px 20px; }
  .yb-drawer__panel { width: 100%; }
  .yb-drawer__header,
  .yb-mini-cart__body { padding-inline: 20px; }
}

@media (max-width: 900px) {
  .yb-cta__inner { grid-template-columns: 1fr; }
  .yb-cta__actions { justify-content: flex-start; }
  .yb-gallery--cols-2,
  .yb-gallery--cols-3,
  .yb-gallery--cols-4 { grid-template-columns: 1fr 1fr; }
  .yb-form-row { grid-template-columns: 1fr; }
}

@media (max-width: 560px) {
  .yb-cta__inner { padding: 24px; }
  .yb-cta__actions,
  .yb-cta__actions .yb-button { width: 100%; }
  .yb-gallery--cols-2,
  .yb-gallery--cols-3,
  .yb-gallery--cols-4 { grid-template-columns: 1fr; }
  .yb-modal__panel { width: calc(100% - 20px); margin-block-start: 72px; padding: 26px 20px; }
}

/* Keep mobile buttons intentional instead of forcing every button full width. */
@media (max-width: 560px) {
  .yb-button { width: auto; }
  .yb-button-group { width: 100%; }
  .yb-button-group .yb-button { width: auto; }
  .mobile-menu__actions .yb-button,
  .yb-cta__actions .yb-button,
  .yb-overlay__panel .yb-button,
  .yb-modal__panel .yb-button,
  .yb-drawer__panel .yb-button { width: 100%; }
}
