/* Homepage redesign integration guards. */
body.page-template-template-home #container > header.header:not(#siteHeader),
body.home #container > header.header:not(#siteHeader),
body.page-template-template-home #container > footer.footer:not(.pp-redesign-footer),
body.home #container > footer.footer:not(.pp-redesign-footer),
body.page-template-template-home #skiptocontent,
body.home #skiptocontent,
body.page-template-template-home > #mobile-navigation,
body.home > #mobile-navigation,
body.page-template-template-home > .mobile-navigation-top-inner,
body.home > .mobile-navigation-top-inner,
body.page-template-template-home .hide-site,
body.home .hide-site {
  display: none !important;
}
body.page-template-template-home #container,
body.home #container {
  overflow: visible;
}
body.page-template-template-home .pp-home-redesign,
body.home .pp-home-redesign {
  isolation: isolate;
}
body.page-template-template-home .pp-home-redesign #main,
body.home .pp-home-redesign #main {
  padding-top: 0 !important;
}

body.page-template-template-home .liveChatFloatingButton,
body.home .liveChatFloatingButton {
  display: none !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
/* =====================================================================
   PARKER & PARKER — page layout & section composition
   Components themselves are locked (system.css); this file places them.
   ===================================================================== */

/* ---------- HEADER (transparent over video; dark-green only after scroll) ---------- */
.header{ position:absolute; top:0; left:0; right:0; z-index:40; transition:background .3s ease, box-shadow .3s ease; }
.header__inner{ display:flex; align-items:center; gap:24px; padding:22px var(--gutter); max-width:var(--maxw); margin:0 auto; }
.header__logo{ display:inline-flex; flex:none; }   /* always visible, upper-left */
.header__logo img{ height:46px; width:auto; filter:brightness(0) invert(1); }  /* uniform white — no gold ampersand */
.header__nav{ flex:1; display:flex; justify-content:center; }
.nav__links{ display:flex; align-items:center; gap:clamp(16px,2vw,30px); list-style:none; margin:0; padding:0; }
.nav__links a{ font-family:var(--sans); font-weight:400; font-size:13px; letter-spacing:.18em;
  text-transform:uppercase; text-decoration:none; color:var(--cream); padding-bottom:4px; white-space:nowrap;
  border-bottom:1px solid transparent; transition:color .2s,border-color .2s; }
.nav__links a:hover{ color:var(--white); border-color:var(--cream-45); }
/* phone CTA pill, top right */
.header__call{ display:inline-flex; align-items:center; gap:9px; text-decoration:none; color:var(--cream); flex:none;
  border:1px solid var(--cream-45); border-radius:999px; padding:9px 17px;
  transition:background .2s,color .2s,border-color .2s; }
.header__call:hover{ background:var(--cream); color:var(--pp-ink); border-color:var(--cream); }
.header__call-icon{ display:inline-flex; }
.header__call-text{ display:flex; flex-direction:column; line-height:1.15; font-family:var(--sans); }
.header__call-l2{ font-size:10px; letter-spacing:.16em; text-transform:uppercase; opacity:.92; }
.header__call-l3{ font-size:14px; letter-spacing:.04em; }
/* plain + sticky phone alt (no oval framing) — reads as a quiet "call or text us" note */
[data-phone="plain"] .header__call{ border-color:transparent; background:transparent; padding:6px 0; gap:9px;
  text-shadow:0 1px 12px rgba(0,0,0,.65); }
[data-phone="plain"] .header__call:hover{ background:transparent; color:var(--white); }
[data-phone="plain"] .header__call:hover .header__call-l3{ border-color:var(--cream); }
[data-phone="plain"] .header__call-l2{ opacity:.95; }
[data-phone="plain"] .header__call-l3{ font-size:15px; font-weight:500; border-bottom:1px solid var(--cream-45); padding-bottom:2px; transition:border-color .2s; }
.nav__burger{ display:none; background:none; border:0; color:var(--cream); cursor:pointer; padding:6px; }
/* scrolled state — fixed dark-green band with the small left logo */
.header.is-scrolled{ position:fixed; background:#12301f; box-shadow:0 6px 24px -12px rgba(0,0,0,.5); }
.header.is-scrolled .header__inner{ padding-top:13px; padding-bottom:13px; }

/* ---------- HEADER: visible over the video (top scrim so the nav reads as a bar) ---------- */
.header::before{ content:""; position:absolute; inset:0 0 auto 0; height:140px; z-index:-1;
  background:linear-gradient(180deg, rgba(8,20,12,.62) 0%, rgba(8,20,12,.30) 52%, rgba(8,20,12,0) 100%);
  pointer-events:none; transition:opacity .3s ease; }
.header.is-scrolled::before{ opacity:0; }

/* ---------- HERO ("building breathes": left lockup, frosted screener lower-right, quiet awards) ---------- */
.hero{ position:relative; color:var(--cream); overflow:hidden; isolation:isolate; }
.hero__media{ position:absolute; inset:0; z-index:0; }
.hero__media #heroStill{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 42%; display:block; }
.hero__media video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 42%; z-index:1; opacity:0; transition:opacity .8s ease; }
.hero__media video.is-playing{ opacity:1; }
[data-heromedia="still"] .hero__media video{ display:none; }
/* light scrim ONLY where text needs legibility — building stays the dominant read */
.hero__scrim{ position:absolute; inset:0; z-index:2; background:
  linear-gradient(105deg, rgba(8,20,12,.62) 0%, rgba(8,20,12,.30) 34%, rgba(8,20,12,.04) 60%, rgba(8,20,12,0) 100%),
  linear-gradient(180deg, rgba(8,20,12,0) 60%, rgba(6,16,9,.55) 100%); }
.hero__inner{ max-width:var(--maxw); margin:0 auto; position:relative; z-index:3;
  padding:clamp(128px,15vh,180px) var(--gutter) clamp(108px,15vh,150px);
  min-height:min(92vh,960px); display:flex; flex-direction:column; align-items:flex-start; justify-content:center; }
.hero__center{ text-align:left; display:flex; flex-direction:column; align-items:flex-start; gap:clamp(14px,2vh,22px); max-width:640px; }
.hero__logo{ display:block; margin:0; width:clamp(240px,28vw,400px); height:auto; filter:brightness(0) invert(1) drop-shadow(0 2px 26px rgba(0,0,0,.5)); }
.hero__h1{ font-family:var(--serif); font-weight:400; color:var(--cream);
  font-size:clamp(13px,1.4vw,18px); letter-spacing:.2em; text-transform:uppercase; line-height:1.5;
  margin:0; text-align:left; text-shadow:0 1px 16px rgba(0,0,0,.5); }
.hero__tagline{ font-family:var(--serif); font-style:normal; font-size:clamp(20px,2.4vw,30px); color:var(--cream);
  margin:2px 0 0; line-height:1.2; text-shadow:0 1px 20px rgba(0,0,0,.5); }
.hero__tagline em{ font-style:italic; }
.hero__cta{ display:inline-flex; align-items:center; gap:.5em; margin-top:clamp(10px,1.8vh,20px); white-space:nowrap;
  font-family:var(--serif); font-weight:400; font-size:14px; letter-spacing:.16em; text-transform:uppercase;
  background:var(--cream); color:var(--pp-ink); text-decoration:none; padding:15px 28px; border-radius:var(--pp-radius-sm);
  transition:background .2s,color .2s; }
.hero__cta:hover{ background:var(--pp-green); color:var(--cream); }

/* frosted one-question screener — right side, vertically centered to the lockup, translucent */
.hero__screener{ position:absolute; right:var(--gutter); top:50%; transform:translateY(-50%); z-index:4;
  width:min(330px,38vw); padding:26px 24px; border-radius:var(--pp-radius-lg);
  background:rgba(28,40,30,.30); -webkit-backdrop-filter:blur(18px) saturate(120%); backdrop-filter:blur(18px) saturate(120%);
  border:1px solid rgba(245,240,232,.34); box-shadow:0 28px 70px -28px rgba(0,0,0,.6); color:var(--cream); }
.hero__screener-kicker{ font-family:var(--serif); font-size:11px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--cream-90); margin:0 0 8px; opacity:.9; }
.hero__screener-q{ font-family:var(--serif); font-size:23px; line-height:1.1; margin:0 0 16px; color:var(--cream); }
.hero__screener-form{ display:grid; gap:11px; }
.hero__screener .pp-field{ background:rgba(255,255,255,.92); }
.hero__screener .pp-select{ background-image:
  linear-gradient(45deg, transparent 50%, var(--pp-ink) 50%),
  linear-gradient(135deg, var(--pp-ink) 50%, transparent 50%);
  background-position:calc(100% - 16px) 50%, calc(100% - 11px) 50%; background-size:5px 5px,5px 5px; background-repeat:no-repeat; }

