@charset "UTF-8";
:root {
  --scrollbar: 0px;
  --100vw: calc(100vw - var(--scrollbar)); }

#HeaderArea2 {
  z-index: 10 !important; }

#ProjectStory {
  /*	border: 1px dotted blue; delete */
  /*	box-sizing: border-box; delete */
  /*font-family: "Noto Sans JP", sans-serif;*/
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  overflow: hidden;
  font-size: 160%; }

@media print {
  #ProjectStory {
    overflow: visible; } }
@media screen and (max-width: 1305px) {
  #ProjectStory #Contents {
    min-width: auto;
    padding-left: 0;
    padding-right: 0; } }
#ProjectStory .GridSet {
  width: 100%; }

@media screen and (min-width: 995px) and (max-width: 1304px) {
  .OptionWideRWD .GridSet {
    margin: 0 !important; } }
@media screen and (max-width: 995px) {
  .JS .GridSet {
    margin: 0 !important; } }
#ProjectStory section {
  /*	border: 1px dotted green; delete */
  /*	box-sizing: border-box; delete */
  margin: 0 auto;
  position: relative;
  width: 1275px; }

@media screen and (max-width: 1305px) {
  #ProjectStory section {
    width: 100%; } }
#ProjectStory section .Section {
  /*	border: 1px dotted red; delete */
  /*	box-sizing: border-box; delete */
  color: #0C0C0C;
  margin: 0 auto;
  width: 965px; }

@media screen and (max-width: 995px) {
  #ProjectStory section .Section {
    box-sizing: border-box;
    padding-left: 15px;
    padding-right: 15px;
    width: 100%; } }
@media screen and (max-width: 767px) {
  #ProjectStory section .Section {
    padding-left: 4vw;
    padding-right: 4vw; } }
/* main visual */
.wrapper {
  overflow: hidden; }

.container {
  width: 100%;
  max-width: 965px;
  margin: 0 auto; }

@media screen and (max-width: 965px) {
  .container {
    max-width: none; } }
.row {
  position: relative;
  min-height: 580px; }

@media screen and (max-width: 1360px) {
  .row {
    min-height: auto;
    height: 42.6470vw; } }
@media screen and (max-width: 767px) {
  .row {
    height: 77vw; } }
.column {
  width: calc(100vw - (100vw - 965px) / 2);
  max-width: 100vw;
  position: absolute; }

@media screen and (max-width: 965px) {
  .column {
    width: 100%;
    max-width: 100%; } }
.column.image {
  top: 0;
  left: 0;
  z-index: 3; }

@media screen and (max-width: 767px) {
  .column.image {
    left: -21%; } }
.column.image img {
  width: 100%; }

@media screen and (max-width: 767px) {
  .column.image img {
    height: 77vw !important;
    max-width: none !important;
    width: auto !important; } }
/* headline */
/* h2 */
#ProjectStory .h_style01 {
  background: none;
  border: none;
  line-height: 1em;
  font-size: 32px;
  /*font-size: divceil($fs, 10, rem);*/
  font-weight: 500;
  margin: 0 0 30px 0;
  padding: 0; }

@media screen and (max-width: 767px) {
  #ProjectStory .h_style01 {
    font-size: 5.6vw;
    line-height: 1.4;
    margin: 0 0 4vw 0; } }
/* h2 */
#ProjectStory .h_style02 {
  background: none;
  border: none;
  line-height: 1em;
  font-size: 24px;
  /*font-size: divceil($fs, 10, rem);*/
  font-weight: 700;
  margin: 0 0 30px 0;
  padding: 0; }

@media screen and (max-width: 767px) {
  #ProjectStory .h_style02 {
    font-size: 4.8vw;
    margin: 0 0 8vw 0; } }
/* h2 english */
#ProjectStory .h_style03 {
  background: none;
  border: none;
  font-family: "Lexend", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  line-height: 1em;
  font-size: 28px;
  /*font-size: divceil($fs, 10, rem);*/
  margin: 0 0 20px 0; }

@media screen and (max-width: 767px) {
  #ProjectStory .h_style03 {
    font-size: 5.33vw;
    line-height: 100%;
    margin: 0 0 4vw 0; } }
