/* =Header */

:root {
--header-background-color:transparent;
--header-overlay-background-color:#141B27;
--header-toggle-color-default:#D79B40;
--header-toggle-color-hover:#DFAF66;
--header-toggle-color-hero:#D79B40;
--header-toggle-color-hero-hover:#DFAF66;
--header-toggle-color-menu:#111;
--header-default-height: 270px;
--header-mobile-height: 250px;
}

.header-block {
height: var(--header-default-height);
}
.hero-gallery-page .header-block {
position: absolute;
top: 0;
left: 0;
width: 100%;
z-index: 100;
height: var(--header-default-height);
}

.header[data-header-transparent="true"] .header-main {
position:absolute;
background-color: transparent;
}
.header-main {
background-color: var(--header-background-color);
}

/* =Position */

.header-position {
position: absolute;
top:0;
left:0;
}

@media screen and (max-width:999px) {
  .header-proxy,
  .header-main,
  .header-block,
  .hero-gallery-page .header-block {
  height:var(--header-mobile-height);
  }
}


/* =Logo */
:root {
--default-logo-width: 200px;
}

.header-logo {
position: relative;
top: 30px;
transition: opacity 0.35s ease;
opacity: 1;
will-change: opacity;
}
.header-position-exited .header-logo,
.home.header-position-exited.loading-screen-exited .header-logo {
opacity: 0;
transition: opacity 0.35s ease, transform 0.35s ease;
pointer-events: none;
}

@media screen and (max-width:999px) {
  .header-logo {
  top: 50px;
  }
}
.header-logo a {
display: block;
padding-left: 20px;
padding-right: 20px;
}
.header-logo-light {
display: none;
}
.header-logo-dark {
display: block;
}
.hero-gallery-page .header-logo-dark,
.theme-light .header-logo-dark {
display: none;
}
.hero-gallery-page .header-logo-light,
.theme-light .header-logo-light {
display: block;
}

.header-logo-light svg,
.header-logo-light img,
.header-logo-dark svg,
.header-logo-dark img {
height: auto;
width: 200px;
max-width: 100%;
view-transition-name: site-logo;
contain: layout; 
}
@media screen and (min-width: 1000px) {
  .home .header-logo-light svg,
  .home .header-logo-light img,
  .home .header-logo-dark svg,
  .home .header-logo-dark img {
  width: 250px;
  }
}
.home .header-logo-light svg,
.home .header-logo-light img {
view-transition-name: none;
}


.header-logo-dark,
.header-logo-light {
opacity: 1;
text-align: center;
}
.header-logo-dark a,
.header-logo-light a {
display: inline-block;
vertical-align: bottom;
}
.header-logo-sticky {
opacity: 0;
}
.header-logo-sticky img {
width: 60px;
height: auto;
}
.header-sticky .header-logo-sticky {
opacity: 1;
}
.header-sticky .header-logo-dark {
opacity: 0;
}
.header-sticky .header-logo-sticky,
.header-sticky .header-logo-dark,
.header-sticky .header-logo-light {
transition: all 0.35s ease;
}


/* =Menus */

.header-menu {
display: none;
}
@media screen and (min-width:1000px) {
  .header-menu {
  display: block;
  padding-top: 20px;
  }
}

.header-menu .menu {
list-style: none;
text-transform: uppercase;
letter-spacing: .1em;
font-weight: 500;
margin: 0;
padding: 0;
opacity: 1;
transition: all 0.35s ease;
text-align: center;
font-size:0;
}
.header-menu .menu li {
font-size:1rem;
display: inline-block;
}
.header-menu a {
text-decoration: none;
}
.header-menu a:hover {
color: var(--wp--preset--color--neptune);
}

.header-menu > div > .menu > li > a {
font-family: var(--wp--preset--font-family--garamond);
font-weight: 600;
letter-spacing: 0.1em;
text-transform: uppercase;
text-decoration: none;
display: inline-block;
padding: 10px 15px;
position: relative;
}

.header-menu .current_page_item a {
text-decoration: underline;
text-decoration-color: var(--wp--preset--color--gold);
text-underline-offset: 0.5em;
transition: all 0.35s ease;
}

.hero-gallery-page .header-menu > div > .menu > li > a {
color: #ddd;
transition: all 0.35s ease;
}
.hero-gallery-page .header-menu > div > .menu > li > a:hover,
.hero-gallery-page .header-menu > div > .menu > li > a:focus-visible {
color: #fff;
transition: all 0.35s ease;
}

