/*
Theme Name: Heart & Hara
Theme URI: https://heartandhara.com
Author: Heart & Hara Home Care
Author URI: https://heartandhara.com
Description: A warm, person-centered custom theme for Heart & Hara Home Care, a Minnesota 245D / HCBS home care agency providing compassionate care along Minnesota's North Shore and across the state. Built to match the Heart & Hara brand: deep navy, Lake Superior teal, pine green, and warm sunrise tones with an elegant serif wordmark. Includes a front-page hero, reusable page templates (Services, Getting Started, Contact), Customizer contact settings, and a responsive mobile nav.
Version: 1.1.5
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: heart-and-hara
*/

/* ============================================================
   HEART & HARA - Brand Design System
   Palette sampled from the official Heart & Hara Home Care logo
   (North Shore scene: navy, Lake Superior teal, pine, sunrise)
   ============================================================ */
:root {
  --hh-navy:         #003C60;  /* primary brand / wordmark navy */
  --hh-navy-deep:    #002B45;  /* footer / topbar */
  --hh-navy-2:       #0A4E78;  /* hover */
  --hh-teal:         #1E7E88;  /* Lake Superior water - links & accents */
  --hh-teal-deep:    #18486C;  /* deep water */
  --hh-water:        #00789C;  /* bright water highlight */
  --hh-pine:         #1E5A2E;  /* pine green */
  --hh-pine-deep:    #184824;
  --hh-sand:         #F4DDB4;  /* sunrise sand */
  --hh-sand-light:   #FCF1DC;  /* pale sunrise */
  --hh-sand-deep:    #E8C79A;

  --hh-bg:           #F1F5F5;  /* soft sky/shore */
  --hh-bg-2:         #E5EEEF;
  --hh-card:         #FFFFFF;
  --hh-ink:          #16303F;  /* deep navy text */
  --hh-muted:        #51646F;
  --hh-line:         #D5E1E2;
  --hh-white:        #FFFFFF;

  --hh-serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --hh-sans:  "Lato", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  --hh-radius:    18px;
  --hh-radius-lg: 28px;
  --hh-radius-pill: 999px;
  --hh-shadow:    0 10px 30px rgba(0, 43, 69, 0.12);
  --hh-shadow-sm: 0 4px 14px rgba(0, 43, 69, 0.09);
  --hh-maxw:      1140px;
}

*,*::before,*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--hh-sans);
  font-size: 18px;
  line-height: 1.7;
  color: var(--hh-ink);
  background: var(--hh-bg);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--hh-teal); text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--hh-navy); }

h1,h2,h3,h4 { font-family: var(--hh-serif); color: var(--hh-navy); font-weight: 600; line-height: 1.12; margin: 0 0 .5em; letter-spacing: .005em; }
h1 { font-size: clamp(2.6rem, 5.2vw, 4rem); }
h2 { font-size: clamp(2rem, 3.6vw, 2.9rem); }
h3 { font-size: clamp(1.35rem, 2vw, 1.7rem); }
p  { margin: 0 0 1.1em; }

.hh-wrap { max-width: var(--hh-maxw); margin: 0 auto; padding: 0 24px; }
.hh-narrow { max-width: 800px; margin: 0 auto; padding: 0 24px; }
.hh-eyebrow { font-family: var(--hh-sans); text-transform: uppercase; letter-spacing: .22em; font-size: .78rem; font-weight: 700; color: var(--hh-teal); margin: 0 0 .8rem; }
.hh-center { text-align: center; }

