@charset "UTF-8";
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated:  2010-09-17
Author:  Richard Clark - http: //richclarkdesign.com
Twitter:  @rich_clark
*/
@import url("https://fonts.googleapis.com/css2?family=Cantarell:wght@700&family=Oswald:wght@400;500;700&display=swap");
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-font-variant-ligatures: none;
          font-variant-ligatures: none;
  -webkit-text-size-adjust: 100%;
}

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i, dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  text-decoration: none;
  color: #000;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

main {
  display: block;
}

img {
  vertical-align: bottom;
  max-width: 100%;
}

img[src$=".svg"] {
  display: block;
  width: 100%;
  height: auto;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}





/* FONT
***************************************************************/
/* コンセプト　PC/*
***************************************************************/

.mvWrap {
    margin-top:150px;
    margin-bottom:0;
  
}
.slider-container {
  width:100%;
 height: 1400px;
 overflow: hidden;
  position: relative;
}

.slider-track {
  width: 7600px; /* 2500px x 2枚 */
  height: 100%;
  background: url('../img/concept_mv_bg.png') repeat-x;
  background-size: 3800px auto;/* 元画像のサイズに一致 */
  animation: slideLoop 50s linear infinite;
}

@keyframes slideLoop {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-2500px); /* ちょうど1枚分ずらす */
  }
}


.mvWrap .inner {
  width: 1200px;
  margin: auto;
}


 .centered {
    position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      background-color: rgba(255, 255, 255, 0.9); /* 白の半透明 */
      padding: 2rem;
      border-radius: 5px;
     width:750px;

        
    }


 .centered-text {
     padding:50px 85px;
      text-align: left;
      font-size:44px;
     line-height: 1.4;
     font-family: 'Zen Kaku Gothic Antique', sans-serif;
     font-weight:bold;
     
      }

.centered-text span{
    color:#26B3BF;
   font-family:'Montserrat', sans-serif;
    font-size:99px; 
     display: inline-block;
    font-weight: 700;
 
    
}

.centered-text span2{
    font-size:53px; 
    font-weight:bold;
    
}


.centered ul.prologue{
    padding:0 0 0 85px;
   
   
    
}

.centered ul.prologue li{
     text-align: left;
      font-size:18px;
    vertical-align: baseline;
     line-height: 1.7;
     font-family: 'Noto Sans JP', sans-serif;
     font-weight:bold;
    display: flex;
  align-items: center;  /* ← これがポイント！ */
}


.centered ul.prologue li span{
    color:#26B3BF;
   font-family:'Montserrat', sans-serif;
    font-size:32px; 
     display: inline-block;
    font-weight: 700;
    margin-right:20px;
 
    
}


.centered p.explanation{
    text-align: left;
     padding:0 0 0 85px;
    margin-top:50px;
      font-size:18px;
     line-height: 2.8;
     font-family: 'Noto Sans JP', sans-serif;
     font-weight:bold;
   
}



.centered p.explanation span{
    color:#26B3BF;
   font-family:'Montserrat', sans-serif;
    font-size:32px; 
     display: inline-block;
    font-weight: 700;
   
}


.centered p.explanation span::before {
  content: '「';
  font-size:30px; /* 親と同じサイズにする */
  font-family: inherit; /* 親と同じフォントにする */
  color: #000000; /* 親と同じ色にする（必要なら変更可） */
}



.centered p.explanation span::after {
    content: '」';
  font-size:30px; /* 親と同じサイズにする */
  font-family: inherit; /* 親と同じフォントにする */
  color: #000000; /* 親と同じ色にする（必要なら変更可） */
}



/* <----------------------コンセプト　PC end---------------------->*/


/* <----------------------コンセプト　sp ---------------------->*/


