/* City of Trees Lawn Care — mobile-first stylesheet */
:root{
  --forest:#15301f;
  --forest-2:#1d4029;
  --leaf:#3e7d4e;
  --leaf-bright:#5ca36c;
  --gold:#c9a227;
  --gold-soft:#e3c869;
  --cream:#f7f3e9;
  --cream-2:#efe9da;
  --ink:#22301f;
  --ink-soft:#4a584a;
  --white:#fff;
  --radius:18px;
  --shadow:0 18px 50px rgba(21,48,31,.16);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Figtree',sans-serif;
  font-size:18px;             /* mobile base — larger than typical for 50+ readers */
  line-height:1.65;
  color:var(--ink);
  background:var(--cream);
}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:'Fraunces',serif;line-height:1.12;color:var(--forest)}
h1{font-size:clamp(2.1rem,7vw,4.2rem);font-weight:600}
h2{font-size:clamp(1.7rem,5vw,2.9rem);font-weight:600}
h3{font-size:1.35rem;font-weight:600}
p{font-size:1.02rem}
.wrap{max-width:1180px;margin:0 auto;padding:0 20px}
main section{padding:64px 0}
.sp-t{margin-top:22px}
.center{text-align:center}
.muted{color:var(--ink-soft);font-size:.98rem}
.rounded{border-radius:var(--radius)}
.shadow{box-shadow:var(--shadow)}
.wide{width:100%;object-fit:cover;max-height:420px;margin-top:18px}
.blend{mix-blend-mode:multiply;border-radius:var(--radius)}

.kicker{
  display:inline-block;font-size:.9rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--gold);margin-bottom:12px;
}
.kicker::before{content:"";display:inline-block;width:30px;height:2px;background:var(--gold);vertical-align:middle;margin-right:10px}
.lead{font-size:1.15rem;color:var(--ink-soft);max-width:62ch}

.btn{
  display:inline-block;font-weight:700;font-size:1.05rem;text-decoration:none;text-align:center;
  padding:16px 28px;border-radius:999px;transition:.25s;cursor:pointer;border:2px solid transparent;
  min-height:48px; /* comfortable tap target */
}
.btn.full{width:100%}
.btn-gold{background:var(--gold);color:var(--forest)}
.btn-gold:hover{background:var(--gold-soft);transform:translateY(-2px);box-shadow:0 10px 24px rgba(201,162,39,.35)}
.btn-outline{border-color:var(--cream);color:var(--cream)}
.btn-outline:hover{background:rgba(255,255,255,.12)}
.btn-forest{background:var(--forest);color:var(--cream)}
.btn-forest:hover{background:var(--forest-2);transform:translateY(-2px)}

/* ---------- top bar ---------- */
.topbar{background:var(--forest);color:var(--cream-2);font-size:.88rem;padding:9px 14px;text-align:center}
.topbar b{color:var(--gold-soft)}

/* ---------- nav (mobile-first) ---------- */
header.nav{
  position:sticky;top:0;z-index:60;background:rgba(247,243,233,.96);
  backdrop-filter:blur(10px);border-bottom:1px solid rgba(21,48,31,.12);
}
.navrow{display:flex;align-items:center;justify-content:space-between;padding:12px 0;gap:14px}
.logo{display:flex;align-items:center;gap:11px;text-decoration:none}
.logo-mark{
  width:46px;height:46px;border-radius:50%;background:var(--forest);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.logo-mark svg{width:28px;height:28px}
.logo-text{font-family:'Fraunces',serif;font-weight:700;font-size:1.12rem;color:var(--forest);line-height:1.05}
.logo-text small{display:block;font-family:'Figtree',sans-serif;font-weight:600;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--leaf)}

.menu-btn{
  display:flex;flex-direction:column;justify-content:center;gap:5px;
  width:48px;height:48px;padding:11px;background:none;border:0;cursor:pointer;
}
.menu-btn span{display:block;height:3px;border-radius:2px;background:var(--forest);transition:.3s}
.menu-btn.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.menu-btn.open span:nth-child(2){opacity:0}
.menu-btn.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

