/* Arbor Survey page styles: services.css */
/* ---------- Brand design system (Brand Guidelines v2.3) ---------- */
.bg-pale{background:var(--pale-green);}
/* ---------- Header / nav ---------- */
.pillar,section[id]{scroll-margin-top:84px;}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}
/* ---------- Lifecycle infographic (interactive) ---------- */
.flow{margin-top:30px;}
.flow-rail{position:relative;display:grid;grid-template-columns:repeat(6,1fr);gap:8px;}
.flow-rail::before{content:"";position:absolute;left:6%;right:6%;top:27px;height:3px;background:var(--pale-green);z-index:0;}
.stage{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:10px;background:none;border:0;
  cursor:pointer;padding:6px 4px;font-family:inherit;text-align:center;color:var(--dark-green);}
.stage .dot{width:54px;height:54px;border-radius:50%;background:#fff;border:3px solid var(--light-green);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.15rem;color:var(--dark-green);
  transition:all .18s ease;}
.stage .slabel{font-size:.82rem;font-weight:600;line-height:1.25;color:var(--dark-green);}
.stage:hover .dot{border-color:var(--sage);}
.stage[aria-selected="true"] .dot{background:var(--dark-green);border-color:var(--dark-green);color:#fff;transform:scale(1.06);}
.stage[aria-selected="true"] .slabel{color:var(--dark-green);text-decoration:underline;text-underline-offset:3px;}
.stage:focus-visible{outline:none;}
.stage:focus-visible .dot{box-shadow:0 0 0 3px var(--pale-green);}
.flow-panel{margin-top:30px;background:#fff;border:1px solid var(--light-grey);border-radius:8px;
  border-left:5px solid var(--dark-green);padding:28px 30px;}
.flow-panel .when{font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--dark-green);margin:0 0 .3rem;}
.flow-panel h3{font-size:1.35rem;margin-bottom:.3em;}
.flow-panel .sub{color:var(--mid-grey);margin-bottom:1.2rem;font-size:1rem;}
.report-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;}
.report{background:var(--pale-tint);border-radius:6px;padding:16px 18px;}
.report .rname{font-weight:700;color:var(--dark-green);font-size:1rem;margin-bottom:4px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.report .abbr{font-size:.66rem;font-weight:700;letter-spacing:.05em;background:var(--dark-green);color:#fff;padding:2px 7px;border-radius:999px;}
.report .rdesc{font-size:.9rem;color:var(--near-black);margin:0;}
/* ---------- Pillar cards ---------- */
.pillars{display:grid;gap:24px;margin-top:30px;}
.pillars--3{grid-template-columns:repeat(3,1fr);}
.pillars--4{grid-template-columns:repeat(4,1fr);}
.pillar{display:flex;flex-direction:column;background:#fff;border:1px solid var(--light-grey);border-radius:8px;
  padding:26px;border-top:4px solid var(--sage);text-decoration:none;color:inherit;
  transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;}
.pillar:hover,.pillar:focus-visible{transform:translateY(-3px);box-shadow:0 10px 26px rgba(35,31,32,.10);
  border-color:var(--sage);color:inherit;outline:none;}
.pillar.feature{border-top-color:var(--dark-green);background:var(--pale-tint);}
.pillar h3{color:var(--dark-green);margin-bottom:.3em;}
.pillar .feat-tag{display:inline-block;font-size:.64rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
  background:var(--dark-green);color:#fff;padding:3px 9px;border-radius:999px;margin-bottom:12px;align-self:flex-start;}
.pillar .pdesc{font-size:.96rem;color:var(--near-black);margin:0 0 1rem;}
.pillar .plist{list-style:none;margin:0 0 1.2rem;padding:0;}
.pillar .plist li{font-size:.85rem;color:var(--mid-grey);padding:3px 0 3px 16px;position:relative;line-height:1.45;}
.pillar .plist li::before{content:"";position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:50%;background:var(--light-green);}
.pillar .go{font-weight:700;color:var(--dark-green);font-size:.92rem;margin-top:auto;}
.pillar:hover .go,.pillar:focus-visible .go{color:var(--dark-green);}
.group-head{margin-top:8px;}
/* ---------- Other reports (hover/click detail) ---------- */
.more-reports{margin-top:8px;}
.more-reports h4{font-size:1rem;color:var(--dark-green);margin:0 0 6px;font-weight:600;}
.more-reports .lede{margin-bottom:16px;}
.rtags{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:10px;}
.rtags button{background:#fff;border:1px solid var(--light-green);color:var(--dark-green);font-size:.86rem;font-weight:600;
  padding:8px 14px;border-radius:999px;cursor:pointer;font-family:inherit;transition:all .12s ease;}
.rtags button:hover,.rtags button:focus-visible,.rtags button[aria-pressed="true"]{background:var(--dark-green);color:#fff;border-color:var(--dark-green);outline:none;}
.rdetail{margin-top:16px;background:#fff;border:1px solid var(--light-grey);border-left:4px solid var(--sage);border-radius:6px;padding:14px 18px;min-height:62px;}
.rdetail .rd-name{font-weight:700;color:var(--dark-green);margin:0 0 3px;font-size:.98rem;}
.rdetail .rd-desc{margin:0;font-size:.92rem;color:var(--near-black);}
.rdetail .rd-hint{margin:0;font-size:.92rem;color:var(--mid-grey);}
/* ---------- Advisory band ---------- */
.advisory{margin-top:30px;background:#fff;border:1px solid var(--light-grey);border-radius:8px;border-left:5px solid var(--dark-green);
  padding:28px 30px;display:flex;flex-wrap:wrap;gap:24px 36px;align-items:center;justify-content:space-between;}
.advisory .adv-main{flex:1;min-width:280px;}
.advisory h3{color:var(--dark-green);margin-bottom:.3em;}
.advisory .pdesc{font-size:.98rem;margin:0 0 .9rem;}
.advisory .plist{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:8px;}
.advisory .plist li{font-size:.78rem;font-weight:700;background:var(--pale-tint);color:var(--dark-green);padding:6px 13px;border-radius:999px;}
.advisory .adv-cta{flex:none;display:flex;flex-direction:column;gap:6px;align-items:flex-start;}
.advisory .go{font-weight:700;color:var(--dark-green);font-size:.92rem;}
.advisory .adv-note{font-size:.82rem;color:var(--mid-grey);max-width:18em;}
/* ---------- Footer ---------- */
@media (max-width:880px){
  h1{font-size:2rem;}
  .pillars--3,.pillars--4{grid-template-columns:repeat(2,1fr);}
  .flow-rail{grid-template-columns:repeat(3,1fr);row-gap:22px;}
  .flow-rail::before{display:none;}
}
@media (max-width:480px){
  .pillars--3,.pillars--4{grid-template-columns:1fr;}
  .flow-rail{grid-template-co