*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --cream:#F7F3EE;
  --sand:#EDE6DA;
  --gold:#C9A84C;
  --gold-lt:#E2C47A;
  --gold-dk:#9A6F28;
  --ink:#1A1714;
  --ink-mid:#3D3530;
  --ink-lt:#7A6E65;
  --white:#FDFBF8;
}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;font-weight:300;background:var(--cream);color:var(--ink);overflow-x:hidden;font-size:15px;line-height:1.7}
h1,h2,h3,h4,.serif{font-family:'Cormorant Garamond',serif}
img{display:block;width:100%;object-fit:cover}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* NAV */
nav{position:fixed;top:0;left:0;width:100%;z-index:100;padding:0 48px;display:flex;align-items:center;justify-content:space-between;height:72px;transition:background .4s}
nav.scrolled{background:rgba(26,23,20,.96)}
.nav-logo{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300;letter-spacing:.12em;color:var(--gold)}
.nav-links{display:flex;gap:36px;list-style:none}
.nav-links a{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.7);transition:color .3s}
.nav-links a:hover{color:var(--gold)}
.lang-toggle{display:flex;gap:0;border:1px solid rgba(201,168,76,.4)}
.lang-btn{padding:6px 14px;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.5);cursor:pointer;transition:all .3s}
.lang-btn.active{background:var(--gold);color:var(--ink)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{display:block;width:22px;height:1px;background:var(--gold)}

/* HERO */
.hero{position:relative;height:100vh;min-height:600px;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-image:url('../img/hero/banner.webp');background-size:cover;background-position:center;transform:scale(1.05)}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(15,10,5,.8) 0%,rgba(15,10,5,.25) 60%,transparent 100%)}
.hero-content{position:relative;z-index:1;padding:80px}
.hero-tag{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:20px}
.hero h1{font-size:clamp(46px,6vw,82px);font-weight:300;line-height:1.1;color:var(--gold);margin-bottom:24px;font-style:italic;text-shadow:0 2px 24px rgba(0,0,0,.4)}
.hero-sub{font-size:15px;color:rgba(255,255,255,.75);line-height:1.8;max-width:440px;margin-bottom:40px}
.hero-actions{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.btn-primary{padding:14px 36px;background:var(--gold);color:var(--ink);font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:400;transition:background .3s}
.btn-primary:hover{background:var(--gold-lt)}
.btn-ghost{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:10px;transition:opacity .3s}
.btn-ghost:hover{opacity:.7}
.btn-ghost::after{content:'';display:block;width:32px;height:1px;background:currentColor}
.hero-scroll{position:absolute;bottom:36px;right:48px;display:flex;align-items:center;gap:12px;color:var(--gold-lt);font-size:10px;letter-spacing:.2em;text-transform:uppercase;opacity:.7}
.scroll-line{width:48px;height:1px;background:var(--gold)}


/* STATS */
.stats-bar{background:var(--ink);padding:40px 80px;display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{padding:20px 40px;border-right:1px solid rgba(201,168,76,.15);text-align:center}
.stat-item:last-child{border:none}
.stat-num{font-family:'Cormorant Garamond',serif;font-size:44px;font-weight:300;color:var(--gold);line-height:1}
.stat-label{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:8px}

/* SECTION BASE */
section{padding:100px 80px}
.section-tag{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(32px,3.5vw,52px);font-weight:300;line-height:1.2;color:var(--ink);margin-bottom:20px}
.section-title em{font-style:italic;color:var(--gold-dk)}
.section-desc{font-size:14px;color:var(--ink-lt);line-height:1.9;max-width:460px}
.divider{width:48px;height:1px;background:var(--gold);margin:28px 0}

/* PROPERTIES */
.properties{background:var(--white)}
.props-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:60px;flex-wrap:wrap;gap:20px}
.filter-tabs{display:flex;border:1px solid var(--sand)}
.tab{padding:10px 24px;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-lt);cursor:pointer;border-right:1px solid var(--sand);transition:all .3s}
.tab:last-child{border:none}
.tab.active,.tab:hover{background:var(--gold);color:var(--ink)}
.props-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.prop-card{cursor:pointer;overflow:hidden;background:var(--sand);position:relative}
.prop-card.featured-card{grid-column:span 2;grid-row:span 2}
.prop-img{overflow:hidden}
.prop-img-inner{height:320px;overflow:hidden}
.prop-card.featured-card .prop-img-inner{height:642px}
.prop-img-inner img{height:100%;transition:transform .7s ease}
.prop-card:hover .prop-img-inner img{transform:scale(1.06)}
.prop-info{padding:24px 28px;background:var(--white)}
.prop-location{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.prop-name{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--ink);margin-bottom:6px}
.prop-details{display:flex;gap:20px;font-size:12px;color:var(--ink-lt);margin-bottom:16px}
.prop-price{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:300;color:var(--gold-dk)}
.prop-price span{font-family:'Jost',sans-serif;font-size:11px;color:var(--ink-lt)}
.prop-badge{position:absolute;top:20px;left:20px;padding:6px 14px;font-size:9px;letter-spacing:.2em;text-transform:uppercase;background:var(--gold);color:var(--ink)}
.prop-compare-btn{position:absolute;top:20px;right:20px;padding:6px 12px;font-size:9px;letter-spacing:.15em;text-transform:uppercase;background:rgba(15,10,5,.6);color:var(--gold-lt);border:1px solid rgba(201,168,76,.4);cursor:pointer;transition:all .3s}
.prop-compare-btn.added{background:var(--gold);color:var(--ink)}
.prop-compare-btn:hover{background:var(--gold);color:var(--ink)}

