@charset "UTF-8";
body {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Noto Sans JP', sans-serif;
}
.hero::after{
  background: url("../img/p2.svg") top/cover no-repeat;
    position:absolute;
    content: "";
    top:17%;
    left:0;
    width:100%;
    height:83%;
    opacity:1;
    z-index:-1;
}
.hero-wrap__logo {
    position: relative;
    display:flex;
    justify-content: space-between;
    z-index: 10;
    padding:15px 15px 0 15px;
}
.logo__right {
    width: 70px;
}
.logo__right img {
    width: 100%;
}
.logo__left {
    background: white;
    aspect-ratio: 1/1;
    border: 2px solid #1A1311;
    text-align: center;
    z-index: 100;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    width:85px;
    height:80px;
}
.logo__left h2 {
    font-size: 16px;
    font-weight: 700;
    margin-bottom:5px;
}
.logo__left p {
    font-size: 8px;
    font-weight: 700;

}
.hero {
    position: relative;
    width: 100%;
  }
.hero::before {
    content: "";
    position: absolute;
    inset: 0; /* top, right, bottom, left: 0 と同じ */
    background: url("../img/top.svg") center/cover no-repeat;
    opacity: 0.2;          /* ← ここで背景だけ薄くできる */
    z-index: -1;           /* ← 中身より後ろに */
  }
  
  .hero__images {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0;
    width: 98%;
    margin: -30px auto 0 auto; 
  }
  
  .hero__images .img {
    box-shadow: 6px 4px 4px rgba(116, 116, 116, 0.5); ;
    -o-object-fit: cover;
       object-fit: cover;
    position: relative;
    width:100%;
  }
  
  .i1 { bottom: -50px; 
    position: relative; 
    left:25px;
    z-index: 1;

}
  .i2 { bottom: 0;
    left:15px; 
    z-index: 2;
    position: relative; }
  .i3 { bottom: -30px;     
    position: relative;
    z-index: 10;
 }
  .i4 { bottom: 0;
    right:10px;
     position: relative; 
     z-index: 2;
    }
  .i5 { bottom: -50px;
    right:15px;
     position: relative; 
     z-index: 3;
    }
  
  .hero__center {
    position: absolute;
    top: 25%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: white;
    width:372px;
    aspect-ratio: 1/1;
    height:372px;
    border: 5px solid #1A1311;
    text-align: center;
    z-index: 100;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
  }
  .hero__center h2 {
    font-size: 64px;
    font-weight: 700;
    margin-bottom:10px;
}
.hero__center p {
    font-size: 32px;
    font-weight: 700;

}
  .__inner {
    max-width: 1100px;
    margin: 0 auto;
  }
  .head {
    font-size: 32px;
    font-weight: 700;
  }
