.event-page-body {
  margin: 0;
  background: #e6dcd0;
}

.canvas.canvas--event {
  height: auto;
  min-height: 7492px;
  background: #e6dcd0;
  overflow: visible;
}

.event-frame {
  position: relative;
  width: 1728px;
  height: 7492px;
  margin: 0 auto;
  overflow: hidden;
  background: #e6dcd0;
}

.event-lower {
  position: absolute;
  left: -1px;
  top: 6710px;
  width: 1729px;
  height: 782px;
  margin: 0;
  z-index: 20;
}

.event-strapline {
  position: absolute;
  left: 0;
  top: 1922px;
  width: 1727px;
  margin: 0;
  z-index: 12;
}

.event-lower .footer {
  position: absolute;
  left: 0;
  top: 0;
  width: 1729px;
  height: 782px;
}

.canvas--event .copyright {
  top: 649px;
}

.canvas--event .nav-links a.nav-page-link {
  display: block;
}

.canvas--event .nav-links li.nav-item--link {
  cursor: default;
}

.canvas--event .nav-links li.nav-item--link:hover {
  transform: none;
}

.canvas--event .nav-links li.nav-item--link a:hover {
  color: #af8b72;
  transform: translateY(-1px);
}

.canvas--event .nav-links li.active .nav-page-link {
  color: #af8b72;
}

.ev-bg-top,
.ev-bg-mid,
.ev-bg-bottom {
  position: absolute;
  left: 0;
}

