@font-face {
  font-display: swap;
  font-family: "Commuters Sans";
  font-style: normal;
  font-weight: 400;
  src: url("assets/fonts/commuterssans-regular.otf") format("opentype");
}

@font-face {
  font-display: swap;
  font-family: "Commuters Sans";
  font-style: normal;
  font-weight: 600;
  src: url("assets/fonts/commuterssans-semibold.otf") format("opentype");
}

@font-face {
  font-display: swap;
  font-family: "Commuters Sans";
  font-style: normal;
  font-weight: 700;
  src: url("assets/fonts/commuterssans-bold.otf") format("opentype");
}

@font-face {
  font-display: swap;
  font-family: "Commuters Sans";
  font-style: normal;
  font-weight: 800;
  src: url("assets/fonts/commuterssans-heavy.otf") format("opentype");
}

:root {
  --black: #000000;
  --cream: #c4ac88;
  --white: #ffffff;
  --frame-w: min(100vw, 56.25svh);
  --frame-h: calc(var(--frame-w) * 1.77777778);
  color-scheme: dark;
}

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

html,
body {
  width: 100%;
  height: 100%;
  margin: 0;
  overflow: hidden;
  background: var(--black);
  color: var(--white);
  font-family: "Commuters Sans", Arial, sans-serif;
  overscroll-behavior: none;
}

body {
  min-width: 320px;
  touch-action: none;
}

.stage {
  width: 100vw;
  transform: translate3d(0, 0, 0);
  transition: transform 940ms cubic-bezier(0.72, 0, 0.16, 1);
  will-change: transform;
}

.panel {
  position: relative;
  display: grid;
  width: 100vw;
  height: 100svh;
  place-items: center;
  overflow: hidden;
  background: var(--black);
}

.frame {
  position: relative;
  width: var(--frame-w);
  height: min(100svh, var(--frame-h));
  aspect-ratio: 9 / 16;
  overflow: hidden;
  background: var(--black);
}

.bg-line,
.reveal,
.motif,
.button,
.copy,
.body-copy,
.countdown-copy,
.location-copy,
.partners {
  position: absolute;
}

.bg-line {
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 1;
}

.reveal,
.copy,
.body-copy,
.countdown-copy,
.location-copy,
.partners {
  z-index: 1;
  opacity: 0;
  transform: translate3d(0, calc(var(--frame-w) * 0.035), 0);
  transition:
    opacity 780ms ease,
    transform 920ms cubic-bezier(0.72, 0, 0.16, 1);
}

