/* home-parity.css
   Purpose: bring WP /home-new visual parity with the static preview.
   Notes:
   - This file contains the inline CSS that existed in dev-notes/previews/home-hero-preview.html
   - It complements system.css + home.css. No Divi/custom.css is required on /home-new.
   - Safe for local only; do not push unless you want the same parity elsewhere.
*/

/* Page background (standalone shell already sets this too) */
body { background: var(--brand-white); }

/* iOS typography + page clamp guards (standalone only) */
.home-standalone {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  overflow-x: clip; /* clamp any subpixel bleed from iOS visual viewport */
}

/* Section 4 — Build (parity) */
.home-build.section { background:#ffffff; padding-top: clamp(24px, 4vw, 64px); padding-bottom: clamp(24px, 4vw, 64px); }
.home-build { --tile-radius: 50px; --tile-gap: clamp(16px, 3vw, 32px); --tile-title-bottom: clamp(40px, 5.4vw, 60px); --tile-title-lh: 1.25em; }
.home-build .build-grid { display:grid; gap: clamp(20px, 3vw, 40px); }

/* left image flush with viewport’s left edge */
.home-build .build-media .bleed-left { width:100vw; margin-left: calc(50% - 50vw); }
.home-build .build-media img { display:block; width: min(60vw, 980px); max-width:none; height:auto; }
.home-build .build-media video { display:block; width: min(60vw, 980px); max-width:none; height:auto; }

/* right side */
.home-build .build-copy { text-align:center; max-width:56ch; margin:0 auto; }
.home-build .build-title {
  font-family: var(--font-heading); font-weight:500; margin:0; line-height:1.12;
  font-size: clamp(22px, 2vw + 8px, 36px);
}
.home-build .build-text { color: var(--text-muted); font-size:15px; line-height:1.6; margin-top:16px; }
.home-build .btn-group { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin-top: clamp(24px, 3vw, 40px); }

/* 2x2 tiles */
.home-build .build-tiles { display:grid; gap: var(--tile-gap); margin-top: clamp(24px, 3vw, 40px); }
.home-build .tiles-row { display:grid; grid-template-columns: 1fr 1fr; gap: var(--tile-gap); }
.home-build .tile {
  background: var(--brand-gray-100);
  border-radius: var(--tile-radius);
  text-decoration: none;
  color: inherit;
  position: relative;
  overflow: hidden;
  display: block;
  aspect-ratio: 1 / 1;
}
.home-build .tile img {
  position: absolute;
  top: 14%;
  left: 50%;
  transform: translate(-50%, -10%);
  width: 66.6667%;
  height: auto;
  max-width: none;
  pointer-events: none;
  display: block;
}
.home-build .tile-title {
  position: absolute;
  left: 50%;
  bottom: calc(var(--tile-title-bottom) * 0.9);
  transform: translateX(-50%);
  width: 100%;
  text-align: center;
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 500;
  font-size: 15px;
  line-height: 1.25;
}
.home-build .tile-title sup { font-size:.55em; line-height:0; position: relative; top:-.4em; }

/* Align first line of two-line titles with single-line baseline */
.home-build .tile-title.is-two-lines {
  bottom: calc(calc(var(--tile-title-bottom) * 0.9) - var(--tile-title-lh));
}

/* Desktop refinements */
@media (min-width: 981px) {
  .home-build.section { padding-top:80px; padding-bottom:80px; }

  /* Rebalance columns: keep left locked, pull right inward and reduce gap */
  .home-build .build-grid {
    grid-template-columns: clamp(480px, 42vw, 620px) 1fr;
    gap: clamp(16px, 2vw, 24px);
    align-items: center;
  }

  /* Restore viewport-left anchor for the bleed image (independent of grid column width) */
  .home-build .build-media .bleed-left {
    margin-left: calc(((100vw - min(100vw, var(--container-max))) / 2 + var(--gutter)) * -1);
  }

  /* Wider right content, centered within its track */
  .home-build .build-copy {
    justify-self: center;
    max-width: clamp(560px, 54vw, 780px);
  }

  /* Larger tiles on desktop */
  .home-build .tiles-row {
    grid-template-columns: repeat(2, 300px);
    gap: 32px;
    justify-content: center;
  }
  .home-build .tile { padding: 36px; }

  .home-build .build-media img { width: min(50vw, 980px); }
  .home-build .build-media video { width: min(50vw, 980px); }
}

/* Section 5 — Utility (parity) */
.home-utility.section { background: var(--brand-gray-100); padding-top: clamp(24px, 4vw, 64px); padding-bottom: clamp(24px, 4vw, 64px); }
.home-utility {
  --tile-radius: 50px;
  --tile-gap: clamp(10px, 2vw, 21px);
  --tile-title-bottom: clamp(40px, 5.4vw, 60px);
  --tile-title-lh: 1.25em;
}
.home-utility .utility-title {
  font-family: var(--font-heading);
  font-weight: 500;
  text-align: center;
  margin: clamp(24px, 3vw, 40px) 0;
  font-size: clamp(20px, 1.6vw + 9px, 31px);
}
.home-utility .utility-tiles {
  display: grid;
  gap: var(--tile-gap);
  margin-top: clamp(24px, 3vw, 40px);
  grid-template-columns: repeat(2, minmax(0, 1fr));
  /* Viewport-spanning row at 85vw to enlarge tiles */
  width: 85vw;
  margin-left: calc(50% - 42.5vw);
  margin-right: calc(50% - 42.5vw);
  padding-inline: var(--gutter);
  box-sizing: border-box;
}
.home-utility .tile {
  background: #ffffff;
  border-radius: var(--tile-radius);
  position: relative;
  overflow: hidden;
  display: block;
  text-decoration: none;
  color: inherit;
  aspect-ratio: 1 / 1;
}
.home-utility .tile img {
  position: absolute;
  top: 14%;
  left: 50%;
  transform: translate(-50%, -10%);
  width: 66.6667%;
  height: auto;
  max-width: none;
  pointer-events: none;
  display: block;
}
.home-utility .tile-title {
  position: absolute;
  left: 50%;
  bottom: calc(var(--tile-title-bottom) * 0.68);
  transform: translateX(-50%);
  width: 100%;
  text-align: center;
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 500;
  font-size: 15px;
  line-height: 1.25;
}
.home-utility .tile-title sup { font-size: .55em; line-height: 0; position: relative; top: -.4em; }
.home-utility .utility-cta {
  margin-top: clamp(24px, 3vw, 40px);
  display: flex;
  justify-content: center;
}

/* Desktop refinements */
@media (min-width: 981px) {
  .home-utility.section { padding-top: 80px; padding-bottom: 80px; }
  .home-utility .utility-tiles { grid-template-columns: repeat(5, minmax(0, 1fr)); }
  .home-utility .utility-title { margin-top: 0; }

  /* Lock inner content width and center (title, tiles, CTA) */
  .home-utility .utility-title,
  .home-utility .utility-tiles,
  .home-utility .utility-cta {
    width: 1224px;
    max-width: 1224px;
    margin-left: auto;
    margin-right: auto;
  }
}

/* Mobile (general) */
@media (max-width: 980px) {
  /* Double global side padding for all sections */
  :root { --gutter: 48px; }

  /* Hero: bigger title; natural wrapping; ignore forced <br> */
  .home-hero .hero-title {
    font-size: clamp(25px, min(9.38vw, 4dvh), 39px);
    line-height: 1.12;
  }
  .home-hero .hero-title br { display: none; }

  /* Hero stack and spacing */
  .home-hero .btn-group {
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 12px;
  }
  .home-hero { padding-bottom: clamp(48px, 8vw, 128px); }

  /* Normalize paddings for sections (exclude full-vh hero) */
  .section:not(.home-hero) {
    padding-top: clamp(48px, 8vw, 128px);
    padding-bottom: clamp(48px, 8vw, 128px);
  }

  /* Discover tweaks */
  .home-discover .section-title {
    font-size: clamp(20px, 1.6vw + 9px, 31px);
    line-height: 1.1;
  }
  .home-discover .discover-stats {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(12px, 3vw, 20px);
    width: 100% !important;
    justify-items: stretch !important;
  }
  .home-discover .discover-stats .stat-card {
    width: 100%;
    max-width: none;
    display: block;
    justify-self: stretch;
    box-sizing: border-box;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .home-discover .discover-card { padding-inline: clamp(28px, 5vw, 40px); padding-block: 0; }
  .home-discover .discover-copy h3 { margin-top: 0; }
  .home-discover .discover-media, .home-discover .discover-media img { margin-bottom: 0; }
  .home-discover .discover-media { display: none !important; }
  .home-discover .discover-card, .home-discover .discover-grid, .home-discover .discover-copy {
    text-align: center !important;
  }
  .home-discover .discover-grid, .home-discover .discover-copy {
    display: flex !important; flex-direction: column !important; align-items: center !important; justify-content: center !important;
  }
  .home-discover .discover-copy .btn-group,
  .home-discover .btn-group {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 12px !important;
  }
  .home-discover .discover-copy .btn-group .btn,
  .home-discover .btn-group .btn { margin: 0 !important; }

  /* Mobile: stack Discover CTA buttons (bottom row) and keep labels on one line */
  .home-discover .discover-cta {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 12px !important;
  }
  .home-discover .discover-cta .btn { white-space: nowrap !important; }

  /* Benefits mobile */
  .home-benefits .benefits-title {
    font-size: clamp(20px, 1.6vw + 9px, 31px) !important;
    line-height: 1.1 !important;
  }
  .home-benefits .benefits-rows { width: 100% !important; max-width: none !important; margin-left: auto !important; margin-right: auto !important; display: grid !important; grid-template-columns: 1fr !important; }
  .home-benefits .benefit-card { display: flex !important; flex-direction: column !important; align-items: center !important; text-align: center !important; gap: var(--card-gap) !important; }
  .home-benefits .benefit-media { order: -1; }
  .home-benefits .benefit-media img { display:block !important; width: 40% !important; max-width: 100% !important; height:auto !important; margin: 0 auto !important; }
  .home-benefits .benefit-copy h3 { font-family: var(--font-heading) !important; font-size: 15px !important; font-weight: 500 !important; }
  .home-benefits .benefit-row { grid-template-columns: 1fr !important; }

  /* Build mobile */
  .home-build .build-media { display: none !important; }
  .home-build .build-title { font-size: clamp(20px, 1.6vw + 9px, 31px) !important; }

  /* Utility mobile */
  .home-utility .tile img { top:14%; left:50%; transform: translate(-50%, -10%); width:66.6667%; height:auto; }
  .home-utility .tile-title { bottom: calc(var(--tile-title-bottom) * 0.9); }
  .home-utility .tile-title.is-two-lines { bottom: calc(calc(var(--tile-title-bottom) * 0.9) - var(--tile-title-lh)); }
  .home-utility .utility-tiles { width:auto !important; margin-left:0 !important; margin-right:0 !important; padding-inline:0 !important; }
  .home-utility { --tile-gap: clamp(16px, 3vw, 32px); }
  .home-utility .utility-tiles > a.tile:nth-child(5) { grid-column: 1 / -1; justify-self: center; width: calc((100% - var(--tile-gap)) / 2); }
}

/* Desktop width locks (parity with preview) */
@media (min-width: 981px) {
  .home-discover .discover-card,
  .home-discover .discover-stats,
  .home-discover .discover-cta {
    width: 980px;
    max-width: 980px;
    margin-left: auto;
    margin-right: auto;
  }
  .home-benefits .benefits-rows {
    width: 980px;
    max-width: 980px;
    margin-left: auto;
    margin-right: auto;
  }
}

/* Button transition parity */
.btn {
  transition: transform .25s ease-in-out, box-shadow .25s ease-in-out, background-color .25s ease, color .25s ease, border-color .25s ease;
}
.home-coded .btn:hover,
.home-coded .btn:focus-visible {
  background-color: var(--brand-black) !important;
  color: #ffffff !important;
  border-color: var(--brand-black) !important;
}
@media (prefers-reduced-motion: reduce) {
  .btn { transition: none; }
}

/* Home New (standalone): suppress focus ring and tap highlight */
.home-standalone a,
.home-standalone button {
  -webkit-tap-highlight-color: transparent;
}
.home-standalone .btn:focus,
.home-standalone .btn:focus-visible,
.home-standalone .home-hero a:focus,
.home-standalone .home-hero a:focus-visible {
  outline: 0 !important;
  outline-color: transparent !important;
  box-shadow: none !important;
}

@media (max-width: 980px) {
  .home-standalone .home-hero { overflow-x: hidden; }
}

/* Reveal animation helpers (scoped to sections) */
.home-hero .hero-anim--up { opacity: 0; transform: translateY(16px); transition: opacity 840ms cubic-bezier(0.22,1,0.36,1), transform 840ms cubic-bezier(0.22,1,0.36,1); will-change: opacity, transform; }
.home-hero .hero-anim--fade { opacity: 0; transition: opacity 640ms cubic-bezier(0.22,1,0.36,1); will-change: opacity; }
.home-hero .hero-anim--scale { opacity: 0; transform: scale(0.985); transition: opacity 1080ms cubic-bezier(0.22,1,0.36,1), transform 1080ms cubic-bezier(0.22,1,0.36,1); will-change: opacity, transform; }
.home-hero .is-in { opacity: 1; transform: none; }

.home-hero [data-stagger] > .btn {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 840ms cubic-bezier(0.22,1,0.36,1), transform 840ms cubic-bezier(0.22,1,0.36,1);
  will-change: opacity, transform;
}
.home-hero [data-stagger].is-in > .btn {
  opacity: 1;
  transform: none;
}

/* Reduced motion variants */
@media (prefers-reduced-motion: reduce) and (min-width: 981px) {
  .home-hero .hero-anim--up,
  .home-hero .hero-anim--fade,
  .home-hero .hero-anim--scale,
  .home-hero [data-stagger] > .btn {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* Discover: staged reveals */
.home-discover .reveal-up { opacity: 0; transform: translateY(16px); transition: opacity 840ms cubic-bezier(0.22,1,0.36,1), transform 840ms cubic-bezier(0.22,1,0.36,1); will-change: opacity, transform; }
.home-discover .is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .home-discover .reveal-up { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* Benefits queued reveals — desktop only */
@media (min-width: 981px) {
  .home-benefits.animate-benefits .benefits-title,
  .home-benefits.animate-benefits .benefit-card {
    opacity: 0;
    transform: translateY(16px);
    transition: opacity 840ms cubic-bezier(0.22,1,0.36,1), transform 840ms cubic-bezier(0.22,1,0.36,1);
    will-change: opacity, transform;
  }
  .home-benefits.animate-benefits .is-in { opacity: 1; transform: none; }
}
@media (prefers-reduced-motion: reduce) and (min-width: 981px) {
  .home-benefits.animate-benefits .benefits-title,
  .home-benefits.animate-benefits .benefit-card {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* Build queued reveals — desktop only */
@media (min-width: 981px) {
  .home-build.animate-build .build-title,
  .home-build.animate-build .build-text,
  .home-build.animate-build .build-tiles .tile,
  .home-build.animate-build .build-copy > .btn-group {
    opacity: 0;
    transform: translateY(16px);
    transition: opacity 840ms cubic-bezier(0.22,1,0.36,1), transform 840ms cubic-bezier(0.22,1,0.36,1);
    will-change: opacity, transform;
  }
  .home-build.animate-build .build-title.is-in,
  .home-build.animate-build .build-text.is-in,
  .home-build.animate-build .build-tiles .tile.is-in,
  .home-build.animate-build .build-copy > .btn-group.is-in { opacity: 1; transform: none; }
}
@media (prefers-reduced-motion: reduce) and (min-width: 981px) {
  .home-build.animate-build .build-title,
  .home-build.animate-build .build-text,
  .home-build.animate-build .build-tiles .tile,
  .home-build.animate-build .build-copy > .btn-group {
    opacity: 1 !important; transform: none !important; transition: none !important;
  }
}

/* Utility queued reveals — desktop only */
@media (min-width: 981px) {
  .home-utility.animate-utility .utility-title,
  .home-utility.animate-utility .utility-tiles > .tile,
  .home-utility.animate-utility .utility-cta {
    opacity: 0; transform: translateY(16px);
    transition: opacity 840ms cubic-bezier(0.22,1,0.36,1), transform 840ms cubic-bezier(0.22,1,0.36,1);
    will-change: opacity, transform;
  }
  .home-utility.animate-utility .utility-title.is-in,
  .home-utility.animate-utility .utility-tiles > .tile.is-in,
  .home-utility.animate-utility .utility-cta.is-in { opacity: 1; transform: none; }
}
@media (prefers-reduced-motion: reduce) and (min-width: 981px) {
  .home-utility.animate-utility .utility-title,
  .home-utility.animate-utility .utility-tiles > .tile,
  .home-utility.animate-utility .utility-cta {
    opacity: 1 !important; transform: none !important; transition: none !important;
  }
}

/* Mobile-only: Hero on-load sequence */
@media (max-width: 980px) {
  .home-hero .m-anim--up { opacity: 0; transform: translateY(16px); transition: opacity 840ms cubic-bezier(0.22,1,0.36,1), transform 840ms cubic-bezier(0.22,1,0.36,1); will-change: opacity, transform; }
  .home-hero .m-anim--up.is-in { opacity: 1; transform: none; }
}
@media (prefers-reduced-motion: reduce) and (max-width: 980px) {
  .home-hero .m-anim--up { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* Mobile-only: Benefits queued reveals */
@media (max-width: 980px) {
  .home-benefits.animate-benefits .benefits-title,
  .home-benefits.animate-benefits .benefit-card { opacity: 0; transform: translateY(16px); transition: opacity 840ms cubic-bezier(0.22,1,0.36,1), transform 840ms cubic-bezier(0.22,1,0.36,1); will-change: opacity, transform; }
  .home-benefits.animate-benefits .is-in { opacity: 1; transform: none; }
}
@media (prefers-reduced-motion: reduce) and (max-width: 980px) {
  .home-benefits.animate-benefits .benefits-title,
  .home-benefits.animate-benefits .benefit-card { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* Mobile-only: Build queued reveals */
@media (max-width: 980px) {
  .home-build.animate-build .build-title,
  .home-build.animate-build .build-text,
  .home-build.animate-build .build-tiles .tile,
  .home-build.animate-build .build-copy > .btn-group { opacity: 0; transform: translateY(16px); transition: opacity 840ms cubic-bezier(0.22,1,0.36,1), transform 840ms cubic-bezier(0.22,1,0.36,1); will-change: opacity, transform; }
  .home-build.animate-build .build-title.is-in,
  .home-build.animate-build .build-text.is-in,
  .home-build.animate-build .build-tiles .tile.is-in,
  .home-build.animate-build .build-copy > .btn-group.is-in { opacity: 1; transform:none; }
}
@media (prefers-reduced-motion: reduce) and (max-width: 980px) {
  .home-build.animate-build .build-title,
  .home-build.animate-build .build-text,
  .home-build.animate-build .build-tiles .tile,
  .home-build.animate-build .build-copy > .btn-group { opacity:1 !important; transform:none !important; transition:none !important; }
}

/* Mobile-only: Utility queued reveals */
@media (max-width: 980px) {
  .home-utility.animate-utility .utility-title,
  .home-utility.animate-utility .utility-tiles > .tile,
  .home-utility.animate-utility .utility-cta { opacity:0; transform:translateY(16px); transition:opacity 840ms cubic-bezier(0.22,1,0.36,1), transform 840ms cubic-bezier(0.22,1,0.36,1); will-change:opacity, transform; }
  .home-utility.animate-utility .utility-title.is-in,
  .home-utility.animate-utility .utility-tiles > .tile.is-in,
  .home-utility.animate-utility .utility-cta.is-in { opacity:1; transform:none; }
}
@media (prefers-reduced-motion: reduce) and (max-width: 980px) {
  .home-utility .utility-title,
  .home-utility .utility-tiles > .tile,
  .home-utility .utility-cta { opacity:1 !important; transform:none !important; transition:none !important; }
}

/* Final mobile parity overrides (reinforce preview behavior) */
@media (max-width: 980px) {
  /* Hero: hide right image; ensure equal side padding */
  .home-hero .hero-visual { display: none !important; }
  .home-hero.section--fullvh { min-height: auto; display: block; align-items: initial; padding-top: var(--mobile-header-offset, 64px); padding-left: 0 !important; padding-right: 0 !important; }
  .home-hero .container.hero { padding-left: var(--gutter) !important; padding-right: var(--gutter) !important; }
  .home-hero .hero-art { display: none !important; }

  /* Discover: make white card truly full width and keep button labels on one line */
  .home-discover .discover-card,
  .home-discover .discover-grid {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .home-discover .discover-copy .btn { white-space: nowrap !important; }

  /* Benefits: center titles and text on mobile */
  .home-benefits .benefit-copy h3,
  .home-benefits .benefit-copy p { text-align: center !important; margin-top: 0 !important; }

  /* Supporters: smaller logos (preview scale) */
  .home-supporters { --logo-height: 22px; }

  /* Rounding: halve all rounded corners for mobile tiles/cards */
  .home-discover .discover-card,
  .home-discover .stat-card,
  .home-benefits .benefit-card,
  .home-build .tile,
  .home-utility .tile {
    border-radius: calc(var(--card-radius, var(--tile-radius)) / 2) !important;
  }

  /* Utility: increase bottom padding 2.5x on mobile */
  .home-utility.section { padding-bottom: clamp(120px, 20vw, 320px) !important; }
}
