/* ------------------------- Variables -------------------------------------------------- */

:root {
  /* CSS Animations */
  --animation-default-fast: 0.35s cubic-bezier(0.625, 0.05, 0, 1);
  --animation-default: 0.735s cubic-bezier(0.625, 0.05, 0, 1);
  --animation-bounce: 0.5s cubic-bezier(0.35, 1.75, 0.6, 1);
  --section-padding: 3.25em;
  --container-padding: 1.875em;
  --gap: 2em;
  --globe-size: 100;
}

/* Tablet */
@media screen and (max-width: 991px) {
	:root {
	  --globe-size: 150;
	}
}

/* Mobile Landscape */
@media screen and (max-width: 767px) {
	:root {
    --section-padding: 6em;
		--container-padding: 1.25em;
	}
}

/* Mobile Portrait */
@media screen and (max-width: 479px) {
	:root {
		--gap-responsive: 1em;
	}
}

/* ------------------------- Copy/Paste Media Queries -------------------------------------------------- */

@media screen and (max-width: 991px) {}
@media screen and (max-width: 767px) {}
@media screen and (max-width: 479px) {}

@media screen and (min-width: 992px) {}
@media screen and (min-width: 768px) {}
@media screen and (min-width: 480px) {}

@media (hover: hover) and (pointer: fine) {}
@media (hover: none) and (pointer: coarse) {}

:is(.wf-design-mode, .w-editor) {}

/* ------------------------- Scaling System made by Dennis Snellenberg -------------------------------------------------- */

/* Desktop */
:root {
  --size-unit: 16; /* body font-size in design - no px */
  --size-container-ideal: 1440; /* screen-size in design - no px */
  --size-container-min: 992px;
  --size-container-max: 2160px;
  --size-container: clamp(var(--size-container-min), 100vw, var(--size-container-max));
  --size-font: calc(var(--size-container) / (var(--size-container-ideal) / var(--size-unit)));
}

/* Tablet */
@media screen and (max-width: 991px) {
	:root {
    --size-container-ideal: 834; /* screen-size in design - no px */
    --size-container-min: 768px;
    --size-container-max: 991px;
	}
}

/* Mobile Landscape */
@media screen and (max-width: 767px) {
	:root {
    --size-container-ideal: 390; /* screen-size in design - no px */
    --size-container-min: 480px;
    --size-container-max: 767px;
	}
}

/* Mobile Portrait */
@media screen and (max-width: 479px) {
	:root {
    --size-container-ideal: 390; /* screen-size in design - no px */
    --size-container-min: 320px;
    --size-container-max: 479px;
	}
}

/* ------------------------- Viewportheight -------------------------------------------------- */

:root {
  --vh-in-px: 8px; /* Default fallback */
  --vh: var(--vh-in-px);
  --dvh: var(--vh); /* Same as original VH */
  --svh: var(--vh);
  --lvh: var(--vh);
}

/* Only on non-touch devices */
@media (hover: hover) and (pointer: fine) {
  :root {
    --vh: 1vh;
  }

  /* If the device supports svh and lvh */
  @supports (height: 1svh) {
    :root {
      --vh: 1vh; /* Viewport height */
      --dvh: 1dvh; /* Dynamic viewport height */
      --svh: 1svh; /* Small viewport height */
      --lvh: 1lvh; /* Large viewport height */
    }
  }
}

/* Only on touch devices */
@media (hover: none) and (pointer: coarse) {
  /* Set vh to dvh initially */
  :root {
    --vh: var(--vh-in-px);
  }
  
  /* If the device supports lvh */
  @supports (height: 1lvh) {
    :root {
      --dvh: 1dvh; /* Dynamic viewport height */
      --svh: 1svh; /* Small viewport height */
      --lvh: 1lvh; /* Large viewport height */
    }
  }
}

/* ------------------------- Lenis -------------------------------------------------- */

html.lenis {height: auto;}
.lenis.lenis-smooth {scroll-behavior: auto; height: 100vh;}
.lenis.lenis-smooth [data-lenis-prevent] {overscroll-behavior: contain;}
.lenis.lenis-stopped {overflow: hidden;}
.lenis.lenis-scrolling iframe {pointer-events: none;}

/* ------------------------- Hide Scrollbar -------------------------------------------------- */

