.shell {
  max-width: 1460px;
  margin: 0 auto;
}

.panel {
  position: relative;
  isolation: isolate;
  display: grid;
  grid-template-columns: minmax(300px, 0.84fr) minmax(0, 1.16fr);
  gap: clamp(28px, 3.2vw, 44px);
  align-items: center;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  overflow: hidden;
}

.panel::before {
  display: none;
}

.panel::after {
  display: none;
}

.content {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 18px;
  align-content: start;
  justify-items: start;
}

.eyebrow {
  margin: 0;
  color: rgba(164, 208, 255, 0.84);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.heading {
  margin: 0;
  max-width: 13ch;
  color: #f3f8ff;
  font-size: clamp(2.2rem, 3.5vw, 3.35rem);
  line-height: 0.98;
  letter-spacing: -0.05em;
}

.description {
  margin: 0;
  max-width: 43ch;
  color: rgba(204, 221, 243, 0.82);
  font-size: 0.98rem;
  line-height: 1.75;
}

.actions {
  padding-top: 6px;
}

.actionLink {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0 16px;
  border: 1px solid rgba(100, 174, 255, 0.18);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(15, 34, 62, 0.92), rgba(10, 23, 44, 0.92));
  color: rgba(179, 219, 255, 0.92);
  box-shadow:
    inset 0 1px 0 rgba(222, 240, 255, 0.05),
    0 12px 28px rgba(2, 8, 18, 0.16);
  transition:
    border-color 220ms ease,
    box-shadow 220ms ease,
    background 220ms ease,
    color 220ms ease;
}

.actionLink:hover,
.actionLink:focus-visible {
  border-color: rgba(114, 190, 255, 0.28);
  background: linear-gradient(180deg, rgba(16, 38, 68, 0.94), rgba(10, 24, 47, 0.94));
  color: #d8efff;
  box-shadow:
    inset 0 1px 0 rgba(222, 240, 255, 0.07),
    0 16px 32px rgba(2, 8, 18, 0.2);
}

.map {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) clamp(110px, 11vw, 152px) minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) clamp(92px, 10vw, 136px) minmax(0, 1fr);
  column-gap: 0;
  row-gap: 0;
  min-height: 520px;
  align-items: stretch;
  padding: 10px 2px;
}

.mapGlow {
  position: absolute;
  inset: 35% 38%;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(66, 142, 255, 0.08), transparent 74%);
  filter: blur(18px);
  opacity: 0.26;
  pointer-events: none;
}

.node {
  position: relative;
  z-index: 2;
  display: flex;
}

.nodeOperations {
  grid-area: 1 / 1;
}

.nodeSafety {
  grid-area: 1 / 3;
}

.nodeDeployment {
  grid-area: 3 / 1;
}

.nodeProcurement {
  grid-area: 3 / 3;
}

.nodeOperations {
  --card-accent-rgb: 100, 170, 255;
  --card-accent-text: rgba(167, 210, 255, 0.96);
}

.nodeSafety {
  --card-accent-rgb: 132, 141, 255;
  --card-accent-text: rgba(194, 200, 255, 0.96);
}

.nodeDeployment {
  --card-accent-rgb: 88, 210, 255;
  --card-accent-text: rgba(174, 241, 255, 0.96);
}

.nodeProcurement {
  --card-accent-rgb: 112, 168, 255;
  --card-accent-text: rgba(186, 217, 255, 0.98);
}

.card {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 14px;
  width: 100%;
  min-height: 194px;
  padding: 22px 22px 20px;
  border: 1px solid rgba(var(--card-accent-rgb), 0.18);
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(11, 25, 48, 0.94), rgba(16, 35, 64, 0.88)),
    radial-gradient(circle at top left, rgba(var(--card-accent-rgb), 0.08), transparent 36%);
  box-shadow:
    inset 0 1px 0 rgba(210, 235, 255, 0.06),
    0 16px 36px rgba(1, 7, 18, 0.18);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition:
    transform 240ms ease,
    border-color 240ms ease,
    box-shadow 240ms ease;
}

.cardTopline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.cardMeta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.cardIcon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(var(--card-accent-rgb), 0.2);
  border-radius: 10px;
  background:
    linear-gradient(180deg, rgba(var(--card-accent-rgb), 0.12), rgba(var(--card-accent-rgb), 0.05)),
    rgba(10, 23, 43, 0.62);
  color: var(--card-accent-text);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.cardLabel {
  margin: 0;
  color: var(--card-accent-text);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.cardArrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(var(--card-accent-rgb), 0.18);
  border-radius: 999px;
  background: rgba(var(--card-accent-rgb), 0.07);
  color: var(--card-accent-text);
  transition:
    transform 240ms ease,
    border-color 240ms ease,
    background 240ms ease,
    box-shadow 240ms ease;
}

