@charset "UTF-8";
:root {
  /* spacing
  ===================================================== */
  --g-spacing-xs: 1rem;
  --g-spacing-s: 4rem;
  --g-spacing-m: 8rem;
  --g-spacing-l: 12rem;
  --g-spacing-xl: 16rem;
  --g-spacing-2xl: 20rem;
  --g-var-vw: 1512;
  /* コンテンツ幅
  ===================================================== */
  --g-var-vh: 790;
  --g-var-vw-min: 768;
  --g-var-vw-max: 1920;
  --g-var-vw-min-unit: 768px;
  --g-var-vw-max-unit: 1920px;
  /* line-height
  ===================================================== */
  --t-lineheight-xs: 1;
  --t-lineheight-s: 1.25;
  --t-lineheight-m: 1.5;
  --t-lineheight-l: 1.75;
  --t-lineheight-xl: 2;
  /* color
  ===================================================== */
  --c-text1: #2f2f2f;
  --c-text2: #fff;
  --c-bg: #F1F1F1;
  /* font-family
  ===================================================== */
  --g-font-family:"futura-pt","Noto Sans JP", sans-serif;
  /* font-family
  ===================================================== */
  --g-font-size-xs: clamp(1rem, 1 / var(--g-var-vw)* 100* 12vw, 1.2rem);
  --g-font-size-s: clamp(1.4rem, 1 / var(--g-var-vw)* 100* 16vw, 1.6rem);
  --g-font-size-m: clamp(1.6rem, 1 / var(--g-var-vw)* 100* 18vw, 1.8rem);
  --g-font-size-l: clamp(1.8rem, 1 / var(--g-var-vw)* 100* 32vw, 2rem);
  --g-font-size-xl: clamp(3.2rem, 1 / var(--g-var-vw)* 100* 48vw, 4.8rem);
  --g-font-size-2xl: clamp(6.4rem, 1 / var(--g-var-vw)* 100* 80vw, 8rem);
  /* グリッド
  ===================================================== */
  --g-var-grid-col-pc: 12;
  --g-var-grid-col-tb: 8;
  --g-var-grid-col-sp: 4;
  --g-var-grid-col-gap-pc: 1.6rem;
  --g-var-grid-col-gap-sp: 1rem;
  --g-var-grid-row-gap-pc: 1.6rem;
  --g-var-grid-row-gap-sp: 1rem;
  /* ラディウス
  ===================================================== */
  --g-radius: 999px;
  /* header, footerの高さ
  ===================================================== */
  --g-menu-height: clamp(72px, calc(100vw / var(--g-var-grid-col-pc)* 0.75), 112px);
  --g-nav-height: clamp(60px, calc(100vw / var(--g-var-grid-col-pc)* 0.75), 80px);
  /* 変数
  ===================================================== */
  --gx-sp: 32px;
}

/* common
===================================================== */
html,
body {
  font-size: 62.5%;
  height: 100%;
  overscroll-behavior-y: none;
  width: 100%;
  line-height: 1;
  scroll-behavior: smooth;
  overflow-x: hidden;
  font-kerning: normal;
  font-family: var(--g-font-family);
}

* {
  box-sizing: border-box;
}

*:focus {
  outline: none;
}

a {
  text-decoration: none;
}
a[href=""] {
  pointer-events: none;
}
a:hover {
  opacity: 0.7;
  transition: opacity 0.3s ease-in-out; /* 0.3秒で滑らかに変化 */
}

img,
video {
  width: 100%;
  display: block;
}

svg {
  fill: var(--c-text1);
}

@media (min-width: 768px) {
  .pcNone {
    display: none !important;
  }
}
@media (max-width: 767px) {
  .spNone {
    display: none !important;
  }
}
/* layout
===================================================== */
.l-wrapper {
  width: 100%;
}

