*{
box-sizing:border-box;
margin:0;
padding:0;
}

html{
scroll-behavior:smooth;
}

:root{
--spot-left-x:0vw;
--spot-left-y:0vh;
--spot-right-x:0vw;
--spot-right-y:0vh;
}

body{
background:#050505;
color:#f3efe7;
font-family:'Inter',sans-serif;
line-height:1.5;
-webkit-font-smoothing:antialiased;
-moz-osx-font-smoothing:grayscale;
text-rendering:optimizeLegibility;
overflow-x:hidden;
}

img{
max-width:100%;
display:block;
}

button,
input,
select,
textarea{
font:inherit;
}

a{
color:inherit;
}

.serif{
font-family:'Cormorant Garamond',serif;
}

.topnav{
position:fixed;
top:0;
left:0;
width:100%;
display:flex;
justify-content:flex-end;
align-items:center;
padding:18px 28px;
z-index:1000;
pointer-events:none;
}

.nav-spacer{
flex:1;
}

.nav-right{
display:flex;
gap:12px;
pointer-events:auto;
}

.pill{
display:inline-flex;
align-items:center;
justify-content:center;
min-height:42px;
padding:0 18px;
border:1px solid rgba(243,239,231,0.16);
border-radius:999px;
text-decoration:none;
font-size:14px;
font-weight:400;
letter-spacing:0.01em;
color:#f3efe7;
background:rgba(8,8,8,0.42);
backdrop-filter:blur(12px);
-webkit-backdrop-filter:blur(12px);
transition:border-color .25s ease,background .25s ease,color .25s ease,transform .25s ease;
}

.pill:hover{
border-color:rgba(232,215,169,0.5);
background:rgba(232,215,169,0.08);
color:#f0e1b2;
transform:translateY(-1px);
}

main{
position:relative;
z-index:2;
width:100%;
}

.hero{
position:relative;
min-height:100vh;
display:flex;
align-items:center;
justify-content:center;
padding:120px 32px 72px;
overflow:hidden;
isolation:isolate;
}

