/* ============================================================
   83A Glen Iris Road — Website
   Luxe dark/bronze, responsive long-scroll
   ============================================================ */
:root{
  --bg:#f4f1ec; --bg-2:#ece7df; --paper:#faf8f4;
  --ink:#1c1a17; --ink-2:#3a3631; --muted:#7a7268;
  --rule:#d9d2c6; --bronze:#8a6a3b; --bronze-2:#b69266; --bronze-3:#cdab7e;
  --dark:#161311; --dark-2:#211d19; --dark-3:#2b2621;
  --maxw:1280px;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;padding:0;background:var(--dark);color:var(--bg);
  font-family:'Inter',sans-serif;font-weight:300;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
em{font-style:italic}
.serif{font-family:'Cormorant Garamond',serif}
h1,h2,h3,h4{margin:0;font-weight:300}

/* shared atoms ------------------------------------------------ */
.eyebrow{font-weight:500;font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--bronze-2)}
.chapter{font-family:'Cormorant Garamond',serif;font-size:15px;letter-spacing:.3em;color:var(--bronze-2);text-transform:uppercase}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(22px,5vw,72px)}
.title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(34px,4.6vw,68px);line-height:1.03;letter-spacing:-.015em}
.title em{color:var(--bronze-2)}
.lede{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(19px,2vw,27px);line-height:1.45;color:#d8d0c2}
.body{font-size:clamp(14.5px,1.05vw,16.5px);line-height:1.8;color:#cfc7b8}
section{position:relative}
.section{padding:clamp(72px,11vh,150px) 0}
.light-sec{background:var(--bg);color:var(--ink)}
.light-sec .body{color:var(--ink-2)}
.light-sec .title em{color:var(--bronze)}
.light-sec .chapter,.light-sec .eyebrow{color:var(--bronze)}
.light-sec .lede{color:var(--ink-2)}

/* buttons ---------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:12px;cursor:pointer;border:0;
  font-family:'Inter',sans-serif;font-size:11px;font-weight:500;letter-spacing:.26em;text-transform:uppercase;
  padding:16px 30px;transition:.4s var(--ease);background:var(--bronze);color:#fff;
}
.btn:hover{background:var(--bronze-2)}
.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.35);color:#f4f1ec}
.btn-ghost:hover{background:#f4f1ec;color:var(--dark);border-color:#f4f1ec}
.light-sec .btn-ghost{border-color:rgba(28,26,23,.3);color:var(--ink)}
.light-sec .btn-ghost:hover{background:var(--dark);color:#f4f1ec;border-color:var(--dark)}
.btn .ar{transition:transform .4s var(--ease)}
.btn:hover .ar{transform:translateX(4px)}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:90;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px clamp(22px,5vw,72px);
  transition:background .5s var(--ease),padding .5s var(--ease),box-shadow .5s var(--ease);
}
.nav.solid{background:rgba(18,15,13,.9);backdrop-filter:blur(14px);padding-top:15px;padding-bottom:15px;box-shadow:0 1px 0 rgba(255,255,255,.07)}
.nav .brand{display:flex;align-items:center;gap:12px;font-family:'Cormorant Garamond',serif;font-size:16px;letter-spacing:.1em;color:#f4f1ec;white-space:nowrap}
.nav .brand .m{font-family:'Inter',sans-serif;font-weight:600;font-size:10px;letter-spacing:.32em;color:var(--bronze-2)}
.nav .links{display:flex;align-items:center;gap:clamp(18px,2.4vw,38px)}
.nav .links a{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#e6ddcd;position:relative;padding:6px 0;font-weight:400}
.nav .links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--bronze-2);transition:width .35s var(--ease)}
.nav .links a:hover::after{width:100%}
.nav .links .nav-cta{border:1px solid var(--bronze-2);padding:11px 22px;color:#f4f1ec}
.nav .links .nav-cta::after{display:none}
.nav .links .nav-cta:hover{background:var(--bronze-2);color:var(--dark)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger i{display:block;width:26px;height:1.6px;background:#f4f1ec;transition:.35s var(--ease)}

/* mobile menu overlay */
.mobile-menu{
  position:fixed;inset:0;z-index:85;background:rgba(18,15,13,.98);backdrop-filter:blur(10px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  opacity:0;pointer-events:none;transition:opacity .45s var(--ease);
}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-menu a{font-family:'Cormorant Garamond',serif;font-size:clamp(28px,7vw,40px);color:#f4f1ec;padding:10px}
.mobile-menu a .mn{font-family:'Inter',sans-serif;font-size:11px;letter-spacing:.3em;color:var(--bronze-2);margin-right:14px;vertical-align:middle}

/* ============ HERO ============ */
.hero{height:100vh;min-height:640px;position:relative;overflow:hidden;display:flex;align-items:flex-end}
.hero-bg{position:absolute;inset:-8% 0;background:url('assets/01-facade.jpg') center 56%/cover;will-change:transform}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.55),rgba(0,0,0,.12) 30%,rgba(0,0,0,.30) 60%,rgba(0,0,0,.9))}
.hero-inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(40px,7vh,86px)}
.hero-kicker{display:flex;align-items:center;gap:18px;font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:#e9dfca;margin-bottom:28px}
.hero-kicker .ln{width:54px;height:1px;background:var(--bronze-2)}
.hero h1{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(40px,6.4vw,108px);line-height:.96;letter-spacing:-.02em;color:#fff;max-width:16ch}
.hero h1 em{color:var(--bronze-3)}
.hero-foot{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-top:clamp(32px,5vh,60px);flex-wrap:wrap}
.hero-addr{font-family:'Cormorant Garamond',serif;font-size:clamp(20px,2vw,30px);font-weight:300;color:#f4f1ec}
.hero-addr small{display:block;font-family:'Inter',sans-serif;font-size:10px;letter-spacing:.34em;text-transform:uppercase;color:#cdc1ab;margin-top:8px;font-weight:400}
.hero-stats{display:flex;gap:clamp(26px,3.4vw,52px)}
.hero-stats .it{text-align:center}
.hero-stats .it .v{font-family:'Cormorant Garamond',serif;font-size:clamp(30px,3.2vw,48px);font-weight:300;line-height:1;color:#fff}
.hero-stats .it .k{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:#bdb3a0;margin-top:8px}
.scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.scroll-cue .bar{width:1px;height:42px;background:linear-gradient(180deg,var(--bronze-2),transparent);animation:cuePulse 2.2s ease-in-out infinite}
@keyframes cuePulse{0%,100%{opacity:.35;transform:scaleY(.7)}50%{opacity:1;transform:scaleY(1)}}

/* ============ INTRO / RESIDENCE ============ */
.intro-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center}
.intro-stats{display:grid;grid-template-columns:repeat(3,auto);gap:0 clamp(26px,3.4vw,50px);margin-top:42px}
.intro-stats .s .v{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,3.6vw,54px);font-weight:300;line-height:1;color:var(--ink)}
.intro-stats .s .v sup{font-size:.4em;vertical-align:super;opacity:.55;margin-left:2px}
.intro-stats .s .k{font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);margin-top:10px}
.accom{display:flex;flex-wrap:wrap;gap:16px;margin-top:30px;padding:16px 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--bronze);font-weight:500}
.accom span{color:var(--rule)}
.intro-media{position:relative;aspect-ratio:4/5;overflow:hidden}
.intro-media img{width:100%;height:100%;object-fit:cover}
.intro-media figcaption{position:absolute;left:0;bottom:0;padding:22px;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.9);z-index:2}
.intro-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.5))}

