:root {
  --footer-height: 30rem;
}

/*
xs:     0 - 576px
sm:     576 - 768px
md:     768 - 992px
lg:     992 - 1200px
xl:     1200 - 1400px
xxl:    1400+
xxxl:   1600+
*/
@keyframes border_anim {
  0% {
    width: 0%;
    border-bottom: solid 3px transparent;
    @media (max-width: 36em) {
      border-bottom: solid 2px transparent;
    }
  }
  100% {
    width: 100%;
    border-bottom: solid 3px #000;
    @media (max-width: 36em) {
      border-bottom: solid 2px #000;
    }
  }
}
@keyframes border_lightgrey_anim {
  0% {
    width: 0%;
    border-bottom: solid 3px transparent;
    @media (max-width: 36em) {
      border-bottom: solid 2px transparent;
    }
  }
  100% {
    width: 100%;
    border-bottom: solid 3px lightgrey;
    @media (max-width: 36em) {
      border-bottom: solid 2px lightgrey;
    }
  }
}
@keyframes border_white_anim {
  0% {
    width: 0%;
    border-bottom: solid 3px transparent;
    @media (max-width: 36em) {
      border-bottom: solid 2px transparent;
    }
  }
  100% {
    width: 100%;
    border-bottom: solid 3px white;
    @media (max-width: 36em) {
      border-bottom: solid 2px white;
    }
  }
}
@keyframes border_anim_reverse {
  0% {
    width: 100%;
    border-bottom: solid 3px initial;
    @media (max-width: 36em) {
      border-bottom: solid 2px initial;
    }
  }
  100% {
    width: 0;
    border-bottom: solid 3px transparent;
    @media (max-width: 36em) {
      border-bottom: solid 2px transparent;
    }
  }
}
@keyframes bg_fade_in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
:root {
  --main-color: #000000;
  --bg-color: hsla(0, 0%, 100%, 1);
  --bg-color-10: hsla(0, 0%, 100%, 0.1);
  --bg-color-20: hsla(0, 0%, 100%, 0.2);
  --bg-color-30: hsla(0, 0%, 100%, 0.3);
  --bg-color-75: hsla(0, 0%, 100%, 0.75);
}

:root {
  --main-font: "HelveticaNeueRoman",sans-serif;
  --bold-font: "HelveticaNeueBold", sans-serif;
  --lyrics-trigger-font: "AcuminProRegular", sans-serif;
  --lyrics-font: "HelveticaNarrow", sans-serif;
  --font-base-weight: 643.1;
  --font-bold-weight: 1000;
  --font-base-size: 1.4rem;
}

