/* ===== Reset & Vars ===== */
*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --cream:#f6f3ee;
  --cream-2:#efeae1;
  --charcoal:#1b1a18;
  --charcoal-2:#2a2825;
  --brass:#a9895f;
  --brass-light:#c9ab7c;
  --line:#ddd5c6;
  --text-soft:#6b6459;
  --serif:'Playfair Display',serif;
  --sans:'Inter',sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans);
  color:var(--charcoal);
  background:var(--cream);
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.container{max-width:1180px;margin:0 auto;padding:0 32px;}

/* ===== Preloader ===== */
#preloader{
  position:fixed;inset:0;background:var(--charcoal);z-index:9999;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .8s var(--ease), visibility .8s var(--ease);
}
#preloader.hidden{opacity:0;visibility:hidden;}
.preloader-mark{
  font-family:var(--serif);color:var(--cream);font-size:1.4rem;letter-spacing:.08em;
  opacity:0;animation:preloaderFade 1.6s var(--ease) forwards;
}
@keyframes preloaderFade{0%{opacity:0;transform:translateY(8px);}50%{opacity:1;transform:translateY(0);}100%{opacity:1;}}

/* ===== Reveal animation ===== */
.fade-up{opacity:0;transform:translateY(24px);animation:fadeUp 1s var(--ease) forwards;}
.fade-up:nth-child(1){animation-delay:.15s;}
.fade-up:nth-child(2){animation-delay:.3s;}
.fade-up:nth-child(3){animation-delay:.45s;}
.fade-up:nth-child(4){animation-delay:.6s;}
.fade-up:nth-child(5){animation-delay:.75s;}
@keyframes fadeUp{to{opacity:1;transform:translateY(0);}}

.reveal{opacity:0;transform:translateY(36px);transition:opacity .9s var(--ease),transform .9s var(--ease);}
.reveal.in-view{opacity:1;transform:translateY(0);}

