/* ============================================================
   ILX ABOUT - About Infinity Landscaping
   Loaded only on the /about/ page (see inc/enqueue.php).
   Scoped under .ab-page. Uses Coastal Estate tokens.
   ============================================================ */

.ab-page .ab-hero{ padding-top:clamp(26px,3.5vw,46px); }

/* ---- Hero ------------------------------------------------- */
.ab-hero__grid{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);
  gap:clamp(28px,5vw,68px);
  align-items:center;
}
.ab-hero__text .eyebrow{ margin-bottom:14px; }
.ab-hero__title{
  font-family:var(--ilx-serif);
  font-size:var(--ilx-fs-h1);
  line-height:1.03;
  letter-spacing:-.015em;
  color:var(--ilx-forest-deep);
  margin:0 0 18px;
}
.ab-hero__lead{
  font-size:var(--ilx-fs-lead);
  color:var(--ilx-muted);
  line-height:1.66;
  margin:0 0 26px;
  max-width:56ch;
}
.ab-hero__cta{ display:flex; flex-wrap:wrap; gap:12px; }

/* ---- Owner portrait --------------------------------------- */
.ab-owner{
  position:relative;
  margin:0;
  border-radius:var(--ilx-r-lg);
  overflow:hidden;
  box-shadow:var(--ilx-shadow-lg);
  border:1px solid var(--ilx-line);
  background:var(--ilx-forest-deep);
  aspect-ratio:4 / 5;
  max-width:440px;
  justify-self:center;
}
.ab-owner img{ width:100%; height:100%; object-fit:cover; object-position:center top; display:block; }
.ab-owner__tag{
  position:absolute; left:0; right:0; bottom:0;
  display:flex; flex-direction:column; gap:1px;
  padding:34px 22px 18px;
  background:linear-gradient(to top, rgba(11,31,20,.92), rgba(11,31,20,.55) 55%, transparent);
  color:#fff;
}
.ab-owner__name{ font-family:var(--ilx-serif); font-size:var(--ilx-fs-h4); font-weight:600; }
.ab-owner__role{ font-size:var(--ilx-fs-sm); color:var(--ilx-gold); letter-spacing:.02em; }
.ab-owner__badge{
  position:absolute; top:16px; right:16px;
  background:var(--ilx-orange); color:#fff;
  font-size:var(--ilx-fs-xs); font-weight:700; letter-spacing:.05em; text-transform:uppercase;
  padding:7px 13px; border-radius:var(--ilx-pill);
  box-shadow:var(--ilx-shadow-bronze);
}

/* ---- Stat band -------------------------------------------- */
.ab-stats{ background:var(--ilx-forest-deep); color:#fff; }
.ab-stats__row{
  list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:24px;
  padding-block:clamp(34px,4vw,52px);
}
.ab-stat{ text-align:center; position:relative; }
.ab-stat + .ab-stat::before{
  content:""; position:absolute; left:-12px; top:50%; transform:translateY(-50%);
  height:46px; width:1px; background:var(--ilx-line-dark);
}
.ab-stat__num{
  display:block;
  font-family:var(--ilx-serif);
  font-size:clamp(2rem,1.4rem + 2.4vw,3rem);
  line-height:1;
  color:var(--ilx-gold);
  margin-bottom:8px;
}
.ab-stat__label{ font-size:var(--ilx-fs-sm); color:rgba(255,255,255,.78); line-height:1.4; display:block; }

/* ---- The Infinity Difference ------------------------------ */
.ab-diff{ position:relative; overflow:hidden; }
.ab-diff__watermark{
  position:absolute; right:-30px; top:50%; transform:translateY(-50%);
  height:120%; width:auto; opacity:.05; pointer-events:none; z-index:0;
}
.ab-diff .ilx-wrap{ position:relative; z-index:1; }
.ab-diff__grid{
  display:grid; grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);
  gap:clamp(28px,4vw,56px); align-items:center;
}
.ab-diff__text .eyebrow{ margin-bottom:14px; }
.ab-diff__text h2{
  font-family:var(--ilx-serif); font-size:var(--ilx-fs-h2);
  color:var(--ilx-forest-deep); line-height:1.1; margin:0 0 16px; letter-spacing:-.01em;
}
.ab-diff__text p{ font-size:var(--ilx-fs-base); color:var(--ilx-muted); line-height:1.66; margin:0 0 14px; }

.ab-quote{
  margin:0;
  background:var(--ilx-forest-deep);
  color:#fff;
  border-radius:var(--ilx-r-lg);
  padding:clamp(28px,3vw,40px);
  position:relative;
  box-shadow:var(--ilx-shadow);
}
.ab-quote::before{
  content:"\201C";
  position:absolute; top:6px; left:22px;
  font-family:var(--ilx-serif); font-size:5rem; line-height:1;
  color:var(--ilx-gold); opacity:.5;
}
.ab-quote p{
  position:relative;
  font-family:var(--ilx-serif);
  font-size:var(--ilx-fs-h4);
  line-height:1.5;
  margin:14px 0 22px;
  color:#fff;
}
.ab-quote footer{ display:flex; flex-direction:column; gap:2px; border-top:1px solid var(--ilx-line-dark); padding-top:16px; }
.ab-quote__name{ font-weight:700; }
.ab-quote__role{ font-size:var(--ilx-fs-sm); color:var(--ilx-gold); }

