* {
  margin: 0;
  padding: 0;
  color: var(--white);
  -webkit-font-smoothing: antialiased;
}

:root {
  /* colors */
  --yellow: #ff73c7;
  --magenta: #ff73c7;
  --aqua: #00FFC5;
  --green:#23C055;
  --blue: #7173ff;
  --black: #D0D0D0;
  --white: #000000;
}

.noselect {
  -webkit-touch-callout: none;
  /* iOS Safari */
  -webkit-user-select: none;
  /* Safari */
  -khtml-user-select: none;
  /* Konqueror HTML */
  -moz-user-select: none;
  /* Old versions of Firefox */
  -ms-user-select: none;
  /* Internet Explorer/Edge */
  user-select: none;
  /* Non-prefixed version, currently
                                  supported by Chrome, Opera and Firefox */
}

*:focus {
  outline: 0;
}

.wistia_click_to_play{
  height: 100% !important;
  width: 100% !important;
  display: flex;
}

a {
  cursor: url(../img/cursor/cursor-link.png), auto;
  text-decoration: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet{
  cursor: url(../img/cursor/cursor-link.png), auto;
}

body {

  cursor: url(../img/cursor/cursor-hand.png), auto;
  background-color: var(--black);
  color: var(--white);
  font-family:'Maru',monospace;
  font-weight: 500;
  letter-spacing: -0.045em;
}

h1, h2, h3 {
  font-family: 'DaVinci', Georgia;
  font-weight: normal;
  /* transition: all 0.2s ease; */
}

h1 {
  font-size: 8.4svw;
  font-weight: normal;
  letter-spacing: -0.05em;
  line-height: 117%;
}

h2 {
  font-size: 90px;
  font-weight: normal;
  margin: -15px 0 -15px 0;
  /* text-transform: uppercase; */
  letter-spacing: -5px;
  line-height: 80px;
}

h3 {
  font-size: 2.8svw;
  font-weight: normal;
  letter-spacing: -0.05em;
  line-height: 117%;
}

p {
  /* font-size: 26px;
  line-height: 32px;
  font-weight: 500;
  letter-spacing: -0.04em; */
}

#logo {
  width: 200px;
  margin: 75px 0 75px 0;
  box-sizing: border-box;
}

#logo img, #logoMini img, #tagline img {
  width: 100%;
}

#works {
  background-color: var(--black)
}

#intro {
  display: flex;
  justify-content: center;
  padding-bottom: 120px;
  background-image: url('../img/graphic-2-EP.svg');
  background-repeat: no-repeat;
  background-size: contain;
  overflow: hidden;
}

.intro-heading, .intro-body{
  width: 100%;
}


#outro {
  display: flex;
  justify-content: center;
  padding-bottom: 120px;
  padding-top: 120px;
}

.introWithReel {
  width: 100%;
  display: flex;
  margin-top: 10svw;
  justify-content: space-between;
  box-sizing: border-box;
  overflow: hidden;
  justify-content: flex-start;
  box-sizing: border-box;
  overflow: hidden;
  flex-direction: column;
  gap: 120px;
}

.introCopy, .footerLinksContainer {
  width: 100%;
  box-sizing: border-box;
  display: flex;
  gap: 5svw;
  font-family: 'America', Arial, Helvetica, sans-serif;


  font-size: 26px;
  line-height: 140%;
  font-weight: 500;
  letter-spacing: -0.04em;
}

.footerLinksContainer{
  margin-top: 80px;
}



.footerLogos{
  display: flex;
  justify-content: space-between;
  align-items: end;
  width: 100%;
  box-sizing: border-box;
  margin-top: 170px;
}

#tagline{
  width: 300px;
}

#logoMini{width: 100px;}

.footerLinksContainer {
  display: flex;
}

.footerLinks {
  margin-right: 100px;
  font-family:'Maru',monospace;
  font-weight: 500;
  letter-spacing: -0.045em;
  font-size: 16px;
}

.footerLinksHeading {
  color: var(--yellow)
}

.reelThumbsStack {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 30px;
}

.videoThumb{
  width: 100%;
  z-index: 10;
  border-radius: 5px;
  position: relative;
}

.reelIcon {
  box-sizing: border-box;
  cursor: url(../img/cursor/cursor-link.png), auto;
  z-index: 2;
  /* min-height: 400px; */
  /* background-color: black; */
/* border-radius: 5px; */
overflow: hidden;
padding: 0;
position: relative;
}

.reelIcon img, .reelIcon picture{
  width: 100%;
  height: 100%;
  z-index: 1;
position: relative;
bottom: 0;
}