.hh-btn { display: inline-block; font-family: var(--hh-sans); font-weight: 700; letter-spacing: .02em; font-size: 1rem; padding: 14px 30px; border-radius: var(--hh-radius-pill); border: 2px solid transparent; cursor: pointer; transition: all .2s ease; }
.hh-btn--primary { background: var(--hh-navy); color: var(--hh-sand); }
.hh-btn--primary:hover { background: var(--hh-navy-2); color: var(--hh-sand); transform: translateY(-1px); }
.hh-btn--ghost { background: transparent; color: var(--hh-navy); border-color: var(--hh-teal); }
.hh-btn--ghost:hover { background: var(--hh-teal); color: #fff; }
.hh-btn--light { background: var(--hh-card); color: var(--hh-navy); }
.hh-btn--light:hover { background: var(--hh-sand-light); }

.hh-topbar { background: var(--hh-navy-deep); color: #fff; font-size: .85rem; padding: 7px 0; letter-spacing: .02em; }
.hh-topbar a { color: var(--hh-sand); font-weight: 700; }

.hh-header { position: sticky; top: 0; z-index: 50; background: rgba(255, 255, 255, 0.94); backdrop-filter: blur(8px); border-bottom: 1px solid var(--hh-line); }
.hh-header__inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 12px 24px; max-width: var(--hh-maxw); margin: 0 auto; }
.hh-brand { display: flex; align-items: center; gap: 12px; }
.hh-brand img, .hh-brand svg { height: 62px; width: auto; }
.hh-brand__txt { font-family: var(--hh-serif); font-size: 1.4rem; letter-spacing: .06em; color: var(--hh-navy); text-transform: uppercase; }

.hh-nav ul { list-style: none; display: flex; align-items: center; gap: 32px; margin: 0; padding: 0; }
.hh-nav a { font-family: var(--hh-sans); font-weight: 700; font-size: .82rem; text-transform: uppercase; color: var(--hh-navy); letter-spacing: .085em; }
.hh-nav a:hover { color: var(--hh-teal); }
.hh-nav .current-menu-item > a, .hh-nav .current_page_item > a { color: var(--hh-teal); }
.hh-nav__cta { margin-left: 8px; }

.hh-burger { display: none; background: none; border: 0; cursor: pointer; padding: 8px; }
.hh-burger span { display: block; width: 26px; height: 2.5px; background: var(--hh-navy); margin: 5px 0; border-radius: 2px; transition: .25s; }

.hh-hero { position: relative; overflow: hidden; background: radial-gradient(120% 90% at 88% -10%, var(--hh-sand-light) 0%, transparent 52%), radial-gradient(90% 80% at -10% 115%, var(--hh-bg-2) 0%, transparent 50%), var(--hh-bg); padding: 90px 0 100px; }
.hh-hero__grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 56px; align-items: center; }
.hh-hero h1 { margin-bottom: .25em; }
.hh-hero p.lead { font-size: 1.22rem; color: var(--hh-muted); max-width: 40ch; }
.hh-hero__tag { font-family: var(--hh-serif); font-style: italic; font-size: 1.55rem; color: var(--hh-teal); margin: 0 0 1rem; }
.hh-hero__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 26px; }
.hh-hero__card { background: var(--hh-card); border-radius: var(--hh-radius-lg); box-shadow: var(--hh-shadow); padding: 36px; text-align: center; border: 1px solid var(--hh-line); border-top: 5px solid var(--hh-teal); }
.hh-hero__card h3 { letter-spacing: .12em; text-transform: uppercase; font-family: var(--hh-sans); font-size: .8rem; color: var(--hh-muted); margin-bottom: .2em; }
.hh-hero__card .phone { font-family: var(--hh-serif); font-size: 2.3rem; color: var(--hh-navy); margin: 6px 0; font-weight: 600; }
.hh-hero__card .sub { font-weight: 700; letter-spacing: .1em; font-size: .9rem; color: var(--hh-muted); }
.hh-hero__card hr { border: 0; border-top: 1px solid var(--hh-line); margin: 22px 0; }
.hh-hero__card .contact-line { font-size: .98rem; color: var(--hh-ink); margin: 4px 0; }

