:root {
  --film-red: #ef1724;
  --film-teal: #53c4cf;
  --film-dark: #052f36;
  --film-ink: #12282c;
  --film-paper: #f5f2ed;
  --film-white: #fff;
}

body.option-two {
  font-family: "DM Sans", Arial, sans-serif;
}

.option-two h1,
.option-two h2,
.option-two h3,
.option-two h4,
.option-two h5,
.option-two h6 {
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 700 !important;
  letter-spacing: 0;
}

.page-home main {
  overflow: hidden;
}

.page-home .section-label {
  margin: 0 0 14px;
  color: var(--film-red);
  font-family: "DM Sans", Arial, sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.film-hero {
  position: relative;
  min-height: clamp(650px, calc(100svh - 96px), 850px);
  color: var(--film-white);
  background: #111;
  isolation: isolate;
}

.film-hero-video,
.film-hero-shade {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.film-hero-video {
  z-index: -2;
  object-fit: cover;
}

.film-hero-shade {
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(3, 25, 29, .9) 0%, rgba(3, 25, 29, .64) 42%, rgba(3, 25, 29, .06) 76%),
    linear-gradient(0deg, rgba(3, 25, 29, .68) 0%, transparent 46%);
}

.film-hero-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: min(1320px, calc(100% - 48px));
  min-height: clamp(650px, calc(100svh - 96px), 850px);
  margin: 0 auto;
  padding: 70px 46% 90px 0;
}

.film-kicker {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0 0 18px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.film-kicker span {
  width: 44px;
  height: 5px;
  background: var(--film-red);
}

.film-hero h1 {
  max-width: 760px;
  margin: 0;
  color: #fff !important;
  font-family: "Barlow Condensed", sans-serif;
  font-size: clamp(80px, 8.5vw, 138px);
  font-weight: 700 !important;
  line-height: .82;
  text-transform: uppercase;
}

.film-hero h1 span,
.film-hero h1 em {
  display: block;
}

.film-hero h1 em {
  color: var(--film-red);
  font-style: normal;
}

.film-intro {
  width: 100%;
  max-width: 550px;
  margin: 28px 0 0;
  font-size: 17px;
  font-weight: 500;
  line-height: 1.6;
}

.film-actions {
  display: flex;
  align-items: center;
  gap: 26px;
  margin-top: 34px;
}

.page-home .film-primary {
  min-height: 56px;
  padding: 0 29px;
  border: 0;
  background: var(--film-red);
  font-size: 12px;
}

.film-secondary,
.feature-link,
.story-link {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  padding: 9px 0;
  border-bottom: 2px solid currentColor;
  color: inherit;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.film-secondary span,
.feature-link span,
.story-link span {
  transition: transform .2s ease;
}

.film-secondary:hover span,
.feature-link:hover span,
.story-link:hover span {
  transform: translateX(5px);
}

.film-note {
  position: absolute;
  right: max(24px, calc((100vw - 1320px) / 2));
  bottom: 42px;
  margin: 0;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.film-control {
  position: absolute;
  right: max(24px, calc((100vw - 1320px) / 2));
  bottom: 78px;
  display: grid;
  width: 46px;
  height: 46px;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, .65);
  color: #fff;
  background: rgba(3, 25, 29, .35);
  font-family: Arial, sans-serif;
  font-size: 11px;
  font-weight: 700;
  place-items: center;
  cursor: pointer;
}

.flavour-ribbon {
  overflow: hidden;
  color: #fff;
  background: var(--film-red);
  border-bottom: 7px solid var(--film-teal);
}

.flavour-ribbon-track {
  display: flex;
  align-items: center;
  gap: 30px;
  width: max-content;
  min-width: 200%;
  padding: 18px 0;
  animation: flavourTicker 30s linear infinite;
}

.flavour-ribbon span {
  font-family: "Archivo Black", sans-serif;
  font-size: 16px;
  text-transform: uppercase;
}

.flavour-ribbon i {
  width: 7px;
  height: 7px;
  background: var(--film-teal);
  transform: rotate(45deg);
}

@keyframes flavourTicker {
  to { transform: translateX(-50%); }
}

.flame-feature {
  display: grid;
  grid-template-columns: minmax(0, 1.16fr) minmax(420px, .84fr);
  min-height: 720px;
  background: var(--film-red);
}

.flame-feature-film {
  position: relative;
  min-height: 720px;
  overflow: hidden;
  background: #111;
}

.flame-feature-film::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(3, 25, 29, .52), transparent 45%);
  pointer-events: none;
}

.flame-feature-film video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .7s ease;
}

.flame-feature:hover .flame-feature-film video {
  transform: scale(1.025);
}

.film-index {
  position: absolute;
  z-index: 1;
  right: 34px;
  bottom: 30px;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.flame-feature-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(55px, 7vw, 115px);
  color: #fff;
}

.page-home .flame-feature-copy .section-label {
  color: var(--film-dark);
}

.flame-feature-copy h2 {
  margin: 0 0 28px;
  color: #fff;
  font-size: clamp(62px, 6.4vw, 104px);
  line-height: .91;
  text-transform: uppercase;
}

.flame-feature-copy h1 {
  max-width: 650px;
  margin: 0 0 28px;
  color: #fff !important;
  font-size: clamp(58px, 5.8vw, 92px);
  line-height: .92;
  text-transform: uppercase;
}

.flame-feature-copy > p:not(.section-label) {
  max-width: 540px;
  margin: 0 0 25px;
  font-size: 15px;
  line-height: 1.7;
}

.flame-story-feature {
  grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr);
  min-height: calc(100svh - 96px);
  background: var(--film-red);
}

.flame-story-feature .flame-feature-film {
  min-height: calc(100svh - 96px);
}

.page-our-story .flame-feature-copy {
  min-width: 0;
  padding: clamp(52px, 6vw, 95px);
}

.page-our-story .flame-feature-copy h1 {
  max-width: 590px;
  font-family: "Barlow Condensed", sans-serif;
  font-size: clamp(42px, 3.8vw, 57px);
  font-weight: 700 !important;
  line-height: .9;
  white-space: nowrap;
}

.page-our-story .flame-feature-copy .section-label {
  color: var(--film-dark);
}

.page-our-story .flame-feature-copy > p:not(.section-label) {
  max-width: 650px;
  margin-bottom: 18px;
  font-size: 15px;
  line-height: 1.72;
}

