/* General site wide styles */
html{
  scroll-behavior: smooth;
}


body{
    background-color: black;
    overflow-x: hidden;
    margin: 0!important;
}
body::-webkit-scrollbar{
    display: none;
  }
p, a, span{
    font-family: 'IBM Plex Mono', monospace;
    color: white;
    font-size: .6rem;
    margin: 0;
    vertical-align: baseline;
}
a{
    text-decoration: none;
}
.bodyWrapper{
    margin: auto;
}
.data{
    width: fit-content;
}



/* header */
.header{
    width: calc(100% - 16px);
    display: flex;
    padding: 0 8px 20px 8px;
    position: fixed;

    z-index: 2;
}
.headerSpacer{
  width: 100vw;
  padding-bottom: calc((var(--vh,1vh) * 20) - 40px);
  padding-top: 34px;
}
.headerLeft{
  width: 50%;
  margin-top: 16px;
  margin-left: 8px;
}
.headerRight{
  margin-left: auto;
  float: right;
  margin-top: 16px;
  display: flex;
}



/* Navingation/menu */
.nav{
  align-self: flex-end;
  margin-right: 8px;
}
.menu {
  position: fixed;
  right: -50vw;
  top: 0;
  bottom: 0;
  width: 50vw;
  background-color: black;
  transition: right 0.5s ease-in-out;
  z-index: 2;
}
.menu.open {
  right: 0;
}
.overlay {
  position: fixed;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  background-color: rgba(0, 0, 0, 0);
  transition: background-color 0.5s ease-in-out;
  z-index: -1;
}
.overlay.open {
  background-color: rgba(0, 0, 0, 0.8);
  z-index: 1;
}
.overlay.fade-out {
  background-color: rgba(0, 0, 0, 0);
}
.menu.open + .overlay {
  background-color: rgba(0, 0, 0, 0.8);
  z-index: 1;
}
.closeWrapper{
  width: 100%;
  display: flex;
  padding-top: 24px;
  padding-bottom: 87px;
}
.close-button{
  margin-left: auto;
  float: right;
  padding-right: 24px;
}



/* Holding page */
.holding{
  position: absolute;
  top: 50%;
  left: 50%;
  width: 170px;
  height: 90px;
  margin: -85px 0 0 -45px;
}
.centre{
  text-align: center;
}




/* Home page */
.contentWrapperIndex{
  margin: 0 16px;
}


/* Four column grid */
.projContWrapper{
  margin: 0 16px;
}
.fourCol{
  width: 100%;
  display: grid;
  grid-template-columns: repeat(4,1fr);
  grid-template-rows: repeat(3,1fr);
  grid-column-gap: 16px;
  grid-row-gap: 24px;
  counter-reset: item;
  height: 75vw;
}
.gridDefault{
  width: 100%;
  position: relative;
  counter-increment: item;
  cursor: pointer;
}
.gridDefault img{
  max-width: 100%;
  height: 94%;
  object-fit: cover;
}
.gridBig img{
  max-width: 100%;
  height: 97%;
  object-fit: cover;
}
.gridBig{
  grid-column: 1 / span 2;
  grid-row: 2 / span 2;
  width: 100%;
  position: relative;
  cursor: pointer;
}





/* Project pages */
.featureImg img{
  width: 100%;
  max-height: 92vh;
  object-fit: cover;
}
.b-list{
  display: flex;
  padding: 0 16px;
  text-transform: uppercase;
  padding-bottom: 20px;
  font-size: .78125vw;
}
.b-id{
  width: 20%;
}
.b-n, .b-p{
  width: 25%;
}
.b-p{
  padding-right: 2%;
}
.b-l{
  width: 28%;
}
.projSpacer{
  margin-top: 3vh;
  margin-bottom: 3vh;
}


/* Project archive */
.contentWrapper:hover .a-list:not(:hover) {
    opacity: 0.5;
}
.line {
    visibility: hidden;
}
.a-list{
    display: flex;
    padding: 0 16px;
    text-transform: uppercase;
    padding-bottom: 20px;
    font-size: .78125vw;
}
.a-id{
    width: 20%;
}
.a-n, .a-p{
    width: 25%;
}
.a-l{
    width: 30%;
}
.prjHoverImgWrap{
  position:fixed;
  z-index: -2;
  margin-left: auto;
  margin-right: auto;
  top: 50%;
  left: 50%;
  top: 30vh;
  max-width: 40vw;
  object-fit: cover;
}
.prjHoverImg{
  transform: translate(-50%, 0%)!important;
  max-height: 40vh;
  visibility: hidden;
  max-width: 40vw;
  object-fit: cover;
}
#prjHoverImg24, #prjHoverImg23, #prjHoverImg22, #prjHoverImg21, #prjHoverImg20, #prjHoverImg19, #prjHoverImg18, #prjHoverImg17, #prjHoverImg16, #prjHoverImg15, #prjHoverImg14, #prjHoverImg13, #prjHoverImg12, #prjHoverImg11, #prjHoverImg10, #prjHoverImg9, #prjHoverImg8, #prjHoverImg7, #prjHoverImg6, #prjHoverImg5, #prjHoverImg4, #prjHoverImg3, #prjHoverImg2, #prjHoverImg1{
  opacity: 0;
  transition: opacity 0.25s ease-in-out;
  -moz-transition: opacity 0.25s ease-in-out;
  -webkit-transition: opacity 0.25s ease-in-out;
}
#pr-24:hover ~ .prjHoverImgWrap > #prjHoverImg24{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out; 
}
#pr-23:hover ~ .prjHoverImgWrap > #prjHoverImg23{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-22:hover ~ .prjHoverImgWrap > #prjHoverImg22{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-21:hover ~ .prjHoverImgWrap > #prjHoverImg21{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-20:hover ~ .prjHoverImgWrap > #prjHoverImg20{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-19:hover ~ .prjHoverImgWrap > #prjHoverImg19{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-18:hover ~ .prjHoverImgWrap > #prjHoverImg18{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-17:hover ~ .prjHoverImgWrap > #prjHoverImg17{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-16:hover ~ .prjHoverImgWrap > #prjHoverImg16{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-15:hover ~ .prjHoverImgWrap > #prjHoverImg15{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-14:hover ~ .prjHoverImgWrap > #prjHoverImg14{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-13:hover ~ .prjHoverImgWrap > #prjHoverImg13{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-12:hover ~ .prjHoverImgWrap > #prjHoverImg12{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-11:hover ~ .prjHoverImgWrap > #prjHoverImg11{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-10:hover ~ .prjHoverImgWrap > #prjHoverImg10{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-9:hover ~ .prjHoverImgWrap > #prjHoverImg9{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-8:hover ~ .prjHoverImgWrap > #prjHoverImg8{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-7:hover ~ .prjHoverImgWrap > #prjHoverImg7{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-6:hover ~ .prjHoverImgWrap > #prjHoverImg6{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-5:hover ~ .prjHoverImgWrap > #prjHoverImg5{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-4:hover ~ .prjHoverImgWrap > #prjHoverImg4{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-3:hover ~ .prjHoverImgWrap > #prjHoverImg3{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-2:hover ~ .prjHoverImgWrap > #prjHoverImg2{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}
#pr-1:hover ~ .prjHoverImgWrap > #prjHoverImg1{
  visibility: visible;
  opacity: 0.8;
  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}

  
  
/* Project pages */
.footer{
  text-align: center;
  padding: 40px 0;
}
  

  

