/* =========================================================
   Participación solidaria (solo estilos de esta página)
   - Mosaicos de fotos estilo editorial (NO carrusel)
   - Mantiene el look institucional del sitio
========================================================= */

/* Espaciado del bloque */
.storyBlock .blockHead{
  display: grid;
  gap: 10px;
}

/* Cabecera del bloque (icono + título) */
.blockTitle{
  display:flex;
  align-items:center;
  gap: 10px;
}

.blockIcon{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  font-size: 18px;
  /* Usa la estética global suave (combina con tu theme) */
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(20,36,70,.12);
  box-shadow: 0 12px 28px rgba(20,36,70,.10);
}

/* ===== 1) Mosaico editorial (4 fotos) ===== */
.photoMosaic{
  margin-top: 14px;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  grid-template-rows: 220px 220px;
  gap: 12px;
}

.mItem{
  position: relative;
  overflow:hidden;
  border-radius: 18px;
  border: 1px solid rgba(20,36,70,.12);
  background: rgba(255,255,255,.65);
  box-shadow: 0 16px 40px rgba(20,36,70,.10);
  transform: translateZ(0);
}

.mItem img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
  transition: transform .35s ease;
}

.mItem figcaption{
  position:absolute;
  left: 10px;
  bottom: 10px;
  padding: 8px 10px;
  border-radius: 14px;
  font-size: 12px;
  font-weight: 900;
  color: rgba(20,36,70,.92);
  background: rgba(255,255,255,.84);
  border: 1px solid rgba(20,36,70,.12);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.mItem:hover img{ transform: scale(1.04); }

/* Posiciones del mosaico */
.mA{ grid-row: 1 / span 2; grid-column: 1; }
.mB{ grid-row: 1; grid-column: 2; }
.mC{ grid-row: 2; grid-column: 2; }
.mD{ display:none; } /* si quieres 4, lo activamos en móvil como extra */

/* ===== 2) Strip: foto grande + dos pequeñas ===== */
.photoStrip{
  margin-top: 14px;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 12px;
  align-items: stretch;
}

.pMain, .pSide figure{
  position: relative;
  overflow:hidden;
  border-radius: 18px;
  border: 1px solid rgba(20,36,70,.12);
  background: rgba(255,255,255,.65);
  box-shadow: 0 16px 40px rgba(20,36,70,.10);
}

.pMain{ height: 360px; }
.pSide{ display:grid; gap: 12px; }
.pSide figure{ height: 174px; }

.pMain img, .pSide img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
  transition: transform .35s ease;
}

.pMain figcaption, .pSide figcaption{
  position:absolute;
  left: 10px;
  bottom: 10px;
  padding: 8px 10px;
  border-radius: 14px;
  font-size: 12px;
  font-weight: 900;
  color: rgba(20,36,70,.92);
  background: rgba(255,255,255,.84);
  border: 1px solid rgba(20,36,70,.12);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.pMain:hover img, .pSide figure:hover img{ transform: scale(1.04); }

/* ===== 3) Galería de eventos en “tarjetas” ===== */
.eventGallery{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.eCard{
  overflow:hidden;
  border-radius: 18px;
  border: 1px solid rgba(20,36,70,.12);
  background: rgba(255,255,255,.70);
  box-shadow: 0 16px 40px rgba(20,36,70,.10);
  transition: transform .18s ease, box-shadow .18s ease;
}

.eCard:hover{
  transform: translateY(-2px);
  box-shadow: 0 22px 54px rgba(20,36,70,.14);
}

.eCard img{
  width: 100%;
  height: 210px;
  object-fit: cover;
  display:block;
}

.eCard figcaption{
  padding: 12px 12px 14px;
  display:grid;
  gap: 4px;
}

.eCard figcaption strong{
  font-weight: 1000;
  color: rgba(20,36,70,.95);
}

.eCard figcaption span{
  font-size: 12px;
  font-weight: 900;
  color: rgba(20,36,70,.70);
}

/* ===== 4) Donativos: foto + cita ===== */
.donativosSplit{
  margin-top: 14px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  align-items: stretch;
}

.donPhoto{
  overflow:hidden;
  border-radius: 18px;
  border: 1px solid rgba(20,36,70,.12);
  background: rgba(255,255,255,.70);
  box-shadow: 0 16px 40px rgba(20,36,70,.10);
}

.donPhoto img{
  width: 100%;
  height: 320px;
  object-fit: cover;
  display:block;
}

.donPhoto figcaption{
  padding: 10px 12px 12px;
  font-size: 12px;
  font-weight: 900;
  color: rgba(20,36,70,.70);
}

.donQuote{
  border-radius: 18px;
  border: 1px solid rgba(20,36,70,.12);
  background:
    radial-gradient(420px 160px at 10% 0%, rgba(179,204,246,.55), transparent 60%),
    radial-gradient(420px 160px at 90% 0%, rgba(173,132,227,.22), transparent 60%),
    rgba(255,255,255,.86);
  box-shadow: 0 16px 40px rgba(20,36,70,.10);
  padding: 16px;
  display:grid;
  gap: 10px;
}

.quoteBadge{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  font-weight: 1000;
  font-size: 12px;
  color: rgba(20,36,70,.92);
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(20,36,70,.12);
  width: fit-content;
}

.donQuote blockquote{
  margin: 0;
  font-size: 15px;
  line-height: 1.7;
  font-weight: 900;
  color: rgba(20,36,70,.92);
}

.quoteHint{
  margin: 0;
  font-size: 12px;
  font-weight: 900;
  color: rgba(20,36,70,.65);
  line-height: 1.6;
}

.btnSoftCta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 14px;
  text-decoration:none;
  font-weight: 1000;
  color: rgba(20,36,70,.92);
  background: rgba(255,255,255,.84);
  border: 1px solid rgba(20,36,70,.12);
  box-shadow: 0 12px 28px rgba(20,36,70,.10);
  width: fit-content;
}

.btnSoftCta:hover{
  background: rgba(179,204,246,.28);
  border-color: rgba(173,132,227,.22);
}

/* Responsive */
@media (max-width: 980px){
  .photoMosaic{ grid-template-columns: 1fr; grid-template-rows: 240px 180px 180px; }
  .mA{ grid-row:auto; grid-column:auto; }
  .mB, .mC{ grid-row:auto; grid-column:auto; }
  .mD{ display:block; height: 180px; } /* en móvil mostramos la 4ta */
  .photoStrip{ grid-template-columns: 1fr; }
  .pMain{ height: 240px; }
  .pSide figure{ height: 180px; }
  .eventGallery{ grid-template-columns: 1fr; }
  .donativosSplit{ grid-template-columns: 1fr; }
  .donPhoto img{ height: 240px; }
}