@charset "utf-8";

.page__fv {
  margin-top: 85px;
  width: 100%;
}

.page__fv-head {
  padding-block: clamp(10px, 2.79vw, 38px) 10px;
}

.page__fv-head-inner {
  width: 100%;
  padding-inline: 6.88vw 1.76vw;
}

.page__fv-title-en {
  font-family: var(--font-en);
  font-size: 30px;
  font-weight: 700;
  letter-spacing: calc(100 / 1000 * 1em);
  line-height: 1.2;
  color: var(--color-thin);
}

.page__fv-title-ja {
  margin-top: 8px;
  color: var(--color-thin);
  font-family: var(--font-title);
  font-size: 14px;
  letter-spacing: calc(40 / 1000 * 1em);
  display: flex;
  align-items: center;
  gap: 10px;
}

.page__fv-title-ja::before {
  content: "";
  width: 7px;
  height: 7px;
  background: var(--color-button);
  border-radius: 50%;
  flex-shrink: 0;
}

.page__fv .c-breadcrumbs__wrapper {
  margin-top: 11px;
}

.page__fv-image {
  width: 100%;
  height: clamp(187px, 36.39vw, 497px);
  overflow: hidden;
  position: relative;
}

.page__fv-image::after {
  content: "";
  pointer-events: none;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 1;
  background: url(../images/page-fv-filter.png) no-repeat center center / cover;
}

.page__fv-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.page__fv-image02 {
  position: relative;
  width: 100%;
  height: 582px;
  overflow: hidden;
  position: relative;
}

.page__fv-image02.page__fv-image04 {
  height: 582px;
}

@media screen and (min-width: 450px) {
  .page__fv-image02,
  .page__fv-image02.page__fv-image04 {
    height: clamp(600px, 101.7vw, 780px);
  }
}

@media screen and (min-width: 768px) {
  .page__fv-image02,
  .page__fv-image02.page__fv-image04 {
    height: 917px;
  }
}

@media screen and (min-width: 1024px) {
  .page__fv-image02,
  .page__fv-image02.page__fv-image04 {
    height: 497px;
  }
}

.page__fv-image02::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 1;
  background: linear-gradient(to bottom, #f2a729 23%, rgba(0, 0, 0, 0) 81%);
  pointer-events: none;
}