/* h3 */
#ProjectStory .h_style04 {
  background: none;
  border: none;
  line-height: 1em;
  font-size: 16px;
  /*font-size: divceil($fs, 10, rem);*/
  font-weight: 500;
  margin: 0 0 10px 0; }

@media screen and (max-width: 767px) {
  #ProjectStory .h_style04 {
    font-size: 3.73vw;
    margin: 0 0 4vw 0; } }
/* h2 english */
#ProjectStory .h_style05 {
  background: none;
  border: none;
  font-family: "Lexend", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  line-height: 1em;
  font-size: 42px;
  /*font-size: divceil($fs, 10, rem);*/
  margin: 0 0 100px 0;
  padding: 0; }

@media screen and (max-width: 767px) {
  #ProjectStory .h_style05 {
    font-size: 6.4vw;
    margin: 0 0 13.33vw 0; } }
/* p */
#ProjectStory section p {
  line-height: 1em;
  font-size: 16px;
  /*font-size: divceil($fs, 10, rem);*/
  margin: 0 0 40px 0; }

@media screen and (max-width: 767px) {
  #ProjectStory section p {
    font-size: 3.73vw;
    margin: 0 0 5.3vw 0; } }
/* icon */
#ProjectStory section span.icon {
  background-color: #18244e;
  box-sizing: border-box;
  color: #fff;
  display: inline-block;
  font-weight: 500;
  letter-spacing: 0.15em;
  line-height: 100%;
  padding: 7px 15px;
  text-align: center;
  min-width: 100px;
  vertical-align: text-bottom; }

@media screen and (max-width: 767px) {
  #ProjectStory section span.icon {
    letter-spacing: 0.05em;
    padding: 2vw;
    min-width: auto;
    width: auto; } }
@media screen and (max-width: 431px) {
  #ProjectStory section span.icon {
    padding: 1vw; } }
/* color */
#ProjectStory .c_navy {
  color: #18244e; }

#ProjectStory .bg_gray {
  background-color: #f0f0f0; }

/* column */
#ProjectStory .text_and_photo {
  display: flex;
  justify-content: space-between; }

#ProjectStory .text_and_photo .photo figure {
  margin: 0; }

#ProjectStory .text_and_photo .photo figure img {
  width: 100%; }

#ProjectStory section .text_and_photo.reverse_r {
  flex-direction: row-reverse; }

#ProjectStory section .text_and_photo.reverse_c {
  flex-direction: column-reverse; }

/* section 01 */
#ProjectStory section .sec01 {
  padding-top: 80px;
  padding-bottom: 20px;
  position: relative; }

@media screen and (max-width: 767px) {
  #ProjectStory section .sec01 {
    padding: 8vw 4vw 2.5vw 4vw; } }
#ProjectStory section .sec01 .project_num {
  display: inline-block;
  font-family: "Lexend", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  line-height: 1em;
  font-size: 16px;
  /*font-size: divceil($fs, 10, rem);*/
  font-style: normal;
  letter-spacing: 0.1em;
  position: absolute;
  top: 80px;
  left: -3.66vw;
  rotate: 90deg;
  transform-origin: top left; }

@media screen and (max-width: 1105px) {
  #ProjectStory section .sec01 .project_num {
    left: -1vw; } }
@media screen and (max-width: 1040px) {
  #ProjectStory section .sec01 .project_num {
    margin: 0 0 5.33vw 0;
    position: relative;
    top: auto;
    left: auto;
    rotate: none;
    transform-origin: 0 0; } }
@media screen and (max-width: 767px) {
  #ProjectStory section .sec01 .project_num {
    font-size: 3.73vw; } }
#ProjectStory section .sec01 .PageTitleStyle1 {
  line-height: 100%;
  margin: 0 0 30px 0; }

@media screen and (max-width: 767px) {
  #ProjectStory section .sec01 .PageTitleStyle1 {
    margin: 0 0 4vw 0; } }
#ProjectStory section .sec01 .PageTitleStyle1 h1 {
  color: #0C0C0C !important;
  line-height: 1.25em;
  font-size: 38px;
  /*font-size: divceil($fs, 10, rem);*/ }

#ProjectStory section .sec01 .PageTitleStyle1 h1 a {
  color: #0C0C0C !important; }

