/* ── TOKENS ── */
:root {
  --bg:      #0E0E0C;
  --s1:      #161614;
  --s2:      #1C1C1A;
  --s3:      #232320;
  --border:  rgba(255,255,255,.09);
  --bh:      rgba(201,168,76,.28);
  --gold:    #C9A84C;
  --gold-d:  rgba(201,168,76,.48);
  --text:    #EAE5DA;
  --t2:      rgba(234,229,218,.66);
  --t3:      rgba(234,229,218,.36);
  --white:   #FFFFFF;
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}

@keyframes zoomBg {from{transform:scale(1.06)}to{transform:scale(1.00)}}
@keyframes heroIn {from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes pgIn   {from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

body > *:not(nav):not(#menuOverlay) { animation: pgIn .38s cubic-bezier(.4,0,.2,1) both; }

/* ════════════════════════════════════
   NAV
════════════════════════════════════ */
#gNav{
  position:fixed;inset:0 0 auto 0;z-index:500;
  height:64px;display:flex;align-items:center;justify-content:space-between;
  padding:0 44px;transition:background .3s,border-color .3s;
}
#gNav.at-top-home{background:transparent;border-bottom:1px solid transparent}
#gNav.scrolled,#gNav.on-subpage{
  background:rgba(14,14,12,.93);backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border);
}
.nav-logo{
  font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:400;
  letter-spacing:.22em;text-transform:uppercase;color:var(--white);cursor:pointer;transition:color .2s;
}
.nav-logo:hover{color:var(--gold)}
.nav-right{display:flex;align-items:center;gap:22px}
.nav-back{
  display:none;align-items:center;gap:8px;
  font-size:.64rem;font-weight:500;letter-spacing:.17em;text-transform:uppercase;
  color:var(--gold);cursor:pointer;transition:gap .24s;
}
.nav-back:hover{gap:13px}
.nav-back svg{flex-shrink:0}
#gNav.on-subpage .nav-back{display:flex}

/* Hamburger */
.nav-menu-btn{
  display:flex;flex-direction:column;justify-content:center;gap:5px;
  width:36px;height:36px;cursor:pointer;padding:4px;background:none;border:none;
}
.nav-menu-btn span{
  display:block;height:1px;background:var(--white);
  transition:transform .3s,opacity .3s,width .3s;transform-origin:center;
}
.nav-menu-btn span:nth-child(1){width:22px}
.nav-menu-btn span:nth-child(2){width:16px}
.nav-menu-btn span:nth-child(3){width:22px}
.nav-menu-btn.open span:nth-child(1){width:22px;transform:translateY(6px) rotate(45deg)}
.nav-menu-btn.open span:nth-child(2){opacity:0}
.nav-menu-btn.open span:nth-child(3){width:22px;transform:translateY(-6px) rotate(-45deg)}

