/* ============================================================
   Yorùbás of Atlanta — Theme stylesheet
   Palette: deep indigo (primary), royal gold (accent), terracotta
   ============================================================ */

:root {
	--yoa-indigo:     #1b1f3a;
	--yoa-indigo-2:   #2a2f5a;
	--yoa-gold:       #d4a437;
	--yoa-gold-2:     #e9c46a;
	--yoa-terracotta: #c14b2f;
	--yoa-cream:      #f6efe2;
	--yoa-ink:        #14172b;
	--yoa-paper:      #fffaf2;
	--yoa-muted:      #6b6b7a;
	--yoa-border:     rgba(20,23,43,.12);

	--font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
	--font-sans:    'Outfit', system-ui, -apple-system, Segoe UI, sans-serif;

	--radius-sm: 8px;
	--radius:    14px;
	--radius-lg: 24px;

	--container: 1200px;
	--shadow-lg: 0 30px 60px -20px rgba(20,23,43,.35);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body.yoa-body {
	margin: 0;
	font-family: var(--font-sans);
	color: var(--yoa-ink);
	background: var(--yoa-paper);
	line-height: 1.6;
	font-size: 17px;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--yoa-indigo); text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--yoa-terracotta); }

.sr-only, .screen-reader-text {
	position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden;
	clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.skip-link { position: absolute; left: -9999px; top: 0; z-index: 100; }
.skip-link:focus { left: 1rem; top: 1rem; background: var(--yoa-gold); padding: .5rem 1rem; border-radius: var(--radius-sm); }

.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 1.5rem; }
.container--prose { max-width: 760px; }
.container--prose h2 { font-family: var(--font-display); font-size: clamp(1.6rem, 2.5vw, 2.2rem); margin: 2.5rem 0 1rem; }
.container--prose h3 { font-family: var(--font-display); font-size: 1.4rem; margin: 2rem 0 .75rem; }
.container--prose p, .container--prose ul { font-size: 1.08rem; }
.container--prose ul { padding-left: 1.25rem; }
.container--prose li { margin: .35rem 0; }

/* -------- Header -------- */
.site-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: rgba(255,250,242,.85);
	backdrop-filter: saturate(180%) blur(12px);
	border-bottom: 1px solid var(--yoa-border);
	transition: background .5s ease, border-color .5s ease, backdrop-filter .5s ease;
}
.site-header__inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 2rem;
	max-width: var(--container);
	margin: 0 auto;
	padding: 1rem 1.5rem;
	transition: padding .5s ease;
}
.site-nav { position: relative; }
.brand-link { display: inline-flex; align-items: center; gap: .75rem; color: var(--yoa-ink); }
.brand-mark {
	width: 44px; height: 44px; display: inline-grid; place-items: center;
	font-family: var(--font-display); font-weight: 800; font-size: .8125rem;
	letter-spacing: -.025em; color: var(--yoa-paper);
	background: linear-gradient(135deg, var(--yoa-indigo), var(--yoa-indigo-2));
	border-radius: 10px; box-shadow: inset 0 0 0 2px var(--yoa-gold);
	transition: background .3s ease, border-radius .3s ease, box-shadow .3s ease, color .3s ease;
}
.brand-text__top { display: block; font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; line-height: 1; }
.brand-text__bottom { display: block; font-size: .78rem; color: var(--yoa-muted); margin-top: 3px; }

.site-nav .primary-menu {
	list-style: none; margin: 0; padding: 0;
	display: flex; gap: .25rem; justify-content: center; align-items: center;
}
.primary-menu a {
	display: inline-block;
	font-weight: 500;
	font-size: .875rem;
	padding: .5rem 1rem;
	border-radius: 999px;
	transition: color .2s ease, background .2s ease;
}
.primary-menu .current-menu-item > a {
	background: rgba(27,31,58,.08);
	color: var(--yoa-indigo);
}

.site-nav__toggle { display: none; }

.btn--join {
	background: linear-gradient(135deg, var(--yoa-terracotta), var(--yoa-gold));
	color: var(--yoa-indigo);
	box-shadow: 0 12px 40px -12px rgba(212,164,55,.5);
}
.btn--join:hover {
	background: linear-gradient(135deg, var(--yoa-gold), var(--yoa-gold-2));
	color: var(--yoa-indigo);
	transform: translateY(-1px);
}

/* -------- Buttons -------- */
.btn {
	display: inline-flex; align-items: center; gap: .5rem; padding: .75rem 1.4rem;
	border-radius: 999px; font-weight: 600; font-size: .95rem;
	border: 1px solid transparent; cursor: pointer; transition: all .2s ease;
}
.btn--gold    { background: var(--yoa-gold); color: var(--yoa-ink); }
.btn--gold:hover { background: var(--yoa-gold-2); color: var(--yoa-ink); transform: translateY(-1px); }
.btn--outline { background: transparent; color: var(--yoa-cream); border-color: var(--yoa-cream); }
.btn--outline:hover { background: var(--yoa-cream); color: var(--yoa-indigo); }
.btn--ghost   { background: transparent; color: var(--yoa-indigo); border-color: var(--yoa-border); }
.btn--ghost:hover { background: var(--yoa-indigo); color: var(--yoa-paper); }
.btn--lg { padding: 1rem 1.8rem; font-size: 1.05rem; }
.btn--sm { padding: .5rem 1rem;   font-size: .85rem; }

/* -------- Hero carousel -------- */
.hero-carousel { position: relative; height: 92vh; min-height: 560px; overflow: hidden; background: var(--yoa-indigo); }
.hero-carousel__track { position: absolute; inset: 0; }
.hero-slide {
	position: absolute; inset: 0; opacity: 0; transition: opacity 900ms ease;
	display: grid; place-items: end start;
}
.hero-slide.is-active { opacity: 1; z-index: 2; }
.hero-slide__media { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero-slide__scrim {
	position: absolute; inset: 0;
	background:
		linear-gradient(180deg, rgba(27,31,58,.25) 0%, rgba(27,31,58,.65) 60%, rgba(27,31,58,.9) 100%),
		radial-gradient(60% 80% at 30% 100%, rgba(193,75,47,.35), transparent 70%);
}
.hero-slide__content {
	position: relative; z-index: 2; color: var(--yoa-paper); padding-bottom: 6rem; padding-top: 6rem; max-width: 760px;
}
.hero-slide__title {
	font-family: var(--font-display); font-weight: 600;
	font-size: clamp(2.4rem, 6vw, 4.6rem); line-height: 1.05; letter-spacing: -.02em;
	margin: .5rem 0 1rem; color: var(--yoa-cream);
}
.hero-slide__lead { font-size: clamp(1.05rem, 1.6vw, 1.25rem); max-width: 620px; color: rgba(255,250,242,.85); margin: 0 0 1.75rem; }

.eyebrow {
	display: inline-block; font-size: .8rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
	color: var(--yoa-terracotta);
}
.eyebrow--gold { color: var(--yoa-gold); }

.hero-carousel__btn {
	position: absolute; top: 50%; transform: translateY(-50%);
	width: 52px; height: 52px; border-radius: 50%;
	background: rgba(255,250,242,.18); color: var(--yoa-paper);
	border: 1px solid rgba(255,250,242,.35); font-size: 1.7rem; cursor: pointer; z-index: 5;
	display: grid; place-items: center; backdrop-filter: blur(8px);
	transition: background .2s ease;
}
.hero-carousel__btn:hover { background: rgba(255,250,242,.32); }
.hero-carousel__btn--prev { left: 1.5rem; }
.hero-carousel__btn--next { right: 1.5rem; }

.hero-carousel__dots { position: absolute; bottom: 1.75rem; left: 50%; transform: translateX(-50%); display: flex; gap: .5rem; z-index: 5; }
.hero-dot { width: 36px; height: 4px; border: 0; border-radius: 2px; background: rgba(255,250,242,.35); cursor: pointer; transition: background .2s ease, width .2s ease; }
.hero-dot.is-active { background: var(--yoa-gold); width: 56px; }

/* -------- Section -------- */
.section { padding: clamp(3.5rem, 7vw, 6rem) 0; }
.section__heading { text-align: center; max-width: 720px; margin: 0 auto 3rem; }
.section__heading h2 { font-family: var(--font-display); font-size: clamp(1.8rem, 3.5vw, 2.8rem); margin: .5rem 0 0; line-height: 1.15; }
.section__heading--light h2 { color: var(--yoa-cream); }
.section__cta { text-align: center; margin-top: 2.5rem; }

.section--dark { background: var(--yoa-indigo); color: var(--yoa-cream); }
.section--dark p, .section--dark h3 { color: var(--yoa-cream); }

.section--mission {
	background-size: cover; background-position: center; color: var(--yoa-cream);
	position: relative; isolation: isolate;
}
.section--mission::before {
	content:""; position:absolute; inset:0; z-index:-1;
	background: linear-gradient(120deg, rgba(27,31,58,.92), rgba(27,31,58,.7) 60%, rgba(193,75,47,.55));
}
.section--mission__inner { padding: 6rem 0; max-width: 760px; }
.display { font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3rem); line-height: 1.1; margin: .25rem 0 1rem; }
.lead { font-size: 1.15rem; color: inherit; max-width: 60ch; }