@media all and (max-width: 680px) {
.mvWrap {
    margin-top:100px;
    margin-bottom:0;
  
}
.slider-container {
  width: 100%;
  height: 1000px;
  overflow: hidden;
  position: relative;
}

.slider-track {
  width: 200%; /* ← スマホ幅に合わせて動的に */
  height: 100%;
  background: url('../img/concept_mv_bg_sp.png') repeat-x;
  background-size: contain; /* or 100% auto; */
  animation: slideLoop 30s linear infinite;
}

@keyframes slideLoop {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%); /* ← ちょうど半分動かす（repeat-xでループ） */
  }
}
    
    
.mvWrap .inner {
  width: 100%;
  margin:0 auto;
}
    
 
 .centered {
    position: absolute;
      top:3%;
      left: 50%;
      transform: translate(-50%);
      background-color: rgba(255, 255, 255, 0.9); /* 白の半透明 */
      padding: 1rem;
      border-radius: 5px;
     width:84%;

        
    }


 .centered-text {
     padding:10px 10px;
      text-align: left;
      font-size:21px;
     line-height: 1.4;
     font-family: 'Zen Kaku Gothic Antique', sans-serif;
     font-weight:bold;
     
      }

.centered-text span{
    color:#26B3BF;
   font-family:'Montserrat', sans-serif;
    font-size:51px; 
     display: inline-block;
    font-weight: 700;
 
    
}

.centered-text span2{
    font-size:25px; 
    font-weight:bold;
    
}


.centered ul.prologue{
    padding:0 0 0 5px;
   
   
    
}   
    
    
 .centered ul.prologue li{
     text-align: left;
      font-size:15px;
    vertical-align: baseline;
     line-height: 1.7;
     font-family: 'Noto Sans JP', sans-serif;
     font-weight:bold;
    display:block;
  align-items: center;  /* ← これがポイント！ */
}


.centered ul.prologue li span{
    color:#26B3BF;
   font-family:'Montserrat', sans-serif;
    font-size:24px; 
     display: inline-block;
    font-weight: 700;
    margin-right:5px;
 
    
}


.centered p.explanation{
    text-align: left;
     padding:0 0 0 5px;
    margin-top:50px;
      font-size:15px;
     line-height: 2.0;
     font-family: 'Noto Sans JP', sans-serif;
     font-weight:bold;
   
}



.centered p.explanation span{
    color:#26B3BF;
   font-family:'Montserrat', sans-serif;
    font-size:24px; 
     display: inline-block;
    font-weight: 700;
   
}


.centered p.explanation span::before {
  content: '「';
  font-size:30px; /* 親と同じサイズにする */
  font-family: inherit; /* 親と同じフォントにする */
  color: #000000; /* 親と同じ色にする（必要なら変更可） */
}



.centered p.explanation span::after {
    content: '」';
  font-size:30px; /* 親と同じサイズにする */
  font-family: inherit; /* 親と同じフォントにする */
  color: #000000; /* 親と同じ色にする（必要なら変更可） */
}


  }


/* <----------------------コンセプト　sp end---------------------->*/

/*<---------------section promise PC--------------------->*/
.promise{
    margin-top:2%;
}


.promise .inner {
  width: 1200px;
  margin: auto;
}

.pro_title{
  width: 25%; 
  margin: 5% auto 5% auto;
  position: relative;
  display: block;
  margin: 5% auto;
}

/* 左の角括弧 */
.pro_title::before {
  content: "";
  position: absolute;
  left: -20px;
  top: 0;
  height: 100%;
  width: 20px;
  border-top: 2px solid #000;
  border-left: 2px solid #000;
  border-bottom: 2px solid #000;
}

/* 右の角括弧 */
.pro_title::after {
  content: "";
  position: absolute;
  right: -20px;
  top: 0;
  height: 100%;
  width: 20px;
  border-top: 2px solid #000;
  border-right: 2px solid #000;
  border-bottom: 2px solid #000;
}

.pro_title h1{
    font-family: 'Montserrat';
    font-weight: bold;
    font-size: 32px;
    text-align: center;
    line-height:1.7;
}
.pro_title p{
    font-family: 'Noto Sans JP';
    font-size:18px;
    text-align: center;
    line-height:1.2;
}


.pro_title_sub{
    text-align: center;
    font-size:53px;
     font-family: 'Noto Sans JP';
    font-weight:bold;
}


.pro_title_sub span{
    color:#26BF84;
}


.pro_title_sub span::before {
  content: '“';
  font-size: 1.0em; /* 括弧だけ少し大きくしたい場合 */
  margin-right: 0.1em;
    color:#000000;
}

