/* Reusable page components, matched to the energy of the AI/GHL pages. Prefix: zh-p-
   Brand vars come from global.css :root. */

.zh-p {
  --zh-orange: #fc9500;
  --zh-orange-text: #9a5200;
  --zh-orange-lt: #ffb84d;
  --zh-orange-hover: #e08600;
  --zh-blue: #3390ff;
  --zh-blue-lt: #66b3ff;
  --zh-navy: #1f2c3f;
  --zh-deep: #141e2a;
  --zh-card-bd: #e4e8ee;
  font-family: "Inter", "Inter Fallback", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  color: #1a2230;
}
.zh-p * { box-sizing: border-box; }
.zh-p-wrap { overflow-x: hidden; }
.zh-p-in { max-width: 1080px; margin: 0 auto; padding: 0 1.5rem; position: relative; z-index: 1; }
.zh-p-in--narrow { max-width: 760px; }

/* ---- buttons ---- */
.zh-p-btn, .zh-p-btn-ghost, .zh-p-btn-white {
  display: inline-flex; align-items: center; gap: 0.5rem; position: relative;
  font-weight: 700; font-size: 0.97rem; line-height: 1;
  padding: 0.95rem 2rem; border-radius: 100px; text-decoration: none;
  transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}
.zh-p-btn { background: var(--zh-orange); color: #1a1a1a; }
.zh-p-btn::after {
  content: ""; position: absolute; inset: 0; border-radius: inherit;
  border: 2px solid rgba(252,149,0,0.6); pointer-events: none;
  animation: zhPPulseRing 2.2s ease-out infinite;
}
.zh-p-btn:hover { background: var(--zh-orange-hover); transform: translateY(-2px); color: #1a1a1a; box-shadow: 0 8px 32px rgba(252,149,0,0.42); }
.zh-p-btn-ghost { background: transparent; color: rgba(255,255,255,0.82); border: 1.5px solid rgba(255,255,255,0.25); font-weight: 600; }
.zh-p-btn-ghost:hover { border-color: rgba(252,149,0,0.55); color: var(--zh-orange); transform: translateY(-2px); }
.zh-p-btn-white { background: #fff; color: var(--zh-orange-text); font-weight: 800; }
.zh-p-btn-white:hover { transform: translateY(-2px); box-shadow: 0 8px 32px rgba(0,0,0,0.18); }
.zh-p-btns { display: flex; flex-wrap: wrap; gap: 0.85rem; }

/* ---- generic section ---- */
.zh-p-sec { padding: 5.5rem 0; position: relative; }
.zh-p-sec--dark { background: var(--zh-navy); color: #fff; }
.zh-p-sec--deep { background: var(--zh-deep); color: #fff; }
.zh-p-sec--light { background: #fafcfc; }
.zh-p-eyebrow {
  display: inline-block; font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.13em; text-transform: uppercase; color: var(--zh-orange-text);
  background: rgba(252,149,0,0.1); border: 1px solid rgba(252,149,0,0.3);
  padding: 0.4rem 0.85rem; border-radius: 100px; margin-bottom: 1.1rem;
}
.zh-p-sec--dark .zh-p-eyebrow, .zh-p-sec--deep .zh-p-eyebrow, .zh-p-hero .zh-p-eyebrow {
  color: #fcb84a; background: rgba(252,149,0,0.12); border-color: rgba(252,149,0,0.35);
}
.zh-p-h2 {
  font-family: "Montserrat", "Montserrat Fallback", "Inter", sans-serif;
  font-size: clamp(1.8rem, 3.6vw, 2.6rem); font-weight: 800;
  letter-spacing: -0.025em; line-height: 1.12; margin: 0 0 1rem;
}
.zh-p-lead { font-size: 1.04rem; line-height: 1.8; max-width: 62ch; color: #556070; }
.zh-p-sec--dark .zh-p-lead, .zh-p-sec--deep .zh-p-lead { color: rgba(255,255,255,0.6); }

/* ---- hero ---- */
.zh-p-hero {
  background: var(--zh-navy); color: #fff; position: relative; overflow: hidden;
  padding: 7rem 0 6rem;
  background-image: radial-gradient(rgba(255,255,255,0.065) 1px, transparent 1px);
  background-size: 30px 30px;
}
.zh-p-hero::before {
  content: ""; position: absolute; top: -80px; left: 50%;
  transform: translate(-50%, -55%); width: 1100px; height: 800px; pointer-events: none;
  background: radial-gradient(ellipse at center, rgba(252,149,0,0.17) 0%, transparent 60%);
}
.zh-p-hero::after {
  content: ""; position: absolute; top: 28%; right: -120px; width: 650px; height: 500px; pointer-events: none;
  background: radial-gradient(ellipse, rgba(51,144,255,0.09) 0%, transparent 65%);
}
.zh-p-watermark {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  font-family: "Montserrat", "Montserrat Fallback", sans-serif; font-size: 22vw; font-weight: 900; color: #fff;
  opacity: 0.022; pointer-events: none; user-select: none; white-space: nowrap; z-index: 0;
}
.zh-p-particles { position: absolute; inset: 0; overflow: hidden; pointer-events: none; z-index: 0; }
.zh-p-particle { position: absolute; border-radius: 50%; opacity: 0; animation: zhPFloat linear infinite; }
/* subtle full-hero light pass, behind the text, exits off the right edge */
.zh-p-particles::before {
  content: ""; position: absolute; top: -20%; bottom: -20%; left: 0; width: 180px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.07), transparent);
  transform: translateX(-200px) skewX(-18deg); will-change: transform;
  animation: zhPHeroSweep 7s ease-in-out infinite;
}
.zh-p-h1 {
  font-family: "Montserrat", "Montserrat Fallback", "Inter", sans-serif;
  font-size: clamp(2.3rem, 5.3vw, 4rem); font-weight: 900;
  letter-spacing: -0.03em; line-height: 1.08; margin: 0 0 1.2rem; max-width: 20ch;
  animation: zhPFadeup 0.6s 0.1s ease both;
}
.zh-p-h1 em {
  font-style: normal;
  background: linear-gradient(90deg, #fc9500 0%, #ffcf6b 40%, #fc9500 70%, #ffb83f 100%);
  background-size: 200% auto; background-position: 0% center;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  animation: zhPFlow 6s linear infinite;
}
.zh-p-hero .zh-p-eyebrow { animation: zhPFadeup 0.6s ease both; }
.zh-p-hero .zh-p-lead { color: rgba(255,255,255,0.66); margin-bottom: 1.7rem; animation: zhPFadeup 0.7s 0.25s ease both; }
.zh-p-hero .zh-p-btns { animation: zhPFadeup 0.6s 0.35s ease both; }

/* ---- trust strip ---- */
.zh-p-trust {
  display: flex; align-items: center; gap: 0.55rem; flex-wrap: wrap;
  margin-top: 1.7rem; font-size: 0.85rem; color: rgba(255,255,255,0.6); letter-spacing: 0.02em;
  animation: zhPFadeup 0.6s 0.45s ease both;
}
.zh-p-stars { color: rgba(252,149,0,0.85); letter-spacing: 1px; }

/* ---- card grids ---- */
.zh-p-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; margin-top: 2.6rem; }
.zh-p-grid--2 { grid-template-columns: repeat(2, 1fr); }
.zh-p-card {
  border-radius: 14px; padding: 1.6rem 1.5rem; position: relative; overflow: hidden;
  background: #fff; border: 1px solid var(--zh-card-bd);
  transition: box-shadow 0.25s ease, border-color 0.25s ease, transform 0.25s ease;
}
.zh-p-card::after {
  content: ""; position: absolute; bottom: 0; left: 0; height: 2px; width: 0;
  background: linear-gradient(90deg, var(--zh-orange), var(--zh-blue)); transition: width 0.4s ease;
}
.zh-p-card:hover { box-shadow: 0 12px 40px rgba(31,44,63,0.12); border-color: rgba(252,149,0,0.3); transform: translateY(-4px); }
.zh-p-card:hover::after { width: 100%; }
.zh-p-sec--dark .zh-p-card, .zh-p-sec--deep .zh-p-card {
  background: #1a2f48; border-color: rgba(255,255,255,0.08); color: #fff;
}
.zh-p-card-k { font-size: 0.7rem; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--zh-orange-text); }
.zh-p-card h3 { font-family: "Montserrat", "Montserrat Fallback", sans-serif; font-size: 1.08rem; font-weight: 800; margin: 0.55rem 0 0.5rem; letter-spacing: -0.01em; }
.zh-p-card p { font-size: 0.91rem; line-height: 1.65; margin: 0; color: #667; }
.zh-p-sec--dark .zh-p-card p, .zh-p-sec--deep .zh-p-card p { color: rgba(255,255,255,0.6); }
.zh-p-sec--dark .zh-p-card-k, .zh-p-sec--deep .zh-p-card-k, .zh-p-sec--dark .zh-p-stat b, .zh-p-sec--deep .zh-p-stat b { color: #fcb84a; }

/* ---- proof strip ---- */
.zh-p-proof { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; margin-top: 2.6rem; }
.zh-p-stat { text-align: center; padding: 0.5rem; }
.zh-p-stat b {
  display: inline-block; font-family: "Courier New", Courier, monospace;
  font-size: clamp(2rem, 4vw, 2.9rem); font-weight: 900; color: var(--zh-orange-text);
  letter-spacing: -0.02em; line-height: 1;
}
.zh-p-sec--dark .zh-p-stat b { text-shadow: 0 0 24px rgba(252,149,0,0.5), 0 0 48px rgba(252,149,0,0.2); }
.zh-p-stat b::after { content: ""; display: block; width: 32px; height: 2px; background: linear-gradient(90deg, var(--zh-orange), transparent); margin: 8px auto 0; border-radius: 2px; }
.zh-p-stat span { display: block; margin-top: 0.7rem; font-size: 0.85rem; color: #777; line-height: 1.5; }
.zh-p-sec--dark .zh-p-stat span { color: rgba(255,255,255,0.55); }

/* ---- process steps ---- */
.zh-p-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; margin-top: 2.6rem; }
.zh-p-step b { display: block; font-family: "Courier New", monospace; font-size: 1.5rem; color: var(--zh-orange-text); font-weight: 900; }
.zh-p-step h3 { font-family: "Montserrat", "Montserrat Fallback", sans-serif; font-size: 1rem; margin: 0.5rem 0; font-weight: 800; }
.zh-p-step p { font-size: 0.9rem; line-height: 1.6; color: #667; margin: 0; }
.zh-p-sec--dark .zh-p-step p { color: rgba(255,255,255,0.6); }

/* ---- testimonials ---- */
.zh-p-quotes { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.25rem; margin-top: 2.6rem; }
.zh-p-quote { margin: 0; background: #fff; border: 1px solid var(--zh-card-bd); border-radius: 14px; padding: 1.7rem 1.6rem; transition: box-shadow 0.25s ease, transform 0.25s ease; }
.zh-p-quote:hover { box-shadow: 0 12px 40px rgba(31,44,63,0.1); transform: translateY(-3px); }
.zh-p-quote .zh-p-stars { color: var(--zh-orange-text); letter-spacing: 1px; font-size: 0.95rem; }
.zh-p-quote blockquote { margin: 0.7rem 0 0.9rem; font-size: 1.02rem; line-height: 1.6; color: #1a2230; }
.zh-p-quote figcaption { font-size: 0.85rem; color: #5a5a5a; font-weight: 700; }

/* ---- FAQ (real, visible, NOT an accordion) ---- */
.zh-p-faq { margin-top: 2rem; }
.zh-p-faq-item { padding: 1.5rem 0; border-top: 1px solid #e6e9ee; }
.zh-p-faq-item:first-child { border-top: none; }
.zh-p-faq-q { font-family: "Montserrat", "Montserrat Fallback", sans-serif; font-size: 1.1rem; font-weight: 800; margin: 0 0 0.55rem; color: var(--zh-navy); letter-spacing: -0.01em; }
.zh-p-faq-a { font-size: 0.98rem; line-height: 1.75; margin: 0; color: #4a5564; max-width: 72ch; }
/* FAQ on dark sections */
.zh-p-sec--dark .zh-p-faq-q, .zh-p-sec--deep .zh-p-faq-q { color: #fff; }
.zh-p-sec--dark .zh-p-faq-a, .zh-p-sec--deep .zh-p-faq-a { color: rgba(255,255,255,0.68); }
.zh-p-sec--dark .zh-p-faq-item, .zh-p-sec--deep .zh-p-faq-item { border-top-color: rgba(255,255,255,0.1); border-bottom-color: rgba(255,255,255,0.1); }

/* ---- internal link cluster ---- */
.zh-p-links { display: flex; flex-wrap: wrap; gap: 0.6rem; margin-top: 1.7rem; }
.zh-p-links a {
  font-size: 0.9rem; font-weight: 600; text-decoration: none; color: var(--zh-navy);
  background: #eef2f6; padding: 0.55rem 1rem; border-radius: 100px;
  transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}
.zh-p-links a:hover { background: var(--zh-orange); color: #fff; transform: translateY(-1px); }

/* ---- CTA banner ---- */
.zh-p-cta { background: var(--zh-navy); color: #fff; text-align: center; padding: 5rem 0; position: relative; overflow: hidden; background-image: radial-gradient(rgba(255,255,255,0.05) 1px, transparent 1px); background-size: 30px 30px; }
.zh-p-cta::before { content: ""; position: absolute; top: -40%; left: 50%; transform: translateX(-50%); width: 900px; height: 600px; background: radial-gradient(ellipse at center, rgba(252,149,0,0.16) 0%, transparent 60%); pointer-events: none; }
.zh-p-cta .zh-p-h2 { color: #fff; }
.zh-p-cta p { font-size: 1.05rem; margin: 0 auto 1.7rem; color: rgba(255,255,255,0.7); max-width: 56ch; }
.zh-p-cta .zh-p-btns { justify-content: center; }
.zh-p-note { font-size: 0.85rem; color: rgba(255,255,255,0.45); margin-top: 1.1rem; }

/* ---- keyframes ---- */
@keyframes zhPFadeup { from { opacity: 0; transform: translateY(22px); } to { opacity: 1; transform: none; } }
@keyframes zhPHeroSweep { 0% { transform: translateX(-200px) skewX(-18deg); opacity: 0; } 15% { opacity: 1; } 50% { opacity: 1; } 65% { transform: translateX(110vw) skewX(-18deg); opacity: 0; } 100% { transform: translateX(110vw) skewX(-18deg); opacity: 0; } }
@keyframes zhPFlow { to { background-position: 200% center; } }
@keyframes zhPPulseRing { 0% { transform: scale(1); opacity: 0.8; } 70% { transform: scale(1.08); opacity: 0; } 100% { transform: scale(1.08); opacity: 0; } }
@keyframes zhPFloat { 0% { transform: translateY(100%) translateX(0); opacity: 0; } 10% { opacity: 1; } 90% { opacity: 0.6; } 100% { transform: translateY(-100px) translateX(30px); opacity: 0; } }
@keyframes zhPGrow { from { height: 6%; } }
@keyframes zhPLive { 0% { box-shadow: 0 0 0 0 rgba(34,197,94,0.5); } 70% { box-shadow: 0 0 0 6px rgba(34,197,94,0); } 100% { box-shadow: 0 0 0 0 rgba(34,197,94,0); } }

/* ---- live dashboard panel ---- */
.zh-p-dash {
  margin-top: 2.6rem; background: #16273c; border: 1px solid rgba(255,255,255,0.09);
  border-radius: 16px; padding: 1.6rem; box-shadow: 0 24px 60px rgba(0,0,0,0.35);
}
.zh-p-dash-head {
  display: flex; align-items: center; gap: 0.7rem; font-size: 0.76rem; font-weight: 800;
  color: rgba(255,255,255,0.55); text-transform: uppercase; letter-spacing: 0.1em;
  padding-bottom: 1.1rem; margin-bottom: 1.3rem; border-bottom: 1px solid rgba(255,255,255,0.07);
}
.zh-p-live { display: inline-flex; align-items: center; gap: 0.45rem; color: #22c55e; }
.zh-p-live i { width: 8px; height: 8px; border-radius: 50%; background: #22c55e; animation: zhPLive 1.8s ease-out infinite; }
.zh-p-dash-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-bottom: 1.5rem; }
.zh-p-tile { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.07); border-radius: 10px; padding: 1.05rem; }
.zh-p-tile span { display: block; font-size: 0.68rem; color: rgba(255,255,255,0.42); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 0.5rem; }
.zh-p-tile b { font-family: "Courier New", monospace; font-size: 1.7rem; font-weight: 900; color: #fc9500; }
.zh-p-bars { display: flex; align-items: flex-end; gap: 0.5rem; height: 130px; }
.zh-p-bar { flex: 1; background: linear-gradient(180deg, #fc9500, rgba(252,149,0,0.25)); border-radius: 4px 4px 0 0; height: var(--h); animation: zhPGrow 1.2s cubic-bezier(0.2,0.8,0.2,1) both; }
.zh-p-bar:last-child { background: linear-gradient(180deg, #ffcf6b, rgba(252,149,0,0.4)); box-shadow: 0 0 18px rgba(252,149,0,0.4); }
.zh-p-bars-label { font-size: 0.74rem; color: rgba(255,255,255,0.4); margin-top: 0.8rem; text-align: center; letter-spacing: 0.04em; }

@media (prefers-reduced-motion: reduce) {
  .zh-p-btn::after, .zh-p-particles::before, .zh-p-h1 em, .zh-p-particle,
  .zh-p-bar, .zh-p-live i { animation: none; }
  .zh-p-h1 em { background-position: 0% center; }
}

/* ---- responsive ---- */
@media (max-width: 860px) {
  .zh-p-grid, .zh-p-grid--2, .zh-p-proof, .zh-p-quotes { grid-template-columns: 1fr 1fr; }
  .zh-p-steps { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .zh-p-sec { padding: 3.8rem 0; }
  .zh-p-hero { padding: 4.5rem 0 3.8rem; }
  .zh-p-watermark { font-size: 34vw; }
  .zh-p-grid, .zh-p-grid--2, .zh-p-proof, .zh-p-quotes, .zh-p-steps { grid-template-columns: 1fr; }
}

/* ===================================================================
   PER-TRADE FLAVOR  (distinct color + ambient glow + line-art emblem)
   Applied via body class zh-trade-<trade> from the page's `trade` var.
   =================================================================== */
.zh-trade-flooring      { --zh-flavor: #e0a458; --zh-glow: rgba(224,164,88,0.14); }
.zh-trade-painting      { --zh-flavor: #3fb6f0; --zh-glow: rgba(63,182,240,0.13); }
.zh-trade-pest-control  { --zh-flavor: #37c98a; --zh-glow: rgba(55,201,138,0.13); }
.zh-trade-cleaning      { --zh-flavor: #5cb8f7; --zh-glow: rgba(92,184,247,0.13); }
.zh-trade-moving        { --zh-flavor: #9b8cff; --zh-glow: rgba(155,140,255,0.14); }

/* hero ambient glow takes the trade color */
[class*="zh-trade-"] .zh-p-hero::after {
  background: radial-gradient(ellipse, var(--zh-glow) 0%, transparent 65%);
}

/* flavor accents on the dashboard + stat underline */
[class*="zh-trade-"] .zh-p-live i { background: var(--zh-flavor); box-shadow: 0 0 0 0 var(--zh-glow); }
[class*="zh-trade-"] .zh-p-bar:last-child { background: linear-gradient(180deg, var(--zh-flavor), rgba(252,149,0,0.15)); box-shadow: 0 0 18px var(--zh-glow); }
[class*="zh-trade-"] .zh-p-stat b::after { background: linear-gradient(90deg, var(--zh-flavor), transparent); }
[class*="zh-trade-"] .zh-p-links a:hover { background: var(--zh-flavor); }

/* ===================================================================
   ALTERNATE LAYOUT COMPONENTS  (for genuinely different page structures)
   =================================================================== */
/* left-aligned hero variant */
.zh-p-hero--left .zh-p-h1, .zh-p-hero--left .zh-p-lead { margin-left: 0; }

/* full-width stat band */
.zh-p-band { background: var(--zh-deep); color: #fff; padding: 2.4rem 0; }
.zh-p-band-in { max-width: 1080px; margin: 0 auto; padding: 0 1.5rem; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.zh-p-bandi { text-align: center; padding: 0.4rem 1rem; border-right: 1px solid rgba(255,255,255,0.1); }
.zh-p-bandi:last-child { border-right: none; }
.zh-p-bandi b { display: block; font-family: "Courier New", monospace; font-size: clamp(1.5rem, 3.4vw, 2.3rem); font-weight: 900; color: var(--zh-flavor, var(--zh-orange)); letter-spacing: -0.02em; }
.zh-p-bandi span { font-size: 0.76rem; color: rgba(255,255,255,0.55); text-transform: uppercase; letter-spacing: 0.06em; }

/* zig-zag two-column split */
.zh-p-split { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 3rem; align-items: center; }
.zh-p-split--rev .zh-p-split-media { order: -1; }
.zh-p-split-text h2 { margin-top: 0; }
.zh-p-panel { border-radius: 16px; padding: 2rem; border: 1px solid var(--zh-card-bd); background: #fff; box-shadow: 0 10px 36px rgba(31,44,63,0.08); }
.zh-p-sec--dark .zh-p-panel, .zh-p-sec--deep .zh-p-panel { background: #16273c; border-color: rgba(255,255,255,0.08); }
.zh-p-panel-big { font-family: "Courier New", monospace; font-size: clamp(2.4rem, 6vw, 3.6rem); font-weight: 900; color: var(--zh-flavor, var(--zh-orange)); line-height: 1; letter-spacing: -0.03em; }
.zh-p-panel-lab { font-size: 0.95rem; color: #667; margin-top: 0.5rem; }
.zh-p-sec--dark .zh-p-panel-lab, .zh-p-sec--deep .zh-p-panel-lab { color: rgba(255,255,255,0.6); }
.zh-p-panel ul { list-style: none; margin: 1rem 0 0; padding: 0; }
.zh-p-panel li { padding: 0.55rem 0 0.55rem 1.7rem; position: relative; font-size: 0.96rem; border-top: 1px solid rgba(127,127,127,0.12); }
.zh-p-panel li:first-child { border-top: none; }
.zh-p-panel li::before { content: ""; position: absolute; left: 0; top: 0.95rem; width: 9px; height: 9px; border-radius: 50%; background: var(--zh-flavor, var(--zh-orange)); }

/* comparison: them vs you */
.zh-p-vs { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; margin-top: 2.6rem; }
.zh-p-vs-col { border-radius: 14px; padding: 1.7rem; }
.zh-p-vs-bad { background: #fff; border: 1px solid #ecd9d9; }
.zh-p-vs-good { background: #16273c; color: #fff; border: 1px solid rgba(252,149,0,0.4); }
.zh-p-vs-col h3 { font-family: "Montserrat", "Montserrat Fallback", sans-serif; font-size: 1.05rem; margin: 0 0 1rem; }
.zh-p-vs-col ul { list-style: none; margin: 0; padding: 0; }
.zh-p-vs-col li { padding: 0.5rem 0 0.5rem 1.8rem; position: relative; font-size: 0.95rem; }
.zh-p-vs-bad li::before { content: "\2715"; position: absolute; left: 0; color: #c0564f; font-weight: 700; }
.zh-p-vs-good li::before { content: "\2713"; position: absolute; left: 0; color: var(--zh-flavor, var(--zh-orange)); font-weight: 700; }

/* big pull-quote testimonial */
.zh-p-pull { max-width: 820px; margin: 0 auto; text-align: center; }
.zh-p-pull blockquote { font-family: "Montserrat", "Montserrat Fallback", sans-serif; font-size: clamp(1.3rem, 2.6vw, 1.8rem); font-weight: 700; line-height: 1.4; letter-spacing: -0.01em; margin: 1rem 0; }
.zh-p-pull .zh-p-stars { font-size: 1.2rem; }
.zh-p-pull figcaption { color: #5a5a5a; font-weight: 600; font-size: 0.92rem; }
.zh-p-sec--dark .zh-p-pull figcaption, .zh-p-sec--deep .zh-p-pull figcaption { color: rgba(255,255,255,0.55); }

/* two-column FAQ */
.zh-p-faq2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0.5rem 3rem; margin-top: 2rem; }
.zh-p-faq2 .zh-p-faq-item { border-top: none; border-bottom: 1px solid #e6e9ee; }

@media (max-width: 860px) {
  .zh-p-band-in { grid-template-columns: 1fr 1fr; gap: 1.5rem 1rem; }
  .zh-p-bandi { border-right: none; }
  .zh-p-split, .zh-p-vs, .zh-p-faq2 { grid-template-columns: 1fr; gap: 1.5rem; }
  .zh-p-split--rev .zh-p-split-media { order: 0; }
}

/* ─── Brainz authority card ─── */
.zh-p-authority {
  display: flex;
  align-items: center;
  gap: 1.85rem;
  margin-top: 2.75rem;
  padding: 1.85rem 2rem;
  background: #fff;
  border: 1px solid #e4e9f0;
  border-radius: 16px;
  box-shadow: 0 6px 24px rgba(31, 44, 63, 0.05);
}
.zh-p-authority-logo {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #1f2c3f;
  border-radius: 12px;
  padding: 1.1rem 1.4rem;
}
.zh-p-authority-logo img { display: block; height: 40px; width: auto; }
.zh-p-authority-body p {
  margin: 0.45rem 0 0.85rem;
  color: #4a5568;
  line-height: 1.7;
  font-size: 0.98rem;
}
.zh-p-authority-link {
  color: var(--zh-orange-text);
  font-weight: 700;
  text-decoration: none;
}
.zh-p-authority-link:hover { text-decoration: underline; }
@media (max-width: 700px) {
  .zh-p-authority { flex-direction: column; align-items: flex-start; gap: 1.25rem; }
}

/* ─── Built on GoHighLevel band ─── */
.zh-p-builton {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 2.75rem;
  align-items: center;
}
.zh-p-builton-logo img { display: block; width: 210px; max-width: 100%; height: auto; }
.zh-p-builton-body .zh-p-h2 { margin: 0.3rem 0 0.75rem; }
.zh-p-builton-body a {
  color: var(--zh-orange);
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
}
.zh-p-builton-body a:hover { text-decoration: underline; }
@media (max-width: 820px) {
  .zh-p-builton { grid-template-columns: 1fr; gap: 1.5rem; }
  .zh-p-builton-body a { white-space: normal; }
}
