/* =========================
   NOSOTROS - QUIÉNES SOMOS
========================= */

.nosotros-about {
  position: relative;
  padding: 58px 0 66px;
  overflow: hidden;
  color: var(--color-text);
  background:
    radial-gradient(circle at 8% 18%, rgba(82, 108, 255, 0.10), transparent 30%),
    radial-gradient(circle at 92% 18%, rgba(216, 118, 255, 0.11), transparent 28%),
    radial-gradient(circle at 82% 86%, rgba(119, 91, 255, 0.08), transparent 30%),
    linear-gradient(180deg, #f8f7ff 0%, #ffffff 100%);
}

.nosotros-about::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.48;
  background:
    radial-gradient(circle at 20% 35%, rgba(106, 124, 255, 0.05) 1px, transparent 1.8px),
    radial-gradient(circle at 78% 22%, rgba(180, 120, 255, 0.06) 1px, transparent 1.8px);
  background-size: 48px 48px, 54px 54px;
  mask-image: linear-gradient(180deg, transparent 0%, #000 16%, #000 84%, transparent 100%);
}

.nosotros-about::after {
  content: "";
  position: absolute;
  right: -180px;
  bottom: -220px;
  width: 540px;
  height: 540px;
  border-radius: 999px;
  pointer-events: none;
  background:
    radial-gradient(circle, rgba(181, 100, 255, 0.12), transparent 62%),
    radial-gradient(circle, rgba(79, 107, 255, 0.09), transparent 72%);
  filter: blur(24px);
}

.nosotros-about-inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 0.94fr) minmax(470px, 1.06fr);
  align-items: center;
  gap: 58px;
}

.nosotros-about-content {
  max-width: 600px;
}

.nosotros-about-content .section-label {
  margin-bottom: 18px;
}

.nosotros-about-content h2 {
  margin: 0;
  max-width: 570px;
  color: var(--color-dark);
  font-size: clamp(38px, 3.65vw, 60px);
  line-height: 1.08;
  letter-spacing: -1.45px;
  font-weight: 800;
  text-wrap: balance;
}

.nosotros-about-content h2 span {
  color: transparent;
  background: linear-gradient(
    135deg,
    #5a6fff 0%,
    #6b63ff 28%,
    #8d5cff 58%,
    #b566ff 82%,
    #cf8dff 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  font-weight: 800;
  text-shadow: none;
  filter: saturate(0.96);
}

.nosotros-about-content p {
  max-width: 520px;
  margin: 20px 0 0;
  color: rgba(25, 33, 72, 0.74);
  font-size: 16px;
  line-height: 1.72;
}

.nosotros-about-content p strong {
  color: #7a4ee9;
  font-weight: 800;
}

/* =========================
   PANEL / CARDS
========================= */

.nosotros-about-panel {
  position: relative;
  display: grid;
  gap: 18px;
  min-height: 330px;
  align-content: center;
  padding: 12px 18px 12px 0;
}

/* Brillantinas / sparkles sutiles detrás de las cards */
.nosotros-about-panel::before {
  content: "";
  position: absolute;
  inset: -14px -12px -12px -12px;
  z-index: 0;
  pointer-events: none;
  opacity: 0.95;
  background:
    radial-gradient(circle at 12% 18%, rgba(255, 255, 255, 0.98) 0 1.8px, rgba(166, 189, 255, 0.42) 2.2px, transparent 7px),
    radial-gradient(circle at 86% 10%, rgba(255, 255, 255, 0.96) 0 2px, rgba(230, 154, 255, 0.38) 2.5px, transparent 8px),
    radial-gradient(circle at 90% 56%, rgba(255, 255, 255, 0.94) 0 1.7px, rgba(172, 188, 255, 0.34) 2.1px, transparent 7px),
    radial-gradient(circle at 8% 78%, rgba(255, 255, 255, 0.94) 0 1.9px, rgba(214, 165, 255, 0.34) 2.3px, transparent 8px),
    radial-gradient(circle at 76% 88%, rgba(255, 255, 255, 0.92) 0 1.5px, rgba(196, 178, 255, 0.28) 1.9px, transparent 6px),
    radial-gradient(circle at 28% 48%, rgba(255, 255, 255, 0.84) 0 1.1px, rgba(181, 198, 255, 0.20) 1.5px, transparent 4px),
    radial-gradient(circle at 62% 22%, rgba(255, 255, 255, 0.82) 0 1px, rgba(219, 175, 255, 0.20) 1.4px, transparent 4px);
  filter: blur(0.2px) drop-shadow(0 0 8px rgba(186, 155, 255, 0.16));
}

.nosotros-about-panel::after {
  content: "";
  position: absolute;
  inset: -6px -22px -10px -10px;
  z-index: 0;
  pointer-events: none;
  opacity: 0.82;
  background:
    linear-gradient(rgba(172, 184, 255, 0.56), rgba(172, 184, 255, 0.56)) 18% 16% / 1px 16px no-repeat,
    linear-gradient(rgba(172, 184, 255, 0.56), rgba(172, 184, 255, 0.56)) 18% 16% / 16px 1px no-repeat,

    linear-gradient(rgba(215, 154, 255, 0.54), rgba(215, 154, 255, 0.54)) 84% 12% / 1px 18px no-repeat,
    linear-gradient(rgba(215, 154, 255, 0.54), rgba(215, 154, 255, 0.54)) 84% 12% / 18px 1px no-repeat,

    linear-gradient(rgba(186, 171, 255, 0.48), rgba(186, 171, 255, 0.48)) 92% 58% / 1px 14px no-repeat,
    linear-gradient(rgba(186, 171, 255, 0.48), rgba(186, 171, 255, 0.48)) 92% 58% / 14px 1px no-repeat,

    linear-gradient(rgba(185, 198, 255, 0.42), rgba(185, 198, 255, 0.42)) 10% 82% / 1px 12px no-repeat,
    linear-gradient(rgba(185, 198, 255, 0.42), rgba(185, 198, 255, 0.42)) 10% 82% / 12px 1px no-repeat,

    linear-gradient(rgba(217, 171, 255, 0.36), rgba(217, 171, 255, 0.36)) 74% 90% / 1px 10px no-repeat,
    linear-gradient(rgba(217, 171, 255, 0.36), rgba(217, 171, 255, 0.36)) 74% 90% / 10px 1px no-repeat;
  filter:
    blur(0.15px)
    drop-shadow(0 0 6px rgba(174, 163, 255, 0.16))
    drop-shadow(0 0 12px rgba(217, 163, 255, 0.10));
}

.nosotros-about-card {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 72px 48px minmax(0, 1fr);
  align-items: center;
  column-gap: 18px;
  width: min(620px, 100%);
  min-height: 96px;
  padding: 15px 24px 15px 18px;
  border-radius: 22px;
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(circle at 12% 20%, rgba(90, 127, 255, 0.30), transparent 28%),
    radial-gradient(circle at 92% 42%, rgba(207, 78, 255, 0.24), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.035) 42%, rgba(255, 255, 255, 0.10)),
    linear-gradient(135deg, #081338 0%, #121d48 46%, #331a66 74%, #5e2291 100%);
  border: 1px solid rgba(255, 255, 255, 0.17);
  box-shadow:
    0 22px 46px rgba(18, 20, 58, 0.20),
    0 8px 22px rgba(85, 48, 164, 0.15),
    inset 0 1px 0 rgba(255, 255, 255, 0.24),
    inset 0 -1px 0 rgba(255, 255, 255, 0.07);
  transition:
    transform 0.25s ease,
    box-shadow 0.25s ease,
    border-color 0.25s ease;
}

.nosotros-about-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: 0.72;
  background:
    linear-gradient(
      112deg,
      transparent 0%,
      transparent 38%,
      rgba(255, 255, 255, 0.12) 48%,
      rgba(255, 255, 255, 0.025) 58%,
      transparent 100%
    );
}