.hh-section { padding: 86px 0; }
.hh-section--alt { background: var(--hh-bg-2); }
.hh-section--navy { background: var(--hh-navy); color: #fff; }
.hh-section--navy h2, .hh-section--navy h3 { color: #fff; }
.hh-section--navy .hh-eyebrow { color: var(--hh-sand); opacity: .95; }
.hh-section__head { max-width: 760px; margin: 0 auto 52px; text-align: center; }
.hh-section__head p { color: var(--hh-muted); font-size: 1.12rem; }
.hh-section--navy .hh-section__head p { color: rgba(255,255,255,.9); }

.hh-grid { display: grid; gap: 26px; }
.hh-grid--3 { grid-template-columns: repeat(3, 1fr); }
.hh-grid--2 { grid-template-columns: repeat(2, 1fr); }
.hh-grid--4 { grid-template-columns: repeat(4, 1fr); }

.hh-card { background: var(--hh-card); border: 1px solid var(--hh-line); border-radius: var(--hh-radius); padding: 30px; box-shadow: var(--hh-shadow-sm); transition: transform .2s ease, box-shadow .2s ease; }
.hh-card:hover { transform: translateY(-4px); box-shadow: var(--hh-shadow); }
.hh-card .num { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: 50%; background: var(--hh-sand); color: var(--hh-navy); font-family: var(--hh-serif); font-weight: 700; font-size: 1.3rem; margin-bottom: 14px; }
.hh-card h3 { margin-bottom: .4em; }
.hh-card p { color: var(--hh-muted); margin: 0; font-size: 1rem; }

.hh-pills { display: flex; flex-direction: column; gap: 16px; }
.hh-pill { background: var(--hh-card); border: 1px solid var(--hh-line); border-left: 5px solid var(--hh-pine); color: var(--hh-navy); border-radius: 14px; padding: 15px 26px; text-align: left; font-weight: 700; font-size: 1.02rem; box-shadow: var(--hh-shadow-sm); }

.hh-service { background: var(--hh-card); border: 1px solid var(--hh-line); border-radius: var(--hh-radius); padding: 34px; box-shadow: var(--hh-shadow-sm); }
.hh-service h3 { color: var(--hh-teal-deep); }
.hh-service ul { margin: 14px 0 0; padding: 0; list-style: none; }
.hh-service li { padding: 12px 0 12px 30px; position: relative; border-bottom: 1px solid var(--hh-line); color: var(--hh-ink); font-size: 1.02rem; }
.hh-service li:last-child { border-bottom: 0; }
.hh-service li strong { display: block; }
.hh-service li span { color: var(--hh-muted); font-weight: 400; font-size: .96rem; }
.hh-service li::before { content: ""; position: absolute; left: 4px; top: 20px; width: 10px; height: 10px; border-radius: 50%; background: var(--hh-teal); }

.hh-cta { background: radial-gradient(110% 130% at 100% 0%, var(--hh-teal) 0%, transparent 55%), radial-gradient(90% 120% at 0% 100%, var(--hh-pine) 0%, transparent 50%), var(--hh-navy); color: #fff; border-radius: var(--hh-radius-lg); padding: 56px; text-align: center; }
.hh-cta h2 { color: #fff; }
.hh-cta .hh-eyebrow { color: var(--hh-sand); }
.hh-cta p { color: rgba(255,255,255,.95); max-width: 60ch; margin-left: auto; margin-right: auto; }
.hh-cta .phone-big { font-family: var(--hh-serif); font-size: clamp(2.2rem,4vw,3rem); margin: 10px 0 4px; font-weight: 600; }

.hh-note { background: var(--hh-sand-light); border-left: 4px solid var(--hh-sand-deep); border-radius: 12px; padding: 20px 24px; color: var(--hh-ink); font-size: 1rem; }

.hh-page-hero { background: radial-gradient(110% 90% at 90% -20%, var(--hh-sand-light) 0%, transparent 52%), var(--hh-bg-2); padding: 74px 0 60px; text-align: center; }
.hh-content { padding: 70px 0; }
.hh-content :where(h2,h3) { margin-top: 1.4em; }
.hh-content ul, .hh-content ol { padding-left: 1.3em; }
.hh-content blockquote { border-left: 4px solid var(--hh-teal); margin: 1.4em 0; padding: .4em 1.2em; color: var(--hh-muted); font-style: italic; font-family: var(--hh-serif); font-size: 1.3rem; }

.hh-contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 44px; align-items: start; }
.hh-contact-card { background: var(--hh-card); border:1px solid var(--hh-line); border-radius: var(--hh-radius); padding: 30px; box-shadow: var(--hh-shadow-sm); }
.hh-contact-item { display:flex; gap:14px; align-items:flex-start; padding: 14px 0; border-bottom:1px solid var(--hh-line); }
.hh-contact-item:last-child { border-bottom:0; }
.hh-contact-item .ico { color: var(--hh-teal); flex: 0 0 auto; margin-top:3px; font-size: 1.1rem; }
.hh-contact-item strong { display:block; }

.hh-footer { background: var(--hh-navy-deep); color: #C9D8DC; padding: 64px 0 28px; }
.hh-footer a { color: var(--hh-sand); }
.hh-footer a:hover { color: #fff; }
.hh-footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 40px; }
.hh-footer h4 { color: #fff; font-family: var(--hh-sans); text-transform: uppercase; letter-spacing: .14em; font-size: .82rem; }
.hh-footer ul { list-style: none; padding: 0; margin: 0; }
.hh-footer li { margin: 8px 0; }
.hh-footer .brandline { font-family: var(--hh-serif); font-size: 1.8rem; color:#fff; letter-spacing:.08em; text-transform: uppercase; }
.hh-footer .tagline { font-family: var(--hh-serif); font-style: italic; color: var(--hh-sand); margin-top: 2px; }
.hh-footer__bottom { border-top: 1px solid rgba(255,255,255,.14); margin-top: 44px; padding-top: 20px; display:flex; flex-wrap:wrap; gap:10px; justify-content: space-between; font-size: .85rem; color: #8FA4AB; }

@media (max-width: 960px) {
  .hh-hero__grid { grid-template-columns: 1fr; gap: 36px; }
  .hh-grid--3, .hh-grid--4 { grid-template-columns: repeat(2, 1fr); }
  .hh-footer__grid { grid-template-columns: 1fr 1fr; }
  .hh-contact-grid { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  body { font-size: 17px; }
  .hh-brand img, .hh-brand svg { height: 62px; }
  .hh-burger { display: block; }
  .hh-nav { position: absolute; top: 100%; right: 0; left: 0; background: var(--hh-white); border-bottom: 1px solid var(--hh-line); display: none; padding: 12px 0; }
  .hh-nav.is-open { display: block; }
  .hh-nav ul { flex-direction: column; align-items: stretch; gap: 0; }
  .hh-nav li { padding: 0 24px; }
  .hh-nav a { display: block; padding: 12px 0; border-bottom: 1px solid var(--hh-line); }
  .hh-nav__cta { margin: 12px 24px; }
  .hh-grid--3, .hh-grid--4, .hh-grid--2 { grid-template-columns: 1fr; }
  .hh-footer__grid { grid-template-columns: 1fr; }
  .hh-cta { padding: 40px 24px; }
}
.aligncenter { margin-left:auto; margin-right:auto; }
.screen-reader-text { position:absolute; left:-9999px; }

/* forms link in nav */
.hh-nav__forms { color: var(--hh-navy); }
.hh-nav__forms:hover { color: var(--hh-teal); }
@media (max-width: 720px) {
  .hh-nav__forms { display:block; padding: 12px 24px; border-bottom: 1px solid var(--hh-line); }
}

/* large homepage hero logo */
.hh-hero__logo { margin: 0 0 10px; }
.hh-hero__logo img { width: 100%; max-width: 380px; height: auto; }
@media (max-width: 960px) {
  .hh-hero { text-align: center; }
  .hh-hero__logo img { margin-left: auto; margin-right: auto; }
  .hh-hero p.lead { margin-left: auto; margin-right: auto; }
  .hh-hero__cta { justify-content: center; }
}

/* keep the nav "Get Started" CTA legible: white text over the navy button
   (overrides .hh-nav a navy color, which otherwise wins on specificity) */
.hh-nav a.hh-btn--primary,
.hh-nav a.hh-btn--primary:hover,
.hh-nav a.hh-btn--primary:focus { color: var(--hh-sand); }

/* ---- cleaner top bar + main menu ---- */
.hh-topbar__inner { max-width: var(--hh-maxw); margin: 0 auto; padding: 0 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.hh-topbar__msg { color: #DCE8EA; }
.hh-topbar__links { display: flex; align-items: center; gap: 22px; }
.hh-topbar__links a { color: var(--hh-sand); font-weight: 700; }
.hh-topbar__links a:hover { color: #fff; }

/* animated underline on the primary menu items (not the CTA button) */
.hh-nav ul a { position: relative; padding: 6px 0; }
.hh-nav ul a::after { content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 2px; background: var(--hh-teal); border-radius: 2px; transform: scaleX(0); transform-origin: center; transition: transform .22s ease; }
.hh-nav ul a:hover::after,
.hh-nav .current-menu-item > a::after,
.hh-nav .current_page_item > a::after { transform: scaleX(1); }

@media (max-width: 720px) {
  .hh-topbar__inner { justify-content: center; }
  .hh-topbar__msg { display: none; }
  .hh-nav ul a::after { display: none; }
}

/* ---- native contact form ---- */
.hh-form { display: grid; gap: 18px; }
.hh-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.hh-field { display: flex; flex-direction: column; gap: 6px; }
.hh-field label { font-weight: 700; font-size: .9rem; color: var(--hh-navy); }
.hh-field label .req { color: var(--hh-teal); }
.hh-field label .opt { color: var(--hh-muted); font-weight: 400; font-size: .82rem; }
.hh-field input, .hh-field textarea {
	font-family: var(--hh-sans); font-size: 1rem; color: var(--hh-ink); background: #fff;
	border: 1.5px solid var(--hh-line); border-radius: 12px; padding: 12px 14px;
	transition: border-color .15s ease, box-shadow .15s ease; width: 100%;
}
.hh-field input:focus, .hh-field textarea:focus {
	outline: none; border-color: var(--hh-teal); box-shadow: 0 0 0 3px rgba(30,126,136,.16);
}
.hh-field textarea { resize: vertical; min-height: 140px; line-height: 1.6; }
.hh-form button[type="submit"] { justify-self: start; margin-top: 2px; }
.hh-form__hint { font-size: .88rem; color: var(--hh-muted); margin: 4px 0 0; }
.hh-hp { position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; }

.hh-alert { border-radius: 12px; padding: 14px 18px; margin-bottom: 20px; font-size: .98rem; line-height: 1.55; }
.hh-alert--ok { background: #E7F3EC; border-left: 4px solid var(--hh-pine); color: #1C4F2A; }
.hh-alert--ok a { color: #1C4F2A; text-decoration: underline; }
.hh-alert--err { background: #FBEAE6; border-left: 4px solid #C0563E; color: #8C3724; }
.hh-alert--err a { color: #8C3724; text-decoration: underline; }

/* ---- embedded (Fillout) referral form ---- */
.hh-embed { background: var(--hh-card); border: 1px solid var(--hh-line); border-radius: var(--hh-radius); box-shadow: var(--hh-shadow-sm); overflow: hidden; }
.hh-embed iframe { width: 100% !important; height: 82vh; min-height: 800px; border: 0; display: block; }

@media (max-width: 560px) {
	.hh-form__row { grid-template-columns: 1fr; }
	.hh-embed iframe { min-height: 680px; }
}


/* ---- main-menu dropdown submenus ---- */
.hh-nav li { position: relative; }
.hh-nav .menu-item-has-children > a { position: relative; padding-right: 18px; }
.hh-nav .menu-item-has-children > a::before {
	content: ""; position: absolute; right: 2px; top: 45%; width: 6px; height: 6px;
	border-right: 2px solid currentColor; border-bottom: 2px solid currentColor;
	transform: translateY(-50%) rotate(45deg); opacity: .6;
}
.hh-nav ul ul, .hh-nav .sub-menu {
	display: none; position: absolute; top: calc(100% + 10px); left: 50%; transform: translateX(-50%);
	min-width: 210px; background: #fff; border: 1px solid var(--hh-line); border-radius: 14px;
	box-shadow: var(--hh-shadow); padding: 8px 0; flex-direction: column; align-items: stretch; gap: 0; z-index: 60;
}
.hh-nav li:hover > ul, .hh-nav li:focus-within > ul { display: flex; }
.hh-nav ul ul li { padding: 0; }
.hh-nav ul ul a { display: block; padding: 10px 20px; text-transform: none; letter-spacing: .01em; font-size: .92rem; white-space: nowrap; }
.hh-nav ul ul a::after { display: none; }
.hh-nav ul ul a:hover { color: var(--hh-teal); background: var(--hh-bg); }

@media (max-width: 720px) {
	.hh-nav ul ul, .hh-nav .sub-menu {
		position: static; transform: none; display: block; box-shadow: none; border: 0;
		border-radius: 0; padding: 0 0 6px 18px; min-width: 0; background: transparent;
	}
	.hh-nav .menu-item-has-children > a::before { display: none; }
	.hh-nav ul ul a { padding: 10px 24px; }
}

/* ---- hero: logo + contact box level on top, centered intro below ---- */
.hh-hero__top { display: flex; align-items: center; justify-content: space-between; gap: 40px; margin-bottom: 46px; }
.hh-hero__top .hh-hero__logo { margin: 0; flex: 0 1 auto; }
.hh-hero__logo img { width: 100%; max-width: 380px; height: auto; }
.hh-hero__top .hh-hero__card { flex: 0 0 auto; width: 100%; max-width: 330px; }
.hh-hero__intro { max-width: 880px; margin: 0 auto; }
.hh-hero__intro .lead { margin-left: auto; margin-right: auto; max-width: 64ch; }
.hh-hero__intro .hh-hero__cta { justify-content: center; }
@media (max-width: 820px) {
	.hh-hero__top { flex-direction: column; text-align: center; gap: 26px; }
	.hh-hero__top .hh-hero__card { margin: 0 auto; }
	.hh-hero__logo img { max-width: 320px; }
}

/* ---- services page: service cards + resources ---- */
.hh-cardgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.hh-scard { background: var(--hh-card); border: 1px solid var(--hh-line); border-radius: var(--hh-radius); padding: 30px; box-shadow: var(--hh-shadow-sm); transition: transform .2s ease, box-shadow .2s ease; display: flex; flex-direction: column; }
.hh-scard:hover { transform: translateY(-4px); box-shadow: var(--hh-shadow); }
.hh-scard__ico { width: 58px; height: 58px; border-radius: 16px; background: var(--hh-bg-2); color: var(--hh-teal); display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.hh-scard__ico svg { width: 28px; height: 28px; }
.hh-scard h3 { color: var(--hh-navy); font-size: 1.28rem; margin-bottom: .4em; }
.hh-scard p { color: var(--hh-muted); margin: 0 0 16px; font-size: 1rem; }
.hh-scard__tag { align-self: flex-start; margin-top: auto; font-size: .68rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--hh-teal-deep); background: var(--hh-sand-light); padding: 5px 12px; border-radius: var(--hh-radius-pill); }

.hh-reslist { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.hh-resitem { display: flex; gap: 14px; align-items: flex-start; padding: 20px 22px; background: var(--hh-card); border: 1px solid var(--hh-line); border-radius: 14px; box-shadow: var(--hh-shadow-sm); transition: transform .18s ease, box-shadow .18s ease; }
.hh-resitem:hover { transform: translateY(-2px); box-shadow: var(--hh-shadow); }
.hh-resitem .ico { color: var(--hh-teal); flex: 0 0 auto; margin-top: 2px; }
.hh-resitem__txt strong { display: block; color: var(--hh-navy); font-size: 1.04rem; margin-bottom: 3px; }
.hh-resitem__txt span { color: var(--hh-muted); font-size: .92rem; line-height: 1.5; }

@media (max-width: 960px) { .hh-cardgrid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .hh-cardgrid, .hh-reslist { grid-template-columns: 1fr; } }

/* ---- helpful links: categorized resource groups ---- */
.hh-linkcat { margin-bottom: 46px; }
.hh-linkcat:last-child { margin-bottom: 0; }
.hh-linkcat__head { display: flex; align-items: center; gap: 14px; margin-bottom: 20px; padding-bottom: 12px; border-bottom: 2px solid var(--hh-line); }
.hh-linkcat__ico { width: 44px; height: 44px; border-radius: 12px; background: var(--hh-bg-2); color: var(--hh-teal); display: flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.hh-linkcat__ico svg { width: 22px; height: 22px; }
.hh-linkcat__head h2 { margin: 0; font-size: 1.5rem; }
/* ---- numbered process steps (Begin the Process) ---- */
.hh-steps { display: flex; flex-direction: column; gap: 18px; max-width: 840px; margin: 0 auto; }
.hh-step { display: flex; gap: 20px; align-items: flex-start; background: var(--hh-card); border: 1px solid var(--hh-line); border-radius: var(--hh-radius); padding: 24px 28px; box-shadow: var(--hh-shadow-sm); }
.hh-step__n { flex: 0 0 auto; width: 46px; height: 46px; border-radius: 50%; background: var(--hh-navy); color: var(--hh-sand); font-family: var(--hh-serif); font-weight: 700; font-size: 1.35rem; display: flex; align-items: center; justify-content: center; }
.hh-step h3 { color: var(--hh-navy); margin: 2px 0 .3em; font-size: 1.25rem; }
.hh-step p { margin: 0; color: var(--hh-muted); }
.hh-step a { font-weight: 700; }
/* two-column service/payment card grid */
.hh-cardgrid--2 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 640px) { .hh-cardgrid--2 { grid-template-columns: 1fr; } }

/* ---- approach: framed square photo cards (Care built around the person) ---- */
.hh-approach { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.hh-approach__item { margin: 0; border-radius: var(--hh-radius); overflow: hidden; border: 5px solid #fff; box-shadow: var(--hh-shadow); background: #fff; }
.hh-approach__item img { width: 100%; height: auto; aspect-ratio: 1 / 1; object-fit: cover; display: block; }
@media (max-width: 900px) { .hh-approach { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .hh-approach { grid-template-columns: 1fr; max-width: 400px; margin: 0 auto; } }

/* ---- caregiver training: course number + CareCertify band ---- */
.hh-coursenum { font-family: var(--hh-serif); font-weight: 700; font-size: 1.5rem; color: var(--hh-navy); }
.hh-scard__ico .hh-coursenum { line-height: 1; }
.hh-cc { background: var(--hh-card); border: 1px solid var(--hh-line); border-radius: var(--hh-radius-lg); box-shadow: var(--hh-shadow-sm); padding: 46px 40px; text-align: center; max-width: 760px; margin: 0 auto; }
.hh-cc img { width: 100%; max-width: 360px; height: auto; margin: 6px auto 20px; }