nav.menu{
  position:fixed;inset:0;top:0;background:var(--forest);z-index:70;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  transform:translateX(100%);transition:transform .35s ease;
}
nav.menu.open{transform:none}
nav.menu a{
  color:var(--cream);text-decoration:none;font-weight:600;font-size:1.35rem;
  font-family:'Fraunces',serif;padding:11px 24px;border-radius:12px;
}
nav.menu a.active{color:var(--gold-soft)}
nav.menu a:hover{background:rgba(255,255,255,.08)}
nav.menu .menu-cta{margin-top:18px;font-family:'Figtree',sans-serif;font-size:1.05rem;background:var(--gold);color:var(--forest)}
body.menu-open{overflow:hidden}
/* close button rides above the menu */
body.menu-open .menu-btn{position:fixed;top:18px;right:20px;z-index:80}
body.menu-open .menu-btn span{background:var(--cream)}

.nav-cta{display:none}

/* sticky mobile call bar */
.callbar{
  position:fixed;left:0;right:0;bottom:0;z-index:55;
  background:var(--gold);color:var(--forest);text-align:center;text-decoration:none;
  font-weight:700;font-size:1.05rem;padding:15px 12px calc(15px + env(safe-area-inset-bottom));
  box-shadow:0 -6px 20px rgba(21,48,31,.25);
}
main{padding-bottom:64px} /* room for callbar */

/* ---------- hero (home) ---------- */
.hero{
  position:relative;color:var(--cream);overflow:hidden;padding:64px 0 0 !important;
  background:
    radial-gradient(900px 420px at 85% -10%, rgba(92,163,108,.35), transparent 60%),
    linear-gradient(160deg,#10271a 0%, #15301f 45%, #1d4029 100%);
}
.hero-grid{display:grid;gap:40px;align-items:center;padding-bottom:64px}
.hero .kicker{color:var(--gold-soft)}
.hero h1{color:var(--cream)}
.hero h1 em{font-style:italic;color:var(--gold-soft)}
.hero p.lead{color:rgba(247,243,233,.85);margin:20px 0 28px}
.hero-ctas{display:flex;flex-direction:column;gap:14px}
.hero-note{margin-top:14px;font-size:.92rem;color:rgba(247,243,233,.65)}
.hero-card{background:var(--cream);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.hero-card img{width:100%;height:240px;object-fit:cover}
.hero-card .cap{padding:15px 20px;color:var(--ink);font-weight:600;font-size:.95rem;display:flex;gap:10px;align-items:center}
.hero-card .cap svg{flex-shrink:0}
.stat-strip{position:relative;z-index:2;background:var(--gold);color:var(--forest)}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:18px 10px;padding:24px 20px}
.stat{text-align:center}
.stat b{font-family:'Fraunces',serif;font-size:1.7rem;display:block;line-height:1}
.stat span{font-size:.85rem;font-weight:600}

/* ---------- page hero (interior) ---------- */
.page-hero{
  color:var(--cream);padding:58px 0 !important;
  background:
    radial-gradient(900px 420px at 85% -10%, rgba(92,163,108,.3), transparent 60%),
    linear-gradient(160deg,#10271a 0%, #1d4029 100%);
}
.page-hero .kicker{color:var(--gold-soft)}
.page-hero h1{color:var(--cream)}
.page-hero .lead{color:rgba(247,243,233,.85);margin-top:18px}

/* ---------- generic two-column ---------- */
.two-col{display:grid;gap:40px;align-items:center}

/* ---------- not mowing / compare ---------- */
.notmow blockquote{
  font-family:'Fraunces',serif;font-size:clamp(1.45rem,4.5vw,2.2rem);font-weight:500;
  color:var(--forest);line-height:1.3;
}
.notmow blockquote strong{color:var(--leaf)}
.compare{display:grid;gap:14px}
.compare .row{display:flex;gap:14px;align-items:flex-start;background:var(--white);border-radius:14px;padding:18px 20px;box-shadow:0 6px 20px rgba(21,48,31,.07)}
.compare .row svg{flex-shrink:0;margin-top:4px}
.compare .row p{font-size:1rem}
.compare .btn{margin-top:6px}

/* ---------- problems ---------- */
.problems{background:var(--forest);color:var(--cream)}
.problems h2{color:var(--cream)}
.prob-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:38px}
.prob{
  display:block;text-decoration:none;
  background:rgba(255,255,255,.06);border:1px solid rgba(247,243,233,.14);
  border-radius:var(--radius);padding:24px 22px;transition:.25s;
}
.prob:hover{background:rgba(255,255,255,.11);transform:translateY(-3px)}
.prob h3{color:var(--gold-soft);font-size:1.15rem;margin-bottom:8px}
.prob p{font-size:.95rem;color:rgba(247,243,233,.82)}

/* ---------- teasers ---------- */
.teaser-grid{display:grid;gap:22px;margin-top:38px}
.teaser{
  display:block;text-decoration:none;background:var(--white);border-radius:var(--radius);
  overflow:hidden;box-shadow:0 8px 26px rgba(21,48,31,.08);transition:.25s;
}
.teaser:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.teaser img{width:100%;height:190px;object-fit:cover}
.teaser .t-body{padding:24px}
.teaser h3{margin-bottom:8px}
.teaser p{color:var(--ink-soft);font-size:.98rem}
.t-link{display:inline-block;margin-top:14px;font-weight:700;color:var(--leaf)}

/* ---------- services detail ---------- */
.svc-detail:nth-of-type(even){background:var(--cream-2)}
.svc-img img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;object-fit:cover;max-height:380px}
ul.points{list-style:none;display:grid;gap:13px}
ul.points li{display:flex;gap:12px;align-items:flex-start;font-size:1.02rem}
ul.points li .ck{flex-shrink:0;margin-top:4px}
ul.points.big li{font-size:1.05rem}
ul.points.light li{color:rgba(247,243,233,.9)}
ul.points b{color:var(--forest)}
ul.points.light b{color:var(--gold-soft)}