.l-footer {
  width: 100%;
  height: 100%;
}
.l-footer__body {
  padding-top: 8rem;
  padding-bottom: 11rem;
}
@media (max-width: 767px) {
  .l-footer__body {
    padding-top: 9rem;
    padding-bottom: 4rem;
  }
}
.l-footer__name {
  text-align: center;
  font-size: 1.6rem;
  line-height: 1.75;
  margin-bottom: 8rem;
}
@media (max-width: 767px) {
  .l-footer__name {
    margin-bottom: 6rem;
    font-size: 1.2rem;
    line-height: 1.6666666667;
  }
}
.l-footer__copy {
  text-align: center;
  font-size: 1.2rem;
}

/* project
===================================================== */
.p-hero {
  margin-bottom: 7rem;
}
@media (max-width: 767px) {
  .p-hero {
    margin-bottom: 6rem;
  }
}

.p-lead {
  margin-bottom: 10rem;
}
@media (max-width: 767px) {
  .p-lead {
    margin-bottom: 8rem;
  }
}
.p-lead__inner {
  max-width: 120rem;
  margin-left: auto;
  margin-right: auto;
}
.p-lead h2 {
  text-align: center;
  line-height: 2;
  font-size: 1.4rem;
}
@media (max-width: 767px) {
  .p-lead h2 {
    font-size: 1.3rem;
  }
}

.p-block.block2, .p-block.block4 {
  padding-top: 15rem;
  background-color: var(--c-bg);
  padding-bottom: 15rem;
}
@media (max-width: 767px) {
  .p-block.block2, .p-block.block4 {
    padding-top: 8rem;
    padding-bottom: 5rem;
  }
}

.p-block.block4 {
  padding-bottom: 8rem;
}

