/*
 * Caritas / CDJP Gikongoro full-width shell (home + Who we are).
 * Loaded on the front page and the Who We Are page; also in the block editor for HTML block preview.
 */
.caritas-static-home,
.caritas-static-home *,
.caritas-static-home *::before,
.caritas-static-home *::after {
	box-sizing: border-box;
}

:root {
	--blue:        #3AACDC;
	--blue-dark:   #1F7EA8;
	--blue-light:  #D6F0FA;
	--blue-mid:    #2196C4;
	--green:       #4CAF50;
	--green-dark:  #388E3C;
	--green-light: #E8F5E9;
	--white:       #FFFFFF;
	--light-bg:    #F4F8FB;
	--dark:        #1C2B36;
	--dark-mid:    #2E4053;
	--border:      #D6E4EE;
	--text:        #2C3E50;
	--text-muted:  #6B8A9A;
	--section-pad: 5rem 2rem;
}

html { scroll-behavior: smooth; }

body.caritas-static-home-page,
.editor-styles-wrapper .caritas-static-home,
.caritas-static-home {
	font-family: 'DM Sans', sans-serif;
	background: var(--white);
	color: var(--text);
	overflow-x: hidden;
}

/* ---- NAV ---- */
.caritas-static-home nav {
	position: fixed; top: 0; width: 100%; z-index: 100;
	display: flex; align-items: center; justify-content: space-between;
	padding: 0 3rem; background: var(--dark); height: 68px;
	border-bottom: 3px solid var(--blue);
}
body.admin-bar .caritas-static-home nav {
	top: 32px;
}
@media screen and (max-width: 782px) {
	body.admin-bar .caritas-static-home nav {
		top: 46px;
	}
}
.caritas-static-home .nav-logo-text { font-family: 'Playfair Display', serif; color: var(--white); font-size: 1.05rem; letter-spacing: 0.02em; line-height: 1.2; }
.caritas-static-home .nav-logo-sub { color: var(--blue); display: block; font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; font-family: 'DM Sans', sans-serif; margin-top: 1px; }
.caritas-static-home .nav-links { display: flex; list-style: none; height: 68px; }
.caritas-static-home .nav-links li { display: flex; }
.caritas-static-home .nav-links a { color: rgba(255,255,255,0.75); text-decoration: none; font-size: 0.8rem; letter-spacing: 0.05em; text-transform: uppercase; padding: 0 1.1rem; display: flex; align-items: center; border-bottom: 3px solid transparent; margin-bottom: -3px; transition: all 0.2s; }
.caritas-static-home .nav-links a:hover, .caritas-static-home .nav-links a.active { color: var(--white); border-bottom-color: var(--blue); }
.caritas-static-home .nav-cta { background: var(--green); color: var(--white); padding: 0.5rem 1.4rem; border-radius: 3px; font-size: 0.78rem; font-weight: 500; text-decoration: none; letter-spacing: 0.06em; text-transform: uppercase; transition: background 0.2s; white-space: nowrap; }
.caritas-static-home .nav-cta:hover { background: var(--green-dark); }

