/*
Theme Name: Bourbon Brothers 
Author: Brendan Lawn
Description: Custom theme for Bourbon Brothers Smokehouse and Tavern.
Version: 0.1.0
*/

@font-face {
  font-family: "Herchey Serif";
  src:
    url("assets/fonts/herchey-serif.woff2") format("woff2"),
    url("assets/fonts/herchey-serif.woff") format("woff");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

/* -------------------------------------------------------------------------- */
/* Table of Contents                                                          */
/* 1. Design Tokens & Base                                                     */
/* 2. Typography                                                               */
/* 3. Buttons                                                                  */
/* 4. Shared Patterns                                                          */
/* 5. Home                                                                     */
/* 6. Our Story                                                                */
/* 7. Privacy Policy                                                           */
/* 8. Sitemap                                                                  */
/* 9. Menus                                                                    */
/* 10. Locations Landing                                                       */
/* 11. Location Page                                                           */
/* 12. Private Events                                                          */
/* 13. Cursor Overrides                                                        */
/* 14. Reduced Motion                                                          */
/* -------------------------------------------------------------------------- */


/* Theme styles */

:root {
  /* Base palette from provided swatches */
  --color-ink: #171717;
  --color-charcoal: #343433;
  --color-bourbon: #9d7343;
  --color-copper: #c59460;
  --color-cream: #f8f2ea;
  
  --font-herchey: "Herchey Serif", "Times New Roman", serif;
  --font-berthold-baskerville: "berthold-baskerville-pro", "Times New Roman", serif;
  --font-baskerville-bt: "baskerville-bt", "Times New Roman", serif;
  --font-pf-signskript: "pf-signskript", "Times New Roman", serif;
  --herchey-letter-spacing: -0.04em;

  --site-header-height: 100px;
  --site-nav-gap: 1.75rem;
  --admin-bar-offset: 0px;
  --menu-categories-height: 3.5rem;
  --safe-area-top: env(safe-area-inset-top, 0px);
  --safe-area-right: env(safe-area-inset-right, 0px);
  --safe-area-bottom: env(safe-area-inset-bottom, 0px);
  --safe-area-left: env(safe-area-inset-left, 0px);
}

body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  background-color: var(--color-cream);
  overflow-x: hidden;
}

html {
  background-color: var(--color-cream);
  overscroll-behavior-y: none;
  overscroll-behavior-x: none;
  overflow-x: hidden;
}

@supports (overflow: clip) {
  html,
  body {
    overflow-x: clip;
  }
}

body.admin-bar {
  min-height: calc(100vh - 32px);
  --admin-bar-offset: 32px;
}

@media (max-width: 782px) {
  body.admin-bar {
    min-height: calc(100vh - 46px);
    --admin-bar-offset: 46px;
  }
}

main {
  flex: 1 0 auto;
}

.site-footer {
  margin-top: auto;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-herchey);
  letter-spacing: var(--herchey-letter-spacing);
  margin: 0 0 1.25rem;
  line-height: 1.1;
  text-wrap: balance;
  font-weight: normal;
}

h1 {
  font-size: clamp(2.75rem, 5vw, 5.2rem);
  text-transform: uppercase;
}

h2 {
  font-size: clamp(1.4rem, 2.8vw, 1.75rem);
  text-transform: uppercase;
  color: var(--color-charcoal);
}

h3 {
  font-size: clamp(1.5rem, 3vw, 2.25rem);
}

h4 {
  font-size: clamp(1.25rem, 2.5vw, 2rem);
}

h5 {
  font-size: clamp(1rem, 2vw, 1.5rem);
}

h6 {
  font-size: clamp(0.875rem, 1.5vw, 1.25rem);
}

/* Copy links */
.full-width-text__content a:not(.btn):not(.wp-block-button__link),
.our-story-feature__copy a:not(.btn):not(.wp-block-button__link),
.private-events-hero__lead a:not(.btn):not(.wp-block-button__link),
.private-events-section__copy a:not(.btn):not(.wp-block-button__link),
.locations-intro a:not(.btn):not(.wp-block-button__link),
.privacy-intro a:not(.btn):not(.wp-block-button__link),
.privacy-section__content a:not(.btn):not(.wp-block-button__link),
.location-module__content a:not(.btn):not(.wp-block-button__link),
.location-module__copy a:not(.btn):not(.wp-block-button__link),
.location-info__description a:not(.btn):not(.wp-block-button__link),
.menu-section__note a:not(.btn):not(.wp-block-button__link),
.menu-footer__note a:not(.btn):not(.wp-block-button__link),
.location-menu-item__description a:not(.btn):not(.wp-block-button__link) {
  color: var(--color-bourbon);
}

.full-width-text__content a:not(.btn):not(.wp-block-button__link):hover,
.our-story-feature__copy a:not(.btn):not(.wp-block-button__link):hover,
.private-events-hero__lead a:not(.btn):not(.wp-block-button__link):hover,
.private-events-section__copy a:not(.btn):not(.wp-block-button__link):hover,
.locations-intro a:not(.btn):not(.wp-block-button__link):hover,
.privacy-intro a:not(.btn):not(.wp-block-button__link):hover,
.privacy-section__content a:not(.btn):not(.wp-block-button__link):hover,
.location-module__content a:not(.btn):not(.wp-block-button__link):hover,
.location-module__copy a:not(.btn):not(.wp-block-button__link):hover,
.location-info__description a:not(.btn):not(.wp-block-button__link):hover,
.menu-section__note a:not(.btn):not(.wp-block-button__link):hover,
.menu-footer__note a:not(.btn):not(.wp-block-button__link):hover,
.location-menu-item__description a:not(.btn):not(.wp-block-button__link):hover,
.full-width-text__content a:not(.btn):not(.wp-block-button__link):focus-visible,
.our-story-feature__copy a:not(.btn):not(.wp-block-button__link):focus-visible,
.private-events-hero__lead a:not(.btn):not(.wp-block-button__link):focus-visible,
.private-events-section__copy a:not(.btn):not(.wp-block-button__link):focus-visible,
.locations-intro a:not(.btn):not(.wp-block-button__link):focus-visible,
.privacy-intro a:not(.btn):not(.wp-block-button__link):focus-visible,
.privacy-section__content a:not(.btn):not(.wp-block-button__link):focus-visible,
.location-module__content a:not(.btn):not(.wp-block-button__link):focus-visible,
.location-module__copy a:not(.btn):not(.wp-block-button__link):focus-visible,
.location-info__description a:not(.btn):not(.wp-block-button__link):focus-visible,
.menu-section__note a:not(.btn):not(.wp-block-button__link):focus-visible,
.menu-footer__note a:not(.btn):not(.wp-block-button__link):focus-visible,
.location-menu-item__description a:not(.btn):not(.wp-block-button__link):focus-visible {
  color: var(--color-copper);
}

/* Buttons */
.btn,
.wp-block-button__link {
  --btn-cut: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.6rem 1.4rem;
  border: 2px solid var(--color-bourbon);
  background: var(--color-bourbon);
  color: var(--color-cream);
  font-family: var(--font-herchey);
  letter-spacing: var(--herchey-letter-spacing);
  font-size: 1rem;
  text-transform: uppercase;
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  clip-path: polygon(
    var(--btn-cut) 0%,
    calc(100% - var(--btn-cut)) 0%,
    100% var(--btn-cut),
    100% calc(100% - var(--btn-cut)),
    calc(100% - var(--btn-cut)) 100%,
    var(--btn-cut) 100%,
    0% calc(100% - var(--btn-cut)),
    0% var(--btn-cut)
  );
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
  min-height: 3rem;
  font-weight: 400;
}

.btn:hover,
.btn:focus-visible,
.wp-block-button__link:hover,
.wp-block-button__link:focus-visible {
  border-color: var(--color-copper);
  background: var(--color-copper);
  color: var(--color-cream);
}

.btn--cream {
  background: var(--color-cream);
  color: var(--color-bourbon);
}

.btn--ink {
  background: #fff;
  color: var(--color-charcoal);
  border-color: transparent;
}

.btn--cream:hover,
.btn--cream:focus-visible {
  border-color: var(--color-copper);
  background: var(--color-cream);
  color: var(--color-copper);
}

