/*
Theme Name: Attic 77
Theme URI: https://attic77.com
Author: Attic 77 Team
Author URI: https://attic77.com
Description: Art space and gallery theme for Attic 77 - A space for art, thought, and collective experience
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: attic77
Tags: art-gallery, events, custom-menu, featured-images, custom-logo
*/

/* Import all styles directly in this file */
@import url("https://cdnjs.cloudflare.com/ajax/libs/meyer-reset/2.0/reset.min.css");
@import url("https://fonts.googleapis.com/css2?family=Azeret+Mono:wght@400;500;600;700&display=swap");

* {
  -webkit-font-smoothing: antialiased;
  box-sizing: border-box;
}

html,
body {
  margin: 0px;
  height: 100%;
}

button:focus-visible {
  outline: 2px solid #4a90e2 !important;
  outline: -webkit-focus-ring-color auto 5px !important;
}

a {
  text-decoration: none;
}

@font-face {
  font-family: "Ranade-Regular";
  src: url("https://anima-uploads.s3.amazonaws.com/projects/6305ce7810f184b075cd8bdb/fonts/ranade-regular.otf") format("opentype");
}

@font-face {
  font-family: "Ranade-Bold";
  src: url("https://anima-uploads.s3.amazonaws.com/projects/6538e583a53b653b9b2e80e9/fonts/ranade-bold.otf") format("opentype");
}

@font-face {
  font-family: "Ranade-Medium";
  src: url("https://anima-uploads.s3.amazonaws.com/projects/6802b44c39e2720d46fa5871/fonts/ranade-medium.otf") format("opentype");
}

/* CSS Variables */
:root {
  --neutral-colors600: rgba(109, 117, 143, 1);
  --neutral-colors100: rgba(255, 255, 255, 1);
  --neutral-colors300: rgba(241, 243, 247, 1);
  --large-title-font-family: "Ranade", Helvetica;
  --large-title-font-weight: 400;
  --large-title-font-size: 128px;
  --large-title-letter-spacing: 0px;
  --large-title-line-height: 130.3000030517578px;
  --large-title-font-style: normal;
  --title-medium-font-family: "Ranade", Helvetica;
  --title-medium-font-weight: 500;
  --title-medium-font-size: 38px;
  --title-medium-letter-spacing: -1.14px;
  --title-medium-line-height: 45px;
  --title-medium-font-style: normal;
  --phone-header-reg-font-family: "Ranade", Helvetica;
  --phone-header-reg-font-weight: 400;
  --phone-header-reg-font-size: 42px;
  --phone-header-reg-letter-spacing: -1.26px;
  --phone-header-reg-line-height: 54px;
  --phone-header-reg-font-style: normal;
  --phone-header-med-font-family: "Ranade", Helvetica;
  --phone-header-med-font-weight: 500;
  --phone-header-med-font-size: 42px;
  --phone-header-med-letter-spacing: -1.26px;
  --phone-header-med-line-height: 54px;
  --phone-header-med-font-style: normal;
  --header-large-header-font-family: "Ranade", Helvetica;
  --header-large-header-font-weight: 400;
  --header-large-header-font-size: 96px;
  --header-large-header-letter-spacing: 0px;
  --header-large-header-line-height: 92px;
  --header-large-header-font-style: normal;
  --header-special-header-font-family: "Ranade", Helvetica;
  --header-special-header-font-weight: 400;
  --header-special-header-font-size: 72px;
  --header-special-header-letter-spacing: -2.16px;
  --header-special-header-line-height: 90px;
  --header-special-header-font-style: normal;
  --header-sub-header-font-family: "Ranade", Helvetica;
  --header-sub-header-font-weight: 500;
  --header-sub-header-font-size: 60px;
  --header-sub-header-letter-spacing: -1.8px;
  --header-sub-header-line-height: 80px;
  --header-sub-header-font-style: normal;
  --subheading-large-bold-CAPS-font-family: "Ranade", Helvetica;
  --subheading-large-bold-CAPS-font-weight: 700;
  --subheading-large-bold-CAPS-font-size: 28px;
  --subheading-large-bold-CAPS-letter-spacing: 1.4px;
  --subheading-large-bold-CAPS-line-height: 40px;
  --subheading-large-bold-CAPS-font-style: normal;
  --subheading-details-large-bold-font-family: "Ranade", Helvetica;
  --subheading-details-large-bold-font-weight: 700;
  --subheading-details-large-bold-font-size: 30px;
  --subheading-details-large-bold-letter-spacing: -0.6px;
  --subheading-details-large-bold-line-height: 36.57481384277344px;
  --subheading-details-large-bold-font-style: normal;
  --subheading-small-bold-CAPS-font-family: "Ranade", Helvetica;
  --subheading-small-bold-CAPS-font-weight: 700;
  --subheading-small-bold-CAPS-font-size: 20px;
  --subheading-small-bold-CAPS-letter-spacing: 1px;
  --subheading-small-bold-CAPS-line-height: 30px;
  --subheading-small-bold-CAPS-font-style: normal;
  --subheading-small-bold-font-family: "Ranade", Helvetica;
  --subheading-small-bold-font-weight: 700;
  --subheading-small-bold-font-size: 20px;
  --subheading-small-bold-letter-spacing: -0.4px;
  --subheading-small-bold-line-height: 28px;
  --subheading-small-bold-font-style: normal;
  --body-body-large-font-family: "Ranade", Helvetica;
  --body-body-large-font-weight: 400;
  --body-body-large-font-size: 24px;
  --body-body-large-letter-spacing: -0.72px;
  --body-body-large-line-height: 32px;
  --body-body-large-font-style: normal;
  --body-body-XL-medium-font-family: "Ranade", Helvetica;
  --body-body-XL-medium-font-weight: 500;
  --body-body-XL-medium-font-size: 28px;
  --body-body-XL-medium-letter-spacing: -0.84px;
  --body-body-XL-medium-line-height: 37px;
  --body-body-XL-medium-font-style: normal;
  --body-body-small-font-family: "Ranade", Helvetica;
  --body-body-small-font-weight: 400;
  --body-body-small-font-size: 18px;
  --body-body-small-letter-spacing: -0.36px;
  --body-body-small-line-height: 26px;
  --body-body-small-font-style: normal;
  --body-body-description-font-family: "Ranade", Helvetica;
  --body-body-description-font-weight: 400;
  --body-body-description-font-size: 14px;
  --body-body-description-letter-spacing: -0.28px;
  --body-body-description-line-height: 22px;
  --body-body-description-font-style: normal;
  --body-caption-font-family: "Ranade", Helvetica;
  --body-caption-font-weight: 700;
  --body-caption-font-size: 15px;
  --body-caption-letter-spacing: -0.15px;
  --body-caption-line-height: 20px;
  --body-caption-font-style: normal;
  --body-body-small-bold-font-family: "Ranade", Helvetica;
  --body-body-small-bold-font-weight: 700;
  --body-body-small-bold-font-size: 18px;
  --body-body-small-bold-letter-spacing: -0.36px;
  --body-body-small-bold-line-height: 26px;
  --body-body-small-bold-font-style: normal;
  --body-body-small-medium-font-family: "Ranade", Helvetica;
  --body-body-small-medium-font-weight: 500;
  --body-body-small-medium-font-size: 18px;
  --body-body-small-medium-letter-spacing: -0.36px;
  --body-body-small-medium-line-height: 26px;
  --body-body-small-medium-font-style: normal;
  --body-body-des-medium-font-family: "Ranade", Helvetica;
  --body-body-des-medium-font-weight: 500;
  --body-body-des-medium-font-size: 14px;
  --body-body-des-medium-letter-spacing: -0.28px;
  --body-body-des-medium-line-height: 22px;
  --body-body-des-medium-font-style: normal;
  --display-2-regular-font-family: "Azeret Mono", "Courier New", monospace;
  --display-2-regular-font-weight: 400;
  --display-2-regular-font-size: 14px;
  --display-2-regular-letter-spacing: 0px;
  --display-2-regular-line-height: 20px;
  --display-2-regular-font-style: normal;
  --secondary-mono-font-family: "Azeret Mono", "Courier New", monospace;
  --neutral-shadow-02: 0px 1px 4px 0px rgba(25, 33, 61, 0.08);
  --variable-collection-citrus: rgba(255, 214, 51, 1);
  --variable-collection-scarlet: rgba(255, 78, 51, 1);
  --variable-collection-sapphire: rgba(61, 61, 255, 1);
  --variable-collection-smoke: rgba(16, 13, 9, 1);
  --attic77-dialog-overlay-opacity: 0.15;
  --attic77-dialog-overlay-blur: 15px;
}

/* WordPress Admin Bar Fix */
body.admin-bar .frame {
  top: 32px;
}

@media screen and (max-width: 782px) {
  body.admin-bar .frame {
    top: 46px;
  }
}

/* Main Styles */
body {
  background-color: #100d09;
  margin: 0;
  padding: 0;
}

.attic77-content-wrap {
  position: relative;
  z-index: 1;
}

.attic77-home-dialog-overlay {
  position: absolute;
  inset: 0;
  z-index: 620;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 220ms ease, visibility 220ms ease;
  background: rgba(var(--attic77-home-overlay-rgb, 246, 191, 47), var(--attic77-dialog-overlay-opacity));
  -webkit-backdrop-filter: blur(var(--attic77-dialog-overlay-blur));
  backdrop-filter: blur(var(--attic77-dialog-overlay-blur));
}

.attic77-home-dialog-overlay.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.landing-page.landing-page-wrapper {
  background-color: #100d09;
  display: grid;
  justify-items: center;
  align-items: start;
  width: 100vw;
  min-height: 100vh;
}

.landing-page .div {
  background-color: var(--variable-collection-smoke);
  overflow: hidden;
  width: 1440px;
  height: 4528px;
  position: relative;
}

.landing-page .overlap {
  position: absolute;
  width: 2161px;
  height: 900px;
  top: 0;
  left: 0;
}

.landing-page .frame {
  display: flex;
  width: 1441px;
  align-items: center;
  justify-content: space-between;
  padding: 40px 60px;
  position: absolute;
  top: 0;
  left: 0;
  background-color: var(--variable-collection-smoke);
  border-bottom-width: 1px;
  border-bottom-style: solid;
  border-color: #ffffff;
  z-index: 100;
}

.frame {
  /* The WP header renders outside of main.landing-page; mirror the exported header styling. */
}

header.frame {
  display: flex;
  width: 100%;
  max-width: 1441px;
  margin: 0 auto;
  align-items: center;
  justify-content: space-between;
  padding: 40px 60px;
  position: relative;
  background-color: var(--variable-collection-smoke);
  border-bottom: 1px solid #ffffff;
  z-index: 1000;
}

header.frame .attic77-menu-toggle {
  display: none !important;
  visibility: hidden;
  pointer-events: none;
  width: 44px;
  height: 44px;
  border: 1px solid #ffffff;
  background: transparent;
  padding: 10px 9px;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
}

header.frame .attic77-menu-toggle span {
  display: block;
  width: 100%;
  height: 2px;
  background: #ffffff;
  transition: transform 220ms ease, opacity 220ms ease;
}

@media (max-width: 900px) and (hover: none), (max-width: 900px) and (pointer: coarse) {
  header.frame .attic77-menu-toggle {
    display: inline-flex !important;
    visibility: visible;
    pointer-events: auto;
    margin-left: auto;
  }

  header.frame .frame-2 {
    display: none !important;
    width: 100%;
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
  }

  header.frame.attic77-menu-open .frame-2 {
    display: flex !important;
  }

  header.frame .menu {
    width: 100%;
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
  }

  header.frame .frame-3 {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }

  header.frame .main-button {
    width: 100%;
    padding: 4px 12px;
  }

  header.frame .frame-4 {
    justify-content: center;
  }

  header.frame.attic77-menu-open .attic77-menu-toggle span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }

  header.frame.attic77-menu-open .attic77-menu-toggle span:nth-child(2) {
    opacity: 0;
  }

  header.frame.attic77-menu-open .attic77-menu-toggle span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }
}

header.frame .img {
  position: relative;
  width: 53.75px;
  height: 55.06px;
}

header.frame .frame-2 {
  display: inline-flex !important;
  align-items: center;
  gap: 192px;
  position: relative;
  flex: 0 0 auto;
}

header.frame .menu {
  display: inline-flex;
  align-items: center;
  gap: 60px;
  position: relative;
  flex: 0 0 auto;
}

header.frame a {
  text-decoration: none;
}

header.frame .text-wrapper-2 {
  position: relative;
  width: fit-content;
  margin-top: -0.90px;
  font-family: "Ranade-Medium", Helvetica;
  font-weight: 500;
  color: var(--variable-collection-citrus);
  font-size: 16px;
  letter-spacing: 1.60px;
  line-height: normal;
  text-transform: uppercase;
  transition: color 0.3s ease;
}