/* ---- HERO ---- */
.caritas-static-home .hero { min-height: 100vh; position: relative; overflow: hidden; display: flex; align-items: center; padding-top: 68px; }
body.admin-bar .caritas-static-home .hero { padding-top: 100px; }
@media screen and (max-width: 782px) {
	body.admin-bar .caritas-static-home .hero { padding-top: 114px; }
}
.caritas-static-home .hero-slides { position: absolute; inset: 0; }
.caritas-static-home .hero-slide { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: 0; transition: opacity 1.2s ease; }
.caritas-static-home .hero-slide.active { opacity: 1; }
.caritas-static-home .hero-slide::after { content: ''; position: absolute; inset: 0; background: linear-gradient(110deg, rgba(28,43,54,0.92) 40%, rgba(58,172,220,0.35) 100%); }
.caritas-static-home .hero-content { position: relative; z-index: 2; max-width: 1200px; margin: 0 auto; padding: 4rem 3rem; width: 100%; }
.caritas-static-home .hero-tag { display: inline-flex; align-items: center; gap: 0.6rem; background: var(--blue); color: var(--white); font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase; padding: 0.4rem 1rem; border-radius: 3px; margin-bottom: 1.75rem; }
.caritas-static-home .hero h1 { font-family: 'Playfair Display', serif; font-size: clamp(2.6rem, 5.5vw, 4.4rem); color: var(--white); line-height: 1.12; margin-bottom: 1.25rem; font-weight: 700; max-width: 700px; }
.caritas-static-home .hero h1 em { color: var(--blue); font-style: normal; }
.caritas-static-home .hero p { font-size: 1.05rem; color: rgba(255,255,255,0.68); line-height: 1.9; max-width: 560px; margin-bottom: 2.5rem; }
.caritas-static-home .hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 4rem; }
.caritas-static-home .btn-blue { background: var(--blue); color: var(--white); padding: 0.85rem 2.2rem; font-weight: 500; font-size: 0.85rem; letter-spacing: 0.07em; text-transform: uppercase; text-decoration: none; border-radius: 3px; border: 2px solid var(--blue); transition: all 0.2s; }
.caritas-static-home .btn-blue:hover { background: var(--blue-dark); border-color: var(--blue-dark); }
.caritas-static-home .btn-green { background: var(--green); color: var(--white); padding: 0.85rem 2.2rem; font-weight: 500; font-size: 0.85rem; letter-spacing: 0.07em; text-transform: uppercase; text-decoration: none; border-radius: 3px; border: 2px solid var(--green); transition: all 0.2s; }
.caritas-static-home .btn-green:hover { background: var(--green-dark); border-color: var(--green-dark); }
.caritas-static-home .btn-ghost { border: 2px solid rgba(255,255,255,0.45); color: var(--white); padding: 0.85rem 2.2rem; font-size: 0.85rem; letter-spacing: 0.07em; text-transform: uppercase; text-decoration: none; border-radius: 3px; transition: all 0.2s; }
.caritas-static-home .btn-ghost:hover { border-color: var(--white); background: rgba(255,255,255,0.08); }
.caritas-static-home .hero-stats { display: flex; gap: 2.5rem; flex-wrap: wrap; padding-top: 2.5rem; border-top: 1px solid rgba(255,255,255,0.15); }
.caritas-static-home .hero-stat strong { display: block; font-family: 'Playfair Display', serif; font-size: 2.2rem; color: var(--blue); font-weight: 700; }
.caritas-static-home .hero-stat span { font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.45); }
.caritas-static-home .hero-dots { position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%); z-index: 3; display: flex; gap: 0.5rem; }
.caritas-static-home .dot { width: 8px; height: 8px; border-radius: 50%; border: 2px solid rgba(255,255,255,0.4); cursor: pointer; transition: all 0.3s; }
.caritas-static-home .dot.active { background: var(--blue); border-color: var(--blue); }

/* ---- INNER PAGE HERO (Who we are) ---- */
.caritas-static-home .page-hero {
	position: relative;
	min-height: 320px;
	display: flex;
	align-items: flex-end;
	padding: 7rem 2rem 3rem;
	margin-top: 68px;
	background-size: cover;
	background-position: center;
}
body.admin-bar .caritas-static-home .page-hero { margin-top: 100px; }
@media screen and (max-width: 782px) {
	body.admin-bar .caritas-static-home .page-hero { margin-top: 114px; }
}
.caritas-static-home .page-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(110deg, rgba(28,43,54,0.92) 40%, rgba(58,172,220,0.35) 100%);
}
.caritas-static-home .page-hero-inner {
	position: relative;
	z-index: 2;
	max-width: 1200px;
	margin: 0 auto;
	width: 100%;
	padding: 0 1rem;
}
.caritas-static-home .page-hero .section-label { color: rgba(255,255,255,0.9); margin-bottom: 0.75rem; }
.caritas-static-home .page-hero .section-label::before { background: var(--blue); }
.caritas-static-home .page-hero-title {
	font-family: 'Playfair Display', serif;
	font-size: clamp(1.85rem, 4vw, 3.1rem);
	color: var(--white);
	line-height: 1.15;
	margin: 0;
	font-weight: 700;
	max-width: 900px;
}
.caritas-static-home .page-hero-title em { color: var(--blue); font-style: normal; }