.btn--ink:hover,
.btn--ink:focus-visible {
  border-color: transparent;
  background: #e9e6e0;
  color: var(--color-copper);
}

.btn:focus-visible,
.wp-block-button__link:focus-visible {
  outline: 2px solid var(--color-copper);
  outline-offset: 4px;
}

/* Shared patterns */
.home-hero,
.our-story-hero,
.privacy-hero,
.sitemap-hero,
.error-hero,
.private-events-hero,
.event-hero {
  position: relative;
  display: flex;
  align-items: center;
  overflow: hidden;
  color: var(--color-cream);
  background-size: cover;
  background-position: center;
}

.menu-hero,
.locations-hero,
.location-hero,
.private-events-hero {
  position: relative;
  padding: calc(var(--site-header-height) + var(--safe-area-top) + 3.5rem) 0 3rem;
  background-color: var(--color-ink);
  background-size: cover;
  background-position: center;
  color: var(--color-cream);
}

.home-hero__overlay,
.our-story-hero__overlay,
.menu-hero__overlay,
.locations-hero__overlay,
.location-hero__overlay,
.privacy-hero__overlay,
.sitemap-hero__overlay,
.error-hero__overlay,
.private-events-hero__overlay,
.event-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.menu-hero__content,
.locations-hero__content,
.location-hero__content {
  position: relative;
  z-index: 2;
  text-align: center;
  max-width: 52rem;
  margin: 0 auto;
}

.our-story-hero__content,
.privacy-hero__content,
.sitemap-hero__content,
.error-hero__content,
.private-events-hero__content,
.event-hero__content {
  position: relative;
  z-index: 2;
  text-align: center;
  margin: 0 auto;
}

.menu-hero__title,
.locations-hero__title,
.location-hero__title {
  margin-bottom: 1rem;
}

.our-story-hero__lead,
.menu-hero__lead,
.locations-hero__lead,
.location-hero__lead,
.privacy-hero__lead,
.sitemap-hero__lead,
.private-events-hero__lead,
.event-hero__lead {
  font-family: var(--font-berthold-baskerville);
  margin: 0 auto;
}

.our-story-hero__lead,
.privacy-hero__lead,
.sitemap-hero__lead,
.event-hero__lead {
  max-width: 36rem;
}

.menu-hero__lead,
.locations-hero__lead,
.location-hero__lead {
  font-size: clamp(1rem, 2.2vw, 1.35rem);
  max-width: 40rem;
}

.our-story-hero__lead > * + *,
.menu-hero__lead > * + *,
.locations-hero__lead > * + *,
.location-hero__lead > * + *,
.privacy-hero__lead > * + *,
.sitemap-hero__lead > * + *,
.private-events-hero__lead > * + *,
.event-hero__lead > * + * {
  margin-top: 0.75rem;
}

.menu-categories__hint,
.location-actions__hint,
.location-sponsors__hint {
  display: none;
  pointer-events: none;
  color: rgba(52, 52, 51, 0.65);
}

.menu-categories__hint-arrow,
.location-actions__hint-arrow,
.location-sponsors__hint-arrow {
  width: 0.7rem;
  height: 0.7rem;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  opacity: 0.85;
  transition: opacity 0.2s ease;
}

.menu-categories__hint-arrow--left,
.location-actions__hint-arrow--left,
.location-sponsors__hint-arrow--left {
  animation: menu-swipe-left 1.6s ease-in-out infinite;
  transform: rotate(-135deg);
}

.menu-categories__hint-arrow--right,
.location-actions__hint-arrow--right,
.location-sponsors__hint-arrow--right {
  animation: menu-swipe-right 1.6s ease-in-out infinite;
  transform: rotate(45deg);
}

.menu-categories__scroller,
.location-actions__scroller,
.location-sponsors__scroller {
  scrollbar-width: none;
}

.menu-categories__scroller::-webkit-scrollbar,
.location-actions__scroller::-webkit-scrollbar,
.location-sponsors__scroller::-webkit-scrollbar {
  height: 0;
  width: 0;
  background: transparent;
}


/* Homepage hero */
.home .site-header + main {
  padding-top: 0;
}

.home h2 {
  font-family: var(--font-pf-signskript);
  letter-spacing: normal;
  text-transform: none;
  font-size: clamp(2.6rem, 5.2vw, 3.2rem);
  color: var(--color-copper);
}

.home-hero {
  min-height: 100vh;
  background-color: var(--color-ink);
  padding: calc(var(--site-header-height) + var(--safe-area-top) + 3rem) 0 4rem;
}

.admin-bar .home-hero {
  min-height: calc(100vh - 32px);
}

@media (max-width: 782px) {
  .admin-bar .home-hero {
    min-height: calc(100vh - 46px);
  }
}


.home-hero__media {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.home-hero__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.home-hero__overlay {
  background-color: var(--color-ink);
}

.home-hero__content {
  position: relative;
  z-index: 2;
  max-width: 44rem;
}

.home-hero__actions,
.menu-hero__actions,
.error-body__actions,
.private-events-hero__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.75rem;
  margin-top: 1.5rem;
}

.home-hero__actions .btn,
.home-hero__actions .btn:hover,
.home-hero__actions .btn:focus-visible {
  color: var(--color-bourbon);
}

@media (max-width: 640px) {
  .home-hero {
    padding-top: calc(var(--site-header-height) + var(--safe-area-top) + 2.25rem);
  }
}

/* Our Story hero */
.page-template-page-our-story .site-header + main {
  padding-top: 0;
}

.our-story-hero {
  background-color: var(--color-ink);
  background-image: var(--our-story-hero-image, none);
  padding: calc(var(--site-header-height) + var(--safe-area-top) + 3.5rem) 0 3rem;
}

.our-story-hero__overlay {
  pointer-events: none;
  background-color: var(--color-ink);
  opacity: 0.75;
}

.our-story-hero__content {
  max-width: 48rem;
}

.our-story-hero__lead {
  font-size: clamp(1.05rem, 2.1vw, 1.45rem);
}

@media (max-width: 640px) {
  .our-story-hero {
    padding-top: calc(var(--site-header-height) + var(--safe-area-top) + 2.75rem);
  }
}

/* Our Story feature */
.our-story-feature {
  padding: var(--section-pad) 0;
}

.page-template-page-our-story h2 {
  color: var(--color-bourbon);
}

.our-story-feature__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--space-7);
  align-items: center;
}

.our-story-feature__copy {
  font-family: var(--font-berthold-baskerville);
  font-size: clamp(1rem, 2vw, 1.2rem);
}

.our-story-feature__copy > * + * {
  margin-top: var(--space-3);
}

.our-story-feature__actions {
  margin-top: var(--space-4);
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
}

.our-story-feature__action-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.35rem;
}

.our-story-feature__action-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(7.2rem, 21.6vw, 9.6rem);
  height: 3.9rem;
  padding: 0.24rem 0.42rem;
}

.our-story-feature__action-image {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
}

.our-story-feature__action-note {
  width: 100%;
  font-size: 0.8rem;
  color: rgba(52, 52, 51, 0.7);
  font-family: var(--font-berthold-baskerville);
  line-height: 1.35;
}

.our-story-feature__action-note > * + * {
  margin-top: 0.25rem;
}

.our-story-feature__media {
  display: grid;
  place-items: center;
  width: 100%;
}