*,
*:after,
*:before {
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

html {
  font-size: 62.5%;
  scroll-behavior: smooth;
}

body {
  font-family: var(--main-font);
  overflow-x: hidden;
}

.clear:before,
.clear:after {
  content: " ";
  display: table;
}

.clear:after {
  clear: both;
}

img {
  max-width: 100%;
  vertical-align: bottom;
}

a {
  color: var(--main-color);
  text-decoration: none;
  transition: all 300ms;
  font-size: 1.4rem;
  font-family: var(--main-font);
  font-variation-settings: "wght" 643.1, "wdth" 74.7, "opsz" 30;
}

a:focus {
  outline: 0;
}

a:hover,
a:active {
  outline: 0;
}

input:focus {
  outline: 0;
  border: 1px solid #04A4CC;
}

button {
  transition: all 300ms;
}

p, strong {
  font-size: 1.4rem;
  font-variation-settings: "wght" 643.1, "wdth" 74.7, "opsz" 30;
}

/*------------------------------------*\
    MISC
\*------------------------------------*/
::selection {
  background: var(--main-color);
  color: black;
  text-shadow: none;
}

::-webkit-selection {
  background: var(--main-color);
  color: black;
  text-shadow: none;
}

::-moz-selection {
  background: var(--main-color);
  color: black;
  text-shadow: none;
}

/*------------------------------------*\
    PRINT
\*------------------------------------*/
@media print {
  * {
    background: transparent !important;
    color: #000 !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }

  a,
a:visited {
    text-decoration: underline;
  }

  a[href]:after {
    content: " (" attr(href) ")";
  }

  abbr[title]:after {
    content: " (" attr(title) ")";
  }

  .ir a:after,
a[href^="javascript:"]:after,
a[href^="#"]:after {
    content: "";
  }

  pre, blockquote {
    border: 1px solid #999;
    page-break-inside: avoid;
  }

  thead {
    display: table-header-group;
  }

  tr, img {
    page-break-inside: avoid;
  }

  img {
    max-width: 100% !important;
  }

  @page {
    margin: 0.5cm;
  }
  p,
h2,
h3 {
    orphans: 3;
    widows: 3;
  }

  h2,
h3 {
    page-break-after: avoid;
  }
}
/* Typography */
@font-face {
  font-family: "HelveticaNeueRoman";
  src: url("../assets/fonts/NeueHelvetica55Roman/normal_normal.woff2") format("woff2"), url("../assets/fonts//NeueHelvetica55Roman/normal_normal.woff") format("woff");
}
@font-face {
  font-family: "HelveticaNeueBold";
  src: url("../assets/fonts/NeueHelvetica75Bold/normal_normal.woff2") format("woff2"), url("../assets/fonts//NeueHelvetica75Bold/normal_normal.woff") format("woff");
}
@font-face {
  font-family: "AcuminProRegular";
  src: url("../assets/fonts/AcuminPro/Acumin-RPro.woff") format("woff");
}
@font-face {
  font-family: "HelveticaNarrow";
  src: url("../assets/fonts/HelveticaNarrowSRegular/normal_normal.ttf") format("truetype");
}
.is-uppercase {
  text-transform: uppercase;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--main-font);
  font-weight: 200;
  font-variation-settings: "wght" 1000, "wdth" 54.3, "opsz" 30;
}

h1 {
  font-size: 4.2rem;
}

h2 {
  font-size: 3rem;
}

.small {
  font-size: 1.1rem;
}
@media (max-width: 36em) {
  .small {
    font-size: 0.8rem;
  }
}

button, input, select, textarea {
  font-size: initial;
}

/* Text flip */
.txt-h-flip {
  position: absolute;
  transform: rotateY(-180deg);
}

.txt-h-v-flip {
  position: absolute;
  transform: rotateY(-180deg) rotateX(-180deg);
}

/* Containers */
.container,
.container-fluid,
.container-xxxl,
.container-xxl,
.container-xl,
.container-lg,
.container-md,
.container-sm,
.container-xs,
.container-xxs {
  margin-left: auto;
  margin-right: auto;
  padding: 0 1.5rem;
  width: 100%;
}

.container-xxl {
  max-width: 1600px;
}

.container-xl {
  max-width: 1300px;
}

.container-lg {
  max-width: 1200px;
}

.container-md {
  max-width: 992px;
}

.container-sm {
  max-width: 768px;
}

.container-xs {
  max-width: 576px;
}

.container-xxs {
  max-width: 566px;
}

/* Positions */
.position-absolute {
  position: absolute;
}

.position-relative {
  position: relative;
}

.position-fixed {
  position: fixed;
}

/* Text alignment */
.txt-align-center {
  text-align: center;
}

.txt-align-left {
  text-align: left;
}

.txt-align-right {
  text-align: right;
}

/* Heights */
.h-100 {
  height: 100%;
}

/* Widths */
.w-100 {
  width: 100%;
}

.w-70 {
  width: 70%;
}

.w-40 {
  width: 40%;
}

@media (max-width: 36em) {
  .w-xs-80 {
    width: 80%;
  }
}

/* Overflow */
.of-h {
  overflow: hidden;
}

/* Display */
.display-none, .d-n {
  display: none !important;
}

.display-flex, .d-flex, .d-f {
  display: flex !important;
}

.display-grid, .d-g {
  display: grid !important;
}

.display-block, .d-b {
  display: block !important;
}

@media (max-width: 36em) {
  .d-xs-b {
    display: block !important;
  }
}

.display-inline-block, .d-ib {
  display: inline-block;
}

/* Flex Justify */
.justify-space-between, .jc-sb {
  justify-content: space-between;
}

.justify-space-evenly, .jc-se {
  justify-content: space-evenly;
}

.fd-c {
  flex-direction: column;
}

@media (max-width: 36em) {
  .fd-xs-c {
    flex-direction: column;
  }
}

/* Flex Align */
.align-items-center, .ai-c {
  align-items: center;
}

/* Flex */
.flex-1 {
  flex: 1;
}

.flex-075 {
  flex: 0.75;
}
@media (max-width: 75em) {
  .flex-075 {
    flex: 1;
  }
}

/* Letter Spacing */
.ls-1 {
  letter-spacing: 1px;
}

/* Stick */
.stick {
  position: fixed;
  top: 0px;
}

/* Disabled text */
.txt-disabled {
  pointer-events: none;
  opacity: 0.5;
}

/* Lazy images */
.lazyImage:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACgAAAAoCAMAAAC7IEhfAAAAulBMVEUBAAD/AAAIAAD/CgoOAAAZAAAUAAD/BQUeAAAuAAA9AAA4AAAoAAAjAADmAABCAAA0AAD/IiLhAAD/HR3ZAACcAAD/GBj6AADSAAB8AABMAAD/MDD/EhKxAACYAABRAAD/KSm5AACTAAB2AABHAAD1AADGAACBAADxAACkAACJAADqAACrAABqAABmAADJAADBAACgAACFAABhAACNAAC+AABdAABVAADeAADuAACPAABwAADNAAD/OTmppkF+AAAEnklEQVQ4yxSSWbKiQBREb3rVaocuLYrRAkQQZFIBh6c+3f+22v4/kZGRechNbJQFlCxMAz/UCgmcxc2PplGfUus/17GM6A1ixYbxNh4nyN0QbJKk4vGiW23XfUl3JaY3a9ZXpLv8C3o5bChlBAD2crP7gRevljwc5uF8PkOwpBwGENoqFbzE9wXsHAfndR0v7Ivj8IGGArMsdQjQBRpICJw/D0hPQDMdCntU7FoK4mB6Kfbjm0MKsJIzyqeCAD4MYyMclnF7GeVytXH4OlsVp1NFpuNQPjnJAeWVLBl2aHmH/T5ajTa7YVqb6wjRMKazr6VWLPEFlGA0XmlPAj8YZWKgtP3Zds2J6tAmGGbz0AkERIKQ4XVWvBnO0aSUVeZYv3Q439M5k4IE+N2EGq5i92kJuF22bVHPf1s/iKLXMVCX8Z3gGm1KIfOQhftN+3RAn8pqWw2LALtDulvM7hwQicIufcl4iI/+svwwrMax9ibZrtzc7Drz385o3d8o6TQAu9M+5wY6tAyzM+mbFcVDRQGL+WZop45FFnOBhxuqEMyWZ5Xyq8mJdvpwOe7qbfq4/Vm3Ed1IMIuELSMA8WQoDe0u85jix2tq8y8dq/h0FacRcXNOGI1A8u0HlUt8MGvDLA2e6ThtuI34ulxFR2IhE9dK4AowXKiQDV++Mx+nM3tNO29Wbbmjy4NcV8NjwPw/uysB9jT29CrmVJ8D6hGsaxnse7JYg23gLUOPn57yuFHBs15ucFz99tmktn+WDn4mpBIIZpYAc6k/sLSLReYG9z33yxj239p+kVPu/7VAbstpA0EQbcazy17ZNbGwUFlSdAGZi0QAAQ74/78ruCozD/3S1ae60WWP2bfdv3Z5dah8Nhb6vjLwUrA0FkAEICIIG+N3SYH1e8rnlwZfv26uEMozNMkAAUQjYgZCmtz7MDm779SKzecEf+Z7a6Ad2HtuFQzARkZG9lisOF0V4u3bJZd5GPvF8EQDUEYwe7awkF7gFm7vOdl89Nm7Dvnp2NsNNMhLTSyUAbyQrSK89uYz7Xi9+zMM60I1Se1L0k4qBCtF6ZWDFnDAZr/vj3X5SNdreZ1n1PxdNrE0IBUzR8/DzdmoCPpldkZXDQiHZFkv0qap6owUZwrOEgKJoDRZgdE3023sdje1qe7YFwMvLxw9iEoQ8FPcsmwFft9MUdX2a1d3b2NANt25B6CZACfV06MiGSEJ6T3gre6w/FWKyUeHR7KFVWQIlkxQpIRUioigq4WVp7+nWzmJy6ZKaD6pQoRgAy0oMHEU0nmgl4fLJSabkI3znK650fnIgrQiKp10gpSFgDb4sLS6X4/Dep5tpydznZ3p3Skd9Q+dgPD8H0Uzv+abw+F8mlt8TmvXX7ajapm11ELBe20ZpAIwJHmESY+yfPGqeSlj330Tac9MQGuRUZSsgoQXyeEo0sXZZdUXZ/MW5ZYGeND/kRhCkG8xOdvL683luzsdZrV/24xZ6lmXTy4JVuRaGDA59OtlO6z25fWjeGwXZyoO/UAeAEmwN2z0c56oJGQx7a6zWaRkNru2K0/baWjxzIJjQEoARND8D7+tgCt2HKJNAAAAAElFTkSuQmCC") center center repeat;
  opacity: 0;
  transition: opacity 0.5s;
}