.page__fv-image04::after {
  /* background: linear-gradient(to bottom, #f2a729 43%, rgba(0, 0, 0, 0) 81%); */
  background: linear-gradient(to bottom, #f2a729 23%, rgba(0, 0, 0, 0) 81%);
}

/* @media screen and (min-width: 500px) {
  .page__fv-image04::after {
    background: linear-gradient(to bottom, #f2a729 38%, rgba(0, 0, 0, 0) 67%);
  }
} */

@media screen and (min-width: 570px) {
  .page__fv-image04::after,
  .page__fv-image02::after {
    background: linear-gradient(to bottom, #f2a729 39%, rgba(0, 0, 0, 0) 61%);
  }
}

@media screen and (min-width: 768px) {
  .page__fv-image04::after,
  .page__fv-image02::after {
    background: linear-gradient(to bottom, #f2a729 30%, rgba(0, 0, 0, 0) 70%);
  }
}

@media screen and (min-width: 1024px) {
  .page__fv-image02::after,
  .page__fv-image04::after {
    background: url(../images/page-fv-image02.png) no-repeat center center /
      cover;
  }
}

.page__fv-image03 {
  width: 100%;
  height: 497px;
  overflow: hidden;
  position: relative;
  background: linear-gradient(to right, #f2a729, #f2c67c);
}

.page__fv-contents {
  max-width: calc(471px + 6.8% * 2);
  margin-top: 40px;
  padding-inline: 6.8%;
  position: relative;
  z-index: 2;
  color: var(--color-white);
}

@media screen and (min-width: 813px) {
  .page__fv-contents {
    margin-top: 60px;
  }
}
@media screen and (min-width: 900px) {
  .page__fv-contents {
    margin-top: 108px;
  }
}

.page__fv-contents-title-wrap {
  text-align: left;
}

.page__fv-contents-title {
  font-size: clamp(30px, 3.37vw, 46px);
  font-weight: 700;
  letter-spacing: calc(130 / 1000 * 1em);
  line-height: calc(60 / 46);
}

.page__fv-contents-title-row {
  display: flex;
}

.page__fv-contents-title-bar {
  position: relative;
}

.page__fv-contents-title-bar::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 5px;
  bottom: -5px;
  left: 0;
  background: var(--color-white);
}

.page__fv-contents-text {
  margin-top: 41px;
  font-size: clamp(12px, 1.03vw, 14px);
  letter-spacing: calc(40 / 1000 * 1em);
  line-height: calc(28 / 14);
}

@media screen and (min-width: 1024px) {
  .page__fv-contents-text {
    max-width: 300px;
  }
}

@media screen and (min-width: 1200px) {
  .page__fv-contents-text {
    max-width: 100%;
  }
}

.page__fv-image02-content {
  position: absolute;
  aspect-ratio: 762/497;
  bottom: 0;
  right: 0;
  width: 100%;
  height: auto;
  display: inline-block;
  margin-inline: auto 0;
}

@media screen and (min-width: 1024px) {
  .page__fv-image02-content {
    bottom: auto;
    top: 0;
    right: 0;
    width: auto;
    height: 100%;
  }
}

.page__fv-image02-content img {
  object-fit: cover;
  object-position: center;
  width: 100%;
  height: 100%;
  mask-image: linear-gradient(to bottom, transparent 0%, black 5%);
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, black 5%);
}

@media (min-width: 1024px) {
  .page__fv-image02-content img {
    mask-image: linear-gradient(to right, transparent 0%, black 5%);
    -webkit-mask-image: linear-gradient(to right, transparent 0%, black 5%);
  }
}

.page__fv-image03-content {
  position: absolute;
  aspect-ratio: 762/497;
  bottom: 0;
  right: 50%;
  transform: translateX(50%);
  width: 95%;
  height: auto;
  display: inline-block;
  margin-inline: auto 0;
}

@media screen and (min-width: 400px) {
  .page__fv-image03-content {
    width: 73%;
  }
}

@media screen and (min-width: 600px) {
  .page__fv-image03-content {
    width: 64%;
  }
}

@media screen and (min-width: 740px) {
  .page__fv-image03-content {
    right: 0;
    transform: translateX(0);
  }
}

@media screen and (min-width: 800px) {
  .page__fv-image03-content {
    width: 60%;
  }
}

@media screen and (min-width: 900px) {
  .page__fv-image03-content {
    width: 52%;
  }
}

@media screen and (min-width: 1177px) {
  .page__fv-image03-content {
    right: 58px;
    width: auto;
    height: 96%;
  }
}

.page__fv-image03-content img {
  object-fit: contain;
  object-position: center;
  width: 100%;
  height: 100%;
}

/* =====================
main
======================= */
.page__main {
  padding-block: 80px 100px;
}

@media screen and (min-width: 768px) {
  .page__main {
    padding-block: 100px 165px;
  }
}

.page__main-background {
  background: #f0f2f5;
}

@media screen and (min-width: 768px) {
  .page__main-inner.l-inner {
    max-width: calc(1286px + 40px * 2);
  }
}

.page__main-container {
  display: flex;
  flex-direction: column-reverse;
  width: 100%;
  margin: 0 auto;
  gap: 40px;
}

@media screen and (min-width: 900px) {
  .page__main-container {
    flex-direction: row;
    justify-content: space-between;
  }
}

/* メインコンテンツエリア */
.page__main-contents {
  flex: 1;
  min-width: 0;
  max-width: 1000px;
  background: var(--color-white);
  border-radius: 10px;
  padding: 40px 25px;
}

@media screen and (min-width: 768px) {
  .page__main-contents {
    padding: 50px 55px;
  }
}

.news__contents.page__main-contents {
  padding: 40px 25px 100px;
}

@media screen and (min-width: 768px) {
  .news__contents.page__main-contents {
    padding: 50px 50px 156px;
  }
}

.page__top-title {
  font-size: clamp(22px, 2.35vw, 32px);
  font-weight: 700;
  letter-spacing: calc(50 / 1000 * 1em);
  color: var(--color-thin);
}

.page__section-title-en {
  margin-top: 15px;
  font-family: var(--font-en);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: calc(100 / 1000 * 1em);
  color: #e95a2a;
}

.page__top-text {
  margin-top: 30px;
  font-size: clamp(12px, 1.03vw, 14px);
  letter-spacing: calc(40 / 1000 * 1em);
  line-height: calc(28 / 14);
  max-width: 471px;
}

.page__section {
  position: relative;
  border-top: 1px solid #d4d4d4;
  padding-top: 40px;
}

.page__section:first-of-type {
  margin-top: 33px;
}

.page__section:not(:last-child) {
  padding-bottom: 40px;
}

@media screen and (min-width: 768px) {
  .page__section {
    padding-top: 70px;
  }
  .page__section:first-of-type {
    margin-top: 50px;
  }
  .page__section:not(:last-child) {
    padding-bottom: 90px;
  }
}

.page__section::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 12.9%;
  height: 1px;
  background: #ea6e2e;
  z-index: 1;
}

.page__section-title-ja {
  font-size: clamp(20px, 2.05vw, 28px);
  font-weight: 700;
  letter-spacing: calc(50 / 1000 * 1em);
  color: var(--color-thin);
}

@media screen and (min-width: 768px) {
  .page__section-title-ja br {
    display: none;
  }
}

/* table */
.page__section-table {
  margin-top: 40px;
  border-radius: 10px 0 0 10px;
  overflow: hidden;
}

@media screen and (min-width: 768px) {
  .page__section-table {
    margin-top: 60px;
  }
}

.page__section-table-row {
  display: grid;
}

@media screen and (min-width: 768px) {
  .page__section-table-row {
    display: grid;
    align-items: center;
    grid-template-columns: 140px 1fr;
  }
}

.page__section-table-row:not(:last-child) {
  border-bottom: 1px solid #d4d4d4;
}

.page__section-table-row:first-child .page__section-table-td {
  border-top: 1px solid #d4d4d4;
}
.page__section-table-row:last-child .page__section-table-td {
  border-bottom: 1px solid #d4d4d4;
  border-radius: 0 0 0 10px;
}

@media screen and (min-width: 768px) {
  .page__section-table-row:last-child .page__section-table-td {
    border-radius: 0;
  }
}

.page__section-table-th {
  padding-block: 15px;
  height: 100%;
}

@media screen and (min-width: 768px) {
  .page__section-table-th {
    padding-block: 35px;
  }
}

.page__section-table-th {
  background: #f7f1ee;
  font-size: clamp(12px, 1.03vw, 14px);
  font-weight: 700;
  letter-spacing: normal;
  line-height: calc(35 / 14);
  color: var(--color-thin);
  padding-inline: clamp(15px, 2.57vw, 35px);
}

@media screen and (min-width: 768px) {
  .page__section-table-th {
    display: grid;
    place-items: center;
  }
}

.page__section-table-td {
  padding: 15px clamp(20px, 3.3vw, 45px);
  height: 100%;
  border: 1px solid #d4d4d4;
}

@media screen and (min-width: 765px) {
  .page__section-table-td {
    padding: 35px clamp(20px, 3.3vw, 45px);
    border: none;
    border-right: 1px solid #d4d4d4;
  }
}

.page__section-table-td-text {
  font-size: clamp(12px, 1.03vw, 14px);
  font-weight: 500;
  letter-spacing: normal;
  line-height: calc(30.8 / 14);
  color: var(--color-thin);
}

.page__section-table-td-text a {
  transition: opacity 0.5s ease;
}
.page__section-table-td-text a:hover {
  opacity: 0.7;
}

.page__section-table-map {
  width: 100%;
  height: 300px;
  margin-top: 30px;
  border-radius: 10px;
  overflow: hidden;
}

.page__section-table-map-box {
  width: 100%;
  height: 100%;
}

.page__section-table-map iframe {
  width: 100%;
  height: 100%;
  border: none;
}

/* サイドバー */
.page__sidemenu {
  width: 100%;
}

@media screen and (min-width: 900px) {
  .page__sidemenu {
    width: 19%;
    flex-shrink: 0;
    position: sticky;
    top: 160px;
    align-self: flex-start;
    height: fit-content;
  }
}

.page__sidemenu-title {
  font-size: clamp(16px, 1.32vw, 18px);
  font-weight: 700;
  letter-spacing: calc(50 / 1000 * 1em);
  display: flex;
  align-items: center;
  gap: 8px;
  padding-bottom: 20px;
}

.page__sidemenu-title::after {
  content: "";
  width: clamp(14px, 1.18vw, 16px);
  height: auto;
  aspect-ratio: 16/16;
  background: url(../images/side-title-icon.svg) no-repeat center center/contain;
}

.page_side-list,
.news__sidemenu .webgene-blog {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: center;
  gap: 10px 0;
  width: 100%;
}

@media screen and (min-width: 600px) {
  .page_side-list,
  .news__sidemenu .webgene-blog {
    grid-template-columns: repeat(3, 1fr);
    justify-content: flex-start;
    align-items: flex-start;
  }
}

@media screen and (min-width: 900px) {
  .page_side-list,
  .news__sidemenu .webgene-blog {
    gap: 0px;
    grid-template-columns: 1fr;
    justify-content: flex-start;
    align-items: flex-start;
  }
}

.page_side-item,
.news__side-wrap {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  border-right: 1px solid #d5d5d5;
}

.page_side-item:nth-child(2n + 1),
.news__side-wrap:nth-child(2n + 1) {
  border-left: 1px solid #d5d5d5;
}

@media screen and (min-width: 600px) {
  .page_side-item:nth-child(3n + 1),
  .news__side-wrap:nth-child(3n + 1) {
    border-left: 1px solid #d5d5d5;
  }
  .page_side-item:nth-child(2n + 1),
  .news__side-wrap:nth-child(2n + 1) {
    border-left: none;
  }
}

@media screen and (min-width: 900px) {
  .page_side-item,
  .news__side-wrap {
    width: 100%;
    border-bottom: 1px solid #d5d5d5;
    border-right: none;
    justify-content: flex-start;
  }

  .page_side-item:first-child,
  .news__side-wrap:first-child {
    border-top: 1px solid #d5d5d5;
  }

  .page_side-item:nth-child(3n + 1),
  .news__side-wrap:nth-child(3n + 1) {
    border-left: none;
  }
}

.page_side-item p {
  padding: 16px 11px;
  font-size: clamp(12px, 1.03vw, 14px);
  font-weight: 500;
  letter-spacing: calc(50 / 1000 * 1em);
  color: #3b3b3c;
  display: block;
  text-align: center;
  width: 100%;
}

@media screen and (min-width: 1270px) {
  .page_side-item p br {
    display: none;
  }
}

/* セクションにいる時（アクティブ状態） */
.page_side-item.is-active p {
  background: #ea5d2b;
  color: #ffffff;
  border-radius: 10px;
}

@media screen and (min-width: 900px) {
  .page_side-item p {
    text-align: left;
  }
}

/* 
.news__side-wrap {
  border-bottom: 1px solid #d5d5d5;
}

.news__side-wrap:first-child {
  border-top: 1px solid #d5d5d5;
} */

.news__side-category {
  width: 100%;
  text-align: center;
  padding: 16px 11px;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: calc(50 / 1000 * 1em);
  color: #3b3b3c;
  display: block;
}

.news__side-category.is-active {
  background: #ea5d2b;
  color: var(--color-white);
  border-radius: 10px;
}

@media screen and (min-width: 900px) {
  .news__side-category {
    text-align: left;
  }
}