.panel.is-active .reveal,
.panel.is-active .copy,
.panel.is-active .body-copy,
.panel.is-active .countdown-copy,
.panel.is-active .location-copy,
.panel.is-active .partners {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

img {
  display: block;
  max-width: 100%;
}

.spl-logo {
  width: 31%;
}

.top-spl {
  top: 13.1%;
  left: 34.7%;
}

.hero-spl {
  top: 16.2%;
  left: 35.1%;
  width: 32%;
}

.hero-title {
  top: 33.1%;
  left: 11.6%;
  width: 77.4%;
}

.motif {
  z-index: 1;
  max-width: none;
  pointer-events: none;
}

.hero-motif {
  top: 52.2%;
  left: -46%;
  width: 162%;
}

.copy,
.body-copy,
.countdown-copy,
.location-copy {
  left: 50%;
  width: 86%;
  text-align: center;
  transform: translate3d(-50%, calc(var(--frame-w) * 0.035), 0);
}

.panel.is-active .copy,
.panel.is-active .body-copy,
.panel.is-active .countdown-copy,
.panel.is-active .location-copy {
  transform: translate3d(-50%, 0, 0);
}

.copy h1 {
  margin: 0 0 calc(var(--frame-w) * 0.145);
  color: var(--cream);
  font-size: calc(var(--frame-w) * 0.067);
  font-weight: 600;
  line-height: 1.16;
  letter-spacing: 0.035em;
  text-transform: uppercase;
}

.copy p,
.body-copy,
.location-copy,
.register-copy {
  margin: 0;
  color: var(--white);
  font-size: calc(var(--frame-w) * 0.04);
  font-weight: 400;
  line-height: 1.36;
  letter-spacing: 0;
}

strong {
  color: var(--cream);
  font-weight: 600;
}

.fallback {
  font-family: Arial, Helvetica, sans-serif;
}

.invite-copy {
  top: 33.8%;
}

.event-logo {
  width: 31%;
}

.footer-event {
  top: 77.2%;
  left: 34.6%;
}

.top-event {
  top: 15.6%;
  left: 34.4%;
  width: 31.5%;
}

.countdown-copy {
  top: 34.1%;
  width: 90%;
  text-transform: uppercase;
}

.countdown-copy h2 {
  margin: 0;
  color: var(--cream);
  font-size: calc(var(--frame-w) * 0.057);
  font-weight: 700;
  line-height: 1.18;
  letter-spacing: 0.035em;
}

.count-number {
  margin-top: calc(var(--frame-w) * 0.085);
  color: var(--white);
  font-size: calc(var(--frame-w) * 0.245);
  font-weight: 700;
  line-height: 0.82;
  letter-spacing: 0;
}

.countdown-copy p {
  margin: calc(var(--frame-w) * 0.08) 0 0;
  color: var(--cream);
  font-size: calc(var(--frame-w) * 0.057);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.055em;
}

.countdown-motif {
  top: 71.8%;
  left: -20%;
  width: 152%;
}

.swei-copy {
  top: 38.2%;
  width: 82%;
  font-size: calc(var(--frame-w) * 0.0385);
  line-height: 1.31;
}

.initiatives-copy {
  top: 26.9%;
  width: 84%;
  font-size: calc(var(--frame-w) * 0.034);
  line-height: 1.23;
}

.initiatives-copy p {
  margin: 0 0 calc(var(--frame-w) * 0.055);
}

.initiatives-copy p:last-child {
  margin-bottom: 0;
}

.bottom-spl {
  top: 78.8%;
  left: 35.2%;
  width: 29.6%;
}

.initiatives-motif {
  top: 90.6%;
  left: -12%;
  width: 132.6%;
}

.location-copy {
  top: 24.4%;
  width: 86%;
}

.honour {
  margin: 0 0 calc(var(--frame-w) * 0.05);
  color: var(--white);
  font-size: calc(var(--frame-w) * 0.04);
  line-height: 1.3;
}

.details {
  margin: 0;
  color: var(--cream);
  font-size: calc(var(--frame-w) * 0.038);
  font-weight: 700;
  line-height: 1.28;
}

.map {
  top: 43.25%;
  left: 3.1%;
  width: 93.8%;
  height: 21.1%;
  object-fit: cover;
  border-radius: calc(var(--frame-w) * 0.025);
  position: relative;
}

.button {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: calc(var(--frame-w) * 0.095);
  border: 0;
  border-radius: calc(var(--frame-w) * 0.028);
  background: var(--cream);
  color: var(--white);
  font-size: calc(var(--frame-w) * 0.035);
  font-weight: 700;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  box-shadow: none;
  cursor: pointer;
}

.button:focus-visible {
  outline: calc(var(--frame-w) * 0.006) solid var(--white);
  outline-offset: calc(var(--frame-w) * 0.01);
}

.directions-button {
  top: 66.2%;
  left: 34.4%;
  width: 31.2%;
}

.location-event {
  top: 79.6%;
  left: 34.5%;
  width: 31.5%;
}

.register-event {
  top: 16%;
}

.register-copy {
  position: absolute;
  top: 37.8%;
  left: 50%;
  z-index: 1;
  width: 78%;
  text-align: center;
  transform: translate3d(-50%, calc(var(--frame-w) * 0.035), 0);
}

.panel.is-active .register-copy {
  transform: translate3d(-50%, 0, 0);
}

.register-button {
  top: 50.1%;
  left: 22.8%;
  width: 53.6%;
  min-height: calc(var(--frame-w) * 0.095);
  font-size: calc(var(--frame-w) * 0.034);
}

.button-label {
  white-space: nowrap;
}

.partners {
  top: 66.2%;
  left: 9.5%;
  display: flex;
  width: 81%;
  align-items: center;
  justify-content: space-between;
  gap: calc(var(--frame-w) * 0.038);
}

.partners img {
  width: auto;
  max-width: 19%;
  max-height: calc(var(--frame-w) * 0.09);
  object-fit: contain;
}

.partners img:nth-child(3) {
  max-height: calc(var(--frame-w) * 0.145);
  max-width: 10.5%;
}

.partners img:nth-child(4) {
  max-width: 22%;
}

.partners img:nth-child(5) {
  max-width: 22%;
}

.register-spl {
  top: 79.4%;
  left: 35%;
  width: 31%;
}

.register-motif {
  top: 91.5%;
  left: 3.2%;
  width: 105.8%;
}

.scroll-cta {
  position: fixed;
  right: max(18px, env(safe-area-inset-right));
  bottom: max(18px, env(safe-area-inset-bottom));
  z-index: 10;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 44px;
  padding: 0 16px 0 18px;
  border: 1px solid rgba(196, 172, 136, 0.62);
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.64);
  color: var(--cream);
  font-family: "Commuters Sans", Arial, sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transform: translate3d(0, 12px, 0);
  transition:
    opacity 260ms ease,
    transform 260ms ease,
    border-color 180ms ease,
    background 180ms ease;
}

.scroll-cta svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

body[data-page="2"] .scroll-cta,
body[data-page="3"] .scroll-cta,
body[data-page="4"] .scroll-cta,
body[data-page="5"] .scroll-cta,
body[data-page="6"] .scroll-cta {
  opacity: 1;
  pointer-events: auto;
  transform: translate3d(0, 0, 0);
}

.scroll-cta:hover {
  background: rgba(196, 172, 136, 0.12);
  border-color: var(--cream);
}

@media (max-width: 520px) {
  .scroll-cta {
    right: 50%;
    bottom: max(16px, env(safe-area-inset-bottom));
    transform: translate3d(50%, 12px, 0);
  }

  body[data-page="2"] .scroll-cta,
  body[data-page="3"] .scroll-cta,
  body[data-page="4"] .scroll-cta,
  body[data-page="5"] .scroll-cta,
  body[data-page="6"] .scroll-cta {
    transform: translate3d(50%, 0, 0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .stage,
  .reveal,
  .copy,
  .body-copy,
  .countdown-copy,
  .location-copy,
  .partners,
  .scroll-cta {
    transition: none;
  }
}

@media screen and (max-width: 768px){
  .frame {
    height: 100vh !important;
  }

  .hero-motif {
    top: 61.2%;
  }

  .countdown-motif {
    top: 71.8%;
    left: -35%;
    width: 182%;
  }

  .register-motif {
    top: 94.5%;
  }

  .partners {
    left: 5.5%;
}

}

.register-copy strong{
  color: white !important;
}

.footer-event {
    top: 81.2% !important;
}

@media screen and (max-width: 768px){

.footer-event{
  top: 77.2% !important;
}
}

.ovyok{
  overflow: visible !important;
}

@media screen and (max-width: 768px){
  .ovyok{
    overflow: hidden !important;
  }
}