/* ============================================================
   Home Plumbing Whole Home Repipe Widget v2 — frontend.css
   All styles scoped under .hprw-wrap to prevent conflicts.
   ============================================================ */

/* ---------- CSS Variables ---------- */
.hprw-wrap {
	--hprw-primary:    #34373e;
	--hprw-secondary:  #88898d;
	--hprw-light:      #ffffff;
	--hprw-accent:     #4a4e58;
	--hprw-bg:         #f4f5f7;
	--hprw-bg-alt:     #eaebee;
	--hprw-text:       #222222;
	--hprw-muted:      #555555;
	--hprw-font-main:    'Inter', 'Segoe UI', sans-serif;
	--hprw-font-display: 'Outfit', 'Inter', sans-serif;
	--hprw-radius-sm: 10px;
	--hprw-radius-md: 20px;
	--hprw-radius-lg: 32px;
	--hprw-shadow-1:   0 2px 8px rgba(52,55,62,.08), 0 1px 3px rgba(52,55,62,.06);
	--hprw-shadow-2:   0 8px 32px rgba(52,55,62,.12), 0 2px 8px rgba(52,55,62,.08);
	--hprw-shadow-3d:  20px 20px 60px rgba(136,137,141,.15), -20px -20px 60px rgba(255,255,255,.9);
	--hprw-shadow-3dh: 30px 30px 80px rgba(136,137,141,.22), -30px -30px 80px rgba(255,255,255,1);
	--hprw-trans-fast:   all .2s cubic-bezier(.25,.8,.25,1);
	--hprw-trans-normal: all .35s cubic-bezier(.25,.8,.25,1);
	font-family: var(--hprw-font-main);
	color: var(--hprw-text);
	line-height: 1.7;
	overflow-x: clip;
}

/* ---------- Reset inside wrap ---------- */
.hprw-wrap *, .hprw-wrap *::before, .hprw-wrap *::after { box-sizing: border-box; margin: 0; padding: 0; }
.hprw-wrap ul { list-style: none; }
.hprw-wrap h1, .hprw-wrap h2, .hprw-wrap h3, .hprw-wrap h4 { font-family: var(--hprw-font-display); line-height: 1.15; color: var(--hprw-primary); }
.hprw-wrap p { font-size: 1.08rem; color: var(--hprw-muted); margin-bottom: 1.1rem; word-wrap: break-word; overflow-wrap: break-word; }
.hprw-wrap p:last-child { margin-bottom: 0; }

/* ---------- Container ---------- */
.hprw-wrap .hprw-container { max-width: 1160px; margin: 0 auto; width: 100%; }

/* ---------- Section base ---------- */
.hprw-wrap section { padding: 7rem 2rem; position: relative; overflow: hidden; }

/* ---------- Reveal Animations ---------- */
.hprw-wrap .hprw-reveal { opacity: 0; transform: translateY(48px); transition: opacity .75s ease-out, transform .75s ease-out; }
.hprw-wrap .hprw-reveal.active { opacity: 1; transform: translateY(0); }
.hprw-wrap .hprw-reveal-left  { opacity: 0; transform: translateX(-60px); transition: opacity .75s ease-out, transform .75s ease-out; }
.hprw-wrap .hprw-reveal-right { opacity: 0; transform: translateX(60px);  transition: opacity .75s ease-out, transform .75s ease-out; }
.hprw-wrap .hprw-reveal-left.active, .hprw-wrap .hprw-reveal-right.active { opacity: 1; transform: translate(0); }
.hprw-wrap .hprw-d1 { transition-delay: .1s; }
.hprw-wrap .hprw-d2 { transition-delay: .2s; }
.hprw-wrap .hprw-d3 { transition-delay: .3s; }
.hprw-wrap .hprw-d4 { transition-delay: .4s; }
.hprw-wrap .hprw-d5 { transition-delay: .5s; }
.hprw-wrap .hprw-d6 { transition-delay: .6s; }

/* ---------- Section typography helpers ---------- */
.hprw-wrap .hprw-label {
	display: inline-block; font-size: .74rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase;
	color: var(--hprw-secondary); background: rgba(136,137,141,.1); padding: .4rem 1rem; border-radius: 50px;
	margin-bottom: 1.4rem; border: 1px solid rgba(136,137,141,.2);
}
.hprw-wrap .hprw-label.on-dark { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.12); color: rgba(255,255,255,.55); }
.hprw-wrap .hprw-title { font-size: clamp(1.9rem, 3.5vw, 3rem); font-weight: 800; color: var(--hprw-primary); margin-bottom: 1.4rem; line-height: 1.12; }
.hprw-wrap .hprw-title.on-dark { color: var(--hprw-light); }
.hprw-wrap .hprw-intro { font-size: 1.12rem; color: var(--hprw-muted); line-height: 1.8; max-width: 700px; }
.hprw-wrap .hprw-intro.on-dark { color: rgba(255,255,255,.7); }
.hprw-wrap .hprw-divider { width: 56px; height: 4px; border-radius: 2px; background: linear-gradient(90deg, var(--hprw-secondary), var(--hprw-primary)); margin-bottom: 2rem; }
.hprw-wrap .hprw-divider.on-dark { background: linear-gradient(90deg, rgba(255,255,255,.3), rgba(255,255,255,.7)); }
.hprw-wrap .hprw-divider.centered { margin-left: auto; margin-right: auto; }

