/* ===========================================================
   Island South Properties — shared styles (app.css)
   ISP-distinct: ocean navy + aqua "water ribbon" + warm sand
   =========================================================== */

:root{
  --navy-900:#04263a;   /* darkest — hero/footer */
  --navy:#06324a;        /* primary brand */
  --navy-700:#0a4d68;    /* mid */
  --aqua:#2293bb;        /* accent (water ribbon) */
  --aqua-bright:#3bb6dc; /* hover / highlight */
  --aqua-soft:#d7eef6;   /* tints */
  --sand:#f4eee2;        /* warm neutral panel */
  --sand-deep:#ece1cc;
  --mist:#eef4f6;        /* cool light panel */
  --ink:#102530;         /* body text on light */
  --ink-soft:#46606d;    /* muted text */
  --line:#dde7eb;        /* hairlines */
  --paper:#ffffff;
  --gold:#e2a13e;        /* sparing warm accent for financing */
  --shadow-sm:0 2px 10px rgba(6,50,74,.08);
  --shadow:0 14px 40px rgba(6,50,74,.16);
  --shadow-lg:0 26px 70px rgba(4,38,58,.28);
  --r:14px; --r-lg:22px; --r-pill:999px;
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Manrope',system-ui,-apple-system,Segoe UI,sans-serif;
  color:var(--ink);background:var(--paper);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.display{font-family:'Space Grotesk','Manrope',sans-serif;letter-spacing:-.02em;font-weight:600}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;letter-spacing:-.02em;line-height:1.08;font-weight:600;color:var(--navy-900)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,40px)}
section{position:relative}
.eyebrow{font-family:'Space Grotesk',sans-serif;font-size:12.5px;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--aqua)}
.muted{color:var(--ink-soft)}

/* ---- water-ribbon underline accent ---- */
.ribbon{display:inline-block;height:7px;width:62px;border-radius:9px;
  background:linear-gradient(90deg,var(--aqua),var(--aqua-bright));margin:18px 0 0}
.ribbon.center{margin-left:auto;margin-right:auto}

/* ---------------- Buttons ---------------- */
.btn{display:inline-flex;align-items:center;gap:9px;justify-content:center;
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14.5px;letter-spacing:.01em;
  border-radius:var(--r-pill);padding:13px 26px;cursor:pointer;border:1.6px solid transparent;
  transition:transform .18s var(--ease),background .2s,color .2s,border-color .2s,box-shadow .2s;
  white-space:nowrap;line-height:1}