@media screen and (max-width: 767px) {
  #ProjectStory section .sec01 .PageTitleStyle1 h1 {
    font-size: 6.4vw; } }
#ProjectStory section .sec01 .PageTitleStyle1 h1 a {
  line-height: 100%; }

@media screen and (max-width: 767px) {
  #ProjectStory section .sec01 .PageTitleStyle1 h1 a {
    line-height: 145%; } }
#ProjectStory section section .sec01 .PageTitleStyle1 h1 a:hover {
  color: #0C0C0C !important; }

#ProjectStory section .sec01 .CatchCopy {
  line-height: 2em;
  font-size: 20px;
  /*font-size: divceil($fs, 10, rem);*/
  font-weight: 500;
  line-height: 200%; }

@media screen and (max-width: 767px) {
  #ProjectStory section .sec01 .CatchCopy {
    font-size: 4vw;
    margin-bottom: 6vw; } }
/* section 02 */
#ProjectStory .bg_gray_sec02 {
  position: relative;
  z-index: 2; }

#ProjectStory .bg_gray_sec02::before {
  background-color: #f0f0f0;
  content: "";
  display: block;
  position: absolute;
  right: calc((100vw - 1275px)/2 + 50px);
  top: -100px;
  height: 100%;
  width: calc(100vw - (100vw - 1275px)/2 - 50px);
  z-index: -1; }

@media screen and (max-width: 1175px) {
  #ProjectStory .bg_gray_sec02::before {
    right: 0;
    width: 100vw; } }
@media screen and (max-width: 767px) {
  #ProjectStory .bg_gray_sec02::before {
    right: 0;
    top: 0;
    z-index: 0; } }
#ProjectStory section .sec02 {
  padding-bottom: 85px;
  padding-top: 245px;
  transform: translate(0, -100px); }

@media screen and (max-width: 767px) {
  #ProjectStory section .sec02 {
    margin-bottom: 18vw;
    padding-bottom: 20vw;
    padding-top: 20vw;
    transform: translate(0, 0); } }
@media screen and (max-width: 767px) {
  #ProjectStory section .sec02 .text_and_photo {
    display: block;
    width: 100%; } }
#ProjectStory section .sec02 .text_and_photo .text {
  width: 38.86010362694301%; }

@media screen and (max-width: 767px) {
  #ProjectStory section .sec02 .text_and_photo .text {
    width: 100%; } }
#ProjectStory section .sec02 .text_and_photo .text p {
  line-height: 212.5%; }

@media screen and (max-width: 767px) {
  #ProjectStory section .sec02 .text_and_photo .text p {
    line-height: 185%;
    margin-bottom: 8vw; } }
#ProjectStory section .sec02 .text_and_photo .text .icon_wrap {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 15px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .sec02 .text_and_photo .text .icon_wrap {
    gap: 4vw; } }
@media screen and (max-width: 431px) {
  #ProjectStory section .sec02 .text_and_photo .text .icon_wrap {
    gap: 2vw; } }
#ProjectStory section .sec02 .text_and_photo .photo {
  width: 56.99481865284974%; }

@media screen and (max-width: 767px) {
  #ProjectStory section .sec02 .text_and_photo .photo {
    margin: 0 auto;
    width: 73.33vw; } }
/* member */
#ProjectStory section .member {
  margin: 0 auto 140px auto;
  width: 720px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member {
    margin: 0 0 18.66vw 0;
    width: 100%; } }
#ProjectStory section .member .inner {
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: 15px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member .inner {
    display: block; } }
#ProjectStory section .member .box {
  background-color: #f0f0f0;
  margin: 0 0 30px 0;
  width: 230px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member .box {
    margin: 0 0 4vw 0;
    width: 100%; } }
#ProjectStory section .member .box a {
  display: block;
  height: 100%;
  position: relative;
  text-decoration: none; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member .box a {
    display: flex; } }
#ProjectStory section .member .box a:hover {
  opacity: 0.8;
  transition-duration: .5s; }