/* ════════════════════════════════════
   MENU OVERLAY
════════════════════════════════════ */
#menuOverlay{
  position:fixed;inset:0;z-index:400;display:flex;
  pointer-events:none;opacity:0;transition:opacity .34s cubic-bezier(.4,0,.2,1);
}
#menuOverlay.open{pointer-events:all;opacity:1}
.menu-backdrop{
  position:absolute;inset:0;background:rgba(10,10,8,.65);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.menu-panel{
  position:relative;z-index:1;margin-left:auto;
  width:360px;max-width:92vw;height:100%;
  background:var(--s1);border-left:1px solid var(--border);
  display:flex;flex-direction:column;
  padding:80px 0 48px;
  transform:translateX(100%);transition:transform .38s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;
}
#menuOverlay.open .menu-panel{transform:translateX(0)}
.menu-scroll{flex:1;padding:0 36px;overflow-y:auto}

.ml{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 0;border-bottom:1px solid var(--border);cursor:pointer;
}
.ml:last-child{border-bottom:none}
.ml-name{
  font-family:'Cormorant Garamond',serif;font-size:1.32rem;font-weight:400;
  color:var(--text);transition:color .2s;line-height:1.1;
}
.ml-right{display:flex;align-items:center;gap:10px}
.ml-arrow{color:var(--gold-d);font-size:.85rem;transition:transform .24s,color .2s}
.ml:hover .ml-name{color:var(--gold)}
.ml:hover .ml-arrow{color:var(--gold)}
.ml.no-sub:hover .ml-arrow{transform:translateX(3px)}

.ml-toggle{
  width:18px;height:18px;display:flex;align-items:center;justify-content:center;
  color:var(--t3);font-size:.65rem;transition:transform .28s,color .2s;flex-shrink:0;
}
.ml.open .ml-toggle{transform:rotate(180deg);color:var(--gold)}
.ml:hover .ml-toggle{color:var(--gold)}

.ml-sub{
  max-height:0;overflow:hidden;
  transition:max-height .36s cubic-bezier(.4,0,.2,1),opacity .28s;
  opacity:0;border-bottom:1px solid var(--border);
}
.ml-sub.open{opacity:1}
.ml-sub-inner{padding:6px 0 14px 0}
.sl{
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 14px;border-radius:2px;cursor:pointer;
  transition:background .18s;margin-bottom:2px;
}
.sl:hover{background:var(--s2)}
.sl-name{font-size:.82rem;font-weight:400;color:var(--t2);transition:color .18s}
.sl-arrow{font-size:.7rem;color:var(--t3);transition:transform .2s,color .2s}
.sl:hover .sl-name{color:var(--gold)}
.sl:hover .sl-arrow{transform:translateX(2px);color:var(--gold)}

.menu-section-label{
  font-size:.54rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;
}
.menu-footer{
  padding:24px 36px 0;border-top:1px solid var(--border);flex-shrink:0;margin-top:12px;
}
.menu-footer a{display:block;font-size:.76rem;color:var(--t2);margin-bottom:7px;transition:color .2s}
.menu-footer a:hover{color:var(--gold)}

/* ════════════════════════════════════
   HOME HERO
════════════════════════════════════ */
.home-hero{
  position:relative;height:100svh;min-height:680px;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.home-hero-bg{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1506905925346-21bda4d32df4?w=1920&q=85') center/cover no-repeat;
  animation:zoomBg 22s ease-in-out infinite alternate;will-change:transform;
}
.home-hero-overlay{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 90% 70% at 50% 45%,rgba(10,10,8,.42) 0%,rgba(10,10,8,.78) 100%),
    linear-gradient(to bottom,rgba(10,10,8,.08) 0%,rgba(10,10,8,.65) 75%,var(--bg) 100%);
}
.home-hero-content{
  position:relative;z-index:2;text-align:center;padding:0 24px;
  animation:heroIn 1.3s cubic-bezier(.4,0,.2,1) both;
}
.hero-brand{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3.5rem,8.5vw,7.5rem);font-weight:300;
  letter-spacing:.1em;text-transform:uppercase;line-height:.92;
  color:var(--white);text-shadow:0 2px 40px rgba(0,0,0,.5);
}
.hero-brand em{
  font-style:italic;font-weight:300;color:rgba(234,229,218,.75);
  font-size:.62em;display:block;letter-spacing:.18em;
}
.hero-tagline{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:clamp(.95rem,1.8vw,1.25rem);font-weight:300;
  color:rgba(234,229,218,.72);margin-top:24px;
  text-shadow:0 1px 12px rgba(0,0,0,.6);
}

