/* MyGravelBuddy PSEO — brand-aligned design system.
   Inherits Poppins font + 1250px container from Hello Elementor + Elementor Kit. */

/* Global guard against horizontal overflow caused by absolutely-positioned
   flyouts, full-bleed sections, or Elementor widgets that paint outside
   their containers. Body `overflow-x: hidden` propagates to the viewport
   in modern browsers, so vertical sticky positioning is unaffected. */
html, body { overflow-x: hidden; }

:root{
  /* Brand tokens — pulled from Elementor Kit (id 14) */
  --pseo-brand:#E8874A;
  --pseo-brand-d:#C56F35;
  --pseo-brand-l:#FBE6D7;
  --pseo-text:#1A1A1A;
  --pseo-text-2:#4A4A4A;
  --pseo-muted:#6B7280;
  --pseo-line:#E5E7EB;
  --pseo-line-2:#F1F2F4;
  --pseo-bg:#FFFFFF;
  --pseo-bg-soft:#F8F8F8;
  --pseo-bg-tint:#FFF8F3;
  --pseo-radius:10px;
  --pseo-radius-sm:6px;
  --pseo-shadow:0 1px 3px rgba(0,0,0,.06);
  --pseo-shadow-md:0 4px 16px rgba(232,135,74,.10);
  --pseo-max:1250px;
}
.pseo,.pseo *{box-sizing:border-box}
.pseo{
  max-width:var(--pseo-max);
  margin:0 auto;
  padding:2rem 1.5rem 4rem;
  color:var(--pseo-text);
  line-height:1.6;
  font-family:"Poppins","Helvetica Neue",Arial,sans-serif;
}
.pseo h1,.pseo h2,.pseo h3,.pseo h4{font-family:"Poppins",sans-serif;letter-spacing:-.01em}
.pseo h1{font-size:clamp(2rem,4.2vw,3rem);line-height:1.12;margin:0 0 .65rem;font-weight:700}
.pseo h2{font-size:clamp(1.4rem,2.6vw,2rem);margin:2.5rem 0 1rem;font-weight:600}
.pseo h3{font-size:1.2rem;margin:1.5rem 0 .6rem;font-weight:600}
.pseo p{margin:.6rem 0}
.pseo a{color:var(--pseo-brand-d);text-decoration:none}
.pseo a:hover{color:var(--pseo-brand);text-decoration:underline}

/* ---- Breadcrumb ---- */
.pseo-crumbs{display:flex;flex-wrap:wrap;gap:.4rem;font-size:.82rem;color:var(--pseo-muted);margin:0 0 1.25rem;letter-spacing:.01em}
.pseo-crumbs a{color:var(--pseo-muted)}
.pseo-crumbs a:hover{color:var(--pseo-brand-d)}
.pseo-crumbs span:not(:last-child)::after{content:"›";margin-left:.4rem;color:var(--pseo-line)}

/* ---- Hero ---- */
/* Full-bleed: the hero band breaks out of the 1250px .pseo column to span the
   entire viewport width, while its inner text stays aligned to the column via
   the column-matched side padding (50vw - half-column + the .pseo gutter). */
.pseo-hero{
  display:grid;
  grid-template-columns:1fr;
  gap:1rem;
  justify-items:center;          /* center each text row horizontally */
  text-align:center;             /* center the text within those rows  */
  background:linear-gradient(135deg,var(--pseo-bg-tint) 0%,var(--pseo-bg) 60%);
  border:1px solid var(--pseo-line);
  border-left:0;
  border-right:0;
  border-radius:0;
  width:100vw;
  max-width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  padding-top:3rem;
  padding-bottom:3rem;
  padding-left:max(1.5rem, calc(50vw - 625px + 1.5rem));
  padding-right:max(1.5rem, calc(50vw - 625px + 1.5rem));
  margin-bottom:1.75rem;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
/* Hero is centered: keep the lede readable + center the meta pills and CTAs. */
.pseo-hero__lede{margin-inline:auto}
.pseo-hero .pseo-meta{justify-content:center}
.pseo-hero .pseo-hero__cta-row{justify-content:center}

/* Homepage (Elementor page 19) hero — center the heading, divider, text,
   icon-list and button in the first section. Scoped to the PAGE BODY
   ([data-elementor-type="wp-page"]) — NOT plain .elementor, which also matches
   the header and was stacking the top-bar email/phone into a column. */
body.page-id-19 [data-elementor-type="wp-page"] > .elementor-element:first-child{ text-align:center; }
body.page-id-19 [data-elementor-type="wp-page"] > .elementor-element:first-child .e-con-inner,
body.page-id-19 [data-elementor-type="wp-page"] > .elementor-element:first-child .e-con{ align-items:center; }
body.page-id-19 [data-elementor-type="wp-page"] > .elementor-element:first-child .elementor-widget-container{ text-align:center; }
body.page-id-19 [data-elementor-type="wp-page"] > .elementor-element:first-child .elementor-icon-list-items{ justify-content:center; display:flex; flex-direction:column; align-items:center; }
body.page-id-19 [data-elementor-type="wp-page"] > .elementor-element:first-child .elementor-divider{ justify-content:center; }
body.page-id-19 [data-elementor-type="wp-page"] > .elementor-element:first-child .elementor-divider-separator{ margin-left:auto; margin-right:auto; }
/* Hero splash image — sits behind the text content, tinted with a brand
   gradient overlay so the H1/lede stays readable. */
.pseo-hero__media{
  position:absolute;
  inset:0;
  z-index:-1;
  overflow:hidden;
  border-radius:inherit;
}
.pseo-hero__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(.85) contrast(.95);
}
.pseo-hero__media-shade{
  position:absolute;
  inset:0;
  background:linear-gradient(105deg,
    rgba(255,248,243,.96) 0%,
    rgba(255,244,235,.86) 35%,
    rgba(255,232,214,.65) 60%,
    rgba(255,232,214,.25) 100%);
}
@media (max-width:768px){
  .pseo-hero{padding-top:2rem;padding-bottom:2rem;padding-left:1.25rem;padding-right:1.25rem}
  .pseo-hero__media-shade{
    background:linear-gradient(180deg,
      rgba(255,248,243,.94) 0%,
      rgba(255,244,235,.90) 60%,
      rgba(255,232,214,.75) 100%);
  }
}
.pseo-hero__eyebrow{display:inline-block;font-size:.78rem;color:var(--pseo-brand-d);font-weight:600;letter-spacing:.08em;text-transform:uppercase;background:var(--pseo-brand-l);padding:.3rem .65rem;border-radius:99px;width:fit-content}
.pseo-hero__lede{color:var(--pseo-text-2);font-size:1.08rem;max-width:62ch;margin:.5rem 0 .25rem}
.pseo-hero__priceline{font-size:1rem;color:var(--pseo-text-2);margin:.85rem 0}
.pseo-hero__priceline strong{font-size:1.7rem;color:var(--pseo-text);font-weight:700;margin-right:.25rem}
.pseo-hero__cta-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.85rem}

/* ---- CTA button — matches Elementor's button shape ---- */
.pseo-cta{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--pseo-brand);color:#fff!important;
  padding:.85rem 1.65rem;border-radius:99px;
  font-weight:600;font-size:1rem;
  text-decoration:none!important;
  border:2px solid var(--pseo-brand);
  transition:background .15s,border-color .15s,transform .12s;
  letter-spacing:.01em;
}
.pseo-cta:hover{background:var(--pseo-brand-d);border-color:var(--pseo-brand-d);transform:translateY(-1px)}
.pseo-cta--ghost{background:transparent;color:var(--pseo-brand-d)!important}
.pseo-cta--ghost:hover{background:var(--pseo-brand);color:#fff!important;border-color:var(--pseo-brand)}
/* "Buy now" CTA — same brand pill but with a stronger shadow for emphasis */
.pseo-cta--buy{
  box-shadow:0 6px 18px -4px rgba(232,135,74,.55);
  font-size:1.05rem;
  padding:.95rem 1.85rem;
}
.pseo-cta--buy:hover{box-shadow:0 8px 22px -4px rgba(232,135,74,.6)}
/* "Buy now" used as the sole hero CTA — larger, more prominent. */
.pseo-cta--xl{
  font-size:1.25rem;
  padding:1.15rem 2.6rem;
  font-weight:700;
}
@media (max-width:600px){
  .pseo-cta--xl{width:100%;justify-content:center}
}

/* ---- Product hub — specifications table ---- */
.pseo-spec-block{margin:2.5rem 0}
.pseo-spec-table{
  background:#fff;
  border:1px solid var(--pseo-line);
  border-radius:12px;
  padding:.4rem 1.2rem;
  box-shadow:var(--pseo-shadow);
}
.pseo-spec-table dl{
  display:grid;
  grid-template-columns:minmax(180px,1fr) minmax(0,2fr);
  gap:0;
  margin:0;
}
.pseo-spec-table dt{
  font-weight:600;
  color:var(--pseo-text-2);
  padding:.85rem 1rem .85rem 0;
  border-bottom:1px solid var(--pseo-line-2);
  font-size:.95rem;
}
.pseo-spec-table dd{
  margin:0;
  padding:.85rem 0;
  border-bottom:1px solid var(--pseo-line-2);
  color:var(--pseo-text);
  font-size:.95rem;
}
.pseo-spec-table dl > dt:last-of-type,
.pseo-spec-table dl > dd:last-of-type{border-bottom:0}
@media (max-width:640px){
  .pseo-spec-table dl{grid-template-columns:1fr}
  .pseo-spec-table dt{padding-bottom:0;border-bottom:0;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;color:var(--pseo-muted)}
  .pseo-spec-table dd{padding-top:.2rem}
}

/* ---- Product hub — coverage estimator grid ---- */
.pseo-coverage{margin:2.5rem 0}
.pseo-coverage__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1rem;
  margin-top:1rem;
}
.pseo-coverage__item{
  background:linear-gradient(160deg,#FFF8F3 0%,#FFE8D6 100%);
  border:1px solid var(--pseo-brand-l);
  border-radius:12px;
  padding:1.4rem 1.2rem;
  display:flex;flex-direction:column;gap:.25rem;
  text-align:left;
}
.pseo-coverage__item strong{
  font-size:1.85rem;line-height:1.05;font-weight:700;
  color:var(--pseo-text);letter-spacing:-.01em;
}
.pseo-coverage__item span{
  font-size:.92rem;font-weight:600;color:var(--pseo-brand-d);
}
.pseo-coverage__item small{
  font-size:.82rem;color:var(--pseo-muted);margin-top:.35rem;
}
@media (max-width:720px){.pseo-coverage__grid{grid-template-columns:1fr}}

/* =========================================================
   COMPARISONS ARCHIVE — /compare/ blog-style card grid.
   ========================================================= */
.pseo-arc-hero{
  padding:2.5rem 0 1.5rem;
  border-bottom:1px solid var(--pseo-line);
  margin-bottom:2rem;
}
.pseo-arc-hero h1{
  font-size:clamp(2rem,4vw,2.75rem);
  margin:.4rem 0 .5rem;
  line-height:1.1;
  letter-spacing:-.01em;
}

/* Filter chips */
.pseo-arc-chips{
  display:flex;flex-wrap:wrap;gap:.5rem;
  margin-top:1.25rem;
}
.pseo-arc-chip{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.5rem 1rem;
  border:1px solid var(--pseo-line);
  border-radius:99px;
  font-size:.88rem;font-weight:600;
  color:var(--pseo-text-2);
  background:#fff;
  text-decoration:none !important;
  transition:background .15s,border-color .15s,color .15s;
}
.pseo-arc-chip:hover{
  border-color:var(--pseo-brand);
  color:var(--pseo-brand-d);
}
.pseo-arc-chip.is-active{
  background:var(--pseo-brand);
  border-color:var(--pseo-brand);
  color:#fff !important;
}

/* Card grid */
.pseo-arc-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:1.5rem;
  margin:1rem 0 2.5rem;
}
@media (max-width:1100px){ .pseo-arc-grid{grid-template-columns:repeat(3,minmax(0,1fr))} }
@media (max-width:820px){  .pseo-arc-grid{grid-template-columns:repeat(2,minmax(0,1fr))} }
@media (max-width:520px){  .pseo-arc-grid{grid-template-columns:1fr} }

.pseo-arc-card{
  display:flex;flex-direction:column;
  background:#fff;
  border:1px solid var(--pseo-line);
  border-radius:14px;
  overflow:hidden;
  text-decoration:none !important;
  color:inherit !important;
  box-shadow:var(--pseo-shadow);
  transition:transform .18s ease, box-shadow .18s ease, border-color .15s;
}
.pseo-arc-card:hover{
  transform:translateY(-3px);
  box-shadow:0 8px 22px -4px rgba(26,26,26,.12), 0 2px 6px rgba(26,26,26,.05);
  border-color:var(--pseo-brand-l);
}

.pseo-arc-card__media{
  position:relative;
  aspect-ratio:16/10;
  background:var(--pseo-bg-soft);
  overflow:hidden;
}
.pseo-arc-card__media img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .35s ease;
}
.pseo-arc-card:hover .pseo-arc-card__media img{ transform:scale(1.04) }

.pseo-arc-card__badge{
  position:absolute;top:.75rem;left:.75rem;
  font-size:.62rem;font-weight:800;letter-spacing:.1em;
  color:#fff;
  padding:.32rem .6rem;
  border-radius:6px;
  box-shadow:0 4px 10px -2px rgba(0,0,0,.25);
}
.pseo-arc-card__badge--vs{
  background:var(--pseo-brand);
}
.pseo-arc-card__badge--best{
  background:#566270;
}

.pseo-arc-card__body{
  padding:1rem 1.15rem 1.25rem;
  display:flex;flex-direction:column;gap:.45rem;flex:1;
}
.pseo-arc-card__title{
  font-size:1.04rem;font-weight:700;line-height:1.25;letter-spacing:-.005em;
  color:var(--pseo-text);
  margin:0;
}
.pseo-arc-card:hover .pseo-arc-card__title{
  color:var(--pseo-brand-d);
}
.pseo-arc-card__meta{
  font-size:.85rem;color:var(--pseo-muted);
  margin:0;line-height:1.45;
}
.pseo-arc-card__cta{
  margin-top:auto;
  font-size:.88rem;font-weight:600;
  color:var(--pseo-brand-d);
  padding-top:.5rem;
}
.pseo-arc-card:hover .pseo-arc-card__cta{ color:var(--pseo-brand) }

/* Pagination */
.pseo-arc-pagination{
  display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem;
  margin:1.5rem 0 3rem;
}
.pseo-arc-pagination a,
.pseo-arc-pagination span{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:42px;padding:.5rem .85rem;
  border:1px solid var(--pseo-line);
  border-radius:8px;
  font-size:.92rem;font-weight:600;
  background:#fff;
  color:var(--pseo-text-2);
  text-decoration:none !important;
  transition:background .15s,border-color .15s;
}
.pseo-arc-pagination a:hover{
  border-color:var(--pseo-brand);
  color:var(--pseo-brand-d);
}
.pseo-arc-pagination .current{
  background:var(--pseo-brand);
  border-color:var(--pseo-brand);
  color:#fff;
}

.pseo-arc-empty{
  padding:3rem 0;text-align:center;
  border:1px dashed var(--pseo-line);border-radius:12px;
  margin:1.5rem 0 3rem;
  background:var(--pseo-bg-soft);
}

/* ---- Comparison: A vs B paired hero cards ---- */
.pseo-cmp-cards{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1.5rem;
  margin:2rem 0;
  position:relative;
  /* Both columns are 1fr (identical width), so any element inside that
     sizes from "100% width + aspect-ratio" gets identical height. The
     VS badge is centred over the gap between the two cards. */
  align-items:stretch;
}
.pseo-cmp-cards::before{
  content:"vs";
  position:absolute;
  left:50%;top:50%;
  transform:translate(-50%,-50%);
  background:var(--pseo-brand);
  color:#fff;
  font-weight:700;font-size:.9rem;
  letter-spacing:.06em;
  padding:.4rem .9rem;
  border-radius:99px;
  z-index:2;
  box-shadow:0 6px 18px -4px rgba(232,135,74,.45);
}
.pseo-cmp-card{
  background:#fff;
  border:1px solid var(--pseo-line);
  border-radius:14px;
  overflow:hidden;
  display:flex;flex-direction:column;
  box-shadow:var(--pseo-shadow);
}
/* Fixed responsive height on the media block: clamp(220, 28vw, 320). Both
   cards' media share this exact value, so the two images are always the
   same height regardless of native aspect ratio. object-fit:cover crops
   any portrait/landscape mismatch into the box. */
.pseo-cmp-card__media{
  display:block;
  height:clamp(220px, 28vw, 320px);
  background:var(--pseo-bg-soft, var(--pseo-line-2));
  overflow:hidden;
}
.pseo-cmp-card__media img{
  width:100% !important;
  height:100% !important;
  max-width:none !important;
  object-fit:cover;
  display:block;
}
.pseo-cmp-card__body{padding:1.1rem 1.3rem 1.3rem}
.pseo-cmp-card__eyebrow{
  display:inline-block;
  font-size:.7rem;font-weight:700;letter-spacing:.12em;
  color:var(--pseo-brand-d);text-transform:uppercase;
  background:var(--pseo-brand-l);padding:.25rem .6rem;border-radius:99px;
  margin-bottom:.55rem;
}
.pseo-cmp-card h3{margin:0 0 .5rem;font-size:1.2rem;font-weight:700;line-height:1.25}
.pseo-cmp-card h3 a{color:var(--pseo-text);text-decoration:none}
.pseo-cmp-card h3 a:hover{color:var(--pseo-brand-d)}
.pseo-cmp-card__specs{list-style:none;padding:0;margin:.4rem 0 0;display:grid;gap:.3rem}
.pseo-cmp-card__specs li{
  display:flex;justify-content:space-between;gap:1rem;
  font-size:.88rem;color:var(--pseo-text);
  padding:.3rem 0;border-bottom:1px solid var(--pseo-line-2);
}
.pseo-cmp-card__specs li:last-child{border-bottom:0}
.pseo-cmp-card__specs li span{color:var(--pseo-muted);font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em}
@media (max-width:720px){
  .pseo-cmp-cards{grid-template-columns:1fr}
  .pseo-cmp-cards::before{position:static;transform:none;display:block;margin:.5rem auto;width:fit-content}
}

