@import url("https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@200;300;400&family=Barlow:wght@400;600;700&family=Noto+Sans+JP:wght@300;400;500&display=swap");
.hero {
  background: url("../images/about-us/hero_bg_sp.jpg") no-repeat center top/100%;
  min-height: 48vw;
  position: relative;
  z-index: 10;
}
.hero .front-image {
  width: 92.3611111111%;
  height: 42.7083333333vw;
  position: absolute;
  top: 27.4305555556%;
  left: 3.8194444444%;
  margin: 0 auto;
  border-radius: 1.3333333333vw;
  overflow: hidden;
}
.hero .front-image img {
  width: 154%;
  height: auto;
  max-width: none;
  margin-top: -2.6666666667vw;
  margin-left: -25.3333333333vw;
}
.hero .title {
  display: block;
  width: 23.4666666667%;
  margin-top: -0.2666666667%;
  position: absolute;
  top: 0;
  left: 0;
}
.hero .title img {
  width: 100%;
}
.hero .txt-box {
  width: 73.3333333333%;
  height: 106.6666666667vw;
  position: absolute;
  bottom: 0;
  right: 0;
  margin-bottom: -68.8%;
  padding: 13.3333333333% 5.3333333333% 9.3333333333% 6.6666666667%;
  background-color: #202020;
  border-top-left-radius: 1.3333333333vw;
  border-bottom-left-radius: 1.3333333333vw;
  color: #fff;
}
.hero .txt-box h2 {
  font-size: 12.2666666667vw;
  line-height: 95%;
  letter-spacing: -0.2vw;
  position: relative;
}
.hero .txt-box h2::before, .hero .txt-box h2::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}
.hero .txt-box h2::before {
  width: 100%;
  height: 0.2666666667vw;
  background-color: #fff;
  margin-top: -9.5652173913%;
}
.hero .txt-box h2::after {
  width: 25.2173913043%;
  height: 0.5333333333vw;
  background-color: #e60012;
  margin-top: 47.8260869565%;
}
.hero .txt-box p {
  font-size: 6.4vw;
  margin-top: 18.6956521739%;
  line-height: 1.55;
}
.hero .txt-box .link-btn {
  border: none;
  width: 100%;
  margin-top: 26.0869565217%;
}
.hero .txt-box .link-btn a .arrow {
  margin-left: 78.2608695652%;
}
.hero .txt-box .link-btn a .arrow::after {
  border-left: none;
  border-right: solid 0.2666666667vw #fff;
  margin-top: -0.5333333333vw;
  margin-left: 5.3333333333vw;
}