.our-story-feature__image {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

@media (min-width: 901px) {
  .our-story-feature--media-left .our-story-feature__content {
    order: 2;
  }

  .our-story-feature--media-left .our-story-feature__media {
    order: 1;
  }
}

@media (max-width: 900px) {
  .our-story-feature__grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (min-width: 641px) {
  .our-story-feature__content {
    text-align: left;
  }

  .our-story-feature__actions {
    justify-content: flex-start;
  }
}

@media (max-width: 640px) {
  .our-story-feature__content {
    text-align: center;
  }

  .our-story-feature__actions {
    justify-content: center;
  }

  .our-story-feature__media {
    padding: var(--space-3);
  }
}

/* Privacy policy template */
.page-template-page-privacy-policy .site-header + main {
  padding-top: 0;
}

.page-template-page-cookie-policy .site-header + main {
  padding-top: 0;
}

.privacy-hero {
  background-color: var(--color-ink);
  background-image: var(--privacy-hero-image, url("/wp-content/uploads/2026/01/bb_smoke_back_v5_1920_white.webp"));
  padding: calc(var(--site-header-height) + var(--safe-area-top) + 3rem) 0 3.5rem;
}

.privacy-hero__overlay {
  pointer-events: none;
  background: linear-gradient(160deg, rgba(23, 23, 23, 0.85), rgba(52, 52, 51, 0.7));
}

.privacy-hero__content {
  max-width: 50rem;
}

.privacy-hero__title {
  margin-bottom: 0.75rem;
}

.privacy-hero__lead {
  font-size: clamp(1.05rem, 2.3vw, 1.45rem);
}

.privacy-hero__meta {
  margin-top: 1.15rem;
  font-family: var(--font-berthold-baskerville);
  font-size: 0.85rem;
  text-transform: uppercase;
  color: rgba(248, 242, 234, 0.8);
}

/* Event single template */
.single-event .site-header + main {
  padding-top: 0;
}

/* Event location taxonomy */
.tax-event_location .site-header + main {
  padding-top: 0;
}

.event-hero {
  min-height: 50vh;
  background-color: var(--color-charcoal);
  background-image: var(--event-hero-image, none);
  padding: calc(var(--site-header-height) + var(--safe-area-top) + 3rem) 0 4rem;
}

.event-hero__overlay {
  pointer-events: none;
  background: linear-gradient(135deg, rgba(23, 23, 23, 0.85), rgba(157, 115, 67, 0.6));
}

.event-hero__content {
  max-width: none;
  width: 100%;
}

.event-hero__title {
  margin-bottom: 0.75rem;
}

.event-hero__lead {
  font-size: clamp(1.05rem, 2.3vw, 1.45rem);
}

.event-hero__meta {
  margin: 0 0 0.75rem;
  font-family: var(--font-berthold-baskerville);
  font-size: 0.85rem;
  text-transform: uppercase;
  color: rgba(248, 242, 234, 0.8);
}

.event-hero .event-single__header {
  max-width: none;
  margin: 0 auto;
  text-align: center;
}

.privacy-body {
  padding: var(--section-pad) 0;
}

.privacy-sheet {
  position: relative;
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
}

.privacy-sheet::before {
  content: none;
}

.privacy-sheet--compact .privacy-sections {
  margin-top: 0;
}

.privacy-intro {
  font-family: var(--font-berthold-baskerville);
  font-size: 1.05rem;
  color: var(--color-charcoal);
}

.privacy-intro > * + * {
  margin-top: 0.75rem;
}

.privacy-intro a,
.privacy-section__content a {
  text-decoration: underline;
  text-decoration-color: rgba(197, 148, 96, 0.65);
  text-underline-offset: 0.2em;
}

.privacy-intro a:hover,
.privacy-intro a:focus-visible,
.privacy-section__content a:hover,
.privacy-section__content a:focus-visible {
  color: var(--color-bourbon);
}

.privacy-intro ul,
.privacy-section__content ul {
  list-style: disc;
  padding-left: 1.25rem;
}

.privacy-intro ol,
.privacy-section__content ol {
  list-style: decimal;
  padding-left: 1.25rem;
}

.privacy-intro li + li,
.privacy-section__content li + li {
  margin-top: 0.35rem;
}

.privacy-sections {
  margin-top: var(--space-6);
  display: grid;
  gap: var(--space-6);
}

.privacy-section__title {
  margin-bottom: 0.75rem;
}

.privacy-section__content {
  font-family: var(--font-berthold-baskerville);
  font-size: 1.02rem;
  color: var(--color-charcoal);
}

.privacy-section__content > * + * {
  margin-top: var(--space-3);
}

@media (max-width: 640px) {
  .privacy-hero {
    padding-top: calc(var(--site-header-height) + var(--safe-area-top) + 2.5rem);
  }

  .privacy-sheet {
    padding: 0;
  }
}

/* Sitemap template */
.page-template-page-sitemap .site-header + main {
  padding-top: 0;
}

.sitemap-hero {
  min-height: 45vh;
  background-color: var(--color-ink);
  background-image: var(--sitemap-hero-image, none);
  padding: calc(var(--site-header-height) + var(--safe-area-top) + 3rem) 0 3.5rem;
}

.sitemap-hero__overlay {
  pointer-events: none;
  background: linear-gradient(160deg, rgba(23, 23, 23, 0.85), rgba(52, 52, 51, 0.7));
}

.sitemap-hero__content {
  max-width: 48rem;
}

.sitemap-hero__title {
  margin-bottom: 0.75rem;
}

.sitemap-hero__lead {
  font-size: clamp(1.05rem, 2.3vw, 1.4rem);
}

.sitemap-body {
  padding: var(--section-pad) 0;
  background: linear-gradient(180deg, rgba(248, 242, 234, 1) 0%, rgba(248, 242, 234, 0.96) 65%, rgba(197, 148, 96, 0.12) 100%);
}

.sitemap-intro {
  max-width: 44rem;
  margin: 0 auto var(--space-6);
  text-align: center;
  font-family: var(--font-berthold-baskerville);
  font-size: 1.05rem;
  color: var(--color-charcoal);
}

.sitemap-intro > * + * {
  margin-top: 0.75rem;
}

.sitemap-nav {
  background: rgba(255, 255, 255, 0.6);
  border: 1px solid rgba(52, 52, 51, 0.12);
  padding: clamp(1.5rem, 4vw, 2.5rem);
}

.sitemap-list {
  list-style: none;
  margin: 0;
  padding: 0;
  columns: 2;
  column-gap: var(--space-6);
}

.sitemap-list .page_item {
  margin: 0 0 var(--space-4);
  break-inside: avoid;
}

.sitemap-list .children .page_item {
  margin: 0;
}

.sitemap-list .page_item > a {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-berthold-baskerville);
  font-size: 1.05rem;
  color: var(--color-ink);
  text-decoration: none;
}

.sitemap-list .page_item > a::before {
  content: "";
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
  background: var(--color-bourbon);
}

.sitemap-list .children .page_item > a::before {
  content: none;
}

.sitemap-list .page_item > a:hover,
.sitemap-list .page_item > a:focus-visible {
  color: var(--color-bourbon);
  outline: none;
}

.sitemap-list .children {
  margin-top: 0.2rem;
  padding-left: 1.25rem;
  border-left: 1px solid rgba(52, 52, 51, 0.12);
  display: grid;
  gap: 0.2rem;
}

.sitemap-list .children a {
  font-size: 0.98rem;
}

.sitemap-list .children a::before {
  content: none;
}

.sitemap-empty {
  text-align: center;
  font-family: var(--font-berthold-baskerville);
  color: var(--color-charcoal);
}

@media (max-width: 900px) {
  .sitemap-list {
    columns: 1;
  }
}

@media (max-width: 640px) {
  .sitemap-hero {
    padding-top: calc(var(--site-header-height) + var(--safe-area-top) + 2.5rem);
  }

  .sitemap-nav {
    padding: clamp(1.25rem, 6vw, 2rem);
  }
}

/* 404 template */
.error404 .site-header + main {
  padding-top: 0;
}

.error-hero {
  min-height: 45vh;
  background-color: var(--color-ink);
  padding: calc(var(--site-header-height) + var(--safe-area-top) + 3rem) 0 3.5rem;
}

.error-hero__overlay {
  pointer-events: none;
  background: linear-gradient(160deg, rgba(23, 23, 23, 0.85), rgba(52, 52, 51, 0.7));
}

.error-hero__content {
  max-width: 48rem;
}

.error-hero__eyebrow {
  margin-bottom: 0.5rem;
  font-family: var(--font-berthold-baskerville);
  font-size: 0.85rem;
  letter-spacing: 0.4em;
  color: rgba(248, 242, 234, 0.8);
}

.error-hero__title {
  margin-bottom: 0.75rem;
}

.error-body {
  padding: var(--section-pad) 0;
}

.error-body__content {
  max-width: 44rem;
  margin: 0 auto;
}

.error-body__lead {
  margin: 0 auto 1.75rem;
  font-family: var(--font-berthold-baskerville);
  font-size: clamp(1.05rem, 2.3vw, 1.35rem);
  color: var(--color-charcoal);
}

@media (max-width: 640px) {
  .error-hero {
    padding-top: calc(var(--site-header-height) + var(--safe-area-top) + 2.5rem);
  }
}

/* Location menu template */
.page-template-page-location-menu .site-header + main {
  padding-top: 0;
}

.menu-hero {
  background-image: var(--menu-hero-image, none);
}

.menu-hero__overlay {
  background-color: var(--color-ink);
  opacity: 0.7;
  pointer-events: none;
}


.menu-page .back-to-top,
.menu-landing .back-to-top,
.location-page .back-to-top {
  position: fixed;
  right: 1.5rem;
  bottom: calc(1.5rem + env(safe-area-inset-bottom, 0px) + var(--back-to-top-offset, 0px));
  z-index: 6;
  width: 2.6rem;
  height: 2.6rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 2px solid rgba(197, 148, 96, 0.75);
  background: var(--color-bourbon);
  color: var(--color-cream);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(6px);
  transition: transform 0.2s ease, border-color 0.2s ease, color 0.2s ease, opacity 0.2s ease, visibility 0.2s ease;
}

.menu-page .back-to-top.is-visible,
.menu-landing .back-to-top.is-visible,
.location-page .back-to-top.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}

