/* Atypical Plumber — Propeller demo build. Reference: tradie/tradie5. */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#0B1A24; --ink-soft:#404B54; --mute:#76828C; --hair:#E6EAEC;
  --paper:#ffffff; --paper-2:#F4F6F7; --paper-3:#EEF2F3;
  --dark:#0B1A24; --dark-2:#0F2531;
  --brand:#0EA5B5; --brand-bright:#51EEF4; --brand-deep:#075A66;
  --radius:18px; --radius-sm:12px; --radius-lg:26px;
  --shadow-soft:0 1px 2px rgba(11,26,36,.04),0 12px 30px -16px rgba(11,26,36,.18);
  --shadow-card:0 1px 2px rgba(11,26,36,.05),0 22px 48px -22px rgba(11,26,36,.22);
  --maxw:1200px;
  --f:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --f-mono:"SF Mono",ui-monospace,"Roboto Mono",Menlo,monospace;
}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--f);background:var(--paper);color:var(--ink-soft);
  line-height:1.6;font-size:16.5px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{color:var(--ink);line-height:1.12;font-weight:800;letter-spacing:-0.025em}
h1{font-size:clamp(2.5rem,6vw,4.6rem)}
h2{font-size:clamp(2rem,4vw,3.15rem)}
h3{font-size:clamp(1.25rem,2vw,1.6rem);letter-spacing:-0.02em}
p{margin:0}
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:104px 0}
.section-sm{padding:72px 0}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--brand-deep)}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--brand);border-radius:2px}
.lead{font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--ink-soft);line-height:1.62}
.thin{font-weight:300;color:var(--mute)}
.center{text-align:center}

/* ===== buttons ===== */
.btn{display:inline-flex;align-items:center;gap:11px;font-weight:700;font-size:15px;
  letter-spacing:-0.01em;border-radius:999px;padding:15px 26px;cursor:pointer;border:1.5px solid transparent;
  transition:transform .25s,background .25s,color .25s,border-color .25s,box-shadow .25s;white-space:nowrap}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:#04323f;transform:translateY(-2px);box-shadow:0 16px 32px -14px rgba(11,26,36,.5)}
.btn-brand{background:var(--brand);color:#04222a}
.btn-brand:hover{background:var(--brand-bright);transform:translateY(-2px);box-shadow:0 16px 34px -14px rgba(14,165,181,.6)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--hair)}
.btn-ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{background:var(--brand-bright);transform:translateY(-2px)}
.btn-arrow{width:34px;height:34px;border-radius:999px;background:var(--brand);
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .25s,background .25s}
.btn-arrow svg{width:15px;height:15px;stroke:#04222a;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.btn:hover .btn-arrow{transform:rotate(-45deg);background:var(--brand-bright)}
.btn-primary .btn-arrow{background:var(--brand)}

/* ===== nav (G20 glass pill, G17 hamburger mobile-only) ===== */
.nav-wrap{position:fixed;top:0;left:0;right:0;z-index:120;display:flex;justify-content:center;
  padding:18px 20px;transition:padding .3s}
.nav-pill{display:inline-flex;align-items:center;gap:30px;width:fit-content;margin:0 auto;
  background:rgba(255,255,255,.82);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.5);box-shadow:0 10px 34px -16px rgba(11,26,36,.45);
  border-radius:999px;padding:9px 9px 9px 22px;transition:background .3s,box-shadow .3s}
.nav-scrolled .nav-pill{background:rgba(255,255,255,.95);box-shadow:0 12px 30px -14px rgba(11,26,36,.32)}
.nav-logo{display:flex;align-items:center;flex-shrink:0}
.nav-logo img{height:30px;width:auto}
.nav-links{display:flex;gap:24px;margin:0}
.nav-links a{font-size:14.5px;font-weight:600;color:var(--ink);letter-spacing:-0.01em;
  padding:6px 2px;position:relative;transition:color .2s}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;
  background:var(--brand);border-radius:2px;transition:right .25s}
.nav-links a:hover{color:var(--brand-deep)}
.nav-links a:hover::after,.nav-links a.active::after{right:0}
.nav-cta{display:flex;align-items:center;gap:6px}
.nav-cta .btn{padding:11px 20px;font-size:14px}
.mobile-menu-toggle{display:none;width:44px;height:44px;border-radius:999px;border:none;
  background:var(--ink);cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:4.5px}