/* ---- WHO PAGE CONTENT ---- */
.caritas-static-home .who-page-content {
	background: var(--white);
	padding: var(--section-pad);
}
.caritas-static-home .who-page-inner {
	max-width: 900px;
	margin: 0 auto;
}
.caritas-static-home .who-photo-wrap { margin: 0 0 1.5rem; }
.caritas-static-home .who-feature-img {
	width: 100%;
	max-height: 440px;
	object-fit: cover;
	border-radius: 4px;
	display: block;
	box-shadow: 0 14px 40px rgba(28,43,54,0.1);
}
.caritas-static-home .who-section-heading {
	font-size: 0.78rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--blue-mid);
	font-weight: 600;
	margin: 0 0 1rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid var(--border);
}
.caritas-static-home .who-prose-block { margin-bottom: 2.75rem; }
.caritas-static-home .who-prose {
	font-size: 0.95rem;
	color: var(--text-muted);
	line-height: 1.85;
}
.caritas-static-home .who-prose p { margin: 0 0 1rem; }
.caritas-static-home .who-vmv-trio { margin-bottom: 2.5rem; }
.caritas-static-home .who-vmv-pair {
	grid-template-columns: repeat(2, 1fr);
	margin-top: 2rem;
}
.caritas-static-home .who-cdjp-label { margin-top: 1rem; }
.caritas-static-home .who-cdjp-intro { margin-bottom: 0.5rem; }
.caritas-static-home .who-cdjp-intro .sec-title { margin-top: 0.5rem; }
.caritas-static-home .who-intro-lead { max-width: none; margin-bottom: 1.25rem; }

/* ---- NEWS INNER PAGE ---- */
.caritas-static-home .news-page-section .news-page-head { justify-content: flex-start; align-items: flex-start; }
.caritas-static-home .news-page-lead { max-width: 640px; margin-top: 0.75rem; }

/* ---- CONTACT INNER PAGE ---- */
.caritas-static-home .contact-page-shell { background: var(--white); padding: var(--section-pad); }
.caritas-static-home .contact-page-inner { max-width: 1200px; margin: 0 auto; }
.caritas-static-home .contact-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 3rem; align-items: start; }
.caritas-static-home .contact-main .section-label { margin-bottom: 0.5rem; }
.caritas-static-home .contact-body-html { font-size: 0.95rem; color: var(--text-muted); line-height: 1.85; }
.caritas-static-home .contact-body-html p { margin: 0 0 1rem; }
.caritas-static-home .contact-body-html a { color: var(--blue-mid); text-decoration: none; }
.caritas-static-home .contact-body-html a:hover { text-decoration: underline; }
.caritas-static-home .contact-side-img { width: 100%; max-height: 440px; object-fit: cover; border-radius: 4px; display: block; box-shadow: 0 14px 40px rgba(28,43,54,0.1); }

/* ---- TEAM PAGE ---- */
.caritas-static-home .team-page-shell { background: var(--white); padding: var(--section-pad); }
.caritas-static-home .team-page-inner { max-width: 1200px; margin: 0 auto; }
.caritas-static-home .team-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1.25rem;
	margin-top: 1.5rem;
}
.caritas-static-home .team-card {
	background: var(--white);
	border: 1px solid var(--border);
	border-radius: 4px;
	overflow: hidden;
	transition: transform .2s, box-shadow .2s;
}
.caritas-static-home .team-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 14px 36px rgba(58,172,220,0.12);
}
.caritas-static-home .team-card-img { height: 240px; overflow: hidden; background: var(--light-bg); }
.caritas-static-home .team-card-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.caritas-static-home .team-card-body { padding: 1rem 1.1rem 1.2rem; }
.caritas-static-home .team-card-body h3 {
	font-family: 'Playfair Display', serif;
	font-size: 1.05rem;
	color: var(--dark);
	margin: 0 0 0.35rem;
}
.caritas-static-home .team-role {
	font-size: 0.68rem;
	letter-spacing: 0.13em;
	text-transform: uppercase;
	color: var(--blue-mid);
	font-weight: 600;
	margin-bottom: 0.6rem;
}
.caritas-static-home .team-card-body p { font-size: 0.82rem; color: var(--text-muted); line-height: 1.65; margin: 0 0 0.8rem; }
.caritas-static-home .team-meta { display: flex; flex-direction: column; gap: 0.25rem; }
.caritas-static-home .team-meta a,
.caritas-static-home .team-meta span { font-size: 0.77rem; color: var(--text-muted); text-decoration: none; }
.caritas-static-home .team-meta a:hover { color: var(--blue-mid); text-decoration: underline; }

