/*
Theme Name:  Verdant
Theme URI:   https://oneearthconsulting.ca
Author:      One Earth Consulting
Description: Clean minimalist theme for One Earth Consulting — sustainability, compliance, credibility.
Version:     1.0.0
License:     GNU General Public License v2 or later
Text Domain: verdant
*/

/* ==========================================================
   TOKENS
   ========================================================== */
:root {
  --cream:       #F5F0E8;
  --cream-dark:  #EDE8DE;
  --forest:      #0E3320;
  --green:       #1A5C35;
  --green-mid:   #2E7D4F;
  --green-light: #D0E8D8;
  --blue:        #4BA8C8;
  --blue-light:  #D6EEF7;
  --ink:         #0F2317;
  --ink-mid:     #5A6B5E;
  --rule:        #D5CEBE;
  --white:       #FFFFFF;

  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'DM Sans', system-ui, sans-serif;
  --mono:  'DM Mono', 'Courier New', monospace;

  --pad: clamp(1.25rem, 5vw, 2.75rem);
  --cap: 1240px;
}

/* ==========================================================
   RESET
   ========================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body { font-family: var(--sans); background: var(--cream); color: var(--ink); line-height: 1.7; overflow-x: hidden; }
img  { max-width: 100%; height: auto; display: block; }
a    { color: inherit; text-decoration: none; }
ul   { list-style: none; }
button { cursor: pointer; font-family: inherit; }

/* ==========================================================
   LAYOUT
   ========================================================== */
.vd-wrap {
  width: 100%;
  max-width: var(--cap);
  margin: 0 auto;
  padding: 0 var(--pad);
}

/* ==========================================================
   NAV
   ========================================================== */
.vd-nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 500;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.4rem var(--pad);
  transition: background .35s ease, padding .35s ease, box-shadow .35s;
}
.vd-nav.stuck {
  background: rgba(245,240,232,.97);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding-top: .85rem;
  padding-bottom: .85rem;
  box-shadow: 0 1px 0 var(--rule);
}

/* Logo */
.vd-nav__logo { display: flex; align-items: center; }
.vd-nav__logo img {
  height: clamp(32px, 4vw, 44px);
  width: auto;
  /* White-ghost on dark hero */
  filter: brightness(0) invert(1);
  transition: filter .35s, height .25s;
}
.vd-nav.stuck .vd-nav__logo img { filter: none; }

/* Desktop links */
.vd-nav__menu {
  display: flex;
  align-items: center;
  gap: clamp(1.4rem, 3vw, 2.4rem);
}
.vd-nav__menu a {
  font-size: .83rem;
  letter-spacing: .05em;
  color: rgba(245,240,232,.8);
  transition: color .2s;
}
.vd-nav.stuck .vd-nav__menu a { color: var(--ink-mid); }
.vd-nav__menu a:hover,
.vd-nav.stuck .vd-nav__menu a:hover { color: var(--green); }

/* CTA link */
.vd-nav__cta {
  font-family: var(--mono);
  font-size: .7rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: .5rem 1.25rem;
  border: 1px solid rgba(245,240,232,.4);
  color: rgba(245,240,232,.9) !important;
  transition: background .2s, border-color .2s !important;
}
.vd-nav__cta:hover { background: rgba(245,240,232,.12) !important; }
.vd-nav.stuck .vd-nav__cta {
  border-color: var(--green) !important;
  color: var(--green) !important;
}
.vd-nav.stuck .vd-nav__cta:hover {
  background: var(--green) !important;
  color: var(--white) !important;
}

/* Hamburger */
.vd-burger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  padding: 4px;
  z-index: 510;
}
.vd-burger span {
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--cream);
  border-radius: 2px;
  transition: transform .3s ease, opacity .25s, background .3s;
  transform-origin: center;
}
.vd-nav.stuck .vd-burger span { background: var(--ink); }
.vd-burger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.vd-burger.open span:nth-child(2) { opacity: 0; }
.vd-burger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* Mobile drawer */
.vd-drawer {
  position: fixed;
  inset: 0;
  background: var(--forest);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(1.6rem, 4vh, 2.4rem);
  z-index: 490;
  opacity: 0;
  visibility: hidden;
  transition: opacity .3s ease, visibility .3s;
}
.vd-drawer.open { opacity: 1; visibility: visible; }
.vd-drawer a {
  font-family: var(--serif);
  font-size: clamp(1.8rem, 5vw, 2.6rem);
  color: var(--cream);
  transition: color .2s;
}
.vd-drawer a:hover { color: var(--blue); }
.vd-drawer .vd-nav__cta {
  font-family: var(--mono) !important;
  font-size: .8rem !important;
  padding: .85rem 2.2rem !important;
}