.btn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--aqua);color:#fff;box-shadow:0 10px 24px rgba(34,147,187,.32)}
.btn-primary:hover{background:var(--aqua-bright)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-700)}
.btn-ghost{background:transparent;border-color:rgba(255,255,255,.55);color:#fff}
.btn-ghost:hover{background:#fff;color:var(--navy);border-color:#fff}
.btn-ghost-dark{background:transparent;border-color:var(--navy);color:var(--navy)}
.btn-ghost-dark:hover{background:var(--navy);color:#fff}
.btn-gold{background:var(--gold);color:#3a2708}
.btn-gold:hover{filter:brightness(1.06)}
.btn-sm{padding:10px 18px;font-size:13px}
.btn-lg{padding:16px 32px;font-size:15.5px}

/* ---------------- Header / nav ---------------- */
header.nav{position:sticky;top:0;z-index:200;transition:background .3s,box-shadow .3s,backdrop-filter .3s}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;height:72px}
.brand{display:flex;align-items:center;gap:12px}
.brand .badge{width:42px;height:42px;border-radius:11px;flex:0 0 auto;box-shadow:var(--shadow-sm)}
.brand .brand-txt{display:flex;flex-direction:column;line-height:1.05}
.brand .brand-name{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:15px;letter-spacing:.01em;color:#fff}
.brand .brand-sub{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.62)}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-family:'Space Grotesk',sans-serif;font-size:13.5px;font-weight:500;letter-spacing:.02em;
  color:rgba(255,255,255,.82);transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:#fff}
.nav-cta{display:flex;align-items:center;gap:12px}
/* transparent over hero, solidifies on scroll */
header.nav{background:transparent}
header.nav.solid{background:rgba(6,50,74,.92);backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(255,255,255,.08)}
/* nav variant on light pages (no hero behind) */
header.nav.on-light .brand-name{color:var(--navy-900)}
header.nav.on-light .brand-sub{color:var(--ink-soft)}
header.nav.on-light .nav-links a{color:var(--ink-soft)}
header.nav.on-light .nav-links a:hover,header.nav.on-light .nav-links a.active{color:var(--navy)}
header.nav.on-light{background:rgba(255,255,255,.9);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line)}
.nav-burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-burger span{display:block;width:22px;height:2px;background:#fff;margin:4px 0;border-radius:2px;transition:.2s}
header.nav.on-light .nav-burger span{background:var(--navy)}
@media(max-width:880px){
  .nav-links{display:none}
  .nav-burger{display:block}
  .nav-cta .btn:not(.js-burger-cta){display:none}
}

/* mobile menu drawer */
.mobile-menu{position:fixed;inset:0;z-index:300;background:var(--navy-900);display:none;
  flex-direction:column;padding:26px clamp(18px,6vw,40px)}
.mobile-menu.open{display:flex}
.mobile-menu .mm-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}
.mobile-menu .mm-close{background:none;border:0;color:#fff;font-size:30px;cursor:pointer;line-height:1}
.mobile-menu a{color:#fff;font-family:'Space Grotesk',sans-serif;font-size:24px;font-weight:600;padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,.1)}
.mobile-menu .mm-cta{margin-top:26px}

/* ---------------- Hero ---------------- */
.hero{position:relative;min-height:clamp(560px,86vh,820px);display:flex;align-items:center;
  color:#fff;overflow:hidden;margin-top:-72px;padding-top:72px}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(4,38,58,.74) 0%,rgba(4,38,58,.58) 45%,rgba(4,38,58,.9) 100%)}
.hero-inner{position:relative;z-index:2;width:100%}
.hero h1{color:#fff;font-size:clamp(38px,6.2vw,76px);font-weight:600;max-width:16ch;text-shadow:0 2px 24px rgba(4,20,30,.45)}
.hero p.lede{font-size:clamp(16px,2vw,20px);color:rgba(255,255,255,.9);max-width:54ch;margin-top:20px;text-shadow:0 1px 16px rgba(4,20,30,.4)}
.hero .hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.hero-strip{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:40px;padding-top:26px;
  border-top:1px solid rgba(255,255,255,.18)}
.hero-strip .hs{display:flex;align-items:center;gap:9px;font-size:13.5px;color:rgba(255,255,255,.9);font-weight:500}
.hero-strip .hs svg{width:18px;height:18px;stroke:var(--aqua-bright);fill:none;stroke-width:2}

/* ---------------- Sections ---------------- */
.block{padding:clamp(64px,9vw,116px) 0}
.block.tint{background:var(--mist)}
.block.sand{background:var(--sand)}
.block.navy{background:var(--navy);color:#fff}
.block.navy h1,.block.navy h2,.block.navy h3{color:#fff}
.block.navy .muted{color:rgba(255,255,255,.72)}
.sec-head{max-width:760px}
.sec-head.center{margin:0 auto;text-align:center}
.sec-head h2{font-size:clamp(28px,4.4vw,46px);margin-top:14px}
.sec-head p{margin-top:16px;font-size:17px;color:var(--ink-soft)}
.block.navy .sec-head p{color:rgba(255,255,255,.74)}

/* feature card grid */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:980px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}

.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;
  box-shadow:var(--shadow-sm);transition:transform .22s var(--ease),box-shadow .22s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .ic{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;margin-bottom:18px;
  background:var(--aqua-soft);color:var(--navy)}
.card .ic svg{width:25px;height:25px;stroke:var(--navy);fill:none;stroke-width:1.9}
.card h3{font-size:19px;margin-bottom:8px}
.card p{font-size:15px;color:var(--ink-soft)}
.block.navy .card{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.12)}
.block.navy .card .ic{background:rgba(59,182,220,.16)}
.block.navy .card .ic svg{stroke:var(--aqua-bright)}
.block.navy .card p{color:rgba(255,255,255,.74)}

/* ---------------- Subdivisions showcase ---------------- */
.subdiv{display:grid;grid-template-columns:1.15fr .85fr;gap:22px}
@media(max-width:860px){.subdiv{grid-template-columns:1fr}}
.subdiv-feature{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:420px;
  display:flex;align-items:flex-end;color:#fff;box-shadow:var(--shadow)}
.subdiv-feature img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  transition:transform .6s var(--ease)}
.subdiv-feature:hover img{transform:scale(1.05)}
.subdiv-feature::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(4,38,58,0) 30%,rgba(4,38,58,.9) 100%);z-index:1}
.subdiv-feature .sf-body{position:relative;z-index:2;padding:34px}
.subdiv-feature .tag{display:inline-block;font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;background:var(--aqua);color:#fff;padding:6px 12px;border-radius:var(--r-pill)}
.subdiv-feature h3{color:#fff;font-size:32px;margin:14px 0 6px}
.subdiv-feature p{color:rgba(255,255,255,.86);font-size:15px;max-width:46ch}
.subdiv-feature .sf-link{display:inline-flex;align-items:center;gap:8px;margin-top:18px;
  font-family:'Space Grotesk',sans-serif;font-weight:600;color:#fff}
.subdiv-feature .sf-link svg{width:18px;height:18px;stroke:var(--aqua-bright);fill:none;stroke-width:2;transition:transform .2s}
.subdiv-feature:hover .sf-link svg{transform:translateX(4px)}
.subdiv-soon{border:2px dashed var(--line);border-radius:var(--r-lg);display:flex;flex-direction:column;
  justify-content:center;align-items:center;text-align:center;padding:40px;color:var(--ink-soft);background:var(--mist)}
.subdiv-soon .ic{width:54px;height:54px;border-radius:14px;background:#fff;display:grid;place-items:center;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.subdiv-soon .ic svg{width:26px;height:26px;stroke:var(--aqua);fill:none;stroke-width:1.8}
.subdiv-soon h3{font-size:20px;color:var(--navy)}
.subdiv-soon p{font-size:14.5px;margin-top:6px}

/* ---------------- Split / media rows ---------------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:center}
.split.reverse .split-media{order:2}
@media(max-width:860px){.split{grid-template-columns:1fr}.split.reverse .split-media{order:0}}
.split-media img{border-radius:var(--r-lg);box-shadow:var(--shadow);width:100%;aspect-ratio:4/3;object-fit:cover}
.split-body h2{font-size:clamp(26px,3.6vw,40px)}
.split-body p{margin-top:16px;color:var(--ink-soft);font-size:16.5px}
.split-body .list{margin-top:22px;display:flex;flex-direction:column;gap:13px}
.split-body .list li{list-style:none;display:flex;gap:12px;align-items:flex-start;font-size:15.5px}
.split-body .list svg{flex:0 0 auto;width:22px;height:22px;stroke:var(--aqua);fill:none;stroke-width:2;margin-top:1px}

/* ---------------- Facts strip ---------------- */
.facts{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}
@media(max-width:720px){.facts{grid-template-columns:repeat(2,1fr)}}
.facts .fact{background:var(--paper);padding:26px 24px}
.facts .fact .k{font-family:'Space Grotesk',sans-serif;font-size:clamp(24px,3vw,32px);font-weight:700;color:var(--navy)}
.facts .fact .l{font-size:13px;color:var(--ink-soft);margin-top:4px;letter-spacing:.02em}

/* ---------------- Financing band ---------------- */
.fin{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,60px);align-items:center}
@media(max-width:860px){.fin{grid-template-columns:1fr}}
.fin .badge-fin{display:inline-flex;align-items:center;gap:9px;background:rgba(226,161,62,.16);
  color:var(--gold);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:12.5px;letter-spacing:.14em;
  text-transform:uppercase;padding:8px 15px;border-radius:var(--r-pill)}
.fin h2{font-size:clamp(28px,4vw,44px);margin-top:18px}
.steps{display:flex;flex-direction:column;gap:14px}
.step{display:flex;gap:16px;align-items:flex-start;background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);border-radius:var(--r);padding:18px 20px}
.step .n{flex:0 0 auto;width:38px;height:38px;border-radius:10px;background:var(--aqua);color:#fff;
  display:grid;place-items:center;font-family:'Space Grotesk',sans-serif;font-weight:700}
.step h4{color:#fff;font-size:16px}
.step p{color:rgba(255,255,255,.72);font-size:14px;margin-top:3px}

/* ---------------- Plat / lots ---------------- */
.plat{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);
  cursor:zoom-in;border:1px solid var(--line);background:var(--navy-900)}
.plat img{width:100%;display:block}
.plat .plat-hint{position:absolute;right:14px;bottom:14px;background:rgba(4,38,58,.82);color:#fff;
  font-size:12.5px;font-weight:600;padding:8px 14px;border-radius:var(--r-pill);display:flex;gap:7px;align-items:center}
.plat .plat-hint svg{width:15px;height:15px;stroke:var(--aqua-bright);fill:none;stroke-width:2}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:400;background:rgba(4,20,30,.94);display:none;
  align-items:center;justify-content:center;padding:20px;cursor:zoom-out}
.lightbox.open{display:flex}
.lightbox img{max-width:100%;max-height:92vh;border-radius:8px;box-shadow:var(--shadow-lg);cursor:default}
.lightbox .lb-close{position:absolute;top:18px;right:22px;color:#fff;font-size:34px;cursor:pointer;line-height:1}

/* map teaser (links to interactive location page) */
.map-teaser{position:relative;display:block;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);
  aspect-ratio:4/3;background:var(--navy-900)}
.map-teaser img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.map-teaser:hover img{transform:scale(1.05)}
.map-teaser::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(4,38,58,.15),rgba(4,38,58,.55))}
.map-teaser .mt-pin{position:absolute;top:50%;left:50%;transform:translate(-50%,-100%);z-index:2;
  display:flex;flex-direction:column;align-items:center}
.map-teaser .mt-pin .dot{width:18px;height:18px;border-radius:50% 50% 50% 0;background:var(--aqua);
  border:3px solid #fff;transform:rotate(-45deg);box-shadow:0 8px 18px rgba(6,50,74,.5)}
.map-teaser .mt-pin .lbl{margin-top:10px;background:#fff;color:var(--navy);font-family:'Space Grotesk',sans-serif;
  font-weight:600;font-size:12.5px;padding:4px 11px;border-radius:var(--r-pill);box-shadow:var(--shadow-sm)}
.map-teaser .mt-cta{position:absolute;left:16px;bottom:16px;z-index:2;display:inline-flex;align-items:center;gap:8px;
  background:rgba(4,38,58,.82);color:#fff;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;
  padding:9px 15px;border-radius:var(--r-pill)}
.map-teaser .mt-cta svg{width:15px;height:15px;stroke:var(--aqua-bright);fill:none;stroke-width:2}

/* ---------------- Gallery ---------------- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:760px){.gallery{grid-template-columns:repeat(2,1fr)}}
.gallery a{border-radius:var(--r);overflow:hidden;display:block;aspect-ratio:3/2;box-shadow:var(--shadow-sm)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.gallery a:hover img{transform:scale(1.06)}

/* ---------------- FAQ ---------------- */
.faq{max-width:840px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{display:flex;justify-content:space-between;gap:18px;align-items:center;cursor:pointer;
  padding:22px 0;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:17.5px;color:var(--navy-900)}
.faq-q .pm{flex:0 0 auto;width:26px;height:26px;position:relative;transition:transform .25s}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--aqua);border-radius:2px}
.faq-q .pm::before{top:12px;left:4px;right:4px;height:2px}
.faq-q .pm::after{left:12px;top:4px;bottom:4px;width:2px;transition:transform .25s}
.faq-item.open .pm::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s var(--ease)}
.faq-a p{padding:0 0 22px;color:var(--ink-soft);font-size:15.5px;max-width:70ch}

/* ---------------- Listings (Propzy) ---------------- */
.listings-rail{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 2px 18px;
  -webkit-overflow-scrolling:touch}
.listings-rail::-webkit-scrollbar{height:8px}
.listings-rail::-webkit-scrollbar-thumb{background:var(--line);border-radius:9px}
.listing-card{flex:0 0 300px;scroll-snap-align:start;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),box-shadow .2s}
.listing-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.listing-card-img{position:relative;aspect-ratio:3/2;background:var(--mist)}
.listing-card-img img{width:100%;height:100%;object-fit:cover}
.listing-badge{position:absolute;top:12px;left:12px;display:flex;gap:6px}
.badge-featured,.badge-status{font-size:11px;font-weight:600;padding:5px 10px;border-radius:var(--r-pill);color:#fff}
.badge-featured{background:var(--gold);color:#3a2708}.badge-status{background:var(--navy)}
.listing-card-body{padding:18px}
.listing-card-body h3{font-size:17px}
.listing-address{font-size:13px;color:var(--ink-soft);margin-top:4px}
.listing-card-row{display:flex;justify-content:space-between;align-items:center;margin-top:14px;gap:10px}
.listing-price{font-family:'Space Grotesk',sans-serif;font-weight:700;color:var(--navy);font-size:18px}
.listing-meta{display:flex;gap:12px}.meta-item{display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--ink-soft)}
.meta-item svg{width:15px;height:15px;stroke:var(--aqua);fill:none;stroke-width:1.8}
.listings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;overflow:visible}
.listings-grid .listing-card{flex:none;width:auto}
@media(max-width:900px){.listings-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.listings-grid{grid-template-columns:1fr}}
.listings-empty{text-align:center;padding:54px 24px;border:2px dashed var(--line);border-radius:var(--r-lg);background:var(--mist)}
.listings-empty svg{width:42px;height:42px;stroke:var(--aqua);fill:none;stroke-width:1.6;margin:0 auto 14px}
.listings-empty h3{font-size:20px;color:var(--navy)}
.listings-empty p{color:var(--ink-soft);margin-top:6px;max-width:46ch;margin-left:auto;margin-right:auto}

/* ---------------- Contact CTA + footer ---------------- */
.cta-band{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-900) 100%);color:#fff;text-align:center;
  border-radius:var(--r-lg);padding:clamp(44px,7vw,80px) clamp(24px,5vw,60px);position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;top:-40%;right:-10%;width:480px;height:480px;border-radius:50%;
  background:radial-gradient(circle,rgba(59,182,220,.28),transparent 70%)}
