/* ===== Variables ===== */
:root{
  --navy:#0B2545;
  --navy-deep:#06182F;
  --blue:#2563EB;
  --blue-dark:#1D4ED8;
  --blue-light:#EAF2FF;
  --amber:#F59E0B;
  --amber-dark:#D97706;
  --gray-50:#F8FAFC;
  --gray-100:#F1F5F9;
  --gray-200:#E2E8F0;
  --gray-600:#475569;
  --gray-700:#334155;
  --white:#FFFFFF;
  --green:#16A34A;
  --radius:14px;
  --shadow:0 10px 30px rgba(11,37,69,.08);
  --shadow-lg:0 24px 60px rgba(11,37,69,.18);
  --maxw:1180px;
}

*{box-sizing:border-box;}
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:200;
  background:var(--navy);color:var(--white);padding:10px 16px;border-radius:0 0 8px 0;font-weight:700;
}
.skip-link:focus{left:0;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--gray-700);
  background:var(--white);
  line-height:1.55;
}
h1,h2,h3,h4{
  color:var(--navy);
  line-height:1.2;
  margin:0 0 .5em;
}
p{margin:0 0 1em;}
a{color:var(--blue);text-decoration:none;}
img,svg{display:block;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:13px 22px;
  border-radius:10px;
  font-weight:600;
  font-size:15px;
  border:none;
  cursor:pointer;
  text-decoration:none;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn-primary{background:var(--white);color:var(--navy);border:1.5px solid var(--gray-200);}
.btn-primary:hover{border-color:var(--blue);color:var(--blue);}
.btn-cta{background:var(--amber);color:var(--navy-deep);}
.btn-cta:hover{background:var(--amber-dark);transform:translateY(-1px);box-shadow:var(--shadow);}
.btn-small{padding:9px 16px;font-size:14px;}
.btn-full{width:100%;}
.btn-large{padding:16px 32px;font-size:17px;margin-top:8px;}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:100;
  background:var(--white);
  border-bottom:1px solid var(--gray-100);
  transition:box-shadow .2s ease;
}
.site-header.is-scrolled{box-shadow:var(--shadow);}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;gap:24px;
}
.logo{display:flex;align-items:center;gap:10px;min-height:56px;}
.logo-img{max-height:56px;width:auto;max-width:160px;display:block;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
.logo-mark{
  width:36px;height:36px;border-radius:9px;background:var(--navy);
  color:var(--white);font-weight:800;font-size:18px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.logo-text{
  font-weight:800;color:var(--navy);font-size:17px;line-height:1.1;
  display:flex;flex-direction:column;
}
.logo-text small{font-weight:600;color:var(--gray-600);font-size:11px;letter-spacing:.04em;text-transform:uppercase;}

.primary-nav{display:flex;gap:28px;}
.primary-nav a{color:var(--gray-700);font-weight:600;font-size:15px;}
.primary-nav a:hover{color:var(--blue);}

.header-actions{display:flex;align-items:center;gap:16px;}
.phone-link{display:flex;align-items:center;gap:6px;color:var(--navy);font-weight:700;font-size:15px;}

.nav-toggle{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:36px;height:36px;background:none;border:none;cursor:pointer;padding:0;
}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--navy);border-radius:2px;}

/* ===== Hero ===== */
.hero{
  background:linear-gradient(135deg,var(--navy-deep),var(--navy) 55%,var(--blue-dark));
  padding:72px 0 96px;
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.08) 1.5px, transparent 1.5px);
  background-size:26px 26px;
  opacity:.5;
}
.hero-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:start;
}
.eyebrow{
  display:inline-block;color:#BFD7FF;font-weight:700;font-size:13px;
  letter-spacing:.03em;margin-bottom:18px;
}
.hero h1{color:var(--white);font-size:42px;margin-bottom:18px;}
.hero-sub{color:#D6E4FF;font-size:17px;max-width:520px;}
.hero-points{list-style:none;margin:28px 0 0;padding:0;display:flex;flex-direction:column;gap:12px;}
.hero-points li{display:flex;align-items:center;gap:10px;color:var(--white);font-weight:600;font-size:15px;}
.hero-points svg{color:var(--amber);flex-shrink:0;}

/* Lead card */
.lead-card{
  background:var(--white);border-radius:var(--radius);
  padding:28px;box-shadow:var(--shadow-lg);
}
.lead-card h2{font-size:21px;margin-bottom:2px;}
.lead-card-sub{color:var(--gray-600);font-size:14px;margin-bottom:18px;}
.form-row{margin-bottom:14px;}
.form-row-split{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
label{display:block;font-weight:600;font-size:13.5px;color:var(--navy);margin-bottom:5px;}
.optional{color:var(--gray-600);font-weight:400;}
input,select,textarea{
  width:100%;padding:11px 12px;border:1.5px solid var(--gray-200);
  border-radius:8px;font-size:14.5px;font-family:inherit;color:var(--gray-700);
  background:var(--gray-50);
}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--blue);background:var(--white);
}
textarea{resize:vertical;}
.form-fineprint{font-size:12px;color:var(--gray-600);margin:10px 0 0;text-align:center;}

