.icos-directory,
.icos-platform-single {
  --icos-blue: #0D96F0;
  --icos-blue-dark: #e41b63;
  --icos-ink: #16202a;
  --icos-muted: #637381;
  --icos-line: #d8e2ec;
  --icos-soft: #f4f8fc;
  --icos-atmosphere: #2f80ed;
  --icos-ocean: #00a6b4;
  --icos-ecosystem: #4f9a52;
  --icos-associated: #7c6fd0;
  color: var(--icos-ink);
}

.icos-directory {
    max-width: 100%;
    margin: 0 auto;
    padding: 0;
}

.icos-directory__header {
  max-width: 780px;
  margin-bottom: 28px;
}

.icos-directory__eyebrow {
  margin: 0 0 8px;
  color: var(--icos-blue);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.icos-directory__header h2,
.icos-platform-hero h1,
.icos-platform-content h2,
.icos-platform-facts h2 {
  color: var(--icos-ink);
  line-height: 1.12;
  letter-spacing: 0;
}

.icos-directory__header h2 {
  margin: 0 0 12px;
  font-size: clamp(2rem, 4vw, 3.35rem);
}

.icos-directory__header p {
  margin: 0;
  color: var(--icos-muted);
  font-size: 1.05rem;
  line-height: 1.65;
}

.icos-directory__map {
  overflow: hidden;
  height: clamp(360px, 48vw, 560px);
  margin: 0 0 28px;
  border: 1px solid var(--icos-line);
  border-radius: 12px;
  background: var(--icos-soft);
}

.icos-directory__map iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
}

.icos-directory__filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 0 24px;
}

.icos-directory__filters button {
  appearance: none;
  border: 1px solid var(--icos-line);
  border-radius: 999px;
  background: #fff;
  color: var(--icos-ink);
  cursor: pointer;
  font: inherit;
  font-weight: 700;
  padding: 10px 16px;
  transition: background 160ms ease, border-color 160ms ease, color 160ms ease;
}

.icos-directory__filters button:hover,
.icos-directory__filters button.is-active {
  border-color: var(--icos-blue);
  background: var(--icos-blue);
  color: #fff;
}

.icos-directory__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
}

.icos-platform-card {
  display: flex;
  min-height: 100%;
  overflow: hidden;
  flex-direction: column;
  border: 1px solid var(--icos-line);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 18px 45px rgba(22, 32, 42, 0.08);
}

.icos-platform-card[hidden] {
  display: none;
}

.icos-platform-card__media {
  display: block;
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 10;
  background: var(--icos-soft);
}

.icos-platform-card__media img,
.icos-platform-hero__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: var(--icos-image-position, center center);
}

.icos-platform-card__placeholder {
  display: flex;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  color: var(--icos-blue);
  font-weight: 800;
}

.icos-platform-card__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  padding: 22px;
}

.icos-domain-badge {
  align-self: flex-start;
  border-radius: 999px;
  color: #fff;
  font-size: 0.76rem;
  font-weight: 800;
  line-height: 1;
  padding: 7px 10px;
}

.icos-domain-badge--atmosphere {
  background: var(--icos-atmosphere);
}

.icos-domain-badge--ocean {
  background: var(--icos-ocean);
}

.icos-domain-badge--ecosystem {
  background: var(--icos-ecosystem);
}

.icos-domain-badge--associated {
  background: var(--icos-associated);
}

.icos-platform-card h3 {
  margin: 14px 0 8px;
  font-size: 1.35rem;
  line-height: 1.18;
}

.icos-platform-card h3 a {
  color: inherit;
  text-decoration: none;
}

.icos-platform-card h3 a:hover {
  color: var(--icos-blue);
}

.icos-platform-card p {
  color: var(--icos-muted);
  line-height: 1.55;
}

.icos-platform-card__meta {
  margin: 0 0 10px;
  color: var(--icos-blue-dark) !important;
  font-weight: 750;
}