.ev-bg-top {
  top: 0;
  width: 1728px;
  height: 2176px;
  background: linear-gradient(180deg, #af8b72 0%, #e6dcd0 71%);
}

.ev-bg-mid {
  top: 1949px;
  width: 1728px;
  height: 1840px;
  background: #af8b72;
}

.ev-bg-bottom {
  left: -1px;
  top: 4486px;
  width: 1729px;
  height: 2628px;
  background: linear-gradient(180deg, #e6dcd0 0%, #af8b72 100%);
}

.ev-word {
  position: absolute;
  margin: 0;
  font: 700 100px/1.24 "Libre Baskerville", serif;
  color: #fefcf8;
  z-index: 3;
}

.ev-hero-figma {
  position: absolute;
  left: 0;
  top: 0;
  width: 1728px;
  height: 360px;
  z-index: 3;
  pointer-events: none;
  transform: scale(0.6888);
  transform-origin: top center;
}

.ev-title-lines {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}

.ev-title-line {
  position: absolute;
  height: 2px;
  background: repeating-linear-gradient(to right, #fff 0 30px, transparent 30px 60px);
}

.ev-title-line--1 { left: -390px; top: 295px; width: 931px; }
.ev-title-line--2 { left: 1369px; top: 295px; width: 749px; }
.ev-title-line--3 { left: 1208px; top: 240px; width: 910px; }
.ev-title-line--4 { left: -390px; top: 240px; width: 749px; }
.ev-title-line--5 { left: 504px; top: 240px; width: 195px; }
.ev-title-line--6 { left: 854px; top: 240px; width: 195px; }
.ev-title-line--7 { left: 1031px; top: 295px; width: 195px; }
.ev-title-line--8 { left: 679px; top: 295px; width: 200px; }

.ev-word-e1 { left: 387px; top: 183px; }
.ev-word-v { left: 559px; top: 249px; }
.ev-word-e2 { left: 732px; top: 191px; }
.ev-word-n { left: 906px; top: 249px; }
.ev-word-t { left: 1083px; top: 191px; }
.ev-word-s { left: 1268px; top: 249px; }

.ev-title-1,
.ev-title-2,
.ev-title-3 {
  position: absolute;
  margin: 0;
  color: #754636;
  z-index: 4;
}

.ev-title-1 {
  left: 665px;
  top: 464px;
  font: 500 50px/0.92 "League Spartan", sans-serif;
}

.ev-title-2 {
  left: 773px;
  top: 523px;
  font: 400 84px/0.88 "Libre Baskerville", serif;
  font-style: italic;
}

.ev-title-3 {
  left: 888px;
  top: 625px;
  font: 500 50px/0.92 "League Spartan", sans-serif;
}

.ev-copy {
  position: absolute;
  margin: 0;
  font: 400 17px/1.24 "Libre Baskerville", serif;
  color: #000;
  z-index: 4;
}

.ev-copy-right {
  left: 817px;
  top: 733px;
  width: 490px;
  text-align: left;
}

.ev-copy-left {
  left: 461px;
  top: 1259px;
  width: 350px;
  text-align: right;
}

.ev-photo {
  position: absolute;
  object-fit: cover;
  border-radius: 20px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25);
  z-index: 4;
}

.ev-photo-4170-573 {
  left: 268px;
  top: 476px;
  width: 511px;
  height: 562px;
  border-radius: 255px 255px 0 0;
}

.ev-photo-4170-576 {
  left: 849px;
  top: 1076px;
  width: 473px;
  height: 631px;
  border-radius: 20px;
}

.ev-book-btn {
  position: absolute;
  left: 492px;
  top: 1450px;
  z-index: 5;
}

.ev-section-title {
  position: absolute;
  width: 1088px;
  margin: 0;
  text-align: center;
  font: 700 50px/1.24 "Libre Baskerville", serif;
  z-index: 4;
}

.ev-interior-title {
  left: 320px;
  top: 2050px;
  color: #eee7dd;
}

.ev-past-title {
  left: 320px;
  top: 3927px;
  color: #754636;
}

.ev-heading-line {
  position: absolute;
  height: 2px;
  background: repeating-linear-gradient(to right, currentColor 0 30px, transparent 30px 60px);
  z-index: 4;
}

.ev-heading-line--interior-left {
  left: 155px;
  top: 2090px;
  width: 535px;
  color: #fff;
}

.ev-heading-line--interior-right {
  left: 1040px;
  top: 2090px;
  width: 533px;
  color: #fff;
}

.ev-heading-line--past-left {
  left: 175px;
  top: 3967px;
  width: 525px;
  color: #754636;
}

.ev-heading-line--past-right {
  left: 1030px;
  top: 3967px;
  width: 543px;
  color: #754636;
}

.ev-card {
  position: absolute;
  margin-left: 46px;
  border-radius: 20px;
  box-shadow: 0 8px 13.8px 3px rgba(0, 0, 0, 0.25);
  object-fit: cover;
  z-index: 4;
  opacity: 0;
  transform: translateY(22px) scale(0.985);
  transition:
    opacity 0.65s cubic-bezier(0.22, 1, 0.36, 1) var(--pin-delay, 0ms),
    transform 0.65s cubic-bezier(0.22, 1, 0.36, 1) var(--pin-delay, 0ms),
    box-shadow 0.38s cubic-bezier(0.22, 1, 0.36, 1) 0ms,
    filter 0.38s cubic-bezier(0.22, 1, 0.36, 1) 0ms;
  will-change: transform, opacity, box-shadow, filter;
  backface-visibility: hidden;
  transform-style: preserve-3d;
}

.ev-card.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  transition-delay: 0ms, 0ms, 0ms, 0ms;
}

.ev-card:hover {
  transform: translateY(-5px) scale(1.008);
  box-shadow: 0 16px 30px rgba(0, 0, 0, 0.2), 0 0 0 3px rgba(117, 70, 54, 0.24);
  filter: saturate(1.04) sepia(0.12) brightness(0.985);
}

@keyframes evHeroFadeUp {
  from {
    opacity: 0;
    transform: translateY(18px);
    filter: blur(3px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
}

@keyframes evHeroFadeOnly {
  from {
    opacity: 0;
    filter: blur(2px);
  }
  to {
    opacity: 1;
    filter: blur(0);
  }
}

@keyframes evHeroLineSweep {
  from {
    opacity: 0;
    transform: scaleX(0.88);
    filter: blur(2px);
  }
  to {
    opacity: 1;
    transform: scaleX(1);
    filter: blur(0);
  }
}

.ev-hero-fx-lines .ev-title-line {
  opacity: 0;
  transform-origin: center;
  animation: none;
}

.ev-hero-fx-word {
  opacity: 0;
  animation: none;
}

.ev-hero-fx-copy {
  opacity: 0;
  animation: none;
}

.canvas--event.is-hero-animated .ev-hero-fx-lines .ev-title-line {
  animation: evHeroLineSweep 900ms cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.canvas--event.is-hero-animated .ev-hero-fx-lines .ev-title-line:nth-child(1) { animation-delay: 60ms; }
.canvas--event.is-hero-animated .ev-hero-fx-lines .ev-title-line:nth-child(2) { animation-delay: 120ms; }
.canvas--event.is-hero-animated .ev-hero-fx-lines .ev-title-line:nth-child(3) { animation-delay: 180ms; }
.canvas--event.is-hero-animated .ev-hero-fx-lines .ev-title-line:nth-child(4) { animation-delay: 240ms; }
.canvas--event.is-hero-animated .ev-hero-fx-lines .ev-title-line:nth-child(5) { animation-delay: 300ms; }
.canvas--event.is-hero-animated .ev-hero-fx-lines .ev-title-line:nth-child(6) { animation-delay: 360ms; }
.canvas--event.is-hero-animated .ev-hero-fx-lines .ev-title-line:nth-child(7) { animation-delay: 420ms; }
.canvas--event.is-hero-animated .ev-hero-fx-lines .ev-title-line:nth-child(8) { animation-delay: 480ms; }

.canvas--event.is-hero-animated .ev-hero-fx-word {
  animation: evHeroFadeUp 760ms cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.canvas--event.is-hero-animated .ev-word-e1.ev-hero-fx-word { animation-delay: 260ms; }
.canvas--event.is-hero-animated .ev-word-v.ev-hero-fx-word { animation-delay: 340ms; }
.canvas--event.is-hero-animated .ev-word-e2.ev-hero-fx-word { animation-delay: 420ms; }
.canvas--event.is-hero-animated .ev-word-n.ev-hero-fx-word { animation-delay: 500ms; }
.canvas--event.is-hero-animated .ev-word-t.ev-hero-fx-word { animation-delay: 580ms; }
.canvas--event.is-hero-animated .ev-word-s.ev-hero-fx-word { animation-delay: 660ms; }

.canvas--event.is-hero-animated .ev-hero-fx-copy {
  animation: evHeroFadeUp 860ms cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.canvas--event.is-hero-animated .ev-title-1.ev-hero-fx-copy { animation-delay: 520ms; }
.canvas--event.is-hero-animated .ev-title-2.ev-hero-fx-copy { animation-delay: 620ms; }
.canvas--event.is-hero-animated .ev-title-3.ev-hero-fx-copy { animation-delay: 720ms; }
.canvas--event.is-hero-animated .ev-copy-right.ev-hero-fx-copy { animation-delay: 850ms; }
.canvas--event.is-hero-animated .ev-copy-left.ev-hero-fx-copy { animation-delay: 950ms; }
.canvas--event.is-hero-animated .ev-book-btn.ev-hero-fx-copy { animation-delay: 1050ms; }

.canvas--event.is-hero-animated .ev-book-btn.ev-hero-fx-copy {
  animation: evHeroFadeOnly 860ms cubic-bezier(0.22, 1, 0.36, 1) forwards;
  animation-delay: 1050ms;
}

.event-strapline.reveal {
  transform: translateY(18px);
  transition:
    opacity 0.9s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
}

.event-strapline.reveal.is-revealed {
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  .ev-hero-fx-lines .ev-title-line,
  .ev-hero-fx-word,
  .ev-hero-fx-copy {
    opacity: 1;
    animation: none;
    transform: none;
    filter: none;
  }

  .ev-card,
  .ev-card:hover {
    opacity: 1;
    transform: none;
    transition: none;
    filter: none;
  }
}

.c-2120-975 { left: 275px; top: 2229px; width: 347px; height: 394px; }
.c-2120-977 { left: 1007px; top: 2229px; width: 346px; height: 399px; }
.c-2120-979 { left: 657px; top: 2544px; width: 314px; height: 449px; }
.c-2120-978 { left: 275px; top: 2657px; width: 347px; height: 434px; }
.c-2120-976 { left: 1008px; top: 3011px; width: 345px; height: 486px; }
.c-2120-983 { left: 1008px; top: 2660px; width: 345px; height: 313px; }
.c-2120-981 { left: 275px; top: 3122px; width: 347px; height: 336px; }
.c-2120-982 { left: 658px; top: 3026px; width: 311px; height: 260px; }
.c-2120-980 { left: 657px; top: 2229px; width: 314px; height: 283px; }

.c-4183-38 { left: 270px; top: 4106px; width: 332px; height: 283px; }
.c-4183-33 { left: 637px; top: 4106px; width: 347px; height: 394px; }
.c-4183-35 { left: 1020px; top: 4106px; width: 346px; height: 470px; }
.c-4183-36 { left: 270px; top: 4421px; width: 332px; height: 379px; }
.c-4183-39 { left: 270px; top: 4832px; width: 332px; height: 370px; }
.c-4183-42 { left: 270px; top: 5236px; width: 332px; height: 419px; }
.c-4183-46 { left: 270px; top: 5677px; width: 332px; height: 445px; }
.c-4183-37 { left: 638px; top: 4532px; width: 347px; height: 449px; }
.c-4183-40 { left: 638px; top: 5012px; width: 347px; height: 341px; }
.c-4183-44 { left: 638px; top: 5385px; width: 347px; height: 449px; }
.c-4183-47 { left: 638px; top: 5866px; width: 347px; height: 449px; }
.c-4183-34 { left: 1021px; top: 4611px; width: 345px; height: 348px; }
.c-4183-41 { left: 1021px; top: 4994px; width: 345px; height: 416px; }
.c-4183-45 { left: 1021px; top: 5445px; width: 345px; height: 416px; }
.c-4183-49 { left: 1021px; top: 5896px; width: 345px; height: 348px; }

.ev-gallery {
  display: contents;
}

.ev-image-modal {
  display: none;
}

@media (max-width: 900px) {
  html,
  body {
    width: 100%;
    max-width: 430px;
    margin: 0 auto;
    overflow-x: hidden;
    background: #e6dcd0;
  }

  .event-page-body {
    overflow-x: hidden;
    background: #e6dcd0;
  }

  .canvas.canvas--event {
    width: 100%;
    max-width: 430px;
    min-height: auto;
    height: auto;
    overflow: hidden;
    background: #e6dcd0;
  }

  .event-frame {
    position: relative;
    width: 100%;
    max-width: 430px;
    height: 2820px;
    margin: 0 auto;
    overflow: hidden;
    background: #e6dcd0;
  }

  .ev-bg-top {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 1380px;
    background: linear-gradient(
      180deg,
      #af8b72 0%,
      #b99680 35%,
      #d5c1ae 68%,
      #e6dcd0 100%
    );
  }

  .ev-bg-mid {
    position: absolute;
    left: 0;
    top: 1420px;
    width: 100%;
    height: 660px;
    background: #af8b72;
  }

  .ev-bg-bottom {
    position: absolute;
    left: 0;
    top: 2080px;
    width: 100%;
    height: 740px;
    background: linear-gradient(180deg, #e6dcd0 0%, #af8b72 100%);
  }

  .ev-hero-figma {
    position: absolute;
    left: 0;
    top: 78px;
    width: 430px;
    height: 130px;
    transform: none;
    pointer-events: none;
    z-index: 3;
  }

  .ev-title-line {
    position: absolute;
    height: 1.5px;
    background: repeating-linear-gradient(
      to right,
      rgba(255, 255, 255, 0.85) 0 16px,
      transparent 16px 31px
    );
  }

  .ev-title-line--1 {
    left: 0;
    top: 52px;
    width: 74px;
  }

  .ev-title-line--2 {
    left: 346px;
    top: 52px;
    width: 75px;
  }

  .ev-title-line--3 {
    left: 324px;
    top: 94px;
    width: 95px;
  }

  .ev-title-line--4 {
    left: 60px;
    top: 94px;
    width: 45px;
  }

  .ev-title-line--5 {
    left: 113px;
    top: 52px;
    width: 55px;
  }

  .ev-title-line--6 {
    left: 204px;
    top: 52px;
    width: 55px;
  }

  .ev-title-line--7 {
    left: 283px;
    top: 52px;
    width: 42px;
  }

  .ev-title-line--8 {
    left: 146px;
    top: 94px;
    width: 52px;
  }

  .ev-word {
    position: absolute;
    margin: 0;
    font: 700 42px/1 "Libre Baskerville", serif;
    color: #fefcf8;
    z-index: 4;
  }

  .ev-word-e1 {
    left: 64px;
    top: 27px;
  }

  .ev-word-v {
    left: 123px;
    top: 70px;
  }

  .ev-word-e2 {
    left: 178px;
    top: 27px;
  }

  .ev-word-n {
    left: 233px;
    top: 70px;
  }

  .ev-word-t {
    left: 288px;
    top: 27px;
  }

  .ev-word-s {
    left: 333px;
    top: 70px;
  }

  .ev-photo {
    object-fit: cover;
  }

  .ev-photo-4170-573 {
    position: absolute;
    left: 68px;
    top: 238px;
    width: 294px;
    height: 320px;
    border-radius: 150px 150px 0 0;
    object-position: center;
    box-shadow: 0 5px 18px rgba(0, 0, 0, 0.22);
    z-index: 4;
  }

  .ev-title-1,
  .ev-title-2,
  .ev-title-3 {
    position: absolute;
    left: 0;
    width: 100%;
    margin: 0;
    color: #754636;
    text-align: center;
    z-index: 5;
  }

  .ev-title-1 {
    top: 586px;
    font: 500 42px/0.92 "League Spartan", sans-serif;
  }

  .ev-title-2 {
    top: 628px;
    font: italic 400 45px/1 "Libre Baskerville", serif;
  }

  .ev-title-3 {
    top: 687px;
    font: 500 42px/0.92 "League Spartan", sans-serif;
  }

  .ev-copy {
    position: absolute;
    margin: 0;
    color: #000;
    font: 400 15.5px/1.04 "Libre Baskerville", serif;
    z-index: 5;
  }

  .ev-copy-right {
    left: 86px;
    top: 772px;
    width: 258px;
    text-align: center;
  }

  .ev-copy-left {
    left: 60px;
    top: 1055px;
    width: 205px;
    text-align: center;
  }

  .ev-photo-4170-576 {
    position: absolute;
    left: 304px;
    top: 1038px;
    width: 170px;
    height: 270px;
    border-radius: 10px;
    object-position: center;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.18);
    z-index: 4;
  }

  .ev-book-btn {
    position: absolute;
    left: 35px;
    top: 1270px;
    width: 234px;
    height: 42px;
    padding: 0 17px;
    border: 1.4px solid #9b6048;
    border-radius: 999px;
    background: transparent;
    color: #b37d66;
    box-sizing: border-box;
    z-index: 6;
  }

  .ev-book-btn .btn-label {
    color: #b37d66;
    font-size: 15px;
    font-weight: 500;
  }

  .ev-book-btn .btn-arrow {
    width: 40px;
    margin-left: auto;
    opacity: 0.75;
  }

  .event-strapline {
    position: absolute;
    left: 0;
    top: 1370px;
    width: 100%;
    height: 52px;
    overflow: hidden;
    z-index: 12;
  }

  .ev-section-title {
    position: absolute;
    left: 0;
    width: 100%;
    margin: 0;
    text-align: center;
    font: 700 26px/1.2 "Libre Baskerville", serif;
    z-index: 4;
  }

  .ev-interior-title {
    top: 1500px;
    color: #eee7dd;
  }

  .ev-past-title {
    top: 2135px;
    color: #754636;
  }

  .ev-heading-line {
    position: absolute;
    height: 1.5px;
    background: repeating-linear-gradient(
      to right,
      currentColor 0 14px,
      transparent 14px 28px
    );
    z-index: 4;
  }

  .ev-heading-line--interior-left {
    left: 24px;
    top: 1516px;
    width: 92px;
    color: #fff;
  }

  .ev-heading-line--interior-right {
    right: 24px;
    left: auto;
    top: 1516px;
    width: 92px;
    color: #fff;
  }

  .ev-heading-line--past-left {
    left: 24px;
    top: 2151px;
    width: 90px;
    color: #754636;
  }

  .ev-heading-line--past-right {
    right: 24px;
    left: auto;
    top: 2151px;
    width: 90px;
    color: #754636;
  }

  .ev-gallery {
    position: absolute;
    left: 24px;
    width: calc(100% - 48px);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    z-index: 5;
  }

  .ev-gallery--interior,
  .ev-interior-gallery {
    top: 1570px;
  }

  .ev-gallery--past,
  .ev-past-gallery {
    top: 2205px;
  }

  .ev-card {
    position: static !important;
    width: 100% !important;
    height: 118px !important;
    margin: 0 !important;
    border-radius: 12px;
    object-fit: cover;
    object-position: center;
    box-shadow: 0 5px 10px rgba(0, 0, 0, 0.22);
    opacity: 1;
    transform: none;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
    cursor: pointer;
  }

  .ev-card:hover {
    transform: scale(1.02);
    box-shadow: 0 8px 14px rgba(0, 0, 0, 0.25);
  }

  .ev-card[class*="interior"],
  .ev-card[class*="past"] {
    position: static !important;
  }

  .ev-image-modal {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(0, 0, 0, 0.78);
    z-index: 10000;
  }

  .ev-image-modal.is-open {
    display: flex;
  }

  .ev-image-modal img,
  .ev-modal-img {
    max-width: 92vw;
    max-height: 78vh;
    border-radius: 14px;
    object-fit: contain;
  }

  .ev-modal-close {
    position: absolute;
    top: 22px;
    right: 24px;
    width: 38px;
    height: 38px;
    border: 0;
    border-radius: 50%;
    background: #fefcf8;
    color: #652c23;
    font-size: 25px;
    line-height: 38px;
    text-align: center;
    cursor: pointer;
  }

  .event-lower {
    position: absolute;
    left: 0;
    top: 2600px;
    width: 100%;
    height: auto;
    z-index: 20;
  }

  .event-lower .footer {
    position: relative;
    left: 0;
    top: 0;
    width: 100%;
    height: auto;
  }

  .canvas--event .quick-links,
  .canvas--event .back-to-top,
  .canvas--event .footer-back-top {
    display: none !important;
  }

  .canvas--event .footer,
  .canvas--event footer {
    text-align: center;
  }

  .canvas--event .footer-logo,
  .canvas--event .footer-brand,
  .canvas--event .footer-contact,
  .canvas--event .footer-social,
  .canvas--event .footer-address,
  .canvas--event .footer-hours,
  .canvas--event .contact-form {
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }

  .canvas--event .copyright {
    position: relative;
    top: auto;
    text-align: center;
  }
}

@media (max-width: 900px) {
  html,
  body.event-page-body {
    width: 100%;
    overflow-x: hidden;
    background: #e6dcd0;
  }

  body.event-page-body.event-modal-open {
    overflow: hidden;
  }

  body.event-page-body .canvas.canvas--event {
    width: 100%;
    min-height: 0 !important;
    background: #e6dcd0;
    overflow: hidden;
  }

  body.event-page-body .event-frame {
    position: relative;
    width: 100% !important;
    height: 2860px !important;
    margin: 0;
    overflow: hidden;
    background: #e6dcd0;
  }

  body.event-page-body .ev-bg-top {
    left: 0;
    top: 0;
    width: 100%;
    height: 1455px;
    background: linear-gradient(180deg, #af8b72 0%, #e6dcd0 74%);
  }

  body.event-page-body .ev-bg-mid {
    left: 0;
    top: 1422px;
    width: 100%;
    height: 670px;
    background: #af8b72;
  }

  body.event-page-body .ev-bg-bottom {
    left: 0;
    top: 2050px;
    width: 100%;
    height: 810px;
    background: linear-gradient(180deg, #e6dcd0 0%, #af8b72 100%);
  }

  body.event-page-body .ev-hero-figma {
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    top: 84px !important;
    width: 100% !important;
    max-width: 360px !important;
    height: 118px !important;
    min-height: 0 !important;
    margin: 0 auto !important;
    padding: 0 !important;
    overflow: visible !important;
    transform: translateX(12px) !important;
    transform-origin: top center !important;
    pointer-events: none !important;
    z-index: 3 !important;
  }

  body.event-page-body .ev-title-lines {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    transform: none !important;
  }

  body.event-page-body .ev-word {
    position: absolute !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    color: #fefcf8 !important;
    font: 700 36px/1 "Libre Baskerville", serif !important;
    opacity: 1 !important;
    animation: none !important;
    filter: none !important;
    transform: none !important;
    z-index: 4 !important;
  }

  body.event-page-body .ev-title-line {
    display: block !important;
    position: absolute !important;
    height: 1.5px !important;
    opacity: 1 !important;
    background: repeating-linear-gradient(to right, #fefcf8 0 14px, transparent 14px 28px) !important;
    transform: none !important;
    z-index: 2 !important;
  }

  body.event-page-body .ev-title-line--4 {
    left: -240px !important;
    top: 32px !important;
    width: 258px !important;
  }
  body.event-page-body .ev-title-line--5 {
    left: 52px !important;
    top: 32px !important;
    width: 74px !important;
  }
  body.event-page-body .ev-title-line--6 {
    left: 158px !important;
    top: 32px !important;
    width: 74px !important;
  }
  body.event-page-body .ev-title-line--3 {
    left: 266px !important;
    top: 32px !important;
    right: 0 !important;
    width: auto !important;
  }

  body.event-page-body .ev-title-line--1 {
    left: -240px !important;
    top: 74px !important;
    width: 310px !important;
  }
  body.event-page-body .ev-title-line--8 {
    left: 108px !important;
    top: 74px !important;
    width: 70px !important;
  }
  body.event-page-body .ev-title-line--7 {
    left: 216px !important;
    top: 74px !important;
    width: 70px !important;
  }
  body.event-page-body .ev-title-line--2 {
    left: 320px !important;
    top: 74px !important;
    right: 0 !important;
    width: auto !important;
  }

  body.event-page-body .ev-word-e1 {
    left: 22px !important;
    top: 14px !important;
  }
  body.event-page-body .ev-word-e2 {
    left: 130px !important;
    top: 14px !important;
  }
  body.event-page-body .ev-word-t {
    left: 238px !important;
    top: 14px !important;
  }

  body.event-page-body .ev-word-v {
    left: 76px !important;
    top: 56px !important;
  }
  body.event-page-body .ev-word-n {
    left: 184px !important;
    top: 56px !important;
  }
  body.event-page-body .ev-word-s {
    left: 292px !important;
    top: 56px !important;
  }

  body.event-page-body .ev-photo-4170-573 {
    left: 0 !important;
    right: 0 !important;
    top: 242px !important;
    width: 292px !important;
    height: 318px !important;
    margin: 0 auto !important;
    transform: none !important;
    border-radius: 146px 146px 0 0 !important;
  }

  body.event-page-body .ev-title-1,
  body.event-page-body .ev-title-2,
  body.event-page-body .ev-title-3 {
    position: absolute !important;
    width: auto !important;
    margin: 0 !important;
    color: #754636 !important;
    text-align: left !important;
  }

  body.event-page-body .ev-title-1 {
    left: 8% !important;
    top: 600px !important;
    font: 700 32px/1.05 "Libre Baskerville", serif !important;
  }

  body.event-page-body .ev-title-2 {
    left: 32% !important;
    top: 638px !important;
    font: italic 400 42px/1.05 "Libre Baskerville", serif !important;
  }

  body.event-page-body .ev-title-3 {
    left: 8% !important;
    top: 690px !important;
    font: 700 32px/1.05 "Libre Baskerville", serif !important;
  }

  body.event-page-body .ev-copy {
    font: 400 14.5px/1.12 "Libre Baskerville", serif !important;
    color: #000 !important;
  }

  body.event-page-body .ev-copy-right {
    left: 0 !important;
    right: 0 !important;
    top: 800px !important;
    width: auto !important;
    max-width: 250px !important;
    margin: 0 auto !important;
    padding: 0 16px !important;
    box-sizing: border-box !important;
    transform: none !important;
    text-align: center !important;
    font: 400 14.5px/1.18 "Libre Baskerville", serif !important;
  }

  body.event-page-body .ev-copy-left {
    left: 18% !important;
    right: auto !important;
    top: 1020px !important;
    width: 34% !important;
    transform: none !important;
    text-align: right !important;
    font: 400 13px/1.22 "Libre Baskerville", serif !important;
  }

  body.event-page-body .ev-photo-4170-576 {
    left: auto !important;
    right: -22% !important;
    top: 1010px !important;
    width: 60% !important;
    max-width: none !important;
    height: 310px !important;
    transform: none !important;
    border-radius: 14px 0 0 14px !important;
  }

  body.event-page-body .ev-book-btn {
    left: 5% !important;
    right: auto !important;
    top: 1260px !important;
    width: 188px !important;
    height: 44px !important;
    padding: 0 16px !important;
    margin: 0 !important;
    transform: none !important;
    box-sizing: border-box !important;
  }

  body.event-page-body .ev-book-btn .btn-label {
    font-size: 15px !important;
  }

  body.event-page-body .ev-book-btn .btn-arrow {
    right: 14px !important;
    width: 36px !important;
  }

  body.event-page-body .event-strapline {
    top: 1370px !important;
    height: 52px !important;
  }

  body.event-page-body .ev-section-title {
    left: 0 !important;
    width: 100% !important;
    font: 700 26px/1.2 "Libre Baskerville", serif !important;
    text-align: center !important;
  }

  body.event-page-body .ev-interior-title {
    top: 1496px !important;
    color: #eee7dd !important;
  }

  body.event-page-body .ev-past-title {
    top: 2114px !important;
    color: #754636 !important;
  }

  body.event-page-body .ev-heading-line {
    height: 1.5px !important;
    background: repeating-linear-gradient(to right, currentColor 0 14px, transparent 14px 28px) !important;
  }

  body.event-page-body .ev-heading-line--interior-left {
    left: 18px !important;
    top: 1512px !important;
    width: 88px !important;
    color: #fefcf8 !important;
  }

  body.event-page-body .ev-heading-line--interior-right {
    right: 18px !important;
    left: auto !important;
    top: 1512px !important;
    width: 88px !important;
    color: #fefcf8 !important;
  }

  body.event-page-body .ev-heading-line--past-left {
    left: 18px !important;
    top: 2130px !important;
    width: 92px !important;
    color: #754636 !important;
  }

  body.event-page-body .ev-heading-line--past-right {
    right: 18px !important;
    left: auto !important;
    top: 2130px !important;
    width: 92px !important;
    color: #754636 !important;
  }

  body.event-page-body .ev-gallery {
    position: absolute !important;
    left: 20px !important;
    width: calc(100% - 40px) !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 9px !important;
    z-index: 6 !important;
  }

  body.event-page-body .ev-gallery--interior {
    top: 1560px !important;
  }

  body.event-page-body .ev-gallery--past {
    top: 2176px !important;
  }

  body.event-page-body .ev-card {
    position: static !important;
    display: block !important;
    width: 100% !important;
    height: 112px !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 12px !important;
    object-fit: cover !important;
    object-position: center !important;
    box-shadow: 0 5px 12px rgba(0, 0, 0, 0.22) !important;
    cursor: pointer;
    opacity: 1 !important;
    transform: none !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
  }

  body.event-page-body .ev-card:active {
    transform: scale(0.97) !important;
  }

  body.event-page-body .ev-card:focus-visible {
    outline: 3px solid #fefcf8;
    outline-offset: 3px;
  }

  body.event-page-body .event-lower {
    position: relative !important;
    left: 0 !important;
    top: auto !important;
    width: 100% !important;
    height: auto !important;
    margin: 0 !important;
    background: #af8b72 !important;
    z-index: 20 !important;
  }

  body.event-page-body .event-lower .footer,
  body.event-page-body .canvas--event .footer {
    position: relative !important;
    left: 0 !important;
    top: auto !important;
    width: 100% !important;
    height: auto !important;
    padding: 0 16px 20px !important;
    background: #e6dcd0 !important;
    overflow: visible !important;
    box-sizing: border-box;
  }

  body.event-page-body .footer-inner,
  body.event-page-body .copyright {
    transform: none !important;
  }
}

.ev-image-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(30, 17, 12, 0.82);
  z-index: 20000;
  box-sizing: border-box;
}

.ev-image-modal.is-open {
  display: flex;
}

.ev-modal-img {
  display: block;
  max-width: min(92vw, 980px);
  max-height: 82vh;
  border-radius: 16px;
  object-fit: contain;
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.38);
}

.ev-modal-close {
  position: absolute;
  top: max(18px, env(safe-area-inset-top));
  right: max(18px, env(safe-area-inset-right));
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 999px;
  background: #fefcf8;
  color: #754636;
  font: 400 30px/42px "League Spartan", sans-serif;
  text-align: center;
  cursor: pointer;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.22);
}

@media (max-width: 900px) {
  body.event-page-body .top-nav {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    max-width: 430px !important;
    height: 72px !important;
    min-height: 72px !important;
    margin: 0 auto !important;
    padding: 6px 26px !important;
    background: #e6dcd0 !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    transform: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    box-sizing: border-box !important;
    z-index: 300 !important;
  }

  body.event-page-body .nav-logo-link {
    position: absolute !important;
    left: 50% !important;
    top: 36px !important;
    width: auto !important;
    height: auto !important;
    margin: 0 !important;
    transform: translate(-50%, -50%) !important;
    z-index: 1 !important;
  }

  body.event-page-body .nav-logo-link:hover {
    transform: translate(-50%, -50%) !important;
  }

  body.event-page-body .nav-logo {
    width: 82px !important;
    height: 82px !important;
    object-fit: contain !important;
  }

  body.event-page-body .nav-toggle {
    position: absolute !important;
    right: 26px !important;
    top: 12px !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    width: 48px !important;
    height: 48px !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    cursor: pointer !important;
    z-index: 2 !important;
    -webkit-tap-highlight-color: transparent;
    appearance: none;
  }

  body.event-page-body .nav-toggle:hover,
  body.event-page-body .nav-toggle:focus,
  body.event-page-body .nav-toggle:active {
    background: transparent !important;
    box-shadow: none !important;
  }

  body.event-page-body .nav-toggle-bar {
    display: block !important;
    width: 42px !important;
    height: 3px !important;
    border-radius: 1px !important;
    background: #652c23 !important;
    transition: transform 0.2s ease, opacity 0.2s ease !important;
  }

  body.event-page-body .nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(1) {
    transform: translateY(8px) rotate(45deg) !important;
  }

  body.event-page-body .nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(2) {
    opacity: 0 !important;
  }

  body.event-page-body .nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(3) {
    transform: translateY(-8px) rotate(-45deg) !important;
  }

  body.event-page-body .nav-links {
    position: fixed !important;
    top: 72px !important;
    right: 22px !important;
    left: auto !important;
    width: 210px !important;
    max-width: none !important;
    height: auto !important;
    max-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    background: #e6dcd0 !important;
    border-radius: 0 0 34px 34px !important;
    box-shadow: none !important;
    font-family: "League Spartan", sans-serif !important;
    font-size: 20px !important;
    color: #652c23 !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: none !important;
    z-index: 299 !important;
    transition: max-height 0.35s ease, padding 0.35s ease !important;
  }

  body.event-page-body .nav-links.is-open {
    max-height: 620px !important;
    padding: 18px 0 28px !important;
  }

  body.event-page-body .nav-links li {
    width: 100% !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 18px 0 !important;
    text-align: center !important;
  }

  body.event-page-body .nav-links li.active,
  body.event-page-body .nav-links li.active .nav-page-link {
    color: #af8b72 !important;
  }

  body.event-page-body .nav-page-link {
    color: inherit !important;
    text-decoration: none !important;
  }

  body.event-page-body .nav-links li.active .nav-underline {
    left: 50% !important;
    bottom: 8px !important;
    width: 86px !important;
    height: 10px !important;
    opacity: 1 !important;
    transform: translateX(-50%) scaleX(1) !important;
    transform-origin: center bottom !important;
  }

  body.event-page-body .nav-links li:not(.active) .nav-underline {
    left: 50% !important;
    bottom: 8px !important;
    width: 86px !important;
    opacity: 0 !important;
    transform: translateX(-50%) scaleX(0) !important;
  }

  body.event-page-body .event-lower {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: 100% !important;
    height: auto !important;
    margin: 0 !important;
    background: #e6dcd0 !important;
    z-index: 20 !important;
  }

  body.event-page-body .event-lower .footer,
  body.event-page-body .canvas--event .footer {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    order: 8 !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 0 16px 20px !important;
    background: #e6dcd0 !important;
    overflow: visible !important;
    box-sizing: border-box !important;
  }

  body.event-page-body .footer-float-up,
  body.event-page-body .footer-backtop {
    display: none !important;
  }

  body.event-page-body .footer-float-chat {
    right: max(14px, calc(50vw - 186px)) !important;
    bottom: 20px !important;
    width: 58px !important;
    height: 58px !important;
  }

  body.event-page-body .footer-inner {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: 100% !important;
    max-width: 360px !important;
    height: auto !important;
    margin: 0 auto !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    transform: none !important;
  }

  body.event-page-body .footer-logo-half {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: 118px !important;
    height: 58px !important;
    margin: -30px auto 8px !important;
    border-radius: 70px 70px 0 0 !important;
    background: #e6dcd0 !important;
  }

  body.event-page-body .footer-logo-half::after {
    display: none !important;
  }

  body.event-page-body .footer-logo {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: 72px !important;
    height: 72px !important;
    margin: 0 auto !important;
    display: block !important;
    object-fit: contain !important;
  }

  body.event-page-body .contact-col {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    order: 1 !important;
    width: 100% !important;
    max-width: 295px !important;
    margin: 0 auto !important;
  }

  body.event-page-body .footer h3 {
    font-family: "League Spartan", sans-serif !important;
    font-size: 31px !important;
    line-height: 1 !important;
    margin: 0 0 14px !important;
    text-align: center !important;
    color: #652c23 !important;
  }

  body.event-page-body .contact-col input {
    width: 100% !important;
    height: 34px !important;
    margin-top: 8px !important;
    border-width: 1px !important;
    font-size: 11px !important;
    padding: 0 18px !important;
    box-sizing: border-box !important;
  }

  body.event-page-body .contact-col .row {
    display: block !important;
  }

  body.event-page-body .footer-submit {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    order: 2 !important;
    align-self: flex-end !important;
    width: 88px !important;
    height: 34px !important;
    margin: 12px 32px 0 0 !important;
    font-size: 11px !important;
  }

  body.event-page-body .footer-socials {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    order: 3 !important;
    justify-content: center !important;
    width: 100% !important;
    gap: 34px !important;
    margin-top: 40px !important;
  }

  body.event-page-body .footer-socials a img {
    width: 48px !important;
    height: 48px !important;
    object-fit: contain !important;
  }

  body.event-page-body .links-col {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    order: 4 !important;
    width: 100% !important;
    max-width: 310px !important;
    margin: 28px auto 0 !important;
    text-align: center !important;
  }

  body.event-page-body .links-col > h3,
  body.event-page-body .links-grid {
    display: none !important;
  }

  body.event-page-body .meta {
    justify-content: center !important;
    gap: 0 !important;
    margin-top: 14px !important;
    text-align: center !important;
    font-size: 12px !important;
    line-height: 1.15 !important;
  }

  body.event-page-body .meta img {
    display: none !important;
  }

  body.event-page-body .meta p {
    margin: 0 !important;
  }

  body.event-page-body .copyright {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    order: 9 !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 24px auto 0 !important;
    padding: 0 !important;
    font-size: 7px !important;
    line-height: 1.3 !important;
    text-align: center !important;
    transform: none !important;
  }
}