/* WYSIWYG content typography */
.hprw-wrap .hprw-wysiwyg p { font-size: inherit; color: inherit; margin-bottom: 1rem; }
.hprw-wrap .hprw-wysiwyg p:last-child { margin-bottom: 0; }
.hprw-wrap .hprw-wysiwyg strong { font-weight: 700; }
.hprw-wrap .hprw-wysiwyg em { font-style: italic; }
.hprw-wrap .hprw-wysiwyg br { display: block; content: ""; }
.hprw-wrap .hprw-wysiwyg ul, .hprw-wrap .hprw-wysiwyg ol { margin-left: 1.4rem; margin-bottom: 1rem; }
.hprw-wrap .hprw-wysiwyg li { margin-bottom: .4rem; }

/* ============================================================
   PART 1 — HERO (background image + overlay)
   ============================================================ */
.hprw-wrap .hprw-hero {
	min-height: 100vh; background-color: var(--hprw-primary);
	background-position: center center; background-size: cover; background-repeat: no-repeat;
	display: flex; align-items: center; justify-content: center; padding: 8rem 2rem 6rem;
}
.hprw-wrap .hprw-hero::before {
	content: ''; position: absolute; inset: 0;
	background: linear-gradient(to bottom, rgba(20,22,26,.78) 0%, rgba(20,22,26,.70) 55%, rgba(20,22,26,.85) 100%);
	pointer-events: none;
}
.hprw-wrap .hprw-orb { position: absolute; border-radius: 50%; filter: blur(80px); pointer-events: none; }
.hprw-wrap .hprw-orb-1 { width: 50vw; height: 50vw; top: -15%; right: -10%; background: radial-gradient(circle, rgba(136,137,141,.2) 0%, transparent 70%); animation: hprwDriftOrb 18s ease-in-out infinite; }
.hprw-wrap .hprw-orb-2 { width: 36vw; height: 36vw; bottom: -12%; left: -8%; background: radial-gradient(circle, rgba(74,78,88,.3) 0%, transparent 70%); animation: hprwDriftOrb 24s ease-in-out infinite reverse; }
.hprw-wrap .hprw-gp { position: absolute; border-radius: var(--hprw-radius-md); background: linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02)); border: 1px solid rgba(255,255,255,.08); -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); pointer-events: none; }
.hprw-wrap .hprw-gp-1 { width:260px; height:170px; top:12%; right:7%;  transform:rotate(-11deg); animation:hprwFloat 12s ease-in-out infinite; }
.hprw-wrap .hprw-gp-2 { width:180px; height:120px; bottom:14%; left:5%; transform:rotate(8deg);  animation:hprwFloat 17s ease-in-out infinite reverse; }
.hprw-wrap .hprw-gp-3 { width:120px; height:80px;  top:55%; right:13%; transform:rotate(16deg); animation:hprwFloat 10s ease-in-out infinite 2s; }
.hprw-wrap .hprw-hero-inner { position: relative; z-index: 2; max-width: 900px; text-align: center; }
.hprw-wrap .hprw-eyebrow {
	display: inline-flex; align-items: center; gap: .6rem; background: rgba(255,255,255,.08);
	border: 1px solid rgba(255,255,255,.14); border-radius: 50px; padding: .5rem 1.4rem;
	font-size: .78rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
	color: rgba(255,255,255,.6); margin-bottom: 2.4rem;
}
.hprw-wrap .hprw-eyebrow-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--hprw-secondary); animation: hprwPulse 2s ease-in-out infinite; }
/* Hero title */
.hprw-wrap .hprw-hero .hprw-hero-title { font-family: var(--hprw-font-display); color: var(--hprw-light); font-size: clamp(2.2rem, 4.5vw, 4.4rem); font-weight: 900; letter-spacing: -.03em; line-height: 1.08; margin-bottom: 2.4rem; text-shadow: 0 4px 32px rgba(0,0,0,.5); }
.hprw-wrap .hprw-hero .hprw-hero-title * { color: inherit; font-family: inherit; }
/* Hero symptom lines */
.hprw-wrap .hprw-hero-subhead { max-width: 720px; margin: 0 auto 1.4rem; text-align: center; }
.hprw-wrap .hprw-hero-symptom { color: rgba(255,255,255,.80); font-size: clamp(.98rem, 1.5vw, 1.14rem); font-weight: 400; font-style: italic; line-height: 2; margin-bottom: 0; }
/* Hero verdict */
.hprw-wrap .hprw-hero-verdict { margin: 2rem auto 0; max-width: 620px; text-align: center; }
.hprw-wrap .hprw-hero-verdict p { color: rgba(255,255,255,.55); font-size: clamp(.9rem, 1.3vw, 1.03rem); font-weight: 600; letter-spacing: .06em; text-transform: uppercase; margin-bottom: .3rem; }
/* Hero divider */
.hprw-wrap .hprw-hero-divider { width: 48px; height: 3px; border-radius: 2px; background: linear-gradient(90deg, rgba(255,255,255,.15), rgba(255,255,255,.55), rgba(255,255,255,.15)); margin: 2rem auto; }
/* Hero support */
.hprw-wrap .hprw-hero-support { max-width: 680px; margin: 0 auto; text-align: center; }
.hprw-wrap .hprw-hero-support p { color: rgba(255,255,255,.48); font-size: clamp(.88rem, 1.25vw, 1rem); font-weight: 400; line-height: 1.9; margin-bottom: .6rem; }
.hprw-wrap .hprw-hero-support .support-bold, .hprw-wrap .hprw-hero-support strong { color: rgba(255,255,255,.65); font-weight: 600; letter-spacing: .03em; }
/* Scroll cue */
.hprw-wrap .hprw-scroll-cue { position: absolute; bottom: 2.4rem; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: .3rem; z-index: 2; }
.hprw-wrap .hprw-sc-arr { width: 22px; height: 22px; border-right: 2px solid rgba(255,255,255,.28); border-bottom: 2px solid rgba(255,255,255,.28); transform: rotate(45deg); animation: hprwScrollDown 1.9s ease-in-out infinite; }
.hprw-wrap .hprw-sc-arr:nth-child(2) { animation-delay: .22s; margin-top: -13px; }

