/*
Theme Name: St. Cabrini Child
Theme URI: https://stcabrini.org/
Description: Lightweight child theme for St. Frances Cabrini Charitable Services — brand styles on top of GeneratePress.
Author: Wonderboy Creative
Template: generatepress
Version: 1.0.0
*/

:root {
	--brand: #553156;
	--brand-dark: #3e213f;
	--brand-light: #7a4a7c;
	--ink: #030303;
	--ink-muted: #6f6f6f;
	--paper: #ffffff;
	--paper-alt: #f4f4f4;
	--rule: #ededed;
	--heading-font: 'Raleway', sans-serif;
	--body-font: 'Inter', sans-serif;
}

body,
.entry-content,
button,
input,
select,
textarea {
	font-family: var(--body-font);
	color: var(--ink);
}

h1, h2, h3, h4, h5, h6,
.site-title,
.menu-item a {
	font-family: var(--heading-font);
	letter-spacing: 0.02em;
}

a { color: var(--brand); }
a:hover, a:focus { color: var(--brand-dark); }

/* --- Header --- */
.cabrini-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	background: var(--paper);
	box-shadow: 0 1px 2px rgba(0,0,0,0.06);
}
.cabrini-header-inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 12px 24px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
}
.cabrini-logo img {
	max-height: 80px;
	width: auto;
	display: block;
}
.cabrini-logo-tagline {
	display: block;
	font-family: var(--heading-font);
	font-size: 11px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--brand);
	margin-top: 4px;
}

/* --- Primary nav --- */
.cabrini-nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 28px;
	align-items: center;
}
.cabrini-nav ul li { position: relative; }
.cabrini-nav a {
	font-family: var(--heading-font);
	font-weight: 600;
	font-size: 13px;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--ink);
	text-decoration: none;
	padding: 10px 0;
	display: inline-block;
}
.cabrini-nav a:hover,
.cabrini-nav .current-menu-item > a,
.cabrini-nav .current-menu-parent > a { color: var(--brand); }

.cabrini-nav .sub-menu {
	position: absolute;
	top: 100%;
	left: -16px;
	background: var(--paper);
	box-shadow: 0 6px 24px rgba(0,0,0,0.12);
	min-width: 240px;
	flex-direction: column;
	gap: 0;
	padding: 8px 0;
	display: none;
}
.cabrini-nav li:hover > .sub-menu,
.cabrini-nav li:focus-within > .sub-menu { display: flex; }
.cabrini-nav .sub-menu li { width: 100%; }
.cabrini-nav .sub-menu a {
	padding: 10px 20px;
	font-size: 12px;
	display: block;
}
.cabrini-nav .sub-menu a:hover { background: var(--paper-alt); }

/* --- Mobile nav toggle --- */
.cabrini-nav-toggle {
	display: none;
	background: transparent;
	border: 0;
	padding: 8px;
	cursor: pointer;
}
.cabrini-nav-toggle span {
	display: block;
	width: 26px;
	height: 2px;
	background: var(--brand);
	margin: 5px 0;
	transition: transform 0.2s, opacity 0.2s;
}
.cabrini-nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.cabrini-nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.cabrini-nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 900px) {
	.cabrini-nav-toggle { display: block; }
	.cabrini-nav {
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		width: 320px;
		max-width: 85vw;
		background: var(--brand);
		padding: 80px 24px 24px;
		transform: translateX(100%);
		transition: transform 0.28s ease;
		overflow-y: auto;
	}
	.cabrini-nav[data-open="true"] { transform: translateX(0); }
	.cabrini-nav ul { flex-direction: column; align-items: flex-start; gap: 6px; }
	.cabrini-nav a { color: var(--paper); padding: 14px 0; }
	.cabrini-nav a:hover,
	.cabrini-nav .current-menu-item > a { color: var(--paper); opacity: 0.7; }
	.cabrini-nav .sub-menu {
		position: static;
		display: flex;
		background: transparent;
		box-shadow: none;
		padding-left: 16px;
		min-width: 0;
	}
	.cabrini-nav .sub-menu a { color: var(--paper); padding: 10px 0; }
}

/* --- Hero --- */
.cabrini-hero {
	position: relative;
	min-height: 620px;
	display: flex;
	align-items: center;
	color: var(--paper);
	background-size: cover;
	background-position: center;
}
.cabrini-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(rgba(0,0,0,0.35), rgba(0,0,0,0.45));
}
.cabrini-hero-inner {
	position: relative;
	max-width: 1200px;
	margin: 0 auto;
	padding: 80px 48px;
	width: 100%;
}
.cabrini-hero h1 {
	font-size: clamp(40px, 6vw, 80px);
	line-height: 1;
	color: var(--paper);
	text-shadow: 0 0 31px rgba(0,0,0,0.8);
	font-weight: 800;
	letter-spacing: 0.04em;
	margin: 0 0 12px;
}
.cabrini-hero p {
	font-size: 20px;
	text-shadow: 0 0 20px rgba(0,0,0,0.8);
}

