/* ==========================================================================
   Hunter Tap & Gas Co. - Plumber demo site
   Designed by Steel Cap Digital
   Navy + Copper light mode. Accessibility-first.
   ========================================================================== */

/* Fonts ------------------------------------------------------------------ */
@font-face{font-family:"Big Shoulders Display";font-style:normal;font-weight:700;font-display:swap;src:url("/assets/fonts/big-shoulders-display-latin-700.woff2") format("woff2")}
@font-face{font-family:"Big Shoulders Display";font-style:normal;font-weight:800;font-display:swap;src:url("/assets/fonts/big-shoulders-display-latin-800.woff2") format("woff2")}
@font-face{font-family:"Inter";font-style:normal;font-weight:400;font-display:swap;src:url("/assets/fonts/inter-latin-regular.woff2") format("woff2")}
@font-face{font-family:"Inter";font-style:normal;font-weight:600;font-display:swap;src:url("/assets/fonts/inter-latin-600.woff2") format("woff2")}

/* Design tokens ---------------------------------------------------------- */
:root{
  /* Surfaces */
  --cream: #faf6ef;
  --cream-deep: #f3ecd9;
  --white: #ffffff;
  --card: #ffffff;
  --card-alt: #f5efe2;
  /* Brand */
  --navy: #15263d;
  --navy-dark: #0e1a2d;
  --navy-soft: #1f3658;
  --copper: #b85c3c;
  --copper-hover: #c96e4d;
  --copper-deep: #94462a;
  --copper-soft: #d8a78f;
  --copper-tint: #f7ece4;
  /* Text */
  --text: #2a2a2a;
  --text-soft: #4a4a4a;
  --muted: #6a6a6a;
  --subtle: #8a8a8a;
  /* Lines */
  --border: #e6dfd0;
  --border-strong: #d1c7b3;
  --border-navy: #2a3d59;
  /* Type */
  --font-head: 'Big Shoulders Display', 'Arial Black', sans-serif;
  --font-body: 'Inter', system-ui, sans-serif;
  /* User-controlled scale (accessibility toggle) */
  --user-font-scale: 1;
  /* Layout */
  --max: 1240px;
  --pad: 24px;
}