/* quiet white awards, bottom of hero, left-aligned, linked */
.hero__awards{ position:absolute; left:var(--gutter); right:auto; bottom:clamp(28px,5vh,48px);
  display:flex; flex-wrap:wrap; justify-content:flex-start; align-items:center; gap:clamp(16px,2.2vw,34px); max-width:60%; }
.hero__awards a, .hero__awards span{ display:inline-flex; align-items:center; opacity:.88; transition:opacity .2s, transform .2s; }
.hero__awards a:hover{ opacity:1; transform:translateY(-1px); }
.hero__awards img{ height:clamp(30px,3.2vw,42px); width:auto; filter:brightness(0) invert(1); }

/* both mockup variants keep an IDENTICAL, intact hero — the screener stays. */
.hero__formcol{ display:none; }

/* phone MERGED into the screener CTA — call/text becomes part of the card (frees the nav) */
.hero__screener-call{ display:none; align-items:center; gap:9px; margin-top:15px; padding-top:15px;
  border-top:1px solid rgba(245,240,232,.26); color:var(--cream); text-decoration:none;
  font-family:var(--serif); font-size:14px; line-height:1.3; }
.hero__screener-call-icon{ display:inline-flex; flex:none; opacity:.9; }
.hero__screener-call strong{ font-weight:400; border-bottom:1px solid rgba(245,240,232,.5); padding-bottom:1px; transition:border-color .2s; }
.hero__screener-call:hover strong{ border-color:var(--cream); }
[data-phone="merged"] .hero__screener-call{ display:flex; }
[data-phone="merged"] .header__call{ display:none; }                 /* no header phone → nav gets full width */
[data-phone="merged"] .header.is-scrolled .header__call{ display:inline-flex; }  /* but reappears in the sticky green bar on scroll */
@media (max-width:960px){ .hero__screener-call{ display:none !important; } } /* mobile uses the sticky bottom call bar instead */