.header-menu > div > .menu > li > a::after {
content: "";
display: block;
position: absolute;
z-index: 50;
bottom: 2px;
left:50%;
width:50px;
height:1px;
background-color: var(--wp--preset--color--gold);
transform: translateX(-50%) scale(0);
transition: all 0.35s ease;
} 
.header-menu > div > .menu > li > a:hover::after,
.header-menu > div > .menu > li > a:focus-visible::after {
transform: translateX(-50%) scale(1);
transition: all .5s ease;
}

.header-menu .current-menu-item > a::after {
transform: translateX(-50%) scale(1) !important;
transition: all .5s ease;
}


/* =Layout */

.header-split-left,
.header-split-right {
position: absolute;
top: 50%;
max-width: calc( 50% - var(--default-logo-width) - 60px);
}
.header-split-left {
right: calc(50% + var(--default-logo-width) - 60px);
transform: translateY(-50%);
}
.header-split-right {
left: calc(50% + var(--default-logo-width) - 60px);
transform: translateY(-50%);
}
@media (max-width: 999px) { /* mobile and tablet */
  .header-split-left,
  .header-split-right {
  display: none;
  }
} 


/* =Utility Menu */

.header-utility-menu {
position: absolute;
z-index: 10;
top:0px;
right:10px;
padding: 4px 0 0 0;
display: flex;
flex-direction: row;
justify-content: flex-end;
color:#666;
}
@media screen and (min-width:769px){
  .header-utility-menu {
  top:20px;
  }
}
.header-utility-menu-item {
flex:1;
margin-left: 10px;
}
.header-utility-menu-embed {
padding: 10px;
font-size:12px;
}
.header-utility-menu a {
display: inline-block;
margin-left: 10px;
text-transform: uppercase;
text-decoration: none;
letter-spacing: 0.1em;
transition: all 0.35s ease;
color: #666;
}
.header-utility-menu a:hover,
.header-utility-menu a:focus-visible {
transition: all 0.35s ease;
text-decoration: none;
color: var(--wp--preset--color--neptune);
}
.hero-gallery-page .header-utility-menu a {
color: #ddd;
}
.hero-gallery-page .header-utility-menu a:hover,
.hero-gallery-page .header-utility-menu a:focus-visible {
color: #fff;
}


/* =Header Overlay */

/* header overlay toggle */

.header-overlay-toggle {
position: fixed;
z-index: 201;
top:0;
left:0;
opacity: 1;
pointer-events: auto;
display: block;
text-transform: uppercase;
padding: 12px;
height: 44px;
width: 44px;
box-sizing:border-box;
margin: 0;
background-color:transparent;
border:none;
transition: .5s all ease;
box-shadow:none;
cursor: pointer;
}
.header-overlay-toggle:hover,
.header-overlay-toggle:focus-visible,
.header-overlay-toggle:active {
background-color:transparent;
border:none;
}
.header-overlay-toggle svg {
display: block;
}

/* mobile and tablet */
@media screen and (max-width:1000px){
  .header-overlay .menu {
  margin-bottom: 2rem;
  padding-left: 0;
  }
  .header-overlay-social {
  margin-top: 3rem;
  }
}

@media screen and (min-width:769px){/* tablet and desktop */
  body .header-overlay-toggle {
  top: 20px;
  left: calc(80px - 44px);
  }
  .header-overlay-toggle:hover,
  .header-overlay-toggle:focus-visible,
  .header-overlay-toggle:active {
  background-color:transparent;
  border:none;
  }
}

.home .header-overlay-toggle {
opacity: 0;
animation: headerOverlayToggleIn .5s ease-out forwards;
animation-delay: .5s;
}

@keyframes headerOverlayToggleIn {
  from {
  opacity: 0;
  }
  to {
  opacity: 1;
  }  
}


/* toggle icon */

.toggle-icon {
position: absolute;
width: 44px;
height: 44px;
top: 0;
left: 0;
}
.toggle-icon > div {
position: absolute;
width: 44px;
transform: translateX(-50%);
left: 50%;
top: 50%;
background-color: transparent;
}
.toggle-icon > div::after {
content: "";
display: block;
position: absolute;
width: 44px;
height: 2px;
background-color: var(--header-toggle-color-default);
}
.toggle-icon > div > div {
position: absolute;
width: 44px;
height: 2px;
background-color: var(--header-toggle-color-default);
}
.header-overlay-toggle:hover .toggle-icon > div::after,
.header-overlay-toggle:focus-visible .toggle-icon > div::after,
.header-overlay-toggle:hover .toggle-icon > div > div,
.header-overlay-toggle:focus-visible .toggle-icon > div > div {
background-color: var(--header-toggle-color-hover);
}