.lazyImageWaiting:before {
  opacity: 1;
  transition: opacity 0s;
}

.lazyImageError img,
.lazyImageWaiting img {
  opacity: 0;
  transform: scale(0);
  transition: none;
}

.keen-slider[data-keen-slider-moves] * {
  cursor: grabbing !important;
  pointer-events: unset !important;
}
.keen-slider[data-keen-slider-moves] * a {
  pointer-events: none !important;
}

.d-only {
  display: block;
}
@media (max-width: 36em) {
  .d-only {
    display: none;
  }
}

.m-only {
  display: none;
}
@media (max-width: 36em) {
  .m-only {
    display: block;
  }
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

/* Paddings */
.p-0 {
  padding: 0;
}

.py-1 {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.py-2 {
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.py-3 {
  padding-top: 3rem;
  padding-bottom: 3rem;
}

.pt-1 {
  padding-top: 1rem;
}

.pt-2 {
  padding-top: 2rem;
}

.pt-3 {
  padding-top: 3rem !important;
}

.pt-4 {
  padding-top: 4rem !important;
}

.pt-5 {
  padding-top: 5rem !important;
}

.pt-6 {
  padding-top: 6rem !important;
}

.pt-7 {
  padding-top: 7rem !important;
}

.pt-11 {
  padding-top: 11rem;
}

.pt-12 {
  padding-top: 12rem;
}

.pt-8 {
  padding-top: 8rem;
}

@media (max-width: 48em) {
  .pt-sm-0 {
    padding-top: 0 !important;
  }

  .pt-sm-1 {
    padding-top: 1rem !important;
  }

  .pt-sm-2 {
    padding-top: 2rem !important;
  }

  .pt-sm-3 {
    padding-top: 3rem !important;
  }

  .pt-sm-4 {
    padding-top: 4rem !important;
  }

  .pt-sm-5 {
    padding-top: 5rem !important;
  }

  .pt-sm-6 {
    padding-top: 6rem;
  }
}
.pl-0 {
  padding-left: 0;
}

.pl-4 {
  padding-left: 4rem;
}

.pl-5 {
  padding-left: 5rem;
}

.pl-6 {
  padding-left: 6rem;
}

.pl-7 {
  padding-left: 7rem;
}

.pl-8 {
  padding-left: 8rem;
}

@media (max-width: 48em) {
  .pl-sm-0 {
    padding-left: 0;
  }

  .pl-sm-1 {
    padding-left: 1rem;
  }

  .pl-sm-2 {
    padding-left: 2rem;
  }

  .pl-sm-3 {
    padding-left: 3rem;
  }

  .pl-sm-4 {
    padding-left: 4rem;
  }

  .pl-sm-5 {
    padding-left: 5rem;
  }

  .pl-sm-6 {
    padding-left: 6rem;
  }
}
.pr-0 {
  padding-right: 0;
}

.pr-4 {
  padding-right: 4rem;
}

.pr-5 {
  padding-right: 5rem;
}

.pr-6 {
  padding-right: 6rem;
}

.pr-7 {
  padding-right: 7rem;
}

.pr-8 {
  padding-right: 8rem;
}

@media (max-width: 48em) {
  .pr-sm-0 {
    padding-right: 0;
  }

  .pr-sm-1 {
    padding-right: 1rem;
  }

  .pr-sm-2 {
    padding-right: 2rem;
  }

  .pr-sm-3 {
    padding-right: 3rem;
  }

  .pr-sm-4 {
    padding-right: 4rem;
  }
}
.pb-3 {
  padding-bottom: 3rem;
}

.pb-4 {
  padding-bottom: 4rem;
}

.pb-5 {
  padding-bottom: 5rem;
}

.pb-6 {
  padding-bottom: 6rem;
}

.pb-7 {
  padding-bottom: 7rem;
}

.pb-8 {
  padding-bottom: 8rem;
}

.pb-11 {
  padding-bottom: 11rem;
}

.pb-12 {
  padding-bottom: 12rem;
}

@media (max-width: 48em) {
  .pb-sm-0 {
    padding-bottom: 0;
  }

  .pb-sm-1 {
    padding-bottom: 1rem;
  }

  .pb-sm-2 {
    padding-bottom: 2rem;
  }

  .pb-sm-3 {
    padding-bottom: 3rem;
  }

  .pb-sm-4 {
    padding-bottom: 4rem;
  }

  .pb-sm-5 {
    padding-bottom: 5rem;
  }

  .pb-sm-6 {
    padding-bottom: 6rem;
  }
}
/* Margins */
.m-auto {
  margin: auto !important;
}

.m-0 {
  margin: 0 !important;
}

.mt-0 {
  margin-top: 0 !important;
}

.mt-1 {
  margin-top: 1rem;
}

.mt-2 {
  margin-top: 2rem;
}

.mt-3 {
  margin-top: 3rem;
}

.mt-4 {
  margin-top: 4rem;
}

.mt-5 {
  margin-top: 5rem;
}

.mt-10 {
  margin-top: 10rem;
}

@media (max-width: 36em) {
  .mt-xs-0 {
    margin-top: 0;
  }

  .mt-xs-1 {
    margin-top: 1rem;
  }

  .mt-xs-2 {
    margin-top: 2rem;
  }

  .mt-xs-3 {
    margin-top: 3rem;
  }

  .mt-xs-4 {
    margin-top: 4rem;
  }
}
.mr-0 {
  margin-right: 0 !important;
}

.mr-1 {
  margin-right: 1rem !important;
}

.mr-2 {
  margin-right: 2rem !important;
}

.mr-3 {
  margin-right: 3rem !important;
}

.mb-0 {
  margin-bottom: 0 !important;
}

.mb-1 {
  margin-bottom: 1rem !important;
}

.mb-2 {
  margin-bottom: 2rem !important;
}

.mb-3 {
  margin-bottom: 3rem !important;
}

.mb-4 {
  margin-bottom: 4rem !important;
}

.mb-5 {
  margin-bottom: 5rem !important;
}

.mb-6 {
  margin-bottom: 6rem !important;
}

.mb-7 {
  margin-bottom: 7rem !important;
}

@media (max-width: 36em) {
  .mb-xs-0 {
    margin-bottom: 0;
  }

  .mb-xs-1 {
    margin-bottom: 1rem;
  }

  .mb-xs-2 {
    margin-bottom: 2rem;
  }
}
.ml-0 {
  margin-left: 0 !important;
}

.ml-1 {
  margin-left: 1 !important;
}

.ml-2 {
  margin-left: 2 !important;
}

.ml-3 {
  margin-left: 3 !important;
}

body {
  color: var(--main-color);
  margin: 0;
  letter-spacing: 0.5px;
  background-color: var(--bg-color);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: 300ms all;
}
body:not(#home) main section#gag-section .cta-container {
  justify-content: flex-end;
}
body svg.svg {
  pointer-events: none;
}
body main {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  margin: 0 4.3rem;
  height: 100vh;
  height: 100dvh;
  position: relative;
  align-content: center;
}
@media (max-width: 36em) {
  body main {
    align-content: flex-start;
    margin: 0 1.6rem;
  }
}
body main section {
  background-repeat: no-repeat;
  padding: 3rem 0;
}
@media (max-width: 36em) {
  body main section#music, body main section#video, body main section#tour, body main section#lyrics {
    position: relative;
    padding-top: 17rem;
    padding-bottom: 0;
  }
}
body main section#music h1, body main section#video h1, body main section#tour h1, body main section#lyrics h1 {
  display: none;
}
@media (max-width: 36em) {
  body main section#music h1, body main section#video h1, body main section#tour h1, body main section#lyrics h1 {
    display: block;
    margin: 0 auto;
    font-size: 1.4rem;
    font-family: var(--bold-font);
    text-transform: uppercase;
    text-align: center;
  }
}
body main section#gag-section {
  position: absolute;
  z-index: 1;
  bottom: 0rem;
  left: initial;
  right: 0;
  padding: 0;
  width: 100%;
  max-width: 30rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media (max-width: 36em) {
  body main section#gag-section {
    right: initial;
    left: 50%;
    transform: translateX(-50%) translateY(calc(-50% + 1rem));
  }
}
body main section#gag-section .cta-container {
  display: flex;
  flex-direction: row;
  width: 100%;
  flex-wrap: nowrap;
  align-content: center;
  justify-content: space-around;
  align-items: center;
}
body main section#gag-section p {
  font-size: 0.8rem;
  font-family: var(--main-font);
  text-align: center;
}
@media (max-width: 36em) {
  body main section#newsletter .signup .form-container form input[type=email], body main section#newsletter .signup-footer .form-container form input[type=email] {
    color: white;
    border-bottom: 1px solid white;
  }
  body main section#newsletter .signup .form-container form input[type=email]::placeholder, body main section#newsletter .signup-footer .form-container form input[type=email]::placeholder {
    color: white;
  }
}
@media (max-width: 36em) {
  body main section#newsletter .signup .form-container form input[type=submit],
body main section#newsletter .signup .form-container form button#submit_join, body main section#newsletter .signup-footer .form-container form input[type=submit],
body main section#newsletter .signup-footer .form-container form button#submit_join {
    color: white;
  }
}
body.open-modal::before {
  content: "";
  background-color: var(--bg-color-30);
  width: 100%;
  height: 100vh;
  position: fixed;
  transition: all 200ms;
  opacity: 1;
  z-index: 10000;
}