/* ---------- FORM (layout around locked card) ---------- */
.formcard__caption{ font-family:var(--serif); font-weight:600; font-size:clamp(22px,1.9vw,27px);
  line-height:1.12; margin:0 0 20px; letter-spacing:-0.005em; }
.formgrid{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.field{ display:flex; flex-direction:column; gap:6px; }
.field--full{ grid-column:1 / -1; }
.field label{ font-family:var(--sans); font-size:11px; letter-spacing:.13em; text-transform:uppercase; opacity:.82; }
.field textarea.pp-field{ resize:vertical; min-height:72px; }
.field__err{ font-family:var(--sans); font-size:11px; letter-spacing:.04em; display:none; }
.pp-form-glass-dark .field__err{ color:#f0a9a6; }
.pp-form-glass-light .field__err{ color:#9e3b38; }
.field--error .field__err{ display:block; }
.field--error .pp-field{ border-color:#b0413e; }
.formcard__foot{ margin-top:16px; }
.formcard__legal{ font-family:var(--sans); font-size:11px; line-height:1.5; letter-spacing:.02em; opacity:.6; margin:13px 0 0; }
.formcard__confirm{ display:none; }
.is-done .formgrid, .is-done .formcard__foot, .is-done .formcard__caption{ display:none; }
.is-done .formcard__confirm{ display:block; }
.confirm__mark{ width:46px; height:46px; border-radius:50%; border:1.5px solid currentColor;
  display:flex; align-items:center; justify-content:center; margin-bottom:16px; opacity:.9; }
.confirm__title{ font-family:var(--serif); font-weight:600; font-size:23px; margin:0 0 12px; line-height:1.15; }
.confirm__body{ font-size:16px; line-height:1.55; opacity:.92; }
.confirm__body strong{ font-weight:600; }

/* ---------- CONVERT ZONE ---------- */
.convert{ position:relative; background:var(--cream); overflow:hidden; }
.convert__bg{ position:absolute; inset:0; z-index:0; }
.convert__bg img{ width:100%; height:100%; object-fit:cover; filter:none; opacity:.9; object-position:center 30%; }
.convert__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(245,240,232,.22),rgba(245,240,232,.46)); }
.convert__inner{ position:relative; z-index:1; }
.convert__text{ max-width:1000px; }
/* slide-2: video is the focal element; caption is subordinate */
.convert__videorow{ display:grid; grid-template-columns:1.55fr .95fr; gap:clamp(28px,4vw,60px); align-items:center; }
.convert__video{ min-width:0; }
.vfacade{ position:relative; width:100%; aspect-ratio:16/9; border-radius:var(--pp-radius); overflow:hidden;
  cursor:pointer; background:#1a1611; box-shadow:0 30px 70px -34px rgba(42,36,31,.55); }
.vfacade__poster{ width:100%; height:100%; object-fit:cover; filter:saturate(1.04) contrast(1.02); transition:transform .5s ease, filter .3s ease; }
.vfacade:hover .vfacade__poster{ transform:scale(1.025); }
.vfacade::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(18,30,20,.12),rgba(18,30,20,.34)); }
.vfacade__play{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); z-index:2;
  width:74px; height:74px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  color:var(--cream); border:1.5px solid rgba(245,240,232,.85); background:rgba(18,30,20,.30);
  -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px); transition:background .2s, transform .2s; padding-left:3px; }