/* ==========================================================
   HERO
   ========================================================== */
.vd-hero {
  min-height: 100svh;
  min-height: 100vh;
  background: var(--forest);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding-bottom: clamp(3.5rem, 8vw, 7rem);
  position: relative;
  overflow: hidden;
}
.vd-hero__bg {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  font-family: var(--serif);
  font-size: clamp(5rem, 22vw, 22rem);
  font-weight: 300;
  color: rgba(255,255,255,.025);
  white-space: nowrap;
  pointer-events: none;
  user-select: none;
  letter-spacing: -.03em;
}
.vd-hero__sub-label {
  font-family: var(--mono);
  font-size: clamp(.58rem, 1vw, .68rem);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 1.2rem;
}
.vd-hero__headline {
  font-family: var(--serif);
  font-size: clamp(2.6rem, 7vw, 6.5rem);
  font-weight: 300;
  color: var(--cream);
  line-height: 1.08;
  letter-spacing: -.025em;
  margin-bottom: 1.4rem;
  max-width: 20ch;
}
.vd-hero__headline em { font-style: italic; color: var(--blue); }
.vd-hero__copy {
  font-size: clamp(.9rem, 1.5vw, 1.1rem);
  color: rgba(245,240,232,.62);
  max-width: 46ch;
  line-height: 1.8;
  margin-bottom: clamp(1.8rem, 3vw, 2.5rem);
}
.vd-hero__btns {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.vd-hero__scroll {
  position: absolute;
  bottom: 1.6rem;
  right: var(--pad);
  display: flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--mono);
  font-size: .58rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(245,240,232,.3);
  transition: opacity .4s;
}
.vd-hero__scroll-line { width: 36px; height: 1px; background: rgba(245,240,232,.2); }

/* Buttons */
.vd-btn {
  font-family: var(--mono);
  font-size: clamp(.68rem, 1.1vw, .78rem);
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: clamp(.7rem, 1.5vw, .9rem) clamp(1.4rem, 2.5vw, 2rem);
  display: inline-block;
  transition: background .22s, border-color .22s, color .22s, transform .18s;
  white-space: nowrap;
}
.vd-btn--solid { background: var(--green-mid); color: #fff; border: 1px solid transparent; }
.vd-btn--solid:hover { background: var(--green); transform: translateY(-2px); }
.vd-btn--ghost { border: 1px solid rgba(245,240,232,.35); color: rgba(245,240,232,.85); background: transparent; }
.vd-btn--ghost:hover { border-color: rgba(245,240,232,.75); color: var(--cream); }

/* ==========================================================
   STATS BAND
   ========================================================== */
.vd-stats {
  background: var(--green);
  border-top: 3px solid var(--blue);
  padding: clamp(2rem, 5vw, 3.5rem) 0;
}
.vd-stats__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  text-align: center;
}
.vd-stats__num {
  font-family: var(--serif);
  font-size: clamp(2rem, 5vw, 4rem);
  color: var(--cream);
  font-weight: 300;
  line-height: 1;
  margin-bottom: .35rem;
}
.vd-stats__lbl {
  font-family: var(--mono);
  font-size: clamp(.54rem, 1vw, .64rem);
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(245,240,232,.55);
}

/* ==========================================================
   SERVICES
   ========================================================== */
.vd-services { background: var(--cream); }

.vd-section-head { margin-bottom: clamp(2.5rem, 5vw, 4.5rem); }
.vd-section-label {
  font-family: var(--mono);
  font-size: clamp(.58rem, 1vw, .65rem);
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-mid);
  display: block;
  margin-bottom: .9rem;
}
.vd-section-head h2 {
  font-family: var(--serif);
  font-size: clamp(2.1rem, 5vw, 4.2rem);
  font-weight: 300;
  letter-spacing: -.02em;
  line-height: 1.12;
}
.vd-section-head h2 em { font-style: italic; color: var(--green); }
.vd-section-intro {
  font-size: clamp(.9rem, 1.4vw, 1.05rem);
  color: var(--ink-mid);
  max-width: 52ch;
  line-height: 1.85;
  margin-top: 1rem;
}

