/* ============================================================
   Artificial Grass Kitchener — "Editorial botanical"
   Cream base, deep forest-green ink, Fraunces serif display
   + Karla humanist sans. Hairline rules, generous margins.
   ============================================================ */

:root{
  --cream:#f6f1e4;
  --paper:#fdfaf2;
  --ink:#1c3a2a;
  --ink-soft:#3c5546;
  --moss:#58745f;
  --ochre:#82672b;
  --hairline:rgba(28,58,42,.22);
  --hairline-soft:rgba(28,58,42,.12);
  --serif:"Fraunces","Iowan Old Style",Georgia,"Times New Roman",serif;
  --sans:"Karla","Gill Sans","Segoe UI",Verdana,system-ui,sans-serif;
  --wrap:1180px;
  --narrow:760px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  font-size:1.0625rem;
  line-height:1.7;
  color:var(--ink-soft);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--ink);text-decoration-color:var(--ochre);text-decoration-thickness:1px;text-underline-offset:3px}
a:hover{color:var(--ochre)}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,summary:focus-visible{
  outline:2px solid var(--ochre);outline-offset:3px;border-radius:2px
}
h1,h2,h3,h4,blockquote{
  font-family:var(--serif);
  font-weight:500;
  color:var(--ink);
  line-height:1.15;
  margin:0 0 .6em;
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-999px;top:0;background:var(--ink);color:var(--cream);padding:.6em 1em;z-index:100}
.skip-link:focus{left:8px;top:8px}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(20px,4vw,48px)}
.wrap.narrow{max-width:var(--narrow)}

/* ---------- type helpers ---------- */
.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--moss);
  margin:0 0 1.1em;
}
.sec-h{
  font-size:clamp(1.7rem,3.4vw,2.6rem);
  margin-bottom:.9em;
}
.lede{font-size:clamp(1.1rem,1.8vw,1.3rem);line-height:1.6;max-width:36em}