.txt {
    max-width:610px;
    font-size: 18px;
  line-height: 1.8;
  font-weight: 500;
  }
  .slant-bar {
  margin: 2vw 0 2.5vw 0;        
  width: 150px;        
  height: 10px;          
  background: #C4151C;
          -webkit-clip-path: polygon(
    0 0,        /* 左上：水平にする */
    100% 0,     /* 右上：水平にする */
    100% 80%,   /* 右下：斜め位置 */
    0 100%      /* 左下：垂直 */
  );
                  clip-path: polygon(
    0 0,        /* 左上：水平にする */
    100% 0,     /* 右上：水平にする */
    100% 40%,   /* 右下：斜め位置 */
    0 100%      /* 左下：垂直 */
  );

}
.about-wrap {
    padding: 220px 0 190px 0;
}
.voice {
   background-image: url("../img/p1.svg");
  background-size: cover;
  background-position: bottom;
  background-repeat: no-repeat;
  position: relative;
  overflow: hidden;    
}
.voice-wrap{
    padding: 12.5vw 0;
}
.slant-barwhite {
  margin: 2vw 0.2vw 2.5vw 0.2vw;
  width: 100px;         
  height: 6.67px;           
  background: #fff;
          -webkit-clip-path: polygon(
    0 0,        /* 左上：水平にする */
    100% 0,     /* 右上：水平にする */
    100% 80%,   /* 右下：斜め位置 */
    0 100%      /* 左下：垂直 */
  );
                  clip-path: polygon(
    0 0,        /* 左上：水平にする */
    100% 0,     /* 右上：水平にする */
    100% 40%,   /* 右下：斜め位置 */
    0 100%      /* 左下：垂直 */
  );
}
.slant-barnext {
    margin: 1.5vw 0.2vw 2vw 0.2vw;
    width: 100px;         
    height: 6.67px;           
    background: #C4151C;
            -webkit-clip-path: polygon(
      0 0,        /* 左上：水平にする */
      100% 0,     /* 右上：水平にする */
      100% 80%,   /* 右下：斜め位置 */
      0 100%      /* 左下：垂直 */
    );
                    clip-path: polygon(
      0 0,        /* 左上：水平にする */
      100% 0,     /* 右上：水平にする */
      100% 40%,   /* 右下：斜め位置 */
      0 100%      /* 左下：垂直 */
    );
}
.title {
    font-family: "Roboto", sans-serif;
    font-size:120px;
    font-weight: 700;
}
.voice-wrap__body__left {
    width: 60%;
}
.voice-wrap__title {
    color:#fff;
}
.voice-wrap__body {
  display:flex;
  justify-content: space-between;
  color:#F8F8F8;
  width:98%;
  margin:2vw auto 0 auto;
}
.voice-wrap__body__left__name {
    margin-bottom:2.5vw;
  font-size:24px;
  font-weight:bold;

}
.voice-wrap__body__left p small {
  font-size:14px;
}
.voice-wrap__body__left__sns {
    margin-top: 1vw;
}
.voice-wrap__body__left__sns a  {
  position: relative;
  display: inline-block;
  font-family: Arial, Helvetica, sans-serif;
  color:#fff;
  text-decoration: none;
  margin-left:10px;

}

.voice-wrap__body__left__sns img {
  margin-top:15px;
  width:25px;
  cursor: pointer;
  transition: transform 0.3s ease;
}
.voice-wrap__body__left__sns img:hover {
    transform: scale(1.2);
  }
  .voice-wrap__body__left__sns a:first-child {
    margin-left:0;
  }
.next {
  background-image: url("../img/p3.svg");
  background-size: cover;
  background-position: center;
  position: relative;
}
.next-wrap {
   padding: 13vw 0 20vw 0; 
   position: relative;
   z-index:10 ;
}
.next-wrap__body {
    width:98%;
    display: flex;
  justify-content: space-between;
  margin: 6.3vw auto 0 auto;
  gap:20px;
}
.next-wrap__left {
    width:47%;
}

.logo {
  background-color: #fff;
  margin: 0 auto;
  padding:40px 0;
}
.logo  a {
  display: block;
  width: 120px;
  margin: 0 auto;
}
.logo  a img {
  width: 100%;
}
.copyright {
  font-family: Arial, Helvetica, sans-serif;
  background-color: #C4151C;
  color: #fff;
  text-align: center;
  padding: 30px 0;
  font-size: 14px;
}
.bg1 {
    font-family: Roboto, sans-serif;
    color: #888888;
    position:absolute;
    font-size:13px;
    z-index:99999;
    background-color: #fff;
    padding:19px 6px;
    top:20%;
    left:0;
    z-index: 1000;
    border:solid 2px #888888;
}
.next-bg {
    position: absolute;
    inset: 0;              /* top:0; right:0; bottom:0; left:0; */
    z-index: 1;
    pointer-events: none;  /* クリックジャマしない */
  }
  
  /* ★ bg共通の仕様（あなたの指定をベースに vw 化） */
  .next-bg .bg1,
  .next-bg .bg2,
  .next-bg .bg3,
  .next-bg .bg4,
  .next-bg .bg5,
  .next-bg .bg6,
  .next-bg .bg7 {
        font-family: Roboto, sans-serif;
        color: #888888;
        position: absolute;
        background-color: #fff;
        border: solid 2px #888888;
        font-size: 13px;
        box-sizing: border-box;
        display: flex;
        justify-content: center;
        align-items: center;
        text-align: center;
        z-index: -1;   
        pointer-events: none; 
        font-weight: bold;
  }