/* ════════════════════════════════════
   HOME CARDS + LOCATION BADGE
════════════════════════════════════ */
.properties{padding:88px 32px 112px}
.sec-head{text-align:center;margin-bottom:52px}
.sec-head h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.7rem,3vw,2.5rem);font-weight:300;letter-spacing:.06em;color:var(--text);
}
.cards-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:14px;max-width:1280px;margin:0 auto;
}
.card{
  position:relative;overflow:hidden;cursor:pointer;aspect-ratio:9/13;
  border-radius:3px;border:1px solid var(--border);transition:border-color .4s,box-shadow .4s;
  display:block;
}
.card:hover{border-color:var(--bh);box-shadow:0 20px 56px rgba(0,0,0,.6)}
.card-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transition:transform .9s cubic-bezier(.25,.46,.45,.94);
}
.card:hover .card-bg{transform:scale(1.06)}
.card-vignette{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(8,8,6,.96) 0%,rgba(8,8,6,.70) 30%,rgba(8,8,6,.22) 62%,transparent 100%);
}
.card-body{position:absolute;bottom:0;left:0;right:0;padding:24px 26px 30px;z-index:2}
.card-loc{font-size:.63rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(234,229,218,.52);margin-bottom:8px}
.card-name{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.4rem,2vw,1.85rem);font-weight:400;line-height:1.1;color:var(--white);
}
.card-cta{
  display:inline-flex;align-items:center;gap:9px;margin-top:16px;
  font-size:.62rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);transition:gap .3s cubic-bezier(.4,0,.2,1);
}
.card:hover .card-cta{gap:14px}
.card-cta-line{display:block;width:20px;height:1px;background:var(--gold);transition:width .32s cubic-bezier(.4,0,.2,1)}
.card:hover .card-cta-line{width:32px}

/* Location badge – top-left of card */
.card-location-badge{
  position:absolute;top:14px;left:14px;z-index:3;
  display:inline-block;
  padding:5px 11px;
  background:#000;
  border:1.5px solid var(--gold);
  border-radius:2px;
  font-size:.56rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);
  pointer-events:none;
}

/* ════════════════════════════════════
   PROPERTY HERO
════════════════════════════════════ */
.prop-hero{
  position:relative;height:88svh;min-height:560px;
  display:flex;align-items:flex-end;overflow:hidden;
}
.prop-hero-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  animation:zoomBg 22s ease-in-out infinite alternate;will-change:transform;
}
.prop-hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(105deg,rgba(8,8,6,.82) 0%,rgba(8,8,6,.28) 58%,transparent 100%),
    linear-gradient(to top,rgba(8,8,6,.92) 0%,rgba(8,8,6,.36) 42%,transparent 100%);
}
.prop-hero-inner{
  position:relative;z-index:2;width:100%;max-width:1200px;margin:0 auto;
  padding:0 56px 68px;animation:pgIn .6s cubic-bezier(.4,0,.2,1) both;
}
.prop-eyebrow{
  font-size:.62rem;font-weight:500;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;text-shadow:0 1px 8px rgba(0,0,0,.7);
}
.prop-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.6rem,6.5vw,5.8rem);font-weight:300;line-height:.92;
  color:var(--white);text-shadow:0 2px 32px rgba(0,0,0,.55);
}
.prop-title em{font-style:italic;color:rgba(234,229,218,.82)}
.prop-address{
  margin-top:20px;font-size:.75rem;font-weight:400;letter-spacing:.1em;color:var(--t2);
  display:flex;align-items:center;gap:10px;text-shadow:0 1px 8px rgba(0,0,0,.5);
}
.prop-address::before{content:'';display:block;width:24px;height:1px;background:var(--gold-d);flex-shrink:0}
.sub-hero .prop-hero{height:72svh;min-height:440px}

/* ════════════════════════════════════
   FACTS BAR
════════════════════════════════════ */
.facts-bar{display:flex;flex-wrap:wrap;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.fact{flex:1;min-width:110px;padding:20px 26px;background:var(--s1);border-right:1px solid var(--border);display:flex;flex-direction:column;gap:5px;transition:background .2s}
.fact:last-child{border-right:none}
.fact:hover{background:var(--s2)}
.fact-label{font-size:.56rem;font-weight:500;letter-spacing:.27em;text-transform:uppercase;color:var(--t3)}
.fact-value{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:400;color:var(--text)}

/* ════════════════════════════════════
   CONTENT
════════════════════════════════════ */
.content-wrap{max-width:1200px;margin:0 auto;padding:76px 56px}
.intro-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;
  padding-bottom:72px;border-bottom:1px solid var(--border);
}
.col-label{font-size:.57rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:13px}
.col-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.5rem,2.2vw,2rem);font-weight:300;line-height:1.3;
  color:var(--text);margin-bottom:17px;
}
.col-body{font-size:.875rem;line-height:1.88;color:var(--t2);font-weight:300}
.col-body+.col-body{margin-top:12px}

