/* ============================================================
   SEO landing-page styles (service + suburb + faq hub pages)
   Adds on top of /assets/css/style.css
   ============================================================ */

.eyebrow-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:14px}

/* Pillars (What we do) — 3-up card row */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin:28px 0 42px}
.pillar{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 22px;box-shadow:var(--shadow-sm);transition:transform .18s var(--ease),box-shadow .18s var(--ease)
}
.pillar:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.pillar .ic{
  width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--blue-bright),var(--blue-deep));color:#fff;margin-bottom:14px
}
.pillar .ic svg{width:22px;height:22px}
.pillar h3{font-size:1.05rem;color:var(--navy);margin-bottom:6px}
.pillar p{color:#4a5a73;font-size:.92rem;line-height:1.55}

/* Split 2-column copy block */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;margin:24px 0 10px}
.split.reverse{direction:rtl}
.split.reverse > *{direction:ltr}
.split-media{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:5/4}
.split-media img{width:100%;height:100%;object-fit:cover}
.split-body h2{font-size:clamp(1.5rem,2.6vw,2.1rem);color:var(--navy);margin-bottom:14px;letter-spacing:-.01em}
.split-body p{color:#4a5a73;line-height:1.7;margin-bottom:12px}
.split-body ul.check{list-style:none;padding:0;margin:14px 0 20px}
.split-body ul.check li{padding-left:30px;position:relative;color:#374151;margin-bottom:9px;font-size:.96rem;line-height:1.55}
.split-body ul.check li::before{content:"";position:absolute;left:0;top:5px;width:20px;height:20px;border-radius:50%;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>"),linear-gradient(135deg,var(--blue-bright),var(--blue-deep));background-repeat:no-repeat;background-position:center;background-size:12px,cover}

/* Stat/response strip */
.coverage{
  background:linear-gradient(135deg,#003388,#006ee2);color:#fff;border-radius:var(--radius);
  padding:28px 30px;display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin:42px 0;box-shadow:var(--shadow)
}
.coverage .c-item{border-left:2px solid rgba(255,255,255,.25);padding-left:18px}
.coverage .c-item:first-child{border-left:0;padding-left:0}
.coverage .num{font:800 2rem/1 'Poppins',sans-serif;letter-spacing:-.01em}
.coverage .lbl{font-size:.82rem;opacity:.88;margin-top:6px;font-weight:500}

/* =========================================================
   AREA CARDS — used on /areas.html hub, homepage, suburb pages
   ========================================================= */
.area-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:28px 0}
.area-card{
  position:relative;display:flex;flex-direction:column;padding:20px 22px 22px;
  border:1px solid var(--line);border-radius:14px;background:#fff;
  text-decoration:none;color:inherit;box-shadow:var(--shadow-sm);
  transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease);
  overflow:hidden;min-height:130px
}
.area-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--blue-bright),var(--blue-deep));
  transform:scaleY(0);transform-origin:top;transition:transform .25s var(--ease)
}
.area-card:hover{
  transform:translateY(-3px);box-shadow:0 12px 30px rgba(11,34,69,.10);
  border-color:transparent
}
.area-card:hover::before{transform:scaleY(1)}
.area-card .pin{
  width:30px;height:30px;border-radius:8px;
  background:linear-gradient(135deg,rgba(0,110,226,.08),rgba(0,51,136,.12));
  color:var(--blue);display:grid;place-items:center;margin-bottom:10px;
  transition:background .2s var(--ease),color .2s var(--ease)
}
.area-card .pin svg{width:16px;height:16px}
.area-card:hover .pin{background:linear-gradient(135deg,var(--blue-bright),var(--blue-deep));color:#fff}
.area-card .nm{font-weight:700;color:var(--navy);font-size:1.02rem;font-family:'Poppins',sans-serif;letter-spacing:-.005em}
.area-card .postcode{color:var(--blue);font-weight:700;font-size:.78rem;letter-spacing:.04em;margin-top:3px;font-family:'Poppins',sans-serif}
.area-card .sub{color:var(--muted);font-size:.78rem;margin-top:8px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.area-card .sub .dot{width:4px;height:4px;border-radius:50%;background:#cbd5e1}
.area-card .sub .eta{color:#475569;font-weight:600}
.area-card .go{
  position:absolute;right:18px;bottom:20px;color:var(--blue);opacity:0;
  transform:translateX(-6px);transition:all .25s var(--ease)
}
.area-card:hover .go{opacity:1;transform:translateX(0)}
.area-card.muted-card{background:var(--bg-cool);border-style:dashed}
.area-card.muted-card::before{display:none}

/* =========================================================
   REGION PANEL — wraps each region on /areas.html
   ========================================================= */
.region-panel{padding:52px 0;border-top:1px solid var(--line)}
.region-panel:first-of-type{border-top:0}
.region-head{
  display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;
  margin-bottom:22px;padding-bottom:18px;border-bottom:1px dashed var(--line-2,#e2e8f0)
}
.region-head .region-badge{
  width:56px;height:56px;border-radius:14px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--blue-bright),var(--blue-deep));color:#fff;
  box-shadow:0 6px 18px rgba(0,110,226,.25)
}
.region-head .region-badge svg{width:24px;height:24px}
.region-head .region-title h2{
  color:var(--navy);font-size:clamp(1.35rem,2.2vw,1.75rem);
  margin:0 0 4px;letter-spacing:-.01em
}
.region-head .region-title p{color:var(--muted);margin:0;font-size:.88rem;font-weight:500}
.region-head .region-count{
  font-family:'Poppins',sans-serif;font-weight:700;color:var(--blue);
  background:var(--bg-cool);border:1px solid var(--line);border-radius:999px;
  padding:7px 15px;font-size:.78rem;letter-spacing:.04em;white-space:nowrap
}

/* Coverage map / hero band on /areas.html */
.area-hub-map{
  background:linear-gradient(135deg,#f0f7ff 0%,#e6f0fb 100%);
  border:1px solid #cfe0f5;border-radius:var(--radius);
  padding:32px 34px;margin:10px 0 12px;
  display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:center
}
.area-hub-map h2{color:var(--navy);font-size:1.5rem;margin:0 0 10px;letter-spacing:-.01em}
.area-hub-map p{color:#4a5a73;line-height:1.65;margin:0 0 14px}
.area-hub-map .hub-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.area-hub-map .hub-stat{
  background:#fff;border:1px solid #cfe0f5;border-radius:12px;padding:14px 16px;
}
.area-hub-map .hub-stat .n{font:800 1.4rem/1 'Poppins',sans-serif;color:var(--blue)}
.area-hub-map .hub-stat .l{color:var(--muted);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;margin-top:5px;font-weight:700}

/* =========================================================
   SUBURB-PAGE INTRO — distance / postcode / LGA info card
   (replaces the awkward split-media intro)
   ========================================================= */
.suburb-intro{display:grid;grid-template-columns:1.25fr .95fr;gap:34px;align-items:start;margin:14px 0}
.suburb-intro .intro-body h2{color:var(--navy);font-size:clamp(1.45rem,2.4vw,2rem);margin:10px 0 14px;letter-spacing:-.01em}
.suburb-intro .intro-body p{color:#4a5a73;line-height:1.7;margin-bottom:14px}
.suburb-intro .intro-body .eyebrow{
  display:inline-block;background:var(--bg-cool);color:var(--blue);
  padding:6px 14px;border-radius:999px;font-size:.74rem;
  font-weight:700;letter-spacing:.1em;text-transform:uppercase
}
.suburb-intro .intro-body .cta-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}

.info-card{
  background:linear-gradient(135deg,#003388,#006ee2);color:#fff;
  border-radius:var(--radius);padding:28px 28px 26px;position:sticky;top:90px;
  box-shadow:0 14px 40px rgba(0,51,136,.22)
}
.info-card h3{color:#fff;font-size:1rem;margin:0 0 4px;letter-spacing:.04em;text-transform:uppercase;font-weight:700;opacity:.88}
.info-card .place{font:800 1.75rem/1.05 'Poppins',sans-serif;margin:0 0 18px;letter-spacing:-.01em}
.info-card .info-row{
  display:flex;gap:14px;padding:14px 0;border-top:1px solid rgba(255,255,255,.18);
  align-items:flex-start
}
.info-card .info-row:first-of-type{border-top:0;padding-top:0}
.info-card .info-row .ic{
  width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.14);
  color:#fff;display:grid;place-items:center;flex-shrink:0
}
.info-card .info-row .ic svg{width:16px;height:16px}
.info-card .info-row .txt{flex:1}
.info-card .info-row .l{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;opacity:.75;font-weight:700;margin-bottom:2px}
.info-card .info-row .v{font-weight:600;font-size:.96rem;line-height:1.35}
.info-card .call-row{margin-top:20px;display:grid;gap:8px}
.info-card .call-row a{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 14px;border-radius:10px;background:#fff;color:var(--blue);
  font-weight:700;text-decoration:none;transition:transform .15s var(--ease)
}
.info-card .call-row a.secondary{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.28)}
.info-card .call-row a:hover{transform:translateY(-1px)}

/* Service grid (service hub) */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:26px 0 8px}
.svc-card{
  display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;text-decoration:none;color:inherit;
  box-shadow:var(--shadow-sm);transition:all .2s var(--ease)
}
.svc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--blue-bright)}
.svc-card .media{aspect-ratio:16/10;overflow:hidden;position:relative}
.svc-card .media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.svc-card:hover .media img{transform:scale(1.04)}
.svc-card .media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,51,136,.2) 100%)}
.svc-card .body{padding:18px 20px;flex:1;display:flex;flex-direction:column}
.svc-card .body h3{font-size:1.1rem;color:var(--navy);margin-bottom:6px}
.svc-card .body p{color:#4a5a73;font-size:.9rem;line-height:1.55;margin:0 0 14px;flex:1}
.svc-card .body .arrow{color:var(--blue);font-weight:700;font-size:.88rem;letter-spacing:.02em}

/* Local proof block (callouts, testimonial badge) */
.local-strip{
  display:grid;grid-template-columns:1.3fr .7fr;gap:28px;margin:34px 0;
  background:var(--bg-cool);border:1px solid var(--line);border-radius:var(--radius);
  padding:28px 30px;align-items:center
}
.local-strip h3{font-size:1.25rem;color:var(--navy);margin-bottom:8px}
.local-strip p{color:#4a5a73;line-height:1.65}
.local-strip .stats{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.local-strip .stat{background:#fff;border-radius:10px;padding:14px;border:1px solid var(--line)}
.local-strip .stat .n{font:800 1.3rem/1 'Poppins',sans-serif;color:var(--blue)}
.local-strip .stat .l{font-size:.76rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:5px;font-weight:700}

/* Mini-FAQ inside a service/suburb page (different visual from hub) */
.mini-faq{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:18px 0}
.mini-faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 18px;transition:border-color .15s}
.mini-faq details[open]{border-color:var(--blue-bright);box-shadow:var(--shadow-sm)}
.mini-faq summary{font-weight:700;color:var(--navy);cursor:pointer;list-style:none}
.mini-faq summary::-webkit-details-marker{display:none}
.mini-faq summary::after{content:"+";float:right;color:var(--blue);font-size:1.15rem;transition:transform .2s}
.mini-faq details[open] summary::after{content:"–"}
.mini-faq details .a{color:#4a5a73;font-size:.92rem;line-height:1.6;margin-top:8px}

/* FAQ hub category nav */
.faq-nav{
  position:sticky;top:84px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:14px 18px;margin-bottom:26px;box-shadow:var(--shadow-sm);z-index:5
}
.faq-nav ul{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:8px}
.faq-nav a{
  text-decoration:none;background:var(--bg-cool);color:var(--navy);
  padding:7px 14px;border-radius:999px;font-size:.84rem;font-weight:600;transition:all .15s
}
.faq-nav a:hover{background:var(--blue);color:#fff}

.faq-cat{margin-bottom:42px;scroll-margin-top:100px}
.faq-cat h2{color:var(--navy);font-size:1.5rem;margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--blue-bright)}

/* Prose blocks */
.prose h2{color:var(--navy);font-size:clamp(1.4rem,2.4vw,1.85rem);margin:30px 0 12px;letter-spacing:-.01em}
.prose h3{color:var(--navy);font-size:1.15rem;margin:22px 0 8px}
.prose p{color:#4a5a73;line-height:1.7;margin-bottom:14px}
.prose ul{margin:0 0 18px 22px;color:#374151;line-height:1.65}
.prose ul li{margin-bottom:6px}

/* =========================================================
   RESPONSIVE BREAKPOINTS
   ========================================================= */

/* Tablet / iPad (820–1100px) */
@media (max-width:1100px){
  .area-grid{grid-template-columns:repeat(3,1fr);gap:14px}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .area-hub-map{grid-template-columns:1fr;gap:22px;padding:26px}
  .suburb-intro{grid-template-columns:1fr;gap:24px}
  .info-card{position:static;padding:24px}
  .region-head .region-badge{width:48px;height:48px}
}

/* Small tablet / large mobile (720–820px) */
@media (max-width:820px){
  .pillars{grid-template-columns:1fr;gap:14px}
  .split{grid-template-columns:1fr;gap:22px}
  .split.reverse{direction:ltr}
  .coverage{grid-template-columns:repeat(2,1fr);gap:18px;padding:22px}
  .area-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .area-card{min-height:auto;padding:18px 20px}
  .svc-grid{grid-template-columns:1fr;gap:14px}
  .local-strip{grid-template-columns:1fr;gap:18px;padding:22px}
  .mini-faq{grid-template-columns:1fr}
  .region-panel{padding:40px 0}
  .region-head{grid-template-columns:auto 1fr;row-gap:14px;padding-bottom:14px;margin-bottom:18px}
  .region-head .region-count{grid-column:1/-1;justify-self:start}
  .area-hub-map .hub-stats{grid-template-columns:1fr 1fr}
}

/* Phone (≤560px) */
@media (max-width:560px){
  .coverage{grid-template-columns:1fr}
  .coverage .c-item{border-left:0;padding-left:0;border-top:1px solid rgba(255,255,255,.18);padding-top:14px}
  .coverage .c-item:first-child{border-top:0;padding-top:0}
  .area-grid{grid-template-columns:1fr;gap:12px}
  .area-hub-map{padding:22px;border-radius:16px}
  .area-hub-map h2{font-size:1.25rem}
  .area-hub-map .hub-stats{grid-template-columns:1fr 1fr;gap:10px}
  .area-hub-map .hub-stat{padding:12px}
  .area-hub-map .hub-stat .n{font-size:1.2rem}
  .region-panel{padding:32px 0}
  .region-head{margin-bottom:16px}
  .region-head .region-badge{width:44px;height:44px;border-radius:12px}
  .region-head .region-badge svg{width:20px;height:20px}
  .info-card{padding:22px}
  .info-card .place{font-size:1.45rem}
  .suburb-intro .intro-body .cta-row .btn{flex:1;text-align:center}
}