main header {
  width: 100%;
  position: absolute;
  top: 0;
  z-index: 1;
}
main header h1 {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 1.7rem;
  text-align: center;
  font-family: var(--bold-font);
  text-transform: uppercase;
  font-size: 4.5rem;
}
@media (max-width: 36em) {
  main header h1 {
    display: none;
  }
}
main header .nav-container {
  position: absolute;
  top: 5rem;
  width: 100%;
  max-width: max-content;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  pointer-events: none;
}
@media (max-width: 36em) {
  main header .nav-container {
    top: 2rem;
  }
}
main header .nav-container a.logo img {
  display: flex;
  width: 16.5rem;
  max-width: initial;
}
main header .nav-container button.toggle-menu {
  display: none;
  background-color: transparent;
  border: none;
  color: var(--main-color);
}
@media (max-width: 62em) {
  main header .nav-container button.toggle-menu {
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 7rem;
    margin-right: 0;
    margin-left: auto;
    width: 100%;
  }
}
@media (max-width: 36em) {
  main header .nav-container button.toggle-menu {
    max-width: initial;
    margin: auto;
  }
}
main header .nav-container button.toggle-menu .line {
  transition: 500ms;
  transform-origin: center;
  fill: var(--main-color);
}
main header .nav-container button.toggle-menu.active .top {
  y: 50;
  transform: rotate(-45deg);
}
main header .nav-container button.toggle-menu.active .bottom {
  y: 50;
  transform: rotate(45deg);
}
main header .nav-container button.toggle-menu.active .middle {
  opacity: 0;
}
main header .nav-container .menu-content {
  display: flex;
  transition: all 300ms;
}
main header .nav-container .menu-content nav {
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  align-items: flex-start;
  padding-top: 3rem;
  gap: 1rem;
}
@media (max-width: 36em) {
  main header .nav-container .menu-content nav {
    padding-top: 1rem;
    gap: 0.6rem;
  }
}
main header .nav-container .menu-content nav a {
  font-family: var(--bold-font);
  font-size: 1.4rem;
  text-transform: uppercase;
  line-height: 2.2rem;
  transition: none;
  padding-bottom: 0.1rem;
  max-width: 6rem;
  width: 100%;
  pointer-events: initial;
}
@media (max-width: 36em) {
  main header .nav-container .menu-content nav a {
    font-size: 1.1rem;
    line-height: 1.4rem;
  }
}
main header .nav-container .menu-content nav a.current::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  border-bottom: solid 3px #000;
  animation: border_anim 300ms linear forwards;
}
@media (max-width: 36em) {
  main header .nav-container .menu-content nav a.current::after {
    border-bottom: solid 2px #000 !important;
  }
}