.hero-backdrop{
position:fixed;
top:-12vh;
left:-10vw;
width:120vw;
height:124vh;
pointer-events:none;
z-index:0;
background:
radial-gradient(circle at 50% 42%, rgba(255,255,255,0.028) 0%, rgba(255,255,255,0.012) 14%, rgba(255,255,255,0) 28%),
linear-gradient(180deg, #040404 0%, #060606 45%, #090909 100%);
transform:translate3d(0,0,0) scale(1.02);
}

.hero-backdrop::before{
content:"";
position:absolute;
width:64vmax;
height:64vmax;
left:-4vmax;
top:-6vmax;
border-radius:50%;
background:
radial-gradient(circle at 50% 50%, rgba(214,171,92,0.26) 0%, rgba(214,171,92,0.18) 10%, rgba(214,171,92,0.10) 20%, rgba(214,171,92,0.045) 32%, rgba(214,171,92,0.015) 42%, rgba(214,171,92,0) 56%);
filter:blur(18px);
opacity:.92;
transform:translate3d(var(--spot-left-x), var(--spot-left-y), 0);
will-change:transform;
}

.hero-backdrop::after{
content:"";
position:absolute;
width:58vmax;
height:58vmax;
right:-2vmax;
bottom:-8vmax;
border-radius:50%;
background:
radial-gradient(circle at 50% 50%, rgba(184,141,72,0.24) 0%, rgba(184,141,72,0.16) 10%, rgba(184,141,72,0.09) 20%, rgba(184,141,72,0.04) 32%, rgba(184,141,72,0.014) 42%, rgba(184,141,72,0) 56%);
filter:blur(16px);
opacity:.82;
transform:translate3d(var(--spot-right-x), var(--spot-right-y), 0);
will-change:transform;
}

.hero-shell{
position:relative;
z-index:2;
width:100%;
max-width:1200px;
display:flex;
align-items:center;
justify-content:center;
}

.hero-copy{
max-width:920px;
display:flex;
flex-direction:column;
align-items:center;
text-align:center;
}

.hero-logo{
width:min(78vw,780px);
margin:0 auto 28px;
will-change:opacity,filter;
animation:heroLogoReveal 2.2s ease-out both;
}

.hero-sub{
max-width:700px;
font-size:20px;
line-height:1.6;
font-weight:300;
letter-spacing:0.01em;
color:rgba(243,239,231,0.78);
will-change:transform,opacity,filter;
animation:heroSubReveal 1.6s ease-out .55s both;
}

.hero-scroll{
display:none;
}

.section{
position:relative;
width:min(1280px,100%);
margin:0 auto;
padding:120px 32px 0;
}

.section-head{
max-width:760px;
margin:0 auto 34px;
text-align:left;
}

.section-title{
font-size:clamp(58px,7vw,108px);
line-height:.9;
font-weight:500;
letter-spacing:-0.03em;
margin-bottom:14px;
color:#f3efe7;
}

.section-sub{
max-width:640px;
font-size:19px;
line-height:1.65;
font-weight:300;
color:rgba(243,239,231,0.72);
}

.image-carousel,
.vertical-videos,
.horizontal-videos,
.web-carousel{
display:flex;
overflow-x:auto;
padding:8px 2px 8px;
scrollbar-width:auto;
scrollbar-color:rgba(236,225,191,0.72) rgba(255,255,255,0.06);
}

.image-carousel{
gap:20px;
align-items:flex-start;
padding-top:12px;
padding-bottom:24px;
min-height:382px;
}

.vertical-videos{
gap:30px;
justify-content:center;
}

.horizontal-videos{
gap:20px;
justify-content:center;
}

.web-carousel{
gap:20px;
justify-content:center;
}

.image-carousel::-webkit-scrollbar,
.vertical-videos::-webkit-scrollbar,
.horizontal-videos::-webkit-scrollbar,
.web-carousel::-webkit-scrollbar{
height:14px;
}

.image-carousel::-webkit-scrollbar-track,
.vertical-videos::-webkit-scrollbar-track,
.horizontal-videos::-webkit-scrollbar-track,
.web-carousel::-webkit-scrollbar-track{
background:rgba(255,255,255,0.06);
border-radius:999px;
}

.image-carousel::-webkit-scrollbar-thumb,
.vertical-videos::-webkit-scrollbar-thumb,
.horizontal-videos::-webkit-scrollbar-thumb,
.web-carousel::-webkit-scrollbar-thumb{
background:rgba(236,225,191,0.72);
border-radius:999px;
border:2px solid rgba(0,0,0,0);
background-clip:padding-box;
}

.image-carousel::-webkit-scrollbar-thumb:hover,
.vertical-videos::-webkit-scrollbar-thumb:hover,
.horizontal-videos::-webkit-scrollbar-thumb:hover,
.web-carousel::-webkit-scrollbar-thumb:hover{
background:rgba(240,225,178,0.9);
border:2px solid rgba(0,0,0,0);
background-clip:padding-box;
}

.image-card,
.video-card,
.web-card{
border:none;
background:none;
padding:0;
cursor:pointer;
display:block;
}

.image-card{
width:280px;
min-width:280px;
border-radius:18px;
overflow:visible;
}

.image-card img{
width:100%;
height:auto;
aspect-ratio:4 / 5;
object-fit:cover;
background:#0d0d0d;
border-radius:18px;
transition:transform .35s ease,filter .35s ease;
}

.image-card:hover img{
transform:translateY(-4px);
filter:brightness(1.04);
}

.video-grid{
display:flex;
flex-direction:column;
gap:22px;
align-items:center;
}

.video-row{
width:100%;
display:flex;
justify-content:center;
}

.video-card{
position:relative;
overflow:hidden;
border-radius:18px;
}

.video-card.vertical{
width:260px;
min-width:260px;
height:462px;
}

.video-card.horizontal{
width:420px;
min-width:420px;
height:236px;
}

.video-thumb-wrap{
position:relative;
display:block;
width:100%;
height:100%;
overflow:hidden;
border-radius:18px;
background:#0d0d0d;
}

.video-thumb{
width:100%;
height:100%;
object-fit:cover;
transition:transform .35s ease,filter .35s ease;
}

.video-card:hover .video-thumb{
transform:scale(1.03);
filter:brightness(1.03);
}

.video-play{
position:absolute;
left:16px;
bottom:16px;
display:inline-flex;
align-items:center;
justify-content:center;
padding:7px 12px;
border-radius:999px;
font-size:13px;
font-weight:500;
color:#f3efe7;
background:rgba(5,5,5,0.72);
backdrop-filter:blur(8px);
-webkit-backdrop-filter:blur(8px);
}

.video-hover-copy{
position:absolute;
left:0;
right:0;
bottom:0;
padding:52px 18px 16px;
font-size:14px;
line-height:1.45;
text-align:left;
color:#f3efe7;
background:linear-gradient(to top, rgba(0,0,0,0.82), rgba(0,0,0,0));
opacity:0;
transition:opacity .22s ease;
}

.video-card:hover .video-hover-copy{
opacity:1;
}

.web-card{
width:420px;
min-width:420px;
height:236px;
overflow:hidden;
border-radius:18px;
}

.web-card img{
width:100%;
height:100%;
object-fit:cover;
border-radius:18px;
background:#0d0d0d;
transition:transform .35s ease,filter .35s ease;
}

.web-card:hover img{
transform:translateY(-4px);
filter:brightness(1.04);
}

.about-section{
padding-top:140px;
}

.about-panel{
display:grid;
grid-template-columns:minmax(280px,420px) minmax(320px,1fr);
gap:56px;
align-items:center;
}

.about-media{
width:100%;
}

.about-photo{
width:100%;
height:auto;
aspect-ratio:4 / 5;
object-fit:cover;
border-radius:22px;
background:#0d0d0d;
}

.about-text{
max-width:640px;
}

.about-title{
font-size:clamp(58px,7vw,108px);
line-height:.9;
font-weight:500;
letter-spacing:-0.03em;
margin-bottom:14px;
color:#f3efe7;
}

.about-sub{
max-width:560px;
font-size:19px;
line-height:1.65;
font-weight:300;
color:rgba(243,239,231,0.72);
margin-bottom:22px;
}

.about-text p{
font-size:17px;
line-height:1.8;
font-weight:300;
color:rgba(243,239,231,0.72);
margin-top:16px;
}

.contact-section{
padding-top:140px;
padding-bottom:120px;
}

.contact-shell{
display:grid;
grid-template-columns:minmax(260px,380px) minmax(320px,1fr);
gap:44px;
align-items:start;
width:100%;
max-width:1100px;
margin:0 auto;
}

.contact-title{
font-size:clamp(58px,7vw,108px);
line-height:.9;
font-weight:500;
letter-spacing:-0.03em;
margin-bottom:14px;
color:#f3efe7;
}

.contact-sub{
max-width:420px;
font-size:19px;
line-height:1.65;
font-weight:300;
color:rgba(243,239,231,0.72);
}

.contact-panel{
background:linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.02));
border:1px solid rgba(243,239,231,0.08);
border-radius:22px;
padding:28px;
box-shadow:0 20px 60px rgba(0,0,0,0.22);
}