.mobile-menu-toggle span{width:18px;height:2px;background:#fff;border-radius:2px;transition:transform .3s,opacity .2s}
.mobile-panel{display:none}

@media (max-width:1023px){
  .nav-links,.nav-cta{display:none}
  .mobile-menu-toggle{display:flex}
  .nav-pill{width:100%;justify-content:space-between;padding:9px 9px 9px 20px;border-radius:22px}
  .mobile-panel{display:block;position:fixed;inset:0;z-index:115;background:rgba(11,26,36,.55);
    opacity:0;pointer-events:none;transition:opacity .3s}
  .mobile-panel.open{opacity:1;pointer-events:auto}
  .mobile-sheet{position:absolute;top:0;right:0;bottom:0;width:min(340px,86vw);background:#fff;
    padding:88px 28px 32px;display:flex;flex-direction:column;gap:6px;
    transform:translateX(100%);transition:transform .34s cubic-bezier(.4,0,.2,1);overflow-y:auto}
  .mobile-panel.open .mobile-sheet{transform:translateX(0)}
  .mobile-sheet a.m-link{font-size:1.32rem;font-weight:800;color:var(--ink);padding:13px 0;
    border-bottom:1px solid var(--hair);letter-spacing:-0.02em}
  .mobile-sheet a.m-link:last-of-type{border-bottom:none}
  .m-phone{margin-top:18px;display:flex;flex-direction:column;gap:4px;
    background:var(--paper-2);border-radius:var(--radius-sm);padding:16px 18px}
  .m-phone .lbl{font-size:11.5px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--brand-deep)}
  .m-phone .num{font-size:1.45rem;font-weight:800;color:var(--ink);letter-spacing:-0.02em}
  .m-cta{margin-top:16px;justify-content:center}
}
@media (min-width:1024px){
  .mobile-menu-toggle{display:none !important}
  .mobile-panel{display:none !important}
}

/* ===== hero (G16 full-bleed photo, G32 perf) ===== */
.hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;
  padding:140px 0 64px;overflow:hidden;background:var(--dark)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:50% 42%}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(11,26,36,.62) 0%,rgba(11,26,36,.30) 38%,rgba(11,26,36,.86) 100%)}
.hero-inner{position:relative;z-index:2;width:100%}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:22px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:700;
  color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border-radius:999px;padding:8px 15px;letter-spacing:-0.005em}
