/* GP Drain & Sewer Page Builder v2.5.0 — authored by Jacob Romano */
.gpds2-page {
  --gpds2-black: #050505;
  --gpds2-panel: #11100e;
  --gpds2-panel-2: #171411;
  --gpds2-cream: #f9f5ee;
  --gpds2-muted: rgba(249,245,238,.74);
  --gpds2-soft: rgba(249,245,238,.58);
  --gpds2-gold: #c7a45e;
  --gpds2-gold-light: #ffd782;
  --gpds2-red: #c1121f;
  --gpds2-blue: #0aa7ff;
  --gpds2-teal: #25d7b8;
  --gpds2-radius: 26px;
  --gpds2-ease: cubic-bezier(.22,.82,.23,1);
  --gpds2-shadow: 0 28px 90px rgba(0,0,0,.52);
  color: var(--gpds2-cream);
  background:
    radial-gradient(circle at 50% 0%, rgba(199,164,94,.16), transparent 20%),
    radial-gradient(circle at 12% 18%, rgba(193,18,31,.08), transparent 26%),
    linear-gradient(180deg, #030303 0%, #090806 50%, #030303 100%);
  font-family: Inter, Montserrat, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  overflow: hidden;
  isolation: isolate;
}
.gpds2-page *, .gpds2-page *::before, .gpds2-page *::after { box-sizing: border-box; }
.gpds2-page a { color: inherit; }
.gpds2-shell { width: min(1180px, calc(100% - clamp(32px, 5vw, 72px))); margin-inline: auto; }
.gpds2-section { position: relative; padding: clamp(54px, 7vw, 112px) 0; }
.gpds2-section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 18%, rgba(199,164,94,.08), transparent 32%),
    linear-gradient(180deg, transparent, rgba(199,164,94,.035), transparent);
  opacity: .85;
}
.gpds2-section > .gpds2-shell { position: relative; z-index: 1; }
.gpds2-section--brighter { background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.01)); }
.gpds2-eyebrow, .gpds2-kicker {
  margin: 0 0 10px;
  color: var(--gpds2-gold-light) !important;
  font-size: .78rem !important;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
  line-height: 1.25;
}
.gpds2-page h1, .gpds2-page h2, .gpds2-page h3 {
  margin: 0;
  color: var(--gpds2-cream);
  font-family: "Libre Baskerville", Georgia, "Times New Roman", serif;
  line-height: .98;
  text-wrap: balance;
}
.gpds2-page h1 { font-size: clamp(2.6rem, 6.2vw, 6.3rem); letter-spacing: -.065em; max-width: 920px; }
.gpds2-page h2 { font-size: clamp(2rem, 4.3vw, 5.1rem); letter-spacing: -.055em; max-width: 930px; }
.gpds2-page h3 { font-size: clamp(1.18rem, 1.7vw, 1.7rem); letter-spacing: -.025em; line-height: 1.05; }
.gpds2-page p { margin: 13px 0 0; color: var(--gpds2-muted); line-height: 1.66; font-size: clamp(1rem, 1.08vw, 1.1rem); }
.gpds2-lead { font-size: clamp(1.07rem, 1.35vw, 1.28rem) !important; max-width: 820px; color: rgba(249,245,238,.84) !important; }
.gpds2-section-head { margin-bottom: clamp(24px, 3.6vw, 46px); }
.gpds2-section-head--split { display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(320px, .72fr); gap: clamp(22px, 4vw, 62px); align-items: end; }
.gpds2-section-head--split > p { margin-top: 0; font-size: clamp(1.05rem, 1.3vw, 1.24rem); }
.gpds2-section-head--side { position: sticky; top: 110px; align-self: start; }

.gpds2-card {
  position: relative;
  border: 1px solid rgba(199,164,94,.28);
  border-radius: var(--gpds2-radius);
  background:
    radial-gradient(circle at var(--mx, 50%) var(--my, 10%), rgba(255,215,130,.12), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.027));
  box-shadow: var(--gpds2-shadow);
  overflow: hidden;
  isolation: isolate;
  transform: translateZ(0);
}
.gpds2-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(circle at var(--mx, 50%) var(--my, 16%), rgba(255,215,130,.17), transparent 35%);
  opacity: 0;
  transition: opacity .28s var(--gpds2-ease);
  pointer-events: none;
  z-index: 1;
}
.gpds2-card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(115deg, transparent 0%, rgba(255,255,255,.14) 42%, transparent 58%);
  opacity: 0;
  transform: translateX(-28%);
  transition: opacity .28s var(--gpds2-ease), transform .85s var(--gpds2-ease);
  z-index: 2;
}
@media (hover:hover) and (pointer:fine) {
  .gpds2-card:hover { border-color: rgba(255,215,130,.58); box-shadow: 0 30px 100px rgba(0,0,0,.62), 0 0 42px rgba(199,164,94,.13); }
  .gpds2-card:hover::before { opacity: 1; }
  .gpds2-card:hover::after { opacity: .64; transform: translateX(30%); }
  .gpds2-route-card:hover, .gpds2-service-card:hover, .gpds2-location-card:hover, .gpds2-step-card:hover, .gpds2-resource-card:hover { transform: translateY(-5px); }
}
.gpds2-card-body, .gpds2-step-body, .gpds2-callout, .gpds2-price-card, .gpds2-options-card, .gpds2-big-copy, .gpds2-final-card { position: relative; z-index: 3; }
.gpds2-card-body { padding: 20px; }
.gpds2-card-body h3 a { text-decoration: none !important; }
.gpds2-card-body h3 a:hover { color: var(--gpds2-gold-light); }