.menu-page .back-to-top:hover,
.menu-page .back-to-top:focus-visible,
.menu-landing .back-to-top:hover,
.menu-landing .back-to-top:focus-visible,
.location-page .back-to-top:hover,
.location-page .back-to-top:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(197, 148, 96, 1);
  background: var(--color-copper);
  color: var(--color-cream);
  outline: none;
}

.menu-page .back-to-top:focus-visible,
.menu-landing .back-to-top:focus-visible,
.location-page .back-to-top:focus-visible {
  outline: 2px solid rgba(197, 148, 96, 0.6);
  outline-offset: 2px;
}

.menu-page .back-to-top:active,
.menu-landing .back-to-top:active,
.location-page .back-to-top:active {
  transform: translateY(0);
}

.back-to-top__icon {
  width: 0.75rem;
  height: 0.75rem;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  display: block;
  transform: translateY(1px) rotate(-45deg);
}

.menu-categories {
  background: var(--color-cream);
  border-bottom: 1px solid rgba(52, 52, 51, 0.1);
}

.page-template-page-location-menu .menu-categories {
  position: sticky;
  top: calc(var(--site-header-height) + var(--safe-area-top) + var(--admin-bar-offset));
  z-index: 900;
}

.menu-categories__scroller {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: center;
  overflow: visible;
  cursor: default;
  user-select: auto;
  -webkit-user-select: auto;
  -ms-user-select: auto;
  padding: 0.65rem 0 0.85rem;
  scroll-snap-type: none;
  -webkit-overflow-scrolling: auto;
  touch-action: pan-y;
  -ms-overflow-style: none;
}

.menu-categories__scroller.is-dragging {
  cursor: grabbing;
  scroll-snap-type: none;
}

.menu-categories__scroller::-webkit-scrollbar-track {
  background: transparent;
}

.menu-categories__scroller::-webkit-scrollbar-thumb {
  background-color: transparent;
  border-radius: 999px;
}

.menu-categories__item {
  flex: 0 0 auto;
  padding: 0.5rem 1.1rem;
  border: 1px solid rgba(52, 52, 51, 0.2);
  border-radius: 999px;
  text-decoration: none;
  text-transform: uppercase;
  font-family: var(--font-berthold-baskerville);
  font-size: 0.78rem;
  font-weight: bold;
  color: var(--color-charcoal);
  background: #fff;
  user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  transition: border-color 0.2s ease, color 0.2s ease, background-color 0.2s ease;
}

.menu-categories__item.is-active,
.menu-categories__item[aria-current="location"] {
  border-color: var(--color-bourbon);
  background-color: var(--color-bourbon);
  color: var(--color-cream);
}

.menu-categories__item:hover,
.menu-categories__item:focus-visible {
  border-color: var(--color-copper);
  color: var(--color-bourbon);
  background-color: #fff;
  outline: none;
}

.menu-categories__item.is-active:hover,
.menu-categories__item.is-active:focus-visible,
.menu-categories__item[aria-current="location"]:hover,
.menu-categories__item[aria-current="location"]:focus-visible {
  border-color: var(--color-copper);
  color: var(--color-cream);
  background-color: var(--color-copper);
}

.menu-categories__item:focus-visible {
  box-shadow: 0 0 0 2px rgba(197, 148, 96, 0.35);
}

@keyframes menu-swipe-left {
  0%,
  100% {
    transform: translateX(0) rotate(-135deg);
    opacity: 0.4;
  }

  50% {
    transform: translateX(-6px) rotate(-135deg);
    opacity: 1;
  }
}

@keyframes menu-swipe-right {
  0%,
  100% {
    transform: translateX(0) rotate(45deg);
    opacity: 0.4;
  }

  50% {
    transform: translateX(6px) rotate(45deg);
    opacity: 1;
  }
}

.menu-sections {
  padding: var(--section-pad) 0;
}

.menu-featured {
  display: grid;
  gap: var(--space-4);
}

.menu-featured__header {
  display: flex;
  align-items: baseline;
  gap: 1rem;
}

.menu-featured__title {
  margin: 0;
  text-transform: uppercase;
  font-size: clamp(1.5rem, 2.6vw, 2.1rem);
}

.menu-featured__single {
  display: flex;
  justify-content: center;
}

.menu-featured__single .location-menu-item,
.menu-featured-carousel .location-menu-item {
  width: min(100%, 52rem);
  margin: 0 auto;
}

.menu-featured-carousel .location-carousel__viewport {
  aspect-ratio: auto;
  overflow: hidden;
}

.menu-featured-carousel .location-carousel__track {
  position: relative;
  width: 100%;
  height: auto;
  display: flex;
  transition: transform 0.45s ease;
}

.menu-featured-carousel .location-carousel__slide {
  position: relative;
  inset: auto;
  opacity: 1;
  display: block;
  transition: none;
  flex: 0 0 100%;
}

.menu-featured-carousel .location-carousel__hint {
  color: rgba(52, 52, 51, 0.7);
}

.menu-featured-carousel .location-carousel__hint:hover,
.menu-featured-carousel .location-carousel__hint:focus-visible {
  color: var(--color-bourbon);
}

.menu-featured-carousel .location-carousel__meta {
  justify-content: center;
}

.menu-section {
  scroll-margin-top: calc(
    var(--site-header-height) + var(--safe-area-top) + var(--admin-bar-offset) + var(--menu-categories-height) + 1.5rem
  );
}

.menu-section + .menu-section {
  margin-top: var(--space-8);
  padding-top: var(--space-8);
  border-top: 1px dashed rgba(52, 52, 51, 0.2);
}

.menu-section__title {
  margin-bottom: 0.5rem;
  font-size: clamp(1.4rem, 2.6vw, 2rem);
}

.menu-section__header {
  margin-bottom: var(--space-6);
}

.menu-section__description {
  font-family: var(--font-berthold-baskerville);
  margin: 0;
}

.menu-section__description > * + * {
  margin-top: 0.75rem;
}

.menu-section__actions {
  margin-top: var(--space-4);
}

.menu-subsections {
  margin-top: var(--space-6);
}

.menu-subsection + .menu-subsection {
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px dashed rgba(52, 52, 51, 0.2);
}

.menu-subsection__title {
  margin-bottom: 0;
  font-size: clamp(1.4rem, 2.8vw, 1.75rem);
  text-transform: uppercase;
}

.menu-subsection__header {
  margin-bottom: var(--space-4);
}

.menu-subsection__description {
  font-family: var(--font-berthold-baskerville);
  margin: 0 0 var(--space-4);
}

.menu-subsection__description > * + * {
  margin-top: 0.5rem;
}

.menu-subsection__note {
  font-family: var(--font-berthold-baskerville);
  margin-top: var(--space-4);
  font-style: italic;
}

.menu-subsection__note > * + * {
  margin-top: 0.5rem;
}

.location-menu-items {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-6);
}

.location-menu-item {
  --menu-cut: 12px;
  background: rgba(255, 255, 255, 0.78);
  border-radius: 0;
  padding: 1.5rem;
  clip-path: polygon(
    var(--menu-cut) 0%,
    calc(100% - var(--menu-cut)) 0%,
    100% var(--menu-cut),
    100% calc(100% - var(--menu-cut)),
    calc(100% - var(--menu-cut)) 100%,
    var(--menu-cut) 100%,
    0% calc(100% - var(--menu-cut)),
    0% var(--menu-cut)
  );
}