.cta-band h2{color:#fff;font-size:clamp(28px,4.4vw,46px);position:relative}
.cta-band p{color:rgba(255,255,255,.8);max-width:54ch;margin:16px auto 0;position:relative}
.cta-band .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:30px;position:relative}

footer.site{background:var(--navy-900);color:rgba(255,255,255,.72);padding:64px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px}
@media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}
.foot-logo img{height:46px;width:auto;margin-bottom:16px}
.foot-about{font-size:14px;max-width:34ch}
.foot-col h4{color:#fff;font-size:13px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:16px;font-family:'Space Grotesk',sans-serif}
.foot-col a,.foot-col p{display:block;font-size:14.5px;color:rgba(255,255,255,.72);padding:5px 0;transition:color .2s}
.foot-col a:hover{color:var(--aqua-bright)}
.foot-contact a{display:flex;align-items:center;gap:10px}
.foot-contact svg{width:17px;height:17px;stroke:var(--aqua-bright);fill:none;stroke-width:2;flex:0 0 auto}
.socials{display:flex;gap:12px;margin-top:14px}
.socials a{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#fff}
.socials a:hover{background:var(--aqua)}
.socials svg{width:19px;height:19px;fill:currentColor}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:46px;padding-top:24px;
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:13px;color:rgba(255,255,255,.5)}

/* ---------------- Contact modal ---------------- */
.modal{position:fixed;inset:0;z-index:500;background:rgba(4,20,30,.6);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;padding:20px}
.modal.open{display:flex}
.modal-card{background:#fff;border-radius:var(--r-lg);width:100%;max-width:480px;overflow:hidden;
  box-shadow:var(--shadow-lg);animation:pop .25s var(--ease)}
@keyframes pop{from{transform:translateY(14px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal-head{background:var(--navy);color:#fff;padding:24px 26px;position:relative}
.modal-head .label{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--aqua-bright);font-weight:600}
.modal-head h3{color:#fff;font-size:23px;margin-top:6px}
.modal-head .x{position:absolute;top:16px;right:18px;color:rgba(255,255,255,.8);font-size:26px;cursor:pointer;line-height:1;background:none;border:0}
.modal-body{padding:26px}
.field{margin-bottom:15px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;font-family:inherit;font-size:15px;color:var(--ink);
  padding:12px 14px;border:1.5px solid var(--line);border-radius:11px;background:#fff;transition:border-color .2s,box-shadow .2s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--aqua);box-shadow:0 0 0 3px var(--aqua-soft)}
.field textarea{resize:vertical;min-height:90px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-msg{font-size:13.5px;margin-top:4px;min-height:18px}
.form-msg.err{color:#c0392b}
.modal-success{text-align:center;padding:18px 6px 4px}
.modal-success .ok{width:60px;height:60px;border-radius:50%;background:var(--aqua-soft);display:grid;place-items:center;margin:0 auto 16px}
.modal-success .ok svg{width:30px;height:30px;stroke:var(--navy);fill:none;stroke-width:2.2}
.modal-success h3{font-size:22px}
.modal-success p{color:var(--ink-soft);margin-top:8px;font-size:15px}

/* floating WhatsApp */
.wa-float{position:fixed;right:18px;bottom:18px;z-index:180;width:56px;height:56px;border-radius:50%;
  background:#25d366;display:grid;place-items:center;box-shadow:0 10px 26px rgba(37,211,102,.45);transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px;fill:#fff}

/* loader */
#loader{position:fixed;inset:0;z-index:700;background:var(--navy-900);display:grid;place-items:center;
  transition:opacity .6s ease,visibility .6s}
#loader.hide{opacity:0;visibility:hidden;pointer-events:none}
#loader img{width:84px;height:84px;border-radius:18px;animation:pulse 1.4s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.07);opacity:1}}

/* page hero (interior pages without full photo hero) */
.page-hero{background:var(--navy);color:#fff;padding:clamp(120px,16vw,168px) 0 clamp(46px,6vw,70px)}
.page-hero .eyebrow{color:var(--aqua-bright)}
.page-hero h1{color:#fff;font-size:clamp(32px,5vw,58px);margin-top:14px}
.page-hero p{color:rgba(255,255,255,.74);max-width:60ch;margin-top:16px;font-size:17px}
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:13px;color:rgba(255,255,255,.6);margin-bottom:8px}
.breadcrumb a:hover{color:#fff}.breadcrumb svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* utilities */
.center{text-align:center}
.mt-s{margin-top:14px}.mt{margin-top:26px}.mt-l{margin-top:44px}
.maxw-sm{max-width:680px}
