main.svc-rich.fy-hub *{box-sizing:border-box;}
main.svc-rich.fy-hub{margin:0;padding:0;}
main.svc-rich.fy-hub .nav {display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:52px;background:#0F5C4A;position:sticky;top:0;z-index:50;}
main.svc-rich.fy-hub .logo {font-size:17px;font-weight:600;color:#fff;}
main.svc-rich.fy-hub .logo em{color:#7ECFB3;font-style:normal;}
main.svc-rich.fy-hub .nav-links {display:flex;gap:4px;}
main.svc-rich.fy-hub .nl {padding:5px 10px;font-size:12px;color:rgba(255,255,255,.8);cursor:pointer;border-radius:6px;}
main.svc-rich.fy-hub .nl:hover {background:rgba(255,255,255,.1);}
main.svc-rich.fy-hub .nav-cta {background:#C89B35;color:#fff;border:none;padding:8px 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;}
/* SECTIONS — crumb, motion hero, trust-bar from service-rich-pages.css */
main.svc-rich.fy-hub .sec {padding:54px 28px;}
main.svc-rich.fy-hub .sec-inner {max-width:900px;margin:0 auto;}
main.svc-rich.fy-hub .sec-label {font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.3px;color:#0F5C4A;margin-bottom:8px;}
main.svc-rich.fy-hub .sec h2 {font-size:22px;font-weight:600;color:#1a1a1a;margin-bottom:10px;line-height:1.3;}
main.svc-rich.fy-hub .lead {font-size:15px;color:#444;line-height:1.8;margin-bottom:16px;}
main.svc-rich.fy-hub .body-p {font-size:14px;color:#555;line-height:1.8;margin-bottom:14px;}

/* SUB-SERVICE CARDS — the hub nav */
main.svc-rich.fy-hub .hub-grid {display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin:24px 0;}
@media(max-width:640px){main.svc-rich.fy-hub .hub-grid{grid-template-columns:1fr;}}
main.svc-rich.fy-hub .hub-card {border:1px solid #e5e5e5;border-radius:14px;padding:22px;background:#fff;cursor:pointer;transition:all .15s;}
main.svc-rich.fy-hub .hub-card:hover {border-color:#0F5C4A;background:#E1F5EE;}
main.svc-rich.fy-hub .hub-card h3 {font-size:15px;font-weight:600;color:#1a1a1a;margin-bottom:6px;}
main.svc-rich.fy-hub .hub-card p {font-size:12px;color:#666;line-height:1.65;margin-bottom:12px;}
main.svc-rich.fy-hub .hub-card .range {font-size:12px;font-weight:600;color:#0F5C4A;}
main.svc-rich.fy-hub .hub-card .arrow {font-size:12px;color:#0F5C4A;margin-top:10px;font-weight:600;}
main.svc-rich.fy-hub .hub-icon {font-size:24px;margin-bottom:10px;}

/* CALLOUTS */
main.svc-rich.fy-hub .cbox {border-radius:12px;padding:18px 20px;margin:20px 0;}
main.svc-rich.fy-hub .cbox.green {background:#E1F5EE;border:1px solid #5DCAA5;}
main.svc-rich.fy-hub .cbox.green h4 {font-size:13px;font-weight:600;color:#085041;margin-bottom:6px;}
main.svc-rich.fy-hub .cbox.green p, main.svc-rich.fy-hub .cbox.green ul {font-size:13px;color:#0F6E56;line-height:1.7;margin:0;}
main.svc-rich.fy-hub .cbox.green ul {padding-left:16px;margin-top:6px;}
main.svc-rich.fy-hub .cbox.green li {margin-bottom:4px;}
main.svc-rich.fy-hub .cbox.amber {background:#FFF8EC;border:1px solid #EF9F27;}
main.svc-rich.fy-hub .cbox.amber h4 {font-size:13px;font-weight:600;color:#412402;margin-bottom:6px;}
main.svc-rich.fy-hub .cbox.amber p {font-size:13px;color:#633806;line-height:1.7;margin:0;}
main.svc-rich.fy-hub .cbox.blue {background:#E6F1FB;border:1px solid #85B7EB;}
main.svc-rich.fy-hub .cbox.blue h4 {font-size:13px;font-weight:600;color:#042C53;margin-bottom:6px;}
main.svc-rich.fy-hub .cbox.blue p {font-size:13px;color:#0C447C;line-height:1.7;margin:0;}
main.svc-rich.fy-hub .cbox.red {background:#fcebeb;border:1px solid #f09595;}
main.svc-rich.fy-hub .cbox.red h4 {font-size:13px;font-weight:600;color:#501313;margin-bottom:6px;}
main.svc-rich.fy-hub .cbox.red p {font-size:13px;color:#A32D2D;line-height:1.7;margin:0;}

/* SOIL CONDITIONS GRID */
main.svc-rich.fy-hub .soil-grid {display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:22px 0;}
@media(max-width:600px){main.svc-rich.fy-hub .soil-grid{grid-template-columns:1fr;}}
main.svc-rich.fy-hub .soil-card {border:1px solid #e5e5e5;border-radius:12px;padding:18px;background:#fff;}
main.svc-rich.fy-hub .soil-card h4 {font-size:14px;font-weight:600;color:#1a1a1a;margin-bottom:8px;display:flex;align-items:center;gap:8px;}
main.svc-rich.fy-hub .soil-card p {font-size:13px;color:#555;line-height:1.7;margin-bottom:10px;}
main.svc-rich.fy-hub .soil-card .implication {font-size:12px;color:#0F6E56;background:#E1F5EE;border-radius:6px;padding:8px 10px;line-height:1.55;}
main.svc-rich.fy-hub .soil-card .implication strong {color:#085041;}

/* PLANT SELECTOR */
main.svc-rich.fy-hub .plant-tabs {display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;}
main.svc-rich.fy-hub .pt {padding:7px 16px;border:1px solid #e5e5e5;border-radius:20px;font-size:12px;color:#555;cursor:pointer;background:#fff;transition:all .15s;}
main.svc-rich.fy-hub .pt:hover {border-color:#0F5C4A;color:#0F5C4A;}
main.svc-rich.fy-hub .pt.active {background:#0F5C4A;color:#fff;border-color:#0F5C4A;}
main.svc-rich.fy-hub .plant-panel {display:none;}.plant-panel.show{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(max-width:560px){main.svc-rich.fy-hub .plant-panel.show{grid-template-columns:1fr;}}
main.svc-rich.fy-hub .plant-card {border:1px solid #e5e5e5;border-radius:10px;padding:14px;background:#fff;}
main.svc-rich.fy-hub .plant-name {font-size:13px;font-weight:600;color:#1a1a1a;margin-bottom:2px;}
main.svc-rich.fy-hub .plant-species {font-size:11px;color:#0F5C4A;font-style:italic;margin-bottom:6px;}
main.svc-rich.fy-hub .plant-desc {font-size:12px;color:#555;line-height:1.6;margin-bottom:6px;}
main.svc-rich.fy-hub .plant-tags {display:flex;flex-wrap:wrap;gap:4px;}
main.svc-rich.fy-hub .plant-tag {font-size:10px;font-weight:600;padding:2px 7px;border-radius:4px;background:#f0f0f0;color:#555;}
main.svc-rich.fy-hub .plant-tag.native {background:#E1F5EE;color:#085041;}
main.svc-rich.fy-hub .plant-tag.drought {background:#FFF8EC;color:#633806;}
main.svc-rich.fy-hub .plant-tag.salt {background:#E6F1FB;color:#042C53;}

/* PROCESS */
main.svc-rich.fy-hub .process {border:1px solid #e5e5e5;border-radius:14px;overflow:hidden;margin:22px 0;}
main.svc-rich.fy-hub .ps {display:flex;gap:0;border-bottom:1px solid #f0f0f0;}
main.svc-rich.fy-hub .ps:last-child {border-bottom:none;}
main.svc-rich.fy-hub .ps-num {width:44px;background:#f9f9f7;border-right:1px solid #f0f0f0;display:flex;align-items:flex-start;justify-content:center;padding-top:15px;font-size:12px;font-weight:600;color:#0F5C4A;flex-shrink:0;}
main.svc-rich.fy-hub .ps-body {padding:14px 18px;flex:1;}
main.svc-rich.fy-hub .ps-body h4 {font-size:13px;font-weight:600;color:#1a1a1a;margin-bottom:5px;}
main.svc-rich.fy-hub .ps-body p {font-size:13px;color:#555;line-height:1.7;margin:0;}

/* PRICE TABLE */
main.svc-rich.fy-hub .price-wrap {border:1px solid #e5e5e5;border-radius:14px;overflow:hidden;margin:22px 0;}
main.svc-rich.fy-hub .price-head {display:grid;grid-template-columns:1.4fr 150px 1.4fr;background:#f9f9f7;border-bottom:1px solid #e5e5e5;}
main.svc-rich.fy-hub .ph {padding:10px 14px;font-size:11px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.7px;border-right:1px solid #f0f0f0;}
main.svc-rich.fy-hub .ph:last-child {border-right:none;}
main.svc-rich.fy-hub .price-row {display:grid;grid-template-columns:1.4fr 150px 1.4fr;border-bottom:1px solid #f0f0f0;}
main.svc-rich.fy-hub .price-row:last-child {border-bottom:none;}
main.svc-rich.fy-hub .pr-cell {padding:12px 14px;font-size:13px;color:#1a1a1a;border-right:1px solid #f0f0f0;}
main.svc-rich.fy-hub .pr-cell:last-child {border-right:none;}
main.svc-rich.fy-hub .pr-cell.price {font-weight:600;color:#0F5C4A;}
main.svc-rich.fy-hub .pr-cell.detail {font-size:12px;color:#666;}
@media(max-width:640px){main.svc-rich.fy-hub .price-head,main.svc-rich.fy-hub .price-row{grid-template-columns:1fr;}main.svc-rich.fy-hub .ph,main.svc-rich.fy-hub .pr-cell{border-right:none;border-bottom:1px solid #f0f0f0;}}

/* FAQ */
main.svc-rich.fy-hub .faq-list {display:flex;flex-direction:column;gap:8px;margin:20px 0;}
main.svc-rich.fy-hub .faq-item {border:1px solid #e5e5e5;border-radius:10px;overflow:hidden;}
main.svc-rich.fy-hub .faq-q {display:flex;align-items:center;justify-content:space-between;padding:14px 16px;cursor:pointer;background:#fff;gap:12px;}
main.svc-rich.fy-hub .faq-q span {font-size:13px;font-weight:600;color:#1a1a1a;line-height:1.4;}
main.svc-rich.fy-hub .faq-tog {width:22px;height:22px;border-radius:50%;background:#E1F5EE;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px;color:#085041;font-weight:300;transition:all .2s;}
main.svc-rich.fy-hub .faq-a {display:none;padding:0 16px 14px;border-top:1px solid #f5f5f5;}
main.svc-rich.fy-hub .faq-a p {font-size:13px;color:#555;line-height:1.75;margin:10px 0 0;}
main.svc-rich.fy-hub .faq-item.open .faq-a {display:block;}
main.svc-rich.fy-hub .faq-item.open .faq-tog {background:#0F5C4A;color:#fff;transform:rotate(45deg);}

/* REVIEWS */
main.svc-rich.fy-hub .rev-grid {display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:20px 0;}
@media(max-width:580px){main.svc-rich.fy-hub .rev-grid{grid-template-columns:1fr;}}
main.svc-rich.fy-hub .rev {border:1px solid #e5e5e5;border-radius:12px;padding:18px 16px;background:#fff;}
main.svc-rich.fy-hub .rev-stars {color:#C89B35;font-size:14px;letter-spacing:2px;margin-bottom:8px;}
main.svc-rich.fy-hub .rev-text {font-size:13px;color:#1a1a1a;line-height:1.72;font-style:italic;margin-bottom:12px;}
main.svc-rich.fy-hub .rev-meta {display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:6px;}
main.svc-rich.fy-hub .rev-name {font-size:12px;font-weight:600;color:#1a1a1a;}
main.svc-rich.fy-hub .rev-loc {font-size:11px;color:#888;}
main.svc-rich.fy-hub .rev-badge {font-size:10px;font-weight:600;padding:2px 9px;border-radius:6px;background:#E1F5EE;color:#085041;}

/* FEATURE GRID */
main.svc-rich.fy-hub .feat-grid {display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin:20px 0;}
main.svc-rich.fy-hub .feat {border:1px solid #e5e5e5;border-radius:12px;padding:18px;background:#fff;}
main.svc-rich.fy-hub .feat-icon {width:34px;height:34px;border-radius:8px;background:#E1F5EE;display:flex;align-items:center;justify-content:center;margin-bottom:11px;}
main.svc-rich.fy-hub .feat-icon svg {width:16px;height:16px;fill:none;stroke:#0F5C4A;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
main.svc-rich.fy-hub .feat h4 {font-size:13px;font-weight:600;color:#1a1a1a;margin-bottom:6px;}
main.svc-rich.fy-hub .feat p {font-size:12px;color:#666;line-height:1.65;margin:0;}

/* CTA */
main.svc-rich.fy-hub .cta-blk {background:#071a0e;border-radius:16px;padding:36px 28px;text-align:center;margin:24px 0;}
main.svc-rich.fy-hub .cta-blk h2 {font-size:22px;font-weight:600;color:#fff;margin-bottom:10px;}
main.svc-rich.fy-hub .cta-blk p {font-size:14px;color:rgba(255,255,255,.68);max-width:470px;margin:0 auto 22px;line-height:1.75;}

/* FOOTER */
main.svc-rich.fy-hub .foot {padding:14px 28px;border-top:1px solid #e5e5e5;display:flex;justify-content:space-between;font-size:11px;color:#888;flex-wrap:wrap;gap:6px;}

/* Two col */
main.svc-rich.fy-hub .two-col {display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:20px 0;}
@media(max-width:620px){main.svc-rich.fy-hub .two-col{grid-template-columns:1fr;}}
main.svc-rich.fy-hub a.hub-card{text-decoration:none;color:inherit;display:block;}

/* Hub aerial / feature art: show full frame (shared hub figure uses 16:9 + cover) */
body.hub-front-yard-charleston main.svc-rich .hub-sec-figure.hub-front-yard-feature{
  aspect-ratio:auto;
}
body.hub-front-yard-charleston main.svc-rich .hub-sec-figure.hub-front-yard-feature img{
  width:100%;
  height:auto;
  max-height:none;
  object-fit:contain;
  object-position:center;
  vertical-align:middle;
}

/* On-site work grid: same idea — no hard crop on portrait or wide stills */
body.hub-front-yard-charleston main.svc-rich .pp-work-photo{
  aspect-ratio:auto;
  min-height:0;
}
body.hub-front-yard-charleston main.svc-rich .pp-work-photo img{
  width:100%;
  height:auto;
  object-fit:contain;
  object-position:center;
}

/* Motion hero: drop parallax layer overscan so backgrounds are not extra-zoomed */
body.hub-front-yard-charleston main.svc-rich .hero.rich-hero--motion .rich-hero-media{
  left:0;
  right:0;
  top:0;
  bottom:0;
}