/* ============================================================
   PART 2 — BRIDGE (Translation Bridge)
   ============================================================ */
.hprw-wrap .hprw-bridge { background: var(--hprw-bg-alt); padding: 6rem 2rem; }
.hprw-wrap .hprw-bridge-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 5rem; align-items: start; }
.hprw-wrap .hprw-bridge-left { position: sticky; top: 7rem; }
.hprw-wrap .hprw-bridge-badge {
	display: inline-block; font-size: .72rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase;
	color: var(--hprw-secondary); background: rgba(136,137,141,.1); padding: .4rem 1rem;
	border-radius: 50px; margin-bottom: 1.6rem; border: 1px solid rgba(136,137,141,.2);
}
.hprw-wrap .hprw-bridge-heading { font-family: var(--hprw-font-display); font-size: clamp(1.7rem, 3vw, 2.6rem); font-weight: 800; color: var(--hprw-primary); line-height: 1.15; margin-bottom: 1.4rem; }
.hprw-wrap .hprw-bridge-intro { font-size: 1.05rem; color: var(--hprw-muted); line-height: 1.8; }
.hprw-wrap .hprw-bridge-intro p { font-size: 1.05rem; color: var(--hprw-muted); line-height: 1.8; }
.hprw-wrap .hprw-bridge-right { display: flex; flex-direction: column; gap: 0; }
.hprw-wrap .hprw-bridge-setup { font-size: 1.08rem; color: var(--hprw-muted); line-height: 1.8; margin-bottom: 2rem; }
.hprw-wrap .hprw-bridge-sequence {
	display: flex; flex-direction: column; gap: 0; margin-bottom: 2.4rem;
	border-left: 2px solid rgba(52,55,62,.12); padding-left: 1.6rem;
}
.hprw-wrap .hprw-bridge-seq-item {
	position: relative; padding: .85rem 0; font-size: 1rem; color: var(--hprw-muted); line-height: 1.6; transition: var(--hprw-trans-fast);
}
.hprw-wrap .hprw-bridge-seq-item::before {
	content: ''; position: absolute; left: -1.75rem; top: 50%; transform: translateY(-50%);
	width: 8px; height: 8px; border-radius: 50%; background: var(--hprw-bg-alt); border: 2px solid rgba(52,55,62,.25); transition: var(--hprw-trans-fast);
}
.hprw-wrap .hprw-bridge-seq-item:hover { color: var(--hprw-primary); }
.hprw-wrap .hprw-bridge-seq-item:hover::before { background: var(--hprw-primary); border-color: var(--hprw-primary); }
.hprw-wrap .hprw-bridge-pivot {
	font-size: 1.1rem; color: var(--hprw-primary); font-weight: 600; line-height: 1.7;
	padding: 1.6rem 2rem; background: var(--hprw-light); border-radius: var(--hprw-radius-md);
	border-left: 4px solid var(--hprw-primary); box-shadow: var(--hprw-shadow-1); margin-bottom: 1.6rem;
}
.hprw-wrap .hprw-bridge-pivot p { font-size: 1.1rem; color: var(--hprw-primary); font-weight: 600; margin-bottom: 0; }
.hprw-wrap .hprw-bridge-close { display: flex; flex-direction: column; gap: .3rem; }
.hprw-wrap .hprw-bridge-close-line { font-size: 1rem; font-weight: 700; color: var(--hprw-primary); letter-spacing: .01em; display: block; }
.hprw-wrap .hprw-bridge-close-line.muted { font-weight: 400; color: var(--hprw-muted); font-size: .97rem; }

/* ============================================================
   PART 3 — FAILURE PATTERNS
   ============================================================ */
.hprw-wrap .hprw-patterns { background: var(--hprw-bg); }
.hprw-wrap .hprw-patterns-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3.2rem; align-items: start; margin-top: 4rem; }
.hprw-wrap .hprw-pattern-list { margin-top: 2rem; display: flex; flex-direction: column; gap: .9rem; }
.hprw-wrap .hprw-plist-item { display: flex; align-items: flex-start; gap: 1rem; background: var(--hprw-light); border-radius: var(--hprw-radius-sm); padding: 1.1rem 1.4rem; border: 1px solid rgba(136,137,141,.1); box-shadow: var(--hprw-shadow-1); transition: var(--hprw-trans-normal); }
.hprw-wrap .hprw-plist-item:hover { transform: translateX(8px); box-shadow: var(--hprw-shadow-2); border-color: rgba(52,55,62,.15); }
.hprw-wrap .hprw-plist-dot { flex-shrink: 0; width: 8px; height: 8px; border-radius: 50%; background: var(--hprw-primary); margin-top: 7px; }
.hprw-wrap .hprw-plist-item p { font-size: .97rem; margin-bottom: 0; }
.hprw-wrap .hprw-region-cards { display: flex; flex-direction: column; gap: 1.2rem; }
.hprw-wrap .hprw-rcrd { background: var(--hprw-light); border-radius: var(--hprw-radius-md); padding: 1.8rem 2rem; box-shadow: var(--hprw-shadow-3d); border: 1px solid rgba(136,137,141,.08); transition: var(--hprw-trans-normal); transform-style: preserve-3d; position: relative; overflow: hidden; }
.hprw-wrap .hprw-rcrd::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: linear-gradient(90deg, var(--hprw-primary), var(--hprw-secondary)); border-radius: var(--hprw-radius-md) var(--hprw-radius-md) 0 0; }
.hprw-wrap .hprw-rcrd:hover { transform: translateY(-6px); box-shadow: var(--hprw-shadow-3dh); }
.hprw-wrap .hprw-rcrd h4 { font-size: 1rem; font-weight: 700; color: var(--hprw-primary); margin-bottom: .5rem; }
.hprw-wrap .hprw-rcrd p  { font-size: .93rem; margin-bottom: 0; }