#ProjectStory section .member .box a::after {
  border-top: 2px solid #18244e;
  border-right: 2px solid #18244e;
  content: "";
  display: block;
  height: 12px;
  position: absolute;
  bottom: 20px;
  left: calc(50% - 6px);
  transform: rotate(135deg);
  width: 12px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member .box a::after {
    border-top: 0.66vw solid #18244e;
    border-right: 0.66vw solid #18244e;
    content: "";
    display: block;
    height: 2.13vw;
    position: absolute;
    bottom: 4vw;
    left: auto;
    right: calc(((100% - 42vw)/2) - 1.065vw);
    transform: rotate(135deg);
    width: 2.13vw; } }
#ProjectStory section .member .box a:hover::after {
  bottom: 16px;
  transition-duration: .5s; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member .box a .wrap {
    position: relative;
    width: 42vw; } }
#ProjectStory section .member .box a .image {
  background-color: #fff;
  width: 230px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member .box a .image {
    height: 28vw;
    padding-bottom: 12vw;
    width: 42vw; } }
#ProjectStory section .member .box a .image img {
  width: 100%; }

#ProjectStory section .member .box a .job {
  background-color: #18244e;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 80px;
  text-align: center;
  width: 100%; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member .box a .job {
    box-sizing: border-box;
    min-height: 14.66vw;
    position: absolute;
    bottom: 0;
    left: 0; } }
#ProjectStory section .member .box a .job span {
  color: #fff;
  line-height: 1em;
  font-size: 16px;
  /*font-size: divceil($fs, 10, rem);*/ }

@media screen and (max-width: 767px) {
  #ProjectStory section .member .box a .job span {
    font-size: 3.73vw;
    line-height: 150%; } }
#ProjectStory section .member .box a .text {
  color: #0C0C0C;
  padding: 30px 20px;
  position: relative; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member .box a .text {
    box-sizing: border-box;
    padding: 5.33vw;
    width: 64.5%; } }
#ProjectStory section .member .box a .text .name {
  line-height: 1em;
  font-size: 24px;
  /*font-size: divceil($fs, 10, rem);*/
  font-weight: 500;
  line-height: 100%;
  margin-bottom: 10px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member .box a .text .name {
    font-size: 5.2vw;
    margin-bottom: 2vw; } }
#ProjectStory section .member .box a .text .belong {
  line-height: 1.6em;
  font-size: 16px;
  /*font-size: divceil($fs, 10, rem);*/
  font-weight: 500;
  margin-bottom: 20px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member .box a .text .belong {
    font-size: 3.73vw;
    margin-bottom: 4vw; } }
/* photo01 */
#ProjectStory .photo01 {
  display: grid;
  grid-template-rows: 295px 295px;
  grid-template-columns: 730px 535px;
  gap: 10px;
  margin: 0 0 50px 0; }

@media screen and (max-width: 1275px) {
  #ProjectStory .photo01 {
    grid-template-rows: 23.13725490196078vw 23.13725490196078vw;
    grid-template-columns: 57.25490196078431vw 41.96078431372549vw;
    gap: 0.7843137254901961vw; } }
@media screen and (max-width: 767px) {
  #ProjectStory .photo01 {
    grid-template-rows: auto;
    grid-template-columns: auto;
    gap: 2vw;
    margin: 0 4vw 6.66vw 4vw; } }
#ProjectStory .photo01 div:nth-of-type(1) {
  grid-row: 1 / 3;
  grid-column: 1 / 2; }

@media screen and (max-width: 767px) {
  #ProjectStory .photo01 div:nth-of-type(1) {
    grid-row: auto;
    grid-column: auto; } }
#ProjectStory .photo01 div:nth-of-type(2) {
  grid-row: 1 / 2;
  grid-column: 2 / 3; }

@media screen and (max-width: 767px) {
  #ProjectStory .photo01 div:nth-of-type(2) {
    grid-row: auto;
    grid-column: auto; } }
#ProjectStory .photo01 div:nth-of-type(3) {
  grid-row: 2 / 3;
  grid-column: 2 / 3; }

@media screen and (max-width: 767px) {
  #ProjectStory .photo01 div:nth-of-type(3) {
    grid-row: auto;
    grid-column: auto; } }
#ProjectStory .photo01 img {
  width: 100%; }

#ProjectStory .caption01 {
  color: #898989;
  display: flex;
  margin: 0 0 90px 0; }

@media screen and (max-width: 767px) {
  #ProjectStory .caption01 {
    margin: 0 0 13.33vw 0; } }