.form-success{text-align:center;padding:12px 4px;}
.form-success svg{color:var(--green);margin:0 auto 10px;}
.form-success h3{margin-bottom:6px;}
.form-success p{color:var(--gray-600);font-size:14px;}

/* ===== Trust strip ===== */
.trust-strip{background:var(--blue-light);padding:26px 0;}
.trust-grid{display:flex;flex-wrap:wrap;justify-content:space-between;gap:18px;}
.trust-item{display:flex;align-items:center;gap:10px;color:var(--navy);font-weight:700;font-size:14px;flex:1;min-width:200px;}
.trust-item svg{color:var(--blue);flex-shrink:0;}

/* ===== Generic section ===== */
.section{padding:80px 0;}
.section-alt{background:var(--gray-50);}
.section-title{font-size:30px;text-align:center;margin-bottom:8px;}
.section-sub{text-align:center;color:var(--gray-600);max-width:560px;margin:0 auto 44px;}
.section-note{text-align:center;color:var(--gray-600);font-size:13px;margin-top:8px;}
.section-cta{text-align:center;margin-top:40px;}

/* Steps */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.step-card{
  background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);
  padding:30px 26px;position:relative;
}
.step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:10px;background:var(--navy);color:var(--white);
  font-weight:800;font-size:16px;margin-bottom:16px;
}
.step-card h3{font-size:18px;}
.step-card p{color:var(--gray-600);font-size:14.5px;margin:0;}

/* Services */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-bottom:48px;}
.service-card{
  background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);
  padding:30px 26px;
}
.service-icon{
  width:56px;height:56px;border-radius:12px;background:var(--blue-light);color:var(--blue);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;
}
.service-card h3{font-size:18px;}
.service-card p{color:var(--gray-600);font-size:14.5px;}
.card-link{font-weight:700;font-size:14px;}

.brands-label{text-align:center;color:var(--gray-600);font-size:14px;margin-bottom:18px;}
.brands-row{
  display:flex;flex-wrap:wrap;justify-content:center;gap:14px 30px;
  padding-top:32px;border-top:1px solid var(--gray-200);
}
.brands-row span,.brands-row a{color:var(--gray-600);font-weight:700;font-size:14px;letter-spacing:.02em;}
.brands-row a:hover{color:var(--blue);text-decoration:underline;}

/* Stats */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.stat-card{
  text-align:center;background:var(--blue-light);border-radius:var(--radius);padding:30px 16px;
}
.stat-card strong{display:block;font-size:30px;color:var(--navy);margin-bottom:6px;}
.stat-card span{color:var(--gray-600);font-size:13.5px;}

/* Areas */
.areas-inner{display:grid;grid-template-columns:1.2fr 1fr;gap:36px;align-items:start;}
.areas-grid{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:18px;}
.area-pill{
  background:var(--white);border:1.5px solid var(--gray-200);color:var(--navy);
  font-weight:700;font-size:14px;padding:9px 18px;border-radius:999px;
}
.area-pill:hover{border-color:var(--blue);color:var(--blue);}
.areas-note{color:var(--gray-600);font-size:14px;}
.map-embed{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);}
.map-embed iframe{display:block;}

/* Testimonials */
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.testimonial-card{
  background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);
  padding:28px;margin:0;
}
.stars{color:var(--amber);letter-spacing:2px;margin-bottom:12px;}
.testimonial-card blockquote{margin:0 0 14px;font-size:15px;color:var(--gray-700);}
.testimonial-card figcaption{font-weight:700;color:var(--navy);font-size:13.5px;}