body ::-webkit-scrollbar, body::-webkit-scrollbar{display: none;} /* Chrome, Safari, Opera */
body {-ms-overflow-style: none;} /* IE & Edge */
html {scrollbar-width: none;} /* Firefox */

/* ------------------------- Body -------------------------------------------------- */

*, *:after, *:before { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box;}
li, ul, figure { padding: 0; margin: 0; list-style: none;}

html {
  scroll-behavior: initial;
}

body {
  -webkit-font-smoothing: antialiased;
}

html, body {
  width: 100%;
  min-height: 100%;
  -webkit-font-smoothing: antialiased;
  position: relative;
}

/* Selection */
::selection {
  background-color: var(--color-primary);
  color: var(--color-dark);
  text-shadow: none;
}

::-moz-selection {
  background-color: var(--color-primary);
  color: var(--color-dark);
  text-shadow: none;
}

/* General */
canvas, img, video, picture, figure {
  max-width: 100%;
  height: auto;
  box-sizing: border-box;
  display: block;
}

img {
  width: 100%;
}

svg {
  max-width: none;
  height: auto;
  box-sizing: border-box;
}

audio, canvas, iframe, img, svg, video, picture, figure {
  vertical-align: middle;
}

h1, h2, h3, h4, h5, h6, p, a, li, ul, ol, span, strong, em, figcaption  {padding: 0; margin: 0;}

/* ------------------------- Font Sizes -------------------------------------------------- */

h1, .h1 {
  font-family: Swiss921BT-RegularA, sans-serif;
  font-size: 4.5em;
  line-height: 1.2;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.05em;
}

h2, .h2 {
  font-family: Swiss921BT-RegularA, sans-serif;
  font-size: 2.5em;
  line-height: 1.2;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.05em;
}

h3, .h3 {
  font-family: Swiss921BT-RegularA, sans-serif;
  font-size: 1.5em;
  line-height: 1.2;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.05em;
}

h4, .h4 {
  font-family: Swiss921BT-RegularA, sans-serif;
  font-size: 1em;
  line-height: 1.2;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.05em;
}

h5, .h5 {
  font-family: Swiss921BT-RegularA, sans-serif;
  font-size: 0.75em;
  line-height: 1.2;
  text-transform: uppercase;
  font-weight: 500;
  letter-spacing: 0.05em;
}

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

@media screen and (max-width: 767px) {
  
  h2, .h2 {
    font-size: 2.6em;
  }

  h3, .h3 {
    font-size: 2.25em;
  }
}

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

/* ------------------------- Loading -------------------------------------------------- */

:is(.wf-design-mode, .w-editor) .loading-container {
  display: none;
}

/* ------------------------- Split Text -------------------------------------------------- */

.single-word {
  overflow: hidden;
  position: relative;
  margin-bottom: -0.225em;
  margin-left: -0.1em;
  margin-right: -0.1em;
  padding: 0 0.1em;
  display: inline-block;
}

.single-word .single-char {
  position: relative;
  display: inline-block;
}

.single-word .single-word-inner {
  position: relative;
  display: inline-block;
}

/* ------------------------- Banner -------------------------------------------------- */


@keyframes loopBanner { 
  0% { transform: translateX(0%); }
  100% {transform: translateX(-100%); } 
}

.banner__inner {
  animation: loopBanner 120s linear;
  animation-iteration-count: infinite;
}


/* ------------------------- Sprite -------------------------------------------------- */

@keyframes sprite {
  to {
    transform: translateX(-100%);
  }
}

[data-hover-sprite]:hover .sprite-svg,
[data-infinite-sprite] .sprite-svg{
  animation: sprite 0.45s steps(4, end) infinite;
}

/* ------------------------- Button Lightning -------------------------------------------------- */

.btn-lightning .btn-lightning__icon {
  transition: var(--animation-bounce);
  transform: translateX(0em, 0em) scale(1) rotate(0.001deg);
  color: var(--color-primary);
}

.btn-lightning:hover .btn-lightning__icon {
  transform: translate(-1.5em, -0.25em) scale(1.5) rotate(-25deg);
  color: var(--color-light);
}

.btn-lightning:hover .btn-lightning__icon.is--flipped {
  transform: translate(1.5em, -0.25em) scale(1.5) rotate(25deg);
  color: var(--color-light);
}

.btn-lightning .btn-lightning__bg {
  transition: var(--animation-bounce);
  width: 100%;
}

.btn-lightning:hover .btn-lightning__bg {
  width: calc(100% - 3em);
}