#ProjectStory section .caption01 p:nth-of-type(1) {
  display: grid;
  grid-template-rows: 32px 32px;
  grid-template-columns: 78px 58px;
  gap: 4px;
  margin: 0; }

@media screen and (max-width: 767px) {
  #ProjectStory section .caption01 p:nth-of-type(1) {
    display: grid;
    grid-template-rows: auto;
    grid-template-columns: auto;
    gap: 5px;
    margin: 0; } }
#ProjectStory section .caption01 p:nth-of-type(1) span {
  display: flex;
  justify-content: center;
  align-items: center; }

#ProjectStory section .caption01 p:nth-of-type(1) span:nth-of-type(1) {
  background-color: #dadada;
  grid-row: 1 / 3;
  grid-column: 1 / 2; }

#ProjectStory section .caption01 p:nth-of-type(1) span:nth-of-type(2) {
  background-color: #dadada;
  grid-row: 1 / 2;
  grid-column: 2 / 3; }

#ProjectStory section .caption01 p:nth-of-type(1) span:nth-of-type(3) {
  background-color: #dadada;
  grid-row: 2 / 3;
  grid-column: 2 / 3; }

@media screen and (max-width: 767px) {
  #ProjectStory section .caption01 p:nth-of-type(1) span:nth-of-type(1) {
    grid-row: auto;
    grid-column: auto;
    height: 12.53vw;
    width: 15.33vw; }

  #ProjectStory section .caption01 p:nth-of-type(1) span:nth-of-type(2) {
    grid-row: auto;
    grid-column: auto;
    height: 8.4vw;
    width: 15.33vw; }

  #ProjectStory section .caption01 p:nth-of-type(1) span:nth-of-type(3) {
    grid-row: auto;
    grid-column: auto;
    height: 8.4vw;
    width: 15.33vw; } }
#ProjectStory section .caption01 p:nth-of-type(2) {
  line-height: 1.801em;
  font-size: 13px;
  /*font-size: divceil($fs, 10, rem);*/
  line-height: 180%;
  margin: 0 0 0 15px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .caption01 p:nth-of-type(2) {
    font-size: 3.2vw;
    line-height: 175%;
    margin: 0 0 0 3vw; } }
/* photo02 */
#ProjectStory .photo02 {
  display: grid;
  grid-template-rows: 295px 295px;
  grid-template-columns: 535px 730px;
  gap: 10px;
  margin: 0 0 50px 0; }

@media screen and (max-width: 1275px) {
  #ProjectStory .photo02 {
    grid-template-rows: 23.13725490196078vw 23.13725490196078vw;
    grid-template-columns: 41.96078431372549vw 57.25490196078431vw;
    gap: 0.7843137254901961vw; } }
@media screen and (max-width: 767px) {
  #ProjectStory .photo02 {
    grid-template-rows: auto;
    grid-template-columns: auto;
    gap: 2vw;
    margin: 0 4vw 6.66vw 4vw; } }
#ProjectStory .photo02 div:nth-of-type(1) {
  grid-row: 1 / 2;
  grid-column: 1 / 2; }

@media screen and (max-width: 767px) {
  #ProjectStory .photo02 div:nth-of-type(1) {
    grid-row: auto;
    grid-column: auto; } }
#ProjectStory .photo02 div:nth-of-type(2) {
  grid-row: 2 / 3;
  grid-column: 1 / 2; }

@media screen and (max-width: 767px) {
  #ProjectStory .photo02 div:nth-of-type(2) {
    grid-row: auto;
    grid-column: auto; } }
#ProjectStory .photo02 div:nth-of-type(3) {
  grid-row: 1 / 3;
  grid-column: 2 / 3; }

@media screen and (max-width: 767px) {
  #ProjectStory .photo02 div:nth-of-type(3) {
    grid-row: auto;
    grid-column: auto; } }
#ProjectStory .photo02 img {
  width: 100%; }

#ProjectStory .caption02 {
  color: #898989;
  display: flex;
  margin: 0 0 90px 0; }

@media screen and (max-width: 767px) {
  #ProjectStory .caption02 {
    margin: 0 0 13.33vw 0; } }