/* ---- STORY DETAIL PAGE ---- */
.caritas-static-home .story-layout { background: var(--white); padding: var(--section-pad); }
.caritas-static-home .story-layout-inner {
	max-width: 1200px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: minmax(0, 1.9fr) minmax(280px, 1fr);
	gap: 1.5rem;
}
.caritas-static-home .story-content {
	background: #fff;
	border: 1px solid var(--border);
	border-radius: 6px;
	padding: 1.2rem 1.25rem;
}
.caritas-static-home .story-byline {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.45rem;
	font-size: 0.76rem;
	color: #64748b;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	margin-bottom: 0.8rem;
}
.caritas-static-home .story-byline-author { color: #0f172a; font-weight: 600; }
.caritas-static-home .story-byline-sep { opacity: 0.4; }
.caritas-static-home .story-featured-quote {
	margin: 0 0 1rem;
	padding: 0.85rem 1rem;
	border-left: 3px solid var(--blue);
	background: #f8fafc;
	color: #334155;
	font-size: 0.92rem;
	line-height: 1.7;
	font-style: italic;
}
.caritas-static-home .story-content h2,
.caritas-static-home .story-content h3 { margin: 0.8rem 0 0.45rem; color: var(--dark); }
.caritas-static-home .story-content p,
.caritas-static-home .story-content li { color: var(--text-muted); line-height: 1.8; font-size: 0.95rem; }
.caritas-static-home .story-meta-card {
	background: var(--light-bg);
	border: 1px solid var(--border);
	border-top: 3px solid var(--blue);
	border-radius: 6px;
	padding: 1rem;
	position: sticky;
	top: 92px;
}
.caritas-static-home .story-meta-card h3 {
	margin: 0 0 0.75rem;
	font-family: 'Playfair Display', serif;
	font-size: 1.1rem;
	color: var(--dark);
}
.caritas-static-home .story-meta-card p { margin: 0 0 0.85rem; font-size: 0.85rem; color: var(--text-muted); line-height: 1.65; }
.caritas-static-home .story-meta-card a { color: var(--blue-mid); text-decoration: none; }
.caritas-static-home .story-meta-card a:hover { text-decoration: underline; }
.caritas-static-home .story-related { background: var(--light-bg); padding: 2.2rem 2rem 3.5rem; }
.caritas-static-home .story-related-inner { max-width: 1200px; margin: 0 auto; }
.caritas-static-home .story-related-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; }
.caritas-static-home .story-badges { display: flex; flex-wrap: wrap; gap: 0.45rem; margin-top: 0.9rem; }
.caritas-static-home .story-badge {
	display: inline-flex;
	align-items: center;
	background: rgba(58,172,220,0.18);
	border: 1px solid rgba(58,172,220,0.4);
	color: #fff;
	padding: 0.28rem 0.56rem;
	font-size: 0.7rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	border-radius: 999px;
}
.caritas-static-home .story-related-card {
	background: #fff;
	border: 1px solid var(--border);
	border-radius: 6px;
	padding: 1rem;
}
.caritas-static-home .story-related-card h4 {
	margin: 0 0 0.5rem;
	font-family: 'Playfair Display', serif;
	font-size: 1.05rem;
	color: var(--dark);
}
.caritas-static-home .story-related-card p { margin: 0; font-size: 0.84rem; color: var(--text-muted); line-height: 1.6; }

/* ---- UTILS ---- */
.caritas-static-home .section-label { display: inline-flex; align-items: center; gap: 0.5rem; font-size: 0.67rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--blue-mid); margin-bottom: 0.6rem; font-weight: 500; }
.caritas-static-home .section-label::before { content: ''; width: 26px; height: 2px; background: var(--blue-mid); }
.caritas-static-home h2.sec-title { font-family: 'Playfair Display', serif; font-size: clamp(1.8rem, 3.5vw, 2.7rem); color: var(--dark); line-height: 1.2; margin-bottom: 1rem; }
.caritas-static-home .sec-lead { font-size: 1rem; color: var(--text-muted); line-height: 1.85; max-width: 600px; }
.caritas-static-home .btn-outline-blue { display: inline-flex; align-items: center; border: 2px solid var(--blue); color: var(--blue-mid); padding: 0.7rem 1.8rem; border-radius: 3px; font-size: 0.82rem; font-weight: 500; letter-spacing: 0.07em; text-transform: uppercase; text-decoration: none; transition: all 0.2s; }
.caritas-static-home .btn-outline-blue:hover { background: var(--blue); color: var(--white); }
.caritas-static-home .btn-outline-green { display: inline-flex; align-items: center; border: 2px solid var(--green); color: var(--green-dark); padding: 0.7rem 1.8rem; border-radius: 3px; font-size: 0.82rem; font-weight: 500; letter-spacing: 0.07em; text-transform: uppercase; text-decoration: none; transition: all 0.2s; }
.caritas-static-home .btn-outline-green:hover { background: var(--green); color: var(--white); }