/* -------- Pillars -------- */
.pillars { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem; }
.pillar {
	display: block; padding: 1.75rem; border-radius: var(--radius-lg);
	background: var(--yoa-cream); color: var(--yoa-ink);
	border: 1px solid var(--yoa-border); transition: transform .2s ease, box-shadow .2s ease;
}
.pillar:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); color: var(--yoa-ink); }
.pillar__num { font-family: var(--font-display); font-size: 1.1rem; color: var(--yoa-terracotta); }
.pillar h3 { font-family: var(--font-display); font-size: 1.4rem; margin: .5rem 0; }
.pillar p { color: var(--yoa-muted); margin: 0; font-size: .95rem; }

/* -------- Cards -------- */
.card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.card {
	display: flex; flex-direction: column; background: var(--yoa-paper);
	border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--yoa-border);
	color: var(--yoa-ink); transition: transform .2s ease, box-shadow .2s ease;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.card__media { aspect-ratio: 4/3; background: var(--yoa-indigo-2); overflow: hidden; }
.card__media img { width: 100%; height: 100%; object-fit: cover; }
.card__body { padding: 1.25rem 1.4rem 1.5rem; }
.card__meta { font-size: .8rem; letter-spacing: .12em; text-transform: uppercase; color: var(--yoa-terracotta); }
.card__title { font-family: var(--font-display); font-size: 1.3rem; margin: .35rem 0 .25rem; }
.card__loc  { color: var(--yoa-muted); font-size: .9rem; margin: 0; }

/* -------- Cause cards -------- */
.cause-card {
	background: rgba(255,250,242,.04); border: 1px solid rgba(246,239,226,.18);
	border-radius: var(--radius-lg); padding: 1.75rem; color: var(--yoa-cream);
}
.cause-card h3 { font-family: var(--font-display); font-size: 1.45rem; margin: 0 0 .5rem; color: var(--yoa-gold); }
.progress { background: rgba(246,239,226,.15); border-radius: 999px; height: 8px; overflow: hidden; margin: 1rem 0 .5rem; }
.progress__bar { background: linear-gradient(90deg, var(--yoa-gold), var(--yoa-terracotta)); height: 100%; }
.cause-card__meta { font-size: .9rem; opacity: .85; margin: 0 0 1rem; }

/* -------- Page hero -------- */
.page-hero { background: var(--yoa-indigo); color: var(--yoa-cream); padding: clamp(4rem, 9vw, 7rem) 0 clamp(3rem, 7vw, 5rem); position: relative; isolation: isolate; }
.page-hero--image,
.page-hero--event { background-size: cover; background-position: center 25%; min-height: min(48vh, 520px); }
.page-hero--image::before { content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(27,31,58,.55), rgba(27,31,58,.9)); z-index:-1; }
.page-hero--event::before { content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(27,31,58,.35), rgba(27,31,58,.85)); z-index:-1; }
.has-hero-header .page-hero--image,
.has-hero-header .page-hero--event {
	padding-top: calc(clamp(5rem, 11vw, 8rem) + 1rem);
	min-height: min(52vh, 560px);
}
.has-hero-header .page-hero--image .container,
.has-hero-header .page-hero--event .container { position: relative; z-index: 1; }
.page-hero .display { color: var(--yoa-cream); }
.page-hero .lead    { color: rgba(246,239,226,.8); }
.event-meta { list-style: none; padding: 0; display: flex; flex-wrap: wrap; gap: 1.5rem; margin: 1rem 0; }

/* -------- Tiers -------- */
.tier-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.tier { padding: 2rem; border-radius: var(--radius-lg); border: 1px solid var(--yoa-border); background: var(--yoa-cream); position: relative; }
.tier h3 { font-family: var(--font-display); font-size: 1.5rem; margin: 0 0 .5rem; }
.tier__price { font-family: var(--font-display); font-size: 2.2rem; margin: .5rem 0; }
.tier__price span { font-size: .9rem; color: var(--yoa-muted); margin-left: .25rem; }
.tier ul { list-style: none; padding: 0; margin: 1rem 0 1.5rem; }
.tier ul li { padding: .35rem 0; border-bottom: 1px dashed var(--yoa-border); }
.tier--featured { background: var(--yoa-indigo); color: var(--yoa-cream); border-color: var(--yoa-gold); }
.tier--featured h3, .tier--featured .tier__price { color: var(--yoa-gold); }
.tier--featured ul li { border-color: rgba(246,239,226,.2); }
.badge { position: absolute; top: -.7rem; right: 1.25rem; background: var(--yoa-gold); color: var(--yoa-ink); font-size: .75rem; padding: .25rem .75rem; border-radius: 999px; font-weight: 600; }