header.frame .text-wrapper-3 {
  position: relative;
  width: fit-content;
  margin-top: -0.90px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 16px;
  letter-spacing: 1.60px;
  line-height: normal;
  text-transform: uppercase;
  transition: color 0.3s ease;
}

header.frame .text-wrapper-3:hover {
  color: var(--variable-collection-citrus);
}

header.frame .frame-3 {
  display: inline-flex;
  align-items: center;
  gap: 20px;
  position: relative;
  flex: 0 0 auto;
}

header.frame .main-button {
  display: inline-flex;
  flex-direction: column;
  height: 31px;
  align-items: flex-start;
  gap: 10px;
  padding: 4px 28px;
  position: relative;
  flex: 0 0 auto;
  background-image: url(https://c.animaapp.com/5RVLcvcp/img/main-button-6@2x.png);
  background-size: cover;
  background-position: 50% 50%;
  border: none;
  cursor: pointer;
}

header.frame .frame-4 {
  display: flex;
  align-items: center;
  gap: 5px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

header.frame .icon {
  position: relative;
  width: 17.52px;
  height: 17.52px;
  aspect-ratio: 1;
}

header.frame .text-wrapper-4 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: var(--variable-collection-smoke);
  font-size: 15.3px;
  letter-spacing: -0.46px;
  line-height: 22.2px;
  white-space: nowrap;
}

.landing-page .img {
  position: relative;
  width: 53.75px;
  height: 55.06px;
}

.landing-page .frame-2 {
  display: inline-flex;
  align-items: center;
  gap: 192px;
  position: relative;
  flex: 0 0 auto;
}

.landing-page .menu {
  display: inline-flex;
  align-items: center;
  gap: 60px;
  position: relative;
  flex: 0 0 auto;
}

.landing-page .text-wrapper-2 {
  position: relative;
  width: fit-content;
  margin-top: -0.90px;
  font-family: "Ranade-Medium", Helvetica;
  font-weight: 500;
  color: var(--variable-collection-citrus);
  font-size: 16px;
  letter-spacing: 1.60px;
  line-height: normal;
  text-transform: uppercase;
  transition: color 0.3s ease;
}

.landing-page .text-wrapper-3 {
  position: relative;
  width: fit-content;
  margin-top: -0.90px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 16px;
  letter-spacing: 1.60px;
  line-height: normal;
  text-transform: uppercase;
  transition: color 0.3s ease;
}

.landing-page .text-wrapper-3:hover {
  color: var(--variable-collection-citrus);
}

.landing-page .frame-3 {
  display: inline-flex;
  align-items: center;
  gap: 20px;
  position: relative;
  flex: 0 0 auto;
}

.landing-page .main-button {
  display: inline-flex;
  flex-direction: column;
  height: 31px;
  align-items: flex-start;
  gap: 10px;
  padding: 4px 28px;
  position: relative;
  flex: 0 0 auto;
  background-image: url(https://c.animaapp.com/5RVLcvcp/img/main-button-6@2x.png);
  background-size: cover;
  background-position: 50% 50%;
  border: none;
  cursor: pointer;
}

.landing-page .frame-4 {
  display: flex;
  align-items: center;
  gap: 5px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.landing-page .icon {
  position: relative;
  width: 17.52px;
  height: 17.52px;
  aspect-ratio: 1;
}

.landing-page .text-wrapper-4 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: var(--variable-collection-smoke);
  font-size: 15.3px;
  letter-spacing: -0.46px;
  line-height: 22.2px;
  white-space: nowrap;
}

.landing-page .frame-5,
.landing-page .attic77-events-carousel {
  display: flex;
  width: 1441px;
  align-items: center;
  padding: 0px 0px 0px 135px;
  position: absolute;
  top: 135px;
  left: 0;
  overflow-x: scroll;
}

.landing-page .frame-5::-webkit-scrollbar,
.landing-page .attic77-events-carousel::-webkit-scrollbar {
  width: 0;
  display: none;
}

/* Swiper migration: override the old "native scroll carousel" behavior. */
.landing-page .frame-5.swiper,
.landing-page .attic77-events-carousel.swiper {
  display: block;
  overflow: hidden;
}

.landing-page .frame-5.swiper .swiper-wrapper,
.landing-page .attic77-events-carousel.swiper .swiper-wrapper {
  align-items: center;
}

/* Slides are now <article class="swiper-slide">; map previous card sizing onto the slide. */
.landing-page .attic77-events-carousel.swiper .swiper-slide {
  display: flex;
  width: 711.56px;
  height: 700px;
  align-items: center;
  justify-content: center;
  gap: 8.25px;
  position: relative;
  overflow: hidden;
}

.landing-page .component {
  display: flex;
  width: 711.56px;
  height: 700px;
  align-items: center;
  justify-content: center;
  gap: 8.25px;
  position: relative;
  overflow: hidden;
}

.landing-page .vector-2 {
  position: absolute;
  width: 606px;
  height: 701px;
  top: 1px;
  left: 54px;
  object-fit: cover;
}

.landing-page .frame-6 {
  display: flex;
  flex-direction: column;
  width: 322px;
  align-items: center;
  justify-content: center;
  gap: 10.89px;
  position: relative;
}

.landing-page .div-wrapper {
  display: inline-flex;
  height: 115px;
  align-items: flex-end;
  justify-content: center;
  gap: 10px;
  position: relative;
}

.landing-page .text-wrapper-5 {
  position: relative;
  width: fit-content;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 42px;
  text-align: center;
  letter-spacing: -1.26px;
  line-height: 49px;
  white-space: nowrap;
}

.landing-page .frame-7 {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  flex: 0 0 auto;
}

.landing-page .text-wrapper-6 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 132px;
  text-align: center;
  letter-spacing: -3.96px;
  line-height: 183.2px;
  white-space: nowrap;
}

.landing-page .february {
  position: relative;
  width: fit-content;
  margin-top: -30px;
  font-family: "Ranade-Bold", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 24px;
  letter-spacing: 1.68px;
  line-height: 57.3px;
  white-space: nowrap;
}

.landing-page .div-2 {
  display: flex;
  width: 711.56px;
  height: 700px;
  align-items: center;
  justify-content: center;
  gap: 8.25px;
  position: relative;
  margin-left: -215px;
  overflow: hidden;
}

.attic77-home-event-cta,
.attic77-home-event-dialog {
  display: none;
}

.landing-page .attic77-home-event-card {
  --attic77-event-accent: #F6BF2F;
  --attic77-event-accent-rgb: 246, 191, 47;
  overflow: visible;
  isolation: isolate;
}

.landing-page .frame-5.swiper .swiper-slide.attic77-home-event-card {
  overflow: visible;
}

/* Swiper now owns horizontal overlap spacing, so neutralize legacy per-card offset class. */
.landing-page .frame-5.swiper .swiper-slide.div-2,
.landing-page .attic77-events-carousel.swiper .swiper-slide.div-2 {
  margin-left: 0 !important;
}

.landing-page .attic77-home-event-card .attic77-home-event-cta {
  display: inline-flex;
  position: absolute;
  /* Align to the center of the tile's bottom edge, not geometric center of full card box. */
  left: calc(50% - 18px);
  bottom: 24px;
  z-index: 8;
  transform: translateX(-50%);
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(var(--attic77-event-accent-rgb), 0.85);
  background: rgba(16, 13, 9, 0.9);
  color: var(--attic77-event-accent);
  font-family: "Ranade-Medium", Helvetica;
  font-size: 16px;
  line-height: 22px;
  padding: 10px 18px;
  white-space: nowrap;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 180ms ease, visibility 180ms ease, transform 180ms ease, background-color 180ms ease;
}

.landing-page .attic77-home-event-card:hover .attic77-home-event-cta,
.landing-page .attic77-home-event-card:focus-within .attic77-home-event-cta {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(-2px);
}

.landing-page .attic77-home-event-card.is-home-dialog-open .attic77-home-event-cta {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.landing-page .attic77-home-event-card .attic77-home-event-cta:hover,
.landing-page .attic77-home-event-card .attic77-home-event-cta:focus-visible {
  background: rgba(16, 13, 9, 0.98);
}

.landing-page .attic77-home-event-card .attic77-home-event-dialog {
  display: flex;
  position: absolute;
  top: 50%;
  right: 0;
  width: min(560px, calc(100% - 24px));
  max-height: calc(100% - 24px);
  z-index: 630;
  padding: 28px 30px 24px 42px;
  background: rgba(16, 13, 9, 0.95);
  border: 1px solid rgba(var(--attic77-event-accent-rgb), 0.32);
  clip-path: polygon(10% 0, 100% 0, 90% 100%, 0 100%);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translate(16%, -50%) scale(0.98);
  transition: opacity 220ms ease, visibility 220ms ease, transform 220ms ease;
  box-sizing: border-box;
}

.landing-page .attic77-home-event-card.is-home-dialog-open .attic77-home-event-dialog {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate(16%, -50%) scale(1);
}

.landing-page .attic77-home-event-card.is-home-dialog-open {
  z-index: 631;
}

.landing-page .frame-5.attic77-home-dialog-active {
  z-index: 625;
}

.landing-page .frame-5.attic77-home-dialog-active .attic77-home-event-card.is-home-dialog-open {
  z-index: 626;
}

.landing-page .frame-5.attic77-home-dialog-active .attic77-home-event-card.is-home-dialog-open .attic77-home-event-dialog {
  z-index: 627;
}

.landing-page .attic77-home-event-card .attic77-home-event-dialog-inner {
  width: 100%;
  max-height: 100%;
  overflow: auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding-left: 14px;
}

.landing-page .attic77-home-event-card .attic77-home-event-dialog-inner .text-wrapper-5 {
  margin: 0;
  white-space: normal;
  text-align: left;
  font-size: 34px;
  line-height: 40px;
}

.landing-page .attic77-home-event-card .attic77-home-event-dialog-inner .we-host-art {
  margin: 0;
  flex: none;
  width: auto;
  font-family: "Ranade-Regular", Helvetica;
  font-size: 20px;
  line-height: 30px;
}

.landing-page .attic77-home-event-card .attic77-home-event-dialog-actions {
  margin-top: 6px;
  display: flex;
  align-items: center;
}

.landing-page .attic77-home-event-card .attic77-home-event-dialog-actions .main-button {
  text-decoration: none;
}

.landing-page .attic77-home-event-card .attic77-home-event-dialog-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(var(--attic77-event-accent-rgb), 0.55);
  background: rgba(var(--attic77-event-accent-rgb), 0.15);
  color: var(--attic77-event-accent);
  font-size: 24px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

@media (hover: none), (pointer: coarse) {
  .landing-page .attic77-home-event-card .attic77-home-event-cta {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%);
  }
}

@media (max-width: 768px) {
  .attic77-home-dialog-overlay {
    display: none !important;
  }

  .landing-page .attic77-home-event-card .attic77-home-event-cta {
    bottom: 12px;
    left: calc(50% - 12px);
    font-size: 14px;
    line-height: 20px;
    padding: 8px 14px;
  }

  .landing-page .attic77-home-event-card .attic77-home-event-dialog {
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100vh;
    max-height: 100vh;
    padding: 0;
    clip-path: none;
    transform: translateY(8px);
    border: 0;
    z-index: 1400;
    background: rgba(16, 13, 9, 0.98);
  }

  .landing-page .attic77-home-event-card.is-home-dialog-open .attic77-home-event-dialog {
    transform: none;
  }

  .landing-page .attic77-home-event-card .attic77-home-event-dialog-inner {
    padding: 64px 16px 22px;
    gap: 8px;
  }

  .landing-page .attic77-home-event-card .attic77-home-event-dialog-inner .text-wrapper-5 {
    font-size: 24px;
    line-height: 30px;
    padding-right: 30px;
  }

  .landing-page .attic77-home-event-card .attic77-home-event-dialog-inner .we-host-art {
    font-size: 16px;
    line-height: 24px;
  }

  .landing-page .attic77-home-event-card .attic77-home-event-dialog-close {
    top: 12px;
    left: 12px;
    right: auto;
    width: auto;
    min-width: 44px;
    height: 36px;
    padding: 0 12px;
    border: 0;
    background: var(--attic77-event-accent);
    color: #100d09;
    font-size: 0;
    line-height: 1;
    font-family: "Ranade-Medium", Helvetica;
  }

  .landing-page .attic77-home-event-card .attic77-home-event-dialog-close::before {
    content: "Back";
    font-size: 14px;
    line-height: 1;
    letter-spacing: 0.3px;
  }
}

.landing-page .vector-4 {
  position: absolute;
  width: 307px;
  height: 700px;
  top: 135px;
  left: 0;
}

.landing-page .overlap-group {
  position: absolute;
  width: 1441px;
  height: 3496px;
  top: 928px;
  left: 0;
}

.landing-page .frame-8 {
  display: flex;
  flex-direction: column;
  width: 1441px;
  align-items: flex-start;
  gap: 60px;
  position: absolute;
  top: 0;
  left: 0;
}

.landing-page .frame-9 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 0px 48px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.landing-page .p {
  position: relative;
  flex: 1;
  margin-top: -1.00px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 72px;
  letter-spacing: -2.16px;
  line-height: 90px;
}

.landing-page .we-host-art {
  position: relative;
  flex: 1;
  margin-top: -1.00px;
  font-family: "Ranade-Medium", Helvetica;
  font-weight: 500;
  color: #ffffff;
  font-size: 24px;
  letter-spacing: -0.72px;
  line-height: 39px;
}

.landing-page .rectangle {
  position: relative;
  align-self: stretch;
  width: 100%;
  height: 616.96px;
}

.landing-page .frame-10 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 0px 48px;
  position: relative;
  flex: 0 0 auto;
}