.location-menu-item--has-image {
  display: grid;
  grid-template-columns: minmax(0, 8.5rem) minmax(0, 1fr);
  gap: 0;
  align-items: stretch;
  padding: 0;
}

.location-menu-item__media {
  width: 100%;
  height: 100%;
}

.location-menu-item__photo {
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 0;
  object-fit: cover;
}

.location-menu-item__content {
  padding: 0;
}

.location-menu-item--has-image .location-menu-item__content {
  padding: 1.5rem;
}

.location-menu-item__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
}

.location-menu-item__name {
  position: relative;
  display: inline-block;
  margin: 0;
  font-size: clamp(1.15rem, 2.2vw, 1.6rem);
  text-transform: uppercase;
}

.location-menu-item__name::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -0.2em;
  height: 2px;
  background: var(--color-copper);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.2s ease;
}

.location-menu-item:hover .location-menu-item__name::after,
.location-menu-item:focus-within .location-menu-item__name::after {
  transform: scaleX(1);
}

.location-menu-item__price {
  font-family: var(--font-herchey);
  letter-spacing: var(--herchey-letter-spacing);
  font-size: clamp(1.15rem, 2.2vw, 1.6rem);
  color: var(--color-bourbon);
  font-weight: bold;
  white-space: nowrap;
}

.location-menu-item__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.location-menu-item__badge {
  --badge-color: var(--color-bourbon);
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.6rem;
  border: 1px solid rgba(0, 0, 0, 0.15);
  border-color: color-mix(in srgb, var(--badge-color) 75%, #000);
  border-radius: 999px;
  text-transform: uppercase;
  font-size: 0.7rem;
  background-color: var(--badge-color);
  color: var(--color-cream);
  font-family: var(--font-herchey);
  letter-spacing: var(--herchey-letter-spacing);
}

.location-menu-item__description {
  font-family: var(--font-berthold-baskerville);
  margin-top: 0.5rem;
}

.location-menu-item__description > * + * {
  margin-top: 0.5rem;
}

.menu-section__note {
  font-family: var(--font-berthold-baskerville);
  margin-top: var(--space-5);
  font-style: italic;
}

.menu-section__note > * + * {
  margin-top: 0.5rem;
}

.menu-footer {
  padding: 0 0 var(--section-pad);
}

.menu-footer__note {
  font-family: var(--font-berthold-baskerville);
  text-align: center;
  max-width: 52rem;
  margin: 0 auto;
}

.menu-footer__note > * + * {
  margin-top: 0.75rem;
}


@media (max-width: 1090px) {
  .menu-categories {
    position: relative;
    overflow: hidden;
  }

  .menu-categories .container {
    position: relative;
  }

  .menu-categories::before,
  .menu-categories::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 2.25rem;
    pointer-events: none;
    z-index: 2;
    opacity: 1;
    transition: opacity 0.2s ease;
  }

  .menu-categories::before {
    left: 0;
    background: linear-gradient(90deg, var(--color-cream) 0%, rgba(248, 242, 234, 0) 100%);
  }

  .menu-categories::after {
    right: 0;
    background: linear-gradient(270deg, var(--color-cream) 0%, rgba(248, 242, 234, 0) 100%);
  }

  .menu-categories__hint {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 0.9rem;
    z-index: 3;
  }

  .menu-categories.is-at-start::before,
  .menu-categories.is-at-end::after {
    opacity: 0;
  }

  .menu-categories.is-at-start .menu-categories__hint-arrow--left,
  .menu-categories.is-at-end .menu-categories__hint-arrow--right {
    opacity: 0;
    animation: none;
  }

  .menu-categories.is-at-start.is-at-end .menu-categories__scroller {
    justify-content: center;
    margin: 0 auto;
  }

  .menu-categories__scroller {
    flex-wrap: nowrap;
    justify-content: flex-start;
    overflow-x: hidden;
    overflow-y: hidden;
    cursor: grab;
    margin: 0 0.5rem;
    user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    scroll-padding-inline: 2.5rem;
    scroll-snap-type: none;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-x;
  }
}

@media (max-width: 900px) {
  .menu-featured {
    text-align: center;
  }

  .menu-featured__header {
    justify-content: center;
  }

  .menu-featured-carousel .location-carousel__meta {
    justify-content: center;
  }

  .location-menu-items {
    grid-template-columns: minmax(0, 1fr);
  }

  .menu-page {
    text-align: center;
  }

  .location-menu-item {
    justify-self: center;
    width: min(100%, 34rem);
  }

  .location-menu-item--has-image {
    grid-template-columns: minmax(0, 1fr);
    text-align: center;
  }

  .location-menu-item__media {
    max-width: none;
    margin: 0;
    width: 100%;
    aspect-ratio: 4 / 3;
    overflow: hidden;
  }

  .location-menu-item__photo {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .location-menu-item--has-image .location-menu-item__content {
    padding: 1.5rem;
  }

  .menu-page .menu-section__header {
    margin: 0 auto var(--space-6);
  }

  .menu-page .location-menu-item__header {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.4rem;
  }

  .menu-page .location-menu-item__description {
    text-align: center;
    margin-top: 0.35rem;
  }

  .menu-page .location-menu-item__badges {
    justify-content: center;
    margin-top: 0.5rem;
  }
}

@media (max-width: 640px) {
  .menu-hero {
    padding-top: calc(var(--site-header-height) + var(--safe-area-top) + 2.75rem);
  }

  .location-menu-item {
    padding: 1.25rem;
  }

  .location-menu-item--has-image {
    padding: 0;
  }

  .location-menu-item--has-image .location-menu-item__content {
    padding: 1.25rem;
  }
}

/* Locations landing template */
.page-template-page-locations .site-header + main {
  padding-top: 0;
}

.page-template-page-location-menus .site-header + main {
  padding-top: 0;
}

.page-template-page-private-events-landing .site-header + main {
  padding-top: 0;
}

.locations-hero {
  background-image: var(--locations-hero-image, none);
}

.locations-hero__overlay {
  background-color: var(--color-ink);
  opacity: 0.65;
  pointer-events: none;
}


.locations-intro {
  max-width: 48rem;
  margin: 0 auto var(--space-7);
  text-align: center;
  font-family: var(--font-berthold-baskerville);
  font-size: 1.05rem;
}

.locations-intro > * + * {
  margin-top: 0.75rem;
}

.locations-grid__list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-5);
}

.locations-card {
  height: 100%;
}

.locations-card__link {
  height: 100%;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  background: #fff;
  border: 1px solid rgba(52, 52, 51, 0.15);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.locations-card__link:hover,
.locations-card__link:focus-within {
  transform: translateY(-4px);
  border-color: rgba(157, 115, 67, 0.4);
  box-shadow: 0 12px 30px rgba(23, 23, 23, 0.12);
  outline: none;
}

.locations-card__link--static:hover {
  transform: none;
  border-color: rgba(52, 52, 51, 0.15);
  box-shadow: none;
}

.locations-card__link--coming-soon {
  opacity: 0.6;
  filter: grayscale(0.2);
}

.locations-card__link--coming-soon:hover,
.locations-card__link--coming-soon:focus-within {
  transform: none;
  border-color: rgba(52, 52, 51, 0.15);
  box-shadow: none;
}

.locations-card__media {
  aspect-ratio: 16 / 9;
  background-color: var(--color-charcoal);
  background-image: var(--locations-card-image, linear-gradient(135deg, rgba(157, 115, 67, 0.45), rgba(23, 23, 23, 0.75)));
  background-size: cover;
  background-position: center;
}

.locations-card__media-link {
  display: block;
  text-decoration: none;
  color: inherit;
}

.locations-card__body {
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1;
}

.locations-card__title {
  margin: 0;
}

.locations-card__title-link {
  text-decoration: none;
  color: inherit;
}

.locations-card__badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 0.3rem 0.85rem;
  border-radius: 999px;
  border: 0;
  color: var(--color-cream);
  font-family: var(--font-herchey);
  font-size: 0.78rem;
  font-weight: bold;
  text-transform: uppercase;
  background: var(--color-ink);
}