/* ============================================================
   PART 4 — PRESSURE & FLOW
   ============================================================ */
.hprw-wrap .hprw-pressure { background: var(--hprw-primary); }
.hprw-wrap .hprw-pressure::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(74,78,88,.4) 0%, transparent 55%), radial-gradient(ellipse at 80% 20%, rgba(136,137,141,.15) 0%, transparent 60%); pointer-events: none; }
.hprw-wrap .hprw-pressure .hprw-container { position: relative; z-index: 1; }
.hprw-wrap .hprw-pressure-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; margin-top: 4rem; }
.hprw-wrap .hprw-stress-cards { display: flex; flex-direction: column; gap: 1.1rem; }
.hprw-wrap .hprw-stress-card { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: var(--hprw-radius-md); padding: 1.6rem 1.8rem; -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); transition: var(--hprw-trans-normal); }
.hprw-wrap .hprw-stress-card:hover { background: rgba(255,255,255,.09); transform: translateY(-4px); border-color: rgba(255,255,255,.2); }
.hprw-wrap .hprw-stress-card h4 { font-size: 1rem; font-weight: 700; color: var(--hprw-light); margin-bottom: .4rem; }
.hprw-wrap .hprw-stress-card p  { font-size: .92rem; color: rgba(255,255,255,.65); margin-bottom: 0; }
.hprw-wrap .hprw-pressure-signals { display: flex; flex-direction: column; gap: 1rem; }
.hprw-wrap .hprw-sig-label { color: rgba(255,255,255,.5); font-size: .75rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 1.2rem; display: block; }
.hprw-wrap .hprw-sig-item { display: flex; align-items: flex-start; gap: 1.1rem; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07); border-radius: var(--hprw-radius-sm); padding: 1.3rem 1.6rem; transition: var(--hprw-trans-fast); }
.hprw-wrap .hprw-sig-item:hover { background: rgba(255,255,255,.08); transform: translateX(6px); }
.hprw-wrap .hprw-sig-num { flex-shrink: 0; width: 30px; height: 30px; border-radius: 50%; background: rgba(136,137,141,.3); display: flex; align-items: center; justify-content: center; font-size: .78rem; font-weight: 700; color: rgba(255,255,255,.8); }
.hprw-wrap .hprw-sig-item p { font-size: .97rem; color: rgba(255,255,255,.72); margin-bottom: 0; }

/* ============================================================
   PART 5 — MATERIAL DEGRADATION
   ============================================================ */
.hprw-wrap .hprw-material { background: var(--hprw-bg-alt); }
.hprw-wrap .hprw-material-cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.6rem; margin-top: 4rem; }
.hprw-wrap .hprw-mat-card { background: var(--hprw-light); border-radius: var(--hprw-radius-md); padding: 2rem 1.8rem; box-shadow: var(--hprw-shadow-2); border: 1px solid rgba(136,137,141,.08); transition: var(--hprw-trans-normal); transform-style: preserve-3d; position: relative; overflow: hidden; }
.hprw-wrap .hprw-mat-card::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, transparent, rgba(52,55,62,.4), transparent); transform: scaleX(0); transition: transform .35s ease; }
.hprw-wrap .hprw-mat-card:hover { transform: translateY(-8px); box-shadow: var(--hprw-shadow-3d); }
.hprw-wrap .hprw-mat-card:hover::after { transform: scaleX(1); }
.hprw-wrap .hprw-mat-icon { font-size: 2rem; margin-bottom: 1rem; display: block; }
.hprw-wrap .hprw-mat-card h3 { font-size: 1.05rem; font-weight: 700; color: var(--hprw-primary); margin-bottom: .7rem; }
.hprw-wrap .hprw-mat-card p  { font-size: .92rem; margin-bottom: 0; }
.hprw-wrap .hprw-mat-warning { margin-top: 3rem; background: var(--hprw-primary); border-radius: var(--hprw-radius-md); padding: 2rem 2.4rem; display: flex; gap: 1.2rem; align-items: center; }
.hprw-wrap .hprw-mat-warning-icon { font-size: 1.6rem; flex-shrink: 0; }
.hprw-wrap .hprw-mat-warning p { color: rgba(255,255,255,.82); font-size: .97rem; margin-bottom: 0; }
.hprw-wrap .hprw-mat-warning strong { color: var(--hprw-light); }

/* ============================================================
   PART 6 — SYSTEM TRIGGERS
   ============================================================ */
