/**
 * IWTMYL Homepage Redesign V5
 * File: /wp-content/themes/iwtmyl/css/homepage.css
 *
 * All rules use body.page-template-home for specificity
 * to override main.css without affecting other pages.
 */

/* BODY & LAYOUT OVERRIDES */
body.page-template-home { padding-bottom: 0 !important; background: #fafaf7 !important; }
body.page-template-home footer#footer { position: relative !important; padding-bottom: 2rem !important; }
body.page-template-home footer#footer:before { display: none !important; }
body.page-template-home header#header .top-hedaer .elem-center { display: none !important; }

:root {
  --hp-green-900: #0f2418; --hp-green-800: #1c3a2a; --hp-green-700: #2d6a4f;
  --hp-green-600: #40916c; --hp-green-500: #52b788; --hp-green-400: #74c69d;
  --hp-green-300: #95d5b2; --hp-green-200: #b7e4c7; --hp-green-100: #d8f3dc;
  --hp-green-50: #f0faf3; --hp-warm-white: #fafaf7; --hp-warm-50: #f5f5f0;
  --hp-warm-100: #e8e8e0; --hp-text-primary: #1a1a18; --hp-text-secondary: #4a4a42;
  --hp-text-muted: #7a7a70; --hp-text-on-dark: #e8e8e0; --hp-text-on-dark-muted: #b0b0a0;
  --hp-serif: 'Source Serif 4', Georgia, serif;
  --hp-sans: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --hp-radius-sm: 6px; --hp-radius-md: 10px; --hp-radius-lg: 16px;
}

/* REQUEST BANNER */
.hp-request-banner { background: var(--hp-green-50) !important; border-bottom: 1px solid var(--hp-green-100) !important; padding: 9px 0 !important; text-align: center !important; }
.hp-request-banner a { font-size: 13px !important; color: var(--hp-green-700) !important; text-decoration: none !important; font-weight: 500 !important; font-family: var(--hp-sans) !important; display: inline !important; }
.hp-request-banner a:hover { text-decoration: underline !important; }
.hp-pulse { display: inline-block !important; width: 7px !important; height: 7px !important; background: var(--hp-green-500) !important; border-radius: 50% !important; margin-right: 7px !important; animation: hp-pulse 2s infinite !important; }
@keyframes hp-pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.8)} }

