@charset "UTF-8";
/* --------------------------------------------------------------------
 common
-------------------------------------------------------------------- */
body:not(#top):not(#about) #header {
  background-color: rgba(246, 247, 248, 1);
  border-bottom: solid 1px rgba(128, 146, 154, 1);
}
body:not(#top):not(#about) .hum span {
  background-color: #222;
}
body:not(#top):not(#about) .header-nav-item a {
  color: #222;
}
body:not(#top):not(#about) .header-brand .logo-white {
  opacity: 0;
}
body:not(#top):not(#about) .header-nav-item::after {
  background-color: #222;
}
body:not(#top):not(#about) .header-nav-item.members-only a::before,
body:not(#top):not(#about) .header-nav-item.members-only a::after {
  background-color: #222;
}

/* --------------------------------------------------------------------
 subpage
-------------------------------------------------------------------- */
.subpage {
  --header-height: 98px;
  --py-space: 80px 0 160px;
  @media screen and (max-width: 768px) {
    --header-height: 65px;
    --py-space: 40px 0 80px;
  }
  padding-top: var(--header-height);
}
.subpage-container {
  padding: var(--py-space);
}
/* --------------------------------------------------------------------
 breadcrumb
-------------------------------------------------------------------- */
.breadcrumb {
  --py-space: 24px 0;
  @media screen and (max-width: 768px) {
    --py-space: 12px 0;
  }
  display: flex;
  justify-content: end;
  padding: var(--py-space);
  overflow: hidden;
}
.breadcrumb-list {
  display: flex;
  gap: 8px;
  font-style: 1.4rem;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.breadcrumb-item {
  gap: 8px;
  white-space: nowrap;
}
.breadcrumb-item:last-child {
  padding-bottom: 8px;
  border-bottom: solid 1px;
}
.breadcrumb-item-link {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #222;
  transition: 0.3s;
  color: #999;
  font-weight: 400;
}
.breadcrumb-item-link:hover {
  color: #222;
}
.breadcrumb-item-link::after {
  content: "";
  display: flex;
  align-items: center;
  width: 8px;
  height: 1px;
  background-color: #222;
}

/* --------------------------------------------------------------------
 page-title
-------------------------------------------------------------------- */
.page-title {
  --jp-font-size: 2rem;
  --en-font-size: 11.2rem;
  @media screen and (max-width: 1440px) {
    --en-font-size: 9.2rem;
  }
  @media screen and (max-width: 768px) {
    --jp-font-size: 1.2rem;
    --en-font-size: 4rem;
  }
}
.page-title .jp {
  display: block;
  font-size: var(--jp-font-size);
  padding-left: 19px;
  position: relative;
  line-height: 2;
}
.page-title .jp::before {
  content: "";
  display: block;
  width: 11px;
  height: 11px;
  background-color: #fc1b1c;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
}
.page-title .en {
  display: block;
  font-size: var(--en-font-size);
  line-height: 1.3;
  font-family: "Jost", "Futura", "Century Gothic", sans-serif;
  font-weight: 500;
  letter-spacing: 0.02em;
}

/* --------------------------------------------------------------------
 page-cat-title
-------------------------------------------------------------------- */
.page-cat-title {
  --main-font-size: 3rem;
  --sub-font-size: 2.4rem;
  @media screen and (max-width: 768px) {
    --main-font-size: 2.4rem;
    --sub-font-size: 1.8rem;
  }

  display: flex;
  align-items: center;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 40px;
}
.page-cat-title .main {
  font-weight: 600;
  font-size: var(--main-font-size);
  line-height: 2em;
}
.page-cat-title .sub {
  font-weight: 400;
  font-size: var(--sub-font-size);
}

/* --------------------------------------------------------------------
 line-table
-------------------------------------------------------------------- */
.line-table-wrap {
  margin: 0 -20px;
  padding: 0 20px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.line-table {
  --cell-space: 24px 20px;
  --cell-space-end: 40px;
  --font-size: 1.6rem;
  @media screen and (max-width: 768px) {
    --font-size: 1.4rem;
    --cell-space: 12px 8px;
    --cell-space-end: 16px;
  }
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
  border: 0;
  font-size: var(--font-size);
}
.line-table-th,
.line-table-td {
  padding: var(--cell-space);
  border-color: #80929a;
  border-style: solid;
  border-width: 0 0 1px 0;
  text-align: left;
  line-height: 1.5;
}
.line-table-tr > :first-child {
  padding-left: var(--cell-space-end);
}
.line-table-tr > :last-child {
  padding-right: var(--cell-space-end);
}
@media screen and (max-width: 1024px) {
  .line-table-th,
  .line-table-td {
    white-space: nowrap;
  }
}
.line-table-th {
  font-weight: 600;
}
.line-table-th.width-sm {
  width: auto;
}
.line-table-link {
  text-decoration: underline;
  color: #222;
  overflow-wrap: anywhere;
}
.line-table-link:hover {
  text-decoration: none;
}
.line-table-bottom-text {
  margin-top: 40px;
  font-size: var(--font-size);
  line-height: 2;
  text-align: right;
}

/* 工業会一覧の表調整 */
.line-table.industry-group .line-table-th:nth-of-type(1) {
  width: 35%;
}
.line-table.industry-group .line-table-th:nth-of-type(2) {
  width: 35%;
}
.line-table.industry-group .line-table-th:nth-of-type(3) {
  width: 15%;
}
.line-table.industry-group .line-table-th:nth-of-type(4) {
  width: 15%;
}
.line-table.industry-group .line-table-td:nth-of-type(3),
.line-table.industry-group .line-table-td:nth-of-type(4) {
  white-space: nowrap;
}

/* 工業会各エリア一覧の表調整 */
.line-table.industry-group-child .line-table-th:nth-of-type(1) {
  width: 20%;
}
.line-table.industry-group-child .line-table-th:nth-of-type(2) {
  width: 25%;
}
.line-table.industry-group-child .line-table-th:nth-of-type(3) {
  width: 15%;
}
.line-table.industry-group-child .line-table-th:nth-of-type(4) {
  width: 10%;
}
.line-table.industry-group-child .line-table-th:nth-of-type(5) {
  width: 30%;
}

/* --------------------------------------------------------------------
 members-contents
-------------------------------------------------------------------- */
.members-contents-container {
  --heading-pb: 24px;
  --heading-mb: 40px;
  --heading-font-size: 4rem;
  --list-gap: 40px 80px;
  --list-columns: repeat(3, 1fr);
  --py-space: 0 0 160px;
  @media screen and (max-width: 768px) {
    --heading-pb: 2px;
    --heading-mb: 24px;
    --heading-font-size: 2.2rem;
    --list-gap: 20px 20px;
    --list-columns: repeat(2, 1fr);
  }
}
.members-contents-heading {
  font-weight: 600;
  font-size: var(--heading-font-size);
  line-height: 2;
  margin-bottom: var(--heading-mb);
  padding-bottom: var(--heading-pb);
  border-bottom: solid 1px #80929a;
}
.members-contents-list {
  display: grid;
  grid-template-columns: var(--list-columns);
  gap: var(--list-gap);
}
.members-contents-link {
  display: block;
  aspect-ratio: 220 / 140;
  overflow: hidden;
}
.members-contents-thumb {
  aspect-ratio: 446 / 280;
  overflow: hidden;
}
.members-contents-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 0.3s;
}
.members-contents-link:hover .members-contents-img {
  scale: 1.1;
}
.members-contents-empty {
  padding: 100px 0;
  text-align: center;
  font-size: var(--heading-font-size);
  color: #84868D;
}

/* --------------------------------------------------------------------
 members-contents-category
-------------------------------------------------------------------- */
.members-contents-category {
  --py-space: 40px 80px;
  --list-gap: 36px;
  --list-mt: 40px;
  --list-columns: repeat(6, 1fr);
  --title-font-size: 4rem;
  --text-font-size: 1.6rem;
  --text-mt: 20px;
  --icon-size: 30px;
  @media screen and (max-width: 768px) {
    --py-space: 40px 20px;
    --list-mt: 20px;
    --list-gap: 20px 20px;
    --list-columns: repeat(2, 1fr);
    --title-font-size: 2.4rem;
    --text-font-size: 1.4rem;
    --text-mt: 12px;
    --icon-size: 16px;
  }
  padding: var(--py-space);
  background: #ebeef1;
}
.members-contents-category-title {
  font-size: var(--title-font-size);
}
.members-contents-category-list {
  display: grid;
  grid-template-columns: var(--list-columns);
  gap: var(--list-gap);
  margin-top: var(--list-mt);
}
.members-contents-category-link {
  display: block;
}
.members-contents-category-link:hover .members-contents-category-img {
  scale: 1.1;
}
.members-contents-category-thumb {
  aspect-ratio: 220 / 140;
  overflow: hidden;
}
.members-contents-category-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 0.3s;
}
.members-contents-category-text-wrap {
  display: flex;
  align-items: flex-start;
  margin-top: var(--text-mt);
  gap: 4px;
}
.members-contents-category-text {
  margin: 0;
  flex-grow: 1;
  font-size: var(--text-font-size);
  color: #222;
  line-height: 1.4;
  font-weight: 600;
}
.members-contents-category-icon {
  width: var(--icon-size);
  height: var(--icon-size);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border-style: solid;
  border-width: 1px;
  transition: 0.3s;
  border-color: #222530;
}
.members-contents-category-icon img {
  width: 50%;
}
/* --------------------------------------------------------------------
 news
-------------------------------------------------------------------- */
.news-container {
  --date-font-size: 1.4rem;
  --title-font-size: 2rem;
  --title-pb: 16px;
  --title-mb: 40px;
  --thumb-mb: 20px;
  --text-font-size: 1.6rem;
  @media screen and (max-width: 768px) {
    --date-font-size: 1.2rem;
    --title-font-size: 1.6rem;
    --title-pb: 8px;
    --title-mb: 20px;
    --thumb-mb: 16px;
    --text-font-size: 1.4rem;
  }

  max-width: 600px;
  margin: 0 auto;
}
.news-date {
  font-size: var(--date-font-size);
  font-family: "Noto Sans JP", sans-serif;
  color: #84868d;
}
.news-title {
  margin-bottom: var(--title-mb);
  padding-bottom: var(--title-pb);
  border-bottom: solid 1px #80929a;
  font-size: var(--title-font-size);
}
.news-thumb {
  margin: 0 auto;
  max-width: 100%;
  width: max-content;
  margin-bottom: var(--thumb-mb);
}
.news-thumb img {
  height: auto;
}
.news-contents {
  font-size: var(--text-font-size);
}
.news-contents p + p {
  margin-top: 30px;
}
/* --------------------------------------------------------------------
 not-found
-------------------------------------------------------------------- */
.not-found-container {
  --title-font-size: 11.2rem;
  --head-gap: 56px;
  --head-mb: 100px;
  @media screen and (max-width: 768px) {
    --title-font-size: 4.5rem;
    --head-gap: 24px;
    --head-mb: 48px;
  }
}
.not-found-title {
  font-family: "Jost", "Futura", "Century Gothic", sans-serif;
  font-size: var(--title-font-size);
  line-height: 1.5;
}
.not-found-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.not-found-head {
  display: flex;
  flex-direction: column;
  gap: var(--head-gap);
  font-size: var(not-found-title);
  margin-bottom: var(--head-mb);
  text-align: center;
}
.not-found-text {
  font-size: 1.6rem;
}