/* High-contrast mode ----------------------------------------------------- */
body.hc-mode{
  --cream: #ffffff;
  --cream-deep: #ffffff;
  --white: #ffffff;
  --card: #ffffff;
  --card-alt: #ffff00;
  --navy: #000000;
  --navy-dark: #000000;
  --navy-soft: #000000;
  --copper: #000000;
  --copper-hover: #000000;
  --copper-deep: #000000;
  --copper-soft: #000000;
  --copper-tint: #ffff00;
  --text: #000000;
  --text-soft: #000000;
  --muted: #000000;
  --subtle: #000000;
  --border: #000000;
  --border-strong: #000000;
  --border-navy: #000000;
}
body.hc-mode a{text-decoration:underline}
body.hc-mode .btn-primary,body.hc-mode .btn-navy{background:#000;color:#fff;border:2px solid #fff;outline:2px solid #000}
body.hc-mode .copper-bar::before,body.hc-mode .section-label::before,body.hc-mode .eyebrow::before{background:#000}

/* Reset ------------------------------------------------------------------ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--cream);
  color:var(--text);
  font-family:var(--font-body);
  font-size:calc(17px * var(--user-font-scale));
  line-height:1.7;
  padding-top:72px;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5{font-family:var(--font-head);font-weight:800;line-height:1.05;letter-spacing:-.005em;color:var(--navy)}
h3,h4{font-family:var(--font-body);font-weight:600;letter-spacing:0;line-height:1.3}
p{line-height:1.75}
a{text-decoration:none;color:var(--copper)}
a:hover{color:var(--copper-deep)}
img{max-width:100%;height:auto;display:block}
strong{font-weight:600;color:var(--navy)}
button{font-family:inherit}

/* Focus ------------------------------------------------------------------ */
:focus{outline:none}
:focus-visible{outline:3px solid var(--copper);outline-offset:3px;border-radius:2px}
.skip-link:focus-visible{outline-offset:4px}

/* Skip link -------------------------------------------------------------- */
.skip-link{position:absolute;top:-100%;left:0;background:var(--copper);color:#fff;padding:10px 18px;font-size:15px;font-weight:600;z-index:9999;text-decoration:none;border-radius:0 0 4px 0}
.skip-link:focus,.skip-link:focus-visible{top:0;color:#fff}

/* Demo banner (always visible) ------------------------------------------ */
.demo-banner{position:fixed;top:0;left:0;right:0;z-index:300;background:var(--navy-dark);color:#fff;padding:6px 16px;text-align:center;font-size:13px;line-height:1.4;border-bottom:2px solid var(--copper)}
.demo-banner a{color:var(--copper-soft);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.demo-banner a:hover{color:#fff}
.demo-banner strong{color:#fff;font-weight:600}
@media (max-width:600px){.demo-banner{font-size:12px;padding:5px 12px}.demo-banner .demo-banner-long{display:none}}

/* Top nav ---------------------------------------------------------------- */
nav.main-nav{position:fixed;top:32px;left:0;right:0;z-index:200;height:72px;background:var(--white);border-bottom:1px solid var(--border);display:flex;align-items:center;transition:box-shadow .25s}
nav.main-nav.scrolled{box-shadow:0 4px 18px rgba(21,38,61,.08)}
@media (max-width:600px){nav.main-nav{top:28px}}
.nav-inner{width:100%;max-width:var(--max);margin:0 auto;padding:0 var(--pad);display:flex;align-items:center;justify-content:space-between;gap:18px}
.nav-brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.nav-brand-mark{width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--navy);border-radius:6px;flex-shrink:0}
.nav-brand-mark svg{width:24px;height:24px;fill:var(--copper)}
.nav-brand-text{font-family:var(--font-head);font-weight:800;font-size:20px;color:var(--navy);letter-spacing:.01em;line-height:1;text-transform:uppercase}
.nav-brand-text .amp{color:var(--copper)}
.nav-brand-text small{display:block;font-size:10px;font-weight:600;letter-spacing:.18em;color:var(--muted);margin-top:3px;font-family:var(--font-body)}

.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{font-size:14px;font-weight:500;color:var(--text);padding:10px 14px;min-height:44px;display:inline-flex;align-items:center;border-radius:4px;transition:color .15s,background .15s}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--navy);background:var(--copper-tint)}
.nav-links a.nav-cta{background:var(--copper);color:#fff;font-weight:600;padding:11px 20px;margin-left:8px;letter-spacing:.02em}
.nav-links a.nav-cta:hover{background:var(--copper-hover);color:#fff}

.nav-dropdown{position:relative}
.nav-dd-btn{background:0;border:0;cursor:pointer;padding:8px;min-height:44px;min-width:32px;font-size:10px;color:var(--muted);transition:transform .2s,color .15s;display:inline-flex;align-items:center}
.nav-dd-btn:hover,.nav-dropdown.open .nav-dd-btn{color:var(--copper)}
.nav-dropdown.open .nav-dd-btn{transform:rotate(180deg)}
.nav-dd-menu{display:none;position:absolute;top:calc(100% + 8px);left:-8px;background:#fff;border:1px solid var(--border);border-top:3px solid var(--copper);min-width:230px;z-index:300;box-shadow:0 12px 28px rgba(21,38,61,.12);padding:6px}
.nav-dropdown.open .nav-dd-menu{display:block}
.nav-dd-menu a{display:block;padding:10px 14px;font-size:14px;color:var(--text);border-radius:4px;transition:background .15s}
.nav-dd-menu a:hover{background:var(--copper-tint);color:var(--navy)}

/* Hamburger / mobile menu */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;width:44px;height:44px;align-items:center;justify-content:center;background:0;border:0}
.hamburger span{display:block;width:24px;height:2px;background:var(--navy);transition:all .25s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;position:fixed;top:calc(72px + 32px);left:0;right:0;bottom:0;background:#fff;z-index:199;padding:16px 20px 32px;overflow-y:auto;border-top:1px solid var(--border)}
.mobile-menu.open{display:flex;flex-direction:column;gap:2px}
.mobile-menu a{font-size:17px;font-weight:500;color:var(--text);padding:14px 14px;display:block;border-bottom:1px solid var(--border);text-decoration:none;min-height:48px}
.mobile-menu a.mob-sub{padding-left:30px;font-size:15px;color:var(--muted)}
.mobile-menu a:hover{color:var(--navy);background:var(--copper-tint)}
.mobile-menu .mob-cta{background:var(--copper);color:#fff;font-weight:600;text-align:center;margin-top:16px;border-radius:6px;border-bottom:0;letter-spacing:.02em}
.mobile-menu .mob-cta:hover{background:var(--copper-hover);color:#fff}

@media (max-width:1000px){
  .nav-links{display:none}
  .hamburger{display:flex}
  body{padding-top:96px}
  nav.main-nav{height:64px;top:28px}
  .mobile-menu{top:calc(64px + 28px)}
}
@media (max-width:600px){body{padding-top:88px}}

/* Accessibility toolbar -------------------------------------------------- */
.a11y-toolbar{position:fixed;top:32px;right:0;z-index:201;display:none}
.a11y-trigger{position:fixed;top:calc(32px + 78px);right:16px;z-index:198;background:var(--navy);color:#fff;border:0;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(21,38,61,.25);cursor:pointer}
.a11y-trigger:hover{background:var(--copper)}
.a11y-trigger svg{width:24px;height:24px;fill:#fff}
.a11y-panel{position:fixed;top:calc(32px + 130px);right:16px;z-index:198;background:#fff;border:1px solid var(--border);border-top:3px solid var(--copper);box-shadow:0 12px 30px rgba(21,38,61,.18);padding:20px;width:280px;display:none;border-radius:6px}
.a11y-panel.open{display:block}
.a11y-panel h2{font-size:16px;font-family:var(--font-body);font-weight:600;color:var(--navy);text-transform:none;letter-spacing:0;margin-bottom:14px}
.a11y-group{margin-bottom:16px}
.a11y-group:last-child{margin-bottom:0}
.a11y-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;display:block}
.a11y-btns{display:flex;gap:6px}
.a11y-btn{flex:1;background:#fff;border:1px solid var(--border-strong);color:var(--text);padding:9px 8px;font-size:13px;cursor:pointer;border-radius:4px;font-weight:500;min-height:40px;transition:all .15s}
.a11y-btn:hover{border-color:var(--copper);color:var(--copper)}
.a11y-btn[aria-pressed="true"]{background:var(--navy);color:#fff;border-color:var(--navy)}
.a11y-btn.size-1{font-size:13px}
.a11y-btn.size-2{font-size:15px}
.a11y-btn.size-3{font-size:17px;font-weight:600}
.a11y-close{position:absolute;top:6px;right:6px;background:0;border:0;width:32px;height:32px;cursor:pointer;color:var(--muted);font-size:18px;display:flex;align-items:center;justify-content:center}
.a11y-close:hover{color:var(--navy)}
@media (max-width:600px){.a11y-trigger{top:auto;bottom:80px;right:12px;width:44px;height:44px}.a11y-panel{top:auto;bottom:140px;right:12px;width:calc(100% - 24px);max-width:300px}}

/* Plain English mode swaps */
.pe-plain{display:none}
body.pe-mode .pe-tech{display:none}
body.pe-mode .pe-plain{display:inline}

/* Buttons ---------------------------------------------------------------- */
.btn-primary,.btn-navy,.btn-outline,.btn-white{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-body);font-size:16px;font-weight:600;letter-spacing:.01em;padding:13px 24px;min-height:48px;border:0;cursor:pointer;border-radius:6px;transition:all .15s;text-align:center;line-height:1.2;text-decoration:none}
.btn-primary{background:var(--copper);color:#fff;box-shadow:0 4px 12px rgba(184,92,60,.25)}
.btn-primary:hover{background:var(--copper-hover);color:#fff;transform:translateY(-1px);box-shadow:0 6px 16px rgba(184,92,60,.35)}
.btn-primary:active{transform:translateY(0)}
.btn-navy{background:var(--navy);color:#fff;box-shadow:0 4px 12px rgba(21,38,61,.18)}
.btn-navy:hover{background:var(--navy-soft);color:#fff;transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--navy);border:2px solid var(--navy);padding:11px 22px}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-outline.on-dark{color:#fff;border-color:#fff}
.btn-outline.on-dark:hover{background:#fff;color:var(--navy)}
.btn-white{background:#fff;color:var(--navy);box-shadow:0 4px 12px rgba(0,0,0,.12)}
.btn-white:hover{background:var(--cream-deep);color:var(--navy);transform:translateY(-1px)}
.btn-block{width:100%}

/* Sticky call CTA (mobile) ---------------------------------------------- */
.sticky-call{display:none;position:fixed;bottom:0;left:0;right:0;z-index:300;background:var(--navy);border-top:3px solid var(--copper);padding:10px 16px calc(10px + env(safe-area-inset-bottom));align-items:center;justify-content:space-between;gap:10px}
.sticky-call-text{color:#fff;font-size:13px;line-height:1.3}
.sticky-call-text strong{color:#fff;font-weight:600;display:block;font-size:14px}
.sticky-call-text span{color:var(--copper-soft);font-size:11px}
.sticky-call .btn-primary{padding:11px 18px;font-size:15px}
@media (max-width:1000px){.sticky-call{display:flex}body{padding-bottom:68px}}

/* Sections --------------------------------------------------------------- */
.section{padding:80px 24px}
.section-inner{max-width:var(--max);margin:0 auto}
.section.alt{background:var(--card-alt)}
.section.navy{background:var(--navy);color:#fff}
.section.navy h1,.section.navy h2,.section.navy h3{color:#fff}
.section.navy .section-label{color:var(--copper-soft)}
.section.navy p{color:rgba(255,255,255,.85)}
.section.deep{background:var(--cream-deep)}
.section.tight{padding:56px 24px}

.section-label,.eyebrow{font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--copper);margin-bottom:14px;display:flex;align-items:center;gap:12px}
.section-label::before,.eyebrow::before{content:'';width:28px;height:3px;background:var(--copper);flex-shrink:0}
.section.navy .section-label::before,.section.navy .eyebrow::before{background:var(--copper-soft)}

.section-title{font-size:clamp(32px,5vw,52px);text-transform:uppercase;color:var(--navy);margin-bottom:14px;line-height:1.05}
.section.navy .section-title{color:#fff}
.section-sub{font-size:18px;color:var(--muted);max-width:620px;line-height:1.7;margin-bottom:0}
.section.navy .section-sub{color:rgba(255,255,255,.8)}

.copper-bar{position:relative;padding-top:6px;display:inline-block}
.copper-bar::before{content:'';position:absolute;top:0;left:0;width:48px;height:4px;background:var(--copper)}

/* Page hero -------------------------------------------------------------- */
.page-hero{background:var(--cream-deep);padding:72px 24px 56px;border-bottom:1px solid var(--border)}
.page-hero-inner{max-width:var(--max);margin:0 auto}
.page-hero .eyebrow{margin-bottom:18px}
.page-hero h1{font-size:clamp(36px,6vw,64px);text-transform:uppercase;color:var(--navy);margin-bottom:16px;max-width:880px}
.page-hero p.lede{font-size:19px;color:var(--text-soft);max-width:640px;line-height:1.65;margin-bottom:0}

/* Home hero -------------------------------------------------------------- */
.home-hero{position:relative;background:var(--navy);color:#fff;overflow:hidden;padding:96px 24px 88px;border-bottom:6px solid var(--copper)}
.home-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 80% 30%,rgba(184,92,60,.18) 0%,transparent 55%),radial-gradient(circle at 20% 70%,rgba(184,92,60,.08) 0%,transparent 45%);pointer-events:none}
.home-hero-inner{max-width:var(--max);margin:0 auto;position:relative;z-index:1;display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:center}
.home-hero .eyebrow{color:var(--copper-soft);margin-bottom:22px}
.home-hero .eyebrow::before{background:var(--copper-soft)}
.home-hero h1{font-size:clamp(44px,7.5vw,84px);text-transform:uppercase;color:#fff;line-height:.95;margin-bottom:22px;letter-spacing:-.01em}
.home-hero h1 em{font-style:normal;color:var(--copper-soft)}
.home-hero p.lede{font-size:19px;color:rgba(255,255,255,.85);max-width:520px;line-height:1.65;margin-bottom:30px}
.home-hero .hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:32px}
.home-hero-trust{display:flex;flex-wrap:wrap;gap:10px 24px;font-size:14px;color:rgba(255,255,255,.75)}
.home-hero-trust span{display:flex;align-items:center;gap:8px}
.home-hero-trust span::before{content:'';width:8px;height:8px;background:var(--copper-soft);border-radius:50%;display:inline-block;flex-shrink:0}
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;min-height:380px}
.hero-photo-frame{position:relative;width:100%;max-width:440px;aspect-ratio:4/5;background:var(--cream-deep);border:3px solid var(--copper);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;text-align:center;box-shadow:0 12px 40px rgba(0,0,0,.3)}
.hero-photo-frame .ph-icon{width:56px;height:56px;color:var(--copper);margin-bottom:16px;opacity:.5}
.hero-photo-frame .ph-icon svg{width:100%;height:100%}
.hero-photo-frame .ph-title{font-family:var(--font-head);font-size:18px;font-weight:800;color:var(--navy);text-transform:uppercase;margin-bottom:6px;letter-spacing:.04em}
.hero-photo-frame .ph-note{font-size:13px;color:var(--muted);line-height:1.55;max-width:280px}
.hero-photo-tag{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--copper);color:#fff;padding:5px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;border-radius:3px}
@media (max-width:900px){
  .home-hero{padding:64px 24px 56px}
  .home-hero-inner{grid-template-columns:1fr;gap:48px}
  .hero-visual{min-height:auto;justify-content:flex-start}
}
@media (max-width:600px){
  .home-hero{padding:48px 20px 48px}
  .home-hero h1{font-size:clamp(36px,9vw,56px)}
  .hero-photo-frame{max-width:100%;aspect-ratio:16/10;padding:24px}
}

/* Trust bar ------------------------------------------------------------- */
.trust-strip{background:#fff;border-bottom:1px solid var(--border);padding:20px 24px}
.trust-strip-inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text-soft);font-weight:500}
.trust-item svg{width:20px;height:20px;color:var(--copper);flex-shrink:0}
.trust-item strong{color:var(--navy)}

/* Generic two-col split -------------------------------------------------- */
.split{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center}
.split.equal{grid-template-columns:1fr 1fr}
.split.flip{direction:rtl}
.split.flip>*{direction:ltr}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:40px}.split.flip{direction:ltr}}

.body-lede{font-size:19px;color:var(--text);line-height:1.7;margin-bottom:18px}
.body-text{font-size:17px;color:var(--text-soft);line-height:1.75;margin-bottom:16px}
.body-text:last-child{margin-bottom:0}

/* Cards ------------------------------------------------------------------ */
.card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:28px;transition:border-color .2s,box-shadow .2s,transform .2s;display:flex;flex-direction:column}
.card:hover{border-color:var(--copper-soft);box-shadow:0 8px 24px rgba(21,38,61,.08);transform:translateY(-2px)}
.card .card-icon{width:48px;height:48px;background:var(--copper-tint);color:var(--copper);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;flex-shrink:0}
.card .card-icon svg{width:24px;height:24px}
.card h3{font-family:var(--font-head);font-size:22px;font-weight:800;text-transform:uppercase;color:var(--navy);margin-bottom:8px;line-height:1.1;letter-spacing:.01em}
.card p{font-size:15px;color:var(--muted);line-height:1.65;margin-bottom:14px}
.card .card-link{color:var(--copper);font-weight:600;font-size:14px;margin-top:auto;display:inline-flex;align-items:center;gap:6px}
.card .card-link::after{content:'→';transition:transform .2s;display:inline-block}
.card:hover .card-link::after{transform:translateX(3px)}

.card-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:44px}
.card-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:44px}
.card-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:44px}
@media (max-width:900px){.card-grid-3,.card-grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.card-grid-3,.card-grid-4,.card-grid-2{grid-template-columns:1fr}}

/* Service card variant (with featured) */
.svc-card{position:relative}
.svc-card.featured{border-color:var(--copper);background:linear-gradient(180deg,#fff 0%,var(--copper-tint) 100%)}
.svc-card.featured::before{content:'24/7';position:absolute;top:-1px;right:18px;background:var(--copper);color:#fff;padding:5px 12px;font-size:11px;font-weight:700;letter-spacing:.12em;border-radius:0 0 4px 4px}

/* Honest pricing strip --------------------------------------------------- */
.pricing-strip{background:var(--navy);color:#fff;padding:64px 24px;border-top:6px solid var(--copper)}
.pricing-strip-inner{max-width:var(--max);margin:0 auto}
.pricing-strip .eyebrow{color:var(--copper-soft);justify-content:center}
.pricing-strip .eyebrow::before{background:var(--copper-soft)}
.pricing-strip-head{text-align:center;margin-bottom:40px}
.pricing-strip h2{color:#fff;text-transform:uppercase;font-size:clamp(28px,4vw,42px);margin-bottom:12px}
.pricing-strip h2 em{font-style:normal;color:var(--copper-soft)}
.pricing-strip-sub{font-size:17px;color:rgba(255,255,255,.75);max-width:580px;margin:0 auto;line-height:1.6}
.pricing-rows{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:8px;overflow:hidden}
.pricing-row{background:var(--navy);padding:22px 24px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.pricing-row-name{font-size:16px;color:#fff;font-weight:500}
.pricing-row-name small{display:block;font-size:13px;color:rgba(255,255,255,.6);margin-top:3px;font-weight:400}
.pricing-row-cost{font-family:var(--font-head);font-size:22px;font-weight:800;color:var(--copper-soft);white-space:nowrap;letter-spacing:.01em}
.pricing-strip-footnote{margin-top:24px;text-align:center;font-size:14px;color:rgba(255,255,255,.65);line-height:1.6}
@media (max-width:700px){.pricing-rows{grid-template-columns:1fr}}

/* Process flow (numbered) ----------------------------------------------- */
.process-flow{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:44px;counter-reset:proc}
.proc-step{background:#fff;border:1px solid var(--border);border-radius:8px;padding:28px 24px;position:relative;border-top:4px solid var(--copper)}
.proc-step::before{counter-increment:proc;content:counter(proc,decimal-leading-zero);font-family:var(--font-head);font-size:48px;font-weight:800;color:var(--copper);line-height:1;display:block;margin-bottom:14px;letter-spacing:-.02em}
.proc-step h3{font-family:var(--font-head);font-size:20px;font-weight:800;text-transform:uppercase;color:var(--navy);margin-bottom:8px;letter-spacing:.02em}
.proc-step p{font-size:14px;color:var(--muted);line-height:1.6}
@media (max-width:900px){.process-flow{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.process-flow{grid-template-columns:1fr}}

/* Areas served (suburb grid) -------------------------------------------- */
.area-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:36px}
.area-tile{background:#fff;border:1px solid var(--border);border-radius:6px;padding:18px 16px;text-align:center;font-size:15px;color:var(--text);font-weight:500;transition:all .15s;text-decoration:none}
.area-tile:hover{background:var(--copper);color:#fff;border-color:var(--copper);transform:translateY(-2px);box-shadow:0 6px 16px rgba(184,92,60,.2)}
.area-tile small{display:block;font-size:11px;color:var(--muted);font-weight:400;letter-spacing:.04em;margin-top:3px}
.area-tile:hover small{color:rgba(255,255,255,.8)}
@media (max-width:900px){.area-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:600px){.area-grid{grid-template-columns:repeat(2,1fr)}}

/* Callout box ------------------------------------------------------------ */
.callout{background:#fff;border:1px solid var(--border);border-left:4px solid var(--copper);padding:22px 26px;border-radius:0 6px 6px 0;margin:24px 0;font-size:15px;color:var(--text-soft);line-height:1.7}
.callout strong.callout-title{display:block;color:var(--navy);font-weight:600;margin-bottom:6px;font-size:16px}
.callout.navy{background:var(--navy);color:#fff;border:0;border-left:4px solid var(--copper)}
.callout.navy strong.callout-title{color:#fff}
.callout.navy p{color:rgba(255,255,255,.85)}

/* FAQ -------------------------------------------------------------------- */
.faq-list{max-width:780px;margin:36px auto 0;display:flex;flex-direction:column;gap:2px}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:6px;overflow:hidden}
.faq-item:has(.faq-q[aria-expanded="true"]){border-color:var(--copper-soft)}
.faq-q{width:100%;background:0;border:0;padding:20px 22px;text-align:left;font-family:var(--font-body);font-size:16px;font-weight:600;color:var(--navy);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;line-height:1.4;min-height:48px}
.faq-q:hover{color:var(--copper)}
.faq-q[aria-expanded="true"]{color:var(--copper)}
.faq-chev{flex-shrink:0;color:var(--muted);font-size:14px;transition:transform .25s}
.faq-q[aria-expanded="true"] .faq-chev{transform:rotate(180deg);color:var(--copper)}
.faq-a{padding:0 22px 20px;font-size:15px;color:var(--text-soft);line-height:1.7;border-top:1px solid var(--border)}
.faq-a[hidden]{display:none}
.faq-a p{margin-bottom:10px}
.faq-a p:last-child{margin-bottom:0}

/* Forms ------------------------------------------------------------------ */
.form-card{background:#fff;border:1px solid var(--border);border-radius:8px;padding:36px;border-top:4px solid var(--copper);box-shadow:0 4px 16px rgba(21,38,61,.05)}
.form-card h2{font-size:26px;text-transform:uppercase;margin-bottom:6px}
.form-card p.form-sub{font-size:15px;color:var(--muted);margin-bottom:24px;line-height:1.5}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text);letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px}
.form-group label .req{color:var(--copper);margin-left:3px}
.form-group input,.form-group select,.form-group textarea{width:100%;background:#fff;border:1px solid var(--border-strong);padding:12px 14px;font-size:16px;color:var(--text);font-family:var(--font-body);border-radius:4px;transition:border-color .15s;min-height:48px}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--copper);box-shadow:0 0 0 3px rgba(184,92,60,.15)}
.form-group textarea{min-height:120px;resize:vertical}
.form-submit{width:100%;background:var(--copper);color:#fff;border:0;padding:14px;font-size:17px;font-weight:600;border-radius:6px;cursor:pointer;min-height:52px;transition:background .15s,transform .12s;font-family:var(--font-body)}
.form-submit:hover{background:var(--copper-hover);transform:translateY(-1px)}
.form-note{font-size:13px;color:var(--muted);margin-top:14px;line-height:1.55;text-align:center}
@media (max-width:600px){.form-card{padding:24px}.form-row{grid-template-columns:1fr}}

/* Contact methods column ------------------------------------------------- */
.contact-methods{display:flex;flex-direction:column;gap:12px}
.cm-tile{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--border);padding:18px 20px;border-radius:6px;text-decoration:none;color:var(--text);transition:all .15s}
.cm-tile:hover{border-color:var(--copper);transform:translateX(4px);box-shadow:0 4px 12px rgba(21,38,61,.06)}
.cm-icon{width:44px;height:44px;background:var(--copper-tint);color:var(--copper);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cm-icon svg{width:22px;height:22px}
.cm-body strong{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:3px}
.cm-body span{display:block;font-size:17px;color:var(--navy);font-weight:600;line-height:1.3}

/* Hours table */
.hours-table{background:#fff;border:1px solid var(--border);border-radius:6px;padding:20px 24px}
.hours-table h3{font-size:14px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px}
.hours-row{display:flex;justify-content:space-between;padding:8px 0;font-size:15px;border-bottom:1px solid var(--border)}
.hours-row:last-child{border-bottom:0}
.hours-row strong{color:var(--navy);font-weight:500}
.hours-row span{color:var(--text-soft)}
.hours-row.emerg{color:var(--copper);font-weight:600;padding-top:14px;border-top:2px solid var(--copper-tint);margin-top:8px}
.hours-row.emerg strong{color:var(--copper)}

/* Recent jobs / blog list ----------------------------------------------- */
.jobs-list{display:flex;flex-direction:column;gap:14px;margin-top:32px}
.job-row{background:#fff;border:1px solid var(--border);border-radius:6px;padding:22px 26px;display:grid;grid-template-columns:170px 1fr 160px;gap:24px;align-items:center;transition:border-color .2s}
.job-row:hover{border-color:var(--copper-soft)}
.job-meta{font-size:13px;color:var(--muted)}
.job-meta strong{display:block;font-size:14px;color:var(--navy);font-weight:600;margin-bottom:2px;text-transform:uppercase;letter-spacing:.04em}
.job-desc{font-size:15px;color:var(--text);line-height:1.55}
.job-desc strong{color:var(--navy)}
.job-cost{font-family:var(--font-head);font-size:22px;font-weight:800;color:var(--copper);text-align:right;line-height:1.05}
.job-cost small{display:block;font-family:var(--font-body);font-size:11px;color:var(--muted);font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin-top:2px}
@media (max-width:800px){.job-row{grid-template-columns:1fr;gap:10px}.job-cost{text-align:left}}

/* Blog cards ------------------------------------------------------------- */
.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:36px}
.blog-card{background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:all .2s;display:flex;flex-direction:column;text-decoration:none;color:inherit}
.blog-card:hover{border-color:var(--copper);transform:translateY(-2px);box-shadow:0 8px 22px rgba(21,38,61,.08)}
.blog-thumb{aspect-ratio:16/9;background:var(--cream-deep);display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.blog-thumb-inner{text-align:center;color:var(--muted);padding:24px}
.blog-thumb-inner svg{width:48px;height:48px;color:var(--copper);opacity:.6;margin-bottom:8px}
.blog-thumb-inner small{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:600}
.blog-body{padding:22px 24px 24px;display:flex;flex-direction:column;flex:1}
.blog-meta{font-size:12px;color:var(--copper);font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}
.blog-body h3{font-family:var(--font-head);font-size:22px;font-weight:800;text-transform:uppercase;color:var(--navy);margin-bottom:10px;line-height:1.15;letter-spacing:.01em}
.blog-body p{font-size:14px;color:var(--muted);line-height:1.65;margin-bottom:14px;flex:1}
.blog-link{font-size:14px;font-weight:600;color:var(--copper)}
@media (max-width:700px){.blog-grid{grid-template-columns:1fr}}

/* Article (blog post body) ---------------------------------------------- */
.article{max-width:760px;margin:0 auto;padding:64px 24px 32px}
.article-meta{font-size:13px;color:var(--copper);font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px}
.article h1{font-size:clamp(32px,5vw,52px);text-transform:uppercase;line-height:1.05;margin-bottom:18px}
.article-lede{font-size:20px;color:var(--text-soft);line-height:1.6;margin-bottom:32px;font-weight:400}
.article-body{font-size:17px;color:var(--text);line-height:1.8}
.article-body p{margin-bottom:18px}
.article-body h2{font-family:var(--font-head);font-size:28px;text-transform:uppercase;color:var(--navy);margin:36px 0 14px;letter-spacing:.01em}
.article-body h3{font-family:var(--font-body);font-size:20px;font-weight:600;color:var(--navy);margin:28px 0 10px}
.article-body ul,.article-body ol{margin:0 0 18px 24px;line-height:1.85}
.article-body li{margin-bottom:6px}
.article-body strong{color:var(--navy);font-weight:600}
.article-body blockquote{border-left:4px solid var(--copper);padding:6px 20px;margin:24px 0;background:var(--cream-deep);border-radius:0 6px 6px 0;font-style:italic;color:var(--text)}
.article-body a{color:var(--copper);text-decoration:underline;text-underline-offset:2px}
.article-cta{background:var(--navy);color:#fff;padding:28px 28px;border-radius:8px;margin:32px 0;border-top:4px solid var(--copper)}
.article-cta h3{color:#fff;font-family:var(--font-head);font-size:22px;text-transform:uppercase;margin-bottom:8px}
.article-cta p{color:rgba(255,255,255,.8);margin-bottom:16px;font-size:15px}

/* Tool widgets ----------------------------------------------------------- */
.tool-card{background:#fff;border:1px solid var(--border);border-radius:8px;padding:32px;border-top:4px solid var(--copper);box-shadow:0 4px 18px rgba(21,38,61,.06)}
.tool-section{margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.tool-section:last-child{border-bottom:0;padding-bottom:0;margin-bottom:0}
.tool-section h3{font-family:var(--font-head);font-size:20px;font-weight:800;text-transform:uppercase;color:var(--navy);margin-bottom:14px;letter-spacing:.02em}
.tool-result{background:var(--cream-deep);border:2px solid var(--copper);border-radius:8px;padding:28px;margin-top:24px}
.tool-result h3{color:var(--copper);margin-bottom:16px}
.tool-result-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(0,0,0,.06);font-size:15px}
.tool-result-row:last-child{border-bottom:0}
.tool-result-row strong{color:var(--navy);font-weight:600}
.tool-result-row span{color:var(--text);font-weight:600}
.tool-result-row.headline{padding:14px 0;font-size:18px}
.tool-result-row.headline strong{font-family:var(--font-head);font-size:22px;color:var(--copper);text-transform:uppercase}
.tool-result-note{margin-top:20px;font-size:14px;color:var(--text-soft);line-height:1.65;padding:14px 18px;background:#fff;border-left:3px solid var(--copper);border-radius:0 4px 4px 0}

.radio-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px;margin-top:8px}
.radio-tile{position:relative}
.radio-tile input{position:absolute;opacity:0;pointer-events:none}
.radio-tile label{display:flex;align-items:center;justify-content:center;padding:14px 12px;background:#fff;border:2px solid var(--border-strong);border-radius:6px;font-size:15px;font-weight:500;color:var(--text);cursor:pointer;text-align:center;min-height:54px;transition:all .15s}
.radio-tile label:hover{border-color:var(--copper-soft)}
.radio-tile input:checked+label{background:var(--copper);color:#fff;border-color:var(--copper)}
.radio-tile input:focus-visible+label{outline:3px solid var(--copper);outline-offset:3px}
.radio-tile label small{display:block;font-size:11px;font-weight:400;color:var(--muted);margin-top:3px}
.radio-tile input:checked+label small{color:rgba(255,255,255,.8)}

/* Step guide (find-your-stop-tap) --------------------------------------- */
.step-guide{display:flex;flex-direction:column;gap:0}
.guide-step{display:none;padding:8px 0}
.guide-step.active{display:block}
.guide-step h2{font-family:var(--font-head);font-size:28px;text-transform:uppercase;color:var(--navy);margin-bottom:12px;letter-spacing:.01em}
.guide-step .guide-illu{background:var(--cream-deep);border:1px solid var(--border);border-radius:8px;padding:32px;text-align:center;margin:18px 0;color:var(--muted);font-size:14px}
.guide-step .guide-illu svg{width:80px;height:80px;color:var(--copper);margin:0 auto 12px;opacity:.7}
.guide-step p{font-size:17px;color:var(--text);line-height:1.7;margin-bottom:14px}
.guide-step ul{margin:0 0 14px 24px;font-size:16px;line-height:1.8}
.guide-step .step-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.guide-progress{display:flex;gap:6px;margin-bottom:24px}
.guide-progress span{flex:1;height:6px;background:var(--border);border-radius:3px}
.guide-progress span.done{background:var(--copper)}
.guide-progress span.current{background:var(--copper);box-shadow:0 0 0 3px rgba(184,92,60,.2)}

/* Suburb page ----------------------------------------------------------- */
.suburb-fact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:32px}
.suburb-fact{background:#fff;border:1px solid var(--border);border-radius:6px;padding:20px 22px;border-left:3px solid var(--copper)}
.suburb-fact h3{font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.suburb-fact p{font-size:15px;color:var(--text);line-height:1.6;margin:0}
@media (max-width:700px){.suburb-fact-grid{grid-template-columns:1fr}}

/* Footer ---------------------------------------------------------------- */
footer.site-footer{background:var(--navy-dark);color:rgba(255,255,255,.7);padding:56px 24px 32px;border-top:4px solid var(--copper)}
.footer-inner{max-width:var(--max);margin:0 auto}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:40px}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:16px;text-decoration:none}
.footer-brand .nav-brand-mark{width:38px;height:38px}
.footer-brand .nav-brand-text{color:#fff}
.footer-brand .nav-brand-text small{color:rgba(255,255,255,.55)}
.footer-tag{font-size:14px;color:rgba(255,255,255,.7);line-height:1.65;margin-bottom:16px;max-width:320px}
.footer-contact{font-size:14px;color:rgba(255,255,255,.65);line-height:1.85}
.footer-contact a{color:var(--copper-soft);text-decoration:none}
.footer-contact a:hover{color:#fff}
.footer-col h4{font-family:var(--font-head);font-size:14px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col a{font-size:14px;color:rgba(255,255,255,.65);text-decoration:none;transition:color .15s}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:13px}
.footer-bottom span{color:rgba(255,255,255,.55)}
.footer-bottom a{color:rgba(255,255,255,.65);text-decoration:none;margin-right:18px}
.footer-bottom a:hover{color:#fff}
.footer-credit{font-size:13px;color:rgba(255,255,255,.6)}
.footer-credit a{color:var(--copper-soft);font-weight:600}
.footer-credit a:hover{color:#fff;text-decoration:underline}
@media (max-width:900px){.footer-top{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:600px){.footer-top{grid-template-columns:1fr;gap:24px}.footer-bottom{flex-direction:column;align-items:flex-start}}

/* Bottom CTA strip ------------------------------------------------------ */
.cta-strip{background:var(--navy);color:#fff;padding:64px 24px;border-top:4px solid var(--copper);text-align:center;position:relative;overflow:hidden}
.cta-strip::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(184,92,60,.15) 0%,transparent 55%);pointer-events:none}
.cta-strip-inner{max-width:840px;margin:0 auto;position:relative;z-index:1}
.cta-strip h2{font-size:clamp(30px,5vw,48px);text-transform:uppercase;color:#fff;margin-bottom:14px;line-height:1.05}
.cta-strip h2 em{font-style:normal;color:var(--copper-soft)}
.cta-strip p{font-size:18px;color:rgba(255,255,255,.8);margin-bottom:28px;line-height:1.5}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Big lock-up phone -----------------------------------------------------*/
.big-phone{display:inline-flex;align-items:center;gap:14px;background:#fff;color:var(--navy);padding:18px 28px;border-radius:8px;text-decoration:none;border:2px solid var(--copper);transition:all .15s;font-family:var(--font-head);font-size:32px;font-weight:800;letter-spacing:.01em;line-height:1}
.big-phone:hover{background:var(--copper);color:#fff;transform:translateY(-2px);box-shadow:0 8px 20px rgba(184,92,60,.3)}
.big-phone svg{width:28px;height:28px;color:var(--copper);transition:color .15s}
.big-phone:hover svg{color:#fff}

/* Utility ----------------------------------------------------------------*/
.text-center{text-align:center}
.mb-0{margin-bottom:0}
.mt-0{margin-top:0}
.hide-mob{display:initial}
@media (max-width:700px){.hide-mob{display:none}}

/* Print -----------------------------------------------------------------*/
@media print{.demo-banner,nav.main-nav,.sticky-call,.a11y-trigger,.a11y-panel,footer.site-footer{display:none}body{padding-top:0}}

/* Reduced motion --------------------------------------------------------*/
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .card:hover,.cm-tile:hover,.blog-card:hover,.area-tile:hover,.btn-primary:hover,.btn-navy:hover,.big-phone:hover{transform:none}
}