/* FEATURED */
.featured{background:var(--cream);display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;padding:120px 80px}
.featured-imgs{position:relative}
.feat-img-main{height:560px;overflow:hidden}
.feat-img-accent{position:absolute;bottom:-40px;right:-40px;width:55%;height:320px;overflow:hidden;border:8px solid var(--cream)}
.feat-img-accent img{height:100%}
.feat-tag{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:20px}
.feat-title{font-family:'Cormorant Garamond',serif;font-size:clamp(36px,3vw,54px);font-weight:300;line-height:1.15;margin-bottom:24px;color:var(--ink)}
.feat-title em{font-style:italic;color:var(--gold-dk)}
.feat-desc{font-size:14px;color:var(--ink-lt);line-height:1.9;margin-bottom:36px}
.feat-specs{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:40px;padding:28px;background:var(--sand)}
.spec-label{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-lt)}
.spec-val{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--gold-dk)}

/* LIGHTBOX GALLERY */
.gallery-section{background:var(--ink);padding:100px 80px}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:auto auto;gap:3px;margin-top:56px}
.gal-item{overflow:hidden;cursor:pointer;position:relative}
.gal-item:nth-child(1){grid-column:span 2;grid-row:span 2}
.gal-item img{width:100%;height:260px;object-fit:cover;transition:transform .6s,filter .4s;filter:brightness(.85)}
.gal-item:nth-child(1) img{height:523px}
.gal-item:hover img{transform:scale(1.07);filter:brightness(.65)}
.gal-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.gal-item:hover .gal-overlay{opacity:1}
.gal-icon{width:44px;height:44px;border:1px solid var(--gold);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:20px}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;background:rgba(10,7,4,.96);z-index:300;display:none;align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lb-img-wrap{position:relative;max-width:88vw;max-height:88vh}
.lb-img-wrap img{max-width:88vw;max-height:80vh;object-fit:contain}
.lb-caption{text-align:center;margin-top:16px;font-family:'Cormorant Garamond',serif;font-size:18px;font-style:italic;color:var(--gold-lt)}
.lb-close{position:fixed;top:24px;right:32px;font-size:28px;color:var(--gold);cursor:pointer;z-index:301;line-height:1}
.lb-arrow{position:fixed;top:50%;transform:translateY(-50%);font-size:32px;color:var(--gold);cursor:pointer;z-index:301;padding:16px;opacity:.7;transition:opacity .3s}
.lb-arrow:hover{opacity:1}
.lb-prev{left:16px}
.lb-next{right:16px}
.lb-counter{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);font-size:12px;letter-spacing:.2em;color:rgba(255,255,255,.4)}

/* MAP */
.map-section{background:var(--cream);padding:100px 80px}
.map-layout{display:grid;grid-template-columns:1fr 2fr;gap:48px;margin-top:56px;align-items:start}
.map-list{display:flex;flex-direction:column;gap:2px}
.map-prop-item{padding:18px 20px;background:var(--white);cursor:pointer;border-left:3px solid transparent;transition:all .3s}
.map-prop-item:hover,.map-prop-item.active{border-left-color:var(--gold);background:var(--sand)}
.map-prop-item .mpi-loc{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:4px}
.map-prop-item .mpi-name{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--ink)}
.map-prop-item .mpi-price{font-size:12px;color:var(--ink-lt);margin-top:3px}
#mapContainer{height:520px;border:1px solid var(--sand)}