.hprw-wrap .hprw-triggers { background: var(--hprw-bg); }
.hprw-wrap .hprw-heaters-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 3.2rem; align-items: start; margin-top: 4rem; }
.hprw-wrap .hprw-tl-label { font-size: .75rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--hprw-secondary); margin-bottom: 1.6rem; display: block; }
.hprw-wrap .hprw-failure-timeline { display: flex; flex-direction: column; gap: 0; }
.hprw-wrap .hprw-tl-item { display: flex; align-items: flex-start; gap: 1.4rem; position: relative; padding-bottom: 1.8rem; }
.hprw-wrap .hprw-tl-item:last-child { padding-bottom: 0; }
.hprw-wrap .hprw-tl-item:not(:last-child)::after { content: ''; position: absolute; left: 15px; top: 32px; bottom: 0; width: 2px; background: linear-gradient(to bottom, var(--hprw-secondary), transparent); }
.hprw-wrap .hprw-tl-circle { flex-shrink: 0; width: 32px; height: 32px; border-radius: 50%; background: var(--hprw-primary); display: flex; align-items: center; justify-content: center; color: var(--hprw-light); font-size: .8rem; font-weight: 700; z-index: 1; }
.hprw-wrap .hprw-tl-body h4 { font-size: .97rem; font-weight: 700; color: var(--hprw-primary); margin-bottom: .2rem; }
.hprw-wrap .hprw-tl-body p  { font-size: .9rem; margin-bottom: 0; }

/* ============================================================
   PART 7 — HOMEOWNER REALITY
   ============================================================ */
.hprw-wrap .hprw-reality { background: var(--hprw-primary); }
.hprw-wrap .hprw-reality::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 20% 80%, rgba(74,78,88,.35) 0%, transparent 55%); pointer-events: none; }
.hprw-wrap .hprw-reality .hprw-container { position: relative; z-index: 1; }
.hprw-wrap .hprw-reality-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; margin-top: 4rem; }
.hprw-wrap .hprw-reality-left p { color: rgba(255,255,255,.7); }
.hprw-wrap .hprw-real-drivers { display: flex; flex-direction: column; gap: .85rem; margin-top: 1.8rem; }
.hprw-wrap .hprw-rd-item { display: flex; align-items: center; gap: 1rem; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: var(--hprw-radius-sm); padding: 1rem 1.4rem; transition: var(--hprw-trans-fast); }
.hprw-wrap .hprw-rd-item:hover { background: rgba(255,255,255,.1); transform: translateX(6px); }
.hprw-wrap .hprw-rd-arrow { color: rgba(255,255,255,.5); font-size: .9rem; }
.hprw-wrap .hprw-rd-item p { font-size: .95rem; color: rgba(255,255,255,.75); margin-bottom: 0; }
.hprw-wrap .hprw-gap-panel { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: var(--hprw-radius-lg); padding: 2.8rem; -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); transition: var(--hprw-trans-normal); }
.hprw-wrap .hprw-gap-panel:hover { background: rgba(255,255,255,.08); transform: translateY(-6px); }
.hprw-wrap .hprw-gap-panel h3 { font-size: 1.2rem; font-weight: 700; color: var(--hprw-light); margin-bottom: 1.4rem; }
.hprw-wrap .hprw-gap-items { display: flex; flex-direction: column; gap: .9rem; }
.hprw-wrap .hprw-gap-item { display: flex; align-items: flex-start; gap: 1rem; }
.hprw-wrap .hprw-gap-icon { font-size: 1.1rem; flex-shrink: 0; margin-top: 2px; }
.hprw-wrap .hprw-gap-item p { font-size: .93rem; color: rgba(255,255,255,.7); margin-bottom: 0; }

/* ============================================================
   PART 8 — REPAIR TO REPIPE
   ============================================================ */
.hprw-wrap .hprw-repipe { background: var(--hprw-bg-alt); }
.hprw-wrap .hprw-repipe-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 3.2rem; align-items: start; margin-top: 4rem; }
.hprw-wrap .hprw-signals-list { display: flex; flex-direction: column; gap: .8rem; margin-top: 1.6rem; }
.hprw-wrap .hprw-sig-badge { display: flex; align-items: center; gap: .9rem; background: var(--hprw-light); border-radius: var(--hprw-radius-sm); padding: .9rem 1.3rem; border: 1px solid rgba(136,137,141,.1); box-shadow: var(--hprw-shadow-1); transition: var(--hprw-trans-fast); }
.hprw-wrap .hprw-sig-badge:hover { transform: translateX(8px); box-shadow: var(--hprw-shadow-2); }
.hprw-wrap .hprw-sig-badge-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--hprw-secondary); flex-shrink: 0; }
.hprw-wrap .hprw-sig-badge p { font-size: .94rem; margin-bottom: 0; }
.hprw-wrap .hprw-repipe-process { background: var(--hprw-light); border-radius: var(--hprw-radius-lg); padding: 2.8rem; box-shadow: var(--hprw-shadow-3d); border: 1px solid rgba(136,137,141,.08); position: relative; overflow: hidden; transition: var(--hprw-trans-normal); transform-style: preserve-3d; }
.hprw-wrap .hprw-repipe-process::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 5px; background: linear-gradient(90deg, var(--hprw-primary), var(--hprw-secondary)); border-radius: var(--hprw-radius-lg) var(--hprw-radius-lg) 0 0; }
.hprw-wrap .hprw-repipe-process:hover { transform: translateY(-8px); box-shadow: var(--hprw-shadow-3dh); }
.hprw-wrap .hprw-repipe-process h3 { font-size: 1.1rem; font-weight: 800; color: var(--hprw-primary); margin-bottom: .5rem; }
.hprw-wrap .hprw-repipe-process > .hprw-proc-intro { font-size: .95rem; margin-bottom: 1.6rem; }
.hprw-wrap .hprw-process-items { display: flex; flex-direction: column; gap: .85rem; }
.hprw-wrap .hprw-proc-item { display: flex; align-items: flex-start; gap: 1rem; padding: 1rem 1.2rem; background: var(--hprw-bg); border-radius: var(--hprw-radius-sm); border: 1px solid rgba(136,137,141,.08); transition: var(--hprw-trans-fast); }
.hprw-wrap .hprw-proc-item:hover { background: var(--hprw-primary); border-color: var(--hprw-primary); }
.hprw-wrap .hprw-proc-item:hover .hprw-proc-text { color: rgba(255,255,255,.85); }
.hprw-wrap .hprw-proc-num { flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%; background: var(--hprw-primary); display: flex; align-items: center; justify-content: center; font-size: .75rem; font-weight: 800; color: var(--hprw-light); transition: var(--hprw-trans-fast); }
.hprw-wrap .hprw-proc-item:hover .hprw-proc-num { background: rgba(255,255,255,.2); }
.hprw-wrap .hprw-proc-text { font-size: .92rem; margin-bottom: 0; transition: var(--hprw-trans-fast); }

