/* Learning Spaces and alternating feature styles */
.learning-spaces-section {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 8% 14%, rgba(246, 198, 75, 0.16), transparent 24%), radial-gradient(circle at 92% 78%, rgba(137, 208, 238, 0.16), transparent 26%),
    linear-gradient(180deg, var(--paper) 0%, #ffffff 100%);
}

.learning-space-feature {
  position: relative;
  margin-bottom: 5rem;
}

.learning-space-feature:last-child {
  margin-bottom: 0;
}

/* Uses shared .panel-media helpers from styles.css:
   .portrait-ratio, .image-fit-contain, .image-position-center */
.learning-space-media {
  width: min(100%, 440px);
  margin: 0 auto;
  background: radial-gradient(circle at top left, rgba(246, 198, 75, 0.16), transparent 32%), linear-gradient(180deg, var(--white), var(--sky-soft));
}

.learning-space-media img {
  transition: transform 0.45s ease;
}

.learning-space-feature:hover .learning-space-media img {
  transform: scale(1.025);
}

.learning-space-content {
  position: relative;
  height: 100%;
  border-radius: 30px;
  padding: 2.4rem;
  background: radial-gradient(circle at top right, rgba(246, 198, 75, 0.14), transparent 28%), linear-gradient(180deg, var(--white), var(--cream));
  box-shadow: var(--shadow-soft);
  border: 1px solid rgba(24, 43, 77, 0.06);
  overflow: hidden;
}

.learning-space-content::before {
  content: "";
  position: absolute;
  left: 0;
  top: 24px;
  bottom: 24px;
  width: 7px;
  border-radius: 999px;
  background: var(--coral);
}

.learning-space-feature:nth-child(2) .learning-space-content {
  background: radial-gradient(circle at top right, rgba(137, 208, 238, 0.18), transparent 28%), linear-gradient(180deg, var(--white), var(--sky-soft));
}

.learning-space-feature:nth-child(2) .learning-space-content::before {
  background: var(--sky);
}

.learning-space-feature:nth-child(3) .learning-space-content {
  background: radial-gradient(circle at top right, rgba(119, 196, 143, 0.18), transparent 28%), linear-gradient(180deg, var(--white), var(--sage-soft));
}

.learning-space-feature:nth-child(3) .learning-space-content::before {
  background: var(--sage);
}

.learning-space-feature:nth-child(4) .learning-space-content {
  background: radial-gradient(circle at top right, rgba(170, 143, 218, 0.16), transparent 28%), linear-gradient(180deg, var(--white), var(--lilac-soft));
}

.learning-space-feature:nth-child(4) .learning-space-content::before {
  background: var(--lilac);
}

.learning-space-content .section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.9rem;
  padding: 0.5rem 0.85rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
  color: var(--navy);
  border: 1px solid rgba(24, 43, 77, 0.08);
  box-shadow: 0 10px 22px rgba(24, 43, 77, 0.06);
  font-weight: 900;
  font-size: 0.78rem;
  letter-spacing: 0.09rem;
  text-transform: uppercase;
}

.learning-space-content h2 {
  margin-bottom: 1rem;
  color: var(--ink);
  font-size: clamp(1.9rem, 3vw, 2.65rem);
  line-height: 1.08;
}

.learning-space-content p {
  color: var(--text);
  line-height: 1.75;
  margin-bottom: 1rem;
}

.learning-space-content p:last-child {
  margin-bottom: 0;
}

.learning-space-feature:hover .learning-space-content {
  box-shadow: var(--shadow);
}

@media (min-width: 992px) {
  .learning-space-feature:not(.flex-lg-row-reverse) .learning-space-media {
    margin-left: auto;
    margin-right: 0;
  }

  .learning-space-feature.flex-lg-row-reverse .learning-space-media {
    margin-left: 0;
    margin-right: auto;
  }
}

@media (max-width: 1199.98px) {
  .learning-space-media {
    width: min(100%, 400px);
  }
}

@media (max-width: 991.98px) {
  .learning-space-feature {
    margin-bottom: 3.5rem;
  }

  .learning-space-media {
    width: min(100%, 420px);
  }

  .learning-space-content {
    padding: 2rem;
  }
}

@media (max-width: 575.98px) {
  .learning-space-media,
  .learning-space-content {
    border-radius: 24px;
  }

  .learning-space-content {
    padding: 1.55rem 1.45rem 1.55rem 1.7rem;
  }

  .learning-space-content::before {
    top: 20px;
    bottom: 20px;
    width: 6px;
  }
}