/* -------- Donate / Contact -------- */
.donate-grid, .contact-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 3rem; align-items: start; }
.donate-form, .contact-form { display: grid; gap: 1rem; background: var(--yoa-cream); padding: 2rem; border-radius: var(--radius-lg); border: 1px solid var(--yoa-border); }
.donate-form label, .contact-form label { display: grid; gap: .35rem; font-weight: 500; font-size: .92rem; }
.donate-form input, .donate-form select, .contact-form input, .contact-form textarea {
	border: 1px solid var(--yoa-border); border-radius: var(--radius-sm); padding: .75rem .9rem;
	font: inherit; background: var(--yoa-paper);
}
.amount-grid { border: 0; padding: 0; display: flex; flex-wrap: wrap; gap: .5rem; }
.amount-pill { position: relative; cursor: pointer; }
.amount-pill input { position: absolute; opacity: 0; inset: 0; }
.amount-pill span, .amount-pill input[type=number] {
	display: inline-block; padding: .6rem 1.1rem; border-radius: 999px;
	border: 1px solid var(--yoa-border); background: var(--yoa-paper); font-weight: 600;
}
.amount-pill input:checked ~ span { background: var(--yoa-gold); border-color: var(--yoa-gold); }
.amount-pill--custom input { padding: .6rem 1rem; width: 110px; font-weight: 500; }
.form-note { color: var(--yoa-muted); font-size: .85rem; margin: .5rem 0 0; }
.contact-aside {
	background: var(--yoa-cream); padding: 2rem; border-radius: var(--radius-lg);
	border: 1px solid var(--yoa-border);
}
.contact-aside h3 { font-family: var(--font-display); font-size: 1.5rem; margin: 0 0 .75rem; }
.contact-aside__location { color: var(--yoa-muted); margin: 0 0 .5rem; }
.contact-aside__heading {
	font-family: var(--font-display); font-size: 1.1rem; color: var(--yoa-gold);
	margin: 1.5rem 0 .75rem;
}
.contact-aside__emails { list-style: none; padding: 0; margin: 0; }
.contact-aside__emails li { margin: .4rem 0; }
.officers-section { margin-top: 3.5rem; }
.officers-section__title {
	font-family: var(--font-display); font-size: clamp(1.6rem, 2.5vw, 2.2rem);
	margin: 0 0 1.5rem; text-align: center;
}
.officers-grid {
	display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1.25rem;
}
.officer-card {
	background: var(--yoa-cream); padding: 1.5rem; border-radius: var(--radius);
	border: 1px solid var(--yoa-border);
	display: flex;
	flex-direction: column;
	height: 100%;
}
.officer-card h3 {
	font-family: var(--font-display); font-size: 1.15rem; margin: .5rem 0 0; line-height: 1.35;
}
.officer-card__action {
	margin-top: auto;
	padding-top: 1.25rem;
}
.officer-card--featured {
	background: var(--yoa-indigo); color: var(--yoa-cream); border-color: var(--yoa-gold);
}
.officer-card--featured .officer-card__role { color: var(--yoa-gold); }
.officer-card--featured a { color: var(--yoa-gold-2); }
.officer-card--featured a:hover { color: var(--yoa-cream); }
.officer-card__role {
	font-size: .78rem; font-weight: 600; color: var(--yoa-terracotta);
	text-transform: uppercase; letter-spacing: .05em; margin: 0;
}
.officer-card__name {
	font-family: var(--font-display); font-size: 1.15rem; margin: .5rem 0 .35rem; line-height: 1.35;
}
.officer-card__email { font-size: .88rem; margin: 0; word-break: break-word; }

/* -------- Gallery -------- */
.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.gallery-item { margin: 0; position: relative; border-radius: var(--radius); overflow: hidden; aspect-ratio: 1/1; }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.gallery-item:hover img { transform: scale(1.05); }
.gallery-item figcaption {
	position: absolute; inset: auto 0 0 0; padding: .75rem 1rem;
	background: linear-gradient(180deg, transparent, rgba(20,23,43,.8));
	color: var(--yoa-cream); font-size: .9rem;
}

/* -------- Posts -------- */
.post-list { display: grid; gap: 2rem; }
.post-card { display: grid; grid-template-columns: 320px 1fr; gap: 1.5rem; align-items: start; }
.post-card__media img { border-radius: var(--radius); }
.post-card__title { font-family: var(--font-display); margin: 0 0 .5rem; }
.post-card__meta  { color: var(--yoa-muted); font-size: .85rem; }

/* -------- Footer -------- */
.site-footer { background: var(--yoa-ink); color: var(--yoa-cream); padding: 4rem 0 0; margin-top: 4rem; }
.site-footer__inner { display: grid; grid-template-columns: 1.4fr 2fr; gap: 3rem; max-width: var(--container); margin: 0 auto; padding: 0 1.5rem; }
.site-footer .brand-link { color: var(--yoa-cream); }
.site-footer .brand-mark { width: 48px; height: 48px; font-size: 1rem; }
.site-footer .brand-text__bottom { color: rgba(246,239,226,.65); }
.site-footer__tagline { color: rgba(246,239,226,.75); max-width: 36ch; margin-top: 1rem; }
.site-footer__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.footer-col h4, .footer-widget__title { font-family: var(--font-display); font-size: 1.1rem; color: var(--yoa-gold); margin: 0 0 .75rem; }
.footer-menu { list-style: none; padding: 0; margin: 0; }
.footer-menu li { margin: .35rem 0; }
.footer-menu a, .site-footer a { color: rgba(246,239,226,.8); }
.footer-menu a:hover, .site-footer a:hover { color: var(--yoa-gold); }
.site-footer__bottom { border-top: 1px solid rgba(246,239,226,.12); margin-top: 3rem; padding: 1.5rem; text-align: center; font-size: .85rem; color: rgba(246,239,226,.6); }

.site-header--hero {
	position: fixed;
	left: 0;
	right: 0;
	top: 0;
	background: transparent;
	border-bottom: 1px solid transparent;
	backdrop-filter: none;
}
.site-header--hero .site-header__inner {
	padding-top: 1.25rem;
	padding-bottom: 1.25rem;
}
.site-header--hero.is-scrolled .site-header__inner {
	padding-top: .75rem;
	padding-bottom: .75rem;
}
.site-header--hero:not(.is-scrolled) .brand-mark {
	border-radius: 50%;
	background: linear-gradient(135deg, var(--yoa-terracotta), var(--yoa-gold));
	color: var(--yoa-indigo);
	box-shadow: 0 12px 40px -12px rgba(212,164,55,.5);
}
.site-header--hero:not(.is-scrolled) .brand-link,
.site-header--hero:not(.is-scrolled) .brand-text__top {
	color: var(--yoa-paper);
}
.site-header--hero:not(.is-scrolled) .brand-text__top {
	text-shadow: 0 1px 8px rgba(0,0,0,.35);
}
.site-header--hero:not(.is-scrolled) .brand-text__bottom {
	color: rgba(255,250,242,.8);
	font-size: .625rem;
	letter-spacing: .25em;
	text-transform: uppercase;
}
.site-header--hero:not(.is-scrolled) .primary-menu a {
	color: rgba(255,250,242,.9);
}
.site-header--hero:not(.is-scrolled) .primary-menu a:hover {
	color: var(--yoa-paper);
}
.site-header--hero:not(.is-scrolled) .primary-menu .current-menu-item > a {
	background: rgba(255,250,242,.15);
	backdrop-filter: blur(8px);
	color: var(--yoa-paper);
}
.site-header--hero.is-scrolled,
.site-header.is-scrolled {
	background: rgba(255,250,242,.9);
	backdrop-filter: saturate(180%) blur(12px);
	border-bottom: 1px solid var(--yoa-border);
}
.site-header--hero.is-scrolled .brand-link,
.site-header--hero.is-scrolled .primary-menu a,
.site-header--hero.is-scrolled .brand-text__top { color: var(--yoa-ink); }
.site-header--hero.is-scrolled .brand-text__bottom { color: var(--yoa-muted); }
.site-header--hero.is-scrolled .brand-mark {
	border-radius: 10px;
	background: linear-gradient(135deg, var(--yoa-indigo), var(--yoa-indigo-2));
	color: var(--yoa-paper);
	box-shadow: inset 0 0 0 2px var(--yoa-gold);
}
.site-header--hero.is-scrolled .primary-menu .current-menu-item > a {
	background: rgba(27,31,58,.08);
	color: var(--yoa-indigo);
}