#contactForm{
display:flex;
flex-direction:column;
gap:14px;
}

.form-row{
display:flex;
gap:14px;
}

.form-row input,
.form-row select{
flex:1;
}

input,
select,
textarea{
width:100%;
padding:14px 16px;
border:1px solid rgba(243,239,231,0.14);
border-radius:16px;
background:rgba(255,255,255,0.02);
color:#f3efe7;
font-family:'Inter',sans-serif;
font-size:16px;
font-weight:300;
outline:none;
transition:border-color .2s ease,background .2s ease,color .2s ease;
appearance:none;
-webkit-appearance:none;
-moz-appearance:none;
}

select{
background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='rgba(243,239,231,0.9)' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
background-repeat:no-repeat;
background-position:right 16px center;
background-size:18px 18px;
padding-right:48px;
}

input::placeholder,
textarea::placeholder{
color:rgba(243,239,231,0.42);
}

select:invalid{
color:rgba(243,239,231,0.42);
}

select option{
color:#111111;
background:#f3efe7;
}

input:focus,
select:focus,
textarea:focus{
border-color:rgba(232,215,169,0.55);
background:rgba(255,255,255,0.03);
}

textarea{
min-height:140px;
resize:vertical;
}

.submit-button{
display:inline-flex;
align-items:center;
justify-content:center;
min-height:54px;
border:none;
border-radius:999px;
padding:0 24px;
background:#ece1bf;
color:#111111;
font-size:15px;
font-weight:500;
cursor:pointer;
transition:transform .2s ease,filter .2s ease;
}

