/* =============================================================
   Mithila Mission & Vision Page — mission-vision.css  v1.0
   Sections: intro · mission · what-we-do · vision · values
             impact · museum · subscribe
   Colour scheme: Creedy theme CSS variables
   ============================================================= */

@import url('https://fonts.googleapis.com/css2?family=Dancing+Script:wght@600&display=swap');

/* ── Reset ───────────────────────────────────────────────── */
.mmv-page *,
.mmv-page *::before,
.mmv-page *::after { box-sizing: border-box; }
.mmv-page img     { max-width: 100%; height: auto; display: block; }
.mmv-page ul,
.mmv-page ol      { list-style: none; margin: 0; padding: 0; }
.mmv-page figure  { margin: 0; }
.mmv-page p       { margin-top: 0; }

.mmv-page {
	width: 100%;
	font-family: var(--wdtFontTypo_Base, 'Roboto', sans-serif);
	color: var(--wdtBodyTxtColor, #202020);
	background: var(--wdtBodyBGColor, #fff);
}
.mmv-page section {
	display: block;
	width: 100%;
	position: relative;
}

/* ── Container ───────────────────────────────────────────── */
.mmv-container {
	width: 100%;
	max-width: 1240px;
	margin-inline: auto;
	padding-inline: clamp(1.25rem, 4vw, 3rem);
}

/* ── Shared typography ──────────────────────────────────── */
.mmv-h2 {
	font-family: var(--wdtFontTypo_Alt, 'Oswald', sans-serif);
	font-size: clamp(1.9rem, 3.8vw, 2.8rem);
	font-weight: var(--wdtFontWeight_Alt, 700);
	color: var(--wdtHeadAltColor, #202020);
	line-height: 1.2;
	margin: 0 0 1.1rem;
}
.mmv-h2--center { text-align: center; }
.mmv-h2--light  { color: #fff; }

.mmv-script-kicker {
	display: block;
	font-family: 'Dancing Script', cursive;
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--wdtPrimaryColor, #d88e7d);
	margin-bottom: .6rem;
	line-height: 1.3;
}
.mmv-script-kicker--center { text-align: center; font-size: 1.5rem; }
.mmv-script-kicker--light  { color: rgba(255,255,255,.85); }

.mmv-divider {
	width: 52px; height: 4px;
	background: var(--wdtPrimaryColor, #d88e7d);
	border-radius: 2px;
	margin-bottom: 1.5rem;
}
.mmv-divider--center { margin-inline: auto; }
.mmv-divider--light  { background: rgba(255,255,255,.55); }

/* ── Button ─────────────────────────────────────────────── */
.mmv-btn {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .72rem 1.75rem;
	background: var(--wdtPrimaryColor, #d88e7d);
	color: #fff;
	border: 2px solid var(--wdtPrimaryColor, #d88e7d);
	border-radius: var(--wdtRadius_Part, 2.5em);
	font-size: .9375rem;
	font-weight: 600;
	font-family: var(--wdtFontTypo_Base, 'Roboto', sans-serif);
	text-decoration: none;
	transition: var(--wdtBaseTransition, all .3s linear);
	cursor: pointer;
	line-height: 1;
	margin-top: 1.5rem;
}
.mmv-btn:hover {
	background: var(--wdtSecondaryColor, #363e5a);
	border-color: var(--wdtSecondaryColor, #363e5a);
	color: #fff;
}
.mmv-btn--outline {
	background: transparent;
	color: #fff;
	border-color: rgba(255,255,255,.65);
}
.mmv-btn--outline:hover {
	background: #fff;
	border-color: #fff;
	color: var(--wdtSecondaryColor, #363e5a);
}

/* ── Pull quote ──────────────────────────────────────────── */
.mmv-pullquote {
	border-left: 4px solid var(--wdtPrimaryColor, #d88e7d);
	padding: 1rem 1.5rem;
	margin: 1.5rem 0;
	background: var(--wdtTertiaryColor, #f8eae1);
	border-radius: 0 var(--wdtRadius_3X, 10px) var(--wdtRadius_3X, 10px) 0;
}
.mmv-pullquote p {
	font-family: var(--wdtFontTypo_Alt, 'Oswald', sans-serif);
	font-size: 1.1rem;
	font-weight: 500;
	font-style: italic;
	color: var(--wdtSecondaryColor, #363e5a);
	line-height: 1.65;
	margin: 0;
}

/* =============================================================
   1. PAGE INTRO
   ============================================================= */
.mmv-intro {
	background: var(--wdtTertiaryColor, #f8eae1);
	padding-block: clamp(4rem, 7vw, 6rem);
	overflow: hidden;
}
.mmv-intro__pattern {
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg stroke='%23d88e7d' stroke-width='0.5' opacity='0.18'%3E%3Ccircle cx='30' cy='30' r='25'/%3E%3Ccircle cx='30' cy='30' r='15'/%3E%3Ccircle cx='30' cy='30' r='5'/%3E%3Cline x1='5' y1='30' x2='55' y2='30'/%3E%3Cline x1='30' y1='5' x2='30' y2='55'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
	background-size: 60px 60px;
	pointer-events: none;
	z-index: 0;
}
.mmv-intro__inner {
	position: relative;
	z-index: 1;
	max-width: 800px;
	margin-inline: auto;
	text-align: center;
}
.mmv-intro__lead {
	font-size: clamp(1.05rem, 2vw, 1.2rem);
	line-height: 1.85;
	color: var(--wdtBodyTxtColor, #202020);
	opacity: .82;
	max-width: 68ch;
	margin: 0 auto;
}

/* =============================================================
   2. MISSION
   ============================================================= */
.mmv-mission {
	background: var(--wdtBodyBGColor, #fff);
	padding-block: clamp(4rem, 7vw, 6.5rem);
	overflow: hidden;
}
.mmv-mission__pattern {
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg stroke='%23d88e7d' stroke-width='0.5' opacity='0.07'%3E%3Ccircle cx='30' cy='30' r='25'/%3E%3Ccircle cx='30' cy='30' r='15'/%3E%3Ccircle cx='30' cy='30' r='5'/%3E%3Cline x1='5' y1='30' x2='55' y2='30'/%3E%3Cline x1='30' y1='5' x2='30' y2='55'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
	background-size: 60px 60px;
	pointer-events: none;
	z-index: 0;
}
.mmv-mission__grid {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2.5rem, 5vw, 5.5rem);
	align-items: center;
}
.mmv-mission__figure img {
	width: 100%;
	max-width: 520px;
	aspect-ratio: 1/1;
	object-fit: cover;
	border-radius: 50%;
	box-shadow: 0 8px 36px rgba(54,62,90,.15);
	margin-inline: auto;
}
.mmv-mission__body p {
	font-size: 1rem;
	line-height: 1.8;
	color: var(--wdtBodyTxtColor, #202020);
	opacity: .82;
	margin-bottom: 1rem;
}
.mmv-mission__body p:last-child { margin-bottom: 0; }

@media (max-width: 820px) {
	.mmv-mission__grid { grid-template-columns: 1fr; }
	.mmv-mission__figure img { border-radius: var(--wdtRadius_3X, 10px); }
}

/* =============================================================
   3. WHAT WE DO — four programme cards
   ============================================================= */
.mmv-what {
	background: var(--wdtTertiaryColor, #f8eae1);
	padding-block: clamp(4rem, 7vw, 6.5rem);
}
.mmv-what__intro {
	text-align: center;
	max-width: 640px;
	margin-inline: auto;
	margin-bottom: clamp(2.5rem, 5vw, 4rem);
}
.mmv-what__intro p {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--wdtBodyTxtColor, #202020);
	opacity: .78;
}
.mmv-what__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1.5rem;
}
.mmv-what__card {
	background: #fff;
	border-radius: var(--wdtRadius_3X, 10px);
	padding: 2rem 1.5rem;
	box-shadow: 0 4px 20px rgba(54,62,90,.07);
	transition: transform .3s ease, box-shadow .3s ease;
	text-align: center;
}
.mmv-what__card:hover {
	transform: translateY(-5px);
	box-shadow: 0 12px 32px rgba(54,62,90,.13);
}
.mmv-what__card-icon {
	width: 64px; height: 64px;
	border-radius: 50%;
	background: var(--wdtTertiaryColor, #f8eae1);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1.25rem;
	font-size: 1.75rem;
	border: 2px solid rgba(216,142,125,.25);
}
.mmv-what__card-title {
	font-family: var(--wdtFontTypo_Alt, 'Oswald', sans-serif);
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--wdtSecondaryColor, #363e5a);
	margin-bottom: .65rem;
}
.mmv-what__card-desc {
	font-size: .9375rem;
	line-height: 1.72;
	color: var(--wdtBodyTxtColor, #202020);
	opacity: .75;
	margin: 0;
}

@media (max-width: 900px) {
	.mmv-what__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 500px) {
	.mmv-what__grid { grid-template-columns: 1fr; }
}

/* =============================================================
   4. VISION
   ============================================================= */
.mmv-vision {
	background: var(--wdtBodyBGColor, #fff);
	padding-block: clamp(4rem, 7vw, 6.5rem);
}
.mmv-vision__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2.5rem, 5vw, 5.5rem);
	align-items: center;
}
.mmv-vision__body p {
	font-size: 1.1rem;
	line-height: 1.8;
	color: var(--wdtBodyTxtColor, #202020);
	opacity: .82;
	margin-bottom: 1rem;
}
.mmv-vision__body p:last-child { margin-bottom: 0; }
.mmv-vision__figure img {
	width: 100%;
	aspect-ratio: 4/3;
	object-fit: cover;
	border-radius: var(--wdtRadius_3X, 10px);
	box-shadow: 0 6px 28px rgba(54,62,90,.14);
	outline: 6px solid var(--wdtPrimaryColor, #d88e7d);
	outline-offset: 8px;
}

@media (max-width: 820px) {
	.mmv-vision__grid { grid-template-columns: 1fr; }
	.mmv-vision__figure { order: -1; }
}

/* =============================================================
   5. CORE VALUES — Mithila brown grid
   ============================================================= */
.mmv-values {
	background: #834d22;
	padding-block: clamp(4rem, 7vw, 6.5rem);
	position: relative;
}
.mmv-values::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 4L56 30L30 56L4 30Z' fill='none' stroke='rgba(255,255,255,.07)' stroke-width='1'/%3E%3Ccircle cx='30' cy='30' r='3' fill='rgba(255,255,255,.04)'/%3E%3C/svg%3E");
	background-size: 60px 60px;
	pointer-events: none;
	z-index: 0;
}
.mmv-values .mmv-container {
	position: relative;
	z-index: 1;
}
.mmv-values__intro {
	text-align: center;
	max-width: 640px;
	margin-inline: auto;
	margin-bottom: clamp(2.5rem, 5vw, 4rem);
}
.mmv-values__intro p {
	font-size: 1rem;
	line-height: 1.75;
	color: rgba(255,255,255,.80);
}
.mmv-values .mmv-script-kicker--light { color: rgba(255,255,255,.85); }
.mmv-values .mmv-h2--light            { color: #fff; }
.mmv-values .mmv-divider--light       { background: rgba(255,255,255,.45); }
.mmv-values__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
}
.mmv-values__card {
	background: #fdf6e3;
	border: none;
	border-radius: 16px;
	padding: 2rem 1.75rem;
	box-shadow: 0 4px 24px rgba(26,15,8,.20);
	transition: transform .3s ease, box-shadow .3s ease;
}
.mmv-values__card:hover {
	background: #fff;
	transform: translateY(-4px);
	box-shadow: 0 14px 40px rgba(26,15,8,.28);
}
.mmv-values__card-num {
	font-family: var(--wdtFontTypo_Alt, 'Playfair Display', serif);
	font-size: 2.5rem;
	font-weight: 700;
	color: #9b2335;
	line-height: 1;
	margin-bottom: .75rem;
	opacity: .75;
}
.mmv-values__card-title {
	font-family: var(--wdtFontTypo_Alt, 'Playfair Display', serif);
	font-size: 1.15rem;
	font-weight: 700;
	color: #1a0f08;
	margin-bottom: .65rem;
}
.mmv-values__card-desc {
	font-size: .9375rem;
	line-height: 1.72;
	color: rgba(26,15,8,.68);
	margin: 0;
}

@media (max-width: 820px) {
	.mmv-values__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 500px) {
	.mmv-values__grid { grid-template-columns: 1fr; }
}

/* =============================================================
   6. IMPACT AREAS — 2 × 2 image cards
   ============================================================= */
.mmv-impact {
	background: var(--wdtTertiaryColor, #f8eae1);
	padding-block: clamp(4rem, 7vw, 6.5rem);
}
.mmv-impact__intro {
	text-align: center;
	max-width: 640px;
	margin-inline: auto;
	margin-bottom: clamp(2.5rem, 5vw, 4rem);
}
.mmv-impact__intro p {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--wdtBodyTxtColor, #202020);
	opacity: .78;
}
.mmv-impact__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2rem;
}
.mmv-impact__card {
	background: #fff;
	border-radius: var(--wdtRadius_3X, 10px);
	overflow: hidden;
	box-shadow: 0 4px 24px rgba(54,62,90,.08);
	display: grid;
	grid-template-columns: 200px 1fr;
	transition: box-shadow .3s ease;
}
.mmv-impact__card:hover { box-shadow: 0 10px 36px rgba(54,62,90,.14); }
.mmv-impact__card-img {
	overflow: hidden;
}
.mmv-impact__card-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .5s ease;
}
.mmv-impact__card:hover .mmv-impact__card-img img { transform: scale(1.07); }
.mmv-impact__card-body {
	padding: 1.75rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.mmv-impact__card-kicker {
	display: inline-block;
	font-size: .78rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--wdtPrimaryColor, #d88e7d);
	margin-bottom: .5rem;
}
.mmv-impact__card-title {
	font-family: var(--wdtFontTypo_Alt, 'Oswald', sans-serif);
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--wdtSecondaryColor, #363e5a);
	margin-bottom: .65rem;
}
.mmv-impact__card-desc {
	font-size: .9375rem;
	line-height: 1.72;
	color: var(--wdtBodyTxtColor, #202020);
	opacity: .78;
	margin: 0;
}

@media (max-width: 900px) {
	.mmv-impact__grid { grid-template-columns: 1fr; }
	.mmv-impact__card { grid-template-columns: 160px 1fr; }
}
@media (max-width: 560px) {
	.mmv-impact__card { grid-template-columns: 1fr; }
	.mmv-impact__card-img { aspect-ratio: 16/7; }
}

/* =============================================================
   7. MUSEUM CTA — dark overlay banner
   ============================================================= */
.mmv-museum {
	position: relative;
	overflow: hidden;
	padding-block: clamp(5rem, 9vw, 8rem);
}
.mmv-museum__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
}
.mmv-museum__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		135deg,
		rgba(54,62,90,.92) 0%,
		rgba(54,62,90,.76) 100%
	);
}
.mmv-museum__inner {
	position: relative;
	z-index: 1;
	max-width: 760px;
	margin-inline: auto;
	text-align: center;
}
.mmv-museum__body p {
	font-size: 1.05rem;
	line-height: 1.82;
	color: rgba(255,255,255,.85);
	margin-bottom: 1rem;
}
.mmv-museum__body p:last-child { margin-bottom: 0; }
.mmv-museum__actions {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
	margin-top: 2rem;
}

/* =============================================================
   8. SUBSCRIBE
   ============================================================= */
.mmv-subscribe {
	position: relative;
	overflow: hidden;
	padding-block: clamp(4.5rem, 8vw, 7rem);
}
.mmv-subscribe__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
}
.mmv-subscribe__overlay {
	position: absolute;
	inset: 0;
	background: rgba(248,234,225,.88);
}
.mmv-subscribe__inner {
	position: relative;
	z-index: 1;
	text-align: center;
}
.mmv-subscribe__desc {
	max-width: 52ch;
	margin: 0 auto 1.75rem;
	font-size: 1rem;
	line-height: 1.7;
	color: var(--wdtBodyTxtColor, #202020);
	opacity: .78;
}
.mmv-subscribe__form {
	display: flex;
	gap: .75rem;
	max-width: 500px;
	margin-inline: auto;
	flex-wrap: wrap;
	justify-content: center;
}
.mmv-subscribe__input {
	flex: 1;
	min-width: 220px;
	padding: .78rem 1.35rem;
	border: 2px solid rgba(54,62,90,.22);
	border-radius: var(--wdtRadius_Part, 2.5em);
	font-size: 1rem;
	font-family: var(--wdtFontTypo_Base, 'Roboto', sans-serif);
	color: var(--wdtBodyTxtColor, #202020);
	background: rgba(255,255,255,.85);
	outline: none;
	transition: var(--wdtBaseTransition, all .3s linear);
}
.mmv-subscribe__input::placeholder { color: rgba(32,32,32,.45); }
.mmv-subscribe__input:focus {
	border-color: var(--wdtPrimaryColor, #d88e7d);
	background: #fff;
	box-shadow: 0 0 0 3px rgba(216,142,125,.2);
}