.locations-card__badge--coming-soon {
  background: #000;
}

.locations-card__description {
  margin: 0;
  font-family: var(--font-berthold-baskerville);
  color: var(--color-charcoal);
}

.locations-card__meta {
  font-family: var(--font-berthold-baskerville);
  color: var(--color-charcoal);
  display: grid;
  gap: 0.35rem;
  font-size: 0.95rem;
}

.locations-card__line {
  display: block;
}

.locations-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: auto;
  align-items: flex-start;
}

.locations-card__cta {
  align-self: flex-start;
  margin-top: 0;
}

.locations-landing .locations-card__cta--reserve {
  background: var(--color-copper);
  border-color: var(--color-copper);
  color: var(--color-cream);
}

.locations-landing .locations-card__cta--reserve:hover,
.locations-landing .locations-card__cta--reserve:focus-visible {
  background: var(--color-bourbon);
  border-color: var(--color-bourbon);
  color: var(--color-cream);
}

.menu-landing .locations-card__cta--drink {
  background: var(--color-copper);
  border-color: var(--color-copper);
  color: var(--color-cream);
}

.menu-landing .locations-card__cta--drink:hover,
.menu-landing .locations-card__cta--drink:focus-visible {
  background: var(--color-bourbon);
  border-color: var(--color-bourbon);
  color: var(--color-cream);
}

.private-events-landing .locations-card__cta--contact {
  background: var(--color-copper);
  border-color: var(--color-copper);
  color: var(--color-cream);
}

.private-events-landing .locations-card__cta--contact:hover,
.private-events-landing .locations-card__cta--contact:focus-visible {
  background: var(--color-bourbon);
  border-color: var(--color-bourbon);
  color: var(--color-cream);
}

.locations-empty {
  text-align: center;
  font-family: var(--font-berthold-baskerville);
}

@media (max-width: 900px) {
  .locations-grid__list {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 640px) {
  .locations-hero {
    padding-top: calc(var(--site-header-height) + var(--safe-area-top) + 2.75rem);
  }
}

/* Location page template */
.page-template-page-location .site-header + main {
  padding-top: 0;
}

.page-template-page-location main {
  --location-section-gap: clamp(2rem, 4vw, 3rem);
}

.location-hero {
  background-image: var(--location-hero-image, none);
}

.location-hero__overlay {
  background-color: var(--color-ink);
  opacity: 0.7;
  pointer-events: none;
}

.location-hero__social {
  margin: 0.75rem 0 0.75rem;
  padding: 0;
  list-style: none;
  justify-content: center;
}

@media (max-width: 1090px) {
  .page-template-page-location .location-hero__social.site-nav__social {
    width: auto;
    padding-top: 0;
    border-top: 0;
  }
}


.location-actions {
  background: var(--color-cream);
  border-bottom: 1px solid rgba(52, 52, 51, 0.1);
}

.location-actions__scroller {
  display: flex;
  gap: 0.75rem;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 0.8rem 0 1rem;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-x;
}

.location-actions__scroller .btn {
  flex: 0 0 auto;
  white-space: nowrap;
  scroll-snap-align: start;
  padding: 0.7rem 1.6rem;
  font-size: 1.05rem;
}

@media (min-width: 1091px) {
  .location-actions__scroller {
    flex-wrap: wrap;
    justify-content: center;
    overflow: visible;
    scroll-snap-type: none;
    -webkit-overflow-scrolling: auto;
    gap: 0;
    row-gap: 0.25rem;
  }

  .location-actions__scroller .btn {
    padding: 0 0.4rem 0 0.2rem;
    min-height: auto;
    background: transparent;
    border-color: transparent;
    clip-path: none;
    color: var(--color-charcoal);
    text-decoration: none;
    font-size: 0.95rem;
    position: relative;
    line-height: 1.15;
    display: inline-flex;
    align-items: center;
  }

  .location-actions__scroller .btn:not(:last-child) {
    padding-right: 1rem;
  }

  .location-actions__scroller .btn:not(:last-child)::after {
    content: "•";
    position: absolute;
    right: 0.2rem;
    top: 50%;
    transform: translateY(-50%);
    color: rgba(52, 52, 51, 0.45);
    line-height: 1;
  }

  .location-actions__scroller .btn:hover,
  .location-actions__scroller .btn:focus-visible {
    background: transparent;
    border-color: transparent;
    color: var(--color-bourbon);
  }
}

.location-sponsors {
  background: var(--color-cream);
  padding: calc(var(--location-section-gap) / 2) 0;
}

.location-sponsors .container {
  border-top: 1px dashed rgba(52, 52, 51, 0.2);
  padding-top: calc(var(--location-section-gap) / 2);
}

.location-sponsors__scroller {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1.5rem;
  overflow: visible;
  padding: 0.4rem 0.75rem;
  -webkit-overflow-scrolling: auto;
}

.location-sponsors__title {
  margin-bottom: 0.75rem;
  text-align: center;
}

.location-sponsors__item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  padding: 0.4rem 0.8rem;
}

.location-sponsors__logo {
  display: block;
  width: auto;
  max-width: clamp(112px, 16vw, 176px);
  max-height: clamp(50px, 8vw, 76px);
  height: auto;
}

@media (min-width: 901px) {
  .location-sponsors__logo {
    max-width: clamp(96px, 11.2vw, 160px);
    max-height: clamp(42px, 6vw, 64px);
  }
}

.location-details {
  padding: calc(var(--location-section-gap) / 2) 0;
}

.location-modules {
  padding: calc(var(--location-section-gap) / 2) 0;
  background: var(--color-cream);
}

.location-modules__list {
  display: grid;
  gap: calc(var(--location-section-gap) * 2);
}

.location-module {
  background: transparent;
  border: 0;
  padding: 0;
}

.location-module__title {
  margin-bottom: 0.75rem;
}

.location-module__content,
.location-module__copy {
  font-family: var(--font-berthold-baskerville);
}

.location-module__content > * + *,
.location-module__copy > * + * {
  margin-top: 0.75rem;
}

.location-module__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1rem;
}

/* Full width text section */
.full-width-text {
  padding: calc(var(--section-pad) / 2) 0 0;
  background: var(--color-cream);
}

.full-width-text--last {
  padding: 0 0 calc(var(--section-pad) / 2);
}

.full-width-text__title {
  margin-bottom: 0.75rem;
}

.full-width-text__content {
  font-family: var(--font-berthold-baskerville);
}

.full-width-text__content > * + * {
  margin-top: 0.75rem;
}

.full-width-text__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1rem;
}

.full-width-text__inner {
  max-width: 64rem;
  margin: 0 auto;
}

@media (max-width: 900px) {
  .full-width-text__actions {
    justify-content: center;
  }
}

/* Parallax image section */
.parallax-image {
  min-height: clamp(14.0625rem, 35.15625vw, 26.5625rem);
  margin: calc(var(--section-pad) / 2) 0;
  background-image: var(--parallax-image, none);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed;
}

@media (max-width: 900px), (prefers-reduced-motion: reduce) {
  .parallax-image {
    background-attachment: scroll;
  }
}

.location-module--slider {
  position: relative;
  grid-column: 1 / -1;
  --location-slider-height: clamp(15rem, 28vw, 22rem);
  width: calc(100% + var(--content-gutter) + var(--safe-area-left) + var(--content-gutter) + var(--safe-area-right));
  margin-left: calc((var(--content-gutter) + var(--safe-area-left)) * -1);
  margin-right: calc((var(--content-gutter) + var(--safe-area-right)) * -1);
  max-width: none;
  padding: clamp(2rem, 4.5vw, 3rem) 0;
  color: var(--color-cream);
  overflow: hidden;
  background-color: var(--color-ink);
  box-shadow: inset 0 0 40px rgba(18, 18, 18, 0.35);
}

@media (min-width: 901px) {
  .location-module--slider {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    max-width: 100vw;
  }
}

.location-module--slider::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--location-slider-bg);
  background-size: cover;
  background-position: center;
  opacity: 1;
  transition: opacity 0.5s ease;
  z-index: 0;
}

.location-module--slider::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--location-slider-bg-next, var(--location-slider-bg));
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 0.5s ease;
  z-index: 0;
}

