*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --cream:#F4F2EE;
  --warm-white:#FAF9F7;
  --charcoal:#26231F;
  --mid:#6B6560;
  --taupe:#9B9088;
  --light-taupe:#D0CAC2;
  --line:rgba(38,35,31,0.12);
}
html{scroll-behavior:smooth;font-size:16px}
body{
  background:var(--cream);
  color:var(--charcoal);
  font-family:'Barlow',sans-serif;
  font-weight:300;
  cursor:none;
  overflow-x:hidden;
}

/* CURSOR */
#cursor{
  position:fixed;width:1px;height:22px;
  background:var(--charcoal);
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:transform 0.06s;
}
#cursor::before{
  content:'';position:absolute;
  width:22px;height:1px;
  background:var(--charcoal);
  top:50%;left:50%;
  transform:translate(-50%,-50%);
}
#cursor-dot{
  position:fixed;width:4px;height:4px;
  border-radius:50%;background:var(--charcoal);
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
}
body.cursor-hover #cursor{transform:translate(-50%,-50%) scale(2);opacity:0.35}

/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;
  z-index:100;
  padding:1.8rem 4rem;
  display:flex;align-items:center;justify-content:space-between;
  transition:padding 0.5s ease,background 0.5s ease,border-color 0.5s ease;
  border-bottom:1px solid transparent;
  background:transparent;
}
nav.scrolled{
  padding:1.1rem 4rem;
  background:rgba(244,242,238,0.94);
  backdrop-filter:blur(16px);
  border-color:var(--line);
}
.nav-logo{
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.75rem;
  font-weight:300;
  letter-spacing:0.3em;
  text-decoration:none;
  color:var(--charcoal);
  display:flex;flex-direction:column;gap:0.15rem;
}
.nav-logo span{
  font-size:0.48rem;
  letter-spacing:0.22em;
  color:var(--taupe);
  font-weight:200;
}
.nav-links{display:flex;gap:3rem;list-style:none}
.nav-links a{
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.6rem;
  letter-spacing:0.22em;
  text-decoration:none;
  color:var(--mid);
  font-weight:300;
  position:relative;
  padding-bottom:0.2rem;
  transition:color 0.3s;
}
.nav-links a::after{
  content:'';position:absolute;
  bottom:0;left:0;width:0;height:1px;
  background:var(--charcoal);
  transition:width 0.4s cubic-bezier(0.76,0,0.24,1);
}
.nav-links a:hover,.nav-links a.active{color:var(--charcoal)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.58rem;letter-spacing:0.2em;
  font-weight:300;
  color:var(--charcoal);
  border:1px solid var(--charcoal);
  padding:0.55rem 1.4rem;
  text-decoration:none;
  transition:background 0.3s,color 0.3s;
}
.nav-cta:hover{background:var(--charcoal);color:var(--cream)}

/* PAGE HEADER (inner pages) */
.page-header{
  padding:14rem 4rem 7rem;
  border-bottom:1px solid var(--line);
  position:relative;overflow:hidden;
}
.page-header-label{
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.55rem;letter-spacing:0.4em;
  color:var(--taupe);font-weight:200;
  margin-bottom:1.5rem;
  display:flex;align-items:center;gap:1rem;
}
.page-header-label::before{content:'';display:block;width:2rem;height:1px;background:var(--taupe)}
.page-header h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3rem,7vw,6.5rem);
  font-weight:300;
  line-height:1.05;
}
.page-header h1 em{font-style:italic;color:var(--taupe)}
.page-header-sub{
  font-size:0.85rem;
  line-height:1.9;
  color:var(--mid);
  max-width:40rem;
  margin-top:2rem;
}
.ph-bg-num{
  position:absolute;right:3rem;bottom:-2rem;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(8rem,20vw,16rem);
  font-weight:300;
  color:transparent;
  -webkit-text-stroke:1px rgba(38,35,31,0.05);
  line-height:1;pointer-events:none;user-select:none;
}

/* SECTION UTILS */
.section-label{
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.55rem;letter-spacing:0.4em;
  color:var(--taupe);font-weight:200;
  margin-bottom:1rem;
  display:flex;align-items:center;gap:1rem;
}
.section-label::before{content:'';display:block;width:2rem;height:1px;background:var(--taupe)}
.reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity 0.9s ease,transform 0.9s ease;
}
.reveal.visible{opacity:1;transform:none}
.reveal-delay-1{transition-delay:0.15s}
.reveal-delay-2{transition-delay:0.3s}
.reveal-delay-3{transition-delay:0.45s}