.vd-svc-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--rule);
}
.vd-svc {
  padding: clamp(1.4rem, 3vw, 2.4rem) 0;
  border-bottom: 1px solid var(--rule);
  display: grid;
  grid-template-columns: clamp(40px, 5vw, 58px) 1fr;
  gap: clamp(.8rem, 1.5vw, 1.4rem);
  align-items: start;
  transition: background .18s;
}
.vd-svc:nth-child(odd)  { padding-right: clamp(1.2rem, 3vw, 3rem); border-right: 1px solid var(--rule); }
.vd-svc:nth-child(even) { padding-left: clamp(1.2rem, 3vw, 3rem); }
.vd-svc--full { grid-column: 1 / -1; padding-left: 0 !important; padding-right: 0 !important; border-right: none !important; }
.vd-svc:hover { background: var(--green-light); }
.vd-svc__num {
  font-family: var(--mono);
  font-size: clamp(.56rem, 1vw, .63rem);
  letter-spacing: .15em;
  color: var(--green);
  padding-top: .2rem;
}
.vd-svc h3 {
  font-family: var(--serif);
  font-size: clamp(1.1rem, 2vw, 1.42rem);
  font-weight: 500;
  margin-bottom: .45rem;
  line-height: 1.2;
}
.vd-svc p {
  font-size: clamp(.82rem, 1.2vw, .9rem);
  color: var(--ink-mid);
  line-height: 1.8;
}

/* ==========================================================
   ABOUT / FOUNDER
   ========================================================== */
.vd-about { background: var(--cream-dark); }
.vd-about__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2.5rem, 6vw, 5rem);
  align-items: start;
}
.vd-about__left h2 {
  font-family: var(--serif);
  font-size: clamp(2.1rem, 4.5vw, 4rem);
  font-weight: 300;
  letter-spacing: -.02em;
  line-height: 1.12;
  margin-bottom: 1.4rem;
}
.vd-about__left h2 em { font-style: italic; color: var(--green); }
.vd-about__text {
  font-size: clamp(.88rem, 1.3vw, 1rem);
  color: var(--ink-mid);
  line-height: 1.85;
  margin-bottom: 1.5rem;
}
.vd-about__quote {
  font-family: var(--serif);
  font-size: clamp(1.05rem, 1.8vw, 1.3rem);
  color: var(--green);
  font-style: italic;
  line-height: 1.55;
  padding-left: 1.3rem;
  border-left: 3px solid var(--blue);
  margin-bottom: 1.5rem;
}

/* Founder card */
.vd-founder {
  background: var(--white);
  border: 1px solid var(--rule);
  overflow: hidden;
}

/* Photo + LinkedIn hover */
.vd-founder__img-wrap {
  position: relative;
  display: block;
  overflow: hidden;
}
.vd-founder__img-wrap img {
  width: 100%;
  height: clamp(220px, 28vw, 340px);
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform .5s ease, filter .38s;
}
.vd-founder__img-wrap:hover img {
  transform: scale(1.04);
  filter: brightness(.5) grayscale(.3);
}
.vd-founder__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .7rem;
  background: rgba(10,102,194,0);
  transition: background .38s ease;
  pointer-events: none;
}
.vd-founder__img-wrap:hover .vd-founder__overlay { background: rgba(10,102,194,.78); }
.vd-founder__li-badge {
  width: 50px; height: 50px;
  border: 2px solid rgba(255,255,255,.85);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--sans);
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .28s .05s ease, transform .28s .05s ease;
}
.vd-founder__li-text {
  font-family: var(--mono);
  font-size: .58rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.9);
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .28s .1s ease, transform .28s .1s ease;
}
.vd-founder__img-wrap:hover .vd-founder__li-badge,
.vd-founder__img-wrap:hover .vd-founder__li-text { opacity: 1; transform: translateY(0); }