.hero-gallery-page .toggle-icon > div::after {
background-color: var(--header-toggle-color-hero);
}
.hero-gallery-page .toggle-icon > div > div {
background-color: var(--header-toggle-color-hero);
}
.header-overlay-toggle:hover .toggle-icon > div::after,
.header-overlay-toggle:focus-visible .toggle-icon > div::after,
.header-overlay-toggle:hover .toggle-icon > div > div,
.header-overlay-toggle:focus-visible .toggle-icon > div > div {
background-color: var(--header-toggle-color-hero-hover);
}


.toggle-icon > div > div:first-child {
transform: translateY(-7px);
}
.toggle-icon > div > div:last-child {
transform: translateY(7px);
}
.header-overlay-show .toggle-icon > div::after {
opacity: 0;
}
.hero-homepage-entered .toggle-label {
color: var(--header-toggle-color-home);
opacity: 1;
pointer-events: all;
}
.toggle-icon div,
.toggle-icon div::after,
.header-overlay-toggle:hover div,
.header-overlay-toggle:focus-visible div,
.header-overlay-show .header-overlay-toggle div {
transition: all .125s ease;
}
.header-overlay-show .toggle-icon > div > div:first-child {
transform: rotate(45deg);
}
.header-overlay-show .toggle-icon > div > div:last-child {
transform: rotate(-45deg);
}
@media screen and (max-width: 768px) {
  .header-overlay-toggle {
  top: 0;
  left: 0;
  }
  .header-overlay-toggle:hover,
  .header-overlay-toggle:focus-visible,
  .header-overlay-toggle:active {
  background-color:transparent;
  border:none;
  }
  .toggle-icon {
  width: 20px;
  height: 20px;
  top: 12px;
  left: 12px;
  }
  .toggle-icon > div,
  .toggle-icon > div > div,
  .toggle-icon > div::after,
  .toggle-icon svg rect {
  width: 20px;
  }
}


/* toggle label */

.toggle-label {
position: absolute;
top: -10000px;
left: -10000px;
}
.toggle-label {
position: absolute;
top: 0;
left: 100%;
font-size:13px;
letter-spacing: .1em;
line-height:45px;
padding-left: 10px;
padding-top: 0;
opacity: 0;
pointer-events: none;
transition: all 0.35s ease;
}
/* .home .toggle-label {
opacity: 1;
pointer-events: all;
}
.home.header-overlay-show .toggle-label {
opacity: 0;
transition: all 0.35s ease;
pointer-events: none;
} */
@media screen and (max-width: 640px) {
  .hero-homepage-entered .toggle-label {
  opacity:0;
  pointer-events: none;
  }
}
  

/* header overlay */

.header-overlay {
pointer-events: none;
position: fixed;
z-index:200;
width: 100%;
height:100%;
height:100vh;
top:0;
left:0;
opacity: 0;
overflow-x: hidden;
overflow-y: auto;
-webkit-overflow-scrolling: touch;
transition: all 0.35s ease-out;
}
.header-overlay-show {
overflow: hidden;
}
html.header-overlay-lock {
overflow: hidden;
}

.header-overlay-show .header-overlay,
.header-overlay:focus-within {
opacity: 1;
pointer-events: auto;
transition: all 0.35s ease-out;
}
.header-overlay-content {
width: 50vw;
max-width: 50vw;
background: var(--header-overlay-background-color);
min-height: 100vh;
min-height: 100svh;
position: relative;
z-index: 5;
padding: 250px 60px 30px 100px;
transform: translateX(-100px);
animation: none;
will-change: opacity, transform;
}
.header-overlay-show .header-overlay-content {
animation: overlay-content-in 0.5s ease-out forwards;
}
@media screen and (max-width:768px) {
  .header-overlay-content {
  width: 400px;
  max-width: calc(100% - 60px);
  padding-left: 30px;
  padding-right: 30px;
  }
}