.vfacade:hover .vfacade__play{ background:var(--pp-green); transform:translate(-50%,-50%) scale(1.06); }
.vfacade video{ width:100%; height:100%; object-fit:cover; display:block; }
.transcript{ margin-top:16px; border-top:1px solid var(--border); padding-top:14px; }
.transcript summary{ cursor:pointer; list-style:none; font-family:var(--serif); font-size:13px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--pp-ink); display:inline-flex; align-items:center; gap:.5em; }
.transcript summary::-webkit-details-marker{ display:none; }
.transcript summary::before{ content:"+"; color:var(--pp-green); font-size:16px; }
.transcript[open] summary::before{ content:"–"; }
.transcript__body{ font-family:var(--serif); font-size:16px; line-height:1.6; color:var(--ink-soft); margin:12px 0 0; max-width:62ch; }
.convert__caption h2{ margin-bottom:26px; line-height:1.22; }
.convert__sub{ margin:0 0 24px; }
.convert__actions{ display:flex; flex-wrap:wrap; gap:14px; }
.convert h2{ line-height:1.22; }
.convert__prose{ max-width:58ch; }
.convert__prose p{ margin:0 0 1em; }
.convert__prose p:last-child{ margin-bottom:0; }
.convert__trust{ margin-top:clamp(40px,5vw,64px); }
.convert__trust .pp-trust-bar{ grid-template-columns:repeat(4,1fr); }

/* ---------- WOVEN SECTION ---------- */
.woven{ position:relative; background:var(--paper); overflow:hidden; }
.woven__bg{ position:absolute; inset:0; z-index:0; }
.woven__bg img{ width:100%; height:100%; object-fit:cover; object-position:right 30%; filter:none; opacity:.85; }
.woven__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(251,248,242,.9) 24%, rgba(251,248,242,.52) 60%, rgba(251,248,242,.26) 100%); }
.woven > .wrap{ position:relative; z-index:1; }
.woven__head{ max-width:760px; margin-bottom:clamp(38px,5vw,64px); }
.woven__steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(22px,3vw,44px) clamp(28px,4vw,56px); }
.step p a{ color:var(--green); text-decoration:underline; text-underline-offset:2px; }
.step{ border-top:2px solid var(--green); padding-top:20px; }
.step__n{ font-family:var(--sans); font-size:12px; letter-spacing:.2em; color:var(--green); margin-bottom:12px; }
.step h3{ margin-bottom:11px; font-size:19px; line-height:1.22; display:flex; align-items:center; gap:9px; }
.step h3 svg{ width:19px; height:19px; flex:none; stroke:var(--green); fill:none; stroke-width:1.5; }
.step h3 a{ color:var(--green-deep); text-decoration:none; transition:color .2s, text-decoration-color .2s; }
.step h3 a:hover{ color:var(--green); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1px; }
.step p{ font-size:16px; line-height:1.5; color:var(--ink-soft); margin:0; }
.woven__sub{ margin-top:clamp(46px,6vw,82px); display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,72px); align-items:start; }
.woven__sub .pp-eyebrow{ margin-bottom:12px; }
.woven__values{ list-style:none; margin:24px 0 0; padding:0; display:grid; gap:20px; }
.woven__values li{ display:grid; grid-template-columns:auto 1fr; gap:16px; align-items:baseline; }
.woven__values .h3{ font-size:19px; }
.woven__values p{ margin:5px 0 0; font-size:16px; color:var(--ink-soft); }