/* -------- Adire pattern -------- */
.adire-pattern {
	position: absolute;
	inset: 0;
	pointer-events: none;
	background-image:
		radial-gradient(circle at 1px 1px, rgba(212,164,55,.25) 1px, transparent 0);
	background-size: 24px 24px;
	opacity: .4;
}

/* -------- Pillars overlap -------- */
.section--pillars { margin-top: -4.5rem; position: relative; z-index: 10; padding-top: 0; }
.section--pillars .pillars {
	background: var(--yoa-paper);
	border: 1px solid var(--yoa-border);
	border-radius: var(--radius-lg);
	padding: 1.5rem;
	box-shadow: var(--shadow-lg);
}

/* -------- Welcome grid -------- */
.welcome-grid__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
.welcome-grid__copy .display em { color: var(--yoa-terracotta); font-style: italic; }
.welcome-grid__actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 1.5rem; }
.welcome-grid__media { position: relative; }
.welcome-grid__media img { border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
.welcome-grid__badge {
	position: absolute; bottom: -1.25rem; left: -1.25rem;
	background: var(--yoa-paper); border: 1px solid var(--yoa-border);
	border-radius: var(--radius); padding: 1rem 1.25rem; box-shadow: var(--shadow-lg);
}
.welcome-grid__badge strong { display: block; font-family: var(--font-display); font-size: 1.75rem; color: var(--yoa-terracotta); }
.welcome-grid__badge span { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--yoa-muted); }

/* -------- Feature cards -------- */
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.feature-card {
	position: relative; border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4/5;
}
.feature-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.feature-card:hover img { transform: scale(1.05); }
.feature-card__overlay {
	position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: end;
	padding: 1.5rem; color: var(--yoa-paper);
	background: linear-gradient(180deg, transparent 20%, rgba(27,31,58,.85) 100%);
}
.feature-card__overlay h3 { font-family: var(--font-display); font-size: 1.5rem; margin: 0; }
.feature-card__overlay p { margin: .5rem 0 0; font-size: .92rem; opacity: .85; }
.feature-card__overlay a { margin-top: .75rem; font-size: .75rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--yoa-gold); }

/* -------- What we do -------- */
.section--what-we-do { position: relative; background: var(--yoa-cream); overflow: hidden; }
.what-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.what-card {
	background: var(--yoa-paper); border: 1px solid var(--yoa-border); border-radius: var(--radius-lg);
	padding: 2rem; transition: transform .2s ease, box-shadow .2s ease;
}
.what-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.what-card h3 { font-family: var(--font-display); font-size: 1.45rem; margin: 0 0 .5rem; }
.what-card a { font-size: .75rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }

/* -------- Cause cards with images -------- */
.cause-card--image { display: flex; flex-direction: column; overflow: hidden; border-radius: var(--radius-lg); }
.cause-card__media { aspect-ratio: 5/4; overflow: hidden; }
.cause-card__media img { width: 100%; height: 100%; object-fit: cover; }
.cause-card--image .cause-card__body { padding: 1.5rem; }

/* -------- Stats band -------- */
.section--stats {
	position: relative; overflow: hidden; background: var(--yoa-indigo); color: var(--yoa-cream);
	padding: clamp(4rem, 8vw, 6rem) 0;
}
.stats-grid {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; text-align: center;
}
.stats-grid strong {
	display: block; font-family: var(--font-display); font-size: clamp(2.5rem, 5vw, 3.75rem);
	color: var(--yoa-gold); line-height: 1;
}
.stats-grid span { display: block; margin-top: .5rem; font-size: .72rem; letter-spacing: .18em; text-transform: uppercase; opacity: .75; }
.stats-cta {
	margin-top: 4rem; text-align: center; padding: 2.5rem;
	border: 1px solid rgba(246,239,226,.15); border-radius: var(--radius-lg);
	background: rgba(255,250,242,.05); backdrop-filter: blur(8px);
}
.stats-cta .display { color: var(--yoa-cream); max-width: 48rem; margin: 0 auto; }
.stats-cta p { max-width: 42rem; margin: 1rem auto 0; opacity: .85; }
.stats-cta .btn { margin-top: 1.5rem; }

/* -------- Homepage stats + donate -------- */
.section--stats-donate {
	padding: clamp(2.25rem, 4vw, 3rem) 0;
}
.stats-donate-layout {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(1.5rem, 3vw, 2.5rem);
	align-items: center;
}
.stats-grid--home {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem 1.25rem;
	text-align: center;
}
.stat-item {
	padding: 1rem .75rem;
	border-radius: var(--radius-lg);
	background: rgba(255,250,242,.06);
	border: 1px solid rgba(246,239,226,.12);
}
.stat-item strong {
	display: block;
	font-family: var(--font-display);
	font-size: clamp(1.85rem, 3.5vw, 2.5rem);
	color: var(--yoa-gold);
	line-height: 1;
}
.stat-item span {
	display: block;
	margin-top: .45rem;
	font-size: .62rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: rgba(246,239,226,.72);
}
.home-donate--compact {
	padding: 1.25rem 1.35rem 1.15rem;
	border-radius: var(--radius-lg);
	background: var(--yoa-cream);
	color: var(--yoa-ink);
	box-shadow: 0 16px 40px -18px rgba(0,0,0,.5);
	border: 1px solid rgba(212,168,75,.4);
}
.home-donate--compact .home-donate__title {
	margin: 0 0 .85rem;
	font-family: var(--font-display);
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--yoa-indigo);
	line-height: 1.2;
}
.home-donate--compact .home-donate__form {
	display: grid;
	gap: .65rem;
}
.home-donate__field--plain select,
.home-donate__submit-row input,
.home-donate__custom input {
	width: 100%;
	padding: .55rem .7rem;
	border-radius: var(--radius);
	border: 1px solid var(--yoa-border);
	background: var(--yoa-paper);
	color: var(--yoa-ink);
	font: inherit;
	font-size: .86rem;
}
.home-donate__field--plain select:focus,
.home-donate__submit-row input:focus,
.home-donate__custom input:focus {
	outline: none;
	border-color: var(--yoa-terracotta);
	box-shadow: 0 0 0 2px rgba(193,75,47,.12);
}
.home-donate__amounts {
	display: flex;
	flex-wrap: wrap;
	gap: .35rem;
}
.home-donate--compact .donate-amount {
	flex: 1 1 calc(16.666% - .35rem);
	min-width: 2.75rem;
	padding: .4rem .25rem;
	border: 1px solid var(--yoa-border);
	border-radius: 999px;
	background: var(--yoa-paper);
	color: var(--yoa-ink);
	font: inherit;
	font-size: .78rem;
	font-weight: 600;
	cursor: pointer;
	transition: border-color .15s ease, background .15s ease;
}
.home-donate--compact .donate-amount.is-active {
	border-color: var(--yoa-terracotta);
	background: rgba(193,75,47,.1);
	color: var(--yoa-indigo);
}
.home-donate__custom input {
	margin-top: -.15rem;
}
.home-donate__submit-row {
	display: grid;
	grid-template-columns: 1fr 1fr auto;
	gap: .45rem;
	align-items: center;
}
.home-donate__submit-row .btn {
	white-space: nowrap;
	padding: .55rem 1rem;
	font-size: .86rem;
}
.home-donate__note {
	margin: .15rem 0 0;
	font-size: .72rem;
	color: var(--yoa-muted);
	text-align: center;
}
.home-donate__note a {
	color: var(--yoa-terracotta);
	font-weight: 600;
}
@media (max-width: 900px) {
	.stats-donate-layout {
		grid-template-columns: 1fr;
	}
	.stats-grid--home {
		max-width: 28rem;
		margin: 0 auto;
	}
	.home-donate--compact {
		max-width: 32rem;
		margin: 0 auto;
		width: 100%;
	}
}
@media (max-width: 560px) {
	.home-donate__submit-row {
		grid-template-columns: 1fr;
	}
	.home-donate__submit-row .btn {
		width: 100%;
		justify-content: center;
	}
	.home-donate--compact .donate-amount {
		flex: 1 1 calc(33.333% - .35rem);
	}
}

