/* reset */
@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-thin.woff2') format('woff2'),
  url('../fonts/geist/geist-thin.woff') format('woff');
  font-weight:100;
  font-style:normal;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-thinitalic.woff2') format('woff2'),
  url('../fonts/geist/geist-thinitalic.woff') format('woff');
  font-weight:100;
  font-style:italic;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-extralight.woff2') format('woff2'),
  url('../fonts/geist/Geist-ExtraLight.woff') format('woff');
  font-weight:200;
  font-style:normal;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-extralightitalic.woff2') format('woff2'),
  url('../fonts/geist/geist-extralightitalic.woff') format('woff');
  font-weight:200;
  font-style:italic;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-light.woff2') format('woff2'),
  url('../fonts/geist/geist-light.woff') format('woff');
  font-weight:300;
  font-style:normal;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-lightitalic.woff2') format('woff2'),
  url('../fonts/geist/geist-lightitalic.woff') format('woff');
  font-weight:300;
  font-style:italic;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-regular.woff2') format('woff2'),
  url('../fonts/geist/geist-regular.woff') format('woff');
  font-weight:400;
  font-style:normal;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-italic.woff2') format('woff2'),
  url('../fonts/geist/geist-italic.woff') format('woff');
  font-weight:400;
  font-style:italic;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-medium.woff2') format('woff2'),
  url('../fonts/geist/geist-medium.woff') format('woff');
  font-weight:500;
  font-style:normal;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-mediumitalic.woff2') format('woff2'),
  url('../fonts/geist/geist-mediumitalic.woff') format('woff');
  font-weight:500;
  font-style:italic;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-semibold.woff2') format('woff2'),
  url('../fonts/geist/geist-semibold.woff') format('woff');
  font-weight:600;
  font-style:normal;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-semibolditalic.woff2') format('woff2'),
  url('../fonts/geist/geist-semibolditalic.woff') format('woff');
  font-weight:600;
  font-style:italic;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-bold.woff2') format('woff2'),
  url('../fonts/geist/geist-bold.woff') format('woff');
  font-weight:700;
  font-style:normal;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-bolditalic.woff2') format('woff2'),
  url('../fonts/geist/geist-bolditalic.woff') format('woff');
  font-weight:700;
  font-style:italic;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-extrabold.woff2') format('woff2'),
  url('../fonts/geist/geist-extrabold.woff') format('woff');
  font-weight:800;
  font-style:normal;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-extrabolditalic.woff2') format('woff2'),
  url('../fonts/geist/geist-extrabolditalic.woff') format('woff');
  font-weight:800;
  font-style:italic;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-black.woff2') format('woff2'),
  url('../fonts/geist/geist-black.woff') format('woff');
  font-weight:900;
  font-style:normal;
  font-display:swap;
}

@font-face {
  font-family:'geist';
  src:
  url('../fonts/geist/geist-blackitalic.woff2') format('woff2'),
  url('../fonts/geist/geist-blackitalic.woff') format('woff');
  font-weight:900;
  font-style:italic;
  font-display:swap;
}

*{
margin:0;

padding:0;
box-sizing:border-box;
}


html,
body{
width:100%;
overflow-x:hidden;

background:#ffffff;

font-family: 'geist', -apple-system, blinkmacsystemfont, 'segoe ui', sans-serif;

color:#262626;

-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-rendering: optimizelegibility;
}


body{
padding-top:84px;
}

/* navbar */

.navbar{
position:fixed;
top:0;
left:0;

width:100%;
height:84px;

z-index:1000;

background:#f7f6f2;

border-bottom:1px solid rgba(0,0,0,.06);
}

img{
  max-width:100%;
  height:auto;
  display:block;
}

.nav-inner{
width:100%;
height:100%;

display:flex;
justify-content:space-between;
align-items:center;

padding:0 64px;
}

/* Logo */

.logo{
font-family: 'geist', -apple-system, blinkmacsystemfont, 'segoe ui', sans-serif;

font-weight:300;

font-size:3.2rem;

letter-spacing:-0.015em;

line-height:1;

color:#262626;

text-decoration:none;

transition:opacity .3s ease;
}

.logo:hover{
opacity:.6;
}

/* Menu */

.nav-right{
display:flex;
align-items:center;

gap:54px;
}

.nav-link{
font-family: 'geist', -apple-system, blinkmacsystemfont, 'segoe ui', sans-serif;

font-weight:300;

font-size:2rem;

letter-spacing:-0.01em;

line-height:1;

color:#262626;

text-decoration:none;

transition:opacity .3s ease;
}

.nav-link:hover{
opacity:.45;
}

/* dropdown */

.dropdown{
position:relative;
}

/* dropdown panel */

.dropdown-menu{
position:absolute;

top:calc(100% + 26px);
left:-18px;

display:flex;
flex-direction:column;
align-items:flex-start;

gap:16px;

padding: 26px 24px;

width:max-content;

background:rgba(247,246,242,.40);

-webkit-backdrop-filter: blur(16px);
backdrop-filter:blur(16px);

border-radius:24px;

border:1px solid rgba(255,255,255,.28);

box-shadow:
0 10px 40px rgba(0,0,0,.08);

opacity:0;
visibility:hidden;

transform:
translatey(10px)
scale(.98);

transition:
opacity .28s ease,
transform .28s ease,
visibility .28s ease;

z-index:2000;
}

/* show */

.dropdown:hover .dropdown-menu{
opacity:1;
visibility:visible;

transform:
translatey(0)
scale(1);
}

