/* ===== KonMar Lofts ===== */
:root{
  --bg:#fbf9f6;
  --bg-dark:#15140f;
  --ink:#1a1916;
  --ink-soft:#5a5750;
  --line:#e9e3d8;
  --line-dark:#2a2722;
  --gold:#b6914c;
  --gold-soft:#d6b274;
  --sand:#efe6d4;
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Inter",system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  font-size:16px;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.1;letter-spacing:-.01em;margin:0}
h1{font-size:clamp(2.6rem,6vw,5rem)}
h2{font-size:clamp(2rem,4.2vw,3.4rem)}
h3{font-size:1.5rem}
.eyebrow{
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);margin:0 0 1rem;font-weight:500;
}
.section{padding:clamp(4rem,9vw,8rem) clamp(1.25rem,5vw,5rem)}
.section.dark{background:var(--bg-dark);color:#ece6d8}
.section.dark .eyebrow{color:var(--gold-soft)}
.section-head{max-width:760px;margin:0 auto 3.5rem;text-align:center}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.95rem 1.6rem;font-size:.82rem;
  letter-spacing:.18em;text-transform:uppercase;
  border:1px solid transparent;transition:all .25s ease;
  white-space:nowrap;
}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:#9d7c3e}
.btn-line{border-color:currentColor}
.btn-line:hover{background:currentColor;color:var(--bg)}
.btn-ghost{border:1px solid var(--line);padding:.55rem 1rem;font-size:.72rem}
.btn-ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn.full{width:100%}