.hero-badge svg{width:14px;height:14px;stroke:var(--brand-bright);fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.hero h1{color:#fff;max-width:16ch}
.hero h1 em{font-style:normal;color:var(--brand-bright)}
.hero-sub{color:rgba(255,255,255,.84);font-size:clamp(1.05rem,1.6vw,1.28rem);
  max-width:46ch;margin-top:20px;line-height:1.58}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px;align-items:center}
.hero-trust{display:flex;align-items:center;gap:12px;margin-top:30px;color:#fff}
.hero-stars{color:#FBBC05;font-size:18px;letter-spacing:1px}
.hero-trust .ht-txt{font-size:13.5px;color:rgba(255,255,255,.8)}
.hero-trust .ht-txt strong{color:#fff;font-weight:700}

/* ===== generic page header (non-home) ===== */
.page-head{position:relative;background:var(--dark);padding:152px 0 70px;overflow:hidden}
.page-head::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;
  right:-160px;top:-220px;background:radial-gradient(circle,rgba(81,238,244,.20),transparent 68%)}
.page-head::after{content:"";position:absolute;width:380px;height:380px;border-radius:50%;
  left:-150px;bottom:-220px;background:radial-gradient(circle,rgba(14,165,181,.20),transparent 70%)}
.page-head .container{position:relative;z-index:2}
.page-head .eyebrow{color:var(--brand-bright)}
.page-head .eyebrow::before{background:var(--brand-bright)}
.page-head h1{color:#fff;margin-top:14px;font-size:clamp(2.3rem,4.6vw,3.7rem)}
.page-head p{color:rgba(255,255,255,.8);max-width:54ch;margin-top:16px;font-size:1.08rem}
.crumbs{display:flex;gap:8px;font-size:12.5px;color:rgba(255,255,255,.6);margin-bottom:6px;flex-wrap:wrap}
.crumbs a:hover{color:var(--brand-bright)}
.crumbs span{color:rgba(255,255,255,.4)}

/* ===== section heads ===== */
.section-head{max-width:660px;margin-bottom:54px}
.section-head.center{margin-left:auto;margin-right:auto}
.section-head h2{margin-top:14px}
.section-head p{margin-top:16px}

/* ===== intro / about-strip ===== */
.intro{background:var(--paper)}
.intro-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.intro-copy h2{margin:14px 0 20px}
.intro-copy p+p{margin-top:14px}
.intro-points{display:flex;flex-direction:column;gap:14px;margin-top:26px}
.intro-point{display:flex;gap:13px;align-items:flex-start}
.intro-point .ico{width:38px;height:38px;border-radius:11px;background:var(--paper-3);flex-shrink:0;
  display:flex;align-items:center;justify-content:center}
.intro-point .ico svg{width:19px;height:19px;stroke:var(--brand-deep);fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.intro-point b{color:var(--ink);font-weight:700;display:block;font-size:15.5px}
.intro-point span{font-size:14.5px;color:var(--mute)}
.intro-media{position:relative}
.intro-media img{border-radius:var(--radius-lg);box-shadow:var(--shadow-card);width:100%;
  aspect-ratio:4/5;object-fit:cover}
.intro-badge{position:absolute;left:-26px;bottom:34px;background:#fff;border-radius:var(--radius);
  box-shadow:var(--shadow-card);padding:18px 22px;display:flex;align-items:center;gap:14px}
.intro-badge .big{font-size:2.1rem;font-weight:800;color:var(--ink);letter-spacing:-0.03em;line-height:1}
.intro-badge .lbl{font-size:12.5px;color:var(--mute);font-weight:600;max-width:13ch}

/* ===== services grid ===== */
.svc-section{background:var(--paper-2)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc-card{background:#fff;border:1px solid var(--hair);border-radius:var(--radius);padding:30px 26px;
  display:flex;flex-direction:column;gap:14px;transition:transform .3s,box-shadow .3s,border-color .3s}
.svc-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-card);border-color:transparent}
.svc-ico{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(140deg,#04222a,#0F2531)}
.svc-ico svg{width:24px;height:24px;stroke:var(--brand-bright);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.svc-card h3{margin-top:2px}
.svc-card p{font-size:14.5px;color:var(--mute);line-height:1.58}
.svc-link{margin-top:auto;display:inline-flex;align-items:center;gap:8px;font-size:13.5px;
  font-weight:700;color:var(--brand-deep);letter-spacing:-0.01em}
.svc-link svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;transition:transform .25s}
.svc-card:hover .svc-link svg{transform:translateX(4px)}

/* ===== stats band (photo overlay) ===== */
.stats{position:relative;padding:80px 0;overflow:hidden;background:var(--dark)}
.stats-bg{position:absolute;inset:0;z-index:0}
.stats-bg img{width:100%;height:100%;object-fit:cover}
.stats-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(11,26,36,.93),rgba(11,26,36,.72))}
.stats .container{position:relative;z-index:2}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.stat{text-align:center}
.stat .num{font-size:clamp(2.4rem,4vw,3.3rem);font-weight:800;color:#fff;letter-spacing:-0.04em;line-height:1}
.stat .num em{font-style:normal;color:var(--brand-bright)}
.stat .lbl{margin-top:9px;font-size:13.5px;color:rgba(255,255,255,.72);font-weight:600}

/* ===== process / steps ===== */
.process{background:var(--paper)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.step{background:var(--paper-2);border-radius:var(--radius);padding:30px 26px;position:relative;overflow:hidden}
.step .step-no{font-family:var(--f-mono);font-size:13px;font-weight:700;color:var(--brand-deep);letter-spacing:.05em}
.step h3{margin:14px 0 8px}
.step p{font-size:14.5px;color:var(--mute)}
.step .step-img{margin:-30px -26px 22px;height:170px}
.step .step-img img{width:100%;height:100%;object-fit:cover}

/* ===== why / feature dark band ===== */
.darkband{background:var(--dark);position:relative;overflow:hidden}
.darkband::before{content:"";position:absolute;width:460px;height:460px;border-radius:50%;
  right:-180px;top:-160px;background:radial-gradient(circle,rgba(81,238,244,.16),transparent 70%)}
.darkband .container{position:relative;z-index:2}
.darkband .eyebrow{color:var(--brand-bright)}
.darkband .eyebrow::before{background:var(--brand-bright)}
.darkband h2{color:#fff}
.darkband .lead{color:rgba(255,255,255,.74)}
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);overflow:hidden;margin-top:48px}
.why-cell{background:var(--dark-2);padding:34px 32px;display:flex;flex-direction:column;gap:12px}
.why-cell .wc-ico{width:46px;height:46px;border-radius:12px;background:rgba(81,238,244,.12);
  display:flex;align-items:center;justify-content:center}
.why-cell .wc-ico svg{width:23px;height:23px;stroke:var(--brand-bright);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.why-cell h3{color:#fff}
.why-cell p{font-size:14.5px;color:rgba(255,255,255,.66)}

/* ===== split feature ===== */
.split{background:var(--paper)}
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split-grid.flip .split-media{order:2}
.split-media img{border-radius:var(--radius-lg);box-shadow:var(--shadow-card);width:100%;
  aspect-ratio:5/4;object-fit:cover}
.split-copy h2{margin:14px 0 18px}
.checklist{display:flex;flex-direction:column;gap:13px;margin-top:24px}
.checklist li{display:flex;gap:12px;align-items:flex-start;list-style:none;font-size:15px;color:var(--ink-soft)}
.checklist li svg{width:21px;height:21px;flex-shrink:0;margin-top:1px}
.checklist li svg circle{fill:var(--brand)}
.checklist li svg path{stroke:#04222a;stroke-width:2.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.checklist li b{color:var(--ink);font-weight:700}

/* ===== Google reviews (G4 — template1 design verbatim) ===== */
.reviews{background:var(--paper-2)}
.gr-summary{display:flex;align-items:center;justify-content:space-between;gap:32px;padding:24px 28px;
  background:#fff;border:1px solid var(--hair);border-radius:18px;margin-bottom:40px;flex-wrap:wrap;box-shadow:var(--shadow-soft)}
.gr-sum-left{display:flex;align-items:center;gap:20px}
.gr-logo{width:48px;height:48px;border-radius:999px;background:#f8f9fa;border:1px solid var(--hair);
  display:flex;align-items:center;justify-content:center;flex-shrink:0}
.gr-meta-top{display:flex;align-items:baseline;gap:10px}
.gr-score{font-size:28px;font-weight:700;letter-spacing:-0.03em;color:var(--ink)}
.gr-stars{display:inline-flex;gap:1px;color:#fbbc05;font-size:17px;letter-spacing:-1px}
.gr-sub{font-size:13px;color:var(--mute);margin-top:2px}
.gr-sub strong{color:var(--ink);font-weight:600}
.gr-cta{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:999px;font-size:13px;
  font-weight:600;color:var(--ink);border:1px solid var(--hair);background:#fff;
  transition:background .25s,transform .25s,border-color .25s,color .25s;letter-spacing:-0.005em}
.gr-cta:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:translateY(-1px)}
.gr-cta svg{width:12px;height:12px}
.gr-marquee{position:relative;overflow:hidden;margin:0 -32px 16px;padding:8px 0;min-height:180px;isolation:isolate;contain:layout}
.gr-marquee::before,.gr-marquee::after{content:'';position:absolute;top:0;bottom:0;width:60px;z-index:2;pointer-events:none}
.gr-marquee::before{left:0;background:linear-gradient(90deg,var(--paper-2),transparent)}
.gr-marquee::after{right:0;background:linear-gradient(-90deg,var(--paper-2),transparent)}
.gr-marquee:last-child{margin-bottom:0}
.gr-track{display:flex;gap:20px;width:max-content;will-change:transform}
.gr-card{flex:0 0 360px;background:#fff;border:1px solid var(--hair);border-radius:16px;padding:20px 22px;
  display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-soft);
  transition:transform .3s,box-shadow .3s,border-color .3s}
.gr-card:hover{transform:translateY(-2px);border-color:rgba(11,26,36,.14);
  box-shadow:0 1px 2px rgba(11,26,36,.04),0 18px 40px -14px rgba(11,26,36,.14)}
.gr-card-head{display:flex;align-items:center;gap:12px}
.gr-avatar{width:40px;height:40px;border-radius:999px;color:#fff;font-weight:700;font-size:14px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:-0.015em}
.gr-who{flex:1;min-width:0}
.gr-name{font-size:14px;font-weight:700;letter-spacing:-0.01em;color:var(--ink);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gr-date{font-size:11.5px;color:var(--mute);margin-top:2px;font-family:var(--f-mono);letter-spacing:0}
.gr-local{color:#1a73e8;font-weight:600}
.gr-g-mark{flex-shrink:0}
.gr-stars-row{display:flex;gap:2px}
.gr-s{width:15px;height:15px;fill:#e7e7e7}
.gr-s.on{fill:#fbbc05}
.gr-text{font-size:13.5px;line-height:1.55;color:var(--ink-soft);letter-spacing:-0.005em;
  display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden}

/* ===== CTA band ===== */
.cta-band{position:relative;overflow:hidden;background:var(--dark);padding:96px 0}
.cta-band .cta-bg{position:absolute;inset:0;z-index:0}
.cta-band .cta-bg img{width:100%;height:100%;object-fit:cover}
.cta-band .cta-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(11,26,36,.95),rgba(7,90,102,.82))}
.cta-band .container{position:relative;z-index:2;text-align:center}
.cta-band h2{color:#fff;max-width:18ch;margin:14px auto 0}
.cta-band p{color:rgba(255,255,255,.78);max-width:48ch;margin:16px auto 0}
.cta-band .eyebrow{color:var(--brand-bright);justify-content:center}
.cta-band .eyebrow::before{background:var(--brand-bright)}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:32px}

/* ===== footer ===== */
.site-footer{background:#06141C;color:rgba(255,255,255,.62);padding:74px 0 0}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:44px;padding-bottom:56px}
.foot-brand img{height:34px;margin-bottom:18px}
.foot-brand p{font-size:14px;line-height:1.6;max-width:34ch}
.foot-nap{margin-top:20px;display:flex;flex-direction:column;gap:7px;font-size:13.5px}
.foot-nap a{display:flex;align-items:center;gap:9px;transition:color .2s}
.foot-nap a:hover{color:var(--brand-bright)}
.foot-nap svg{width:15px;height:15px;stroke:var(--brand-bright);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.foot-col h4{color:#fff;font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px;font-weight:700}
.foot-col a{display:block;font-size:14px;padding:5px 0;transition:color .2s}
.foot-col a:hover{color:var(--brand-bright)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding:22px 0;display:flex;
  justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:12.5px}
.footer-credit a{color:var(--brand-bright);font-weight:600}
.foot-licence{font-size:12.5px;color:rgba(255,255,255,.45)}

/* ===== mobile sticky CTA (G8) ===== */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:110;display:none;
  box-shadow:0 -8px 24px -10px rgba(11,26,36,.4)}
.sticky-cta a{flex:1;display:flex;align-items:center;justify-content:center;gap:9px;
  padding:15px 8px;font-weight:800;font-size:15px;letter-spacing:-0.01em}
.sticky-cta .sc-call{background:var(--brand-bright);color:#04222a}
.sticky-cta .sc-msg{background:#0a0a0a;color:#fff}
.sticky-cta svg{width:17px;height:17px;fill:none;stroke-width:2.3;stroke-linecap:round;stroke-linejoin:round}
.sticky-cta .sc-call svg{stroke:#04222a}
.sticky-cta .sc-msg svg{stroke:#fff}
@media (max-width:767px){
  .sticky-cta{display:flex}
  body{padding-bottom:54px}
}

/* ===== contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.contact-info .ci-block{display:flex;gap:15px;padding:22px 0;border-bottom:1px solid var(--hair)}
.contact-info .ci-block:last-child{border-bottom:none}
.contact-info .ci-ico{width:46px;height:46px;border-radius:12px;background:var(--paper-3);flex-shrink:0;
  display:flex;align-items:center;justify-content:center}
.contact-info .ci-ico svg{width:22px;height:22px;stroke:var(--brand-deep);fill:none;stroke-width:2.1;stroke-linecap:round;stroke-linejoin:round}
.contact-info .ci-block b{color:var(--ink);font-weight:700;font-size:15px;display:block;margin-bottom:3px}
.contact-info .ci-block .big{font-size:1.5rem;font-weight:800;color:var(--ink);letter-spacing:-0.02em}
.contact-info .ci-block a.big:hover{color:var(--brand-deep)}
.contact-info .ci-block p{font-size:14.5px;color:var(--mute)}
.form-card{background:#fff;border:1px solid var(--hair);border-radius:var(--radius-lg);
  padding:34px;box-shadow:var(--shadow-card)}
.form-card .fc-tag{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;color:var(--brand-deep);margin-bottom:18px}
.form-card label{display:block;font-size:13px;font-weight:700;color:var(--ink);margin:14px 0 6px}
.form-card input,.form-card textarea{width:100%;border:1.5px solid var(--hair);border-radius:11px;
  padding:13px 15px;font-family:var(--f);font-size:15px;color:var(--ink);background:var(--paper-2);
  transition:border-color .2s,background .2s}
.form-card input:focus,.form-card textarea:focus{outline:none;border-color:var(--brand);background:#fff}
.form-card textarea{min-height:120px;resize:vertical}
.form-card .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-card button{margin-top:20px;width:100%;justify-content:center}
.form-note{font-size:12.5px;color:var(--mute);margin-top:12px;text-align:center}
.form-ok{display:none;text-align:center;padding:38px 20px}
.form-ok .ok-ico{width:62px;height:62px;border-radius:999px;background:var(--brand);margin:0 auto 16px;
  display:flex;align-items:center;justify-content:center}
.form-ok .ok-ico svg{width:30px;height:30px;stroke:#04222a;fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.form-ok h3{margin-bottom:8px}
.form-ok p{color:var(--mute);font-size:14.5px}

/* ===== areas ===== */
.areas{background:var(--paper)}
.area-feature{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:42px}
.area-branch{background:var(--dark);border-radius:var(--radius);padding:26px 24px;color:#fff;position:relative;overflow:hidden}
.area-branch .ab-ico{width:42px;height:42px;border-radius:11px;background:rgba(81,238,244,.14);
  display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.area-branch .ab-ico svg{width:21px;height:21px;stroke:var(--brand-bright);fill:none;stroke-width:2.1;stroke-linecap:round;stroke-linejoin:round}
.area-branch h3{color:#fff;font-size:1.22rem}
.area-branch p{font-size:13.5px;color:rgba(255,255,255,.62);margin-top:5px}
.suburb-card{background:var(--paper-2);border:1px solid var(--hair);border-radius:var(--radius);padding:30px}
.suburb-card h3{margin-bottom:18px}
.suburb-cols{columns:4;column-gap:22px}
.suburb-cols span{display:block;font-size:13.8px;color:var(--ink-soft);padding:5px 0;
  break-inside:avoid;border-bottom:1px solid var(--hair)}
.suburb-cols span::before{content:"▸";color:var(--brand);margin-right:8px;font-size:11px}

/* ===== faq / details ===== */
.faq-wrap{max-width:820px;margin:0 auto}
.faq-group{margin-bottom:46px}
.faq-group>h3{margin-bottom:18px;padding-bottom:12px;border-bottom:2px solid var(--hair)}
details.qa{background:#fff;border:1px solid var(--hair);border-radius:var(--radius-sm);
  margin-bottom:12px;overflow:hidden;transition:border-color .2s,box-shadow .2s}
details.qa[open]{border-color:rgba(14,165,181,.4);box-shadow:var(--shadow-soft)}
details.qa summary{padding:19px 22px;cursor:pointer;font-weight:700;color:var(--ink);font-size:15.5px;
  list-style:none;display:flex;justify-content:space-between;gap:16px;align-items:center}
details.qa summary::-webkit-details-marker{display:none}
details.qa summary .qa-plus{width:24px;height:24px;flex-shrink:0;position:relative}
details.qa summary .qa-plus::before,details.qa summary .qa-plus::after{content:"";position:absolute;
  background:var(--brand-deep);border-radius:2px;transition:transform .25s}
details.qa summary .qa-plus::before{top:11px;left:4px;right:4px;height:2.4px}
details.qa summary .qa-plus::after{left:11px;top:4px;bottom:4px;width:2.4px}
details.qa[open] summary .qa-plus::after{transform:rotate(90deg);opacity:0}
details.qa .qa-body{padding:0 22px 20px;font-size:14.6px;color:var(--ink-soft);line-height:1.62}
.faq-toc{position:sticky;top:100px;display:flex;flex-direction:column;gap:6px}
.faq-toc a{font-size:14px;color:var(--mute);padding:7px 12px;border-radius:9px;font-weight:600;transition:background .2s,color .2s}
.faq-toc a:hover{background:var(--paper-2);color:var(--ink)}

/* ===== article / blog ===== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.blog-card{background:#fff;border:1px solid var(--hair);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s,border-color .3s}
.blog-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-card);border-color:transparent}
.blog-card .bc-img{height:200px;overflow:hidden}
.blog-card .bc-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.blog-card:hover .bc-img img{transform:scale(1.05)}
.blog-card .bc-body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.blog-card .bc-tag{font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--brand-deep)}
.blog-card h3{font-size:1.2rem}
.blog-card p{font-size:14px;color:var(--mute)}
.blog-card .bc-link{margin-top:auto;display:inline-flex;align-items:center;gap:7px;
  font-size:13.5px;font-weight:700;color:var(--ink);padding-top:6px}
.blog-card .bc-link svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;transition:transform .25s}
.blog-card:hover .bc-link svg{transform:translateX(4px)}
.article{max-width:760px;margin:0 auto;padding:0 28px}
.article-hero{margin:34px 0 8px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card)}
.article-hero img{width:100%;aspect-ratio:16/8;object-fit:cover}
.article-body{font-size:16.5px;line-height:1.72;color:var(--ink-soft)}
.article-body h2{font-size:clamp(1.5rem,2.6vw,1.95rem);margin:38px 0 14px}
.article-body h3{font-size:1.25rem;margin:28px 0 10px}
.article-body p{margin:14px 0}
.article-body ul{margin:14px 0;padding-left:4px;list-style:none;display:flex;flex-direction:column;gap:9px}
.article-body ul li{display:flex;gap:11px;align-items:flex-start;font-size:15.5px}
.article-body ul li::before{content:"";width:8px;height:8px;border-radius:3px;background:var(--brand);
  flex-shrink:0;margin-top:9px}
.article-body strong{color:var(--ink)}
.article-tip{background:var(--paper-2);border-left:3px solid var(--brand);border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  padding:18px 22px;margin:20px 0;font-size:15px}
.article-tip b{color:var(--brand-deep)}

/* ===== legal / prose ===== */
.prose{max-width:760px;margin:0 auto}
.prose h2{font-size:1.4rem;margin:32px 0 12px}
.prose p{margin:12px 0;font-size:15.5px;line-height:1.7}
.prose ul{margin:12px 0 12px 22px}
.prose li{margin:6px 0;font-size:15px}

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

/* ===== responsive ===== */
@media (max-width:980px){
  .section{padding:78px 0}
  .intro-grid,.split-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
  .split-grid.flip .split-media{order:0}
  .svc-grid,.steps,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:34px 20px}
  .why-grid{grid-template-columns:1fr}
  .area-feature{grid-template-columns:repeat(2,1fr)}
  .suburb-cols{columns:3}
  .intro-media img{aspect-ratio:3/2}
  .intro-badge{left:auto;right:18px;bottom:-22px}
  .faq-toc{position:static;flex-direction:row;flex-wrap:wrap;margin-bottom:26px}
}
@media (max-width:620px){
  .container{padding:0 20px}
  .section{padding:60px 0}
  .hero{min-height:auto;padding:124px 0 52px}
  .svc-grid,.steps,.blog-grid,.area-feature{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .suburb-cols{columns:2}
  .form-card{padding:24px}
  .hero-actions .btn,.cta-actions .btn{width:100%;justify-content:center}
  .intro-badge{right:14px}
  .article-body h2{font-size:1.4rem}
}