.landing-page .text-wrapper-7 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "Ranade-Medium", Helvetica;
  font-weight: 500;
  color: #ffffff;
  font-size: 60px;
  letter-spacing: -1.8px;
  line-height: 80px;
  white-space: nowrap;
}

/* Homepage intro copy: keep heading and body on separate lines with breathing room. */
.landing-page .overlap-group .frame-8 > .frame-9 + .frame-9 {
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 20px;
}

.landing-page .overlap-group .frame-8 > .frame-9 + .frame-9 .text-wrapper-7,
.landing-page .overlap-group .frame-8 > .frame-9 + .frame-9 .we-host-art {
  margin-top: 0;
}

.landing-page .frame-11 {
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

/* Photo gallery viewport wrapper (added by theme JS). */
.landing-page .attic77-photo-gallery {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.landing-page .attic77-photo-gallery.attic77-photo-gallery--dynamic {
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
  scrollbar-width: none;
}

.landing-page .attic77-photo-gallery.attic77-photo-gallery--dynamic::-webkit-scrollbar {
  display: none;
}

.landing-page .attic77-photo-gallery-track {
  display: flex;
  align-items: stretch;
  gap: 12px;
  min-width: max-content;
  height: 376.104px;
}

.landing-page .attic77-photo-gallery-item {
  position: relative;
  flex: 0 0 393px;
  width: 393px;
  height: 376.104px;
  margin: 0;
  overflow: hidden;
  background: #000000;
  clip-path: polygon(21.5% 0, 100% 0, 78.5% 100%, 0 100%);
}

.landing-page .attic77-photo-gallery-item img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 1024px) {
  .landing-page .attic77-photo-gallery-track {
    height: min(340px, 46vw);
  }

  .landing-page .attic77-photo-gallery-item {
    flex-basis: min(360px, 72vw);
    width: min(360px, 72vw);
    height: min(340px, 46vw);
  }
}

@media (max-width: 768px) {
  .landing-page .attic77-photo-gallery-track {
    gap: 10px;
    height: min(300px, 56vw);
  }

  .landing-page .attic77-photo-gallery-item {
    flex-basis: min(320px, 84vw);
    width: min(320px, 84vw);
    height: min(300px, 56vw);
  }
}

.landing-page .attic77-photo-gallery img.frame-11 {
  display: block;
  width: auto;
  height: 376.104px;
  max-width: none;
}

.landing-page .frame-12 {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
  flex: 0 0 auto;
}

.landing-page .frame-13 {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 60px;
  padding: 64px 0px;
  position: relative;
  flex: 0 0 auto;
  background-image: url(https://c.animaapp.com/5RVLcvcp/img/frame-100.png);
  background-size: cover;
  background-position: 50% 50%;
}

.landing-page .frame-14 {
  display: flex;
  flex-direction: column;
  width: 1441px;
  align-items: flex-start;
  gap: 68px;
  position: relative;
  flex: 0 0 auto;
}

.landing-page .frame-15 {
  display: flex;
  align-items: flex-start;
  gap: 60px;
  padding: 0px 94px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.landing-page .frame-16 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  position: relative;
  flex: 1;
  align-self: stretch;
  flex-grow: 1;
}

.landing-page .layer {
  position: relative;
  width: 146px;
  height: 88px;
}

.landing-page .text-wrapper-8 {
  position: relative;
  align-self: stretch;
  font-family: "Ranade-Medium", Helvetica;
  font-weight: 500;
  color: #ffffff;
  font-size: 24px;
  text-align: center;
  letter-spacing: -0.72px;
  line-height: 30px;
}

.landing-page .text-wrapper-9 {
  position: relative;
  align-self: stretch;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 24px;
  text-align: center;
  letter-spacing: -0.72px;
  line-height: 30px;
}

.landing-page .frame-17 {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 60px;
  padding: 0px 94px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.landing-page .professional-audio {
  position: relative;
  align-self: stretch;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 24px;
  text-align: center;
  letter-spacing: -0.72px;
  line-height: 39px;
}

.landing-page .text-wrapper-10 {
  position: relative;
  align-self: stretch;
  height: 69.7px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 24px;
  text-align: center;
  letter-spacing: -0.72px;
  line-height: 39px;
}

.landing-page .text-wrapper-11 {
  position: relative;
  align-self: stretch;
  height: 69.7px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 24px;
  text-align: center;
  letter-spacing: -0.72px;
  line-height: 30px;
}

.landing-page .div-3 {
  position: relative;
  width: 1440px;
  height: 810px;
}

.landing-page .bottom-nav {
  height: 810px;
}

.landing-page .group {
  position: absolute;
  width: 123px;
  height: 248px;
  top: 562px;
  left: 1317px;
}

.landing-page .group-2 {
  position: absolute;
  width: 1440px;
  height: 810px;
  top: 0;
  left: 0;
}

.landing-page .overlap-group-wrapper {
  position: absolute;
  width: 759px;
  height: 810px;
  top: 0;
  left: 65px;
}

.landing-page .overlap-group-2 {
  position: relative;
  width: 757px;
  height: 810px;
}

.landing-page .vector-5 {
  position: absolute;
  width: 757px;
  height: 810px;
  top: 0;
  left: 0;
}

.landing-page .text-wrapper-12 {
  position: absolute;
  top: 357px;
  left: 273px;
  font-family: "Ranade-Medium", Helvetica;
  font-weight: 500;
  color: var(--variable-collection-smoke);
  font-size: 47.9px;
  letter-spacing: -1.44px;
  line-height: 96.3px;
  white-space: nowrap;
}

.landing-page .overlap-wrapper {
  position: absolute;
  width: 345px;
  height: 255px;
  top: 0;
  left: 619px;
}

.landing-page .overlap-2 {
  position: relative;
  width: 343px;
  height: 255px;
  background-image: url(https://c.animaapp.com/5RVLcvcp/img/vector-15.svg);
  background-size: 100% 100%;
}

.landing-page .text-wrapper-13 {
  position: absolute;
  top: 79px;
  left: 99px;
  font-family: "Ranade-Medium", Helvetica;
  font-weight: 500;
  color: #ffffff;
  font-size: 47.9px;
  letter-spacing: -1.44px;
  line-height: 96.3px;
  white-space: nowrap;
}

.landing-page .group-3 {
  position: absolute;
  width: 637px;
  height: 307px;
  top: 255px;
  left: 683px;
}

.landing-page .overlap-3 {
  position: relative;
  width: 635px;
  height: 307px;
  background-image: url(https://c.animaapp.com/5RVLcvcp/img/vector-16.svg);
  background-size: 100% 100%;
}

.landing-page .text-wrapper-14 {
  position: absolute;
  top: 102px;
  left: 222px;
  font-family: "Ranade-Medium", Helvetica;
  font-weight: 500;
  color: #ffffff;
  font-size: 47.9px;
  letter-spacing: -1.44px;
  line-height: 96.3px;
  white-space: nowrap;
}

.landing-page .footer-top {
  display: flex;
  width: 1441px;
  gap: 24px;
  padding: 10px 60px 50px;
  background-color: var(--variable-collection-smoke);
  border-top-width: 1px;
  border-top-style: solid;
  border-color: #ffffff;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
  flex: 0 0 auto;
}

.footer-top {
  /* The WP footer renders outside of main.landing-page; mirror the exported footer styling. */
  display: flex;
  width: 100%;
  max-width: 1441px;
  margin: 0 auto;
  gap: 24px;
  padding: 10px 60px 50px;
  background-color: var(--variable-collection-smoke);
  border-top: 1px solid #ffffff;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
  flex: 0 0 auto;
}

.footer-top .frame-18,
.footer-top .frame-19,
.footer-top .footer-column,
.footer-top .grid-column,
.footer-top .frame-20,
.footer-top .frame-21,
.footer-top .frame-22,
.footer-top .text-wrapper-15,
.footer-top .text-wrapper-16,
.footer-top .element-AM-PM,
.footer-top .m-floor-m,
.footer-top .vector-6 {
  /* Ensure footer uses the same layout typography rules even outside .landing-page. */
}

.footer-top .frame-18 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.footer-top .img-2 {
  position: relative;
  flex: 0 0 auto;
}

.footer-top .footer-social-links {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  position: relative;
  flex: 0 0 auto;
}

.footer-top .footer-social-link {
  text-decoration: none;
}

.footer-top .footer-column {
  display: inline-flex;
  height: 128px;
  justify-content: space-around;
  gap: 32px;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
  flex: 0 0 auto;
}

.footer-top .grid-column {
  display: inline-flex;
  align-items: flex-start;
  gap: 13px;
  position: relative;
  flex: 0 0 auto;
}

.footer-top .text-wrapper-15 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 16px;
  text-align: center;
  letter-spacing: 0;
  line-height: 22px;
  white-space: nowrap;
}

.footer-top .frame-19 {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.footer-top .frame-12 {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
  flex: 0 0 auto;
}

.footer-top .frame-20 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 15px;
  position: relative;
  flex: 0 0 auto;
}

.footer-top .vector-6 {
  position: relative;
  width: 24.79px;
  height: 29.18px;
  aspect-ratio: 0.85;
}

.footer-top .m-floor-m {
  position: relative;
  width: 214px;
  margin-top: -1.00px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 14px;
  letter-spacing: 0;
  line-height: 20px;
}

.footer-top .frame-21 {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 15px;
  position: relative;
  flex: 0 0 auto;
}

.footer-top .frame-22 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  position: relative;
  flex: 0 0 auto;
}

.footer-top .text-wrapper-16 {
  position: relative;
  width: 263px;
  margin-top: -1.00px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 16px;
  text-align: right;
  letter-spacing: 0;
  line-height: 22px;
  text-decoration: underline;
}

.footer-top .element-AM-PM {
  position: relative;
  width: fit-content;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 12px;
  letter-spacing: 0;
  line-height: 20px;
  white-space: nowrap;
}

.footer-top .text-wrapper-15 {
  color: #ffffff;
  transition: color 0.3s ease;
}

.footer-top a.text-wrapper-15:hover,
.footer-top a.text-wrapper-15:focus-visible {
  color: var(--variable-collection-citrus);
}

.footer-top a.text-wrapper-16:hover,
.footer-top a.text-wrapper-16:focus-visible {
  color: var(--variable-collection-citrus);
}

html.attic77-dialog-open,
html.attic77-dialog-open body {
  overflow: hidden;
}

.attic77-policy-dialog {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: rgba(16, 13, 9, 0.72);
}

.attic77-policy-dialog.is-open {
  display: flex;
}

.attic77-policy-dialog-panel {
  position: relative;
  width: min(980px, 100%);
  height: min(86vh, 760px);
  background: #100d09;
  border: 1px solid rgba(255, 214, 51, 0.35);
  display: flex;
  flex-direction: column;
}

.attic77-policy-dialog-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(255, 214, 51, 0.45);
  background: rgba(16, 13, 9, 0.85);
  color: #ffffff;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
}

.attic77-policy-dialog-title {
  margin: 0;
  padding: 14px 52px 14px 18px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 20px;
  line-height: 28px;
  border-bottom: 1px solid rgba(255, 214, 51, 0.25);
}

.attic77-policy-dialog-content {
  flex: 1;
  min-height: 0;
}

.attic77-policy-dialog-frame {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
  background: #ffffff;
}

@media (max-width: 768px) {
  .attic77-policy-dialog {
    padding: 8px;
  }

  .attic77-policy-dialog-panel {
    height: min(90vh, 820px);
  }

  .attic77-policy-dialog-title {
    font-size: 18px;
    line-height: 24px;
  }
}

.attic77-newsletter-dialog {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: rgba(16, 13, 9, 0.72);
}

.attic77-newsletter-dialog.is-open {
  display: flex;
}

.attic77-newsletter-dialog-panel {
  position: relative;
  width: min(640px, 100%);
  background: #100d09;
  border: 1px solid rgba(255, 214, 51, 0.35);
  padding: 28px 24px 24px;
}

.attic77-newsletter-dialog-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(255, 214, 51, 0.45);
  background: rgba(16, 13, 9, 0.85);
  color: #ffffff;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
}

.attic77-newsletter-dialog-title {
  margin: 0 0 18px;
  padding-right: 40px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 28px;
  line-height: 36px;
}

.attic77-newsletter-form {
  display: grid;
  gap: 14px;
}

.attic77-newsletter-honeypot {
  position: absolute;
  left: -5000px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.attic77-newsletter-field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.attic77-newsletter-field {
  display: grid;
  gap: 6px;
}

.attic77-newsletter-field span {
  font-family: "Ranade-Regular", Helvetica;
  font-size: 14px;
  line-height: 20px;
  color: #ffffff;
}

.attic77-newsletter-field input {
  width: 100%;
  min-height: 46px;
  border: 1px solid rgba(255, 214, 51, 0.45);
  background: rgba(16, 13, 9, 0.92);
  color: #ffffff;
  padding: 10px 12px;
  font-family: var(--secondary-mono-font-family);
  font-size: 14px;
  line-height: 20px;
}

.attic77-newsletter-field input:focus-visible {
  outline: 2px solid var(--variable-collection-citrus);
  outline-offset: 0;
}

.attic77-newsletter-submit {
  min-height: 48px;
  border: 0;
  background: var(--variable-collection-citrus);
  color: #100d09;
  font-family: "Ranade-Bold", Helvetica;
  font-size: 16px;
  line-height: 22px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  cursor: pointer;
}

.attic77-newsletter-submit[disabled] {
  opacity: 0.7;
  cursor: wait;
}

.attic77-newsletter-response {
  margin: 0;
  min-height: 20px;
  font-family: "Ranade-Regular", Helvetica;
  font-size: 14px;
  line-height: 20px;
  color: rgba(255, 255, 255, 0.78);
}

.attic77-newsletter-response.is-success {
  color: var(--variable-collection-citrus);
}

.attic77-newsletter-response.is-error {
  color: #ff7f66;
}

.attic77-newsletter-help-text {
  margin: 0;
  font-family: "Ranade-Regular", Helvetica;
  font-size: 14px;
  line-height: 20px;
  color: rgba(255, 255, 255, 0.85);
}

@media (max-width: 768px) {
  .attic77-newsletter-dialog {
    padding: 8px;
  }

  .attic77-newsletter-dialog-panel {
    padding: 24px 16px 16px;
  }

  .attic77-newsletter-dialog-title {
    font-size: 24px;
    line-height: 32px;
  }

  .attic77-newsletter-field-grid {
    grid-template-columns: 1fr;
  }
}

html.attic77-photo-dialog-open,
html.attic77-photo-dialog-open body {
  overflow: hidden;
}

.attic77-photo-dialog {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: rgba(16, 13, 9, 0.9);
}

.attic77-photo-dialog.is-open {
  display: flex;
}

.attic77-photo-dialog-panel {
  position: relative;
  width: min(1400px, 100%);
  height: min(88vh, 980px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.attic77-photo-dialog-image {
  display: block;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
}

.attic77-photo-dialog-close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(255, 214, 51, 0.55);
  background: rgba(16, 13, 9, 0.82);
  color: #ffffff;
  font-size: 30px;
  line-height: 1;
  cursor: pointer;
}

.attic77-photo-dialog-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border: 1px solid rgba(255, 214, 51, 0.55);
  background: rgba(16, 13, 9, 0.82);
  color: #ffffff;
  font-size: 36px;
  line-height: 1;
  cursor: pointer;
}

.attic77-photo-dialog-prev {
  left: 8px;
}

.attic77-photo-dialog-next {
  right: 8px;
}

@media (max-width: 768px) {
  .attic77-photo-dialog {
    padding: 10px;
  }

  .attic77-photo-dialog-panel {
    height: min(86vh, 760px);
  }

  .attic77-photo-dialog-nav {
    width: 42px;
    height: 42px;
    font-size: 30px;
  }
}

.landing-page .frame-18 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.landing-page .img-2 {
  position: relative;
  flex: 0 0 auto;
}

.landing-page .footer-column {
  display: inline-flex;
  height: 128px;
  justify-content: space-around;
  gap: 32px;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
  flex: 0 0 auto;
}

.landing-page .grid-column {
  display: inline-flex;
  align-items: flex-start;
  gap: 13px;
  position: relative;
  flex: 0 0 auto;
}

.landing-page .text-wrapper-15 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 16px;
  text-align: center;
  letter-spacing: 0;
  line-height: 22px;
  white-space: nowrap;
}

.landing-page .frame-19 {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.landing-page .frame-20 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 15px;
  position: relative;
  flex: 0 0 auto;
}

.landing-page .vector-6 {
  position: relative;
  width: 24.79px;
  height: 29.18px;
  aspect-ratio: 0.85;
}

.landing-page .m-floor-m {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 14px;
  letter-spacing: 0;
  line-height: 20px;
}

.landing-page .frame-21 {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 15px;
  position: relative;
  flex: 0 0 auto;
}

.landing-page .frame-22 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  position: relative;
  flex: 0 0 auto;
}