.pro_title_sub span::after {
  content: '”';
  font-size: 1.0em;
  margin-left: 0.1em;
   color:#000000; 
}




.pro_title_sub span2{
    color:#C78926;
}


.pro_title_sub span2::before {
  content: '“';
  font-size: 1.0em; /* 括弧だけ少し大きくしたい場合 */
  margin-right: 0.1em;
    color:#000000;
}

.pro_title_sub span2::after {
  content: '”';
  font-size: 1.0em;
  margin-left: 0.1em;
   color:#000000; 
}

.pro_title_sub p{
    font-size:32px;
    line-height: 2.3;
    padding-bottom: 5%;
}



/*<---------------section promise end--------------------->*/



/*<---------------section promise SP--------------------->*/


@media all and (max-width: 680px) {

.promise .inner {
  width: 100%;
  margin: auto;
}

.pro_title{
  width: 50%; 
}

.pro_title h1{
    font-size: 28px;
    text-align: center;
 
}
.pro_title p{
    font-size:15px;
}

.pro_title_sub{
    font-size:38px;

}

 .pro_title_sub p{
    font-size:22px;
    
}
   
    
    
    
}
/*<---------------section promise SP end--------------------->*/

/*<---------------section promise_item PC--------------------->*/


.promise_item{
    
}


.promise_item .inner {
  width: 1200px;
  margin: 0 auto;
  margin-bottom: 5%;  
    border-top:5px solid;
    
}

.pro_text{
    width:62%;
    display:inline-block;
    vertical-align: top; /* ← これを追加 */
    margin-top:4%;
}


.pro_img{
    width:35%;
    display:inline-block;
    vertical-align: top; /* ← これを追加 */
    margin-top:4%;
    
}




.number-label {
  display:inline-block;
  align-items: center;
  gap: 10px;
  font-family: 'Montserrat', sans-serif;
}

.number {
  font-size: 50px;
  font-weight: 800;
  color: #111;
}

.slash {
   width: 1px;
  height: 80px;
 position: relative;
    top:35px;
    left:-5px;
  background-color: #111;
  transform: rotate(40deg); /* 明確に斜めに！ */
  display: inline-block;
}

.label {
  font-size: 20px;
  font-weight: 600;
   position: relative;
   top:25px; 
     left:-13px; 
  letter-spacing: 0.05em;
}

.pro_text_main{
    display: inline-block;
      font-family: 'Noto Sans JP';
    vertical-align: top; /* ←追加 */
    font-size:18px;
    margin-left:2%;

}

.pro_text_main span{
    font-size:40px;
    font-weight: bold;
    line-height: 2.0;
}

   .fade-box {
     
      opacity: 0;
     /* animation: fadeInUp 0.8s ease forwards;*/
         transform: translateX(70px);
  transition: opacity 0.8s ease, transform 0.8s ease;
    }

/* 表示されたときに付与される */
.fade-box.in-view {
  opacity: 1;
  transform: translateX(0);
}


    /* アニメーション */
@keyframes fadeInRight {
  0% {
    opacity: 0;
    transform: translateX(70px); /* 右から */
  }
  100% {
    opacity: 1;
    transform: translateX(0); /* 元の位置へ */
  }
}
    /* 各ボックスに時間差を追加 */
    .fade-box:nth-child(1) { animation-delay: 0s; }
    .fade-box:nth-child(2) { animation-delay: 0.3s; }
    .fade-box:nth-child(3) { animation-delay: 0.6s; }
    .fade-box:nth-child(4) { animation-delay: 0.9s; }
    .fade-box:nth-child(5) { animation-delay: 1.2s; }
    .fade-box:nth-child(6) { animation-delay: 1.5s; }



.pro_01{
    padding-top:0;
    padding-bottom:7%;
    border-bottom: 2px solid;
}