/* COMPARATOR */
.compare-section{background:var(--sand);padding:100px 80px}
.compare-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:48px;flex-wrap:wrap;gap:16px}
.compare-selected{display:flex;gap:12px;flex-wrap:wrap}
.compare-tag{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--gold);color:var(--ink);font-size:11px;letter-spacing:.1em}
.compare-tag button{font-size:14px;line-height:1;color:var(--ink-dk);opacity:.7}
.compare-empty{font-size:13px;color:var(--ink-lt);font-style:italic}
.compare-table-wrap{overflow-x:auto}
table.compare-tbl{width:100%;border-collapse:collapse;min-width:600px}
table.compare-tbl th{padding:16px 20px;text-align:left;font-size:10px;letter-spacing:.2em;text-transform:uppercase;background:var(--ink);color:var(--gold);font-weight:400}
table.compare-tbl td{padding:14px 20px;font-size:13px;color:var(--ink-mid);border-bottom:1px solid rgba(201,168,76,.15);background:var(--white)}
table.compare-tbl tr:last-child td{border:none}
table.compare-tbl td:first-child{font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-lt);background:var(--sand);font-weight:400}
.compare-hint{font-size:12px;color:var(--ink-lt);margin-top:20px;font-style:italic}

/* DESTINATIONS */
.destinations{background:var(--ink);padding:100px 80px}
.dest-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:60px}
.dest-title{font-family:'Cormorant Garamond',serif;font-size:clamp(32px,3vw,52px);font-weight:300;color:var(--gold)}
.dest-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
.dest-card{position:relative;overflow:hidden;cursor:pointer}
.dest-img{height:420px;overflow:hidden}
.dest-img img{height:100%;filter:brightness(.8);transition:transform .7s,filter .5s}
.dest-card:hover .dest-img img{transform:scale(1.08);filter:brightness(.6)}
.dest-overlay{position:absolute;bottom:0;left:0;right:0;padding:28px 24px;background:linear-gradient(transparent,rgba(10,7,4,.88))}
.dest-name{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:300;color:var(--gold)}
.dest-count{font-size:11px;letter-spacing:.15em;color:rgba(255,255,255,.5);margin-top:4px}

/* PHILOSOPHY */
.philosophy{display:grid;grid-template-columns:1fr 1fr;background:var(--sand)}
.phil-img{overflow:hidden;min-height:600px}
.phil-img img{height:100%;min-height:600px}
.phil-content{padding:100px 80px;display:flex;flex-direction:column;justify-content:center}
.phil-quote{font-family:'Cormorant Garamond',serif;font-size:clamp(22px,2.2vw,34px);font-weight:300;font-style:italic;line-height:1.5;color:var(--gold-dk);margin:28px 0}
.phil-author{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}

/* SERVICES */
.services{background:var(--white);padding:100px 80px}
.serv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;margin-top:60px}
.serv-item{border-top:1px solid var(--sand);padding-top:32px}
.serv-num{font-family:'Cormorant Garamond',serif;font-size:48px;font-weight:300;color:var(--sand);line-height:1;margin-bottom:20px}
.serv-name{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--gold-dk);margin-bottom:12px}
.serv-desc{font-size:13px;color:var(--ink-lt);line-height:1.9}