.page-our-story .flame-stats {
  margin-top: 42px;
}

.feature-link {
  align-self: flex-start;
  margin-top: 8px;
  color: #fff;
}

.flame-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-top: 60px;
  padding-top: 24px;
  border-top: 1px solid rgba(255, 255, 255, .4);
}

.flame-stats span {
  font-size: 11px;
  font-weight: 600;
  line-height: 1.45;
  text-transform: uppercase;
}

.flame-stats strong {
  display: block;
  margin-bottom: 2px;
  color: var(--film-dark);
  font-family: "Archivo Black", sans-serif;
  font-size: 25px;
}

.page-home .story-preview {
  display: grid;
  grid-template-columns: minmax(0, .86fr) minmax(0, 1.14fr);
  gap: clamp(50px, 7vw, 110px);
  width: 100%;
  padding: 120px max(24px, calc((100vw - 1320px) / 2));
  color: var(--film-ink);
  background: var(--film-paper);
}

.page-home .story-copy {
  order: 1;
  align-self: center;
  padding: 0;
}

.page-home .story-copy h2 {
  max-width: 620px;
  margin: 0 0 28px;
  color: var(--film-dark);
  font-size: clamp(57px, 5.8vw, 90px);
  line-height: .94;
  text-transform: uppercase;
}

.page-home .story-copy > p:not(.section-label) {
  max-width: 610px;
  color: #526266;
  font-size: 14px;
  line-height: 1.75;
}

.page-home .story-copy ul {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin: 28px 0 23px;
  padding: 0;
  color: var(--film-dark);
  list-style: none;
}

.page-home .story-copy li {
  padding: 12px 0;
  border-top: 1px solid rgba(5, 47, 54, .18);
  background: transparent;
  font-size: 12px;
  font-weight: 700;
}

.page-home .story-copy li:last-child {
  border-bottom: 1px solid rgba(5, 47, 54, .18);
}

.page-home .story-copy li::before {
  display: inline-block;
  width: 7px;
  height: 7px;
  margin-right: 12px;
  background: var(--film-red);
  content: "";
  transform: rotate(45deg);
}

.story-link {
  color: var(--film-red);
}

.page-home .story-visual {
  position: relative;
  order: 2;
  min-height: 720px;
  padding: 0;
}

.page-home .story-visual::before {
  display: none;
}

.page-home .story-visual img {
  width: 100%;
  height: 720px;
  margin: 0;
  object-fit: cover;
  box-shadow: 18px 18px 0 var(--film-teal);
}

.page-home .story-visual span {
  position: absolute;
  right: -18px;
  bottom: 40px;
  display: block;
  padding: 20px 24px;
  color: #fff;
  background: var(--film-red);
  font-family: "Archivo Black", sans-serif;
  font-size: 22px;
  line-height: 1.05;
  text-transform: uppercase;
}

.craving-films {
  padding: 110px max(24px, calc((100vw - 1320px) / 2)) 125px;
  color: #fff;
  background: var(--film-dark);
}

.craving-heading {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 25px;
  margin-bottom: 42px;
}

.craving-heading .section-label {
  grid-column: 1 / -1;
  margin-bottom: -12px;
  color: var(--film-teal);
}

.craving-heading h2 {
  max-width: 900px;
  margin: 0;
  color: #fff;
  font-size: clamp(58px, 6vw, 94px);
  line-height: .94;
  text-transform: uppercase;
}

.craving-heading > p:last-child {
  max-width: 260px;
  margin: 0 0 5px;
  color: #bad1d4;
  font-size: 13px;
  text-align: right;
}

.craving-grid {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 18px;
}

.craving-card {
  position: relative;
  min-height: 540px;
  overflow: hidden;
  color: #fff;
  background: #111;
}

.craving-card::after {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(2, 26, 30, .84), transparent 58%);
  content: "";
}

.craving-card video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .55s ease;
}

.craving-card:hover video {
  transform: scale(1.035);
}

.craving-card > span {
  position: absolute;
  z-index: 1;
  right: 30px;
  bottom: 28px;
  left: 30px;
}

.craving-card small {
  display: block;
  margin-bottom: 7px;
  color: var(--film-teal);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.craving-card strong {
  display: block;
  font-family: "Archivo Black", sans-serif;
  font-size: clamp(29px, 3vw, 48px);
  line-height: 1;
  text-transform: uppercase;
}

.page-home .home-menu-preview {
  padding: 115px max(24px, calc((100vw - 1320px) / 2)) 135px;
  color: var(--film-dark);
  background: #fff;
}

.page-home .popular-heading {
  align-items: end;
  max-width: 1320px;
  margin: 0 auto 42px;
}

.page-home .popular-heading h2 {
  margin: 0 0 12px;
  color: var(--film-dark);
  font-size: clamp(47px, 4.5vw, 71px);
  line-height: .94;
}

.page-home .popular-intro {
  max-width: 790px;
  color: #526266;
  font-size: 13px;
}

.page-home .preview-grid {
  gap: 18px;
  max-width: 1320px;
  margin: 0 auto;
}

.page-home .popular-card,
.page-home .popular-card:nth-child(2),
.page-home .popular-card:nth-child(2):hover {
  border: 0;
  background: var(--film-paper);
  box-shadow: none;
  transform: none;
}

.page-home .popular-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 40px rgba(5, 47, 54, .13);
}

.page-home .popular-image {
  aspect-ratio: 1.1 / 1;
  background: var(--film-teal);
}

.page-home .popular-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.page-home .popular-copy {
  padding: 23px 24px 25px;
}