.pro_02{
    width:99%;
    margin-top:5%;
    padding-bottom:5%;
    position: relative;
    background-image: radial-gradient(circle, #7b7b7b 1.5px, transparent 1.5px);
  background-position: left bottom;
  background-repeat: repeat-x;
  background-size: 13px 3px;
}

.pro_beside{
    width:27%;
     font-size:20px;
    display: inline-block;
 font-family: 'Noto Sans JP';
    font-weight: bold;
     vertical-align:middle;
    line-height: 1.7;
    
}

.pro_vertical{
      font-size:40px;
    font-weight: bold;
    color:#26BF84;
    vertical-align:middle;
    display: inline-block;
    writing-mode: vertical-rl; 
}



.pro_vertical {
  --ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);

  opacity: 0;
  filter: blur(1em);
  scale: 1.1;
  transition:
    scale 1.8s var(--ease-out-quart),
    opacity 2s var(--ease-out-quart),
    filter 2.2s var(--ease-out-quart);
}

.pro_vertical.isActive {
  opacity: 1;
  filter: blur(0);
  scale: 1;
}




.coment{
    width:62%;
    padding-left:1%;
   display: inline-block; 
    vertical-align:middle; 
       font-size:14px;
    line-height: 1.8;
}


.pro_03{
    width:99%;
    margin-top:5%;
    padding-bottom:5%;
    position: relative;
    
}



.pro_vertical_03{
      font-size:40px;
    font-weight: bold;
    color:#C78926;
    vertical-align:middle;
    display: inline-block;
    writing-mode: vertical-rl; 
}



.pro_vertical_03 {
  --ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);

  opacity: 0;
  filter: blur(1em);
  scale: 1.1;
  transition:
    scale 1.8s var(--ease-out-quart),
    opacity 2s var(--ease-out-quart),
    filter 2.2s var(--ease-out-quart);
}

.pro_vertical_03.isActive {
  opacity: 1;
  filter: blur(0);
  scale: 1;
}



.pro_vertical { transition-delay: 0s; }
.pro_vertical_03 { transition-delay: 0.4s; }



















.banner-group {
  display: flex;
  gap: 20px; /* バナー間のスペース */
}

.banner-button {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  background-color: #000;
  color: #fff;
  font-weight: bold;
  font-size: 15px;
  padding: 10px 12px;
  width: 283px;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  transition: background 0.3s ease;
  border-radius: 4px;
}

.banner-label {
  white-space: nowrap;
}

.banner-arrow {
  display: inline-block;
  transition: transform 0.3s ease;
  font-size: 18px;
  margin-left: auto;
}

.banner-button:hover .banner-arrow {
  transform: translateX(6px);
}


/*<---------------section promise_item end PC--------------------->*/


/*<---------------section promise_item SP--------------------->*/


@media all and (max-width: 680px) {

.promise_item .inner {
  width: 90%;
  margin: 0 auto;
  margin-bottom: 5%;  
    border-top:5px solid;
    
}

.pro_text{
    width:98%;
    display:inline-block;
    vertical-align: top; /* ← これを追加 */
    margin-top:0;
}


.pro_img{
    width:98%;
    display:inline-block;
    vertical-align: top; /* ← これを追加 */
    margin-top:4%;
    
}


.number {
  font-size: 42px;

}

.pro_text_main span{
    font-size:26px;
    
   
}

.pro_text_main{
    font-size:16px;
    margin-top:5%;
}    
    
 .pro_beside{
    width:55%;
     font-size:18px;
    display: inline-block;
 font-family: 'Noto Sans JP';
    font-weight: bold;
     vertical-align:middle;
    line-height: 1.7;
    
}

.pro_vertical{
      font-size:42px;
    font-weight: bold;
    color:#26BF84;
    vertical-align:middle;
    display: inline-block;
    writing-mode: horizontal-tb;
}

.coment{
    width:98%;
    padding-left:1%;
   display: inline-block; 
    vertical-align:middle; 
       font-size:14px;
    line-height: 1.8;
    letter-spacing: -0.05em;
}

    
  .pro_vertical_03{
      font-size:42px;
    font-weight: bold;
    color:#C78926;
    vertical-align:middle;
    display: inline-block;
    writing-mode: horizontal-tb;
}
  
    
.banner-group {
    flex-direction: column;
    gap: 15px; /* スマホ時の縦間隔を少し調整 */
  }

  .banner-button {
    width: 90%; /* スマホ画面の横幅いっぱいにする */
      margin:0 auto;
  }
    


}


/*<---------------section promise_item SP end-------------------->*/