/* ---------- ATTORNEYS ---------- */
.attorneys{ background:var(--cream); }
.attorney{ display:grid; grid-template-columns:.82fr 1.18fr; gap:clamp(32px,5vw,72px); align-items:center; }
.attorney--rev{ grid-template-columns:1.18fr .82fr; }
.attorney--rev .attorney__photo{ order:2; }
.attorney__photo img{ width:100%; border-radius:3px; aspect-ratio:4/5; object-fit:cover; object-position:center top; box-shadow:0 30px 60px -34px rgba(42,36,31,.5); }
.attorney + .attorney{ margin-top:clamp(52px,7vw,100px); padding-top:clamp(52px,7vw,100px); border-top:1px solid var(--border); }
.attorney__body .h3{ font-size:clamp(24px,2.4vw,32px); margin-bottom:16px; }
.attorney__meta{ display:flex; flex-wrap:wrap; gap:9px; margin:20px 0 24px; }
.tag{ font-family:var(--sans); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--green-deep); border:1px solid var(--border); padding:7px 12px; border-radius:2px; }

/* ---------- PRACTICE AREAS ---------- */
.practice{ background:var(--paper); position:relative; overflow:hidden; }
.pa__head{ display:flex; flex-wrap:wrap; justify-content:space-between; align-items:flex-end; gap:24px; margin-bottom:clamp(32px,4vw,52px); }
.pa__featured{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--border); border:1px solid var(--border); }
.pa__card{ background:var(--paper); padding:30px 28px; display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:22px; text-decoration:none; transition:background .25s; }
.pa__card:hover{ background:var(--cream); }
.pa__icon{ width:62px; height:62px; border-radius:50%; background:var(--pp-green); display:flex; align-items:center; justify-content:center; flex:none; }
.pa__icon img{ width:30px; height:30px; object-fit:contain; filter:brightness(0) invert(1); }
.pa__body h3{ font-size:21px; margin-bottom:8px; }
.pa__body p{ font-size:15.5px; line-height:1.5; color:var(--ink-soft); margin:0; }
.pa__arrow{ font-family:var(--serif); color:var(--green); font-size:20px; opacity:.5; transition:opacity .2s, transform .2s; }
.pa__card:hover .pa__arrow{ opacity:1; transform:translateX(3px); }
.pa__more{ position:relative; margin-top:clamp(42px,5vw,68px); isolation:isolate; }
.pa__more__bg{ position:absolute; top:clamp(-110px,-7vw,-72px); bottom:clamp(-104px,-7vw,-72px); left:50%; width:100vw; transform:translateX(-50%); z-index:0; pointer-events:none; }
.pa__more__bg img{ width:100%; height:100%; object-fit:cover; object-position:center 30%; opacity:.92; }
.pa__more__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,
  rgba(251,248,242,1) 0%,
  rgba(251,248,242,.96) 12%,
  rgba(251,248,242,.72) 28%,
  rgba(251,248,242,.54) 52%,
  rgba(251,248,242,.72) 76%,
  rgba(251,248,242,.96) 91%,
  rgba(251,248,242,1) 100%); }
.pa__more > *:not(.pa__more__bg){ position:relative; z-index:1; }
.pa__more-head{ max-width:760px; margin-bottom:clamp(24px,3vw,38px); }
.pa__group{ display:grid; grid-template-columns:208px 1fr; gap:clamp(18px,3vw,44px); border-top:1px solid var(--border); padding-top:18px; margin-top:18px; align-items:start; }
.pa__group:first-of-type{ margin-top:0; }
.pa__grouphead{ display:flex; align-items:baseline; gap:12px; margin:0; }
.pa__groupnum{ font-family:var(--serif); font-size:14px; letter-spacing:.1em; color:var(--green); }
.pa__grouphead h4{ font-family:var(--serif); font-weight:400; font-size:clamp(18px,1.8vw,23px); color:var(--ink); margin:0; line-height:1.2; }
.pa__grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:0 clamp(20px,3vw,40px); background:transparent; border:0; }
.pa__cell{ background:transparent; padding:8px 0; display:block; text-decoration:none; border:0; border-bottom:1px solid rgba(226,217,197,.55); margin:0; }
.pa__cell:hover{ background:transparent; }
.pa__cell strong{ display:block; font-weight:500; font-size:14.5px; line-height:1.35; margin-bottom:0; color:var(--ink); transition:color .2s; }
.pa__cell:hover strong{ color:var(--green); }
.pa__cell span{ display:none; }

.woven__sub-media .vfacade__poster{ filter:saturate(1.04) contrast(1.02); }