/* MARQUEE */
.marquee-band{
  overflow:hidden;
  padding:2.5rem 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:var(--warm-white);
}
.marquee-track{
  display:flex;
  animation:marquee 22s linear infinite;
  white-space:nowrap;
}
.marquee-item{
  font-family:'Cormorant Garamond',serif;
  font-size:1.1rem;font-weight:300;
  font-style:italic;color:var(--light-taupe);
  padding:0 2.5rem;
  display:flex;align-items:center;gap:2.5rem;
}
.marquee-item::after{content:'✦';font-size:0.55rem;color:var(--taupe);font-style:normal}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* FOOTER */
footer{
  background:var(--charcoal);
  padding:4rem;
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  align-items:center;
  gap:2rem;
  border-top:1px solid rgba(244,242,238,0.06);
}
.footer-logo{
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.7rem;letter-spacing:0.3em;
  color:rgba(244,242,238,0.35);font-weight:200;
}
.footer-logo span{display:block;font-size:0.45rem;letter-spacing:0.2em;margin-top:0.3rem;color:rgba(244,242,238,0.2)}
.footer-links{
  display:flex;gap:2rem;justify-content:center;
}
.footer-links a{
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.55rem;letter-spacing:0.2em;
  color:rgba(244,242,238,0.3);font-weight:200;
  text-decoration:none;
  transition:color 0.3s;
}
.footer-links a:hover{color:rgba(244,242,238,0.7)}
.footer-contact{
  text-align:right;
}
.footer-contact a,.footer-contact span{
  display:block;
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.55rem;letter-spacing:0.18em;
  color:rgba(244,242,238,0.3);font-weight:200;
  text-decoration:none;margin-bottom:0.4rem;
  transition:color 0.3s;
}
.footer-contact a:hover{color:rgba(244,242,238,0.6)}
.footer-copy{
  grid-column:1/-1;
  border-top:1px solid rgba(244,242,238,0.06);
  padding-top:2rem;
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.45rem;letter-spacing:0.2em;
  color:rgba(244,242,238,0.15);font-weight:200;
  text-align:center;
}

/* HAMBURGER */
.nav-hamburger{
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;border:none;
  padding:4px;z-index:200;
  cursor:pointer;
}
.nav-hamburger span{
  display:block;width:24px;height:1.5px;
  background:var(--charcoal);
  transition:all 0.4s cubic-bezier(0.76,0,0.24,1);
  transform-origin:center;
}

/* MOBILE MENU */
.mobile-menu{
  position:fixed;inset:0;
  background:var(--charcoal);
  z-index:150;
  visibility:hidden;
  opacity:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  transition:opacity 0.4s ease, visibility 0.4s ease;
}
.mobile-menu.open{
  visibility:visible;
  opacity:1;
}
.mobile-menu-close{
  position:absolute;top:1.6rem;right:2rem;
  background:none;border:none;
  color:rgba(244,242,238,0.5);
  font-size:1.5rem;
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:color 0.3s,transform 0.3s;
}
.mobile-menu-close:hover{color:var(--cream);transform:rotate(90deg)}
.mobile-menu-links{
  list-style:none;
  display:flex;flex-direction:column;
  align-items:center;gap:2rem;
  margin-bottom:3rem;
}
.mobile-menu-links li{
  overflow:hidden;
}
.mobile-menu-links a{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.2rem,10vw,3.5rem);
  font-weight:300;
  color:rgba(244,242,238,0.6);
  text-decoration:none;
  display:block;
  transform:translateY(100%);
  transition:transform 0.5s cubic-bezier(0.16,1,0.3,1), color 0.3s;
}
.mobile-menu.open .mobile-menu-links li:nth-child(1) a{transform:translateY(0);transition-delay:0.05s}
.mobile-menu.open .mobile-menu-links li:nth-child(2) a{transform:translateY(0);transition-delay:0.1s}
.mobile-menu.open .mobile-menu-links li:nth-child(3) a{transform:translateY(0);transition-delay:0.15s}
.mobile-menu.open .mobile-menu-links li:nth-child(4) a{transform:translateY(0);transition-delay:0.2s}
.mobile-menu-links a:hover,.mobile-menu-links a.active{color:var(--cream)}
.mobile-menu-cta{
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.65rem;letter-spacing:0.25em;
  color:var(--cream);
  border:1px solid rgba(244,242,238,0.3);
  padding:1rem 2.5rem;
  text-decoration:none;
  opacity:0;
  transform:translateY(10px);
  transition:opacity 0.4s ease 0.3s, transform 0.4s ease 0.3s, background 0.3s;
}
.mobile-menu.open .mobile-menu-cta{opacity:1;transform:none}
.mobile-menu-cta:hover{background:rgba(244,242,238,0.08)}
.mobile-menu-contact{
  position:absolute;bottom:2.5rem;
  text-align:center;
  opacity:0;
  transition:opacity 0.4s ease 0.35s;
}
.mobile-menu.open .mobile-menu-contact{opacity:1}
.mobile-menu-contact a{
  display:block;
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.55rem;letter-spacing:0.2em;
  color:rgba(244,242,238,0.3);
  text-decoration:none;margin-bottom:0.4rem;
}

/* RESPONSIVE */
/* RESPONSIVE */
@media(max-width:900px){
  body{cursor:auto}
  #cursor,#cursor-dot{display:none}
  nav{padding:1.4rem 2rem}
  nav.scrolled{padding:0.9rem 2rem}
  .nav-links{display:none}
  .nav-cta{display:none}
  .nav-hamburger{display:flex}
  .page-header{padding:10rem 2rem 5rem}
  footer{grid-template-columns:1fr;text-align:center;padding:3rem 2rem}
  .footer-links{justify-content:center}
  .footer-contact{text-align:center}
}