.landing-page .text-wrapper-16 {
  position: relative;
  width: 263px;
  margin-top: -1.00px;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 16px;
  text-align: right;
  letter-spacing: 0;
  line-height: 22px;
  text-decoration: underline;
}

.landing-page .element-AM-PM {
  position: relative;
  width: fit-content;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 12px;
  letter-spacing: 0;
  line-height: 20px;
  white-space: nowrap;
}

.landing-page .group-4 {
  position: absolute;
  width: 42px;
  height: 42px;
  top: 1429px;
  left: 1375px;
  background-image: url(https://c.animaapp.com/5RVLcvcp/img/expand-left-1.png);
  background-size: 100% 100%;
  border: none;
  cursor: pointer;
}

.landing-page .rectangle-2 {
  position: absolute;
  width: 89px;
  height: 376px;
  top: 1273px;
  left: 1351px;
  background-color: #000000a6;
}

.landing-page .group-5 {
  position: absolute;
  width: 89px;
  height: 376px;
  top: 1273px;
  left: 0;
}

.landing-page .overlap-4 {
  position: relative;
  height: 376px;
}

.landing-page .rectangle-3 {
  position: absolute;
  width: 89px;
  height: 376px;
  top: 0;
  left: 0;
  background-color: #000000a6;
  transform: rotate(-180.00deg);
}

.landing-page .expand-left {
  position: absolute;
  width: 42px;
  height: 42px;
  top: 167px;
  left: 23px;
  background: transparent;
  border: none;
  cursor: pointer;
}

/* Photo Gallery arrows: align + baseline-match on the homepage only. */
body.home .landing-page .group-4 {
  width: 89px;
  height: 376px;
  top: 1273px;
  left: 1351px;
  background-color: rgba(0, 0, 0, 0.65);
  background-image: url(https://c.animaapp.com/5RVLcvcp/img/expand-left-2.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 42px 42px;
  transform: rotate(180deg);
}

body.home .landing-page .rectangle-2 {
  display: none;
}

body.home .landing-page .expand-left {
  width: 89px;
  height: 376px;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Contact Form Styles */
.landing-page.form-wrapper {
  background-color: #100d09;
  display: grid;
  justify-items: center;
  align-items: start;
  width: 100vw;
}

.landing-page .form {
  background-color: var(--variable-collection-smoke);
  overflow: hidden;
  width: 1441px;
  height: 1571px;
  position: relative;
}

.landing-page .overlap-5 {
  position: absolute;
  width: 2161px;
  height: 1054px;
  top: 0;
  left: 0;
}

.landing-page .frame-23 {
  display: flex;
  flex-direction: column;
  width: 1441px;
  align-items: flex-end;
  gap: 60px;
  position: absolute;
  top: 218px;
  left: 0;
}

.landing-page .frame-24 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 40px;
  padding: 0px 48px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.landing-page .frame-25 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  position: relative;
  flex: 0 0 auto;
}

.landing-page .paragraph {
  position: relative;
  align-self: stretch;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 24px;
  letter-spacing: 0;
  line-height: 34px;
}

.landing-page .attic77-contact-intro,
.landing-page .attic77-contact-submission {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-self: stretch;
  width: 100%;
}

.landing-page .attic77-contact-mailto {
  color: var(--variable-collection-citrus);
  text-decoration: underline;
}

.landing-page .attic77-contact-mailto:hover,
.landing-page .attic77-contact-mailto:focus-visible {
  color: #ffffff;
}

.attic77-contact-page {
  width: 100%;
  max-width: 1441px;
  margin: 0 auto;
  background: var(--variable-collection-smoke);
}

.attic77-contact-shell {
  width: 100%;
  padding: 48px 48px 80px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 24px;
}

.attic77-contact-title {
  margin: 0;
  font-family: "Ranade-Medium", Helvetica;
  font-weight: 500;
  color: #ffffff;
  font-size: 60px;
  letter-spacing: -1.8px;
  line-height: 80px;
}

.attic77-contact-subtitle {
  margin: 8px 0 0;
  font-family: "Ranade-Bold", Helvetica;
  font-weight: 700;
  color: var(--variable-collection-citrus);
  font-size: 20px;
  letter-spacing: -0.4px;
  line-height: 28px;
}

.attic77-contact-copy {
  margin: 0;
  width: 100%;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 24px;
  letter-spacing: 0;
  line-height: 34px;
}

.attic77-contact-mailto {
  color: var(--variable-collection-citrus);
  text-decoration: underline;
}

.attic77-contact-mailto:hover,
.attic77-contact-mailto:focus-visible {
  color: #ffffff;
}

.attic77-contact-form-wrap {
  width: 100%;
  margin-top: 4px;
}

.attic77-contact-form-wrap .forminator-ui {
  margin: 0;
}

/* Contact page: force the active Forminator (branched logic) form text to white on dark bg. */
.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23,
.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-title,
.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-subtitle,
.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-label,
.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-description,
.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-description p,
.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-radio-label,
.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-checkbox-label,
.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-file-upload > span {
  color: #ffffff !important;
}

.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-input,
.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-textarea,
.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-input input {
  color: #ffffff !important;
  caret-color: #ffffff;
}

.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-input::placeholder,
.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-textarea::placeholder,
.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-input input::placeholder {
  color: rgba(255, 255, 255, 0.72) !important;
}

.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-select2 + .forminator-select .selection .select2-selection__rendered,
.page-template-page-contact .attic77-contact-form-wrap #forminator-module-23 .forminator-select2 + .forminator-select .selection .select2-selection__arrow {
  color: #ffffff !important;
}

.attic77-about-page {
  width: 100%;
  max-width: 1441px;
  margin: 0 auto;
  background: var(--variable-collection-smoke);
}

.attic77-about-shell {
  width: 100%;
  padding: 48px 48px 84px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 28px;
}

.attic77-about-title {
  margin: 0;
  font-family: "Ranade-Medium", Helvetica;
  font-weight: 500;
  color: #ffffff;
  font-size: 60px;
  letter-spacing: -1.8px;
  line-height: 80px;
}

.attic77-about-intro {
  width: 100%;
  display: grid;
  gap: 14px;
}

.attic77-about-intro p {
  margin: 0;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 24px;
  letter-spacing: 0;
  line-height: 34px;
}

.attic77-about-team {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 28px;
}

.attic77-about-card {
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(16, 13, 9, 0.88);
  padding: 24px;
  display: grid;
  gap: 12px;
}

.attic77-about-card-title,
.attic77-about-subtitle {
  margin: 0;
  font-family: "Ranade-Bold", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 36px;
  letter-spacing: -0.9px;
  line-height: 44px;
}

.attic77-about-card-role {
  margin: 0;
  font-family: "Ranade-Bold", Helvetica;
  font-weight: 700;
  color: var(--variable-collection-citrus);
  font-size: 18px;
  letter-spacing: -0.36px;
  line-height: 26px;
}

.attic77-about-card p,
.attic77-about-associates p {
  margin: 0;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 18px;
  letter-spacing: -0.36px;
  line-height: 27px;
}

.attic77-about-card a,
.attic77-about-associates a {
  color: var(--variable-collection-citrus);
  text-decoration: underline;
}

.attic77-about-card a:hover,
.attic77-about-card a:focus-visible,
.attic77-about-associates a:hover,
.attic77-about-associates a:focus-visible {
  color: #ffffff;
}

.attic77-about-associates {
  width: 100%;
  display: grid;
  gap: 12px;
}

@media (max-width: 1024px) {
  .attic77-contact-shell {
    padding: 36px 24px 64px;
    gap: 18px;
  }

  .attic77-contact-title {
    font-size: 46px;
    line-height: 56px;
  }

  .attic77-contact-copy {
    font-size: 20px;
    line-height: 30px;
  }

  .attic77-about-shell {
    padding: 36px 24px 64px;
    gap: 20px;
  }

  .attic77-about-title {
    font-size: 46px;
    line-height: 56px;
  }

  .attic77-about-intro p {
    font-size: 20px;
    line-height: 30px;
  }

  .attic77-about-team {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .attic77-about-card-title,
  .attic77-about-subtitle {
    font-size: 30px;
    line-height: 38px;
  }
}

@media (max-width: 768px) {
  .attic77-contact-shell {
    padding: 24px 16px 48px;
    gap: 14px;
  }

  .attic77-contact-title {
    font-size: 36px;
    line-height: 44px;
  }

  .attic77-contact-copy {
    font-size: 17px;
    line-height: 26px;
  }

  .attic77-contact-subtitle {
    margin-top: 4px;
  }

  .attic77-about-shell {
    padding: 24px 16px 48px;
    gap: 16px;
  }

  .attic77-about-title {
    font-size: 36px;
    line-height: 44px;
  }

  .attic77-about-intro p {
    font-size: 17px;
    line-height: 26px;
  }

  .attic77-about-card {
    padding: 16px;
  }

  .attic77-about-card-title,
  .attic77-about-subtitle {
    font-size: 24px;
    line-height: 32px;
  }

  .attic77-about-card p,
  .attic77-about-associates p {
    font-size: 16px;
    line-height: 24px;
  }
}

.landing-page .form-content-wrapper {
  height: 605px;
  gap: 10px;
  padding: 32px 48px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
  align-self: stretch;
  width: 100%;
}

.landing-page .form-content {
  gap: 42px;
  flex: 0 0 auto;
  margin-bottom: -234.00px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
  align-self: stretch;
  width: 100%;
}

.landing-page .frame-26 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 24px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.landing-page .text-wrapper-17 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "Ranade-Bold", Helvetica;
  font-weight: 700;
  color: var(--variable-collection-citrus);
  font-size: 20px;
  letter-spacing: -0.4px;
  line-height: 28px;
  white-space: nowrap;
}

.landing-page .column {
  display: flex;
  align-items: center;
  gap: 32px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.landing-page .div-4 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  position: relative;
  flex: 1;
  flex-grow: 1;
}

.landing-page .text-wrapper-18 {
  width: fit-content;
  white-space: nowrap;
  position: relative;
  margin-top: -1.00px;
  font-family: "Ranade-Bold", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 18px;
  letter-spacing: -0.36px;
  line-height: 26px;
}

.landing-page .input-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 14px 16px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  background-color: #2d2d2d;
  border: 1px solid;
  border-color: #404040;
}