/* blog library — over the live B&W office background */
.library{ position:relative; background:var(--pp-charcoal); color:var(--cream); overflow:hidden; }
.library__bg{ position:absolute; inset:0; z-index:0; }
.library__bg img{ width:100%; height:100%; object-fit:cover; filter:grayscale(1) contrast(1.06); opacity:.34; }
.library__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(20,17,13,.64),rgba(20,17,13,.82)); }
.library__inner{ position:relative; z-index:1; }
.library .pp-eyebrow{ color:var(--cream-70); }
.library h2{ color:var(--cream); }
.library__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:rgba(245,240,232,.16); border:1px solid rgba(245,240,232,.16); margin-top:clamp(32px,4vw,48px); }
.lib__card{ background:#241f19; padding:28px 26px; text-decoration:none; color:var(--cream); display:grid; gap:11px; align-content:start; transition:background .25s; min-height:188px; }
.lib__card:hover{ background:#2c261f; }
.lib__tag{ font-family:var(--sans); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--cream-70); }
.lib__card h3{ color:var(--cream); font-size:21px; }
.lib__card p{ font-size:15px; line-height:1.5; color:var(--cream-70); margin:0; }
.library__foot{ display:flex; flex-wrap:wrap; gap:13px 26px; margin-top:30px; align-items:center; }
.library__foot a{ font-family:var(--sans); font-size:13px; letter-spacing:.04em; color:var(--cream-90); text-decoration:none; }
.library__foot a:hover{ color:var(--white); }

/* ---------- CHARITABLE (parallax building behind) ---------- */
.charity{ position:relative; overflow:hidden; background:var(--pp-charcoal); color:var(--cream); }
.charity__bg{ position:absolute; inset:0; z-index:0; background-image:url('../assets/home-redesign/media/video_first_frame.webp');
  background-size:cover; background-position:center 38%; background-attachment:fixed; }
.charity__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(10,18,12,.66),rgba(10,18,12,.8)); }
.charity__inner{ position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,78px); align-items:center; }
.charity__fig{ font-family:var(--serif); font-weight:600; font-size:clamp(56px,8vw,100px); line-height:.9; color:var(--cream); letter-spacing:-0.02em; }

/* ---------- CLIENT REVIEWS (solid charcoal) ---------- */
.tmni{ position:relative; color:var(--cream); overflow:hidden; background:var(--pp-charcoal); }
.tmni__bg{ display:none; }
.tmni__bg::after{ content:""; position:absolute; inset:0; }
.tmni__inner{ position:relative; z-index:1; }
.tmni__head{ max-width:760px; margin-bottom:clamp(30px,4vw,48px); }
.reviews__rating{ display:flex; align-items:center; gap:12px; margin:18px 0 0; font-family:var(--serif); }
.reviews__score{ font-size:30px; color:var(--cream); }
.reviews__stars{ color:var(--cream); letter-spacing:.08em; font-size:20px; }
.reviews__count{ font-size:14px; letter-spacing:.06em; color:var(--cream-70); text-transform:uppercase; }
.quote__by span{ opacity:.7; }
.tmni .pp-eyebrow{ color:var(--cream-70); }
.tmni__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(26px,3vw,42px); margin-top:clamp(32px,4vw,52px); }
.quote__stars{ color:var(--cream); opacity:.8; letter-spacing:.1em; font-size:14px; margin-bottom:12px; }
.quote__title{ font-family:var(--serif); font-style:italic; font-weight:500; font-size:22px; margin:0 0 12px; color:var(--cream); }
.quote p{ font-size:16.5px; line-height:1.6; color:var(--cream-90); margin:0 0 14px; }
.quote__by{ font-family:var(--sans); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--cream-70); }

/* ---------- MID CTA (Perry anchors it, left) ---------- */
.midcta{ background:var(--paper); }
.midcta__grid{ display:grid; grid-template-columns:.82fr 1.18fr; gap:clamp(28px,5vw,72px); align-items:center; }
.midcta__perry{ position:relative; display:flex; justify-content:center; }
.midcta__perry img{ width:100%; max-width:400px; height:auto; }
.midcta__inner{ max-width:560px; }
.midcta h2{ margin-bottom:16px; }
.midcta__row{ display:flex; flex-wrap:wrap; gap:14px; justify-content:flex-start; margin-top:30px; }