.bg1 {
    width: 51px;   
    height: 51px; 
    top: 11%; 
    left: 6%; 
}
.bg2 { 
     width: 70px;   
    height: 70px; 
    top: 75%; 
    left: 11%; 
}
.bg3 {  
    width: 100px;   
    height: 100px; 
    top: 80%; 
    left: 28%; 
}
.bg4 { 
    width: 70px;   
    height: 70px; 
    top:8%; 
    left: 62%; 
}
.bg5 { 
    width: 53px;   
    height: 53px; 
    top: 68%; 
    right: 39%; 
}
.bg6 { 
    width: 61px;   
    height: 61px; 
    top: 14%; 
    right: 14%; 
}
.bg7 { 
    width: 
    65px;   
    height: 65px; 
    top: 57%;
    right: 5%; 
    transform: translateX(-50%); 
}
.js-slide-left {
    position: relative;
    opacity: 0;
    transform: translate3d(-60px, 0, 0) skewX(3deg);
    -webkit-filter: blur(6px);
            filter: blur(6px);
    transition:
      opacity 1s ease,
      transform 1s cubic-bezier(0.19, 1, 0.22, 1),
      -webkit-filter 1s ease;
    transition:
      opacity 1s ease,
      transform 1s cubic-bezier(0.19, 1, 0.22, 1),
      filter 1s ease;
    transition:
      opacity 1s ease,
      transform 1s cubic-bezier(0.19, 1, 0.22, 1),
      filter 1s ease,
      -webkit-filter 1s ease;
  }
  .js-slide-left.is-show {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    -webkit-filter: blur(0);
            filter: blur(0);
  }
  .next-wrap__right {
    width: 47%;
  }
  .video-wrapper {
    width: 550px;
    height: auto;
  }
    .video-wrapper video {
        width: 100%;
        height: auto;
        display: block;
    }
    .voice-wrap__body__left__topsp__bottom {
        display: none;
    }
    .next-wrap__left__pro {
        width:100%;
    }
    .nexttxt--comingsoon  {
        font-size: 24px;
        font-weight: 500;
    }
    .name {
        font-size: 28px;
        margin: 20px 0;
        font-weight: 500;
    }
    .company {
        font-size:20px;
        margin: 20px 0;
        font-weight: 500;
    }
    .url  a{
        color:#1A1311;
        font-size:16px;
        margin: 20px 0;
        font-weight: 500;
    }