#ProjectStory section .caption02 p:nth-of-type(1) {
  display: grid;
  grid-template-rows: 32px 32px;
  grid-template-columns: 58px 78px;
  gap: 4px;
  margin: 0; }

@media screen and (max-width: 767px) {
  #ProjectStory section .caption02 p:nth-of-type(1) {
    display: grid;
    grid-template-rows: auto;
    grid-template-columns: auto;
    gap: 5px;
    margin: 0; } }
#ProjectStory section .caption02 p:nth-of-type(1) span {
  display: flex;
  justify-content: center;
  align-items: center; }

#ProjectStory section .caption02 p:nth-of-type(1) span:nth-of-type(1) {
  background-color: #dadada;
  grid-row: 1 / 2;
  grid-column: 1 / 2; }

#ProjectStory section .caption02 p:nth-of-type(1) span:nth-of-type(2) {
  background-color: #dadada;
  grid-row: 2 / 3;
  grid-column: 1 / 2; }

#ProjectStory section .caption02 p:nth-of-type(1) span:nth-of-type(3) {
  background-color: #dadada;
  grid-row: 1 / 3;
  grid-column: 2 / 3; }

@media screen and (max-width: 767px) {
  #ProjectStory section .caption02 p:nth-of-type(1) span:nth-of-type(1) {
    grid-row: auto;
    grid-column: auto;
    height: 8.4vw;
    width: 15.33vw; }

  #ProjectStory section .caption02 p:nth-of-type(1) span:nth-of-type(2) {
    grid-row: auto;
    grid-column: auto;
    height: 8.4vw;
    width: 15.33vw; }

  #ProjectStory section .caption02 p:nth-of-type(1) span:nth-of-type(3) {
    grid-row: auto;
    grid-column: auto;
    height: 12.53vw;
    width: 15.33vw; } }
#ProjectStory section .caption02 p:nth-of-type(2) {
  line-height: 1.801em;
  font-size: 13px;
  /*font-size: divceil($fs, 10, rem);*/
  line-height: 180%;
  margin: 0 0 0 15px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .caption02 p:nth-of-type(2) {
    font-size: 3.2vw;
    line-height: 175%;
    margin: 0 0 0 3vw; } }
/* member_detail */
#ProjectStory section .member_detail {
  margin-bottom: 90px;
  position: relative; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member_detail {
    margin-bottom: 12vw; }

  #ProjectStory section .member_detail h2 {
    margin-bottom: 5.33vw; }

  #ProjectStory section .member_detail .icon {
    margin-bottom: 3vw;
    padding: 2vw 4vw; } }
#ProjectStory section .member_detail .name {
  line-height: 1.4em;
  font-size: 24px;
  /*font-size: divceil($fs, 10, rem);*/
  font-weight: 500;
  line-height: 140%;
  margin: 0 0 0 30px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member_detail .name {
    display: block;
    font-size: 4.8vw;
    line-height: 166%;
    margin: 0; } }
#ProjectStory section .member_detail .name .en {
  font-family: "Lexend", sans-serif;
  font-optical-sizing: auto;
  line-height: 22.5em;
  font-size: 16px;
  /*font-size: divceil($fs, 10, rem);*/
  font-weight: 400;
  font-style: normal;
  line-height: 125%; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member_detail .name .en {
    font-size: 3.73vw;
    line-height: 100%; } }
/* member - text_and_photo */
#ProjectStory section .member_detail .text_and_photo {
  margin: 95px 0 0 0;
  padding: 0 0 50px 0;
  position: relative;
  left: 0;
  top: 0;
  z-index: 3; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member_detail .text_and_photo {
    display: block;
    margin: 13.33vw 0 0 0;
    padding: 0 0 5vw 0;
    z-index: 1; } }
#ProjectStory section .member_detail .text_and_photo .text {
  width: 450px; }

@media screen and (max-width: 995px) {
  #ProjectStory section .member_detail .text_and_photo .text {
    width: 46.63212435233161vw; } }
@media screen and (max-width: 767px) {
  #ProjectStory section .member_detail .text_and_photo .text {
    width: 100%; } }
#ProjectStory section .member_detail .text_and_photo h3 {
  line-height: 200%; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member_detail .text_and_photo h3 {
    line-height: 188%;
    margin-bottom: 6.66vw; } }