/* ---- Comparison: best-for winner card ---- */
.pseo-cmp-winner{
  display:grid;
  grid-template-columns:minmax(220px,300px) 1fr;
  gap:1.5rem;
  margin:2rem 0;
  background:#fff;
  border:1px solid var(--pseo-line);
  border-radius:14px;
  overflow:hidden;
  box-shadow:var(--pseo-shadow-md);
}
.pseo-cmp-winner__media{aspect-ratio:4/3;background:var(--pseo-bg-soft)}
.pseo-cmp-winner__media img{width:100%;height:100%;object-fit:cover;display:block}
.pseo-cmp-winner__body{padding:1.5rem 1.6rem 1.6rem}
.pseo-cmp-winner__body h2{margin:0 0 .5rem;font-size:1.65rem}
.pseo-cmp-winner__body h2 a{color:var(--pseo-text);text-decoration:none}
.pseo-cmp-winner__body h2 a:hover{color:var(--pseo-brand-d)}
.pseo-cmp-winner__meta{color:var(--pseo-text-2);font-size:.95rem;margin:.4rem 0}
.pseo-cmp-winner__line{
  margin-top:.9rem;padding:.7rem 1rem;
  background:linear-gradient(160deg,#FFF8F3 0%,#FFE8D6 100%);
  border-left:3px solid var(--pseo-brand);
  border-radius:0 8px 8px 0;
  font-size:.95rem;
}
@media (max-width:720px){
  .pseo-cmp-winner{grid-template-columns:1fr}
}

/* ---- Comparison: side-by-side table ---- */
.pseo-cmp-table-section{margin:2.5rem 0}
.pseo-cmp-table-wrap{
  overflow-x:auto;
  border:1px solid var(--pseo-line);
  border-radius:12px;
  background:#fff;
  box-shadow:var(--pseo-shadow);
}
.pseo-cmp-table{
  width:100%;
  border-collapse:collapse;
  font-size:.95rem;
  margin:0;
}
.pseo-cmp-table thead th{
  background:var(--pseo-bg-tint);
  color:var(--pseo-brand-d);
  font-weight:700;font-size:.82rem;
  text-transform:uppercase;letter-spacing:.06em;
  text-align:left;
  padding:.85rem 1.1rem;
  border-bottom:1px solid var(--pseo-line);
}
.pseo-cmp-table tbody td{
  padding:.85rem 1.1rem;
  border-bottom:1px solid var(--pseo-line-2);
  vertical-align:top;
}
.pseo-cmp-table tbody tr:last-child td{border-bottom:0}
.pseo-cmp-table tbody td:first-child{
  background:var(--pseo-bg-soft);
  font-weight:600;color:var(--pseo-text);
  min-width:140px;
}
.pseo-cmp-table__pick td{
  background:linear-gradient(90deg,#FFF8F3 0%,#fff 100%);
  position:relative;
}
.pseo-cmp-table__pick td:first-child::before{
  content:"OUR PICK";
  display:inline-block;
  font-size:.62rem;font-weight:800;letter-spacing:.08em;
  color:#fff;background:var(--pseo-brand);
  padding:.18rem .4rem;border-radius:4px;
  margin-right:.5rem;vertical-align:middle;
}

/* ---- Comparison: verdict callout ---- */
.pseo-cmp-verdict{
  margin:2.5rem 0;
  padding:1.6rem 1.8rem;
  background:linear-gradient(160deg,#FFF8F3 0%,#FFE8D6 100%);
  border:1px solid var(--pseo-brand-l);
  border-radius:14px;
}
.pseo-cmp-verdict h2{margin-top:0}
.pseo-cmp-verdict p{margin:.4rem 0 .9rem;line-height:1.6}
.pseo-cmp-verdict__line{
  font-size:1rem;
  padding:.7rem 1rem;
  background:#fff;
  border-left:3px solid var(--pseo-brand);
  border-radius:0 8px 8px 0;
  margin:0 0 1rem;
}

/* ---- Comparison: body content spacing ---- */
.pseo-cmp-body h2{margin-top:2.2rem;font-size:clamp(1.15rem,2vw,1.4rem)}
.pseo-cmp-body p{font-size:1rem;line-height:1.65;color:var(--pseo-text)}

/* ---- Product hub — how-to install steps ---- */
.pseo-howto{margin:2.5rem 0}
.pseo-howto__steps{
  list-style:none;padding:0;margin:1.25rem 0 0;
  display:grid;gap:1rem;
  counter-reset:howto;
}
.pseo-howto__steps > li{
  display:flex;gap:1rem;align-items:flex-start;
  background:#fff;
  border:1px solid var(--pseo-line);
  border-radius:12px;
  padding:1.1rem 1.3rem;
  box-shadow:var(--pseo-shadow);
}
.pseo-howto__num{
  flex-shrink:0;
  width:36px;height:36px;
  display:grid;place-items:center;
  border-radius:99px;
  background:var(--pseo-brand);color:#fff;
  font-weight:700;font-size:.95rem;
}
.pseo-howto__steps strong{
  display:block;font-size:1.02rem;font-weight:700;
  margin-bottom:.2rem;color:var(--pseo-text);
}
.pseo-howto__steps p{margin:0;font-size:.92rem;color:var(--pseo-text-2);line-height:1.55}

/* ---- Spec / metadata pills ---- */
.pseo-meta{display:flex;flex-wrap:wrap;gap:.5rem .9rem;color:var(--pseo-text-2);font-size:.92rem;margin:.5rem 0}
.pseo-meta span{display:inline-flex;align-items:center;gap:.3rem;background:#fff;padding:.35rem .7rem;border:1px solid var(--pseo-line);border-radius:99px;font-size:.85rem}
.pseo-meta b{color:var(--pseo-text);font-weight:600}

/* ---- Price tier table ---- */
.pseo-table{
  width:100%;border-collapse:separate;border-spacing:0;
  margin:1rem 0;background:#fff;
  border:1px solid var(--pseo-line);border-radius:var(--pseo-radius);
  overflow:hidden;box-shadow:var(--pseo-shadow);
}
.pseo-table th,.pseo-table td{padding:.9rem 1rem;text-align:left;border-bottom:1px solid var(--pseo-line-2);font-size:.97rem}
.pseo-table th{background:var(--pseo-bg-soft);font-weight:600;color:var(--pseo-text);text-transform:uppercase;font-size:.78rem;letter-spacing:.06em}
.pseo-table tr:last-child td{border-bottom:0}
.pseo-table tr:hover td{background:var(--pseo-bg-tint)}
.pseo-table .pseo-table__price{font-weight:700;color:var(--pseo-brand-d);font-size:1.05rem}

/* ---- Card grids (related products, calculators, locations) ---- */
.pseo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin:1rem 0}
.pseo-card{
  display:block;background:#fff;
  border:1px solid var(--pseo-line);border-radius:var(--pseo-radius);
  padding:1.15rem 1.25rem;color:inherit;
  box-shadow:var(--pseo-shadow);
  text-decoration:none;transition:border-color .15s,box-shadow .15s,transform .12s;
  position:relative;
}
.pseo-card:hover{border-color:var(--pseo-brand);box-shadow:var(--pseo-shadow-md);transform:translateY(-2px);text-decoration:none}
.pseo-card strong{display:block;color:var(--pseo-text);margin-bottom:.25rem;font-size:1.02rem;font-weight:600}
.pseo-card span{color:var(--pseo-muted);font-size:.88rem;display:block}
.pseo-card::after{content:"→";position:absolute;right:1rem;top:1.15rem;color:var(--pseo-brand);opacity:0;transition:opacity .15s,transform .15s;font-weight:700}
.pseo-card:hover::after{opacity:1;transform:translateX(2px)}

/* ---- FAQ accordion ---- */
.pseo-faq{margin:2.5rem 0}
.pseo-faq__list{display:grid;gap:.6rem}
.pseo-faq__item{border:1px solid var(--pseo-line);border-radius:var(--pseo-radius);background:#fff;overflow:hidden;transition:border-color .15s}
.pseo-faq__item[open]{border-color:var(--pseo-brand)}
.pseo-faq__item summary{padding:1rem 3rem 1rem 1.15rem;cursor:pointer;list-style:none;font-weight:600;position:relative;font-size:1.02rem;line-height:1.4;color:var(--pseo-text)}
.pseo-faq__item summary::-webkit-details-marker{display:none}
.pseo-faq__item summary::after{content:"+";position:absolute;right:1.15rem;top:50%;transform:translateY(-50%);color:var(--pseo-brand);font-weight:700;font-size:1.3rem;width:1.8rem;height:1.8rem;display:grid;place-items:center;background:var(--pseo-brand-l);border-radius:50%;transition:transform .2s}
.pseo-faq__item[open] summary::after{content:"−"}
.pseo-faq__item>div{padding:0 1.15rem 1.15rem;color:var(--pseo-text-2);line-height:1.65}

/* ---- Calculator widget ---- */
.pseo-calc{background:var(--pseo-bg-tint);border:1px solid var(--pseo-line);border-radius:var(--pseo-radius);padding:1.5rem;margin:1.5rem 0;box-shadow:var(--pseo-shadow)}
.pseo-calc__title{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:var(--pseo-text)}
.pseo-calc__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.85rem}
.pseo-calc__grid label{display:flex;flex-direction:column;font-size:.85rem;color:var(--pseo-muted);gap:.35rem;font-weight:500}
.pseo-calc__grid input{padding:.7rem .85rem;border:1px solid var(--pseo-line);border-radius:var(--pseo-radius-sm);font-size:1rem;background:#fff;font-family:inherit;transition:border-color .15s,box-shadow .15s}
.pseo-calc__grid input:focus{outline:none;border-color:var(--pseo-brand);box-shadow:0 0 0 3px var(--pseo-brand-l)}
.pseo-calc__out{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-top:1.1rem}
.pseo-calc__out>div{background:#fff;border:1px solid var(--pseo-line);border-radius:var(--pseo-radius-sm);padding:.75rem 1rem;text-align:center}
.pseo-calc__out span{display:block;font-size:.72rem;color:var(--pseo-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.pseo-calc__out strong{font-size:1.4rem;color:var(--pseo-brand-d);font-weight:700;display:block;margin-top:.2rem}
.pseo-calc__note{margin:.85rem 0 0;font-size:.83rem;color:var(--pseo-muted);font-style:italic}

/* ---- Local product cards (Location page) — replaces the pricing table ---- */
.mygb-prodcards{margin:2.5rem 0}
.mygb-prodcards__head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:1rem;flex-wrap:wrap;
  margin-bottom:1.25rem;
}
.mygb-prodcards__head .pseo-linkgrp__title{margin:.25rem 0 0}
.mygb-prodcards__grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:1.25rem;
}
.mygb-prodcard{
  display:flex;flex-direction:column;
  background:#fff;
  border:1px solid var(--pseo-line);
  border-radius:14px;
  overflow:hidden;
  text-decoration:none !important;
  color:inherit !important;
  box-shadow:var(--pseo-shadow);
  transition:transform .15s ease, box-shadow .18s ease, border-color .12s;
}
.mygb-prodcard:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 32px -10px rgba(232,135,74,.25), 0 2px 6px rgba(0,0,0,.05);
  border-color:var(--pseo-brand);
  text-decoration:none !important;
}
.mygb-prodcard__media{
  position:relative;
  aspect-ratio:16/10;
  overflow:hidden;
  background:var(--pseo-bg-soft);
}
.mygb-prodcard__media img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  transition:transform .4s ease;
}
.mygb-prodcard:hover .mygb-prodcard__media img{transform:scale(1.04)}
.mygb-prodcard__price{
  position:absolute;
  top:.85rem;left:.85rem;
  background:#fff;
  color:var(--pseo-brand-d);
  font-weight:700;font-size:.78rem;letter-spacing:.02em;
  padding:.35rem .7rem;
  border-radius:99px;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
  border:1px solid var(--pseo-brand-l);
}
.mygb-prodcard__price--quote{
  background:rgba(255,255,255,.92);
  color:var(--pseo-text-2);
  border-color:var(--pseo-line);
  font-weight:600;
}
.mygb-prodcard--remote{
  /* slightly subdued for products without local pricing */
  background:var(--pseo-bg-soft);
}
.mygb-prodcard--remote .mygb-prodcard__media img{
  opacity:.92;
}
.mygb-prodcard__body{
  padding:1rem 1.15rem 1.15rem;
  display:flex;flex-direction:column;gap:.65rem;
  flex:1;
}
.mygb-prodcard__name{
  font-size:1.08rem;font-weight:700;color:var(--pseo-text);
  line-height:1.2;letter-spacing:-.005em;
}
.mygb-prodcard__cat{
  display:block;
  font-size:.7rem;font-weight:600;letter-spacing:.08em;
  color:var(--pseo-muted);text-transform:uppercase;
  margin-top:-.25rem;
}
.mygb-prodcard__specs{
  list-style:none;padding:0;margin:0;
  display:grid;
  grid-template-columns:1fr;
  gap:.25rem;
}
.mygb-prodcard__specs li{
  font-size:.82rem;color:var(--pseo-text-2);
  display:flex;justify-content:space-between;gap:.5rem;
  padding:.3rem 0;
  border-bottom:1px solid var(--pseo-line-2);
}
.mygb-prodcard__specs li:last-child{border-bottom:0}
.mygb-prodcard__specs li span{color:var(--pseo-muted);font-weight:500;text-transform:uppercase;font-size:.7rem;letter-spacing:.06em}
.mygb-prodcard__cta{
  margin-top:auto;
  font-size:.86rem;font-weight:600;
  color:var(--pseo-brand-d);
  padding:.55rem 0 .15rem;
  border-top:1px dashed var(--pseo-line);
  transition:color .12s, transform .12s;
}
.mygb-prodcard:hover .mygb-prodcard__cta{color:var(--pseo-brand)}
@media (max-width:640px){
  .mygb-prodcards__grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.85rem}
  .mygb-prodcard__body{padding:.75rem .85rem .85rem}
  .mygb-prodcard__name{font-size:.95rem}
}

/* ---- State hub (/delivery/[state]/) ---- */
.mygb-state-stats{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:1rem;
  margin:1.5rem 0 2rem;
  background:var(--pseo-bg-tint);
  border:1px solid var(--pseo-line);
  border-radius:14px;
  padding:1.25rem 1.5rem;
}
.mygb-state-stat{text-align:center}
.mygb-state-stat strong{
  display:block;
  font-size:1.85rem;font-weight:700;color:var(--pseo-brand-d);
  letter-spacing:-.02em;line-height:1;
}
.mygb-state-stat span{
  display:block;
  margin-top:.3rem;
  font-size:.82rem;color:var(--pseo-muted);font-weight:500;
}

/* Dense city grid for state hubs */
.pseo-grid--dense{
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:.65rem;
}
.pseo-grid--dense .pseo-card{
  padding:.85rem 1rem;
}
.pseo-grid--dense .pseo-card strong{font-size:.95rem}
.pseo-grid--dense .pseo-card span{font-size:.78rem}

/* ---- Link group (rule-driven cross-cluster links) ---- */
.pseo-linkgrp{margin:2rem 0}
.pseo-linkgrp__eyebrow{
  display:inline-block;
  font-size:.7rem;font-weight:700;letter-spacing:.12em;
  color:var(--pseo-brand-d);text-transform:uppercase;
  background:var(--pseo-brand-l);
  padding:.25rem .65rem;border-radius:99px;
  margin-bottom:.5rem;
}
.pseo-linkgrp__title{
  margin:.25rem 0 1rem;
  font-size:1.35rem;font-weight:700;color:var(--pseo-text);
  letter-spacing:-.01em;
}

/* ---- Mid-content CTA band (mygb_pseo_inline_cta_band) ---- */
.pseo-cta-band{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.5rem;
  margin:1.75rem 0;
  padding:1.3rem 1.6rem;
  background:linear-gradient(135deg, rgba(232,135,74,.08) 0%, rgba(232,135,74,.02) 100%);
  border:1px solid rgba(232,135,74,.25);
  border-left:4px solid var(--pseo-brand);
  border-radius:14px;
}
.pseo-cta-band__text{ flex:1 1 auto; min-width:0; }
.pseo-cta-band__eyebrow{
  display:inline-block;
  font-size:.7rem;font-weight:700;letter-spacing:.14em;
  color:var(--pseo-brand-d);text-transform:uppercase;
  margin-bottom:.35rem;
}
.pseo-cta-band__title{
  margin:0 0 .35rem;
  font-size:1.2rem;font-weight:700;color:var(--pseo-text);
  letter-spacing:-.01em;line-height:1.25;
}
.pseo-cta-band__body{
  margin:0;color:var(--pseo-muted);
  font-size:.95rem;line-height:1.5;max-width:48rem;
}
.pseo-cta-band__actions{
  display:flex;align-items:center;gap:.55rem;flex-shrink:0;flex-wrap:wrap;
}
@media (max-width:720px){
  .pseo-cta-band{
    flex-direction:column;
    align-items:flex-start;
    padding:1.15rem 1.2rem;
  }
  .pseo-cta-band__actions{ width:100%; }
  .pseo-cta-band__actions .pseo-cta,
  .pseo-cta-band__actions .pseo-cta--ghost{ flex:1 1 auto;justify-content:center;text-align:center; }
}

/* ---- Inline product anchor (body-content autolinks) ---- */
.pseo-inline-prod{
  color:var(--pseo-brand-d);
  text-decoration:underline;
  text-decoration-color:rgba(232,135,74,.4);
  text-decoration-thickness:1.5px;
  text-underline-offset:2.5px;
  font-weight:500;
  transition:color .12s ease, text-decoration-color .12s ease;
}
.pseo-inline-prod:hover,
.pseo-inline-prod:focus-visible{
  color:var(--pseo-brand);
  text-decoration-color:var(--pseo-brand);
}

/* ---- Paragraph-anchored inline CTA inside article bodies ---- */
.pseo-cta-inline{
  margin:1.25rem 0;
  padding:.7rem 1.05rem;
  border-left:3px solid var(--pseo-brand);
  background:var(--pseo-bg-tint, #fafafa);
  border-radius:0 8px 8px 0;
  font-size:.95rem;
  font-style:italic;
}
.pseo-cta-inline .pseo-cta--ghost{
  font-style:normal;
  font-weight:600;
}

/* ---- ZIP-input CTA (extends .pseo-cta-band) ---------------------------
   The form sits in the band's actions slot and reads as a single, weighty
   pill: white background, brand accent, with the input visually anchored
   by a small map-pin icon. Hover/focus lifts the pill and tints the ring.
   ---------------------------------------------------------------------- */
.pseo-cta-zip{
  background:linear-gradient(135deg, rgba(232,135,74,.10) 0%, rgba(232,135,74,.04) 100%);
  flex-wrap:wrap;                 /* let the multi-field form drop to its own row */
}
/* Stack: intro text on top, the name+mobile+ZIP form full-width below it. */
.pseo-cta-zip > .pseo-cta-band__text{ flex:1 1 100%; }
.pseo-cta-zip form.pseo-cta-band__actions{
  display:flex;
  flex-wrap:wrap;
  align-items:stretch;
  gap:.5rem;
  flex:1 1 100%;
  width:100%;
  margin-top:.25rem;
}
/* Each field is its own rounded pill — all three share equal width. */
.pseo-cta-zip .pseo-zip-field{
  flex:1 1 0;
  min-width:0;
  border:1.5px solid rgba(232,135,74,.3);
  border-radius:99px;
  background:#fff;
  margin:0;
  padding:.72rem 1.05rem;
  font:inherit;
  font-size:1rem;
  font-weight:600;
  color:var(--pseo-text);
  outline:none;
  box-shadow:0 2px 6px -2px rgba(26,26,26,.07);
  transition:border-color .15s ease, box-shadow .15s ease;
}
.pseo-cta-zip .pseo-zip-field:hover{ border-color:rgba(232,135,74,.5); }
.pseo-cta-zip .pseo-zip-field:focus{
  border-color:var(--pseo-brand);
  box-shadow:0 0 0 4px rgba(232,135,74,.16);
}
.pseo-cta-zip .pseo-zip-field::placeholder{ color:#94989F;font-weight:500;letter-spacing:.01em; }
.pseo-cta-zip .pseo-zip-field:focus::placeholder{ opacity:.55; }
.pseo-cta-zip .pseo-zip-field:-webkit-autofill{
  -webkit-text-fill-color:var(--pseo-text);
  box-shadow:0 0 0 1000px #fff inset;
}
/* The ZIP field keeps the map-pin icon (name/mobile don't) but matches width. */
.pseo-cta-zip .pseo-zip-field--zip{
  flex:1 1 0;
  letter-spacing:.06em;
  font-variant-numeric:tabular-nums;
  padding-left:2.4rem;
  background:#fff
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23E8874A' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><path d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/><circle cx='12' cy='10' r='3'/></svg>")
    no-repeat .8rem center;
  background-size:1.05rem 1.05rem;
}
/* Validation / error message under the fields. */
.pseo-zip-error{
  flex-basis:100%;
  width:100%;
  margin:.15rem 0 0;
  color:#c0392b;
  font-size:.85rem;
  font-weight:600;
}
.pseo-zip-error[hidden]{ display:none; }
.pseo-cta-zip button{
  position:relative;
  /* Belt-and-braces rounded clipping: overflow:hidden + clip-path. The
     clip-path is the load-bearing one — Chrome/Safari can render
     border-radius corners flat when overflow:hidden meets a transformed
     compositing layer, but clip-path with `round` survives the transform.
     will-change promotes the layer up-front so the corners don't flicker
     on the first hover. */
  overflow:hidden;
  clip-path:inset(0 round 999px);
  will-change:transform;
  display:inline-flex;
  align-items:center;
  gap:.45em;
  flex:0 0 auto;
  border:0;
  cursor:pointer;
  color:#fff;
  font:inherit;
  font-weight:700;
  font-size:.95rem;
  padding:.75rem 1.55rem;
  border-radius:99px;
  letter-spacing:.02em;
  white-space:nowrap;
  /* Subtle vertical gradient gives the pill depth even at rest */
  background:linear-gradient(180deg, var(--pseo-brand) 0%, var(--pseo-brand-d) 100%);
  box-shadow:
    0 4px 10px -2px rgba(232,135,74,.55),
    inset 0 1px 0 rgba(255,255,255,.18);
  transition:
    transform .18s cubic-bezier(.34, 1.3, .64, 1),
    box-shadow .2s ease,
    filter .15s ease,
    letter-spacing .25s ease;
}
/* Animated arrow rendered via pseudo so the helper can stay markup-free */
.pseo-cta-zip button::after{
  content:"\2192"; /* → */
  display:inline-block;
  font-weight:800;
  transform:translateX(0);
  transition:transform .28s cubic-bezier(.34, 1.3, .64, 1);
}
/* Shimmer pass — a diagonal highlight that sweeps across on hover.
   Clipped by overflow:hidden + border-radius so it follows the pill. */
.pseo-cta-zip button::before{
  content:"";
  position:absolute;
  top:0;
  left:-80%;
  width:55%;
  height:100%;
  background:linear-gradient(110deg,
    transparent 0%,
    rgba(255,255,255,.18) 40%,
    rgba(255,255,255,.55) 50%,
    rgba(255,255,255,.18) 60%,
    transparent 100%);
  transform:skewX(-22deg);
  pointer-events:none;
  transition:left .65s cubic-bezier(.4, 0, .2, 1);
}
.pseo-cta-zip button:hover{
  transform:translateY(-2px);
  letter-spacing:.04em;
  filter:saturate(1.15);
  box-shadow:
    0 10px 22px -4px rgba(232,135,74,.7),
    0 2px 4px -1px rgba(26,26,26,.12),
    inset 0 1px 0 rgba(255,255,255,.3);
}
.pseo-cta-zip button:hover::after{
  transform:translateX(5px);
  animation:pseo-cta-zip-bob .9s ease-in-out .3s infinite;
}
.pseo-cta-zip button:hover::before{
  left:135%;
}
.pseo-cta-zip button:active{
  transform:translateY(0) scale(.97);
  transition-duration:.08s;
  box-shadow:
    0 2px 6px -1px rgba(232,135,74,.5),
    inset 0 1px 0 rgba(255,255,255,.18),
    inset 0 -1px 2px rgba(0,0,0,.12);
}
.pseo-cta-zip button:active::after{
  transform:translateX(3px);
  animation:none;
}
.pseo-cta-zip button:focus-visible{
  outline:2px solid #fff;
  outline-offset:-3px;
  box-shadow:
    0 0 0 3px var(--pseo-brand),
    0 4px 10px -2px rgba(232,135,74,.55),
    inset 0 1px 0 rgba(255,255,255,.18);
}
@keyframes pseo-cta-zip-bob{
  0%, 100% { transform:translateX(5px); }
  50%      { transform:translateX(9px); }
}
@media (prefers-reduced-motion: reduce){
  .pseo-cta-zip button,
  .pseo-cta-zip button::after,
  .pseo-cta-zip button::before{
    transition-duration:.05s !important;
    animation:none !important;
  }
  .pseo-cta-zip button:hover{ transform:none; letter-spacing:.02em; }
  .pseo-cta-zip button:hover::after{ transform:translateX(3px); }
}
@media (max-width:720px){
  .pseo-cta-zip form.pseo-cta-band__actions{
    width:100%;
    min-width:0;
  }
}
@media (max-width:420px){
  .pseo-cta-zip form.pseo-cta-band__actions{
    flex-direction:column;
    gap:.5rem;
  }
  .pseo-cta-zip .pseo-zip-field{
    flex:1 1 auto;
    width:100%;
    border-radius:12px;
  }
  .pseo-cta-zip button{
    width:100%;
    border-radius:12px;
    padding:.75rem 1rem;
  }
}

/* Inline product-name span used by mygb_pseo_product_link() when the
   product is self-referential (page is about this product). Keeps the
   word styled like a link target without actually linking. */
.pseo-prodname{ font-weight:600; color:var(--pseo-text); }

/* =========================================================
   PRODUCT CAROUSEL (mygb_pseo_render_products_filter)
   Category-filtered, scroll-snap, 4-per-row on desktop.
   Cards mirror the .mygb-prodcard pattern (image + price badge,
   name, category, specs list, CTA hint).
   ========================================================= */
.pseo-pgrid{
  --pseo-pgrid-gap: 1.1rem;
  --pseo-pgrid-visible: 4;
  margin:2.5rem 0;
}
.pseo-pgrid__header{ margin:0 0 1.1rem; }
.pseo-pgrid__eyebrow{
  display:inline-block;
  font-size:.7rem;font-weight:700;letter-spacing:.14em;
  color:var(--pseo-brand-d);text-transform:uppercase;
  background:var(--pseo-brand-l, rgba(232,135,74,.18));
  padding:.28rem .7rem;border-radius:99px;
  margin-bottom:.5rem;
}
.pseo-pgrid__title{
  margin:.25rem 0 0;
  font-size:clamp(1.3rem, 2vw, 1.6rem);
  font-weight:700;color:var(--pseo-text);
  letter-spacing:-.01em;
}

/* --- Filter pill rail ---------------------------------------------- */
.pseo-pgrid__filter{
  display:flex;
  flex-wrap:nowrap;
  gap:.45rem;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scroll-snap-type:x proximity;
  padding:.3rem .25rem 1rem;
  margin:0 -.25rem 1.1rem;
  scrollbar-width:none;
}
.pseo-pgrid__filter::-webkit-scrollbar{ display:none; }
.pseo-pgrid__filter button{
  flex:0 0 auto;
  position:relative;
  cursor:pointer;
  scroll-snap-align:start;
  border:1.5px solid var(--pseo-line-2);
  background:#fff;
  color:var(--pseo-text);
  padding:.55rem 1.15rem;
  border-radius:99px;
  /* Belt-and-braces rounded clipping for the hover/selected transform.
     Chrome/Safari can render the border-radius corners flat when a pill
     gets promoted to its own compositing layer by `transform` — the
     same bug fixed on .pseo-cta-zip button. clip-path with `round` is
     applied at the compositor level and survives the transform.
     will-change promotes the layer up-front so corners don't flicker. */
  clip-path:inset(0 round 999px);
  will-change:transform;
  font:inherit;font-weight:600;font-size:.9rem;
  letter-spacing:.01em;
  white-space:nowrap;
  box-shadow:0 1px 2px -1px rgba(26,26,26,.08);
  transition:
    background .18s ease,
    color .15s ease,
    border-color .15s ease,
    transform .14s cubic-bezier(.34, 1.3, .64, 1),
    box-shadow .18s ease,
    letter-spacing .2s ease;
}
.pseo-pgrid__filter button:hover{
  border-color:rgba(232,135,74,.6);
  color:var(--pseo-brand-d);
  background:rgba(232,135,74,.04);
  transform:translateY(-2px);
  box-shadow:
    0 0 0 4px rgba(232,135,74,.14),
    0 6px 14px -4px rgba(232,135,74,.4),
    0 2px 4px -1px rgba(26,26,26,.06);
}
.pseo-pgrid__filter button[aria-selected="true"]{
  background:linear-gradient(180deg, var(--pseo-brand) 0%, var(--pseo-brand-d) 100%);
  color:#fff;
  border-color:var(--pseo-brand);
  letter-spacing:.03em;
  box-shadow:
    0 8px 18px -4px rgba(232,135,74,.55),
    0 2px 4px -1px rgba(26,26,26,.1),
    inset 0 1px 0 rgba(255,255,255,.22);
}
.pseo-pgrid__filter button[aria-selected="true"]:hover{
  transform:translateY(-2px);
  filter:saturate(1.15);
  box-shadow:
    0 0 0 4px rgba(232,135,74,.22),
    0 10px 22px -4px rgba(232,135,74,.6),
    0 2px 4px -1px rgba(26,26,26,.1),
    inset 0 1px 0 rgba(255,255,255,.22);
}
.pseo-pgrid__filter button:active{ transform:translateY(0); transition-duration:.08s; }
.pseo-pgrid__filter button:focus-visible{
  outline:2px solid var(--pseo-brand);
  outline-offset:3px;
}

/* --- Carousel container & track ------------------------------------ */
.pseo-pgrid__carousel{
  position:relative;
  /* Reserve room on the sides so the arrow buttons sit fully OUTSIDE the
     card row instead of overlapping it. --nav-size is the arrow's outer
     width; the carousel reserves nav-size + .75rem of breathing room per
     side. On <=720px the arrows are hidden, so we reset the padding. */
  --pseo-pgrid-nav-size:38px;
  padding-left:calc(var(--pseo-pgrid-nav-size) + .75rem);
  padding-right:calc(var(--pseo-pgrid-nav-size) + .75rem);
}
.pseo-pgrid__track{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:calc((100% - (var(--pseo-pgrid-visible) - 1) * var(--pseo-pgrid-gap)) / var(--pseo-pgrid-visible));
  gap:var(--pseo-pgrid-gap);
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  scrollbar-width:thin;
  padding:.4rem .15rem 1.25rem;
  margin:0;
}
.pseo-pgrid__track::-webkit-scrollbar{ height:6px; }
.pseo-pgrid__track::-webkit-scrollbar-thumb{
  background:rgba(0,0,0,.12);
  border-radius:99px;
}

/* --- Cards (mirror .mygb-prodcard layout) -------------------------- */
.pseo-pgrid__card{
  display:flex;
  flex-direction:column;
  scroll-snap-align:start;
  background:#fff;
  border:1px solid var(--pseo-line);
  border-radius:14px;
  overflow:hidden;
  text-decoration:none !important;
  color:var(--pseo-text) !important;
  box-shadow:var(--pseo-shadow, 0 1px 2px rgba(0,0,0,.04));
  transition:transform .15s ease, box-shadow .18s ease, border-color .12s;
  min-width:0;
}
.pseo-pgrid__card:hover,
.pseo-pgrid__card:focus-visible{
  border-color:var(--pseo-brand);
  box-shadow:0 16px 32px -10px rgba(232,135,74,.25), 0 2px 6px rgba(0,0,0,.05);
  transform:translateY(-3px);
  outline:0;
}
.pseo-pgrid__card.is-hidden{ display:none; }

.pseo-pgrid__media{
  position:relative;
  aspect-ratio:16 / 10;
  overflow:hidden;
  background:var(--pseo-bg-soft, var(--pseo-line-2));
}
.pseo-pgrid__img{
  width:100% !important;
  height:100% !important;
  object-fit:cover;
  display:block;
  max-width:none !important;
  transition:transform .4s ease;
}
.pseo-pgrid__card:hover .pseo-pgrid__img{ transform:scale(1.05); }
.pseo-pgrid__img--ph{
  display:block;
  width:100%;height:100%;
  background:linear-gradient(135deg, var(--pseo-line-2) 0%, #fff 100%);
}
.pseo-pgrid__price{
  position:absolute;
  top:.7rem;left:.7rem;
  background:#fff;
  color:var(--pseo-brand-d);
  font-weight:700;font-size:.75rem;letter-spacing:.02em;
  padding:.32rem .65rem;
  border-radius:99px;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
  border:1px solid var(--pseo-brand-l);
  white-space:nowrap;
}
.pseo-pgrid__price--quote{
  background:rgba(255,255,255,.92);
  color:var(--pseo-text-2, var(--pseo-muted));
  border-color:var(--pseo-line);
  font-weight:600;
}

.pseo-pgrid__body{
  padding:.95rem 1rem 1rem;
  display:flex;flex-direction:column;gap:.55rem;
  flex:1;
}
.pseo-pgrid__name{
  font-size:1.02rem;font-weight:700;color:var(--pseo-text);
  line-height:1.22;letter-spacing:-.005em;
}
.pseo-pgrid__cat{
  display:block;
  font-size:.68rem;font-weight:600;letter-spacing:.08em;
  color:var(--pseo-muted);text-transform:uppercase;
  margin-top:-.3rem;
}
.pseo-pgrid__specs{
  list-style:none;padding:0;margin:0;
  display:grid;
  grid-template-columns:1fr;
  gap:0;
}
.pseo-pgrid__specs li{
  font-size:.8rem;color:var(--pseo-text-2, var(--pseo-text));
  display:flex;justify-content:space-between;align-items:baseline;gap:.5rem;
  padding:.32rem 0;
  border-bottom:1px solid var(--pseo-line-2);
}
.pseo-pgrid__specs li:last-child{ border-bottom:0; }
.pseo-pgrid__specs li span{
  color:var(--pseo-muted);
  font-weight:500;text-transform:uppercase;
  font-size:.66rem;letter-spacing:.06em;
}
.pseo-pgrid__cta{
  margin-top:auto;
  font-size:.86rem;font-weight:700;
  color:var(--pseo-brand-d);
  display:inline-flex;align-items:center;gap:.25rem;
  transition:color .15s ease, transform .15s ease;
}
.pseo-pgrid__card:hover .pseo-pgrid__cta{
  color:var(--pseo-brand);
  transform:translateX(2px);
}

/* --- Nav arrows (carousel prev/next) ------------------------------- */
/* Square button with a small 8px corner radius — clean, modern, reads
   as a navigation control (not a generic round icon). Flat white fill,
   hairline border, single drop shadow, stroked SVG arrow with shaft +
   arrowhead. Sits fully outside the card row thanks to the carousel
   container's side padding. */
.pseo-pgrid__nav{
  position:absolute;
  top:calc(50% - 12px);
  transform:translateY(-50%);
  width:var(--pseo-pgrid-nav-size, 40px);
  height:var(--pseo-pgrid-nav-size, 40px);
  border-radius:8px;
  /* clip-path with rounded inset keeps the corners truly rounded on
     transform-promoted compositing layers (Chrome/Safari bug). */
  clip-path:inset(0 round 8px);
  will-change:transform;
  background:#fff;
  border:1px solid var(--pseo-line);
  color:var(--pseo-text);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  padding:0;
  box-shadow:0 1px 2px rgba(26,26,26,.06), 0 4px 10px -3px rgba(26,26,26,.12);
  transition:
    background .18s ease,
    border-color .15s ease,
    color .15s ease,
    transform .16s cubic-bezier(.34, 1.3, .64, 1),
    box-shadow .18s ease,
    opacity .15s ease;
  z-index:2;
}
.pseo-pgrid__nav--prev{ left:0; }
.pseo-pgrid__nav--next{ right:0; }
.pseo-pgrid__nav-icon{
  display:block;
  flex-shrink:0;
  transition:transform .2s cubic-bezier(.34, 1.3, .64, 1);
  pointer-events:none;
}
.pseo-pgrid__nav:hover{
  background:var(--pseo-brand);
  border-color:var(--pseo-brand);
  color:#fff;
  transform:translateY(-50%) translateY(-1px);
  box-shadow:
    0 2px 4px rgba(26,26,26,.08),
    0 8px 18px -4px rgba(232,135,74,.55);
}
.pseo-pgrid__nav--prev:hover .pseo-pgrid__nav-icon{ transform:translateX(-3px); }
.pseo-pgrid__nav--next:hover .pseo-pgrid__nav-icon{ transform:translateX(3px); }
.pseo-pgrid__nav:active{
  transform:translateY(-50%) translateY(1px);
  transition-duration:.08s;
  box-shadow:0 1px 2px rgba(26,26,26,.08);
}
.pseo-pgrid__nav:focus-visible{
  outline:none;
  box-shadow:
    0 0 0 3px rgba(232,135,74,.4),
    0 1px 2px rgba(26,26,26,.06),
    0 4px 10px -3px rgba(26,26,26,.12);
}
.pseo-pgrid__nav[disabled]{
  opacity:.3;
  cursor:not-allowed;
  pointer-events:none;
  box-shadow:none;
  background:#fafafa;
}
.pseo-pgrid.is-static .pseo-pgrid__carousel{
  padding-left:0;
  padding-right:0;
}
.pseo-pgrid.is-static .pseo-pgrid__nav{ display:none; }
.pseo-pgrid.is-static .pseo-pgrid__track{ scroll-snap-type:none; }

/* --- Grid mode (mygb_pseo_render_wc_shop_grid, etc.) ---------------
   Drops the carousel: track wraps to multiple rows, no horizontal
   scroll, no nav arrows. Filter pills still work to hide/show cards.
   Used on /shop/ and any caller that passes mode='grid'. */
.pseo-pgrid--grid .pseo-pgrid__carousel{
  padding-left:0 !important;
  padding-right:0 !important;
}
.pseo-pgrid--grid .pseo-pgrid__nav{ display:none !important; }

/* ---- Related guides cards (thumbnail-rich) ---------------------- */
.pseo-rg{ margin:2.5rem 0; }
.pseo-rg__head{ margin:0 0 1.1rem; }
.pseo-rg__eyebrow{
  display:inline-block;
  font-size:.7rem;font-weight:700;letter-spacing:.14em;
  color:var(--pseo-brand-d);text-transform:uppercase;
  background:var(--pseo-brand-l, rgba(232,135,74,.18));
  padding:.28rem .7rem;border-radius:99px;
  margin-bottom:.5rem;
}
.pseo-rg__title{
  margin:.25rem 0 0;
  font-size:clamp(1.3rem, 2vw, 1.6rem);
  font-weight:700;color:var(--pseo-text);
  letter-spacing:-.01em;
}
.pseo-rg__grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:1.1rem;
}
.pseo-rg-card{
  display:flex;flex-direction:column;
  background:#fff;
  border:1px solid var(--pseo-line);
  border-radius:14px;
  overflow:hidden;
  text-decoration:none !important;
  color:var(--pseo-text) !important;
  box-shadow:var(--pseo-shadow, 0 1px 2px rgba(0,0,0,.04));
  transition:transform .15s ease, box-shadow .18s ease, border-color .12s;
}
.pseo-rg-card:hover,
.pseo-rg-card:focus-visible{
  border-color:var(--pseo-brand);
  box-shadow:0 16px 32px -10px rgba(232,135,74,.25), 0 2px 6px rgba(0,0,0,.05);
  transform:translateY(-3px);
  outline:0;
}
.pseo-rg-card__media{
  display:block;
  aspect-ratio:16 / 10;
  overflow:hidden;
  background:var(--pseo-bg-soft, var(--pseo-line-2));
}
.pseo-rg-card__media img{
  width:100% !important;
  height:100% !important;
  object-fit:cover;
  display:block;
  max-width:none !important;
  transition:transform .4s ease;
}
.pseo-rg-card:hover .pseo-rg-card__media img{ transform:scale(1.05); }
.pseo-rg-card__media--ph{
  display:block;
  width:100%;height:100%;
  background:linear-gradient(135deg, var(--pseo-line-2) 0%, #fff 100%);
}
.pseo-rg-card__body{
  display:flex;flex-direction:column;gap:.5rem;
  padding:1rem 1.1rem 1.1rem;
  flex:1;
}
.pseo-rg-card__eyebrow{
  font-size:.66rem;font-weight:700;letter-spacing:.12em;
  color:var(--pseo-brand-d);text-transform:uppercase;
}
.pseo-rg-card__title{
  display:block;
  font-size:1.02rem;font-weight:700;
  color:var(--pseo-text);
  line-height:1.25;letter-spacing:-.005em;
}
.pseo-rg-card__excerpt{
  display:block;
  font-size:.86rem;line-height:1.5;
  color:var(--pseo-text-2, var(--pseo-muted));
  /* clamp to 3 lines so cards stay equal height */
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.pseo-rg-card__cta{
  margin-top:auto;
  font-size:.86rem;font-weight:700;
  color:var(--pseo-brand-d);
}
.pseo-rg-card:hover .pseo-rg-card__cta{ color:var(--pseo-brand); }
@media (max-width:980px){
  .pseo-rg__grid{ grid-template-columns:repeat(3, minmax(0, 1fr)); }
}
@media (max-width:720px){
  .pseo-rg__grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); gap:.85rem; }
}
@media (max-width:480px){
  .pseo-rg__grid{ grid-template-columns:1fr; }
}

/* Category archive long-form content (under the product grid on
   /product-category/<slug>/). Typography matches the pseo-intro pattern
   used elsewhere. */
.pseo-cat-content{ margin:3rem 0 2rem; max-width:62rem; }
.pseo-cat-content__intro{ margin:0 0 1.75rem; }
.pseo-cat-content__lede{
  font-size:1.15rem; line-height:1.65;
  color:var(--pseo-text-2, var(--pseo-text));
  margin:0;
  padding-left:1.1rem;
  border-left:3px solid var(--pseo-brand);
}
.pseo-cat-content__section{ margin:2rem 0; }
.pseo-cat-content__section h2{
  font-size:clamp(1.35rem, 2vw, 1.65rem);
  margin:0 0 .75rem;
  color:var(--pseo-text);
  letter-spacing:-.01em;
}
.pseo-cat-content__section p{
  font-size:1rem; line-height:1.7;
  color:var(--pseo-text);
  margin:0 0 1rem;
}
.pseo-cat-content__faq{ margin-top:2.5rem; }
.pseo-cat-content__faq h2{
  font-size:clamp(1.35rem, 2vw, 1.65rem);
  margin:0 0 1rem;
}

.pseo-pgrid--grid .pseo-pgrid__track{
  display:grid;
  grid-auto-flow:row;
  grid-template-columns:repeat(var(--pseo-pgrid-visible, 4), minmax(0, 1fr));
  grid-auto-columns:initial;
  overflow:visible;
  scroll-snap-type:none;
  padding:.4rem 0 1rem;
  margin:0;
}

/* --- Compact variant (related/comparable single-template blocks) --- */
.pseo-pgrid--compact{ margin:1.75rem 0; --pseo-pgrid-gap:.85rem; }
.pseo-pgrid--compact .pseo-pgrid__title{ font-size:1.15rem; }
.pseo-pgrid--compact .pseo-pgrid__media{ aspect-ratio:4 / 3; }
.pseo-pgrid--compact .pseo-pgrid__body{ padding:.75rem .85rem .85rem; gap:.4rem; }
.pseo-pgrid--compact .pseo-pgrid__name{ font-size:.94rem; }
.pseo-pgrid--compact .pseo-pgrid__price{ font-size:.7rem; padding:.25rem .55rem; }
.pseo-pgrid--compact .pseo-pgrid__specs li{ padding:.22rem 0; font-size:.76rem; }
.pseo-pgrid--compact .pseo-pgrid__cta{ font-size:.78rem; }

/* --- Responsive: shrink visible card count + mobile arrow handling -- */
@media (max-width:980px){
  .pseo-pgrid{ --pseo-pgrid-visible:3; }
  .pseo-pgrid__carousel{ --pseo-pgrid-nav-size:34px; }
}
@media (max-width:720px){
  .pseo-pgrid{ --pseo-pgrid-visible:2; --pseo-pgrid-gap:.75rem; }
  .pseo-pgrid__carousel{ padding-left:0; padding-right:0; }
  .pseo-pgrid__nav{ display:none !important; }
  .pseo-pgrid__filter button{ padding:.5rem 1rem; font-size:.85rem; }
}
@media (max-width:480px){
  .pseo-pgrid__track{
    grid-auto-columns:78%;
  }
}

/* ---- Supplier card ---- */
.pseo-supplier{margin:2rem 0}
.pseo-supplier__card{
  display:flex;align-items:center;gap:1.25rem;
  background:#fff;
  border:1px solid var(--pseo-line);
  border-radius:var(--pseo-radius);
  padding:1.25rem 1.5rem;
  box-shadow:var(--pseo-shadow);
}
.pseo-supplier__avatar{
  flex-shrink:0;
  width:60px;height:60px;
  border-radius:50%;
  background:linear-gradient(135deg,#E8874A,#C56F35);
  color:#fff;
  font-size:1.6rem;font-weight:700;
  display:grid;place-items:center;
  box-shadow:inset 0 -2px 0 rgba(0,0,0,.1);
}
.pseo-supplier__body{flex:1;min-width:0}
.pseo-supplier__name{
  display:block;
  font-size:1.15rem;font-weight:700;color:var(--pseo-text);
  margin-bottom:.25rem;
}
.pseo-supplier__meta{
  display:flex;flex-wrap:wrap;gap:.5rem 1rem;
  font-size:.85rem;color:var(--pseo-text-2);
}
.pseo-supplier__call{
  display:inline-flex;align-items:center;gap:.4rem;
  margin-top:.5rem;
  font-size:.95rem;font-weight:600;
  color:var(--pseo-brand-d) !important;
}
.pseo-supplier__call:hover{color:var(--pseo-brand) !important;text-decoration:underline}
@media (max-width:640px){
  .pseo-supplier__card{flex-direction:column;text-align:center;align-items:center}
  .pseo-supplier__meta{justify-content:center}
}

/* ---- Internal link block ---- */
.pseo-internal{margin:2.5rem 0;background:var(--pseo-bg-soft);border-radius:var(--pseo-radius);padding:1.75rem 1.75rem 1.5rem;border:1px solid var(--pseo-line)}
.pseo-internal h3{margin-top:0;margin-bottom:1.25rem;font-size:1.2rem;color:var(--pseo-text)}
.pseo-internal__cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem}
.pseo-internal h4{font-size:.78rem;margin:.25rem 0 .65rem;color:var(--pseo-brand-d);text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.pseo-internal ul{list-style:none;padding:0;margin:0}
.pseo-internal li{margin:.3rem 0;font-size:.95rem}
.pseo-internal li a{color:var(--pseo-text-2);transition:color .12s}
.pseo-internal li a:hover{color:var(--pseo-brand-d);text-decoration:underline}

/* ---- Comparison columns ---- */
.pseo-cmp{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin:1.5rem 0}
.pseo-cmp__col{background:#fff;border:1px solid var(--pseo-line);border-radius:var(--pseo-radius);padding:1.5rem 1.25rem;text-align:center;box-shadow:var(--pseo-shadow)}
.pseo-cmp__col h3{margin:.5rem 0 .65rem;font-size:1.25rem}
.pseo-cmp__col img{max-width:100%;height:auto;border-radius:var(--pseo-radius-sm)}

/* ---- Project step list ---- */
.pseo-steps{counter-reset:s;list-style:none;padding:0;margin:1.25rem 0;display:grid;gap:.85rem}
.pseo-steps li{counter-increment:s;background:#fff;border:1px solid var(--pseo-line);border-radius:var(--pseo-radius);padding:1.1rem 1.25rem 1.1rem 3.6rem;position:relative;box-shadow:var(--pseo-shadow)}
.pseo-steps li::before{content:counter(s);position:absolute;left:1rem;top:50%;transform:translateY(-50%);background:var(--pseo-brand);color:#fff;border-radius:50%;width:2rem;height:2rem;display:grid;place-items:center;font-weight:700;font-size:.95rem}
.pseo-steps li strong{display:block;margin-bottom:.25rem;color:var(--pseo-text);font-size:1.05rem}

/* ---- Sticky mobile CTA ---- */
.pseo-sticky-cta{display:none}
@media (max-width:768px){
  .pseo{padding:1.25rem 1rem 5rem}
  .pseo-hero{padding:1.5rem 1.25rem}
  .pseo-cmp{grid-template-columns:1fr}
  .pseo-internal{padding:1.25rem 1.25rem 1rem}
  .pseo-sticky-cta{display:block;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--pseo-line);padding:.75rem 1rem;text-align:center;box-shadow:0 -4px 16px rgba(0,0,0,.08);z-index:50}
  .pseo-sticky-cta .pseo-cta{display:flex;justify-content:center}
}

/* =========================================================
   LOCATIONS HUB — rendered by [mygb_locations_map] on the
   Delivery page. Stat strip + geographic CSS-grid map +
   per-state city directory.
   ========================================================= */
.mygb-loc-hub{
  font-family:"Poppins","Helvetica Neue",Arial,sans-serif;
  max-width:1250px;
  margin:2rem auto;
  padding:0 1.25rem;
  color:var(--pseo-text);
}

/* Stat strip */
.mygb-loc-hub__stats{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:1rem;
  margin-bottom:2rem;
  background:var(--pseo-bg-tint);
  border:1px solid var(--pseo-line);
  border-radius:14px;
  padding:1.5rem;
}
.mygb-loc-hub__stat{text-align:center}
.mygb-loc-hub__stat strong{
  display:block;
  font-size:2rem;font-weight:700;color:var(--pseo-brand-d);
  letter-spacing:-.02em;line-height:1;
}
.mygb-loc-hub__stat span{
  display:block;
  margin-top:.35rem;
  font-size:.85rem;color:var(--pseo-muted);
  font-weight:500;
}

/* Geographic map */
.mygb-loc-hub__map-wrap{
  background:#fff;
  border:1px solid var(--pseo-line);
  border-radius:14px;
  padding:1.75rem 1.25rem 1.25rem;
  margin-bottom:2.5rem;
  box-shadow:0 1px 3px rgba(0,0,0,.04);
}
.mygb-loc-hub__map{
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  grid-template-rows:repeat(8,minmax(46px,auto));
  gap:6px;
  margin:0 auto 1.25rem;
  max-width:920px;
}
.mygb-loc-hub__cell{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:.4rem .2rem;
  font-weight:700;font-size:.82rem;letter-spacing:.04em;
  border-radius:8px;
  text-decoration:none !important;
  position:relative;
  transition:transform .12s,box-shadow .12s,background .12s;
}
.mygb-loc-hub__cell-count{
  font-size:.65rem;font-weight:600;letter-spacing:.04em;
  opacity:.85;
  margin-top:.15rem;
}
.mygb-loc-hub__cell--none{
  background:var(--pseo-line-2);
  color:var(--pseo-muted);
  cursor:default;
}
.mygb-loc-hub__cell--light{
  background:#FDE6D2;color:var(--pseo-brand-d);
  border:1px solid #F5C9A0;
}
.mygb-loc-hub__cell--mid{
  background:linear-gradient(135deg,#F4A86C,#E8874A);color:#fff;
  border:1px solid #E8874A;
}
.mygb-loc-hub__cell--heavy{
  background:linear-gradient(135deg,#E8874A,#C56F35);color:#fff;
  border:1px solid #C56F35;
  box-shadow:inset 0 -2px 0 rgba(0,0,0,.08);
}
.mygb-loc-hub__cell:not(.mygb-loc-hub__cell--none):hover{
  transform:translateY(-2px);
  box-shadow:0 8px 20px -6px rgba(232,135,74,.4);
  z-index:2;
}

/* Legend */
.mygb-loc-hub__legend{
  display:flex;align-items:center;justify-content:center;
  gap:1rem;flex-wrap:wrap;
  font-size:.78rem;color:var(--pseo-muted);
  padding-top:.85rem;
  border-top:1px solid var(--pseo-line-2);
}
.mygb-loc-hub__legend-dot{
  display:inline-block;
  width:14px;height:14px;
  border-radius:4px;
  margin-right:.35rem;
  vertical-align:-2px;
}
.mygb-loc-hub__legend-dot--none{background:var(--pseo-line-2)}
.mygb-loc-hub__legend-dot--light{background:#FDE6D2;border:1px solid #F5C9A0}
.mygb-loc-hub__legend-dot--mid{background:linear-gradient(135deg,#F4A86C,#E8874A)}
.mygb-loc-hub__legend-dot--heavy{background:linear-gradient(135deg,#E8874A,#C56F35)}

/* State directory */
.mygb-loc-hub__dir{display:grid;gap:1.5rem}
.mygb-loc-hub__state{
  background:#fff;
  border:1px solid var(--pseo-line);
  border-radius:14px;
  padding:1.5rem;
  scroll-margin-top:120px;
}
.mygb-loc-hub__state-head{
  display:flex;align-items:center;gap:.85rem;
  padding-bottom:1rem;margin-bottom:1rem;
  border-bottom:1px solid var(--pseo-line-2);
}
.mygb-loc-hub__state-badge{
  display:grid;place-items:center;
  width:44px;height:44px;
  background:linear-gradient(135deg,#E8874A,#C56F35);color:#fff;
  border-radius:10px;
  font-weight:700;font-size:.95rem;letter-spacing:.04em;
  box-shadow:inset 0 -2px 0 rgba(0,0,0,.08);
}
.mygb-loc-hub__state-head h3{
  margin:0;flex:1;
  font-size:1.3rem;font-weight:700;
  color:var(--pseo-text);
  letter-spacing:-.01em;
}
.mygb-loc-hub__state-count{
  font-size:.82rem;color:var(--pseo-muted);
  background:var(--pseo-bg-soft);
  padding:.3rem .7rem;border-radius:99px;
  font-weight:600;
}

.mygb-loc-hub__cities{
  list-style:none;padding:0;margin:0;
  display:grid;
  grid-template-columns:repeat(var(--cols,4),minmax(0,1fr));
  gap:.55rem;
}
.mygb-loc-hub__cities li{margin:0;padding:0}
.mygb-loc-hub__cities a{
  display:block;
  padding:.7rem .9rem;
  background:var(--pseo-bg-soft);
  border:1px solid transparent;
  border-radius:8px;
  text-decoration:none !important;
  color:var(--pseo-text);
  transition:background .12s,border-color .12s,transform .1s;
  min-height:100%;
}
.mygb-loc-hub__cities a:hover{
  background:#fff;
  border-color:var(--pseo-brand);
  transform:translateY(-1px);
  box-shadow:0 4px 12px -4px rgba(232,135,74,.3);
}
.mygb-loc-hub__city-name{
  display:block;
  font-weight:600;font-size:.95rem;
  color:var(--pseo-text);
}
.mygb-loc-hub__city-meta{
  display:block;
  margin-top:.15rem;
  font-size:.74rem;color:var(--pseo-muted);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

/* Mobile */
@media (max-width:760px){
  .mygb-loc-hub__map{
    grid-template-columns:repeat(12,minmax(0,1fr));
    grid-template-rows:repeat(8,minmax(34px,auto));
    gap:3px;
  }
  .mygb-loc-hub__cell{font-size:.66rem;padding:.25rem .1rem}
  .mygb-loc-hub__cell-count{font-size:.58rem;margin-top:.05rem}
  .mygb-loc-hub__stat strong{font-size:1.6rem}
  .mygb-loc-hub__cities{grid-template-columns:repeat(2,minmax(0,1fr))}
  .mygb-loc-hub__state{padding:1rem}
}

/* ---- Hide redundant page title/breadcrumb that Hello Elementor injects above singular CPTs ---- */
.single-pseo_location .page-header,
.single-pseo_product_loc .page-header,
.single-pseo_usecase_loc .page-header,
.single-pseo_calculator .page-header,
.single-pseo_comparison .page-header,
.single-pseo_guide .page-header{display:none!important}

/* =========================================================
   MEGA MENU — high-end flyout system layered onto ElementsKit's
   nav widget. Triggered only when our injected items add the
   .pseo-megamenu / .pseo-mm-* classes, so we don't touch the
   regular dropdown for unrelated menu items.

   Tokens reused: --pseo-brand (#E8874A), --pseo-brand-d, --pseo-brand-l,
   --pseo-text, --pseo-text-2, --pseo-muted, --pseo-line.
   ========================================================= */

/* --- Top-level trigger (parent <li>) -------------------------------- */
.elementskit-navbar-nav{position:relative}                         /* anchor flyouts to the nav center */
.elementskit-navbar-nav > li{white-space:nowrap}                   /* don't break item text mid-word */
.elementskit-navbar-nav .pseo-megamenu{position:static}            /* keep panel anchored to nav, not the li */

/* Hide ElementsKit's own chevron icon on PSEO mega items — we draw our own */
.elementskit-navbar-nav .pseo-megamenu > a > i.elementskit-submenu-indicator,
.elementskit-navbar-nav .pseo-megamenu > a > .elementskit-submenu-indicator{
  display:none !important;
}

.elementskit-navbar-nav .pseo-megamenu > a::after{
  content:"";
  display:inline-block;
  width:.5em;height:.5em;
  margin-left:.45em;
  border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;
  opacity:.55;
  transform:translateY(-2px) rotate(45deg);
  transition:transform .2s ease,opacity .15s;
}
.elementskit-navbar-nav .pseo-megamenu:hover > a::after,
.elementskit-navbar-nav .pseo-megamenu:focus-within > a::after{
  transform:translateY(1px) rotate(-135deg);
  opacity:1;
  color:var(--pseo-brand);
}

/* --- The flyout panel — viewport-anchored via position:fixed ----- */
/* Use `position: fixed` + `left:0; right:0; margin:0 auto` so the panel
   is centered in the viewport regardless of where the navbar sits within
   the header layout (flex columns, off-center wrappers, etc.). The trick
   with `margin: 0 auto` on a fixed/absolute element works because
   `left: 0; right: 0` plus a finite width gives auto-margins room to
   distribute equally — the panel ends up viewport-centered.
   We intentionally avoid `translateX(-50%)` (which depends on the
   containing block being viewport-centered) and `left: 50%` (which
   depends on no transformed ancestor hijacking position:fixed). */
.pseo-megamenu > ul.elementskit-submenu-panel,
.pseo-megamenu > .elementskit-submenu-panel{
  display:grid !important;
  grid-auto-flow:row;
  gap:0;
  grid-template-columns:repeat(2,minmax(0,1fr)) minmax(260px,300px);
  width:min(96vw, 1300px) !important;
  max-width:calc(100vw - 24px) !important;
  padding:0 !important;
  background:#fff !important;
  border:1px solid var(--pseo-line) !important;
  border-radius:14px !important;
  box-shadow:
    0 4px 12px rgba(0,0,0,.04),
    0 28px 60px -12px rgba(26,26,26,.20) !important;
  position:fixed !important;
  top:var(--mygb-header-bottom, 92px) !important;
  left:0 !important;
  right:0 !important;
  bottom:auto !important;
  margin:0 auto !important;
  transform:translateY(8px) scale(.985) !important;
  transform-origin:top center;
  z-index:99999;
  opacity:0 !important;
  visibility:hidden !important;
  pointer-events:none !important;
  transition:opacity .15s ease,transform .15s ease,visibility 0s linear .25s;
  list-style:none;
  overflow:hidden;
}
.pseo-megamenu:hover > ul.elementskit-submenu-panel,
.pseo-megamenu:hover > .elementskit-submenu-panel,
.pseo-megamenu:focus-within > ul.elementskit-submenu-panel,
.pseo-megamenu:focus-within > .elementskit-submenu-panel,
/* JS hover-intent (functions.php) adds this class on mouseenter and removes
   it after a short delay on mouseleave, so the panel no longer closes the
   instant the cursor crosses the gap to a left-aligned trigger. */
.pseo-megamenu.pseo-mm-hover-open > ul.elementskit-submenu-panel,
.pseo-megamenu.pseo-mm-hover-open > .elementskit-submenu-panel{
  opacity:1 !important;
  visibility:visible !important;
  pointer-events:auto !important;
  transform:translateY(0) scale(1) !important;
  transition:opacity .18s ease,transform .18s ease,visibility 0s linear 0s;
}
/* Hover bridge above the panel — catches the cursor traveling from the
   trigger down to the panel through the visual gap. Widened for forgiveness
   now that the trigger is left-aligned while the panel stays centered. */
.pseo-megamenu > .elementskit-submenu-panel::before{
  content:"";position:absolute;
  top:-44px;left:0;right:0;height:44px;
  background:transparent;
}

/* Position-fixed sometimes gets hijacked by transformed ancestors
   (Elementor sections sometimes get `transform: translate3d(0,0,0)`
   added by motion effects or sticky-header plugins). Strip transforms
   from common ancestors so our fixed positioning truly anchors to
   the viewport. We scope this to header-related wrappers only so we
   don't break Elementor body-content animations. */
[data-elementor-type="header"],
[data-elementor-type="header"] .elementor-section,
[data-elementor-type="header"] .elementor-container,
[data-elementor-type="header"] .elementor-widget-wrap,
[data-elementor-type="header"] .e-con,
[data-elementor-type="header"] .e-con-inner,
[data-elementor-type="header"] .elementor-widget-ekit-nav-menu,
.ekit-template-content-header,
.elementor-location-header,
.elementskit-menu-container,
.elementskit-navbar-nav{
  transform:none !important;
  perspective:none !important;
  filter:none !important;
}

/* =========================================================
   HEADER ALIGNMENT (desktop ≥1025px) — pull the logo + menu
   tight to the left and push the Order button to the far right,
   replacing Elementor's 20%/60%/12% centered columns that left big
   gaps. Scoped to the nav row only (the boxed container that holds
   the ekit nav menu), identified via :has() so the top utility bar
   and everything else are untouched. The flyout panels are
   position:fixed/viewport-centered, so realigning the menu cannot
   move or break them.
   ========================================================= */
@media (min-width:1025px){
  /* Let the nav row use the full header width with a small left inset so the
     logo + menu sit close to the left edge (not centered in a boxed column). */
  [data-elementor-type="header"] .e-con-boxed:has(.elementskit-menu-container){
    padding-left:clamp(1rem, 2.5vw, 2.5rem) !important;
    padding-right:clamp(1rem, 2.5vw, 2.5rem) !important;
  }
  /* The nav row (inner flex track of the boxed container with the menu). */
  [data-elementor-type="header"] .e-con-boxed:has(.elementskit-menu-container) > .e-con-inner{
    flex-direction:row !important;
    justify-content:flex-start !important;
    align-items:center !important;
    gap:clamp(.5rem, 1vw, 1rem) !important;   /* tight logo ↔ menu spacing */
    flex-wrap:nowrap !important;
    max-width:100% !important;                /* span full width, no centered box */
    margin-left:0 !important;
    margin-right:0 !important;
  }
  /* Logo + button columns shrink to content; the MENU column grows to fill
     the middle so the button lands flush-right and the menu never wraps. */
  [data-elementor-type="header"] .e-con-boxed:has(.elementskit-menu-container) > .e-con-inner > .e-con:has(.elementor-widget-image),
  [data-elementor-type="header"] .e-con-boxed:has(.elementskit-menu-container) > .e-con-inner > .e-con:has(.elementor-widget-button){
    width:auto !important;
    max-width:none !important;
    flex:0 0 auto !important;
    justify-content:flex-start !important;
  }
  [data-elementor-type="header"] .e-con-boxed:has(.elementskit-menu-container) > .e-con-inner > .e-con:has(.elementskit-menu-container){
    width:auto !important;
    max-width:none !important;
    flex:1 1 auto !important;
    min-width:0 !important;
    justify-content:flex-start !important;
  }
  /* Override ElementsKit's centered menu (elementskit-menu-po-center) →
     left-align the items and never wrap them onto a second row. */
  [data-elementor-type="header"] .elementskit-navbar-nav{
    justify-content:flex-start !important;
    flex-wrap:nowrap !important;
  }
  [data-elementor-type="header"] .elementskit-navbar-nav > li{ white-space:nowrap !important; }
  /* Give the logo a clean fixed header height so its column shrink-wraps
     predictably (it was sized at 50% of a % -width column). */
  [data-elementor-type="header"] .e-con-boxed:has(.elementskit-menu-container) .elementor-widget-image img{
    height:60px !important;
    width:auto !important;
    max-width:none !important;
  }
}

/* Top utility bar ("Welcome to My Gravel Buddy Company") contact list — force
   the email + phone onto one inline row that never wraps. The real cause of the
   stacking was the over-broad homepage-hero rule above (now re-scoped); this is
   a defensive guarantee. The bar is desktop-only (hide_tablet/hide_mobile), so
   no breakpoint gate is needed. Targeted by the widget's Elementor element ID. */
.elementor-element-2ae8c57 .elementor-icon-list-items{
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:nowrap !important;
}
.elementor-element-2ae8c57 .elementor-icon-list-text,
.elementor-element-2ae8c57 .elementor-icon-list-item,
.elementor-element-2ae8c57 .elementor-icon-list-item a{
  white-space:nowrap !important;
}

.elementskit-navbar-nav .pseo-megamenu--narrow > .elementskit-submenu-panel{
  /* Calculator: 2 cols of calc cards + tall feature card */
  width:clamp(640px,56vw,780px) !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) minmax(230px,270px);
}
/* Per-flyout grid templates. The modifier classes (pseo-megamenu--materials etc.)
   are now on the portaled panel itself (not on a parent). */

/* MATERIALS — three full-width rows (titlebar / rail+pane body / feature) */
.pseo-megamenu.pseo-megamenu--materials > .elementskit-submenu-panel{
  grid-template-columns:1fr !important;
  width:min(94vw, 1100px) !important;
}
.pseo-megamenu.pseo-megamenu--materials > .elementskit-submenu-panel > li{
  grid-column:1 / -1;
}
.pseo-megamenu.pseo-megamenu--materials > .elementskit-submenu-panel > li.pseo-mm-feature-col{
  border-top:1px solid var(--pseo-line-2);
  border-left:0;
}

/* The materials-body LI carries the rail+pane grid. Strip the default LI
   chrome so the inner .pseo-mm-mb element owns the layout. */
.pseo-megamenu.pseo-megamenu--materials > .elementskit-submenu-panel > li.pseo-mm-materials-body{
  list-style:none;
  padding:0 !important;
  margin:0 !important;
  background:transparent !important;
  border:0 !important;
}

/* --- Rail + pane body ------------------------------------------------- */
.pseo-mm-mb{
  display:grid;
  grid-template-columns:minmax(220px, 260px) 1fr;
  gap:0;
  min-height:320px;
}

/* Left rail — vertical category list, scrollable if absurdly long */
.pseo-mm-mb__rail{
  list-style:none;
  margin:0;
  padding:.65rem 0;
  border-right:1px solid var(--pseo-line-2);
  background:linear-gradient(180deg, #fff 0%, var(--pseo-bg-tint, #fafafa) 100%);
  max-height:60vh;
  overflow:auto;
}
.pseo-mm-mb__rail > li{
  list-style:none;
  margin:0;
  padding:0;
}
.pseo-mm-mb__rail button,
.pseo-mm-mb__rail a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  width:100%;
  padding:.7rem 1rem .7rem 1.15rem;
  border:0;
  border-left:3px solid transparent;
  background:transparent;
  color:var(--pseo-text);
  text-decoration:none;
  font:inherit;
  font-weight:500;
  font-size:.95rem;
  text-align:left;
  cursor:pointer;
  transition:background .12s ease, color .12s ease, border-color .12s ease;
}
.pseo-mm-mb__rail button:hover,
.pseo-mm-mb__rail button:focus-visible,
.pseo-mm-mb__rail a:hover,
.pseo-mm-mb__rail a:focus-visible{
  background:rgba(232,135,74,.06);
  color:var(--pseo-brand-d);
  outline:0;
}
.pseo-mm-mb__rail button[aria-selected="true"],
.pseo-mm-mb__rail a[aria-selected="true"]{
  background:rgba(232,135,74,.08);
  color:var(--pseo-brand-d);
  border-left-color:var(--pseo-brand);
  font-weight:600;
}
.pseo-mm-mb__rail-chevron{
  display:inline-block;
  width:.45em;height:.45em;
  margin-left:.6em;
  border-right:2px solid currentColor;
  border-top:2px solid currentColor;
  opacity:.4;
  transform:rotate(45deg);
  transition:opacity .12s ease, transform .12s ease;
}
.pseo-mm-mb__rail button:hover .pseo-mm-mb__rail-chevron,
.pseo-mm-mb__rail button[aria-selected="true"] .pseo-mm-mb__rail-chevron,
.pseo-mm-mb__rail a:hover .pseo-mm-mb__rail-chevron,
.pseo-mm-mb__rail a[aria-selected="true"] .pseo-mm-mb__rail-chevron{
  opacity:.85;
  transform:translateX(2px) rotate(45deg);
}

/* Right pane container — only the active pane is shown */
.pseo-mm-mb__panes{
  position:relative;
  padding:1rem 1.25rem 1.15rem;
}
.pseo-mm-mb__pane{
  display:none;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:.15rem .9rem;
}
.pseo-mm-mb__pane.is-active{
  display:grid;
  animation:pseo-mm-fade .14s ease;
}
@keyframes pseo-mm-fade{
  from{opacity:0;transform:translateY(2px)}
  to{opacity:1;transform:none}
}
.pseo-mm-mb__pane > a{
  display:flex;
  align-items:center;
  gap:.65rem;
  padding:.4rem .55rem;
  margin:0;
  border-radius:6px;
  color:var(--pseo-text);
  text-decoration:none;
  font-size:.95rem;
  font-weight:500;
  line-height:1.3;
  transition:background .12s ease, color .12s ease, transform .1s ease;
}
.pseo-mm-mb__pane > a:hover,
.pseo-mm-mb__pane > a:focus-visible{
  background:var(--pseo-bg-tint, #fafafa);
  color:var(--pseo-brand-d);
  outline:0;
  transform:translateX(2px);
}
.pseo-mm-mb__thumb{
  flex:0 0 40px;
  width:40px;
  height:40px;
  border-radius:6px;
  overflow:hidden;
  background:var(--pseo-line-2);
  display:block;
}
.pseo-mm-mb__thumb-img{
  width:100% !important;
  height:100% !important;
  object-fit:cover;
  display:block;
  max-width:none !important;
}
.pseo-mm-mb__name{
  flex:1 1 auto;
  min-width:0;
  line-height:1.3;
}

/* CALCULATOR — rail + pane body (mirrors the Materials layout). Three
   full-width rows: titlebar / .pseo-mm-mb body / feature col. */
.pseo-megamenu.pseo-megamenu--calc > .elementskit-submenu-panel{
  grid-template-columns:1fr !important;
  width:min(94vw, 1100px) !important;
}
.pseo-megamenu.pseo-megamenu--calc > .elementskit-submenu-panel > li{
  grid-column:1 / -1;
}
.pseo-megamenu.pseo-megamenu--calc > .elementskit-submenu-panel > li.pseo-mm-feature-col{
  border-top:1px solid var(--pseo-line-2);
  border-left:0;
}
.pseo-megamenu.pseo-megamenu--calc > .elementskit-submenu-panel > li.pseo-mm-calc-body{
  list-style:none;
  padding:0 !important;
  margin:0 !important;
  background:transparent !important;
  border:0 !important;
}

/* SERVICE AREAS — 6-column state grid with ZIP form row at top */
.pseo-megamenu.pseo-megamenu--areas > .elementskit-submenu-panel{
  grid-template-columns:repeat(6,minmax(0,1fr)) !important;
  width:min(96vw, 1300px) !important;
}
.pseo-megamenu.pseo-megamenu--areas > .elementskit-submenu-panel > li.pseo-mm-titlebar,
.pseo-megamenu.pseo-megamenu--areas > .elementskit-submenu-panel > li.pseo-mm-zipform-row,
.pseo-megamenu.pseo-megamenu--areas > .elementskit-submenu-panel > li.pseo-mm-feature-col{
  grid-column:1 / -1;
}
.pseo-megamenu.pseo-megamenu--areas > .elementskit-submenu-panel > li.pseo-mm-feature-col{
  border-top:1px solid var(--pseo-line-2);
  border-left:0;
}

/* COMPARE — flat 3-column grid, title bar + feature col span full width */
.pseo-megamenu.pseo-megamenu--compare > .elementskit-submenu-panel{
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  width:min(94vw, 1050px) !important;
}
.pseo-megamenu.pseo-megamenu--compare > .elementskit-submenu-panel > li.pseo-mm-titlebar,
.pseo-megamenu.pseo-megamenu--compare > .elementskit-submenu-panel > li.pseo-mm-feature-col{
  grid-column:1 / -1;
}
.pseo-megamenu.pseo-megamenu--compare > .elementskit-submenu-panel > li.pseo-mm-feature-col{
  border-top:1px solid var(--pseo-line-2);
  border-left:0;
}
/* Compare → 3-column body (Glossary / Project Guides / Blog). The marker
   <li> spans the whole panel and lays out its own three columns. */
.pseo-megamenu.pseo-megamenu--compare > .elementskit-submenu-panel > li.pseo-mm-compare-body{
  grid-column:1 / -1;
  list-style:none;
  margin:0;padding:0;border:0;background:transparent;
}
.pseo-mm-compare3{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.pseo-mm-c3col{
  display:flex;flex-direction:column;
  min-width:0;
  padding:1.4rem 1.25rem 1.25rem;
  border-right:1px solid var(--pseo-line-2);
}
.pseo-mm-c3col:last-child{border-right:0}
.pseo-mm-c3col__head{
  font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--pseo-brand-d);
  padding-bottom:.55rem;margin-bottom:.5rem;
  border-bottom:2px solid var(--pseo-line-2);
}
.pseo-mm-c3list{
  list-style:none;margin:0;padding:0;flex:1;
  display:flex;flex-direction:column;gap:.05rem;
}
.pseo-mm-c3list > li{margin:0}
.pseo-mm-c3list > li > a{
  display:block;
  padding:.4rem 0;
  color:var(--pseo-text);
  text-decoration:none;
  font-size:.95rem;font-weight:500;line-height:1.3;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  transition:color .12s ease, padding-left .12s ease;
}
.pseo-mm-c3list > li > a:hover{color:var(--pseo-brand-d);padding-left:.25rem}
.pseo-mm-c3all{
  margin-top:.65rem;padding-top:.55rem;
  border-top:1px dashed var(--pseo-line);
  color:var(--pseo-brand-d) !important;
  font-weight:600;font-size:.9rem;text-decoration:none !important;
}
.pseo-mm-c3all:hover{color:var(--pseo-brand) !important}

/* ZIP-form row — full-width inside the flyout */
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-zipform-row{
  list-style:none;
  padding:.85rem 1.25rem 1.1rem;
  background:var(--pseo-bg-tint);
  border-bottom:1px solid var(--pseo-line-2);
  display:flex;align-items:center;justify-content:center;
}

/* --- Category column (replaces the old card-col pattern) --- */
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-cat{
  list-style:none;
  padding:1.25rem 1.15rem 1rem;
  border-right:1px solid var(--pseo-line-2);
  display:flex;flex-direction:column;
}
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-cat:last-of-type:not(.pseo-mm-feature-col),
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-cat + li.pseo-mm-feature-col{border-right:0}
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-cat > a{
  display:block !important;
  padding:0 !important;
  margin:0 0 .55rem !important;
  border:0 !important;
  background:transparent !important;
  pointer-events:none; /* category header is non-clickable */
  cursor:default;
}
.pseo-mm-cat__label{
  font-size:.7rem;font-weight:700;letter-spacing:.12em;
  color:var(--pseo-brand-d);text-transform:uppercase;
  padding-bottom:.5rem;
  border-bottom:2px solid var(--pseo-brand-l);
}

/* State count badge inside Service Areas state items */
.pseo-mm-cat__count{
  display:inline-block;
  margin-left:.4rem;
  font-size:.68rem;font-weight:600;
  color:var(--pseo-muted);
  background:var(--pseo-line-2);
  padding:.1rem .45rem;
  border-radius:99px;
}

/* Flat-row items (used by Service Areas states AND Materials products) */
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-state{
  list-style:none;
  padding:0;
}
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-state > a{
  display:block !important;
  padding:.75rem 1rem !important;
  border:0 !important;
  border-bottom:1px solid var(--pseo-line-2) !important;
  font-weight:600 !important;font-size:.88rem !important;
  color:var(--pseo-text) !important;
  background:transparent !important;
  transition:background .12s,padding-left .12s;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-state > a:hover{
  background:var(--pseo-bg-tint);
  padding-left:1.25rem !important;
  color:var(--pseo-brand-d) !important;
}

/* ZIP form — now a standalone <form> row inside the flyout (lifted out of <a>) */
.pseo-mm-zipform{
  display:flex;align-items:center;gap:.5rem;
  background:#fff;
  border:1.5px solid var(--pseo-brand-l);
  border-radius:99px;
  padding:.3rem .3rem .3rem 1rem;
  box-shadow:0 4px 12px rgba(232,135,74,.15);
  width:100%;max-width:520px;
}
.pseo-mm-zipform input[type="text"]{
  flex:1;
  border:0 !important;
  background:transparent !important;
  font-size:.95rem;font-weight:500;
  color:var(--pseo-text);
  padding:.5rem .25rem !important;
  outline:none !important;
  font-family:inherit;
  min-width:0;
}
.pseo-mm-zipform input::placeholder{color:var(--pseo-muted);font-weight:400}
.pseo-mm-zipform input:focus{outline:none}
.pseo-mm-zipform button{
  flex-shrink:0;
  background:var(--pseo-brand);
  color:#fff;
  border:0;
  border-radius:99px;
  padding:.55rem 1.15rem;
  font-size:.88rem;font-weight:600;
  cursor:pointer;
  transition:background .12s, transform .1s;
  font-family:inherit;
}
.pseo-mm-zipform button:hover{background:var(--pseo-brand-d);transform:translateY(-1px)}
.pseo-mm-bar{
  display:flex;align-items:center;gap:1rem;flex-wrap:wrap;
}
.pseo-mm-bar__eyebrow{flex-shrink:0}
.pseo-mm-bar__body{flex:1;min-width:200px}

/* --- Title bar (spans full width) ----------------------------------- */
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-titlebar{
  grid-column:1 / -1;
  list-style:none;
  background:linear-gradient(90deg,var(--pseo-brand-l) 0%,#fff 70%);
  border-bottom:1px solid var(--pseo-line-2);
  padding:0;
}
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-titlebar > a{
  display:flex !important;align-items:baseline;gap:.85rem;flex-wrap:wrap;
  padding:.85rem 1.5rem !important;
  background:transparent !important;border:0 !important;
}
.pseo-mm-bar__eyebrow{
  font-size:.7rem;font-weight:700;letter-spacing:.14em;
  color:var(--pseo-brand-d);text-transform:uppercase;
  background:#fff;padding:.25rem .55rem;border-radius:99px;
  border:1px solid var(--pseo-brand-l);
}
.pseo-mm-bar__body{
  font-size:.92rem;color:var(--pseo-text-2);font-weight:500;
}

/* --- Rich product card (Materials flyout) --------------------------- */
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-card-col{
  list-style:none;
  padding:0;
  border-right:1px solid var(--pseo-line-2);
  display:flex;min-width:0;
}
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-card-col:last-of-type{border-right:0}
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-card-col > a{
  display:block !important;
  flex:1;
  padding:1.5rem 1.35rem 1.35rem !important;
  border:0 !important;
  text-decoration:none !important;
  color:inherit !important;
  background:transparent !important;
  transition:background .15s;
}
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-card-col:hover > a{
  background:var(--pseo-bg-tint);
}
.pseo-mm-card{display:flex;flex-direction:column;gap:.5rem;height:100%}
.pseo-mm-card__head{display:flex;align-items:center;justify-content:space-between;gap:.65rem;flex-wrap:wrap}
.pseo-mm-card__pricetag{
  font-size:.78rem;font-weight:600;color:var(--pseo-brand-d);
  background:#fff;border:1px solid var(--pseo-brand-l);
  padding:.22rem .6rem;border-radius:99px;white-space:nowrap;
}
.pseo-mm-card__name{
  font-size:1.12rem;font-weight:700;color:var(--pseo-text);
  line-height:1.2;letter-spacing:-.01em;
  margin-top:.15rem;
}
.pseo-mm-card__desc{
  font-size:.86rem;color:var(--pseo-muted);
  line-height:1.5;flex:1;
}
.pseo-mm-card__cta{
  font-size:.85rem;font-weight:600;color:var(--pseo-brand-d);
  margin-top:.35rem;
  display:inline-flex;align-items:center;gap:.35rem;
}
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-card-col:hover .pseo-mm-card__cta{color:var(--pseo-brand)}
/* Hide ElementsKit's chevron icon on these single-level cards */
.pseo-mm-card-col > a > .elementskit-submenu-indicator,
.pseo-mm-card-col > a > i.elementskit-submenu-indicator{display:none !important}

/* --- Columns (depth 1 = product / state / calculator) --------------- */
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-col{
  list-style:none;
  padding:1.4rem 1.25rem 1.25rem;
  border-right:1px solid var(--pseo-line-2);
  min-width:0;
  display:flex;flex-direction:column;
}
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-col:last-of-type{border-right:0}

/* The column header (the <a> wrapping our HTML title) */
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-col > a{
  display:block !important;
  padding:0 !important;
  margin:0 0 .65rem !important;
  border:0 !important;
  text-decoration:none !important;
  color:inherit !important;
  background:transparent !important;
}
.pseo-mm-col__inner{
  display:flex;gap:.7rem;align-items:flex-start;
  padding:.1rem 0 .55rem;
  border-bottom:2px solid var(--pseo-line-2);
  transition:border-color .15s;
}
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-col:hover > a .pseo-mm-col__inner{
  border-bottom-color:var(--pseo-brand);
}
.pseo-mm-col__text{display:flex;flex-direction:column;min-width:0;flex:1}
.pseo-mm-col__name{
  font-size:1.02rem;font-weight:700;color:var(--pseo-text);
  line-height:1.2;letter-spacing:-.005em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pseo-mm-col__tag{
  font-size:.78rem;color:var(--pseo-muted);font-weight:500;
  margin-top:.15rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-col:hover > a .pseo-mm-col__name{
  color:var(--pseo-brand-d);
}

/* Letter badge variants -------------------------------------------- */
.pseo-mm-badge{
  flex-shrink:0;
  width:38px;height:38px;
  border-radius:10px;
  display:grid;place-items:center;
  font-weight:700;font-size:.78rem;letter-spacing:.02em;
  color:#fff;
  box-shadow:inset 0 -2px 0 rgba(0,0,0,.08);
  text-transform:uppercase;
  font-family:"Poppins",sans-serif;
}
.pseo-mm-badge--orange{background:linear-gradient(135deg,#F19E66 0%,#E8874A 100%)}
.pseo-mm-badge--amber {background:linear-gradient(135deg,#F0B26B 0%,#D49340 100%)}
.pseo-mm-badge--earth {background:linear-gradient(135deg,#9B7B5C 0%,#6F5440 100%)}
.pseo-mm-badge--slate {background:linear-gradient(135deg,#7C8694 0%,#566270 100%)}

/* --- Leaves (cities / sub-items inside a column) ------------------- */
.pseo-megamenu li.pseo-mm-col > .elementskit-submenu-panel,
.pseo-megamenu li.pseo-mm-col > .elementskit-dropdown{
  position:static !important;
  display:flex !important;flex-direction:column;
  padding:0 !important;margin:0 !important;
  background:transparent !important;
  border:0 !important;box-shadow:none !important;
  opacity:1 !important;visibility:visible !important;transform:none !important;
  min-width:0 !important;max-width:none !important;
  grid-template-columns:none !important;width:auto !important;
}
.pseo-mm-leaf{list-style:none;margin:0}
.pseo-mm-leaf > a{
  display:flex !important;align-items:center;gap:.5rem;
  padding:.38rem 0 !important;
  font-size:.93rem !important;
  color:var(--pseo-text-2) !important;
  font-weight:500 !important;
  border:0 !important;
  text-decoration:none !important;
  transition:color .12s,padding-left .12s;
  background:transparent !important;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pseo-mm-leaf > a::before{
  content:"";
  width:0;height:1px;
  background:currentColor;
  transition:width .15s ease;
}
.pseo-mm-leaf > a:hover{color:var(--pseo-brand-d) !important;padding-left:.45rem !important}
.pseo-mm-leaf > a:hover::before{width:.35rem}

/* "View all X →" leaf */
.pseo-mm-leaf--all > a{
  margin-top:.6rem;
  padding-top:.65rem !important;
  border-top:1px dashed var(--pseo-line) !important;
  color:var(--pseo-brand-d) !important;
  font-weight:600 !important;
  font-size:.85rem !important;
}
.pseo-mm-leaf--all > a:hover{padding-left:0 !important}
.pseo-mm-leaf--all > a::before{display:none}

/* Hide ElementsKit's chevron icon on every depth-1+ PSEO item */
.pseo-mm-col > a > .elementskit-submenu-indicator,
.pseo-mm-col > a > i.elementskit-submenu-indicator,
.pseo-mm-cat > a > .elementskit-submenu-indicator,
.pseo-mm-cat > a > i.elementskit-submenu-indicator,
.pseo-mm-state > a > .elementskit-submenu-indicator,
.pseo-mm-state > a > i.elementskit-submenu-indicator,
.pseo-mm-leaf > a > .elementskit-submenu-indicator,
.pseo-mm-leaf > a > i.elementskit-submenu-indicator,
.pseo-mm-titlebar > a > .elementskit-submenu-indicator,
.pseo-mm-titlebar > a > i.elementskit-submenu-indicator,
.pseo-mm-feature-col > a > .elementskit-submenu-indicator,
.pseo-mm-feature-col > a > i.elementskit-submenu-indicator{
  display:none !important;
}

/* --- Feature card (last cell in the flyout) ------------------------ */
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-feature-col{
  list-style:none;
  background:linear-gradient(160deg,#FFF4EB 0%,#FFE8D6 100%);
  padding:0;
  border-left:1px solid var(--pseo-line-2);
  display:flex;
}
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-feature-col > a{
  display:flex !important;
  flex:1;flex-direction:column;justify-content:space-between;
  padding:1.5rem 1.4rem !important;
  background:transparent !important;
  border:0 !important;text-decoration:none !important;color:inherit !important;
  height:100%;
}
.pseo-mm-feature{display:flex;flex-direction:column;height:100%;gap:.5rem}
.pseo-mm-feature__eyebrow{
  font-size:.66rem;font-weight:700;letter-spacing:.14em;
  color:var(--pseo-brand-d);text-transform:uppercase;
  background:#fff;padding:.3rem .6rem;border-radius:99px;
  align-self:flex-start;
  border:1px solid var(--pseo-brand-l);
}
.pseo-mm-feature__title{
  font-size:1.1rem;font-weight:700;color:var(--pseo-text);
  line-height:1.25;letter-spacing:-.01em;
  margin-top:.25rem;
}
.pseo-mm-feature__body{
  font-size:.86rem;color:var(--pseo-text-2);line-height:1.5;
  flex:1;
}
.pseo-mm-feature__cta{
  display:inline-flex;align-items:center;gap:.4rem;
  align-self:flex-start;
  background:var(--pseo-brand);color:#fff;
  padding:.55rem 1.05rem;border-radius:99px;
  font-weight:600;font-size:.88rem;
  box-shadow:0 4px 10px -2px rgba(232,135,74,.45);
  transition:background .15s,transform .12s,box-shadow .15s;
  margin-top:.25rem;
}
.pseo-megamenu > .elementskit-submenu-panel > li.pseo-mm-feature-col:hover .pseo-mm-feature__cta{
  background:var(--pseo-brand-d);
  transform:translateY(-1px);
  box-shadow:0 6px 14px -2px rgba(232,135,74,.55);
}

/* --- Narrow (calculator-style) variant adjustments ----------------- */
.pseo-megamenu--narrow > .elementskit-submenu-panel > li.pseo-mm-col--single{
  border-right:1px solid var(--pseo-line-2);
  padding:1.15rem 1.1rem;
  /* When single-row, each is a clickable card with hover lift */
  cursor:pointer;
}
.pseo-megamenu--narrow > .elementskit-submenu-panel > li.pseo-mm-col--single:hover{
  background:var(--pseo-bg-tint);
}

/* =========================================================
   MOBILE — On <=1024px, ElementsKit's hamburger toggles an
   offcanvas drawer. The panels live inside their triggers,
   so the drawer renders them as a vertical list. We *override*
   the desktop absolute-positioning + hover-only visibility so
   panels don't dangle over the page when the drawer is closed.
   ========================================================= */
@media (max-width:1024px){
  /* Reset desktop flyout positioning everywhere — panels become inline blocks */
  .pseo-megamenu > ul.elementskit-submenu-panel,
  .pseo-megamenu > .elementskit-submenu-panel,
  .pseo-megamenu:hover > .elementskit-submenu-panel,
  .pseo-megamenu:focus-within > .elementskit-submenu-panel{
    position:static !important;
    transform:none !important;
    width:auto !important;max-width:none !important;
    box-shadow:none !important;border:0 !important;border-radius:0 !important;
    padding:0 !important;margin:0 !important;
    grid-template-columns:none !important;
    background:transparent !important;
    overflow:visible !important;
    transition:none !important;
  }
  /* Kill the hover-bridge pseudo on mobile */
  .pseo-megamenu > .elementskit-submenu-panel::before{display:none !important}


  /* Inside the offcanvas drawer the mega-panels behave as an ACCORDION:
     collapsed by default, expanded only when JS adds .pseo-mm-open to the
     parent <li>. This is what prevents every panel rendering at once and
     overlapping. The open rule also explicitly cancels the desktop
     position:fixed / opacity:0 / visibility:hidden declarations. */
  .elementskit-menu-offcanvas-elements .pseo-megamenu > ul.elementskit-submenu-panel,
  .elementskit-menu-offcanvas-elements .pseo-megamenu > .elementskit-dropdown{
    display:none !important;
    opacity:0 !important;visibility:hidden !important;
    pointer-events:none !important;
    position:static !important;transform:none !important;
    max-height:none !important;overflow:visible !important;
  }
  .elementskit-menu-offcanvas-elements .pseo-megamenu.pseo-mm-open > ul.elementskit-submenu-panel,
  .elementskit-menu-offcanvas-elements .pseo-megamenu.pseo-mm-open > .elementskit-dropdown{
    display:block !important;
    opacity:1 !important;visibility:visible !important;
    pointer-events:auto !important;
    padding:.25rem 0 .75rem 1rem !important;
  }

  /* Section header (top-level mega trigger) — full-width tappable row.
     Reuses the base ::after chevron (defined at ~1879); we only rotate it
     to "up" when the section is open. */
  .elementskit-menu-offcanvas-elements .pseo-megamenu > a{
    display:flex !important;
    align-items:center;
    justify-content:space-between;
    width:100% !important;
  }
  .elementskit-menu-offcanvas-elements .pseo-megamenu.pseo-mm-open > a::after{
    transform:translateY(1px) rotate(-135deg) !important;
    opacity:1 !important;
    color:var(--pseo-brand) !important;
  }
  /* Keep the caret from being squeezed out / forcing the row wider. */
  .elementskit-menu-offcanvas-elements .pseo-megamenu > a::after{flex:0 0 auto;margin-left:auto}

  /* --- Containment: every drawer item must stay within the menu width.
     Neutralises desktop fixed widths, nowrap and flex min-widths that would
     otherwise force horizontal scroll inside the offcanvas drawer. --- */
  .elementskit-menu-offcanvas-elements,
  .elementskit-menu-offcanvas-elements *{box-sizing:border-box}
  .elementskit-menu-offcanvas-elements .elementskit-navbar-nav,
  .elementskit-menu-offcanvas-elements .elementskit-navbar-nav > li,
  .elementskit-menu-offcanvas-elements .pseo-megamenu > .elementskit-submenu-panel,
  .elementskit-menu-offcanvas-elements .pseo-megamenu > .elementskit-submenu-panel > li{
    max-width:100% !important;
    width:auto !important;
    white-space:normal !important;          /* override base .elementskit-navbar-nav>li nowrap (~1870) */
    overflow-wrap:anywhere;
  }
  /* The expanded panel clips any stray horizontal overflow without touching
     the drawer's own vertical scroll. */
  .elementskit-menu-offcanvas-elements .pseo-megamenu.pseo-mm-open > .elementskit-submenu-panel{
    overflow-x:hidden !important;
  }
  /* In-menu ZIP form: shrink to fit, wrap if needed, never overflow. */
  .elementskit-menu-offcanvas-elements .pseo-mm-zipform{
    flex-wrap:wrap;min-width:0 !important;
  }
  .elementskit-menu-offcanvas-elements .pseo-mm-zipform input[type="text"]{min-width:0 !important;flex:1 1 60% !important}
  .elementskit-menu-offcanvas-elements .pseo-mm-zipform button{flex:0 0 auto !important}
  /* Titlebar bar + eyebrow: allow wrap, drop the desktop 200px min-width. */
  .elementskit-menu-offcanvas-elements .pseo-mm-bar{min-width:0 !important;max-width:100% !important}
  .elementskit-menu-offcanvas-elements .pseo-mm-bar__eyebrow{white-space:normal !important}

  .elementskit-menu-offcanvas-elements .pseo-megamenu > ul.elementskit-submenu-panel > li{
    border:0 !important;
    padding:0 !important;
    background:transparent !important;
    display:block !important;
    grid-column:auto !important;
  }
  /* Hide the desktop feature/CTA card in the mobile drawer. */
  .elementskit-menu-offcanvas-elements .pseo-mm-feature-col{display:none !important}
  /* Re-show the titlebar as a compact, tappable "Browse all →" hub link at
     the top of the open panel (it's the section's link to /materials/ etc.). */
  .elementskit-menu-offcanvas-elements .pseo-mm-titlebar{display:block !important}
  .elementskit-menu-offcanvas-elements .pseo-mm-titlebar > a{
    display:block !important;
    padding:.5rem 0 .6rem !important;
    margin:0 0 .25rem !important;
    color:var(--pseo-brand-d) !important;
    font-weight:700 !important;
    font-size:.82rem !important;
    text-transform:uppercase;
    letter-spacing:.05em;
    border-bottom:1px dashed var(--pseo-line) !important;
    background:transparent !important;
  }
  /* The titlebar's desktop eyebrow/body are noisy on mobile — show only the
     headline row, hide the long description. */
  .elementskit-menu-offcanvas-elements .pseo-mm-titlebar .pseo-mm-bar__body{display:none !important}

  /* Category headers — small uppercase labels, non-clickable */
  .elementskit-menu-offcanvas-elements .pseo-mm-cat > a{
    padding:.65rem 0 .3rem !important;
    color:var(--pseo-brand-d) !important;
    font-weight:700 !important;
    font-size:.78rem !important;
    text-transform:uppercase;
    letter-spacing:.06em;
    background:transparent !important;
    pointer-events:none;
    border:0 !important;
  }
  .elementskit-menu-offcanvas-elements .pseo-mm-cat__label{
    border:0 !important;padding:0 !important;
  }
  /* Flat list items (state rows, product rows, leaves) */
  .elementskit-menu-offcanvas-elements .pseo-mm-state > a,
  .elementskit-menu-offcanvas-elements .pseo-mm-leaf > a{
    display:block !important;
    padding:.5rem 0 !important;
    font-size:.95rem !important;
    font-weight:500 !important;
    color:var(--pseo-text) !important;
    border:0 !important;
    background:transparent !important;
    white-space:normal !important;
    overflow:visible !important;
    text-overflow:initial !important;
  }
  .elementskit-menu-offcanvas-elements .pseo-mm-state > a:hover,
  .elementskit-menu-offcanvas-elements .pseo-mm-leaf > a:hover{
    color:var(--pseo-brand-d) !important;
    background:transparent !important;
    padding-left:0 !important;
  }
  /* "View all →" leaves — keep their accent in mobile too */
  .elementskit-menu-offcanvas-elements .pseo-mm-leaf--all > a{
    color:var(--pseo-brand-d) !important;
    font-weight:600 !important;
    margin-top:.25rem;
    padding-top:.5rem !important;
    border-top:1px dashed var(--pseo-line) !important;
  }
  /* ZIP form — full-width inside mobile drawer */
  .elementskit-menu-offcanvas-elements .pseo-mm-zipform-row{
    padding:.5rem 0 1rem !important;
    background:transparent !important;
    border:0 !important;
    display:block !important;
  }
  .elementskit-menu-offcanvas-elements .pseo-mm-zipform{
    max-width:100% !important;width:100% !important;
  }
  /* State count badges — smaller */
  .elementskit-menu-offcanvas-elements .pseo-mm-cat__count{
    font-size:.65rem !important;
  }

  /* Materials rail+pane body — collapses to a stacked accordion.
     Categories become section headers; tapping one expands its pane. */
  .elementskit-menu-offcanvas-elements .pseo-mm-materials-body > a{
    display:none !important; /* hide the placeholder <a>; the inner .pseo-mm-mb owns content */
  }
  .elementskit-menu-offcanvas-elements .pseo-mm-materials-body{
    display:block !important;
  }
  /* The display:contents wrapper above only kicks in when the <a> renders;
     here we re-show the .pseo-mm-mb directly inside the LI. */
  .elementskit-menu-offcanvas-elements .pseo-mm-mb{
    display:block !important;
    min-height:0 !important;
    grid-template-columns:none !important;
  }
  .elementskit-menu-offcanvas-elements .pseo-mm-mb__rail,
  .elementskit-menu-offcanvas-elements .pseo-mm-mb__panes{
    display:block !important;
    padding:0 !important;
    margin:0 !important;
    border:0 !important;
    background:transparent !important;
    max-height:none !important;
    overflow:visible !important;
  }
  .elementskit-menu-offcanvas-elements .pseo-mm-mb__rail{display:none !important}
  .elementskit-menu-offcanvas-elements .pseo-mm-mb__pane{
    display:block !important;
    grid-template-columns:none !important;
    animation:none !important;
    padding:.15rem 0 .55rem 0 !important;
  }
  /* Section header for each category, populated by JS via data-label
     (uses the category's display name, e.g. "Crushed Stone"). */
  .elementskit-menu-offcanvas-elements .pseo-mm-mb__pane[data-label]::before{
    content:attr(data-label);
    display:block;
    padding:.65rem 0 .3rem !important;
    color:var(--pseo-brand-d) !important;
    font-weight:700 !important;
    font-size:.78rem !important;
    text-transform:uppercase;
    letter-spacing:.06em;
  }
  .elementskit-menu-offcanvas-elements .pseo-mm-mb__pane > a{
    display:flex !important;
    align-items:center;
    gap:.6rem;
    padding:.4rem 0 !important;
    margin:0 !important;
    border-radius:0 !important;
    color:var(--pseo-text) !important;
    font-size:.95rem !important;
    font-weight:500 !important;
    background:transparent !important;
    transform:none !important;
    white-space:normal !important;
  }
  .elementskit-menu-offcanvas-elements .pseo-mm-mb__pane > a:hover,
  .elementskit-menu-offcanvas-elements .pseo-mm-mb__pane > a:focus-visible{
    color:var(--pseo-brand-d) !important;
    background:transparent !important;
    transform:none !important;
  }
  .elementskit-menu-offcanvas-elements .pseo-mm-mb__thumb{
    flex:0 0 36px;
    width:36px;
    height:36px;
  }
  /* Compare 3-column body stacks to a single column in the mobile drawer. */
  .elementskit-menu-offcanvas-elements .pseo-mm-compare3{
    grid-template-columns:1fr !important;
  }
  .elementskit-menu-offcanvas-elements .pseo-mm-c3col{
    border-right:0 !important;
    padding:.4rem 0 .6rem !important;
  }
}

/* Smaller phones — tighter tap targets */
@media (max-width:480px){
  .elementskit-menu-offcanvas-elements .pseo-mm-state > a,
  .elementskit-menu-offcanvas-elements .pseo-mm-leaf > a{
    padding:.45rem 0 !important;
    font-size:.92rem !important;
  }
}

/* =========================================================
   INTERACTIVE US MAP — /delivery/ page
   ========================================================= */
.pseo-usmap-wrap{
  background:#fff;
  border:1px solid var(--pseo-line);
  border-radius:14px;
  padding:1.6rem 1.6rem 1.2rem;
  margin:1.5rem 0 2.25rem;
  box-shadow:var(--pseo-shadow);
}
.pseo-usmap-stage{
  position:relative;
  width:100%;
  overflow:hidden;
}
.pseo-usmap{
  width:100%;
  height:auto;
  max-width:100%;
  display:block;
  /* Override the SVG's inline styles that ship with the wikimedia base */
  fill:#E9EBEF;
}
.pseo-usmap path{ transition:fill .15s ease, transform .12s ease; }
.pseo-usmap__state{ cursor:default; }
.pseo-usmap__state--inactive{
  fill:#E5E7EB;
}
.pseo-usmap__state--active{
  cursor:pointer;
  fill:var(--pseo-brand-l);
}
.pseo-usmap__state--active.pseo-usmap__state--light  { fill:#F8C9A7; }
.pseo-usmap__state--active.pseo-usmap__state--mid    { fill:#F1A476; }
.pseo-usmap__state--active.pseo-usmap__state--heavy  { fill:#E8874A; }
.pseo-usmap__state--active:hover,
.pseo-usmap__state--active:focus{
  fill:var(--pseo-brand-d);
  outline:none;
}
/* Tooltip on hover using the SVG's built-in <title> behaviour from the OS,
   plus a CSS tooltip via aria-label is enough; no JS tooltip layer needed. */

.pseo-usmap__legend{
  display:flex;flex-wrap:wrap;gap:.85rem 1.4rem;
  margin-top:.95rem;padding-top:.95rem;
  border-top:1px solid var(--pseo-line-2);
  font-size:.86rem;color:var(--pseo-text-2);
  align-items:center;
}
.pseo-usmap__legend-dot{
  display:inline-block;
  width:14px;height:14px;
  border-radius:3px;
  margin-right:.4rem;
  vertical-align:-3px;
  border:1px solid rgba(0,0,0,.08);
}
.pseo-usmap__legend-dot--none  { background:#E5E7EB; }
.pseo-usmap__legend-dot--light { background:#F8C9A7; }
.pseo-usmap__legend-dot--mid   { background:#F1A476; }
.pseo-usmap__legend-dot--heavy { background:#E8874A; }

@media (max-width:640px){
  .pseo-usmap-wrap{ padding:1rem .75rem .75rem; }
}

/* =========================================================
   GOOGLE MAPS EMBED — state + city pages
   ========================================================= */
.pseo-mapsection{ margin:2.5rem 0; }
.pseo-mapwrap{
  border:1px solid var(--pseo-line);
  border-radius:14px;
  overflow:hidden;
  background:var(--pseo-bg-soft);
  box-shadow:var(--pseo-shadow);
  margin-top:1rem;
}
.pseo-mapwrap iframe{ display:block; width:100%; }

/* =========================================================
   MAIN FOOTER — child-theme footer.php, replaces the
   previously-used Elementor footer template. Renders brand +
   five standardized 5-link columns with a "See more" accent.
   ========================================================= */
.pseo-main-footer{
  background:#101113;
  color:#B8BBC0;
  padding:3rem 1.25rem 1.6rem;
  font-family:"Poppins","Helvetica Neue",Arial,sans-serif;
  border-top:1px solid #2A2A2A;
}
.pseo-main-footer__inner{ max-width:1320px;margin:0 auto; }

.pseo-main-footer__cols{
  display:grid;
  grid-template-columns:1.3fr repeat(5, minmax(0, 1fr));
  gap:2rem;
  padding-bottom:2rem;
  border-bottom:1px solid #2A2A2A;
}
@media (max-width:1180px){
  .pseo-main-footer__cols{ grid-template-columns:repeat(3, minmax(0,1fr)); }
  .pseo-main-footer__brand{ grid-column:1 / -1; }
}

.pseo-main-footer__brand{ display:flex;flex-direction:column;gap:.85rem; }
.pseo-main-footer__logo img{ max-width:200px;height:auto;display:block; }
.pseo-main-footer__sitename{
  font-size:1.4rem;font-weight:700;color:#fff;
  text-decoration:none;letter-spacing:-.01em;
}
.pseo-main-footer__tagline{
  font-size:.92rem;line-height:1.55;color:#9DA1A7;
  margin:0;
}
.pseo-main-footer__cta{
  display:inline-flex;align-items:center;gap:.4rem;
  align-self:flex-start;
  background:var(--pseo-brand);color:#fff !important;
  padding:.7rem 1.3rem;border-radius:99px;
  font-weight:600;font-size:.92rem;
  text-decoration:none !important;
  transition:background .15s,transform .12s;
}
.pseo-main-footer__cta:hover{ background:var(--pseo-brand-d);transform:translateY(-1px); }
.pseo-main-footer__cta::after{ content:" \2192";font-weight:700; }

.pseo-main-footer__col-title{
  font-size:.74rem;font-weight:700;letter-spacing:.16em;
  color:#fff;text-transform:uppercase;
  margin:0 0 .9rem;
}
.pseo-main-footer__col ul{ list-style:none;margin:0;padding:0; }
.pseo-main-footer__col li{ margin:.3rem 0; }
.pseo-main-footer__col a{
  color:#B8BBC0;text-decoration:none;
  font-size:.9rem;line-height:1.5;
  transition:color .12s;
}
.pseo-main-footer__col a:hover{ color:#fff; }
.pseo-main-footer__col li:has(> .pseo-main-footer__col-all){
  margin-top:.65rem;
}
.pseo-main-footer__col-all{
  color:var(--pseo-brand) !important;
  font-weight:600;
}
.pseo-main-footer__col-all::after{
  content:" \2192";
  font-weight:700;
}
.pseo-main-footer__col-all:hover{ color:#fff !important; }

.pseo-main-footer__bottom{
  display:flex;justify-content:space-between;align-items:center;
  gap:1rem;flex-wrap:wrap;
  padding-top:1.2rem;
  font-size:.84rem;color:#7B7F87;
}
.pseo-main-footer__bottom-links{
  display:inline-flex;gap:1.3rem;flex-wrap:wrap;
}
.pseo-main-footer__bottom-links a{
  color:#7B7F87;text-decoration:none;
  transition:color .12s;
}
.pseo-main-footer__bottom-links a:hover{ color:#fff; }

@media (max-width:980px){
  .pseo-main-footer__cols{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }
  .pseo-main-footer__brand{ grid-column:1 / -1; }
}
@media (max-width:560px){
  .pseo-main-footer{ padding:2.25rem 1rem 1.4rem; }
  .pseo-main-footer__cols{ gap:1.5rem; }
  .pseo-main-footer__bottom{ flex-direction:column;align-items:flex-start; }
}

/* =========================================================
   US MAP — labels + centering polish
   ========================================================= */
.pseo-usmap-stage{
  text-align:center;        /* center the inline-block SVG */
}
.pseo-usmap{
  margin:0 auto;            /* belt-and-suspenders centering */
}
/* State name labels rendered on top of each state */
.pseo-usmap__label{
  font-family:"Poppins","Helvetica Neue",Arial,sans-serif;
  font-size:11px;
  font-weight:700;
  fill:#3A2E25;
  pointer-events:none;       /* labels never block clicks on the path */
  text-anchor:middle;
  dominant-baseline:central;
}
.pseo-usmap__state--inactive + .pseo-usmap__label,
.pseo-usmap__label--inactive{ fill:#6B7280;font-weight:600; }
.pseo-usmap__label--small{ font-size:9px; }
.pseo-usmap__label--white{ fill:#fff; }

/* Landing page US map section */
.pseo-home-usmap{
  background:linear-gradient(180deg,#FFF8F3 0%,#fff 100%);
  padding:3rem 1.25rem;
  margin:0 auto;
  width:100%;
}
.pseo-home-usmap__inner{
  max-width:1320px;margin:0 auto;
}
.pseo-home-usmap__head{
  text-align:center;margin-bottom:1.5rem;
}
.pseo-home-usmap__eyebrow{
  display:inline-block;
  font-size:.72rem;font-weight:700;letter-spacing:.18em;
  color:var(--pseo-brand);text-transform:uppercase;
  background:#fff;padding:.32rem .85rem;border-radius:99px;
  border:1px solid var(--pseo-brand-l);
  margin-bottom:.7rem;
}
.pseo-home-usmap__h2{
  font-size:clamp(1.7rem, 3vw, 2.4rem);
  font-weight:700;
  margin:0 0 .65rem;
  letter-spacing:-.01em;
  color:var(--pseo-text);
}
.pseo-home-usmap__lede{
  font-size:1.02rem;color:var(--pseo-text-2);
  margin:0 auto 1rem;max-width:42rem;line-height:1.55;
}

/* =========================================================
   CONTACT US PAGE - rendered by page-contact-us.php.
   The full page uses existing PSEO design tokens (pseo-hero,
   mygb-state-stats, pseo-howto, pseo-grid, pseo-card, pseo-faq).
   Only the contact-grid + form-section layouts below are
   specific to this template.
   ========================================================= */

/* Brand-gradient hero background (no stock image needed) */
.pseo-hero--contact .pseo-hero__media--gradient{
  position:absolute;inset:0;
  background:linear-gradient(135deg,#FFF8F3 0%,#FFE8D6 55%,#F8C9A7 100%);
  z-index:0;
}
.pseo-hero--contact .pseo-hero__media--gradient .pseo-hero__media-shade{
  display:none;
}
.pseo-hero--contact{
  position:relative;
  background:transparent;
}
.pseo-hero--contact > *:not(.pseo-hero__media){
  position:relative;z-index:1;
}

/* Two-column contact details + quick links block */
.pseo-contact-grid{
  display:grid;
  grid-template-columns:minmax(260px,1fr) 2fr;
  gap:1.5rem;
  margin:2.5rem 0;
}
.pseo-contact-card{
  background:#fff;
  border:1px solid var(--pseo-line);
  border-radius:14px;
  padding:1.5rem 1.6rem;
  box-shadow:var(--pseo-shadow);
}
.pseo-contact-card h3{
  margin:0 0 1rem;
  font-size:1.1rem;font-weight:700;
  color:var(--pseo-text);
  letter-spacing:-.005em;
}
.pseo-contact-card--info dl{
  display:grid;
  grid-template-columns:minmax(80px,auto) 1fr;
  gap:.65rem 1rem;
  margin:0 0 1.2rem;
}
.pseo-contact-card--info dt{
  font-size:.74rem;font-weight:700;letter-spacing:.14em;
  color:var(--pseo-muted);text-transform:uppercase;
  align-self:center;
}
.pseo-contact-card--info dd{
  margin:0;font-size:.98rem;color:var(--pseo-text);
}
.pseo-contact-card--info dd a{
  color:var(--pseo-brand-d);font-weight:600;text-decoration:none;
}
.pseo-contact-card--info dd a:hover{ color:var(--pseo-brand); }

.pseo-contact-card--links{
  background:var(--pseo-bg-soft);
}
.pseo-contact-card--links .pseo-grid{
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:.75rem;
}

@media (max-width:760px){
  .pseo-contact-grid{ grid-template-columns:1fr; }
  .pseo-contact-card--links .pseo-grid{ grid-template-columns:1fr; }
}

/* Contact form wrapper section */
.pseo-form-section{
  margin:2.5rem 0;
  padding:2rem 1.5rem 2.25rem;
  background:#fff;
  border:1px solid var(--pseo-line);
  border-radius:14px;
  box-shadow:var(--pseo-shadow-md);
}
.pseo-form-section h2{ margin-top:0; }
.pseo-form-section__lede{
  font-size:1rem;color:var(--pseo-text-2);
  margin:0 0 1.4rem;line-height:1.55;max-width:42rem;
}
.pseo-form-section__lede a{
  color:var(--pseo-brand-d);font-weight:600;text-decoration:none;
}
.pseo-form-section__lede a:hover{ color:var(--pseo-brand); }
.pseo-form-section__form{
  scroll-margin-top:80px;
}
.pseo-form-section .elementor-form{
  max-width:none;
}

/* ---- ZIP CTA lead-capture modal ---- */
body.mygb-lead-open{overflow:hidden}
.mygb-lead-overlay{
  position:fixed;inset:0;z-index:99999;
  display:flex;align-items:center;justify-content:center;
  padding:1.25rem;
  background:rgba(26,26,26,.55);
  backdrop-filter:blur(2px);
}
.mygb-lead-overlay[hidden]{display:none}
.mygb-lead-modal{
  position:relative;
  width:100%;max-width:440px;
  background:#fff;
  border-radius:14px;
  padding:2rem 1.75rem 1.75rem;
  box-shadow:0 24px 60px -12px rgba(26,26,26,.4);
  font-family:"Poppins","Helvetica Neue",Arial,sans-serif;
  animation:mygbLeadIn .18s ease-out;
}
@keyframes mygbLeadIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.mygb-lead-close{
  position:absolute;top:.6rem;right:.85rem;
  border:0;background:transparent;cursor:pointer;
  font-size:1.6rem;line-height:1;color:var(--pseo-muted,#888);
}
.mygb-lead-close:hover{color:var(--pseo-text,#1a1a1a)}
.mygb-lead-title{
  font-size:1.3rem;font-weight:700;margin:0 1.5rem .35rem 0;
  color:var(--pseo-text,#1a1a1a);letter-spacing:-.01em;
}
.mygb-lead-sub{margin:0 0 1.1rem;color:var(--pseo-text-2,#555);font-size:.95rem}
.mygb-lead-form{display:flex;flex-direction:column;gap:.85rem}
.mygb-lead-form label{
  display:flex;flex-direction:column;gap:.3rem;
  font-size:.82rem;font-weight:600;color:var(--pseo-text,#1a1a1a);
}
.mygb-lead-form input{
  font:inherit;font-weight:400;
  padding:.8rem .95rem;
  border:1.5px solid var(--pseo-line,#e3e3e3);
  border-radius:8px;outline:none;
  transition:border-color .15s;
}
.mygb-lead-form input:focus{border-color:var(--pseo-brand,#e8874a)}
.mygb-lead-error{
  margin:0;color:#c0392b;font-size:.85rem;font-weight:500;
}
.mygb-lead-submit{
  margin-top:.35rem;
  background:var(--pseo-brand,#e8874a);color:#fff;
  border:0;border-radius:99px;
  padding:.9rem 1.5rem;
  font:inherit;font-weight:700;font-size:1.02rem;
  cursor:pointer;
  transition:background .15s,transform .12s;
}
.mygb-lead-submit:hover{background:var(--pseo-brand-d,#d2702f);transform:translateY(-1px)}
.mygb-lead-submit:disabled{opacity:.65;cursor:default;transform:none}

/* =========================================================
   SINGLE PRODUCT PAGE (/product/<slug>/) — restyle only.
   All WooCommerce hooks/markup are preserved; this only brands
   and re-lays-out the existing elements. Everything is scoped to
   .pseo-product so the rest of the site is unaffected.
   ========================================================= */
.pseo-product .pseo-product__wc{ max-width:none; }
.pseo-product .pseo-product__entry{ margin:0 0 2.5rem; }

/* Neutralise WooCommerce's default float/48% single-product layout — our
   CSS grid owns the layout, so the gallery + summary must each be full width
   of their column (this is what fixes the "tiny image"). */
.pseo-product div.product{ display:block !important; }
.pseo-product div.product > .woocommerce-product-gallery,
.pseo-product div.product > .summary,
.pseo-product div.product .woocommerce-product-gallery,
.pseo-product div.product .summary,
.pseo-product div.product .entry-summary{
  width:100% !important;
  float:none !important;
  margin:0 !important;
}

/* Two-column top: gallery | summary (stacks on mobile). */
.pseo-product__top{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);
  gap:2.75rem;
  align-items:start;
  margin:.5rem 0 2.5rem;
}
@media (max-width:900px){
  .pseo-product__top{ grid-template-columns:1fr; gap:1.5rem; }
}

/* Gallery — large, framed main image with a clean thumbnail row. */
.pseo-product__gallery{ position:relative; min-width:0; }
.pseo-product__gallery .woocommerce-product-gallery{ margin:0 !important; width:100% !important; }
.pseo-product__gallery .woocommerce-product-gallery__wrapper{ margin:0 !important; }
.pseo-product__gallery .flex-viewport{ width:100% !important; }
.pseo-product__gallery .woocommerce-product-gallery__image,
.pseo-product__gallery .woocommerce-product-gallery__image > a{ display:block; width:100% !important; }
/* Main slide image — every product image renders at the SAME size: a large
   square, centre-cropped (object-fit:cover) so tall/wide originals all match. */
.pseo-product__gallery .woocommerce-product-gallery__image > a > img,
.pseo-product__gallery .woocommerce-product-gallery__image > img{
  width:100% !important;
  aspect-ratio:1 / 1;
  height:auto !important;
  object-fit:cover;
  object-position:center;
  display:block;
  border-radius:14px;
  border:1px solid var(--pseo-line);
  box-shadow:0 16px 40px -16px rgba(26,26,26,.22);
  background:#fff;
}
/* The zoom overlay WooCommerce injects must keep its natural dimensions —
   forcing width/height onto it is what was skewing the magnified image. */
.pseo-product__gallery img.zoomImg{
  width:auto !important;
  height:auto !important;
  max-width:none !important;
  aspect-ratio:auto !important;
  object-fit:fill !important;
  border:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
}
/* Thumbnail strip below the main image. */
.pseo-product__gallery .flex-control-thumbs{
  display:flex; flex-wrap:wrap; gap:.6rem; list-style:none; margin:.85rem 0 0; padding:0;
}
.pseo-product__gallery .flex-control-thumbs li{ width:auto; margin:0; flex:0 0 auto; }
.pseo-product__gallery .flex-control-thumbs img{
  width:72px !important; height:72px; object-fit:cover;
  border-radius:10px; border:2px solid var(--pseo-line);
  cursor:pointer; opacity:.75; transition:opacity .15s, border-color .15s;
}
.pseo-product__gallery .flex-control-thumbs img:hover,
.pseo-product__gallery .flex-control-thumbs img.flex-active{ opacity:1; border-color:var(--pseo-brand); }
/* Zoom / lightbox trigger. */
.pseo-product__gallery .woocommerce-product-gallery__trigger{
  z-index:5; top:1rem; right:1rem;
}
.pseo-product__gallery .onsale{
  background:var(--pseo-brand) !important; color:#fff !important;
  border:0 !important; border-radius:99px !important;
  font-weight:700; min-height:0 !important; min-width:0 !important;
  padding:.3rem .8rem !important; line-height:1.4 !important;
}

.pseo-product__summary{ min-width:0; }
.pseo-product .product_title{
  font-family:"Poppins",sans-serif;
  font-size:clamp(1.6rem,3vw,2.3rem);
  font-weight:700; letter-spacing:-.01em; line-height:1.15;
  margin:0 0 .6rem; color:var(--pseo-text);
}
.pseo-product .price,
.pseo-product .summary .price{
  color:var(--pseo-text) !important;
  font-size:1.5rem !important; font-weight:700;
  margin:.25rem 0 1rem;
}
.pseo-product .price del{ color:var(--pseo-muted); font-weight:500; opacity:.7; }
.pseo-product .price ins{ text-decoration:none; color:var(--pseo-brand-d); }
.pseo-product .woocommerce-product-details__short-description{
  color:var(--pseo-text-2); line-height:1.6; margin-bottom:1.25rem;
}

/* Quantity + variation selects + add-to-cart — branded, fully functional. */
.pseo-product .quantity{ display:inline-flex; align-items:center; }
.pseo-product .quantity input.qty{
  border:1.5px solid var(--pseo-line); border-radius:10px;
  padding:.75rem .5rem; font:inherit; font-size:1rem; font-weight:600;
  width:4.75rem; height:auto; text-align:center; background:#fff; color:var(--pseo-text);
}

/* Variations laid out as clean stacked rows: label above a full-width select. */
.pseo-product table.variations{
  display:block; width:100%; border:0; margin:0 0 1.1rem;
}
.pseo-product table.variations tbody{ display:flex; flex-direction:column; gap:.9rem; }
.pseo-product table.variations tr{ display:flex; flex-direction:column; gap:.35rem; }
.pseo-product table.variations th.label,
.pseo-product table.variations td.value{ padding:0; border:0; text-align:left; }
/* Remove the theme's zebra-stripe (hsla(0,0%,50%,.071)) that paints the odd
   variation row grey behind the Tons select. */
.pseo-product table.variations tbody > tr:nth-child(odd) > td,
.pseo-product table.variations tbody > tr:nth-child(odd) > th,
.pseo-product table.variations tbody > tr:nth-child(even) > td,
.pseo-product table.variations tbody > tr:nth-child(even) > th{ background-color:transparent !important; }
.pseo-product table.variations th.label label{
  margin:0; font-weight:600; font-size:.85rem; letter-spacing:.02em;
  text-transform:uppercase; color:var(--pseo-muted);
}
.pseo-product table.variations td.value{ display:flex; align-items:center; gap:.85rem; flex-wrap:wrap; }
.pseo-product .variations select,
.pseo-product .single_variation_wrap select,
.pseo-product select{
  appearance:none !important; -webkit-appearance:none !important; -moz-appearance:none !important;
  flex:1 1 240px; max-width:100%;
  border:1.5px solid var(--pseo-line) !important; border-radius:10px !important;
  /* Force a white field (kills WooCommerce/theme grey) and keep the chevron. */
  background-color:#fff !important;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23C56F35' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") !important;
  background-repeat:no-repeat !important;
  background-position:right 1rem center !important;
  background-size:14px 14px !important;
  padding:.8rem 2.5rem .8rem 1rem !important; font:inherit; font-size:1rem; font-weight:600; color:var(--pseo-text);
  cursor:pointer; min-height:auto; line-height:1.3; box-shadow:0 1px 2px rgba(26,26,26,.05);
}
.pseo-product .variations select:hover,
.pseo-product .single_variation_wrap select:hover{ border-color:rgba(232,135,74,.55) !important; }
.pseo-product a.reset_variations{
  font-size:.85rem; color:var(--pseo-brand-d); font-weight:600; text-decoration:none;
}
.pseo-product a.reset_variations:hover{ color:var(--pseo-brand); }
.pseo-product .woocommerce-variation-price .price{ font-size:1.35rem !important; margin:.5rem 0 !important; }
.pseo-product .variations select:focus,
.pseo-product .quantity input.qty:focus{ outline:none; border-color:var(--pseo-brand); box-shadow:0 0 0 3px rgba(232,135,74,.15); }
.pseo-product .single_add_to_cart_button,
.pseo-product .single_add_to_cart_button.button{
  background:var(--pseo-brand) !important; color:#fff !important;
  border:0 !important; border-radius:99px !important;
  font-weight:700 !important; font-size:1.05rem !important;
  padding:.95rem 2rem !important; letter-spacing:.01em;
  box-shadow:0 6px 18px -4px rgba(232,135,74,.55); transition:background .15s, transform .12s;
}
.pseo-product .single_add_to_cart_button:hover{ background:var(--pseo-brand-d) !important; transform:translateY(-1px); }
.pseo-product .woocommerce-variation-add-to-cart{ display:flex; flex-wrap:wrap; align-items:center; gap:.6rem; }
.pseo-product .cart{ margin-bottom:1.25rem; display:flex; flex-wrap:wrap; align-items:center; gap:.6rem; }
.pseo-product .product_meta{ font-size:.85rem; color:var(--pseo-muted); border-top:1px solid var(--pseo-line); padding-top:1rem; margin-top:.5rem; }
.pseo-product .product_meta a{ color:var(--pseo-brand-d); }

/* Quick-spec pills under add-to-cart. */
.pseo-product__quickspecs{
  list-style:none; margin:1rem 0 0; padding:0;
  display:flex; flex-wrap:wrap; gap:.5rem;
}
.pseo-product__quickspecs li{
  display:flex; flex-direction:column; gap:.1rem;
  background:var(--pseo-bg-tint); border:1px solid var(--pseo-line);
  border-radius:10px; padding:.5rem .8rem; min-width:90px;
}
.pseo-product__quickspecs span{ font-size:.7rem; text-transform:uppercase; letter-spacing:.06em; color:var(--pseo-muted); font-weight:600; }
.pseo-product__quickspecs strong{ font-size:.95rem; color:var(--pseo-text); }

/* Editorial sections (About / coverage / how-to) reuse the .pseo headings. */
.pseo-product__about,
.pseo-product__coverage,
.pseo-product__howto{ margin:2.25rem 0; }
.pseo-product__blurb{ color:var(--pseo-text-2); font-size:1.05rem; line-height:1.6; max-width:70ch; }
.pseo-coverage-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; margin-top:1rem; }
@media (max-width:560px){ .pseo-coverage-grid{ grid-template-columns:1fr; } }
.pseo-coverage-card{
  background:#fff; border:1px solid var(--pseo-line); border-radius:12px;
  padding:1.1rem 1.25rem; text-align:center; box-shadow:var(--pseo-shadow);
}
.pseo-coverage-card strong{ display:block; font-size:1.5rem; color:var(--pseo-brand-d); font-weight:700; }
.pseo-coverage-card span{ font-size:.85rem; color:var(--pseo-muted); }

/* WooCommerce product tabs — brand the active tab + clean borders. */
.pseo-product .woocommerce-tabs{ margin:2.5rem 0 1rem; clear:both; }
.pseo-product .woocommerce-tabs ul.tabs{
  border-bottom:1px solid var(--pseo-line); padding:0 0 0 0; margin:0 0 1.25rem; display:flex; flex-wrap:wrap; gap:.25rem;
}
.pseo-product .woocommerce-tabs ul.tabs::before{ border:0 !important; }
.pseo-product .woocommerce-tabs ul.tabs li{
  background:transparent !important; border:0 !important; border-radius:0 !important;
  margin:0 !important; padding:0 !important;
}
.pseo-product .woocommerce-tabs ul.tabs li::before,
.pseo-product .woocommerce-tabs ul.tabs li::after{ display:none !important; }
.pseo-product .woocommerce-tabs ul.tabs li a{
  display:block; padding:.7rem 1.1rem !important; font-weight:600; color:var(--pseo-text-2) !important;
  border-bottom:2px solid transparent; transition:color .12s, border-color .12s;
}
.pseo-product .woocommerce-tabs ul.tabs li.active a{ color:var(--pseo-brand-d) !important; border-bottom-color:var(--pseo-brand); }
/* Tab panel content sits in a padded, bordered card. */
.pseo-product .woocommerce-tabs .panel,
.pseo-product .woocommerce-Tabs-panel{
  padding:1.6rem 1.75rem !important;
  margin:0 0 1.5rem !important;
  background:#fff;
  border:1px solid var(--pseo-line);
  border-radius:12px;
  box-shadow:var(--pseo-shadow);
}
.pseo-product .woocommerce-Tabs-panel > h2:first-child{ margin-top:0; }
.pseo-product .woocommerce-Tabs-panel h2{ font-family:"Poppins",sans-serif; }
/* Additional information attributes table — padded rows, clean dividers. */
.pseo-product .shop_attributes{
  width:100%; border-collapse:collapse; margin:.25rem 0 0;
}
.pseo-product .shop_attributes th,
.pseo-product .shop_attributes td{
  padding:.75rem 1rem !important;
  border:1px solid var(--pseo-line) !important;
  text-align:left; vertical-align:top; font-style:normal;
}
.pseo-product .shop_attributes th{
  background:var(--pseo-bg-tint); font-weight:600; color:var(--pseo-text); width:30%;
}
.pseo-product .shop_attributes td{ color:var(--pseo-text-2); }
.pseo-product .shop_attributes td p{ margin:0; }

/* Mobile: full-width add-to-cart for an easy tap target. */
@media (max-width:560px){
  .pseo-product .single_add_to_cart_button,
  .pseo-product .single_add_to_cart_button.button{ width:100%; justify-content:center; text-align:center; }
}

/* Shop grid embedded in an Elementor page (homepage "Bulk Gravel & Aggregate
   Delivered Nationwide" section). The .pseo wrapper already supplies the
   1250px max-width + 1.5rem left/right gutters; trim the heavy default
   top/bottom padding since a heading sits directly above it. */
.mygb-shop-embed{ padding-top:.5rem !important; padding-bottom:1.5rem !important; }