#thumb1{
  background-image: url('../img/HypeReelIcon_01_temp_2x.png');
  background-size: cover;
  background-repeat: no-repeat;
  aspect-ratio: 1680/1059;
}

#thumb2{
  background-image: url('../img/HypeReelIcon_02_2x.png');
  background-size: cover;
  background-repeat: no-repeat;
  aspect-ratio: 1680/345;
}

.section {
  background-color: var(--black);
  display: flex;
  justify-content: center;
  padding: 100px 0 100px 0;
}

.projectContainer {
  flex-grow: 1;
  max-width: 1920px;
  padding: 0 80px;
  overflow-x: hidden;
}

.sectionHeading {
  display: flex;
  align-items: flex-end;
  padding: 100px 0;
}

.sectionExtras {
  display: flex;
  padding: 100px 0;
}

.sectionIntro {
  font-family: 'America', Arial, Helvetica, sans-serif;
  font-size: 29px;
  line-height: 120%;
  letter-spacing: -0.035em;

}

.sectionDescription {
  font-size: 15px;
  line-height: 22px;
}

.sectionTitle, .sectionIntro, .sectionDetails, .sectionDescription {
  /* flex: 0 0 50%; */
}

.sectionTitle, .sectionDetails {
  /* margin-right: 20px; */
  flex: 0 0 45%;
  margin-right: 5%;
}

.sectionDetails {
  display: flex;
  flex-direction: column;
  align-content: flex-start;
  align-items: flex-start;
}

.sectionIntro, .sectionDescription {
  /* margin-left: 50px; */
  flex: 0 0 50%;
    margin-bottom: -10px;
}

.sectionImage {
  background-color: var(--black);
  flex: 0 0 100%;
  height: 400px;
}

.sectionDetails-simple {
  margin: 10px;
}

.sectionDetails-full {
  background-color: var(--black);
  color: var(--white);
  padding: 8px 14px 8px 14px;
  margin-top: 3px;
  margin-bottom: 15px;
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing: 0.05em;
  line-height: 13px;
  border-radius: 5px;
}

.projectStats {
  margin-bottom: 15px;
  line-height: 15px;
  display: flex;
align-items: flex-start;
}

.projectStatHeading {
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing: 4px;
  line-height: 21px;
  border-radius: 5px;
  min-width: 75px;
  display: inline-block;
  margin-right: 20px;
}

.projectStatDescription {
  /* font-size: 13px; */
  line-height: 21px;
}

.sectionCarousel {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: column;
}

.swiper-container {
  width: 100%;
  /* max-width: 1050px; */
  height: 100%;
  /* box-shadow: 0px 3px 2px rgba(0, 0, 0, 0.02); */
  border-radius: 5px;
  cursor: url(../img/cursor/cursor-swipe.png), auto;
}

.swiper-slide {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  text-align: center;
  font-size: 18px;
  background: var(--white);
  height: auto;
}

.swiper-pagination {
  position: relative;
  margin-top: 28px;
}

.swiper-pagination-bullet {
  border-radius: 30%;
  margin-right: 5px;
  opacity: 1;
}

.swiper-pagination-bullet-active {
  background: var(--white)
}

.swiper-pagination-bullet:last-child {
  margin: 0;
}

.projectThumb{
  cursor: url(../img/cursor/cursor-swipe.png), auto;
}

img.projectThumb {
  width: 100%;
}

.statementContainer {
  position: relative;
  width: 73svw;
  min-height: 30svw;
}

#mainStatement {
  /* box-sizing: border-box; */
  /* border: solid 1px transparent; */
}

/* #handles {
  width: 100%;
  height: 100%;
  visibility: hidden;
} */

#mainStatement:hover {
  /* border: solid 1px var(--aqua); */
  cursor: url(../img/cursor/cursor-reload.png), auto;
  /* transition: all 0s; */
}

.footerStack{
  display: flex;
  flex-direction: column;
  gap: 30px;
  margin-top: 60px;
}

/* .editingHandles {
  width: 6px;
  height: 6px;
  background: var(--black);
  border: solid 1px var(--aqua);
  position: absolute;
  transform: translate(-4px, -4px);

} */


.handleH_1 {
  left: 0;
}

.handleH_2 {
  left: 50%;
}

.handleH_3 {
  left: 100%;
}

.handleV_1 {
  top: 0;
}

.handleV_2 {
  top: 50%;
}

.handleV_3 {
  top: 100%;
}

@keyframes wiggle {
  0% {
    top: 0px;
  }

  5% {
    top: -10px;
  }

  10% {
    top: 10px;
  }

  15% {
    top: 0px;
  }

  100% {
    top: 0px;
  }
}