.btn--block { width: 100%; justify-content: center; }

/* -------- Donate page -------- */
.donate-page__grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 2.5rem; align-items: start; }
.donate-causes__title { font-family: var(--font-display); font-size: 1.75rem; margin: 0 0 1.5rem; }
.donate-causes__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.25rem; }
.donate-cause-card {
	display: block; width: 100%; text-align: left; cursor: pointer;
	border: 1px solid var(--yoa-border); border-radius: var(--radius-lg);
	overflow: hidden; background: var(--yoa-paper); color: var(--yoa-ink);
	transition: border-color .2s ease, box-shadow .2s ease;
}
.donate-cause-card:hover { border-color: var(--yoa-terracotta); }
.donate-cause-card.is-active { border-color: var(--yoa-terracotta); box-shadow: 0 12px 40px -12px rgba(193,75,47,.35); }
.donate-cause-card img { width: 100%; height: 8rem; object-fit: cover; display: block; }
.donate-cause-card__body { padding: 1rem 1.1rem 1.25rem; }
.donate-cause-card h3 { font-family: var(--font-display); font-size: 1.1rem; margin: 0 0 .5rem; }
.donate-cause-card__meta { display: flex; justify-content: space-between; font-size: .78rem; color: var(--yoa-muted); margin: .35rem 0 0; }

.donate-panel {
	border: 1px solid var(--yoa-border); border-radius: var(--radius-lg);
	background: var(--yoa-paper); padding: 2rem; box-shadow: var(--shadow-lg);
}
.donate-panel h3 { font-family: var(--font-display); font-size: 1.5rem; margin: 0; }
.donate-panel__supporting { margin: .35rem 0 0; font-size: .92rem; color: var(--yoa-muted); }
.donate-panel__supporting strong { color: var(--yoa-ink); }
.donate-panel__form { margin-top: 1.25rem; display: grid; gap: 1.25rem; }
.donate-panel__field { display: grid; gap: .35rem; font-size: .92rem; font-weight: 500; }
.donate-panel__field input {
	border: 1px solid var(--yoa-border); border-radius: var(--radius-sm);
	padding: .75rem .9rem; font: inherit; background: var(--yoa-cream);
}
.donate-panel__note { text-align: center; margin: 0; }

.donate-fieldset { border: 0; padding: 0; margin: 0; }
.donate-fieldset legend {
	font-size: .72rem; font-weight: 700; letter-spacing: .14em;
	text-transform: uppercase; color: var(--yoa-muted); margin-bottom: .65rem;
}
.donate-toggle-grid, .donate-amount-grid { display: grid; gap: .5rem; }
.donate-toggle-grid { grid-template-columns: 1fr 1fr; }
.donate-amount-grid { grid-template-columns: repeat(3, 1fr); }
.donate-toggle, .donate-amount {
	display: flex; align-items: center; justify-content: center;
	border: 1px solid var(--yoa-border); border-radius: var(--radius-sm);
	padding: .65rem .75rem; font-size: .92rem; font-weight: 600;
	background: var(--yoa-cream); cursor: pointer; transition: all .2s ease;
}
.donate-toggle input, .donate-amount { font-family: inherit; }
.donate-toggle input { position: absolute; opacity: 0; pointer-events: none; }
.donate-toggle.is-active, .donate-amount.is-active {
	border-color: var(--yoa-terracotta); background: rgba(193,75,47,.12); color: var(--yoa-ink);
}
.donate-custom-amount input {
	width: 100%; margin-top: .5rem; border: 1px solid var(--yoa-border);
	border-radius: var(--radius-sm); padding: .75rem .9rem; font: inherit;
}
.is-hidden { display: none !important; }

.donate-notice {
	border-radius: var(--radius); padding: 1rem 1.25rem; margin-bottom: 2rem;
	display: grid; gap: .25rem;
}
.donate-notice--success {
	background: rgba(212,164,55,.15); border: 1px solid var(--yoa-gold); color: var(--yoa-ink);
}
.donate-notice--error {
	background: rgba(193,75,47,.1); border: 1px solid var(--yoa-terracotta); color: var(--yoa-ink);
}
.contact-form__fieldset { border: 0; padding: 0; margin: 0; }
.contact-form__fieldset legend { font-weight: 600; margin-bottom: .5rem; }
.contact-form__checks { display: flex; flex-wrap: wrap; gap: .75rem 1.25rem; }
.contact-form__check { display: inline-flex; align-items: center; gap: .35rem; font-weight: 500; }

/* Organization contact panel (volunteer + contact pages) */
.volunteer-layout,
.contact-grid.contact-grid--r3 {
	display: grid;
	grid-template-columns: minmax(280px, 1fr) minmax(320px, 1.15fr);
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: start;
}
.contact-form-wrap { display: grid; gap: 1.25rem; min-width: 0; }

.org-contact-panel {
	position: relative;
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: linear-gradient(145deg, var(--yoa-indigo) 0%, #252a4f 55%, #1b1f3a 100%);
	color: var(--yoa-cream);
	box-shadow: var(--shadow-lg);
	border: 1px solid rgba(212, 164, 55, 0.35);
}
.org-contact-panel__pattern {
	position: absolute;
	inset: 0;
	opacity: 0.12;
	background-image: radial-gradient(circle at 20% 20%, var(--yoa-gold) 1px, transparent 1px);
	background-size: 18px 18px;
	pointer-events: none;
}
.org-contact-panel__inner {
	position: relative;
	padding: clamp(1.75rem, 4vw, 2.5rem);
	display: grid;
	gap: 1.5rem;
}
.org-contact-panel__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--yoa-gold);
}
.org-contact-panel__eyebrow::before {
	content: "";
	width: 1.5rem;
	height: 2px;
	background: var(--yoa-gold);
	border-radius: 2px;
}
.org-contact-panel__brand {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
}
.org-contact-panel__mark {
	flex-shrink: 0;
	width: 3.25rem;
	height: 3.25rem;
	display: grid;
	place-items: center;
	border-radius: 50%;
	background: rgba(212, 164, 55, 0.18);
	border: 1px solid rgba(212, 164, 55, 0.45);
	font-family: var(--font-display);
	font-weight: 800;
	font-size: .8125rem;
	letter-spacing: -.025em;
	color: var(--yoa-gold);
}
.org-contact-panel__name {
	margin: 0;
	font-family: var(--font-display);
	font-size: clamp(1.35rem, 2.5vw, 1.75rem);
	line-height: 1.2;
	color: var(--yoa-cream);
}
.org-contact-panel__tagline {
	margin: 0.35rem 0 0;
	font-size: 0.95rem;
	line-height: 1.45;
	color: rgba(246, 239, 226, 0.82);
}
.org-contact-panel__details {
	margin: 0;
	display: grid;
	gap: 1.1rem;
}
.org-contact-panel__detail {
	margin: 0;
	padding-top: 1rem;
	border-top: 1px solid rgba(246, 239, 226, 0.12);
}
.org-contact-panel__detail dt {
	margin: 0 0 0.35rem;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--yoa-gold);
}
.org-contact-panel__detail dd {
	margin: 0;
	font-size: 0.98rem;
	line-height: 1.55;
	color: var(--yoa-cream);
}
.org-contact-panel__detail a {
	color: var(--yoa-gold-2, #e8c56a);
	text-decoration: none;
	word-break: break-word;
}
.org-contact-panel__detail a:hover {
	color: var(--yoa-cream);
	text-decoration: underline;
}

/* Join Us modal */
body.yoa-modal-open { overflow: hidden; }

.yoa-modal {
	position: fixed;
	inset: 0;
	z-index: 10000;
	display: grid;
	place-items: center;
	padding: 1.25rem;
}
.yoa-modal[hidden] { display: none !important; }

.yoa-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(15, 18, 35, 0.72);
	backdrop-filter: blur(4px);
}