.landing-page .placeholder-wrapper {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  position: relative;
  flex: 0 0 auto;
  width: 100%;
}

.landing-page .placeholder-wrapper input {
  background: transparent;
  border: none;
  color: #7e7e7e;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  font-size: 14px;
  letter-spacing: -0.28px;
  line-height: 22px;
  padding: 0;
  width: 100%;
  outline: none;
}

.landing-page .placeholder-wrapper input:focus {
  color: #ffffff;
}

.landing-page .email {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "Ranade-Bold", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 18px;
  letter-spacing: -0.36px;
  line-height: 26px;
  white-space: nowrap;
}

.landing-page .placeholder {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  position: relative;
  flex: 0 0 auto;
  width: 100%;
}

.landing-page .placeholder input {
  background: transparent;
  border: none;
  color: #7e7e7e;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  font-size: 14px;
  letter-spacing: -0.28px;
  line-height: 22px;
  padding: 0;
  width: 100%;
  outline: none;
}

.landing-page .placeholder input:focus {
  color: #ffffff;
}

.landing-page .input-text-2 {
  position: relative;
  align-self: stretch;
  width: 100%;
  height: 50px;
  background-color: #2d2d2d;
  border: 1px solid;
  border-color: #404040;
  padding: 14px 16px;
  color: #7e7e7e;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  font-size: 14px;
  letter-spacing: -0.28px;
  line-height: 22px;
  outline: none;
}

.landing-page .input-text-2:focus {
  color: #ffffff;
  border-color: var(--variable-collection-citrus);
}

.landing-page .text-wrapper-20 {
  width: 657px;
  margin-right: -0.50px;
  position: relative;
  margin-top: -1.00px;
  font-family: "Ranade-Bold", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 18px;
  letter-spacing: -0.36px;
  line-height: 26px;
}

.landing-page .input-text-3 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 14px 16px;
  position: relative;
  align-self: stretch;
  width: 100%;
  height: 50px;
  background-color: #2d2d2d;
  border: 1px solid;
  border-color: #404040;
}

.landing-page .input-text-3 input {
  background: transparent;
  border: none;
  color: #7e7e7e;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  font-size: 14px;
  letter-spacing: -0.28px;
  line-height: 22px;
  padding: 0;
  width: 100%;
  outline: none;
}

.landing-page .input-text-3 input:focus {
  color: #ffffff;
}

.landing-page .form-content input:not([type="hidden"]),
.landing-page .form-content textarea {
  color: #ffffff;
}

.landing-page .form-content input:not([type="hidden"])::placeholder,
.landing-page .form-content textarea::placeholder {
  color: rgba(255, 255, 255, 0.75);
}

.landing-page .placeholder-wrapper-2 {
  position: relative;
  width: 79px;
  height: 10px;
}

.landing-page .frame-27 {
  display: flex;
  align-items: center;
  gap: 12px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  cursor: pointer;
}

.landing-page .vector-8 {
  position: relative;
  width: 8.12px;
  height: 13.41px;
  aspect-ratio: 0.5;
}