.amenities-grid{
  display:grid;grid-template-columns:1fr 1fr;
  border:1px solid var(--border);border-radius:3px;overflow:hidden;margin-top:30px;
}
.amenity{
  display:flex;align-items:center;gap:11px;padding:13px 17px;
  border-bottom:1px solid var(--border);border-right:1px solid var(--border);
  background:var(--s1);transition:background .2s;
}
.amenity:nth-child(even){border-right:none}
.amenity:nth-last-child(-n+2){border-bottom:none}
.amenity:hover{background:var(--s2)}
.am-dot{width:4px;height:4px;border-radius:50%;background:var(--gold);flex-shrink:0;opacity:.75}
.am-text{font-size:.77rem;color:var(--t2)}

/* ════════════════════════════════════
   SUB-PROPERTY CARDS
════════════════════════════════════ */
.sub-section{padding:60px 0;border-bottom:1px solid var(--border)}
.sub-section-head{margin-bottom:32px}
.sub-section-head h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.5rem,2.3vw,2rem);font-weight:300;color:var(--text);
}
.sub-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.sub-card{
  overflow:hidden;border-radius:3px;border:1px solid var(--border);
  background:var(--s1);cursor:pointer;display:block;
  transition:border-color .3s,box-shadow .3s,transform .28s cubic-bezier(.4,0,.2,1);
}
.sub-card:hover{border-color:var(--bh);box-shadow:0 14px 44px rgba(0,0,0,.45);transform:translateY(-2px)}
.sub-card-img{
  height:220px;background-size:cover;background-position:center;
  transition:transform .6s cubic-bezier(.4,0,.2,1);
}
.sub-card:hover .sub-card-img{transform:scale(1.04)}
.sub-card-body{padding:22px 24px 26px}
.sub-card-label{font-size:.56rem;font-weight:600;letter-spacing:.27em;text-transform:uppercase;color:var(--gold);margin-bottom:7px}
.sub-card-name{
  font-family:'Cormorant Garamond',serif;
  font-size:1.2rem;font-weight:400;color:var(--text);line-height:1.22;margin-bottom:7px;
}
.sub-card-detail{font-size:.72rem;color:var(--t3);letter-spacing:.04em;margin-bottom:16px}
.sub-card-btn{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.6rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);transition:gap .25s;
}
.sub-card:hover .sub-card-btn{gap:13px}
.sub-card-btn-line{display:block;width:18px;height:1px;background:var(--gold);transition:width .28s}
.sub-card:hover .sub-card-btn-line{width:28px}

/* ════════════════════════════════════
   EVENTS
════════════════════════════════════ */
.events-section{padding:60px 0;border-bottom:1px solid var(--border)}
.events-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:32px}
.event-card{
  padding:30px 28px;background:var(--s1);border:1px solid var(--border);border-radius:3px;
  transition:background .24s,border-color .28s;
}
.event-card:hover{background:var(--s2);border-color:var(--bh)}
.event-card-num{
  font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:300;
  color:var(--gold);opacity:.32;line-height:1;margin-bottom:14px;
}
.event-card-title{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:400;color:var(--text);margin-bottom:9px}
.event-card-desc{font-size:.79rem;line-height:1.74;color:var(--t2);font-weight:300}

/* ════════════════════════════════════
   PROPERTY GALLERY (hero + thumbnails)
════════════════════════════════════ */
.gallery-section{padding:60px 0 68px;border-bottom:1px solid var(--border)}
.gallery-label{font-size:.57rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}

.gallery-stage{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  overflow:hidden;
  border-radius:3px;
  border:1px solid var(--border);
  background:var(--s1);
  cursor:zoom-in;
}
.gallery-stage img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;display:block;
  opacity:0;
  transition:opacity .35s cubic-bezier(.4,0,.2,1);
}
.gallery-stage img.active{opacity:1}