#interchangableRole {
  color: var(--yellow);
  position: relative;
  /* transition: all 0.2s ease; */
  /* animation: mymove 2s infinite; */
}

.megaMail {
  margin-top: 50px;
  font-size: 16px;
  line-height: 28px;
  font-weight: normal;
}

@keyframes rainbowColor {
  0% {
    color: var(--aqua);
  }

  25% {
    color: var(--yellow);
  }

  50% {
    color: var(--magenta);
  }

  75% {
    color: var(--blue);
  }

  100% {
    color: var(--aqua);
  }
}

.flickeringMail {
  animation: rainbowColor 1s infinite;
}

#reloadTooltip {
  position: absolute;
  bottom: 95px;
  right: 0px;
  background-color: var(--green);
  color: var(--white);
  z-index: 9000;
  /* visibility: hidden; */
  padding: 8px 14px 8px 14px;
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing: 0.04em;
  line-height: 13px;
  border-radius: 5px;
  min-width: 184px;
  /* height: 40px; */
}


.fullWidthVideoContainer{
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  position: fixed;
  z-index: 99999999999999;
  background-color: var(--black);
}

#reelButton2022{
  /* min-height: 415px;
  margin-bottom: 25px; */
}

#reelButton2020{
  /* min-height: 215px; */
}

#reelButton_popover{
  border-radius: 17px !important;
  overflow: hidden !important;
  cursor: url(../img/cursor/cursor-hand.png), auto !important;
}



.reelPreview {
  /* visibility: hidden; */
  width: 19%;
  height: 65%;
  left: 61.5%;
  top: 13.5%;
  border-radius: 5px;
  position: absolute;
  background-image: url("../img/previewReel/previewReel_spritesheet-temp.png");
  background-size: 800% 200%;
  background-repeat: no-repeat;
  background-position-x: 100%;
  animation: playX 1.5s steps(8) infinite,
              playY 12s steps(2) infinite,
              revealIntro 3s steps(2);
  z-index: 0;
  animation-fill-mode: both;
}

@keyframes playX {
  from {background-position-x: 0%;}
  to {background-position-x: 114.28%}
}

@keyframes playY {
  from {background-position-y: 0%}
  to {background-position-y: 200%}
}

@keyframes revealIntro {
  /* from {visibility: hidden}
  to {visibility:visible} */
}



/*//////////////////////////////////// RESPONSIVE //////////////////////////////////////////*/
/*//////////////////////////////////// RESPONSIVE //////////////////////////////////////////*/
/*//////////////////////////////////// RESPONSIVE //////////////////////////////////////////*/
/*//////////////////////////////////// RESPONSIVE //////////////////////////////////////////*/
/*//////////////////////////////////// RESPONSIVE //////////////////////////////////////////*/
/*//////////////////////////////////// RESPONSIVE //////////////////////////////////////////*/
/*//////////////////////////////////// RESPONSIVE //////////////////////////////////////////*/
/*//////////////////////////////////// RESPONSIVE //////////////////////////////////////////*/

/* INBETWEENS */
@media only screen and (max-width: 1050px) {
  /* body {
    background-color: grey
  } */

  #intro {
    /* background-size: 130%;
    background-position: 50% -5%; */
  }

  .projectContainer {
    max-width: 85%;
  }

  .introWithReel {
    /* flex-direction: column;
    margin-top: 50px; */
  }

  .introCopy, .footerLinksContainer {
    /* width: 45%; */
  }

  .reelThumbsStack {
    /* width: 100%; */
    /* margin-top: 30px; */

  }

  h1 {
    font-size: 9svw;
    font-weight: normal;
    letter-spacing: -0.05em;
    line-height: 115%;
  }

  h2 {
    font-size: 56px;
    margin: -15px 0 -15px 0;
    /* text-transform: uppercase; */
    line-height: 55px;
  }

  h3 {
    font-size: 3.8svw;
    font-weight: normal;
    letter-spacing: -0.05em;
    line-height: 117%;
  }

  p {
    /* font-size: 16px;
    line-height: 28px; */
  }

  .introCopy, .footerLinksContainer {
    font-size: 21px;
  }
  

  .sectionDetails-full {

    font-size: 9px;

  }


  #logo {
    width: 200px;
    margin: 30px 0 30px 0;
    box-sizing: border-box;
  }

  .section{
    padding: 50px 0 50px 0
  }

  .statementContainer {
    position: relative;
    width: 100%;
  }

  .sectionHeading {
    /* padding: 50px 0; */
    /* flex-direction: column;
    align-items: flex-start; */
  }

  .sectionTitle, .sectionDetails {
    /* margin-right: 20px; */
    flex: 0 0 45%;
    margin-right: 10%;
  }

  .sectionIntro {
    font-size: 18px;
    line-height: 23px;
    font-weight: 500;
    /* flex: 0 0 45%; */
  }

  .sectionDescription {
    /* margin-left: 50px; */
    flex: 0 0 45%;
    font-size: 13px;
    line-height: 140%;
}

