/* ==========================================================================
   Demo: Forward — Organization / Nonprofit
   Identity: optimistic + action-led. Forest green, bright leaf, warm sand.
   ========================================================================== */

.lumina-demo-organization {
	--lum-bg:        #ffffff;
	--lum-surface:   #f3f1e8;
	--lum-ink:       #14271d;
	--lum-ink-soft:  #44574c;
	--lum-line:      #e4e6dd;
	--lum-accent:    #1f8f5b;
	--lum-accent-ink:#ffffff;
	--lum-muted:     #7f8a82;

	--fwd-deep: #14271d;
	--fwd-leaf: #3fc07a;
	--fwd-sand: #f0ead6;
}
.lumina-demo-organization { --lum-font-display: "Fraunces", Georgia, serif; }

/* Hero ------------------------------------------------------------------ */
.fwd-hero {
	background: var(--fwd-deep);
	color: #fff;
	padding-block: clamp(3.5rem, 2rem + 6vw, 7rem);
}
.fwd-hero .lum-eyebrow { color: var(--fwd-leaf); }
.fwd-hero__grid { display: grid; grid-template-columns: 1.5fr 0.8fr; gap: clamp(2rem, 4vw, 4rem); align-items: center; }
.fwd-hero__title { font-size: var(--lum-step-4); margin: 1.4rem 0; letter-spacing: -0.03em; max-width: 16ch; }
.fwd-hero__lead { font-size: var(--lum-step-1); color: color-mix(in srgb, #fff 78%, var(--fwd-deep)); max-width: 52ch; }
.fwd-hero__actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2rem; }
.fwd-hero .lum-btn--ghost { color: #fff; border-color: color-mix(in srgb, #fff 36%, transparent); }
.fwd-hero .lum-btn--ghost:hover { border-color: #fff; }

.fwd-hero__card {
	background: linear-gradient(160deg, var(--fwd-leaf), var(--lum-accent));
	color: var(--fwd-deep);
	border-radius: var(--lum-radius-lg);
	padding: clamp(1.8rem, 1rem + 2vw, 2.6rem);
}
.fwd-hero__card-label { font-family: var(--lum-font-mono); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; }
.fwd-hero__card-num { display: block; font-family: var(--lum-font-display); font-size: clamp(3.4rem, 2rem + 6vw, 5rem); line-height: 1; font-weight: 600; margin: 0.6rem 0; }
.fwd-hero__card p { font-weight: 500; }
.fwd-hero__card-link { display: inline-block; margin-top: 1.2rem; font-weight: 700; text-decoration: none; }
.fwd-hero__card-link:hover { text-decoration: underline; }
@media (max-width: 860px) { .fwd-hero__grid { grid-template-columns: 1fr; } }

/* Stats ----------------------------------------------------------------- */
.fwd-stats { background: var(--fwd-sand); }
.fwd-stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; padding-block: clamp(2.4rem, 1.5rem + 3vw, 4rem); }
.fwd-stat { text-align: left; }
.fwd-stat__num { display: block; font-family: var(--lum-font-display); font-size: clamp(2.6rem, 1.6rem + 4vw, 4.4rem); line-height: 0.95; font-weight: 600; color: var(--lum-accent); letter-spacing: -0.03em; }
.fwd-stat__label { display: block; margin-top: 0.5rem; color: var(--lum-ink-soft); font-size: 0.95rem; max-width: 22ch; }
@media (max-width: 760px) { .fwd-stats__grid { grid-template-columns: 1fr 1fr; gap: 2rem 1.5rem; } }

/* Programs -------------------------------------------------------------- */
.fwd-work__head { margin-bottom: clamp(2rem, 1rem + 3vw, 3.2rem); max-width: 30ch; }
.fwd-work__head h2 { font-size: var(--lum-step-3); margin-top: 0.6rem; }
.fwd-causes { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.2rem, 0.5rem + 2vw, 2rem); }
.fwd-cause { border: 1px solid var(--lum-line); border-radius: var(--lum-radius-lg); overflow: hidden; display: flex; flex-direction: column; transition: transform 0.5s var(--lum-ease), box-shadow 0.5s; }
.fwd-cause:hover { transform: translateY(-6px); box-shadow: var(--lum-shadow); }
.fwd-cause__media { aspect-ratio: 16 / 11; overflow: hidden; }
.fwd-cause__media img { width: 100%; height: 100%; object-fit: cover; }
.fwd-cause__media--ph {
	background:
		radial-gradient(90% 90% at 30% 20%, color-mix(in srgb, var(--fwd-leaf) 55%, transparent), transparent 60%),
		linear-gradient(160deg, var(--lum-accent), var(--fwd-deep));
}
.fwd-cause__body { padding: 1.6rem; display: flex; flex-direction: column; gap: 0.7rem; flex: 1; }
.fwd-cause__body h3 { font-size: var(--lum-step-1); }
.fwd-cause__body p { color: var(--lum-ink-soft); font-size: 0.96rem; flex: 1; }
.fwd-progress { height: 8px; border-radius: 99px; background: var(--lum-surface); overflow: hidden; margin-top: 0.4rem; }
.fwd-progress__bar { display: block; height: 100%; width: var(--pct, 50%); border-radius: 99px; background: linear-gradient(90deg, var(--lum-accent), var(--fwd-leaf)); }
.fwd-progress__label { font-family: var(--lum-font-mono); font-size: 0.74rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--lum-accent); }
@media (max-width: 820px) { .fwd-causes { grid-template-columns: 1fr; max-width: 460px; } }