.p-block {
  margin-bottom: 15rem;
}
@media (max-width: 767px) {
  .p-block {
    margin-bottom: 8rem;
  }
}
.p-block__inner {
  position: relative;
  max-width: 1256px;
  margin-left: auto;
  margin-right: auto;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: var(--g-var-grid-col-gap-pc);
}
@media (max-width: 767px) {
  .p-block__inner {
    width: 100%;
    grid-template-columns: repeat(4, 1fr);
    column-gap: var(--g-var-grid-col-gap-sp);
    padding-left: var(--gx-sp);
    padding-right: var(--gx-sp);
  }
}
.p-block__left {
  order: 1;
}
.p-block__right {
  order: 2;
}
.p-block__left.block1, .p-block__left.block3, .p-block__left.block5 {
  grid-column: 1/span 5;
  margin-left: 2.8rem;
  margin-right: -2.8rem;
}
.p-block__right.block1, .p-block__right.block3, .p-block__right.block5 {
  grid-column: 7/span 5;
  margin-left: -2.2rem;
  margin-right: 2.2rem;
}
@media (max-width: 767px) {
  .p-block__right.block1, .p-block__right.block3, .p-block__right.block5 {
    grid-column: 1/span 4;
    margin-left: 0;
    margin-right: 0;
  }
}
.p-block__right.block3 {
  align-self: center;
}
.p-block__left.block2, .p-block__left.block4 {
  grid-column: 2/span 5;
  margin-left: 2.2rem;
  margin-right: -2.2rem;
}
@media (max-width: 767px) {
  .p-block__left.block2, .p-block__left.block4 {
    grid-column: 1/span 4;
    margin-left: 0;
    margin-right: 0;
  }
}
.p-block__right.block2, .p-block__right.block4 {
  grid-column: 8/span 5;
  margin-left: -2.8rem;
  margin-right: 2.8rem;
}
.p-block__wide {
  order: 3;
}
.p-block__wide.wide-1 {
  grid-column: 3/span 8;
  margin-top: 10rem;
  margin-left: 1.6rem;
  margin-right: 1.6rem;
}
@media (max-width: 767px) {
  .p-block__wide.wide-1 {
    width: calc(100% + var(--gx-sp) * 2);
    grid-column: 1/span 4;
    margin-top: 6rem;
    margin-left: calc(-1 * var(--gx-sp));
    margin-right: 0;
  }
}
.p-block__wide.wide-1 a {
  color: var(--c-text1);
}
.p-block__itemname.wide-1 {
  font-size: 2.6rem;
  font-weight: 300;
  margin-bottom: -1rem;
  margin-left: 0.2rem;
  position: relative;
  z-index: 2;
}
@media (max-width: 767px) {
  .p-block__itemname.wide-1 {
    font-size: 1.8rem;
    margin-left: 1.6rem;
  }
}
.p-block__itemname.wide-1 span {
  font-weight: 500;
}
.p-block__credit.wide-1 {
  display: flex;
  justify-content: space-between;
  font-size: 1.4rem;
  font-weight: 400;
  margin-top: 0.8rem;
}
@media (max-width: 767px) {
  .p-block__credit.wide-1 {
    font-size: 1.2rem;
    margin-left: 1.6rem;
    margin-right: 1.6rem;
  }
}
.p-block__wide.wide-2 {
  grid-column: 5/span 4;
  margin-top: 8rem;
}
@media (max-width: 767px) {
  .p-block__wide.wide-2 {
    grid-column: 1/span 4;
  }
}
.p-block__itemtext1.wide-2 {
  font-size: 1.4rem;
  font-weight: 400;
  margin-bottom: 1.2rem;
  text-align: center;
}
@media (max-width: 767px) {
  .p-block__itemtext1.wide-2 {
    font-size: 1.2rem;
    margin-bottom: 0.8rem;
  }
}
.p-block__itemname.wide-2 {
  position: relative;
  display: flex;
  align-items: center;
}
@media (max-width: 767px) {
  .p-block__itemname.wide-2 {
    margin-left: 1.6rem;
    margin-right: 1.6rem;
  }
}
.p-block__itemname.wide-2 p {
  position: absolute;
  writing-mode: vertical-lr;
  -webkit-writing-mode: vertical-lr;
  -ms-writing-mode: vertical-lr;
  transform: rotate(180deg);
  font-size: 6.7rem;
  font-weight: 300;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .p-block__itemname.wide-2 p {
    font-size: 4.2rem;
  }
}
.p-block__itemname.wide-2 p:first-child {
  right: -3.5rem;
}
@media (max-width: 767px) {
  .p-block__itemname.wide-2 p:first-child {
    right: -2.2rem;
  }
}
.p-block__itemname.wide-2 p:last-child {
  left: -3.5rem;
  z-index: 0;
}
@media (max-width: 767px) {
  .p-block__itemname.wide-2 p:last-child {
    left: -2.2rem;
  }
}
.p-block__itemname.wide-2 p span {
  font-weight: 500;
}
.p-block__itemtext2.wide-2 {
  font-size: 1.4rem;
  font-weight: 400;
  margin-top: 1.2rem;
  text-align: center;
}
@media (max-width: 767px) {
  .p-block__itemtext2.wide-2 {
    font-size: 1.2rem;
    margin-top: 0.8rem;
  }
}
.p-block__wide.wide-3 {
  position: relative;
  grid-column: 5/span 4;
  margin-top: 8rem;
}
@media (max-width: 767px) {
  .p-block__wide.wide-3 {
    grid-column: 1/span 4;
    margin-top: 0;
  }
}
.p-block__itemname.wide-3 {
  position: absolute;
  left: -13.5rem;
  font-size: 2.6rem;
  font-weight: 500;
  text-align: right;
}
@media (max-width: 767px) {
  .p-block__itemname.wide-3 {
    position: relative;
    font-size: 1.8rem;
    left: 0;
    text-align: left;
    margin-bottom: 0.6rem;
  }
}
.p-block__itemname.wide-3 span {
  font-weight: 300;
}
.p-block__credit.wide-3 {
  position: absolute;
  font-size: 1.4rem;
  font-weight: 400;
  bottom: 0;
  right: -8.5rem;
}
@media (max-width: 767px) {
  .p-block__credit.wide-3 {
    position: relative;
    font-size: 1.2rem;
    right: 0;
    text-align: right;
    margin-top: 2rem;
  }
}
.p-block__credit.wide-3 p {
  margin-bottom: 0.4rem;
}
.p-block__wide.wide-4 {
  position: absolute;
  bottom: 0;
  right: 0;
  margin-right: 2.8rem;
  font-size: 1.4rem;
  font-weight: 300;
  line-height: 1.5714285714;
  text-align: right;
}
@media (max-width: 767px) {
  .p-block__wide.wide-4 {
    position: relative;
    grid-column: 1/span 4;
    font-size: 1.2rem;
    line-height: 1.4166666667;
    margin-top: 1.4rem;
  }
}