/* --- Section helpers --- */
.cabrini-section {
	padding: 80px 24px;
}
.cabrini-section-narrow {
	max-width: 1200px;
	margin: 0 auto;
}
.cabrini-section-dark {
	background: var(--brand);
	color: var(--paper);
}
.cabrini-section-dark h1, .cabrini-section-dark h2, .cabrini-section-dark h3 { color: var(--paper); }
.cabrini-section-alt { background: var(--paper-alt); }

.text-divider-double,
.cabrini-eyebrow {
	display: inline-block;
	font-family: var(--heading-font);
	font-weight: 700;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	font-size: 14px;
	color: var(--brand);
	position: relative;
	padding: 0 40px;
	margin-bottom: 24px;
}
.text-divider-double::before,
.text-divider-double::after,
.cabrini-eyebrow::before,
.cabrini-eyebrow::after {
	content: '';
	position: absolute;
	top: 50%;
	width: 28px;
	height: 2px;
	background: var(--brand);
}
.text-divider-double::before, .cabrini-eyebrow::before { left: 0; }
.text-divider-double::after, .cabrini-eyebrow::after { right: 0; }

.accent-1 {
	font-size: clamp(28px, 3.5vw, 50px);
	line-height: 1.1;
	font-weight: 800;
	color: var(--brand);
	max-width: 900px;
	margin: 0 auto;
}

/* --- Services cards --- */
.services-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 32px;
	max-width: 1200px;
	margin: 0 auto;
}
.services {
	background: var(--paper);
	text-align: center;
}
.services .thumbnail img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 4px;
}
.services-title {
	font-size: 24px;
	margin: 24px 0 12px;
}
.services-title a { color: var(--ink); text-decoration: none; }
.services-title a:hover { color: var(--brand); }
.services-content {
	color: var(--ink-muted);
	line-height: 1.6;
	margin-bottom: 20px;
}
.services-button-wrap a {
	display: inline-block;
	color: var(--brand);
	font-weight: 700;
	text-decoration: none;
	letter-spacing: 0.1em;
	font-size: 13px;
	text-transform: uppercase;
}

/* --- Donate button --- */
.donate-btn,
.wp-block-button__link.donate-btn,
a.donate-btn {
	display: inline-block;
	background: var(--brand);
	color: var(--paper) !important;
	padding: 12px 28px;
	font-family: var(--heading-font);
	font-weight: 700;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	font-size: 13px;
	text-decoration: none;
	border-radius: 4px;
	transition: background 0.2s;
}
.donate-btn:hover { background: var(--brand-dark); }

/* --- Countdown (matches old .wpv-countdown.single-event.style-dark.layout-classic) --- */
.cabrini-countdown {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 32px;
	padding: 40px 24px;
	background: var(--brand);
	color: var(--paper);
	text-align: center;
}
.cabrini-countdown .cd-unit {
	min-width: 90px;
}
.cabrini-countdown .value {
	display: block;
	font-family: var(--heading-font);
	font-size: 56px;
	font-weight: 800;
	line-height: 1;
}
.cabrini-countdown .word {
	display: block;
	font-family: var(--heading-font);
	font-size: 12px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	opacity: 0.8;
	margin-top: 8px;
}
.cabrini-countdown-heading {
	width: 100%;
	font-size: 18px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin: 0 0 12px;
	font-weight: 600;
}
.cabrini-countdown-event {
	width: 100%;
	font-size: 28px;
	font-weight: 800;
	margin: 0 0 20px;
}

/* --- Iframe donation container --- */
.cabrini-donation-iframe {
	display: block;
	max-width: 100%;
	margin: 24px auto;
}
.cabrini-donation-iframe iframe {
	width: 100%;
	max-width: 814px;
	min-height: 315px;
	border: 0;
}

/* --- Footer --- */
.cabrini-footer {
	background: var(--brand);
	color: var(--paper);
	padding: 60px 24px 0;
}
.cabrini-footer-inner {
	max-width: 1200px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 40px;
}
.cabrini-footer .widget-title {
	font-family: var(--heading-font);
	font-size: 16px;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin: 0 0 16px;
}
.cabrini-footer a { color: var(--paper); text-decoration: none; }
.cabrini-footer a:hover { text-decoration: underline; }
.cabrini-footer p { line-height: 1.7; margin: 0 0 10px; }
.cabrini-footer img { max-width: 220px; height: auto; }
.cabrini-footer-bottom {
	border-top: 1px solid rgba(255,255,255,0.12);
	margin-top: 40px;
	padding: 24px 0;
	text-align: center;
	font-size: 13px;
	opacity: 0.8;
}

/* --- Generic containers --- */
.site-content .entry-title { font-size: clamp(32px, 4vw, 52px); }
.site-main { background: var(--paper); }

/* --- GeneratePress overrides --- */
.site-header,
.main-navigation { display: none !important; } /* we render our own */
.inside-header { padding: 0; }
body .site { background: var(--paper); }