/* Founder body */
.vd-founder__body { padding: clamp(1.3rem, 2.5vw, 2rem); }
.vd-founder__name {
  font-family: var(--serif);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 400;
  margin-bottom: .15rem;
}
.vd-founder__role {
  font-family: var(--mono);
  font-size: .6rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--green);
  display: block;
  margin-bottom: 1.2rem;
}
.vd-tag-row-label {
  font-family: var(--mono);
  font-size: .57rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-mid);
  display: block;
  margin-bottom: .5rem;
}
.vd-tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: .38rem;
  margin-bottom: 1.2rem;
}
.vd-tag {
  font-family: var(--mono);
  font-size: .56rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .26rem .6rem;
  border-radius: 2px;
}
.vd-tag--green { background: var(--green-light); color: var(--green); border: 1px solid rgba(26,92,53,.2); }
.vd-tag--blue  { background: var(--blue-light); color: #1a6080; border: 1px solid rgba(75,168,200,.25); transition: background .18s, color .18s; }
.vd-tag--blue:hover { background: var(--blue); color: #fff; }

.vd-founder__bio {
  font-size: clamp(.84rem, 1.2vw, .92rem);
  color: var(--ink-mid);
  line-height: 1.85;
  margin-bottom: 1.2rem;
}
.vd-founder__link {
  font-family: var(--mono);
  font-size: .61rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--blue);
  border-bottom: 1px solid transparent;
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  transition: border-color .18s;
}
.vd-founder__link:hover { border-bottom-color: var(--blue); }

/* ==========================================================
   CREDIBILITY
   ========================================================== */
.vd-cred { background: var(--forest); color: var(--cream); }
.vd-cred .vd-section-label { color: var(--blue); }
.vd-cred__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2.5rem, 6vw, 5rem);
  align-items: center;
}
.vd-cred h2 {
  font-family: var(--serif);
  font-size: clamp(2.1rem, 4.5vw, 4rem);
  font-weight: 300;
  letter-spacing: -.02em;
  margin: .8rem 0 1.3rem;
  line-height: 1.12;
}
.vd-cred h2 em { font-style: italic; color: var(--blue); }
.vd-cred__body {
  font-size: clamp(.88rem, 1.3vw, 1rem);
  color: rgba(245,240,232,.62);
  line-height: 1.9;
}
.vd-cred__body + .vd-cred__body { margin-top: .9rem; }
.vd-cred__em { color: var(--blue); font-weight: 500; }
.vd-cred__panel {
  padding: clamp(1.5rem, 3vw, 2.5rem);
  border: 1px solid rgba(245,240,232,.1);
  background: rgba(255,255,255,.04);
}
.vd-pillars { display: flex; flex-direction: column; gap: 1.7rem; }
.vd-pillar  { display: flex; gap: 1rem; align-items: flex-start; }
.vd-pillar__icon { font-size: 1.3rem; flex-shrink: 0; }
.vd-pillar__title {
  font-family: var(--serif);
  font-size: clamp(1rem, 1.4vw, 1.1rem);
  font-weight: 500;
  color: var(--cream);
  margin-bottom: .25rem;
}
.vd-pillar__desc {
  font-size: clamp(.79rem, 1.1vw, .86rem);
  color: rgba(245,240,232,.48);
  line-height: 1.75;
}

/* ==========================================================
   CONTACT
   ========================================================== */
.vd-contact { background: var(--cream); }
.vd-contact__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2.5rem, 6vw, 5rem);
  align-items: start;
}
.vd-contact h2 {
  font-family: var(--serif);
  font-size: clamp(2.1rem, 4.5vw, 4rem);
  font-weight: 300;
  letter-spacing: -.02em;
  margin: .8rem 0 1.3rem;
  line-height: 1.12;
}
.vd-contact h2 em { font-style: italic; color: var(--green); }
.vd-contact__body { font-size: clamp(.88rem, 1.3vw, 1rem); color: var(--ink-mid); line-height: 1.85; margin-bottom: 1.8rem; }
.vd-contact__success {
  padding: .9rem 1.3rem;
  background: var(--green-light);
  border-left: 3px solid var(--blue);
  color: var(--green);
  font-size: .87rem;
  margin-bottom: 1.4rem;
}
.vd-contact__meta { display: flex; flex-direction: column; gap: .9rem; }
.vd-contact__row {
  display: flex; align-items: center; gap: .85rem;
  font-size: clamp(.84rem, 1.2vw, .93rem);
  color: var(--ink-mid);
}
.vd-contact__row a { color: var(--green); border-bottom: 1px solid transparent; transition: border-color .18s; }
.vd-contact__row a:hover { border-bottom-color: var(--green); }