/* ===== Navbar ===== */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease);
  padding:22px 0;
}
.navbar.scrolled{
  background:rgba(246,243,238,.92);backdrop-filter:blur(10px);
  box-shadow:0 1px 0 var(--line);padding:14px 0;
}
.nav-inner{max-width:1180px;margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:space-between;}
.nav-logo{font-family:var(--serif);font-size:1.25rem;letter-spacing:.04em;color:#fff;transition:color .4s var(--ease);}
.navbar.scrolled .nav-logo{color:var(--charcoal);}
.nav-links{display:flex;align-items:center;gap:30px;}
.nav-links a{
  font-size:.82rem;letter-spacing:.05em;text-transform:uppercase;color:#fff;
  transition:color .4s var(--ease), opacity .3s;opacity:.9;
}
.nav-links a:hover{opacity:1;color:var(--brass-light);}
.navbar.scrolled .nav-links a{color:var(--charcoal-2);}
.navbar.scrolled .nav-links a:hover{color:var(--brass);}
.nav-cta{
  border:1px solid currentColor;padding:9px 18px;border-radius:2px;
}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;z-index:1001;}
.nav-toggle span{width:24px;height:2px;background:#fff;transition:background .3s;}
.navbar.scrolled .nav-toggle span{background:var(--charcoal);}
.mobile-menu{
  position:fixed;top:0;right:0;height:100vh;width:78%;max-width:340px;
  background:var(--charcoal);transform:translateX(100%);
  transition:transform .5s var(--ease);z-index:999;
  display:flex;flex-direction:column;gap:26px;padding:100px 40px;
}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu a{color:var(--cream);font-size:1.05rem;letter-spacing:.03em;}

/* ===== Hero ===== */
.hero{position:relative;height:100vh;min-height:640px;display:flex;align-items:center;overflow:hidden;}
.hero-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.08);animation:heroZoom 20s ease-out forwards;
}
@keyframes heroZoom{to{transform:scale(1);}}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,14,12,.35) 0%, rgba(15,14,12,.25) 40%, rgba(15,14,12,.78) 100%);
}
.hero-content{position:relative;z-index:2;color:#fff;max-width:880px;margin:0 auto;padding:0 32px;text-align:center;}
.hero-eyebrow{
  text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;color:var(--brass-light);margin-bottom:18px;font-weight:500;
}
.hero-title{font-family:var(--serif);font-weight:500;font-size:clamp(2.6rem,7vw,5rem);line-height:1.05;margin-bottom:22px;}
.hero-sub{font-size:1.05rem;max-width:560px;margin:0 auto 36px;color:#ece8e0;font-weight:300;}
.hero-meta{display:flex;align-items:center;justify-content:center;gap:22px;margin-bottom:40px;flex-wrap:wrap;}
.hero-meta-item{display:flex;flex-direction:column;align-items:center;}
.hero-meta-item .num{font-family:var(--serif);font-size:1.6rem;color:#fff;}
.hero-meta-item .label{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:#cfc9bd;margin-top:4px;}
.hero-meta-divider{width:1px;height:34px;background:rgba(255,255,255,.3);}
.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

.btn{display:inline-block;padding:14px 30px;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;border-radius:2px;transition:all .35s var(--ease);}
.btn-light{background:#fff;color:var(--charcoal);}
.btn-light:hover{background:var(--brass-light);color:#fff;}
.btn-outline{border:1px solid rgba(255,255,255,.7);color:#fff;}
.btn-outline:hover{background:#fff;color:var(--charcoal);}
.btn-dark{background:var(--charcoal);color:#fff;border:1px solid var(--charcoal);}
.btn-dark:hover{background:var(--brass);border-color:var(--brass);}
.full-width{width:100%;text-align:center;cursor:pointer;border:none;}

.scroll-cue{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:2;}
.scroll-cue span{
  display:block;width:1px;height:42px;background:rgba(255,255,255,.55);
  position:relative;overflow:hidden;
}
.scroll-cue span::after{
  content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:#fff;
  animation:scrollLine 2.2s ease-in-out infinite;
}
@keyframes scrollLine{0%{top:-100%;}50%{top:0;}100%{top:100%;}}

/* ===== Section generic ===== */
.section{padding:110px 0;}
.section-eyebrow{
  text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;color:var(--brass);font-weight:600;margin-bottom:14px;
}
.section-title{font-family:var(--serif);font-weight:500;font-size:clamp(1.8rem,3.4vw,2.6rem);line-height:1.2;}
.section-title em{font-style:italic;color:var(--brass);}
.center{text-align:center;}

/* ===== Overview ===== */
.overview{background:var(--cream);}
.overview-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:70px;align-items:center;}
.overview-text p{color:var(--text-soft);margin:20px 0;font-size:1rem;}
.overview-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:36px;padding-top:30px;border-top:1px solid var(--line);}
.overview-stats strong{display:block;font-family:var(--serif);font-size:1.7rem;color:var(--charcoal);}
.overview-stats span{display:block;font-size:.72rem;letter-spacing:.04em;color:var(--text-soft);text-transform:uppercase;margin-top:4px;}
.overview-image img{border-radius:3px;box-shadow:0 30px 60px -20px rgba(20,15,5,.35);}

/* ===== Gallery ===== */
.gallery-section{background:var(--cream-2);}
.gallery-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:50px;
}
.gallery-grid .g-item{
  position:relative;overflow:hidden;border-radius:2px;cursor:pointer;background:#000;aspect-ratio:1/1;
}
.gallery-grid .g-item:nth-child(7n+1){grid-column:span 2;grid-row:span 2;aspect-ratio:1/1;}
.gallery-grid .g-item img{
  width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);
}
.gallery-grid .g-item:hover img{transform:scale(1.08);}
.gallery-grid .g-item::after{
  content:'\002B';color:#fff;font-size:1.6rem;position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;background:rgba(15,14,12,0);
  opacity:0;transition:opacity .35s var(--ease), background .35s var(--ease);
}
.gallery-grid .g-item:hover::after{opacity:1;background:rgba(15,14,12,.25);}
.gallery-more{
  margin:46px auto 0;display:block;width:max-content;
}

/* ===== Highlights ===== */
.highlights{background:var(--cream);}
.highlight-row{
  display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center;margin-top:90px;
}
.highlights .container > h2, .highlights .container > p{margin-top:0;}
.highlight-row.reverse{direction:rtl;}
.highlight-row.reverse > *{direction:ltr;}
.highlight-image img{border-radius:3px;box-shadow:0 30px 60px -20px rgba(20,15,5,.3);}
.highlight-no{font-family:var(--serif);font-size:.95rem;color:var(--brass);letter-spacing:.1em;}
.highlight-text h3{font-family:var(--serif);font-size:1.7rem;margin:10px 0 16px;font-weight:500;}
.highlight-text p{color:var(--text-soft);}

/* ===== Amenities ===== */
.amenities{background:var(--charcoal);color:var(--cream);}
.amenities .section-title{color:#fff;}
.amenity-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:60px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);
}
.amenity{
  background:var(--charcoal);padding:38px 20px;text-align:center;
  transition:background .35s var(--ease);
}
.amenity:hover{background:var(--charcoal-2);}
.amenity-icon{font-size:1.8rem;margin-bottom:14px;}
.amenity span{font-size:.86rem;letter-spacing:.02em;color:#d8d2c4;}

/* ===== Lease ===== */
.lease{background:var(--cream-2);}
.lease-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:start;}
.lease-intro p{color:var(--text-soft);margin-top:18px;}
.lease-table{border-top:1px solid var(--line);}
.lease-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 4px;border-bottom:1px solid var(--line);
}
.lease-row span{color:var(--text-soft);font-size:.92rem;}
.lease-row strong{font-family:var(--serif);font-size:1.05rem;}

/* ===== Location ===== */
.location{background:var(--cream);}
.location-sub{color:var(--text-soft);margin-top:6px;}
.map-wrap{height:460px;margin-top:50px;}

/* ===== Contact ===== */
.contact{background:var(--cream-2);}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:70px;}
.contact-info p{color:var(--text-soft);margin:18px 0 36px;}
.agent-card{display:flex;gap:20px;align-items:center;background:var(--cream);padding:26px;border-radius:3px;border:1px solid var(--line);}
.agent-avatar{
  width:62px;height:62px;border-radius:50%;background:var(--charcoal);color:var(--brass-light);
  display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.2rem;flex-shrink:0;
}
.agent-name{font-family:var(--serif);font-size:1.15rem;}
.agent-role{font-size:.78rem;color:var(--text-soft);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;}
.agent-line{display:block;font-size:.92rem;color:var(--charcoal-2);margin-top:2px;transition:color .3s;}
.agent-line:hover{color:var(--brass);}

.contact-form{background:var(--cream);padding:36px;border-radius:3px;border:1px solid var(--line);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.form-field{margin-bottom:18px;}
.form-field label{display:block;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;color:var(--text-soft);margin-bottom:7px;}
.form-field input,.form-field textarea{
  width:100%;padding:12px 14px;border:1px solid var(--line);background:#fff;
  font-family:var(--sans);font-size:.95rem;border-radius:2px;transition:border-color .3s;
}
.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--brass);}
.form-note{margin-top:14px;font-size:.85rem;text-align:center;color:var(--brass);min-height:1.2em;}

/* ===== Footer ===== */
.footer{background:var(--charcoal);color:var(--cream);padding:50px 0;}
.footer-inner{text-align:center;}
.footer-address{font-family:var(--serif);font-size:1.1rem;margin-bottom:10px;}
.footer-contact{font-size:.88rem;color:#cfc9bd;margin-bottom:18px;}
.footer-legal{font-size:.74rem;color:#8c867a;}

/* ===== Lightbox ===== */
.lightbox{
  position:fixed;inset:0;background:rgba(10,9,8,.96);z-index:2000;
  display:none;align-items:center;justify-content:center;
}
.lightbox.open{display:flex;}
.lightbox img{max-width:88vw;max-height:84vh;border-radius:2px;box-shadow:0 30px 80px rgba(0,0,0,.5);}
.lb-close{position:absolute;top:24px;right:32px;background:none;border:none;color:#fff;font-size:2.2rem;cursor:pointer;line-height:1;}
.lb-arrow{
  position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.25);color:#fff;font-size:1.8rem;width:52px;height:52px;border-radius:50%;
  cursor:pointer;transition:background .3s;
}
.lb-arrow:hover{background:rgba(255,255,255,.2);}
.lb-prev{left:24px;}
.lb-next{right:24px;}
.lb-counter{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);color:#cfc9bd;font-size:.85rem;letter-spacing:.05em;}

/* ===== Responsive ===== */
@media (max-width:980px){
  .nav-links{display:none;}
  .nav-toggle{display:flex;}
  .overview-grid,.lease-grid,.contact-grid{grid-template-columns:1fr;gap:40px;}
  .highlight-row{grid-template-columns:1fr;gap:30px;}
  .highlight-row.reverse{direction:ltr;}
  .highlight-row.reverse .highlight-image{order:0;}
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
  .gallery-grid .g-item:nth-child(7n+1){grid-column:span 2;}
  .amenity-grid{grid-template-columns:repeat(2,1fr);}
  .form-row{grid-template-columns:1fr;}
  .overview-stats{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:560px){
  .section{padding:80px 0;}
  .hero-meta{gap:14px;}
  .hero-meta-divider{display:none;}
  .gallery-grid{grid-template-columns:repeat(2,1fr);gap:8px;}
  .lb-arrow{width:42px;height:42px;font-size:1.4rem;}
}