/* ===== Nav ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem clamp(1.25rem,4vw,3rem);
  background:rgba(251,249,246,.85);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(0,0,0,.04);
}
.brand{display:flex;align-items:center;gap:.7rem}
.brand-mark{
  font-family:var(--serif);font-size:1.3rem;letter-spacing:.05em;
  width:38px;height:38px;border:1px solid var(--gold);
  display:grid;place-items:center;color:var(--gold);
}
.brand-mark.big{width:54px;height:54px;font-size:1.6rem}
.brand-mark .amp{font-size:.7em;margin:0 1px}
.brand-name{font-family:var(--serif);font-size:1.15rem;letter-spacing:.02em}
.nav-links{display:flex;gap:1.8rem}
.nav-links a{
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-soft);transition:color .2s;
}
.nav-links a:hover{color:var(--gold)}
.nav-right{display:flex;align-items:center;gap:1rem}
.lang{display:flex;gap:.15rem;border:1px solid var(--line);border-radius:2px}
.lang button{
  padding:.4rem .6rem;font-size:.7rem;letter-spacing:.1em;
  color:var(--ink-soft);
}
.lang button.active{background:var(--ink);color:#fff}
.menu-btn{display:none;width:32px;height:32px;flex-direction:column;justify-content:center;gap:5px}
.menu-btn span{height:1px;background:var(--ink);display:block;transition:.3s}

/* ===== Hero ===== */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  color:#fff;text-align:center;overflow:hidden;
}
.hero-media{position:absolute;inset:0}
.hero-media img{width:100%;height:100%;object-fit:cover;animation:zoom 18s ease-out forwards}
@keyframes zoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.45) 0%,rgba(0,0,0,.25) 40%,rgba(0,0,0,.55) 100%);
}
.hero-content{position:relative;z-index:2;max-width:880px;padding:0 1.25rem}
.hero-content .eyebrow{color:var(--gold-soft)}
.hero-content h1{margin-bottom:1.5rem;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero-sub{font-size:clamp(1.05rem,1.6vw,1.3rem);max-width:600px;margin:0 auto 2.5rem;opacity:.92;font-weight:300}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.scroll-cue{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;
  color:#fff;font-size:1.6rem;animation:bob 2.4s ease-in-out infinite;
}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ===== About ===== */
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,6rem);
  align-items:center;max-width:1280px;margin:0 auto;
}
.about-text p{color:var(--ink-soft);margin:1rem 0}
.about-text h2{margin-bottom:1.5rem}
.about-stats{
  display:flex;gap:2.5rem;margin-top:2.5rem;
  padding-top:2rem;border-top:1px solid var(--line);
}
.about-stats > div{display:flex;flex-direction:column}
.about-stats strong{font-family:var(--serif);font-size:2.4rem;color:var(--gold);font-weight:500}
.about-stats span{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
.about-media{position:relative}
.about-media::before{
  content:"";position:absolute;inset:-20px -20px 20px 20px;
  border:1px solid var(--gold);z-index:0;
}
.about-media img{position:relative;z-index:1;width:100%;aspect-ratio:4/5;object-fit:cover}

/* ===== Lofts ===== */
.lofts-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;
  max-width:1320px;margin:0 auto;
}
.loft-card{
  background:#1f1c17;border:1px solid var(--line-dark);
  transition:transform .35s ease,border-color .35s;
}
.loft-card:hover{transform:translateY(-6px);border-color:var(--gold)}
.loft-media{aspect-ratio:4/3;overflow:hidden}
.loft-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.loft-card:hover .loft-media img{transform:scale(1.06)}
.loft-body{padding:1.8rem}
.loft-body h3{font-size:1.7rem;margin-bottom:1.2rem;color:var(--gold-soft)}
.loft-specs{list-style:none;padding:0;margin:0;display:grid;gap:.5rem}
.loft-specs li{
  display:flex;justify-content:space-between;font-size:.85rem;
  padding:.5rem 0;border-bottom:1px solid var(--line-dark);
}
.loft-specs li:last-child{border:0}
.loft-specs span{color:#9b958a;letter-spacing:.1em;text-transform:uppercase;font-size:.72rem}
.loft-specs strong{font-weight:500}
.lofts-note{text-align:center;margin:3rem auto 0;max-width:600px;color:#b8b0a0;font-style:italic;font-family:var(--serif);font-size:1.2rem}

/* ===== Amenities ===== */
.amen-grid{
  list-style:none;padding:0;margin:0 auto;max-width:1280px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;
}
.amen-grid li{
  display:flex;align-items:center;gap:1rem;
  padding:1.5rem 1.25rem;border:1px solid var(--line);
  transition:background .2s;
}
.amen-grid li:hover{background:#fff}
.amen-grid svg{width:26px;height:26px;stroke:var(--gold);stroke-width:1.4;fill:none;flex-shrink:0;stroke-linecap:round;stroke-linejoin:round}
.amen-grid span{font-size:.92rem}
.bath-feature{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);
  align-items:center;max-width:1280px;margin:5rem auto 0;
}
.bf-media img{aspect-ratio:3/4;object-fit:cover;width:100%}
.bf-text h3{font-size:clamp(1.6rem,2.6vw,2.4rem);margin-bottom:1rem}
.bf-text p{color:var(--ink-soft)}

/* ===== Gallery ===== */
.gallery-grid{
  display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:160px;
  gap:.5rem;max-width:1400px;margin:0 auto;
}
.gallery-grid a{overflow:hidden;position:relative;cursor:zoom-in}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform .6s,filter .3s;filter:saturate(.95)}
.gallery-grid a:hover img{transform:scale(1.06);filter:saturate(1.1)}
.g1{grid-column:span 2;grid-row:span 2}
.g2{grid-column:span 2;grid-row:span 1}
.g3{grid-column:span 2;grid-row:span 2}
.g4{grid-column:span 2;grid-row:span 1}
.g5{grid-column:span 2;grid-row:span 2}
.g6{grid-column:span 2;grid-row:span 1}
.g7{grid-column:span 2;grid-row:span 1}
.g8{grid-column:span 2;grid-row:span 2}
.g9{grid-column:span 2;grid-row:span 1}
.g10{grid-column:span 2;grid-row:span 1}
.g11{grid-column:span 2;grid-row:span 1}
.g12{grid-column:span 6;grid-row:span 2}

/* ===== Location ===== */
.loc-grid{
  display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,5rem);
  max-width:1320px;margin:0 auto;align-items:center;
}
.loc-text h2{margin-bottom:1.5rem}
.loc-text p{color:var(--ink-soft);margin-bottom:2rem}
.loc-list{list-style:none;padding:0;margin:0 0 2.5rem}
.loc-list li{
  display:flex;justify-content:space-between;align-items:baseline;gap:1rem;
  padding:1rem 0;border-bottom:1px solid var(--line);
}
.loc-list strong{font-family:var(--serif);font-size:1.25rem;font-weight:500}
.loc-list span{color:var(--ink-soft);font-size:.85rem;text-align:right}
.loc-map{aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line)}
.loc-map iframe{width:100%;height:100%;border:0;filter:grayscale(.3) contrast(.95)}