.p-itemlist {
  padding-top: 8rem;
  padding-bottom: 8rem;
  background-color: var(--c-bg);
}
@media (max-width: 767px) {
  .p-itemlist {
    padding-bottom: 5rem;
  }
}
.p-itemlist__inner {
  position: relative;
  max-width: 1256px;
  margin-left: auto;
  margin-right: auto;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: var(--g-var-grid-col-gap-pc);
}
@media (max-width: 767px) {
  .p-itemlist__inner {
    grid-template-columns: repeat(4, 1fr);
    column-gap: var(--g-var-grid-col-gap-sp);
    padding-left: var(--gx-sp);
    padding-right: var(--gx-sp);
  }
}
.p-itemlist__title {
  grid-column: 5/span 4;
  font-size: 4rem;
  font-weight: 300;
  text-align: center;
  margin-bottom: 6rem;
}
@media (max-width: 767px) {
  .p-itemlist__title {
    grid-column: 2/span 2;
    font-size: 2.8rem;
    margin-bottom: 4rem;
  }
}
.p-itemlist__title span {
  font-weight: 600;
}
.p-itemlist__items {
  grid-column: 3/span 8;
  display: flex;
  justify-content: center;
  gap: 4rem 2rem;
  flex-wrap: wrap;
  margin-bottom: 8rem;
}
@media (max-width: 767px) {
  .p-itemlist__items {
    grid-column: 1/span 4;
    gap: 2rem 1.5rem;
    margin-bottom: 7rem;
    justify-content: flex-start;
  }
}
.p-itemlist__items::after {
  content: "";
  width: 100%;
}
.p-itemlist__items li {
  width: 31.7307692308%;
}
@media (max-width: 767px) {
  .p-itemlist__items li {
    width: calc(50% - 0.75rem);
  }
}
.p-itemlist__items li:nth-child(1), .p-itemlist__items li:nth-child(2) {
  order: 0;
}
.p-itemlist__items li:nth-child(3), .p-itemlist__items li:nth-child(4), .p-itemlist__items li:nth-child(5) {
  order: 1;
}
.p-itemlist__num {
  font-size: 2rem;
  font-weight: 600;
  margin-bottom: 0.2rem;
}
@media (max-width: 767px) {
  .p-itemlist__num {
    font-size: 1.6rem;
  }
}
.p-itemlist__name {
  font-size: 1.6rem;
  font-weight: 400;
  margin-bottom: 1rem;
}
@media (max-width: 767px) {
  .p-itemlist__name {
    font-size: 1.2rem;
    margin-bottom: 0.4rem;
  }
}
.p-itemlist__item:hover p {
  color: var(--c-text1);
  background-color: var(--c-text2);
  border: solid 0.1rem var(--c-text1);
  padding: 0.3rem 1.5rem 0.2rem;
}
.p-itemlist__btn {
  width: min-content;
  margin-left: auto;
  margin-top: 1rem;
}
.p-itemlist__btn p {
  font-size: 1.4rem;
  font-weight: 500;
  padding: 0.4rem 1.5rem 0.3rem;
  color: var(--c-text2);
  background-color: var(--c-text1);
  border-radius: 999px;
  transition: color 0.3s ease, background-color 0.3s ease, border-color 0.3s ease;
}
@media (max-width: 767px) {
  .p-itemlist__btn p {
    font-size: 1.2rem;
  }
}
.p-itemlist__allbtn {
  grid-column: 1/span 12;
  width: 15rem;
  display: grid;
  justify-self: center;
}
@media (max-width: 767px) {
  .p-itemlist__allbtn {
    grid-column: 1/span 4;
    width: 20rem;
    margin-left: auto;
    margin-right: auto;
  }
}
.p-itemlist__allbtn a {
  font-size: 1.4rem;
  color: var(--c-text2);
  font-weight: 500;
  display: block;
  text-align: center;
  width: 100%;
  padding-top: 1.1rem;
  padding-bottom: 1.2rem;
  color: var(--c-text2);
  background-color: var(--c-text1);
  border-radius: 999px;
}
.p-itemlist__allbtn a:hover {
  color: var(--c-text1);
  background-color: var(--c-text2);
  border: solid 0.1rem var(--c-text1);
  padding-top: 1rem;
  padding-bottom: 1.1rem;
}