@property --p {
  syntax: "<number>";
  inherits: true;
  initial-value: 0;
}
@-webkit-keyframes p {
  from {
    --p: 0 ;
  }
}
@keyframes p {
  from {
    --p: 0 ;
  }
}
.p_title {
  min-height: 48vw;
  padding-top: 17.8666666667%;
  position: relative;
  overflow: hidden;
}
.p_title .bg-number {
  position: absolute;
  mix-blend-mode: soft-light;
  opacity: 0.65;
  letter-spacing: -2.2vw;
  top: 0;
}
.p_title .bg-number.no01 {
  color: #fff;
  mix-blend-mode: overlay;
  font-size: 42.6666666667vw;
  right: 0;
  margin-top: 62.9333333333%;
  margin-right: 3.4666666667%;
}
.p_title .bg-number.no01 .per {
  font-size: 15.4666666667vw;
  margin-left: 2.6666666667%;
}
.p_title .bg-number.no02 {
  font-size: 47.2vw;
  right: 0;
  margin-top: 306.1333333333%;
  margin-right: 4%;
  line-height: 1.1186440678;
}
.p_title .bg-number.no03 {
  font-size: 24vw;
  left: 0;
  margin-top: 761.6%;
  line-height: 1.1222222222;
}
.p_title .bg-number.no04 {
  font-size: 35.2vw;
  right: 0;
  margin-top: 846.9333333333%;
  margin-right: 4.2666666667%;
  line-height: 1.1136363636;
}
.p_title .txt-wrap {
  padding: 0 7.4666666667%;
}
.p_title .txt-wrap .title {
  font-size: 12.8vw;
  color: #202020;
  margin-top: -1.4492753623%;
  letter-spacing: -0.4vw;
  line-height: 1;
  position: relative;
}
.p_title .txt-wrap .title span {
  display: inline-block;
  padding: 0.5797101449% 1.4492753623% 1.4492753623% 0;
  -webkit-clip-path: inset(0 100% 0 0);
          clip-path: inset(0 100% 0 0);
  transition: 0.8s cubic-bezier(0.16, 1, 0.3, 1);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.p_title .txt-wrap .title::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  padding-top: 0.5797101449%;
  margin-top: 21.7391304348%;
  background-color: #e60012;
  transition: 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.p_title .txt-wrap .title.animated span {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.p_title .txt-wrap .title.animated::after {
  width: 18.8405797101%;
}
.p_title .txt-wrap p {
  font-size: 4vw;
  margin-top: 16.8115942029%;
  letter-spacing: 0.2vw;
}
.p_title .txt-wrap p:not(:first-of-type) {
  margin-top: 4.347826087%;
  line-height: 1.75;
}

.philosophy {
  position: relative;
  /*padding-top: calcPerSp(54);*/
  padding-bottom: 21.3333333333%;
  overflow: hidden;
  height: 384.8vw;
}
.philosophy .box {
  position: relative;
}
.philosophy .box .bg-txt-lft,
.philosophy .box .bg-txt-rgt {
  font-size: 24vw;
  line-height: 0.62;
  color: #f6f6f6;
  position: absolute;
  top: 9.8666666667vw;
  left: -1.6vw;
}
.philosophy .box .pic-wrap {
  position: absolute;
  top: 281.3333333333vw;
  left: 0;
  width: 100%;
  margin-top: 24%;
}
.philosophy .box .pic-wrap .pic {
  width: 80.5333333333%;
  height: 48vw;
  border-top-right-radius: 1.3333333333vw;
  border-bottom-right-radius: 1.3333333333vw;
  overflow: hidden;
  position: relative;
  background-color: #fff;
}
.philosophy .box .pic-wrap .pic .bdr-rgt {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-top: solid 3.2vw rgba(255, 255, 255, 0.5);
  border-right: solid 3.2vw rgba(255, 255, 255, 0.5);
  border-bottom: solid 3.2vw rgba(255, 255, 255, 0.5);
  border-top-right-radius: 26.6666666667vw;
  border-bottom-right-radius: 26.6666666667vw;
  z-index: 10;
}
.philosophy .box .pic-wrap .pic .bdr-lft {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-top: solid 3.2vw rgba(255, 255, 255, 0.5);
  border-left: solid 3.2vw rgba(255, 255, 255, 0.5);
  border-bottom: solid 3.2vw rgba(255, 255, 255, 0.5);
  border-top-left-radius: 26.6666666667vw;
  border-bottom-left-radius: 26.6666666667vw;
  z-index: 10;
}
.philosophy .box .pic-wrap .pic img {
  max-width: none;
  width: 130%;
  margin-top: -16.0120845921%;
  margin-left: -15.1057401813%;
}
.philosophy .box .pic-wrap .pic + .rec {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background-color: #e60012;
  width: 50.6666666667%;
  position: absolute;
  top: 0;
  left: 50.6666666667%;
  height: 0;
  margin-top: 18.6666666667%;
  padding-top: 34.1333333333%;
  z-index: -1;
  border-top-left-radius: 1.3333333333vw;
  border-bottom-left-radius: 1.3333333333vw;
  border-top-right-radius: 1.3333333333vw;
  border-bottom-right-radius: 1.3333333333vw;
}
.philosophy .box .txt-wrap h2 {
  font-size: 10.6666666667vw;
  color: #e60012;
  margin-left: 8%;
  padding-top: 3.2%;
  position: relative;
  letter-spacing: -0.01vw;
  line-height: 0.86;
  -webkit-clip-path: inset(100% 0 0 0);
          clip-path: inset(100% 0 0 0);
  transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.philosophy .box .txt-wrap h2 .jp-sub {
  font-size: 4.2666666667vw;
  color: #202020;
  display: inline-block;
  margin-left: 0.8%;
}
.philosophy .box .txt-wrap h2.animated {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.philosophy .box .txt-wrap h2.animated::before {
  width: 100%;
}
.philosophy .box .txt-wrap h3 {
  margin-top: 81.6%;
  margin-left: 11.7333333333%;
  position: relative;
}
.philosophy .box .txt-wrap h3 span {
  -webkit-clip-path: inset(100% 0 0 0);
          clip-path: inset(100% 0 0 0);
  transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.philosophy .box .txt-wrap h3::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  padding-top: 0.6042296073%;
  margin-top: 34.1389728097%;
  background-color: #e60012;
  transition: width 0.6s 0.5s;
}
.philosophy .box .txt-wrap h3 + p {
  margin-top: 13.3333333333%;
  margin-left: 11.7333333333%;
  margin-right: 8%;
  opacity: 0;
  transform: translateY(13.3333333333vw);
  transition: transform 1s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.7s;
}
.philosophy .box .txt-wrap h3 + p.animated {
  opacity: 1;
  transform: none;
}
.philosophy .box .txt-wrap h3.animated span {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.philosophy .box .txt-wrap h3.animated::after {
  width: 17.2205438066%;
}
.philosophy .box .txt-wrap .link-btn {
  margin-top: 11.4666666667vw;
  margin-left: 11.7333333333vw;
}
.philosophy .box .panels {
  background-color: #f6f6f6;
  position: relative;
  top: 4.2666666667vw;
  min-height: 297.8666666667vw;
}
.philosophy .box .panels ul {
  width: 91.6666666667%;
  margin: 0.5555555556% auto 0;
  position: relative;
  top: 5.9027777778vw;
  list-style: none;
}
.philosophy .box .panels ul li {
  background-color: #fff;
  min-height: 27.7777777778vw;
  border-radius: 1.3888888889%;
  width: 100%;
  transform: translateY(6.9444444444vw);
  margin-bottom: 5%;
}
.philosophy .box .panels ul li h4 {
  font-size: 22.5vw;
  line-height: 100%;
  padding: 8.3333333333% 7.5% 6.1111111111% 7.5%;
  border-bottom: solid 0.0694444444vw #ddd;
  letter-spacing: -0.2vw;
}
.philosophy .box .panels ul li h4 > span.per {
  font-size: 3.8194444444vw;
}
.philosophy .box .panels ul li .panel-title {
  font-size: 5.5555555556vw;
  line-height: 100%;
  line-height: 1.2;
  padding: 7.5% 8.3333333333% 0 8.3333333333%;
  letter-spacing: 0.05vw;
}
.philosophy .box .panels ul li .caption {
  font-size: 0.8333333333vw;
  padding: 3.8888888889% 6.6666666667% 0 6.6666666667%;
}
.philosophy .box .panels ul li .icon {
  width: 13.8888888889%;
  margin-top: 6.9444444444%;
  margin-left: 77.7777777778%;
  padding-bottom: 5.5555555556%;
}
.philosophy .box .panels ul li .icon img.mt-top {
  margin-top: 69.4444444444%;
}
.philosophy .box .panels ul li:not(:first-child) {
  margin-top: 0;
}

.profile {
  position: relative;
  padding-bottom: 21.3333333333%;
  margin-bottom: 12.8vw;
  overflow: hidden;
  height: 690vw;
  border-bottom: solid 0.2666666667vw #ddd;
}
.profile .box {
  position: relative;
  border-bottom: solid 0.2666666667vw #ddd;
  padding-bottom: 6.1333333333vw;
}
.profile .box .bg-txt-lft,
.profile .box .bg-txt-rgt {
  font-size: 24vw;
  line-height: 0.62;
  color: #f6f6f6;
  position: absolute;
  top: 9.8666666667vw;
  left: -1.6vw;
}
.profile .box .txt-wrap h2 {
  font-size: 10.1333333333vw;
  color: #e60012;
  margin-left: 8%;
  padding-top: 3.2%;
  position: relative;
  letter-spacing: -0.01vw;
  line-height: 0.86;
  -webkit-clip-path: inset(100% 0 0 0);
          clip-path: inset(100% 0 0 0);
  transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.profile .box .txt-wrap h2 .jp-sub {
  font-size: 4vw;
  color: #202020;
  display: inline-block;
  margin-left: 1.3333333333%;
}
.profile .box .txt-wrap h2.animated {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.profile .box .txt-wrap h2.animated::before {
  width: 100%;
}
.profile .box .txt-wrap h3 {
  margin-top: 81.6%;
  margin-left: 11.7333333333%;
  position: relative;
}
.profile .box .txt-wrap h3 span {
  -webkit-clip-path: inset(100% 0 0 0);
          clip-path: inset(100% 0 0 0);
  transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.profile .box .txt-wrap h3::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  padding-top: 0.6042296073%;
  margin-top: 34.1389728097%;
  background-color: #e60012;
  transition: width 0.6s 0.5s;
}
.profile .box .txt-wrap h3 + p {
  margin-top: 13.3333333333%;
  margin-left: 11.7333333333%;
  margin-right: 8%;
  opacity: 0;
  transform: translateY(13.3333333333vw);
  transition: transform 1s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.7s;
}
.profile .box .txt-wrap h3 + p.animated {
  opacity: 1;
  transform: none;
}
.profile .box .txt-wrap h3.animated span {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.profile .box .txt-wrap h3.animated::after {
  width: 17.2205438066%;
}
.profile .box .txt-wrap .link-btn {
  margin-top: 11.4666666667vw;
  margin-left: 11.7333333333vw;
}
.profile .box .panels {
  background-color: #f6f6f6;
  position: relative;
  top: 5.3333333333vw;
  min-height: 297.8666666667vw;
}
.profile .box .panels ul {
  width: 91.6666666667%;
  margin: 0.5555555556% auto 0;
  position: relative;
  top: 5.9027777778vw;
  list-style: none;
}
.profile .box .panels ul li {
  background-color: #fff;
  min-height: 27.7777777778vw;
  border-radius: 1.3888888889%;
  width: 100%;
  transform: translateY(6.9444444444vw);
  margin-bottom: 5%;
}
.profile .box .panels ul li h4 {
  font-size: 22.5vw;
  line-height: 100%;
  padding: 8.3333333333% 7.5% 6.1111111111% 7.5%;
  border-bottom: solid 0.0694444444vw #ddd;
  letter-spacing: -0.2vw;
}
.profile .box .panels ul li h4 > span.per {
  font-size: 3.8194444444vw;
}
.profile .box .panels ul li .panel-title {
  font-size: 5.5555555556vw;
  line-height: 100%;
  line-height: 1.2;
  padding: 7.5% 8.3333333333% 0 8.3333333333%;
  letter-spacing: 0.05vw;
}
.profile .box .panels ul li .caption {
  font-size: 0.8333333333vw;
  padding: 3.8888888889% 6.6666666667% 0 6.6666666667%;
}
.profile .box .panels ul li .icon {
  width: 13.8888888889%;
  margin-top: 6.9444444444%;
  margin-left: 77.7777777778%;
  padding-bottom: 5.5555555556%;
}
.profile .box .panels ul li .icon img.mt-top {
  margin-top: 69.4444444444%;
}
.profile .box .panels ul li:not(:first-child) {
  margin-top: 0;
}
.profile .container {
  width: 92%;
  margin: 0 auto;
  padding: 8% 4%;
  background-color: #f6f6f6;
  border-right: solid 0.2666666667vw #ddd;
  border-left: solid 0.2666666667vw #ddd;
}
.profile .container .inner {
  width: 100%;
  background-color: #fff;
  padding: 5.8666666667vw 2.6666666667vw;
}
.profile .container .cnt-block {
  width: 100%;
  padding: 5.6vw 4vw;
  border-bottom: solid 0.2666666667vw #ddd;
}
.profile .container .cnt-block .head {
  font-size: 3.4666666667vw;
  color: #888;
  margin-bottom: 2.1333333333vw;
}
.profile .container .cnt-block .item p {
  font-size: 3.4666666667vw;
  line-height: 1.3;
  margin-bottom: 2.1333333333vw;
}
.profile .container .noborder {
  border-bottom: none;
}
.profile .container ul {
  list-style: none;
}
.profile .container ul.dept-list > li {
  border-top: solid 0.2666666667vw #ddd;
}
.profile .container ul.dept-list > li h3.title {
  font-size: 4.2666666667vw;
  padding: 6.3768115942% 17.3913043478% 6.3768115942% 4.347826087%;
  position: relative;
  cursor: pointer;
}
.profile .container ul.dept-list > li h3.title::before, .profile .container ul.dept-list > li h3.title::after {
  position: absolute;
  content: "";
  width: 5.3333333333vw;
  height: 0.5333333333vw;
  background-color: #e60012;
}
.profile .container ul.dept-list > li h3.title::before {
  top: 48%;
  right: 6.6666666667vw;
  transform: rotate(0deg);
}
.profile .container ul.dept-list > li h3.title::after {
  top: 48%;
  right: 6.6666666667vw;
  transform: rotate(90deg);
}
.profile .container ul.dept-list > li h3.title.close::after {
  transform: rotate(0deg);
}
.profile .container ul.dept-list > li .acd-content {
  display: none;
}
.profile .container ul.dept-list > li ul.job-list {
  padding: 8.6956521739% 4.347826087%;
  margin: 0;
  border-top: solid 0.2666666667vw #ddd;
}
.profile .container ul.dept-list > li ul.job-list li a {
  display: block;
  width: 100%;
  height: 100%;
  font-size: 4vw;
  background-color: #fff;
  border-radius: 1.3333333333vw;
  padding: 6.3897763578% 13.4185303514% 5.750798722% 4.4728434505%;
  position: relative;
}
.profile .container ul.dept-list > li ul.job-list li a::after {
  position: absolute;
  content: "";
  width: 2.9333333333vw;
  height: 2.9333333333vw;
  top: 40%;
  right: 0;
  margin-right: 4.4728434505%;
  border-top: solid 0.5333333333vw #e60012;
  border-right: solid 0.5333333333vw #e60012;
  transform: rotate(45deg);
}
.profile .container ul.dept-list > li ul.job-list li:not(:first-of-type) {
  margin-top: 2.915451895%;
}

.access {
  position: relative;
  padding-bottom: 21.3333333333%;
  overflow: hidden;
  height: 434.6666666667vw;
  border-bottom: solid 0.2666666667vw #ddd;
  background-color: #f6f6f6;
}
.access .box {
  position: relative;
  padding-bottom: 10.6666666667vw;
  background-color: #fff;
  z-index: 1;
}
.access .box .bg-txt-lft,
.access .box .bg-txt-rgt {
  font-size: 24vw;
  line-height: 0.62;
  color: #f6f6f6;
  position: absolute;
  top: 13.6vw;
  left: -1.6vw;
}
.access .box .txt-wrap h2 {
  font-size: 10.1333333333vw;
  color: #e60012;
  margin-left: 8%;
  padding-top: 3.2%;
  position: relative;
  letter-spacing: -0.01vw;
  line-height: 0.86;
  -webkit-clip-path: inset(100% 0 0 0);
          clip-path: inset(100% 0 0 0);
  transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.access .box .txt-wrap h2 .jp-sub {
  font-size: 4vw;
  color: #202020;
  display: inline-block;
  margin-left: 1.3333333333%;
}
.access .box .txt-wrap h2.animated {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.access .box .txt-wrap h2.animated::before {
  width: 100%;
}
.access .box .txt-wrap h3 {
  margin-top: 81.6%;
  margin-left: 11.7333333333%;
  position: relative;
}
.access .box .txt-wrap h3 span {
  -webkit-clip-path: inset(100% 0 0 0);
          clip-path: inset(100% 0 0 0);
  transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.access .box .txt-wrap h3::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  padding-top: 0.6042296073%;
  margin-top: 34.1389728097%;
  background-color: #e60012;
  transition: width 0.6s 0.5s;
}
.access .box .txt-wrap h3 + p {
  margin-top: 13.3333333333%;
  margin-left: 11.7333333333%;
  margin-right: 8%;
  opacity: 0;
  transform: translateY(13.3333333333vw);
  transition: transform 1s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.7s;
}
.access .box .txt-wrap h3 + p.animated {
  opacity: 1;
  transform: none;
}
.access .box .txt-wrap h3.animated span {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.access .box .txt-wrap h3.animated::after {
  width: 17.2205438066%;
}
.access .box .txt-wrap .link-btn {
  margin-top: 11.4666666667vw;
  margin-left: 11.7333333333vw;
}
.access .pic-wrap {
  position: absolute;
  top: 6.6666666667vw;
  left: 0;
  width: 100%;
  margin-top: 24%;
  z-index: 2;
}
.access .pic-wrap .pic {
  width: 88%;
  height: 189.3333333333vw;
  border-top-right-radius: 1.3333333333vw;
  border-bottom-right-radius: 1.3333333333vw;
  overflow: hidden;
  position: relative;
  background-color: #fff;
}
.access .pic-wrap .pic picture iframe {
  width: 100%;
  height: 71.4666666667vw;
}
.access .pic-wrap .pic img {
  max-width: none;
  width: 105%;
  margin-left: -3.6253776435%;
}
.access .pic-wrap .pic + .rec {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background-color: #e60012;
  width: 93.3333333333%;
  position: absolute;
  top: -2.6666666667vw;
  left: 12%;
  height: 0;
  margin-top: -1.3333333333%;
  padding-top: 182.6666666667%;
  z-index: -1;
  border-top-left-radius: 1.3333333333vw;
  border-bottom-left-radius: 1.3333333333vw;
  border-top-right-radius: 1.3333333333vw;
  border-bottom-right-radius: 1.3333333333vw;
}
.access .pic-wrap .access-data {
  background-color: #fff;
  width: 100%;
  padding: 7.4666666667% 8.5333333333%;
}
.access .pic-wrap .access-data .title {
  font-size: 9.0666666667vw;
  color: #202020;
  margin-top: -0.5797101449%;
  letter-spacing: -0.2vw;
  line-height: 1;
  position: relative;
}
.access .pic-wrap .access-data .title span {
  display: inline-block;
  padding: 0.5797101449% 1.4492753623% 1.4492753623% 0;
  -webkit-clip-path: inset(0 100% 0 0);
          clip-path: inset(0 100% 0 0);
  transition: 0.8s cubic-bezier(0.16, 1, 0.3, 1);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.access .pic-wrap .access-data .title::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  padding-top: 0.5797101449%;
  margin-top: 22.0289855072%;
  background-color: #e60012;
  transition: 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.access .pic-wrap .access-data .title.animated span {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.access .pic-wrap .access-data .title.animated::after {
  width: 21.1594202899%;
}
.access .pic-wrap .access-data .address {
  margin-top: 18.6666666667%;
}
.access .pic-wrap .access-data .route {
  font-size: 3.3333333333vw;
  margin-top: 24%;
  line-height: 1.8;
}
.access .pic-wrap .access-data .link-txt {
  background-color: transparent;
  position: relative;
  bottom: 0;
  left: 0;
  margin-top: 18.1333333333%;
  margin-left: 54.6666666667%;
  overflow: visible;
}
.access .pic-wrap .access-data .link-txt a .arrow {
  margin-left: 81.3333333333%;
}
.access #osaka {
  position: relative;
  top: 182.6666666667vw;
  left: 12%;
}
.access #osaka .pic {
  height: 189.3333333333vw;
}
.access #osaka .pic + .rec {
  width: 89.3333333333%;
  position: absolute;
  left: -13.3333333333%;
  height: 0;
  margin-top: -1.3333333333%;
  padding-top: 162.6666666667%;
  z-index: -1;
}
.access #osaka .route {
  margin-top: 12%;
}

.message {
  padding-top: 0;
  overflow: hidden;
}
.message .box {
  position: relative;
  padding-bottom: 10.6666666667vw;
  background-color: #fff;
  z-index: 1;
}
.message .box .bg-txt-lft,
.message .box .bg-txt-rgt {
  font-size: 24vw;
  line-height: 0.62;
  color: #f6f6f6;
  position: absolute;
  top: 22.4vw;
  left: -1.6vw;
}
.message .box .txt-wrap h2 {
  font-size: 10.1333333333vw;
  color: #e60012;
  margin-left: 8%;
  padding-top: 16%;
  position: relative;
  letter-spacing: -0.01vw;
  line-height: 0.86;
  -webkit-clip-path: inset(100% 0 0 0);
          clip-path: inset(100% 0 0 0);
  transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.message .box .txt-wrap h2 .jp-sub {
  font-size: 4vw;
  color: #202020;
  display: inline-block;
  margin-left: 1.3333333333%;
}
.message .box .txt-wrap h2.animated {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.message .box .txt-wrap h2.animated::before {
  width: 100%;
}
.message .box .txt-wrap h3 {
  margin-top: 81.6%;
  margin-left: 11.7333333333%;
  position: relative;
}
.message .box .txt-wrap h3 span {
  -webkit-clip-path: inset(100% 0 0 0);
          clip-path: inset(100% 0 0 0);
  transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.message .box .txt-wrap h3::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  padding-top: 0.6042296073%;
  margin-top: 34.1389728097%;
  background-color: #e60012;
  transition: width 0.6s 0.5s;
}
.message .box .txt-wrap h3 + p {
  margin-top: 13.3333333333%;
  margin-left: 11.7333333333%;
  margin-right: 8%;
  opacity: 0;
  transform: translateY(13.3333333333vw);
  transition: transform 1s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.7s;
}
.message .box .txt-wrap h3 + p.animated {
  opacity: 1;
  transform: none;
}
.message .box .txt-wrap h3.animated span {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.message .box .txt-wrap h3.animated::after {
  width: 17.2205438066%;
}
.message .box .txt-wrap .link-btn {
  margin-top: 11.4666666667vw;
  margin-left: 11.7333333333vw;
}
.message .pic-wrap {
  position: relative;
  top: -29.3333333333vw;
  left: 12.2666666667%;
  width: 94.6666666667%;
  margin-top: 24%;
  z-index: 2;
}
.message .pic-wrap .pic {
  width: 88%;
  height: 85.3333333333vw;
  border-radius: 1.3333333333vw;
  overflow: hidden;
  position: relative;
  background-color: #fff;
}
.message .pic-wrap .pic picture iframe {
  width: 100%;
  height: 71.4666666667vw;
}
.message .pic-wrap .pic img {
  max-width: none;
  width: 154%;
  margin-top: -7.8549848943%;
  margin-left: -33.2326283988%;
}
.message .pic-wrap .pic + .rec {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background-color: #e60012;
  width: 93.3333333333%;
  position: absolute;
  top: 9.3333333333vw;
  left: 12%;
  height: 0;
  margin-top: -1.3333333333%;
  padding-top: 117.3333333333%;
  z-index: -1;
  border-top-left-radius: 1.3333333333vw;
  border-bottom-left-radius: 1.3333333333vw;
  border-top-right-radius: 1.3333333333vw;
  border-bottom-right-radius: 1.3333333333vw;
}
.message .pic-wrap .comment {
  width: 89.2753623188%;
  background-color: #202020;
  color: #fff;
  border-radius: 1.6vw;
  padding: 27.5362318841% 7.2463768116% 14.4927536232% 8.4057971014%;
  position: relative;
  margin-top: -14.4927536232%;
  margin-left: -8.6956521739%;
  z-index: 10;
}
.message .pic-wrap .comment::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background: url(../images/career/people_quotation.svg) no-repeat left top/contain;
  width: 8vw;
  height: 8vw;
  margin-top: 11.3924050633%;
  margin-left: 9.4936708861%;
}
.message .pic-wrap .comment h2 {
  font-size: 5.3333333333vw;
  line-height: 150%;
}
.message .pic-wrap .comment p {
  font-size: 4vw;
  letter-spacing: 0.15vw;
  line-height: 174%;
}
.message .pic-wrap .access-data {
  background-color: #fff;
  width: 100%;
  padding: 7.4666666667% 8.5333333333%;
}
.message .pic-wrap .access-data .title {
  font-size: 9.0666666667vw;
  color: #202020;
  margin-top: -0.5797101449%;
  letter-spacing: -0.2vw;
  line-height: 1;
  position: relative;
}
.message .pic-wrap .access-data .title span {
  display: inline-block;
  padding: 0.5797101449% 1.4492753623% 1.4492753623% 0;
  -webkit-clip-path: inset(0 100% 0 0);
          clip-path: inset(0 100% 0 0);
  transition: 0.8s cubic-bezier(0.16, 1, 0.3, 1);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.message .pic-wrap .access-data .title::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  padding-top: 0.5797101449%;
  margin-top: 22.0289855072%;
  background-color: #e60012;
  transition: 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.message .pic-wrap .access-data .title.animated span {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.message .pic-wrap .access-data .title.animated::after {
  width: 21.1594202899%;
}
.message .pic-wrap .access-data .address {
  margin-top: 18.6666666667%;
}
.message .pic-wrap .access-data .route {
  font-size: 3.3333333333vw;
  margin-top: 24%;
  line-height: 1.8;
}
.message .pic-wrap .access-data .link-txt {
  background-color: transparent;
  position: relative;
  bottom: 0;
  left: 0;
  margin-top: 18.1333333333%;
  margin-left: 54.6666666667%;
  overflow: visible;
}
.message .pic-wrap .access-data .link-txt a .arrow {
  margin-left: 81.3333333333%;
}
.message .p_profile {
  margin-top: -23.768115942%;
  margin-left: 8.115942029%;
  position: relative;
  width: 100%;
}
.message .p_profile .position {
  font-size: 4.1333333333vw;
  line-height: 1.5;
  letter-spacing: 0.05vw;
}
.message .p_profile .name {
  font-size: 6.1333333333vw;
  line-height: 1.7777777778;
  margin-top: 0.7936507937%;
  letter-spacing: 0;
  position: relative;
}
.message .p_profile .name span {
  font-size: 5.6vw;
  display: block;
  color: #a9a9a9;
  margin-top: -3.1746031746%;
}
.message .p_profile .name::after {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 0;
  height: 0.5333333333vw;
  margin-bottom: -5.8666666667vw;
  background-color: #e60012;
}
.message .p_profile .prof_txt {
  margin-top: 10.7246376812%;
  width: 84.0579710145%;
  font-size: 3.7333333333vw;
  line-height: 1.8333333333;
  letter-spacing: 0.1vw;
}
.message .p_profile .prof_add {
  margin-top: 2.3188405797%;
  margin-left: 4.347826087%;
  width: 84.0579710145%;
  font-size: 3.2vw;
  line-height: 1.8333333333;
  letter-spacing: 0.1vw;
  list-style-image: url("../images/about-us/mrk_line.png");
}
.message .p_profile.animated .name::after {
  width: 22.6666666667vw;
}
.message .container {
  width: 92%;
  margin: 0 auto;
  padding: 2.6666666667%;
  background-color: #fff;
  border-radius: 1.3333333333vw;
}
.message .container .pic-wrap {
  width: 100%;
  border-radius: 1.3333333333vw;
  position: relative;
  overflow: hidden;
}
.message .container .pic-wrap .card {
  width: 69.2307692308%;
  height: 24.6153846154%;
  border-top-right-radius: 1.3333333333vw;
  border-bottom-right-radius: 1.3333333333vw;
  position: absolute;
  top: 0;
  left: 0;
  margin-top: 66.7692307692%;
  background-color: #fff;
  overflow: hidden;
}
.message .container .pic-wrap .card .company {
  background-color: #e60012;
  color: #fff;
  font-size: 4vw;
  line-height: 170%;
  padding: 2.6666666667% 8.8888888889% 1.3333333333%;
}
.message .container .pic-wrap .card .name {
  font-size: 4.2666666667vw;
  line-height: 1.875;
  padding: 3.1111111111% 8.8888888889% 3.5555555556%;
  letter-spacing: 0;
}

.members {
  padding-top: 3.4666666667vw;
  overflow: hidden;
}
.members .box {
  position: relative;
  padding-bottom: 10.6666666667vw;
  background-color: #fff;
  z-index: 1;
}
.members .box .bg-txt-lft,
.members .box .bg-txt-rgt {
  font-size: 20vw;
  line-height: 0.62;
  color: #f6f6f6;
  position: absolute;
  top: 24.5333333333vw;
  left: -1.6vw;
}
.members .box .txt-wrap h2 {
  font-size: 10.1333333333vw;
  color: #e60012;
  margin-left: 8%;
  padding-top: 16%;
  position: relative;
  letter-spacing: -0.01vw;
  line-height: 0.86;
  -webkit-clip-path: inset(100% 0 0 0);
          clip-path: inset(100% 0 0 0);
  transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.members .box .txt-wrap h2 .jp-sub {
  font-size: 4vw;
  color: #202020;
  display: inline-block;
  margin-left: 1.3333333333%;
}
.members .box .txt-wrap h2.animated {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.members .box .txt-wrap h2.animated::before {
  width: 100%;
}
.members .box .txt-wrap h3 {
  margin-top: 81.6%;
  margin-left: 11.7333333333%;
  position: relative;
}
.members .box .txt-wrap h3 span {
  -webkit-clip-path: inset(100% 0 0 0);
          clip-path: inset(100% 0 0 0);
  transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.members .box .txt-wrap h3::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  padding-top: 0.6042296073%;
  margin-top: 34.1389728097%;
  background-color: #e60012;
  transition: width 0.6s 0.5s;
}
.members .box .txt-wrap h3 + p {
  margin-top: 13.3333333333%;
  margin-left: 11.7333333333%;
  margin-right: 8%;
  opacity: 0;
  transform: translateY(13.3333333333vw);
  transition: transform 1s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.7s;
}
.members .box .txt-wrap h3 + p.animated {
  opacity: 1;
  transform: none;
}
.members .box .txt-wrap h3.animated span {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.members .box .txt-wrap h3.animated::after {
  width: 17.2205438066%;
}
.members .box .txt-wrap .link-btn {
  margin-top: 11.4666666667vw;
  margin-left: 11.7333333333vw;
}
.members .prof_group .prof_unit {
  margin-bottom: 25.0666666667vw;
}
.members .pic-wrap {
  position: relative;
  /*top: calcVwSp(-110);*/
  left: 8%;
  width: 96%;
  margin-top: -5.3333333333%;
  z-index: 2;
}
.members .pic-wrap .pic {
  width: 88%;
  height: 98.6666666667vw;
  border-radius: 1.3333333333vw;
  overflow: hidden;
  position: relative;
  background-color: #fff;
}
.members .pic-wrap .pic picture iframe {
  width: 100%;
  height: 71.4666666667vw;
}
.members .pic-wrap .pic img {
  max-width: none;
  width: 175%;
  margin-left: -37.7643504532%;
}
.members .p_profile {
  margin-top: 5.7971014493%;
  margin-left: 8.115942029%;
  position: relative;
  width: 100%;
}
.members .p_profile .position {
  font-size: 4.1333333333vw;
  line-height: 1.5;
  letter-spacing: 0.05vw;
}
.members .p_profile .name {
  font-size: 6.1333333333vw;
  line-height: 1.7777777778;
  margin-top: 0.7936507937%;
  letter-spacing: 0;
  position: relative;
}
.members .p_profile .name span {
  font-size: 5.6vw;
  display: block;
  color: #a9a9a9;
  margin-top: -3.1746031746%;
}
.members .p_profile .name::after {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 0;
  height: 0.5333333333vw;
  margin-bottom: -5.8666666667vw;
  background-color: #e60012;
}
.members .p_profile .prof_txt {
  margin-top: 10.7246376812%;
  width: 84.0579710145%;
  font-size: 3.7333333333vw;
  line-height: 1.8333333333;
  letter-spacing: 0.1vw;
}
.members .p_profile .prof_add {
  margin-top: 2.3188405797%;
  margin-left: 4.347826087%;
  width: 78.2608695652%;
  font-size: 3.2vw;
  line-height: 1.8333333333;
  letter-spacing: 0.1vw;
  list-style-image: url("../images/about-us/mrk_line.png");
}
.members .p_profile.animated .name::after {
  width: 22.6666666667vw;
}

.history {
  padding-top: 1.8666666667vw;
}
.history .box {
  position: relative;
  padding-bottom: 5.3333333333vw;
  background-color: #fff;
  z-index: 1;
}
.history .box .bg-txt-lft,
.history .box .bg-txt-rgt {
  font-size: 20vw;
  line-height: 0.62;
  color: #f6f6f6;
  position: absolute;
  top: 8.5333333333vw;
  left: -1.6vw;
}
.history .box .txt-wrap h2 {
  font-size: 10.1333333333vw;
  color: #e60012;
  margin-left: 8%;
  position: relative;
  letter-spacing: -0.01vw;
  line-height: 0.86;
  -webkit-clip-path: inset(100% 0 0 0);
          clip-path: inset(100% 0 0 0);
  transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.history .box .txt-wrap h2 .jp-sub {
  font-size: 4vw;
  color: #202020;
  display: inline-block;
  margin-left: 1.3333333333%;
}
.history .box .txt-wrap h2.animated {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.history .box .txt-wrap h2.animated::before {
  width: 100%;
}
.history .box .txt-wrap h3 {
  margin-top: 81.6%;
  margin-left: 11.7333333333%;
  position: relative;
}
.history .box .txt-wrap h3 span {
  -webkit-clip-path: inset(100% 0 0 0);
          clip-path: inset(100% 0 0 0);
  transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.history .box .txt-wrap h3::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  padding-top: 0.6042296073%;
  margin-top: 34.1389728097%;
  background-color: #e60012;
  transition: width 0.6s 0.5s;
}
.history .box .txt-wrap h3 + p {
  margin-top: 13.3333333333%;
  margin-left: 11.7333333333%;
  margin-right: 8%;
  opacity: 0;
  transform: translateY(13.3333333333vw);
  transition: transform 1s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.7s;
}
.history .box .txt-wrap h3 + p.animated {
  opacity: 1;
  transform: none;
}
.history .box .txt-wrap h3.animated span {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.history .box .txt-wrap h3.animated::after {
  width: 17.2205438066%;
}
.history .box .txt-wrap .link-btn {
  margin-top: 11.4666666667vw;
  margin-left: 11.7333333333vw;
}
.history .container {
  width: 92%;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.history .container ul {
  list-style: none;
  border-bottom: solid 0.2666666667vw #ddd;
}
.history .container ul li {
  border-top: solid 0.2666666667vw #ddd;
}
.history .container ul li .period {
  position: relative;
}
.history .container ul li .period h3 {
  color: #e60012;
  font-family: "Barlow Condensed", sans-serif;
  font-size: 8.5333333333vw;
  font-weight: 300;
  letter-spacing: 0;
  padding: 2.9333333333% 4.8% 2.4%;
  cursor: pointer;
}
.history .container ul li .period h3::before, .history .container ul li .period h3::after {
  position: absolute;
  content: "";
  width: 5.3333333333vw;
  height: 0.5333333333vw;
  background-color: #e60012;
}
.history .container ul li .period h3::before {
  top: 48%;
  right: 6.6666666667vw;
  transform: rotate(0deg);
}
.history .container ul li .period h3::after {
  top: 48%;
  right: 6.6666666667vw;
  transform: rotate(90deg);
}
.history .container ul li .period.close h3::after {
  transform: rotate(0deg);
}
.history .container ul li .timeline {
  position: relative;
  border-top: solid 0.2666666667vw #ddd;
  margin-bottom: 5.0666666667vw;
}
.history .container ul li .timeline .his_unit {
  display: flex;
}
.history .container ul li .timeline p {
  padding: 4.8% 2.9333333333% 0;
  font-size: 4vw;
  width: 77%;
}
.history .container ul li .timeline .y_m {
  width: 23%;
  height: 7.4666666667vw;
  margin-top: 5.0666666667vw;
  padding: 0 2.4%;
  font-family: "Barlow Condensed", sans-serif;
  font-size: 5.3333333333vw;
  line-height: 1.4;
  border-right: solid 1px #ddd;
}
.history .container ul li .timeline a {
  color: #000;
  text-decoration: underline;
}
.history .container ul li .timeline a:visited {
  color: #000;
}
.history .container ul li .timeline a:hover {
  color: #e60012;
}
.history .container ul li .timeline a:hover::after {
  transform: translateX(1.3333333333vw) translateY(-50%) rotate(135deg);
}
.history .container ul li .acd-content {
  display: none;
}

footer {
  margin-top: 8vh;
}

@media screen and (min-width: 769px) {
  .hero {
    background: url("../images/about-us/hero_bg_pc.jpg") no-repeat center top/cover;
    min-height: 25vw;
    height: 100%;
    width: auto;
  }
  .hero .front-image {
    width: 88.8888888889%;
    height: 26.7361111111vw;
    position: absolute;
    top: 19.0972222222%;
    left: 5.4166666667%;
    margin: 0 auto;
    border-radius: 0.3472222222vw;
  }
  .hero .front-image img {
    margin-top: -3.8194444444vw;
    margin-left: 0;
    width: 100%;
  }
  .p_title {
    min-height: 20vw;
    padding-top: 7.9861111111%;
  }
  .p_title .bg-number {
    opacity: 0.65;
  }
  .p_title .bg-number.no01 {
    font-size: 25.6944444444vw;
    margin-top: 12.9166666667%;
    margin-right: 4.0277777778%;
    letter-spacing: -1.35vw;
  }
  .p_title .bg-number.no01 .per {
    font-size: 9.375vw;
    margin-left: 0.6944444444%;
  }
  .p_title .bg-number.no02 {
    font-size: 46.1805555556vw;
    left: 0;
    right: auto;
    margin-top: 142.3611111111%;
    margin-left: 13.6111111111%;
    line-height: 1.1187969925;
    letter-spacing: -2vw;
    color: #fff;
  }
  .p_title .bg-number.no05 {
    font-size: 19.9305555556vw;
    left: 0;
    margin-top: 66.4583333333%;
    line-height: 1.1149825784;
    letter-spacing: -1vw;
    color: #fff;
  }
  .p_title .bg-number.no06 {
    font-size: 14.3055555556vw;
    left: 0;
    margin-top: 109.6527777778%;
    margin-left: 57.6388888889%;
    line-height: 1.1213592233;
    letter-spacing: -1vw;
    color: #fff;
  }
  .p_title .txt-wrap {
    padding: 0 33.3333333333% 0 11.1111111111%;
  }
  .p_title .txt-wrap .title {
    font-size: 4.8611111111vw;
    margin-top: 5%;
    letter-spacing: 0.05vw;
    line-height: 1;
  }
  .p_title .txt-wrap .title span {
    padding: 0;
  }
  .p_title .txt-wrap .title::after {
    padding-top: 0.25%;
    margin-top: 11.875%;
  }
  .p_title .txt-wrap .title.animated::after {
    width: 10%;
  }
  .p_title .txt-wrap p {
    font-size: 1.25vw;
    margin-top: 7.75%;
    line-height: 1.85;
    letter-spacing: 0.09vw;
  }
  .p_title .txt-wrap p:not(:first-of-type) {
    margin-top: 1.875%;
    line-height: 1.8;
  }
  .philosophy {
    position: relative;
    /*padding-top: calcPerSp(54);*/
    padding-bottom: 0;
    overflow: hidden;
    height: 84vw;
  }
  .philosophy .box {
    position: relative;
  }
  .philosophy .box .bg-txt-lft,
.philosophy .box .bg-txt-rgt {
    font-size: 15.2vw;
    line-height: 0.62;
    color: #f6f6f6;
    position: absolute;
    top: 0;
    left: -1vw;
    /*letter-spacing: -0.65vw;*/
    z-index: -5;
  }
  .philosophy .box .pic-wrap {
    position: absolute;
    top: 0;
    left: 0;
    width: 94.4%;
    margin-top: 51.3888888889%;
  }
  .philosophy .box .pic-wrap .pic {
    width: 88.2666666667%;
    height: 29.0666666667vw;
    border-top-right-radius: 0.4vw;
    border-bottom-right-radius: 0.4vw;
    overflow: hidden;
    position: relative;
    background-color: #fff;
  }
  .philosophy .box .pic-wrap .pic .bdr-rgt {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-top: solid 3.2vw rgba(255, 255, 255, 0.5);
    border-right: solid 3.2vw rgba(255, 255, 255, 0.5);
    border-bottom: solid 3.2vw rgba(255, 255, 255, 0.5);
    border-top-right-radius: 26.6666666667vw;
    border-bottom-right-radius: 26.6666666667vw;
    z-index: 10;
  }
  .philosophy .box .pic-wrap .pic .bdr-lft {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-top: solid 3.2vw rgba(255, 255, 255, 0.5);
    border-left: solid 3.2vw rgba(255, 255, 255, 0.5);
    border-bottom: solid 3.2vw rgba(255, 255, 255, 0.5);
    border-top-left-radius: 26.6666666667vw;
    border-bottom-left-radius: 26.6666666667vw;
    z-index: 10;
  }
  .philosophy .box .pic-wrap .pic img {
    max-width: none;
    width: 102%;
    margin-left: 0;
    margin-top: -12.3867069486vw;
  }
  .philosophy .box .pic-wrap .pic + .rec {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    position: absolute;
    top: 0;
    left: 64.8%;
    background-color: #e60012;
    width: 41.3333333333%;
    height: 0;
    margin-top: 9.3333333333%;
    padding-top: 23.2%;
    z-index: -1;
    border-radius: 0.4vw;
  }
  .philosophy .box .txt-wrap h2 {
    font-size: 3.2vw;
    color: #e60012;
    margin-left: 10.9333333333%;
    padding-top: 4.4444444444%;
    padding-bottom: 0.6944444444%;
    position: relative;
    letter-spacing: -0.01vw;
  }
  .philosophy .box .txt-wrap h2 .jp-sub {
    font-size: 1.3333333333vw;
    color: #202020;
    display: inline-block;
    margin-left: 1.3333333333%;
  }
  .philosophy .box .txt-wrap h2.animated::before {
    width: 100%;
  }
  .philosophy .box .txt-wrap h3 {
    margin-top: 81.6%;
    margin-left: 11.7333333333%;
    position: relative;
  }
  .philosophy .box .txt-wrap h3 span {
    -webkit-clip-path: inset(100% 0 0 0);
            clip-path: inset(100% 0 0 0);
    transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
    transition-property: -webkit-clip-path;
    transition-property: clip-path;
    transition-property: clip-path, -webkit-clip-path;
  }
  .philosophy .box .txt-wrap h3::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    padding-top: 0.6042296073%;
    margin-top: 34.1389728097%;
    background-color: #e60012;
    transition: width 0.6s 0.5s;
  }
  .philosophy .box .txt-wrap h3 + p {
    margin-top: 13.3333333333%;
    margin-left: 11.7333333333%;
    margin-right: 8%;
    opacity: 0;
    transform: translateY(13.3333333333vw);
    transition: transform 1s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.7s;
  }
  .philosophy .box .txt-wrap h3 + p.animated {
    opacity: 1;
    transform: none;
  }
  .philosophy .box .txt-wrap h3.animated span {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
  .philosophy .box .txt-wrap h3.animated::after {
    width: 17.2205438066%;
  }
  .philosophy .box .txt-wrap .link-btn {
    margin-top: 11.4666666667vw;
    margin-left: 11.7333333333vw;
  }
  .philosophy .box .panels {
    background-color: #f6f6f6;
    position: relative;
    top: 0;
    margin-top: 2.7777777778%;
    min-height: 38.6666666667vw;
  }
  .philosophy .box .panels ul {
    display: flex;
    flex-direction: row;
    width: 77.7777777778%;
    height: 39.3055555556vw;
    margin: 0.5555555556% auto 0;
    justify-content: space-between;
    align-items: flex-start;
    position: relative;
    top: -2.4305555556vw;
    list-style: none;
  }
  .philosophy .box .panels ul li {
    background-color: #fff;
    min-height: 27.7777777778vw;
    border-radius: 1.3888888889%;
    width: 32.1428571429%;
    transform: translateY(6.9444444444vw);
  }
  .philosophy .box .panels ul li h4 {
    font-size: 6.25vw;
    line-height: 100%;
    padding: 10% 5.5555555556% 8.3333333333% 5.5555555556%;
    border-bottom: solid 0.0694444444vw #ddd;
    letter-spacing: -0.2vw;
  }
  .philosophy .box .panels ul li h4 > span.per {
    font-size: 3.8194444444vw;
  }
  .philosophy .box .panels ul li .panel-title {
    font-size: 1.5277777778vw;
    line-height: 100%;
    line-height: 1.6;
    padding: 8.3333333333% 6.9444444444% 0 6.9444444444%;
    letter-spacing: 0.05vw;
  }
  .philosophy .box .panels ul li .caption {
    font-size: 0.8333333333vw;
    padding: 3.8888888889% 6.6666666667% 0 6.6666666667%;
  }
  .philosophy .box .panels ul li .icon {
    width: 13.8888888889%;
    margin-top: 15.2777777778%;
    margin-left: 80.5555555556%;
  }
  .philosophy .box .panels ul li .icon img.mt-top {
    margin-top: 69.4444444444%;
  }
  .philosophy .box .panels ul li:not(:first-child) {
    margin-top: 0;
  }
  .profile {
    position: relative;
    padding-bottom: 0;
    overflow: hidden;
    height: 158vw;
    border-bottom: solid 1px #ddd;
  }
  .profile .box {
    position: relative;
    padding-bottom: 0;
    height: 10.9866666667vw;
    border-bottom: solid 1px #ddd;
  }
  .profile .box .bg-txt-lft,
.profile .box .bg-txt-rgt {
    font-size: 15.2vw;
    line-height: 0.62;
    color: #f6f6f6;
    position: absolute;
    top: 0.2vw;
    left: -1vw;
    z-index: -5;
  }
  .profile .box .txt-wrap h2 {
    font-size: 3.2vw;
    color: #e60012;
    margin-left: 10.9333333333%;
    padding-top: calcPerpc(74);
    position: relative;
    letter-spacing: -0.01vw;
  }
  .profile .box .txt-wrap h2 span {
    -webkit-clip-path: inset(100% 0 0 0);
            clip-path: inset(100% 0 0 0);
    transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
    transition-property: -webkit-clip-path;
    transition-property: clip-path;
    transition-property: clip-path, -webkit-clip-path;
  }
  .profile .box .txt-wrap h2 .jp-sub {
    font-size: 1.3333333333vw;
    color: #202020;
    display: inline-block;
    margin-left: 1.3333333333%;
  }
  .profile .box .txt-wrap h2.animated span {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
  .profile .box .txt-wrap h2.animated::before {
    width: 100%;
  }
  .profile .box .txt-wrap h3 {
    margin-top: 81.6%;
    margin-left: 11.7333333333%;
    position: relative;
  }
  .profile .box .txt-wrap h3 span {
    -webkit-clip-path: inset(100% 0 0 0);
            clip-path: inset(100% 0 0 0);
    transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
    transition-property: -webkit-clip-path;
    transition-property: clip-path;
    transition-property: clip-path, -webkit-clip-path;
  }
  .profile .box .txt-wrap h3::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    padding-top: 0.6042296073%;
    margin-top: 34.1389728097%;
    background-color: #e60012;
    transition: width 0.6s 0.5s;
  }
  .profile .box .txt-wrap h3 + p {
    margin-top: 13.3333333333%;
    margin-left: 11.7333333333%;
    margin-right: 8%;
    opacity: 0;
    transform: translateY(13.3333333333vw);
    transition: transform 1s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.7s;
  }
  .profile .box .txt-wrap h3 + p.animated {
    opacity: 1;
    transform: none;
  }
  .profile .box .txt-wrap h3.animated span {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
  .profile .box .txt-wrap h3.animated::after {
    width: 17.2205438066%;
  }
  .profile .box .txt-wrap .link-btn {
    margin-top: 11.4666666667vw;
    margin-left: 11.7333333333vw;
  }
  .profile .container {
    width: 82.1333333333%;
    padding: 3.4666666667% 2.1333333333% 5.6%;
    border-right: solid 1px #ddd;
    border-left: solid 1px #ddd;
  }
  .profile .container .inner {
    width: 100%;
    background-color: #fff;
    padding: 1.3333333333vw 5.6vw;
  }
  .profile .container .cnt-block {
    display: flex;
    width: 100%;
    padding: 2.4vw 5.6vw;
    border-bottom: solid 1px #ddd;
  }
  .profile .container .cnt-block .head {
    font-size: 1.04vw;
    color: #888;
    margin-bottom: 0;
    width: 10.9333333333vw;
  }
  .profile .container .cnt-block .item {
    min-width: -webkit-fit-content;
    min-width: -moz-fit-content;
    min-width: fit-content;
  }
  .profile .container .cnt-block .item p {
    font-size: 1.04vw;
    line-height: 1.3;
    margin-bottom: 0.4vw;
  }
  .profile .container .cnt-block .sp {
    width: 23.4666666667vw;
  }
  .profile .container .noborder {
    border-bottom: none;
  }
  .access {
    position: relative;
    top: -6.1333333333vw;
    padding-bottom: 0;
    overflow: hidden;
    height: 92.8vw;
    border-bottom: none;
    background-color: #f6f6f6;
  }
  .access .box {
    position: relative;
    padding-bottom: 0;
    height: 10.9866666667vw;
  }
  .access .box .bg-txt-lft,
.access .box .bg-txt-rgt {
    font-size: 15.2vw;
    line-height: 0.62;
    color: #f6f6f6;
    position: absolute;
    top: 0.5vw;
    left: -1.1vw;
    z-index: -5;
  }
  .access .box .txt-wrap h2 {
    font-size: 3.2vw;
    color: #e60012;
    padding-top: 3.8888888889%;
    margin-left: 11.1111111111%;
    position: relative;
    letter-spacing: -0.01vw;
  }
  .access .box .txt-wrap h2 span {
    -webkit-clip-path: inset(100% 0 0 0);
            clip-path: inset(100% 0 0 0);
    transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
    transition-property: -webkit-clip-path;
    transition-property: clip-path;
    transition-property: clip-path, -webkit-clip-path;
  }
  .access .box .txt-wrap h2 .jp-sub {
    font-size: 1.3333333333vw;
    color: #202020;
    display: inline-block;
    margin-left: 1.3333333333%;
  }
  .access .box .txt-wrap h2.animated span {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
  .access .box .txt-wrap h2.animated::before {
    width: 100%;
  }
  .access .box .txt-wrap h3 {
    margin-top: 81.6%;
    margin-left: 11.7333333333%;
    position: relative;
  }
  .access .box .txt-wrap h3 span {
    -webkit-clip-path: inset(100% 0 0 0);
            clip-path: inset(100% 0 0 0);
    transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
    transition-property: -webkit-clip-path;
    transition-property: clip-path;
    transition-property: clip-path, -webkit-clip-path;
  }
  .access .box .txt-wrap h3::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    padding-top: 0.6042296073%;
    margin-top: 34.1389728097%;
    background-color: #e60012;
    transition: width 0.6s 0.5s;
  }
  .access .box .txt-wrap h3 + p {
    margin-top: 13.3333333333%;
    margin-left: 11.7333333333%;
    margin-right: 8%;
    opacity: 0;
    transform: translateY(13.3333333333vw);
    transition: transform 1s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.7s;
  }
  .access .box .txt-wrap h3 + p.animated {
    opacity: 1;
    transform: none;
  }
  .access .box .txt-wrap h3.animated span {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
  .access .box .txt-wrap h3.animated::after {
    width: 17.2205438066%;
  }
  .access .box .txt-wrap .link-btn {
    margin-top: 11.4666666667vw;
    margin-left: 11.7333333333vw;
  }
  .access .pic-wrap {
    position: absolute;
    top: 6.6666666667vw;
    left: 0;
    width: 100%;
    margin-top: 3.2%;
    z-index: 2;
  }
  .access .pic-wrap .pic {
    display: flex;
    width: 88.8%;
    height: 33.8666666667vw;
    border-top-right-radius: 0.4vw;
    border-bottom-right-radius: 0.4vw;
    overflow: hidden;
    position: relative;
    top: 1.3333333333vw;
    background-color: #fff;
  }
  .access .pic-wrap .pic picture {
    width: 189.3333333333%;
  }
  .access .pic-wrap .pic picture iframe {
    width: 100%;
    height: 71.4666666667vw;
  }
  .access .pic-wrap .pic img {
    max-width: none;
    width: 105%;
    margin-left: -3.6253776435%;
  }
  .access .pic-wrap .pic + .rec {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    background-color: #e60012;
    width: 93.3333333333%;
    position: absolute;
    top: 0;
    left: 11.2%;
    height: 0;
    margin-top: -5.5555555556vw;
    padding-top: 30.4vw;
    z-index: -1;
    border-top-left-radius: 0.4vw;
    border-bottom-left-radius: 0.4vw;
    border-top-right-radius: 0.4vw;
    border-bottom-right-radius: 0.4vw;
  }
  .access .pic-wrap .access-data {
    background-color: #fff;
    width: 100%;
    padding: 1.8666666667% 3.2%;
  }
  .access .pic-wrap .access-data .title {
    font-size: 2.32vw;
    color: #202020;
    margin-top: 5.7971014493%;
    letter-spacing: 0;
    line-height: 1;
    position: relative;
  }
  .access .pic-wrap .access-data .title span {
    display: inline-block;
    padding: 0.5797101449% 1.4492753623% 1.4492753623% 0;
    -webkit-clip-path: inset(0 100% 0 0);
            clip-path: inset(0 100% 0 0);
    transition: 0.8s cubic-bezier(0.16, 1, 0.3, 1);
    transition-property: -webkit-clip-path;
    transition-property: clip-path;
    transition-property: clip-path, -webkit-clip-path;
  }
  .access .pic-wrap .access-data .title::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    padding-top: 0.5797101449%;
    margin-top: 15.3623188406%;
    background-color: #e60012;
    transition: 0.8s cubic-bezier(0.22, 1, 0.36, 1);
  }
  .access .pic-wrap .access-data .title.animated span {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
  .access .pic-wrap .access-data .title.animated::after {
    width: 21.1594202899%;
  }
  .access .pic-wrap .access-data .address {
    margin-top: 12%;
  }
  .access .pic-wrap .access-data .route {
    font-size: 1vw;
    margin-top: 13.8666666667%;
    line-height: 1.8;
  }
  .access .pic-wrap .access-data .link-txt {
    background-color: transparent;
    position: relative;
    bottom: 0;
    left: 0;
    margin-top: 16%;
    margin-left: 68.8%;
    overflow: visible;
  }
  .access .pic-wrap .access-data .link-txt a .arrow {
    margin-left: 70.9333333333%;
  }
  .access #osaka {
    position: relative;
    top: 36.5333333333vw;
    left: 11.2%;
  }
  .access #osaka .pic {
    height: 34vw;
    flex-direction: row-reverse;
    border-top-left-radius: 0.4vw;
    border-bottom-left-radius: 0.4vw;
  }
  .access #osaka .pic + .rec {
    width: 91.2%;
    position: absolute;
    left: -13.3333333333%;
    height: 0;
    margin-top: -6.25vw;
    padding-top: 30.4vw;
    z-index: -1;
  }
  .access #osaka .access-data {
    background-color: #fff;
    width: 100%;
    padding: 0.8% 4%;
  }
  .access #osaka .access-data .title {
    font-size: 2.32vw;
    color: #202020;
    margin-top: 9.5652173913%;
    letter-spacing: 0;
    line-height: 1;
    position: relative;
  }
  .access #osaka .access-data .title span {
    display: inline-block;
    padding: 0.5797101449% 1.4492753623% 1.4492753623% 0;
    -webkit-clip-path: inset(0 100% 0 0);
            clip-path: inset(0 100% 0 0);
    transition: 0.8s cubic-bezier(0.16, 1, 0.3, 1);
    transition-property: -webkit-clip-path;
    transition-property: clip-path;
    transition-property: clip-path, -webkit-clip-path;
  }
  .access #osaka .access-data .title::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    padding-top: 0.5797101449%;
    margin-top: 15.3623188406%;
    background-color: #e60012;
    transition: 0.8s cubic-bezier(0.22, 1, 0.36, 1);
  }
  .access #osaka .access-data .title.animated span {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
  .access #osaka .access-data .title.animated::after {
    width: 21.1594202899%;
  }
  .access #osaka .access-data .address {
    margin-top: 12%;
  }
  .access #osaka .access-data .route {
    font-size: 1vw;
    margin-top: 6.9333333333%;
    line-height: 1.8;
  }
  .access #osaka .access-data .link-txt {
    background-color: transparent;
    position: relative;
    bottom: 0;
    left: 0;
    margin-top: 16%;
    margin-left: 68.8%;
    overflow: visible;
  }
  .access #osaka .access-data .link-txt a .arrow {
    margin-left: 70.9333333333%;
  }
  .access #osaka .route {
    margin-top: 12%;
  }
  .message {
    padding-top: 0;
  }
  .message .box {
    position: relative;
    top: 41.6%;
    padding-bottom: 0;
    height: 10.9866666667vw;
  }
  .message .box .bg-txt-lft,
.message .box .bg-txt-rgt {
    font-size: 15.2vw;
    line-height: 0.62;
    color: #f6f6f6;
    position: absolute;
    top: 2.5vw;
    left: -1.1vw;
    z-index: -5;
  }
  .message .box .txt-wrap h2 {
    font-size: 3.2vw;
    color: #e60012;
    margin-left: 10.9333333333%;
    padding-top: 7.3611111111%;
    position: relative;
    letter-spacing: -0.01vw;
  }
  .message .box .txt-wrap h2 span {
    -webkit-clip-path: inset(100% 0 0 0);
            clip-path: inset(100% 0 0 0);
    transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
    transition-property: -webkit-clip-path;
    transition-property: clip-path;
    transition-property: clip-path, -webkit-clip-path;
  }
  .message .box .txt-wrap h2 .jp-sub {
    font-size: 1.3333333333vw;
    color: #202020;
    display: inline-block;
    margin-left: 1.3333333333%;
  }
  .message .box .txt-wrap h2.animated span {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
  .message .box .txt-wrap h2.animated::before {
    width: 100%;
  }
  .message .box .txt-wrap h3 {
    margin-top: 81.6%;
    margin-left: 11.7333333333%;
    position: relative;
  }
  .message .box .txt-wrap h3 span {
    -webkit-clip-path: inset(100% 0 0 0);
            clip-path: inset(100% 0 0 0);
    transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
    transition-property: -webkit-clip-path;
    transition-property: clip-path;
    transition-property: clip-path, -webkit-clip-path;
  }
  .message .box .txt-wrap h3::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    padding-top: 0.6042296073%;
    margin-top: 34.1389728097%;
    background-color: #e60012;
    transition: width 0.6s 0.5s;
  }
  .message .box .txt-wrap h3 + p {
    margin-top: 13.3333333333%;
    margin-left: 11.7333333333%;
    margin-right: 8%;
    opacity: 0;
    transform: translateY(13.3333333333vw);
    transition: transform 1s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.7s;
  }
  .message .box .txt-wrap h3 + p.animated {
    opacity: 1;
    transform: none;
  }
  .message .box .txt-wrap h3.animated span {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
  .message .box .txt-wrap h3.animated::after {
    width: 17.2205438066%;
  }
  .message .box .txt-wrap .link-btn {
    margin-top: 11.4666666667vw;
    margin-left: 11.7333333333vw;
  }
  .message .pic-wrap {
    position: relative;
    top: -29.3333333333vw;
    left: 12.2666666667%;
    width: 94.6666666667%;
    margin-top: 24%;
    z-index: 2;
  }
  .message .pic-wrap .pic {
    width: 46.9333333333%;
    height: 47.2vw;
    margin-left: 32vw;
    border-radius: 0.4vw;
    overflow: hidden;
    position: relative;
    background-color: #fff;
  }
  .message .pic-wrap .pic picture {
    margin-top: 21.3333333333vw;
  }
  .message .pic-wrap .pic picture iframe {
    width: 100%;
    height: 71.4666666667vw;
  }
  .message .pic-wrap .pic img {
    max-width: none;
    width: 161%;
    margin-top: -0.3021148036%;
    margin-left: -31.7220543807%;
  }
  .message .pic-wrap .pic + .rec {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    background-color: #e60012;
    width: 45.3333333333%;
    position: absolute;
    top: 0.8vw;
    left: 51.4666666667%;
    height: 0;
    margin-top: -1.3333333333%;
    padding-top: 57.6%;
    z-index: -1;
    border-top-left-radius: 0.4vw;
    border-bottom-left-radius: 0.4vw;
    border-top-right-radius: 0.4vw;
    border-bottom-right-radius: 0.4vw;
  }
  .message .pic-wrap .comment {
    width: 44.0579710145%;
    background-color: #202020;
    color: #fff;
    border-radius: 0.4vw;
    padding: 2.8985507246% 2.8985507246% 3.4782608696% 2.8985507246%;
    position: relative;
    margin-top: -42.0289855072%;
    margin-left: -1.1594202899%;
    z-index: 10;
  }
  .message .pic-wrap .comment::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    background: url(../images/career/people_quotation.svg) no-repeat left top/contain;
    width: 2.6666666667vw;
    height: 2.6666666667vw;
    margin-top: 9.4936708861%;
    margin-left: 8.2278481013%;
  }
  .message .pic-wrap .comment h2 {
    font-size: 5.3333333333vw;
    line-height: 150%;
  }
  .message .pic-wrap .comment p {
    margin-top: 5.8666666667vw;
    font-size: 1.0666666667vw;
    letter-spacing: 0.15vw;
    line-height: 197%;
  }
  .message .p_profile {
    margin-top: -26.3768115942%;
    margin-left: 11.0144927536%;
    position: relative;
    width: 100%;
  }
  .message .p_profile .position {
    font-size: 1.0666666667vw;
    line-height: 1.5;
    letter-spacing: 0.05vw;
  }
  .message .p_profile .name {
    font-size: 1.7333333333vw;
    line-height: 1.7777777778;
    margin-top: 0;
    letter-spacing: 0;
    position: relative;
  }
  .message .p_profile .name span {
    font-size: 1.7333333333vw;
    display: inline;
    color: #a9a9a9;
    margin-top: -3.1746031746%;
    margin-left: 0.7936507937%;
  }
  .message .p_profile .name::after {
    position: absolute;
    content: "";
    top: 4vw;
    bottom: 0;
    left: 0;
    width: 0;
    height: 0.1333333333vw;
    margin-bottom: -5.8666666667vw;
    background-color: #e60012;
  }
  .message .p_profile .prof_txt {
    margin-top: 2.8985507246%;
    width: 30.4347826087%;
    font-size: 1.0666666667vw;
    line-height: 1.6666666667;
    letter-spacing: 0.1vw;
  }
  .message .p_profile .prof_add {
    margin-top: 1.4492753623%;
    margin-left: 1.4492753623%;
    width: 84.0579710145%;
    font-size: 0.8533333333vw;
    line-height: 1.8333333333;
    letter-spacing: 0.1vw;
    list-style-image: url("../images/about-us/mrk_line.png");
  }
  .message .p_profile.animated .name::after {
    width: 5.8666666667vw;
  }
  .members {
    padding-top: 6.9333333333vw;
  }
  .members .box {
    position: relative;
    top: 41.6%;
    padding-bottom: 0;
    height: 10.9866666667vw;
  }
  .members .box .bg-txt-lft,
.members .box .bg-txt-rgt {
    font-size: 15.2vw;
    line-height: 0.62;
    color: #f6f6f6;
    position: absolute;
    top: 2vw;
    left: -1.1vw;
    z-index: -5;
  }
  .members .box .txt-wrap h2 {
    font-size: 3.2vw;
    color: #e60012;
    margin-left: 10.9333333333%;
    padding-top: 6.8055555556%;
    position: relative;
    letter-spacing: -0.01vw;
  }
  .members .box .txt-wrap h2 span {
    -webkit-clip-path: inset(100% 0 0 0);
            clip-path: inset(100% 0 0 0);
    transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
    transition-property: -webkit-clip-path;
    transition-property: clip-path;
    transition-property: clip-path, -webkit-clip-path;
  }
  .members .box .txt-wrap h2 .jp-sub {
    font-size: 1.3333333333vw;
    color: #202020;
    display: inline-block;
    margin-left: 1.3333333333%;
  }
  .members .box .txt-wrap h2.animated span {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
  .members .box .txt-wrap h2.animated::before {
    width: 100%;
  }
  .members .box .txt-wrap h3 {
    margin-top: 81.6%;
    margin-left: 11.7333333333%;
    position: relative;
  }
  .members .box .txt-wrap h3 span {
    -webkit-clip-path: inset(100% 0 0 0);
            clip-path: inset(100% 0 0 0);
    transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
    transition-property: -webkit-clip-path;
    transition-property: clip-path;
    transition-property: clip-path, -webkit-clip-path;
  }
  .members .box .txt-wrap h3::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    padding-top: 0.6042296073%;
    margin-top: 34.1389728097%;
    background-color: #e60012;
    transition: width 0.6s 0.5s;
  }
  .members .box .txt-wrap h3 + p {
    margin-top: 13.3333333333%;
    margin-left: 11.7333333333%;
    margin-right: 8%;
    opacity: 0;
    transform: translateY(13.3333333333vw);
    transition: transform 1s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.7s;
  }
  .members .box .txt-wrap h3 + p.animated {
    opacity: 1;
    transform: none;
  }
  .members .box .txt-wrap h3.animated span {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
  .members .box .txt-wrap h3.animated::after {
    width: 17.2205438066%;
  }
  .members .box .txt-wrap .link-btn {
    margin-top: 11.4666666667vw;
    margin-left: 11.7333333333vw;
  }
  .members .prof_group {
    display: flex;
    flex-wrap: wrap;
    width: 87.2vw;
    margin-top: 2.7777777778vw;
    margin-left: 9.3333333333vw;
  }
  .members .prof_group .prof_unit {
    margin-bottom: 6.5866666667vw;
    width: 22.9333333333%;
  }
  .members .no-photo {
    margin-top: 3.2vw;
  }
  .members .pic-wrap {
    position: relative;
    /*top: calcVwSp(-110);*/
    left: 8.8%;
    margin-top: -5.3333333333%;
    z-index: 2;
  }
  .members .pic-wrap .pic {
    width: 93.3333333333%;
    height: 20.8vw;
    border-radius: 0.4vw;
    overflow: hidden;
    position: relative;
    background-color: #fff;
  }
  .members .pic-wrap .pic picture iframe {
    width: 100%;
    height: 71.4666666667vw;
  }
  .members .pic-wrap .pic img {
    max-width: none;
    width: 175%;
    margin-top: 0.3021148036%;
    margin-left: -36.253776435%;
  }
  .members .p_profile {
    margin-top: 8.6956521739%;
    margin-left: 8.115942029%;
    position: relative;
    width: 107%;
  }
  .members .p_profile .position {
    font-size: 1.0666666667vw;
    line-height: 1.5;
    letter-spacing: 0.05vw;
  }
  .members .p_profile .name {
    font-size: 1.7333333333vw;
    line-height: 1.7777777778;
    margin-top: 0.4vw;
    letter-spacing: 0;
    position: relative;
  }
  .members .p_profile .name span {
    font-size: 1.7333333333vw;
    display: block;
    color: #a9a9a9;
    margin-top: -3.9682539683%;
    margin-left: 0;
  }
  .members .p_profile .name::after {
    position: absolute;
    content: "";
    top: 6.1333333333vw;
    bottom: 0;
    left: 0;
    width: 0;
    height: 0.1333333333vw;
    margin-bottom: -5.8666666667vw;
    background-color: #e60012;
  }
  .members .p_profile .prof_txt {
    margin-top: 11.5942028986%;
    /*width: calcPerSp(65, 345);*/
    font-size: 0.96vw;
    line-height: 1.7916666667;
    letter-spacing: 0.1vw;
  }
  .members .p_profile .prof_add {
    margin-top: 4.347826087%;
    margin-left: 6.3768115942%;
    width: 79.7101449275%;
    font-size: 0.8533333333vw;
    line-height: 1.7;
    letter-spacing: 0.05vw;
    list-style-image: url("../images/about-us/mrk_line.png");
  }
  .members .p_profile.animated .name::after {
    width: 5.8666666667vw;
  }
  .history {
    padding-top: 1.8666666667vw;
    margin-bottom: 5.8666666667vw;
  }
  .history .box {
    position: relative;
    top: 41.6%;
    padding-bottom: 0;
    height: 6.6666666667vw;
  }
  .history .box .bg-txt-lft,
.history .box .bg-txt-rgt {
    font-size: 15.2vw;
    line-height: 0.62;
    color: #f6f6f6;
    position: absolute;
    top: -4vw;
    left: -1.1vw;
    z-index: -5;
  }
  .history .box .txt-wrap h2 {
    font-size: 3.2vw;
    color: #e60012;
    margin-left: 10.9333333333%;
    padding-top: 0.8333333333%;
    padding-bottom: 0.6944444444%;
    position: relative;
    letter-spacing: -0.01vw;
  }
  .history .box .txt-wrap h2 span {
    -webkit-clip-path: inset(100% 0 0 0);
            clip-path: inset(100% 0 0 0);
    transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
    transition-property: -webkit-clip-path;
    transition-property: clip-path;
    transition-property: clip-path, -webkit-clip-path;
  }
  .history .box .txt-wrap h2 .jp-sub {
    font-size: 1.3333333333vw;
    color: #202020;
    display: inline-block;
    margin-left: 1.3333333333%;
  }
  .history .box .txt-wrap h2.animated span {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
  .history .box .txt-wrap h2.animated::before {
    width: 100%;
  }
  .history .box .txt-wrap h3 {
    margin-top: 81.6%;
    margin-left: 11.7333333333%;
    position: relative;
  }
  .history .box .txt-wrap h3 span {
    -webkit-clip-path: inset(100% 0 0 0);
            clip-path: inset(100% 0 0 0);
    transition: 1.6s cubic-bezier(0.16, 1, 0.3, 1);
    transition-property: -webkit-clip-path;
    transition-property: clip-path;
    transition-property: clip-path, -webkit-clip-path;
  }
  .history .box .txt-wrap h3::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    padding-top: 0.6042296073%;
    margin-top: 34.1389728097%;
    background-color: #e60012;
    transition: width 0.6s 0.5s;
  }
  .history .box .txt-wrap h3 + p {
    margin-top: 13.3333333333%;
    margin-left: 11.7333333333%;
    margin-right: 8%;
    opacity: 0;
    transform: translateY(13.3333333333vw);
    transition: transform 1s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.7s;
  }
  .history .box .txt-wrap h3 + p.animated {
    opacity: 1;
    transform: none;
  }
  .history .box .txt-wrap h3.animated span {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
  .history .box .txt-wrap h3.animated::after {
    width: 17.2205438066%;
  }
  .history .box .txt-wrap .link-btn {
    margin-top: 11.4666666667vw;
    margin-left: 11.7333333333vw;
  }
  .history .container {
    width: 77.8666666667%;
    margin: 0 auto;
  }
  .history .container ul {
    list-style: none;
    border-bottom: solid 1px #ddd;
  }
  .history .container ul li {
    border-top: solid 1px #ddd;
  }
  .history .container ul li .period {
    position: relative;
  }
  .history .container ul li .period h3 {
    color: #e60012;
    font-family: "Barlow Condensed", sans-serif;
    font-size: 2.5066666667vw;
    font-weight: 300;
    letter-spacing: 0.05vw;
    padding: 1.2% 2.1333333333%;
    cursor: pointer;
  }
  .history .container ul li .period h3::before, .history .container ul li .period h3::after {
    position: absolute;
    content: "";
    width: 1.3333333333vw;
    height: 0.1333333333vw;
    background-color: #e60012;
  }
  .history .container ul li .period h3::before {
    top: 48%;
    right: 1.7333333333vw;
    transform: rotate(0deg);
  }
  .history .container ul li .period h3::after {
    top: 48%;
    right: 1.7333333333vw;
    transform: rotate(90deg);
  }
  .history .container ul li .period.close h3::after {
    transform: rotate(0deg);
  }
  .history .container ul li .timeline {
    position: relative;
    border-top: solid 1px #ddd;
    margin-bottom: 5.0666666667vw;
  }
  .history .container ul li .timeline .his_unit {
    display: flex;
  }
  .history .container ul li .timeline p {
    padding: 3.0666666667% 1.8666666667% 0;
    font-size: 1.12vw;
    width: 77%;
  }
  .history .container ul li .timeline .y_m {
    width: 11.25vw;
    height: 2.4vw;
    margin-top: 2.2666666667vw;
    padding: 0 0vw 0 5.4861111111vw;
    font-family: "Barlow Condensed", sans-serif;
    font-size: 1.5277777778vw;
    line-height: 1.4;
    border-right: solid 1px #ddd;
  }
  .history .container ul li .timeline a {
    color: #000;
    text-decoration: underline;
  }
  .history .container ul li .timeline a:visited {
    color: #000;
  }
  .history .container ul li .timeline a:hover {
    color: #e60012;
  }
  .history .container ul li .timeline a:hover::after {
    transform: translateX(1.3333333333vw) translateY(-50%) rotate(135deg);
  }
  .history .container ul li .acd-content {
    display: none;
  }
}
/*20240705*/
@media screen and (min-width: 769px) {
.members .box .txt-wrap h2 {
  line-height: 1;
}
}

/*# sourceMappingURL=about-us.css.map */