/* ---------- buttons ---------- */
.btn{
  display:inline-block;
  font-family:var(--sans);
  font-weight:700;
  font-size:.95rem;
  letter-spacing:.04em;
  padding:.85em 1.7em;
  border-radius:2px;
  text-decoration:none;
  border:1px solid var(--ink);
  transition:background .18s,color .18s;
  cursor:pointer;
}
.btn-solid{background:var(--ink);color:var(--cream)}
.btn-solid:hover{background:var(--ochre);border-color:var(--ochre);color:#fff}
.btn-line{background:transparent;color:var(--ink)}
.btn-line:hover{background:var(--ink);color:var(--cream)}

/* ---------- header ---------- */
.site-head{
  background:var(--paper);
  border-bottom:1px solid var(--hairline);
  position:sticky;top:0;z-index:50;
}
.head-row{display:flex;align-items:center;gap:28px;min-height:76px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand img{width:44px;height:44px}
.brand-name{
  font-family:var(--serif);
  font-size:1.18rem;
  color:var(--ink);
  line-height:1.05;
  display:flex;flex-direction:column;
}
.brand-name em{font-style:italic;color:var(--moss);font-size:.92em}
.site-nav{margin-left:auto}
.site-nav ul{display:flex;gap:26px;list-style:none;margin:0;padding:0}
.site-nav a{
  font-size:.95rem;font-weight:500;text-decoration:none;color:var(--ink-soft);
  padding:.4em 0;border-bottom:2px solid transparent;
}
.site-nav a:hover{color:var(--ink);border-bottom-color:var(--ochre)}
.site-nav a[aria-current="page"]{color:var(--ink);border-bottom-color:var(--ink)}

/* ---------- dropdown sub-nav ---------- */
.site-nav .has-sub{position:relative}
.sub-toggle{
  display:flex;align-items:center;gap:7px;
  font-family:var(--sans);font-size:.95rem;font-weight:500;color:var(--ink-soft);
  background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;
  padding:.4em 0;line-height:inherit;
}
.sub-toggle:hover,.has-sub:hover>.sub-toggle,.has-sub:focus-within>.sub-toggle{color:var(--ink);border-bottom-color:var(--ochre)}
.sub-toggle .caret{
  width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;
  border-top:5px solid currentColor;transition:transform .2s ease;
}
.has-sub:hover>.sub-toggle .caret,.sub-toggle[aria-expanded="true"] .caret{transform:rotate(180deg)}
.site-nav .sub-menu{
  display:block;
  position:absolute;top:calc(100% + 10px);left:0;min-width:248px;z-index:200;
  list-style:none;margin:0;padding:8px;
  background:var(--paper);border:1px solid var(--hairline);
  box-shadow:0 18px 40px -18px rgba(28,58,42,.45);
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .18s ease,transform .18s ease,visibility .18s ease;
}
.sub-menu::before{content:"";position:absolute;bottom:100%;left:0;right:0;height:12px}
.has-sub:hover>.sub-menu,.has-sub:focus-within>.sub-menu,.sub-toggle[aria-expanded="true"]+.sub-menu{
  opacity:1;visibility:visible;transform:translateY(0);
}
.site-nav .sub-menu a{
  display:block;padding:.6em .7em;white-space:nowrap;border-bottom:none;
  font-size:.92rem;font-weight:500;color:var(--ink-soft);
}
.site-nav .sub-menu a:hover{color:var(--ink);background:rgba(93,122,100,.1)}
.site-nav .sub-menu a[aria-current="page"]{color:var(--ink);border-bottom:none;background:rgba(93,122,100,.14)}

.head-call{
  font-family:var(--serif);font-size:1.12rem;font-weight:600;
  color:var(--ink);text-decoration:none;white-space:nowrap;
  border:1px solid var(--hairline);border-radius:2px;padding:.5em 1em;
  display:flex;flex-direction:column;line-height:1.1;
}
.head-call:hover{border-color:var(--ochre)}
.head-call-label{font-family:var(--sans);font-size:.62rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--moss)}
.head-cta{white-space:nowrap;padding:.62em 1.25em;font-size:.85rem}
.nav-toggle{display:none;background:none;border:1px solid var(--hairline);border-radius:2px;padding:10px;cursor:pointer}
.nav-toggle span:not(.sr-only){display:block;width:22px;height:2px;background:var(--ink);margin:4px 0;transition:transform .2s,opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ---------- hero ---------- */
.hero{background:var(--cream);border-bottom:1px solid var(--hairline-soft)}
.hero-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);
  align-items:center;padding-top:clamp(48px,7vw,96px);padding-bottom:clamp(48px,7vw,96px);
}
.hero h1,.page-hero h1{
  font-size:clamp(2.5rem,5.6vw,4.3rem);
  font-weight:600;letter-spacing:-.01em;margin-bottom:.35em;
}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;margin:1.6em 0}
.hero-badges{display:flex;align-items:center;gap:22px;margin-top:1.8em;padding-top:1.4em;border-top:1px solid var(--hairline)}
.hero-badges img{width:auto;height:64px}
.framed{
  margin:0;background:var(--paper);
  border:1px solid var(--hairline);
  padding:10px;position:relative;
}
.framed::after{
  content:"";position:absolute;inset:-14px 14px 14px -14px;
  border:1px solid var(--hairline-soft);z-index:-1;
}
.framed img{width:100%;object-fit:cover}
.hero-art .framed img{aspect-ratio:4/3}

/* ---------- page hero (inner pages) ---------- */
.page-hero{
  background:var(--cream);
  border-bottom:1px solid var(--hairline-soft);
  padding:clamp(44px,6vw,84px) 0;
}
.crumbs{font-size:.85rem;margin-bottom:1.4em}
.crumbs span{color:var(--moss);margin:0 .4em}

/* ---------- sections ---------- */
.section{padding:clamp(56px,8vw,104px) 0}
.section-tint{background:var(--cream);border-top:1px solid var(--hairline-soft);border-bottom:1px solid var(--hairline-soft)}
.section-quotefeel .sec-h{font-style:italic}
.rule{border:0;border-top:1px solid var(--hairline);margin:2em 0}

/* ---------- solutions ---------- */
.sol-grid{
  list-style:none;margin:0;padding:0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,26px);
}
.sol-item{padding:1.4em 0 1.8em;position:relative}
.sol-num{
  font-family:var(--serif);font-style:italic;font-size:.95rem;color:var(--ochre);
  display:block;margin-bottom:.5em;
}
.sol-item h3{font-size:1.45rem;margin-bottom:.35em}
.sol-item p{margin:0;font-size:.98rem}