.gpds2-actions { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; margin-top: 28px; }
.gpds2-actions--center { justify-content: center; }
.gpds2-actions--stack { align-items: stretch; }
.gpds2-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 13px 21px;
  border-radius: 999px;
  border: 1px solid rgba(199,164,94,.46);
  text-decoration: none !important;
  font-weight: 900;
  letter-spacing: .01em;
  line-height: 1;
  transition: transform .24s var(--gpds2-ease), border-color .24s var(--gpds2-ease), background .24s var(--gpds2-ease), color .24s var(--gpds2-ease), box-shadow .24s var(--gpds2-ease);
  position: relative;
  z-index: 5;
  white-space: nowrap;
}
.gpds2-btn:hover, .gpds2-btn:focus-visible { transform: translateY(-2px); box-shadow: 0 14px 38px rgba(0,0,0,.34), 0 0 28px rgba(199,164,94,.18); outline: none; }
.gpds2-btn--red { background: var(--gpds2-red); color: #fff !important; border-color: rgba(255,255,255,.22); }
.gpds2-btn--red:hover, .gpds2-btn--red:focus-visible { background: #e01627; color: #fff !important; }
.gpds2-btn--gold { background: linear-gradient(180deg, #e0bd6e, var(--gpds2-gold)); color: #080807 !important; border-color: rgba(255,215,130,.78); }
.gpds2-btn--gold:hover, .gpds2-btn--gold:focus-visible { background: var(--gpds2-gold-light); color: #050505 !important; }
.gpds2-btn--cream { background: var(--gpds2-cream); color: #111 !important; border-color: rgba(255,215,130,.78); }
.gpds2-btn--cream:hover, .gpds2-btn--cream:focus-visible { background: var(--gpds2-gold-light); color: #080808 !important; }
.gpds2-btn--ghost { background: rgba(0,0,0,.34); color: var(--gpds2-cream) !important; border-color: rgba(199,164,94,.48); }
.gpds2-btn--ghost:hover, .gpds2-btn--ghost:focus-visible { background: rgba(199,164,94,.16); color: var(--gpds2-gold-light) !important; }

.gpds2-linkchips { position: relative; z-index: 5; display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.gpds2-linkchips a {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  border: 1px solid rgba(199,164,94,.32);
  border-radius: 999px;
  padding: 7px 11px;
  color: rgba(249,245,238,.88) !important;
  text-decoration: none !important;
  background: rgba(0,0,0,.24);
  font-size: .83rem;
  font-weight: 800;
  transition: border-color .22s var(--gpds2-ease), background .22s var(--gpds2-ease), color .22s var(--gpds2-ease), transform .22s var(--gpds2-ease);
}
.gpds2-linkchips a:hover, .gpds2-linkchips a:focus-visible { border-color: var(--gpds2-gold-light); background: rgba(199,164,94,.17); color: var(--gpds2-gold-light) !important; transform: translateY(-1px); outline: none; }

.gpds2-media {
  position: relative;
  display: block;
  width: 100%;
  min-height: 220px;
  margin: 0;
  border-radius: 22px;
  overflow: hidden;
  background: radial-gradient(circle at 50% 42%, rgba(199,164,94,.13), transparent 54%), #070707;
  border: 1px solid rgba(199,164,94,.22);
  z-index: 3;
}
.gpds2-media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: var(--gpds2-img-fit, cover);
  object-position: var(--gpds2-img-pos, 50% 50%);
  display: block;
  z-index: 2;
  transition: transform .6s var(--gpds2-ease), opacity .25s ease;
}
.gpds2-media:hover img { transform: scale(1.035); }
.gpds2-media--hero { min-height: clamp(420px, 39vw, 570px); border-radius: 30px; }
.gpds2-media--card { aspect-ratio: 16/10; min-height: 190px; border-radius: 22px 22px 0 0; border-width: 0 0 1px; }
.gpds2-media--service { aspect-ratio: 16/11; min-height: 208px; border-radius: 22px 22px 0 0; border-width: 0 0 1px; }
.gpds2-media--location { aspect-ratio: 16/10; min-height: 190px; border-radius: 22px 22px 0 0; border-width: 0 0 1px; }
.gpds2-media--step { aspect-ratio: 16/9; min-height: 176px; border-radius: 22px 22px 0 0; border-width: 0 0 1px; }
.gpds2-media--wide { aspect-ratio: 16/9; min-height: 250px; }
.gpds2-media--large { min-height: 360px; }
.gpds2-media--person-safe { background-position: center top; }
.gpds2-media-fallback {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: none;
  place-items: center;
  padding: 18px;
  background: radial-gradient(circle at 50% 45%, rgba(199,164,94,.16), transparent 50%), #070707;
}
.gpds2-media.is-broken img { opacity: 0; }
.gpds2-pipe-visual { position: relative; width: min(330px, 84%); height: 150px; display: block; filter: drop-shadow(0 0 22px rgba(199,164,94,.14)); }
.gpds2-pipe-visual i, .gpds2-pipe-visual b { position: absolute; display: block; border-radius: 999px; }
.gpds2-pipe-visual i:nth-child(1) { left: 8%; right: 8%; top: 42%; height: 13px; background: linear-gradient(90deg, var(--gpds2-blue), #f92760); box-shadow: 0 0 22px rgba(10,167,255,.6); }
.gpds2-pipe-visual i:nth-child(2) { left: 18%; top: 18%; width: 72px; height: 72px; border: 8px solid var(--gpds2-teal); border-bottom-color: transparent; box-shadow: 0 0 22px rgba(37,215,184,.5); }
.gpds2-pipe-visual i:nth-child(3) { right: 18%; bottom: 14%; width: 96px; height: 12px; background: linear-gradient(90deg, rgba(199,164,94,.4), rgba(255,215,130,.95)); transform: rotate(-7deg); box-shadow: 0 0 18px rgba(255,215,130,.25); }
.gpds2-pipe-visual b { left: 12%; right: 12%; bottom: 16%; height: 0; border-bottom: 8px dotted var(--gpds2-teal); filter: drop-shadow(0 0 8px rgba(37,215,184,.7)); }

.gpds2-hero { padding-top: clamp(90px, 8vw, 148px); }
.gpds2-hero-grid { display: grid; grid-template-columns: minmax(0, 1.06fr) minmax(340px, .94fr); gap: clamp(22px, 4vw, 54px); align-items: center; }
.gpds2-hero-copy { padding: clamp(28px, 4.8vw, 58px); }
.gpds2-hero-media-wrap { position: relative; }
.gpds2-floating-note { padding: 20px; margin-top: 16px; }
.gpds2-floating-note strong { color: var(--gpds2-cream); font-size: 1.05rem; }
.gpds2-trust-row, .gpds2-guide-points, .gpds2-mini-grid { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 24px; }
.gpds2-trust-row span, .gpds2-guide-points span, .gpds2-mini-grid span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  border: 1px solid rgba(199,164,94,.25);
  background: rgba(255,255,255,.055);
  border-radius: 999px;
  padding: 7px 11px;
  color: rgba(249,245,238,.82);
  font-size: .88rem;
  font-weight: 700;
}

.gpds2-card-grid { display: grid; gap: 18px; }
.gpds2-card-grid--symptoms { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.gpds2-card-grid--services { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.gpds2-card-grid--locations { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.gpds2-route-card, .gpds2-service-card, .gpds2-location-card, .gpds2-step-card, .gpds2-resource-card { transition: transform .28s var(--gpds2-ease), border-color .28s var(--gpds2-ease); }
.gpds2-card--urgent { border-color: rgba(193,18,31,.55); }
.gpds2-card--urgent .gpds2-kicker { color: #ff8a94 !important; }
.gpds2-card-media-link { display: block; text-decoration: none !important; }

.gpds2-atlas-section { background: linear-gradient(180deg, rgba(255,255,255,.015), rgba(199,164,94,.035), rgba(255,255,255,.01)); }
.gpds2-guide-grid { display: grid; grid-template-columns: 1fr; gap: clamp(20px, 3vw, 34px); align-items: start; }
.gpds2-guide-copy { padding-top: 14px; }
.gpds2-guide-card { padding: clamp(12px, 1.8vw, 24px); min-height: clamp(680px, 72vw, 960px); overflow: visible; width: 100%; }
.gpds2-guide-card > * { position: relative; z-index: 3; }
.gpds2-guide-card .gpdw2-root, .gpds2-guide-card .gpdw-root, .gpds2-guide-card [class*="gpdw"] { max-width: 100%; }
.gpds2-guide-card .gpdw2-root { width: 100% !important; max-width: 1360px !important; margin-inline: auto !important; padding: 0 !important; }
.gpds2-guide-card .gpdw2-shell { width: 100% !important; max-width: none !important; }
.gpds2-guide-card .gpdw2-grid { grid-template-columns: minmax(0, 1.32fr) minmax(320px, .68fr) !important; gap: clamp(18px, 2.6vw, 34px) !important; }
.gpds2-guide-card .gpdw2-stage { min-height: clamp(500px, 52vw, 820px) !important; }
.gpds2-guide-card .gpdw2-shell, .gpds2-guide-card .gpdw-shell { max-width: 100%; }
.gpds2-guide-card iframe { width: 100%; max-width: 100%; }
.gpds2-guide-fallback { position: relative; z-index: 3; display: grid; grid-template-columns: 260px 1fr; gap: 22px; align-items: center; min-height: 360px; padding: 26px; border: 1px solid rgba(199,164,94,.25); border-radius: 22px; background: rgba(0,0,0,.24); }
.gpds2-guide-mini-visual { min-height: 220px; display: grid; place-items: center; border: 1px solid rgba(199,164,94,.18); border-radius: 20px; background: #080808; }

.gpds2-two-col, .gpds2-pricing-grid, .gpds2-evidence-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(18px, 3vw, 34px); align-items: stretch; }
.gpds2-callout, .gpds2-price-card, .gpds2-options-card, .gpds2-big-copy, .gpds2-final-card { padding: clamp(26px, 4vw, 52px); }
.gpds2-callout--danger { background: radial-gradient(circle at 12% 0%, rgba(193,18,31,.19), transparent 40%), linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.025)); }
.gpds2-risk-list { padding: 14px; }
.gpds2-risk-list ul, .gpds2-options-card ul { position: relative; z-index: 3; margin: 20px 0 0; padding-left: 22px; color: rgba(249,245,238,.78); line-height: 1.7; }
.gpds2-evidence-photo-stack { display: grid; grid-template-columns: 1fr; gap: 18px; }
.gpds2-evidence-photo-stack .gpds2-media:nth-child(2) { min-height: 290px; }

.gpds2-cause-grid { display: grid; grid-template-columns: minmax(260px, .46fr) minmax(0, 1fr); gap: 18px; align-items: start; }
.gpds2-cause-buttons { display: flex; flex-wrap: wrap; gap: 10px; align-content: flex-start; }
.gpds2-cause-tab {
  border: 1px solid rgba(199,164,94,.30);
  border-radius: 999px;
  background: rgba(255,255,255,.045);
  color: rgba(249,245,238,.82);
  padding: 11px 14px;
  font-weight: 850;
  cursor: pointer;
  transition: background .22s var(--gpds2-ease), border-color .22s var(--gpds2-ease), color .22s var(--gpds2-ease), transform .22s var(--gpds2-ease);
}
.gpds2-cause-tab:hover, .gpds2-cause-tab:focus-visible, .gpds2-cause-tab.is-active { background: rgba(199,164,94,.20); border-color: rgba(255,215,130,.72); color: var(--gpds2-gold-light); transform: translateY(-1px); outline: none; }
.gpds2-cause-panel { min-height: 260px; padding: clamp(24px, 3vw, 38px); }
.gpds2-cause-content { display: none; position: relative; z-index: 3; }
.gpds2-cause-content.is-active { display: block; }

.gpds2-step-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.gpds2-step-body { display: grid; grid-template-columns: 48px 1fr; gap: 14px; padding: 18px; align-items: start; }
.gpds2-step-body > span { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 50%; background: var(--gpds2-gold); color: #090909; font-weight: 950; }
.gpds2-step-body p { margin-top: 8px; }
.gpds2-price-mark { margin-top: 28px; color: var(--gpds2-gold-light); font-size: clamp(4.4rem, 8vw, 8rem); line-height: .88; font-weight: 950; letter-spacing: -.07em; font-family: Inter, Montserrat, sans-serif; }
.gpds2-resource-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.gpds2-resource-card { min-height: 170px; padding: 22px; text-decoration: none !important; }
.gpds2-resource-card strong { position: relative; z-index: 3; display: block; color: var(--gpds2-cream); font-family: "Libre Baskerville", Georgia, serif; font-size: 1.1rem; line-height: 1.1; }
.gpds2-resource-card span { position: relative; z-index: 3; display: block; margin-top: 10px; color: var(--gpds2-muted); line-height: 1.5; }

.gpds2-faq-grid { display: grid; grid-template-columns: minmax(280px, .38fr) minmax(0, 1fr); gap: clamp(22px, 4vw, 54px); align-items: start; }
.gpds2-faq-list { display: grid; gap: 12px; }
.gpds2-faq-list details { padding: 0; }
.gpds2-faq-list summary { list-style: none; cursor: pointer; padding: 19px 58px 19px 22px; color: var(--gpds2-cream); font-weight: 900; position: relative; z-index: 4; }
.gpds2-faq-list summary::-webkit-details-marker { display: none; }
.gpds2-faq-list summary::after { content: "+"; position: absolute; right: 22px; top: 50%; transform: translateY(-50%); color: var(--gpds2-gold-light); font-size: 1.5rem; }
.gpds2-faq-list details[open] summary::after { content: "–"; }
.gpds2-faq-list details p { position: relative; z-index: 3; padding: 0 22px 22px; margin: 0; }
.gpds2-final { padding-bottom: clamp(76px, 9vw, 138px); }
.gpds2-final-card { text-align: center; max-width: 960px; margin-inline: auto; }
.gpds2-final-card p { margin-inline: auto; max-width: 760px; }

.gpds2-pulse { animation: gpds2Pulse 1.3s var(--gpds2-ease) 1; }
@keyframes gpds2Pulse { 0%,100% { box-shadow: var(--gpds2-shadow); } 45% { box-shadow: 0 0 0 4px rgba(255,215,130,.3), 0 0 74px rgba(255,215,130,.24), var(--gpds2-shadow); } }

@media (max-width: 1240px) {
  .gpds2-card-grid--services { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .gpds2-resource-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 1100px) {
  .gpds2-guide-grid { grid-template-columns: 1fr; }
  .gpds2-section-head--side { position: static; }
  .gpds2-guide-card { min-height: 0; overflow-x: auto; }
  .gpds2-guide-card > * { min-width: min(980px, 100%); }
  .gpds2-guide-card .gpdw2-grid { grid-template-columns: 1fr !important; }
  .gpds2-guide-card .gpdw2-stage { min-height: clamp(420px, 74vw, 720px) !important; }
  .gpds2-card-grid--symptoms { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .gpds2-card-grid--locations { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .gpds2-step-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 920px) {
  .gpds2-hero-grid, .gpds2-section-head--split, .gpds2-two-col, .gpds2-pricing-grid, .gpds2-evidence-grid, .gpds2-faq-grid, .gpds2-cause-grid { grid-template-columns: 1fr; }
  .gpds2-section-head--split > p { margin-top: 0; }
  .gpds2-hero { padding-top: clamp(72px, 10vw, 102px); }
  .gpds2-media--hero { min-height: clamp(360px, 64vw, 520px); }
  .gpds2-evidence-photo-stack { grid-template-columns: 1fr 1fr; }
  .gpds2-evidence-photo-stack .gpds2-media { min-height: 260px !important; }
}
@media (max-width: 720px) {
  .gpds2-shell { width: min(100% - 28px, 1180px); }
  .gpds2-section { padding: 48px 0; }
  .gpds2-card-grid--symptoms, .gpds2-card-grid--services, .gpds2-card-grid--locations, .gpds2-step-grid, .gpds2-resource-grid, .gpds2-evidence-photo-stack { grid-template-columns: 1fr; }
  .gpds2-page h1 { font-size: clamp(2.42rem, 13vw, 4rem); }
  .gpds2-page h2 { font-size: clamp(2rem, 10vw, 3.35rem); }
  .gpds2-hero-copy, .gpds2-callout, .gpds2-price-card, .gpds2-options-card, .gpds2-big-copy, .gpds2-final-card { padding: 24px; }
  .gpds2-media img { object-position: var(--gpds2-img-pos-mobile, var(--gpds2-img-pos, 50% 50%)); }
  .gpds2-media--card, .gpds2-media--service, .gpds2-media--location { min-height: 225px; }
  .gpds2-media--step { min-height: 210px; }
  .gpds2-guide-fallback { grid-template-columns: 1fr; }
  .gpds2-actions { align-items: stretch; }
  .gpds2-actions .gpds2-btn { flex: 1 1 100%; }
  .gpds2-linkchips a { font-size: .8rem; }
  .gpds2-cause-buttons { display: grid; grid-template-columns: 1fr; }
}
@media (max-width: 420px) {
  .gpds2-shell { width: min(100% - 20px, 1180px); }
  .gpds2-card-body, .gpds2-step-body { padding: 16px; }
  .gpds2-media--hero { min-height: 330px; }
  .gpds2-media--card, .gpds2-media--service, .gpds2-media--location { min-height: 200px; }
}
@media (prefers-reduced-motion: reduce) {
  .gpds2-page *, .gpds2-page *::before, .gpds2-page *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: .01ms !important; }
}


/* v2.1 live QA refinements: real-photo media, larger drain guide, safer cropping */
.gpds2-media img { object-fit: var(--gpds2-img-fit, cover); }
.gpds2-media.is-fallback-photo::after { content: "Image fallback loaded"; position: absolute; left: -9999px; }
.gpds2-guide-section, .gpds2-atlas-section { overflow: visible; }
.gpds2-guide-card { max-width: 100%; }
.gpds2-guide-card .gpdw2-title { font-size: clamp(2rem, 3.4vw, 3.3rem) !important; }
.gpds2-guide-card .gpdw2-card { min-width: 0; }
@media (max-width: 760px) {
  .gpds2-media img { object-position: var(--gpds2-img-pos-mobile, var(--gpds2-img-pos, 50% 50%)); }
  .gpds2-guide-card { padding: 8px; }
}


/* v2.3 bottom-section rebuild: premium process, pricing, and next-page routing */
.gpds2-process-showcase {
  display: grid;
  grid-template-columns: minmax(320px, .92fr) minmax(0, 1.08fr);
  gap: clamp(18px, 3vw, 34px);
  align-items: stretch;
}
.gpds2-process-lead { display: grid; grid-template-rows: auto 1fr; min-height: 100%; }
.gpds2-process-lead .gpds2-media { border-radius: 22px 22px 0 0; border-width: 0 0 1px; min-height: clamp(260px, 28vw, 430px); }
.gpds2-process-lead-copy { position: relative; z-index: 3; padding: clamp(22px, 3vw, 36px); }
.gpds2-process-lead-copy h3 { font-size: clamp(1.45rem, 2vw, 2rem); max-width: 620px; }
.gpds2-process-steps { display: grid; gap: 12px; }
.gpds2-step-card {
  display: grid;
  grid-template-columns: minmax(132px, 180px) minmax(0, 1fr);
  align-items: stretch;
  min-height: 132px;
}
.gpds2-step-card .gpds2-media--step {
  min-height: 132px;
  aspect-ratio: auto;
  border-radius: 22px 0 0 22px;
  border-width: 0 1px 0 0;
}
.gpds2-step-card .gpds2-media img,
.gpds2-media--person-safe img,
.gpds2-route-card .gpds2-media img,
.gpds2-location-card .gpds2-media img,
.gpds2-service-card .gpds2-media img {
  object-position: var(--gpds2-img-pos, 50% 22%);
}
.gpds2-step-body {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  gap: 14px;
  padding: 18px 18px 18px 16px;
  align-items: start;
}
.gpds2-step-body h3 { font-size: clamp(1.08rem, 1.25vw, 1.42rem); letter-spacing: -.025em; max-width: none; }
.gpds2-step-body p { margin-top: 6px; font-size: .96rem; line-height: 1.48; }
.gpds2-step-body > span { width: 38px; height: 38px; font-size: .95rem; box-shadow: 0 0 0 5px rgba(199,164,94,.11), 0 0 24px rgba(255,215,130,.18); }

.gpds2-pricing-grid--premium { grid-template-columns: minmax(320px, .94fr) minmax(0, 1.06fr); align-items: stretch; }
.gpds2-price-proof-row { display: grid; gap: 10px; margin-top: 24px; }
.gpds2-price-proof-row span {
  display: flex;
  align-items: center;
  min-height: 42px;
  border: 1px solid rgba(199,164,94,.28);
  border-radius: 999px;
  padding: 9px 13px;
  color: rgba(249,245,238,.88);
  background: rgba(255,255,255,.05);
  font-weight: 800;
}
.gpds2-options-card--photo { padding: 0; display: grid; grid-template-rows: auto 1fr; }
.gpds2-options-card--photo .gpds2-media { border-radius: 22px 22px 0 0; border-width: 0 0 1px; min-height: clamp(220px, 24vw, 360px); }
.gpds2-options-copy { position: relative; z-index: 3; padding: clamp(24px, 3vw, 42px); }
.gpds2-options-copy h3 { font-size: clamp(1.5rem, 2vw, 2.15rem); }
.gpds2-options-card--photo ul { margin-top: 18px; }

.gpds2-next-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.gpds2-next-card { display: grid; grid-template-rows: auto 1fr; min-width: 0; }
.gpds2-next-card .gpds2-media { border-radius: 22px 22px 0 0; border-width: 0 0 1px; min-height: 220px; }
.gpds2-next-body { position: relative; z-index: 3; padding: 22px; }
.gpds2-next-body h3 { font-size: clamp(1.22rem, 1.45vw, 1.65rem); max-width: none; }
.gpds2-resource-strip {
  margin-top: 22px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.gpds2-resource-pill {
  position: relative;
  overflow: hidden;
  min-height: 108px;
  border: 1px solid rgba(199,164,94,.24);
  border-radius: 20px;
  background: radial-gradient(circle at var(--mx, 50%) var(--my, 12%), rgba(255,215,130,.10), transparent 42%), rgba(255,255,255,.035);
  text-decoration: none !important;
  padding: 16px;
  transition: transform .24s var(--gpds2-ease), border-color .24s var(--gpds2-ease), background .24s var(--gpds2-ease);
}
.gpds2-resource-pill strong { display: block; color: var(--gpds2-cream); font-family: "Libre Baskerville", Georgia, serif; line-height: 1.12; }
.gpds2-resource-pill span { display: block; margin-top: 8px; color: var(--gpds2-muted); font-size: .9rem; line-height: 1.45; }
.gpds2-resource-pill:hover, .gpds2-resource-pill:focus-visible { transform: translateY(-3px); border-color: rgba(255,215,130,.62); background: rgba(199,164,94,.10); outline: none; }

@media (max-width: 1180px) {
  .gpds2-process-showcase, .gpds2-pricing-grid--premium { grid-template-columns: 1fr; }
  .gpds2-next-grid { grid-template-columns: 1fr; }
  .gpds2-resource-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 720px) {
  .gpds2-step-card { grid-template-columns: 1fr; }
  .gpds2-step-card .gpds2-media--step { border-radius: 22px 22px 0 0; border-width: 0 0 1px; min-height: 210px; }
  .gpds2-step-body { grid-template-columns: 44px minmax(0, 1fr); }
  .gpds2-resource-strip { grid-template-columns: 1fr; }
  .gpds2-next-card .gpds2-media { min-height: 210px; }
  .gpds2-options-card--photo .gpds2-media { min-height: 225px; }
}

/* v2.3 live QA repair: disable/wpautop fallout guards, drain tool sizing, common-cause visuals, controlled-visit rebuild */
.gpds2-page p:empty,
.gpds2-page .gpds2-card > p,
.gpds2-page .gpds2-shell > p,
.gpds2-page .gpds2-section-head > p:empty,
.gpds2-page .gpds2-card-body > p:empty,
.gpds2-page .gpds2-step-body > p,
.gpds2-page .gpds2-linkchips br,
.gpds2-page .gpds2-card-media-link p { display: none !important; margin: 0 !important; padding: 0 !important; }
.gpds2-media.is-fallback-photo img { opacity: 1 !important; }
.gpds2-media.is-broken:not(.is-fallback-photo) img { opacity: 0; }

/* Drain blockage guide: keep it large, but stop the wide-screen overflow / awkward scaling. */
.gpds2-atlas-section .gpds2-shell { width: min(1360px, calc(100% - clamp(24px, 4vw, 64px))); }
.gpds2-guide-card { padding: clamp(8px, 1.2vw, 16px) !important; min-height: 0 !important; overflow: hidden !important; }
.gpds2-guide-card .gpdw2-tool { width: 100% !important; max-width: 100% !important; padding: 18px 12px 26px !important; }
.gpds2-guide-card .gpdw2-shell { width: 100% !important; max-width: 100% !important; overflow: hidden !important; }
.gpds2-guide-card .gpdw2-hero { padding: 20px 20px 10px !important; }
.gpds2-guide-card .gpdw2-topbar { padding: 0 20px 14px !important; }
.gpds2-guide-card .gpdw2-grid { min-width: 0 !important; width: 100% !important; padding: 0 20px 20px !important; gap: 16px !important; align-items: start !important; }
.gpds2-guide-card .gpdw2-card,
.gpds2-guide-card .gpdw2-panel { min-width: 0 !important; }
.gpds2-guide-card .gpdw2-card { padding: 12px !important; border-radius: 22px !important; }
.gpds2-guide-card .gpdw2-stage { min-height: 0 !important; height: clamp(430px, 43vw, 620px) !important; aspect-ratio: auto !important; }
.gpds2-guide-card .gpdw2-title { font-size: clamp(1.65rem, 2.55vw, 2.55rem) !important; }
.gpds2-guide-card .gpdw2-subtitle { font-size: clamp(.98rem, 1.06vw, 1.05rem) !important; max-width: 78ch !important; }
.gpds2-guide-card .gpdw2-cardhead h2,
.gpds2-guide-card .gpdw2-panel h2 { font-size: clamp(1.04rem, 1.22vw, 1.22rem) !important; }
.gpds2-guide-card .gpdw2-legend { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; gap: 8px !important; }
@media (min-width: 960px) {
  .gpds2-guide-card .gpdw2-grid { grid-template-columns: minmax(0, .98fr) minmax(300px, .48fr) !important; }
}
@media (max-width: 959px) {
  .gpds2-guide-card { overflow-x: hidden !important; }
  .gpds2-guide-card > * { min-width: 0 !important; }
  .gpds2-guide-card .gpdw2-grid { grid-template-columns: 1fr !important; }
  .gpds2-guide-card .gpdw2-stage { height: clamp(350px, 70vw, 560px) !important; }
  .gpds2-guide-card .gpdw2-legend { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 620px) {
  .gpds2-guide-card { padding: 6px !important; }
  .gpds2-guide-card .gpdw2-tool { padding: 12px 6px 22px !important; }
  .gpds2-guide-card .gpdw2-hero,
  .gpds2-guide-card .gpdw2-topbar,
  .gpds2-guide-card .gpdw2-grid { padding-left: 10px !important; padding-right: 10px !important; }
  .gpds2-guide-card .gpdw2-stage { height: clamp(300px, 76vw, 460px) !important; }
}

/* Common causes: add the missing visual weight and remove the empty-card feeling. */
.gpds2-cause-grid { grid-template-columns: minmax(240px, .38fr) minmax(0, 1fr); gap: clamp(16px, 2.4vw, 28px); }
.gpds2-cause-buttons { display: grid; gap: 10px; }
.gpds2-cause-tab { width: 100%; text-align: left; justify-content: flex-start; }
.gpds2-cause-panel { min-height: 0 !important; padding: 0 !important; }
.gpds2-cause-content { display: none; position: relative; z-index: 3; grid-template-columns: minmax(220px, .44fr) minmax(0, 1fr); gap: clamp(18px, 2.6vw, 32px); align-items: stretch; }
.gpds2-cause-content.is-active { display: grid; }
.gpds2-media--cause { min-height: clamp(260px, 24vw, 390px); aspect-ratio: auto; border-radius: 22px 0 0 22px; border-width: 0 1px 0 0; }
.gpds2-cause-copy { padding: clamp(24px, 3vw, 42px); align-self: center; min-width: 0; }
.gpds2-cause-copy h3 { font-size: clamp(1.55rem, 2vw, 2.35rem); max-width: none; }
.gpds2-cause-copy p { max-width: 70ch; }
@media (max-width: 920px) {
  .gpds2-cause-grid { grid-template-columns: 1fr; }
  .gpds2-cause-buttons { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .gpds2-cause-content { grid-template-columns: 1fr; }
  .gpds2-media--cause { min-height: 260px; border-radius: 22px 22px 0 0; border-width: 0 0 1px; }
}
@media (max-width: 620px) { .gpds2-cause-buttons { grid-template-columns: 1fr; } }

/* Controlled visit: rebuild from narrow side-strips into readable premium story cards. */
.gpds2-process-showcase { grid-template-columns: 1fr !important; gap: clamp(18px, 3vw, 34px); }
.gpds2-process-lead { grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr); grid-template-rows: auto !important; align-items: stretch; }
.gpds2-process-lead .gpds2-media { min-height: clamp(320px, 30vw, 480px); border-radius: 22px 0 0 22px; border-width: 0 1px 0 0; }
.gpds2-process-lead-copy { display: flex; flex-direction: column; justify-content: center; }
.gpds2-process-steps { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.gpds2-step-card { display: grid !important; grid-template-columns: 1fr !important; grid-template-rows: auto 1fr; min-height: 0 !important; }
.gpds2-step-card .gpds2-media--step { min-height: clamp(190px, 18vw, 260px); aspect-ratio: 16 / 9; border-radius: 22px 22px 0 0 !important; border-width: 0 0 1px !important; }
.gpds2-step-body { grid-template-columns: 52px minmax(0, 1fr) !important; gap: 14px; padding: 20px !important; align-items: start; }
.gpds2-step-body > div { min-width: 0; }
.gpds2-step-body h3 { font-size: clamp(1.2rem, 1.45vw, 1.55rem) !important; line-height: 1.03; }
.gpds2-step-body p { font-size: .98rem !important; line-height: 1.55 !important; max-width: 36ch; }
.gpds2-step-body > span { width: 42px !important; height: 42px !important; }
@media (max-width: 1100px) { .gpds2-process-steps { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 760px) {
  .gpds2-process-lead { grid-template-columns: 1fr; }
  .gpds2-process-lead .gpds2-media { border-radius: 22px 22px 0 0; border-width: 0 0 1px; }
  .gpds2-process-steps { grid-template-columns: 1fr; }
  .gpds2-step-card .gpds2-media--step { min-height: 220px; }
}
@media (max-width: 720px) {
  .gpds2-step-card .gpds2-media img,
  .gpds2-media--person-safe img,
  .gpds2-route-card .gpds2-media img,
  .gpds2-location-card .gpds2-media img,
  .gpds2-service-card .gpds2-media img { object-position: var(--gpds2-img-pos-mobile, var(--gpds2-img-pos, 50% 22%)) !important; }
}

/* v2.3 QA repair: drain guide fit, missing-picture fallback, common-causes visual depth, and non-autop layout guards */
.gpds2-page p:empty,
.gpds2-page .gpds2-step-body > p:empty,
.gpds2-page .gpds2-visit-step-copy > p:empty,
.gpds2-page .gpds2-card-body > p:empty,
.gpds2-page .gpds2-cause-copy > p:empty { display: none !important; }
.gpds2-linkchips br,
.gpds2-trust-row br,
.gpds2-guide-points br,
.gpds2-mini-grid br,
.gpds2-price-proof-row br,
.gpds2-visit-proof-row br,
.gpds2-cause-signals br { display: none !important; }

/* Interactive guide: keep the drain widget readable at wide widths instead of letting the SVG/panels sprawl or clip. */
.gpds2-guide-card {
  padding: clamp(10px, 1.4vw, 20px);
  overflow: hidden;
}
.gpds2-guide-card .gpdw2-shortcode,
.gpds2-guide-card .gpdw2-tool,
.gpds2-guide-card .gpdw2-shell,
.gpds2-guide-card .gpdw2-maincol,
.gpds2-guide-card .gpdw2-card,
.gpds2-guide-card .gpdw2-panel { min-width: 0 !important; }
.gpds2-guide-card .gpdw2-tool {
  max-width: 1160px !important;
  margin-inline: auto !important;
  padding: 0 !important;
}
.gpds2-guide-card .gpdw2-shell {
  overflow: hidden !important;
  border-radius: 28px !important;
}
.gpds2-guide-card .gpdw2-hero { padding: clamp(18px, 2vw, 26px) clamp(18px, 2vw, 26px) 8px !important; }
.gpds2-guide-card .gpdw2-title { font-size: clamp(1.55rem, 2.7vw, 2.65rem) !important; letter-spacing: -.045em !important; }
.gpds2-guide-card .gpdw2-subtitle { max-width: 86ch !important; font-size: clamp(.94rem, 1vw, 1.02rem) !important; }
.gpds2-guide-card .gpdw2-topbar { padding: 0 clamp(18px, 2vw, 26px) 14px !important; }
.gpds2-guide-card .gpdw2-grid {
  grid-template-columns: minmax(0, 1fr) minmax(286px, .46fr) !important;
  gap: clamp(14px, 1.8vw, 22px) !important;
  padding: 0 clamp(18px, 2vw, 26px) clamp(18px, 2vw, 26px) !important;
}
.gpds2-guide-card .gpdw2-stage {
  min-height: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
}
.gpds2-guide-card .gpdw2-panel { padding: clamp(16px, 1.7vw, 22px) !important; }
.gpds2-guide-card .gpdw2-panelblock,
.gpds2-guide-card .gpdw2-highlight { padding: clamp(14px, 1.5vw, 20px) !important; }
.gpds2-guide-card .gpdw2-highlight h2 { font-size: clamp(1.22rem, 1.65vw, 1.75rem) !important; line-height: 1.08 !important; }
.gpds2-guide-card .gpdw2-panel h3 { font-size: clamp(.82rem, .9vw, .96rem) !important; letter-spacing: .14em !important; }

/* Common causes: visual, useful, and no longer a mostly-empty tab panel. */
.gpds2-cause-grid { grid-template-columns: minmax(230px, .34fr) minmax(0, 1fr); gap: clamp(16px, 2.4vw, 28px); }
.gpds2-cause-buttons { display: grid; grid-template-columns: 1fr; gap: 10px; }
.gpds2-cause-panel { padding: 0; min-height: clamp(360px, 31vw, 500px); }
.gpds2-cause-content { height: 100%; }
.gpds2-cause-content-grid {
  display: grid;
  grid-template-columns: minmax(280px, .46fr) minmax(0, 1fr);
  min-height: inherit;
  height: 100%;
}
.gpds2-media--cause {
  min-height: 100%;
  height: 100%;
  aspect-ratio: auto;
  border-radius: 26px 0 0 26px;
  border-width: 0 1px 0 0;
}
.gpds2-cause-copy {
  position: relative;
  z-index: 3;
  min-width: 0;
  padding: clamp(24px, 3.2vw, 46px);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.gpds2-cause-copy h3 { font-size: clamp(1.55rem, 2.4vw, 2.5rem); line-height: 1.02; max-width: 700px; }
.gpds2-cause-signals {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 20px;
}
.gpds2-cause-signals span,
.gpds2-visit-proof-row span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  border: 1px solid rgba(255,215,130,.28);
  border-radius: 999px;
  padding: 7px 11px;
  background: rgba(255,255,255,.045);
  color: rgba(249,245,238,.84);
  font-weight: 850;
  font-size: .84rem;
}

/* Controlled visit: replaces the thin image/text rows with a readable premium service-story layout. */
.gpds2-visit-showcase { display: grid; gap: clamp(18px, 3vw, 34px); }
.gpds2-visit-lead {
  display: grid;
  grid-template-columns: minmax(320px, .9fr) minmax(0, 1.1fr);
  align-items: stretch;
  padding: 0;
}
.gpds2-media--visit-lead {
  min-height: clamp(300px, 30vw, 470px);
  height: 100%;
  aspect-ratio: auto;
  border-radius: 26px 0 0 26px;
  border-width: 0 1px 0 0;
}
.gpds2-visit-lead-copy {
  position: relative;
  z-index: 3;
  min-width: 0;
  padding: clamp(24px, 3.3vw, 48px);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.gpds2-visit-lead-copy h3 { font-size: clamp(1.8rem, 3vw, 3.15rem); max-width: 720px; }
.gpds2-visit-proof-row { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 22px; }
.gpds2-visit-step-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.gpds2-visit-step-card { display: grid; grid-template-rows: auto 1fr; min-width: 0; }
.gpds2-media--visit-step {
  aspect-ratio: 16 / 10;
  min-height: 180px;
  border-radius: 22px 22px 0 0;
  border-width: 0 0 1px;
}
.gpds2-visit-step-copy {
  position: relative;
  z-index: 3;
  min-width: 0;
  padding: 20px;
}
.gpds2-step-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  margin-bottom: 14px;
  border-radius: 999px;
  background: linear-gradient(180deg, #e0bd6e, var(--gpds2-gold));
  color: #070707;
  font-weight: 950;
  box-shadow: 0 0 0 6px rgba(199,164,94,.12), 0 0 28px rgba(255,215,130,.2);
}
.gpds2-visit-step-copy h3 { font-size: clamp(1.18rem, 1.45vw, 1.55rem); line-height: 1.08; max-width: none; }
.gpds2-visit-step-copy p { margin-top: 8px; font-size: .96rem; line-height: 1.5; }
.gpds2-media--visit-lead img,
.gpds2-media--visit-step img,
.gpds2-media--cause img { object-position: var(--gpds2-img-pos, 50% 22%); }

@media (max-width: 1180px) {
  .gpds2-visit-step-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 1120px) {
  .gpds2-guide-card .gpdw2-grid { grid-template-columns: 1fr !important; }
  .gpds2-guide-card .gpdw2-panel {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px !important;
  }
  .gpds2-guide-card .gpdw2-highlight { grid-column: 1 / -1; }
}
@media (max-width: 920px) {
  .gpds2-cause-grid { grid-template-columns: 1fr; }
  .gpds2-cause-buttons { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .gpds2-cause-content-grid { grid-template-columns: 1fr; }
  .gpds2-media--cause { border-radius: 26px 26px 0 0; border-width: 0 0 1px; min-height: 270px; }
  .gpds2-visit-lead { grid-template-columns: 1fr; }
  .gpds2-media--visit-lead { border-radius: 26px 26px 0 0; border-width: 0 0 1px; min-height: 300px; }
}
@media (max-width: 720px) {
  .gpds2-guide-card { padding: 6px; overflow-x: hidden; }
  .gpds2-guide-card .gpdw2-tool { max-width: 100% !important; }
  .gpds2-guide-card .gpdw2-hero,
  .gpds2-guide-card .gpdw2-topbar,
  .gpds2-guide-card .gpdw2-grid { padding-left: 12px !important; padding-right: 12px !important; }
  .gpds2-guide-card .gpdw2-panel { grid-template-columns: 1fr !important; }
  .gpds2-guide-card .gpdw2-legend { grid-template-columns: 1fr 1fr !important; }
  .gpds2-cause-buttons { grid-template-columns: 1fr; }
  .gpds2-visit-step-grid { grid-template-columns: 1fr; }
  .gpds2-media--visit-step { min-height: 220px; }
  .gpds2-media--visit-lead img,
  .gpds2-media--visit-step img,
  .gpds2-media--cause img { object-position: var(--gpds2-img-pos-mobile, var(--gpds2-img-pos, 50% 18%)); }
}

/* v2.5.0 bottom-third rebuild: anti-collapse common causes, controlled visit process rail, cleaner route index, stronger guide wrapper. */
.gpds2-page {
  --gpds2-text-max: 70ch;
}
.gpds2-page p,
.gpds2-page li {
  word-break: normal;
  overflow-wrap: break-word;
}
.gpds2-page .gpds2-card,
.gpds2-page .gpds2-cause-copy,
.gpds2-page .gpds2-controlled-step-copy,
.gpds2-page .gpds2-next-body,
.gpds2-page .gpds2-options-copy { min-width: 0; }

/* Interactive drain tool: feature-product wrapper, not a squeezed side widget. */
.gpds2-atlas-section .gpds2-shell,
.gpds2-atlas-section .gpds2-guide-grid {
  width: min(1400px, calc(100% - clamp(20px, 4vw, 64px))) !important;
  max-width: 1400px !important;
}
.gpds2-guide-grid { grid-template-columns: 1fr !important; }
.gpds2-guide-copy {
  display: grid;
  grid-template-columns: minmax(0, .72fr) minmax(280px, .28fr);
  gap: clamp(18px, 3vw, 34px);
  align-items: end;
  padding-top: 0 !important;
}
.gpds2-guide-copy .gpds2-actions--stack { align-items: center; justify-content: flex-end; margin-top: 0; }
.gpds2-guide-card {
  padding: clamp(10px, 1.25vw, 18px) !important;
  overflow: visible !important;
  min-height: 0 !important;
  border-radius: 30px !important;
}
.gpds2-guide-card .gpdw2-tool,
.gpds2-guide-card .gpdw2-root,
.gpds2-guide-card .gpdw2-shell,
.gpds2-guide-card [class*="gpdw2"] {
  max-width: 100% !important;
}
.gpds2-guide-card .gpdw2-tool,
.gpds2-guide-card .gpdw2-root { margin-inline: auto !important; }
.gpds2-guide-card .gpdw2-grid {
  grid-template-columns: minmax(0, 1.12fr) minmax(310px, .48fr) !important;
  gap: clamp(14px, 2vw, 26px) !important;
}
.gpds2-guide-card .gpdw2-stage {
  height: clamp(500px, 48vw, 760px) !important;
  min-height: 500px !important;
}
@media (max-width: 1180px) {
  .gpds2-guide-copy { grid-template-columns: 1fr; }
  .gpds2-guide-copy .gpds2-actions--stack { justify-content: flex-start; margin-top: 22px; }
  .gpds2-guide-card .gpdw2-grid { grid-template-columns: 1fr !important; }
  .gpds2-guide-card .gpdw2-stage { height: clamp(430px, 68vw, 650px) !important; min-height: 430px !important; }
}
@media (max-width: 680px) {
  .gpds2-atlas-section .gpds2-shell,
  .gpds2-atlas-section .gpds2-guide-grid { width: min(100% - 18px, 1400px) !important; }
  .gpds2-guide-card { padding: 6px !important; overflow: hidden !important; }
  .gpds2-guide-card .gpdw2-stage { height: clamp(310px, 82vw, 480px) !important; min-height: 310px !important; }
}

/* Common causes v2.5.0: wide media banner + readable explanation. */
.gpds2-cause-grid { display: none !important; }
.gpds2-cause-layout-v24 {
  display: grid;
  grid-template-columns: minmax(250px, 340px) minmax(0, 1fr);
  gap: clamp(18px, 3vw, 36px);
  align-items: stretch;
}
.gpds2-cause-tabs-card {
  padding: clamp(22px, 3vw, 34px);
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-height: 100%;
}
.gpds2-cause-tabs-card h3 { font-size: clamp(1.35rem, 1.65vw, 1.85rem); }
.gpds2-cause-note { margin-top: auto !important; color: rgba(249,245,238,.62) !important; font-size: .94rem !important; }
.gpds2-cause-layout-v24 .gpds2-cause-buttons { display: grid !important; grid-template-columns: 1fr !important; gap: 10px; }
.gpds2-cause-layout-v24 .gpds2-cause-tab {
  width: 100%;
  text-align: left;
  min-height: 44px;
  line-height: 1.15;
}
.gpds2-cause-panel {
  padding: 0 !important;
  min-height: 0 !important;
  display: block;
}
.gpds2-cause-content { display: none !important; min-width: 0; }
.gpds2-cause-content.is-active { display: block !important; }
.gpds2-cause-hero-media { position: relative; z-index: 3; }
.gpds2-cause-hero-media .gpds2-media--cause {
  min-height: clamp(240px, 25vw, 360px) !important;
  aspect-ratio: 21 / 9;
  height: auto !important;
  border-radius: 26px 26px 0 0 !important;
  border-width: 0 0 1px !important;
}
.gpds2-cause-copy {
  padding: clamp(24px, 3.2vw, 46px) !important;
  display: block !important;
  max-width: 980px;
}
.gpds2-cause-copy h3 {
  font-size: clamp(1.7rem, 3vw, 3rem) !important;
  line-height: 1.02 !important;
  max-width: 860px !important;
}
.gpds2-cause-copy > p { max-width: var(--gpds2-text-max); }
.gpds2-cause-meta-grid {
  display: grid;
  grid-template-columns: minmax(0, .82fr) minmax(0, 1.18fr);
  gap: clamp(16px, 2.4vw, 30px);
  margin-top: 24px;
}
.gpds2-cause-meta-grid strong {
  display: block;
  color: var(--gpds2-gold-light);
  font-size: .78rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.gpds2-cause-signals { margin-top: 0 !important; }
@media (max-width: 1020px) {
  .gpds2-cause-layout-v24 { grid-template-columns: 1fr; }
  .gpds2-cause-layout-v24 .gpds2-cause-buttons { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 680px) {
  .gpds2-cause-layout-v24 .gpds2-cause-buttons,
  .gpds2-cause-meta-grid { grid-template-columns: 1fr !important; }
  .gpds2-cause-hero-media .gpds2-media--cause { min-height: 220px !important; aspect-ratio: 16 / 10; }
}

/* Controlled Visit v2.5.0: feature story plus horizontal process rail. */
.gpds2-visit-showcase { display: none !important; }
.gpds2-controlled-v24 {
  display: grid;
  grid-template-columns: minmax(360px, .9fr) minmax(540px, 1.1fr);
  gap: clamp(20px, 3vw, 42px);
  align-items: start;
}
.gpds2-controlled-feature {
  padding: 0;
  display: grid;
  grid-template-rows: auto 1fr;
}
.gpds2-controlled-feature-media .gpds2-media--controlled-feature {
  min-height: clamp(320px, 32vw, 520px);
  aspect-ratio: 16 / 11;
  border-radius: 26px 26px 0 0;
  border-width: 0 0 1px;
}
.gpds2-controlled-feature-copy {
  position: relative;
  z-index: 3;
  padding: clamp(24px, 3.3vw, 48px);
}
.gpds2-controlled-feature-copy h3 {
  font-size: clamp(1.85rem, 3.2vw, 3.35rem);
  max-width: 760px;
}
.gpds2-controlled-feature-copy p { max-width: 72ch; }
.gpds2-controlled-rail {
  display: grid;
  gap: 14px;
}
.gpds2-controlled-step {
  display: grid;
  grid-template-columns: 54px minmax(170px, 220px) minmax(0, 1fr);
  gap: 16px;
  align-items: stretch;
  padding: 14px;
  min-width: 0;
}
.gpds2-controlled-step .gpds2-step-number {
  margin: 0;
  align-self: center;
  justify-self: center;
}
.gpds2-controlled-step .gpds2-media--controlled-step {
  min-height: 128px;
  height: 100%;
  aspect-ratio: 16 / 10;
  border-radius: 18px;
  border-width: 1px;
}
.gpds2-controlled-step-copy {
  position: relative;
  z-index: 3;
  align-self: center;
  padding: 4px 6px 4px 0;
}
.gpds2-controlled-step-copy h3 {
  font-size: clamp(1.18rem, 1.55vw, 1.65rem);
  max-width: none;
}
.gpds2-controlled-step-copy p {
  margin-top: 8px;
  max-width: 42ch;
  font-size: .98rem;
  line-height: 1.52;
}
@media (max-width: 1240px) {
  .gpds2-controlled-v24 { grid-template-columns: 1fr; }
  .gpds2-controlled-feature { grid-template-columns: minmax(320px, .9fr) minmax(0, 1.1fr); grid-template-rows: auto; }
  .gpds2-controlled-feature-media .gpds2-media--controlled-feature {
    min-height: clamp(280px, 32vw, 430px);
    height: 100%;
    aspect-ratio: auto;
    border-radius: 26px 0 0 26px;
    border-width: 0 1px 0 0;
  }
}
@media (max-width: 880px) {
  .gpds2-controlled-feature,
  .gpds2-controlled-step { grid-template-columns: 1fr; }
  .gpds2-controlled-feature-media .gpds2-media--controlled-feature {
    border-radius: 26px 26px 0 0;
    border-width: 0 0 1px;
    min-height: 280px;
    aspect-ratio: 16 / 10;
  }
  .gpds2-controlled-step { padding: 12px; }
  .gpds2-controlled-step .gpds2-step-number { justify-self: start; margin-left: 4px; }
  .gpds2-controlled-step .gpds2-media--controlled-step { min-height: 220px; }
  .gpds2-controlled-step-copy { padding: 0 8px 10px; }
  .gpds2-controlled-step-copy p { max-width: var(--gpds2-text-max); }
}

/* Pricing: stronger trust-section shape. */
.gpds2-pricing-grid--premium { grid-template-columns: minmax(360px, .98fr) minmax(0, 1.02fr); }
.gpds2-price-proof-row {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.gpds2-price-proof-row span { border-radius: 18px; min-height: 56px; }
@media (max-width: 920px) {
  .gpds2-price-proof-row { grid-template-columns: 1fr; }
}

/* Next Pages: convert the bottom link dump into a useful route index. */
.gpds2-route-index {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 22px;
}
.gpds2-route-index-group {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(199,164,94,.24);
  border-radius: 24px;
  padding: clamp(20px, 2.6vw, 30px);
  background:
    radial-gradient(circle at 20% 0%, rgba(255,215,130,.10), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.022));
  box-shadow: 0 20px 58px rgba(0,0,0,.28);
}
.gpds2-route-index-group h3 {
  font-size: clamp(1.18rem, 1.55vw, 1.7rem);
  max-width: none;
}
.gpds2-route-index-group .gpds2-linkchips { margin-top: 18px; }
.gpds2-resource-strip { display: none !important; }
@media (max-width: 860px) {
  .gpds2-route-index { grid-template-columns: 1fr; }
}

/* Lower-page spacing polish: less dead space without crowding. */
.gpds2-process,
.gpds2-pricing,
.gpds2-resources,
.gpds2-faq { padding-top: clamp(46px, 6vw, 84px); padding-bottom: clamp(46px, 6vw, 84px); }
.gpds2-final { padding-top: clamp(44px, 6vw, 78px); }

@media (max-width: 720px) {
  .gpds2-media--controlled-feature,
  .gpds2-media--controlled-step,
  .gpds2-media--cause { min-height: 220px; }
}

/* v2.5.0 QA fixes: FAQ answers + narrow-width grid regression repair. */
.gpds2-faq-list details.gpds2-faq-item {
  overflow: hidden;
}
.gpds2-faq-list details.gpds2-faq-item summary {
  min-height: 62px;
  display: flex;
  align-items: center;
}
.gpds2-faq-list details.gpds2-faq-item .gpds2-faq-answer {
  position: relative;
  z-index: 3;
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
  padding: 0 22px 22px;
}
.gpds2-faq-list details.gpds2-faq-item:not([open]) .gpds2-faq-answer {
  display: none !important;
}
.gpds2-faq-list details.gpds2-faq-item .gpds2-faq-answer p {
  display: block !important;
  visibility: visible !important;
  color: rgba(249,245,238,.76) !important;
  padding: 0 !important;
  margin: 0 !important;
  max-width: 74ch;
  line-height: 1.66;
}
.gpds2-faq-list details.gpds2-faq-item[open] {
  border-color: rgba(255,215,130,.48);
  background:
    radial-gradient(circle at 22% 0%, rgba(255,215,130,.13), transparent 46%),
    linear-gradient(180deg, rgba(255,255,255,.082), rgba(255,255,255,.034));
}

.gpds2-pricing-grid--premium {
  align-items: stretch;
}
.gpds2-options-card--photo {
  display: grid;
  grid-template-rows: auto 1fr;
  min-height: 0 !important;
}
.gpds2-options-card--photo .gpds2-media--wide {
  min-height: clamp(210px, 20vw, 310px);
  border-radius: 26px 26px 0 0;
  border-width: 0 0 1px;
}
.gpds2-options-card--photo .gpds2-options-copy {
  position: relative;
  z-index: 3;
  padding: clamp(22px, 3vw, 36px);
}
@media (max-width: 1040px) {
  .gpds2-pricing-grid--premium {
    grid-template-columns: 1fr !important;
  }
  .gpds2-options-card--photo {
    grid-template-columns: minmax(260px, .9fr) minmax(0, 1.1fr);
    grid-template-rows: auto;
  }
  .gpds2-options-card--photo .gpds2-media--wide {
    height: 100%;
    min-height: 260px;
    aspect-ratio: auto;
    border-radius: 26px 0 0 26px;
    border-width: 0 1px 0 0;
  }
}
@media (max-width: 760px) {
  .gpds2-options-card--photo {
    grid-template-columns: 1fr;
  }
  .gpds2-options-card--photo .gpds2-media--wide {
    min-height: 220px;
    aspect-ratio: 16 / 10;
    border-radius: 26px 26px 0 0;
    border-width: 0 0 1px;
  }
  .gpds2-price-card .gpds2-actions,
  .gpds2-final-card .gpds2-actions {
    align-items: stretch;
  }
  .gpds2-price-card .gpds2-actions .gpds2-btn,
  .gpds2-final-card .gpds2-actions .gpds2-btn {
    flex: 1 1 100%;
  }
}
@media (max-width: 1040px) {
  .gpds2-controlled-v24 {
    grid-template-columns: 1fr !important;
  }
}
@media (max-width: 760px) {
  .gpds2-controlled-feature,
  .gpds2-controlled-step {
    grid-template-columns: 1fr !important;
  }
  .gpds2-controlled-step .gpds2-media--controlled-step {
    min-height: 210px;
    width: 100%;
  }
  .gpds2-controlled-step-copy p {
    max-width: 68ch;
  }
}

/* GPDS v2.5.0 — responsive polish, jump routing, and anti-collapse safeguards */
.gpds2-page,
.gpds2-page * {
  min-width: 0;
}

.gpds2-page img {
  max-width: 100%;
}

.gpds2-jump-nav {
  position: relative;
  z-index: 8;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 9px;
  margin-top: clamp(-18px, -1.4vw, -8px);
  margin-bottom: clamp(16px, 2.6vw, 34px);
  padding: 13px;
  border: 1px solid rgba(199,164,94,.24);
  border-radius: 999px;
  background:
    radial-gradient(circle at 50% 0%, rgba(255,215,130,.12), transparent 52%),
    linear-gradient(180deg, rgba(18,16,13,.88), rgba(8,8,7,.78));
  box-shadow: 0 22px 64px rgba(0,0,0,.36), inset 0 0 0 1px rgba(255,255,255,.04);
  backdrop-filter: blur(16px);
}
.gpds2-jump-nav a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 9px 14px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  color: rgba(249,245,238,.84) !important;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .11em;
  text-transform: uppercase;
  text-decoration: none !important;
  background: rgba(255,255,255,.04);
  transition: transform .24s var(--gpds2-ease), border-color .24s var(--gpds2-ease), background .24s var(--gpds2-ease), color .24s var(--gpds2-ease), box-shadow .24s var(--gpds2-ease);
}
.gpds2-jump-nav a:hover,
.gpds2-jump-nav a:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(255,215,130,.5);
  color: var(--gpds2-gold-light) !important;
  background: rgba(255,215,130,.085);
  box-shadow: 0 10px 28px rgba(199,164,94,.13);
  outline: none;
}

.gpds2-btn,
.gpds2-btn span {
  color: inherit !important;
}
.gpds2-btn--cream,
.gpds2-btn--cream span {
  color: #090807 !important;
}
.gpds2-btn--cream:hover,
.gpds2-btn--cream:focus-visible,
.gpds2-btn--cream:hover span,
.gpds2-btn--cream:focus-visible span {
  color: #090807 !important;
}

.gpds2-media.is-broken.is-fallback-photo,
.gpds2-media.is-fallback-photo {
  background:
    radial-gradient(circle at 50% 16%, rgba(255,215,130,.18), transparent 48%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(0,0,0,.14));
}
.gpds2-media.is-broken.is-fallback-photo img,
.gpds2-media.is-fallback-photo img {
  opacity: 1 !important;
  visibility: visible !important;
}
.gpds2-media--person-safe img {
  object-position: var(--gpds2-img-pos, 50% 22%) !important;
}
@media (max-width: 720px) {
  .gpds2-media--person-safe img {
    object-position: var(--gpds2-img-pos-mobile, var(--gpds2-img-pos, 50% 16%)) !important;
  }
}

@media (min-width: 901px) and (max-width: 1260px) {
  .gpds2-section-head--split {
    grid-template-columns: minmax(0, .95fr) minmax(280px, .75fr);
  }
  .gpds2-cause-layout-v24 {
    grid-template-columns: minmax(240px, 300px) minmax(0, 1fr) !important;
    align-items: stretch;
  }
  .gpds2-cause-tabs-card,
  .gpds2-cause-panel {
    min-width: 0;
  }
  .gpds2-cause-copy {
    padding: clamp(24px, 3vw, 40px) !important;
  }
  .gpds2-cause-copy p,
  .gpds2-cause-copy li {
    max-width: 72ch;
  }
  .gpds2-cause-content.is-active .gpds2-cause-hero-media .gpds2-media--cause {
    min-height: clamp(230px, 26vw, 340px) !important;
  }
}

@media (max-width: 1080px) {
  .gpds2-controlled-step {
    grid-template-columns: 52px minmax(180px, 230px) minmax(0, 1fr) !important;
  }
  .gpds2-controlled-step-copy {
    padding-right: clamp(14px, 2.2vw, 26px);
  }
  .gpds2-controlled-step-copy p {
    max-width: 68ch;
  }
}
@media (max-width: 960px) {
  .gpds2-controlled-step,
  .gpds2-controlled-feature {
    grid-template-columns: 1fr !important;
  }
  .gpds2-controlled-step .gpds2-step-number {
    justify-self: start;
  }
  .gpds2-controlled-step .gpds2-media--controlled-step,
  .gpds2-controlled-feature .gpds2-media--wide {
    width: 100%;
    min-height: clamp(220px, 45vw, 360px) !important;
  }
}

@media (max-width: 1120px) {
  .gpds2-pricing-grid--premium {
    grid-template-columns: 1fr !important;
  }
  .gpds2-price-card,
  .gpds2-options-card--photo,
  .gpds2-final-card,
  .gpds2-next-card,
  .gpds2-faq-list .gpds2-card {
    min-width: 0 !important;
  }
}
@media (max-width: 880px) {
  .gpds2-jump-nav {
    justify-content: flex-start;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    width: min(1180px, calc(100% - 22px));
    border-radius: 22px;
    padding: 10px;
    scroll-snap-type: x proximity;
  }
  .gpds2-jump-nav a {
    flex: 0 0 auto;
    scroll-snap-align: start;
  }
  .gpds2-section {
    padding-top: clamp(44px, 9vw, 72px);
    padding-bottom: clamp(44px, 9vw, 72px);
  }
}
@media (max-width: 680px) {
  .gpds2-shell {
    width: min(100% - 22px, 1180px) !important;
  }
  .gpds2-card-grid,
  .gpds2-next-grid,
  .gpds2-two-col,
  .gpds2-faq-grid,
  .gpds2-pricing-grid--premium,
  .gpds2-controlled-v24,
  .gpds2-cause-layout-v24 {
    grid-template-columns: 1fr !important;
  }
  .gpds2-actions {
    align-items: stretch;
  }
  .gpds2-actions .gpds2-btn {
    flex: 1 1 100%;
    width: 100%;
  }
  .gpds2-guide-card .gpdw2-stage {
    height: clamp(330px, 86vw, 520px) !important;
    min-height: 330px !important;
  }
  .gpds2-guide-card .gpdw2-grid,
  .gpds2-guide-card .gpdw2-hero,
  .gpds2-guide-card .gpdw2-topbar,
  .gpds2-guide-card .gpdw2-copy {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  .gpds2-jump-nav a {
    transition: none !important;
  }
}

/* GPDS v2.5.0 — final install-candidate hardening
   Purpose: keep the bottom 30% premium at every width, prevent skinny text columns,
   preserve real photo use, and keep the embedded drain guide readable. */
.gpds2-page { isolation: isolate; }
.gpds2-card,
.gpds2-panel,
.gpds2-route-index-group,
.gpds2-guide-card { contain: layout paint; }
.gpds2-card h2,
.gpds2-card h3,
.gpds2-card p,
.gpds2-card li,
.gpds2-section-head p,
.gpds2-cause-copy,
.gpds2-controlled-step-copy,
.gpds2-options-copy,
.gpds2-next-body {
  word-break: normal !important;
  overflow-wrap: anywhere;
  hyphens: none;
}

/* Drain guide: give the house layout priority, then stack result panels before they squeeze it. */
.gpds2-guide-card .gpdw2-grid {
  grid-template-columns: minmax(0, 1.18fr) minmax(320px, .52fr) !important;
  align-items: start !important;
}
.gpds2-guide-card .gpdw2-maincol,
.gpds2-guide-card .gpdw2-panel { min-width: 0 !important; }
.gpds2-guide-card .gpdw2-stage {
  height: clamp(500px, 48vw, 760px) !important;
  min-height: 500px !important;
}
.gpds2-guide-card .gpdw2-panel { align-self: stretch !important; }
@media (max-width: 1220px) {
  .gpds2-guide-card .gpdw2-grid { grid-template-columns: 1fr !important; }
  .gpds2-guide-card .gpdw2-stage {
    height: clamp(430px, 70vw, 680px) !important;
    min-height: 430px !important;
  }
  .gpds2-guide-card .gpdw2-panel {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 14px !important;
  }
  .gpds2-guide-card .gpdw2-panelblock,
  .gpds2-guide-card .gpdw2-highlight { min-width: 0 !important; }
}
@media (max-width: 760px) {
  .gpds2-guide-card .gpdw2-panel { grid-template-columns: 1fr !important; }
  .gpds2-guide-card .gpdw2-stage {
    height: clamp(330px, 88vw, 520px) !important;
    min-height: 330px !important;
  }
}

/* Common Causes: stack earlier and present the active explanation as a strong visual story. */
@media (max-width: 1160px) {
  .gpds2-cause-layout-v24 { grid-template-columns: 1fr !important; }
  .gpds2-cause-layout-v24 .gpds2-cause-buttons {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .gpds2-cause-tabs-card { min-height: 0 !important; }
}
.gpds2-cause-panel { overflow: hidden !important; }
.gpds2-cause-hero-media .gpds2-media--cause img {
  object-position: var(--gpds2-img-pos, 50% 24%) !important;
}
.gpds2-cause-copy > p {
  font-size: clamp(1.02rem, 1.12vw, 1.18rem) !important;
  line-height: 1.72 !important;
}
.gpds2-cause-signals span,
.gpds2-cause-copy .gpds2-linkchips a { white-space: normal !important; }
@media (max-width: 680px) {
  .gpds2-cause-layout-v24 .gpds2-cause-buttons { grid-template-columns: 1fr !important; }
  .gpds2-cause-copy { padding: 22px !important; }
  .gpds2-cause-copy h3 { font-size: clamp(1.52rem, 9vw, 2.3rem) !important; }
}

/* Controlled Visit: remove the skinny third-column trap. Number becomes a badge, photo and copy get real room. */
.gpds2-controlled-step {
  position: relative;
  grid-template-columns: minmax(210px, .58fr) minmax(0, 1fr) !important;
  gap: clamp(16px, 2.2vw, 26px) !important;
  align-items: stretch !important;
  padding: clamp(14px, 1.6vw, 20px) !important;
}
.gpds2-controlled-step .gpds2-step-number {
  position: absolute;
  left: 18px;
  top: 18px;
  z-index: 5;
  box-shadow: 0 14px 34px rgba(0,0,0,.38), 0 0 0 5px rgba(12,10,8,.62);
}
.gpds2-controlled-step .gpds2-media--controlled-step {
  min-height: clamp(155px, 17vw, 240px) !important;
  height: 100% !important;
}
.gpds2-controlled-step-copy {
  padding: clamp(14px, 2vw, 24px) clamp(14px, 2.4vw, 30px) !important;
  align-self: center !important;
}
.gpds2-controlled-step-copy h3 {
  font-size: clamp(1.28rem, 1.95vw, 2rem) !important;
  line-height: 1.04 !important;
}
.gpds2-controlled-step-copy p {
  font-size: clamp(1rem, 1.08vw, 1.1rem) !important;
  line-height: 1.66 !important;
  max-width: 62ch !important;
}
@media (max-width: 1180px) {
  .gpds2-controlled-feature {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
  }
  .gpds2-controlled-feature-media .gpds2-media--controlled-feature {
    border-radius: 26px 26px 0 0 !important;
    border-width: 0 0 1px !important;
    min-height: clamp(300px, 43vw, 480px) !important;
    aspect-ratio: 16 / 10 !important;
  }
}
@media (max-width: 820px) {
  .gpds2-controlled-step { grid-template-columns: 1fr !important; }
  .gpds2-controlled-step .gpds2-step-number {
    position: relative;
    left: auto;
    top: auto;
    justify-self: start !important;
    margin: 0 0 0 4px !important;
    box-shadow: 0 12px 28px rgba(0,0,0,.32);
  }
  .gpds2-controlled-step .gpds2-media--controlled-step {
    min-height: clamp(220px, 58vw, 360px) !important;
    width: 100% !important;
  }
  .gpds2-controlled-step-copy { padding: 0 8px 14px !important; }
}

/* Pricing and final CTAs: guarantee contrast after theme/button inheritance. */
.gpds2-price-card .gpds2-actions .gpds2-btn,
.gpds2-final-card .gpds2-actions .gpds2-btn { min-width: min(100%, 188px); }
.gpds2-btn--gold,
.gpds2-btn--gold span { color: #090807 !important; }
.gpds2-btn--red,
.gpds2-btn--red span { color: #fff7ec !important; }
.gpds2-btn--ghost,
.gpds2-btn--ghost span { color: #fff7ec !important; }
.gpds2-btn--ghost:hover,
.gpds2-btn--ghost:hover span { color: var(--gpds2-gold-light) !important; }

/* Next page route cards and FAQ: keep the close strong and avoid bottom-page dead space. */
.gpds2-next-grid { align-items: stretch; }
.gpds2-next-card { grid-template-rows: auto 1fr; }
.gpds2-next-card .gpds2-media--location { min-height: clamp(230px, 20vw, 340px) !important; }
.gpds2-route-index-group { min-height: 100%; }
.gpds2-faq-grid { grid-template-columns: minmax(260px, .34fr) minmax(0, 1fr); }
@media (max-width: 980px) {
  .gpds2-faq-grid { grid-template-columns: 1fr !important; }
  .gpds2-section-head--side { max-width: 760px; }
}

/* Image treatment: real photos only, no placeholder-looking empty panels. */
.gpds2-media:not(.is-fallback-photo)::after { content: none !important; }
.gpds2-media img[src=""],
.gpds2-media img:not([src]) { display: none !important; }

@media (max-width: 420px) {
  .gpds2-page h1 { font-size: clamp(2.16rem, 13vw, 3.05rem) !important; }
  .gpds2-page h2 { font-size: clamp(1.78rem, 10vw, 2.42rem) !important; }
  .gpds2-trust-row span,
  .gpds2-guide-points span,
  .gpds2-mini-grid span { width: 100%; justify-content: center; }
}