/* ---- SERVICES STRIP ---- */
.caritas-static-home .services-strip { background: var(--blue); }
.caritas-static-home .strip-inner { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: repeat(4,1fr); }
.caritas-static-home .srv-item { padding: 2rem 1.5rem; border-right: 1px solid rgba(255,255,255,0.18); text-align: center; transition: background 0.2s; }
.caritas-static-home .srv-item:last-child { border-right: none; }
.caritas-static-home .srv-item:hover { background: var(--blue-dark); }
.caritas-static-home .srv-icon { font-size: 1.8rem; margin-bottom: 0.6rem; display: block; }
.caritas-static-home .srv-item h4 { color: var(--white); font-size: 0.88rem; font-weight: 500; margin-bottom: 0.25rem; }
.caritas-static-home .srv-item h4 a { color: inherit; text-decoration: none; }
.caritas-static-home .srv-item h4 a:hover { text-decoration: underline; }
.caritas-static-home .srv-item p { color: rgba(255,255,255,0.65); font-size: 0.75rem; line-height: 1.5; }

/* ---- ABOUT ---- */
.caritas-static-home .about { background: var(--white); padding: var(--section-pad); }
.caritas-static-home .about-grid { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.caritas-static-home .about-img-wrap { position: relative; }
.caritas-static-home .about-img-wrap img { width: 100%; height: 460px; object-fit: cover; border-radius: 4px; display: block; }
.caritas-static-home .about-accent { position: absolute; bottom: -1.5rem; right: -1.5rem; background: var(--dark); color: var(--white); padding: 1.75rem; text-align: center; min-width: 145px; border-top: 4px solid var(--blue); }
.caritas-static-home .about-accent strong { font-family: 'Playfair Display', serif; font-size: 2.2rem; display: block; color: var(--blue); }
.caritas-static-home .about-accent span { font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.7; }
.caritas-static-home .pillars { display: flex; flex-direction: column; gap: 0.85rem; margin: 1.5rem 0 2rem; }
.caritas-static-home .pillar { display: flex; align-items: flex-start; gap: 1rem; padding: 1rem 1.25rem; background: var(--light-bg); border-left: 4px solid var(--blue); border-radius: 0 4px 4px 0; }
.caritas-static-home .pillar-icon { color: var(--blue-mid); font-size: 1.2rem; flex-shrink: 0; line-height: 1.4; }
.caritas-static-home .pillar h4 { font-size: 0.88rem; font-weight: 500; color: var(--dark); margin-bottom: 0.2rem; }
.caritas-static-home .pillar p { font-size: 0.8rem; color: var(--text-muted); line-height: 1.55; }

/* ---- VMV ---- */
.caritas-static-home .vmv { background: var(--light-bg); padding: var(--section-pad); }
.caritas-static-home .vmv-inner { max-width: 1200px; margin: 0 auto; }
.caritas-static-home .vmv-header { text-align: center; margin-bottom: 3rem; }
.caritas-static-home .vmv-org-label { font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--dark-mid); font-weight: 600; padding-bottom: 0.5rem; border-bottom: 1px solid var(--border); margin-bottom: 1.25rem; text-align: center; }
.caritas-static-home .vmv-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }
.caritas-static-home .vmv-card { background: var(--white); border-radius: 4px; padding: 1.75rem; border-top: 4px solid var(--blue); }
.caritas-static-home .vmv-card.green-top { border-top-color: var(--green); }
.caritas-static-home .vmv-card-label { font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--blue-mid); font-weight: 600; margin-bottom: 0.75rem; display: flex; align-items: center; gap: 0.5rem; }
.caritas-static-home .vmv-card-label::before { content: ''; width: 18px; height: 2px; background: var(--blue); }
.caritas-static-home .vmv-card.green-top .vmv-card-label { color: var(--green-dark); }
.caritas-static-home .vmv-card.green-top .vmv-card-label::before { background: var(--green); }
.caritas-static-home .vmv-card h3 { font-family: 'Playfair Display', serif; font-size: 1.1rem; color: var(--dark); margin-bottom: 0.6rem; }
.caritas-static-home .vmv-card p { font-size: 0.83rem; color: var(--text-muted); line-height: 1.75; }

