/* ==========================================================================
   ULFAH Donatie — hoofdstylesheet (mobile-first)
   Tokens staan in style.css (:root). Hier de componenten.
   ========================================================================== */

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
	margin: 0;
	font-family: var(--ulfah-font-body);
	color: var(--ulfah-ink);
	background: var(--ulfah-cream);
	line-height: 1.6;
	font-size: 17px;
	-webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 { font-family: var(--ulfah-font-head); line-height: 1.15; color: var(--ulfah-green-900); font-weight: 600; margin: 0 0 .5em; }
h1 { font-size: clamp(1.9rem, 6vw, 3.1rem); }
h2 { font-size: clamp(1.5rem, 4.5vw, 2.2rem); }
h3 { font-size: 1.25rem; }

a { color: var(--ulfah-green-700); text-decoration-thickness: 1px; text-underline-offset: 2px; }
img { max-width: 100%; height: auto; display: block; }

.ulfah-container { width: 100%; max-width: var(--ulfah-maxw); margin: 0 auto; padding: 0 var(--ulfah-sp-4); }
.ulfah-narrow { max-width: 760px; }

.screen-reader-text, .ulfah-skip {
	position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden;
}
.ulfah-skip:focus {
	left: var(--ulfah-sp-4); top: var(--ulfah-sp-4); width: auto; height: auto; z-index: 1000;
	background: var(--ulfah-gold-500); color: var(--ulfah-green-900); padding: 10px 16px; border-radius: 8px;
}

