.corporate-structure__content {
  margin-top: 2.5rem;
}

.structure-table {
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
  table-layout: fixed;
  width: 100%;
}

.structure-table tr {
  border-bottom: 0.0625rem solid var(--primary-2);
}

.structure-table thead tr {
  background-color: var(--primary-0);
  position: relative;
}

.structure-table th {
  color: var(--primary-14);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.4;
  padding: 0.75rem 1.5rem;
  text-align: left;
  vertical-align: middle;
  white-space: nowrap;
}

.structure-table th span {
  border-bottom: 0.1875rem solid var(--primary-4);
  display: block;
  padding: 0.625rem 0;
  width: 100%;
}

.structure-table td {
  border-bottom: 0.125rem solid var(--gray-4);
  color: var(--gray-12);
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.4;
  padding: 1.375rem 1.5rem;
  text-align: left;
  vertical-align: middle;
}

.structure-table td:first-child {
  color: var(--gray-9);
  font-weight: 700;
  line-height: 1.4;
  white-space: nowrap;
}

.corporate-structure__note {
  margin-top: 1.5rem;
  color: var(--primary-12);
  line-height: 1.4;
}

@media (max-width: 47.99875rem) {
  .structure-table {
    border-radius: 0;
    box-shadow: none;
    display: block;
  }

  .structure-table thead {
    border-top: 0.0625rem solid var(--primary-2);
    padding-bottom: 1rem;
  }

  .structure-table thead tr {
    display: none;
  }

  .structure-table tbody,
  .structure-table td,
  .structure-table th,
  .structure-table thead,
  .structure-table tr {
    display: block;
    width: 100% !important;
  }

  .structure-table tr {
    margin-bottom: 1rem;
  }

  .structure-table td:first-child,
  .structure-table th:first-child {
    border-bottom: none;
  }

  .structure-table td {
    border-width: 0.0625rem;
    padding: 0;
  }

  .structure-table td:first-child {
    color: var(--primary-12);
    padding-bottom: 0.5rem;
  }

  .structure-table td:last-child {
    padding-bottom: 1rem;
  }
}

@media (max-width: 20rem) {
  .corporate-structure__content {
    margin-top: 1.5rem;
  }
}

@media (min-width: 20rem) and (max-width: 120rem) {
  .corporate-structure__content {
    margin-top: clamp(1.5rem, 1.3rem + 1vw, 2.5rem);
  }

  .structure-table td:first-child {
    font-size: clamp(1rem, 0.95rem + 0.25vw, 1.25rem);
  }
}

@media (min-width: 120rem) {
  .corporate-structure__content {
    margin-top: 2.5rem;
  }
}