#ProjectStory section .member_detail .text_and_photo p {
  line-height: 237.5%; }

@media screen and (max-width: 767px) {
  #ProjectStory section .member_detail .text_and_photo p {
    line-height: 207.14%; } }
#ProjectStory section .member_detail .text_and_photo .photo {
  width: 440px; }

@media screen and (max-width: 995px) {
  #ProjectStory section .member_detail .text_and_photo .photo {
    width: 45.59585492227979vw; } }
@media screen and (max-width: 767px) {
  #ProjectStory section .member_detail .text_and_photo .photo {
    width: 100%; }

  #ProjectStory section .member_detail .text_and_photo .photo figure {
    margin: 0 auto 10.66vw;
    width: 73.33333333333333vw; } }
/* member - bg_gray_right */
#ProjectStory section .member_detail .bg_gray_right {
  position: relative;
  z-index: 2; }

#ProjectStory section .member_detail .bg_gray_right::before {
  background-color: #f0f0f0;
  content: "";
  display: block;
  height: calc(100% + 100px);
  position: absolute;
  right: calc((var(--100vw, 100vw) - 965px)/2 * -1);
  top: -100px;
  width: calc((var(--100vw, 100vw) - 965px)/2 + 798px);
  z-index: -1; }

@media screen and (max-width: 995px) {
  #ProjectStory section .member_detail .bg_gray_right::before {
    right: -15px;
    top: -100px;
    width: calc(82.69430051813472vw + 15px);
    z-index: -1; } }
@media screen and (max-width: 767px) {
  #ProjectStory section .member_detail .bg_gray_right::before {
    height: calc(100% + 13.33vw);
    left: -4vw;
    right: -4vw;
    top: -13.33vw;
    width: calc(100% + 8vw); } }
/* member - bg_gray_left */
#ProjectStory section .member_detail .bg_gray_left {
  position: relative;
  z-index: 2; }

#ProjectStory section .member_detail .bg_gray_left::before {
  background-color: #f0f0f0;
  content: "";
  display: block;
  height: calc(100% + 100px);
  position: absolute;
  left: calc((var(--100vw, 100vw) - 965px)/2 * -1);
  top: -100px;
  width: calc((var(--100vw, 100vw) - 965px)/2 + 798px);
  z-index: -1; }

@media screen and (max-width: 995px) {
  #ProjectStory section .member_detail .bg_gray_left::before {
    left: -15px;
    top: -100px;
    width: calc(82.69430051813472vw + 15px);
    z-index: -1; } }
@media screen and (max-width: 767px) {
  #ProjectStory section .member_detail .bg_gray_left::before {
    height: calc(100% + 13.33vw);
    left: -4vw;
    right: -4vw;
    top: -13.33vw;
    width: calc(100% + 8vw); } }
/* through_the_project */
#ProjectStory section .through_the_project {
  margin-top: 140px;
  padding-top: 150px;
  padding-bottom: 130px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .through_the_project {
    margin-top: 18.66vw;
    padding-top: 20vw;
    padding-bottom: 17.33vw; } }
#ProjectStory section .through_the_project h2 {
  font-weight: 500;
  line-height: 100%;
  margin-bottom: 50px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .through_the_project h2 {
    margin-bottom: 7.33vw; } }
#ProjectStory section .through_the_project .box {
  background-color: #fff;
  box-sizing: border-box;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin: 0 0 20px 0;
  padding: 50px 20px 50px 0;
  width: 100%; }

@media screen and (max-width: 767px) {
  #ProjectStory section .through_the_project .box {
    display: block;
    margin: 0 0 4vw 0;
    padding: 6.66vw 4vw 6.66vw 4vw;
    width: 100%; } }
#ProjectStory section .through_the_project .box .person {
  text-align: center;
  width: 232px; }

@media screen and (max-width: 995px) {
  #ProjectStory section .through_the_project .box .person {
    width: 24.04145077720207vw; } }
@media screen and (max-width: 767px) {
  #ProjectStory section .through_the_project .box .person {
    margin: 0 0 9.33vw 0;
    width: 100%; } }
#ProjectStory section .through_the_project .box .person .photo {
  margin: 0 auto 30px;
  width: 120px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .through_the_project .box .person .photo {
    margin: 0 auto 4vw;
    width: 32vw; } }