/* ===== Book ===== */
.book-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);
  max-width:1280px;margin:0 auto;
}
.book-text h2{margin-bottom:1.2rem}
.book-text > p{color:#b8b0a0;margin-bottom:2rem;max-width:440px}
.book-contact{list-style:none;padding:0;margin:0 0 2rem;display:grid;gap:.6rem}
.book-contact li{display:flex;align-items:center;gap:1rem}
.book-contact span{
  width:36px;height:36px;display:grid;place-items:center;
  border:1px solid var(--gold);color:var(--gold);font-size:.95rem;
}
.book-contact a{transition:color .2s}
.book-contact a:hover{color:var(--gold-soft)}
.check-times{font-size:.85rem;color:#b8b0a0;padding-top:1.5rem;border-top:1px solid var(--line-dark)}
.check-times strong{color:var(--gold-soft);font-family:var(--serif);font-size:1.2rem;margin:0 .15rem}

.book-form{background:#1f1c17;padding:2.2rem;border:1px solid var(--line-dark)}
.book-form .field{margin-bottom:1.2rem}
.book-form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.book-form .row:has(>.field:nth-child(3)){grid-template-columns:1fr 1fr 1fr}
.book-form label{
  display:block;font-size:.7rem;letter-spacing:.18em;
  text-transform:uppercase;color:#9b958a;margin-bottom:.5rem;
}
.book-form input,.book-form select,.book-form textarea{
  width:100%;background:#15140f;border:1px solid var(--line-dark);
  color:#ece6d8;padding:.85rem 1rem;font:inherit;font-size:.92rem;
  transition:border-color .2s;
}
.book-form input:focus,.book-form select:focus,.book-form textarea:focus{
  outline:0;border-color:var(--gold);
}
.book-form textarea{resize:vertical;min-height:90px}
.form-note{margin:1rem 0 0;font-size:.85rem;color:var(--gold-soft);min-height:1.2em}

/* ===== Flatpickr — luxury theme ===== */
.book-form .flatpickr-input + .form-control,
.book-form input.form-control{
  background:#15140f;border:1px solid var(--line-dark);
  color:#ece6d8;padding:.85rem 1rem;width:100%;font:inherit;font-size:.92rem;
}
.book-form input[readonly]{cursor:pointer}
.flatpickr-calendar{
  background:#1f1c17;border:1px solid var(--line-dark);box-shadow:0 20px 60px rgba(0,0,0,.5);
  font-family:var(--sans);
}
.flatpickr-calendar.arrowTop:before,.flatpickr-calendar.arrowTop:after,
.flatpickr-calendar.arrowBottom:before,.flatpickr-calendar.arrowBottom:after{display:none}
.flatpickr-months,.flatpickr-month,
.flatpickr-current-month,.flatpickr-current-month input.cur-year,
.flatpickr-weekdays,.flatpickr-weekday{
  background:#1f1c17;color:#ece6d8;
}
.flatpickr-weekday{color:#9b958a;font-weight:500;letter-spacing:.08em;font-size:.72rem;text-transform:uppercase}
.flatpickr-current-month{font-family:var(--serif);font-size:1.15rem;font-weight:500}
.flatpickr-current-month .flatpickr-monthDropdown-months{color:#ece6d8;background:#1f1c17}
.flatpickr-monthDropdown-month{background:#1f1c17;color:#ece6d8}
.flatpickr-prev-month,.flatpickr-next-month{fill:var(--gold-soft);color:var(--gold-soft)}
.flatpickr-prev-month:hover svg,.flatpickr-next-month:hover svg{fill:var(--gold)}
.flatpickr-day{color:#d6cebe;border-radius:2px;transition:all .15s}
.flatpickr-day.flatpickr-disabled,.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay{color:#5a5750}
.flatpickr-day:hover{background:#2a2722;border-color:#2a2722;color:#fff}
.flatpickr-day.today{border-color:var(--gold-soft);color:var(--gold-soft)}
.flatpickr-day.today:hover{background:var(--gold-soft);color:#15140f}
.flatpickr-day.selected,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange,.flatpickr-day.endRange{
  background:var(--gold);border-color:var(--gold);color:#fff;
}
.flatpickr-day.inRange{background:rgba(182,145,76,.15);border-color:transparent;color:#ece6d8;box-shadow:none}
.flatpickr-current-month .numInputWrapper span.arrowUp:after{border-bottom-color:var(--gold-soft)}
.flatpickr-current-month .numInputWrapper span.arrowDown:after{border-top-color:var(--gold-soft)}

/* ===== Footer ===== */
.footer{background:#0e0d0a;color:#9b958a;padding:4rem clamp(1.25rem,5vw,5rem) 1.5rem}
.foot-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.5rem;
  max-width:1280px;margin:0 auto 3rem;
}
.foot-grid h4{
  font-family:var(--sans);font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold-soft);margin-bottom:1.2rem;font-weight:500;
}
.foot-grid a{display:block;padding:.3rem 0;font-size:.9rem;transition:color .2s}
.foot-grid a:hover{color:var(--gold-soft)}
.foot-name{font-family:var(--serif);font-size:1.4rem;color:#ece6d8;margin:1rem 0 .3rem}
.foot-addr{font-size:.88rem;margin:0;line-height:1.7}
.foot-bottom{
  max-width:1280px;margin:0 auto;padding-top:1.5rem;
  border-top:1px solid var(--line-dark);font-size:.78rem;text-align:center;
}

/* ===== WhatsApp FAB ===== */
.wa-fab{
  position:fixed;bottom:1.5rem;right:1.5rem;z-index:60;
  display:flex;align-items:center;gap:.6rem;
  background:#fff;color:#1a1916;
  padding:.55rem 1.1rem .55rem .55rem;
  border-radius:999px;
  box-shadow:0 8px 24px rgba(0,0,0,.18),0 2px 6px rgba(0,0,0,.08);
  transition:transform .25s ease,box-shadow .25s ease;
  font-size:.85rem;font-weight:500;letter-spacing:.02em;
}
.wa-fab:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.22)}
.wa-fab svg{width:36px;height:36px;flex-shrink:0}
.wa-fab .wa-label{padding-right:.3rem}
@media (max-width:640px){
  .wa-fab{bottom:1rem;right:1rem;padding:.4rem}
  .wa-fab svg{width:42px;height:42px}
  .wa-fab .wa-label{display:none}
}

/* ===== Lightbox ===== */
.lightbox{
  position:fixed;inset:0;background:rgba(10,9,7,.96);z-index:100;
  display:flex;align-items:center;justify-content:center;
}
.lightbox[hidden]{display:none}
.lightbox img{max-width:92vw;max-height:90vh;object-fit:contain}
.lb-close,.lb-prev,.lb-next{
  position:absolute;color:#fff;width:48px;height:48px;font-size:2rem;
  display:grid;place-items:center;transition:opacity .2s;
}
.lb-close{top:1.5rem;right:1.5rem;font-size:2.5rem}
.lb-prev{left:1rem;top:50%;transform:translateY(-50%)}
.lb-next{right:1rem;top:50%;transform:translateY(-50%)}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{opacity:.6}

/* ===== Responsive ===== */
@media (max-width:1024px){
  .nav-links{display:none}
  .menu-btn{display:flex}
  .nav.open .nav-links{
    display:flex;flex-direction:column;position:absolute;
    top:100%;left:0;right:0;background:var(--bg);
    padding:1rem 1.5rem 1.5rem;gap:1rem;border-bottom:1px solid var(--line);
  }
  .about-grid,.bath-feature,.loc-grid,.book-grid{grid-template-columns:1fr}
  .about-media{order:-1;max-width:520px;margin:0 auto}
  .about-media::before{inset:-12px -12px 12px 12px}
  .lofts-grid{grid-template-columns:repeat(2,1fr)}
  .amen-grid{grid-template-columns:repeat(3,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .gallery-grid{grid-template-columns:repeat(4,1fr);grid-auto-rows:140px}
  .g1,.g3,.g5,.g8{grid-column:span 2;grid-row:span 2}
  .g2,.g4,.g6,.g7,.g9,.g10,.g11{grid-column:span 2;grid-row:span 1}
  .g12{grid-column:span 4;grid-row:span 2}
}
@media (max-width:640px){
  .brand-name{display:none}
  .nav-right .btn-ghost{display:none}
  .lofts-grid{grid-template-columns:1fr}
  .amen-grid{grid-template-columns:repeat(2,1fr)}
  .about-stats{gap:1.5rem;flex-wrap:wrap}
  .about-stats strong{font-size:1.9rem}
  .foot-grid{grid-template-columns:1fr 1fr;gap:1.5rem}
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:120px}
  .gallery-grid > a{grid-column:span 1!important;grid-row:span 1!important}
  .gallery-grid .g1,.gallery-grid .g5,.gallery-grid .g12{grid-column:span 2!important;grid-row:span 2!important}
  .book-form{padding:1.5rem}
  .book-form .row,.book-form .row:has(>.field:nth-child(3)){grid-template-columns:1fr}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{width:100%}
  .section{padding:4rem 1.25rem}
}
