/* --------------------------------------------------------------------------
   Use cases catalogue and carousel
   -------------------------------------------------------------------------- */
.uc-eyebrow {
  display: block;
  margin-bottom: 1rem;
  color: #6b7280;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .45em;
  text-transform: uppercase;
}

.uc-footer-block {
  border-top: 1px solid rgba(255,255,255,.06);
  padding: 4rem 0 3.25rem;
  margin-bottom: 2rem;
}

.uc-footer-heading {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 2rem;
  margin-bottom: 2rem;
}

.uc-footer-heading h2 {
  color: #fff;
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: .95;
  letter-spacing: -.06em;
  font-weight: 900;
  max-width: 720px;
}

.uc-footer-cta,
.uc-primary-link,
.uc-load-more,
.uc-modal-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: #fff;
  color: #000;
  padding: 1rem 1.4rem;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .24em;
  text-transform: uppercase;
  transition: transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
}

.uc-footer-cta:hover,
.uc-primary-link:hover,
.uc-load-more:hover,
.uc-modal-cta:hover {
  transform: translateY(-2px);
}

.uc-footer-shell {
  overflow: hidden;
}

.uc-footer-track {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.uc-card {
  position: relative;
  display: flex;
  min-height: 310px;
  flex-direction: column;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 1.75rem;
  padding: 1.5rem;
  background: radial-gradient(circle at 15% 0%, rgba(59,130,246,.12), transparent 34%), rgba(255,255,255,.035);
  color: #fff;
  overflow: hidden;
  isolation: isolate;
  transition: transform .25s ease, border-color .25s ease, background .25s ease;
}

.uc-card:before {
  content: '';
  position: absolute;
  inset: auto -20% -35% -20%;
  height: 7rem;
  background: linear-gradient(90deg, rgba(59,130,246,.20), rgba(5,199,167,.16));
  filter: blur(38px);
  opacity: .65;
  z-index: -1;
}

.uc-card:hover {
  transform: translateY(-6px);
  border-color: rgba(255,255,255,.22);
  background: radial-gradient(circle at 15% 0%, rgba(59,130,246,.18), transparent 38%), rgba(255,255,255,.055);
}

.uc-card-footer {
  min-height: 280px;
}

.uc-card-kicker {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  color: rgba(255,255,255,.45);
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.uc-card h3 {
  margin-bottom: .75rem;
  color: #fff;
  font-size: 1.35rem;
  line-height: 1.05;
  letter-spacing: -.04em;
  font-weight: 900;
}

.uc-card-sector {
  margin-bottom: 1rem;
  color: #34d399;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.uc-card-summary {
  color: rgba(255,255,255,.62);
  font-size: .95rem;
  line-height: 1.55;
  font-weight: 600;
}

.uc-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  margin-top: auto;
  padding-top: 1.25rem;
}

.uc-card-tags span,
.uc-modal-meta span {
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 999px;
  padding: .4rem .6rem;
  color: rgba(255,255,255,.68);
  background: rgba(255,255,255,.04);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .12em;
}

.uc-card-link,
.uc-card-detail {
  margin-top: 1rem;
  color: #fff;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .22em;
  text-transform: uppercase;
  text-align: left;
}

.uc-card-detail {
  border: 0;
  background: transparent;
  cursor: pointer;
  opacity: .62;
}

.uc-card-link:hover,
.uc-card-detail:hover {
  opacity: 1;
}

.uc-section {
  position: relative;
  padding: 8rem 0;
  background: #050505;
  color: #fff;
  border-top: 1px solid rgba(255,255,255,.06);
  overflow: hidden;
}

.uc-section:before {
  content: '';
  position: absolute;
  width: 42rem;
  height: 42rem;
  right: -18rem;
  top: -20rem;
  border-radius: 999px;
  background: rgba(59,130,246,.12);
  filter: blur(90px);
}

.uc-section-inner {
  position: relative;
  z-index: 1;
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1rem;
}

.uc-section-header {
  max-width: 820px;
  margin-bottom: 2.5rem;
}

.uc-section-header h2 {
  margin-bottom: 1.5rem;
  font-size: clamp(3rem, 7vw, 6rem);
  line-height: .9;
  letter-spacing: -.075em;
  font-weight: 900;
}

.uc-section-header p {
  color: rgba(255,255,255,.58);
  font-size: 1.15rem;
  line-height: 1.75;
  font-weight: 600;
  max-width: 760px;
}

.uc-controls {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  margin-bottom: 1.25rem;
}

.uc-filter {
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 999px;
  padding: .8rem 1rem;
  background: rgba(255,255,255,.035);
  color: rgba(255,255,255,.62);
  cursor: pointer;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .15em;
  text-transform: uppercase;
  transition: background .2s ease, color .2s ease, border-color .2s ease;
}

.uc-filter.is-active,
.uc-filter:hover {
  border-color: rgba(255,255,255,.24);
  background: #fff;
  color: #000;
}

.uc-search-label {
  display: block;
  margin-bottom: .7rem;
  color: rgba(255,255,255,.45);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .22em;
  text-transform: uppercase;
}

.uc-search {
  width: 100%;
  margin-bottom: 2rem;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 1.25rem;
  padding: 1.1rem 1.25rem;
  background: rgba(255,255,255,.045);
  color: #fff;
  outline: none;
}

.uc-search:focus {
  border-color: rgba(255,255,255,.3);
}

.uc-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.uc-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  margin-top: 2.5rem;
}

.uc-load-more {
  background: transparent;
  color: #fff;
  cursor: pointer;
}

.uc-load-more:hover {
  background: rgba(255,255,255,.08);
}

.uc-empty {
  grid-column: 1 / -1;
  color: rgba(255,255,255,.6);
  font-weight: 700;
}

.uc-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.uc-modal.is-open {
  display: flex;
}

.uc-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.76);
  backdrop-filter: blur(12px);
}

.uc-modal-panel {
  position: relative;
  width: min(760px, 100%);
  max-height: 90vh;
  overflow: auto;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 2rem;
  padding: 2rem;
  background: #080808;
  color: #fff;
  box-shadow: 0 30px 100px rgba(0,0,0,.55);
}

.uc-modal-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  display: flex;
  width: 2.25rem;
  height: 2.25rem;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 999px;
  background: rgba(255,255,255,.05);
  color: #fff;
  cursor: pointer;
  font-size: 1.5rem;
}

.uc-modal-panel h2 {
  max-width: 650px;
  margin-bottom: .6rem;
  font-size: clamp(2rem, 5vw, 4rem);
  line-height: .95;
  letter-spacing: -.06em;
  font-weight: 900;
}

.uc-modal-sector {
  margin-bottom: 2rem;
  color: #34d399;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.uc-modal-copy h3,
.uc-modal-meta strong {
  display: block;
  margin: 1.5rem 0 .6rem;
  color: rgba(255,255,255,.45);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .22em;
  text-transform: uppercase;
}

.uc-modal-copy p {
  color: rgba(255,255,255,.7);
  line-height: 1.7;
  font-weight: 600;
}

.uc-modal-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin: 1.5rem 0 2rem;
}

.uc-modal-meta div div {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

@media (max-width: 1024px) {
  .uc-footer-track,
  .uc-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 700px) {
  .uc-footer-heading {
    align-items: flex-start;
    flex-direction: column;
  }

  .uc-footer-track,
  .uc-grid,
  .uc-modal-meta {
    grid-template-columns: 1fr;
  }

  .uc-section {
    padding: 5rem 0;
  }
}