/* ---- PROGRAMS ---- */
.caritas-static-home .programs { background: var(--white); padding: var(--section-pad); }
.caritas-static-home .programs-inner { max-width: 1200px; margin: 0 auto; }
.caritas-static-home .programs-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 2.5rem; flex-wrap: wrap; gap: 1.5rem; }
.caritas-static-home .what-programs .programs-head { justify-content: flex-start; }
.caritas-static-home .what-photo-wrap { margin: 0 0 1.4rem; }
.caritas-static-home .what-feature-img {
	width: 100%;
	max-height: 440px;
	object-fit: cover;
	border-radius: 4px;
	display: block;
	box-shadow: 0 14px 40px rgba(28,43,54,0.1);
}
.caritas-static-home .what-row-break { grid-column: 1 / -1; }
.caritas-static-home .prog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }
.caritas-static-home .prog-card { border: 1px solid var(--border); border-radius: 4px; overflow: hidden; transition: box-shadow 0.25s, transform 0.25s; }
.caritas-static-home .prog-card:hover { transform: translateY(-4px); box-shadow: 0 14px 36px rgba(58,172,220,0.12); }
.caritas-static-home .prog-img { height: 190px; overflow: hidden; }
.caritas-static-home .prog-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s; }
.caritas-static-home .prog-card:hover .prog-img img { transform: scale(1.05); }
.caritas-static-home .prog-placeholder { height: 190px; display: flex; align-items: center; justify-content: center; font-size: 3rem; }
.caritas-static-home .prog-body { padding: 1.4rem; }
.caritas-static-home .prog-cat { font-size: 0.65rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--blue-mid); font-weight: 500; margin-bottom: 0.4rem; }
.caritas-static-home .prog-body h3 { font-family: 'Playfair Display', serif; font-size: 1.05rem; color: var(--dark); margin-bottom: 0.5rem; line-height: 1.3; }
.caritas-static-home .prog-body p { font-size: 0.81rem; color: var(--text-muted); line-height: 1.7; }
.caritas-static-home .prog-link { display: inline-flex; align-items: center; gap: 0.3rem; margin-top: 0.85rem; font-size: 0.77rem; font-weight: 500; color: var(--blue-mid); text-decoration: none; }
.caritas-static-home .prog-link:hover { color: var(--green-dark); }
.caritas-static-home .prog-wide { grid-column: span 2; }
.caritas-static-home .prog-wide .prog-inner { display: grid; grid-template-columns: 1fr 1.3fr; height: 100%; }
.caritas-static-home .prog-wide .prog-img { height: 100%; min-height: 180px; }

/* ---- IMPACT ---- */
.caritas-static-home .impact { background: var(--dark); padding: 4rem 2rem; }
.caritas-static-home .impact-inner { max-width: 1100px; margin: 0 auto; }
.caritas-static-home .impact-header { text-align: center; margin-bottom: 3rem; }
.caritas-static-home .impact-header .section-label { color: var(--blue); justify-content: center; }
.caritas-static-home .impact-header .section-label::before { background: var(--blue); }
.caritas-static-home .impact-header h2 { font-family: 'Playfair Display', serif; font-size: clamp(1.8rem,3.5vw,2.6rem); color: var(--white); margin-bottom: 0.5rem; }
.caritas-static-home .impact-header p { color: rgba(255,255,255,0.4); font-size: 0.92rem; }
.caritas-static-home .impact-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: rgba(58,172,220,0.15); border: 1px solid rgba(58,172,220,0.15); border-radius: 4px; overflow: hidden; }
.caritas-static-home .impact-item { padding: 2.5rem 1.5rem; text-align: center; background: var(--dark); }
.caritas-static-home .impact-num { font-family: 'Playfair Display', serif; font-size: 2.8rem; color: var(--blue); font-weight: 700; display: block; margin-bottom: 0.35rem; }
.caritas-static-home .impact-item:nth-child(odd) .impact-num { color: var(--green); }
.caritas-static-home .impact-lbl { font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.38); }

/* ---- TESTIMONIAL ---- */
.caritas-static-home .testimonial { background: var(--blue); padding: 5rem 2rem; text-align: center; }
.caritas-static-home .testimonial-inner { max-width: 740px; margin: 0 auto; }
.caritas-static-home .q-mark { font-family: 'Playfair Display', serif; font-size: 6rem; color: rgba(255,255,255,0.2); line-height: 0.5; display: block; margin-bottom: 1.5rem; }
.caritas-static-home .testimonial blockquote { font-family: 'Playfair Display', serif; font-size: clamp(1.15rem, 2.5vw, 1.6rem); color: var(--white); line-height: 1.65; font-style: italic; margin-bottom: 1.75rem; }
.caritas-static-home .testimonial cite { font-style: normal; font-size: 0.76rem; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.55); }