/* For techs */
.for-techs{background:var(--navy);padding:72px 0;}
.for-techs-inner{max-width:680px;}
.for-techs h2{color:var(--white);font-size:28px;}
.for-techs p{color:#C7D6EE;}
.check-list{list-style:none;margin:22px 0 26px;padding:0;display:flex;flex-direction:column;gap:12px;}
.check-list li{display:flex;align-items:center;gap:10px;color:var(--white);font-weight:600;font-size:15px;}
.check-list svg{color:var(--amber);flex-shrink:0;}

/* FAQ */
.faq-list{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:12px;}
details{
  background:var(--gray-50);border:1px solid var(--gray-200);border-radius:10px;padding:16px 20px;
}
summary{font-weight:700;color:var(--navy);cursor:pointer;font-size:15.5px;}
details p{color:var(--gray-600);margin:12px 0 0;font-size:14.5px;}

/* Final CTA */
.final-cta{background:var(--blue-light);padding:64px 0;text-align:center;}
.final-cta h2{font-size:26px;margin-bottom:18px;}

/* ===== Footer ===== */
.site-footer{background:var(--navy-deep);color:#A9BCDA;padding:56px 0 0;}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:32px;padding-bottom:40px;}
.footer-grid h3{color:var(--white);font-size:14px;margin-bottom:14px;}
.footer-grid > div{display:flex;flex-direction:column;gap:10px;}
.footer-grid a{color:#A9BCDA;font-size:14px;}
.footer-grid a:hover{color:var(--white);}
.footer-grid p{color:#A9BCDA;font-size:14px;margin:0;}
.footer-logo{margin-bottom:10px;}
.footer-logo .logo-text{color:var(--white);}
.abn em{display:block;color:#7C90B5;font-size:12px;font-style:normal;}
.footer-suburb-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;}
.footer-notice{
  border-top:1px solid rgba(255,255,255,.1);padding:18px 24px;
}
.footer-notice p{color:#7C90B5;font-size:12.5px;margin:0;max-width:900px;}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding:20px 24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  font-size:13px;
}
.footer-bottom a{color:#A9BCDA;}

/* ===== Sticky mobile CTA ===== */
.sticky-cta{display:none;}

/* ===== Breadcrumbs ===== */
.breadcrumb-bar{background:var(--gray-50);border-bottom:1px solid var(--gray-100);padding:10px 0;}
.breadcrumb-bar ol{list-style:none;display:flex;flex-wrap:wrap;gap:6px;margin:0;padding:0;font-size:13px;color:var(--gray-600);}
.breadcrumb-bar li{display:flex;align-items:center;gap:6px;}
.breadcrumb-bar li:not(:last-child)::after{content:"/";color:var(--gray-200);margin-left:6px;}
.breadcrumb-bar a{color:var(--gray-600);}
.breadcrumb-bar a:hover{color:var(--blue);}
.breadcrumb-bar li:last-child{color:var(--navy);font-weight:600;}

/* ===== Long-form content (landing pages) ===== */
.content-prose{max-width:760px;margin:0 auto;}
.content-prose h2{font-size:26px;margin-top:44px;}
.content-prose h3{font-size:19px;margin-top:28px;}
.content-prose p{color:var(--gray-700);font-size:15.5px;}
.content-prose ul{color:var(--gray-700);font-size:15.5px;padding-left:22px;}
.content-prose li{margin-bottom:8px;}
.content-prose .lead-intro{font-size:18px;color:var(--gray-700);}

.notice-box{
  background:var(--gray-50);border-left:4px solid var(--blue);border-radius:8px;
  padding:14px 18px;font-size:13.5px;color:var(--gray-600);margin:18px 0;
}
.fault-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:24px 0;}
.fault-card{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:10px;padding:18px 20px;}
.fault-card h3{color:var(--navy);font-size:15px;margin:0 0 6px;}
.fault-card p{color:var(--gray-600);font-size:14px;margin:0;}

.related-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;}
.related-links a{
  background:var(--blue-light);color:var(--blue-dark);font-weight:700;font-size:13.5px;
  padding:8px 14px;border-radius:999px;
}
.related-links a:hover{background:var(--blue);color:var(--white);}

/* ===== Responsive ===== */
@media (max-width:980px){
  .hero-inner{grid-template-columns:1fr;}
  .steps-grid,.services-grid,.testimonial-grid{grid-template-columns:1fr 1fr;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .areas-inner{grid-template-columns:1fr;}
  .fault-grid{grid-template-columns:1fr;}
}
@media (max-width:760px){
  .primary-nav{
    position:absolute;top:72px;left:0;right:0;background:var(--white);
    flex-direction:column;padding:16px 24px;gap:14px;
    border-bottom:1px solid var(--gray-100);box-shadow:var(--shadow);
    display:none;
  }
  .primary-nav.is-open{display:flex;}
  .nav-toggle{display:flex;}
  .phone-link{display:flex;font-size:13px;gap:4px;white-space:nowrap;}
  .header-actions .btn-small{display:none;}
  .hero h1{font-size:30px;}
  .steps-grid,.services-grid,.testimonial-grid,.stats-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .footer-suburb-grid{grid-template-columns:1fr 1fr;}
  .trust-grid{flex-direction:column;}
  .logo-text{font-size:15px;}

  body{padding-bottom:76px;}
  .sticky-cta{
    display:block;position:fixed;left:0;right:0;bottom:0;z-index:90;
    padding:10px 16px;background:var(--white);
    box-shadow:0 -8px 24px rgba(11,37,69,.15);
    transition:transform .2s ease;
  }
  .sticky-cta.is-hidden{transform:translateY(110%);}
}