.location-module--slider.is-bg-crossfading::before {
  opacity: 0;
}

.location-module--slider.is-bg-crossfading::after {
  opacity: 1;
}

.location-module--slider.is-bg-no-transition::before,
.location-module--slider.is-bg-no-transition::after {
  transition: none;
}

.location-module__slider-overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(23, 23, 23, 0.65);
  box-shadow: inset 0 0 40px rgba(18, 18, 18, 0.35);
  z-index: 1;
  pointer-events: none;
}

.location-module__slides {
  position: relative;
  min-height: var(--location-slider-height);
  overflow-x: hidden;
  overflow-y: visible;
  z-index: 2;
  touch-action: pan-y;
}

.location-module__slide {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-3);
  align-items: center;
  justify-items: center;
  text-align: center;
  min-height: var(--location-slider-height);
  pointer-events: none;
  --slide-x: 100%;
  transform: translateX(var(--slide-x));
  transition: transform 0.5s ease;
  z-index: 0;
}

.location-module__slide--text {
  grid-template-columns: minmax(0, 1fr);
}

.location-module__slide.is-active {
  pointer-events: auto;
  --slide-x: 0%;
  z-index: 1;
}

.location-module__slide-media {
  width: 100%;
  max-width: clamp(8rem, 20vw, 14rem);
  height: clamp(4rem, 10vw, 6.5rem);
  display: flex;
  align-items: center;
  justify-content: center;
}

.location-module__slide-content {
  max-width: 42rem;
}

.location-module__slide-image {
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 0;
  object-fit: contain;
}

.location-module__slide-title {
  margin-bottom: 0.75rem;
  color: #fff;
}

.location-module__slide-copy {
  font-family: var(--font-berthold-baskerville);
  max-width: 40rem;
}

.location-module__slide-copy > * + * {
  margin-top: 0.75rem;
}

.location-module__slider-controls {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-4);
  margin-top: var(--space-5);
  z-index: 3;
}

.location-module__slider-dots {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
}

.location-module__slider-dot {
  appearance: none;
  border: 1px solid rgba(248, 242, 234, 0.6);
  background: transparent;
  width: 0.6rem;
  height: 0.6rem;
  border-radius: 999px;
  padding: 0;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.location-module__slider-dot.is-active {
  background-color: var(--color-cream);
  border-color: var(--color-cream);
  transform: scale(1.1);
}

.location-module__slider-dot:focus-visible {
  outline: 2px solid var(--color-copper);
  outline-offset: 3px;
}

.location-module__slider-arrow {
  appearance: none;
  border: 1px solid rgba(248, 242, 234, 0.45);
  background: rgba(23, 23, 23, 0.2);
  color: var(--color-cream);
  width: 2.6rem;
  height: 2.6rem;
  border-radius: 999px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.2s ease, border-color 0.2s ease;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
}

.location-module__slider-arrow--prev {
  left: clamp(1rem, 3vw, 2rem);
}

.location-module__slider-arrow--next {
  right: clamp(1rem, 3vw, 2rem);
}

.location-module--slider .location-module__actions {
  justify-content: center;
}

.location-module__slider-arrow span {
  font-size: 1.1rem;
  line-height: 1;
}

.location-module__slider-arrow:hover,
.location-module__slider-arrow:focus-visible {
  background: rgba(23, 23, 23, 0.4);
  border-color: rgba(248, 242, 234, 0.75);
  outline: none;
}

.location-module--media {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--space-6);
  align-items: center;
}

.location-module--image-right .location-module__media {
  order: 2;
}

.location-module__image {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.location-details__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: var(--space-7);
  align-items: start;
}

.location-details__grid--single {
  grid-template-columns: minmax(0, 1fr);
}

.location-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.location-accordion {
  border: 1px solid rgba(52, 52, 51, 0.2);
  background: #fff;
}

.location-accordion__item + .location-accordion__item {
  border-top: 1px solid rgba(52, 52, 51, 0.15);
}

.location-accordion__summary {
  list-style: none;
  cursor: pointer;
  padding: 1rem 1.25rem;
  text-transform: uppercase;
  font-family: var(--font-berthold-baskerville);
  font-weight: bold;
  position: relative;
  background-color: var(--color-cream);
}

.location-accordion__summary::-webkit-details-marker {
  display: none;
}

.location-accordion__summary::after {
  content: "";
  position: absolute;
  right: 1.25rem;
  top: 50%;
  width: 0.6rem;
  height: 0.6rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: translateY(-50%) rotate(45deg);
  transition: transform 0.2s ease;
}

.location-accordion__summary:focus-visible {
  outline: 2px solid var(--color-copper);
  outline-offset: 3px;
}

.location-accordion__item[open] .location-accordion__summary::after {
  transform: translateY(-50%) rotate(-135deg);
}

.location-accordion__content {
  font-family: var(--font-berthold-baskerville);
}

.location-accordion__body {
  padding: 1.25rem 1.25rem;
}

.location-accordion[data-accordion-enhanced] .location-accordion__content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease;
}

.location-accordion__body > * + * {
  margin-top: 0.5rem;
}

.location-info__description {
  font-family: var(--font-berthold-baskerville);
}

.location-info__description > * + * {
  margin-top: 0.5rem;
}

.location-info__description a {
  text-decoration: underline;
  text-decoration-color: rgba(197, 148, 96, 0.6);
  text-underline-offset: 0.2em;
}

.location-info__description a:hover,
.location-info__description a:focus-visible {
  color: var(--color-bourbon);
}

.location-info-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--space-5);
}

.location-info-grid--single {
  grid-template-columns: minmax(0, 1fr);
}

.location-info__block + .location-info__block {
  margin-top: var(--space-4);
}

.location-info__label {
  display: inline-block;
  text-transform: uppercase;
  margin-bottom: 0.5rem;
  font-weight: 700;
  color: var(--color-copper);
}

.location-info__text {
  font-family: var(--font-berthold-baskerville);
}

.location-info__link {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color 0.2s ease, border-color 0.2s ease;
}

.location-info__link:hover,
.location-info__link:focus-visible {
  color: var(--color-bourbon);
  border-color: var(--color-copper);
  outline: none;
}

.location-accordion .location-info__link {
  border-bottom: none;
}

.location-accordion .location-info__link:hover,
.location-accordion .location-info__link:focus-visible {
  border-color: transparent;
}

.location-hours {
  display: grid;
  gap: 0.5rem;
}

.location-hours__row {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.location-hours__day {
  text-transform: uppercase;
  font-weight: 700;
  font-size: 0.8rem;
}

.location-hours__time {
  font-family: var(--font-berthold-baskerville);
}

.location-hours__time--closed {
  color: var(--color-bourbon);
}

.location-carousel {
  background: transparent;
}

.location-carousel__viewport {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: transparent;
  touch-action: pan-y;
}

.location-carousel__hint {
  position: absolute;
  top: 50%;
  width: 2.6rem;
  height: 2.6rem;
  border-radius: 999px;
  border: 0;
  background: transparent;
  color: rgba(248, 242, 234, 0.75);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transform: translateY(-50%);
  cursor: pointer;
  z-index: 2;
  transition: color 0.2s ease, opacity 0.2s ease;
}

.location-carousel__hint::before {
  content: "";
  width: 0.65rem;
  height: 0.65rem;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  display: block;
}

.location-carousel__hint--prev {
  left: 0.4rem;
}

.location-carousel__hint--prev::before {
  transform: rotate(-135deg);
}

.location-carousel__hint--next {
  right: 0.4rem;
}

.location-carousel__hint--next::before {
  transform: rotate(45deg);
}

.location-carousel__hint:hover,
.location-carousel__hint:focus-visible {
  color: rgba(248, 242, 234, 1);
  outline: none;
}

.location-carousel__track {
  position: relative;
  width: 100%;
  height: 100%;
}

.location-carousel__slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.4s ease;
}

.location-carousel__slide.is-active {
  opacity: 1;
  z-index: 1;
}

.location-carousel__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.location-carousel__meta {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: var(--space-3);
}