/* ---- NEWS ---- */
.caritas-static-home .news { background: var(--light-bg); padding: var(--section-pad); }
.caritas-static-home .news-inner { max-width: 1200px; margin: 0 auto; }
.caritas-static-home .news-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 2.5rem; flex-wrap: wrap; gap: 1.5rem; }
.caritas-static-home .news-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 1.25rem; }
.caritas-static-home .news-card-feat, .caritas-static-home .news-card { background: var(--white); border-radius: 4px; overflow: hidden; border: 1px solid var(--border); }
.caritas-static-home .news-card { display: flex; flex-direction: column; }
.caritas-static-home .news-card-feat img { width: 100%; height: 250px; object-fit: cover; display: block; }
.caritas-static-home .news-card img { width: 100%; height: 145px; object-fit: cover; display: block; }
.caritas-static-home .news-body { padding: 1.25rem; flex: 1; }
.caritas-static-home .news-meta { display: flex; align-items: center; gap: 0.65rem; margin-bottom: 0.5rem; }
.caritas-static-home .news-cat { font-size: 0.62rem; letter-spacing: 0.14em; text-transform: uppercase; background: var(--blue-light); color: var(--blue-dark); padding: 0.22rem 0.55rem; border-radius: 3px; font-weight: 500; }
.caritas-static-home .news-cat.green { background: var(--green-light); color: var(--green-dark); }
.caritas-static-home .news-date { font-size: 0.71rem; color: var(--text-muted); }
.caritas-static-home .news-body h3 { font-family: 'Playfair Display', serif; font-size: 1rem; color: var(--dark); margin-bottom: 0.45rem; line-height: 1.35; }
.caritas-static-home .news-body p { font-size: 0.8rem; color: var(--text-muted); line-height: 1.65; }
.caritas-static-home .news-more { display: inline-flex; align-items: center; gap: 0.3rem; margin-top: 0.8rem; font-size: 0.77rem; font-weight: 500; color: var(--blue-mid); text-decoration: none; }
.caritas-static-home .news-more:hover { color: var(--green-dark); }
.caritas-static-home .sa-news-modal { display: none; }
.caritas-static-home .sa-news-modal.is-open { display: block; }
.caritas-static-home .sa-news-modal__overlay {
	position: fixed;
	inset: 0;
	background: rgba(20, 30, 40, 0.62);
	z-index: 998;
}
.caritas-static-home .sa-news-modal__dialog {
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: min(940px, calc(100vw - 2rem));
	max-height: calc(100vh - 2rem);
	overflow: auto;
	background: var(--white);
	border-radius: 8px;
	box-shadow: 0 24px 60px rgba(17, 24, 39, 0.26);
	z-index: 999;
	padding: 1.4rem 1.4rem 1rem;
}
.caritas-static-home .sa-news-modal__close {
	position: absolute;
	right: 0.7rem;
	top: 0.55rem;
	border: 0;
	background: transparent;
	font-size: 1.7rem;
	line-height: 1;
	color: var(--text-muted);
	cursor: pointer;
}
.caritas-static-home .sa-news-modal__header h3 {
	font-family: 'Playfair Display', serif;
	font-size: 1.45rem;
	color: var(--dark);
	margin: 0.45rem 0 0.9rem;
}
.caritas-static-home .sa-news-modal__body {
	color: var(--text);
	font-size: 0.95rem;
	line-height: 1.82;
}
.caritas-static-home .sa-news-modal__body p { margin: 0 0 1rem; }
.caritas-static-home .sa-news-modal__body img { max-width: 100%; height: auto; border-radius: 4px; }

/* ---- GET INVOLVED ---- */
.caritas-static-home .get-involved { background: var(--white); padding: var(--section-pad); }
.caritas-static-home .get-involved-inner { max-width: 1200px; margin: 0 auto; }
.caritas-static-home .involve-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; margin-top: 3rem; }
.caritas-static-home .involve-card { border: 1px solid var(--border); border-radius: 4px; padding: 2rem; text-align: center; transition: border-color 0.2s, transform 0.2s; }
.caritas-static-home .involve-card:hover { border-color: var(--blue); transform: translateY(-3px); }
.caritas-static-home .involve-card:nth-child(2):hover { border-color: var(--green); }
.caritas-static-home .involve-icon { width: 58px; height: 58px; background: var(--blue-light); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 1.2rem; font-size: 1.5rem; }
.caritas-static-home .involve-card:nth-child(2) .involve-icon { background: var(--green-light); }
.caritas-static-home .involve-card:nth-child(3) .involve-icon { background: var(--green-light); }
.caritas-static-home .involve-card h3 { font-family: 'Playfair Display', serif; font-size: 1.1rem; color: var(--dark); margin-bottom: 0.6rem; }
.caritas-static-home .involve-card p { font-size: 0.82rem; color: var(--text-muted); line-height: 1.7; margin-bottom: 1.25rem; }

