@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;
}

body { /*#d6cdb7;*/
  background-color: #d6cdb7;
  color: #2b2209;
  margin: 0;
  font-family: sans-serif;
  overflow-x: hidden;
   touch-action: manipulation !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@font-face {
  font-family: "FT1";
  src: url("OTGubestileUnlicensedTrial-Extended.otf")
    format("opentype");
}

@font-face {
  font-family: "FT2";
  src: url("OPTISpire.otf")
    format("opentype");
}

a {text-decoration:none; color: #090909 !important;}

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

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


h1 {font-weight:normal;}


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

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

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


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



.logoSpan {
  font-family: "FT1";	
  margin-bottom:0;
  margin-top:0;
  font-weight:300;
  font-size: .9vw;
  line-height: 1.2em;
  letter-spacing:.35em;	
  text-transform:uppercase;
}

#fixed-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 1;
  mix-blend-mode: multiply;
}

.imgHolder {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 60%;
  height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
  will-change: transform, opacity;
  transform: translateZ(0);
  backface-visibility: hidden;
}

.imgHolder img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  cursor: pointer;
  will-change: opacity;
  transform: translateZ(0);
  backface-visibility: hidden;
}

.imgHolder h1 {
  font-family: "FT2";
  position: absolute; 
  margin: 0;
  color: #171717;
  opacity: 0; 
  pointer-events: none; 
  letter-spacing:.05em;
  text-transform:uppercase;
  display: block !important;
  text-align:center;
  font-size: 400px;
  width: max-content; 
  line-height: 1.15;
  will-change: opacity, transform;
  transform: translateZ(0); 
  backface-visibility: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

#slide-counter {
  position: fixed;
  bottom: 40px;
  right: 40px;
  z-index: 100;
  color: #171717;
  font-family: sans-serif;
  font-size: 14px;
  letter-spacing: 1px;
  pointer-events: auto;
  cursor: pointer;
  transition: opacity 0.3s ease;
  font-variant-numeric: tabular-nums; 
  opacity:.2;
}

#slide-counter:hover {
  opacity: 1;
}

#salon-view {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 200;
  background-color: #d6cdb7;
  display: none;
  opacity: 0;
  overflow: hidden; /* Hide scrollbars, we will pan with GSAP */
}

#salon-canvas {
  position: absolute;
  width: 300vw; 
  height: 300vh;
  top: -100vh;
  left: -100vw;
}

.salon-img {
  position: absolute;
  max-width: 50vw;
  /*box-shadow: 0 20px 40px rgba(0,0,0,0.15);*/
  cursor: grab;
}

.salon-img:active {
  cursor: grabbing;
}

#salon-close {
  position: fixed;
  top: 40px;
  right: 40px;
  z-index: 201;
  color: #171717;
  font-family: sans-serif;
  font-size: 14px;
  letter-spacing: 1px;
  cursor: pointer;
  display: none;
  opacity: 0;
  text-transform: uppercase;
}



@media (max-width: 768px) {
  .imgHolder {
    width: 70%;
    height: 60vh;
  }
}

#trigger-area {
  position: relative;
  z-index: 2;
  pointer-events: none;
}
#empty-container {
  height: 50vh;
  background-color: none;
  position: relative;
  z-index: 10;
}