/* Story ----------------------------------------------------------------- */
.fwd-story__grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(2rem, 4vw, 4rem); align-items: center; }
.fwd-story__media {
	aspect-ratio: 5 / 4;
	border-radius: var(--lum-radius-lg);
	background:
		radial-gradient(70% 70% at 70% 30%, color-mix(in srgb, var(--fwd-leaf) 40%, transparent), transparent 60%),
		linear-gradient(200deg, var(--fwd-sand), var(--lum-accent));
}
.fwd-story__quote { border: 0; padding: 0; font-family: var(--lum-font-display); font-size: var(--lum-step-2); line-height: 1.2; font-style: italic; margin: 1rem 0 1.2rem; }
.fwd-story__cite { color: var(--lum-ink-soft); font-style: normal; font-size: 0.92rem; }
@media (max-width: 820px) { .fwd-story__grid { grid-template-columns: 1fr; } }

/* Give ------------------------------------------------------------------ */
.fwd-give__inner {
	background: var(--fwd-deep);
	color: #fff;
	border-radius: var(--lum-radius-lg);
	padding: clamp(2rem, 1.4rem + 3vw, 4rem);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(1.5rem, 3vw, 3rem);
	align-items: center;
}
.fwd-give__title { font-size: var(--lum-step-3); margin-bottom: 0.8rem; }
.fwd-give__text p { color: color-mix(in srgb, #fff 76%, var(--fwd-deep)); max-width: 40ch; }
.fwd-give__amounts { display: grid; grid-template-columns: 1fr 1fr; gap: 0.8rem; }
.fwd-amount {
	display: grid; place-items: center;
	padding: 1.1rem; border-radius: 14px;
	border: 1px solid color-mix(in srgb, #fff 26%, transparent);
	font-family: var(--lum-font-display); font-size: var(--lum-step-1); font-weight: 600;
	text-decoration: none; color: #fff;
	transition: background 0.3s, border-color 0.3s, transform 0.3s var(--lum-ease);
}
.fwd-amount:hover { background: var(--lum-accent); border-color: var(--lum-accent); transform: translateY(-3px); }
.fwd-give__cta { grid-column: 1 / -1; justify-content: center; background: var(--fwd-leaf); color: var(--fwd-deep); }
@media (max-width: 760px) { .fwd-give__inner { grid-template-columns: 1fr; } }