/* photo solution tiles (gradient overlay keeps white text readable) */
.sol-item.has-bg{
  display:flex;align-items:flex-end;min-height:248px;padding:0;overflow:hidden;
  border:1px solid var(--hairline);border-top:1px solid var(--hairline);
  background-color:var(--ink);background-size:cover;background-position:center;
}
.sol-item.has-bg::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(15,28,20,.12) 0%,rgba(15,28,20,.5) 52%,rgba(15,28,20,.88) 100%);
}
.sol-item.has-bg .sol-body{position:relative;z-index:2;padding:1.3em 1.4em 1.5em;display:block}
.sol-item.has-bg .sol-num{color:#e7d9ad}
.sol-item.has-bg h3{color:#fff;margin-bottom:.3em}
.sol-item.has-bg p{color:rgba(255,255,255,.92)}

/* ---------- projects ---------- */
.proj-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
}
.proj{margin:0;border:1px solid var(--hairline);padding:7px;background:var(--paper)}
.proj img{aspect-ratio:4/3;object-fit:cover;width:100%}
.proj:nth-child(1),.proj:nth-child(6){grid-column:span 2;grid-row:span 2}
.proj:nth-child(1) img,.proj:nth-child(6) img{height:100%;aspect-ratio:auto}

/* ---------- services ---------- */
.svc-list{
  list-style:none;margin:0;padding:0;
  display:grid;grid-template-columns:repeat(2,1fr);gap:0 clamp(32px,5vw,72px);
}
.svc{border-top:1px solid var(--hairline);padding:1.5em 0 1.9em}
.svc h3{font-size:1.5rem;display:flex;align-items:baseline;gap:.6em}
.svc-num{font-family:var(--serif);font-style:italic;font-size:.8em;color:var(--ochre)}
.svc p{margin:0}

/* ---------- benefits ---------- */
.benefit-grid{
  list-style:none;margin:0;padding:0;
  display:grid;grid-template-columns:repeat(2,1fr);gap:0 clamp(32px,5vw,72px);
}
.benefit{border-top:1px solid var(--hairline);padding:1.3em 0 1.6em}
.benefit h3{font-size:1.3rem;margin-bottom:.3em}
.benefit p{margin:0;font-size:.98rem}

/* ---------- about split ---------- */
.about-grid{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,5vw,80px);
  align-items:start;
}
.about-art img{aspect-ratio:3/4;object-fit:cover}

/* ---------- FAQ ---------- */
.faq{border-top:1px solid var(--hairline);padding:0}
.faq:last-of-type{border-bottom:1px solid var(--hairline)}
.faq summary{
  font-family:var(--serif);font-size:1.25rem;color:var(--ink);
  padding:1em 2.2em 1em 0;cursor:pointer;list-style:none;position:relative;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";position:absolute;right:.2em;top:50%;transform:translateY(-50%);
  font-family:var(--serif);font-size:1.4em;color:var(--ochre);transition:transform .2s;
}
.faq[open] summary::after{content:"–"}
.faq p{margin:0 0 1.4em;max-width:60ch}

/* ---------- blog cards / journal ---------- */
.post-card-row{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,48px)}
.post-card{border-top:1px solid var(--hairline);padding-top:1.3em}
.post-card h3{font-size:1.35rem;line-height:1.25}
.post-card h3 a,.blog-row h2 a{text-decoration:none}
.post-card h3 a:hover,.blog-row h2 a:hover{color:var(--ochre)}
.readmore a,.readall a{
  font-size:.82rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  text-decoration:none;border-bottom:1px solid var(--ochre);padding-bottom:2px;
}
.readall{margin-top:3em}

.blog-wrap{max-width:840px}
.blog-row{border-top:1px solid var(--hairline);padding:2.2em 0}
.blog-row:first-of-type{border-top:0;padding-top:0}
.blog-row h2{font-size:clamp(1.5rem,2.6vw,2rem);line-height:1.2}
.blog-row.featured h2{font-size:clamp(1.9rem,3.6vw,2.8rem)}
.blog-row.featured{padding-bottom:2.8em}
.blog-row p{max-width:64ch}