/* ============================================================
   PART 9 — PERMITS & COMPLIANCE
   ============================================================ */
.hprw-wrap .hprw-permits { background: var(--hprw-primary); }
.hprw-wrap .hprw-permits::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(74,78,88,.4) 0%, transparent 60%), radial-gradient(ellipse at 85% 15%, rgba(136,137,141,.12) 0%, transparent 55%); pointer-events: none; }
.hprw-wrap .hprw-permits .hprw-container { position: relative; z-index: 1; }
.hprw-wrap .hprw-permits-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.6rem; margin-top: 4rem; }
.hprw-wrap .hprw-permit-card { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: var(--hprw-radius-md); padding: 2rem 1.8rem; -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); transition: var(--hprw-trans-normal); position: relative; overflow: hidden; }
.hprw-wrap .hprw-permit-card:hover { background: rgba(255,255,255,.1); transform: translateY(-8px); border-color: rgba(255,255,255,.2); }
.hprw-wrap .hprw-permit-icon { font-size: 2rem; margin-bottom: 1rem; display: block; }
.hprw-wrap .hprw-permit-card h3 { font-size: 1rem; font-weight: 700; color: var(--hprw-light); margin-bottom: .6rem; }
.hprw-wrap .hprw-permit-card p  { font-size: .9rem; color: rgba(255,255,255,.65); margin-bottom: 0; }
.hprw-wrap .hprw-permits-note { margin-top: 3rem; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: var(--hprw-radius-md); padding: 2rem 2.4rem; display: flex; gap: 1.4rem; align-items: flex-start; }
.hprw-wrap .hprw-permits-note-icon { font-size: 1.5rem; flex-shrink: 0; }
.hprw-wrap .hprw-permits-note p { color: rgba(255,255,255,.78); font-size: .97rem; margin-bottom: 0; }
.hprw-wrap .hprw-permits-note strong { color: var(--hprw-light); }

/* ============================================================
   PART 10 — REGIONAL RISK
   ============================================================ */
.hprw-wrap .hprw-risk { background: var(--hprw-bg); }
.hprw-wrap .hprw-risk-split { display: grid; grid-template-columns: 1fr 1fr; gap: 3.2rem; align-items: start; margin-top: 4rem; }
.hprw-wrap .hprw-risk-factors { display: flex; flex-direction: column; gap: 1rem; }
.hprw-wrap .hprw-risk-factor { background: var(--hprw-light); border-radius: var(--hprw-radius-md); padding: 1.6rem 1.8rem; box-shadow: var(--hprw-shadow-2); border-left: 4px solid var(--hprw-primary); transition: var(--hprw-trans-normal); }
.hprw-wrap .hprw-risk-factor:hover { transform: translateX(8px); box-shadow: var(--hprw-shadow-3d); }
.hprw-wrap .hprw-risk-factor h4 { font-size: .97rem; font-weight: 700; color: var(--hprw-primary); margin-bottom: .35rem; }
.hprw-wrap .hprw-risk-factor p  { font-size: .9rem; margin-bottom: 0; }

/* ============================================================
   PART 11 — DECISION FRAMEWORK
   ============================================================ */
.hprw-wrap .hprw-framework { background: var(--hprw-bg-alt); }
.hprw-wrap .hprw-framework-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 3.2rem; align-items: start; margin-top: 4rem; }
.hprw-wrap .hprw-fw-items { display: flex; flex-direction: column; gap: 1rem; }
.hprw-wrap .hprw-fw-item { background: var(--hprw-light); border-radius: var(--hprw-radius-md); padding: 1.6rem 2rem; box-shadow: var(--hprw-shadow-2); border: 1px solid rgba(136,137,141,.08); display: flex; align-items: flex-start; gap: 1.1rem; transition: var(--hprw-trans-normal); transform-style: preserve-3d; }
.hprw-wrap .hprw-fw-item:hover { transform: translateY(-5px); box-shadow: var(--hprw-shadow-3d); }
.hprw-wrap .hprw-fw-num { flex-shrink: 0; width: 40px; height: 40px; border-radius: var(--hprw-radius-sm); background: linear-gradient(135deg, var(--hprw-primary), var(--hprw-accent)); display: flex; align-items: center; justify-content: center; color: var(--hprw-light); font-weight: 800; font-size: .95rem; box-shadow: 0 4px 14px rgba(52,55,62,.25); }
.hprw-wrap .hprw-fw-item h4 { font-size: .97rem; font-weight: 700; color: var(--hprw-primary); margin-bottom: .25rem; }
.hprw-wrap .hprw-fw-item p  { font-size: .88rem; margin-bottom: 0; }

