:root {
  --color-text: #f5f3ea;
  --overlay: rgba(0, 0, 0, 0.24);
  --overlay-hover: rgba(0, 0, 0, 0.14);
  --font-sabon: "Sabon", "Times New Roman", serif;
  --font-sackers: "Sackers Gothic", "Arial Narrow", sans-serif;
  --logo-color: #ffffff;
  --desktop-logo-size-v1: 200px;
  --desktop-logo-size-v2: 200px;
  --desktop-logo-size-v3: 200px;
  --desktop-logo-size: var(--desktop-logo-size-v1);
  --mobile-top-logo-size: 170px;
  --desktop-kicker-size: 16px;
  --desktop-label-size: 21px;
  --desktop-label-letter-spacing: 0.22em;
  --mobile-kicker-size: 16px;
  --mobile-label-size: 18px;
  --desktop-top-margin: 60px;
  --desktop-top-logo-offset: 60px;
  --desktop-bottom-text-offset: clamp(2.4rem, 6vh, 4.2rem);
  --desktop-shop-image: url("../assets/images/shop-desktop.png");
  --desktop-estate-image: url("../assets/images/estate-desktop.png");
  --mobile-shop-image: url("../assets/images/shop-mobile.png");
  --mobile-estate-image: url("../assets/images/estate-mobile.png");
  --variant-shop-image: url("../assets/images/shop-version-top-bottom.png");
}

body.variant-top-bottom {
  --desktop-shop-image: var(--variant-shop-image);
  --mobile-shop-image: var(--variant-shop-image);
}

body.version-1 {
  --desktop-logo-size: var(--desktop-logo-size-v1);
}

body.version-2 {
  --desktop-logo-size: var(--desktop-logo-size-v2);
  --desktop-top-logo-offset: clamp(1rem, 2.2vh, 2rem);
  --desktop-top-margin: 0px;
}

body.version-3 {
  --desktop-logo-size: var(--desktop-logo-size-v3);
  --desktop-top-logo-offset: clamp(1rem, 2.2vh, 2rem);
  --desktop-top-margin: 0px;
}

body.variant-top-bottom .reel-slide__overlay {
  width: 100%;
  min-height: 100%;
  align-content: end;
}

@font-face {
  font-family: "Sabon";
  src: url("../assets/fonts/Sabon.otf") format("truetype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Sabon";
  src: url("../assets/fonts/SabonItalic.otf") format("truetype");
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Sackers Gothic";
  src: url("../assets/fonts/SackersGothicLight.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}



*,
*::before,
*::after {
  box-sizing: border-box;
}

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

body {
  font-family: var(--font-sabon);
  color: var(--color-text);
  background: #000;
  overflow: hidden;
}

body.overlay-open {
  overflow: hidden;
}

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

.info-trigger {
  position: fixed;
  top: 10px;
  right: 0px;
  z-index: 40;
  width: 40px;
  height: 40px;
  border: 0;
  background: transparent;
  color: #f5f3ea;
  cursor: pointer;
}

.info-trigger__glyph {
  font-family: var(--font-sabon);
  font-style: italic;
  font-size: 30px;
  line-height: 1;
}

.info-overlay {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: grid;
  background: #9bac9f;
  color: #0f090b;
}

.info-overlay[hidden] {
  display: none;
}

.info-overlay__close {
  position: absolute;
  top: 0.8rem;
  right: 5px;
  border: 0;
  background: transparent;
  color: #0f090b;
  font-family: var(--font-sabon);
  font-size: 30px;
  cursor: pointer;
  opacity: 0.8;
}

.info-overlay__inner {
  min-height: 100%;
  display: grid;
  align-content: center;
  justify-items: center;
  text-align: center;
  padding: 2rem 1.5rem 3rem;
  gap: 8rem;
}

.info-overlay__intro {
  margin: 0;
  max-width: 36ch;
  font-size: 16px;
  line-height: 1.5;
}

.info-overlay__contact {
  margin: 0;
  font-size: 16px;
  line-height: 1.35;
}

.info-overlay__contact a {
  font-style: italic;
}

.desktop-hero {
  position: relative;
  display: flex;
  min-height: 100dvh;
  overflow: hidden;
}

.hero-half {
  position: relative;
  flex: 1 1 50%;
  display: grid;
  place-items: center;
  isolation: isolate;
  transition: transform 180ms ease, filter 180ms ease;
}

.hero-half--left {
  margin-right: -1px;
}

.hero-half::before {
  content: "";
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  z-index: -2;
}

.hero-half::after {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--overlay);
  transition: background 180ms ease;
  z-index: -1;
}

.hero-half--left::before {
  background-image: var(--desktop-shop-image);
}

.hero-half--right::before {
  background-image: var(--desktop-estate-image);
}

.hero-half__text {
  display: grid;
  justify-items: center;
  gap: 0.25rem;
}

.hero-half__kicker {
  font-family: var(--font-sabon);
  font-style: italic;
  font-size: var(--desktop-kicker-size);
  letter-spacing: 0.02em;
  line-height: 1.1;
}

.hero-half__label {
  font-family: var(--font-sackers);
  text-transform: lowercase;
  letter-spacing: var(--desktop-label-letter-spacing);
  font-size: var(--desktop-label-size);
  padding: 0.4rem 0.8rem;
}

.hero-half:focus-visible,
.reel-slide:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.92);
  outline-offset: -3px;
}