.landing-page .frame-wrapper {
  display: inline-flex;
  flex-direction: column;
  height: 31px;
  align-items: flex-start;
  gap: 10px;
  padding: 4px 28px;
  position: relative;
  background-image: url(https://c.animaapp.com/5RVLcvcp/img/main-button-6@2x.png);
  background-size: cover;
  background-position: 50% 50%;
  border: none;
  cursor: pointer;
}

.landing-page .footer-top-2 {
  display: flex;
  flex-direction: column;
  width: 1441px;
  align-items: flex-start;
  gap: 24px;
  padding: 10px 60px 50px;
  position: absolute;
  top: 1302px;
  left: 0;
  background-color: var(--variable-collection-smoke);
  border-top-width: 1px;
  border-top-style: solid;
  border-color: #ffffff;
}

/* Interactive Elements */
button {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}

button:focus {
  outline: 2px solid var(--variable-collection-citrus);
  outline-offset: 2px;
}

input:focus {
  outline: 2px solid var(--variable-collection-citrus);
  outline-offset: 2px;
}

a {
  color: inherit;
  text-decoration: none;
}

a:hover {
  opacity: 0.8;
}

a:focus {
  outline: 2px solid var(--variable-collection-citrus);
  outline-offset: 2px;
}

fieldset {
  border: none;
  margin: 0;
  padding: 0;
}

legend {
  padding: 0;
}

details {
  cursor: pointer;
}

summary {
  cursor: pointer;
  list-style: none;
}

summary::-webkit-details-marker {
  display: none;
}

input[type="date"]::-webkit-calendar-picker-indicator {
  filter: invert(1);
}

/* Events Page Styles (Figma parity) */
.events-render-page {
  background: #100d09;
  color: #ffffff;
  width: 100%;
}

.events-render-shell {
  width: min(1441px, 100%);
  margin: 0 auto;
  padding: 40px 0 80px;
  display: flex;
  flex-direction: column;
  gap: 80px;
}

.events-render-section {
  display: flex;
  flex-direction: column;
  gap: 36px;
}

.events-render-title {
  margin: 0;
  padding: 0 48px;
  font-family: "Ranade-Medium", Helvetica;
  font-weight: 500;
  font-size: 60px;
  line-height: 80px;
  letter-spacing: -1.8px;
  color: #ffffff;
}

.events-render-grid {
  width: 100%;
  padding: 0 48px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 44px 28px;
}

.events-render-card {
  --attic77-event-accent: #F6BF2F;
  --attic77-event-accent-rgb: 246, 191, 47;
  display: flex;
  flex-direction: column;
  gap: 20px;
  color: #ffffff;
}

.events-render-media {
  position: relative;
  display: block;
  height: 390px;
  overflow: hidden;
}

.events-render-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.events-render-accent {
  position: absolute;
  top: -1px;
  left: calc(-116.84% - 2px);
  width: calc(139.96% + 4px);
  height: calc(100% + 2px);
  clip-path: polygon(0 0, 83.56% 0, 100% 100%, 16.39% 100%);
  opacity: 0.95;
  transform: translateZ(0);
  background: var(--attic77-event-accent);
}

.events-render-card.is-blue .events-render-accent {
  background: #3d3dff;
}

.events-render-card.is-yellow .events-render-accent {
  background: #FFD633;
}

.events-render-card.is-red .events-render-accent {
  background: #ff4e33;
}

.attic77-event-accent--interactive {
  --attic77-event-accent: #F6BF2F;
  --attic77-event-accent-rgb: 246, 191, 47;
}

.attic77-event-accent--performance {
  --attic77-event-accent: #FF4E33;
  --attic77-event-accent-rgb: 255, 78, 51;
}

.attic77-event-accent--experiential {
  --attic77-event-accent: #3D3DFF;
  --attic77-event-accent-rgb: 61, 61, 255;
}

.events-render-date-badge {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 80px;
  background: #100d09;
  color: #ffffff;
  padding: 6px 10px 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}

.events-render-date-badge strong {
  font-family: var(--secondary-mono-font-family);
  font-weight: 600;
  font-size: 46px;
  line-height: 52px;
  letter-spacing: -0.8px;
}

.events-render-date-badge em {
  font-family: var(--secondary-mono-font-family);
  font-weight: 500;
  font-style: normal;
  font-size: 18px;
  line-height: 22px;
  letter-spacing: 1px;
}

.events-render-copy {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.events-render-copy h2 {
  margin: 0;
  font-family: "Ranade-Medium", Helvetica;
  font-size: 38px;
  line-height: 45px;
  letter-spacing: -1.14px;
  color: #ffffff;
}

.events-render-title-link {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color 180ms ease, border-color 180ms ease;
}

.events-render-title-link:hover,
.events-render-title-link:focus-visible {
  color: var(--attic77-event-accent);
  border-bottom-color: rgba(var(--attic77-event-accent-rgb), 0.55);
  opacity: 1;
}

.events-render-conductor {
  margin: 0;
  font-family: "Ranade-Bold", Helvetica;
  font-size: 20px;
  line-height: 30px;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.events-render-meta {
  margin: 0;
  font-family: var(--secondary-mono-font-family);
  font-weight: 500;
  font-size: 18px;
  line-height: 26px;
  letter-spacing: 0;
}

.events-render-description {
  margin: 0;
  font-family: "Ranade-Regular", Helvetica;
  font-size: 18px;
  line-height: 26px;
  letter-spacing: -0.32px;
  color: #f3f3f3;
}

.events-render-link {
  display: inline-block;
  margin-top: 4px;
  font-family: "Ranade-Medium", Helvetica;
  font-size: 18px;
  line-height: 24px;
  color: var(--attic77-event-accent);
}

.events-render-link:hover,
.events-render-link:focus-visible {
  opacity: 1;
}

.events-render-empty {
  grid-column: 1 / -1;
  border: 1px solid #404040;
  padding: 28px;
}

.events-render-empty p {
  margin: 0;
  font-family: "Ranade-Regular", Helvetica;
  font-size: 20px;
  line-height: 30px;
}

.events-render-past-wrap .attic77-past-events-carousel {
  display: block;
  width: 100%;
  position: relative;
  top: auto;
  left: auto;
  padding: 0 48px;
  overflow: hidden;
}

.events-render-past-wrap .attic77-past-events-carousel .swiper-wrapper {
  align-items: center;
}

.events-render-past-wrap .attic77-past-events-carousel .component,
.events-render-past-wrap .attic77-past-events-carousel.swiper .swiper-slide {
  width: min(710px, 80vw);
  height: 700px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.events-render-past-wrap .attic77-past-events-carousel .vector-2 {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  object-fit: cover;
}

.events-render-past-wrap .attic77-past-events-carousel .attic77-past-event-dialog {
  position: absolute;
  inset: 0;
  z-index: 5;
  display: flex;
  align-items: flex-end;
  padding: 28px;
  background: linear-gradient(180deg, rgba(16, 13, 9, 0.1) 8%, rgba(16, 13, 9, 0.88) 72%);
  opacity: 0;
  visibility: hidden;
  transition: opacity 220ms ease, visibility 220ms ease;
}

.events-render-past-wrap .attic77-past-events-carousel .component:hover .attic77-past-event-dialog,
.events-render-past-wrap .attic77-past-events-carousel .component.is-dialog-open .attic77-past-event-dialog {
  opacity: 1;
  visibility: visible;
}

.events-render-past-wrap .attic77-past-events-carousel .attic77-past-event-dialog-inner {
  width: min(560px, calc(100% - 10px));
  max-height: 100%;
  overflow: auto;
  padding: 24px;
  background: rgba(16, 13, 9, 0.9);
  border: 1px solid rgba(var(--attic77-event-accent-rgb, 246, 191, 47), 0.28);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.events-render-past-wrap .attic77-past-events-carousel .attic77-past-event-dialog-inner .text-wrapper-5 {
  margin: 0;
  white-space: normal;
  font-family: "Ranade-Medium", Helvetica;
  font-size: 34px;
  line-height: 40px;
  text-align: left;
}

.events-render-past-wrap .attic77-past-events-carousel .attic77-past-event-dialog-inner .we-host-art {
  margin: 0;
  font-family: "Ranade-Regular", Helvetica;
  font-size: 20px;
  line-height: 30px;
}

.events-render-past-wrap .attic77-past-events-carousel .attic77-past-event-dialog-close {
  display: none;
  position: absolute;
  top: 16px;
  right: 16px;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(var(--attic77-event-accent-rgb, 246, 191, 47), 0.55);
  background: rgba(16, 13, 9, 0.88);
  color: var(--attic77-event-accent, #F6BF2F);
  font-size: 24px;
  line-height: 1;
}

.events-render-past-wrap .attic77-past-events-carousel .attic77-past-event-card {
  cursor: pointer;
}

.events-render-past-wrap .attic77-past-events-carousel .attic77-past-event-dialog {
  display: none !important;
}

.events-render-past-dialog[hidden] {
  display: none !important;
}

.events-render-past-dialog {
  margin: 32px 48px 0;
  position: relative;
  display: none;
  align-items: center;
  gap: 52px;
  padding: 36px 52px;
  background: var(--attic77-event-accent, #F6BF2F);
  color: #100d09;
  -webkit-clip-path: polygon(10% 0, 100% 0, 90% 100%, 0 100%);
  clip-path: polygon(10% 0, 100% 0, 90% 100%, 0 100%);
}

.events-render-past-dialog.is-open {
  display: flex;
}

.events-render-past-dialog-copy {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.events-render-past-dialog-title {
  margin: 0;
  font-family: "Ranade-Medium", Helvetica;
  font-size: 60px;
  line-height: 80px;
  letter-spacing: -1.8px;
}

.events-render-past-dialog-date {
  margin: 0;
  font-family: var(--secondary-mono-font-family);
  font-weight: 500;
  font-size: 38px;
  line-height: 46px;
  letter-spacing: -0.4px;
}

.events-render-past-dialog-description {
  margin: 6px 0 0;
  font-family: "Ranade-Regular", Helvetica;
  font-size: 24px;
  line-height: 37px;
  letter-spacing: -0.72px;
}

.events-render-past-dialog-media {
  width: min(473px, 44%);
  height: min(474px, 42vw);
  min-height: 260px;
  overflow: hidden;
  flex: 0 0 auto;
}

.events-render-past-dialog-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.events-render-past-dialog-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 40px;
  height: 40px;
  border: 1px solid rgba(16, 13, 9, 0.42);
  background: rgba(255, 255, 255, 0.35);
  color: #100d09;
  font-size: 28px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

@media (max-width: 1200px) {
  .events-render-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .events-render-shell {
    padding-top: 24px;
    gap: 56px;
  }

  .events-render-title {
    padding: 0 24px;
    font-size: 44px;
    line-height: 56px;
  }

  .events-render-grid {
    padding: 0 24px;
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .events-render-media {
    height: min(420px, 72vw);
  }

  .events-render-copy h2 {
    font-size: 30px;
    line-height: 38px;
  }

  .events-render-past-wrap .attic77-past-events-carousel {
    padding: 0 24px;
  }

  .events-render-past-wrap .attic77-past-events-carousel .component,
  .events-render-past-wrap .attic77-past-events-carousel.swiper .swiper-slide {
    width: min(560px, 82vw);
    height: 520px;
  }

  .events-render-past-dialog {
    margin: 24px 24px 0;
    padding: 24px 28px;
    gap: 26px;
    -webkit-clip-path: polygon(10% 0, 100% 0, 90% 100%, 0 100%);
    clip-path: polygon(10% 0, 100% 0, 90% 100%, 0 100%);
  }

  .events-render-past-dialog-title {
    font-size: 40px;
    line-height: 52px;
  }

  .events-render-past-dialog-date {
    font-size: 30px;
    line-height: 38px;
  }

  .events-render-past-dialog-description {
    font-size: 19px;
    line-height: 30px;
  }
}

@media (max-width: 768px) {
  .events-render-past-wrap .attic77-past-events-carousel .attic77-past-event-dialog {
    padding: 12px;
  }

  .events-render-past-wrap .attic77-past-events-carousel .attic77-past-event-dialog-inner {
    width: 100%;
    max-width: 100%;
    padding: 14px 14px 18px;
    gap: 8px;
  }

  .events-render-past-wrap .attic77-past-events-carousel .attic77-past-event-dialog-inner .text-wrapper-5 {
    font-size: 24px;
    line-height: 30px;
    padding-right: 30px;
  }

  .events-render-past-wrap .attic77-past-events-carousel .attic77-past-event-dialog-inner .we-host-art {
    font-size: 16px;
    line-height: 24px;
  }

  .events-render-past-wrap .attic77-past-events-carousel .attic77-past-event-dialog-close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .events-render-past-dialog {
    margin: 16px 12px 0;
    padding: 16px 16px 18px;
    gap: 14px;
    clip-path: none;
    flex-direction: column-reverse;
    align-items: stretch;
  }

  .events-render-past-wrap.is-mobile-panel-open {
    min-height: 100vh;
    display: grid;
    grid-template-rows: 50vh 50vh;
    gap: 0;
  }

  .events-render-past-wrap.is-mobile-panel-open .attic77-past-events-carousel {
    height: 50vh;
    padding: 0 12px;
    align-self: stretch;
  }

  .events-render-past-wrap.is-mobile-panel-open .attic77-past-events-carousel .component,
  .events-render-past-wrap.is-mobile-panel-open .attic77-past-events-carousel.swiper .swiper-slide {
    width: min(560px, calc(100vw - 24px));
    height: 50vh;
  }

  .events-render-past-wrap.is-mobile-panel-open .events-render-past-dialog {
    margin: 0;
    width: 100%;
    height: 50vh;
    max-height: 50vh;
    min-height: 0;
    padding: 56px 16px 18px;
    gap: 12px;
    clip-path: none;
    flex-direction: column;
    align-items: stretch;
    overflow-y: auto;
  }

  .events-render-past-wrap.is-mobile-panel-open .events-render-past-dialog-copy {
    gap: 10px;
    overflow-y: auto;
  }

  .events-render-past-wrap.is-mobile-panel-open .events-render-past-dialog-media {
    display: none;
  }

  .events-render-past-dialog-title {
    font-size: 30px;
    line-height: 36px;
  }

  .events-render-past-dialog-date {
    font-size: 22px;
    line-height: 30px;
  }

  .events-render-past-dialog-description {
    font-size: 16px;
    line-height: 24px;
  }

  .events-render-past-dialog-media {
    width: 100%;
    min-height: 180px;
    height: min(40vh, 280px);
  }

  .events-render-past-dialog-close {
    top: 12px;
    left: 12px;
    right: auto;
    width: auto;
    min-width: 44px;
    height: 36px;
    padding: 0 12px;
    border: 0;
    background: var(--attic77-event-accent, #F6BF2F);
    color: #100d09;
    font-size: 0;
    line-height: 1;
    font-family: "Ranade-Medium", Helvetica;
  }

  .events-render-past-dialog-close::before {
    content: "Back";
    font-size: 14px;
    line-height: 1;
    letter-spacing: 0.3px;
  }
}

.event-card {
  background-color: #1a1a1a;
  border-radius: 8px;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.event-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(255, 214, 51, 0.2);
}

.event-card-image {
  width: 100%;
  height: 250px;
  overflow: hidden;
}

.event-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.event-card:hover .event-card-image img {
  transform: scale(1.05);
}

.event-card-content {
  padding: 24px;
}

.event-card-title {
  font-family: "Ranade-Medium", Helvetica;
  font-weight: 500;
  color: #ffffff;
  font-size: 24px;
  letter-spacing: -0.72px;
  line-height: 32px;
  margin-bottom: 12px;
}

.event-card-date {
  font-family: var(--secondary-mono-font-family);
  font-weight: 400;
  color: var(--variable-collection-citrus);
  font-size: 14px;
  letter-spacing: 0;
  line-height: 20px;
  display: block;
  margin-bottom: 16px;
}

.event-card-excerpt {
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  color: #cccccc;
  font-size: 16px;
  letter-spacing: -0.32px;
  line-height: 24px;
  margin-bottom: 20px;
}

.event-card-link {
  font-family: "Ranade-Medium", Helvetica;
  font-weight: 500;
  color: var(--variable-collection-citrus);
  font-size: 16px;
  letter-spacing: 0;
  line-height: 22px;
  text-decoration: none;
  display: inline-block;
  transition: opacity 0.3s ease;
}

.event-card-link:hover {
  opacity: 0.8;
  text-decoration: underline;
}

.no-events {
  grid-column: 1 / -1;
  text-align: center;
  padding: 60px 20px;
}

/* About Page Styles */
.about-page .about-content {
  min-height: 2000px;
}

.about-page .frame-9 {
  margin-bottom: 40px;
}

/* Single Event Page Styles */
.single-event-page .single-event-hero {
  height: 600px;
  position: relative;
}

.single-event-page .div {
  height: auto;
  overflow: visible;
}

.single-event-page .overlap.single-event-hero {
  position: relative;
  width: 100%;
  height: auto;
  top: 0;
  left: 0;
}

.single-event-page .overlap-group.single-event-content {
  position: relative;
  width: 100%;
  height: auto;
  top: 0;
  left: 0;
  min-height: 0;
}

.single-event-image {
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  position: relative;
}

.single-event-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom, rgba(0,0,0,0.3), rgba(0,0,0,0.7));
  display: flex;
  align-items: center;
  justify-content: center;
}

.single-event-content {
  min-height: 1500px;
}

.single-event-page .frame-8 {
  position: relative;
  width: 100%;
  top: 0;
  left: 0;
  gap: 24px;
}

.single-event-page .event-meta-row {
  font-family: var(--secondary-mono-font-family);
  font-size: 20px;
  line-height: 32px;
}

.single-event-page .event-meta-row strong {
  font-family: var(--secondary-mono-font-family);
  font-weight: 600;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--attic77-event-accent, var(--variable-collection-citrus));
}

.single-event-page .event-description {
  font-size: 16px;
  line-height: 24px;
}

.single-event-page .event-description p {
  margin-bottom: 12px;
}

.single-event-page .event-description p:last-child {
  margin-bottom: 0;
}

.event-featured-image {
  width: 100%;
  margin: 40px 0;
}

.event-featured-image img {
  width: 100%;
  height: auto;
  border-radius: 8px;
}

.single-event-page .event-booking-section {
  display: flex;
  gap: 20px;
  align-items: center;
  justify-content: center;
  padding: 8px 0 0;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .events-grid {
    grid-template-columns: 1fr;
    gap: 30px;
  }
  
  .event-booking-section {
    flex-direction: column;
  }
  
  .single-event-page .single-event-hero {
    height: 400px;
  }
}

/* === Visual parity tweaks (2026-02-14) ===
 * Goal: closer parity with the exported React/Figma version without changing layout geometry.
 * Constraints: no inline CSS/JS; transform/opacity-only motion; respect reduced motion.
 */

:root {
  --attic77-smoke: #100d09;
  --attic77-citrus: #FFD633;
  --attic77-scarlet: #ff4e33;
  --attic77-sapphire: #3d3dff;

  /* Matches export facilities overlay: rgba(0,0,0,0.58) + image opacity */
  --attic77-scrim-strong: rgba(0, 0, 0, 0.58);
}

/* Font-family aliases to align with export naming without changing the actual font files. */
@font-face {
  font-family: "Ranade_Variable";
  src: url("https://anima-uploads.s3.amazonaws.com/projects/6305ce7810f184b075cd8bdb/fonts/ranade-regular.otf")
    format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Ranade_Variable";
  src: url("https://anima-uploads.s3.amazonaws.com/projects/6802b44c39e2720d46fa5871/fonts/ranade-medium.otf")
    format("opentype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Ranade_Variable";
  src: url("https://anima-uploads.s3.amazonaws.com/projects/6538e583a53b653b9b2e80e9/fonts/ranade-bold.otf")
    format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* 1) Colours and overlays (scrims, contrast) */
.landing-page .div {
  background-color: var(--attic77-smoke);
}

/* Facilities section: add a consistent scrim overlay, matching export contrast. */
.landing-page .frame-13 {
  position: relative;
  isolation: isolate;
}

.landing-page .frame-13::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--attic77-scrim-strong);
  pointer-events: none;
  z-index: 0;
}

.landing-page .frame-13 > * {
  position: relative;
  z-index: 1;
}

/* Ensure main image crops like the export (no distortion). */
.landing-page img.rectangle {
  display: block;
  width: 100%;
  object-fit: cover;
  object-position: center;
}

/* 2) Decorative nav shapes hover effects (transform-only, no layout shift) */
.landing-page .overlap-group-wrapper,
.landing-page .overlap-wrapper,
.landing-page a.group-3 {
  transform-origin: 50% 50%;
  transition: transform 300ms ease, filter 300ms ease;
  will-change: transform;
}

.landing-page .overlap-group-wrapper:hover,
.landing-page .overlap-group-wrapper:focus-within,
.landing-page .overlap-wrapper:hover,
.landing-page .overlap-wrapper:focus-within,
.landing-page a.group-3:hover,
.landing-page a.group-3:focus-visible {
  transform: scale(1.02);
}

/* 3) Hover polish for cards/tiles */
.landing-page .component {
  cursor: pointer;
  transform-origin: 50% 50%;
  transition: transform 300ms ease;
  will-change: transform;
}

.landing-page .component:hover,
.landing-page .component:focus-within {
  transform: scale(1.05);
  z-index: 10;
}

.landing-page .frame-16 {
  transform-origin: 50% 50%;
  transition: transform 300ms ease;
  will-change: transform;
}

.landing-page .frame-16:hover,
.landing-page .frame-16:focus-within {
  transform: scale(1.05);
}

/* Arrow buttons: match export hover affordance. */
.landing-page .expand-left,
.landing-page .group-4 {
  transition: transform 200ms ease, opacity 200ms ease;
  will-change: transform;
}

.landing-page .expand-left:hover,
.landing-page .group-4:hover,
.landing-page .expand-left:focus-visible,
.landing-page .group-4:focus-visible {
  transform: scale(1.05);
}

/* If Swiper adds pagination, hide it for parity (export uses arrows + snapping feel). */
.landing-page .frame-5 .swiper-pagination {
  display: none;
}

/* Home hero only: show clickable pagination dots without changing carousel geometry. */
body.home .landing-page .frame-5:not(.attic77-past-events-carousel) .swiper-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  bottom: 22px;
  left: 0;
  right: 0;
  z-index: 12;
}

body.home .landing-page .frame-5:not(.attic77-past-events-carousel) .swiper-pagination-bullet {
  width: 9px;
  height: 9px;
  margin: 0 !important;
  background: rgba(255, 255, 255, 0.46);
  opacity: 1;
}

body.home .landing-page .frame-5:not(.attic77-past-events-carousel) .swiper-pagination-bullet-active {
  background: var(--variable-collection-citrus);
}

/* Past events carousel: hover CTA + click-open parallelogram dialog */
.attic77-past-event-cta {
  display: none;
}

.landing-page .attic77-past-events-carousel .component,
.landing-page .attic77-past-events-carousel.swiper .swiper-slide {
  transform: none;
  overflow: visible;
  isolation: isolate;
}

.landing-page .attic77-past-events-carousel .component:hover,
.landing-page .attic77-past-events-carousel .component:focus-within {
  transform: none;
}

.landing-page .attic77-past-events-carousel .attic77-past-event-cta {
  display: inline-flex;
  position: absolute;
  left: 50%;
  bottom: 20px;
  z-index: 7;
  transform: translateX(-50%);
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(var(--attic77-event-accent-rgb, 246, 191, 47), 0.75);
  background: rgba(16, 13, 9, 0.88);
  color: var(--attic77-event-accent, #F6BF2F);
  font-family: "Ranade-Medium", Helvetica;
  font-size: 16px;
  line-height: 22px;
  padding: 10px 18px;
  white-space: nowrap;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 180ms ease, visibility 180ms ease, transform 180ms ease, background-color 180ms ease;
}

.landing-page .attic77-past-events-carousel .component:hover .attic77-past-event-cta,
.landing-page .attic77-past-events-carousel .component:focus-within .attic77-past-event-cta {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(-2px);
}

.landing-page .attic77-past-events-carousel .component.is-dialog-open .attic77-past-event-cta {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.landing-page .attic77-past-events-carousel .attic77-past-event-cta:hover,
.landing-page .attic77-past-events-carousel .attic77-past-event-cta:focus-visible {
  background: rgba(16, 13, 9, 0.98);
}

.landing-page .attic77-past-events-carousel .attic77-past-event-dialog {
  position: absolute;
  top: 50%;
  right: 0;
  width: min(560px, calc(100% - 24px));
  max-height: calc(100% - 24px);
  z-index: 8;
  display: flex;
  align-items: stretch;
  justify-content: stretch;
  padding: 28px 30px 24px 42px;
  background: rgba(16, 13, 9, 0.95);
  border: 1px solid rgba(var(--attic77-event-accent-rgb, 246, 191, 47), 0.32);
  clip-path: polygon(10% 0, 100% 0, 90% 100%, 0 100%);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translate(16%, -50%) scale(0.98);
  transition: opacity 220ms ease, visibility 220ms ease, transform 220ms ease;
  box-sizing: border-box;
}

.landing-page .attic77-past-events-carousel .component.is-dialog-open .attic77-past-event-dialog {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate(16%, -50%) scale(1);
}

.landing-page .attic77-past-events-carousel .attic77-past-event-dialog-inner {
  width: 100%;
  max-height: 100%;
  overflow: auto;
  padding: 0;
  background: transparent;
  border: 0;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.landing-page .attic77-past-events-carousel .attic77-past-event-dialog-inner .text-wrapper-5 {
  margin: 0;
  white-space: normal;
  font-size: 34px;
  line-height: 40px;
  text-align: left;
}

.landing-page .attic77-past-events-carousel .attic77-past-event-dialog-inner .we-host-art {
  margin: 0;
  font-size: 20px;
  line-height: 30px;
}

.landing-page .attic77-past-events-carousel .attic77-past-event-dialog-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(var(--attic77-event-accent-rgb, 246, 191, 47), 0.55);
  background: rgba(16, 13, 9, 0.88);
  color: var(--attic77-event-accent, #F6BF2F);
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
}

/* 3) Scroll reveals: gated by html.attic77-reveal (added by theme JS). */
html.attic77-reveal .attic77-reveal {
  opacity: 0;
  transform: translate3d(0, 20px, 0);
  transition: opacity 600ms ease, transform 600ms ease;
  will-change: opacity, transform;
}

html.attic77-reveal .attic77-reveal.attic77-inview {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  .landing-page .component,
  .landing-page .frame-16,
  .landing-page .overlap-group-wrapper,
  .landing-page .overlap-wrapper,
  .landing-page a.group-3,
  .landing-page .expand-left,
  .landing-page .group-4 {
    transition: none !important;
    transform: none !important;
  }

  html.attic77-reveal .attic77-reveal {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

@media (hover: none), (pointer: coarse) {
  .landing-page .attic77-past-events-carousel .attic77-past-event-cta {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%);
  }

  .landing-page .attic77-past-events-carousel .component.is-dialog-open .attic77-past-event-dialog {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
}

@media (max-width: 768px) {
  .landing-page .attic77-past-events-carousel .attic77-past-event-cta {
    bottom: 12px;
    font-size: 14px;
    line-height: 20px;
    padding: 8px 14px;
  }

  .landing-page .attic77-past-events-carousel .attic77-past-event-dialog {
    inset: 12px;
    width: auto;
    max-height: none;
    padding: 12px;
    clip-path: none;
    transform: none;
    align-items: stretch;
  }

  .landing-page .attic77-past-events-carousel .component.is-dialog-open .attic77-past-event-dialog {
    transform: none;
  }

  .landing-page .attic77-past-events-carousel .attic77-past-event-dialog-inner {
    width: 100%;
    max-width: 100%;
    max-height: 100%;
    padding: 14px 14px 18px;
    gap: 8px;
  }

  .landing-page .attic77-past-events-carousel .attic77-past-event-dialog-inner .text-wrapper-5 {
    font-size: 24px;
    line-height: 30px;
    padding-right: 30px;
  }

  .landing-page .attic77-past-events-carousel .attic77-past-event-dialog-inner .we-host-art {
    font-size: 16px;
    line-height: 24px;
  }

  .landing-page .attic77-past-events-carousel .attic77-past-event-dialog-close {
    top: 8px;
    right: 8px;
    border: 0;
    background: var(--attic77-event-accent, #F6BF2F);
    color: #100d09;
  }
}

/* === Homepage responsive parity (2026-02-15) ===
 * Goal: make the existing homepage CSS responsive (mobile + tablet) without rebuilding the layout.
 * Constraints: homepage-scoped only; desktop unchanged; CSS-only.
 *
 * Strategy:
 * - Under breakpoints, override fixed 1440px widths/heights to use 100% width and auto height.
 * - Convert key absolute-positioned homepage sections to flow layout for small screens.
 * - Stack content and reduce padding/typography so there's no horizontal scrolling.
 */

/* Desktop homepage: remove dead space below bottom nav so it sits flush with footer. */
@media (min-width: 1025px) {
  body.home .landing-page .div {
    height: 4035px;
  }

  /* Tighten spacing between hero carousel and Welcome heading on desktop. */
  body.home .landing-page .overlap-group {
    top: 884px;
  }

  body.home .footer-top {
    margin-top: -1px;
  }
}

@media (max-width: 1024px) {
  body.home {
    overflow-x: hidden;
  }

  body.home .landing-page.landing-page-wrapper {
    width: 100%;
    overflow-x: hidden;
  }

  /* Header (outside .landing-page): keep React spacing intent, but fluid on tablet/mobile. */
  body.home header.frame {
    width: 100%;
    max-width: 100%;
    padding: 24px;
  }

  body.home header.frame .frame-2 {
    gap: 32px;
    min-width: 0;
    width: 100%;
    justify-content: space-between;
  }

  body.home header.frame .menu {
    gap: 28px;
    min-width: 0;
  }

  body.home header.frame .frame-3 {
    gap: 12px;
    min-width: 0;
  }

  body.home header.frame .main-button {
    padding: 4px 16px;
  }

  body.home .landing-page .div {
    width: 100%;
    max-width: 100%;
    height: auto;
    min-height: 100vh;
  }

  body.home .landing-page .overlap {
    position: relative;
    width: 100%;
    height: auto;
    left: auto;
    top: auto;
  }

  body.home .landing-page .frame-5,
  body.home .landing-page .attic77-events-carousel {
    position: relative;
    top: auto;
    left: auto;
    width: 100%;
    padding: 0 24px;
    margin-top: 135px;
    overflow-x: hidden;
  }

  body.home .landing-page .component,
  body.home .landing-page .attic77-events-carousel.swiper .swiper-slide {
    width: min(560px, 86vw);
    height: 520px;
  }

  body.home .landing-page .vector-2 {
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
  }

  body.home .landing-page .frame-6 {
    width: min(320px, 70vw);
  }

  body.home .landing-page .text-wrapper-5 {
    white-space: normal;
  }

  body.home .landing-page .text-wrapper-6 {
    font-size: 96px;
    line-height: 120px;
    white-space: nowrap;
  }

  body.home .landing-page .overlap-group {
    position: relative;
    top: auto;
    left: auto;
    width: 100%;
    height: auto;
    margin-top: 40px;
  }

  body.home .landing-page .frame-8 {
    position: relative;
    width: 100%;
    gap: 40px;
  }

  body.home .landing-page .frame-9 {
    padding: 0 24px;
  }

  body.home .landing-page .p {
    font-size: 56px;
    line-height: 64px;
  }

  body.home .landing-page .we-host-art {
    font-size: 20px;
    line-height: 32px;
  }

  body.home .landing-page .rectangle {
    height: 420px;
  }

  body.home .landing-page .frame-10 {
    padding: 0 24px;
  }

  body.home .landing-page .text-wrapper-7 {
    font-size: 44px;
    line-height: 54px;
    white-space: normal;
  }

  body.home .landing-page .frame-14,
  body.home .landing-page .footer-top {
    width: 100%;
  }

  body.home .landing-page .frame-15,
  body.home .landing-page .frame-17 {
    flex-wrap: wrap;
    padding: 0 24px;
    gap: 24px;
  }

  body.home .landing-page .frame-16 {
    flex: 1 1 calc(50% - 24px);
    min-width: 220px;
  }

  body.home .landing-page .div-3,
  body.home .landing-page .bottom-nav,
  body.home .landing-page .group-2 {
    width: 100%;
    height: auto;
  }

  /* Bottom nav: keep the links, drop large decorative shapes that cause overflow. */
  body.home .landing-page .group,
  body.home .landing-page .vector-5 {
    display: none;
  }

  body.home .landing-page .overlap-group-wrapper,
  body.home .landing-page .overlap-wrapper,
  body.home .landing-page a.group-3 {
    position: relative;
    left: auto;
    top: auto;
    width: min(520px, calc(100% - 48px));
    height: auto;
    margin: 0 auto 16px;
  }

  body.home .landing-page .overlap-group-2,
  body.home .landing-page .overlap-2,
  body.home .landing-page .overlap-3 {
    width: 100%;
    height: auto;
    background-size: cover;
    background-position: 50% 50%;
  }

  body.home .landing-page .text-wrapper-12,
  body.home .landing-page .text-wrapper-13,
  body.home .landing-page .text-wrapper-14 {
    position: relative;
    left: auto;
    top: auto;
    display: block;
    text-align: center;
    padding: 24px 20px;
  }

  body.home .landing-page .footer-top {
    padding: 10px 24px 40px;
  }

  body.home .footer-top {
    width: 100%;
    max-width: 100%;
    padding: 10px 24px 40px;
  }
}

@media (max-width: 768px) {
  body.home header.frame {
    padding: 16px;
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
  }

  body.home header.frame .frame-2 {
    width: 100%;
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
  }

  body.home header.frame .menu {
    width: 100%;
    gap: 18px;
    flex-wrap: wrap;
  }

  body.home header.frame .text-wrapper-2,
  body.home header.frame .text-wrapper-3 {
    font-size: 14px;
    letter-spacing: 1px;
  }

  body.home header.frame .frame-3 {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  body.home header.frame .main-button {
    width: 100%;
    justify-content: center;
    padding: 4px 12px;
  }

  body.home header.frame .frame-4 {
    justify-content: center;
  }

  body.home .footer-top {
    padding: 10px 16px 32px;
  }

  body.home .footer-top .frame-18,
  body.home .footer-top .frame-19 {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
  }

  body.home .footer-top .footer-column,
  body.home .footer-top .frame-12,
  body.home .footer-top .frame-21 {
    width: 100%;
    align-items: flex-start;
  }

  body.home .footer-top .grid-column {
    width: 100%;
    flex-wrap: wrap;
    gap: 10px 14px;
  }

  body.home .footer-top .m-floor-m,
  body.home .footer-top .text-wrapper-16 {
    width: 100%;
    max-width: 100%;
    text-align: left;
    overflow-wrap: anywhere;
  }

  /* Stack headline/paragraph rows. */
  body.home .landing-page .frame-9 {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }

  body.home .landing-page .p {
    font-size: 40px;
    line-height: 48px;
  }

  body.home .landing-page .we-host-art {
    font-size: 18px;
    line-height: 28px;
  }

  body.home .landing-page .rectangle {
    height: 320px;
  }

  /* Facilities: single column for readability. */
  body.home .landing-page .frame-16 {
    flex: 1 1 100%;
    min-width: 0;
  }

  /* Footer: stack columns. */
  body.home .landing-page .frame-18,
  body.home .landing-page .frame-19 {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
  }

  body.home .landing-page .grid-column {
    flex-direction: column;
    gap: 12px;
  }

  body.home .landing-page .frame-21 {
    align-items: flex-start;
  }

  /* Carousel arrows: rely on swipe on touch widths to avoid awkward overlay placement. */
  body.home .landing-page .group-4,
  body.home .landing-page .rectangle-2,
  body.home .landing-page .group-5 {
    display: none;
  }

  body.home .landing-page .vector-4 {
    display: none;
  }
}

@media (max-width: 480px) {
  body.home header.frame .frame-3 {
    grid-template-columns: 1fr;
  }

  body.home header.frame .text-wrapper-4 {
    font-size: 14px;
    line-height: 20px;
  }

  body.home .footer-top {
    padding: 10px 14px 28px;
  }

  body.home .footer-top .text-wrapper-15,
  body.home .footer-top .text-wrapper-16 {
    font-size: 14px;
    line-height: 20px;
  }

  body.home .landing-page .frame-5,
  body.home .landing-page .attic77-events-carousel {
    padding: 0 16px;
    margin-top: 110px;
  }

  body.home .landing-page .component,
  body.home .landing-page .attic77-events-carousel.swiper .swiper-slide {
    height: 420px;
  }

  body.home .landing-page .text-wrapper-5 {
    font-size: 28px;
    line-height: 34px;
  }

  body.home .landing-page .text-wrapper-6 {
    font-size: 72px;
    line-height: 90px;
  }
}

/* WooCommerce checkout parity */
.woocommerce-page .attic77-woocommerce-shell {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 24px 24px 80px;
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.woocommerce-page .attic77-checkout-banner {
  position: relative;
  width: 100%;
  min-height: 170px;
  height: min(320px, 36vw);
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: #100d09;
}

.woocommerce-page .attic77-checkout-banner img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.woocommerce-page .attic77-checkout-banner-title {
  position: absolute;
  left: 18px;
  bottom: 18px;
  margin: 0;
  padding: 8px 12px;
  background: rgba(16, 13, 9, 0.72);
  color: #ffffff;
  font-family: "Ranade-Medium", Helvetica;
  font-size: 28px;
  line-height: 34px;
  letter-spacing: -0.7px;
}

.woocommerce-page .attic77-woocommerce-content {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}

.woocommerce-page .attic77-checkout-page-heading {
  width: 100%;
}

.woocommerce-page .attic77-checkout-page-title {
  margin: 0;
  color: #ffffff;
  font-family: "Ranade-Regular", Helvetica;
  font-weight: 400;
  font-size: clamp(36px, 5vw, 54px);
  letter-spacing: -1.2px;
  line-height: 1.1;
}

.woocommerce-page .woocommerce {
  color: #ffffff;
}

.woocommerce-page .woocommerce h1,
.woocommerce-page .woocommerce h2,
.woocommerce-page .woocommerce h3 {
  font-family: "Ranade-Medium", Helvetica;
  color: #ffffff;
}

.woocommerce-page .woocommerce .woocommerce-info,
.woocommerce-page .woocommerce .woocommerce-message,
.woocommerce-page .woocommerce .woocommerce-error {
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: rgba(16, 13, 9, 0.9);
  color: #ffffff;
}

.woocommerce-page .woocommerce form.checkout,
.woocommerce-page .woocommerce .woocommerce-checkout-review-order {
  background: #100d09;
  border: 1px solid rgba(255, 255, 255, 0.16);
  padding: 24px;
}

.woocommerce-page .woocommerce .form-row label {
  color: #ffffff;
  font-family: "Ranade-Regular", Helvetica;
  letter-spacing: 0.2px;
}

.woocommerce-page .woocommerce input.input-text,
.woocommerce-page .woocommerce textarea,
.woocommerce-page .woocommerce select {
  background: #0a0a0a;
  border: 1px solid rgba(255, 255, 255, 0.32);
  color: #ffffff;
  border-radius: 0;
  min-height: 46px;
}

.woocommerce-page .woocommerce input.input-text:focus,
.woocommerce-page .woocommerce textarea:focus,
.woocommerce-page .woocommerce select:focus {
  border-color: var(--variable-collection-citrus);
  outline: 0;
}

.woocommerce-page .woocommerce table.shop_table {
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-collapse: collapse;
  background: #0f0f0f;
}

.woocommerce-page .woocommerce table.shop_table th,
.woocommerce-page .woocommerce table.shop_table td {
  border-color: rgba(255, 255, 255, 0.15);
  color: #ffffff;
  font-family: "Ranade-Regular", Helvetica;
}

.woocommerce-page .woocommerce-checkout-review-order-table .product-total,
.woocommerce-page .woocommerce-checkout-review-order-table .order-total td {
  color: var(--variable-collection-citrus);
  font-family: var(--secondary-mono-font-family);
  font-weight: 500;
}

.woocommerce-page .woocommerce #place_order {
  width: 100%;
  border: 0;
  border-radius: 0;
  background: var(--variable-collection-citrus);
  color: #100d09;
  font-family: "Ranade-Medium", Helvetica;
  font-size: 15px;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  padding: 14px 18px;
}

.woocommerce-page .woocommerce #place_order:hover,
.woocommerce-page .woocommerce #place_order:focus-visible {
  filter: brightness(1.05);
}

.woocommerce-page .woocommerce-checkout-review-order-table tr.cart-subtotal {
  display: none;
}

.woocommerce-page .woocommerce-form-coupon-toggle,
.woocommerce-page form.checkout_coupon,
.woocommerce-page .showcoupon {
  display: none !important;
}

.woocommerce-page .woocommerce-message .wc-forward,
.woocommerce-page .woocommerce-info .showcoupon {
  display: none !important;
}

.woocommerce-page .hostinger-reach-optin {
  display: none !important;
}

.woocommerce-page .attic77-checkout-consent {
  margin: 14px 0 0;
  font-family: "Ranade-Regular", Helvetica;
  font-size: 13px;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.86);
}

.woocommerce-page .attic77-checkout-consent a {
  color: var(--variable-collection-citrus);
  text-decoration: underline;
}

.woocommerce-page .woocommerce .woocommerce-terms-and-conditions-wrapper,
.woocommerce-page .woocommerce .shipping_address {
  display: none;
}

@media (max-width: 768px) {
  .woocommerce-page .attic77-woocommerce-shell {
    padding: 16px 14px 56px;
    gap: 14px;
  }

  .woocommerce-page .attic77-checkout-banner {
    min-height: 140px;
    height: min(240px, 42vw);
  }

  .woocommerce-page .attic77-checkout-banner-title {
    left: 10px;
    right: 10px;
    bottom: 10px;
    font-size: 20px;
    line-height: 26px;
  }

  .woocommerce-page .attic77-woocommerce-content {
    padding: 0;
  }

  .woocommerce-page .attic77-checkout-page-title {
    font-size: 44px;
    letter-spacing: -0.9px;
  }

  .woocommerce-page .woocommerce form.checkout,
  .woocommerce-page .woocommerce .woocommerce-checkout-review-order {
    padding: 14px;
  }
}

/* Keep original home bottom-nav geometry on desktop/tablet pointer devices. */
@media (min-width: 769px) and (hover: hover) and (pointer: fine) {
  body.home .landing-page .div-3 {
    width: 1440px;
    height: 810px;
  }

  body.home .landing-page .bottom-nav {
    height: 810px;
  }

  body.home .landing-page .group {
    display: block;
    position: absolute;
    width: 123px;
    height: 248px;
    top: 562px;
    left: 1317px;
  }

  body.home .landing-page .group-2 {
    width: 1440px;
    height: 810px;
    position: absolute;
    top: 0;
    left: 0;
  }

  body.home .landing-page .overlap-group-wrapper {
    position: absolute;
    width: 759px;
    height: 810px;
    top: 0;
    left: 65px;
    margin: 0;
  }

  body.home .landing-page .overlap-wrapper {
    position: absolute;
    width: 345px;
    height: 255px;
    top: 0;
    left: 619px;
    margin: 0;
  }

  body.home .landing-page a.group-3 {
    position: absolute;
    width: 637px;
    height: 307px;
    top: 255px;
    left: 683px;
    margin: 0;
  }

  body.home .landing-page .vector-5 {
    display: block;
  }

  body.home .landing-page .text-wrapper-12 {
    position: absolute;
    top: 357px;
    left: 273px;
    padding: 0;
    text-align: initial;
  }

  body.home .landing-page .text-wrapper-13 {
    position: absolute;
    top: 79px;
    left: 99px;
    padding: 0;
    text-align: initial;
  }

  body.home .landing-page .text-wrapper-14 {
    position: absolute;
    top: 102px;
    left: 222px;
    padding: 0;
    text-align: initial;
  }
}