.submit-button:hover{
transform:translateY(-1px);
filter:brightness(1.03);
}

.footer{
position:relative;
z-index:2;
padding:0 32px 44px;
text-align:center;
font-size:14px;
font-weight:300;
color:rgba(243,239,231,0.5);
}

.placeholder-card{
display:flex;
align-items:center;
justify-content:center;
background:#0d0d0d;
color:rgba(243,239,231,0.26);
border:1px solid rgba(243,239,231,0.03);
border-radius:18px;
font-family:'Inter',sans-serif;
font-size:18px;
font-weight:300;
text-align:center;
}

.image-placeholder{
width:280px;
min-width:280px;
height:350px;
}

.video-placeholder.vertical{
width:260px;
min-width:260px;
height:462px;
}

.video-placeholder.horizontal{
width:420px;
min-width:420px;
height:236px;
}

.web-placeholder{
width:420px;
min-width:420px;
height:236px;
}

.site-modal{
position:fixed;
top:0;
right:0;
bottom:0;
left:0;
display:none;
z-index:9999;
}

.site-modal.open{
display:block;
}

.site-modal-backdrop{
position:absolute;
top:0;
right:0;
bottom:0;
left:0;
background:rgba(0,0,0,0.82);
backdrop-filter:blur(10px);
-webkit-backdrop-filter:blur(10px);
}

.site-modal-panel{
position:relative;
max-width:1100px;
width:min(1100px,calc(100vw - 24px));
margin:1vh auto;
background:#121212;
border:1px solid rgba(243,239,231,0.08);
border-radius:24px;
padding:20px;
z-index:2;
height:98vh;
max-height:98vh;
overflow:auto;
box-shadow:0 24px 80px rgba(0,0,0,0.35);
}

.site-modal-close{
position:absolute;
top:14px;
right:14px;
width:42px;
height:42px;
border:none;
border-radius:999px;
background:rgba(255,255,255,0.04);
color:#f3efe7;
font-size:28px;
cursor:pointer;
z-index:4;
}

.modal-image-wrap,
.modal-video-wrap{
display:grid;
grid-template-rows:minmax(0,1fr) auto;
gap:12px;
height:100%;
min-height:0;
padding:18px 42px 6px;
}

.modal-image{
display:block;
width:100%;
max-width:100%;
height:100%;
max-height:100%;
object-fit:contain;
object-position:center;
border-radius:18px;
background:#0d0d0d;
margin:0 auto;
min-height:0;
}

.modal-copy{
flex:0 0 auto;
max-width:760px;
}

.modal-copy h3{
font-size:34px;
line-height:1;
font-weight:500;
letter-spacing:-0.02em;
margin-bottom:8px;
font-family:'Cormorant Garamond',serif;
color:#f3efe7;
}

.modal-copy p{
font-size:15px;
line-height:1.55;
font-weight:300;
color:rgba(243,239,231,0.72);
display:-webkit-box;
-webkit-box-orient:vertical;
-webkit-line-clamp:2;
overflow:hidden;
}

.modal-video-embed{
position:relative;
width:100%;
padding-top:56.25%;
border-radius:18px;
overflow:hidden;
background:#0d0d0d;
}

.modal-video-embed iframe{
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
border:0;
}

.modal-link-wrap{
margin-top:14px;
}

.modal-link{
color:#ece1bf;
text-decoration:none;
}