/* ---------- FAQ TEASER ---------- */
.faq{ background:var(--cream); }
.faq__grid{ display:grid; grid-template-columns:repeat(2,1fr); column-gap:clamp(34px,4vw,64px); }
.faq__col{ display:grid; align-content:start; }
.faq__item{ border-bottom:1px solid var(--border); padding:22px 0; }
.faq__item summary{ cursor:pointer; list-style:none; font-family:var(--serif); font-weight:600; font-size:19px; display:flex; justify-content:space-between; gap:18px; align-items:center; }
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary .pm{ font-family:var(--sans); font-weight:300; font-size:22px; color:var(--green); transition:transform .2s; flex:none; }
.faq__item[open] summary .pm{ transform:rotate(45deg); }
.faq__item p{ font-size:16px; line-height:1.6; color:var(--ink-soft); margin:13px 0 0; max-width:62ch; }
.faq__cta{ margin-top:26px; padding-top:22px; border-top:2px solid var(--green); display:grid; gap:7px; }
.faq__cta p{ font-family:var(--serif); font-weight:600; font-size:18px; color:var(--ink); margin:0; }
.faq__cta-or{ font-family:var(--sans); font-size:13px; color:var(--ink-soft); letter-spacing:.01em; }
.faq__cta-or a{ color:var(--green-deep); text-decoration:none; border-bottom:1px solid var(--border); }
.faq__cta-or a:hover{ border-color:var(--green); }

/* ---------- CLOSING CONTACT ---------- */
.closing{ background:var(--green-deepest); color:var(--cream); }
.closing__perry{ display:flex; align-items:center; gap:18px; margin-top:clamp(30px,4vw,44px); padding-top:clamp(24px,3vw,32px); border-top:1px solid rgba(245,240,232,.18); }
.closing__perry img{ width:96px; height:96px; border-radius:50%; object-fit:cover; object-position:center 30%; flex:none; background:var(--cream); }
.closing__perry-cap{ font-family:var(--serif); font-size:17px; line-height:1.4; color:var(--cream-90); margin:0; max-width:24ch; }
.closing__perry-cap em{ font-style:italic; color:var(--cream); }
.closing__inner{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(38px,6vw,86px); align-items:center; }
.closing .pp-eyebrow{ color:var(--cream-70); }
.closing h2{ color:var(--cream); }
.closing__contact{ display:grid; gap:24px; margin-top:8px; }
.contactline{ display:grid; gap:5px; }
.contactline .lbl{ font-family:var(--sans); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--cream-70); }
.contactline .val{ font-family:var(--serif); font-size:22px; }
.contactline a{ text-decoration:none; }
.map{ border-radius:3px; overflow:hidden; border:1px solid rgba(245,240,232,.2); aspect-ratio:16/12; }
.map iframe{ width:100%; height:100%; border:0; filter:grayscale(.4); }

/* ---------- FOOTER ---------- */
.footer{ background:var(--green-deepest); color:var(--cream-70); border-top:1px solid rgba(245,240,232,.14); }
.footer__inner{ display:flex; flex-wrap:wrap; gap:24px; justify-content:space-between; align-items:center; padding-block:32px; }
.footer__logo img{ height:52px; filter:brightness(0) invert(1); }
.footer__legal{ font-family:var(--sans); font-size:12px; letter-spacing:.04em; display:flex; flex-wrap:wrap; gap:8px 16px; align-items:center; }
.footer__legal a{ color:var(--cream-90); text-decoration:none; }
.footer__legal a:hover{ color:var(--white); }

/* ---------- CHAT WIDGET ---------- */
#chat{ position:fixed; right:20px; bottom:20px; z-index:1200; max-width:320px; background:var(--paper);
  border:1px solid var(--border); border-radius:8px; box-shadow:0 26px 60px -22px rgba(42,36,31,.5);
  padding:20px; font-family:var(--serif); transform:translateY(20px); opacity:0; pointer-events:none;
  transition:opacity .35s,transform .35s; }
#chat.show{ transform:translateY(0); opacity:1; pointer-events:auto; }
#chat .chat__hd{ display:flex; justify-content:space-between; align-items:flex-start; gap:12px; }
#chat .chat__t{ font-family:var(--serif); font-weight:600; font-size:18px; margin:0; }
#chat .chat__x{ background:none; border:0; cursor:pointer; color:var(--ink-soft); font-size:18px; line-height:1; }
#chat p{ font-size:15px; line-height:1.5; color:var(--ink-soft); margin:8px 0 16px; }
#chat .chat__avatar{ width:8px; height:8px; border-radius:50%; background:#3fae5a; display:inline-block; margin-right:7px; vertical-align:middle; }

