/* ============================================================
   Manchester City Yas Residences by Ohana — ohanayas.ae
   Editorial waterfront luxury. Real renders, full-bleed.
   8pt rhythm · sky-blue hairline motif · physics-based reveals.
   ============================================================ */

:root{
  --sky:#6CABDD; --sky-2:#9ad4f5; --navy:#0A1A2F; --navy-2:#0e2238;
  --ink:#10243b; --sand:#E7DDCB; --ivory:#F6F2EA; --paper:#FBF9F4;
  --line:rgba(108,171,221,.5); --muted:#5d6b7a; --muted-d:rgba(246,242,234,.7);
  --gold:#C9A24B;
  --serif:'Playfair Display',Georgia,'Times New Roman',serif;
  --serif-2:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost',-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;
  --maxw:1240px; --pad:clamp(20px,5vw,64px);
  --r:14px; --r-lg:22px;
  --sh:0 18px 50px -24px rgba(10,26,47,.4);
  --sh-lift:0 30px 70px -30px rgba(10,26,47,.55);
  --ease:cubic-bezier(.22,.61,.36,1);
  --t:.6s var(--ease);
}
html[dir=rtl]{ --serif:'El Messiri',Georgia,serif; --serif-2:'El Messiri',serif; --sans:'Tajawal',-apple-system,sans-serif; }

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans); color:var(--ink); background:var(--paper);
  line-height:1.65; font-weight:300; -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