.page-home .popular-copy small {
  color: var(--film-red);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.page-home .popular-copy strong {
  margin: 7px 0;
  color: var(--film-dark);
  font-family: "Archivo Black", sans-serif;
  font-size: 24px;
  line-height: 1.05;
  text-transform: uppercase;
}

.page-home .popular-copy p {
  color: #526266;
  font-size: 11px;
}

.page-home .popular-price {
  top: auto;
  right: 0;
  bottom: 0;
  border-radius: 0;
  color: #fff;
  background: var(--film-red);
  font-family: "Archivo Black", sans-serif;
  font-size: 18px;
}

/* A lighter shared visual language for the second option's inner pages */
.option-two:not(.page-home) main {
  color: var(--film-ink);
  background: var(--film-paper);
}

.option-two:not(.page-home) main h1,
.option-two:not(.page-home) main h2,
.option-two:not(.page-home) main h3 {
  color: var(--film-dark);
}

/* Compact inner-page title system */
.option-two .store-locator-heading,
.option-two .contact-page-heading,
.option-two .gallery-simple-heading {
  padding-top: 44px;
  padding-bottom: 46px;
}

.option-two .store-locator-heading h1,
.option-two .contact-page-heading h1,
.option-two .gallery-simple-heading h1,
.option-two .gallery-detail-heading h1,
.option-two .location-detail-heading h1,
.option-two .location-not-found h1 {
  font-family: "Barlow Condensed", sans-serif;
  font-size: clamp(34px, 3.2vw, 48px);
  font-weight: 700 !important;
  line-height: .98;
}

/* Catering film */
.option-two .catering-film-hero {
  position: relative;
  display: flex;
  align-items: center;
  min-height: clamp(610px, calc(100svh - 96px), 780px);
  overflow: hidden;
  color: #fff;
  background: var(--film-dark);
  isolation: isolate;
}

.option-two .catering-film-hero > video,
.option-two .catering-film-shade {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.option-two .catering-film-hero > video {
  z-index: -2;
  object-fit: cover;
}

.option-two .catering-film-shade {
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(3, 25, 29, .92) 0%, rgba(3, 25, 29, .64) 48%, rgba(3, 25, 29, .14) 78%),
    linear-gradient(0deg, rgba(3, 25, 29, .52), transparent 48%);
}

.option-two .catering-film-hero .catering-hero-content {
  width: min(1320px, calc(100% - 48px));
  max-width: none;
  margin: 0 auto;
  padding: 70px 48% 80px 0;
}

.option-two .catering-film-hero .section-label {
  color: var(--film-teal);
}

.option-two .catering-film-hero h1 {
  margin: 0 0 22px;
  color: #fff !important;
  font-family: "Barlow Condensed", sans-serif;
  font-size: clamp(62px, 6.4vw, 94px);
  font-weight: 700 !important;
  line-height: .88;
}

.option-two .catering-film-hero h1 span {
  color: var(--film-red) !important;
}

.option-two .catering-film-hero p:not(.section-label) {
  max-width: 550px;
  color: #fff;
  font-size: 15px;
}

/* Map-first locations concept */
.option-two .location-atlas {
  padding-bottom: 110px;
  background: var(--film-paper);
}

.option-two .location-atlas .store-locator-heading {
  width: min(1320px, calc(100% - 48px));
  margin: 0 auto;
  padding: 70px 0 34px;
  color: var(--film-dark);
  background: transparent;
  border-bottom: 1px solid rgba(5, 47, 54, .18);
}

.option-two .location-atlas .store-locator-heading .section-label {
  color: var(--film-red);
}

.option-two .location-atlas .store-locator-heading h1 {
  max-width: none;
  color: var(--film-dark);
  white-space: nowrap;
}

.location-atlas-inner {
  width: min(1320px, calc(100% - 48px));
  margin: 34px auto 0;
}

.location-atlas-selector {
  margin-bottom: 18px;
}

.location-atlas-map {
  position: relative;
  height: 500px;
  overflow: hidden;
  background: #ddd;
  border-bottom: 8px solid var(--film-teal);
}

.location-atlas-map .store-map-bar {
  position: absolute;
  z-index: 2;
  top: 24px;
  right: 24px;
  left: 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 17px 20px;
  color: #fff;
  background: var(--film-dark);
  border-bottom: 5px solid var(--film-red);
}

.location-atlas-map .store-map-bar span {
  display: block;
  color: var(--film-teal);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.location-atlas-map .store-map-bar strong {
  display: block;
  font-family: "Barlow Condensed", sans-serif;
  font-size: 25px;
  line-height: 1;
  text-transform: uppercase;
}

.location-atlas-map .store-map-bar a {
  color: var(--film-teal);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
}

.location-atlas-map .location-map {
  width: 100%;
  height: 100%;
}

.location-atlas-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 20px;
}

.location-atlas-card {
  display: flex;
  min-height: 300px;
  padding: 25px 24px 22px;
  flex-direction: column;
  background: #fff;
  border-top: 6px solid var(--film-teal);
  transition: transform .2s ease, color .2s ease, background .2s ease;
}

.location-atlas-card.active {
  color: #fff;
  background: var(--film-dark);
  border-top-color: var(--film-red);
}

.location-atlas-card:hover {
  transform: translateY(-4px);
}

.location-atlas-region {
  margin: 0 0 6px;
  color: var(--film-red);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.location-atlas-card h2 {
  margin: 0 0 18px;
  color: var(--film-dark);
  font-size: 31px;
  line-height: .96;
  text-transform: uppercase;
}

.location-atlas-card.active h2 {
  color: #fff;
}

.location-atlas-address {
  margin-bottom: 24px;
  color: #657174;
  font-size: 12px;
  line-height: 1.55;
}

.location-atlas-card.active .location-atlas-address {
  color: #c6d7d9;
}

.location-atlas-address strong {
  display: block;
  margin-bottom: 5px;
  color: inherit;
}

.location-atlas-address p {
  margin: 0;
}

.location-atlas-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px 18px;
  margin-top: auto;
}

.location-atlas-actions button,
.location-atlas-actions a {
  border: 0;
  color: var(--film-dark);
  background: transparent;
  font-family: "DM Sans", sans-serif;
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  cursor: pointer;
}

.location-atlas-actions button {
  min-height: 36px;
  padding: 0 13px;
  color: #fff;
  background: var(--film-red);
}

.location-atlas-card.active .location-atlas-actions button {
  background: var(--film-teal);
}

.location-atlas-card.active .location-atlas-actions a {
  color: #fff;
}

@media (max-width: 1050px) {
  .film-hero-content {
    padding-right: 32%;
  }

  .flame-feature {
    grid-template-columns: 1fr;
  }

  .flame-feature-film,
  .flame-feature {
    min-height: 570px;
  }

  .flame-feature-copy {
    padding: 75px max(24px, calc((100vw - 800px) / 2));
  }

  .page-home .story-preview {
    grid-template-columns: 1fr 1fr;
    gap: 45px;
  }

  .page-home .story-visual,
  .page-home .story-visual img {
    min-height: 620px;
    height: 620px;
  }

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

@media (max-width: 760px) {
  .film-hero,
  .film-hero-content {
    min-height: calc(100svh - 82px);
  }

  .film-hero-shade {
    background:
      linear-gradient(0deg, rgba(3, 25, 29, .9) 0%, rgba(3, 25, 29, .45) 72%, rgba(3, 25, 29, .14) 100%);
  }

  .film-hero-video {
    object-position: 58% center;
  }

  .film-hero-content {
    justify-content: flex-end;
    width: 100%;
    padding: 90px 24px 85px;
  }

  .film-kicker {
    margin-bottom: 13px;
    font-size: 10px;
  }

  .film-hero h1 {
    max-width: 430px;
    font-size: clamp(52px, 15vw, 66px);
    line-height: .88;
  }

  .film-intro {
    max-width: 430px;
    margin-top: 18px;
    font-size: 13px;
  }

  .film-actions {
    align-items: flex-start;
    flex-direction: column;
    gap: 14px;
    margin-top: 24px;
  }

  .page-home .film-primary {
    min-height: 50px;
  }

  .film-note,
  .film-control {
    display: none;
  }

  .flavour-ribbon-track {
    gap: 20px;
    padding: 13px 0;
  }

  .flavour-ribbon span {
    font-size: 12px;
  }

  .flame-feature-film {
    min-height: 420px;
  }

  .flame-feature-copy {
    padding: 58px 24px 64px;
  }

  .flame-feature-copy h2 {
    font-size: clamp(48px, 15vw, 68px);
  }

  .flame-feature-copy h1 {
    font-size: clamp(46px, 14vw, 64px);
  }

  .flame-story-feature,
  .flame-story-feature .flame-feature-film {
    min-height: 430px;
  }

  .flame-story-feature {
    grid-template-columns: 1fr;
  }

  .page-our-story .flame-feature-copy {
    padding: 58px 24px 68px;
  }

  .page-our-story .flame-feature-copy h1 {
    font-size: clamp(35px, 10.8vw, 46px);
    white-space: normal;
  }

  .flame-stats {
    margin-top: 42px;
  }

  .page-home .story-preview {
    display: flex;
    flex-direction: column;
    gap: 45px;
    padding: 70px 24px 80px;
  }

  .page-home .story-copy {
    order: 1;
  }

  .page-home .story-copy h2 {
    font-size: clamp(46px, 13.5vw, 66px);
  }

  .page-home .story-visual {
    order: 2;
  }

  .page-home .story-visual,
  .page-home .story-visual img {
    min-height: 520px;
    height: 520px;
  }

  .page-home .story-visual img {
    box-shadow: 9px 9px 0 var(--film-teal);
  }

  .page-home .story-visual span {
    right: -9px;
    bottom: 24px;
    padding: 15px 17px;
    font-size: 17px;
  }

  .craving-films {
    padding: 70px 16px 80px;
  }

  .craving-heading {
    display: block;
    margin: 0 8px 28px;
  }

  .craving-heading .section-label {
    margin-bottom: 12px;
  }

  .craving-heading h2 {
    font-size: clamp(46px, 13.5vw, 66px);
  }

  .craving-heading > p:last-child {
    margin-top: 12px;
    text-align: left;
  }

  .craving-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .craving-card {
    min-height: 390px;
  }

  .craving-card > span {
    right: 20px;
    bottom: 20px;
    left: 20px;
  }

  .page-home .home-menu-preview {
    padding: 72px 16px 85px;
  }

  .page-home .popular-heading {
    margin: 0 8px 28px;
  }

  .page-home .popular-heading h2 {
    font-size: clamp(36px, 10.5vw, 51px);
  }

  .page-home .preview-grid {
    gap: 13px;
  }

  .page-home .popular-image {
    aspect-ratio: 1.28 / 1;
  }

  .option-two .store-locator-heading,
  .option-two .contact-page-heading,
  .option-two .gallery-simple-heading {
    padding-top: 32px;
    padding-bottom: 34px;
  }

  .option-two .store-locator-heading h1,
  .option-two .contact-page-heading h1,
  .option-two .gallery-simple-heading h1,
  .option-two .gallery-detail-heading h1,
  .option-two .location-detail-heading h1 {
    max-width: 340px;
    font-size: 30px;
    white-space: normal;
  }

  .option-two .catering-film-hero {
    min-height: calc(100svh - 82px);
  }

  .option-two .catering-film-hero .catering-hero-content {
    width: 100%;
    padding: 280px 24px 58px;
  }

  .option-two .catering-film-hero h1 {
    font-size: clamp(48px, 14vw, 64px);
  }

  .option-two .catering-film-shade {
    background: linear-gradient(0deg, rgba(3, 25, 29, .92) 0%, rgba(3, 25, 29, .25) 82%);
  }

  .option-two .location-atlas {
    padding-bottom: 75px;
  }

  .option-two .location-atlas .store-locator-heading,
  .location-atlas-inner {
    width: calc(100% - 32px);
  }

  .option-two .location-atlas .store-locator-heading {
    padding: 42px 0 24px;
  }

  .option-two .location-atlas .store-locator-heading h1 {
    max-width: none;
    white-space: nowrap;
  }

  .location-atlas-map {
    height: 390px;
  }

  .location-atlas-map .store-map-bar {
    top: 12px;
    right: 12px;
    left: 12px;
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }

  .location-atlas-grid {
    grid-template-columns: 1fr;
  }

  .location-atlas-card {
    min-height: 260px;
  }
}

/* Bright menu-board popular picks */
.page-home .home-menu-preview {
  color: var(--film-dark);
  background: #fff;
}

.page-home .popular-heading {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 35px;
  padding-bottom: 30px;
  border-bottom: 1px solid rgba(5, 47, 54, .18);
}

.page-home .popular-heading h2 {
  color: var(--film-dark);
}

.page-home .popular-heading .section-label {
  color: var(--film-red);
}

.page-home .popular-intro {
  color: #526266;
}

.page-home .popular-menu-link {
  color: #fff;
  background: var(--film-red);
}

.popular-menu-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  max-width: 1320px;
  margin: 0 auto;
  border-top: 7px solid var(--film-red);
  border-bottom: 1px solid rgba(5, 47, 54, .18);
}

.popular-menu-item {
  display: block;
  min-width: 0;
  color: var(--film-dark);
  background: #fff;
  border-right: 1px solid rgba(5, 47, 54, .18);
  transition: background .25s ease, transform .25s ease;
}

.popular-menu-item:last-child {
  border-right: 0;
}

.popular-menu-item:hover {
  background: var(--film-paper);
  transform: translateY(-5px);
}

.popular-menu-image {
  display: block;
  aspect-ratio: 1 / .84;
  overflow: hidden;
  background: var(--film-teal);
}

.popular-menu-image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .55s ease;
}