/* ---------- programs ---------- */
.programs{background:var(--cream-2);padding-top:48px !important}
.prog-grid{display:grid;gap:24px}
.prog{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:0 8px 26px rgba(21,48,31,.08);display:flex;flex-direction:column}
.prog-head{background:var(--forest);color:var(--cream);padding:22px 24px}
.prog-head.gold{background:var(--gold);color:var(--forest)}
.prog-head h3{color:inherit;font-size:1.3rem}
.prog-head p{font-size:.9rem;opacity:.85;margin-top:4px}
.prog-body{padding:24px;display:flex;flex-direction:column;flex:1}
.prog-body ul{list-style:none;display:grid;gap:12px;margin-bottom:22px}
.prog-body li{display:flex;gap:11px;align-items:flex-start;font-size:.98rem}
.prog-body li .ck{flex-shrink:0;margin-top:4px}
.prog-body .btn{margin-top:auto}
.badge{display:inline-block;background:var(--forest);color:var(--gold-soft);font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;border-radius:999px;padding:5px 13px;margin-bottom:9px}

/* ---------- season ---------- */
.season-grid{display:grid;gap:18px;margin-top:36px}
.s-card{background:var(--white);border-radius:var(--radius);padding:26px 24px;box-shadow:0 8px 26px rgba(21,48,31,.08);border-top:5px solid var(--leaf)}
.s-card h3{margin-bottom:8px}
.s-card p{color:var(--ink-soft);font-size:.98rem}

/* ---------- local / why us ---------- */
.local-photos{position:relative;margin-bottom:42px}
.local-photos img.main{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;object-fit:cover;aspect-ratio:4/3}
.local-photos img.float{
  position:absolute;width:48%;border-radius:14px;border:5px solid var(--cream);
  box-shadow:var(--shadow);bottom:-34px;right:-6px;transform:rotate(3deg);
}
.fleet{background:var(--cream-2)}