.dropdown.mobile-open .dropdown-menu{
opacity:1;
visibility:visible;

transform:
translatey(0)
scale(1);
}

/* links */

.dropdown-item{
font-family: 'geist', -apple-system, blinkmacsystemfont, 'segoe ui', sans-serif;

font-weight:300;

font-size:1.6rem;

letter-spacing:-0.02em;

line-height:1.2;

color:rgba(38,38,38,.98);

text-decoration:none;

white-space:nowrap;

transition:
opacity .3s ease,
transform .3s ease;
}

/* hover */

.dropdown-item:hover{
opacity:.5;

transform:translatex(6px);
}

/* sections */

section{
width:100%;
display:block;
}

/* project section */

.project-section{
position:relative;
}

/* section label */

.section-label{
position:absolute;

left:24px;
bottom:22px;

z-index:10;

color:rgba(247,246,242,.92);

font-family: 'geist', -apple-system, blinkmacsystemfont, 'segoe ui', sans-serif;

font-size:11px;

font-weight:300;

letter-spacing:.12em;

text-transform:uppercase;

line-height:1;

pointer-events:none;

text-shadow:
0 1px 10px rgba(0,0,0,.35);
}

/* grid */

.grid-2{
display:grid;

grid-template-columns:1fr 1fr;

gap:0;
}

.grid-3{
display:grid;

grid-template-columns:1fr 1fr;

gap:0;
}

/* tile */

.tile{
position:relative;

display:block;

overflow:hidden;

aspect-ratio:1 / 1;

min-height:420px;

background:#111;

cursor:pointer;

text-decoration:none;
}

/* images */

.tile img{
width:100%;
height:100%;

display:block;

object-fit:cover;

transform:scale(1);

transition:
transform 1.4s ease,
filter 1.4s ease;
}

.tile:hover img{
transform:scale(1.03);
}

/* photography */

.photo-banner{
position:relative;

width:100%;

background:#000;

overflow:hidden;

cursor:pointer;
}

.photo-link{
display:block;

text-decoration:none;
}

.photo-banner img{
width:100%;

height:auto;

display:block;

transform:scale(1);

transition:
transform 1.4s ease,
filter 1.4s ease;
}

.photo-banner:hover img{
transform:scale(1.03);
}

/* contact cta */

.contact-cta{
min-height:72vh;
min-height:72svh;

display:flex;
align-items:center;

padding:
140px
64px
140px
64px;

background:#ffffff;
}

.contact-inner{
max-width:1180px;
}

.contact-inner h2{
font-family: 'geist', -apple-system, blinkmacsystemfont, 'segoe ui', sans-serif;

font-size:clamp(52px,5vw,92px);

font-weight:300;

line-height:1.02;

letter-spacing:-0.045em;

color:#262626;

max-width:1100px;
}

.contact-meta{
margin-top:56px;

display:flex;
flex-direction:column;

gap:14px;
}

.contact-meta a,
.contact-meta span{
font-family: 'geist', -apple-system, blinkmacsystemfont, 'segoe ui', sans-serif;

font-size:20px;

font-weight:300;

letter-spacing:-0.01em;

line-height:1.3;

color:#262626;

text-decoration:none;

transition:opacity .3s ease;
}

.contact-meta a:hover{
opacity:.45;
}

/* footer */

.site-footer{
background:#f7f6f2;

display:grid;

grid-template-columns:
minmax(0,1fr)
minmax(260px,320px)
minmax(0,1fr);

align-items:start;

padding:80px 96px;

border-top:1px solid rgba(0,0,0,.06);
}

/* footer columns */

.footer-column{
justify-self:center;
}

.footer-column:first-child{
justify-self:start;
}

.footer-column:last-child{
justify-self:end;
}

/* footer titles */

.footer-column h4{
font-size:12px;

font-weight:500;

letter-spacing:.12em;

margin-bottom:24px;

text-transform:uppercase;
}

/* footer list */

.footer-column ul{
list-style:none;
}

.footer-column li{
font-size:14px;

font-weight:300;

line-height:2;

letter-spacing:.01em;

color:#4a4a4a;
}

/* footer links */

.footer-column a{
color:inherit;

text-decoration:none;

transition:opacity .3s ease;
}

.footer-column a:hover{
opacity:.5;
}

/* responsive */

@media(max-width:1000px){

body{
padding-top:110px;
}

.navbar{
height:110px;
}

.nav-inner{
flex-direction:column;

justify-content:center;

gap:16px;

padding:0 24px;
}

.logo{
font-size:2.3rem;
}

.nav-right{
gap:28px;
}

.nav-link{
font-size:1.3rem;
}

.dropdown-menu{
left:0;

min-width:300px;

padding:26px;

gap:18px;

border-radius:22px;
}

.dropdown-item{
font-size:1.8rem;
}

.grid-2,
.grid-3{
grid-template-columns:1fr;
}

.tile{
aspect-ratio:auto;

height:78vw;

min-height:300px;
}

.section-label{
left:20px;
bottom:18px;
}

.contact-cta{
padding:
100px
28px
100px
28px;
}

.contact-inner h2{
font-size:clamp(40px,9vw,68px);
}

.contact-meta{
margin-top:40px;
}

.contact-meta a,
.contact-meta span{
font-size:17px;
}

.site-footer{
grid-template-columns:1fr;

gap:56px;

padding:64px 32px;
}

.footer-column,
.footer-column:first-child,
.footer-column:last-child{
justify-self:start;
}
}

/* reduced motion*/

@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}