/* Home page — nonprofit template refresh */

.home-hero {
  min-height: 680px;
  display: grid;
  grid-template-columns: minmax(320px, 0.9fr) 1.1fr;
  align-items: center;
  background:
    linear-gradient(105deg, rgba(13,79,128,0.96) 0%, rgba(13,79,128,0.82) 43%, rgba(13,79,128,0.08) 100%),
    url("A.png") center / cover no-repeat;
  position: relative;
  overflow: hidden;
}
.home-hero::after {
  content: "";
  position: absolute;
  right: -120px;
  bottom: -120px;
  width: 360px;
  height: 360px;
  border-radius: 50%;
  border: 48px solid rgba(41,171,226,0.2);
}
.home-hero-left { padding: 72px 52px 72px 72px; position: relative; z-index: 1; }
.home-hero-right { min-height: 100%; }
.change-world-tag {
  display: inline-flex;
  background: rgba(255,255,255,0.16);
  border: 1px solid rgba(255,255,255,0.28);
  color: #fff;
  border-radius: 999px;
  padding: 9px 16px;
  font-size: 0.94rem;
  font-weight: 900;
  margin-bottom: 18px;
}
.home-hero-left h1 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: clamp(3.4rem, 7vw, 6.8rem);
  color: #fff;
  line-height: 0.98;
  letter-spacing: -0.05em;
  margin-bottom: 26px;
  max-width: 760px;
}
.home-hero-left .hero-subtitle {
  max-width: 640px;
  color: rgba(255,255,255,0.9);
  font-size: 1.24rem;
  line-height: 1.7;
  font-weight: 700;
  margin-bottom: 30px;
}
.home-hero .hero-video-thumb { display: none; }

.mvv-section {
  padding: 84px 40px;
  background: linear-gradient(180deg, #fff 0%, #eaf7ff 100%);
}
.mvv-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  max-width: 1160px;
  margin: 0 auto;
}
.mvv-card {
  border-radius: 30px;
  padding: 42px 34px 38px;
  min-height: 295px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  background: #fff;
  box-shadow: var(--shadow);
  border: 1px solid rgba(13,79,128,0.08);
  position: relative;
  overflow: hidden;
}
.mvv-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 9px;
  background: var(--card-color);
}
.mvv-blue { --card-color: var(--blue); }
.mvv-green { --card-color: var(--green); }
.mvv-yellow { --card-color: var(--yellow); }
.mvv-icon {
  width: 104px;
  height: 104px;
  display: grid;
  place-items: center;
}
.mvv-icon svg { width: 100%; height: 100%; }
.mvv-card h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 2.15rem;
  color: var(--ink);
}
.mvv-card p { font-size: 1rem; line-height: 1.65; color: var(--muted); font-weight: 700; }