#ProjectStory section .through_the_project .box .person .photo img {
  width: 100%; }

#ProjectStory section .through_the_project .box .person .name {
  line-height: 1.4em;
  font-size: 24px;
  /*font-size: divceil($fs, 10, rem);*/
  font-weight: 500;
  line-height: 141.6%;
  margin: 0 0 10px 0; }

@media screen and (max-width: 767px) {
  #ProjectStory section .through_the_project .box .person .name {
    font-size: 4.8vw;
    line-height: 166.6%;
    margin: 0 0 2vw 0; } }
#ProjectStory section .through_the_project .box .person .en {
  font-family: "Lexend", sans-serif;
  font-optical-sizing: auto;
  line-height: 1.25em;
  font-size: 16px;
  /*font-size: divceil($fs, 10, rem);*/
  font-weight: 300;
  font-style: normal;
  line-height: 125%;
  margin: 0; }

@media screen and (max-width: 767px) {
  #ProjectStory section .through_the_project .box .person .en {
    font-size: 3.73vw; } }
#ProjectStory section .through_the_project .box .text {
  box-sizing: border-box;
  padding: 0 25px;
  width: 723px; }

@media screen and (max-width: 995px) {
  #ProjectStory section .through_the_project .box .text {
    width: 74.92227979274611vw; } }
@media screen and (max-width: 767px) {
  #ProjectStory section .through_the_project .box .text {
    padding: 0;
    width: 100%; } }
#ProjectStory section .through_the_project .box .text p {
  line-height: 237.5%;
  margin: 0; }

@media screen and (max-width: 767px) {
  #ProjectStory section .through_the_project .box .text p {
    line-height: 207.14%; } }
/* data */
#ProjectStory section .data {
  margin-top: 140px;
  margin-bottom: 65px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .data {
    margin-top: 20vw;
    margin-bottom: 8.66vw; } }
#ProjectStory section .data .table_and_photo {
  display: flex;
  justify-content: space-between; }

@media screen and (max-width: 767px) {
  #ProjectStory section .data .table_and_photo {
    display: block; } }
#ProjectStory section .data .table_and_photo .table {
  width: 400px; }

@media screen and (max-width: 995px) {
  #ProjectStory section .data .table_and_photo .table {
    width: 41.45077720207254vw; } }
@media screen and (max-width: 767px) {
  #ProjectStory section .data .table_and_photo .table {
    margin-bottom: 13.33vw;
    width: 100%; } }
#ProjectStory section .data .table_and_photo .table tr {
  border-top: 1px solid rgba(24, 36, 78, 0.3); }

#ProjectStory section .data .table_and_photo .table tr:last-child {
  border-bottom: 1px solid rgba(24, 36, 78, 0.3); }

#ProjectStory section .data .table_and_photo .table tr th,
#ProjectStory section .data .table_and_photo .table tr td {
  border: none;
  box-sizing: border-box;
  padding: 20px 25px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .data .table_and_photo .table tr th,
  #ProjectStory section .data .table_and_photo .table tr td {
    font-size: 3.73vw;
    padding: 2.66vw 3.33vw; } }
#ProjectStory section .data .table_and_photo .table tr th {
  background-color: rgba(24, 36, 78, 0.1);
  width: 175px; }

@media screen and (max-width: 767px) {
  #ProjectStory section .data .table_and_photo .table tr th {
    width: 30.66vw; } }
#ProjectStory section .data .table_and_photo figure {
  margin: 0;
  width: 500px; }

@media screen and (max-width: 995px) {
  #ProjectStory section .data .table_and_photo figure {
    width: 51.81347150259067vw; } }
@media screen and (max-width: 767px) {
  #ProjectStory section .data .table_and_photo figure {
    margin: 0 auto;
    width: 73.33vw; } }
#ProjectStory section .data .table_and_photo figure img {
  width: 100%; }

/* 注釈用追加
Update: 2024.09.17
 */
.AdditionalNotesStyle1.note-komenum dt,
.AdditionalNotesStyle2.note-komenum dt {
  width: 2em; }

.AdditionalNotesStyle1.note-komenum dd,
.AdditionalNotesStyle2.note-komenum dd {
  margin: -1.55em 0 5px 2.1em; }