footer {
  display: flex;
  padding-top: 3.7rem;
}
footer .footer-container {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  padding: 0 4.3rem;
}
@media (max-width: 75em) {
  footer .footer-container {
    padding: 0 1.6rem;
    text-align: center;
    flex-direction: column-reverse;
  }
}
footer .footer-container .social {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2.5rem;
  padding: 1.6rem 0;
}
@media (max-width: 36em) {
  footer .footer-container .social {
    padding: 1rem 0;
  }
}
footer .footer-container .social a {
  font-size: 1.5rem;
}
footer .footer-container .disclaimer {
  max-width: 48rem;
}
@media (max-width: 75em) {
  footer .footer-container .disclaimer {
    margin: auto;
  }
}
footer .footer-container .disclaimer p {
  margin: 0 0 2rem 0;
  font-family: var(--footer-font);
  font-size: 0.8rem;
}
@media (max-width: 75em) {
  footer .footer-container .disclaimer p {
    margin: 0.7rem 0 0.7rem 0;
  }
}
footer .footer-container .disclaimer p a {
  font-family: var(--footer-font);
  font-size: 0.8rem;
}
footer .footer-container .disclaimer svg {
  width: 3rem;
}

.btn {
  position: relative;
  font-family: var(--bold-font);
  color: black;
  text-align: center;
  text-transform: uppercase;
  font-size: 1.2rem;
  line-height: 1.2rem;
  max-height: 10rem;
  cursor: pointer;
  border: none;
  background-color: transparent;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.2rem 0;
}
.btn i {
  margin-top: -4px;
  font-size: 1.4rem;
}
.btn::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  border-bottom: solid 3px #000;
  animation: border_anim 300ms linear forwards;
}
@media (max-width: 36em) {
  .btn::after {
    border-bottom: solid 2px #000;
  }
}
.btn.btn-default:hover::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  animation: border_anim_reverse 300ms linear forwards;
}