.header-overlay-closer {
position: fixed;
top:0;
left:0;
width:100%;
height:100%;
z-index:1;
background-color: rgba(0,0,0,0.5);
cursor: pointer;
}
.header-overlay .logo {
display: none;
}
.header-overlay-background {
position: fixed;
z-index: 1;
top:0;
left:0;
width:100%;
height:100%;
}
img.header-overlay-background-image {
position: fixed;
z-index: 1;
top:0;
left:0;
width:100%;
height:100%;
object-fit: cover;
}
.header-overlay-logo {
text-align: center;
margin-bottom: 0;
width: 250px;
position: absolute;
top: 30px;
left: 50%;
transform: translateX(-50%);
opacity: 0;
}
.header-overlay-logo a {
display: block;
padding: 20px;
}
.header-overlay-logo img {
display: inline-block;
}
.header-overlay .menu,
.header-overlay .menu li.menu-item,
.header-overlay .menu li.page_item {
display: block;
text-align: left;
}
.header-overlay .menu a {
display: block;
padding: .25rem 0 1rem;
line-height: 1;
text-decoration: none;
color: #ddd;
}
.header-overlay .menu a:hover,
.header-overlay .menu a:focus-visible {
color: #fff;
}
.header-overlay .menu {
margin-bottom: 0;
}
.header-overlay-menu-primary a {
font-family: var(--wp--preset--font-family--garamond);
font-size: var(--wp--preset--font-size--xx-large);
font-weight: normal;
letter-spacing: .025em;
opacity: 0;
}
.header-overlay-menu-secondary .menu li a {
font-family: var(--wp--preset--font-family--haas);
font-size: var(--wp--preset--font-size--small);
text-transform: uppercase;
letter-spacing: 0.1em;
/* padding-bottom: 1.565rem; */
opacity: 0;
}
.header-overlay-social a {
text-decoration: none;
}
.header-social-links {
list-style: none;
padding: 0;
margin: 0;
}
.header-social-links a {
display: inline-block;
}
.header-social-links span {
display: none;
}
.header-social-links li {
display: inline-block;
margin-right: 10px;
}
.header-social-links svg {
vertical-align: bottom;
}
.header-social-links path {
transition: all 0.35s ease;
}
.header-social-links a:hover path,
.header-social-links a:focus-visible path {
fill: #111;
transition: all 0.35s ease;
}


/* mobile and tablet */
@media screen and (max-width:999px) {
  .header-overlay-content {
  padding: 200px 60px 30px;
  }
  .header-overlay .menu {
  margin-top: 3rem;
  margin-bottom: 3rem;
  }
  .header-overlay-show .logo {
  opacity: 0 !important;
  pointer-events: none !important;
  }
  .header-overlay-show .toggle-label-close {
  opacity: 0 !important;
  }
  .header-overlay-content li {
  list-style-type: none;
  }
  .header-overlay .menu-primary-menu-container > ul.menu > li > a {
  font-size: 36px;
  line-height: 36px;
  display: block;
  padding: 10px 0;
  }
  .header-overlay .menu-tertiary-menu-container {
  margin:2rem 0;
  }
  .header-overlay .sub-menu li {
  margin:1rem 0;
  }
  .header-overlay .social-links {
  margin: 2rem 0;
  }
  .menu-primary-menu-container ul li {
  position: relative;
  }
  .header-overlay .menu, 
  .header-overlay .menu li.menu-item, 
  .header-overlay .menu li.page_item {
  text-align: center;
  }
  
  .header-overlay {
  text-align: center;
  }
  .header-overlay .color-selection {
  text-align: center;
  }
  .header-overlay .color-selection li {
  display: inline-block;
  margin: 0 10px;
  }
  .header-overlay .color-selection button {
  height:30px;
  width:30px;
  border-radius:50%;
  }
  .header-overlay .social-links i {
  font-size:24px;
  }
}

/* desktop */
@media screen and (min-width: 1000px){

  .header-overlay .background-image {
  position: fixed;
  z-index: 0;
  top:0;
  left:0;
  width:100%;
  height:100%;
  }
  .header-overlay .menu-primary-menu-container {
  text-align: left;
  }
  .header-overlay .menu-primary-menu-container ul.menu {
  margin: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100vh;
  }
  .header-overlay .menu-primary-menu-container ul.menu {
  margin: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  }
  .menu-primary-menu-container li {
  list-style-type: none;
  display: flex;
  flex-direction:column;
  }

  .header-overlay-navigation {
  display: grid;
  grid-template-columns: 1fr 1fr;
  /* height:100vh; */
  gap: 50px;
  }
  .header-overlay-navigation > div {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  }
  
}
  
@media screen and (min-width:999px) and (max-height: 650px) {
  .header-overlay .menu-primary-menu-container .menu > li {
  font-size: 48px;
  }
}