.hero-half:hover::after,
.hero-half:focus-visible::after {
  background: var(--overlay-hover);
}

.hero-center {
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  z-index: 5;
}

.hero-center__home-link,
.mobile-top-logo__home-link {
  display: block;
  pointer-events: auto;
}

.logo-mark {
  display: block;
  background-color: var(--logo-color);
  -webkit-mask-image: url("../assets/images/the-break-logo.svg");
  mask-image: url("../assets/images/the-break-logo.svg");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
}

.hero-center__logo {
  width: var(--desktop-logo-size);
  aspect-ratio: 15799 / 2005;
  height: auto;
  opacity: 0.92;
}

.desktop-hero--top-bottom .hero-half {
  place-items: end center;
  padding-bottom: var(--desktop-bottom-text-offset);
}

.desktop-hero--top-bottom .hero-half__text {
  align-self: end;
}

.desktop-hero--top-bottom .hero-center {
  top: calc(var(--desktop-top-logo-offset) + var(--desktop-top-margin));
  left: 50%;
  transform: translateX(-50%);
}

.desktop-hero--top-middle .hero-center {
  top: calc(var(--desktop-top-logo-offset) + var(--desktop-top-margin));
  left: 50%;
  transform: translateX(-50%);
}

.mobile-reel-wrap {
  display: none;
}

.mobile-top-logo {
  position: fixed;
  top: calc(env(safe-area-inset-top, 0px) + 1rem);
  left: 50%;
  transform: translateX(-50%);
  z-index: 20;
}

.mobile-top-logo__mark {
  width: var(--mobile-top-logo-size);
  aspect-ratio: 15799 / 2005;
  opacity: 0.95;
}

.mobile-reel {
  height: 100dvh;
  overflow-y: auto;
  overscroll-behavior-y: contain;
  scroll-snap-type: y mandatory;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
  scrollbar-width: none;
}

.mobile-reel::-webkit-scrollbar {
  display: none;
}

.reel-slide {
  min-height: 100dvh;
  scroll-snap-align: start;
  scroll-snap-stop: always;
  position: relative;
  display: grid;
  place-items: center;
  background-size: cover;
  background-position: center;
}

.reel-slide--shop {
  background-image: linear-gradient(var(--overlay), var(--overlay)),
    var(--mobile-shop-image);
}

.reel-slide--estate {
  background-image: linear-gradient(var(--overlay), var(--overlay)),
    var(--mobile-estate-image);
}

.reel-slide__overlay {
  display: grid;
  justify-items: center;
  align-content: end;
  gap: 0.75rem;
  text-align: center;
}

.reel-slide__text {
  display: grid;
  justify-items: center;
  gap: 0.3rem;
}

.reel-slide__kicker {
  font-family: var(--font-sabon);
  font-style: italic;
  font-size: var(--mobile-kicker-size);
  line-height: 1.15;
}

.reel-slide__label {
  font-family: var(--font-sackers);
  text-transform: lowercase;
  letter-spacing: 0.1em;
  font-size: var(--mobile-label-size);
}

@media (max-width: 900px) {
  html,
  body {
    overflow: hidden;
    height: 100dvh;
  }

  .desktop-hero {
    display: none;
  }

  .mobile-reel-wrap {
    display: block;
    position: fixed;
    inset: 0;
    overflow: hidden;
  }
}

@media (min-width: 901px) {
  .mobile-reel-wrap {
    display: none;
  }

  .mobile-top-logo {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero-half,
  .hero-half::after {
    transition: none;
  }
}