/* ------------------------- Button Lightning -------------------------------------------------- */

.underline-link::before,
.underline-link.is--alt::before,
.underline-link.is--alt::after{
  content: "";
  position: absolute;
  bottom: 0em;
  left: 0;
  width: 100%;
  height: 0.09375em;
  background-color: var(--color-primary);
  transition: transform 0.735s cubic-bezier(0.625, 0.05, 0, 1);
  transform-origin: right;
  transform: scaleX(0) rotate(0.001deg);
}

/* ------------------------- Underline Link -------------------------------------------------- */

.underline-link:hover::before {
  transform-origin: left;
  transform: scaleX(1) rotate(0.001deg);
}

/* Alt */
.underline-link.is--alt::before {
  transform-origin: left;
  transform: scaleX(1) rotate(0.001deg);
  transition-delay: 0.3s;
}

.underline-link.is--alt:hover::before {
  transform-origin: right;
  transform: scaleX(0) rotate(0.001deg);
  transition-delay: 0s;
}

.underline-link.is--alt::after {
  transform-origin: right;
  transform: scaleX(0) rotate(0.001deg);
  transition-delay: 0s;
}

.underline-link.is--alt:hover::after {
  transform-origin: left;
  transform: scaleX(1) rotate(0.001deg);
  transition-delay: 0.3s;
}

/* ------------------------- Marquee -------------------------------------------------- */


[data-marquee-direction] {
  transition: transform 0.5s cubic-bezier(0.6, 0, 0.4, 1);
  transition: var(--animation-bounce);
  transform: rotate(4deg);
}

[data-marquee-status="inverted"] {
  transform: rotate(-4deg);
}

/* ------------------------- Audio -------------------------------------------------- */

[data-howler-status="not-playing"] .howler-player__btn-play,
[data-howler-status="playing"] .howler-player__btn-pause{
  display: flex;
}

[data-howler-status="playing"] .howler-player__btn-play,
[data-howler-status="not-playing"] .howler-player__btn-pause{
  display: none;
}

.album-vinyl,
.album-cover{
 transition: transform var(--animation-bounce); 
}

[data-howler-status="playing"] .album-vinyl {
  transform: translateX(10%) rotate(0.001deg);
}

[data-howler-status="playing"] .album-cover {
  transform: translateX(10%) rotate(0.001deg);
}

@media screen and (max-width: 991px) {
  [data-howler-status="playing"] .album-vinyl {
    transform: translateX(0%) rotate(0.001deg);
  }
  
  [data-howler-status="playing"] .album-cover {
    transform: translateX(0%) rotate(0.001deg);
  }
}

/* ------------------------- Switcher -------------------------------------------------- */

[data-switcher-cards] [data-switcher-status] {
 transition: transform 0.8s cubic-bezier(0.5, 0.15, 0, 1) 0.1s;
}

[data-switcher-cards] [data-switcher-status] {
  transform: translateY(calc(var(--switcher-position) * 100%)) scale(0.8) rotate(0.001deg);
}

[data-switcher-cards] [data-switcher-status="active"] {
  transform: translateY(0%) scale(1) rotate(0.001deg);
}

[data-switcher-btns] [data-switcher-status] .audio-player__control-thumb {
  transition: var(--animation-bounce);
  transform: scale(0.75) rotate(0.001deg);
}

[data-switcher-btns] [data-switcher-status]:hover .audio-player__control-thumb {
  transform: scale(0.875) rotate(0.001deg);
}

[data-switcher-btns] [data-switcher-status="active"] .audio-player__control-thumb,
[data-switcher-btns] [data-switcher-status="active"]:hover .audio-player__control-thumb{
  transform: scale(1) rotate(0.001deg);
}

[data-switcher-btns] [data-switcher-status] .single-active-corner-inner,
[data-switcher-btns]:hover [data-switcher-status="active"] .single-active-corner-inner{
  transition: var(--animation-bounce);
  transform: translate(-25%, -25%) rotate(0.001deg);
  opacity: 0;
}

[data-switcher-btns] [data-switcher-status]:hover .single-active-corner-inner,
[data-switcher-btns] [data-switcher-status="active"] .single-active-corner-inner{
  transform: translate(0%, 0%) rotate(0.001deg);
  opacity: 0.75;
}

:is(.wf-design-mode, .w-editor) .audio-card {
  position: relative;
}