/* entrance choreography */

.header-overlay:focus-within .header-overlay-logo,
.header-overlay-show .header-overlay-logo {
animation: overlay-logo-in 0.5s ease-out forwards;
animation-delay: 0.4s;
will-change: opacity, transform;
}
.header-overlay-menu-primary a,
.header-overlay-menu-secondary a {
will-change: opacity;
}
.header-overlay:focus-within .header-overlay-menu-primary li:nth-child(1) a,
.header-overlay-show .header-overlay-menu-primary li:nth-child(1) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 0.4s;
}
.header-overlay:focus-within .header-overlay-menu-primary li:nth-child(2) a,
.header-overlay-show .header-overlay-menu-primary li:nth-child(2) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 0.5s;
}
.header-overlay:focus-within .header-overlay-menu-primary li:nth-child(3) a,
.header-overlay-show .header-overlay-menu-primary li:nth-child(3) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 0.6s;
}
.header-overlay:focus-within .header-overlay-menu-primary li:nth-child(4) a,
.header-overlay-show .header-overlay-menu-primary li:nth-child(4) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 0.7s;
}
.header-overlay:focus-within .header-overlay-menu-primary li:nth-child(5) a,
.header-overlay-show .header-overlay-menu-primary li:nth-child(5) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 0.8s;
}
.header-overlay:focus-within .header-overlay-menu-primary li:nth-child(6) a,
.header-overlay-show .header-overlay-menu-primary li:nth-child(6) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 0.9s;
}
.header-overlay:focus-within .header-overlay-menu-primary li:nth-child(7) a,
.header-overlay-show .header-overlay-menu-primary li:nth-child(7) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 1.0s;
}
.header-overlay:focus-within .header-overlay-menu-primary li:nth-child(8) a,
.header-overlay-show .header-overlay-menu-primary li:nth-child(8) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 1.1s;
}
.header-overlay:focus-within .header-overlay-menu-primary li:nth-child(9) a,
.header-overlay-show .header-overlay-menu-primary li:nth-child(9) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 1.2s;
}
.header-overlay:focus-within .header-overlay-menu-primary li:nth-child(10) a,
.header-overlay-show .header-overlay-menu-primary li:nth-child(10) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 1.3s;
}

.header-overlay:focus-within .header-overlay-menu-secondary li:nth-child(1) a,
.header-overlay-show .header-overlay-menu-secondary li:nth-child(1) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 0.8s;
}
.header-overlay:focus-within .header-overlay-menu-secondary li:nth-child(2) a,
.header-overlay-show .header-overlay-menu-secondary li:nth-child(2) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 0.9s;
}
.header-overlay:focus-within .header-overlay-menu-secondary li:nth-child(3) a,
.header-overlay-show .header-overlay-menu-secondary li:nth-child(3) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 1.0s;
}
.header-overlay:focus-within .header-overlay-menu-secondary li:nth-child(4) a,
.header-overlay-show .header-overlay-menu-secondary li:nth-child(4) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 1.1s;
}
.header-overlay:focus-within .header-overlay-menu-secondary li:nth-child(5) a,
.header-overlay-show .header-overlay-menu-secondary li:nth-child(5) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 1.2s;
}
.header-overlay:focus-within  .header-overlay-menu-secondary li:nth-child(6) a,
.header-overlay-show .header-overlay-menu-secondary li:nth-child(6) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 1.3s;
}
.header-overlay:focus-within .header-overlay-menu-secondary li:nth-child(7) a,
.header-overlay-show .header-overlay-menu-secondary li:nth-child(7) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 1.4s;
}
.header-overlay:focus-within .header-overlay-menu-secondary li:nth-child(8) a,
.header-overlay-show .header-overlay-menu-secondary li:nth-child(8) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 1.5s;
}
.header-overlay:focus-within .header-overlay-menu-secondary li:nth-child(9) a,
.header-overlay-show .header-overlay-menu-secondary li:nth-child(9) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 1.6s;
}
.header-overlay:focus-within .header-overlay-menu-secondary li:nth-child(10) a,
.header-overlay-show .header-overlay-menu-secondary li:nth-child(10) a {
animation: overlay-menu-item-in 0.5s ease-out forwards;
animation-delay: 1.7s;
}

@keyframes overlay-menu-item-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes overlay-logo-in {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}

@keyframes overlay-content-in {
  from {
    opacity: 0;
    transform: translateX(-100px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}