/* component
===================================================== */
.c-leadtitle {
  width: 100%;
  margin-top: 8rem;
}
@media (max-width: 767px) {
  .c-leadtitle {
    margin-top: 0;
  }
}
.c-leadtitle .c-leadnum {
  text-align: right;
  font-size: 4rem;
  font-weight: 300;
}
@media (max-width: 767px) {
  .c-leadtitle .c-leadnum {
    text-align: left;
    font-size: 2.6rem;
  }
}
.c-leadtitle .c-leadnum span {
  font-size: 1.6rem;
  font-weight: 400;
  margin-right: 0.8rem;
  margin-bottom: 0.8rem;
}
@media (max-width: 767px) {
  .c-leadtitle .c-leadnum span {
    font-size: 1.2rem;
    margin-right: 0.5rem;
  }
}
@media (max-width: 767px) {
  .c-leadtitle .c-leadnum.block2, .c-leadtitle .c-leadnum.block4 {
    text-align: right;
  }
}
.c-leadtitle .c-bottomline {
  display: block;
  height: 0.4rem;
  width: 100%;
  border-top: 0.1rem solid var(--c-text1);
  border-bottom: 0.1rem solid var(--c-text1);
  margin-bottom: 5rem;
}
@media (max-width: 767px) {
  .c-leadtitle .c-bottomline {
    margin-bottom: 2rem;
    width: calc(100% + var(--gx-sp));
  }
}
@media (max-width: 767px) {
  .c-leadtitle .c-bottomline.block2, .c-leadtitle .c-bottomline.block4 {
    margin-left: calc(-1 * var(--gx-sp));
  }
}
.c-leadtitle .c-enname {
  font-size: 4rem;
  line-height: 1.075;
  font-weight: 600;
}
@media (max-width: 767px) {
  .c-leadtitle .c-enname {
    font-size: 2.6rem;
    text-align: right;
  }
}
@media (max-width: 767px) {
  .c-leadtitle .c-enname.block2, .c-leadtitle .c-enname.block4 {
    text-align: left;
  }
}
.c-leadtitle .c-jpname {
  font-size: 2.1rem;
  line-height: 1.1904761905;
  font-weight: 300;
  margin-top: 1rem;
  margin-bottom: 8rem;
}
@media (max-width: 767px) {
  .c-leadtitle .c-jpname {
    font-size: 1.5rem;
    text-align: right;
    margin-top: 0.8rem;
    margin-bottom: 2.5rem;
  }
}
@media (max-width: 767px) {
  .c-leadtitle .c-jpname.block2, .c-leadtitle .c-jpname.block4 {
    text-align: left;
  }
}

@media (max-width: 767px) {
  .c-mainimg {
    margin-bottom: 3rem;
  }
}
.c-mainimg:hover ~ .c-btn a {
  color: var(--c-text1);
  background-color: var(--c-text2);
  border: solid 0.1rem var(--c-text1);
}