/* ---- What we do ------------------------------------------- */
.ab-services__grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:clamp(16px,2vw,22px); margin-top:28px;
}
.ab-svc{
  background:var(--ilx-white);
  border:1px solid var(--ilx-line);
  border-radius:var(--ilx-r-md);
  padding:28px 26px;
  box-shadow:var(--ilx-shadow-sm);
  transition:transform var(--ilx-dur-fast) var(--ilx-ease), box-shadow var(--ilx-dur-fast) var(--ilx-ease), border-color var(--ilx-dur-fast) var(--ilx-ease);
}
.ab-svc:hover{ transform:translateY(-3px); box-shadow:var(--ilx-shadow-md); border-color:var(--ilx-sage); }
.ab-svc__icon{
  display:grid; place-items:center;
  width:52px; height:52px; border-radius:var(--ilx-r-sm);
  background:var(--ilx-leaf-soft); color:var(--ilx-forest);
  border:1px solid var(--ilx-line);
  margin-bottom:18px;
}
.ab-svc__icon svg{ width:26px; height:26px; }
.ab-svc h3{ font-family:var(--ilx-serif); font-size:var(--ilx-fs-h4); color:var(--ilx-forest-deep); margin:0 0 9px; }
.ab-svc p{ font-size:var(--ilx-fs-sm); color:var(--ilx-muted); line-height:1.6; margin:0; }

/* ---- Why choose us (value cards) -------------------------- */
.ab-values{ background:var(--ilx-cream); }
.ab-values__grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:clamp(16px,2vw,24px); margin-top:28px;
}
.ab-value{
  display:flex; gap:18px; align-items:flex-start;
  background:var(--ilx-white);
  border:1px solid var(--ilx-line);
  border-radius:var(--ilx-r-md);
  padding:26px 26px;
  box-shadow:var(--ilx-shadow-sm);
}
.ab-value__icon{
  flex:none;
  width:66px; height:66px; border-radius:var(--ilx-r-md);
  display:grid; place-items:center;
  background:var(--ilx-forest-ghost);
  border:1px solid var(--ilx-line);
}
.ab-value__icon img{ width:40px; height:40px; display:block; }
.ab-value h3{ font-family:var(--ilx-serif); font-size:var(--ilx-fs-h4); color:var(--ilx-forest-deep); margin:0 0 8px; }
.ab-value p{ font-size:var(--ilx-fs-sm); color:var(--ilx-muted); line-height:1.6; margin:0; }

/* ---- Service areas ---------------------------------------- */
.ab-areas__inner{
  background:var(--ilx-forest-ghost);
  border:1px solid var(--ilx-line);
  border-radius:var(--ilx-r-lg);
  padding:clamp(26px,3.5vw,46px);
  display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);
  gap:clamp(22px,3vw,40px); align-items:center;
}
.ab-areas__head .eyebrow{ margin-bottom:12px; }
.ab-areas__head h2{ font-family:var(--ilx-serif); font-size:var(--ilx-fs-h3); color:var(--ilx-forest-deep); margin:0 0 8px; }
.ab-areas__head p{ font-size:var(--ilx-fs-base); color:var(--ilx-muted); line-height:1.6; margin:0; }
.ab-areas__chips{ display:flex; flex-wrap:wrap; gap:10px; }
.ab-chip{
  font-size:var(--ilx-fs-base); font-weight:600;
  color:var(--ilx-forest);
  background:var(--ilx-white);
  border:1px solid var(--ilx-line);
  border-radius:var(--ilx-pill);
  padding:9px 18px;
}

/* ---- CTA -------------------------------------------------- */
.ab-cta{
  background:var(--ilx-forest-deep);
  color:#fff;
  border-radius:var(--ilx-r-lg);
  padding:clamp(28px,4vw,48px);
  display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
  box-shadow:var(--ilx-shadow);
}
.ab-cta__title{ font-family:var(--ilx-serif); font-size:var(--ilx-fs-h2); margin:0 0 8px; }
.ab-cta__text{ font-size:var(--ilx-fs-base); color:rgba(255,255,255,.82); margin:0; max-width:54ch; line-height:1.6; }

/* ---- Responsive ------------------------------------------- */
@media (max-width:920px){
  .ab-hero__grid{ grid-template-columns:1fr; gap:34px; }
  .ab-owner{ order:-1; max-width:360px; }
  .ab-diff__grid{ grid-template-columns:1fr; }
  .ab-areas__inner{ grid-template-columns:1fr; }
}
@media (max-width:680px){
  .ab-stats__row{ grid-template-columns:repeat(2,1fr); gap:28px 16px; }
  .ab-stat::before{ display:none !important; }
}
@media (max-width:420px){
  .ab-value{ flex-direction:column; gap:12px; }
  .ab-cta .ilx-btn{ width:100%; justify-content:center; }
}

@media (prefers-reduced-motion:reduce){
  .ab-svc{ transition:none; }
}