.paging{
  display:flex;flex-wrap:wrap;gap:10px;align-items:center;
  border-top:1px solid var(--hairline);padding-top:2em;margin-top:1em;
}
.pg{
  font-family:var(--serif);font-size:1.05rem;text-decoration:none;
  min-width:2.4em;text-align:center;padding:.35em .5em;
  border:1px solid transparent;border-radius:2px;
}
a.pg:hover{border-color:var(--hairline)}
.pg-cur{border-color:var(--ink);color:var(--ink)}
.pg-prev,.pg-next{font-style:italic;color:var(--moss)}

/* ---------- post / prose ---------- */
.post-hero h1{font-size:clamp(2rem,4.4vw,3.3rem);max-width:20em}
.prose h2{font-size:clamp(1.5rem,2.6vw,2.05rem);margin-top:1.9em;padding-top:.9em;border-top:1px solid var(--hairline-soft)}
.prose h3{font-size:1.35rem;margin-top:1.6em}
.prose h4{font-size:1.15rem;margin-top:1.5em}
.prose p{margin:0 0 1.25em}
.prose ul,.prose ol{padding-left:1.3em;margin:0 0 1.4em}
.prose li{margin-bottom:.45em}
.prose strong{color:var(--ink)}
.prose blockquote{
  border-left:2px solid var(--ochre);margin:1.6em 0;padding:.2em 0 .2em 1.2em;
  font-style:italic;font-size:1.15rem;
}
.prose table{
  width:100%;border-collapse:collapse;margin:1.6em 0;font-size:.95rem;
}
.prose th,.prose td{
  border:1px solid var(--hairline);padding:.6em .8em;text-align:left;vertical-align:top;
}
.prose th{font-family:var(--serif);font-weight:600;background:var(--cream)}
.prose img{margin:1.6em 0;border:1px solid var(--hairline);padding:8px;background:var(--paper)}

.post-related .related-list{list-style:none;margin:0;padding:0}
.related-list li{
  border-top:1px solid var(--hairline);padding:1.1em 0;
  display:flex;flex-direction:column;gap:.2em;
}
.related-list li:last-child{border-bottom:1px solid var(--hairline)}
.related-list time{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--moss)}
.related-list a{font-family:var(--serif);font-size:1.2rem;text-decoration:none}
.related-list a:hover{color:var(--ochre)}

/* ---------- quote band & form ---------- */
.quote-band{background:var(--cream);border-top:1px solid var(--hairline)}
.quote-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(36px,5vw,80px);align-items:start}
.quote-phone a{
  font-family:var(--serif);font-size:clamp(1.8rem,3.6vw,2.7rem);font-weight:600;
  text-decoration:none;color:var(--ink);
}
.quote-phone a:hover{color:var(--ochre)}
.cta-simple{text-align:center;max-width:680px}

.form-card{
  background:var(--paper);border:1px solid var(--hairline);padding:clamp(24px,3.5vw,44px);
  position:relative;
}
.form-card::after{content:"";position:absolute;inset:10px;border:1px solid var(--hairline-soft);pointer-events:none}
.form-title{font-size:1.6rem;margin-bottom:.2em}
.form-sub{margin-top:0;font-size:.95rem}
.quote-form{position:relative;z-index:1}
.ff{margin-bottom:1.25em}
.ff label,.ff legend,.ff-sub label{
  display:block;font-size:.8rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink);margin-bottom:.45em;
}
.req{font-weight:400;color:var(--moss);text-transform:none;letter-spacing:0}
.ff input,.ff textarea{
  width:100%;font-family:var(--sans);font-size:1rem;color:var(--ink);
  background:transparent;border:0;border-bottom:1px solid var(--hairline);
  padding:.55em 2px;border-radius:0;
}
.ff input:focus,.ff textarea:focus{border-bottom-color:var(--ochre);outline:none}
.ff input:focus-visible,.ff textarea:focus-visible{outline:2px solid var(--ochre);outline-offset:2px}
.ff textarea{resize:vertical;border:1px solid var(--hairline);padding:.7em}
.ff-address{border:0;padding:0;margin:0 0 1.25em}
.ff-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.ff-sub{margin-top:.9em}
.ff-sub label{font-size:.68rem;color:var(--moss)}
.ff input::placeholder,.ff textarea::placeholder{color:rgba(60,85,70,.45)}
.ff-hp{position:absolute;left:-9999px;top:-9999px;height:1px;width:1px;overflow:hidden}
.btn-submit{width:100%;font-size:1.02rem}
.btn-submit[disabled]{opacity:.55;cursor:wait}
.form-msg{
  margin-top:1.2em;padding:1em 1.2em;border:1px solid var(--moss);
  background:rgba(93,122,100,.08);color:var(--ink);font-weight:500;
}
.form-msg.error{border-color:#9a4a33;background:rgba(154,74,51,.07)}

/* ---------- footer ---------- */
.site-foot{
  background:var(--cream);
  border-top:1px solid var(--hairline);
  padding:clamp(48px,6vw,80px) 0 0;
  color:var(--ink-soft);
}
.foot-grid{
  display:grid;grid-template-columns:1.4fr .8fr 1fr;gap:clamp(32px,4vw,64px);
  padding-bottom:clamp(36px,4vw,56px);
}
.foot-logo{font-family:var(--serif);font-size:1.5rem;color:var(--ink);margin:0 0 .6em}
.foot-logo em{color:var(--moss)}
.foot-brand p{font-size:.95rem}
.foot-h{
  font-family:var(--sans);font-size:.74rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--moss);margin:0 0 1.2em;
}
.foot-col ul{list-style:none;margin:0;padding:0}
.foot-col li{margin-bottom:.7em;font-size:.97rem}
.foot-col a{text-decoration:none}
.foot-col a:hover{text-decoration:underline;text-decoration-color:var(--ochre)}
.foot-grid a{display:inline-block;padding:.2rem 0;overflow-wrap:anywhere}
.foot-bottom{
  border-top:1px solid var(--hairline);padding-top:1.4em;padding-bottom:1.6em;
  font-size:.85rem;
}
.foot-bottom p{margin:0}