.c-description {
  width: 100%;
  font-size: 1.4rem;
  line-height: 2;
  margin-bottom: 4rem;
}
@media (max-width: 767px) {
  .c-description {
    font-size: 1.3rem;
    margin-bottom: 3rem;
  }
}

.c-btn {
  display: flex;
  gap: 0.8rem;
  align-items: center;
  margin-bottom: 8rem;
}
@media (max-width: 767px) {
  .c-btn {
    justify-content: end;
    margin-bottom: 6rem;
  }
}
.c-btn p {
  font-size: 1.4rem;
  font-weight: 400;
}
@media (max-width: 767px) {
  .c-btn p {
    font-size: 1.3rem;
  }
}
.c-btn span {
  font-size: 1.3rem;
  font-weight: 400;
  margin-left: 0.5rem;
}
@media (max-width: 767px) {
  .c-btn span {
    font-size: 1.2rem;
  }
}
.c-btn a {
  font-size: 1.4rem;
  font-weight: 500;
  padding: 0.4rem 1.5rem 0.3rem;
  color: var(--c-text2);
  background-color: var(--c-text1);
  border-radius: 999px;
  transition: color 0.3s ease, background-color 0.3s ease, border-color 0.3s ease;
}
@media (max-width: 767px) {
  .c-btn a {
    font-size: 1.2rem;
  }
}
.c-btn a:hover {
  color: var(--c-text1);
  background-color: var(--c-text2);
  border: solid 0.1rem var(--c-text1);
  padding: 0.3rem 1.5rem 0.2rem;
}

.c-btn.block3, .c-btn.block4, .c-btn.block5 {
  margin-bottom: 5rem;
}

.c-subimg {
  display: flex;
  gap: 0.8rem;
}
@media (max-width: 767px) {
  .c-subimg {
    display: block;
    position: relative;
    gap: 0.6rem;
  }
}
.c-subimg p {
  writing-mode: vertical-rl;
  font-size: 1.4rem;
  font-weight: 400;
}

.c-subimg.block1, .c-subimg.block5 {
  margin-left: 5.5rem;
  margin-right: 2.2rem;
}
@media (max-width: 767px) {
  .c-subimg.block1, .c-subimg.block5 {
    width: 28rem;
    margin-right: -3.2rem;
    margin-left: auto;
  }
}
@media (max-width: 767px) {
  .c-subimg.block1 p, .c-subimg.block5 p {
    font-size: 1.2rem;
    position: absolute;
    top: 0;
    left: -1.6rem;
  }
}

.c-subimg.block1 {
  align-items: baseline;
}
@media (max-width: 767px) {
  .c-subimg.block1 {
    align-items: flex-start;
  }
}

.c-subimg.block2, .c-subimg.block4 {
  margin-right: 5.5rem;
  flex-direction: row-reverse;
  margin-left: 2.2rem;
}
@media (max-width: 767px) {
  .c-subimg.block2, .c-subimg.block4 {
    width: 28rem;
    margin-left: -3.2rem;
    margin-right: 0;
  }
}
@media (max-width: 767px) {
  .c-subimg.block2 p, .c-subimg.block4 p {
    font-size: 1.2rem;
    position: absolute;
    top: 0;
    right: -1.6rem;
  }
}

.c-subimg.block2 {
  align-items: baseline;
}

.c-subimg.block4 {
  align-items: flex-start;
}

.c-logo {
  text-align: center;
  margin-bottom: 3rem;
}
.c-logo svg {
  width: 5.5rem;
  height: 3rem;
}

.c-icon {
  display: flex;
  gap: 2.4rem;
  align-items: center;
  justify-content: center;
  margin-bottom: 3rem;
}
.c-icon svg {
  width: 1.8rem;
  height: 1.8rem;
}/*# sourceMappingURL=style.css.map */