.yoa-modal__dialog {
	position: relative;
	width: min(100%, 42rem);
	max-height: min(92vh, 900px);
	overflow: auto;
	border-radius: var(--radius-lg);
	background: var(--yoa-cream);
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.35);
	border: 1px solid rgba(212, 164, 55, 0.35);
}

.yoa-modal__close {
	position: absolute;
	top: 0.85rem;
	right: 0.85rem;
	z-index: 2;
	width: 2.25rem;
	height: 2.25rem;
	border: 0;
	border-radius: 50%;
	background: rgba(27, 31, 58, 0.08);
	color: var(--yoa-indigo);
	font-size: 1.5rem;
	line-height: 1;
	cursor: pointer;
}
.yoa-modal__close:hover { background: rgba(27, 31, 58, 0.14); }

.yoa-modal__header {
	padding: 1.5rem 1.75rem 1rem;
	background: linear-gradient(135deg, var(--yoa-indigo), #2a3158);
	color: var(--yoa-cream);
	border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.yoa-modal__title {
	margin: 0;
	font-family: var(--font-display);
	font-size: clamp(1.35rem, 3vw, 1.75rem);
}
.yoa-modal__lead {
	margin: 0.4rem 0 0;
	font-size: 0.92rem;
	color: rgba(246, 239, 226, 0.82);
}

.yoa-modal__body { padding: 1.5rem 1.75rem 1.75rem; }
.yoa-modal__form.is-hidden { display: none; }

.yoa-modal__notice {
	border-radius: var(--radius);
	padding: 1rem 1.15rem;
	margin-bottom: 1rem;
	display: grid;
	gap: 0.25rem;
}
.yoa-modal__notice.is-hidden { display: none; }
.yoa-modal__notice--success {
	background: rgba(212, 164, 55, 0.15);
	border: 1px solid var(--yoa-gold);
}
.yoa-modal__notice--error {
	background: rgba(193, 75, 47, 0.1);
	border: 1px solid var(--yoa-terracotta);
}

.yoa-modal__hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	opacity: 0;
	pointer-events: none;
}

.contact-form select {
	width: 100%;
	padding: 0.7rem 0.85rem;
	border: 1px solid var(--yoa-border);
	border-radius: var(--radius);
	background: #fff;
	font: inherit;
}

.site-header__cta .btn--join {
	font: inherit;
}

/* About page: proverbs carousel, CTA band, causes slider */
.section--proverbs {
	background: linear-gradient(180deg, var(--yoa-paper) 0%, var(--yoa-cream) 100%);
}
.section__heading-lead { max-width: 42rem; margin-inline: auto; }

.media-carousel {
	position: relative;
	padding: 0 2.75rem 2.5rem;
}
.media-carousel__viewport {
	overflow: hidden;
	border-radius: var(--radius-lg);
}
.media-carousel__track {
	display: flex;
	gap: 1rem;
	transition: transform 0.45s ease;
	will-change: transform;
}
.media-carousel__slide {
	flex: 0 0 100%;
	min-width: 0;
}
.media-carousel[data-carousel-per-view="3"] .media-carousel__slide {
	flex-basis: calc((100% - 2rem) / 3);
}
.media-carousel__btn {
	position: absolute;
	top: 42%;
	transform: translateY(-50%);
	z-index: 2;
	width: 2.5rem;
	height: 2.5rem;
	border: 0;
	border-radius: 50%;
	background: rgba(27, 31, 58, 0.82);
	color: var(--yoa-cream);
	font-size: 1.5rem;
	line-height: 1;
	cursor: pointer;
}
.media-carousel__btn:hover { background: var(--yoa-indigo); }
.media-carousel__btn--prev { left: 0; }
.media-carousel__btn--next { right: 0; }
.media-carousel__dots {
	display: flex;
	justify-content: center;
	gap: 0.5rem;
	margin-top: 1.25rem;
}
.media-carousel__dot {
	width: 0.55rem;
	height: 0.55rem;
	border: 0;
	border-radius: 50%;
	background: rgba(27, 31, 58, 0.2);
	cursor: pointer;
	padding: 0;
}
.media-carousel__dot.is-active { background: var(--yoa-gold); transform: scale(1.15); }

.proverb-card {
	border-radius: var(--radius-lg);
	overflow: hidden;
	border: 1px solid var(--yoa-border);
	background: var(--yoa-indigo);
	box-shadow: var(--shadow-lg);
}
.proverb-card__link {
	display: block;
	position: relative;
	aspect-ratio: 16 / 10;
}
.proverb-card__link img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.35s ease;
}
.proverb-card__overlay {
	position: absolute;
	inset: auto 0 0 0;
	padding: 1rem 1.1rem;
	background: linear-gradient(180deg, transparent, rgba(15, 18, 35, 0.88));
	color: var(--yoa-cream);
}
.proverb-card__overlay h3 {
	margin: 0;
	font-family: var(--font-display);
	font-size: 1rem;
}
.proverb-card__overlay span {
	font-size: 0.82rem;
	color: var(--yoa-gold);
}
.proverb-card__link:hover img { transform: scale(1.04); }

.about-cta-band {
	background:
		radial-gradient(circle at top right, rgba(212, 164, 55, 0.12), transparent 42%),
		var(--yoa-indigo);
	color: var(--yoa-cream);
}
.about-cta-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.5rem;
}
.about-cta-card {
	padding: clamp(1.5rem, 3vw, 2.25rem);
	border-radius: var(--radius-lg);
	border: 1px solid rgba(212, 164, 55, 0.28);
	background: rgba(255, 255, 255, 0.04);
}
.about-cta-card h2.display {
	color: var(--yoa-cream);
	margin: 0.35rem 0;
	font-size: clamp(1.6rem, 3vw, 2.2rem);
}
.about-cta-card h3 {
	margin: 0 0 0.75rem;
	font-family: var(--font-display);
	color: var(--yoa-gold);
	font-size: 1.35rem;
}
.about-cta-card p {
	color: rgba(246, 239, 226, 0.82);
	margin: 0 0 1.25rem;
}