/* ============ LIFESTYLE NARRATIVE ============ */
.life{display:grid;grid-template-columns:1fr 1fr;min-height:88vh}
.life-media{position:relative;overflow:hidden}
.life-media img{width:100%;height:100%;object-fit:cover}
.life-text{display:flex;flex-direction:column;justify-content:center;padding:clamp(48px,7vw,110px)}
.daypart{padding:18px 0;border-top:1px solid rgba(255,255,255,.13)}
.daypart:last-child{border-bottom:1px solid rgba(255,255,255,.13)}
.daypart h4{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:22px;color:var(--bronze-2);margin-bottom:8px}
.daypart p{margin:0;font-size:14px;line-height:1.7;color:#cfc7b8}

/* ============ FEATURE SPLITS ============ */
.feature{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;min-height:84vh}
.feature.reverse .f-media{order:-1}
.f-media{position:relative;overflow:hidden;min-height:52vh}
.f-media img{width:100%;height:100%;object-fit:cover;transition:transform 1.6s var(--ease)}
.feature:hover .f-media img{transform:scale(1.04)}
.f-media.duo{display:grid;grid-template-rows:1.5fr 1fr;gap:6px}
.f-text{display:flex;flex-direction:column;justify-content:center;padding:clamp(48px,6.5vw,104px)}
.spec{list-style:none;padding:0;margin:34px 0 0;max-width:46ch}
.spec li{display:grid;grid-template-columns:30px 1fr;gap:16px;padding:15px 0;border-top:1px solid var(--rule);align-items:baseline}
.dark-sec .spec li,.feature:not(.light-sec) .spec li{border-color:rgba(255,255,255,.14)}
.spec li:last-child{border-bottom:1px solid var(--rule)}
.dark-sec .spec li:last-child,.feature:not(.light-sec) .spec li:last-child{border-color:rgba(255,255,255,.14)}
.spec .n{font-family:'Cormorant Garamond',serif;font-size:13px;color:var(--bronze-2);letter-spacing:.05em}
.spec .t{font-family:'Cormorant Garamond',serif;font-size:clamp(17px,1.5vw,21px);font-weight:400;color:#f4f1ec}
.light-sec .spec .t{color:var(--ink)}
.spec .t small{display:block;font-family:'Inter',sans-serif;font-weight:300;font-size:12.5px;letter-spacing:.01em;color:#a9a092;margin-top:5px;line-height:1.5}
.light-sec .spec .t small{color:var(--muted)}

/* ============ FULL-BLEED PARALLAX BREAK ============ */
.bleed{height:100vh;min-height:560px;position:relative;overflow:hidden;display:flex;align-items:center}
.bleed.bottom{align-items:flex-end}
.bleed-bg{position:absolute;inset:-10% 0;background-size:cover;background-position:center;will-change:transform}
.bleed::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(0,0,0,.74) 0%,rgba(0,0,0,.4) 38%,rgba(0,0,0,0) 68%)}
.bleed.bottom::after{background:linear-gradient(180deg,rgba(0,0,0,0) 38%,rgba(0,0,0,.8))}
.bleed-content{position:relative;z-index:2;width:100%;padding-top:0;padding-bottom:0;color:#f4f1ec}
.bleed.bottom .bleed-content{padding-bottom:clamp(50px,9vh,110px)}
.bleed .title{color:#fff}.bleed .title em{color:var(--bronze-3)}
.bleed .lede{color:#e4ddcf}
.bleed .spec li{border-color:rgba(255,255,255,.22)}
.bleed .spec li:last-child{border-color:rgba(255,255,255,.22)}
.bleed-tag{position:absolute;right:clamp(22px,5vw,72px);bottom:clamp(28px,5vw,60px);z-index:2;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.6);text-align:right}

/* ============ GALLERY ============ */
.gallery-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:40px;flex-wrap:wrap}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:230px;gap:12px}
.gal-grid figure{margin:0;overflow:hidden;position:relative;cursor:pointer;background:#222}
.gal-grid img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.gal-grid figure:hover img{transform:scale(1.06)}
.gal-grid figure::after{content:"";position:absolute;inset:0;background:rgba(18,15,13,.0);transition:background .4s}
.gal-grid figure:hover::after{background:rgba(18,15,13,.16)}
.gal-grid figure .plus{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);z-index:2;opacity:0;transition:.4s var(--ease);color:#fff;font-size:26px;font-weight:200}
.gal-grid figure:hover .plus{opacity:1;transform:translate(-50%,-50%) scale(1)}
.gal-grid .span2{grid-column:span 2;grid-row:span 2}
.gal-grid .wide{grid-column:span 2}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(10,8,7,.96);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s var(--ease)}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:90vw;max-height:84vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb-close{position:absolute;top:24px;right:30px;background:none;border:0;color:#f4f1ec;font-size:34px;cursor:pointer;line-height:1;font-weight:200}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:none;border:1px solid rgba(255,255,255,.3);color:#fff;width:54px;height:54px;border-radius:50%;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:.3s}
.lb-nav:hover{background:rgba(255,255,255,.12)}
.lb-prev{left:26px}.lb-next{right:26px}
.lb-count{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);font-size:11px;letter-spacing:.24em;color:#cdc1ab}

/* ============ FLOORPLAN ============ */
.fp-grid{display:grid;grid-template-columns:.85fr 2fr;gap:clamp(40px,5vw,72px);align-items:center}
.fp-plan{background:var(--paper);border:1px solid var(--rule);padding:clamp(20px,3vw,42px);display:flex;align-items:center;justify-content:center;position:relative}
.fp-plan img{max-width:100%;height:auto;transition:transform 1.2s var(--ease)}
.fp-plan:hover img{transform:scale(1.02)}
.fp-plus{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);z-index:2;opacity:0;transition:.4s var(--ease);width:54px;height:54px;border-radius:50%;background:rgba(18,15,13,.82);color:#fff;font-size:24px;font-weight:200;display:flex;align-items:center;justify-content:center}
.fp-plan:hover .fp-plus{opacity:1;transform:translate(-50%,-50%) scale(1)}

/* ============ LOCATION ============ */
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,5vw,80px);align-items:center}
.loc-media{position:relative;aspect-ratio:4/3;overflow:hidden}
.loc-media img{width:100%;height:100%;object-fit:cover}
.loc-media figcaption{position:absolute;left:0;bottom:0;padding:22px;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.9);z-index:2}
.loc-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.5))}
.nearby{display:grid;grid-template-columns:1fr 1fr;gap:0 40px;margin-top:34px}
.nearby h5{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--bronze-2);margin:0 0 4px;font-weight:600;padding-top:22px;border-top:1px solid rgba(255,255,255,.16)}
.light-sec .nearby h5{color:var(--bronze);border-color:var(--rule)}
.nearby ul{list-style:none;padding:0;margin:0 0 18px}
.nearby li{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.09);font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:300}
.light-sec .nearby li{border-color:var(--rule)}
.nearby li span{font-family:'Inter',sans-serif;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:#9f9787;font-weight:400;align-self:center}
.map-embed{margin-top:46px;border:1px solid rgba(255,255,255,.14);overflow:hidden;position:relative;background:var(--dark-2)}
#locMap{width:100%;height:clamp(380px,52vh,560px);background:#1a1714;z-index:1}
.map-embed .leaflet-container{font-family:'Inter',sans-serif;background:#1a1714}
.map-embed .leaflet-control-attribution{background:rgba(18,15,13,.6);color:#9f9787;font-size:9px}
.map-embed .leaflet-control-attribution a{color:#b69266}
.map-embed .leaflet-bar a{background:var(--dark-2);color:#f4f1ec;border-color:rgba(255,255,255,.14)}
.map-embed .leaflet-bar a:hover{background:var(--bronze)}
/* custom markers */
.mk{position:relative;display:flex;align-items:center;justify-content:center}
.mk .dot{width:14px;height:14px;border-radius:50%;border:2px solid #fff;box-shadow:0 1px 6px rgba(0,0,0,.5)}
.mk.prop .dot{width:20px;height:20px;border-width:3px;background:var(--bronze-2)}
.mk.prop .pulse{position:absolute;width:20px;height:20px;border-radius:50%;background:var(--bronze-2);opacity:.5;animation:mkPulse 2.4s ease-out infinite}
@keyframes mkPulse{0%{transform:scale(1);opacity:.5}100%{transform:scale(3.4);opacity:0}}
.mk-parks .dot{background:#5a8f5e}.mk-schools .dot{background:#b07d3c}.mk-transport .dot{background:#5f7fb0}.mk-lifestyle .dot{background:#a8606a}
.map-embed .leaflet-tooltip{background:rgba(18,15,13,.9);border:1px solid rgba(255,255,255,.16);color:#f4f1ec;font-size:11px;letter-spacing:.04em;font-weight:400;box-shadow:0 4px 16px rgba(0,0,0,.4);padding:4px 9px;white-space:nowrap}
.map-embed .leaflet-tooltip::before{display:none}
.map-embed .leaflet-tooltip-top:before,.map-embed .leaflet-tooltip-bottom:before{display:none}
.prop-tip{background:var(--bronze)!important;border-color:var(--bronze-2)!important;font-weight:600!important;letter-spacing:.08em!important;text-transform:uppercase;font-size:10px!important}
/* legend */
.map-legend{position:absolute;left:16px;bottom:16px;z-index:400;background:rgba(18,15,13,.82);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);padding:13px 16px;display:flex;flex-wrap:wrap;gap:8px 18px;max-width:calc(100% - 32px)}
.map-legend .li{display:flex;align-items:center;gap:8px;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#d8d0c2}
.map-legend .sw{width:10px;height:10px;border-radius:50%;border:1.5px solid #fff}

/* ============ SPEC SUMMARY ============ */
.ss-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:34px 46px;margin-top:46px}
.ss-col h5{font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--bronze);margin:0 0 14px;font-weight:600;padding-bottom:10px;border-bottom:1px solid var(--rule)}
.ss-col ul{list-style:none;padding:0;margin:0}
.ss-col li{font-size:12.5px;line-height:1.5;color:var(--ink-2);padding:7px 0;border-bottom:1px solid var(--rule)}

/* ============ ENQUIRY ============ */
.enquire{background:var(--dark);position:relative;overflow:hidden}
.enq-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(44px,6vw,96px);align-items:center}
.enq-form{display:grid;grid-template-columns:1fr 1fr;gap:18px 20px}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1/-1}
.field label{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:#9f9787}
.field input,.field textarea,.field select{
  background:transparent;border:0;border-bottom:1px solid rgba(255,255,255,.22);
  color:#f4f1ec;font-family:'Inter',sans-serif;font-size:15px;font-weight:300;padding:10px 0;transition:border-color .3s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--bronze-2)}
.field textarea{resize:vertical;min-height:70px}
.field select{appearance:none}
.field select option{background:var(--dark-2)}
.enq-form .btn{grid-column:1/-1;justify-content:center;margin-top:8px}
.enq-note{font-size:11px;letter-spacing:.04em;color:var(--muted);margin-top:18px;line-height:1.6}
.form-success{display:none;padding:30px 0;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:24px;color:var(--bronze-2)}
.enquire.sent .enq-form{display:none}
.enquire.sent .form-success{display:block}
.contact-block{margin-top:30px;display:flex;flex-direction:column;gap:4px}
.contact-block .line{display:flex;justify-content:space-between;gap:20px;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:14px;color:#d8d0c2}
.contact-block .line span{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:#8b8475;align-self:center}

/* ============ FOOTER ============ */
.footer{background:var(--dark-2);padding:clamp(50px,7vh,90px) 0 40px;border-top:1px solid rgba(255,255,255,.08)}
.foot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-brand{font-family:'Cormorant Garamond',serif;font-size:30px;color:#f4f1ec}
.foot-brand .m{display:block;font-family:'Inter',sans-serif;font-size:10px;letter-spacing:.32em;color:var(--bronze-2);margin-bottom:8px}
.foot-links{display:flex;gap:30px;flex-wrap:wrap}
.foot-links a{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#cfc7b8}
.foot-links a:hover{color:var(--bronze-2)}
.foot-bottom{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;padding-top:26px;font-size:11px;letter-spacing:.04em;color:var(--muted)}
.foot-disc{max-width:70ch;line-height:1.7}

/* ============ REVEALS ============ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s var(--ease),transform 1.1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  html{scroll-behavior:auto}
  .hero-bg,.bleed-bg{transform:none!important}
}

/* ============ FILM / VIDEO REEL ============ */
.film{background:var(--dark);overflow:hidden}
.film-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-bottom:46px}
.reel-controls{display:flex;gap:10px}
.reel-controls button{width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.28);background:transparent;color:#f4f1ec;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:.3s var(--ease)}
.reel-controls button:hover{background:var(--bronze-2);border-color:var(--bronze-2);color:var(--dark)}
.reel-wrap{position:relative;margin:0 calc(-1 * clamp(22px,5vw,72px))}
.reel{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px clamp(22px,5vw,72px) 18px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.reel::-webkit-scrollbar{display:none}
.reel-card{position:relative;flex:0 0 auto;width:clamp(232px,25vw,310px);aspect-ratio:480/592;overflow:hidden;background:var(--dark-2);scroll-snap-align:center;cursor:pointer;border:1px solid rgba(255,255,255,.08)}
.reel-card video,.reel-card .rc-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.reel-card .rc-poster{z-index:1;transition:opacity .6s var(--ease)}
.reel-card.playing .rc-poster{opacity:0}
.reel-card::after{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,0) 30%,rgba(0,0,0,0) 60%,rgba(0,0,0,.6));pointer-events:none}
.reel-card .rc-label{position:absolute;left:18px;bottom:16px;z-index:3;color:#f4f1ec;pointer-events:none}
.reel-card .rc-label .t{font-family:'Cormorant Garamond',serif;font-size:21px;line-height:1.1}
.reel-card .rc-label .n{font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--bronze-3);margin-bottom:6px}
.reel-card .rc-expand{position:absolute;top:14px;right:14px;z-index:3;width:38px;height:38px;border-radius:50%;background:rgba(18,15,13,.55);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.85);transition:.4s var(--ease);color:#fff}
.reel-card:hover .rc-expand{opacity:1;transform:scale(1)}
.reel-card .rc-sound{position:absolute;bottom:16px;right:14px;z-index:3;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:6px;pointer-events:none}
.film-note{margin-top:22px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}

/* video modal */
.vmodal{position:fixed;inset:0;z-index:130;background:rgba(8,6,5,.95);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s var(--ease)}
.vmodal.open{opacity:1;pointer-events:auto}
.vmodal video{max-width:min(92vw,520px);max-height:88vh;background:#000;box-shadow:0 30px 90px rgba(0,0,0,.7)}
.vm-close{position:absolute;top:22px;right:28px;background:none;border:0;color:#f4f1ec;font-size:34px;cursor:pointer;line-height:1;font-weight:200}
.vm-nav{position:absolute;top:50%;transform:translateY(-50%);background:none;border:1px solid rgba(255,255,255,.3);color:#fff;width:54px;height:54px;border-radius:50%;cursor:pointer;font-size:22px;display:flex;align-items:center;justify-content:center;transition:.3s}
.vm-nav:hover{background:rgba(255,255,255,.12)}
.vm-prev{left:26px}.vm-next{right:26px}

@media (max-width:880px){
  .reel-card{width:72vw;max-width:330px}
  .reel-controls{display:none}
}

/* ============ RESPONSIVE ============ */
@media (max-width:1024px){
  .gal-grid{grid-auto-rows:200px}
}
@media (max-width:1080px){
  .nav .links{gap:18px}
  .nav .brand .serif{display:none}
}
@media (max-width:880px){
  .nav .links{display:none}
  .burger{display:flex}
  .intro-grid,.feature,.life,.loc-grid,.fp-grid,.enq-grid{grid-template-columns:1fr}
  .feature{min-height:0}
  .feature.reverse .f-media{order:0}
  .f-media{min-height:0;aspect-ratio:4/3}
  .f-media.duo{aspect-ratio:auto;grid-template-rows:none;grid-template-columns:1fr 1fr}
  .f-media.duo img{aspect-ratio:3/4}
  .f-text{padding:clamp(40px,8vw,60px) clamp(22px,6vw,40px)}
  .life{min-height:0}
  .life-media{aspect-ratio:4/3}
  .life-text{padding:clamp(40px,8vw,60px) clamp(22px,6vw,40px)}
  .intro-media{aspect-ratio:4/3;order:-1}
  .ss-grid{grid-template-columns:1fr 1fr}
  .gal-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .gal-grid .span2{grid-column:span 2;grid-row:span 1}
  .gal-grid .wide{grid-column:span 2}
  .fp-plan{order:-1}
  .map-embed{aspect-ratio:16/10}
  .enq-form{grid-template-columns:1fr}
  .hero-bg,.bleed-bg{background-attachment:scroll}
}
@media (max-width:560px){
  .hero-foot{gap:24px}
  .hero-stats{gap:24px}
  .intro-stats{gap:0 26px}
  .nearby{grid-template-columns:1fr 1fr}
  .ss-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:1fr 1fr;grid-auto-rows:140px}
  .foot-top{flex-direction:column}
  .bleed-tag{display:none}
}