.ngc-relations {
  --ngc-relations-text: var(--e-global-color-text, currentColor);
  --ngc-relations-primary: var(--e-global-color-primary, currentColor);
  --ngc-relations-secondary: var(--e-global-color-secondary, currentColor);
  --ngc-relations-accent: var(--e-global-color-accent, currentColor);

  --ngc-relations-bg: color-mix(
    in srgb,
    var(--e-global-color-text, #ffffff) 6%,
    transparent
  );

  --ngc-relations-bg-hover: color-mix(
    in srgb,
    var(--e-global-color-text, #ffffff) 10%,
    transparent
  );

  --ngc-relations-border: color-mix(
    in srgb,
    var(--e-global-color-text, #ffffff) 18%,
    transparent
  );

  --ngc-relations-border-hover: color-mix(
    in srgb,
    var(--e-global-color-accent, #ffffff) 48%,
    transparent
  );

  margin: 2rem 0 3rem;
  display: grid;
  gap: 2rem;
  color: var(--ngc-relations-text);
}

.ngc-relations-group {
  display: grid;
  gap: 1rem;
}

.ngc-relations-heading {
  margin: 0;
  color: var(--ngc-relations-primary);
  font-family: var(--e-global-typography-primary-font-family, inherit);
  font-size: 1.35rem;
  font-weight: 700;
  line-height: 1.2;
}

.ngc-relations-list {
  display: grid;
  gap: 1rem;
}

.ngc-relation-card {
  display: block;
  position: relative;
  padding: 1.15rem 1.25rem;
  border: 1px solid var(--ngc-relations-border);
  border-radius: 18px;
  background: var(--ngc-relations-bg);
  color: inherit;
  text-decoration: none;
  overflow: hidden;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    background 180ms ease,
    box-shadow 180ms ease;
}

.ngc-relation-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--ngc-relations-accent) 14%, transparent),
    transparent 52%
  );
  opacity: 0;
  transition: opacity 180ms ease;
  pointer-events: none;
}

.ngc-relation-card::after {
  content: "→";
  position: absolute;
  right: 1.25rem;
  top: 1.15rem;
  color: var(--ngc-relations-accent);
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1;
  opacity: 0;
  transform: translateX(-6px);
  transition:
    opacity 180ms ease,
    transform 180ms ease;
}

.ngc-relation-card:hover,
.ngc-relation-card:focus-visible {
  transform: translateY(-2px);
  border-color: var(--ngc-relations-border-hover);
  background: var(--ngc-relations-bg-hover);
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.16);
  text-decoration: none;
}

.ngc-relation-card:hover::before,
.ngc-relation-card:focus-visible::before {
  opacity: 1;
}

.ngc-relation-card:hover::after,
.ngc-relation-card:focus-visible::after {
  opacity: 1;
  transform: translateX(0);
}

.ngc-relation-title {
  display: block;
  position: relative;
  z-index: 1;
  margin: 0 2rem 0.35rem 0;
  color: var(--ngc-relations-accent);
  font-family: var(--e-global-typography-primary-font-family, inherit);
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.25;
  text-decoration: none;
  transition:
    color 180ms ease,
    transform 180ms ease;
}

.ngc-relation-card:hover .ngc-relation-title,
.ngc-relation-card:focus-visible .ngc-relation-title {
  transform: translateX(3px);
}

.ngc-relation-meta {
  display: block;
  position: relative;
  z-index: 1;
  margin-bottom: 0.6rem;
  color: var(--ngc-relations-secondary);
  font-family: var(--e-global-typography-text-font-family, inherit);
  font-size: 0.78rem;
  line-height: 1.3;
  opacity: 0.78;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.ngc-relation-summary {
  display: block;
  position: relative;
  z-index: 1;
  margin: 0;
  color: var(--ngc-relations-text);
  font-family: var(--e-global-typography-text-font-family, inherit);
  font-size: 0.95rem;
  line-height: 1.55;
  opacity: 0.88;
}

.ngc-relation-card:focus-visible {
  outline: 2px solid var(--ngc-relations-accent);
  outline-offset: 3px;
}

@media (min-width: 768px) {
  .ngc-relations {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
  }

  .ngc-relations-group:only-child {
    grid-column: 1 / -1;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ngc-relation-card,
  .ngc-relation-card::before,
  .ngc-relation-card::after,
  .ngc-relation-title {
    transition: none;
  }

  .ngc-relation-card:hover,
  .ngc-relation-card:focus-visible,
  .ngc-relation-card:hover .ngc-relation-title,
  .ngc-relation-card:focus-visible .ngc-relation-title {
    transform: none;
  }
}