.popular-menu-item:hover .popular-menu-image img {
  transform: scale(1.025);
}

.popular-menu-copy {
  display: block;
  min-height: 245px;
  padding: 27px 27px 25px;
}

.popular-menu-copy small {
  display: block;
  margin-bottom: 12px;
  color: var(--film-red);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.popular-menu-title {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
}

.popular-menu-title strong {
  display: block;
  max-width: 260px;
  color: var(--film-dark);
  font-family: "Barlow Condensed", sans-serif;
  font-size: clamp(29px, 2.4vw, 38px);
  font-weight: 700;
  line-height: .96;
  text-transform: uppercase;
}

.popular-menu-title b {
  flex: 0 0 auto;
  color: var(--film-red);
  font-family: "Barlow Condensed", sans-serif;
  font-size: 23px;
  line-height: 1;
}

.popular-menu-copy > span:not(.popular-menu-title) {
  display: block;
  max-width: 330px;
  margin-top: 16px;
  color: #667477;
  font-size: 14px;
  line-height: 1.6;
}

.popular-menu-copy em {
  display: inline-block;
  margin-top: 24px;
  padding-bottom: 5px;
  border-bottom: 2px solid var(--film-red);
  color: var(--film-dark);
  font-size: 11px;
  font-style: normal;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
}

/* Equal-status store directory */
.option-two .location-directory {
  padding: 76px max(24px, calc((100vw - 1320px) / 2)) 120px;
  background: var(--film-paper);
}

.location-directory-heading {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(280px, .75fr);
  align-items: end;
  gap: 60px;
  margin-bottom: 42px;
  padding-bottom: 32px;
  border-bottom: 1px solid rgba(5, 47, 54, .2);
}

.location-directory-heading .section-label {
  margin-bottom: 12px;
  color: var(--film-red);
}

.location-directory-heading h1 {
  margin: 0;
  color: var(--film-dark);
  font-size: clamp(38px, 3.5vw, 54px);
  line-height: .95;
}

.location-directory-heading > p {
  max-width: 430px;
  margin: 0 0 2px;
  color: #617174;
  font-size: 13px;
  line-height: 1.7;
}

.location-directory-list {
  border-top: 7px solid var(--film-red);
}

.location-directory-row {
  display: grid;
  grid-template-columns: minmax(250px, .85fr) minmax(330px, 1.15fr) auto;
  align-items: center;
  gap: 45px;
  min-height: 175px;
  padding: 30px 32px;
  background: #fff;
  border-bottom: 1px solid rgba(5, 47, 54, .15);
  transition: color .2s ease, background .2s ease, transform .2s ease;
}

.location-directory-row:hover {
  color: #fff;
  background: var(--film-dark);
  transform: translateX(6px);
}

.location-directory-name p {
  margin: 0 0 7px;
  color: var(--film-red);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.location-directory-name h2 {
  margin: 0;
  color: var(--film-dark);
  font-size: clamp(27px, 2.2vw, 36px);
  line-height: .96;
  text-transform: uppercase;
}

.location-directory-name h2 a {
  color: inherit;
}

.location-directory-address {
  color: #667477;
  font-size: 14px;
  line-height: 1.6;
}

.location-directory-address strong {
  display: block;
  margin-bottom: 4px;
  color: var(--film-dark);
}

.location-directory-address p {
  margin: 0;
}

.location-directory-actions {
  display: grid;
  gap: 9px;
  min-width: 138px;
}

.location-directory-actions a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 11px 0;
  border-bottom: 1px solid currentColor;
  color: var(--film-dark);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.option-two .location-directory-row:hover .location-directory-name h2,
.location-directory-row:hover .location-directory-address,
.location-directory-row:hover .location-directory-address strong,
.location-directory-row:hover .location-directory-actions a {
  color: #fff !important;
}

.location-directory-row:hover .location-directory-name p {
  color: var(--film-teal);
}

/* Calm, information-first location detail */
.option-two .location-detail-hero {
  position: relative;
  padding: 0;
  color: #fff;
  background: var(--film-dark);
  border-bottom: 8px solid var(--film-teal);
}

.option-two .location-detail-hero::after {
  position: absolute;
  right: max(24px, calc((100vw - 1320px) / 2));
  bottom: -8px;
  width: min(240px, 24vw);
  height: 8px;
  background: var(--film-red);
  content: "";
}

.option-two .location-detail-heading {
  width: min(1320px, calc(100% - 48px));
  max-width: none;
  margin: 0 auto;
  padding: 64px 0 70px;
}

.option-two .location-detail-heading .location-back-link {
  margin-bottom: 48px;
  color: var(--film-teal);
  font-size: 12px;
}

.option-two .location-detail-heading .section-label {
  margin-bottom: 12px;
  color: var(--film-red);
}

.option-two .location-detail-heading h1 {
  max-width: 980px;
  margin: 0;
  color: #fff !important;
  font-family: "Barlow Condensed", sans-serif;
  font-size: clamp(50px, 5vw, 72px);
  font-weight: 700 !important;
  line-height: .94;
}

.option-two .location-detail-hero h1 + p {
  max-width: 700px;
  margin-top: 18px;
  color: #c7d7d9;
  font-size: 15px;
}

.option-two .location-visit-grid {
  background: var(--film-paper);
}

.option-two .location-visit-grid .location-detail-info {
  padding-top: 68px;
  padding-bottom: 72px;
  background: var(--film-paper);
}

.option-two .location-detail-info .section-label {
  color: var(--film-red);
}

.option-two .location-detail-info h2 {
  color: var(--film-dark);
}

.option-two .location-facts div {
  border-top-color: rgba(5, 47, 54, .18);
}

/* Event-journal gallery */
.option-two .gallery-journal {
  padding: 75px max(24px, calc((100vw - 1320px) / 2)) 125px;
  background: var(--film-paper);
}

.gallery-journal-heading {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(270px, .75fr);
  align-items: end;
  gap: 60px;
  margin-bottom: 52px;
  padding-bottom: 31px;
  border-bottom: 1px solid rgba(5, 47, 54, .2);
}

.gallery-journal-heading .section-label {
  margin-bottom: 12px;
  color: var(--film-red);
}

.gallery-journal-heading h1 {
  max-width: 850px;
  margin: 0;
  color: var(--film-dark);
  font-size: clamp(44px, 4.6vw, 68px);
  line-height: .92;
}

.gallery-journal-heading > p {
  max-width: 410px;
  margin: 0 0 2px;
  color: #617174;
  font-size: 13px;
  line-height: 1.7;
}

.gallery-journal-list {
  display: grid;
  gap: 26px;
}

.gallery-journal-entry {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(330px, .65fr);
  min-height: 500px;
  height: 520px;
  overflow: hidden;
  color: var(--film-dark);
  background: #fff;
}

.gallery-journal-entry:nth-child(even) {
  grid-template-columns: minmax(330px, .65fr) minmax(0, 1.35fr);
}

.gallery-journal-entry:nth-child(even) figure {
  order: 2;
}

.gallery-journal-entry figure {
  min-width: 0;
  margin: 0;
  overflow: hidden;
  background: var(--film-teal);
}

.gallery-journal-entry figure img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
  transition: transform .55s ease;
}

.gallery-journal-entry:hover figure img {
  transform: scale(1.025);
}

.gallery-journal-copy {
  display: flex;
  justify-content: center;
  flex-direction: column;
  min-width: 0;
  padding: clamp(38px, 5vw, 72px);
  border-top: 7px solid var(--film-teal);
  transition: color .25s ease, background .25s ease;
}

.gallery-journal-entry:nth-child(even) .gallery-journal-copy {
  border-top-color: var(--film-red);
}

.gallery-journal-entry:hover .gallery-journal-copy {
  color: #fff;
  background: var(--film-dark);
}

.gallery-journal-meta {
  display: flex;
  align-items: center;
  gap: 13px;
  margin-bottom: 35px;
}

.gallery-journal-meta span {
  color: var(--film-red);
  font-family: "Barlow Condensed", sans-serif;
  font-size: 28px;
  font-weight: 700;
}

.gallery-journal-meta small {
  color: #778588;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.gallery-journal-entry h2 {
  max-width: 430px;
  margin: 0;
  color: var(--film-dark);
  font-size: clamp(43px, 4vw, 62px);
  line-height: .9;
  text-transform: uppercase;
}

.gallery-journal-entry:hover h2 {
  color: #fff;
}

.gallery-journal-copy > p {
  max-width: 410px;
  margin: 20px 0 38px;
  color: #677578;
  font-size: 12px;
  line-height: 1.65;
}

.gallery-journal-entry:hover .gallery-journal-copy > p,
.gallery-journal-entry:hover .gallery-journal-meta small {
  color: #bfd0d2;
}

.gallery-journal-action {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding-top: 15px;
  border-top: 1px solid rgba(5, 47, 54, .2);
  color: var(--film-dark);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.gallery-journal-action strong {
  color: var(--film-red);
}

.gallery-journal-entry:hover .gallery-journal-action {
  color: #fff;
  border-top-color: rgba(255, 255, 255, .2);
}

.gallery-journal-entry:hover .gallery-journal-action strong {
  color: var(--film-teal);
}

/* Image-led gallery wall */
.option-two .gallery-wall {
  padding: 72px max(18px, calc((100vw - 1380px) / 2)) 110px;
  background: #fff;
}

.gallery-wall-heading {
  width: min(1320px, 100%);
  margin: 0 auto 34px;
  padding-bottom: 25px;
  border-bottom: 1px solid rgba(5, 47, 54, .2);
}

.gallery-wall-heading .section-label {
  margin-bottom: 10px;
  color: var(--film-red);
}

.gallery-wall-heading h1 {
  margin: 0;
  color: var(--film-dark);
  font-size: clamp(44px, 4.6vw, 68px);
  line-height: .92;
}

.gallery-wall-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-template-rows: 340px 210px 340px;
  gap: 10px;
  width: min(1380px, 100%);
  margin: 0 auto;
  padding: 10px;
  background: var(--film-dark);
}

.gallery-wall-item {
  position: relative;
  display: block;
  min-width: 0;
  overflow: hidden;
  color: #fff;
  background: var(--film-teal);
  isolation: isolate;
}

.gallery-wall-item-1 {
  grid-column: 1 / 9;
  grid-row: 1 / 3;
}

.gallery-wall-item-2 {
  grid-column: 9 / 13;
  grid-row: 1 / 3;
}

.gallery-wall-item-3 {
  grid-column: 1 / 7;
  grid-row: 3;
}

.gallery-wall-item-4 {
  grid-column: 7 / 13;
  grid-row: 3;
}

.gallery-wall-item img,
.gallery-wall-shade {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.gallery-wall-item img {
  z-index: -2;
  object-fit: cover;
  transition: transform .55s ease, filter .4s ease;
}

.gallery-wall-item-2 img {
  object-position: center 38%;
}

.gallery-wall-item-4 img {
  object-position: center 34%;
}

.gallery-wall-shade {
  z-index: -1;
  background: linear-gradient(0deg, rgba(3, 29, 34, .92) 0%, rgba(3, 29, 34, .08) 65%, transparent 100%);
  transition: background .3s ease;
}

.gallery-wall-copy {
  position: absolute;
  right: 25px;
  bottom: 24px;
  left: 25px;
}

.gallery-wall-copy small {
  display: block;
  margin-bottom: 8px;
  color: var(--film-teal);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
}

.gallery-wall-copy h2 {
  max-width: 620px;
  margin: 0;
  color: #fff;
  font-size: clamp(34px, 3.7vw, 56px);
  line-height: .9;
  text-transform: uppercase;
}

.gallery-wall-item-2 .gallery-wall-copy h2 {
  font-size: clamp(32px, 3vw, 45px);
}

.gallery-wall-copy strong {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin-top: 15px;
  padding-bottom: 4px;
  border-bottom: 2px solid var(--film-red);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.gallery-wall-copy strong span {
  transition: transform .2s ease;
}

.gallery-wall-item:hover img {
  transform: scale(1.035);
  filter: saturate(1.08);
}

.gallery-wall-item:hover .gallery-wall-shade {
  background: linear-gradient(0deg, rgba(3, 29, 34, .96) 0%, rgba(3, 29, 34, .2) 74%, transparent 100%);
}

.gallery-wall-item:hover .gallery-wall-copy strong span {
  transform: translateX(5px);
}

/* Gallery story view */
.option-two .gallery-detail-heading {
  padding: 64px max(24px, calc((100vw - 1320px) / 2)) 68px;
  color: #fff;
  background: var(--film-dark);
  border-bottom: 8px solid var(--film-teal);
}

.option-two .gallery-detail-heading > a {
  margin-bottom: 45px;
  color: var(--film-teal);
  font-family: "DM Sans", sans-serif;
  font-size: 10px;
}

.option-two .gallery-detail-heading .section-label {
  color: var(--film-red);
}

.option-two .gallery-detail-heading h1 {
  max-width: 950px;
  color: #fff !important;
  font-size: clamp(46px, 5vw, 72px);
  line-height: .92;
}

.option-two .gallery-detail-heading > p:last-child {
  color: #c1d2d4;
  font-size: 12px;
}

.option-two .gallery-photo-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-auto-rows: 170px;
  gap: 10px;
  padding: 50px max(24px, calc((100vw - 1320px) / 2)) 110px;
  background: var(--film-paper);
}

.option-two .gallery-photo {
  height: auto;
  min-height: 0;
}

.option-two .gallery-photo:nth-child(7n + 1),
.option-two .gallery-photo:nth-child(7n + 5) {
  grid-column: span 2;
  grid-row: span 2;
}

.option-two .gallery-photo:nth-child(7n + 3),
.option-two .gallery-photo:nth-child(7n + 6) {
  grid-row: span 2;
}

.option-two .gallery-photo span {
  border-radius: 0;
  background: var(--film-red);
}

/* Guided catering enquiry */
.option-two .catering-planner {
  display: grid;
  grid-template-columns: minmax(330px, .78fr) minmax(0, 1.22fr);
  width: min(1320px, calc(100% - 48px));
  margin: 110px auto 125px;
  background: #fff;
  box-shadow: 0 22px 55px rgba(5, 47, 54, .1);
}

.catering-planner-intro {
  padding: 58px 48px;
  color: #fff;
  background: var(--film-dark);
  border-top: 7px solid var(--film-red);
}

.catering-planner-intro .section-label {
  margin-bottom: 14px;
  color: var(--film-teal);
}

.catering-planner-intro h2 {
  margin: 0 0 20px;
  color: #fff !important;
  font-size: clamp(48px, 5vw, 72px);
  line-height: .9;
}

.catering-planner-intro > p:not(.section-label) {
  max-width: 420px;
  margin: 0;
  color: #c5d5d7;
  font-size: 12px;
  line-height: 1.7;
}

.catering-planner-steps {
  display: grid;
  gap: 0;
  margin: 38px 0 35px;
  padding: 0;
  list-style: none;
}

.catering-planner-steps li {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 2px 12px;
  padding: 15px 0;
  border-top: 1px solid rgba(255, 255, 255, .18);
}

.catering-planner-steps li:last-child {
  border-bottom: 1px solid rgba(255, 255, 255, .18);
}

.catering-planner-steps span {
  grid-row: 1 / 3;
  color: var(--film-red);
  font-family: "Barlow Condensed", sans-serif;
  font-size: 20px;
  font-weight: 700;
}

.catering-planner-steps strong {
  color: #fff;
  font-size: 13px;
  text-transform: uppercase;
}

.catering-planner-steps small {
  color: #9eb7ba;
  font-size: 12px;
}

.option-two .contact-details-panel h2 {
  color: #fff !important;
}

/* Shared header sizing refinements */
.option-two .site-header {
  grid-template-columns: 202px minmax(0, 1fr) auto;
}

.option-two .brand {
  width: 190px;
}

.option-two .brand img {
  width: 165px;
  height: 86px;
}

.option-two .nav {
  font-size: 13px;
}

.catering-planner-intro .catering-contact-note {
  border-top-color: rgba(255, 255, 255, .18);
}

.catering-planner-intro .catering-contact-note span {
  color: var(--film-teal);
}

.catering-planner-intro .catering-contact-note a {
  color: #fff;
  font-size: 25px;
}

.catering-planner-form-wrap {
  padding: 58px clamp(32px, 5vw, 70px) 65px;
}

.catering-planner-form-heading {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 4px 25px;
  margin-bottom: 30px;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(5, 47, 54, .18);
}

.catering-planner-form-heading p {
  grid-column: 1 / -1;
  margin: 0;
  color: var(--film-red);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.catering-planner-form-heading h3 {
  margin: 0;
  color: var(--film-dark);
  font-size: 35px;
  line-height: 1;
}

.catering-planner-form-heading span {
  color: #788588;
  font-size: 10px;
}

.option-two .catering-planner-form {
  gap: 21px 18px;
  padding: 0;
  background: transparent;
  box-shadow: none;
}

.option-two .catering-planner-form input,
.option-two .catering-planner-form select,
.option-two .catering-planner-form textarea {
  background: var(--film-paper);
  border: 1px solid #d6dddd;
}

.option-two .catering-planner-form .btn {
  min-height: 54px;
  padding-right: 28px;
  padding-left: 28px;
}

@media (max-width: 1050px) {
  .popular-menu-board {
    grid-template-columns: 1fr;
  }

  .popular-menu-item,
  .popular-menu-item:last-child {
    border-right: 0;
    border-bottom: 1px solid rgba(5, 47, 54, .18);
  }

  .location-directory-row {
    grid-template-columns: minmax(220px, .8fr) minmax(300px, 1.2fr);
  }

  .location-directory-actions {
    grid-column: 1 / -1;
    grid-template-columns: repeat(2, minmax(0, 150px));
  }

  .option-two .catering-planner {
    grid-template-columns: minmax(300px, .72fr) minmax(0, 1.28fr);
  }

  .gallery-journal-entry,
  .gallery-journal-entry:nth-child(even) {
    grid-template-columns: minmax(0, 1.1fr) minmax(310px, .9fr);
  }

  .option-two .gallery-photo-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .gallery-wall-grid {
    grid-template-rows: 310px 190px 300px;
  }
}

@media (max-width: 760px) {
  .option-two .site-header {
    grid-template-columns: 155px 1fr;
  }

  .option-two .brand {
    width: 146px;
  }

  .option-two .brand img {
    width: 131px;
    height: 73px;
  }

  .page-home .popular-heading {
    display: block;
    padding-bottom: 24px;
  }

  .page-home .popular-menu-link {
    margin-top: 20px;
  }

  .popular-menu-board {
    display: flex;
    width: calc(100vw - 16px);
    margin-right: -8px;
    margin-left: -8px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
  }

  .popular-menu-item,
  .popular-menu-item:last-child {
    flex: 0 0 min(84vw, 330px);
    border-right: 1px solid rgba(5, 47, 54, .18);
    border-bottom: 0;
    scroll-snap-align: start;
  }

  .popular-menu-image {
    aspect-ratio: 1 / .9;
  }

  .popular-menu-copy {
    min-height: 250px;
    padding: 23px 20px 24px;
  }

  .popular-menu-title strong {
    font-size: 31px;
  }

  .option-two .location-directory {
    padding: 45px 16px 80px;
  }

  .location-directory-heading {
    display: block;
    margin-bottom: 26px;
    padding-bottom: 24px;
  }

  .location-directory-heading h1 {
    font-size: 31px;
    white-space: nowrap;
  }

  .location-directory-heading > p {
    margin-top: 16px;
    font-size: 11px;
  }

  .location-directory-row {
    display: block;
    min-height: 0;
    padding: 25px 20px;
  }

  .location-directory-row:hover {
    transform: none;
  }

  .location-directory-address {
    margin: 18px 0 20px;
  }

  .location-directory-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .option-two .location-detail-heading {
    width: calc(100% - 32px);
    padding: 42px 0 46px;
  }

  .option-two .location-detail-heading .location-back-link {
    margin-bottom: 34px;
    font-size: 10px;
  }

  .option-two .location-detail-heading h1 {
    font-size: clamp(39px, 12vw, 52px);
  }

  .option-two .location-detail-hero h1 + p {
    margin-top: 13px;
    font-size: 12px;
  }

  .option-two .location-detail-hero::after {
    right: 16px;
    width: 110px;
  }

  .option-two .location-visit-grid .location-detail-info {
    padding: 50px 20px 58px;
  }

  .option-two .gallery-journal {
    padding: 45px 16px 80px;
  }

  .gallery-journal-heading {
    display: block;
    margin-bottom: 28px;
    padding-bottom: 24px;
  }

  .gallery-journal-heading h1 {
    font-size: 39px;
  }

  .gallery-journal-heading > p {
    margin-top: 15px;
    font-size: 11px;
  }

  .gallery-journal-list {
    gap: 16px;
  }

  .gallery-journal-entry,
  .gallery-journal-entry:nth-child(even) {
    display: flex;
    min-height: 0;
    height: auto;
    flex-direction: column;
  }

  .gallery-journal-entry:nth-child(even) figure {
    order: 0;
  }

  .gallery-journal-entry figure img {
    min-height: 0;
    aspect-ratio: 1.15 / 1;
  }

  .gallery-journal-copy {
    padding: 28px 22px 30px;
  }

  .gallery-journal-meta {
    margin-bottom: 22px;
  }

  .gallery-journal-entry h2 {
    font-size: 39px;
  }

  .gallery-journal-copy > p {
    margin: 15px 0 25px;
  }

  .option-two .gallery-detail-heading {
    padding: 42px 16px 46px;
  }

  .option-two .gallery-detail-heading > a {
    margin-bottom: 32px;
  }

  .option-two .gallery-detail-heading h1 {
    font-size: 42px;
  }

  .option-two .gallery-photo-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-auto-rows: 145px;
    gap: 7px;
    padding: 20px 7px 70px;
  }

  .option-two .gallery-photo:nth-child(7n + 1),
  .option-two .gallery-photo:nth-child(7n + 5) {
    grid-column: span 2;
  }

  .option-two .gallery-wall {
    padding: 43px 8px 75px;
  }

  .gallery-wall-heading {
    width: calc(100% - 16px);
    margin-bottom: 23px;
  }

  .gallery-wall-heading h1 {
    font-size: 39px;
  }

  .gallery-wall-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: 310px 230px 230px;
    gap: 6px;
    padding: 6px;
  }

  .gallery-wall-item-1 {
    grid-column: 1 / 3;
    grid-row: 1;
  }

  .gallery-wall-item-2 {
    grid-column: 1;
    grid-row: 2 / 4;
  }

  .gallery-wall-item-3 {
    grid-column: 2;
    grid-row: 2;
  }

  .gallery-wall-item-4 {
    grid-column: 2;
    grid-row: 3;
  }

  .gallery-wall-copy {
    right: 14px;
    bottom: 14px;
    left: 14px;
  }

  .gallery-wall-copy small {
    font-size: 7px;
  }

  .gallery-wall-copy h2,
  .gallery-wall-item-2 .gallery-wall-copy h2 {
    font-size: 26px;
  }

  .gallery-wall-item-3 .gallery-wall-copy h2,
  .gallery-wall-item-4 .gallery-wall-copy h2 {
    font-size: 22px;
  }

  .gallery-wall-copy strong {
    margin-top: 10px;
    font-size: 7px;
  }

  .option-two .catering-planner {
    display: block;
    width: calc(100% - 32px);
    margin: 65px auto 80px;
  }

  .catering-planner-intro,
  .catering-planner-form-wrap {
    padding: 42px 22px 46px;
  }

  .catering-planner-form-heading {
    display: block;
  }

  .catering-planner-form-heading h3 {
    margin: 5px 0 8px;
    font-size: 30px;
  }

  .option-two .catering-planner-form {
    grid-template-columns: 1fr;
  }

  .option-two .catering-planner-form .form-field,
  .option-two .catering-planner-form .form-field-wide,
  .option-two .catering-planner-form .form-success {
    grid-column: 1;
  }
}

@media (max-width: 820px) {
  .option-two .site-header {
    grid-template-columns: 155px 1fr;
  }

  .option-two .brand {
    width: 146px;
  }

  .option-two .brand img {
    width: 131px;
    height: 73px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .flavour-ribbon-track {
    animation: none;
  }
}