/* ---------- mobile CTA bar ---------- */
.mobile-cta{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;
  background:var(--paper);border-top:1px solid var(--hairline);
  padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  gap:10px;
}
.mobile-cta .btn{flex:1;text-align:center;padding:.8em .5em;font-size:.9rem}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:980px){
  .sol-grid{grid-template-columns:repeat(2,1fr)}
  .proj-grid{grid-template-columns:repeat(2,1fr)}
  .svc-list,.benefit-grid{grid-template-columns:1fr}
  .post-card-row{grid-template-columns:1fr}
  .quote-grid,.about-grid,.hero-grid{grid-template-columns:1fr}
  .hero-art{order:-1}
  .head-call,.head-cta{display:none}
}
@media (max-width:820px){
  .nav-toggle{display:block;margin-left:auto}
  .site-nav{
    display:none;position:absolute;top:100%;left:0;right:0;
    background:var(--paper);border-bottom:1px solid var(--hairline);
    padding:10px clamp(20px,4vw,48px) 22px;margin-left:0;
  }
  .site-nav.open{display:block}
  .site-nav ul{flex-direction:column;gap:4px}
  .site-nav a{display:block;padding:.7em 0;font-size:1.1rem;border-bottom:1px solid var(--hairline-soft)}
  /* mobile accordion sub-nav */
  .site-nav .has-sub{position:static}
  .sub-toggle{width:100%;justify-content:space-between;font-size:1.1rem;padding:.7em 0;border-bottom:1px solid var(--hairline-soft)}
  .site-nav .sub-menu{
    position:static;min-width:0;opacity:1;visibility:hidden;transform:none;
    background:rgba(93,122,100,.06);border:none;box-shadow:none;
    padding:0 0 .3em .9em;margin:0;
    max-height:0;overflow:hidden;transition:max-height .25s ease,visibility .25s ease;
  }
  .sub-toggle[aria-expanded="true"]+.sub-menu{visibility:visible;max-height:520px}
  .site-nav .sub-menu a{font-size:1rem;padding:.55em 0}
  .mobile-cta{display:flex}
  body{padding-bottom:74px}
  .foot-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  .proj-grid{grid-template-columns:1fr}
  .proj:nth-child(1),.proj:nth-child(6){grid-column:span 1;grid-row:span 1}
  .proj:nth-child(1) img,.proj:nth-child(6) img{aspect-ratio:4/3}
  .sol-grid{grid-template-columns:1fr}
  .ff-row{grid-template-columns:1fr}
  .hero-badges img{height:52px}
}

/* Mobile overflow guards: prevent horizontal scroll from long words and wide tables */
h1, h2, h3, h4 { overflow-wrap: break-word; }
main table { display: block; overflow-x: auto; max-width: 100%; }
