/* ===== Wallaby Pools — shared design system (network luxury: forest/bronze/ivory) ===== */
:root{
  --forest:#1b2a22; --forest-2:#24382d; --moss:#3c5544;
  --ivory:#f6f2ea; --paper:#fbf9f4; --sand:#ece4d6;
  --ink:#23271f; --muted:#6b6f64; --line:#e0d8c8;
  --bronze:#b08850; --bronze-lt:#caa86c; --gold:#d8b878;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Jost',-apple-system,sans-serif;color:var(--ink);background:var(--paper);line-height:1.7;font-weight:300;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Cormorant Garamond',Georgia,serif;color:var(--forest);font-weight:500;line-height:1.12;margin:0 0 .35em;letter-spacing:.4px}
h1{font-size:clamp(2.6rem,6vw,5rem);font-weight:500}
h2{font-size:clamp(2rem,4.4vw,3.4rem)}
h3{font-size:1.45rem}
p{margin:0 0 1.1rem}
a{color:var(--moss);text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{font-family:'Jost',sans-serif;text-transform:uppercase;letter-spacing:.32em;font-size:.72rem;font-weight:500;color:var(--bronze);margin-bottom:1.4em;display:inline-block}
.eyebrow::before{content:"";display:inline-block;width:26px;height:1px;background:var(--bronze);vertical-align:middle;margin-right:12px;margin-bottom:3px}
.lede{font-size:1.18rem;color:var(--muted);font-weight:300;max-width:60ch}
.btn{display:inline-block;font-family:'Jost',sans-serif;font-weight:500;letter-spacing:.12em;text-transform:uppercase;font-size:.78rem;padding:16px 34px;border-radius:2px;transition:.35s;cursor:pointer;border:1px solid transparent}
.btn-gold{background:var(--bronze);color:#fff}
.btn-gold:hover{background:var(--forest);color:#fff}
.btn-out{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.55)}
.btn-out:hover{background:#fff;color:var(--forest);border-color:#fff}
.btn-dark{background:var(--forest);color:#fff}
.btn-dark:hover{background:var(--bronze)}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}

/* Header */
header{position:fixed;top:0;left:0;right:0;z-index:60;transition:.4s;padding:22px 0}
header.solid{background:rgba(27,42,34,.97);backdrop-filter:blur(8px);padding:12px 0;box-shadow:0 6px 26px rgba(0,0,0,.18)}
.nav{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px;color:#fff;font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;letter-spacing:1px}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{color:#f2efe6;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;font-weight:400;transition:.25s}
.nav-links a:hover{color:var(--gold)}
.nav-phone{border:1px solid rgba(255,255,255,.4);padding:11px 22px;border-radius:2px}
.nav-phone:hover{background:var(--bronze);border-color:var(--bronze);color:#fff}
@media(max-width:980px){.nav-links a:not(.nav-phone){display:none}}

/* Hero */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;color:#fff;background:linear-gradient(180deg,rgba(20,30,24,.62),rgba(20,30,24,.74)),linear-gradient(135deg,#24382d,#0f1813);background-size:cover;background-position:center;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(180deg,rgba(18,28,22,.45),rgba(15,22,18,.82)),url("../images/hero.jpg");background-size:cover;background-position:center;z-index:0;animation:kenburns 32s ease-in-out infinite alternate;will-change:transform}
.hero .wrap{position:relative;z-index:2;padding-top:90px;padding-bottom:60px}
.hero h1{color:#fff;max-width:20ch;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.hero .lead{color:#ece7db;font-size:1.24rem;font-weight:300;max-width:48ch;margin-top:.4em}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:38px}
.hero-meta{position:absolute;bottom:34px;left:0;right:0;z-index:2}
.hero-meta .wrap{display:flex;gap:38px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.18);padding-top:22px;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:#d8d2c4}
.hero-meta b{color:var(--gold);font-weight:500}
@keyframes kenburns{0%{transform:scale(1)}100%{transform:scale(1.09)}}
.motes{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.motes i{position:absolute;bottom:-12px;border-radius:50%;background:radial-gradient(circle,rgba(216,184,120,.95),rgba(216,184,120,0) 70%);opacity:0;animation:floatmote linear infinite}
@keyframes floatmote{0%{opacity:0;transform:translateY(0) scale(.5)}15%{opacity:.7}50%{opacity:.38}85%{opacity:.55}100%{opacity:0;transform:translateY(-80vh) scale(1.15)}}
@media(prefers-reduced-motion:reduce){.hero::before{animation:none}.motes{display:none}}

/* page hero (sub-pages) */
.phero{position:relative;color:#fff;padding:160px 0 70px;background:linear-gradient(180deg,rgba(18,28,22,.6),rgba(15,22,18,.85)),linear-gradient(135deg,#24382d,#0f1813);background-size:cover;background-position:center}
.phero h1{color:#fff;font-size:clamp(2.2rem,5vw,3.8rem)}
.phero .lead{color:#ece7db;max-width:60ch;font-size:1.15rem}
.phero.poolbg::before{content:"";position:absolute;inset:0;background-image:linear-gradient(180deg,rgba(18,28,22,.55),rgba(15,22,18,.78)),url("../images/header-arena.jpg");background-size:cover;background-position:center;z-index:0}
.phero .wrap{position:relative;z-index:2}

/* Sections */
section{padding:clamp(64px,9vw,118px) 0}
.center{text-align:center}
.center .eyebrow::after{content:"";display:inline-block;width:26px;height:1px;background:var(--bronze);vertical-align:middle;margin-left:12px;margin-bottom:3px}
.center .eyebrow::before{margin-right:12px}
.section-head{max-width:64ch;margin-bottom:56px}
.center .section-head{margin-inline:auto}

/* Stats */
.stats{background:var(--forest);color:#fff}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stat .n{font-family:'Cormorant Garamond',serif;font-size:3.3rem;color:var(--gold);line-height:1}
.stat .l{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:#cdd4c8;margin-top:8px}
@media(max-width:720px){.stats .grid{grid-template-columns:1fr 1fr;gap:40px 20px}}

/* Split feature */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,80px);align-items:center}
.split.rev .media{order:2}
.media{position:relative;border-radius:3px;overflow:hidden;aspect-ratio:4/5;background:linear-gradient(135deg,#2b4034,#16201a)}
.media img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s ease}
.media:hover img{transform:scale(1.05)}
.media .frame{position:absolute;inset:14px;border:1px solid rgba(255,255,255,.35);pointer-events:none}
@media(max-width:820px){.split{grid-template-columns:1fr}.split.rev .media{order:0}.media{aspect-ratio:16/11}}

/* Why list */
.why-list{display:grid;grid-template-columns:1fr 1fr;gap:8px 46px;margin-top:10px}
.why-item{padding:22px 0;border-top:1px solid var(--line)}
.why-item h3{font-size:1.3rem;margin-bottom:.25em;display:flex;align-items:baseline;gap:12px}
.why-item h3 .num{font-family:'Jost',sans-serif;font-size:.72rem;letter-spacing:.2em;color:var(--bronze);font-weight:600}
.why-item p{color:var(--muted);font-size:.98rem;margin:0}
@media(max-width:760px){.why-list{grid-template-columns:1fr;gap:0 0}}

/* Wedge band w/ bg image */
.wedge{position:relative;color:#fff;background:var(--forest-2)}
.wedge::before{content:"";position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(18,28,22,.92),rgba(18,28,22,.6)),url("../images/feature.jpg");background-size:cover;background-position:center;z-index:0}
.wedge .wrap{position:relative;z-index:2;max-width:760px}
.wedge h2{color:#fff}
.wedge p{color:#e4ddcf}
.wedge ul{list-style:none;padding:0;margin:30px 0 0;display:grid;gap:0}
.wedge li{padding:16px 0 16px 38px;position:relative;border-top:1px solid rgba(255,255,255,.16);font-size:1.02rem;color:#f0ebde}
.wedge li::before{content:"✦";position:absolute;left:0;color:var(--gold)}

/* Services / model cards */
.svc{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.svc.four{grid-template-columns:repeat(4,1fr)}
.svc-card{background:var(--paper);border:1px solid var(--line);border-radius:3px;overflow:hidden;transition:.4s;display:flex;flex-direction:column}
.svc-card:hover{transform:translateY(-6px);box-shadow:0 22px 50px rgba(27,42,34,.14);border-color:var(--bronze-lt)}
.svc-card .ph{aspect-ratio:3/2;overflow:hidden;background:linear-gradient(135deg,#2b4034,#16201a)}
.svc-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s}
.svc-card:hover .ph img{transform:scale(1.07)}
.svc-card .body{padding:22px 24px 26px}
.svc-card h3{font-size:1.3rem;margin-bottom:.3em}
.svc-card .dim{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bronze);font-weight:500;margin-bottom:.5em}
.svc-card p{color:var(--muted);font-size:.95rem;margin:0}
@media(max-width:980px){.svc.four{grid-template-columns:1fr 1fr}}
@media(max-width:880px){.svc{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.svc,.svc.four{grid-template-columns:1fr}}

/* Process timeline (supports 5 or 8 steps) */
.proc{background:var(--ivory)}
.timeline{display:grid;grid-template-columns:repeat(5,1fr);gap:0}
.timeline.eight{grid-template-columns:repeat(4,1fr);gap:34px 0}
.tl{position:relative;padding:0 18px}
.tl::before{content:"";position:absolute;top:22px;left:0;right:0;height:1px;background:var(--line)}
.tl .dot{width:46px;height:46px;border-radius:50%;background:var(--forest);color:var(--gold);display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:1.4rem;position:relative;z-index:2;margin-bottom:20px}
.tl h3{font-size:1.15rem}
.tl p{font-size:.9rem;color:var(--muted)}
@media(max-width:880px){.timeline,.timeline.eight{grid-template-columns:1fr 1fr;gap:34px 18px}.tl::before{display:none}}
@media(max-width:520px){.timeline,.timeline.eight{grid-template-columns:1fr}}

/* Cross / secondary band (fiberglass) */
.crossband{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.crossband .wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,6vw,70px);align-items:center}
.crossband .media{aspect-ratio:16/11}
@media(max-width:820px){.crossband .wrap{grid-template-columns:1fr}}

/* Gallery */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gal a{position:relative;overflow:hidden;border-radius:3px;aspect-ratio:1;display:block;background:linear-gradient(135deg,#2b4034,#16201a);cursor:zoom-in}
.gal a.tall{grid-row:span 2;aspect-ratio:1/2}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform 1.3s ease}
.gal a:hover img{transform:scale(1.08)}
.gal .cap{position:absolute;left:0;right:0;bottom:0;padding:34px 18px 14px;background:linear-gradient(transparent,rgba(15,22,18,.82));color:#fff;font-size:.82rem;letter-spacing:.06em;opacity:0;transform:translateY(8px);transition:.4s}
.gal a:hover .cap{opacity:1;transform:none}
@media(max-width:760px){.gal{grid-template-columns:1fr 1fr}.gal a.tall{grid-row:auto;aspect-ratio:1}}
.note{font-size:.82rem;color:var(--muted);margin-top:18px;font-style:italic;text-align:center}

/* Testimonials */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.quote{background:var(--paper);border:1px solid var(--line);border-radius:3px;padding:34px 30px}
.quote .stars{color:var(--gold);letter-spacing:3px;font-size:.9rem;margin-bottom:14px}
.quote p{font-family:'Cormorant Garamond',serif;font-size:1.28rem;font-style:italic;color:#33392e;line-height:1.45;margin-bottom:18px}
.quote .who{font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--forest);font-weight:500}
.quote .where{font-size:.78rem;color:var(--muted);letter-spacing:.1em}
@media(max-width:820px){.quotes{grid-template-columns:1fr}}

/* Areas */
.chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:8px}
.chip{border:1px solid var(--line);border-radius:40px;padding:10px 22px;font-size:.84rem;letter-spacing:.06em;color:var(--moss);background:var(--paper);transition:.3s}
.chip:hover{background:var(--forest);color:#fff;border-color:var(--forest)}

/* FAQ */
.faq-wrap{max-width:820px;margin:0 auto}
details{border-bottom:1px solid var(--line)}
summary{cursor:pointer;padding:24px 4px;font-family:'Cormorant Garamond',serif;font-size:1.35rem;color:var(--forest);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";font-size:1.6rem;color:var(--bronze);font-weight:300;transition:.3s}
details[open] summary::after{content:"–"}
details .body{padding:0 4px 24px;color:var(--muted);max-width:70ch}

/* Contact */
.contact{position:relative;color:#fff;background:var(--forest)}
.contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:stretch}
.contact h2{color:#fff}
.contact a{color:var(--gold)}
.nap{line-height:2;font-size:1.02rem;color:#e4ddcf}
.nap strong{color:var(--gold);font-weight:500}
.map-box{border-radius:3px;overflow:hidden;min-height:380px}
.map-box iframe{width:100%;height:100%;min-height:380px;border:0;filter:grayscale(.3) contrast(1.05)}
.cform{display:grid;gap:14px;margin-top:8px}
.cform .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cform label{display:block;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:#cdd4c8;margin-bottom:6px}
.cform input,.cform select,.cform textarea{width:100%;padding:13px 14px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.06);color:#fff;font-family:'Jost',sans-serif;font-size:.95rem;font-weight:300;border-radius:2px}
form input[type=checkbox]{width:auto !important;flex:none;margin-top:3px}
.cform input::placeholder,.cform textarea::placeholder{color:#9aa896}
.cform input:focus,.cform select:focus,.cform textarea:focus{outline:none;border-color:var(--gold)}
.cform select option{color:#1b2a22}
.cform textarea{min-height:96px;resize:vertical}
.cform button{justify-self:start;cursor:pointer}
.cform .note{font-size:.76rem;color:#9aa896;margin:0}
.nap-mini{font-size:.9rem;color:#d8d2c4;line-height:1.8;margin-top:18px}
.nap-mini a{color:var(--gold)}
@media(max-width:560px){.cform .row{grid-template-columns:1fr}}
@media(max-width:820px){.contact .wrap{grid-template-columns:1fr}}

/* Philosophy band */
.philo{background:var(--forest);color:#ede7d9;padding:80px 0;text-align:center}
.philo .wrap{max-width:760px}
.philo-eyebrow{font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:22px}
.philo-lead{font-family:'Cormorant Garamond',serif;font-size:clamp(1.7rem,3.6vw,2.5rem);line-height:1.3;color:#fff;font-weight:500;margin:0 auto 22px;max-width:24ch}
.philo-body{font-size:1.05rem;line-height:1.85;color:#cdd4c8;font-weight:300;max-width:60ch;margin:0 auto}

/* Accreditations */
.accred{background:var(--ivory);padding:46px 0;text-align:center}
.accred .lab{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--bronze);margin-bottom:18px}
.accred .row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:880px;margin:0 auto}
.accred .b{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:#fff;border-radius:40px;padding:10px 18px;font-size:.82rem;letter-spacing:.03em;color:var(--forest);font-weight:500}
.accred .b svg{width:14px;height:14px;fill:none;stroke:var(--bronze);stroke-width:2.4;flex:none}

/* Story */
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;padding:24px 0}
.story-img img{width:100%;border-radius:4px;box-shadow:0 12px 34px rgba(0,0,0,.14)}
.story-sign{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--forest);font-size:1.18rem;margin-top:8px}
.founder-mini{display:flex;align-items:center;gap:14px;margin:4px 0 22px}
.founder-mini img{width:62px;height:62px;border-radius:50%;object-fit:cover;border:2px solid var(--gold);flex:none}
.founder-mini span{color:#e4ddcf;font-size:.95rem;line-height:1.45}
.founder-mini b{color:#fff}
@media(max-width:820px){.story-grid{grid-template-columns:1fr;gap:22px}}

/* Bars */
.callbar{display:none}
@media(max-width:768px){.callbar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:120;background:var(--forest);border-top:1px solid rgba(255,255,255,.14);box-shadow:0 -4px 18px rgba(0,0,0,.28)}
.callbar a{flex:1;text-align:center;padding:15px 8px;color:#fff;text-decoration:none;font-weight:600;letter-spacing:.04em;font-size:.95rem;font-family:'Jost',sans-serif}
.callbar a.cb-quote{background:var(--bronze);color:#1b2a22}
body{padding-bottom:54px}}
.trustbar{background:var(--forest);color:#cdd4c8;padding:16px 0;border-top:1px solid rgba(255,255,255,.08)}
.trustbar .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 22px;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;text-align:center}
.trustbar b{color:var(--gold);font-weight:500}
.pressbar{background:var(--paper);border-top:1px solid var(--line);padding:18px 0;text-align:center}
.pressbar .lab{font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--bronze);margin-bottom:8px}
.pressbar .outlets{font-family:'Cormorant Garamond',serif;font-size:1.05rem;color:var(--muted);display:flex;flex-wrap:wrap;gap:4px 16px;justify-content:center;align-items:center}
.pressbar .outlets a{color:var(--muted);text-decoration:none}.pressbar .outlets a:hover{color:var(--bronze)}

/* Footer */
footer{background:#121c16;color:#9aa896;font-size:.85rem;padding:48px 0 36px}
footer .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
footer h4{color:var(--gold);font-family:'Jost',sans-serif;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:14px}
footer a{color:#c4cdbd;display:block;margin-bottom:7px}
footer a:hover{color:var(--gold)}
.foot-brand{font-family:'Cormorant Garamond',serif;font-size:1.6rem;color:#fff;margin-bottom:8px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:30px;padding-top:20px;text-align:center;font-size:.78rem;color:#7c8a78;letter-spacing:.05em}
.foot-keywords{max-width:920px;margin-inline:auto;line-height:2}
.foot-keywords a{display:inline;margin:0;color:#8a978a;white-space:nowrap}
.foot-keywords a:hover{color:var(--gold)}
@media(max-width:720px){footer .wrap{grid-template-columns:1fr}}
.social{display:flex;gap:13px;justify-content:flex-start;margin:14px 0 4px}
.social a{width:40px;height:40px;border:1px solid rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#c4cdbd;transition:.25s}
.social a:hover{background:var(--gold);border-color:var(--gold);color:#1b2a22}
.social svg{width:18px;height:18px;fill:currentColor}

.skip{position:absolute;left:-999px}.skip:focus{left:8px;top:8px;background:#fff;color:#000;padding:8px;z-index:99}

/* Lightbox */
#lb{position:fixed;inset:0;background:rgba(12,18,14,.94);display:none;align-items:center;justify-content:center;z-index:200}
#lb.open{display:flex}
#lb img{max-width:92vw;max-height:84vh;border-radius:3px;box-shadow:0 24px 70px rgba(0,0,0,.55)}
#lb .lbcap{position:absolute;bottom:22px;left:0;right:0;text-align:center;color:#f0ece0;font-size:.9rem;letter-spacing:.06em}
#lb .lbn{position:absolute;color:#cdd4c8;font-size:.78rem;top:26px;left:26px;letter-spacing:.1em}
#lb button{position:absolute;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.32);color:#fff;width:54px;height:54px;border-radius:50%;font-size:1.6rem;line-height:1;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center}
#lb button:hover{background:var(--bronze);border-color:var(--bronze)}
#lbPrev{left:24px;top:50%;transform:translateY(-50%)}
#lbNext{right:24px;top:50%;transform:translateY(-50%)}
#lbClose{top:22px;right:22px;width:46px;height:46px;font-size:1.1rem}
@media(max-width:700px){#lbPrev{left:8px}#lbNext{right:8px}#lb button{width:46px;height:46px}}

/* ============================================================
   FLAGSHIP COMPONENTS (deep homepage + model pages)
   ============================================================ */

/* --- Mega / dropdown nav + mobile menu --- */
.menu-btn{display:none;background:none;border:0;color:#fff;cursor:pointer;padding:8px;z-index:70}
.menu-btn span{display:block;width:26px;height:2px;background:#fff;margin:5px 0;transition:.3s}
body.menu-open .menu-btn span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .menu-btn span:nth-child(2){opacity:0}
body.menu-open .menu-btn span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.has-drop{position:relative}
.drop{position:absolute;top:calc(100% + 18px);left:50%;transform:translateX(-50%) translateY(10px);min-width:560px;background:#fff;border-radius:4px;box-shadow:0 26px 60px rgba(15,22,18,.22);padding:26px 28px;opacity:0;visibility:hidden;transition:.3s;display:grid;grid-template-columns:1fr 1fr;gap:8px 30px;z-index:65}
.has-drop:hover .drop,.has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateX(-50%)}
.drop::before{content:"";position:absolute;top:-18px;left:0;right:0;height:18px}
.drop a{color:var(--ink)!important;text-transform:none!important;letter-spacing:0!important;font-size:.95rem!important;padding:9px 10px;border-radius:3px;display:flex;flex-direction:column;transition:.2s}
.drop a:hover{background:var(--ivory)}
.drop a b{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--forest);font-weight:600}
.drop a span{font-size:.78rem;color:var(--muted)}
.drop .dhead{grid-column:1 / -1;font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--bronze);margin:6px 0 2px;font-weight:600}
@media(max-width:1100px){
  .menu-btn{display:block}
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(86vw,380px);background:var(--forest);flex-direction:column;align-items:flex-start;gap:4px;padding:96px 30px 40px;transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);overflow-y:auto;box-shadow:-10px 0 40px rgba(0,0,0,.3)}
  body.menu-open .nav-links{transform:none}
  .nav-links a:not(.nav-phone){display:block!important;width:100%;padding:13px 4px;border-bottom:1px solid rgba(255,255,255,.1);font-size:.95rem}
  .nav-phone{margin-top:16px}
  .has-drop .drop{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;background:transparent;padding:6px 0 6px 14px;min-width:0;grid-template-columns:1fr;gap:0}
  .drop a{color:#cdd4c8!important;padding:9px 4px}
  .drop a:hover{background:rgba(255,255,255,.06)}
  .drop a b{color:#fff;font-size:1rem}
  .drop a span{color:#9aa896}
  .drop .dhead{color:var(--gold)}
}

/* --- Video hero --- */
.vhero{position:relative;min-height:100vh;display:flex;align-items:center;color:#fff;overflow:hidden;background:linear-gradient(135deg,#24382d,#0f1813)}
.vhero video,.vhero .vposter{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.vhero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,24,19,.5),rgba(14,20,16,.82));z-index:1}
.vhero .wrap{position:relative;z-index:3;padding-top:120px;padding-bottom:140px}
.vhero .eyebrow{color:var(--gold)}
.vhero h1{color:#fff;max-width:18ch;text-shadow:0 2px 40px rgba(0,0,0,.4)}
.vhero .lead{color:#ece7db;font-size:1.3rem;font-weight:300;max-width:50ch;margin-top:.5em}
.vhero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:40px}
.vhero-meta{position:absolute;bottom:30px;left:0;right:0;z-index:3}
.vhero-meta .wrap{padding-top:22px;border-top:1px solid rgba(255,255,255,.2);display:flex;gap:36px;flex-wrap:wrap;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:#d8d2c4}
.vhero-meta b{color:var(--gold);font-weight:500}
.playbadge{position:absolute;bottom:30px;right:28px;z-index:3;display:flex;align-items:center;gap:10px;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:#e7e1d4}
.playbadge i{width:30px;height:30px;border:1px solid rgba(255,255,255,.5);border-radius:50%;display:flex;align-items:center;justify-content:center;font-style:normal}
@media(max-width:680px){.vhero-meta{display:none}.playbadge{display:none}}

/* --- Model showcase (spec rows) --- */
.model{padding:0}
.modelrow{display:grid;grid-template-columns:1.05fr .95fr;align-items:stretch;min-height:540px}
.modelrow .mr-media{position:relative;overflow:hidden;background:linear-gradient(135deg,#2b4034,#16201a)}
.modelrow .mr-media img{width:100%;height:100%;object-fit:cover;transition:transform 1.6s ease}
.modelrow:hover .mr-media img{transform:scale(1.05)}
.modelrow .mr-body{display:flex;flex-direction:column;justify-content:center;padding:clamp(40px,6vw,84px)}
.modelrow.alt{background:var(--ivory)}
.modelrow.alt .mr-media{order:2}
.mr-size{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--bronze)}
.modelrow h2{font-size:clamp(2.4rem,4vw,3.6rem);margin:.1em 0 .3em}
.mr-specs{display:flex;gap:30px;margin:18px 0 24px;flex-wrap:wrap}
.mr-specs div{border-left:2px solid var(--bronze-lt);padding-left:14px}
.mr-specs .v{font-family:'Cormorant Garamond',serif;font-size:1.7rem;color:var(--forest);line-height:1}
.mr-specs .k{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
@media(max-width:860px){.modelrow{grid-template-columns:1fr}.modelrow .mr-media{min-height:300px;order:0!important}.modelrow.alt .mr-media{order:0}}

/* --- Dual tracks (homeowners / professionals) --- */
.tracks{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.track{position:relative;min-height:440px;display:flex;align-items:flex-end;border-radius:4px;overflow:hidden;color:#fff;background:linear-gradient(135deg,#2b4034,#16201a)}
.track img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.4s ease}
.track:hover img{transform:scale(1.06)}
.track::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,22,18,.15),rgba(15,22,18,.85))}
.track .t-body{position:relative;z-index:2;padding:38px 36px}
.track h3{color:#fff;font-size:1.9rem;margin-bottom:.2em}
.track p{color:#e4ddcf;margin-bottom:16px;max-width:38ch}
@media(max-width:760px){.tracks{grid-template-columns:1fr}}

/* --- Stat strip variant on dark image --- */
.bigclaim{position:relative;color:#fff;text-align:center;background:var(--forest-2)}
.bigclaim::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,24,19,.7),rgba(14,20,16,.88));z-index:0}
.bigclaim .wrap{position:relative;z-index:2;max-width:820px}
.bigclaim h2{color:#fff;font-size:clamp(2.2rem,5vw,3.8rem)}
.bigclaim .lede{color:#e4ddcf;margin-inline:auto}

/* --- interim photo note --- */
.imgsrc-note{font-size:.72rem;color:var(--muted);text-align:center;font-style:italic;padding:10px 0 0}

/* --- Blog post article --- */
.postwrap{max-width:800px;margin:0 auto}
.post{font-size:1.06rem}
.post h2{font-size:clamp(1.7rem,3vw,2.4rem);margin:1.7em 0 .4em}
.post h3{font-size:1.28rem;margin:1.5em 0 .3em;color:var(--moss);font-family:'Cormorant Garamond',serif}
.post p{margin:0 0 1.15rem;color:#33392e}
.post ul{margin:0 0 1.2rem;padding-left:1.2em}
.post li{margin:.35em 0;color:#33392e}
.post strong{color:var(--forest)}
.postmeta{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bronze);margin-bottom:10px}
.post-cta{background:var(--ivory);border:1px solid var(--line);border-radius:4px;padding:30px 32px;margin:36px 0 0;text-align:center}
.post-cta h3{color:var(--forest);margin-bottom:.3em}
.relatedlist{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:14px}
.relatedlist a{display:block;border:1px solid var(--line);border-radius:4px;padding:18px 20px;color:var(--forest);font-family:'Cormorant Garamond',serif;font-size:1.12rem;background:var(--paper);transition:.25s}
.relatedlist a:hover{border-color:var(--bronze-lt);background:#fff}
@media(max-width:760px){.relatedlist{grid-template-columns:1fr}}

/* --- Cost calculator + resources --- */
.calc{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,4vw,48px);align-items:start}
@media(max-width:900px){.calc{grid-template-columns:1fr}}
.calc-form{background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:clamp(22px,3vw,34px)}
.calc-form .fld{margin-bottom:20px}
.calc-form label{display:block;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-weight:500}
.seg{display:flex;flex-wrap:wrap;gap:8px}
.seg button{flex:1;min-width:84px;border:1px solid var(--line);background:#fff;color:var(--forest);padding:11px 10px;border-radius:3px;font-family:'Jost',sans-serif;font-size:.86rem;cursor:pointer;transition:.2s;font-weight:400}
.seg button.on{background:var(--forest);color:#fff;border-color:var(--forest)}
.seg button .s{display:block;font-size:.68rem;color:var(--muted)}
.seg button.on .s{color:var(--gold)}
.opts{display:grid;grid-template-columns:1fr 1fr;gap:8px}
@media(max-width:520px){.opts{grid-template-columns:1fr}}
.optchk{display:flex;align-items:center;gap:9px;border:1px solid var(--line);background:#fff;border-radius:3px;padding:11px 13px;cursor:pointer;font-size:.9rem;color:var(--ink);transition:.2s}
.optchk.on{border-color:var(--bronze);background:#fffdf8}
.optchk input{accent-color:var(--bronze);width:16px;height:16px}
.optchk .p{margin-left:auto;color:var(--muted);font-size:.8rem}
.calc-out{position:sticky;top:96px;background:var(--forest);color:#fff;border-radius:6px;padding:clamp(24px,3vw,36px);text-align:center}
.calc-out .lab{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.calc-out .big{font-family:'Cormorant Garamond',serif;font-size:clamp(2.4rem,6vw,3.6rem);color:#fff;line-height:1.05;margin:8px 0 2px}
.calc-out .sub{color:#cdd4c8;font-size:.92rem}
.calc-out .mo{margin:20px 0;padding:16px 0;border-top:1px solid rgba(255,255,255,.16);border-bottom:1px solid rgba(255,255,255,.16)}
.calc-out .mo b{color:var(--gold);font-family:'Cormorant Garamond',serif;font-size:1.9rem}
.calc-out .disc{font-size:.74rem;color:#9aa896;margin-top:14px;line-height:1.5}
.calc-out .btn{width:100%;margin-top:6px}
.dl-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media(max-width:760px){.dl-grid{grid-template-columns:1fr}}
.dl-card{display:flex;gap:16px;align-items:flex-start;border:1px solid var(--line);background:var(--paper);border-radius:5px;padding:22px 24px;transition:.25s}
.dl-card:hover{border-color:var(--bronze-lt);box-shadow:0 14px 34px rgba(27,42,34,.1)}
.dl-card .ic{flex:none;width:42px;height:42px;border-radius:4px;background:var(--forest);color:var(--gold);display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:1.2rem}
.dl-card h3{font-size:1.18rem;margin-bottom:.2em}
.dl-card p{color:var(--muted);font-size:.9rem;margin:0 0 10px}
.dl-card a{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bronze);font-weight:500}
a.dl-card{text-decoration:none;color:inherit}
a.dl-card h3{color:var(--forest)}
.dl-go{display:inline-block;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bronze);font-weight:500}
a.dl-card:hover .dl-go{color:var(--forest)}
.dl-subhead{font-family:'Cormorant Garamond',serif;font-size:1.55rem;color:var(--forest);font-weight:600;margin:36px 0 14px;text-align:center}
.dl-subhead:first-of-type{margin-top:6px}

/* Map removed (Jun 2026) — single, centered contact column */
.contact .wrap{grid-template-columns:1fr;max-width:720px;margin-inline:auto}
.map-box{display:none !important}
.cform input[type=checkbox]{width:auto !important;flex:none;margin-top:3px}

/* Footer social — contain like .wrap so it lines up under the brand */
.social{max-width:var(--maxw);margin:14px auto 4px;padding:0 28px}
/* Upbeat download icons */
.dl-card .ic{background:linear-gradient(135deg,var(--gold),var(--bronze));color:var(--forest)}
.dl-card .ic svg{width:23px;height:23px;display:block}

/* Header logo — match the other sites */
.brand .logo{height:38px;width:auto;display:block}
.brand .brandtag{color:#cdd4c8;font-family:'Jost',sans-serif;font-size:.58rem;letter-spacing:.26em;text-transform:uppercase;font-weight:400;padding-left:12px;margin-left:2px;border-left:1px solid rgba(255,255,255,.28)}
.brand.nologo::before{content:'Wallaby Pools';color:#fff;font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:600}
@media(max-width:480px){.brand .brandtag{display:none}}