@media (max-width:1180px){

    .about-wrap {
        padding: 220px 0 220px 0;
    }
    .voice-wrap__body__right {
        width:40%;
    }
    .voice-wrap__body__left {
        width: 55%;
    }
    
    
    .voice-wrap__body__right img {
        width:100%;
        margin:0 auto;
        display:block;
    }
    .hero__center {
        top: 23%;
        left: 50%;
        width:clamp(15.625rem, 4.8295rem + 22.7273vw, 18.75rem);;
        height:clamp(15.625rem, 4.8295rem + 22.7273vw, 18.75rem);
        border: 5px solid ;
        z-index: 100;
      }
      .hero__center h2 {
        font-size: 54px;
        font-weight: 700;
        margin-bottom:10px;
    }
    .hero__center p {
        font-size: 28px;
    
      }
      .__inner {
        max-width: 980px;
        margin: 0 auto;
      }
      .title {
        font-size: 100px;
    }
      .head {
        font-size: 28px;
      }
      .txt {
        font-size: 18px;
    }
    .bg1 {
        width: 51px;   
        height: 51px; 
        top: 3%; 
        left: 6%; 
    }
}
@media (max-width:980px){
    
    .i1 { 
        bottom: -40px; 
        position: relative; 
        left:25px;
        z-index: 1;
    
    }
    .i5 {
        bottom: -35px;
    }
    .hero__center {
        top: 28%;
        left: 50%;
        width: clamp(15.625rem, -13.5417rem + 166.6667vw, 18.75rem);;
        height: clamp(15.625rem, -13.5417rem + 166.6667vw, 18.75rem);
        border: 5px solid #1A1311;
        z-index: 100;
    }
    .hero::after{
        background: url("../img/p2.svg") top/cover no-repeat;
          position:absolute;
          content: "";
          top:14%;
          left:0;
          width:100%;
          height:86%;
          opacity:1;
          z-index:-1;
      }
    .about-wrap {
        padding: 220px 0 240px 0;
    }
    .title {
        font-size: 72px;
    }
    .txt {
        font-size: 16px;
    }
    .__inner {
        max-width: 700px;
        margin: 0 auto;
      }
      .voice-wrap__body {
        display: flex;
        justify-content: space-between;
        color: #F8F8F8;
        width: 98%;
        margin: 50px auto 0 auto;
        gap:0;
    }
    .voice-wrap {
        padding: 140px 0 140px 0;
    }
    .voice-wrap__body__left {
        width: 60%;
    }
    .voice-wrap__body__right img {
        width:100%;
        margin:0 auto;
        display:block;
    }
    .next-wrap__body {
        flex-direction: column;
        gap:20px;
    }
    .voice-wrap__body__right {
        width: 35%;
    }
    .next-wrap__right {
        width: 100%;
      }
      .head {
        font-size: 24px;
      }
      .voice-wrap__body__left__name {
        margin-bottom: 2vw;
        font-size: 20px;
    }
    .slant-barwhite {
        margin: 2vw 0.2vw;
        width: 80px;
    height: 6px;
    }
    .slant-bar {
        margin: 20px 0;
        width: 100px;
        height: 6px;
        background: #C4151C;
    }
    .next-wrap__body {
        width: 98%;
        display: flex;
        justify-content: space-between;
        margin: 4vw auto 0 auto;
    }
    .next-wrap {
        padding: 80px 0 80px 0;
        position: relative;
        z-index: 10;
    }
    .next-bg .bg1,
    .next-bg .bg2,
    .next-bg .bg3,
    .next-bg .bg4,
    .next-bg .bg5,
    .next-bg .bg6,
    .next-bg .bg7 {
          font-family: Roboto, sans-serif;
          color: #888888;
          position: absolute;
          background-color: #fff;
          border: solid 2px #888888;
          font-size: 10px;
          box-sizing: border-box;
          display: flex;
          justify-content: center;
          align-items: center;
          text-align: center;
          z-index: -1;   
          pointer-events: none; 
          font-weight: bold;
    }
    .bg1 {
        width: 41px;   
        height: 41px; 
        top: 20%; 
        left:60%; 
    }
    .bg2 { 
         width: 60px;   
        height: 60px; 
        top: 67%; 
        left: 11%; 
    }
    .bg3 {  
        width: 90px;   
        height: 90px; 
        top: 56%; 
        left: 28%; 
    }
    .bg4 { 
        width: 60px;   
        height: 60px; 
        top:8%; 
        left: 62%; 
    }
    .bg5 { 
        width: 43px;   
        height: 43px; 
        top: 68%; 
        right: 39%; 
    }
    .bg6 { 
        width: 51px;   
        height: 51px; 
        top: 14%; 
        right: 14%; 
    }
    .bg7 { 
        width: 
        55px;   
        height: 55px; 
        top: 57%;
        right: 5%; 
        transform: translateX(-50%); 
    }
    .next-wrap__left {
        width:100%;
    }
    .video-wrapper {
        width: 100%;
    }
    .name {
        font-size: 20px;
    }
    .company {
        font-size: 18px;
    }
    .nexttxt {
        font-size: 14px;
    }
    .url a {
        font-size: 14px;
        font-weight: 400;
    }
}
@media (max-width:760px){
    .hero__center {
        top: 20%;
        left: 50%;
        width: 240px;
        height: 240px;
        border: 4px solid #1A1311;
        z-index: 100;
    }
    .hero__center h2 {
        font-size: 48px;
        font-weight: 600;
    }
    .hero__center p {
        font-size: 24px;
    }
    .hero-wrap__logo img {
        width:100%;
    }
    .__inner {
        width:95%;
        margin: 0 auto;
    }
    .logo a {
        display: block;
        width: 160px;
        margin: 0 auto;
    }
    .logo {
        padding: 25px 0;
    }
    .voice-wrap {
        padding: 70px 0 50px 0;
    }
    .logo__left {
        width: 60px;
        height: 55px;
    }
    .logo__left h2 {
        font-size: 12px;
        font-weight: 600;
    }
    .logo__left p {
        font-size: 6px;
        font-weight: 600;
    }
    .voice-wrap__body__right {
        display:none;
    }
    .voice-wrap__body__left__topsp__bottom {
        display: block;
        width:40%;
    }
    .voice-wrap__body__left__top {
        display: flex;
        flex-direction: row-reverse;
        gap: 40px;
        justify-content: flex-end;
        margin-bottom: 40px;
    }
    .voice-wrap__body__left__topsp__top {
        justify-content: center;
        display: flex;
        flex-direction: column;
        width: 60%;
    }
    .voice-wrap__body__left {
        width: 100%;
    }
    .voice-wrap__body__left__topsp__bottom img {
        width:100%;
        margin:0;
        display:block;
}
.nexttxt--comingsoon  {
    font-size: 18px;
    font-weight: 400;
}
}
@media (max-width:620px){
    .hero-wrap__logo {
        position: relative;
        display: flex;
        justify-content: space-between;
        z-index: 10;
        padding: 10px 10px 0 10px;
    }
    .about-wrap {
        padding: 140px 0 150px 0;
    }
    .hero__images {
        width:100%;
        margin: -25px auto 0 auto;
    }
    .hero__center {
        top: 22%;
        left: 50%;
        width: 180px;
        height: 180px;
    }
    .i1 {
        bottom: -35px;
        position: relative;
        left: 20px;
        z-index: 1;
    }
    .i2 { 
        bottom: 0;
        left:15px; 
        z-index: 2;
        position: relative; 
    }
      .i3 { 
        bottom: -20px;     
        position: relative;
        z-index: 10;
     }
      .i4 { 
        bottom: -0;
        right:10px;
         position: relative; 
         z-index: 2;
        }
      .i5 { 
        bottom: -45px;
        right:10px;
         position: relative; 
         z-index: 3;
        }
        .hero__center h2 {
            font-size: 36px;
            font-weight: 600;
        }
        .hero__center p {
            font-size: 20px;
        }
        .next-wrap__left {
            width:100%;
        }
        .next-bg .bg1,
    .next-bg .bg2,
    .next-bg .bg3,
    .next-bg .bg4,
    .next-bg .bg5,
    .next-bg .bg6,
    .next-bg .bg7 {
        display: none;
    }
    .voice-wrap {
        padding: 60px 0 60px 0;
    }
    .voice-wrap__body {
        flex-direction: column;
        margin: 20px auto 0 auto;
    }
    .voice-wrap__body__right {
        width: 140px;
        position: relative;
    }
    .voice-wrap__body__right img {
        position:absolute;
        top:-30px;
        left: 240px;
    }
    .voice-wrap__body__left {
        width: 100%;
    }
    .slant-barwhite {
        margin: 10px 0.2vw 20px 0.2vw;
        width: 60px;
        height: 6px;
    }
    .voice-wrap__body__left__name {
        font-size: 20px;
        margin-bottom:0;
    }
    .title{
            font-size: 64px;
        }
        .voice-wrap__body__left__top {
            display: flex;
            flex-direction: row-reverse;
            gap:60px;
            justify-content: flex-end;
            margin-bottom:40px;
        }
    .voice-wrap__body__left__topsp {
        display: block;
    }
    .voice-wrap__body__left__topsp__bottom {
        display: block;
        width:35%;
    }
    .voice-wrap__body__left__topsp__bottom img {
        width:100%;
        margin:0;
        display:block;
}
.voice-wrap__body__left__topsp__top {
    justify-content: center;
    display: flex;
    flex-direction: column;
    width:60%;
}
}
@media (max-width:500px){
    .title {
        font-size: 36px;
        font-weight:500;
    }
    .head {
        font-weight:500;
        font-size: 18px;
    }
    .voice-wrap {
        padding: 30px 0 30px 0;
    }
    .voice-wrap__body__left__name {
        font-size: 18px;
    }
    .slant-barwhite {
        margin: 10px 0.2vw 15px 0.2vw;
        width: 60px;
        height: 6px;
    }
    .slant-bar {
        margin: 10px 0 15px 0;
        width: 80px;
        height: 5px;
    }
    .txt {
        font-size: 12px;
        font-weight:500;
    }
    .voice-wrap__body__left__sns {
        font-size:14px;
    }
    .voice-wrap__body__left__sns img {
        margin-top: 10px;
        width:20px;
    }
    .logo {
        padding: 20px 0;
    }
    .logo a {
        display: block;
        width: 80px;
        margin: 0 auto;
    }
    .copyright {
        font-family: Arial, Helvetica, sans-serif;
        background-color: #C4151C;
        color: #fff;
        text-align: center;
        padding: 20px 0;
        font-size: 12px;
    }
    .hero-wrap__logo {
        position: relative;
        z-index: 10;
        padding: 10px 10px 0 10px;
    }
    .hero__center {
        top: 22%;
        left: 50%;
        width: 130px;
        height: 130px;
    }
    .hero__center h2 {
        font-size: 24px;
        font-weight: 600;
    }
    .hero__center p {
        font-size: 14px;
    }
    .voice-wrap__body__left__topsp__bottom {
        width: 45%; 
    }
    .voice-wrap__body {
        margin: 10px auto 0 auto;
    }
    .logo__right {
        width: 60px;
    }
    .about-wrap {
        padding: 140px 0 70px 0;
    }
    .logo__left h2 {
        font-size: 8px;
    }
    .logo__left p {
        font-size: 4px;
        font-weight: 600;
    }
    .logo__left {
        width: 40px;
        height: 36px;
    }
    .i1 {
        bottom: -30px;
        position: relative;
        left: 15px;
        z-index: 1;
    }
    .i2 {
        bottom: 0;
        left: 5px;
        z-index: 2;
        position: relative;
    }
    .i4 {
        bottom: -0;
        right: 5px;
        position: relative;
        z-index: 2;
    }
    .i5 {
        bottom: -30px;
        right: 10px;
        position: relative;
        z-index: 3;
    }
    .voice-wrap__body__left__top {
        margin-bottom: 20px;
    }
    .next-wrap {
        padding: 50px 0 50px 0;
    }
    .txt {
        line-height: 1.6;
    }
    .slant-barnext {
        margin: 2vw 0.2vw 2.5vw 0.2vw;
        width: 60px;
        height: 5px;
    }
    .name {
        font-size: 16px;
    }
    .company {
        font-size: 16px;
    }
    .nexttxt {
        font-size: 12px;
    }
    .url a {
        font-size: 12px;
        font-weight: 400;
    }
}