/* Form */
.vd-form { display: flex; flex-direction: column; gap: 1rem; }
.vd-field { display: flex; flex-direction: column; gap: .36rem; }
.vd-field label {
  font-family: var(--mono);
  font-size: .59rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-mid);
}
.vd-field input,
.vd-field select,
.vd-field textarea {
  font-family: var(--sans);
  font-size: clamp(.87rem, 1.2vw, .95rem);
  padding: clamp(.68rem, 1.4vw, .84rem) 1rem;
  background: transparent;
  border: 1px solid var(--rule);
  color: var(--ink);
  outline: none;
  width: 100%;
  border-radius: 0;
  -webkit-appearance: none;
  appearance: none;
  transition: border-color .18s;
}
.vd-field input:focus,
.vd-field select:focus,
.vd-field textarea:focus { border-color: var(--green); }
.vd-field textarea { min-height: 118px; resize: vertical; }
.vd-form__btn {
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: clamp(.82rem, 2vw, 1rem) clamp(1.5rem, 3vw, 2.2rem);
  background: var(--green);
  color: #fff;
  border: none;
  align-self: flex-start;
  transition: background .22s, transform .18s;
}
.vd-form__btn:hover { background: var(--green-mid); transform: translateY(-2px); }

/* ==========================================================
   FOOTER
   ========================================================== */
.vd-footer { background: var(--ink); padding: clamp(1.8rem, 4vw, 3rem) 0; }
.vd-footer__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1.2rem;
}
.vd-footer__logo img {
  height: clamp(28px, 3.5vw, 40px);
  width: auto;
  filter: brightness(0) invert(1);
}
.vd-footer__links { display: flex; flex-wrap: wrap; gap: clamp(.8rem, 2vw, 1.8rem); justify-content: center; }
.vd-footer__links a {
  font-family: var(--mono);
  font-size: .57rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: rgba(245,240,232,.38);
  transition: color .18s;
}
.vd-footer__links a:hover { color: var(--cream); }
.vd-footer__copy {
  font-family: var(--mono);
  font-size: .56rem;
  letter-spacing: .1em;
  color: rgba(245,240,232,.28);
}

/* ==========================================================
   REVEAL ANIMATION
   ========================================================== */
.vd-reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1);
}
.vd-reveal.shown { opacity: 1; transform: none; }
.vd-d1 { transition-delay: .1s; }
.vd-d2 { transition-delay: .2s; }
.vd-d3 { transition-delay: .3s; }

/* ==========================================================
   RESPONSIVE — LARGE ≥ 1440px
   ========================================================== */
@media (min-width: 1440px) {
  :root { --cap: 1380px; --pad: 3rem; }
  .vd-svc:nth-child(odd)  { padding-right: 4rem; }
  .vd-svc:nth-child(even) { padding-left: 4rem; }
}

/* ==========================================================
   RESPONSIVE — TABLET ≤ 1024px
   (hamburger nav, stack 2-col grids)
   ========================================================== */
@media (max-width: 1024px) {
  .vd-nav__menu { display: none; }
  .vd-burger    { display: flex; }

  .vd-about__grid,
  .vd-cred__grid,
  .vd-contact__grid { grid-template-columns: 1fr; }

  .vd-founder__img-wrap img { height: clamp(240px, 45vw, 400px); }
  .vd-cred__panel { margin-top: 0; }
}

/* ==========================================================
   RESPONSIVE — MOBILE ≤ 768px
   (services 1-col, footer stack)
   ========================================================== */
@media (max-width: 768px) {
  .vd-svc-grid { grid-template-columns: 1fr; }
  .vd-svc:nth-child(odd)  { border-right: none; padding-right: 0; }
  .vd-svc:nth-child(even) { padding-left: 0; }
  .vd-svc--full { grid-column: 1; }

  .vd-hero__scroll { display: none; }

  .vd-footer__row { flex-direction: column; align-items: center; text-align: center; }
  .vd-footer__copy { white-space: normal; text-align: center; }
}

/* ==========================================================
   RESPONSIVE — SMALL PHONE ≤ 480px
   ========================================================== */
@media (max-width: 480px) {
  .vd-hero__btns { flex-direction: column; align-items: stretch; }
  .vd-btn        { text-align: center; }

  .vd-stats__grid { grid-template-columns: 1fr; gap: 1.8rem; }

  .vd-form__btn { width: 100%; text-align: center; align-self: stretch; }
}

/* Keep 3-col stats on mid-mobile (480-768) */
@media (min-width: 480px) and (max-width: 768px) {
  .vd-stats__grid { grid-template-columns: repeat(3, 1fr); }
}
