@charset "utf-8";
address,
article,
aside,
button,
blockquote,
body,
dd,
dialog,
dl,
dt,
fieldset,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
li,
nav,
ol,
p,
pre,
section,
td,
th,
tr,
ul {
  margin: 0;
  padding: 0;
}

* {
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
}


body {
  background: #ebece7;
  color: #2b2209;
  margin: 0;
  padding: 0;
  font-family: "AGB1";
  width: 100vw !important;
  overflow-x: hidden;
  height:auto;	
  line-height: 0;
  touch-action: manipulation !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
	

@font-face {
  font-family: "AGB1";
  src: url("FKTSinvollSansMono_Rg.ttf")
    format("truetype");
}

@font-face {
  font-family: "RM1";
  src: url("FKTSinvollSansMono_Rg.ttf")
    format("truetype");
}

a {color: #2b2209; text-decoration:none;}

.btn:focus {
  outline: none !important;
  box-shadow: none !important;
}

::-webkit-scrollbar {
  display: none !important; 
  width: 0px !important;	
  opacity: 0 !important; 	
}

html {
    -webkit-text-size-adjust: 100%; /* Prevent font scaling in landscape while allowing user zoom */
}



.transition-fade {
    transition: .4s;
    opacity: 1;
	/*transition-delay: .3s;*/
}

html.is-animating .transition-fade {
    opacity: 0;
}



.lazyload,
.lazyloading {
	opacity: 0;
}
.lazyloaded {
	opacity: 1;
	transition: opacity 300ms;
}


h1 {
  font-family: "AGB1";
  line-height: 1em;
  font-weight:normal;
  	
}

h2 {
  font-family: "RM1";
   font-size:1.75vw;
   line-height:1.2em;
   letter-spacing:.01em;
   text-transform:uppercase;
  	
}

.logoType{
  font-size:4vh;	
  font-family: "AGB1";
  line-height: 1em;
  letter-spacing:-.01em;	 
  font-weight:normal;
  text-transform:uppercase;	
  	
}


.container {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: scroll;
  scroll-snap-type: y mandatory;
  scroll-snap-align: center;
  -webkit-transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  will-change:transform;	
	
}

.section {
  height: 100vh;
  width: 100vw;
  position: relative;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  scroll-snap-align: center;
  -webkit-transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  will-change:transform;		
	
}

.section img {
  position: relative;
  width: 100%;
  height: 100%;
  object-fit: cover;
}



.caption1 {
  display: none;
}

.caption2 {
  display: none;
}


.microType{
  font-family: "RM1";
   font-size:1.75vw;
   line-height:1.2em;
   letter-spacing:.01em;
   text-transform:uppercase;
}

.menuFace {
  font-family: "RM1";
   font-size:1vw;
   line-height:1em;
   letter-spacing:.1em;
	text-transform:uppercase;
	transition: color 0.3s ease;
}



.descripType{

 font-family: "RM1";
   font-size:1.15vw;
   line-height:1.5em;
   letter-spacing:.1em;
	text-transform:uppercase;
	
	
}	

.mediumType{
  
   font-size:5.5vw;
   line-height:1em;
   letter-spacing:.3em;
   text-transform:uppercase;
   text-align:center;	
}


.largeType{
  
   font-size:6.5vw;
   line-height:1em;
   letter-spacing:.4em;
	text-transform:uppercase;
}


.xlargeType{
  
   font-size: 11.5vw;
   line-height: 1em;
   text-transform:uppercase;
}

.hugeType{
  
   font-size: 12vw;
   line-height: 1em;
   letter-spacing:.06em;	
   text-transform:uppercase;
	color: #cccbbe;
}


.logoHolder {
   white-space: normal;
      width: 100%;
      text-align: left;
	display: flex;
  flex-direction: column;
  justify-content: space-evenly; /* distributes lines evenly */
  height: 100%;
	will-change: transform;
}


.block {
      white-space: normal;
      width: 100%;
      text-align: left;
	display: flex;
  flex-direction: column;
  justify-content: space-evenly; /* distributes lines evenly */
  height: 100%;
	opacity:0;
    }


.container .block, 
.container2 .block {
  opacity: 0;
}

.primaryLogo {position:fixed; top:0; left:0; z-index:99999 !important; height:100vh; width:100vw; pointer-events:none; display:flex !important; align-items:center; justify-content:center;}


.projectTitles {width:70vw; height:80vh;}
.projectTitles2 {width:70vw; height:100vh;}


.descrContain {
	width:40vw; height:auto; padding-top:20vh; padding-bottom:20vh;
}

.captioner1 {
  display: none;
}

.slides-container {
  position: relative;
  top:0;	
  overflow: hidden;  
  display: flex;
  flex: 1;
  height:100vh;
  width:75vw;	
  transform: will-change	
}

.slides-inner {
  top:0;	
  position: absolute;
  height: 100%;
  width: 100%;  
  overflow: hidden;
}

.slide {
  position: absolute;
  display: flex;
  align-items: end;
  justify-content: flex-start;
  height:100vh;
  width: 75vw;
  padding-right: 200px; 
  box-sizing: content-box;	
}

.slide img {
  object-fit: contain;
  width:75vw;
  max-height:80vh;	
  height:auto;	
  object-position:left bottom;
  	
}

.slide video {

width:auto; height:90vh; max-width:100vw; object-fit:cover; mix-blend-mode:lighten;

}	
	
.prevButton{
  position:absolute;
  left:0;
  top:0;
  width:10vw;
  height:100%;
  opacity:0;
  z-index:10;
  cursor:pointer;
}

.nextButton{
   position:absolute;
  right:0;
   top:0;
  width:10vw; 
  height:100%;
  opacity:0;
  z-index:10;
  cursor:pointer;
}

.stickyContainer {
   z-index:100;
  transition: transform .35s cubic-bezier(.55, .08, 0, 1), opacity .3s cubic-bezier(.55, .08, 0, 1);
  will-change: transform, opacity;
}
.stickyContainer.is-hidden {
  transform: translateY(-15px);
  opacity: 0;
  pointer-events: none;
}

.bottomSet {position:fixed; bottom:2em; left:0; width:97vw; margin-left:1.5vw; display:flex; justify-content:space-between; flex-direction:column; z-index:0; pointer-events:auto !important;}



 /*
  * 
  * 
  * MAINFRAME
  * 
  * 
  * 
  */ 
  

.mainframe {
  opacity: 1 !important;
  transition: opacity 0.25s;
}
.mainframe.is-hidden {
  opacity: 0 !important;
}


.vertical-stack-wrapper {
	display:flex;
	flex-direction:column; 
	gap:250px;
}


.wp-media-block + .wp-media-block {
    margin-top: 250px;
}

.wp-media-block {
    display: flex;
    width: 100vw;
}
.align-left   { justify-content: flex-start; align-items:end; }
.align-center { justify-content: center; align-items:end; }
.align-right  { justify-content: flex-end; align-items:end; }

/* Image Scaling */
.scale-small  { width: 25%; margin-left:5%; margin-right:5%; } /* Or whatever pixel value you prefer */
.scale-medium { width: 45%; }
.scale-large  { height: 90vh; width:auto; max-width:100vw; object-fit:contain; }
.scale-xlarge  { width: 100%; }

/* --- New Row Mode --- */
.row-mode {
    /* Inherits display:flex and width:100vw from .wp-media-block */
    justify-content: space-between; 
    align-items: flex-end;
    padding: 0 5%; /* Optional: Adds safety gutters on the far edges */
    box-sizing: border-box;
}

/* Reset margins inside row-mode so space-between works correctly */
.row-mode img {
    margin-left: 0;
    margin-right: 0;
}

.logoTopper {
    position:fixed; right:2em; top:2em; z-index:9999;"
}

.imgMode {mix-blend-mode:multiply;}
.backgroundCC {background: #ebece7;}




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

	
h2 {
    font-family: "RM1";
   font-size:2.75vw;
   line-height:1.2em;
   letter-spacing:.01em;
   text-transform:uppercase;
  	
}

.logoType{
  font-size:4.5vh;	
  font-family: "AGB1";
  line-height: 1em;
  letter-spacing:-.01em;	 
  font-weight:normal;
  text-transform:uppercase;	
  	
}
	

.microType{
  font-family: "RM1";
   font-size:2.75vw;
   line-height:1.2em;
   letter-spacing:.01em;
   text-transform:uppercase;
}
	
	
	
.logoTopper {
    position:fixed; left:2em; top:2em; z-index:9999;"
}	
	
.descrContain {
	width:70vw; height:auto; padding-top:10vh; padding-bottom:10vh;
}
	
	
.logoHolder {
   white-space: normal;
      width: 100%;
      text-align: left;
	display: flex;
  flex-direction: column;
  justify-content: space-evenly; /* distributes lines evenly */
  height: 100%;
	will-change: transform;
}


.block {
      white-space: normal;
      width: 100%;
      text-align: left;
	display: flex;
  flex-direction: column;
  justify-content: space-evenly; /* distributes lines evenly */
  height: 100%;
    }	
	
	

	
.projectTitles{width:80vw; height:80vh;}	
	
.mediumType{
  
   font-size:7vw;
   line-height:1em;
   letter-spacing:.25em;
	text-transform:uppercase;
}


.largeType{
  
   font-size:8.5vw;
   line-height:1em;
   letter-spacing:.4em;
   text-transform:uppercase;
}


.xlargeType{
  
   font-size: 13.5vw;
   line-height: 1em;
   letter-spacing:0em;
	text-transform:uppercase;
}
	
	
.descripType{

 font-family: "RM1";
   font-size:2.25vw;
   line-height:1.5em;
   letter-spacing:.1em;
	text-transform:uppercase;

	
}	
	
	
.swup-slot { position: relative; height: auto;}

.transition-slide {
  position: absolute;
  inset: 0;
  width: 100vw;
  height: 108vh;
  backface-visibility: hidden;
  will-change: transform, opacity;
  transform: translateZ(0);	
}	
	
.container {
  position: sticky;
  top: 0;
  height: 100dvh;
  overflow-y: scroll;
  scroll-snap-type: y mandatory;
  scroll-snap-align: center;
  -webkit-transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  will-change:transform;
}

.section {
 height: 100dvh;
  width: 100vw;
  position: relative;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  scroll-snap-align: center;
}	

.slides-container {
  position: relative;
  top:0;	
  overflow: hidden;  
  display: flex;
  flex: 1;
  height: 100dvh;
  width:100vw;	
  transform: will-change	
}
	
.slides-inner {
  top:0;	
  position: absolute;
  height: 100%;
  width: 100%;  
  overflow: hidden;
}	

.slide {
  position: absolute;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  height: 100dvh;
  width: 100vw;	
  padding-right: 200px; 
  box-sizing: content-box;
}

.slide img {
  object-fit: cover;
  width:100vw;
  height: auto;	
  max-height:65vh;
  min-height:45vh;
  object-position: 50% 50%;
	
}
	
	
	
	
}


*:focus {
  outline: 0;
  outline: none;
}