.sectionIntro{

font-size: 22px;
line-height: 120%;
}

  .sectionDetails{

  }

  .sectionExtras {
    /* flex-direction: column;
    padding: 50px 0; */
  }

  .footerLinksContainer{
    /* margin-top: 50px; */
  }

  #reloadTooltip {
    /* margin-left: -100px; */
    top: auto;
    bottom: 30px;
    /* top:78%; */
    /* left:43%; */
    font-size: 10px;
    padding: 4px 8px 1px 8px;
    text-transform: uppercase;
    letter-spacing: 2px;
    line-height: 10px;
    border-radius: 5px;
    width: 161px;

  }



  #thumb1{
    background-image: url('../img/HypeReelIcon_01-tablet_temp_2x.png');
    aspect-ratio: 1680/1059;
  }

  #thumb2{
    background-image: url('../img/HypeReelIcon_02-tablet_2x.png');
    aspect-ratio: 1680/414;
  }
}





/* PHONES */



@media only screen and (max-width: 800px) {
  /* body {
    background-color: blue
  } */

  .projectContainer {
    max-width: 100%;
    padding: 0 16px;
  }

  .introWithReel {
    flex-direction: column;
    margin-top: 15svw;
    gap: 50px;
  }

  .introCopy{
    flex-direction: column;
  }

  .introCopy, .footerLinksContainer {
    width: 100%;
    gap: 9svw;
  }

  #intro {

    padding-bottom: 70px;

}

  #outro {

    padding-bottom: 50px;

  }

  .footerLogos{
    margin-top: 70px;
  }

  .footerLinks {
    font-size: 12px;
}

  .reelThumbsStack {
    width: 100%;
    /* margin-top: 30px; */
  }

  h1 {
    font-size: 13svw;
    font-weight: normal;
    letter-spacing: -0.05em;
    line-height: 115%;
  }

  h2 {
    font-size: 66px;
    margin: -15px 0 -15px 0;
    /* text-transform: uppercase; */
    line-height: 66px;
  }

  h3 {
    font-size: 8.5svw;
    font-weight: normal;
    letter-spacing: -0.05em;
    line-height: 120%;
  }

  p {
    /* font-size: 14px;
    line-height: 27px; */
  }

  #logo {
    width: 170px;
    margin: 30px 0 30px 0;
    box-sizing: border-box;
  }

  .section{
    padding: 50px 0 50px 0
  }

  .sectionHeading {
    padding: 50px 0;
    flex-direction: column;
    align-items: flex-start;
  }

  .sectionTitle, .sectionDetails {
    /* margin-right: 20px; */
    flex: 0 0 100%;
    margin-right: 0;
    margin-bottom: 30px;;
  }

  .sectionIntro {
    font-size: 19px;
    line-height: 127%;
  }

  .sectionDetails{

  }

  .sectionExtras {
    flex-direction: column;
    padding: 50px 0;
  }

  .projectStatDescription {
    font-size: 15px;
    line-height: 20px;
    }

    .projectStatHeading {
        font-size: 11px;
      }

  .footerLinksContainer{
    margin-top: 50px;
  }

  #reloadTooltip {
    /* margin-left: -100px; */
    top: auto;
    bottom: 30px;
    /* top:78%; */
    left:43%;
    font-size: 10px;
    padding: 6px;
    text-transform: uppercase;
    letter-spacing: 2px;
    line-height: 10px;
    border-radius: 5px;
    min-width: 178px;

  }

  #logoMini{
    width:12%;
   }
   
   #tagline{
    width: 40%;
   }


    #thumb1{
      background-image: url('../img/HypeReelIcon_01-mobile_temp_2x.png');
      aspect-ratio: 1680/1059;
    }

    #thumb2{
      background-image: url('../img/HypeReelIcon_02-mobile_2x.png');
      aspect-ratio: 1680/562;
    }
   
}


@keyframes clessidraSpin {
  0% {
    transform: rotate(0deg);
  }

  25% {
    transform: rotate(180deg);
  }

  100% {
    transform: rotate(180deg);
  }
}


.swiper-lazy-preloader{

  width: 27px;
  height: 26px;
  margin-left: -13px;
margin-top: -13px;

  border: none;
  background-image: url('../img/clessidra.svg');
  background-repeat: no-repeat;
  background-size: cover;

  animation: clessidraSpin 1s infinite ease;
}