.about-cause-slide__inner {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
	gap: 1.5rem;
	align-items: center;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(212, 164, 55, 0.22);
	border-radius: var(--radius-lg);
	overflow: hidden;
}
.about-cause-slide__media img {
	width: 100%;
	height: 100%;
	min-height: 16rem;
	object-fit: cover;
	display: block;
}
.about-cause-slide__body {
	padding: 1.5rem 1.5rem 1.75rem 0;
}
.about-cause-slide__body h3 {
	font-family: var(--font-display);
	font-size: clamp(1.4rem, 2.5vw, 2rem);
	margin: 0.35rem 0 0.75rem;
	color: var(--yoa-cream);
}
.about-cause-slide__body p {
	color: rgba(246, 239, 226, 0.82);
	margin: 0 0 1rem;
}
.media-carousel--causes .media-carousel__btn {
	background: rgba(246, 239, 226, 0.16);
}
.media-carousel--causes .media-carousel__dot {
	background: rgba(246, 239, 226, 0.25);
}
.media-carousel--causes .media-carousel__dot.is-active {
	background: var(--yoa-gold);
}

@media (max-width: 899px) {
	.media-carousel[data-carousel-per-view="3"] .media-carousel__slide {
		flex-basis: calc((100% - 1rem) / 2);
	}
}
@media (max-width: 599px) {
	.media-carousel { padding-inline: 2.25rem; }
	.media-carousel[data-carousel-per-view="3"] .media-carousel__slide,
	.media-carousel__slide {
		flex-basis: 100%;
	}
	.about-cta-grid,
	.about-cause-slide__inner {
		grid-template-columns: 1fr;
	}
	.about-cause-slide__body { padding: 1.25rem; }
}

/* -------- r3-aligned layouts -------- */
.page-hero--immersive {
	min-height: min(70vh, 640px);
	padding: clamp(7rem, 14vw, 10rem) 0 clamp(4rem, 8vw, 6rem);
	background-size: cover;
	background-position: center;
	color: var(--yoa-cream);
	position: relative;
	isolation: isolate;
}
.page-hero--immersive::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(27,31,58,.85), rgba(27,31,58,.7) 45%, rgba(27,31,58,.9));
	z-index: -1;
}
.page-hero__inner { position: relative; z-index: 1; text-align: center; max-width: 48rem; margin: 0 auto; }
.page-hero__badge {
	display: inline-flex; align-items: center; gap: .75rem;
	border: 1px solid rgba(255,250,242,.25); background: rgba(255,250,242,.1);
	border-radius: 999px; padding: .4rem 1rem;
	font-size: .72rem; letter-spacing: .25em; text-transform: uppercase;
}
.page-hero__badge-dot { width: .45rem; height: .45rem; border-radius: 50%; background: var(--yoa-gold); }
.kente-border { height: 8px; background: repeating-linear-gradient(90deg, var(--yoa-gold) 0 25%, var(--yoa-terracotta) 25% 50%, var(--yoa-indigo) 50% 75%, var(--yoa-cream) 75% 100%); }
.kente-border--bottom { position: absolute; left: 0; right: 0; bottom: 0; }
.kente-border--top { position: absolute; left: 0; right: 0; top: 0; }

.members-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.member-card { border: 1px solid var(--yoa-border); border-radius: var(--radius-lg); overflow: hidden; background: var(--yoa-paper); box-shadow: var(--shadow-lg); transition: transform .2s ease; }
.member-card:hover { transform: translateY(-4px); }
.member-card__media { aspect-ratio: 4/5; overflow: hidden; background: var(--yoa-cream); }
.member-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.member-card:hover .member-card__media img { transform: scale(1.05); }
.member-card__body { padding: 1.25rem 1.5rem 1.5rem; }
.member-card h3 { font-family: var(--font-display); font-size: 1.1rem; margin: 0; }
.member-card__credentials { margin: .35rem 0 0; font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--yoa-terracotta); font-weight: 600; }
.members-cta { margin-top: 3rem; text-align: center; color: var(--yoa-muted); }

.about-split__inner, .values-grid { display: grid; gap: 2rem; }
.about-split__inner { grid-template-columns: 1fr 1fr; align-items: center; gap: 4rem; }
.about-split__inner img { border-radius: var(--radius-lg); width: 100%; object-fit: cover; box-shadow: var(--shadow-lg); }
.about-split--reverse .about-split__inner > :first-child { order: 2; }
.values-grid { grid-template-columns: repeat(3, 1fr); }
.values-card { border: 1px solid var(--yoa-border); border-radius: var(--radius-lg); background: var(--yoa-paper); padding: 2rem; }

.contact-info-stack { display: grid; gap: 1rem; align-content: start; }
.contact-info-card { display: grid; gap: .35rem; padding: 1.25rem 1.5rem; border: 1px solid var(--yoa-border); border-radius: var(--radius); background: var(--yoa-paper); }
.contact-info-card strong { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--yoa-muted); }
.contact-info-card span { font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; }
.contact-form--card { box-shadow: var(--shadow-lg); }
.contact-form--card h2 { font-family: var(--font-display); font-size: 1.5rem; margin: 0 0 1rem; }
.contact-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.contact-form__row--3 { grid-template-columns: repeat(3, 1fr); }

/* Scholarship application */
.scholarship-layout { max-width: 52rem; margin-inline: auto; }
.scholarship-form-wrap { width: 100%; }
.scholarship-form { gap: 0; padding: 0; overflow: hidden; }
.scholarship-form__header {
	padding: clamp(1.5rem, 3vw, 2rem) clamp(1.5rem, 3vw, 2.25rem);
	background: linear-gradient(135deg, var(--yoa-indigo) 0%, #2a3058 100%);
	color: var(--yoa-cream);
	border-bottom: 4px solid var(--yoa-gold);
}
.scholarship-form__org {
	margin: 0;
	font-family: var(--font-display);
	font-size: clamp(1.2rem, 2.5vw, 1.5rem);
	font-weight: 700;
}
.scholarship-form__address {
	margin: .35rem 0 0;
	font-size: .9rem;
	opacity: .88;
}
.scholarship-form__title {
	margin: 1.25rem 0 0;
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 3vw, 1.85rem);
	color: var(--yoa-gold);
}
.scholarship-form__intro {
	margin: .5rem 0 0;
	font-size: .92rem;
	opacity: .9;
	max-width: 38rem;
}
.scholarship-form__section {
	display: grid;
	gap: 1rem;
	padding: clamp(1.5rem, 3vw, 2rem) clamp(1.5rem, 3vw, 2.25rem);
	border-top: 1px solid var(--yoa-border);
	background: var(--yoa-cream);
}
.scholarship-form__section:nth-child(even) {
	background: var(--yoa-paper);
}
.scholarship-form__section-head {
	display: flex;
	align-items: center;
	gap: .85rem;
	margin-bottom: .25rem;
}
.scholarship-form__section-num {
	flex-shrink: 0;
	width: 2rem;
	height: 2rem;
	display: grid;
	place-items: center;
	border-radius: 50%;
	background: var(--yoa-gold);
	color: var(--yoa-indigo);
	font-family: var(--font-display);
	font-weight: 700;
	font-size: .95rem;
}
.scholarship-form__section h3 {
	margin: 0;
	font-family: var(--font-display);
	font-size: 1.35rem;
	color: var(--yoa-indigo);
}
.scholarship-form__hint {
	margin: 0 0 .5rem;
	font-size: .9rem;
	color: var(--yoa-muted);
}
.scholarship-form__subsection {
	display: grid;
	gap: .85rem;
	padding: 1rem 1.1rem;
	border-radius: var(--radius);
	border: 1px dashed var(--yoa-border);
	background: rgba(255, 250, 242, .6);
}
.scholarship-form__subsection h4 {
	margin: 0;
	font-size: .78rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--yoa-terracotta);
	font-weight: 700;
}
.scholarship-form__fieldset legend {
	font-size: .85rem;
	letter-spacing: .06em;
	text-transform: uppercase;
	color: var(--yoa-muted);
}
.scholarship-form__fieldset-hint {
	margin: 0 0 .75rem;
	font-size: .88rem;
	color: var(--yoa-muted);
}
.scholarship-form__list {
	display: grid;
	gap: .65rem;
}
.scholarship-form__list-item {
	display: grid;
	grid-template-columns: minmax(6.5rem, 8.5rem) 1fr;
	align-items: center;
	gap: .75rem 1rem;
	font-weight: 500;
	font-size: .92rem;
}
.scholarship-form__list-label {
	color: var(--yoa-muted);
	font-size: .85rem;
	font-weight: 600;
}
.scholarship-form__ref-block {
	display: grid;
	gap: .5rem;
	padding: .85rem 0;
	border-top: 1px solid var(--yoa-border);
}
.scholarship-form__ref-block:first-of-type {
	border-top: 0;
	padding-top: 0;
}
.scholarship-form__ref-title {
	margin: 0;
	font-size: .78rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--yoa-terracotta);
}
.scholarship-form__ref-row label {
	font-size: .88rem;
}
.scholarship-form__file input[type="file"] {
	padding: .65rem;
	border: 1px dashed var(--yoa-border);
	border-radius: var(--radius-sm);
	background: var(--yoa-paper);
	font-size: .88rem;
}
.scholarship-form > .btn {
	margin: 0 clamp(1.5rem, 3vw, 2.25rem) clamp(1.5rem, 3vw, 2rem);
}
.scholarship-form__note {
	margin: 0 clamp(1.5rem, 3vw, 2.25rem) clamp(1.5rem, 3vw, 2rem);
	text-align: center;
}