/* Stage hover indicator (subtle "click to expand") */
.gallery-stage::after{
  content:'';
  position:absolute;top:14px;right:14px;
  width:38px;height:38px;border-radius:50%;
  background:rgba(14,14,12,.78);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'><path d='M3 8V3H8M17 8V3H12M3 12V17H8M17 12V17H12' stroke='%23EAE5DA' stroke-width='1.5' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;background-position:center;background-size:18px 18px;
  border:1px solid var(--border);
  opacity:0;transition:opacity .25s;
  pointer-events:none;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.gallery-stage:hover::after{opacity:1}

/* Stage prev/next buttons */
.stage-nav{
  position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:42px;height:42px;border-radius:50%;
  background:rgba(14,14,12,.72);border:1px solid var(--border);
  color:var(--text);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .22s,border-color .22s,color .22s,opacity .22s;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:.4;
}
.gallery-stage:hover .stage-nav{opacity:1}
.stage-nav:hover{background:var(--gold);border-color:var(--gold);color:#000;opacity:1}
.stage-nav.prev{left:14px}
.stage-nav.next{right:14px}
.stage-nav svg{width:14px;height:14px}

/* Counter on stage */
.gallery-counter{
  position:absolute;left:14px;bottom:14px;z-index:5;
  padding:5px 11px;
  background:rgba(14,14,12,.72);border:1px solid var(--border);
  border-radius:2px;
  font-size:.6rem;font-weight:600;letter-spacing:.18em;
  color:var(--text);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  pointer-events:none;
}

/* "View all photos" button */
.gallery-view-all{
  position:absolute;right:14px;bottom:14px;z-index:5;
  padding:8px 14px;
  background:rgba(14,14,12,.78);border:1px solid var(--gold);
  border-radius:2px;cursor:pointer;
  font-family:'Inter',sans-serif;
  font-size:.58rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);
  transition:background .2s,color .2s;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  display:inline-flex;align-items:center;gap:8px;
}
.gallery-view-all:hover{background:var(--gold);color:#000}
.gallery-view-all svg{width:11px;height:11px}

/* Thumbnail strip below stage */
.gallery-thumbs{
  display:grid;
  grid-template-columns:repeat(8,1fr);
  gap:6px;
  margin-top:10px;
}
.gallery-thumb{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  border-radius:2px;
  cursor:pointer;
  border:1px solid var(--border);
  background:var(--s1);
}
.gallery-thumb img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .4s cubic-bezier(.4,0,.2,1),filter .25s;
  filter:brightness(.7);
}
.gallery-thumb:hover img{filter:brightness(1)}
.gallery-thumb.active{border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,168,76,.35)}
.gallery-thumb.active img{filter:brightness(1)}

/* "+ N more" overlay on last visible thumb if there are extras */
.gallery-thumb-more{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  background:rgba(8,8,6,.72);
  color:var(--white);
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem;font-weight:400;letter-spacing:.05em;
  pointer-events:none;
}

/* ════════════════════════════════════
   LIGHTBOX
════════════════════════════════════ */
#lightbox{
  display:none;
  position:fixed;inset:0;z-index:9000;
  align-items:center;justify-content:center;
  background:rgba(0,0,0,.95);
  animation:lbFadeIn .28s cubic-bezier(.4,0,.2,1);
}
#lightbox.open{display:flex}

@keyframes lbFadeIn{from{opacity:0}to{opacity:1}}

#lightbox-img{
  max-width:90vw;max-height:88vh;object-fit:contain;
  border-radius:2px;box-shadow:0 24px 80px rgba(0,0,0,.7);
  transition:opacity .22s;
}
#lightbox-close{
  position:fixed;top:20px;right:24px;z-index:9100;
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);
  color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,border-color .2s,color .2s,transform .2s;
  font-size:1.4rem;line-height:1;
  font-family:'Inter',sans-serif;
  padding:0;
}
#lightbox-close:hover{background:#fff;color:#000;transform:rotate(90deg)}