.nosotros-about-card::after {
  content: "";
  position: absolute;
  top: -90%;
  left: -42%;
  z-index: 1;
  width: 36%;
  height: 260%;
  pointer-events: none;
  opacity: 0;
  transform: rotate(18deg);
  background: linear-gradient(
    115deg,
    transparent 0%,
    rgba(255, 255, 255, 0.05) 30%,
    rgba(255, 255, 255, 0.34) 50%,
    rgba(255, 255, 255, 0.05) 70%,
    transparent 100%
  );
  transition:
    left 0.75s ease,
    opacity 0.28s ease;
}

.nosotros-about-card:hover {
  transform: translateY(-5px);
  border-color: rgba(203, 161, 255, 0.42);
  box-shadow:
    0 30px 68px rgba(18, 20, 58, 0.24),
    0 0 38px rgba(133, 100, 255, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.28),
    inset 0 -1px 0 rgba(255, 255, 255, 0.09);
}

.nosotros-about-card:hover::after {
  left: 125%;
  opacity: 1;
}

.nosotros-about-card-1 {
  justify-self: start;
  margin-left: 0;
}

.nosotros-about-card-2 {
  justify-self: end;
  width: min(560px, 100%);
}

.nosotros-about-card-3 {
  justify-self: start;
  margin-left: 0;
}