.about-section {
  padding: 92px 52px;
  background:
    radial-gradient(circle at left top, rgba(41,171,226,0.18), transparent 30%),
    #fff;
}
.about-inner {
  display: grid;
  grid-template-columns: 1.06fr 0.94fr;
  gap: 62px;
  align-items: start;
  max-width: 1200px;
  margin: 0 auto;
}
.about-eyebrow { margin-bottom: 12px; }
.about-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: clamp(2.2rem, 4vw, 4rem);
  line-height: 1.05;
  color: var(--ink);
  margin-bottom: 34px;
  letter-spacing: -0.03em;
}
.stem-colored { color: var(--blue); }
.about-photos {
  display: grid;
  grid-template-columns: 0.82fr 1.22fr 0.82fr;
  grid-template-rows: 220px 220px;
  gap: 16px;
}
.about-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 28px;
  border: none;
  box-shadow: 0 18px 34px rgba(23,50,77,0.13);
}
.about-photo:nth-child(1) { grid-column: 1; grid-row: 1 / 3; border-bottom: 10px solid var(--red); }
.about-photo:nth-child(2) { grid-column: 2; grid-row: 1; border-bottom: 10px solid var(--green); }
.about-photo:nth-child(3) { grid-column: 2; grid-row: 2; border-bottom: 10px solid var(--blue); }
.about-photo:nth-child(4) { grid-column: 3; grid-row: 1 / 3; border-bottom: 10px solid var(--yellow); }
.about-right {
  padding-top: 168px;
}
.about-bold-quote {
  font-weight: 900;
  font-size: 1.18rem;
  color: var(--dark-blue);
  line-height: 1.7;
  margin-bottom: 18px;
  background: var(--sky-soft);
  border-left: 6px solid var(--blue);
  border-radius: 20px;
  padding: 20px;
}
.about-body { font-size: 1.02rem; line-height: 1.8; color: var(--muted); margin-bottom: 14px; font-weight: 700; }
.about-checks { display: flex; gap: 12px; flex-wrap: wrap; font-size: 0.96rem; font-weight: 900; color: var(--ink); margin: 22px 0; }
.about-checks .sep { color: #cbd8e2; }
.btn-donate-red {
  background: linear-gradient(135deg, var(--red), #ff6a4e);
  color: #fff;
  border: none;
  border-radius: 999px;
  padding: 14px 40px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 900;
  font-size: 1rem;
  cursor: pointer;
  letter-spacing: 0.05em;
}

.workshops-section {
  padding: 94px 40px;
  background:
    linear-gradient(rgba(234,247,255,0.84), rgba(255,255,255,0.96)),
    linear-gradient(90deg, rgba(41,171,226,0.13) 1px, transparent 1px),
    linear-gradient(0deg, rgba(41,171,226,0.13) 1px, transparent 1px);
  background-size: auto, 42px 42px, 42px 42px;
}
.workshops-title-deco { display: flex; align-items: center; gap: 18px; justify-content: center; margin-bottom: 48px; }
.workshops-title-deco h2 { font-family: 'Plus Jakarta Sans', sans-serif; font-size: clamp(2.2rem, 4vw, 3.4rem); color: var(--ink); }
.dash { width: 54px; height: 5px; border-radius: 99px; }
.yellow-dash { background: var(--yellow); }
.workshop-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  max-width: 1280px;
  margin: 0 auto;
}
.workshop-card {
  background: #fff;
  border-radius: 30px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow);
  border: 1px solid rgba(13,79,128,0.1);
}
.ws-img { aspect-ratio: 4 / 3; overflow: hidden; }
.ws-img img { width: 100%; height: 100%; object-fit: cover; }
.ws-body {
  padding: 26px;
  background: #fff;
  border-top: 9px solid var(--workshop-color);
  flex: 1;
  display: flex;
  flex-direction: column;
}
.ws-body h3 { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 1.55rem; margin-bottom: 12px; color: var(--ink); }
.ws-red { --workshop-color: var(--red); }
.ws-yellow { --workshop-color: var(--yellow); }
.ws-blue { --workshop-color: var(--blue); }
.ws-green { --workshop-color: var(--green); }
.ws-body p { font-size: 0.98rem; color: var(--muted); line-height: 1.65; font-weight: 700; flex: 1; }
.ws-btn {
  margin-top: 22px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  border-radius: 999px;
  padding: 12px 18px;
  background: var(--workshop-color);
  color: #fff;
  font-weight: 900;
  box-shadow: 0 10px 20px rgba(13,79,128,0.12);
}
.ws-yellow .ws-btn { color: #222; }

@media (max-width: 980px) {
  .home-hero, .about-inner, .mvv-grid { grid-template-columns: 1fr; }
  .workshop-cards { grid-template-columns: repeat(2, 1fr); }
  .home-hero-left { padding: 64px 30px; }
  .about-right { padding-top: 0; }
}
@media (max-width: 700px) {
  .about-section, .workshops-section { padding-left: 20px; padding-right: 20px; }
  .about-photos { grid-template-columns: 1fr; grid-template-rows: none; }
  .about-photo:nth-child(1), .about-photo:nth-child(2), .about-photo:nth-child(3), .about-photo:nth-child(4) { grid-column: auto; grid-row: auto; }
  .about-photo:nth-child(1), .about-photo:nth-child(4) { aspect-ratio: 4/5; }
  .about-photo:nth-child(2), .about-photo:nth-child(3) { aspect-ratio: 16/10; }
  .workshop-cards { grid-template-columns: 1fr; }
}
.btn-donate-orange { display: inline-flex; align-items: center; justify-content: center; text-align: center; }
.btn-donate-red { display: inline-flex; align-items: center; justify-content: center; text-align: center; }

/* Requested About and campaign refinements */
.about-photos {
  grid-template-columns: 1.25fr 0.78fr;
  grid-template-rows: 230px 230px;
}
.about-photo:nth-child(1) { grid-column: 1; grid-row: 1; }
.about-photo:nth-child(2) { grid-column: 2; grid-row: 1; }
.about-photo:nth-child(3) { grid-column: 1; grid-row: 2; }
.about-photo:nth-child(4) { grid-column: 2; grid-row: 2; }
.about-photo:nth-child(1), .about-photo:nth-child(3) { aspect-ratio: 16/9; }
.about-photo:nth-child(2), .about-photo:nth-child(4) { aspect-ratio: 4/5; }
.about-who-title {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--blue);
  font-weight: 900;
  font-size: 1.35rem;
  margin-bottom: 18px;
}
.about-who-title::before {
  content: "";
  width: 42px;
  height: 5px;
  border-radius: 99px;
  background: var(--blue);
}
.feature-icon { margin-right: 6px; }
.campaign-progress { margin-top: 18px; }
.campaign-progress-label { display: flex; justify-content: space-between; gap: 12px; color: var(--ink); font-weight: 900; font-size: 0.85rem; }
.campaign-bar { height: 12px; background: #e5eef5; border-radius: 999px; overflow: hidden; margin-top: 8px; }
.campaign-bar span { display: block; height: 100%; background: linear-gradient(90deg, var(--green), var(--blue)); border-radius: inherit; }
.campaign-amounts { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-top: 14px; }
.campaign-amounts button,
.campaign-custom { border: 1px solid rgba(13,79,128,0.18); border-radius: 999px; padding: 9px 8px; font: inherit; font-weight: 900; }
.campaign-amounts button { background: var(--sky-soft); color: var(--ink); cursor: pointer; }
.campaign-amounts button.is-selected { background: var(--yellow); }
.campaign-custom { width: 100%; margin-top: 10px; border-radius: 16px; }
.paypal-donate-btn { background: var(--red); }
@media (max-width: 700px) {
  .about-photo:nth-child(1), .about-photo:nth-child(2), .about-photo:nth-child(3), .about-photo:nth-child(4) { aspect-ratio: auto; }
}

/* Final 2x2 mosaic proportions: wide/vertical, then reversed */
.about-photos {
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: 230px 230px;
}
.about-photo:nth-child(1) { grid-column: 1 / span 3; grid-row: 1; }
.about-photo:nth-child(2) { grid-column: 4; grid-row: 1; }
.about-photo:nth-child(3) { grid-column: 1; grid-row: 2; }
.about-photo:nth-child(4) { grid-column: 2 / span 3; grid-row: 2; }

/* More polished campaign controls shared by the workshop reference card. */
.campaign-progress {
  background: linear-gradient(180deg, rgba(217,241,255,0.72), rgba(255,255,255,0.92));
  border: 1px solid rgba(41,171,226,0.18);
  border-radius: 22px;
  padding: 16px;
}
.campaign-progress-label {
  align-items: center;
  font-size: 0.9rem;
}
.campaign-bar {
  height: 15px;
  padding: 3px;
  background: #fff;
  box-shadow: inset 0 0 0 1px rgba(13,79,128,0.12), inset 0 2px 8px rgba(13,79,128,0.08);
}
.campaign-bar span {
  background: linear-gradient(90deg, var(--green), var(--blue), var(--yellow));
  box-shadow: 0 6px 14px rgba(41,171,226,0.22);
}
.campaign-amounts {
  gap: 10px;
}
.campaign-amounts button,
.campaign-custom {
  border: 2px solid rgba(13,79,128,0.1);
  box-shadow: 0 8px 18px rgba(13,79,128,0.08);
}
.campaign-amounts button {
  background: #fff;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}
.campaign-amounts button:hover,
.campaign-amounts button.is-selected {
  background: var(--yellow);
  transform: translateY(-2px);
  box-shadow: 0 12px 22px rgba(245,197,24,0.25);
}