.nav {
  position: relative;
}
.nav:hover::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  border-bottom: solid 3px #000;
  animation: border_anim 200ms linear forwards;
}
@media (max-width: 36em) {
  .nav:hover::after {
    border-bottom: solid 2px #000;
  }
}

.social a span.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}
@media (max-width: 75em) {
  .social {
    text-align: center;
    width: 100%;
  }
}
@media (max-width: 36em) {
  .social {
    min-width: inherit;
    margin-bottom: 0;
  }
}

.signup, .signup-footer {
  display: flex;
}
.signup .form-container, .signup-footer .form-container {
  display: flex;
  align-items: center;
  width: 100%;
}
.signup .form-container form, .signup-footer .form-container form {
  background-color: transparent;
  padding: 0;
  height: 3rem;
  width: 100%;
  margin: auto;
  display: flex;
  gap: 1rem;
}
@media (max-width: 36em) {
  .signup .form-container form, .signup-footer .form-container form {
    justify-content: center;
  }
}
.signup .form-container form .form-group, .signup-footer .form-container form .form-group {
  position: relative;
}
.signup .form-container form input[type=email], .signup-footer .form-container form input[type=email] {
  font-family: var(--bold-font);
  font-size: 1.2rem;
  background-color: transparent;
  text-align: left;
  color: var(--main-color);
  letter-spacing: 0;
  text-transform: uppercase;
  transition: all 300ms;
  padding: 1rem 0;
  border: none;
  border-bottom: 1px solid black;
  border-radius: 0;
  width: 21rem;
}
.signup .form-container form input[type=email]::placeholder, .signup-footer .form-container form input[type=email]::placeholder {
  font-family: var(--bold-font);
  color: black;
}
.signup .form-container form input[type=submit],
.signup .form-container form button#submit_join, .signup-footer .form-container form input[type=submit],
.signup-footer .form-container form button#submit_join {
  font-family: var(--bold-font);
  font-size: 1.2rem;
  letter-spacing: 0;
  text-transform: uppercase;
  text-align: right;
  color: var(--main-color);
  background-color: transparent;
  border: none;
  border-radius: 0;
  transition: all 300ms;
  padding: 1.8rem 3rem;
  text-decoration: none;
  cursor: pointer;
  display: flex;
  align-items: center;
}
.signup .form-container form .default-mailing-list, .signup-footer .form-container form .default-mailing-list {
  display: none;
}

#newsletter {
  position: absolute;
  z-index: 1;
  bottom: 0rem;
  left: 0;
  padding: 0;
  max-width: 32rem;
}
@media (max-width: 36em) {
  #newsletter {
    bottom: -1rem;
  }
}

#apple_music_form .input-group {
  display: grid;
  grid-template-columns: 1fr 7rem;
  gap: 1rem;
}
#apple_music_form .input-group .btn {
  width: 100%;
  text-align: center;
  justify-content: center;
}
#apple_music_form .input-group input[type=email] {
  font-family: var(--bold-font);
  font-size: 1.2rem;
  background-color: transparent;
  text-align: left;
  color: var(--main-color);
  letter-spacing: 0;
  text-transform: uppercase;
  transition: all 300ms;
  padding: 1rem 0;
  border: none;
  border-bottom: 1px solid black;
  border-radius: 0;
}
#apple_music_form .input-group input[type=email]::placeholder {
  font-family: var(--bold-font);
  color: black;
}

.slick-next,
.slick-prev {
  width: 100%;
  max-width: 30rem;
  height: 6rem;
  position: absolute;
  top: initial;
  top: 50%;
  z-index: 1;
  transition: all 400ms;
}
@media (max-width: 36em) {
  .slick-next,
.slick-prev {
    max-width: 12rem;
    height: 4rem;
  }
}
.slick-next:hover,
.slick-prev:hover {
  filter: brightness(4);
}

.slick-next::before,
.slick-prev::before {
  content: "";
  background-image: url("../assets/img/arrow.svg");
  background-repeat: no-repeat;
  background-size: 70%;
  background-position: center;
  opacity: 1;
  height: 6rem;
  width: 100%;
  display: block;
}
@media (max-width: 36em) {
  .slick-next::before,
.slick-prev::before {
    background-size: 100%;
    height: 4rem;
  }
}

.slick-prev {
  left: initial;
  right: 50%;
  transform: translateX(-40%) translateY(-50%);
}
@media (max-width: 36em) {
  .slick-prev {
    top: 100%;
    right: 50%;
    transform: translateX(-30%) translateY(-50%);
  }
}

.slick-next {
  right: 50%;
  transform: translateX(140%) translateY(-50%);
}
@media (max-width: 36em) {
  .slick-next {
    top: 100%;
    right: 50%;
    transform: translateX(130%) translateY(-50%);
  }
}
.slick-next::before {
  transform: rotate(180deg);
}
.slick-next:hover::before {
  transform: rotate(180deg);
}