/* ============================================================
   PART 12 — OUTCOMES
   ============================================================ */
.hprw-wrap .hprw-outcomes { background: var(--hprw-primary); }
.hprw-wrap .hprw-outcomes::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 15% 85%, rgba(74,78,88,.4) 0%, transparent 55%), radial-gradient(ellipse at 90% 10%, rgba(136,137,141,.15) 0%, transparent 50%); pointer-events: none; }
.hprw-wrap .hprw-outcomes .hprw-container { position: relative; z-index: 1; }
.hprw-wrap .hprw-outcomes-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 1.4rem; margin-top: 4rem; }
.hprw-wrap .hprw-out-card { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: var(--hprw-radius-md); padding: 1.8rem; -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); transition: var(--hprw-trans-normal); display: flex; align-items: flex-start; gap: 1.1rem; }
.hprw-wrap .hprw-out-card:hover { background: rgba(255,255,255,.1); transform: translateY(-5px); border-color: rgba(255,255,255,.2); }
.hprw-wrap .hprw-out-icon { font-size: 1.5rem; flex-shrink: 0; }
.hprw-wrap .hprw-out-card h4 { font-size: 1rem; font-weight: 700; color: var(--hprw-light); margin-bottom: .3rem; }
.hprw-wrap .hprw-out-card p  { font-size: .9rem; color: rgba(255,255,255,.65); margin-bottom: 0; }
.hprw-wrap .hprw-shift-statement { margin-top: 3.5rem; text-align: center; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: var(--hprw-radius-md); padding: 2.4rem; }
.hprw-wrap .hprw-shift-statement p { color: rgba(255,255,255,.6); font-size: 1.05rem; line-height: 2; text-align: center; margin-bottom: 0; }
.hprw-wrap .hprw-shift-statement strong { color: var(--hprw-light); font-size: 1.15rem; }

/* ============================================================
   PART 13 — START POINT
   ============================================================ */
.hprw-wrap .hprw-start { background: var(--hprw-bg); }
.hprw-wrap .hprw-start-inner { max-width: 780px; margin: 0 auto; text-align: center; }
.hprw-wrap .hprw-start-inner .hprw-label { display: inline-block; }
.hprw-wrap .hprw-start-inner .hprw-divider { margin: 0 auto 2rem; }
.hprw-wrap .hprw-start-inner p { text-align: center; }

/* ============================================================
   PART 14 — REGIONAL EXPANSION (reusable)
   ============================================================ */
.hprw-wrap .hprw-region { padding: 7rem 2rem; }
.hprw-wrap .hprw-region.hprw-region-light   { background: var(--hprw-bg); }
.hprw-wrap .hprw-region.hprw-region-alt     { background: var(--hprw-bg-alt); }
.hprw-wrap .hprw-region.hprw-region-dark    { background: var(--hprw-primary); }
.hprw-wrap .hprw-region-intro { max-width: 720px; margin-bottom: 4rem; }
.hprw-wrap .hprw-region-blocks { display: grid; grid-template-columns: repeat(2,1fr); gap: 1.6rem; }
.hprw-wrap .hprw-rblk { border-radius: var(--hprw-radius-md); padding: 2rem 1.8rem; border: 1px solid rgba(136,137,141,.1); transition: var(--hprw-trans-normal); position: relative; overflow: hidden; }
.hprw-wrap .hprw-rblk.hprw-rblk-light { background: var(--hprw-light); box-shadow: var(--hprw-shadow-2); }
.hprw-wrap .hprw-rblk.hprw-rblk-dark  { background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.1); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); }
.hprw-wrap .hprw-rblk.hprw-rblk-light:hover { transform: translateY(-6px); box-shadow: var(--hprw-shadow-3d); }
.hprw-wrap .hprw-rblk.hprw-rblk-dark:hover  { transform: translateY(-6px); background: rgba(255,255,255,.09); border-color: rgba(255,255,255,.2); }
.hprw-wrap .hprw-rblk::before { content: ''; position: absolute; top: 0; left: 0; bottom: 0; width: 4px; background: linear-gradient(to bottom, var(--hprw-primary), var(--hprw-secondary)); }
.hprw-wrap .hprw-rblk.hprw-rblk-dark::before { background: linear-gradient(to bottom, rgba(136,137,141,.6), rgba(136,137,141,.2)); }
.hprw-wrap .hprw-rblk h3 { font-size: 1rem; font-weight: 700; margin-bottom: .6rem; padding-left: .8rem; }
.hprw-wrap .hprw-rblk.hprw-rblk-light h3 { color: var(--hprw-primary); }
.hprw-wrap .hprw-rblk.hprw-rblk-dark  h3 { color: var(--hprw-light); }
.hprw-wrap .hprw-rblk p { font-size: .91rem; margin-bottom: 0; padding-left: .8rem; }
.hprw-wrap .hprw-rblk.hprw-rblk-light p { color: var(--hprw-muted); }
.hprw-wrap .hprw-rblk.hprw-rblk-dark  p { color: rgba(255,255,255,.65); }
.hprw-wrap .hprw-region-conclusion { margin-top: 3rem; border-radius: var(--hprw-radius-md); padding: 2rem 2.4rem; display: flex; gap: 1.2rem; align-items: flex-start; }
.hprw-wrap .hprw-region-conclusion.hprw-rc-light { background: var(--hprw-primary); }
.hprw-wrap .hprw-region-conclusion.hprw-rc-dark  { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); }
.hprw-wrap .hprw-rc-icon { font-size: 1.4rem; flex-shrink: 0; }
.hprw-wrap .hprw-region-conclusion p { font-size: .96rem; margin-bottom: 0; }
.hprw-wrap .hprw-region-conclusion.hprw-rc-light p { color: rgba(255,255,255,.82); }
.hprw-wrap .hprw-region-conclusion.hprw-rc-dark  p { color: rgba(255,255,255,.78); }
.hprw-wrap .hprw-region-conclusion strong { color: var(--hprw-light); }