/* ---- PARTNERS ---- */
.caritas-static-home .partners { background: var(--light-bg); padding: 3.5rem 2rem; }
.caritas-static-home .partners-inner { max-width: 1100px; margin: 0 auto; }
.caritas-static-home .partners-head { display: flex; align-items: center; gap: 1rem; margin-bottom: 2rem; }
.caritas-static-home .partners-head h2 { font-family: 'Playfair Display', serif; font-size: 1.3rem; color: var(--dark); white-space: nowrap; }
.caritas-static-home .partners-divider { flex: 1; height: 1px; background: var(--border); }
.caritas-static-home .logos-row { display: flex; align-items: center; justify-content: center; gap: 2.5rem; flex-wrap: wrap; }
.caritas-static-home .logo-item { filter: grayscale(100%); opacity: 0.5; transition: all 0.3s; }
.caritas-static-home .logo-item:hover { filter: grayscale(0%); opacity: 1; }
.caritas-static-home .logo-item img { max-height: 44px; max-width: 110px; object-fit: contain; display: block; }

/* ---- FOOTER ---- */
.caritas-static-home footer { background: var(--dark); color: rgba(255,255,255,0.55); }
.caritas-static-home .footer-top { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr 1fr 1.3fr; gap: 3rem; padding: 4rem 2rem 2.5rem; }
.caritas-static-home .footer-brand-name { font-family: 'Playfair Display', serif; color: var(--white); font-size: 1.05rem; }
.caritas-static-home .footer-brand-name span { color: var(--blue); }
.caritas-static-home .footer-brand p { font-size: 0.83rem; line-height: 1.75; max-width: 270px; margin-top: 0.75rem; }
.caritas-static-home footer h4 { font-size: 0.68rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--blue); margin-bottom: 1.25rem; font-weight: 500; }
.caritas-static-home footer ul { list-style: none; display: flex; flex-direction: column; gap: 0.5rem; }
.caritas-static-home footer ul a { color: rgba(255,255,255,0.5); text-decoration: none; font-size: 0.83rem; transition: color 0.2s; }
.caritas-static-home footer ul a:hover { color: var(--blue); }
.caritas-static-home .contact-line { font-size: 0.83rem; line-height: 1.9; }
.caritas-static-home .contact-line a { color: var(--blue); text-decoration: none; }
.caritas-static-home .footer-bar { border-top: 1px solid rgba(255,255,255,0.07); }
.caritas-static-home .footer-bar-inner { max-width: 1200px; margin: 0 auto; padding: 1.25rem 2rem; display: flex; justify-content: space-between; font-size: 0.75rem; flex-wrap: wrap; gap: 0.5rem; }

/* ---- RESPONSIVE ---- */
@media (max-width: 960px) {
	.caritas-static-home nav { padding: 0 1.5rem; }
	.caritas-static-home .nav-links { display: none; }
	.caritas-static-home .about-grid, .caritas-static-home .vmv-grid, .caritas-static-home .prog-grid, .caritas-static-home .news-grid, .caritas-static-home .involve-grid, .caritas-static-home .footer-top, .caritas-static-home .strip-inner { grid-template-columns: 1fr; }
	.caritas-static-home .strip-inner { grid-template-columns: repeat(2,1fr); }
	.caritas-static-home .impact-grid { grid-template-columns: repeat(2,1fr); }
	.caritas-static-home .prog-wide { grid-column: span 1; }
	.caritas-static-home .prog-wide .prog-inner { grid-template-columns: 1fr; }
	.caritas-static-home .prog-wide .prog-img { height: 190px; }
	.caritas-static-home .about-accent { right: 1rem; bottom: 1rem; }
	.caritas-static-home .about-img-wrap img { height: 300px; }
	.caritas-static-home .who-vmv-pair { grid-template-columns: 1fr; }
	.caritas-static-home .page-hero { min-height: 260px; padding: 5.5rem 1.25rem 2rem; }
	.caritas-static-home .contact-grid { grid-template-columns: 1fr; }
	.caritas-static-home .team-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.caritas-static-home .story-layout-inner { grid-template-columns: 1fr; }
	.caritas-static-home .story-meta-card { position: static; top: auto; }
	.caritas-static-home .story-related-grid { grid-template-columns: 1fr; }
	.caritas-static-home .what-row-break { grid-column: span 1; }
	:root { --section-pad: 3.5rem 1.5rem; }
}
@media (max-width: 640px) {
	.caritas-static-home .team-grid { grid-template-columns: 1fr; }
}