.icos-platform-card__facts {
  display: grid;
  gap: 10px;
  margin: 8px 0 20px;
}

.icos-platform-card__facts div,
.icos-platform-facts dl div {
  border-top: 1px solid var(--icos-line);
  padding-top: 10px;
}

.icos-platform-card__facts dt,
.icos-platform-facts dt {
  color: var(--icos-muted);
  font-size: 0.76rem;
  font-weight: 800;
  text-transform: uppercase;
}

.icos-platform-card__facts dd,
.icos-platform-facts dd {
  margin: 2px 0 0;
  color: var(--icos-ink);
  font-weight: 650;
}

.icos-platform-card__link,
.icos-platform-links a,
.icos-platform-back a {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  margin-top: auto;
  border-radius: 999px;
  background: var(--icos-blue);
  color: #fff;
  font-weight: 800;
  padding: 10px 16px;
  text-decoration: none;
}

.icos-platform-card__link:hover,
.icos-platform-links a:hover,
.icos-platform-back a:hover {
  background: var(--icos-blue-dark);
  color: #fff;
}

.icos-platform-single {
  max-width: 1180px;
  margin: 0 auto;
  padding: 48px 20px 72px;
}

.icos-platform-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.2fr);
  gap: 36px;
  align-items: center;
  margin-bottom: 44px;
}

.icos-platform-hero h1 {
  margin: 0 0 14px;
  font-size: clamp(2.4rem, 5vw, 4.6rem);
}

.icos-platform-hero__content > p:not(.icos-directory__eyebrow) {
  color: var(--icos-muted);
  font-size: 1.12rem;
  line-height: 1.65;
}

.icos-platform-hero__image {
  overflow: hidden;
  aspect-ratio: 16 / 10;
  border-radius: 12px;
  background: var(--icos-soft);
}

.icos-platform-layout {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 44px;
  align-items: start;
}

.icos-platform-facts {
  position: sticky;
  top: 24px;
  border: 1px solid var(--icos-line);
  border-radius: 12px;
  background: var(--icos-soft);
  padding: 24px;
}

.icos-platform-facts h2,
.icos-platform-content h2 {
  margin: 0 0 18px;
  font-size: 1.45rem;
}

.icos-platform-facts dl {
  display: grid;
  gap: 14px;
  margin: 0;
}

.icos-platform-content {
  max-width: 760px;
}

.icos-platform-content p {
  color: var(--icos-ink);
  font-size: 1.03rem;
  line-height: 1.75;
}

.icos-platform-content h2 {
  margin-top: 34px;
}

.icos-platform-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}

.icos-platform-back {
  margin-top: 34px;
}

.icos-platform-gallery,
.icos-platform-map {
  margin-top: 36px;
}

.icos-platform-gallery h2,
.icos-platform-map h2 {
  margin: 0 0 18px;
  color: var(--icos-ink);
  font-size: 1.45rem;
  line-height: 1.12;
}

.icos-platform-gallery__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.icos-platform-gallery figure {
  overflow: hidden;
  aspect-ratio: 16 / 10;
  margin: 0;
  border-radius: 12px;
  background: var(--icos-soft);
}

.icos-platform-gallery img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.icos-platform-map iframe {
  display: block;
  width: 100%;
  min-height: 360px;
  border: 0;
  border-radius: 12px;
  background: var(--icos-soft);
}

@media (max-width: 980px) {
  .icos-directory__grid,
  .icos-platform-hero,
  .icos-platform-layout {
    grid-template-columns: 1fr;
  }

  .icos-platform-facts {
    position: static;
  }
}

@media (max-width: 640px) {
  .icos-directory,
  .icos-platform-single {
    padding-right: 16px;
    padding-left: 16px;
  }

  .icos-directory__grid {
    gap: 16px;
  }

  .icos-platform-card__body {
    padding: 18px;
  }

  .icos-platform-gallery__grid {
    grid-template-columns: 1fr;
  }
}