/* TESTIMONIAL */
.testimonial{background:var(--ink);padding:100px 80px;text-align:center}
.test-quote{font-family:'Cormorant Garamond',serif;font-size:clamp(20px,2.5vw,36px);font-weight:300;font-style:italic;color:var(--gold-lt);max-width:800px;margin:0 auto 36px;line-height:1.6}
.test-author{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.test-role{font-size:12px;color:rgba(255,255,255,.35);margin-top:4px}
.test-dots{display:flex;justify-content:center;gap:8px;margin-top:40px}
.test-dot{width:6px;height:6px;background:rgba(255,255,255,.15);cursor:pointer;transition:background .3s}
.test-dot.active{background:var(--gold)}

/* CONTACT */
.contact{background:var(--cream);display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.contact-img{position:relative;overflow:hidden;min-height:600px}
.contact-img img{height:100%;position:absolute;inset:0}
.contact-form{padding:100px 80px}
.form-title{font-family:'Cormorant Garamond',serif;font-size:40px;font-weight:300;line-height:1.2;margin-bottom:8px;color:var(--ink)}
.form-title em{font-style:italic;color:var(--gold-dk)}
.form-sub{font-size:13px;color:var(--ink-lt);margin-bottom:48px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.field{margin-bottom:24px}
.field label{display:block;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;border:none;border-bottom:1px solid var(--sand);background:transparent;padding:10px 0;font-family:'Jost',sans-serif;font-size:14px;color:var(--ink);outline:none;transition:border-color .3s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold)}
.field select{cursor:pointer;appearance:none}
.field textarea{resize:none;height:80px}
.form-submit{width:100%;padding:16px;background:var(--ink);color:var(--gold);font-family:'Jost',sans-serif;font-size:11px;letter-spacing:.25em;text-transform:uppercase;cursor:pointer;border:1px solid var(--gold);transition:all .3s}
.form-submit:hover{background:var(--gold);color:var(--ink)}

/* FOOTER */
footer{background:var(--ink);padding:80px 80px 40px}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;margin-bottom:60px}
.footer-logo{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:300;letter-spacing:.1em;color:var(--gold);margin-bottom:16px}
.footer-tagline{font-size:13px;color:rgba(255,255,255,.35);line-height:1.8;max-width:280px}
.footer-col h4{font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:20px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col ul a{font-size:13px;color:rgba(255,255,255,.4);transition:color .3s}
.footer-col ul a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(201,168,76,.12);padding-top:32px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer-legal{font-size:11px;color:rgba(255,255,255,.25)}
.footer-social{display:flex;gap:20px}
.footer-social a{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.3);transition:color .3s}
.footer-social a:hover{color:var(--gold)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(10,7,4,.88);z-index:200;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal{background:var(--white);max-width:820px;width:100%;max-height:92vh;overflow-y:auto;display:grid;grid-template-columns:1fr 1fr;position:relative}
.modal-img{overflow:hidden;min-height:400px}
.modal-img img{height:100%;min-height:400px}
.modal-content{padding:48px 40px;overflow-y:auto}
.modal-tag{font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.modal-title{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:300;line-height:1.2;margin-bottom:20px;color:var(--ink)}
.modal-price{font-family:'Cormorant Garamond',serif;font-size:26px;margin-bottom:28px;color:var(--gold-dk)}
.modal-specs{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:28px;padding:20px;background:var(--cream)}
.modal-spec .sl{font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-lt)}
.modal-spec .sv{font-size:15px;font-family:'Cormorant Garamond',serif;color:var(--gold-dk);margin-top:2px}
.modal-desc{font-size:13px;color:var(--ink-lt);line-height:1.9;margin-bottom:32px}
.modal-close{position:absolute;top:16px;right:16px;font-size:22px;color:var(--ink-lt);cursor:pointer;z-index:5;width:32px;height:32px;display:flex;align-items:center;justify-content:center}
.modal-btn{width:100%;padding:14px;background:var(--ink);color:var(--gold);font-family:'Jost',sans-serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;border:1px solid var(--gold);transition:all .3s}
.modal-btn:hover{background:var(--gold);color:var(--ink)}

/* REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s,transform .8s}
.reveal.visible{opacity:1;transform:none}

/* MOBILE */
@media(max-width:960px){
  nav{padding:0 20px}
  .nav-links{display:none}
  .hamburger{display:flex}
  .nav-mob-open .nav-links{display:flex;flex-direction:column;position:absolute;top:72px;left:0;right:0;background:var(--ink);padding:20px 24px 28px;gap:18px}
  section{padding:64px 24px}
  .hero-content{padding:60px 24px}
  .stats-bar{grid-template-columns:repeat(2,1fr);padding:32px 24px}
  .stat-item{padding:16px}
  .props-grid{grid-template-columns:1fr}
  .prop-card.featured-card{grid-column:1;grid-row:auto}
  .prop-card.featured-card .prop-img-inner{height:300px}
  .featured{grid-template-columns:1fr;padding:64px 24px;gap:48px}
  .feat-img-accent{display:none}
  .gal-grid{grid-template-columns:repeat(2,1fr)}
  .gal-item:nth-child(1){grid-column:1;grid-row:auto}
  .gal-item img,.gal-item:nth-child(1) img{height:220px}
  .map-layout{grid-template-columns:1fr}
  #mapContainer{height:360px}
  .destinations{padding:64px 24px}
  .dest-grid{grid-template-columns:repeat(2,1fr)}
  .dest-img{height:260px}
  .philosophy{grid-template-columns:1fr}
  .phil-img{min-height:300px}
  .phil-img img{min-height:300px;height:300px}
  .phil-content{padding:60px 24px}
  .serv-grid{grid-template-columns:1fr}
  .testimonial{padding:64px 24px}
  .contact{grid-template-columns:1fr}
  .contact-img{display:none}
  .contact-form{padding:64px 24px}
  .form-row{grid-template-columns:1fr}
  footer{padding:60px 24px 32px}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .modal{grid-template-columns:1fr}
  .modal-img{min-height:200px}
  .modal-img img{min-height:200px}
  .modal-content{padding:28px 24px}
  .dest-header{flex-direction:column;gap:12px}
  .compare-section{padding:64px 24px}
}