.nosotros-about-icon {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 58px;
  height: 58px;
  border-radius: 18px;
  color: #b873ff;
  background:
    radial-gradient(circle at 35% 22%, rgba(108, 215, 255, 0.22), transparent 46%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.035));
  border: 1px solid rgba(142, 179, 255, 0.24);
  box-shadow:
    0 0 22px rgba(124, 89, 255, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

.nosotros-about-icon svg {
  width: 36px;
  height: 36px;
  filter:
    drop-shadow(0 0 8px rgba(103, 209, 255, 0.34))
    drop-shadow(0 0 10px rgba(198, 88, 255, 0.28));
}

.nosotros-about-number {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding-right: 18px;
  color: rgba(255, 255, 255, 0.82);
  font-size: 14px;
  font-weight: 900;
  letter-spacing: -0.2px;
  border-right: 1px solid rgba(255, 255, 255, 0.18);
}

.nosotros-about-card-content {
  position: relative;
  z-index: 2;
}

.nosotros-about-card h3 {
  margin: 0;
  color: #ffffff;
  font-size: 20px;
  line-height: 1.12;
  letter-spacing: -0.55px;
  font-weight: 800;
  text-shadow:
    0 0 10px rgba(134, 163, 255, 0.08),
    0 0 14px rgba(205, 111, 255, 0.06);
}

.nosotros-about-card h3 span {
  color: transparent;
  background: linear-gradient(
    135deg,
    #eef1ff 0%,
    #d9ddff 18%,
    #b7b2ff 40%,
    #cd9eff 68%,
    #f0d7ff 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  font-weight: 800;
  text-shadow: none;
}

.nosotros-about-card p {
  margin: 8px 0 0;
  color: rgba(255, 255, 255, 0.75);
  font-size: 14.5px;
  line-height: 1.5;
}

/* =========================
   RESPONSIVE
========================= */

@media (max-width: 1180px) {
  .nosotros-about {
    padding: 54px 0 62px;
  }

  .nosotros-about-inner {
    grid-template-columns: minmax(0, 0.92fr) minmax(430px, 1.08fr);
    gap: 50px;
  }

  .nosotros-about-content h2 {
    font-size: clamp(36px, 3.75vw, 52px);
    letter-spacing: -1.25px;
  }

  .nosotros-about-card {
    width: min(590px, 100%);
  }

  .nosotros-about-card-2 {
    width: min(540px, 100%);
  }
}

@media (max-width: 980px) {
  .nosotros-about {
    padding: 60px 0 66px;
  }

  .nosotros-about-inner {
    grid-template-columns: 1fr;
    gap: 38px;
  }

  .nosotros-about-content {
    max-width: 740px;
  }

  .nosotros-about-content h2 {
    max-width: 660px;
  }

  .nosotros-about-content p {
    max-width: 620px;
  }

  .nosotros-about-panel {
    max-width: 720px;
    min-height: auto;
    padding-right: 0;
  }

  .nosotros-about-card {
    width: min(620px, 100%);
  }

  .nosotros-about-card-1,
  .nosotros-about-card-2,
  .nosotros-about-card-3 {
    justify-self: stretch;
    margin-left: 0;
    margin-right: 0;
  }

  .nosotros-about-card-2 {
    width: min(620px, 100%);
    margin-left: 42px;
  }
}

@media (max-width: 720px) {
  .nosotros-about {
    padding: 50px 0 56px;
  }

  .nosotros-about-inner {
    gap: 32px;
  }

  .nosotros-about-content h2 {
    max-width: 440px;
    font-size: clamp(31px, 7.5vw, 41px);
    line-height: 1.09;
    letter-spacing: -1px;
  }

  .nosotros-about-content p {
    max-width: 420px;
    margin-top: 17px;
    font-size: 15.5px;
    line-height: 1.68;
  }

  .nosotros-about-panel {
    gap: 14px;
  }

  .nosotros-about-panel::before {
    opacity: 0.82;
  }

  .nosotros-about-panel::after {
    opacity: 0.70;
  }

  .nosotros-about-card {
    grid-template-columns: 58px 40px minmax(0, 1fr);
    column-gap: 14px;
    min-height: 90px;
    padding: 15px 18px 15px 15px;
    border-radius: 18px;
  }

  .nosotros-about-card-2 {
    width: min(620px, 100%);
    margin-left: 0;
  }

  .nosotros-about-icon {
    width: 50px;
    height: 50px;
    border-radius: 16px;
  }

  .nosotros-about-icon svg {
    width: 31px;
    height: 31px;
  }

  .nosotros-about-number {
    min-height: 42px;
    padding-right: 12px;
    font-size: 13px;
  }

  .nosotros-about-card h3 {
    font-size: 18.5px;
    letter-spacing: -0.35px;
  }

  .nosotros-about-card p {
    margin-top: 6px;
    font-size: 13.5px;
    line-height: 1.45;
  }
}

@media (max-width: 480px) {
  .nosotros-about {
    padding: 46px 0 52px;
  }

  .nosotros-about-content h2 {
    max-width: 350px;
    font-size: clamp(28px, 8vw, 35px);
    line-height: 1.09;
    letter-spacing: -0.9px;
  }

  .nosotros-about-content p {
    max-width: 340px;
    font-size: 15px;
  }

  .nosotros-about-panel::before,
  .nosotros-about-panel::after {
    display: none;
  }

  .nosotros-about-card {
    grid-template-columns: 48px minmax(0, 1fr);
    column-gap: 13px;
    min-height: auto;
    padding: 16px;
    border-radius: 17px;
  }

  .nosotros-about-icon {
    width: 46px;
    height: 46px;
    border-radius: 15px;
  }

  .nosotros-about-icon svg {
    width: 28px;
    height: 28px;
  }

  .nosotros-about-number {
    position: absolute;
    top: 14px;
    right: 16px;
    min-height: auto;
    padding: 0;
    border-right: 0;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.62);
  }

  .nosotros-about-card-content {
    padding-right: 28px;
  }

  .nosotros-about-card h3 {
    font-size: 17.5px;
  }

  .nosotros-about-card p {
    font-size: 13.2px;
  }
}