/* ---------- Knoppen ---------- */
.ulfah-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: 8px;
	font-family: var(--ulfah-font-body); font-weight: 700; font-size: 1rem;
	padding: 14px 22px; border-radius: var(--ulfah-radius-pill); border: 0; cursor: pointer;
	text-decoration: none; line-height: 1; transition: transform .08s ease, box-shadow .2s ease, background .2s ease;
	min-height: 48px;
}
.ulfah-btn:active { transform: translateY(1px); }
.ulfah-btn--gold { background: var(--ulfah-gold-500); color: #2b220a; box-shadow: 0 6px 18px rgba(200,162,74,.35); }
.ulfah-btn--gold:hover { background: var(--ulfah-gold-400); }
.ulfah-btn--green { background: var(--ulfah-green-800); color: #fff; }
.ulfah-btn--green:hover { background: var(--ulfah-green-700); }
.ulfah-btn--ghost { background: transparent; color: var(--ulfah-green-800); border: 1.5px solid var(--ulfah-green-700); }
.ulfah-btn--lg { padding: 17px 30px; font-size: 1.1rem; }
.ulfah-btn.is-busy { opacity: .7; cursor: progress; }
.ulfah-btn:disabled { opacity: .55; cursor: not-allowed; }

.ulfah-link { color: var(--ulfah-green-700); font-weight: 600; text-decoration: none; }
.ulfah-link:hover { text-decoration: underline; }

/* ---------- Header ---------- */
.ulfah-header {
	position: sticky; top: 0; z-index: 100; background: var(--ulfah-cream);
	transition: box-shadow .2s ease, background .2s ease;
}
.ulfah-header.is-scrolled { box-shadow: 0 2px 14px rgba(15,61,46,.08); background: rgba(251,248,241,.96); backdrop-filter: blur(6px); }
.ulfah-header__inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; height: 68px; }
.ulfah-logo { text-decoration: none; }
.ulfah-logo__mark { font-family: var(--ulfah-font-head); font-weight: 700; font-size: 1.5rem; color: var(--ulfah-green-900); letter-spacing: 1px; }
.custom-logo { max-height: 48px; width: auto; }
.ulfah-nav { display: none; }
.ulfah-nav__list { display: flex; gap: 22px; list-style: none; margin: 0; padding: 0; }
.ulfah-nav__list a { color: var(--ulfah-ink); text-decoration: none; font-weight: 500; font-size: .98rem; }
.ulfah-nav__list a:hover { color: var(--ulfah-green-700); }
.ulfah-header__actions { display: flex; align-items: center; gap: 10px; }
.ulfah-header__donate { display: none; padding: 11px 18px; min-height: 42px; }

.ulfah-burger { width: 44px; height: 44px; background: transparent; border: 0; cursor: pointer; display: flex; flex-direction: column; justify-content: center; gap: 5px; padding: 10px; }
.ulfah-burger span { height: 2.5px; background: var(--ulfah-green-900); border-radius: 2px; transition: .2s; }

.ulfah-mobile-nav { background: var(--ulfah-cream); border-top: 1px solid var(--ulfah-line); padding: var(--ulfah-sp-4); }
.ulfah-mobile-nav__list { list-style: none; margin: 0 0 14px; padding: 0; display: flex; flex-direction: column; }
.ulfah-mobile-nav__list a { display: block; padding: 13px 4px; color: var(--ulfah-ink); text-decoration: none; font-weight: 600; border-bottom: 1px solid var(--ulfah-line); }
.ulfah-mobile-nav .ulfah-btn { width: 100%; }

/* ---------- Hero ---------- */
.ulfah-hero { position: relative; color: #fff; overflow: hidden; }
.ulfah-hero__media { position: absolute; inset: 0; z-index: 0; }
.ulfah-hero__media img, .ulfah-hero__media video { width: 100%; height: 100%; object-fit: cover; }
.ulfah-hero__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(15,61,46,.78), rgba(15,61,46,.92)); }
.ulfah-hero__inner { position: relative; z-index: 1; padding: var(--ulfah-sp-8) 0; display: grid; gap: var(--ulfah-sp-6); }
.ulfah-hero__copy h1 { color: #fff; }
.ulfah-hero__copy p { font-size: 1.15rem; color: rgba(255,255,255,.92); max-width: 36ch; }

/* ---------- Trust ---------- */
.ulfah-trust { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: var(--ulfah-sp-5); }
.ulfah-trust__item { display: flex; gap: 10px; align-items: center; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.16); border-radius: var(--ulfah-radius-sm); padding: 10px 12px; }
.ulfah-trust__ico { font-size: 1.3rem; }
.ulfah-trust__item div { display: flex; flex-direction: column; line-height: 1.25; }
.ulfah-trust__item strong { font-size: .92rem; color: #fff; }
.ulfah-trust__item span { font-size: .78rem; color: rgba(255,255,255,.8); }
/* Trust op lichte achtergrond */
.ulfah-anbi .ulfah-trust__item, .ulfah-checkout__aside .ulfah-trust__item { background: #fff; border-color: var(--ulfah-line); }
.ulfah-anbi .ulfah-trust__item strong, .ulfah-checkout__aside .ulfah-trust__item strong { color: var(--ulfah-green-900); }
.ulfah-anbi .ulfah-trust__item span, .ulfah-checkout__aside .ulfah-trust__item span { color: var(--ulfah-muted); }

/* ---------- Secties ---------- */
.ulfah-section { padding: var(--ulfah-sp-8) 0; }
.ulfah-section--sand { background: var(--ulfah-sand-100); }
.ulfah-section--green { background: var(--ulfah-green-900); color: #fff; }
.ulfah-section__head { margin-bottom: var(--ulfah-sp-6); }
.ulfah-section__head h2 { margin-bottom: .25em; }
.ulfah-section__head p { color: var(--ulfah-muted); margin: 0; }
.ulfah-section__head--light h2 { color: #fff; }
.ulfah-section__head--light p { color: rgba(255,255,255,.85); }

/* ---------- Grids ---------- */
.ulfah-grid { display: grid; gap: var(--ulfah-sp-5); }
.ulfah-grid--cards, .ulfah-grid--3, .ulfah-grid--4 { grid-template-columns: 1fr; }

/* ---------- Cards ---------- */
.ulfah-card { background: #fff; border-radius: var(--ulfah-radius); overflow: hidden; box-shadow: var(--ulfah-shadow); display: flex; flex-direction: column; }
.ulfah-card__media { display: block; aspect-ratio: 4 / 3; overflow: hidden; background: var(--ulfah-sand-200); }
.ulfah-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.ulfah-card:hover .ulfah-card__media img { transform: scale(1.04); }
.ulfah-card__body { padding: var(--ulfah-sp-5); display: flex; flex-direction: column; gap: 10px; flex: 1; }
.ulfah-card__title { margin: 0; font-size: 1.2rem; }
.ulfah-card__title a { color: var(--ulfah-green-900); text-decoration: none; }
.ulfah-card__excerpt { margin: 0; color: var(--ulfah-muted); font-size: .96rem; }
.ulfah-card__cta { margin-top: auto; align-self: flex-start; }
.ulfah-card--donate { box-shadow: var(--ulfah-shadow-lg); }
.ulfah-card--donate .ulfah-card__body, .ulfah-card--donate { padding: 0; }

/* ---------- Voortgangsbalk ---------- */
.ulfah-progress { margin: 6px 0; }
.ulfah-progress__track { height: 10px; background: var(--ulfah-sand-200); border-radius: var(--ulfah-radius-pill); overflow: hidden; }
.ulfah-progress__fill { height: 100%; background: linear-gradient(90deg, var(--ulfah-green-700), var(--ulfah-gold-500)); border-radius: inherit; transition: width .6s ease; }
.ulfah-progress__labels { display: flex; align-items: baseline; gap: 6px; margin-top: 8px; font-size: .95rem; }
.ulfah-progress__labels strong { color: var(--ulfah-green-900); font-size: 1.05rem; }
.ulfah-progress__labels span { color: var(--ulfah-muted); }

/* ---------- Stats ---------- */
.ulfah-stats { display: grid; grid-template-columns: 1fr 1fr; gap: var(--ulfah-sp-5); text-align: center; }
.ulfah-stat { padding: var(--ulfah-sp-4); }
.ulfah-stat__num { display: block; font-family: var(--ulfah-font-head); font-size: clamp(1.8rem, 7vw, 2.8rem); font-weight: 700; color: var(--ulfah-gold-400); }
.ulfah-stat__label { color: rgba(255,255,255,.88); font-size: .92rem; }

/* ---------- Why ---------- */
.ulfah-why { text-align: center; padding: var(--ulfah-sp-4); }
.ulfah-why span { font-size: 2rem; display: block; margin-bottom: 8px; }
.ulfah-why h3 { margin: 0 0 .3em; }
.ulfah-why p { color: var(--ulfah-muted); margin: 0; font-size: .95rem; }

/* ---------- Testimonials ---------- */
.ulfah-testimonial { background: #fff; border-radius: var(--ulfah-radius); padding: var(--ulfah-sp-5); box-shadow: var(--ulfah-shadow); margin: 0; border-left: 4px solid var(--ulfah-gold-500); }
.ulfah-testimonial blockquote { margin: 0 0 14px; font-size: 1.02rem; color: var(--ulfah-ink); }
.ulfah-testimonial figcaption { display: flex; flex-direction: column; }
.ulfah-testimonial figcaption strong { color: var(--ulfah-green-900); }
.ulfah-testimonial figcaption span { color: var(--ulfah-muted); font-size: .85rem; }

/* ---------- CTA band ---------- */
.ulfah-cta-band { background: linear-gradient(135deg, var(--ulfah-green-800), var(--ulfah-green-900)); color: #fff; text-align: center; padding: var(--ulfah-sp-8) 0; }
.ulfah-cta-band h2 { color: #fff; margin-bottom: var(--ulfah-sp-5); }

/* ==========================================================================
   Donatieformulier (de centrale component)
   ========================================================================== */
.ulfah-donate { background: #fff; border-radius: var(--ulfah-radius); padding: var(--ulfah-sp-5); display: flex; flex-direction: column; gap: var(--ulfah-sp-4); }
.ulfah-donate.is-compact { padding: var(--ulfah-sp-4); gap: 12px; box-shadow: none; }
.ulfah-donate__title { margin: 0; font-size: 1.3rem; }

.ulfah-toggle { display: grid; grid-template-columns: 1fr 1fr; background: var(--ulfah-sand-100); border-radius: var(--ulfah-radius-pill); padding: 4px; }
.ulfah-toggle__btn { border: 0; background: transparent; padding: 11px; border-radius: var(--ulfah-radius-pill); font-weight: 600; cursor: pointer; color: var(--ulfah-muted); font-size: .95rem; }
.ulfah-toggle__btn.is-active { background: var(--ulfah-green-800); color: #fff; box-shadow: 0 2px 8px rgba(15,61,46,.2); }

.ulfah-amounts { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
.ulfah-amount { border: 1.5px solid var(--ulfah-line); background: #fff; border-radius: var(--ulfah-radius-sm); padding: 14px 6px; font-weight: 700; font-size: 1.05rem; cursor: pointer; color: var(--ulfah-green-900); transition: .12s; min-height: 52px; }
.ulfah-amount:hover { border-color: var(--ulfah-green-600); }
.ulfah-amount.is-active { border-color: var(--ulfah-green-800); background: var(--ulfah-green-800); color: #fff; }
.ulfah-amount--custom { grid-column: span 3; display: flex; align-items: center; gap: 6px; padding: 6px 14px; cursor: text; }
.ulfah-amount__cur { font-weight: 700; color: var(--ulfah-muted); }
.ulfah-amount__input { border: 0; outline: 0; width: 100%; font-size: 1.05rem; font-weight: 700; font-family: inherit; background: transparent; color: var(--ulfah-green-900); padding: 8px 0; }

.ulfah-express { display: flex; flex-direction: column; gap: 12px; }
.ulfah-express__buttons { min-height: 0; }
.ulfah-or { display: flex; align-items: center; text-align: center; color: var(--ulfah-muted); font-size: .85rem; }
.ulfah-or::before, .ulfah-or::after { content: ""; flex: 1; height: 1px; background: var(--ulfah-line); }
.ulfah-or span { padding: 0 12px; }

.ulfah-payment-element { margin: 2px 0; }

.ulfah-field { display: flex; flex-direction: column; gap: 6px; }
.ulfah-field label { font-size: .85rem; color: var(--ulfah-muted); font-weight: 600; }
.ulfah-field input { padding: 12px 14px; border: 1.5px solid var(--ulfah-line); border-radius: var(--ulfah-radius-sm); font-size: 1rem; font-family: inherit; }

.ulfah-donate__submit { width: 100%; }
.ulfah-donate__msg { margin: 0; font-size: .95rem; min-height: 1.2em; text-align: center; }
.ulfah-donate__msg.is-error { color: var(--ulfah-danger); }
.ulfah-donate__msg.is-success { color: var(--ulfah-green-700); font-weight: 700; }
.ulfah-donate__trust { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; color: var(--ulfah-muted); font-size: .82rem; }
.ulfah-donate.is-done .ulfah-amounts, .ulfah-donate.is-done .ulfah-payment-element, .ulfah-donate.is-done .ulfah-express, .ulfah-donate.is-done .ulfah-donate__submit { opacity: .5; pointer-events: none; }

/* ---------- Pagina-koppen ---------- */
.ulfah-page-head { background: var(--ulfah-green-900); color: #fff; padding: var(--ulfah-sp-7) 0; }
.ulfah-page-head h1 { color: #fff; margin: 0; }
.ulfah-page-head p { color: rgba(255,255,255,.85); margin: 10px 0 0; }
.ulfah-eyebrow { display: inline-block; background: var(--ulfah-gold-500); color: #2b220a; padding: 4px 12px; border-radius: var(--ulfah-radius-pill); font-size: .8rem; font-weight: 700; margin-bottom: 12px; }

.ulfah-breadcrumb { font-size: .85rem; color: var(--ulfah-muted); margin-bottom: 12px; }
.ulfah-breadcrumb a { color: var(--ulfah-green-700); text-decoration: none; }

/* ---------- Campagnepagina ---------- */
.ulfah-campaign-hero { padding: var(--ulfah-sp-6) 0 var(--ulfah-sp-7); }
.ulfah-campaign-hero__grid { display: grid; gap: var(--ulfah-sp-6); }
.ulfah-campaign-hero__sub { font-size: 1.15rem; color: var(--ulfah-muted); }
.ulfah-campaign-hero__media { border-radius: var(--ulfah-radius); overflow: hidden; margin: var(--ulfah-sp-4) 0; aspect-ratio: 16/9; }
.ulfah-campaign-hero__media img { width: 100%; height: 100%; object-fit: cover; }

/* ---------- Prose ---------- */
.ulfah-prose { font-size: 1.05rem; }
.ulfah-prose h2 { margin-top: 1.4em; }
.ulfah-prose p { margin: 0 0 1.1em; }
.ulfah-prose img { border-radius: var(--ulfah-radius); margin: 1em 0; }
.ulfah-video { position: relative; aspect-ratio: 16/9; margin: 0 0 1.4em; border-radius: var(--ulfah-radius); overflow: hidden; }
.ulfah-video iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

.ulfah-anbi h2 { margin-top: 0; }

/* ---------- Checkout ---------- */
.ulfah-checkout { padding: var(--ulfah-sp-7) 0; }
.ulfah-checkout__grid { display: grid; gap: var(--ulfah-sp-6); }
.ulfah-checkout__lead { color: var(--ulfah-muted); font-size: 1.1rem; margin-top: -6px; }
.ulfah-checkout__aside h2 { font-size: 1.3rem; }
.ulfah-checkout__methods { margin-top: var(--ulfah-sp-4); }
.ulfah-checkout__methods > span { font-size: .82rem; color: var(--ulfah-muted); }
.ulfah-methods { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; }
.ulfah-methods span { background: #fff; border: 1px solid var(--ulfah-line); border-radius: 8px; padding: 6px 10px; font-size: .8rem; font-weight: 600; color: var(--ulfah-green-900); }
.ulfah-checkout__anbi { font-size: .85rem; color: var(--ulfah-muted); margin-top: var(--ulfah-sp-4); }

/* ---------- Zakat ---------- */
.ulfah-zakat { background: #fff; border-radius: var(--ulfah-radius); padding: var(--ulfah-sp-5); box-shadow: var(--ulfah-shadow); display: flex; flex-direction: column; gap: var(--ulfah-sp-5); }
.ulfah-zakat__group { border: 0; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.ulfah-zakat__group legend { font-family: var(--ulfah-font-head); font-size: 1.2rem; color: var(--ulfah-green-900); padding: 0; margin-bottom: 4px; }
.ulfah-zakat__field { display: flex; flex-direction: column; gap: 6px; }
.ulfah-zakat__field > span { font-size: .92rem; color: var(--ulfah-ink); font-weight: 500; }
.ulfah-zakat__input { display: flex; align-items: center; border: 1.5px solid var(--ulfah-line); border-radius: var(--ulfah-radius-sm); padding: 0 14px; }
.ulfah-zakat__input i { color: var(--ulfah-muted); font-style: normal; font-weight: 700; }
.ulfah-zakat__input input { border: 0; outline: 0; width: 100%; padding: 13px 8px; font-size: 1.05rem; font-family: inherit; background: transparent; }
.ulfah-zakat__result { background: var(--ulfah-sand-100); border-radius: var(--ulfah-radius-sm); padding: var(--ulfah-sp-4); }
.ulfah-zakat__row { display: flex; justify-content: space-between; align-items: center; padding: 6px 0; }
.ulfah-zakat__row--total { border-top: 1px solid var(--ulfah-line); margin-top: 6px; padding-top: 12px; }
.ulfah-zakat__row--total strong { font-size: 1.5rem; color: var(--ulfah-green-900); font-family: var(--ulfah-font-head); }
.ulfah-zakat__note { font-size: .85rem; color: var(--ulfah-muted); margin: 8px 0 0; }
.ulfah-zakat__disclaimer { font-size: .8rem; color: var(--ulfah-muted); text-align: center; margin: 0; }

/* ---------- Formulieren / notices ---------- */
.ulfah-form { display: flex; flex-direction: column; gap: var(--ulfah-sp-4); background: #fff; padding: var(--ulfah-sp-5); border-radius: var(--ulfah-radius); box-shadow: var(--ulfah-shadow); }
.ulfah-form label { display: flex; flex-direction: column; gap: 6px; font-weight: 600; font-size: .9rem; color: var(--ulfah-ink); }
.ulfah-form input, .ulfah-form textarea { padding: 12px 14px; border: 1.5px solid var(--ulfah-line); border-radius: var(--ulfah-radius-sm); font-size: 1rem; font-family: inherit; }
.ulfah-notice { padding: 14px 18px; border-radius: var(--ulfah-radius-sm); margin-bottom: var(--ulfah-sp-4); font-weight: 600; }
.ulfah-notice--ok { background: #e4f1e9; color: var(--ulfah-green-800); }
.ulfah-notice--err { background: #f7e3df; color: var(--ulfah-danger); }

/* ---------- Article ---------- */
.ulfah-article__meta { color: rgba(255,255,255,.8); margin: 0; }
.ulfah-article__hero { margin: var(--ulfah-sp-6) auto; border-radius: var(--ulfah-radius); overflow: hidden; }

/* ---------- FAQ ---------- */
.ulfah-faq { display: flex; flex-direction: column; gap: 10px; }
.ulfah-faq__item { background: #fff; border: 1px solid var(--ulfah-line); border-radius: var(--ulfah-radius-sm); overflow: hidden; }
.ulfah-faq__item summary { cursor: pointer; padding: 16px 18px; font-weight: 600; color: var(--ulfah-green-900); list-style: none; display: flex; justify-content: space-between; align-items: center; }
.ulfah-faq__item summary::-webkit-details-marker { display: none; }
.ulfah-faq__item summary::after { content: "+"; font-size: 1.4rem; color: var(--ulfah-gold-500); }
.ulfah-faq__item[open] summary::after { content: "–"; }
.ulfah-faq__a { padding: 0 18px 16px; color: var(--ulfah-muted); }
.ulfah-faq__a p { margin: 0; }

/* ---------- Sticky mobiele CTA ---------- */
.ulfah-sticky-cta {
	position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 90;
	background: var(--ulfah-gold-500); color: #2b220a; text-align: center; font-weight: 700;
	padding: 16px; border-radius: var(--ulfah-radius-pill); text-decoration: none;
	box-shadow: var(--ulfah-shadow-lg); transform: translateY(140%); transition: transform .25s ease;
}
.ulfah-sticky-cta.is-visible { transform: translateY(0); }

/* ---------- Footer ---------- */
.ulfah-footer { background: var(--ulfah-green-900); color: rgba(255,255,255,.82); padding: var(--ulfah-sp-8) 0 0; margin-top: var(--ulfah-sp-7); }
.ulfah-footer__grid { display: grid; gap: var(--ulfah-sp-6); }
.ulfah-footer__col h4 { color: #fff; font-family: var(--ulfah-font-body); font-size: 1rem; text-transform: uppercase; letter-spacing: .5px; margin-bottom: 14px; }
.ulfah-footer__col p { margin: 0 0 10px; font-size: .95rem; }
.ulfah-footer__col a { color: rgba(255,255,255,.85); text-decoration: none; }
.ulfah-footer__col a:hover { color: var(--ulfah-gold-400); }
.ulfah-logo__mark--footer { color: #fff; margin-bottom: 14px; }
.ulfah-footer__menu { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.ulfah-footer__socials { display: flex; gap: 10px; margin-top: 12px; }
.ulfah-footer__socials a { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; border: 1px solid rgba(255,255,255,.25); border-radius: 50%; font-size: .8rem; font-weight: 700; }
.ulfah-footer__rsin { font-size: .82rem; opacity: .7; }
.ulfah-footer__bottom { border-top: 1px solid rgba(255,255,255,.12); margin-top: var(--ulfah-sp-7); padding: var(--ulfah-sp-4) 0; font-size: .85rem; }

/* ---------- Search ---------- */
.ulfah-search { display: flex; gap: 8px; }
.ulfah-search input { flex: 1; padding: 12px 14px; border: 1.5px solid var(--ulfah-line); border-radius: var(--ulfah-radius-sm); font-size: 1rem; }

/* ---------- Pagination ---------- */
.pagination, .nav-links { display: flex; gap: 8px; justify-content: center; margin-top: var(--ulfah-sp-6); flex-wrap: wrap; }
.pagination .page-numbers, .nav-links .page-numbers { padding: 8px 14px; border-radius: var(--ulfah-radius-sm); background: #fff; border: 1px solid var(--ulfah-line); text-decoration: none; color: var(--ulfah-green-900); }
.pagination .current { background: var(--ulfah-green-800); color: #fff; }

.ulfah-img-placeholder { width: 100%; height: 100%; object-fit: cover; }

/* ==========================================================================
   Tablet / desktop
   ========================================================================== */
@media (min-width: 720px) {
	.ulfah-grid--cards { grid-template-columns: repeat(2, 1fr); }
	.ulfah-grid--3 { grid-template-columns: repeat(2, 1fr); }
	.ulfah-grid--4 { grid-template-columns: repeat(2, 1fr); }
	.ulfah-checkout__grid { grid-template-columns: 1.4fr 1fr; align-items: start; }
	.ulfah-trust { grid-template-columns: repeat(4, 1fr); }
}

@media (min-width: 960px) {
	.ulfah-nav { display: block; }
	.ulfah-header__donate { display: inline-flex; }
	.ulfah-burger { display: none; }
	.ulfah-mobile-nav { display: none !important; }
	.ulfah-sticky-cta { display: none; }

	.ulfah-hero__inner { grid-template-columns: 1.1fr .9fr; align-items: center; padding: var(--ulfah-sp-9) 0; }
	.ulfah-trust { grid-template-columns: 1fr 1fr; }

	.ulfah-grid--cards { grid-template-columns: repeat(3, 1fr); }
	.ulfah-grid--3 { grid-template-columns: repeat(3, 1fr); }
	.ulfah-grid--4 { grid-template-columns: repeat(4, 1fr); }
	.ulfah-stats { grid-template-columns: repeat(4, 1fr); }

	.ulfah-campaign-hero__grid { grid-template-columns: 1.5fr 1fr; align-items: start; }
	.ulfah-campaign-hero__form { position: sticky; top: 88px; }

	.ulfah-footer__grid { grid-template-columns: 1.5fr 1fr 1fr 1fr; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	* { scroll-behavior: auto !important; transition: none !important; animation: none !important; }
}