em{font-style:italic;color:var(--sky)}
::selection{background:var(--sky);color:#fff}

.container{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.skip{position:absolute;left:-9999px;top:0;background:var(--navy);color:#fff;padding:12px 18px;z-index:200;border-radius:0 0 10px 0}
.skip:focus{left:0}

/* ---------- typography scale ---------- */
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.04;letter-spacing:-.015em}
.eyebrow{
  font-family:var(--sans);font-weight:500;font-size:.74rem;letter-spacing:.32em;
  text-transform:uppercase;color:var(--sky);margin-bottom:18px;
}
.section .lead{font-size:clamp(1.04rem,1.6vw,1.22rem);color:var(--muted);max-width:62ch;font-weight:300;margin-top:18px}
.sec-head,.prop-head{max-width:760px;margin-bottom:clamp(40px,5vw,64px)}
.sec-head h2,.prop-head h2{font-size:clamp(2.1rem,5vw,3.6rem)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--sans);font-weight:500;font-size:.95rem;letter-spacing:.02em;
  padding:16px 30px;border-radius:100px;cursor:pointer;border:1px solid transparent;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s,color .3s;
  position:relative;
}
.btn-primary{background:var(--sky);color:var(--navy);font-weight:600;box-shadow:0 12px 30px -12px rgba(108,171,221,.7)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 20px 44px -14px rgba(108,171,221,.85)}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-ghost-light:hover{background:rgba(255,255,255,.1);transform:translateY(-2px)}
.btn-full{width:100%;margin-top:8px}
.btn.sm{padding:12px 22px;font-size:.88rem}

/* ============ NAV ============ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .4s var(--ease),box-shadow .4s,padding .4s var(--ease)}
.nav-in{display:flex;align-items:center;justify-content:space-between;padding-top:22px;padding-bottom:22px;transition:padding .4s var(--ease)}
.nav.scrolled{background:rgba(10,26,47,.9);backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(108,171,221,.18)}
.nav.scrolled .nav-in{padding-top:13px;padding-bottom:13px}
.lockup{display:flex;align-items:center;gap:12px}
.crest-img{width:36px;height:36px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.35))}
.nav.scrolled .crest-img{width:30px;height:30px}
.lockup-tx{display:flex;flex-direction:column;line-height:1.05;color:#fff}
.lockup-tx strong{font-family:var(--sans);font-weight:600;font-size:.92rem;letter-spacing:.12em}
.lockup-tx small{font-size:.64rem;letter-spacing:.18em;color:var(--sky-2);text-transform:uppercase;margin-top:2px}
.anchors{display:flex;gap:30px}
.anchors a{color:rgba(255,255,255,.82);font-size:.9rem;font-weight:300;letter-spacing:.02em;position:relative;padding:4px 0}
.anchors a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--sky);transition:width .35s var(--ease)}
.anchors a:hover{color:#fff}.anchors a:hover::after{width:100%}
.nav-r{display:flex;align-items:center;gap:18px}
.lang{background:transparent;border:1px solid rgba(255,255,255,.35);color:#fff;font-family:var(--sans);font-size:.82rem;font-weight:500;padding:8px 14px;border-radius:100px;cursor:pointer;transition:.3s}
.lang:hover{border-color:var(--sky);color:var(--sky-2)}
.cta-pill{background:var(--sky);color:var(--navy);font-weight:600;font-size:.86rem;padding:11px 22px;border-radius:100px;transition:transform .3s var(--ease),box-shadow .3s}
.cta-pill:hover{transform:translateY(-2px);box-shadow:0 14px 28px -12px rgba(108,171,221,.8)}

/* ============ HERO ============ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--navy)}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);will-change:transform}
.hero-scrim{position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,rgba(10,26,47,.55) 0%,rgba(10,26,47,.1) 32%,rgba(10,26,47,.35) 62%,rgba(10,26,47,.92) 100%);}
.hero-in{position:relative;z-index:2;padding-bottom:clamp(70px,11vh,140px);padding-top:140px;width:100%}
.kicker{display:inline-block;color:var(--sky-2);font-size:.74rem;font-weight:500;letter-spacing:.28em;text-transform:uppercase;margin-bottom:26px;padding-bottom:14px;border-bottom:1px solid rgba(154,212,245,.4)}
.hero h1{color:#fff;font-size:clamp(2.9rem,8.5vw,6.6rem);font-weight:600;line-height:.98;letter-spacing:-.02em;text-shadow:0 6px 40px rgba(0,0,0,.35)}
.hero h1 em{color:var(--sky-2)}
.hero-sub{color:rgba(255,255,255,.86);font-size:clamp(1rem,1.5vw,1.2rem);max-width:54ch;margin-top:26px;font-weight:300}
.hero-cta{display:flex;align-items:center;gap:24px;flex-wrap:wrap;margin-top:38px}
.hero-price{color:#fff;font-size:.95rem;font-weight:400;letter-spacing:.02em;padding-left:24px;border-left:1px solid rgba(255,255,255,.3)}
html[dir=rtl] .hero-price{border-left:0;border-right:1px solid rgba(255,255,255,.3);padding-left:0;padding-right:24px}
.scroll-cue{position:absolute;left:50%;transform:translateX(-50%);bottom:26px;z-index:3;display:flex;flex-direction:column;align-items:center;gap:6px;color:rgba(255,255,255,.75);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase}
.scroll-cue svg{animation:bob 1.8s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

/* ============ MARQUEE ============ */
.marquee{background:var(--navy);color:var(--sky-2);overflow:hidden;border-top:1px solid rgba(108,171,221,.2);border-bottom:1px solid rgba(108,171,221,.2);padding:16px 0}
.marquee-track{display:inline-flex;align-items:center;white-space:nowrap;animation:slide 38s linear infinite;will-change:transform}
.marquee-track span{font-family:var(--serif-2);font-size:1.4rem;font-weight:500;letter-spacing:.01em;padding:0 8px;color:rgba(246,242,234,.92)}
.marquee-track i{color:var(--sky);font-style:normal;padding:0 6px}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============ SECTION base ============ */
.section{padding:clamp(72px,11vw,140px) 0}
.prop{background:var(--paper)}

/* ---------- stat grid (count-ups) ---------- */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-top:clamp(24px,4vw,48px)}
.stat-tile{background:var(--paper);padding:clamp(28px,3vw,40px) clamp(20px,2.5vw,32px)}
.stat-n{display:block;font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);font-weight:600;color:var(--navy);line-height:1;letter-spacing:-.02em}
.stat-l{display:block;margin-top:14px;font-size:.92rem;color:var(--muted);font-weight:300}