/* ---------- LEAD MODAL ---------- */
.modal{ position:fixed; inset:0; z-index:1600; display:none; }
.modal.show{ display:block; }
.modal__backdrop{ position:absolute; inset:0; background:rgba(12,20,14,.66); -webkit-backdrop-filter:blur(3px); backdrop-filter:blur(3px); }
.modal__panel{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:min(620px,calc(100vw - 32px)); max-height:calc(100vh - 48px); overflow:auto;
  background:var(--paper); border-radius:var(--pp-radius-lg); box-shadow:0 40px 100px -30px rgba(0,0,0,.6);
  padding:clamp(26px,4vw,44px); }
.modal__close{ position:absolute; top:14px; right:16px; background:none; border:0; cursor:pointer;
  font-size:26px; line-height:1; color:var(--ink-soft); }
.modal__close:hover{ color:var(--ink); }
.modal__intro{ margin-bottom:22px; }
.modal__title{ font-family:var(--serif); font-size:clamp(26px,3vw,34px); line-height:1.1; margin:6px 0 10px; color:var(--ink); }
.modal__sub{ font-family:var(--serif); font-size:17px; line-height:1.5; color:var(--ink-soft); margin:0; max-width:52ch; }
.modal__formwrap{ padding:0; background:none; border:0; box-shadow:none; -webkit-backdrop-filter:none; backdrop-filter:none; }

/* ---------- MOBILE STICKY CLICK-TO-CALL BAR ---------- */
.callbar{ display:none; position:fixed; left:0; right:0; bottom:0; z-index:1300;
  align-items:center; justify-content:center; gap:10px;
  background:var(--pp-green); color:var(--cream); text-decoration:none;
  font-family:var(--serif); font-size:16px; letter-spacing:.1em; text-transform:uppercase;
  padding:15px 18px calc(15px + env(safe-area-inset-bottom)); box-shadow:0 -8px 24px -12px rgba(0,0,0,.5); }
.callbar__icon{ display:inline-flex; }

/* ---------- RESPONSIVE ---------- */
@media (max-width:960px){
  .nav__links{ display:none; }
  .nav__burger{ display:block; }
  .header__call{ display:none; }            /* phone moves to the sticky bottom call bar */
  [data-phone="merged"] .header.is-scrolled .header__call{ display:none; }
  .header__nav{ flex:1; justify-content:flex-end; }
  .callbar{ display:flex; }
  body{ padding-bottom:58px; }              /* room for the sticky call bar */
  #chat{ bottom:74px; }
  .hero__inner{ min-height:auto; padding-block:clamp(116px,15vh,150px) clamp(40px,7vh,72px); }
  .hero__screener{ position:static; transform:none; width:100%; margin-top:clamp(28px,5vh,44px); }
  .hero__awards{ position:static; left:auto; right:auto; max-width:none; margin-top:clamp(30px,6vh,52px); }
  .convert__trust .pp-trust-bar{ grid-template-columns:1fr 1fr; }
  .convert__videorow{ grid-template-columns:1fr; gap:clamp(20px,4vw,32px); }
  .woven__steps{ grid-template-columns:repeat(2,1fr); }
  .pa__group{ grid-template-columns:1fr; gap:8px; }
  .woven__sub{ grid-template-columns:1fr; }
  .midcta__grid{ grid-template-columns:1fr; gap:clamp(20px,4vw,32px); }
  .midcta__perry{ order:-1; }
  .midcta__perry img{ max-width:300px; }
  .attorney, .attorney--rev{ grid-template-columns:1fr; }
  .attorney--rev .attorney__photo{ order:0; }
  .pa__featured{ grid-template-columns:repeat(2,1fr); }
  .pa__grid{ grid-template-columns:1fr 1fr; }
  .library__grid{ grid-template-columns:1fr; }
  .charity__inner, .closing__inner, .tmni__grid, .faq__grid{ grid-template-columns:1fr; }
  .tmni__grid{ gap:34px; }
  .faq__col{ gap:0; }
}
@media (max-width:560px){
  .hero__h1{ white-space:normal; max-width:22ch; }
  .formgrid{ grid-template-columns:1fr; }
  .pp-trust-bar{ grid-template-columns:1fr; }
  .woven__steps, .pa__featured{ grid-template-columns:1fr; }
  .pa__grid{ grid-template-columns:1fr; }
  .footer__inner{ flex-direction:column; align-items:flex-start; }
  #chat{ left:14px; right:14px; max-width:none; width:auto; }
}