/* ---------- gallery ---------- */
.gallery{background:var(--forest-2);color:var(--cream);padding-top:48px !important}
.gallery .lead{color:rgba(247,243,233,.8)}
.gal-grid{display:grid;gap:22px}
.gal-card{background:rgba(255,255,255,.05);border:1px solid rgba(247,243,233,.15);border-radius:var(--radius);overflow:hidden}
.gal-pair{display:grid;grid-template-columns:1fr 1fr}
.gal-pair .half{position:relative}
.gal-pair img{width:100%;height:180px;object-fit:cover}
.tag{
  position:absolute;top:10px;left:10px;background:rgba(21,48,31,.85);color:var(--cream);
  font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:4px 11px;border-radius:999px;
}
.tag.after{background:var(--gold);color:var(--forest)}
.gal-card .cap{padding:16px 20px;font-size:.95rem;color:rgba(247,243,233,.85)}
.gal-card .cap b{color:var(--gold-soft);display:block;font-size:1.02rem;margin-bottom:2px}
.gal-ph{
  height:180px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:9px;
  background:repeating-linear-gradient(45deg, rgba(255,255,255,.04) 0 14px, rgba(255,255,255,.08) 14px 28px);
  color:rgba(247,243,233,.6);font-size:.85rem;font-weight:600;text-align:center;padding:0 14px;
}
.gallery .lead.center{color:rgba(247,243,233,.85);max-width:none}

/* ---------- reviews ---------- */
.rev-head{display:flex;flex-direction:column;gap:22px;margin-bottom:34px}
.gbadge{display:flex;align-items:center;gap:14px;background:var(--white);border-radius:14px;padding:14px 22px;box-shadow:0 6px 20px rgba(21,48,31,.08);width:fit-content}
.gbadge.solo{margin-bottom:36px}
.gbadge b{font-family:'Fraunces',serif;font-size:1.6rem;color:var(--forest)}
.stars{color:var(--gold);font-size:1.15rem;letter-spacing:2px}
.gbadge small{color:var(--ink-soft)}
.rev-grid{display:grid;gap:20px}
.rev{
  background:var(--white);border-radius:var(--radius);padding:26px 24px;
  box-shadow:0 8px 26px rgba(21,48,31,.08);display:flex;flex-direction:column;gap:14px;
}
.rev p{font-size:.98rem;color:var(--ink-soft)}
.rev .who{display:flex;align-items:center;gap:13px;margin-top:auto}
.rev .av{width:44px;height:44px;border-radius:50%;background:var(--forest);color:var(--gold-soft);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex-shrink:0}
.rev .who b{color:var(--forest);display:block;line-height:1.2}
.rev .who small{color:var(--ink-soft);font-size:.82rem}