/* ============ SHOWBAND (full-bleed image + card) ============ */
.showband{position:relative;min-height:min(86vh,760px);display:flex;align-items:center;overflow:hidden;background:var(--navy)}
.showband-media{position:absolute;inset:0}
.showband-media img{width:100%;height:100%;object-fit:cover;transform:scale(1.05);will-change:transform}
.showband-overlay{position:relative;z-index:2;width:100%;background:linear-gradient(90deg,rgba(10,26,47,.86) 0%,rgba(10,26,47,.5) 48%,rgba(10,26,47,0) 78%)}
html[dir=rtl] .showband-overlay{background:linear-gradient(270deg,rgba(10,26,47,.86) 0%,rgba(10,26,47,.5) 48%,rgba(10,26,47,0) 78%)}
.showband-card{max-width:540px;color:#fff;padding:clamp(48px,7vw,90px) 0}
.sb-tag{display:inline-block;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--sky-2);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid rgba(154,212,245,.4)}
.showband-card h2{font-size:clamp(2.2rem,4.6vw,3.6rem);color:#fff}
.showband-card h2 em{color:var(--sky-2)}
.showband-card p{margin:22px 0 32px;color:rgba(255,255,255,.85);font-weight:300;font-size:1.06rem}

/* ============ RESIDENCES ============ */
.residences{background:var(--ivory)}
.res-feature{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(24px,4vw,60px);align-items:center;margin-bottom:clamp(40px,5vw,72px)}
.res-feature-img{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh)}
.res-feature-img img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/11;transition:transform 1s var(--ease)}
.res-feature:hover .res-feature-img img{transform:scale(1.04)}
.res-flag{display:inline-block;font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:var(--sky);font-weight:600;margin-bottom:14px}
.res-feature-body h3{font-size:clamp(1.8rem,3.2vw,2.6rem);color:var(--navy)}
.res-beds{color:var(--sky);font-weight:500;font-size:1rem;margin:10px 0 18px}
.res-feature-body p,.res-card-body p{color:var(--muted);font-weight:300}
.num{font-variant-numeric:tabular-nums;white-space:nowrap}
.res-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,40px)}
.res-card{background:var(--paper);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);transition:transform .5s var(--ease),box-shadow .5s}
.res-card:hover{transform:translateY(-6px);box-shadow:var(--sh-lift)}
.res-card-img{overflow:hidden}
.res-card-img img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform 1s var(--ease)}
.res-card:hover .res-card-img img{transform:scale(1.05)}
.res-card-body{padding:clamp(24px,3vw,36px)}
.res-card-body h3{font-size:1.6rem;color:var(--navy)}
.res-foot{margin-top:clamp(28px,4vw,48px);font-size:1.04rem;color:var(--muted)}
.res-foot a{color:var(--navy);border-bottom:1px solid var(--sky);padding-bottom:2px;transition:.3s}
.res-foot a:hover{color:var(--sky)}