/* HERO */
body.page-template-home .hp-hero { background: linear-gradient(180deg, #5a9fd4 0%, #88c1e0 20%, #bdd9ec 48%, #e2eff6 72%, #fff 100%) !important; padding: 60px 0 76px !important; position: relative !important; overflow: hidden !important; text-align: left !important; }
body.page-template-home .hp-hero::before { content: '' !important; position: absolute !important; top: 5% !important; left: -4% !important; width: 520px !important; height: 130px !important; background: radial-gradient(ellipse,rgba(255,255,255,.4) 0%,transparent 70%) !important; filter: blur(35px) !important; pointer-events: none !important; }
body.page-template-home .hp-hero::after { content: '' !important; position: absolute !important; top: 14% !important; right: -2% !important; width: 380px !important; height: 100px !important; background: radial-gradient(ellipse,rgba(255,255,255,.28) 0%,transparent 70%) !important; filter: blur(28px) !important; pointer-events: none !important; }
body.page-template-home .hp-hero>.container { position: relative !important; z-index: 1 !important; }
body.page-template-home .hp-hero-layout { display: grid !important; grid-template-columns: 1fr 400px !important; gap: 48px !important; align-items: start !important; }
.hp-hero-eyebrow { display: inline-flex !important; align-items: center !important; gap: 8px !important; font-size: 12.5px !important; font-weight: 600 !important; color: var(--hp-green-800) !important; text-transform: uppercase !important; letter-spacing: .07em !important; margin-bottom: 16px !important; background: rgba(255,255,255,.6) !important; backdrop-filter: blur(6px) !important; padding: 6px 14px !important; border-radius: 20px !important; font-family: var(--hp-sans) !important; }
.hp-hero-eyebrow .dot { width: 6px !important; height: 6px !important; background: var(--hp-green-500) !important; border-radius: 50% !important; display: inline-block !important; }
body.page-template-home .hp-hero h1 { font-family: var(--hp-serif) !important; font-size: 44px !important; font-weight: 700 !important; line-height: 1.12 !important; margin-bottom: 18px !important; color: var(--hp-green-900) !important; text-align: left !important; }
body.page-template-home .hp-hero h1 em { font-style: italic !important; color: var(--hp-green-700) !important; }
.hp-hero-sub { font-size: 16.5px !important; line-height: 1.6 !important; color: var(--hp-text-secondary) !important; margin-bottom: 28px !important; max-width: 500px !important; font-family: var(--hp-sans) !important; }
.hp-hero-ctas { display: flex !important; gap: 12px !important; flex-wrap: wrap !important; margin-bottom: 28px !important; }
body.page-template-home a.hp-btn-primary { display: inline-flex !important; align-items: center !important; font-family: var(--hp-sans) !important; font-size: 15px !important; font-weight: 600 !important; color: #fff !important; background: var(--hp-green-700) !important; border: none !important; padding: 14px 28px !important; border-radius: var(--hp-radius-sm) !important; text-decoration: none !important; box-shadow: 0 2px 8px rgba(45,106,79,.25) !important; line-height: 1.4 !important; width: auto !important; height: auto !important; }
body.page-template-home a.hp-btn-primary:hover { background: var(--hp-green-800) !important; color: #fff !important; text-decoration: none !important; }
body.page-template-home a.hp-btn-secondary { display: inline-flex !important; align-items: center !important; font-family: var(--hp-sans) !important; font-size: 15px !important; font-weight: 600 !important; color: var(--hp-green-800) !important; background: rgba(255,255,255,.75) !important; backdrop-filter: blur(6px) !important; border: 1.5px solid rgba(45,106,79,.2) !important; padding: 14px 28px !important; border-radius: var(--hp-radius-sm) !important; text-decoration: none !important; line-height: 1.4 !important; width: auto !important; height: auto !important; }
body.page-template-home a.hp-btn-secondary:hover { background: #fff !important; border-color: var(--hp-green-500) !important; text-decoration: none !important; }
.hp-hero-trust { display: flex !important; flex-wrap: wrap !important; gap: 10px !important; font-size: 12px !important; color: var(--hp-text-muted) !important; font-family: var(--hp-sans) !important; }
.hp-hero-trust span { display: inline-flex !important; align-items: center !important; gap: 5px !important; background: rgba(255,255,255,.5) !important; padding: 4px 10px !important; border-radius: 4px !important; font-weight: 500 !important; }

/* ZIP CARD */
body.page-template-home .hp-zip-card { background: #fff !important; border: 1px solid rgba(0,0,0,.08) !important; border-radius: var(--hp-radius-lg) !important; padding: 30px 26px !important; box-shadow: 0 8px 32px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.04) !important; }
body.page-template-home .hp-zip-card h3 { font-family: var(--hp-serif) !important; font-size: 21px !important; font-weight: 600 !important; margin-bottom: 5px !important; color: var(--hp-green-900) !important; text-align: left !important; }
body.page-template-home .hp-zip-card>p { font-size: 13.5px !important; color: var(--hp-text-secondary) !important; margin-bottom: 16px !important; line-height: 1.45 !important; font-family: var(--hp-sans) !important; text-align: left !important; }

/* ZIP FORM — override main.css form styles */
body.page-template-home .hp-zip-form { display: flex !important; flex-direction: row !important; align-items: stretch !important; gap: 8px !important; margin-bottom: 10px !important; background: transparent !important; border: none !important; padding: 0 !important; border-radius: 0 !important; box-shadow: none !important; max-width: 100% !important; width: 100% !important; }
body.page-template-home .hp-zip-form .form-group { flex: 1 !important; margin: 0 !important; padding: 0 !important; width: auto !important; }
body.page-template-home .hp-zip-form .form-group label { display: none !important; }
body.page-template-home .hp-zip-form .form-control { width: 100% !important; padding: 12px 14px !important; font-size: 16px !important; font-family: var(--hp-sans) !important; border: 1.5px solid var(--hp-warm-100) !important; border-radius: var(--hp-radius-sm) !important; background: var(--hp-warm-50) !important; color: var(--hp-text-primary) !important; height: 48px !important; box-shadow: none !important; text-align: left !important; }
body.page-template-home .hp-zip-form .form-control:focus { border-color: var(--hp-green-500) !important; background: #fff !important; box-shadow: none !important; }
body.page-template-home .hp-zip-form input[type="submit"].btn.green-btn,
body.page-template-home .hp-zip-form input[type="submit"].btn { padding: 0 20px !important; font-size: 14px !important; font-weight: 600 !important; font-family: var(--hp-sans) !important; background: var(--hp-green-700) !important; color: #fff !important; border: none !important; border-radius: var(--hp-radius-sm) !important; line-height: 48px !important; height: 48px !important; width: auto !important; min-width: 90px !important; box-shadow: none !important; }
body.page-template-home .hp-zip-form input[type="submit"].btn:hover { background: var(--hp-green-800) !important; box-shadow: none !important; }

.hp-zip-note { font-size: 11.5px !important; color: var(--hp-text-muted) !important; line-height: 1.4 !important; margin-bottom: 14px !important; font-family: var(--hp-sans) !important; }
.hp-zip-note a { color: var(--hp-green-700) !important; text-decoration: underline !important; }
.hp-zip-divider { display: flex !important; align-items: center !important; gap: 10px !important; margin: 12px 0 !important; font-size: 11px !important; color: var(--hp-text-muted) !important; text-transform: uppercase !important; letter-spacing: .1em !important; font-family: var(--hp-sans) !important; }
.hp-zip-divider::before,.hp-zip-divider::after { content: '' !important; flex: 1 !important; height: 1px !important; background: var(--hp-warm-100) !important; }
.hp-zip-alt { text-align: center !important; }
.hp-zip-alt a { font-size: 13px !important; color: var(--hp-green-700) !important; text-decoration: none !important; font-weight: 500 !important; font-family: var(--hp-sans) !important; }
.hp-zip-alt a:hover { text-decoration: underline !important; }

/* DONATE INLINE */
.hp-donate-inline { margin-top: 16px !important; padding-top: 16px !important; border-top: 1px solid var(--hp-warm-100) !important; }
.hp-donate-header { display: flex !important; align-items: center !important; gap: 7px !important; margin-bottom: 6px !important; }
.hp-donate-header h4 { font-size: 13.5px !important; font-weight: 700 !important; color: var(--hp-green-800) !important; font-family: var(--hp-sans) !important; margin: 0 !important; }
.hp-donate-inline p { font-size: 11.5px !important; color: var(--hp-text-muted) !important; line-height: 1.4 !important; margin-bottom: 10px !important; font-family: var(--hp-sans) !important; }
body.page-template-home a.hp-donate-btn { display: block !important; width: 100% !important; text-align: center !important; font-size: 13.5px !important; font-weight: 600 !important; font-family: var(--hp-sans) !important; color: var(--hp-green-700) !important; background: var(--hp-green-50) !important; border: 1.5px solid var(--hp-green-200) !important; padding: 10px 14px !important; border-radius: var(--hp-radius-sm) !important; text-decoration: none !important; line-height: 1.4 !important; height: auto !important; }
body.page-template-home a.hp-donate-btn:hover { background: var(--hp-green-100) !important; border-color: var(--hp-green-400) !important; text-decoration: none !important; }

/* TRUST BAR */
.hp-trust-bar { background: #fff !important; border-bottom: 1px solid rgba(0,0,0,.05) !important; padding: 22px 0 !important; }
.hp-trust-bar>.container { display: flex !important; align-items: center !important; justify-content: center !important; gap: 32px !important; flex-wrap: wrap !important; }
.hp-trust-label { font-size: 11px !important; font-weight: 600 !important; color: var(--hp-text-muted) !important; text-transform: uppercase !important; letter-spacing: .08em !important; font-family: var(--hp-sans) !important; }
.hp-trust-logos { display: flex !important; align-items: center !important; gap: 24px !important; flex-wrap: wrap !important; justify-content: center !important; }
.hp-trust-logo { font-size: 13px !important; font-weight: 700 !important; color: var(--hp-text-muted) !important; opacity: .5 !important; font-family: var(--hp-sans) !important; }
.hp-trust-logo:hover { opacity: .85 !important; }

/* SECTIONS */
.hp-section { padding: 72px 0 !important; }
.hp-section-alt { background: var(--hp-warm-50) !important; }
.hp-section-dark { background: var(--hp-green-900) !important; color: #fff !important; }
.hp-section-header { text-align: center !important; max-width: 620px !important; margin: 0 auto 44px !important; }
.hp-section-eyebrow { font-size: 12px !important; font-weight: 600 !important; color: var(--hp-green-600) !important; text-transform: uppercase !important; letter-spacing: .08em !important; margin-bottom: 10px !important; font-family: var(--hp-sans) !important; }
.hp-section-dark .hp-section-eyebrow { color: var(--hp-green-400) !important; }
body.page-template-home .hp-section-header h2 { font-family: var(--hp-serif) !important; font-size: 31px !important; font-weight: 700 !important; line-height: 1.2 !important; margin-bottom: 12px !important; }
.hp-section-dark .hp-section-header h2 { color: #fff !important; }
.hp-section-header p { font-size: 15px !important; line-height: 1.6 !important; color: var(--hp-text-secondary) !important; font-family: var(--hp-sans) !important; }
.hp-section-dark .hp-section-header p { color: var(--hp-text-on-dark-muted) !important; }

/* HOW IT WORKS */
.hp-steps-grid { display: grid !important; grid-template-columns: repeat(4,1fr) !important; gap: 20px !important; }
.hp-step-card { text-align: center !important; padding: 24px 14px !important; }
.hp-step-number { width: 40px !important; height: 40px !important; background: var(--hp-green-100) !important; color: var(--hp-green-700) !important; border-radius: 50% !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 15px !important; font-weight: 700 !important; margin: 0 auto 14px !important; font-family: var(--hp-sans) !important; }
.hp-step-card h4 { font-size: 14px !important; font-weight: 700 !important; margin-bottom: 5px !important; font-family: var(--hp-sans) !important; color: var(--hp-text-primary) !important; }
.hp-step-card p { font-size: 13px !important; line-height: 1.5 !important; color: var(--hp-text-secondary) !important; font-family: var(--hp-sans) !important; margin-bottom: 0 !important; }

/* WHO WE HELP */
.hp-who-grid { display: grid !important; grid-template-columns: repeat(3,1fr) !important; gap: 22px !important; }
.hp-who-card { background: #fff !important; border: 1px solid rgba(0,0,0,.06) !important; border-radius: var(--hp-radius-lg) !important; padding: 30px 22px !important; transition: all .25s !important; }
.hp-who-card:hover { box-shadow: 0 4px 12px rgba(15,36,24,.08) !important; transform: translateY(-2px) !important; }
.hp-who-icon { font-size: 28px !important; margin-bottom: 12px !important; display: block !important; }
.hp-who-card h4 { font-size: 15.5px !important; font-weight: 700 !important; margin-bottom: 7px !important; font-family: var(--hp-sans) !important; color: var(--hp-text-primary) !important; }
.hp-who-card p { font-size: 13.5px !important; line-height: 1.5 !important; color: var(--hp-text-secondary) !important; font-family: var(--hp-sans) !important; margin-bottom: 0 !important; }

/* IMPACT */
.hp-impact-grid { display: grid !important; grid-template-columns: repeat(4,1fr) !important; gap: 24px !important; text-align: center !important; }
.hp-impact-number { font-family: var(--hp-serif) !important; font-size: 38px !important; font-weight: 700 !important; color: var(--hp-green-300) !important; line-height: 1 !important; margin-bottom: 5px !important; }
.hp-impact-label { font-size: 13px !important; color: var(--hp-text-on-dark-muted) !important; line-height: 1.35 !important; font-family: var(--hp-sans) !important; }

/* COVERAGE MAP */
.hp-coverage { padding: 56px 0 !important; background: #fff !important; border-top: 1px solid rgba(0,0,0,.04) !important; }
.hp-coverage-inner { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 48px !important; align-items: center !important; }
body.page-template-home .hp-coverage-text h3 { font-family: var(--hp-serif) !important; font-size: 26px !important; font-weight: 700 !important; line-height: 1.2 !important; margin-bottom: 12px !important; color: var(--hp-text-primary) !important; text-align: left !important; }
.hp-coverage-text h3 em { color: var(--hp-green-700) !important; font-style: italic !important; }
.hp-coverage-text p { font-size: 14.5px !important; line-height: 1.6 !important; color: var(--hp-text-secondary) !important; margin-bottom: 8px !important; font-family: var(--hp-sans) !important; text-align: left !important; }
.hp-coverage-stats { display: flex !important; gap: 28px !important; margin: 20px 0 !important; }
.hp-cs-num { font-family: var(--hp-serif) !important; font-size: 28px !important; font-weight: 700 !important; color: var(--hp-green-700) !important; line-height: 1 !important; }
.hp-cs-label { font-size: 11.5px !important; color: var(--hp-text-muted) !important; margin-top: 3px !important; font-family: var(--hp-sans) !important; }
body.page-template-home a.hp-coverage-cta { display: inline-flex !important; align-items: center !important; gap: 8px !important; font-size: 14px !important; font-weight: 600 !important; color: #fff !important; background: var(--hp-green-700) !important; padding: 12px 22px !important; border-radius: var(--hp-radius-sm) !important; text-decoration: none !important; margin-top: 8px !important; font-family: var(--hp-sans) !important; line-height: 1.4 !important; height: auto !important; width: auto !important; border: none !important; }
body.page-template-home a.hp-coverage-cta:hover { background: var(--hp-green-800) !important; color: #fff !important; text-decoration: none !important; }
.hp-coverage-map svg { width: 100% !important; height: auto !important; }

/* EXPECTATIONS */
.hp-expectations { background: var(--hp-warm-50) !important; border: 1px solid rgba(0,0,0,.06) !important; border-radius: var(--hp-radius-lg) !important; padding: 36px 40px !important; max-width: 760px !important; margin: 0 auto !important; }
body.page-template-home .hp-expectations h3 { font-family: var(--hp-serif) !important; font-size: 20px !important; font-weight: 600 !important; margin-bottom: 12px !important; color: var(--hp-text-primary) !important; text-align: left !important; }
.hp-expectations p { font-size: 14px !important; line-height: 1.6 !important; color: var(--hp-text-secondary) !important; margin-bottom: 8px !important; font-family: var(--hp-sans) !important; }
.hp-expectations-link { display: inline-flex !important; font-size: 13.5px !important; font-weight: 600 !important; color: var(--hp-green-700) !important; text-decoration: none !important; margin-top: 10px !important; font-family: var(--hp-sans) !important; }

/* ECOSYSTEM */
.hp-ecosystem { background: var(--hp-green-800) !important; padding: 52px 0 !important; color: #fff !important; }
.hp-eco-grid { display: grid !important; grid-template-columns: repeat(4,1fr) !important; gap: 18px !important; }
.hp-eco-card { background: rgba(255,255,255,.06) !important; border: 1px solid rgba(255,255,255,.08) !important; border-radius: var(--hp-radius-md) !important; padding: 26px 20px !important; text-align: center !important; }
.hp-eco-card:hover { background: rgba(255,255,255,.1) !important; transform: translateY(-2px) !important; }
.hp-eco-icon { width: 48px !important; height: 48px !important; margin: 0 auto 12px !important; background: rgba(255,255,255,.08) !important; border-radius: var(--hp-radius-md) !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 22px !important; }
.hp-eco-card h4 { font-size: 14.5px !important; font-weight: 700 !important; margin-bottom: 5px !important; color: #fff !important; font-family: var(--hp-sans) !important; }
.hp-eco-card p { font-size: 12.5px !important; line-height: 1.45 !important; color: var(--hp-text-on-dark-muted) !important; margin-bottom: 12px !important; font-family: var(--hp-sans) !important; }
.hp-eco-link { font-size: 12px !important; font-weight: 600 !important; color: var(--hp-green-300) !important; text-decoration: none !important; }
.hp-eco-link:hover { color: #fff !important; }
.hp-eco-badge { display: inline-block !important; font-size: 10px !important; font-weight: 700 !important; background: rgba(82,183,136,.15) !important; color: var(--hp-green-300) !important; padding: 2px 7px !important; border-radius: 3px !important; margin-top: 5px !important; text-transform: uppercase !important; letter-spacing: .05em !important; }

/* GET INVOLVED */
.hp-involve-grid { display: grid !important; grid-template-columns: repeat(3,1fr) !important; gap: 22px !important; }
.hp-involve-card { background: #fff !important; border: 1px solid rgba(0,0,0,.06) !important; border-radius: var(--hp-radius-md) !important; padding: 26px 22px !important; text-align: center !important; }
.hp-involve-card:hover { box-shadow: 0 4px 12px rgba(15,36,24,.08) !important; transform: translateY(-2px) !important; }
.hp-involve-icon { font-size: 24px !important; margin-bottom: 10px !important; display: block !important; }
.hp-involve-card h4 { font-size: 14.5px !important; font-weight: 700 !important; margin-bottom: 5px !important; font-family: var(--hp-sans) !important; color: var(--hp-text-primary) !important; }
.hp-involve-card p { font-size: 12.5px !important; line-height: 1.45 !important; color: var(--hp-text-secondary) !important; margin-bottom: 12px !important; font-family: var(--hp-sans) !important; }
.hp-involve-link { font-size: 12.5px !important; font-weight: 600 !important; color: var(--hp-green-700) !important; text-decoration: none !important; }
.hp-involve-link:hover { text-decoration: underline !important; }

/* PARTNERS */
.hp-partners { padding: 40px 0 !important; background: var(--hp-warm-50) !important; border-top: 1px solid rgba(0,0,0,.04) !important; }
.hp-partners-split { display: flex !important; align-items: flex-start !important; justify-content: center !important; }
.hp-partners-group { flex: 1 !important; text-align: center !important; padding: 0 32px !important; }
.hp-partners-group-label { font-size: 10.5px !important; font-weight: 700 !important; color: var(--hp-text-muted) !important; text-transform: uppercase !important; letter-spacing: .1em !important; margin-bottom: 14px !important; font-family: var(--hp-sans) !important; }
.hp-partners-names { display: flex !important; align-items: center !important; justify-content: center !important; flex-wrap: wrap !important; }
body.page-template-home a.hp-partner-name { font-size: 13.5px !important; font-weight: 600 !important; color: var(--hp-text-secondary) !important; opacity: .55 !important; padding: 5px 14px !important; text-decoration: none !important; font-family: var(--hp-sans) !important; display: inline-block !important; }
body.page-template-home a.hp-partner-name:hover { opacity: 1 !important; color: var(--hp-green-700) !important; text-decoration: none !important; }
.hp-partners-divider { width: 1px !important; align-self: stretch !important; background: var(--hp-warm-100) !important; flex-shrink: 0 !important; min-height: 60px !important; }
.hp-partners-sub { text-align: center !important; margin-top: 18px !important; font-size: 12px !important; color: var(--hp-text-muted) !important; font-family: var(--hp-sans) !important; }
.hp-partners-sub a { color: var(--hp-green-700) !important; text-decoration: none !important; font-weight: 600 !important; }

/* TOOLKIT + SOCIAL */
.hp-community-strip { background: #fff !important; border-top: 1px solid rgba(0,0,0,.04) !important; padding: 36px 0 !important; }
.hp-community-grid { display: grid !important; grid-template-columns: 1fr auto !important; gap: 40px !important; align-items: center !important; }
.hp-toolkit { display: flex !important; align-items: center !important; gap: 20px !important; background: var(--hp-green-50) !important; border: 1px solid var(--hp-green-100) !important; border-radius: var(--hp-radius-md) !important; padding: 20px 24px !important; }
.hp-toolkit-icon { flex-shrink: 0 !important; width: 44px !important; height: 44px !important; background: var(--hp-green-700) !important; border-radius: var(--hp-radius-sm) !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 20px !important; }
.hp-toolkit-text h4 { font-size: 14px !important; font-weight: 700 !important; color: var(--hp-green-800) !important; margin-bottom: 3px !important; font-family: var(--hp-sans) !important; }
.hp-toolkit-text p { font-size: 12.5px !important; color: var(--hp-text-secondary) !important; line-height: 1.4 !important; margin-bottom: 6px !important; font-family: var(--hp-sans) !important; }
.hp-toolkit-link { font-size: 12.5px !important; font-weight: 600 !important; color: var(--hp-green-700) !important; text-decoration: none !important; }
.hp-social-compact { text-align: right !important; }
.hp-social-label { font-size: 10.5px !important; font-weight: 700 !important; color: var(--hp-text-muted) !important; text-transform: uppercase !important; letter-spacing: .06em !important; margin-bottom: 10px !important; font-family: var(--hp-sans) !important; }
.hp-social-row { display: flex !important; gap: 8px !important; justify-content: flex-end !important; flex-wrap: wrap !important; }
body.page-template-home a.hp-social-btn { width: 38px !important; height: 38px !important; border-radius: 50% !important; display: flex !important; align-items: center !important; justify-content: center !important; text-decoration: none !important; border: 1.5px solid transparent !important; padding: 0 !important; line-height: 1 !important; }
body.page-template-home a.hp-social-btn:hover { transform: translateY(-2px) !important; box-shadow: 0 3px 8px rgba(0,0,0,.1) !important; }
.hp-social-btn svg { width: 18px !important; height: 18px !important; fill: currentColor !important; }
.hp-sb-facebook { background: #e8f0fe !important; color: #1877f2 !important; } .hp-sb-facebook:hover { border-color: #1877f2 !important; }
.hp-sb-instagram { background: #fce4ec !important; color: #c13584 !important; } .hp-sb-instagram:hover { border-color: #c13584 !important; }
.hp-sb-tiktok { background: #f0f0f0 !important; color: #010101 !important; } .hp-sb-tiktok:hover { border-color: #010101 !important; }
.hp-sb-youtube { background: #fde8e8 !important; color: #ff0000 !important; } .hp-sb-youtube:hover { border-color: #ff0000 !important; }
.hp-sb-linkedin { background: #e4f0f8 !important; color: #0a66c2 !important; } .hp-sb-linkedin:hover { border-color: #0a66c2 !important; }
.hp-sb-x { background: #f0f0f0 !important; color: #111 !important; } .hp-sb-x:hover { border-color: #555 !important; }
.hp-sb-pinterest { background: #fde8e8 !important; color: #e60023 !important; } .hp-sb-pinterest:hover { border-color: #e60023 !important; }

/* GRASS */
.hp-grass-zone { height: 80px !important; background: url('../images/grass.png') repeat-x bottom center !important; background-size: auto 80px !important; position: relative !important; }
.hp-grass-zone::before { content: '' !important; position: absolute !important; top: 0 !important; left: 0 !important; right: 0 !important; height: 24px !important; background: linear-gradient(180deg,var(--hp-warm-white) 0%,transparent 100%) !important; pointer-events: none !important; }

/* RESPONSIVE */
@media(max-width:960px) {
  body.page-template-home .hp-hero-layout { grid-template-columns: 1fr !important; gap: 36px !important; }
  body.page-template-home .hp-hero h1 { font-size: 36px !important; }
  .hp-steps-grid { grid-template-columns: repeat(2,1fr) !important; }
  .hp-impact-grid { grid-template-columns: repeat(2,1fr) !important; }
  .hp-eco-grid { grid-template-columns: repeat(2,1fr) !important; }
  .hp-coverage-inner { grid-template-columns: 1fr !important; }
  .hp-community-grid { grid-template-columns: 1fr !important; }
  .hp-social-compact { text-align: left !important; }
  .hp-social-row { justify-content: flex-start !important; }
  .hp-partners-split { flex-direction: column !important; gap: 24px !important; }
  .hp-partners-divider { width: 80% !important; height: 1px !important; min-height: 1px !important; margin: 0 auto !important; }
}
@media(max-width:640px) {
  body.page-template-home .hp-hero { padding: 36px 0 48px !important; }
  body.page-template-home .hp-hero h1 { font-size: 28px !important; }
  .hp-hero-sub { font-size: 15px !important; }
  .hp-hero-ctas { flex-direction: column !important; }
  body.page-template-home a.hp-btn-primary,body.page-template-home a.hp-btn-secondary { width: 100% !important; justify-content: center !important; text-align: center !important; }
  body.page-template-home .hp-zip-form { flex-direction: column !important; }
  .hp-steps-grid { grid-template-columns: 1fr !important; gap: 2px !important; }
  .hp-who-grid { grid-template-columns: 1fr !important; }
  .hp-involve-grid { grid-template-columns: 1fr !important; }
  .hp-eco-grid { grid-template-columns: 1fr !important; }
  .hp-impact-grid { grid-template-columns: repeat(2,1fr) !important; gap: 10px !important; }
  .hp-impact-number { font-size: 28px !important; }
  .hp-section { padding: 48px 0 !important; }
  body.page-template-home .hp-section-header h2 { font-size: 24px !important; }
  .hp-expectations { padding: 22px 18px !important; }
  .hp-hero-trust { gap: 6px !important; }
  .hp-hero-trust span { font-size: 11px !important; padding: 3px 8px !important; }
  .hp-coverage-stats { gap: 16px !important; }
  .hp-cs-num { font-size: 22px !important; }
  body.page-template-home a.hp-partner-name { font-size: 12px !important; padding: 4px 10px !important; }
  .hp-toolkit { flex-direction: column !important; text-align: center !important; gap: 12px !important; }
  .hp-social-row { justify-content: center !important; }
  .hp-grass-zone { height: 60px !important; background-size: auto 60px !important; }
}
