.org-section {
  margin-bottom: 5rem;
}
.org-section--contact {
  margin-bottom: 0;
}
.org-section__header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
}
.org-section__symbol {
  display: flex;
  align-items: center;
}
.org-section__symbol span {
  display: block;
  width: 0.625rem;
  height: 0.625rem;
  transform: rotate(45deg);
}
.org-section__symbol span:nth-child(1) {
  background: var(--primary);
}
.org-section__symbol span:nth-child(2) {
  background: var(--secondary);
}
.org-section__symbol span:nth-child(3) {
  background: var(--tertiary);
}
.org-section__title {
  font-size: 1.625rem;
  font-weight: 700;
  color: var(--g80);
}
@media only screen and (max-width: 767px) {
  .org-section__title {
    font-size: 1.25rem;
  }
}

.org-chart {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 2.5rem 0;
  position: relative;
  height: 45.4375rem;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .org-chart {
    height: 40.4375rem;
  }
}
@media only screen and (max-width: 767px) {
  .org-chart {
    height: 59.5625rem;
    padding: 1.5rem 0;
  }
}
.org-chart__top {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 8.125rem;
  height: 8.125rem;
  background: #fff;
  border-radius: 50%;
  border: 0.9375rem solid var(--primary);
  z-index: 2;
}
@media only screen and (max-width: 1279px) {
  .org-chart__top {
    width: 6rem;
    height: 6rem;
    border-width: 0.625rem;
  }
}
.org-chart__top::after {
  content: "";
  position: absolute;
  top: 115%;
  left: 50%;
  transform: translateX(-50%);
  width: 0.0625rem;
  height: 23.5rem;
  border-left: 0.0625rem dashed #A8A8A8;
}
@media only screen and (max-width: 767px) {
  .org-chart__top::after {
    top: 113%;
    height: 51.6875rem;
  }
}
.org-chart__top span {
  font-size: var(--f4);
  line-height: var(--l4);
  font-weight: 700;
  color: var(--g80);
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .org-chart__top span {
    font-size: 1.25rem;
  }
}
@media only screen and (max-width: 767px) {
  .org-chart__top span {
    font-size: 1.125rem;
  }
}
.org-chart__row {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 1.25rem;
  width: 100%;
  position: absolute;
}
@media only screen and (max-width: 767px) {
  .org-chart__row {
    flex-direction: column;
    align-items: center;
    gap: 1rem;
  }
}
.org-chart__row--level2 {
  top: 8.5625rem;
}
@media only screen and (max-width: 1279px) {
  .org-chart__row--level2 {
    top: 6.25rem;
  }
}
@media only screen and (max-width: 767px) {
  .org-chart__row--level2 {
    top: 11.875rem;
  }
}
.org-chart__row--level2::before {
  content: "";
  position: absolute;
  top: 3.5rem;
  transform: translateX(-50%);
  width: 14rem;
  height: 0.0625rem;
  border-top: 0.0625rem dashed #A8A8A8;
}
@media only screen and (max-width: 1279px) {
  .org-chart__row--level2::before {
    width: 9rem;
  }
}
@media only screen and (max-width: 767px) {
  .org-chart__row--level2::before {
    width: 1rem;
    top: 0.5rem;
  }
}
.org-chart__row--level3 {
  top: 20.125rem;
}
@media only screen and (max-width: 1279px) {
  .org-chart__row--level3 {
    top: 17.125rem;
  }
}
@media only screen and (max-width: 767px) {
  .org-chart__row--level3 {
    top: 29.25rem;
  }
}
.org-chart__row--level3::before {
  content: "";
  position: absolute;
  top: 3.5rem;
  width: 37rem;
  height: 0.0625rem;
  border-top: 0.0625rem dashed #A8A8A8;
}
@media only screen and (max-width: 1279px) {
  .org-chart__row--level3::before {
    width: 23rem;
  }
}
@media only screen and (max-width: 767px) {
  .org-chart__row--level3::before {
    top: -5rem;
    width: 55%;
  }
}
@media only screen and (max-width: 767px) {
  .org-chart__row--level3::after {
    content: "";
    position: absolute;
    top: -5rem;
    width: 55%;
    height: 1.875rem;
    border-inline: 0.0625rem dashed #A8A8A8;
  }
}
.org-chart__row--level4 {
  top: 34rem;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .org-chart__row--level4 {
    top: 30.7rem;
  }
}
@media only screen and (max-width: 767px) {
  .org-chart__row--level4 {
    top: 38rem;
  }
}
.org-chart__row--level4::before {
  content: "";
  position: absolute;
  top: -1.875rem;
  left: 50%;
  transform: translateX(-50%);
  width: 35rem;
  height: 0.0625rem;
  border-top: 0.0625rem dashed #A8A8A8;
}
@media only screen and (max-width: 1279px) {
  .org-chart__row--level4::before {
    width: 67.5%;
  }
}
@media only screen and (max-width: 767px) {
  .org-chart__row--level4::before {
    display: none;
  }
}
.org-chart__box {
  display: flex;
  flex-direction: column;
  border-radius: 0.5rem;
  position: absolute;
  z-index: 10;
}
.org-chart__box--committee {
  width: 18.75rem;
}
@media only screen and (max-width: 1279px) {
  .org-chart__box--committee {
    width: 12.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .org-chart__box--committee {
    width: 9.375rem;
    max-width: 12.5rem;
  }
}
.org-chart__box--main {
  width: 15rem;
  top: 5.0625rem;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .org-chart__box--main {
    width: 12.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .org-chart__box--main {
    width: 100%;
    max-width: 12.5rem;
    top: 4.6875rem;
  }
}
.org-chart__box--left {
  left: 11.1875rem;
}
@media only screen and (max-width: 1599px) and (min-width: 1280px) {
  .org-chart__box--left {
    left: 5.1875rem;
  }
}
@media only screen and (max-width: 1279px) {
  .org-chart__box--left {
    left: 0;
  }
}
.org-chart__box--right {
  right: 11.1875rem;
}
@media only screen and (max-width: 1599px) and (min-width: 1280px) {
  .org-chart__box--right {
    right: 5.1875rem;
  }
}
@media only screen and (max-width: 1279px) {
  .org-chart__box--right {
    right: 0;
  }
}
.org-chart__box--team {
  width: 15rem;
  top: 27.625rem;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .org-chart__box--team {
    width: 11.25rem;
    top: 24.625rem;
  }
}
@media only screen and (max-width: 767px) {
  .org-chart__box--team {
    width: 100%;
    max-width: 11.25rem;
    top: 34.625rem;
  }
}
.org-chart__box--task {
  width: 16.25rem;
}
@media only screen and (max-width: 1279px) {
  .org-chart__box--task {
    width: 14rem;
  }
}
@media only screen and (max-width: 767px) {
  .org-chart__box--task {
    width: 100%;
    max-width: 13.875rem;
    position: static;
  }
}
.org-chart__box--task-left {
  left: 15.8125rem;
}
@media only screen and (max-width: 1599px) and (min-width: 1280px) {
  .org-chart__box--task-left {
    left: 8.8125rem;
  }
}
@media only screen and (max-width: 1279px) {
  .org-chart__box--task-left {
    left: 0;
  }
}
.org-chart__box--task-left::before {
  content: "";
  width: 0.0625rem;
  height: 1.875rem;
  position: absolute;
  top: -1.85rem;
  left: 50%;
  transform: translateX(-50%);
  border-left: 0.0625rem dashed #A8A8A8;
  z-index: -1;
}
@media only screen and (max-width: 767px) {
  .org-chart__box--task-left::before {
    display: none;
  }
}
.org-chart__box--task-right {
  right: 15.8125rem;
}
@media only screen and (max-width: 1599px) and (min-width: 1280px) {
  .org-chart__box--task-right {
    right: 8.75rem;
  }
}
@media only screen and (max-width: 1279px) {
  .org-chart__box--task-right {
    right: 0;
  }
}
.org-chart__box--task-right::before {
  content: "";
  width: 0.0625rem;
  height: 1.875rem;
  position: absolute;
  top: -1.85rem;
  left: 50%;
  transform: translateX(-50%);
  border-left: 0.0625rem dashed #A8A8A8;
  z-index: -1;
}
@media only screen and (max-width: 767px) {
  .org-chart__box--task-right::before {
    display: none;
  }
}
.org-chart__box-header {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 1.25rem;
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
}
@media only screen and (max-width: 767px) {
  .org-chart__box-header {
    font-size: 0.875rem;
    padding: 0.5rem 1rem;
  }
}
.org-chart__box-header--yellow {
  background: #e39627;
  border-radius: 0.5rem 0.5rem 0 0;
}
.org-chart__box-header--red {
  background: #b11116;
  border-radius: 0.5rem;
}
.org-chart__box--team .org-chart__box-header--red {
  border-radius: 0.5rem;
}
.org-chart__box-body {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding: 1rem 1.25rem;
  background: #fff;
  border: 0.0625rem solid #e1e1e4;
  border-top: none;
  border-radius: 0 0 0.5rem 0.5rem;
}
.org-chart__box-body p {
  font-size: 0.875rem;
  line-height: 1.5;
  color: #505050;
  text-align: center;
  letter-spacing: -0.035em;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .org-chart__box-body {
    padding: 0.75rem 0.625rem 1rem 0.625rem;
  }
}
@media only screen and (max-width: 767px) {
  .org-chart__box-body {
    padding: 0.5rem 0.25rem;
  }
  .org-chart__box-body p {
    font-size: 0.75rem;
  }
}
.org-chart__box-body--list ul {
  margin: 0;
  padding-left: 1.3rem;
}
.org-chart__box-body--list ul li {
  font-size: 0.875rem;
  line-height: 1.5;
  color: #505050;
  letter-spacing: -0.035em;
  list-style: disc;
}
@media only screen and (max-width: 767px) {
  .org-chart__box-body--list ul li {
    font-size: 0.75rem;
  }
}

.org-table {
  border-top: 0.125rem solid var(--primary);
}
.org-table__content {
  overflow-x: auto;
}
.org-table__content table {
  width: 100%;
  min-width: 50rem;
  border-collapse: collapse;
  table-layout: fixed;
}
.org-table__content table th:nth-child(1), .org-table__content table td:nth-child(1) {
  width: 12.5rem;
}
.org-table__content table th:nth-child(2), .org-table__content table td:nth-child(2) {
  width: 18.75rem;
}
.org-table__content table th:nth-child(3), .org-table__content table td:nth-child(3) {
  width: 18.75rem;
}
.org-table__content table th:nth-child(4), .org-table__content table td:nth-child(4) {
  width: auto;
}
.org-table__content table th, .org-table__content table td {
  padding: 1rem 1.25rem;
  text-align: center;
  font-size: 1rem;
  line-height: 1.5;
  letter-spacing: -0.02em;
  border: 1px solid #E1E1E4;
  vertical-align: middle;
}
.org-table__content table thead tr th {
  border-top: none;
}
.org-table__content table tr:last-child td {
  border-bottom: 1px solid #E1E1E4;
}
.org-table__content table th:first-child,
.org-table__content table td:first-child {
  border-left: none;
}
.org-table__content table th:last-child,
.org-table__content table td:last-child {
  border-right: none;
}
.org-table__content table th {
  background: #F8F8FA;
  font-weight: 500;
  color: var(--g80);
}
.org-table__content table td {
  background: #fff;
  font-weight: 400;
  color: #505050;
}
@media only screen and (max-width: 1279px) and (min-width: 768px) {
  .org-table__content table {
    min-width: 40rem;
  }
  .org-table__content table th:nth-child(1), .org-table__content table td:nth-child(1) {
    width: 7.5rem;
  }
  .org-table__content table th:nth-child(2), .org-table__content table td:nth-child(2) {
    width: 6.25rem;
  }
  .org-table__content table th:nth-child(3), .org-table__content table td:nth-child(3) {
    width: 8.125rem;
  }
  .org-table__content table th, .org-table__content table td {
    padding: 0.75rem 0.5rem;
    font-size: 0.875rem;
  }
}
@media only screen and (max-width: 767px) {
  .org-table__content table {
    min-width: 100%;
  }
  .org-table__content table th:nth-child(1), .org-table__content table td:nth-child(1) {
    width: 3.75rem;
  }
  .org-table__content table th:nth-child(2), .org-table__content table td:nth-child(2) {
    width: 4rem;
  }
  .org-table__content table th:nth-child(3), .org-table__content table td:nth-child(3) {
    width: 4.75rem;
  }
  .org-table__content table th:nth-child(4), .org-table__content table td:nth-child(4) {
    width: auto;
  }
  .org-table__content table th {
    padding: 0.375rem;
    font-size: 0.875rem;
  }
  .org-table__content table td {
    padding: 0.25rem;
    font-size: 0.875rem;
  }
  .org-table__content table td:nth-child(3) {
    padding: 0.5rem;
  }
}
.org-table__group-last td {
  border-bottom: 0.0625rem solid #000 !important;
}
.org-table__dept {
  border-bottom: 0.0625rem solid #000 !important;
}