/* ======================================================================
 setting
====================================================================== */
@font-face {
  font-family: 'Josefin Sans';
  src: url(../fonts/JosefinSans-Light.ttf);
  font-weight: 100;
}
@font-face {
  font-family: 'Josefin Sans';
  src: url(../fonts/JosefinSans-Regular.ttf);
  font-weight: 300;
}
@font-face {
  font-family: 'Josefin Sans';
  src: url(../fonts/JosefinSans-SemiBold.ttf);
  font-weight: 500;
}
@font-face {
  font-family: 'Josefin Sans';
  src: url(../fonts/JosefinSans-Bold.ttf);
  font-weight: 700;
}
/* ======================================================================
 p_member
====================================================================== */
@media screen and (max-width: 768px) {
  .p_member .l_content {
    padding: 0;
  }
}
.p_member .l_content .l_main > .inner {
  width: 1200px;
  margin: 0 auto;
  padding: 160px 0 200px;
}
@media screen and (max-width: 768px) {
  .p_member .l_content .l_main > .inner {
    width: 100%;
    padding: 0 5.33vw 40px;
  }
}
.p_member .l_content .l_main .content_wrap {
  padding: 0 0 0 130px;
}
@media screen and (max-width: 768px) {
  .p_member .l_content .l_main .content_wrap {
    padding: 0;
  }
}
@media screen and (max-width: 768px) {
  .p_member .l_content .l_main > .inner .ttlarea {
    display: none;
  }
}
.p_member .l_content .l_main > .inner .ttlarea > .inner {
  width: 840px;
  padding: 60px 0 100px;
  background: linear-gradient(90deg, #ffffff 0%, #ffffff 25%, #f8f8f8 25%, #f8f8f8 100%);
  margin: 0 70px 0 290px;
}
.p_member .l_content .l_main > .inner .ttlarea > .inner .u_txt_9 {
  font-weight: bold;
}
.p_member .l_content .l_main > .inner .ttlarea > .inner .u_txt_4 {
  letter-spacing: 0;
}
.p_member .l_content .l_main > .inner .ttlarea > .inner > .u_txt_5 {
  margin: 20px 0 0;
}
.p_member .l_content .l_main > .inner .ttlarea > .inner .btnarea {
  margin: 50px 0 0;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: start;
  -moz-justify-content: start;
  -ms-justify-content: start;
  justify-content: start;
  -ms-flex-pack: start;
}
.p_member .l_content .l_main > .inner .ttlarea > .inner .btnarea .c_btn_1:nth-of-type(2) {
  width: 320px;
  margin: 0 0 0 20px;
}


/* sec + ttl
--------------------------------------- */
.p_member .l_content .l_main ._bg .content_wrap .m_subtitle {
  white-space: nowrap;
}
.p_member .sec {
  margin-top: 60px;
  margin-bottom: 100px;
}
.p_member .profile .sec {
  margin-top: 60px;
  margin-bottom: 60px;
}
.p_member .profile .profile_block .sec {
  margin-top: 40px;
}
.p_member .sec > .inner .c_block_1 {
  margin: 0 0 30px;
}
.p_member .sec_ad > .inner .c_block_1 {
  margin: 0 0 5px;
}
.p_member .sec > .inner .c_block_1 > .inner {
  padding: 0 0 0 40px;
  font-size: 3em;
  line-height: 1.7em;
}
.p_member .sec .sec_content .img_box {
  text-align: center;
}
.p_member .sec .sec_content .img_box img {
  max-width: 100%;
  height: auto;
}
@media screen and (max-width: 768px) {
  .p_member .sec {
    margin-bottom: 30px;
  }
  .p_member .profile .sec {
    margin-top: 30px;
    margin-bottom: 30px;
  }
  .p_member .l_content .l_main ._bg .content_wrap .m_subtitle {
    white-space: wrap;
  }
  .p_member .l_content .l_main ._bg .content_wrap .sp_txt_size {
    margin-bottom: 10px;
  }
  .p_member .sec .sec_content .img_box {
    width: 85%;
    margin: auto;
  }
  .p_member .sec > .inner .c_block_1 {
    margin: 0 0 20px;
  }
  .p_member .sec > .inner .c_block_1 > .inner {
    padding: 0 0 0 20px;
    font-size: 2.4em;
    line-height: 1.03333;
  }
  .p_member .u_txt_23 {
    font-size: 2.0em;
    line-height: 1.2;
  }
}


/* member_list
--------------------------------------- */
.p_member .member_list {
  margin-top: 30px;
}
.p_member .box_grid_col_2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 75px;
  padding-bottom: 44px;
}
.p_member .box_grid_col_4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 30px 20px;
}
.p_member .grid_item {
  position: relative;
  top: 0;
  left: 0;
  z-index: 1;
}
.p_member .grid_item .person_title {
  font-size: 1.4em;
  line-height: 1.42;
  font-weight: bold;
}
.p_member .grid_item .person_title span {
  display: inline-block;
}
.p_member .grid_item .name {
  font-size: 2.0em;
  font-weight: bold;
  margin-top: 10px;
}
.p_member .grid_item .thumb img {
  width: 100%;
}
.p_member .grid_item .box {
  margin-top: 20px;
}
.p_member .grid_item .box.executive {
  position: absolute;
  bottom: -44px;
  right: -35px;
  z-index: 2;
  background: #fff;
  border: 1px solid #000;
  padding: 20px;
}
.p_member .l_content .l_main > .inner .ttlarea.ttlarea_right > .inner {
  margin: 0 70px 0 0;
}
.p_member .sec_content:not(:first-of-type) {
  margin-top: 100px;
}
.p_member .sec_content:nth-of-type(2) {
  padding-right: 35px;
  margin-top: 0;
}
@media screen and (max-width: 768px) {
  .p_member .member_list {
    margin-top: 20px;
  }
  .p_member .box_grid_col_2 {
    grid-template-columns: repeat(1, 1fr);
    gap: 48px;
    padding-bottom: 18px;
  }
  .p_member .box_grid_col_4 {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
  .p_member .grid_item .person_title {
    font-size: 1.2em;
  }
  .p_member .grid_item .name {
    font-size: 1.6em;
  }
  .p_member .grid_item .box {
    margin-top: 10px;
  }
  .p_member .grid_item .box.executive {
    bottom: -18px;
    right: -2.66vw;
    padding: 10px;
  }
  .p_member .sec_content:not(:first-of-type) {
    margin-top: 50px;
  }
  .p_member .sec_content:nth-of-type(2) {
    padding-right: 2.66vw;
    margin-top: 0;
  }
}


/* profile */
.profile {
  line-height: 1.6875;
  background: #fff;
  max-width: 963px;
  padding: 60px;
  border: 1px solid #000;
  margin: 100px auto;
}
.profile_name {
  font-size: 3.0rem;
  line-height: 1.1333;
  font-weight: bold;
  padding-left: 20px;
  border-left: 4px solid #000;
  margin-bottom: 30px;
}
.profile_name span {
  font-size: 1.4rem;
  margin-left: 20px;
}
.profile-footer .c_btn_1._pt2 {
  margin: auto;
  font-size: inherit;
  font-family: inherit;
}
.profile_img {
  display: block;
  height: auto;
}
/* pc only */
@media screen and (min-width: 769px) {
  .profile_block {
    position: relative;
    padding: 0 343px 0 0;
  }
  .sec,
  .profile_name {
    margin-right: 40px;
  }
  .profile_img {
    position: absolute;
    top: 0;
    right: 0;
    width: 343px;
  }
}
/* sp only */
@media screen and (max-width: 768px) {
  .profile {
    max-width: 100%;
    padding: 20px 0;
    margin: 83px auto;
  }
  .profile .inner {
    margin-left: 20px;
  }
  .profile_name {
    font-size: 2.4rem;
    line-height: 1.0833;
  }
  .profile_name span {
    font-size: 1.2rem;
    margin-left: 10px;
  }
  .profile_img {
    width: 69%;
    margin: auto;
  }
  .profile .u_txt_23 {
    font-size: 1.8em;
  }
  .profile ._scroll {
    overflow: scroll;
    scrollbar-width: none;
  }
}


/* profile table */
.p_member .profile ._table {
  margin: 30px 0 0;
  font-size: 1.6em;
  width: 100%;
  text-align: center;
}
.p_member .profile ._table ._tr {
  display: table;
  width: 100%;
}
.p_member .profile ._table ._tr ._th {
  background: #585858;
  display: table-cell;
  padding: 15px 0;
  color: #fff;
  font-weight: bold;
}
.p_member .profile ._table ._tr ._td {
  position: relative;
  display: table-cell;
  padding: 15px 0;
  vertical-align: middle;
  line-height: 1.7;
}
.p_member .profile ._table ._tr ._td:after {
  content: '';
  background: #040505;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
}
.p_member .profile ._table.dev_2 ._th {
  width: 50%;
}
.p_member .profile ._table.dev_2 ._th:nth-child(2) {
  border-left: 4px solid #fff;
}
.p_member .profile ._table.dev_2 ._td {
  width: 50%;
}
.p_member .profile ._table.dev_2.l_th {
  border-top: 1px solid #040505;
  margin: 30px 0 0;
  text-align: left;
}
.p_member .profile ._table.dev_2.l_th ._th {
  background: #f8f8f8;
  position: relative;
  padding: 15px 0 15px 20px;
  color: #333;
  width: 26%;
}
.p_member .profile ._table.dev_2.l_th ._th:after {
  content: '';
  background: #040505;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
}
.p_member .profile ._table.dev_2.l_th ._td {
  padding: 10px 0 10px 25px;
  width: 74%;
}
@media screen and (max-width: 768px) {
  .p_member .profile ._table {
    width: 620px;
    margin: 15px 20px 0;
    font-size: 1.2em;
  }
  .p_member .profile ._table ._tr ._th {
    padding:20px 0;
  }
  .p_member .profile ._table ._tr ._td {
    padding: 20px 0;
  }
  .p_member .profile ._table.dev_2 ._th:nth-child(2) {
    border-left: 2px solid #fff;
  }
  .p_member .profile ._table.dev_2.l_th {
    margin: 15px 20px 15px;
    font-size: 1.4em;
    line-height: 1.715;
  }
  .p_member .profile ._table.dev_2.l_th ._th {
    padding: 20px;
    width: 30%;
  }
  .p_member .profile ._table.dev_2.l_th ._td {
    padding: 7px 0 7px 14px;
  }
}


/* ======================================
  JS用のCSS
====================================== */

/* Magnific Popup
-------------------------------------- */
.p_member .mfp-bg {
  background: #fff;
  opacity: 0.9;
}
.p_member .profile {
  position: relative;
}
.p_member button.mfp-close, button.mfp-arrow {
  background: #333;
  opacity: 1;
}
.p_member .mfp-close {
  position: absolute;
  top: 0;
  width: 43px;
  height: 43px;
  opacity: 1;
  background: #333;
}
.p_member .mfp-close::before,
.p_member .mfp-close::after {
  content: "";
  display: block;
  width: 27px;
  height: 2px;
  background-color: #fff;
  position: absolute;
  top: 20px;
  left: 9px;
}
.p_member .mfp-close::before {
  transform: rotate(45deg);
}
.p_member .mfp-close::after {
  transform: rotate(-45deg);
}
.p-member .mfp-close-btn-in .mfp-close {
    color: #fff;
}
@media screen and (max-width: 900px) {
  .p_member .mfp-container {
    padding-left: 5.33vw;
    padding-right: 5.33vw;
  }
}
@media screen and (max-width: 768px) {
  .p_member .mfp-close {
    position: absolute;
    top: -43px;
    right: -1px;
  }
}

/* scroll-hint
-------------------------------------- */
.profile .scroll-hint-icon {
  /* position: absolute; */
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 153px;
  border-radius: 10px;
  background: rgba(0, 0, 0, .75);
  padding: 20px 34px;
}
.profile .scroll-hint-text {
  font-size: 1.4em;
  line-height: 1.7;
  font-weight: bold;
  margin-top: 11px;
}
.profile .scroll-hint-icon:after {
  background-image: none;
}
.profile .scroll-hint-icon:before {
  width: 73px;
  height: 73px;
  background-image: url(../img/common/icon_scroll_hint_white_hand.svg);
}
.profile .scroll-hint-shadow-wrap::before,
.profile .scroll-hint-shadow-wrap::after {
  display: none;
}