.web-coming-soon{
display:flex;
align-items:center;
justify-content:center;
width:100%;
height:100%;
background:#0d0d0d;
color:rgba(243,239,231,0.26);
font-size:22px;
font-weight:300;
border-radius:18px;
}

.modal-coming-soon{
min-height:320px;
max-height:100%;
}

body.modal-open{
overflow:hidden;
}

@keyframes heroLogoReveal{
0%{
opacity:0;
filter:invert(1) brightness(1.3) blur(16px) drop-shadow(0 0 40px rgba(240,225,191,0.28));
}
42%{
opacity:.78;
filter:invert(1) brightness(1.16) blur(8px) drop-shadow(0 0 28px rgba(240,225,191,0.18));
}
72%{
opacity:1;
filter:invert(1) brightness(1.08) blur(2px) drop-shadow(0 0 14px rgba(240,225,191,0.08));
}
100%{
opacity:1;
filter:invert(1) brightness(1.02) blur(0) drop-shadow(0 0 0 rgba(240,225,191,0));
}
}

@keyframes heroSubReveal{
0%{
opacity:0;
transform:translate3d(0,14px,0);
filter:blur(8px);
}
100%{
opacity:1;
transform:translate3d(0,0,0);
filter:blur(0);
}
}

@media (prefers-reduced-motion:reduce){
html{
scroll-behavior:auto;
}

.hero-logo,
.hero-sub{
animation:none;
}
}

@media (max-width:1100px){

.hero-logo{
width:min(82vw,680px);
}

.section-title,
.about-title,
.contact-title{
font-size:clamp(50px,8vw,88px);
}

.about-panel,
.contact-shell{
grid-template-columns:1fr;
gap:34px;
}

.modal-image-wrap,
.modal-video-wrap{
padding-left:28px;
padding-right:28px;
}
}

@media (max-width:760px){

.topnav{
padding:14px 16px;
}

.nav-right{
gap:8px;
}

.pill{
min-height:38px;
padding:0 14px;
font-size:13px;
}

.hero{
min-height:92vh;
padding:108px 20px 60px;
}

.hero-logo{
width:min(88vw,540px);
margin-bottom:20px;
}

.hero-sub{
font-size:17px;
line-height:1.55;
max-width:520px;
}

.section{
padding:92px 20px 0;
}

.section-head{
margin-bottom:24px;
}

.section-title,
.about-title,
.contact-title{
font-size:clamp(42px,14vw,64px);
line-height:.92;
margin-bottom:10px;
}

.section-sub,
.about-sub,
.contact-sub{
font-size:17px;
line-height:1.55;
}

.image-card,
.image-placeholder{
width:220px;
min-width:220px;
}

.image-placeholder{
height:275px;
}

.image-carousel{
min-height:307px;
padding-bottom:22px;
}

.vertical-videos{
gap:20px;
justify-content:flex-start;
}

.horizontal-videos{
gap:16px;
justify-content:flex-start;
}

.web-carousel{
justify-content:flex-start;
}

.video-card.vertical,
.video-placeholder.vertical{
width:220px;
min-width:220px;
height:392px;
}

.video-card.horizontal,
.video-placeholder.horizontal{
width:320px;
min-width:320px;
height:180px;
}

.web-card,
.web-placeholder{
width:320px;
min-width:320px;
height:180px;
}

.about-section,
.contact-section{
padding-top:110px;
}

.form-row{
flex-direction:column;
gap:14px;
}

.contact-panel{
padding:22px;
border-radius:20px;
}

.footer{
padding:0 20px 36px;
}

.site-modal-panel{
width:calc(100vw - 12px);
height:98vh;
max-height:98vh;
margin:1vh auto;
padding:14px;
border-radius:20px;
}

.modal-image-wrap,
.modal-video-wrap{
gap:10px;
padding:34px 6px 4px;
}

.modal-copy h3{
font-size:28px;
margin-bottom:6px;
}

.modal-copy p{
font-size:14px;
line-height:1.5;
}

.modal-coming-soon{
min-height:220px;
}

.site-modal-close{
top:10px;
right:10px;
}
}