.slick-slide {
  transition: all 200ms;
}
@media (max-width: 36em) {
  .slick-slide {
    transform: scale(0.6);
    opacity: 0.4;
  }
}
.slick-slide.slick-active {
  opacity: 0.4;
  transform: scale(0.8);
}
@media (max-width: 36em) {
  .slick-slide.slick-active {
    transform: scale(0.6);
  }
}
.slick-slide.slick-active.slick-center {
  opacity: 1;
  transform: scale(1);
}
@media (max-width: 36em) {
  .slick-slide.slick-active.slick-center {
    transform: scale(0.8);
  }
}
.slick-slide a img {
  width: 100%;
}
.slick-slide a h3 {
  text-transform: uppercase;
  font-size: 1.2rem;
}
.slick-slide.video a {
  aspect-ratio: 16/9;
  overflow: hidden;
}

.modal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  z-index: 10000;
  background-color: var(--bg-color);
  color: var(--main-color);
  text-align: center;
  border-radius: 0;
  padding: 0 2rem;
  transition: all 300ms;
}
.modal.hidden {
  opacity: 0;
  pointer-events: none;
}
.modal .btn-close {
  position: absolute;
  top: 0.6rem;
  right: 0.6rem;
  font-family: var(--main-font);
  letter-spacing: 1px;
  max-width: 2rem;
  cursor: pointer;
}
.modal .btn-close a {
  color: var(--bg-color);
}
.modal .btn-close svg {
  width: 100%;
}
.modal .btn-close svg .top {
  transform-origin: center;
  fill: var(--main-color);
  y: 50;
  transform: rotate(-45deg);
}
.modal .btn-close svg .bottom {
  transform-origin: center;
  fill: var(--main-color);
  y: 50;
  transform: rotate(45deg);
}
.modal h2 {
  font-family: var(--main-font);
  letter-spacing: 1px;
  color: var(--main-color);
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  margin: 0;
  font-size: 2.4rem;
  line-height: 2.6rem;
}
.modal.msj-modal {
  width: 30rem;
  height: 14rem;
}
.modal.lyrics-modal {
  width: 100%;
  border: none;
  box-shadow: none;
  padding: 12rem 0 4rem 0;
  height: 100vh;
  z-index: 0;
}
.modal.lyrics-modal #modalTitle {
  display: block;
  height: initial;
  max-width: 32rem;
  width: 100%;
  margin: auto;
  font-size: 2rem;
  font-family: var(--lyrics-trigger-font);
}
@media (max-width: 36em) {
  .modal.lyrics-modal #modalTitle {
    font-size: 1.8rem;
    max-width: 21rem;
    line-height: 1.9rem;
  }
}
.modal.lyrics-modal #modalContent {
  font-family: var(--lyrics-font);
  font-size: 1.6rem;
  max-width: 34rem;
  margin: auto;
  line-height: 2.3rem;
}
@media (max-width: 36em) {
  .modal.lyrics-modal #modalContent {
    font-size: 1.1rem;
    max-width: 21rem;
    line-height: 1.8rem;
    letter-spacing: -0.3px;
  }
}
.modal.lyrics-modal #modalContent pre {
  display: inline-block;
  width: 2.5rem;
  margin: 0;
}
.modal.lyrics-modal .close {
  position: absolute;
  right: 3rem;
  top: 1rem;
  font-size: 5rem;
  cursor: pointer;
}
.modal.lyrics-modal .close:hover {
  opacity: 0.5;
}
.modal.lyrics-modal .modal-content {
  position: relative;
  overflow-y: scroll;
  max-height: 80vh;
  text-align: left;
}
.modal.apple-modal {
  max-width: 30rem;
  width: 90%;
  padding-top: 5rem;
  padding-bottom: 2rem;
}

body {
  height: 100vh;
  height: 100dvh;
  position: relative;
}
body#home::after {
  content: "";
  width: 100%;
  height: 100vh;
  height: 100dvh;
  position: absolute;
  top: 0;
  left: 0;
  background-image: url("../assets/img/kesha-bg.webp");
  background-size: cover;
  background-position: center;
  z-index: -1;
  animation: bg_fade_in 500ms linear;
}
@media (max-width: 36em) {
  body#home header .logo img {
    filter: invert(1);
  }
}
@media (max-width: 36em) {
  body#home header nav a.nav:hover::after {
    animation: border_white_anim 200ms linear forwards;
  }
}
@media (max-width: 36em) {
  body#home header nav a.nav.current::after {
    border-bottom: solid 2px #fff !important;
  }
}
@media (max-width: 36em) {
  body#home header nav a {
    color: white;
  }
  body#home header nav a svg {
    filter: invert(1);
    max-width: 2.2rem;
  }
}
@media (max-width: 36em) {
  body#home section a, body#home section span, body#home section p, body#home section button {
    color: white;
    border-color: white;
  }
}
@media (max-width: 36em) {
  body#home section#gag-section h1 {
    margin-top: 0;
    margin-bottom: 1.2rem;
  }
}
@media (max-width: 36em) {
  body#home section#gag-section img {
    max-width: 26rem;
    width: 100%;
  }
}
@media (max-width: 36em) {
  body#home section img {
    filter: invert(1);
  }
}
@media (max-width: 36em) {
  body#home section .btn::after {
    border-bottom: solid 2px white;
    animation: border_white_anim 300ms linear forwards;
  }
}
@media (max-width: 36em) {
  body#home footer .social a {
    color: white;
  }
}
@media (max-width: 36em) {
  body#home footer .disclaimer svg {
    filter: invert(1);
  }
}
@media (max-width: 75em) {
  body#home footer .disclaimer p {
    color: white;
  }
}
@media (max-width: 36em) {
  body#home footer .disclaimer p a {
    color: white;
  }
}

