/* LeadG2 Report Hero (2026) — scoped to .lg2-rh */
.lg2-rh { position: relative; overflow: hidden; padding: 54px 44px 88px; font-family: 'Mulish', system-ui, -apple-system, sans-serif; }
.lg2-rh * { box-sizing: border-box; }
.lg2-rh__grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px); background-size: 54px 54px; -webkit-mask-image: radial-gradient(78% 70% at 30% 22%, #000 0%, transparent 76%); mask-image: radial-gradient(78% 70% at 30% 22%, #000 0%, transparent 76%); }
.lg2-rh__glow { position: absolute; top: -120px; right: -50px; width: 440px; height: 440px; border-radius: 50%; opacity: 0.24; filter: blur(22px); pointer-events: none; }
.lg2-rh__wrap { position: relative; max-width: 1240px; margin: 0 auto; }
.lg2-rh__crumbs { display: flex; align-items: center; gap: 9px; margin-bottom: 28px; font-size: 13px; font-weight: 600; color: #9DA6B5; }
.lg2-rh__sep { opacity: .5; }
.lg2-rh__cols { display: grid; grid-template-columns: 1.08fr 0.92fr; gap: 52px; align-items: center; }
.lg2-rh__badge { display: inline-flex; align-items: center; gap: 9px; padding: 7px 15px 7px 8px; border-radius: 999px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); margin-bottom: 24px; color: #E6E9EF; font-size: 13px; font-weight: 700; }
.lg2-rh__badge-ic { display: inline-flex; width: 20px; height: 20px; border-radius: 6px; align-items: center; justify-content: center; color: #fff; font-size: 11px; }
.lg2-rh__kicker { margin: 0 0 14px; font-weight: 700; font-size: 15px; line-height: 1.4; color: #9DA6B5; max-width: 520px; }
.lg2-rh__title { margin: 0 0 22px; font-weight: 800; font-size: clamp(38px, 4.8vw, 64px); line-height: 1.03; letter-spacing: -2px; color: #fff; }
.lg2-rh__lede { margin: 0 0 32px; max-width: 520px; font-family: 'Lora', Georgia, serif; font-size: 19px; line-height: 1.62; color: #AEB6C4; }
.lg2-rh__lede p { margin: 0; }
.lg2-rh__ctas { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.lg2-rh__btn { display: inline-flex; align-items: center; gap: 9px; padding: 15px 28px; border-radius: 11px; font-weight: 700; font-size: 16px; text-decoration: none; transition: transform .25s ease, filter .25s ease; }
.lg2-rh__btn--primary { color: #fff; box-shadow: 0 14px 34px -10px rgba(225,114,38,0.6); }
.lg2-rh__btn--primary:hover { transform: translateY(-3px); filter: brightness(1.06); }
.lg2-rh__btn--ghost { background: rgba(255,255,255,0.06); color: #fff; border: 1px solid rgba(255,255,255,0.16); }
.lg2-rh__btn--ghost:hover { background: rgba(255,255,255,0.12); }
.lg2-rh__btn-ic { font-size: 18px; }
.lg2-rh__card { position: relative; border-radius: 22px; border: 1px solid rgba(255,255,255,0.09); padding: 30px; box-shadow: 0 44px 90px -34px rgba(0,0,0,0.7); }
.lg2-rh__card-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 22px; }
.lg2-rh__card-title { font-weight: 800; font-size: 16px; color: #fff; }
.lg2-rh__card-dots { color: #5C6675; font-size: 18px; }
.lg2-rh__stat { display: flex; align-items: center; gap: 14px; padding: 14px 0; border-top: 1px solid rgba(255,255,255,0.08); }
.lg2-rh__ring { flex: 0 0 auto; display: inline-flex; width: 52px; height: 52px; border-radius: 50%; border: 3px solid; align-items: center; justify-content: center; font-weight: 800; font-size: 14px; }
.lg2-rh__stat-text { font-weight: 600; font-size: 14px; line-height: 1.4; color: #C2C8D4; }

@keyframes lg2-rh-drift { 0%, 100% { transform: translate(0, 0); } 50% { transform: translate(28px, -22px); } }
@keyframes lg2-rh-float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
@keyframes lg2-rh-rise { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: no-preference) {
  @supports (animation-timeline: view()) {
    .lg2-rh--anim .lg2-rh__rise { animation: lg2-rh-rise linear both; animation-timeline: view(); animation-range: entry 0% entry 36%; }
  }
}

@media (max-width: 940px) {
  .lg2-rh { padding: 40px 28px 64px; }
  .lg2-rh__cols { grid-template-columns: 1fr; gap: 34px; }
}
@media (max-width: 560px) {
  .lg2-rh { padding: 32px 20px 48px; }
  .lg2-rh__btn { width: 100%; justify-content: center; }
}
@media (prefers-reduced-motion: reduce) {
  .lg2-rh__glow, .lg2-rh__card { animation: none !important; }
  .lg2-rh__btn { transition: none; }
}