/* ============================================================
   PART 15 — WHY REGIONAL MATTERS
   ============================================================ */
.hprw-wrap .hprw-why-regional { background: var(--hprw-bg-alt); }
.hprw-wrap .hprw-why-regional::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(52,55,62,.04) 0%, transparent 55%); pointer-events: none; }
.hprw-wrap .hprw-why-regional .hprw-container { position: relative; z-index: 1; }
.hprw-wrap .hprw-why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3.2rem; align-items: start; margin-top: 4rem; }
.hprw-wrap .hprw-why-explains { display: flex; flex-direction: column; gap: .9rem; margin-top: 1.8rem; }
.hprw-wrap .hprw-why-exp-item { display: flex; align-items: flex-start; gap: 1rem; background: var(--hprw-light); border: 1px solid rgba(136,137,141,.1); border-radius: var(--hprw-radius-sm); padding: 1.1rem 1.4rem; transition: var(--hprw-trans-fast); box-shadow: var(--hprw-shadow-1); }
.hprw-wrap .hprw-why-exp-item:hover { transform: translateX(6px); box-shadow: var(--hprw-shadow-2); border-color: rgba(52,55,62,.15); }
.hprw-wrap .hprw-why-exp-item p { font-size: .94rem; margin-bottom: 0; }
.hprw-wrap .hprw-why-arrow { color: var(--hprw-primary); font-size: .9rem; flex-shrink: 0; margin-top: 2px; font-weight: 700; }
.hprw-wrap .hprw-final-statement { background: var(--hprw-light); border: 1px solid rgba(136,137,141,.08); border-radius: var(--hprw-radius-lg); padding: 2.8rem; box-shadow: var(--hprw-shadow-3d); transition: var(--hprw-trans-normal); }
.hprw-wrap .hprw-final-statement:hover { box-shadow: var(--hprw-shadow-3dh); transform: translateY(-5px); }
.hprw-wrap .hprw-final-statement h3 { font-size: 1.2rem; font-weight: 800; color: var(--hprw-primary); margin-bottom: 1.2rem; }
.hprw-wrap .hprw-final-statement p { font-size: .95rem; }
.hprw-wrap .hprw-final-italic { margin-top: 1rem !important; font-style: italic; color: rgba(52,55,62,.55) !important; }

/* ============================================================
   KEYFRAMES
   ============================================================ */
@keyframes hprwDriftOrb { 0%,100% { transform: translate(0,0) scale(1); } 33% { transform: translate(30px,-20px) scale(1.05); } 66% { transform: translate(-20px,15px) scale(.95); } }
@keyframes hprwFloat    { 0%,100% { transform: rotate(-11deg) translateY(0); } 50% { transform: rotate(-9deg) translateY(-18px); } }
@keyframes hprwPulse    { 0%,100% { opacity:1; transform:scale(1); } 50% { opacity:.5; transform:scale(.75); } }
@keyframes hprwScrollDown { 0% { opacity:0; transform:rotate(45deg) translateY(-8px); } 50% { opacity:1; } 100% { opacity:0; transform:rotate(45deg) translateY(8px); } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 992px) {
	.hprw-wrap .hprw-bridge-grid      { grid-template-columns: 1fr; gap: 2.4rem; }
	.hprw-wrap .hprw-bridge-left      { position: static; }
	.hprw-wrap .hprw-patterns-grid, .hprw-wrap .hprw-pressure-grid,
	.hprw-wrap .hprw-heaters-layout,  .hprw-wrap .hprw-reality-grid,
	.hprw-wrap .hprw-repipe-layout,   .hprw-wrap .hprw-risk-split,
	.hprw-wrap .hprw-framework-layout,.hprw-wrap .hprw-why-grid { grid-template-columns: 1fr; }
	.hprw-wrap .hprw-material-cards   { grid-template-columns: repeat(2,1fr); }
	.hprw-wrap .hprw-permits-grid     { grid-template-columns: repeat(2,1fr); }
	.hprw-wrap .hprw-outcomes-grid    { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
	.hprw-wrap section { padding: 5rem 1.5rem; }
	.hprw-wrap .hprw-hero { padding: 6rem 1.5rem 5rem; }
	.hprw-wrap .hprw-material-cards, .hprw-wrap .hprw-permits-grid, .hprw-wrap .hprw-region-blocks { grid-template-columns: 1fr; }
	.hprw-wrap .hprw-gp { display: none; }
	.hprw-wrap .hprw-hero .hprw-hero-title { font-size: 2.2rem !important; }
}