body#tour-page {
  min-height: 100vh;
  min-height: 100dvh;
  height: 100%;
}
body#tour-page main {
  min-height: 100vh;
  min-height: 100dvh;
  height: 100%;
}

section {
  width: 100%;
}
section#tour {
  display: flex;
  align-items: center;
  padding-top: 13rem;
}
@media (max-width: 48em) {
  section#tour {
    flex-direction: column;
  }
}
section#tour #dates {
  display: grid;
  grid-auto-flow: column;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 5rem;
  row-gap: 1.7rem;
  grid-auto-flow: row;
}
@media (max-width: 87.5em) {
  section#tour #dates {
    max-width: 70rem;
    grid-auto-flow: initial;
    grid-template-columns: initial;
  }
}
@media (max-width: 48em) {
  section#tour #dates {
    max-width: 90%;
    display: flex;
    flex-direction: column;
    gap: 3rem;
  }
}
section#tour #dates .event * {
  font-family: var(--main-font);
  font-size: 1.2rem;
  text-transform: uppercase;
}
section#tour #dates .event .bit-details {
  display: grid;
  grid-template-columns: 8rem 1fr 21rem;
}
@media (max-width: 48em) {
  section#tour #dates .event .bit-details {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
}
section#tour #dates .event .bit-details .location2 .location-separator {
  display: none;
}
section#tour #dates .event .bit-details .tickets {
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  gap: 1rem;
}
section#tour #dates .event .bit-details .tickets a {
  width: 10rem;
  text-align: center;
  padding: 0.8rem 0 0.8rem 0;
  position: relative;
}
section#tour #dates .event .bit-details .tickets a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  border-bottom: solid 3px #000;
  animation: border_anim 300ms linear forwards;
}
@media (max-width: 36em) {
  section#tour #dates .event .bit-details .tickets a::after {
    border-bottom: solid 2px #000;
  }
}
section#tour #dates .event .bit-details .tickets a:hover::after {
  content: "";
  position: absolute;
  left: 0;
  width: 0;
  animation: border_anim 300ms linear forwards;
}
section#tour #dates .event .bit-details .tickets .tickets-link.soon {
  display: none;
}
section#tour #dates .no-events {
  text-align: center;
}

section {
  width: 100%;
}
section#lyrics {
  display: flex;
  align-items: center;
}
@media (max-width: 36em) {
  section#lyrics {
    flex-direction: column;
  }
}
section#lyrics .container {
  display: grid;
  grid-template-columns: 1fr 37rem 1fr;
  align-items: center;
  gap: 6rem;
  max-width: 130rem;
}
@media (max-width: 87.5em) {
  section#lyrics .container {
    grid-template-columns: 1fr 29rem 1fr;
  }
}
@media (max-width: 62em) {
  section#lyrics .container {
    padding-top: 4rem;
    display: grid;
    gap: 0.5rem;
    grid-template-areas: "lyrics-1" "lyrics-2" "lyrics-download";
    grid-template-columns: 1fr;
  }
  section#lyrics .container ul {
    margin: 0;
  }
  section#lyrics .container ul:first-of-type {
    grid-area: lyrics-1;
  }
  section#lyrics .container ul:last-of-type {
    grid-area: lyrics-2;
  }
  section#lyrics .container div {
    grid-area: lyrics-download;
  }
  section#lyrics .container div img.album-artwork {
    display: none;
  }
}
section#lyrics .container a.download-lyrics {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 1rem;
  gap: 0.5rem;
}
section#lyrics .container a.download-lyrics:hover {
  opacity: 0.8;
}
section#lyrics .container a.download-lyrics svg {
  max-width: 1.4rem;
}
section#lyrics ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
@media (max-width: 36em) {
  section#lyrics ul {
    gap: 0.5rem;
  }
}
section#lyrics ul li button {
  font-family: var(--lyrics-font);
  font-size: 1.9rem;
  text-transform: uppercase;
  background-color: transparent;
  border: none;
  margin-left: 0;
  padding: 0;
  transition: all 300ms;
  cursor: pointer;
  display: grid;
  grid-template-columns: 2.3rem 1fr;
  gap: 3rem;
  text-align: left;
  color: var(--main-color);
}
@media (max-width: 87.5em) {
  section#lyrics ul li button {
    font-size: 1.4rem;
  }
}
@media (max-width: 48em) {
  section#lyrics ul li button {
    font-size: 1.2rem;
    gap: 2rem;
  }
}
section#lyrics ul li button .track-number {
  text-align: right;
}
section#lyrics ul li button:hover {
  filter: opacity(0.4);
}
section#lyrics ul li button span.track-number {
  text-align: right;
}

body#photos-page {
  min-height: 100vh;
  min-height: 100dvh;
  height: 100%;
}
body#photos-page main {
  min-height: 100vh;
  min-height: 100dvh;
  height: 100%;
}

section {
  width: 100%;
}
section#photos {
  display: flex;
  align-items: center;
  flex-direction: column;
  padding-top: 13rem;
}
section#photos .container {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
@media (max-width: 36em) {
  section#photos .container {
    max-width: 70%;
  }
}

/*# sourceMappingURL=style.css.map */