/* ---------- areas ---------- */
.areas{padding-top:48px !important}
.area-grid{display:grid;gap:18px;margin-bottom:40px}
.area-card{background:var(--white);border-radius:var(--radius);padding:26px 24px;box-shadow:0 8px 26px rgba(21,48,31,.08)}
.area-card h3{display:flex;align-items:center;gap:9px;font-size:1.2rem;margin-bottom:8px}
.area-card p{color:var(--ink-soft);font-size:.98rem}
.map-card{background:var(--forest);border-radius:var(--radius);padding:28px;color:var(--cream);box-shadow:var(--shadow)}
.map-card h3{color:var(--gold-soft);font-size:1.35rem;margin-bottom:12px}
.map-card p{color:rgba(247,243,233,.85);font-size:.98rem;margin-bottom:20px}
.map-visual{border-radius:14px;overflow:hidden;background:#0f2417;padding:8px}

/* ---------- guarantee / gold card ---------- */
.guarantee{background:var(--gold)}
.g-inner{display:grid;gap:28px;justify-items:center;text-align:center}
.g-seal{
  width:118px;height:118px;border-radius:50%;background:var(--forest);color:var(--gold-soft);
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  font-family:'Fraunces',serif;font-weight:700;font-size:1.45rem;line-height:1.05;flex-shrink:0;
  box-shadow:0 12px 30px rgba(21,48,31,.3);
}
.g-seal small{font-family:'Figtree',sans-serif;font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-top:5px}
.guarantee h2{font-size:clamp(1.5rem,4.5vw,2.3rem)}
.guarantee p{color:rgba(21,48,31,.85);font-size:1.02rem;max-width:62ch}
.gold-card{background:var(--gold);border-radius:var(--radius);padding:32px 28px;display:grid;gap:22px;justify-items:center;text-align:center;box-shadow:var(--shadow)}
.gold-card h3{font-size:1.35rem}
.gold-card p{color:rgba(21,48,31,.85)}

/* ---------- how it works ---------- */
.steps{display:grid;gap:44px;margin-top:50px;counter-reset:step}
.step{position:relative;background:var(--white);border-radius:var(--radius);padding:56px 24px 28px;box-shadow:0 8px 26px rgba(21,48,31,.08)}
.step::before{
  counter-increment:step;content:counter(step);
  position:absolute;top:-22px;left:24px;width:54px;height:54px;border-radius:50%;
  background:var(--leaf);color:var(--cream);font-family:'Fraunces',serif;font-weight:700;font-size:1.55rem;
  display:flex;align-items:center;justify-content:center;box-shadow:0 8px 18px rgba(62,125,78,.4);
}
.step h3{font-size:1.18rem;margin-bottom:8px}
.step p{font-size:.95rem;color:var(--ink-soft)}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(160deg,#10271a, #1d4029);color:var(--cream)}
.cta-inner{display:grid;gap:26px}
.cta-band h2{color:var(--cream)}
.cta-band p{color:rgba(247,243,233,.8);margin-top:8px}
.cta-actions{display:flex;flex-direction:column;gap:14px}

/* ---------- contact ---------- */
.contact{background:linear-gradient(160deg,#10271a, #1d4029);color:var(--cream);padding-top:56px !important}
.contact h1{color:var(--cream);font-size:clamp(1.9rem,6vw,3.4rem)}
.contact .lead{color:rgba(247,243,233,.82)}
.contact .muted{color:rgba(247,243,233,.65)}
.kicker.gold{color:var(--gold-soft)}
.big-phone{display:block;font-family:'Fraunces',serif;font-size:clamp(1.9rem,7vw,3rem);font-weight:700;color:var(--gold-soft);text-decoration:none;margin:22px 0 10px}
.form-card{background:var(--cream);border-radius:var(--radius);padding:30px 24px;color:var(--ink);box-shadow:var(--shadow)}
.form-card h3{margin-bottom:6px;font-size:1.4rem}
.form-card .sub{font-size:.92rem;color:var(--ink-soft);margin-bottom:22px}
.frow{display:grid;gap:14px;margin-bottom:14px}
.form-card input,.form-card select{
  width:100%;padding:15px 17px;border-radius:12px;border:1.5px solid rgba(21,48,31,.22);
  background:var(--white);font-family:'Figtree',sans-serif;font-size:1.02rem;color:var(--ink);
}
.form-card input:focus,.form-card select:focus{outline:none;border-color:var(--leaf)}
.form-card .btn{margin-top:14px}
.form-card select{margin-bottom:2px}
.fine{font-size:.78rem;color:var(--ink-soft);margin-top:13px;line-height:1.5}
.form-thanks{text-align:center;padding:36px 8px}
.form-thanks .leafy{font-size:2.8rem}

/* ---------- footer ---------- */
footer{background:#0d2014;color:rgba(247,243,233,.75);padding:56px 0 110px;font-size:.93rem}
.foot-grid{display:grid;gap:36px;margin-bottom:40px}
footer h4{color:var(--cream);font-size:1rem;margin-bottom:14px;font-family:'Figtree',sans-serif;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
footer a{color:rgba(247,243,233,.75);text-decoration:none;display:block;padding:6px 0}
footer a:hover{color:var(--gold-soft)}
.foot-logo{margin-bottom:16px}
.foot-logo .logo-text{color:var(--cream)}
.foot-logo .logo-text small{color:var(--gold-soft)}
.foot-phone{margin-top:12px}
.foot-phone a{display:inline;font-weight:700;color:var(--gold-soft);font-size:1.1rem}
.foot-bottom{border-top:1px solid rgba(247,243,233,.15);padding-top:24px;font-size:.83rem;display:flex;flex-direction:column;gap:10px}
.foot-bottom a{display:inline}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
}

/* ============================================================
   TABLET & UP
   ============================================================ */
@media(min-width:640px){
  .hero-ctas,.cta-actions{flex-direction:row;flex-wrap:wrap}
  .frow{grid-template-columns:1fr 1fr}
  .prob-grid{grid-template-columns:1fr 1fr}
  .season-grid{grid-template-columns:1fr 1fr}
  .gal-grid{grid-template-columns:1fr 1fr}
  .rev-grid{grid-template-columns:1fr 1fr}
  .area-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:repeat(4,1fr)}
  .steps{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}

/* ============================================================
   DESKTOP
   ============================================================ */
@media(min-width:1020px){
  body{font-size:20px}
  main{padding-bottom:0}
  main section{padding:96px 0}
  .wrap{padding:0 28px}
  .callbar{display:none}
  footer{padding-bottom:36px}

  /* desktop nav */
  .menu-btn{display:none}
  nav.menu{
    position:static;transform:none;background:none;flex-direction:row;gap:26px;
    align-items:center;justify-content:flex-end;
  }
  nav.menu a{
    color:var(--ink);font-family:'Figtree',sans-serif;font-size:1rem;padding:6px 2px;border-radius:0;
  }
  nav.menu a:hover{background:none;color:var(--leaf)}
  nav.menu a.active{color:var(--leaf);border-bottom:2px solid var(--gold)}
  nav.menu .menu-cta{display:none}
  .nav-cta{display:flex;align-items:center;gap:16px}
  .phone{font-family:'Fraunces',serif;font-weight:700;font-size:1.2rem;color:var(--forest);text-decoration:none;white-space:nowrap}
  .phone span{color:var(--gold)}
  .nav-cta .btn{padding:12px 24px;font-size:.98rem}
  .navrow{padding:14px 0}
  .logo-mark{width:52px;height:52px}
  .logo-text{font-size:1.3rem}

  .hero{padding-top:110px !important}
  .hero-grid{grid-template-columns:1.15fr .85fr;gap:60px;padding-bottom:110px}
  .hero-card{transform:rotate(1.5deg)}
  .hero-card img{height:340px}
  .stat b{font-size:2rem}

  .two-col{grid-template-columns:1fr 1fr;gap:64px}
  .svc-detail.flip .two-col > div:first-child{order:2}
  .svc-detail.flip .two-col > .svc-img{order:1}

  .prob-grid{grid-template-columns:repeat(4,1fr)}
  .teaser-grid{grid-template-columns:repeat(3,1fr)}
  .prog-grid{grid-template-columns:repeat(3,1fr)}
  .season-grid{grid-template-columns:repeat(4,1fr)}
  .gal-grid{grid-template-columns:repeat(3,1fr)}
  .gal-pair img,.gal-ph{height:200px}
  .rev-grid{grid-template-columns:repeat(3,1fr)}
  .rev-head{flex-direction:row;align-items:flex-end;justify-content:space-between}
  .area-grid{grid-template-columns:repeat(3,1fr)}
  .steps{grid-template-columns:repeat(4,1fr)}
  .g-inner{grid-template-columns:auto 1fr auto;text-align:left;justify-items:start;align-items:center;gap:44px}
  .gold-card{grid-template-columns:auto 1fr;text-align:left;justify-items:start}
  .cta-inner{grid-template-columns:1fr auto;align-items:center}
  .foot-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}
  .foot-bottom{flex-direction:row;justify-content:space-between}
  .local-photos{margin-bottom:0}
  .local-photos img.float{right:-20px;bottom:-44px;border-width:6px}
  .form-card{padding:42px}
}