.lb-btn{
  position:fixed;top:50%;transform:translateY(-50%);z-index:9100;
  width:52px;height:52px;border-radius:50%;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);
  color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,border-color .2s,color .2s;
  padding:0;
}
.lb-btn:hover{background:var(--gold);border-color:var(--gold);color:#000}
.lb-btn svg{width:22px;height:22px}
#lb-prev{left:20px}
#lb-next{right:20px}

#lightbox-counter{
  position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:9100;
  font-size:.7rem;letter-spacing:.2em;color:rgba(255,255,255,.7);
  padding:6px 14px;background:rgba(0,0,0,.5);border-radius:2px;
}

/* ════════════════════════════════════
   GALERIE PAGE  (full grid, no carousel)
════════════════════════════════════ */
.galerie-hero{
  position:relative;height:40vh;min-height:260px;display:flex;align-items:flex-end;overflow:hidden;
}
.galerie-hero-bg{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1441974231531-c6227db76b6e?w=1800&q=85') center/cover no-repeat;
  filter:brightness(.38);
}
.galerie-hero-inner{
  position:relative;z-index:2;width:100%;max-width:1200px;margin:0 auto;padding:0 56px 52px;
}
.galerie-hero-inner h1{
  font-family:'Cormorant Garamond',serif;font-size:clamp(2.5rem,5vw,4rem);font-weight:300;
  color:var(--white);text-shadow:0 2px 20px rgba(0,0,0,.5);
}
.galerie-body{padding:64px 56px 96px;max-width:1200px;margin:0 auto}
.galerie-sec-head{
  display:flex;align-items:baseline;gap:18px;
  margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--border);
}
.galerie-sec-head h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.3rem,2vw,1.7rem);font-weight:300;color:var(--text)}
.galerie-sec-head span{font-size:.57rem;font-weight:600;letter-spacing:.27em;text-transform:uppercase;color:var(--gold)}
.galerie-grid{display:grid;gap:6px;border-radius:3px;overflow:hidden;margin-bottom:64px;grid-template-columns:repeat(4,1fr)}
.gg-item{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--s1);
  border-radius:2px;
  cursor:pointer;
}
.gg-item img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .5s cubic-bezier(.4,0,.2,1),filter .25s;
}
.gg-item:hover img{transform:scale(1.04);filter:brightness(1.08)}

@media(max-width:960px){
  .galerie-grid{grid-template-columns:repeat(3,1fr);gap:5px}
}
@media(max-width:680px){
  .galerie-grid{grid-template-columns:repeat(2,1fr);gap:4px}
}