.officers-section__lead { max-width: 42rem; color: var(--yoa-muted); margin: 0 0 2rem; }
.officer-card__email-btn {
	display: inline-flex; margin-top: 1rem; padding: .55rem 1rem; border-radius: 999px;
	background: var(--yoa-indigo); color: var(--yoa-cream); font-size: .72rem; font-weight: 700;
	letter-spacing: .12em; text-transform: uppercase;
}
.officer-card__email-btn--muted { background: transparent; border: 1px solid var(--yoa-border); color: var(--yoa-muted); }

.event-list { display: grid; gap: 2.5rem; }
.event-row { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; align-items: stretch; border: 1px solid var(--yoa-border); border-radius: var(--radius-lg); overflow: hidden; background: var(--yoa-paper); }
.event-row__media {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1.25rem;
	background: var(--yoa-cream);
}
.event-row__media img {
	width: auto;
	max-width: 100%;
	height: auto;
}
.event-row--reverse .event-row__media { order: 2; }
.event-row__body { padding: 2rem 2.5rem; }
.event-row__date { display: inline-block; padding: .25rem .75rem; border-radius: 999px; background: rgba(193,75,47,.12); color: var(--yoa-terracotta); font-size: .72rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.event-row h2 { font-family: var(--font-display); font-size: clamp(1.6rem, 3vw, 2.2rem); margin: 1rem 0 .5rem; }
.event-row__loc { color: var(--yoa-muted); margin: 0 0 1rem; }
.event-row__copy { color: var(--yoa-muted); margin-bottom: 1.5rem; }

.gallery-grid--masonry { grid-template-columns: repeat(4, 1fr); grid-auto-rows: 260px; }
.gallery-item--large { grid-column: span 2; grid-row: span 2; }
.gallery-item--wide { grid-column: span 2; }

.site-footer--r3 { position: relative; background: var(--yoa-indigo); margin-top: 0; }
.site-footer--r3 .site-footer__inner { grid-template-columns: 1.4fr 1fr; }
.site-footer--r3 .site-footer__cols { grid-template-columns: 1fr 1fr; }
.footer-contact { list-style: none; padding: 0; margin: 0; display: grid; gap: .75rem; }
.section__cta-link { margin: .75rem 0 0; }
.section__cta-link a { color: var(--yoa-gold-2); font-weight: 600; }
.section--dark .section__cta-link a { color: var(--yoa-gold); }

/* -------- Responsive -------- */
@media (max-width: 960px) {
	.pillars, .card-grid, .tier-grid, .gallery-grid, .feature-grid, .what-grid, .welcome-grid__inner, .officers-grid, .members-grid, .values-grid, .about-split__inner, .event-row { grid-template-columns: repeat(2, 1fr); }
	.donate-page__grid, .donate-causes__grid { grid-template-columns: 1fr; }
	.donate-grid, .contact-grid, .volunteer-layout, .contact-grid.contact-grid--r3, .site-footer__inner { grid-template-columns: 1fr; }
	.post-card { grid-template-columns: 1fr; }
	.site-footer__cols { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
	.site-header__inner { grid-template-columns: auto auto; }
	.site-header__cta { display: none; }
	.site-nav__toggle {
		display: inline-grid; place-items: center; width: 44px; height: 44px;
		background: transparent; border: 1px solid var(--yoa-border); border-radius: 999px; cursor: pointer;
	}
	.site-header--hero:not(.is-scrolled) .site-nav__toggle {
		border-color: rgba(255,250,242,.35);
	}
	.hamburger, .hamburger::before, .hamburger::after {
		content: ""; display: block; width: 20px; height: 2px; background: var(--yoa-ink); position: relative; transition: transform .2s ease, background .2s ease;
	}
	.site-header--hero:not(.is-scrolled) .hamburger,
	.site-header--hero:not(.is-scrolled) .hamburger::before,
	.site-header--hero:not(.is-scrolled) .hamburger::after {
		background: var(--yoa-paper);
	}
	.hamburger::before { position: absolute; top: -6px; }
	.hamburger::after  { position: absolute; top:  6px; }
	.site-nav .primary-menu {
		display: none; position: absolute; top: calc(100% + .75rem); left: 50%;
		transform: translateX(-50%); width: min(100vw - 2rem, 420px);
		flex-direction: column; gap: .25rem; align-items: stretch;
		background: rgba(255,250,242,.95); backdrop-filter: blur(12px);
		border: 1px solid var(--yoa-border); border-radius: var(--radius-lg);
		box-shadow: var(--shadow-lg); padding: 1rem;
	}
	.site-nav.is-open .primary-menu { display: flex; }
	.primary-menu li { padding: 0; border: 0; }
	.primary-menu a { border-radius: var(--radius-sm); }
	.pillars, .card-grid, .tier-grid, .gallery-grid, .feature-grid, .what-grid, .welcome-grid__inner, .site-footer__cols, .stats-grid, .officers-grid, .members-grid, .values-grid, .about-split__inner, .event-row, .gallery-grid--masonry { grid-template-columns: 1fr; }
	.event-row--reverse .event-row__media { order: 0; }
	.contact-form__row { grid-template-columns: 1fr; }
	.contact-form__row--3 { grid-template-columns: 1fr; }
	.scholarship-form__list-item { grid-template-columns: 1fr; }
	.hero-carousel { height: 80vh; }
	.hero-carousel__btn { display: none; }
}