.card h3 {
  margin: 0;
  color: #f5f8ff;
  font-size: 1.22rem;
  line-height: 1.14;
  letter-spacing: -0.03em;
}

.card p:last-child {
  margin: 0;
  color: rgba(204, 221, 243, 0.82);
  font-size: 0.92rem;
  line-height: 1.65;
}

.mapLines {
  position: absolute;
  inset: 12px 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  overflow: visible;
  pointer-events: none;
}

.line {
  fill: none;
  stroke-width: 1.68;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: 0.94;
  transition:
    opacity 220ms ease,
    stroke-width 220ms ease,
    filter 220ms ease;
  filter: drop-shadow(0 0 1.4px rgba(102, 174, 255, 0.1));
}

.lineSpine {
  stroke: url(#line-spine);
}

.lineOperations {
  stroke: url(#line-operations);
}

.lineSafety {
  stroke: url(#line-safety);
}

.lineDeployment {
  stroke: url(#line-deployment);
}

.lineProcurement {
  stroke: url(#line-procurement);
}

.outerPoint,
.spinePoint,
.hubPoint {
  fill: rgba(158, 221, 255, 0.98);
  filter: drop-shadow(0 0 3px rgba(104, 184, 255, 0.22));
}

.outerPoint {
  opacity: 0.92;
}

.spinePoint {
  opacity: 0.96;
}

.hubPoint {
  opacity: 0.98;
}

.flowDot {
  fill: rgba(164, 228, 255, 0.92);
  opacity: 0.54;
  filter: drop-shadow(0 0 2px rgba(116, 196, 255, 0.16));
}

.node:hover .card,
.node:focus-within .card {
  transform: translateY(-6px);
  border-color: rgba(var(--card-accent-rgb), 0.34);
  box-shadow:
    inset 0 1px 0 rgba(210, 235, 255, 0.08),
    0 22px 46px rgba(1, 7, 18, 0.22),
    0 0 0 1px rgba(var(--card-accent-rgb), 0.12);
}

.node:hover .cardIcon,
.node:focus-within .cardIcon {
  border-color: rgba(var(--card-accent-rgb), 0.32);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 0 18px rgba(var(--card-accent-rgb), 0.08);
}

.node:hover .cardArrow,
.node:focus-within .cardArrow {
  transform: translateX(4px);
  border-color: rgba(var(--card-accent-rgb), 0.32);
  box-shadow: 0 0 14px rgba(var(--card-accent-rgb), 0.08);
}

.nodeOperations:hover ~ .mapLines .lineOperations,
.nodeOperations:focus-within ~ .mapLines .lineOperations,
.nodeSafety:hover ~ .mapLines .lineSafety,
.nodeSafety:focus-within ~ .mapLines .lineSafety,
.nodeDeployment:hover ~ .mapLines .lineDeployment,
.nodeDeployment:focus-within ~ .mapLines .lineDeployment,
.nodeProcurement:hover ~ .mapLines .lineProcurement,
.nodeProcurement:focus-within ~ .mapLines .lineProcurement {
  opacity: 1;
  stroke-width: 1.86;
  filter: drop-shadow(0 0 2px rgba(104, 184, 255, 0.14));
}

.nodeOperations:hover ~ .mapLines .lineSpine,
.nodeOperations:focus-within ~ .mapLines .lineSpine,
.nodeSafety:hover ~ .mapLines .lineSpine,
.nodeSafety:focus-within ~ .mapLines .lineSpine,
.nodeDeployment:hover ~ .mapLines .lineSpine,
.nodeDeployment:focus-within ~ .mapLines .lineSpine,
.nodeProcurement:hover ~ .mapLines .lineSpine,
.nodeProcurement:focus-within ~ .mapLines .lineSpine {
  opacity: 0.96;
}

@keyframes hubPulse {
  0%,
  100% {
    transform: scale(1);
    filter:
      drop-shadow(0 0 1px rgba(97, 157, 255, 0.18))
      drop-shadow(0 0 4px rgba(97, 157, 255, 0.12));
    opacity: 0.9;
  }

  50% {
    transform: scale(1.08);
    filter:
      drop-shadow(0 0 1px rgba(97, 157, 255, 0.2))
      drop-shadow(0 0 5px rgba(97, 157, 255, 0.14));
    opacity: 1;
  }
}

:global(:root[data-theme="light"]) .panel {
  background: transparent;
  box-shadow: none;
}

:global(:root[data-theme="light"]) .panel::before {
  display: none;
}

:global(:root[data-theme="light"]) .panel::after {
  display: none;
}

:global(:root[data-theme="light"]) .eyebrow {
  color: rgba(84, 116, 165, 0.92);
}

:global(:root[data-theme="light"]) .heading {
  color: #10233f;
}

:global(:root[data-theme="light"]) .description {
  color: rgba(54, 77, 109, 0.86);
}

:global(:root[data-theme="light"]) .actionLink {
  border-color: rgba(115, 162, 227, 0.28);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(236, 244, 255, 0.98));
  color: #245694;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.92),
    0 14px 28px rgba(16, 35, 63, 0.08);
}

:global(:root[data-theme="light"]) .actionLink:hover,
:global(:root[data-theme="light"]) .actionLink:focus-visible {
  border-color: rgba(97, 154, 231, 0.36);
  background: linear-gradient(180deg, rgba(255, 255, 255, 1), rgba(229, 240, 255, 1));
  color: #1f4f89;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 1),
    0 16px 30px rgba(16, 35, 63, 0.1);
}

:global(:root[data-theme="light"]) .mapGlow {
  background: radial-gradient(circle, rgba(94, 151, 255, 0.08), transparent 72%);
  opacity: 0.22;
}

:global(:root[data-theme="light"]) .nodeOperations {
  --card-accent-text: rgba(48, 107, 184, 0.94);
}

:global(:root[data-theme="light"]) .nodeSafety {
  --card-accent-text: rgba(76, 93, 182, 0.94);
}

:global(:root[data-theme="light"]) .nodeDeployment {
  --card-accent-text: rgba(35, 146, 170, 0.94);
}

:global(:root[data-theme="light"]) .nodeProcurement {
  --card-accent-text: rgba(53, 112, 192, 0.94);
}

:global(:root[data-theme="light"]) .card {
  border-color: rgba(var(--card-accent-rgb), 0.22);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(236, 244, 255, 0.95)),
    radial-gradient(circle at top left, rgba(var(--card-accent-rgb), 0.06), transparent 36%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.92),
    0 16px 32px rgba(16, 35, 63, 0.08);
}

:global(:root[data-theme="light"]) .cardIcon {
  border-color: rgba(var(--card-accent-rgb), 0.22);
  background:
    linear-gradient(180deg, rgba(var(--card-accent-rgb), 0.12), rgba(var(--card-accent-rgb), 0.06)),
    rgba(255, 255, 255, 0.9);
}

:global(:root[data-theme="light"]) .cardArrow {
  border-color: rgba(var(--card-accent-rgb), 0.22);
  background: rgba(var(--card-accent-rgb), 0.08);
}

:global(:root[data-theme="light"]) .card h3 {
  color: #132946;
}

:global(:root[data-theme="light"]) .card p:last-child {
  color: rgba(67, 87, 114, 0.9);
}

:global(:root[data-theme="light"]) .line {
  filter: drop-shadow(0 0 1px rgba(108, 170, 255, 0.08));
}

:global(:root[data-theme="light"]) .outerPoint,
:global(:root[data-theme="light"]) .spinePoint,
:global(:root[data-theme="light"]) .hubPoint {
  fill: rgba(120, 186, 255, 0.94);
  filter: drop-shadow(0 0 2px rgba(103, 169, 255, 0.14));
}

:global(:root[data-theme="light"]) .flowDot {
  fill: rgba(116, 192, 255, 0.88);
  filter: drop-shadow(0 0 1.6px rgba(103, 169, 255, 0.12));
}

@media (max-width: 1080px) {
  .panel {
    grid-template-columns: 1fr;
  }

  .content {
    max-width: 40rem;
  }

  .heading {
    max-width: 16ch;
  }

  .map {
    max-width: 760px;
    width: 100%;
    margin: 0 auto;
    min-height: 480px;
  }
}

@media (max-width: 760px) {
  .panel {
    padding: 0;
    border-radius: 0;
  }

  .map {
    min-height: auto;
    padding: 0;
    grid-template-columns: minmax(0, 1fr) 72px minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr) 72px minmax(0, 1fr);
  }

  .card {
    padding: 20px 18px;
    border-radius: 22px;
  }

  .heading {
    font-size: clamp(2rem, 9vw, 2.75rem);
  }
}

@media (max-width: 820px) {
  .map {
    grid-template-columns: 1fr;
    grid-template-rows: none;
    gap: 16px;
  }

  .nodeOperations,
  .nodeSafety,
  .nodeDeployment,
  .nodeProcurement {
    grid-area: auto;
  }

  .mapGlow,
  .mapLines {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .card,
  .cardArrow,
  .line,
  .hubPoint,
  .flowDot,
  .actionLink {
    animation: none;
    transition: none;
  }

  .node:hover .card,
  .node:focus-within .card,
  .node:hover .cardArrow,
  .node:focus-within .cardArrow {
    transform: none;
  }

  .flowDot {
    display: none;
  }
}