/* ════════════════════════════════════
   BOOKING CTA
════════════════════════════════════ */
.booking-section{padding:60px 0 0}
.booking-head{text-align:center;margin-bottom:36px}
.booking-head .col-label{text-align:center}
.booking-head h3{font-family:'Cormorant Garamond',serif;font-size:clamp(1.4rem,2.2vw,2rem);font-weight:300;color:var(--text)}
.booking-head p{font-size:.78rem;color:var(--t3);margin-top:7px}
.booking-cards{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.b-card{
  display:flex;flex-direction:column;padding:38px 34px 34px;
  background:var(--s1);border:1px solid var(--border);border-radius:3px;
  text-decoration:none;color:inherit;
  transition:background .27s,border-color .28s,transform .27s cubic-bezier(.4,0,.2,1),box-shadow .28s;
}
.b-card:hover{background:var(--s2);border-color:var(--bh);transform:translateY(-3px);box-shadow:0 16px 44px rgba(0,0,0,.42)}
.b-card-label{font-size:.56rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.b-card-title{font-family:'Cormorant Garamond',serif;font-size:1.28rem;font-weight:400;margin-bottom:4px;color:var(--text)}
.b-card-sub{font-size:.72rem;color:var(--t3);margin-bottom:13px}
.b-card-val{font-size:.86rem;font-weight:400;color:var(--gold)}
.b-card-cta{
  margin-top:auto;padding-top:26px;display:flex;align-items:center;gap:9px;
  font-size:.59rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--t3);transition:color .22s,gap .27s cubic-bezier(.4,0,.2,1);
}
.b-card:hover .b-card-cta{color:var(--gold);gap:13px}
.b-card-cta-line{display:block;width:20px;height:1px;background:currentColor;transition:width .28s cubic-bezier(.4,0,.2,1)}
.b-card:hover .b-card-cta-line{width:30px}

/* ════════════════════════════════════
   CONTACT PAGE
════════════════════════════════════ */
.contact-hero{position:relative;height:36vh;min-height:240px;display:flex;align-items:flex-end;overflow:hidden}
.contact-hero-bg{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1464822759023-fed622ff2c3b?w=1600&q=80') center/cover no-repeat;
  filter:brightness(.38);
}
.contact-hero-inner{position:relative;z-index:2;width:100%;max-width:960px;margin:0 auto;padding:0 56px 48px}
.contact-hero-inner h1{
  font-family:'Cormorant Garamond',serif;font-size:clamp(2.3rem,5vw,3.8rem);font-weight:300;
  color:var(--white);text-shadow:0 2px 20px rgba(0,0,0,.5);
}
.contact-hero-inner p{font-size:.8rem;color:var(--t2);margin-top:9px;text-shadow:0 1px 8px rgba(0,0,0,.5)}
.contact-body{background:var(--bg);padding:68px 32px 92px}
.contact-inner{max-width:960px;margin:0 auto;display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:start}
.contact-info h3{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:300;margin-bottom:18px;color:var(--text)}
.contact-info p{font-size:.83rem;line-height:1.85;color:var(--t2);font-weight:300;margin-bottom:28px}
.contact-detail{display:flex;flex-direction:column;gap:12px}
.c-item{display:flex;flex-direction:column;gap:3px;padding:15px 19px;background:var(--s1);border:1px solid var(--border);border-radius:3px}
.c-item-label{font-size:.56rem;font-weight:600;letter-spacing:.27em;text-transform:uppercase;color:var(--t3)}
.c-item-val{font-size:.88rem;color:var(--gold)}
.c-item-val a{color:inherit;transition:color .2s}
.c-item-val a:hover{color:var(--text)}
.contact-form{display:flex;flex-direction:column;gap:15px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:.59rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--t3)}
.field input,.field textarea{
  background:var(--s1);border:1px solid var(--border);border-radius:3px;color:var(--text);
  font-family:'Inter',sans-serif;font-size:.875rem;font-weight:300;
  padding:13px 15px;outline:none;transition:border-color .22s,background .22s;resize:none;
}
.field input::placeholder,.field textarea::placeholder{color:var(--t3)}
.field input:focus,.field textarea:focus{border-color:var(--bh);background:var(--s2)}
.field textarea{min-height:136px}
.form-submit{
  margin-top:6px;display:inline-flex;align-items:center;justify-content:center;gap:11px;
  padding:15px 34px;background:transparent;border:1px solid var(--gold);border-radius:2px;
  color:var(--gold);font-family:'Inter',sans-serif;font-size:.67rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;cursor:pointer;
  transition:background .24s,color .24s,box-shadow .24s;align-self:flex-start;
}
.form-submit:hover{background:var(--gold);color:var(--bg);box-shadow:0 8px 24px rgba(201,168,76,.22)}
.form-submit svg{transition:transform .24s}
.form-submit:hover svg{transform:translateX(4px)}
.form-note{font-size:.69rem;color:var(--t3);margin-top:3px}
.form-success{
  display:none;text-align:center;padding:44px 28px;
  background:var(--s1);border:1px solid var(--border);border-radius:3px;
}
.form-success h4{font-family:'Cormorant Garamond',serif;font-size:1.55rem;font-weight:300;color:var(--text);margin-bottom:9px}
.form-success p{font-size:.8rem;color:var(--t2)}

/* ════════════════════════════════════
   FOOTER
════════════════════════════════════ */
footer{background:var(--s1);border-top:1px solid var(--border);padding:40px 32px}
.footer-inner{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}
.footer-wordmark{font-family:'Cormorant Garamond',serif;font-size:.98rem;font-weight:300;letter-spacing:.24em;text-transform:uppercase;color:var(--text)}
.footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:5px 26px}
.footer-link{font-size:.74rem;color:var(--gold);transition:color .2s}
.footer-link:hover{color:var(--text)}
.footer-copy{font-size:.59rem;color:var(--t3);letter-spacing:.07em}