/* ============ AMENITIES ============ */
.amenities{background:var(--navy);color:#fff}
.amenities .eyebrow{color:var(--sky-2)}
.amenities h2{color:#fff}.amenities h2 em{color:var(--sky-2)}
.amenities .lead{color:var(--muted-d)}
.amen-feature{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lift);margin-bottom:clamp(20px,3vw,32px)}
.amen-feature-img img{width:100%;aspect-ratio:21/9;object-fit:cover}
.amen-feature-cap{position:absolute;left:0;right:0;bottom:0;padding:clamp(28px,4vw,52px);background:linear-gradient(0deg,rgba(10,26,47,.92),rgba(10,26,47,0))}
.amen-feature-cap h3{font-size:clamp(1.5rem,2.8vw,2.2rem);color:#fff}
.amen-feature-cap p{color:rgba(255,255,255,.82);max-width:60ch;margin-top:10px;font-weight:300}
.amen-pair{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,32px);margin-bottom:clamp(36px,5vw,56px)}
.amen-shot{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh)}
.amen-shot img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform 1s var(--ease)}
.amen-shot:hover img{transform:scale(1.05)}
.amen-shot figcaption{position:absolute;left:18px;bottom:16px;color:#fff;font-family:var(--serif-2);font-size:1.3rem;font-weight:500;text-shadow:0 2px 12px rgba(0,0,0,.5)}
.amen-list{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid rgba(108,171,221,.25)}
.amen-list li{padding:18px 4px;border-bottom:1px solid rgba(108,171,221,.18);color:rgba(255,255,255,.9);font-size:1.02rem;font-weight:300;position:relative;padding-left:24px}
.amen-list li::before{content:"";position:absolute;left:0;top:26px;width:8px;height:8px;background:var(--sky);border-radius:50%}
html[dir=rtl] .amen-list li{padding-left:4px;padding-right:24px}
html[dir=rtl] .amen-list li::before{left:auto;right:0}

/* ============ GALLERY ============ */
.gallery{background:var(--paper);padding-bottom:clamp(56px,8vw,100px)}
.gallery-rail{display:flex;gap:18px;overflow-x:auto;padding:6px var(--pad) 26px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--sky) transparent}
.gallery-rail::-webkit-scrollbar{height:6px}
.gallery-rail::-webkit-scrollbar-thumb{background:var(--sky);border-radius:10px}
.gal-item{flex:0 0 clamp(280px,42vw,560px);scroll-snap-align:center;border:0;padding:0;background:none;cursor:pointer;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);position:relative}
.gal-item img{width:100%;aspect-ratio:3/2;object-fit:cover;transition:transform .8s var(--ease)}
.gal-item:hover img{transform:scale(1.05)}
.gal-item::after{content:"⤢";position:absolute;top:14px;right:14px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:rgba(10,26,47,.6);color:#fff;border-radius:50%;opacity:0;transition:.3s;font-size:1.1rem}
.gal-item:hover::after{opacity:1}
.gallery-hint{margin-top:8px;color:var(--muted);font-size:.92rem}

/* ============ LOCATION ============ */
.location{background:var(--ivory)}
.loc-wrap{display:grid;grid-template-columns:1fr 1fr 1.3fr;gap:clamp(28px,4vw,56px);align-items:start}
.loc-h{font-family:var(--sans);font-weight:500;font-size:.92rem;letter-spacing:.06em;color:var(--sky);text-transform:uppercase;margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.loc-list{list-style:none}
.loc-list li{padding:11px 0;border-bottom:1px solid rgba(16,36,59,.08);font-size:1.05rem;color:var(--ink);font-weight:300}
.loc-map{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);height:100%;min-height:340px}
.loc-map iframe{width:100%;height:100%;min-height:340px;border:0;display:block;filter:grayscale(.2) contrast(1.05)}

/* ============ PAYMENT ============ */
.payment{background:var(--paper)}
.plans{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.5vw,28px)}
.plan{border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(28px,3.5vw,42px);background:var(--paper);transition:transform .5s var(--ease),box-shadow .5s}
.plan:hover{transform:translateY(-5px);box-shadow:var(--sh)}
.plan.feature{background:linear-gradient(180deg,#fff,var(--ivory));border-color:var(--sky)}
.plan h3{font-size:clamp(1.7rem,3vw,2.4rem);color:var(--navy);margin-bottom:24px;letter-spacing:.01em}
.timeline{display:flex;gap:10px;position:relative}
.tl-step{flex:1;text-align:center;position:relative;padding-top:28px}
.tl-step::before{content:"";position:absolute;top:6px;left:50%;width:12px;height:12px;background:var(--sky);border-radius:50%;transform:translateX(-50%);box-shadow:0 0 0 4px rgba(108,171,221,.18)}
.timeline::after{content:"";position:absolute;top:11px;left:8%;right:8%;height:1px;background:var(--line);z-index:0}
.tl-pct{display:block;font-family:var(--serif);font-size:1.7rem;font-weight:600;color:var(--navy)}
.tl-lbl{display:block;font-size:.8rem;color:var(--muted);margin-top:4px}
.plan-simple p{color:var(--muted);font-weight:300;margin-bottom:18px}
.plan-chip{display:inline-block;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sky);border:1px solid var(--line);border-radius:100px;padding:6px 14px}
.plan-sched{list-style:none;margin:0 0 20px;padding:0}
.plan-sched li{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:9px 0;border-bottom:1px solid var(--line);font-size:.92rem}
.plan-sched li:last-child{border-bottom:0}
.plan-sched .ps-when{color:var(--muted);font-weight:300}
.plan-sched .ps-pct{font-family:var(--serif);font-weight:600;color:var(--navy);white-space:nowrap;text-align:right}
.plan-sched li.ps-handover{border-top:1px solid var(--sky);margin-top:4px;padding-top:13px}
.plan-sched li.ps-handover .ps-when,.plan-sched li.ps-handover .ps-pct{color:var(--sky)}
.plan-disclaimer{margin-top:clamp(28px,4vw,44px);font-size:.92rem;color:var(--muted);max-width:80ch}

/* ============ LEAD FORM ============ */
.lead-sec{position:relative;background:var(--navy);color:#fff;overflow:hidden}
.lead-bg{position:absolute;inset:0;z-index:0}
.lead-bg img{width:100%;height:100%;object-fit:cover;opacity:.16}
.lead-sec::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(10,26,47,.85),rgba(10,26,47,.96))}
.lead-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,84px);align-items:center}
.lead-sec .eyebrow{color:var(--sky-2)}
.lead-copy h2{font-size:clamp(2.1rem,4.4vw,3.4rem);color:#fff}
.lead-copy h2 em{color:var(--sky-2)}
.lead-copy .lead{color:rgba(255,255,255,.84)}
.reassure{list-style:none;margin-top:28px;display:grid;gap:14px}
.reassure li{padding-left:30px;position:relative;color:rgba(255,255,255,.9);font-weight:300}
.reassure li::before{content:"";position:absolute;left:0;top:8px;width:16px;height:9px;border-left:2px solid var(--sky);border-bottom:2px solid var(--sky);transform:rotate(-45deg)}
html[dir=rtl] .reassure li{padding-left:0;padding-right:30px}
html[dir=rtl] .reassure li::before{left:auto;right:0}
.lead-card{background:var(--paper);color:var(--ink);border-radius:var(--r-lg);padding:clamp(28px,3.5vw,44px);box-shadow:var(--sh-lift)}
.lc-eyebrow{font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--sky);font-weight:500}
.lead-card h3{font-size:clamp(1.5rem,2.6vw,2rem);color:var(--navy);margin:8px 0 24px}
.field{margin-bottom:16px;position:relative}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field label{display:block;font-size:.82rem;font-weight:500;color:var(--ink);margin-bottom:7px;letter-spacing:.01em}
.field input,.field select,.cc{
  width:100%;padding:13px 15px;border:1px solid #d8d2c4;border-radius:11px;background:#fff;
  font-family:var(--sans);font-size:1rem;color:var(--ink);font-weight:300;transition:border .25s,box-shadow .25s;
}
.field input:focus,.field select:focus,.cc:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 3px rgba(108,171,221,.18)}
.tel{display:flex;gap:8px}
.cc{flex:0 0 112px}
.field .err{display:none;color:#c0392b;font-size:.8rem;margin-top:5px}
.field.invalid input{border-color:#c0392b}
.field.invalid .err{display:block}
.form-fine{font-size:.78rem;color:var(--muted);margin-top:14px;line-height:1.5}
.form-fine a{color:var(--navy);text-decoration:underline}
.form-msg{margin-top:12px;font-size:.9rem}
.form-msg.error{color:#c0392b}
.btn-load{display:none;width:18px;height:18px;border:2px solid rgba(10,26,47,.3);border-top-color:var(--navy);border-radius:50%;animation:spin .7s linear infinite}
#leadSubmit.loading .btn-tx{opacity:.5}
#leadSubmit.loading .btn-load{display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* ============ FOOTER ============ */
.footer{background:#06121f;color:#fff;padding:clamp(48px,6vw,72px) 0 32px}
.footer-in{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-bottom:32px;border-bottom:1px solid rgba(108,171,221,.18)}
.footer-brand{display:flex;align-items:center;gap:16px}
.footer-crest{width:42px;height:42px}
.footer-brand strong{display:block;font-family:var(--sans);font-weight:600;letter-spacing:.08em;font-size:.95rem}
.footer-dev{display:block;color:var(--muted-d);font-size:.85rem;font-weight:300;margin-top:4px}
.footer-r{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.footer-ohana{height:42px;width:auto;opacity:.92}
.footer-fine{display:flex;flex-direction:column;gap:14px;padding-top:26px}
.footer-links a{color:var(--sky-2);font-size:.88rem;transition:.3s}
.footer-links a:hover{color:#fff}
.footer-fine p{color:rgba(255,255,255,.42);font-size:.74rem;line-height:1.7;max-width:none;font-weight:300}

/* ============ STICKY CTA (mobile) ============ */
.sticky-cta{position:fixed;left:16px;right:16px;bottom:16px;z-index:90;background:var(--sky);color:var(--navy);text-align:center;font-weight:600;padding:16px;border-radius:100px;box-shadow:0 16px 36px -12px rgba(108,171,221,.85);transform:translateY(140%);transition:transform .5s var(--ease);display:none}
.sticky-cta.show{transform:translateY(0)}

/* ============ LIGHTBOX ============ */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(6,18,31,.96);display:none;align-items:center;justify-content:center;padding:5vw}
.lightbox.open{display:flex}
.lb-img{max-width:92vw;max-height:84vh;border-radius:8px;box-shadow:0 30px 90px rgba(0,0,0,.6)}
.lb-close,.lb-prev,.lb-next{position:absolute;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);color:#fff;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.3s}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:var(--sky);color:var(--navy);border-color:var(--sky)}
.lb-close{top:24px;right:24px;width:46px;height:46px;font-size:1.6rem;line-height:1}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);width:54px;height:54px;font-size:1.8rem}
.lb-prev{left:24px}.lb-next{right:24px}
.lb-cap{position:absolute;bottom:30px;left:0;right:0;text-align:center;color:rgba(255,255,255,.85);font-family:var(--serif-2);font-size:1.2rem}

/* ============ SCROLL REVEAL ============ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.stat-tile.reveal{transition-delay:calc(var(--i,0)*.06s)}

/* ============ RESPONSIVE ============ */
@media(max-width:980px){
  .anchors{display:none}
  .stat-grid{grid-template-columns:1fr 1fr}
  .res-feature{grid-template-columns:1fr}
  .res-row{grid-template-columns:1fr}
  .amen-pair{grid-template-columns:1fr}
  .amen-list{grid-template-columns:1fr 1fr}
  .loc-wrap{grid-template-columns:1fr 1fr}
  .loc-map{grid-column:1/-1;min-height:300px}
  .plans{grid-template-columns:1fr}
  .lead-grid{grid-template-columns:1fr}
  .sticky-cta{display:block}
}
@media(max-width:640px){
  .nav-in{padding-top:16px;padding-bottom:16px}
  .lockup-tx small{display:none}
  .hero h1{font-size:clamp(2.6rem,12vw,4rem)}
  .hero-cta{gap:16px}
  .hero-price{border-left:0;padding-left:0}
  html[dir=rtl] .hero-price{border-right:0;padding-right:0}
  .stat-grid{grid-template-columns:1fr}
  .amen-list{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .footer-in{flex-direction:column;align-items:flex-start}
  .marquee-track span{font-size:1.15rem}
}

/* ============ REDUCED MOTION ============ */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .hero-img,.showband-media img{transform:none}
  .marquee-track{animation:none}
}