.location-carousel__pagination {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.location-carousel__dot {
  appearance: none;
  border: 1px solid rgba(52, 52, 51, 0.35);
  background: transparent;
  width: 0.6rem;
  height: 0.6rem;
  border-radius: 999px;
  padding: 0;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.location-carousel__dot.is-active {
  background-color: var(--color-bourbon);
  border-color: var(--color-bourbon);
  transform: scale(1.15);
}

.location-carousel__dot:focus-visible {
  outline: 2px solid var(--color-copper);
  outline-offset: 3px;
}


@media (max-width: 1090px) {
  .location-actions {
    position: relative;
    overflow: hidden;
  }

  .location-actions .container {
    position: relative;
  }

  .location-actions::before,
  .location-actions::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 2.25rem;
    pointer-events: none;
    z-index: 2;
    opacity: 1;
    transition: opacity 0.2s ease;
  }

  .location-actions::before {
    left: 0;
    background: linear-gradient(90deg, var(--color-cream) 0%, rgba(248, 242, 234, 0) 100%);
  }

  .location-actions::after {
    right: 0;
    background: linear-gradient(270deg, var(--color-cream) 0%, rgba(248, 242, 234, 0) 100%);
  }

  .location-actions__hint {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 0.35rem;
    z-index: 3;
    pointer-events: none;
  }

  .location-actions__hint-button {
    pointer-events: auto;
    appearance: none;
    border: 0;
    background: transparent;
    padding: 0;
    width: 2.25rem;
    height: 2.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
  }

  .location-actions__hint-button:focus-visible {
    outline: 2px solid var(--color-copper);
    outline-offset: 2px;
    border-radius: 999px;
  }

  .location-actions.is-at-start::before,
  .location-actions.is-at-end::after {
    opacity: 0;
  }

  .location-actions.is-at-start .location-actions__hint-arrow--left,
  .location-actions.is-at-end .location-actions__hint-arrow--right {
    opacity: 0;
    animation: none;
  }

  .location-actions__scroller {
    margin: 0 0.5rem;
    scroll-padding-inline: 2.5rem;
  }

  .location-sponsors {
    position: relative;
    overflow: hidden;
  }

  .location-sponsors .container {
    position: relative;
  }

  .location-sponsors::before,
  .location-sponsors::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 2.25rem;
    pointer-events: none;
    z-index: 2;
    opacity: 1;
    transition: opacity 0.2s ease;
  }

  .location-sponsors::before {
    left: 0;
    background: linear-gradient(90deg, var(--color-cream) 0%, rgba(248, 242, 234, 0) 100%);
  }

  .location-sponsors::after {
    right: 0;
    background: linear-gradient(270deg, var(--color-cream) 0%, rgba(248, 242, 234, 0) 100%);
  }

  .location-sponsors__hint {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 0.9rem;
    z-index: 3;
  }

  .location-sponsors.is-at-start::before,
  .location-sponsors.is-at-end::after {
    opacity: 0;
  }

  .location-sponsors.is-at-start .location-sponsors__hint-arrow--left,
  .location-sponsors.is-at-end .location-sponsors__hint-arrow--right {
    opacity: 0;
    animation: none;
  }

  .location-sponsors.is-at-start.is-at-end .location-sponsors__scroller {
    justify-content: center;
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }

  .location-sponsors__scroller {
    margin: 0 0.5rem;
    padding-left: 0;
    padding-right: 1.25rem;
    scroll-padding-inline: 1.75rem;
    justify-content: flex-start;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
  }
}

@media (max-width: 900px) {
  .location-details__grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .page-template-page-location .location-modules .container {
    padding-left: var(--content-gutter);
    padding-right: var(--content-gutter);
  }

  .location-module__slides {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
  }

  .location-module__slide {
    grid-template-columns: minmax(0, 1fr);
    text-align: center;
    padding-inline: clamp(3.5rem, 14vw, 5rem);
  }

  .location-module__slide.is-active {
    position: relative;
  }

  .location-module__slide-content {
    max-width: min(26rem, 100%);
  }

  .location-module__slider-arrow--prev {
    left: 0.5rem;
  }

  .location-module__slider-arrow--next {
    right: 0.5rem;
  }

  .location-module--media {
    grid-template-columns: minmax(0, 1fr);
    text-align: center;
  }

  .location-module--image-right .location-module__media {
    order: 0;
  }

  .location-module__actions {
    justify-content: center;
  }

  .location-info-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .location-accordion__summary {
    padding-right: 5rem;
  }
}

@media (max-width: 640px) {
  .location-accordion__summary-nowrap {
    white-space: nowrap;
  }

  .location-hero {
    padding-top: calc(var(--site-header-height) + var(--safe-area-top) + 2.75rem);
  }

  .location-actions__scroller .btn {
    padding: 0.85rem 1.75rem;
    font-size: 1.1rem;
    min-height: 44px;
  }

  .location-carousel {
    padding: var(--space-3);
  }
}

/* Private events template */
.page-template-page-private-events .site-header + main {
  padding-top: 0;
}

.private-events-hero {
  background-image: var(--private-events-hero-image, none);
}

.private-events-hero__overlay {
  pointer-events: none;
  background-color: var(--color-ink);
  opacity: 0.7;
}

.private-events-hero__content {
  max-width: 52rem;
}

.private-events-hero__title {
  margin-bottom: 0.85rem;
}

.private-events-hero__lead {
  font-size: clamp(1rem, 2.2vw, 1.35rem);
}

.private-events-sections {
  padding: var(--section-pad) 0;
  background: var(--color-cream);
}

.private-events-section {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: clamp(2rem, 4vw, 4rem);
  align-items: center;
}

.private-events-section + .private-events-section {
  margin-top: var(--space-8);
  padding-top: var(--space-8);
  border-top: 1px dashed rgba(52, 52, 51, 0.2);
}

.private-events-section--image-right {
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
}

.private-events-section--image-right .private-events-section__media {
  order: 2;
}

.private-events-section--image-right .private-events-section__content {
  order: 1;
}

.private-events-section__content {
  color: var(--color-charcoal);
}

.private-events-section__media,
.private-events-section__content {
  min-width: 0;
}

.private-events-section__copy {
  font-family: var(--font-berthold-baskerville);
}

.private-events-section__copy > * + * {
  margin-top: 0.75rem;
}

.private-events-section__actions {
  margin-top: var(--space-4);
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.private-events-section--no-media,
.private-events-section--no-content {
  grid-template-columns: minmax(0, 1fr);
}

@media (max-width: 900px) {
  .private-events-section {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 640px) {
  .private-events-hero {
    padding-top: calc(var(--site-header-height) + var(--safe-area-top) + 2.75rem);
  }

  .private-events-section {
    text-align: center;
  }

  .private-events-section__actions {
    justify-content: center;
  }
}

/* Cursor overrides */
html body {
  cursor: auto !important;
}

html body input[type="text"],
html body input[type="email"],
html body input[type="search"],
html body input[type="password"],
html body input[type="tel"],
html body input[type="url"],
html body input[type="number"],
html body textarea,
html body [contenteditable="true"] {
  cursor: text !important;
}

html body input[type="checkbox"],
html body input[type="radio"],
html body input[type="file"] {
  cursor: pointer !important;
}

html body .btn,
html body a[href],
html body button,
html body input[type="button"],
html body input[type="submit"],
html body input[type="reset"],
html body [role="button"],
html body .location-carousel__dot,
html body .location-carousel__hint,
html body .location-module__slider-dot,
html body .location-module__slider-arrow,
html body [data-carousel-prev],
html body [data-carousel-next],
html body [data-carousel-dot],
html body [data-slider-prev],
html body [data-slider-next],
html body [data-slider-dot] {
  cursor: pointer !important;
}

html body .btn *,
html body a[href] *,
html body button * {
  cursor: inherit !important;
}

html body .menu-categories__scroller {
  cursor: grab !important;
}

html body .menu-categories__scroller.is-dragging {
  cursor: grabbing !important;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .menu-categories__hint-arrow,
  .location-actions__hint-arrow,
  .location-sponsors__hint-arrow {
    animation: none;
  }

  .locations-card__link {
    transition: none;
  }

  .locations-card__link:hover,
  .locations-card__link:focus-within {
    transform: none;
  }

  .location-carousel__slide {
    transition: none;
  }

  .location-module__slide {
    transition: none;
  }

  .location-accordion[data-accordion-enhanced] .location-accordion__content {
    transition: none;
  }
}