/* ════════════════════════════════════
   WHATSAPP FLOATING BUTTON
════════════════════════════════════ */
#whatsapp-fab{
  position:fixed;
  right:24px;bottom:24px;
  width:58px;height:58px;
  border-radius:50%;
  background:#25D366;
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(37,211,102,.32),0 2px 8px rgba(0,0,0,.18);
  cursor:pointer;
  z-index:450;
  transition:transform .26s cubic-bezier(.4,0,.2,1),box-shadow .26s,background .26s;
  text-decoration:none;
  animation:wapPulse 2.4s ease-in-out infinite;
}
#whatsapp-fab:hover{
  transform:scale(1.08);
  background:#1ebe5d;
  box-shadow:0 12px 32px rgba(37,211,102,.48),0 4px 12px rgba(0,0,0,.22);
  animation-play-state:paused;
}
#whatsapp-fab svg{width:30px;height:30px;flex-shrink:0}

/* Tooltip on hover (desktop only) */
#whatsapp-fab::before{
  content:'Scrie-ne pe WhatsApp';
  position:absolute;
  right:calc(100% + 12px);
  top:50%;transform:translateY(-50%) translateX(6px);
  padding:8px 12px;
  background:rgba(14,14,12,.94);
  border:1px solid var(--border);
  border-radius:3px;
  font-family:'Inter',sans-serif;
  font-size:.65rem;font-weight:500;letter-spacing:.05em;
  color:var(--text);
  white-space:nowrap;
  opacity:0;pointer-events:none;
  transition:opacity .22s,transform .22s;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
#whatsapp-fab:hover::before{
  opacity:1;
  transform:translateY(-50%) translateX(0);
}

/* Subtle pulse ring */
@keyframes wapPulse{
  0%,100%{box-shadow:0 8px 24px rgba(37,211,102,.32),0 0 0 0 rgba(37,211,102,.5),0 2px 8px rgba(0,0,0,.18)}
  50%{box-shadow:0 8px 24px rgba(37,211,102,.32),0 0 0 14px rgba(37,211,102,0),0 2px 8px rgba(0,0,0,.18)}
}

/* Hide tooltip on touch devices */
@media(hover:none){
  #whatsapp-fab::before{display:none}
}

/* Mobile: slightly smaller, closer to corner */
@media(max-width:680px){
  #whatsapp-fab{
    width:54px;height:54px;
    right:16px;bottom:16px;
  }
  #whatsapp-fab svg{width:28px;height:28px}
}

/* ════════════════════════════════════
   RESPONSIVE
════════════════════════════════════ */
@media(max-width:960px){
  #gNav{padding:0 22px}
  .prop-hero-inner{padding:0 26px 52px}
  .content-wrap{padding:56px 26px}
  .intro-grid{grid-template-columns:1fr;gap:44px}
  .gallery-stage{aspect-ratio:4/3}
  .gallery-thumbs{grid-template-columns:repeat(6,1fr)}
  .booking-cards{grid-template-columns:1fr}
  .sub-cards{grid-template-columns:1fr}
  .events-grid{grid-template-columns:1fr}
  .contact-inner{grid-template-columns:1fr;gap:44px}
  .contact-hero-inner{padding:0 26px 40px}
  .galerie-hero-inner{padding:0 26px 40px}
  .galerie-body{padding:48px 26px 80px}
}
@media(max-width:680px){
  .cards-grid{grid-template-columns:1fr;gap:10px}
  .card{aspect-ratio:4/3}
  .form-row{grid-template-columns:1fr}
  .contact-body{padding:44px 18px 72px}
  .facts-bar .fact{min-width:100px;padding:17px 14px}
  .content-wrap{padding:48px 18px}
  .gallery-stage{aspect-ratio:4/3}
  .gallery-thumbs{grid-template-columns:repeat(4,1fr);gap:4px}
  .stage-nav{width:36px;height:36px}
  .stage-nav.prev{left:8px}
  .stage-nav.next{right:8px}
  .gallery-view-all{font-size:.52rem;padding:6px 10px}
  #lb-prev{left:8px}
  #lb-next{right:8px}
}
