@charset "UTF-8";

/*
Theme Name: kurokipro
*/

@import url('https://fonts.googleapis.com/css2?family=Anton&family=Noto+Sans+JP:wght@300;400;500;600;700;800;900&family=Roboto:ital,wght@0,100;0,300;0,400;1,400&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP&family=Noto+Serif:ital,wght@0,100..900;1,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Source+Sans+3:ital,wght@0,200..900;1,200..900&display=swap');

:root { 
  --key-Color: #1a2254;
  --blue: #022e78;
  --red: #b30000;
  --corner: 2.46em;
  --row-space : 4.69vw;
  --col-space : 10.2vh;
  --w50-space: 45%;
  --s1-space: 7.5vh;
  --s2-space: 5vh;
  --s3-space: 2.5vh;
  --containner: 1100px;
  --h1 :5.510vw;
  --h2 :5.7083vw;
  --h3 : 3.7rem;
  --h4 : 1.25rem;
  --Text-normal: 16px;
  --navi-ft-size: 1.0rem;
  --flex_hurf : calc(92% / 2);
  --flex_third : calc((100% - 5vw) / 3);
  --flex_third_space : calc((100% - 6%) / 3);
  --flex_fourth : calc((100% - 6%) / 4);
  --flex_five : calc((94% - 6vw) / 5);
  --flex_six : calc(100% / 3);
  --ph_left_img: 50vw;
  --futura: 'futura-pt';
  }
  
  @media screen and (min-width: 768px) and (max-width: 1350px) {
  
    :root { 
      --logo_wide: 200px;
      --nav_ft_size: 16px;
      --row-space : 5vw;
      --negative_margin_bottom: -10vh;
    }
  
  }
  
  @media screen and (min-width: 768px) and (max-width: 1024px) {
  
    :root { 
      --logo_wide: 200px;
      --nav_ft_size: 16px;
      --row-space : 1.5em;
      --col-space : 5vh;
      --s2-space: 3vh;
      --negative_margin_bottom: -10vh;
      --w50-space :100%;
      --ph_left_img: 70vw;
    }
  
  }
  
  @media screen and (max-width: 767px) {
  
    :root { 
      --row-space : 4vw;
      --col-space : 5vh;
      --h1 :10.510vw;
      --h2 :10.7083vw;
      --s1-space: 5vh;
      --s2-space: 2.5vh;
      --s3-space: 1.5vh;
      --Text-normal: 15px;
      --flex_hurf : 100%;
      --flex_third : calc(96% / 2);
      --flex_third_space : calc(100% / 1);
      --flex_fourth : calc((100% - 6%) / 2);
      --flex_five : calc(100% / 1);
      --flex_six : calc(100% / 2);
      --flex_third :100%;
      --sp-none: none;
      --fix_head_margin: 50px;
      --flex_concept01 : calc(100% / 2);
      --flex_concept02 : calc(100% / 2);
      --w50-space: 100%;
      }
  
      .sp-none{
        display:none;
      }
  
  }
  
  
  
  @media screen and (min-width: 768px) {
  
    .br-sp{display:none;}
  
    .pc-none{
    display:none !important;
    }
  }
  
  form a{
    color: var(--key-Color);
  }
  

html {
  scroll-behavior: smooth;
}

body {
  width: 100%;
  font-family: "Noto Sans CJK JP";
  font-size: 1vw;
  letter-spacing: 0.05em;
  color: #010101;
  background:#fff;
}

body{
  --sb-track-color: #e9e9e9;
  --sb-thumb-color: #000000;
  --sb-size: 10px;
  scrollbar-color: var(--sb-thumb-color) 
                   var(--sb-track-color);
}

body::-webkit-scrollbar {
  width: var(--sb-size) 
}

body::-webkit-scrollbar-track {
  background: var(--sb-track-color);
}

body::-webkit-scrollbar-thumb {
  background: var(--sb-thumb-color);
  }
  article.sec-block{
    position: relative;
  }

  article.sec-block:last-child{
    min-height: 125vh;
    position: relative;
    display: flex;
    justify-content: center;
    flex-direction: column;
  }

  .sec-block.news{
    min-height: 50vh;
    background: #fff;
    display: flex;
    justify-content: center;
    flex-direction: column;
  }

  .block-bg {
    transition: all .7s ease;
}

html.active {
  overflow: hidden;
}

main {
  position: relative;
}

img {
  max-width:100%;
}

section {
  width: 100%;
  position: relative;
}

.post_main section:not([class]){
  padding: var(--col-space) var(--row-space);
}


section.news__part{
  background: #fff;
  padding: var(--col-space) var(--row-space);
}

section.news__part .main_container1{
  max-width: 1100px;
  margin: auto;
}

section.news__part h2.center{
  padding: .5em;
  border-top: 1px solid rgba(0,0,0,0.75);
    border-bottom: 1px solid rgba(0,0,0,0.75);
  text-align: center;
  font-weight: 300;
  font-family: "acumin-pro", sans-serif;
  font-size: calc(1.4rem,1.75rem,1.8rem);
}

dl.news{
  display: flex;
  padding: 1em 0;
  border-bottom: 1px solid rgba(0,0,0,0.75);
  margin: 0;
}

dl.news dt{
  padding: 0;
  margin: 0;
  width: 15%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  font-weight: 200;
  font-family:游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif !important;
}

dl.news dd{
  margin: 0;
  padding: 0;
  width: 85%;
  color:#898989;
font-feature-settings: "palt";
}

ul, li {
  list-style: none;
  margin: 0;
  padding: 0;
}

h1, h2, h3, h4, h5, h6, p {
  margin: 0;
}

.mv__caption__wrap{
  display: flex;
  width: 100%;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 1;
  padding-bottom: 2.5vh;
}

h2.en{
  font-family: "acumin-pro", sans-serif;
  font-size: 4.947916666666666vw;
  font-style: normal;
  color:#fff;
  position: relative;
  z-index: 3;
  margin-left: -.5em;
  font-weight: 100;
}

div span.jpn{
  display: block;
  font-size: 1.447916666666666vw;
  font-family:'Noto Sans JP',游ゴシック体, 'Yu Gothic', YuGothic,'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  font-weight: 400;
  margin-top: .5em;
    position: relative;
  z-index: 3;
  margin-left: -1em;
  color:#fff;
}

.title {
  display: flex;
  flex-direction: column;
  position: relative;
}

.title .circle {
      width: 13.020833333333334vw;
    height: 13.020833333333334vw;
    border: 0.5px solid rgba(255,255,255,0.15);
    border-radius: 50%;
    z-index: 0;
    align-items: center;
    aspect-ratio: 1 / 1;
    display: flex
;
    justify-content: center;
}
.title .circle__arrow {
    display: flex
;
    flex-direction: row-reverse;
    overflow: hidden;
    position: relative;
    width: 1.6875em;
    z-index: 1;
}

.title .circle .arrow{
  background: url(../images/arrow.svg)no-repeat;
  background-size: contain;
  width: 30px;
  display: block;
  height: 30px;
  transition: all .3s;
}
.title .circle:hover .arrow{
  margin-right: -.75em;
}

.pulse-btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  cursor: pointer;
  transition: all 0.3s;
}

.pulse-btn img {
  width: 60%;
}

.pulse-btn::before, .pulse-btn::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  border: 0.5px solid rgba(255,255,255,0.25);
  border-radius: 50%;
  box-sizing: border-box;
  pointer-events: none;
}

.pulse-btn:hover {
  box-shadow: 0 0 20px #fff;
  background: rgba(0,0,0,0.115);
  transform: scale(1.1, 1.1);
}

.pulse-btn:hover::before, 
.pulse-btn:hover::after {
  animation: pulsate 2s linear infinite;
}

.pulse-btn:hover::after {
  animation-delay: 1s;
}

@keyframes pulsate {
  0% {
    transform: scale(1);
    opacity: 1;
  }

  100% {
    transform: scale(2);
    opacity: 0;
  }
}

@media screen and (max-width: 768px) {
  .pulse-btn {
    box-shadow: 0 0 20px #fff;
  }

  .pulse-btn::before, .pulse-btn::after {
    animation: pulsate 2s linear infinite;
  }

  .pulse-btn::after {
    animation: pulsate 2s linear infinite;
  }
}

.pulse-btn-center {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  padding:6px;
  cursor: pointer;
  transition: all 0.3s;
  color:#9cb1db;
  font-weight: bold;
  margin: 1em auto 0;
}

.pulse-btn-center .Inner{
font-family: 'Franklin Gothic Medium', 'Arial Narrow', Arial, sans-serif;
  background-color: #9cb1db;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
}

.pulse-btn-center::before, .pulse-btn-center::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  border: 1px solid #7597da;
  border-radius: 50%;
  box-sizing: border-box;
  pointer-events: none;
}

.pulse-btn-center:hover {
  box-shadow: 0 0 20px #9cb1db;
}

.pulse-btn-center:hover::before, 
.pulse-btn-center:hover::after {
  animation: pulsate 2s linear infinite;
}

.pulse-btn-center:hover::after {
  animation-delay: 1s;
}

@keyframes pulsate {
  0% {
    transform: scale(1);
    opacity: 1;
  }

  100% {
    transform: scale(2);
    opacity: 0;
  }
}

.pulse-btn-pformance{
  position: relative;
}

.pulse-btn-pformance::before, .pulse-btn-pformance::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  border: 1px solid rgba(0, 0, 0, 0.25);
  border-radius: 50%;
  box-sizing: border-box;
  pointer-events: none;
}

.pulse-btn-pformance:hover {
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
}

.pulse-btn-pformance:hover::before, 
.pulse-btn-pformance:hover::after {
  animation: pulsate 2s linear infinite;
}

.pulse-btn-pformance:hover::after {
  animation-delay: 1s;
}

@keyframes pulsate {
  0% {
    transform: scale(1);
    opacity: 1;
  }

  100% {
    transform: scale(2);
    opacity: 0;
  }
}


@media screen and (max-width: 768px) {
  .pulse-btn-center {
    box-shadow: 0 0 20px #e4e9f6;
  }

  .pulse-btn-center::before, .pulse-btn-center::after {
    animation: pulsate 2s linear infinite;
  }

  .pulse-btn-center::after {
    animation: pulsate 2s linear infinite;
  }
}


h2.text {
  overflow: hidden; /* 1つ目の影を隠す */
  color: transparent; /* テキスト本体は透明にする */
  /*
   影の設定
   1つ目：Y方向の位置にマイナスに設定してテキスト本体の上に配置、ぼかしなし
   2つ目：位置はテキスト本体と同じ、ぼかしなし
  */
  text-shadow: 0 -1.5em 0 #fff, 0 0 0 #fff;
  transition: text-shadow 0.5s;
}

.mv__caption__wrap .title:hover h2.text {
  text-shadow: 0 0 0 #fff, 0 1.5em 0 #fff; /* 2つの影の位置を上方向に1.5emずつずらす */
}

.mv__caption__wrap .title{
  display: flex;
  flex-direction: row-reverse;
  row-gap: 1em;
  margin-left: auto;
  align-items: center;
  padding-right: var(--row-space);
}

h3{
  font-weight: normal;
  font-size: 1.25rem;
}

h4{
  font-size: var(--h4);
  font-weight: bold;
  margin-bottom: .5em;
  color:var(--blue);
}

a {
  text-decoration: none;
  transition: 0.4s;
}


p{
  font-size: 1.0rem;
  line-height: 1.9;
  color:#121212;
}

p:not(:last-child){
  margin-bottom: 1em;
}

p.Center{
  text-align: center;
}

p.bold{
  font-weight: bold;
}

p.mt{
  margin-top: var(--s2-space);
}

.pc {
  display: block;
}

.sp {
  display: none;
}

* {
  margin: 0;
  padding: 0;
}

.main_container {
  max-width: 93.75vw;
  padding: 0 50px;
  margin: auto;
}

.main_container1 {
  width:100%;
  max-width: 1350px;
  padding: 0;
  margin:0 auto;
}

.main_container1 + .main_container1{
  margin-top: var(--col-space);
}

.main_container1.full{
  max-width:100%;
}

.main_container2 {
  padding: 0;
  margin: auto;
  position: relative;
  z-index: 1;
}

.main_container2.sec{
  max-width: 1000px;
  margin: var(--col-space) auto 0;
}

.main_container2.sec.mt_none{
  margin-top: 0;
}

.main_container2.flex{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.main_container2.flex h2{
  width:35%;
  padding-right: 5%;
}

.main_container2.flex .contents{
  width:65%;
}

/* アニメーション */

.sitename{
  color:var(--sb-thumb-color);
  font-family: "goudy-old-style", serif;
  font-weight: 400;
  letter-spacing: 0.08em;
  font-size: 46px;
}

.sitename span{
  opacity: 0;
  position:relative;
  transition: all .3s;  
}
@keyframes showtext{
  0%{
      opacity: 0;
      bottom:-60px;
      filter: blur(4px);
  }
  100%{
      opacity: 1;
      bottom:0;
      filter: blur(0);
  }
}

/*========= ローディング画面のためのCSS ===============*/
#splash {
  position: fixed;
  width: 100%;
  height: 100%;
  background: #fff;
  z-index: 9999999;
  text-align:center;
  color:#111;
}

#splash-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 95%;
  max-width: 150px;
}


/*========= 画面遷移のためのCSS ===============*/

body{
    background:#fff;
}

body.appear{
    background:#eeeee0;
}

.splashbg{
  position: fixed;
  top: 0;
  right:0;
  bottom:0;
  left: 0;
  border-width: 0px;
  border-style:solid;
    border-color: #fff;
  animation-duration:.5s;
  animation-fill-mode:forwards;
}

@keyframes backBoxAnime{
  99.9% {
        z-index: 2;
    border-width: 0px;
  }
    100%{
       z-index: -1;
        border-width: 0px;
    }
}

#container{
    position: relative;
  opacity: 0;
}

body.appear #container{
  animation-name:PageAnimeAppear;
  animation-duration:1s;
  animation-delay:0.2s;
  animation-fill-mode:forwards;
  opacity: 0;
}

@keyframes PageAnimeAppear{
  0% {
  opacity: 0;
  }
  100% {
  opacity: 1;
}
}

.animation_wrap{
  position: relative;
  overflow: hidden;
}

.animation_wrap_text{
  position: relative;
}

.animation::before,
.animation::after{
    content: '';
    width: 100%;
    height: 100.5%;
    position: absolute;
    left: 0;
    top: 0;
}
.animation::before{
  background: #d9d6ec;
  z-index: 3;
  transition: .55s;
}
.animation::after{
background: var(--blue);
  z-index: 2;
  transition: .55s;
}

.animation-bk::before,
.animation-bk::after{
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 1px;
}
.animation-bk::before{
    background: #1a2254;
    z-index: 3;
    transition: 1s;
}
.animation-bk::after{
  background: #262626;
    z-index: 2;
    transition: 1s;
    transition-delay: .5s;
}

.animation.show::before,
.animation.show::after,
.animation-bk::before,
.animation-bk::after
{
    transform: translateY(100%);
}
.animation img, .animation-bk img{
    opacity: 0;
    transform: scale(1.5);
    transition: 1.2s cubic-bezier(0.785, 0.135, 0.15, 0.86);
    transition-delay: .4s;
}
.animation.show img, .animation-bk.show img{
    opacity: 1;
    transform: scale(1);
}

.bgappearTrigger,
.bgUDextendTrigger,
.bgDUextendTrigger,
.bgRLextendTrigger,
.bgLRextendTrigger{
    opacity: 0;
}

.bgextend{
	animation-name:bgextendAnimeBase;
	animation-duration:1s;
	animation-fill-mode:forwards;
	position: relative;
	overflow: hidden;
	opacity:0;
}

@keyframes bgextendAnimeBase{
  from {
    opacity:0;
  }

  to {
    opacity:1;  
}
}

.bgappear{
	animation-name:bgextendAnimeSecond;
	animation-duration:1s;
	animation-delay: 0.6s;
	animation-fill-mode:forwards;
	opacity: 0;
}

@keyframes bgextendAnimeSecond{
	0% {
	opacity: 0;
	}
	100% {
	opacity: 1;
}
}

.bgLRextend::before{
	animation-name:bgLRextendAnime;
	animation-duration:1s;
	animation-fill-mode:forwards;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: var(--red);
}
@keyframes bgLRextendAnime{
	0% {
		transform-origin:left;
		transform:scaleX(0);
	}
	50% {
		transform-origin:left;
		transform:scaleX(1);
	}
	50.001% {
		transform-origin:right;
	}
	100% {
		transform-origin:right;
		transform:scaleX(0);
	}
}


.page__fv.animation{
  opacity: 0;
  transform: scale(1.5);
  transition: 1.2s cubic-bezier(0.785, 0.135, 0.15, 0.86);
  transition-delay: .4s;
}
.page__fv.animation.show{
  opacity: 1;
  transform: scale(1);
}

.page__fv.animation::before{
  background: transparent;
}

.animation_wrap_top.show{
animation-delay:2s;
}

.animation-text{
  opacity: 0;
  -webkit-filter: blur(10px);
  filter: blur(10px);
  transition: 1.2s;
  transition-delay: 1s;
}

.animation-text.show {
  opacity: 1;
  -webkit-filter: blur(0px);
  filter: blur(0px);
}

.animation-title{
  opacity: 0;
  -webkit-filter: blur(10px);
  filter: blur(10px);
  transition: 1.2s;
  transition-delay: .8s;
}

.animation-title.show {
  opacity: 1;
  -webkit-filter: blur(0px);
  filter: blur(0px);
}

.animation p{
    color: #FFF;
    opacity: 0;
    transform: translateX(-40px);
    transition: 1.2s;
    transition-delay: 1s;
    z-index: 1;
    overflow: hidden;
}
.animation.show p{
    opacity: 1;
    transform: translateX(0);
}

.animation-pattern2 {
  opacity: 0;
  transform: translateY(40px);
  transition: 1s;
  transition-delay: 1s;
  -webkit-filter: blur(20px);
  filter: blur(20px);
  padding-bottom: 1px;
}

.animation-pattern2.show{
  opacity: 1;
  transform: translateY(0);
  -webkit-filter: blur(0px);
  filter: blur(0px);
  -webkit-transition: all 1s;
  transition: all 1s;
}

.animation-pattern2.show .eye img{
  transition:1s all;
}

.animation-pattern2.show:hover .eye img{
  transform:scale(1.1,1.1);
  transition:1s all;
}

.animation-pattern2.show .eye{
  overflow: hidden;
}

.animation-pattern3.show, .animation-pattern4.show {
  opacity: 1;
  transform: translateX(0);
}

.animation-pattern3{
  opacity: 0;
  transform: translateX(40px);
  transition: 1s;
  transition-delay: 1s;
}
 
.animation-pattern4{
  opacity: 0;
  transform: translateX(40px);
  transition: .8s;
  transition-delay: 1s;
}
main#main__bg{
  position: relative;
}

header .header_main ul li{
  opacity: 0;
  transform: translateY(-100px);
  transition: .8s;
  transition-delay: .2s;
  filter: blur(6px);
}

header .header_main ul li:nth-of-type(2){
  opacity: 0;
  transform: translateY(-100px);
  transition: .8s;
  transition-delay: .4s;
}

header .header_main ul li:nth-of-type(3){
  opacity: 0;
  transform: translateY(-100px);
  transition: .8s;
  transition-delay: .6s;
}

header .header_main ul li:nth-of-type(4){
  opacity: 0;
  transform: translateY(-100px);
  transition: .8s;
  transition-delay: .8s;
}

header .header_main ul li:nth-of-type(5){
  opacity: 0;
  transform: translateY(-100px);
  transition: .8s;
  transition-delay: 1s;
}

header .header_main ul li:nth-of-type(6){
  opacity: 0;
  transform: translateY(-100px);
  transition: .8s;
  transition-delay: 1.2s;
}

header .show.header_main ul li{
  opacity: 1;
  transform: translateY(0px);
  filter: blur(0px);
}


/* header */
header {
  width: 100%;
  padding:0;
  z-index: 1;
  margin-left: auto;
  height: 100vh;
  position: relative;
}

.header_logo{
  margin-top:0;
  margin-bottom:0;
  position: fixed;
  width: clamp(220px,240px,280px);
  min-width: 150px;
  margin-left: auto;
  right:var(--row-space);
  top:calc(var(--row-space) - 2em) ;
  z-index: 3;
}

.header_logo.sec{
  display: block !important;
  top:calc(var(--row-space) - 3em);
}

header .header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: auto 0;
  position: relative;
}


header.sec::after{
  background: #cfffe0;
}

header.show::after{
  width:100%;
}
.title_wrap{
  position: absolute;
  left:2lvw;
  bottom:-4.5em;
  z-index: 2;
  max-width: 50vw;
  margin-top: auto;
}

.site__title{
  font-size: var(--h1);
  color:#fff;
  font-family: var(--futura), sans-serif;
  font-weight: 900;
  line-height: 1.15;
  width:48vw;
}

.site__title:nth-of-type(2){
  margin-left:12.5vw;
}

.top_slider .disc{
  color:#fff;
  margin-top: 2em;
  font-size: 1.0rem;
}

.top_slider img{
  width:100vw;
}

.top_slider{
  min-height: 100vh;
}

.nav__fixed{
  position: fixed;
  z-index: 1;
  width: 100vw;
  padding:calc(var(--row-space) - 2em) var(--row-space) 2em;
  top:0;
  left:0;
  
}

.nav__fixed ul{
  list-style: none;
  display: flex;
  column-gap: .25vw;
  margin: 0;
}
.nav__fixed ul li a, .nav__fixed ul li{
    font-family: "acumin-pro", sans-serif;
    font-weight: 300;
    letter-spacing: 0.16em;
    font-size: 0.9rem;
    transition: all 0.5s ease;
    position: relative;
    padding: 0 1em;
    overflow: hidden;
}
.nav__fixed ul li{
	padding:0 0;
}
.nav__fixed ul li a{
    transition: .3s;
      color:#555;
    }
.nav__fixed ul li a{
  padding-left: 2em;
  padding-right: 2em;
}

.nav__fixed ul li a::after {
  position: absolute;
  left: 0;
  top: -30px;
  width: 100%;
  display: block;
  line-height: 1;
  content: attr(data-item);
  padding: 3px;
  text-align: center;
  color:#fff;
background: linear-gradient(to right,  rgba(0,0,0,0) 0%,rgba(0,0,0,0.04) 2%,rgba(0,0,0,0.96) 48%,rgba(0,0,0,1) 50%,rgba(0,0,0,0) 100%);
  font-size: 0.7rem;
  transition: all 0.5s ease;
  opacity: 0;
  letter-spacing: 0.042em;
}

.nav__fixed ul li a:hover::after{
  top: 0px;
  opacity:1;
}

.nav__fixed ul li a:hover{
  color:transparent !important;
}

.nav__fixed ul li a:hover span{
  position: relative;
  bottom: -60px;
  transition: all 0.3s ease;
}
.nav__fixed ul li a span{
  position: relative;
  bottom: 0;
    transition: all 0.3s ease;

}
.pin{
  	position: relative;
	overflow: visible;
  height: 200vh;
}
.pin_container {
	height: 100vh;
	position: sticky;
	top: 0;
	overflow: hidden;
	backface-visibility: hidden;
}
.pin {
	width: 100%;
	height: 100vh;
	position: relative;
	overflow: visible;
	background-color: #fff;
  z-index: 3;
}

.pin_container {
	height: 100vh;
	background-color: #000;
	overflow: hidden;
	backface-visibility: hidden;
}

.box {
	width: 100%;
	height: 100vh;
	margin: auto;
	z-index: 2;
	backface-visibility: hidden;
}
.box2 {
	transform: scale(0.91);
}


.mv__wrap{
  height: 100vh;
  background: url(../images/extrawanted.png)no-repeat #000;
   background-size: cover;
  width: 100vw;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.mv__wrap__02{
  z-index: 2;
  background: url(../images/performance.png)no-repeat #000;
   background-size: cover;
  width: 100vw;
  height: 100vh;
    display: flex;
  flex-direction: column;
  justify-content: center;
}
.mv__wrap__03{
  z-index: 2;
  background: url(../images/slider/slider_01.webp)no-repeat #000;
   background-size: cover;
  width: 100vw;
  height: 100vh;
    display: flex;
  flex-direction: column;
  justify-content: center;
}
.mv__wrap__04{
  z-index: 2;
  background: url(../images/slider/slider_02.webp)no-repeat #000;
   background-size: cover;
  width: 100vw;
  height: 100vh;
    display: flex;
  flex-direction: column;
  justify-content: center;
}
.mv__wrap__05{
  z-index: 2;
  background: url(../images/slider/slider_03.webp)no-repeat #000;
   background-size: cover;
  width: 100vw;
  height: 100vh;
    display: flex;
  flex-direction: column;
  justify-content: center;
}
.mv__wrap .caption{
  position: absolute;
  z-index: 3;
  bottom: clamp(10vh,37vh,40vh);
  color:#fff;
  font-style: italic;
  left: 5vw;
}

@media screen and (min-width: 768px) and (max-width: 1024px) {

  .mv__wrap .caption{
    bottom:30vh;
  }
  p.big {
    font-size: 20px !important;
}
  main#main__bg::before{
    content: '';
    background: url(../images/mv_bg.svg) no-repeat center top 7vh;
    position: absolute;
    width: 100vw;
    height: 150vh;
    background-size: cover;
  }
}

.mv__wrap .caption p{
  color:#fff;
  line-height: 2.0;
  letter-spacing: 0.26em;
}

header nav.gloval{
  position: relative;
  z-index: 2;
  max-width: calc(100% - 290px);
  width:100%;
}

header nav.gloval ul{
  display: flex;
  flex-direction: row;
  column-gap: 1%;
  justify-content: flex-end;
}

header nav.gloval li a{
  display: block;
  padding: .5em;
  text-align: center;
  color:#fff;
  font-size: 0.95rem;
}

header .header .header_main ul {
  display: none;
  gap: 40px;
}

header .header .header_main.open ul{
  display: flex;
}

header .header .header_main ul li a {
  letter-spacing: 0.08em;
  color: #221818;
}

@media screen and (min-width: 1025px) and (max-width: 1240px) {

  header nav.gloval{
    margin-right: 0;
  }
}

@media screen and (min-width: 768px) and (max-width: 1024px) {
  header nav.gloval{
    display: none;
  }
  header .header_logo{
    max-width: 200px;
  }
}
@media screen and (max-width: 767px) {
  header nav.gloval{
    display: none;
  }
}

.sp_menu_btn {
  top:4vh;
  right:calc(var(--row-space) / 2);
  width: 11.9047619048vw;
  height: 11.9047619048vw;
  max-width:90px;
  max-height: 90px;
  z-index: 100;
  position: fixed;
  opacity:1;
  background: #fff;
  backdrop-filter: blur(3px);
  transition: all 0.3s;
  display: block;
  border-radius: 50%;
}

.sp_menu_btn .bt-menu-trigger {
  font-size: 11px;
  position: relative;
  display: inline-block;
  width: 100%;
  height: 100%;
  cursor: pointer;
  z-index: 1;
  text-align: center;
}

.sp_menu_btn .bt-menu-trigger .txt{
  position: absolute;
  bottom: 2px;
  left: calc(50% - 14px);
  display: block;
  font-family: "Poiret One", sans-serif;
  color:#222;
  font-weight: 100;
  letter-spacing: 1.5px;
  font-size: 8px;
}


.sp_menu_btn .bt-menu-trigger span {
  position: absolute;
  top: 50%;
  left: calc(50% - 15px);
  display: block;
  width: 30px;
  height: 1px;
  margin-top: -0.1em;
  background-color: #000;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  transition: background-color 0.3s;
}
.sp_menu_btn .bt-menu-trigger span:after,
.sp_menu_btn .bt-menu-trigger span:before {
  position: absolute;
  left: calc(50% - 15px);
  width: 30px;
  height: 1px;
  background: #000;
  content: "";
  transition: transform 0.3s;
}
@media screen and (max-width: 767px) {

  .sp_menu_btn .bt-menu-trigger span{
    width: 30px;
    left: calc(50% - 15px);
  }

  .sp_menu_btn .bt-menu-trigger .txt{
    display: block;
  }
}
.sp_menu_btn.sec span:after, .sp_menu_btn.sec span:before{
  background: #000;
}

.sp_menu_btn.sec .bt-menu-trigger .txt{
 color:#000; 
}
.sp_menu_btn .bt-menu-trigger.bt-menu-open span{
  background: transparent;
}

.sp_menu_btn .bt-menu-trigger span:before {
  transform: translateY(-7px);
}
.sp_menu_btn .bt-menu-trigger span:after {
  transform: translateY(7px);
}
.sp_menu_btn .bt-menu-trigger.bt-menu-open span:before {
  transform: translateY(0px) translateX(0px) rotate(45deg) scaleX(0.6);
  background: #000;
}
.sp_menu_btn .bt-menu-trigger.bt-menu-open span:after {
  transform: translateY(0px) translateX(0px) rotate(-45deg) scaleX(0.6);
    background: #000;
}

.sp_menu_btn .bt-menu-trigger.bt-menu-open .txt{
  opacity: 1;
  display: block;
}
.sp_menu_btn.isActive {
  opacity: 1;
  transition: all 0.65s;
  pointer-events: inherit;
}



.drawer_main{
  position: fixed;
  top: 0;
  right: 0;
  width: 100vw;
  height: 100vh;
  pointer-events: none;
  opacity: 0;
  transition: opacity .5s linear;
  background: rgba(0,0,0,0.85);
}

.drawer_main p.small{
  opacity: 0;
}

.drawer_main.open p.small{font-size: 11px;
    color:#999;
    margin-left: 12vw;
    margin-bottom: 5vh;
    opacity: 1;
}


.drawer_main.open {
  z-index: 99;
  pointer-events: auto;
  opacity: 1;
}

.drawer_main .Right {
  display: flex;
  flex-direction: column;
  height: 100vh;
  justify-content: center;
}

.drawer_main .Right .copy{
  display: none;
}


.drawer_main.open .Right{
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: #1f1f1f;
  height: 70vh;
}

.drawer_main.open .Right .copy{
  margin:0 auto 5vh;
  text-align: center;
  max-width: 300px;
  display: block;
}

.drawer_main.open .copy img{
  max-width: 100%;
  width: auto;
}

.drawer_main ul{
 display: none;
  animation: slideIn 1s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}

.drawer_main .logo{
  margin-bottom: 5vh;
  padding:2.5vh 5.6vw;
  border-bottom: 1px solid rgba(255,255,255,0.18);
}
.drawer_main .logo img{
  max-width: 190px;
}
.drawer_main.open ul{
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-left: 10vw;
}
.drawer_main.open ul li a {
  font-size: 14px;
  position: relative;
  letter-spacing: 0.08em;
  font-weight: 500;
  padding: .5em;
  display: block;
  color:#fff;
    font-family: "acumin-pro", sans-serif;
    font-weight: 100;
    letter-spacing: 0.26em;
}
.drawer_main.open .sns__wrapper {
  font-size: 18px;
  margin-left: 12vw;
  margin-bottom: 5vh;
}

.drawer_main.open .sns__wrapper i{
  font-size: 18px;
}

 .drawer_main.open .sns__wrapper a{
  color:#fff;
 }
@keyframes slideIn {
  0% {
    transform: translateY(-20px);
    opacity: 0;
    filter: blur(6px);
  }
  100% {
    transform: translateY(0);
    filter: blur(0px);
  }
  40%,100% {
    opacity: 1;
  }
}

.drawer_main ul li a:after{
  position: absolute;
  bottom: -2px;
  left: 0;
  content: "";
  width: 100%;
  height: 1px;
  background:#e689ad;
  transition: transform .3s;
  transform-origin: right top;
  transform: scale(0,1);
}
.drawer_main ul li a:hover:after {
  transform-origin: left;
  transform: scale(1,1);
}

header .Inner{
  position: relative;
}

.top_slider {
  z-index: -1;
  position: relative;
}

.top_slide_main{
  overflow: hidden;
}

.top_slider .slick-img img {
  width: 100%;
}

.top_slider .slick-next, .top_slider .slick-prev{
  background: #000;
  width:60px;
  height:60px;
  z-index: 10;
  top:inherit;
  bottom:20px;
  cursor: pointer;
}
.top_slider .slick-prev:hover::before{
-webkit-animation: prev-arrow .5s forwards;
    animation: prev-arrow .5s forwards;
}

.top_slider .slick-next:hover::before{
  -webkit-animation: next-arrow .5s forwards;
    animation: next-arrow .5s forwards;
}

@keyframes prev-arrow{
0% {
  opacity: 0;
  margin-left: 10px;
}
99.9%, 100% {
  opacity: 1;
  margin-left: 1px;
}
}
@keyframes next-arrow{
  0% {
    opacity: 0;
    margin-right: 10px;
  }
  99.9%, 100% {
    opacity: 1;
    margin-right: 1px;
  }
  }

.top_slider .slick-prev{
  left:inherit;
  right:120px;
}

.slick-prev:before, .slick-next:before{
  font-size: 28px;
  display: block;
}

.slick-prev:before{
  font-family: "FontAwesome";
	content: '\f104';
}

.slick-next:before{
  font-family: "FontAwesome";
	content: '\f105';
}


.top_slider .slick-next{
  left:inherit;
  right:50px;
}

.dots-5{
  position: absolute;
  z-index: 10;
  bottom:2em;
}

.dots-5 .slick-dots {
  text-align: center;
}
.dots-5 .slick-dots li {
  display: inline-block;
  width: 100px;
  height: 6px;
  margin: 4px;
  background: #eaeaea;
  cursor: pointer;
}
.dots-5 .slick-dots button {
  display: block;
  width: 0%;
  height: 6px;
  margin: 0;
  font-size: 0;
  padding: 0;
  border: 0;
  opacity: 0;
  outline: none;
  background: #0a467d;
  cursor: pointer;
}
.dots-5 .slick-dots .slick-active button {
  background: #0a467d;
  opacity: 1;
}
.slick-slide{
position: relative;
}

.slide-items .slick-slide img, .slide-items-brand .slick-slide img{
  height:100%;
  width:100%;
  object-fit: cover;
}

@keyframes zoomUp {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.15);
  }
}
.add-animation {
  animation: zoomUp 10s linear 0s normal both;
}

.top_slider .top_slide_main {
  width: 100vw;
  margin: 0;
  position: relative;
  z-index: -1;
}

.top_slider .main_content {
  position: absolute;
  right: 15.3333333333vw;
  top: 11.0208333333vw;
}

.top_slider .main_content h2 span {
  font-size: 35px;
  display: block;
  margin-top: 7.5vh;
}

.top_slider .scroll__down {
  position: absolute;
  right: calc(var(--row-space) * 1.5);
  bottom: 10.5vh;
  font-family: "goudy-old-style", serif;
  font-weight: normal;
  font-size: 18px;
  letter-spacing: 0.01em;
  line-height: 24.01px;
  color: var(--key-Color);
  writing-mode: vertical-rl;
  text-orientation: mixed;
}


.page__fv{
  min-height:35vh;
  margin: 0 calc(50% - 50vw);
  width:100vw;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
}

.page__fv h1{
  margin: 1em auto 0;
  font-size: 2.4375vw;
  color: #fff;
  text-align: center;
  font-family:'Noto Sans JP',游ゴシック体, 'Yu Gothic', YuGothic,'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  font-weight: 600;
  max-height: 25vh;
  position: relative;
  z-index: 5;
}

.page__fv::after{
  content:'';
  background: rgba(0,0,0,0.355);
  position: absolute;
  left:0;
  top:0;
  width: 100%;
  height: 100%;
  transform: translateY(0%) !important;
}

.js-scroll-overlap {
  position: relative;
  background: #000;
}
.js-scroll-overlap:not(.is-disabled) {
  --sticky-offset: -1px;
  --overlay-opacity: 0;
  position: sticky;
  top: var(--sticky-offset);
}
.js-scroll-overlap[data-is-overlay="true"]:not(.is-disabled)::after {
  content: "";
  opacity: var(--overlay-opacity);
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.8);
  pointer-events: none;
}
.js-scroll-overlap[data-is-overlay="true"]:not(.is-disabled).is-active::after {
  will-change: opacity;
}
.js-scroll-overlap .scroll-content {
  --scale: 1;
  transform: scale(var(--scale));
  transition: transform 0.1s linear;
}
.relative {
  position: relative;
}

.about_part {
  padding:var(--col-space) var(--row-space);
  position: relative;
  z-index: 2;
  overflow: inherit;
  margin-top: -25vh;
}

.about_part .flex-box .about_one:first-of-type{
  padding-top: var(--col-space);
  width:90%;
}

p.big{
	font-size:clamp(20px,25px,30px);
}

p.violet{
 color:#0f002e;
}

.about_part.greeting .flex-box .about_one:first-of-type{
  padding-top: 0;
}
.ilust_profile{
  padding-top: 2em;
  border-top: 1px solid #808080;
  color:#808080;
}

.flex-box .about_one.pb{
	padding-bottom:10vh;
}
/***********************見出し****************************/



h3.en{
  font-family: "Roboto", serif;
  font-style: italic;
  color:#000;
  opacity:0.4;
  font-weight: 600;
  letter-spacing: 0.119em;
  font-size: clamp(30px,2.5416666666666665vw,38px);
  margin-bottom: 1em;
  text-align: center;
}

section.fv{
background: linear-gradient(135deg,  rgba(189,195,201,0.6) 0%,rgba(255,255,255,0.7) 26%,rgba(255,255,255,0.78) 46%,rgba(255,255,255,0.9) 75%,rgba(189,195,201,1) 100%);

  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  width: 100vw;
}

section.fv .Inner__wrap{
  display: flex;
  justify-content: space-between;
}

section.company_part{
  padding: var(--col-space) var(--row-space);
  background: url(../images/company__bg.webp) no-repeat;
  background-size: cover;
}

.company_part .Hurf{
  width: var(--flex_hurf);
  position: relative;
}
.company_part .Hurf.flex{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
}

.company_part .map{
  position: relative;
}

.company_part .map a{
  width: 120px;
  display: block;
  position: absolute;
  bottom:0;
  right:0;
}

.about_part.greeting::after{
  display: none;
}


.about_part .Inner{
  position: relative;
}

.about_part.greeting{
  z-index: 5;
}

.about_part.greeting .main_container1{
  display: block;
}
.timeline {
  list-style: none;
}
.timeline > li {
  margin-bottom: 60px;
}

/* for Desktop */
@media ( min-width : 768px ){
  .timeline > li {
    overflow: hidden;
    margin: 0;
    position: relative;
  }
  .timeline-date {
    width: 110px;
    float: left;
    margin-top: 0;
    color:#fff;
  }
  .timeline-content {
    width: 75%;
    float: left;
    border-left: 1px #fff solid;
    padding-left: 30px;
    color:#fff;
    padding-bottom: 2em;
    font-size: 0.95rem;
  }
  section h3{
    font-size: 0.95rem;
  }

  .timeline-content:before {
        content: '';
        width: 12px;
        height: 12px;
        background: #fff;
        position: absolute;
        left: 105px;
        top: 10px;
        border-radius: 100%;
  }
}


@media screen and (max-width: 767px) {

  .about_part .flex-box .about_one:first-of-type{
    width:100%;
  }
	
	.about_part .flex-box{
	flex-wrap:wrap;
}
	
.flex-box .about_one.pb{
	padding-bottom:0vh;
}

  .staff__contents{
    flex-wrap: wrap;
    margin-top: 5vh; 
  }
  .staff__contents div:first-child{
    width: 100%;
    display: flex;
    column-gap: 10px;
    align-items: center;
  }
  .staff__contents div.cont {
    width: calc(100% - 150px);
}
.staff__contents .profile{
  flex-direction: column;
  align-items: flex-start !important;
}
.staff__contents .profile > div{
  width: 100%;
  max-width: 100%;
  display: flex;
}
}

/*****************カンパニー*******************/

.concept_part  p{
  letter-spacing: 0.26em;
  line-height: 2.5;
  margin-bottom: 2.5em;
}

.sns__wrapper{
  display: flex;
  column-gap: .5em;
  margin-top: 3vh;
  padding-left: 0;
}

.sns__wrapper a{
  width: 35px;
  display: block;
}

.banner a{
    display: block;
    transition: all .3s ease-in-out;
    transform: translateY(0);
}
.banner img{
    width: 100%;
    vertical-align: middle;
}
.content banner .banner img{
	    width: 100%;
    vertical-align: middle;
    object-fit: scale-down;
    max-width: 100%;
    max-height: 69px;
}

.banner a:hover{
    transform: translateY(-5px);
  opacity: .5;
}

      .cls-1 {
        fill: #231815;
      }

      .cls-2 {
        fill: none;
        stroke: #231815;
        stroke-miterlimit: 10;
        stroke-width: 1.04px;
      }

.campaign{
  max-width: 480px;
  margin-left: auto;
  margin-right: var(--row-space);
  width: 100%;
}

.company_part{
  position: relative;
  padding: var(--col-space) var(--row-space);
  background: #fff;
}

.company_part.history{
  overflow: inherit;
  background: transparent;
  padding-top: 0;
}

.company_part.history::before{
  content:'';
  background:#fff;
  position: absolute;
  z-index: -1;
  top:-50%;
  left:0vw;
  width:0;
  opacity: 0;
  height:0%;
  transform: skewY(-10deg);
  transform-origin: top right;
  transition: all .75s;
}

.company_part.history.show::before{
  height: 120%;
  width:110vw;
  opacity: 1;
}


.company_part h2{
  color:#fff !important;
  text-align: right;
}



.sec_access_part{
  background: url(../images/access__bg.svg)no-repeat center top;
  background-size: cover;
  position: relative;
  z-index: 0;
  padding: var(--col-space) var(--row-space) var(--col-space);
}

.sec_access_part .flex-box.space{
  max-width: 1530px;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  z-index: 4;
}


dl.company{
  display: flex;
  flex-direction: row;
  margin-bottom: .75em;
  color:#fff;
}

dl.company dt{
  padding-right: .5em;
  font-size: 0.85rem;
  padding: 0 1em 0 0;
  margin: 0 0 .5em 0;
  font-weight: 300;
  min-width:15%;
}

dl.company dd{
  padding: 0;
  font-size: .85rem;
  font-weight: 400;
}

ul.disc{
  list-style: none;
  padding: 0;
  margin: 0 0 0 1em;
}

ul.disc li{
  margin: 0;
  padding: 0;
  text-indent: -.65em;
  padding-left: 1em;
}

ul.disc li:before{
  content: '〇';
  display: inline-block;
  margin-right: .25em;
}

.sec_access_part .flex-box .detail{
  width: 52%;
}
.sec_access_part .flex-box .map{
  width: 38%;
  margin-bottom: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  padding-right: 10%;
}

.wh_wrap.top{
  overflow: inherit;
  padding-bottom: 0;
}

.wh_wrap.top::after{
  content: '';
  background: #fff;
  position: absolute;
  z-index: -1;
  bottom: 10%;
  left: 0;
  width: 0;
  opacity: 0;
  height: 90%;
  transform: skewY(-10deg);
  transform-origin: top right;
  transition: all .75s;
}

.wh_wrap.top.show::after{
  width: 130vw;
  transition: .5s;
  transition-delay: .5s;
  opacity: 1;
}

.sec_contact_part h2{
  color:#a29ccb;
  margin:auto 0 0 !important;
}

.sec_contact_part h2 span{
  color:#a29ccb;
}

.sec_contact_part p{
  color:#a59fc8;
  font-weight: 300;
  letter-spacing: 0.4em;
  font-family:'Noto Sans JP',游ゴシック体, 'Yu Gothic', YuGothic,'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  font-size: 0.9rem;
  margin-bottom: 5vh;
}

.staff_part::after{
  content: '';
  position: absolute;
  bottom:0vh;
  left:0;
  width:100vw;
  height:20vh;
  background: #fff;
  z-index: -2;
}


@media screen and (max-width: 767px) {
  a.sec_contact{
    max-width: 300px;
    margin: 2em auto;
  }
  .access{
    width: 100%;
    margin: 2em auto;
  }

}

p.min{
  font-size: 0.8rem !important;
}

.about_part .Inner.none::before{
  display: none;
}

.about_part .main_container1 {
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
}

.about_part .main_container1.bk{
  display: block;
}

.about_part .main_container1 .about_one.small{
  width:20%;
}

.about_part .main_container1 .about_one .content {
  padding: 20px 12px 0;
  flex-wrap: wrap;
}

.about_part .main_container1 .about_one .content p {
  font-weight: 400;
  line-height: 2.0;
  margin-top: 15px;
  font-size: 1.0rem;
}

.about_part .main_container1.reverse{
  flex-direction: row;
}

.about_part .main_container1.center{
  align-items: center;
}

.about_part .main_container1 + .main_container1{
  margin: var(--col-space) auto;
}

.about_part .main_container1 .about_one .content{
  display: flex;
  justify-content: center;
  column-gap: 2%;
  row-gap: var(--row-space);
}

.about_part .main_container1 .about_one .content .three{
  width:var(--flex_third);
  position: relative;
  padding-right: 2%; 
  position: relative;
}

.about_part .main_container1 .about_one .content .three a{
  position: absolute;
  width: 100%;
  height: 100%;
  top:0;
  left:0;
  z-index: 2;
}

.about_part .main_container1 .about_one .content .three::after{
  content: '';
  position: absolute;
  right:0;
  top:0;
  width:2px;
  height:0;
  transition: all .3s;
  background: #000;
}

.about_part .main_container1 .about_one .content .three.show::after{
  height:100%;
}

.about_part .main_container1 .about_one .content .three:nth-of-type(3)::after, .about_part .main_container1 .about_one .content .three:nth-of-type(4)::after{
  display: none;
}

.about_part .main_container1 + .main_container1:last-child{
  margin-bottom: 0;
}

.about_one h3{
  font-size: calc(var(--h3) / 2);
  position: relative;
  overflow: inherit;
}

.about_one h3{
  padding-bottom: 1em;
  border-bottom: #131313 solid 5px;
  position: relative;
}

.about_one h3::before{
  content: '';
  background: #000;
  position: absolute;
  width:100%;
  height:5px;
  left:0px;
  bottom:-5px;
  z-index: 3;
}

.about_one h3::after{
  content: '';
  background: #b30000;
  position: absolute;
  width:80px;
  height:5px;
  left:20px;
  bottom:-5px;
  z-index:4;
}

.concept_part{
  position: relative;
  z-index: 0;
  padding: var(--col-space) 0 var(--col-space) var(--row-space) ;
  background: #fff;
  min-height: 100vh;
}

.Center{
  text-align: center;
}


#video-area{
  position: fixed;
  z-index: -1;
  top: 0;
  right:0;
  left:0;
  bottom:0;
  overflow: hidden;
}

#video {
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 177.77777778vh;
  height: 56.25vw;
  min-height: 100%;
  min-width: 100%;
  background: #eee;
}

.pagebtn{
  position: relative;
  z-index: 4;
}

@media screen and (max-width: 767px) {

  .casting_part .text{
    font-size: 1.15rem;
  }

  .casting__title{
    font-size: 0.9rem;
  }
	p.big {
    font-size: 16px;
}

}

h2.Center{
  text-align: center;
}

h2.bold{
  font-weight: 800;
}

.sec h2.Center{
  margin-bottom: 1em;
  font-size: calc(var(--h3) / 1.5);
}

.en__title.right{
  text-align: right;
}

.about_part h2, .about_part h3{
  color:#292828;
}

.about_part h2{
  margin-top: 4.5vw;
}

.service__icon__wrap{
  display: flex;
  flex-wrap: wrap;
  column-gap: 1%;
  max-width: 1200px;
  margin:var(--col-space) auto 0;
}

.service__icon{
  width:calc(92% / 5);
  color:#fff;
  display: flex;
  justify-content: center;
  flex-direction: column;
}

.service__icon p{
  margin-bottom: .5em;
}

.service__icon:nth-of-type(odd){
  background: var(--red);
  padding: 1em;
  border-radius:5px;
  text-align: center;
}

.service__icon:nth-of-type(even){
  background: var(--blue);
  padding: 1em;
  border-radius:5px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .about_part .main_container1 .about_one .content .three::after{
    display: none;
  }

  .service__icon{
    width: calc(94% / 3);
    font-size: 0.9rem;
  }
  .service__icon__wrap{
    row-gap: 1.5vh;
    justify-content: center;
    column-gap: 2%;
  }
}
.map iframe{
   height:50vh !important;
}

.map{
  margin-top: var(--s2-space);
}

section h3{
  font-weight: 300;
  line-height: 1.55;
}

p.serif{
  font-family: 'Noto Serif JP', "ヒラギノ明朝 ProN W6", HiraMinProN-W6, HG明朝E, "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif !important;
  color:#000;
  line-height: 2.85;
}

p.tl + h3{
  margin-top: var(--s3-space);
}

h3.l-bordert{
  font-size: calc(var(--h3) * 0.65);
}

.about_part h2.en__title img{
  width:22.1666vw;
  position: absolute;
  bottom:-3.5vh;
  left:4.01vw;
  z-index: 0;
}

.brand_part {
  padding-right: var(--row-space);
  padding-top:0;
  padding-bottom:0;
  position: relative;
}

.spilits_part {
  padding-right: var(--row-space);
  padding-top:0;
  padding-bottom:var(--col-space);
  position: relative;
}

.category_part {
  padding-right:0;
  padding-left:0;
  padding-top: 0;
  padding-bottom:var(--col-space);
  position: relative;
}

.brand_part_wrap, .category_part_wrap{
display: flex;
flex-wrap: wrap;
align-items: center;
justify-content: space-between;
position: relative;
padding: var(--col-space) 0;
}

.brand_part_wrap{
  padding-left: var(--row-space);
  padding-bottom: 0;
}

.category_part_wrap{
  padding-left: var(--row-space);
  padding-bottom: 0;
}

.brand_part_wrap::after{
  content: '';
  background: url(../images/border-top.png)no-repeat right top;
  background-size: cover;
  width: 0;
  height:100%;
  position: absolute;
  z-index: -1;
  right:0;
  top:0;
  transition: .5s;
  transition-delay: .5s;
}

.show.brand_part_wrap::after{
  width: 40vw;
  transition: .5s;
  transition-delay: .5s;
}

.brand_part .slick-next:before, .brand_part .slick-prev:before, .category_part .slick-next:before, .category_part .slick-prev:before{
  color: var(--red);
  font-size: 50px;
  font-weight: 200;
}

.brand_part .slick-prev:after, .category_part .slick-prev:after{
  content: '';
  background: var(--red);
  width: 1px;
  height:5vh;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right:-15px;
}

.brand_part .slick-prev, .brand_part .slick-next, .category_part .slick-prev, .category_part .slick-next{
  top:-50px;
  height: 50px;
}

.brand_part .slick-prev{
  left: inherit;
  right:100px;
}
.brand_part .slick-next{
  left: inherit;
  right:50px;
}

.category_part .slick-prev{
  left: 50px;
  bottom:0px;
}
.category_part .slick-next{
  left: 100px;
  bottom:0px;
  right: inherit;
}

.selif__center{
  font-family: 'Noto Serif JP', "ヒラギノ明朝 ProN W6", HiraMinProN-W6, HG明朝E, "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
  font-weight: 500;
  font-size: calc(var(--h3) / 1.5);
  text-align: center;
  margin: var(--s2-space) calc(50% - 50vw);
  line-height: 1.9;
  position: relative;
  padding: var(--col-space) var(--row-space);
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
  position: relative;
}

.selif__center::before{
  content: '';
  background:url(../images/color.png)no-repeat;
  background-size: contain;
  position: absolute;
  width:140px;
  height:60px;
  top:-7px;
  left:var(--col-space);
}

.selif__center.products{
  padding: 1em;
}

.products + figure.Center{
  max-width: 400px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: var(--s2-space);
}

.recruit_part_wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  position: relative;
  padding: var(--col-space) 0 0;
  background: #fff;
}

.about_part.afnone::after{
  display: none;
}

.brand_part .content:first-child {
  width:57.7%;
  position: relative;
  z-index: 2;
}

.brand_part h2.en__title{
  color:#292828;
  margin-bottom: 0;
}

.recruit_part .content:nth-of-type(1){
  width:46.88vw;
  display: flex;
}

.brand_part_wrap .content:nth-of-type(2), .recruit_part .content:nth-of-type(2){
  max-width:46.88vw;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  z-index: 3;
}

.recruit_part .content:nth-of-type(2){
  padding-top: 10vh;
}

.brand_scroll_wrap{
  padding-bottom: 1em;
  padding-top:80px;
  overflow-x: auto;
  width: 100vw;
  margin:0 cacl(50% - 50vw);
}

.slick-slider{
  margin-bottom: 0;
}

.slide-items.movie li{
  padding: 1em;
  background: #fff;
  margin: 0 5px;
}

.slide-items.movie li .youtube{
  margin-bottom: 0;
}

.slide-items-brand li{
  overflow: hidden;
}

.slide-items-brand img{
  transition:1s all;
}

.slide-items-brand li:hover img{
  transform:scale(1.2,1.2);
  transition:1s all;
}

.brand_part .content:nth-of-type(2)::before, .brand_part .content:nth-of-type(3)::before{
  display: none;
}

.slide-items.movie {
  margin:0 auto;
}

.slide-items li{
  position: relative;
}

.factory__box a{
  position: absolute;
  top:0;
  left:0;
  width: 100%;
  height:100%;
  z-index: 1;
}

.factory__box .eye{
 width:100%;
}

.factory__box .eye img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body {
  counter-reset: number 0;
  overflow-x: hidden;
}

.factory__box .txt{
  font-size: 16px;
  letter-spacing: 0.08em;
  color: #363636;
  padding:0;
  position: relative;
  width:100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}


.factory__box .title{
  font-weight: 400;
  font-size: 18px;
  color:#262626;
  margin-bottom: .5em;
  font-weight: 600;
  min-height: 60px;
}

.factory__box .price{
  padding:0 0 .5em;
  border-bottom: 1px dashed #ccc;
  font-weight: 600;
  text-align: right;
}

.factory__box:not(:last-child){
  margin-left: 5px;
  margin-right: 5px;
}

.factory__index{
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  color:#b5b5b5;
  position: absolute;
  top:calc(var(--col-space) * 2);
  left:var(--row-space);
  font-size: 2.46vw;
  font-weight: 600;
  z-index: 1;
}

.factory__index a{
  color:#b5b5b5;
  -webkit-transition: all .3s;
  transition: all .3s;
}

.factory__index a:hover{
  color: var(--red);
}

.factory__index i{
  display: inline-block;
  margin-bottom: .5em;
}

dl.spec{
  display: flex;
  flex-direction: row;
  padding: .5em 0 0;
  font-weight: normal;
  font-size: 0.85rem;
  margin-top: 0;
  margin-bottom: 0;
  color:#808080;
}

dl.spec:last-of-type{
  margin-bottom: var(--col-space);
}

dl.spec dt{
  font-weight: normal;
  margin-right: 3%;
  margin-bottom: 0;
  padding-bottom: 10px;
  border-bottom: 1px solid #d4d1e7;
  width:24%;
}

dl.spec dd{
  margin-bottom: 0;
  padding-bottom: 10px;
  border-bottom: 1px solid #d4d1e7;
  width:73%;
}

dl.client{
  display: flex;
  column-gap: 10px;
  font-size: 0.8rem;
  height: 100%;
  color:#808080;
}

dl.client dt{
  width:25%;
  border-right: 1px solid #d4d1e7;
  font-weight: normal;
  padding-right: 2%;
}

dl.client dd, dl.client dd p{
  font-size: 0.75rem;
  color:#808080;
}

dl.client dd p{
  margin-bottom: 1em;
}

@media screen and (max-width: 767px) {
  dl.client{
    margin-top: var(--col-space);
  }

  dl.client dd, dl.client dd p{
    font-size: 0.8rem
  }

}

.brand__image{
  width:100%;
  height:50vh;
  position: relative;
}

.brand__image img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.spilits__image{
  width:100%;
  height:50vh;
  margin-bottom: var(--col-space);
}

.spilits__image img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.recruit_part {
  padding-left: var(--row-space);
  padding-top: var(--col-space);
  padding-bottom:var(--col-space);
  position: relative;
}

.recruit__image{
  width:100%;
  height:50vh;
}

.recruit__image img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.news_part {
  padding: var(--col-space) var(--row-space) 0;
  position: relative;
  z-index: 1;
}

.news_part::before{
  content: '';
  background: url(../images/border-bottom.png)no-repeat right bottom;
  width: 0;
  height:var(--col-space);
  position: absolute;
  z-index: 0;
  right:0;
  top:0;
}

.news_part::after{
  position: absolute;
  content: '';
  background: #f2f2f2;
  bottom:0;
  height:80%;
  width:0%;
  z-index: 0;
  left: 0;
}

.show.news_part::after{
    opacity:1.0;
    width:100vw;
    transition: .5s;
    transition-delay: .5s;
}

.news_part .image__wrap{
  background: url(../images/topics__bg.png)no-repeat right top;
  background-size: contain;
  position: relative;
  margin-bottom: calc(var(--col-space) * .5);
  opacity:0;
  filter: blur(10px);
}
.show.image__wrap{
transition: .25s;
transition-delay: .25s;
opacity:1;
filter: blur(0px);
padding-bottom: 5vh;
}

.news_part .image__wrap .images{
  max-width: 56.5vw;
}

.news_part .image__wrap .title__wrap{
  position: absolute;
  right: var(--col-space);
  bottom: 5vh;
}

.news_part h2.en__title img{
  width:37.97vw;
  bottom:-10vh;
  left:-2.01vw;
  z-index: 0;
  position: relative;
}

.news_part.sec__part h2.en__title span{
  position: relative;
  text-align: center;
  margin-bottom: 0;
  bottom:0;
  right:0;
}

.news_part p.title {
  text-align: center;
}
.news_part .main {
  margin-top: 20px;
}
.news_part .main .one {
  padding: 30px 45px;
}
.news_part .main .one a {
  display: flex;
  gap: 40px;
  transition: all .3s;
  position: relative;
}

/*.news_part .main .one a:after{
  font-family: "FontAwesome";
	content: '\f105';
  position: absolute;
  width:40px;
  height: 40px;
  line-height: 40px;
  background: var(--red);
  color: #fff;
  text-align: center;
  bottom:0;
  right:0;
  font-size: 20px;
  -webkit-transition: all .3s;
  transition: all .3s;
}*/

.news_part .main .one a:hover p.txt{
  color:var(--red) !important;
  text-decoration: underline;
  -webkit-transition: all .3s;
  transition: all .3s;
}

.news_part .main .one a:hover::after{
  right:-10px;
}
.news_part .main .one p.cat{
  display: inline-block;
  background: var(--blue);
  padding: 10px 25px;
  min-width: 33%;
  color:#fff;
  line-height: 1.0;
  text-align: center;
  margin-bottom: 0;
}

.news_part .main .one p.date {
  font-weight: 400;
  font-size: 18px;
  letter-spacing: 0.08em;
  font-style: italic;
  color: #a4a4a4;
  margin-bottom: 0;
}
.news_part .main .one p.txt {
  font-weight: 400;
  font-size: 18px;
  letter-spacing: 0.08em;
  color: #262626;
  margin-bottom: 0;
}

.more_btn {
  position: relative;
  text-align: center;
  border: none;
  margin: 2em 0 0 auto;
  background: transparent;
  min-height: 45px;
  padding: 0;
  width:max-content;
}

.more_btn a {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  font-weight: 600;
  font-size: 22px;
  letter-spacing: 0.08em;
  color: #121212;
  position: relative;
  padding-left: 5px;
  padding-top: 5px;
  text-decoration: underline;
  -webkit-transition: all .3s;
  transition: all .3s;
  padding-bottom: 10px;
  border-bottom: 2px solid #000;
  text-decoration: none;
}

.news .more_btn a, .recruit_part_wrap .more_btn a{
  justify-content: flex-start;
}

.more_btn a:hover{
color:var(--red);
}

.more_btn a:hover::before{
  -webkit-animation: prev-arrow .5s forwards;
    animation: prev-arrow .5s forwards;
}

@keyframes prev-arrow{
0% {
  opacity: 0;
  margin-left: 10px;
}
99.9%, 100% {
  opacity: 1;
  margin-left: 1px;
}
}

.news_part .more_btn a:hover span, .btn__wh:hover span{
 right:-10px;

}

.news_part .more_btn a:hover span:before, .btn__wh:hover span:before{
  left:-40px;
}

.cat_name{
  background: rgba(255,255,255,0.85);
  display: inline-block;
  padding: 10px;
  font-weight: 600;
  font-size: 1.1rem;
  color:#121212;
  text-align: center;
  position: absolute;
  bottom:0;
  left:0;
  z-index: 2;
}

.arrow__wrap{
  position: absolute;
  right:0;
  bottom:0;
}


.gallery_part {
  padding: var(--col-space) 0 var(--col-space) 0;
  width: auto;
  opacity:0;
filter: blur(10px);
}

.show.gallery_part{
transition: .25s;
transition-delay: .25s;
opacity:1;
filter: blur(0px);
}

.gallery_part .main {
  display: flex;
  flex-wrap: wrap;
  -moz-column-gap: 3.7335%;
       column-gap: 3.7335%;
  row-gap: 2.6041666667vw;
  margin:0 var(--row-space);
  justify-content: center;
}
.gallery_part .main .one {
  width: 22.2%;
}

.gallery_part .main .one:nth-of-type(2){
  margin-top: 12.5vh;
}

.gallery_part .main .one:nth-of-type(3){
  margin-top: 25vh;
}

.gallery_part::before {
  content: "";
  position: absolute;
  background: url(../images/bottom__bg.png)no-repeat center top;
  background-size: cover;
  top:0;
  width: 100vw;
  height: 100%;
  z-index: -1;
}

.contact_part{
  display: flex;
  justify-content: center;
  flex-direction: column;
  color: #fff;
  position: relative;
}

a.contact__btn{
  border:1px solid #162b39;
  padding: .7em 2em;
  text-align: center;
  display: block;
  color: #162b39;
  position: relative;
  font-size: 1.1rem;
  letter-spacing: 0.4em;
  max-width:413px;
  margin: auto;
  width:100%;
  font-family: "Source Sans 3", serif;
}

a.sec_contact{
  display: block;
  padding: .5em;
  text-align: center;
  color:#162b39;
  max-width: 300px;
  margin:0 auto 0;
  font-size: 0.9rem;
  border-color: #162b39;
}

a.contact__btn.sec_contact{
  max-width: 100%;
  padding: .5em 1em;
}

a.contact__btn.sec_contact::before{
  content: '';
  right: -15px;
  position: absolute;
  background: #d4d1e7;
  padding: 0;
  height: 15px;
  width: 30px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 0;
}

.access{
  display: flex;
  flex-direction: column;
  padding-left: var(--row-space);
}

.access p{
  margin-bottom: 0;
}

.wh_wrap{
  background: #fff;
  position: relative;
  z-index: 3;
  padding: var(--col-space) var(--row-space);
}

.wh_wrap h2{
  color:#c3c3c3;
}

.pagetop{
  position: absolute;
  bottom: 0;
  right:0;
}

.sec__part{
  padding: var(--col-space) var(--row-space);
}

a.btn__wh{
  outline: 1px solid #000;
  color:#000;
  font-size: calc(var(--h3) / 4);
  text-align: center;
  display: block;
  max-width: 495px;
  position: relative;
  padding: 1.25em 0.55em 1.25em 1em;
}

a.btn__wh.mt{
  margin-top: 2em !important;
}
a.btn__wh.mtb{
  margin-top: 2em !important;
  margin-bottom: 2em !important;
}
a.btn__wh::before{
  background: #000;
  width:4px;
  content: '';
  height: 100%;
  top:0;
  left: 0;
}

a.btn__wh::after{
  font-family: "FontAwesome";
	content: '\f105';
  width: 30px;
  height: 30px;
  margin-left: .5em;
  position: absolute;
  line-height: 30px;
  right: .15em;
  background: transparent;
  color: #000;
  top: 50%;
  transform: translateY(-50%);
}

a.btn__wh.contact{
  background: var(--red);
  margin-left: auto;
  margin-right: auto;
  font-size: 1.3rem;
  color:#fff;
}

a.btn__wh.contact::after{
  color: #fff;
}

a.btn__wh:hover{
  background:#000;
  transition: all .3s;
  color:#fff;
}

a.btn__wh:hover::after{
  color:#fff;
}

a.btn__wh:last-of-type{
  margin-top: 0;
}

@media screen and (min-width: 768px) and (max-width: 1024px) {
  .plusmark{
    width: 25px !important;
  }
}

@media screen and (max-width: 767px) {

  a.btn__wh.contact{
    max-width: 95%;
    margin-left: auto;
    margin-right: auto;
  }
}

/****************  レイアウト *************************/

.flex-box{
  display: flex;
  flex-wrap: wrap;
  justify-content:flex-start;
  column-gap: 1.75%;
  row-gap: 2vh;
}

.image__concept__wrap{
  display: flex;
  flex-direction: column;
  justify-content: center;
  row-gap: 5vh;
}

.image__concept__wrap picture:first-of-type{
  margin-left: auto;
  margin-right: -4.46vw;
  display: block;
}

.entory__btn{
  max-width: 500px;
  margin:2em auto 0;
}

.image__concept__wrap picture.second{
  max-width: 400px;
  margin-top: calc(var(--col-space) / 2);
}

.flex-box.js-end{
  justify-content: flex-end;
}

.flex-box.center{
  justify-content: center;
}

.flex-box.space{
  justify-content: space-between;
}
.flex-box.reverse{
  flex-direction: row-reverse;
}
.flex-box .Hurf{
  width:var(--flex_hurf);
}

.flex-box.contact .Hurf:first-of-type{
  width:50%;
}
.flex-box.contact .Hurf:last-of-type{
  width:40%;
}
.flex-box .third{
  width:var(--flex_third_space);
}

.flex-box.greeting .about_one:first-child{
  width:40%;
}

.flex-box.greeting .about_one:last-child{
  width:50%;
}

.plusmark{
  width: clamp(22px,42px,48px);
  background: url(../images/plus.svg)no-repeat center;
  background-size: contain;
}

.flex-box.center{
  justify-content: center;
}

.flex-box.end{
  align-items: flex-end;
}

.flex-box.space{
  justify-content: space-between;
}

.flex-box.align__items{
  align-items: center;
}

.flex-box .about_one{
  width:var(--flex_hurf);
}

.nowrap{
  flex-wrap:nowrap;
}

.about_part .greeting.flex-box .about_one{
	  width:var(--flex_hurf);
}

.greeting .flex-box .about_one:last-of-type{
   text-align: right;
}

.flex-box .about_one h2{
  margin-bottom: 0;
  text-align: right;
}

.flex-box .about_one.Center{
  text-align: center;
}

.flex-box + p{
  margin-top: calc(var(--row-space) / 2);
}

.flex-box .fourth{
  width:var(--flex_fourth);
}

.flex-box .fifth{
  width:var(--flex_five);
}



.wh__curcle{
  background: #fff;
  padding: 2em;
  text-align: center;
  border-radius: 50%;
  width:18vw;
  height:17.5vw;
  text-align: center;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  margin:0 auto .5em;
  position: relative;
  max-width: 90%;
}

.flex-box .fifth:last-of-type .wh__curcle::after{
  display: none;
}
.wh__curcle img{
  max-width: 100%;
}
.wh__curcle img.min{
  max-width: 85%;
}

.fl__title{
  color:#0f002e;
  font-weight: 600;
  font-size: calc(var(--h4) * 1.25); 
  margin-bottom: .5em !important;
}

@media screen and (max-width: 767px) {
	.wh__curcle img {
    max-width: 60%;
}
.flex-box.greeting .about_one:first-child{
  width:100%;
  margin-bottom: var(--col-space);
}

.flex-box.contact .Hurf:first-of-type{
  width:100%;
}
.flex-box.contact .Hurf:last-of-type{
  width:100%;
}

.flex-box.greeting .about_one:last-child{
  width:100%;
}

dl.spec dt, dl.client dt{
  width: 30%;
}
	
}

ul.worries{
  list-style: none;
}

ul.worries.points{
  margin-bottom: 2em;
}

ul.worries li{
  padding: 1em;
  background: #ededed;
  font-weight: bold;
  font-size: 1.1rem;
  margin-top: 1em;
}

ul.worries.points li{
  font-weight: bold;
  border: 3px solid #4c9ac0;
  background-color: #fff;
  padding: 1em 1em;
  position: relative;
}

ul.worries.points li::after {
  content: '';
  background-color: #4c9ac0;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  transform: rotate(-1deg);
}

.triangle {
  width: 200px;
  height: 200px;
  background: linear-gradient(45deg, transparent 50%, #ffffff 50%, #cccccc);
  transform:rotate(135deg);
  margin:0 auto 1em;
  }

  p.Center.big{
    font-size:calc( var(--h3) / 2);
    font-weight: bold;
    margin-top: 2em;
  }

  p.price{
    font-family: Arial, Helvetica, sans-serif;
    font-size:calc( var(--h3) / 1.5);
  }

  p.price span{
    font-size: 1.25rem;
    display: inline-block;
    margin: 0 10px;
    margin-top: -10px;
    font-weight: normal;
  }

  .equipment{
    width:calc(96% / 3);
    background: #262626;
    padding: 1em;
    text-align: center;
    color:#fff;
    border-radius: 0.046em;
  }

  @media screen and (max-width: 767px) {

    .casting_part .flex-box{
      row-gap: 1.5vh;
    }

    .wh__curcle{
      width:200px;
      height:200px;
    }

    .wh__curcle::after{
      display: none;
    }

    a.contact__btn{
      max-width: 90%;
    }

    .triangle {
      width: 60px;
      height: 60px;
      background: linear-gradient(45deg, transparent 50%, #ffffff 50%, #cccccc);
      transform:rotate(135deg);
      margin:0 auto 1em;
      }
      p.Center.big{
        margin-top: 1em;
        font-size: calc(var(--h3) / 3);
      }
      .flex-box{
        column-gap: 2%;
        row-gap: 1vh;
      }
  }

  .flow_design {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    max-width: 1000px;
  }
  
  .flow_design ul {
    padding: 0;
  }
  
  .flow_design li {
    list-style-type: none;
  }
  
  .flow_design dd {
    margin-left: 0;
    font-size: 18px;
  }
  
  .flow {
    position: relative;
  }
  
  .flow::before {
    content: "";
    width: 15px;
    height: 100%;
    background: #eee;
    margin-left: -129px;
    display: block;
    position: absolute;
    top: 0;
    left: 120px;
    border-radius: 20px;
  }
  
  .flow > li {
    position: relative;
  }
  
  .flow > li:not(:last-child) {
    margin-bottom: 60px;
  }
  
  .flow > li .icon {
    font-size: 0.8em;
    width: 2em;
    height: 2em;
    line-height: 2;
    text-align: center;
    font-weight: bold;
    border-radius: 100vh;
    color: #fff;
    background: #8EB83C;
    display: inline-block;
    margin-right: 0.3em;
  }
  
  .flow > li dl {
    padding-left: 70px;
    position: relative;
  }
  
  .flow > li dl::before,
  .flow > li dl::after {
    content: "";
    display: block;
    position: absolute;
    top: 15px;
  }  
  .flow > li dl::before {
    width: 7px;
    height: 7px;
    margin-top: -3px;
    background: #8EB83C;
    border-radius: 50%;
    left: -4px;
  }
    
  .flow > li dl::after {
    width: 50px;
    border-bottom: 1px dashed #999;
    position: absolute;
    left: 5px;
  }

  
@media screen and (max-width: 767px) {
  .flow > li dl::before {
    width: 9px;
    height: 9px;
    margin-top: -3px;
    background: #8EB83C;
    border-radius: 50%;
    left: 0px;
  }
  .selif__center::before {
    top: -0px;
    left: 15px;
}
}
  
  .flow > li dl dt {
    font-size:20px;
    font-weight: 600;
    color: #8EB83C;
    margin-bottom: 0.5em;
    display: flex;
    align-items: center;
  }
  .dropmenu {
    width: 100%;
    margin: 0 auto;
  }
  .dropmenu li {
    position: relative;
  }
  .dropmenu li a {
    display: block;
    margin: 0;
    padding: 1.1em 1em;
    font-size: 16px;
    cursor: pointer;
  }
  
  .dropmenu li ul {
    position: absolute;
    width: 100%;
    z-index: 9999;
    top: 100%;
    left: 0;
    display: flex !important;
    flex-direction: column !important;
  }
  .dropmenu li ul li{
    overflow: hidden;
    height: 0;
    transition: .2s;
  }
  .dropmenu li ul li a{
    border-top: 1px solid #999;
    background: #000;
    color: #fff;
    padding: 1em !important;
  }
  .dropmenu li ul li:first-child a{
    border-top: none;
  }

  header nav.gloval ul .dropmenu li ul {
    width:140%;
    left:-20%;
  }

  header nav.gloval ul .dropmenu li ul{
    background: #000;
  }

  header nav.gloval li a{
    outline:0;
  }

  header .symbol{
width: 400px;
    position: absolute;
    bottom: 0;
    right: var(--row-space);
    padding-bottom: 2em;
  }
   header .symbol picture{
     max-width: 350px;
    display: block;
    margin-left: auto;
    margin-top: 1em;
   }

  @media screen and (min-width: 601px) {
    .dropmenu li:hover ul li{
      overflow: visible;
      height: 56px;
    }
    .dropmenu li ul li a:hover {
      background: #666;
      transition: .5s;
    }
  }

  @media screen and (max-width: 600px) {
    .dropmenu li.active_sp a:after {
      transform: rotate(180deg);
      transition: .1s;
    }
    .dropmenu li.active_sp ul li{
      overflow: visible;
      height: 40px;
    }
  }

  @media screen and (max-width: 767px) {
  .dropmenu li a{
    font-size: 0.75rem;
    padding: 1em;
  }

  }
  /****************  お知らせ *************************/

  .news__list{
    display: flex;
    column-gap: 2%;
    row-gap: 2.5vh;
    flex-wrap: wrap;
    justify-content: flex-start;
  }

  .news__list .item{
    width:var(--flex_third);
    padding: 1em;
    border: 1px solid #ddd;
  }

  .News__scroll{
    max-height: 600px;
    overflow-y: auto;
    padding:0 clamp(1em,2.6vw,2.7vw);
  }

/****************  製品情報=TOP & 詳細ページ *************************/

.products__archive__wrap{
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  justify-content: flex-start;
}

.products__archive__wrap .Item{
  width: calc(96% / 3);
  margin-right: 2%;
  margin-top: var(--s2-space);
}

.products__archive__wrap .Item:nth-of-type(3n){
  width: calc(96% / 3);
  margin-right: 0;
}

.products__archive__wrap .Item h3{
  font-size: var(--h4);
  margin-top: 1.5em;
  color:#010101;
}

.products__archive__wrap .Item h3 a{
  color:#010101;
}

.products__archive__wrap .Item a img{
  transition: all .3s;
  height: auto;
}

.products__archive__wrap .Item a img:hover{
 opacity: 0.8;
 background: #fff;
}

@media screen and (max-width: 767px) {

  .products__archive__wrap .Item{
    width: 100%;
    margin: 0 auto var(--s2-space);
  }
  
  .products__archive__wrap .Item:nth-of-type(3n){
    margin-right: 0;
  }
  
}

.slider-photo, .thumbnail{
 margin:0 auto 1em;
}
.slider-photo li{
  text-align: center;
}

.slider-photo img{
  margin: auto;
}

ul.thumbnail li{
  background: #fafaf9;
  height: 100%;
  margin: 0 5px;
}

ul.thumbnail img{
  width: 100%;
  height: 100%;
  max-height: 280px;
  object-fit: contain;
  object-position: 50% 50%;
  background: #fff;
}

.products_txt{
  margin:2em auto;
}

.products_txt .short{
  max-width: 1000px;
}

.products_txt .short.wide .about_one:first-child{
  width:auto;
}

.products_txt .short .main_container1 + .main_container1{
  margin-top: var(--s3-space);
  margin-bottom: 0;
}

.products_txt .short .main_container1{
  flex-direction: row;
  align-items: center;
}

figure.Center{
  text-align: center;
}

figure.Center img{
  margin: auto;
}

.about_part .short .about_one:last-of-type{
  width:80%;
  margin-left: 2%;
}

.products_txt table{
  border:1px solid #ccc;
  border-right: 0;
  border-bottom: 0;
  width: 100%;
  border-spacing: 0;
  border-collapse: collapse;
  min-width: 500px;
  font-size: 1.0rem;
  margin: 2em auto;
}

.table-container table.min{
  min-width: 300px;
}

.table-container table{
  background: #fff;
}

.products_txt table th, .products_txt table td{
  padding: .5em;
  border-right: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  text-align: center;
}

.products_txt table td p:last-child{
  display: none;
}

.products_txt table .rtecenter, .products_txt table th{
  background: #ddd !important;
  text-align: center;
  font-weight: 400;
}

.table-container {
  position: relative;
  overflow-x: auto;
  white-space: nowrap;
}

/****************  修理事例 *************************/

.factory img{
  display: block;
  margin: var(--s2-space) auto;
}

.scroll-hint {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 10px;
  background: rgba(0, 0, 0, 0.5);
  color: #fff;
  font-weight: 700;
  line-height: 1.4;
  display: none;
  animation: scroll-hint-animation 2s infinite ease;
}

@keyframes scroll-hint-animation {
  0% {
    transform: translate(-50%, -50%);
  }
  50% {
    transform: translate(-40%, -50%);
  }
  100% {
    transform: translate(-50%, -50%);
  }
}

.scroll-hint--show {
  display: block;
}

.detail_part{
  max-width: 1100px;
  margin: auto;
}

.detail_part p{
  margin-top: var(--s2-space);
  margin-bottom: var(--s2-space);
}

.detail_part .title{
  font-family: "a-otf-ryumin-pr6n", serif;
  font-size: 20px;
  margin-bottom: 1em;
  font-style: italic;
  letter-spacing: 0.083em;
}

.detail_part dl{
  margin-top: 20px;
  display: flex;
  font-size: 1.0rem;
  justify-content: space-between;
}
.detail_part dl dt{
  padding: 1em;
  display: flex;
  align-items: center;
  border-top:1px solid #121212;
  border-bottom:1px solid #121212;
  width:25%;
  font-family:'Noto Sans JP',游ゴシック体, 'Yu Gothic', YuGothic,'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}
.detail_part dl dd{
  font-weight: normal;
  letter-spacing: 0.08em;
  width:74%;
  text-align: left;
  color: #121212;
  display: flex;
  justify-content: center;
  flex-direction: column;
  padding: 1em;
  margin-bottom: 0;
  line-height: 1.8;
  border-bottom: 1px solid rgba(180, 165, 146, 0.5);
  border-top: 1px solid rgba(180, 165, 146, 0.5);
  font-family:'Noto Sans JP',游ゴシック体, 'Yu Gothic', YuGothic,'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}

.detail_part dd p{
  margin-top: 0;
  margin-bottom: 1em;
}

.mail h3{
  font-size:var(--h4);
  font-weight: bold;
  margin-top: 5vh;
}

input[type="radio"]{
  width:25px;
  height:25px;
  vertical-align:top;
}

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="search"],
input[type="password"],
select,
textarea {
	-moz-appearance: none !important;
	-webkit-appearance: none !important;
	appearance: none !important;
 	-webkit-border-radius: 3px;
-moz-border-radius: 3px;
border-radius: 3px;
padding:1em .5em;
border:solid 1px #a7a7a7;
background: #fff !important;
margin:auto;
width:100%;
display:block;
color:#000 !important;
line-height:1.4;
  box-shadow: 4px 4px 10px 0px rgba(0, 0, 0, 0.2);
  width: 100%;
}

.caution p{
  font-size: 13px;
  color:#b4b4b4;
  margin-top: .25em;
}

input[type="text"]:focus,
input[type="tel"]:focus,
input[type="email"]:focus,
input[type="search"]:focus,
input[type="password"]:focus,
textarea:focus,
select:focus {
border:solid 1px #d00249;
background-color: #f2f2f2;
}

input[type="text"], input[type="email"], input[type="password"], input[type="tel"]{
    background-color: transparent;
    border:none;
}

input[type="reset"],
input[type="button"],
input[type="submit"],
button {
   color: #FFFFFF;
	display:block;
   margin:1em auto 0 auto;
   padding:25px;
   -moz-appearance: none !important;
	-webkit-appearance: none !important;
	appearance: none !important;
	cursor: pointer;

}

select{
  border:none;
  width: 50%;
  margin: 0;
}

input[type="submit"]{
  padding: 0;
  background: transparent;
  border: none;
  font-size: 0;
  background: url(../images/mail.svg)no-repeat center;
  background-size: contain;
  width: 60px;
  height: 60px;
}
input[type="submit"]:hover{
    background: url(../images/submit.svg)no-repeat center;
  background-size: contain;
}

.pulse-btn-center .Inner p{
  height: 60px;
}

select{
 font-size:1.0rem;
 }

.aboutus_wrap{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  position: relative;
  padding: var(--row-space);
  background: #fafaf9;
  margin: var(--s2-space) auto;
}

.aboutus_wrap .Item{
  width: calc(96% / 2);
  margin: 2em 0;
  position: relative;
  z-index: 1;
}

.aboutus_wrap::after{
  content: '';
  border:30px solid #c3cbe3;
  position: absolute;
  z-index: 0;
  width: 80%;
  height: 40%;
  top: 40%;
  left: 50%;
  transform: translateY(-40%) translateX(-50%);
}

.contact_part{
  background: #f2f2fa;
  padding:calc( var(--row-space) / 1.2 ) var(--row-space);
  position: relative;
  z-index: 3;
}

.privacy h3{
  font-size: 1.2rem;
  margin: 5vh auto 1em !important;
  font-weight: bold;
}

section.banner{
  background: #fff;
  padding: var(--col-space) var(--row-space);
}

.banner__wrap{
  display: flex;
  flex-wrap: wrap;
  column-gap: 0.5%;
  row-gap: .5vh;
  max-width: 1000px;
  margin: 0 auto;
}

.banner__wrap li{
  width: calc(98.5% / 3);
  margin: 0;
}

.scroll-top {
  position: fixed;
  bottom: 30px;
  right: 30px;
   width: 45px;
  height: 45px;
  background: white;
  border-radius: 50%;
  cursor: pointer;
   display: flex;
  justify-content: center;
  align-items: center;
  z-index: 5;
  border:1px solid #c88989;
}
  .scroll-top a {
    text-decoration: none;
    color: #c88989;
    font-size: 16px;
  }
  @media screen and (max-width: 767px) {

    .scroll-top{
      bottom: 10px;
      right: 10px;
       width: 40px;
      height: 40px;
    }

  }

footer {
  padding:2em var(--row-space);
  font-size: 1.0rem;
  position: relative;
  z-index: 1;
  margin-top:0;
  background: #000000;
}

footer *{
  color:#fff;
}

footer .main_container{
  max-width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

footer .logo{
  max-width: 300px;
  width: 100%;
}

.sns{
  display: flex;
  justify-content:flex-end;
  gap:2%;
}

.sns a{
  color:#000;
  font-size: 0.9rem;
}

 .sns i{
  font-size: 30px;
}

.Right .sns{
  justify-content: center;
}

footer .link__wrap{
  padding: 0;
}

footer .link__wrap ul{
  list-style: none;
  display: flex;
  padding: 0;
  column-gap: 1.7em;
  font-size: 0.9rem;
}

footer .link__wrap ul li{
  letter-spacing: 0.086em;
}

footer .link__wrap .Inner .Hurf ul.link li a{color: #0f002e;font-family: Calibri, Candara, Segoe, Segoe UI, Optima, Arial, sans-serif;}

footer .link__wrap .Inner .Hurf ul.link li a:hover{
  text-decoration: underline;
}

footer .main{
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

footer.sec{
  background: #fff6b5;
}

footer.sec a, footer.sec li, footer.sec p, footer.sec li:after{
  color:#e3b000 !important;
}

footer .main ul.link{
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
}

footer .main ul.link li{
  margin-right: 10px;
  font-size: 0.9rem;
}

footer .main ul.link li::before{
  content: '>';
  display: inline-block;
  margin-right: 5px;
}

footer .main ul.link li a{
  color:#000000;
}

footer .main .instagram{
  width: 50%;
  text-align: left;
  font-family: "goudy-old-style", serif;
  font-size: 16px;
  color: var(--key-Color);
}

footer .main .instagram a{
  color: var(--key-Color);
}

p.copyright {
  font-weight: normal;
  font-size: clamp(10px,12px,13px);
  letter-spacing: 0.08em;
  color: #fff;
  text-align: center;
  margin:5vh auto 0;
    font-family: "acumin-pro", sans-serif;

}

footer .link__wrap .item a{
  -webkit-transition: all .3s;
  transition: all .3s;
}

footer .link__wrap .item a:hover{
  opacity: 0.75;
}

@media screen and (min-width: 768px) and (max-width: 1240px) {

  footer .link__wrap .Inner .Hurf{
    width: 100%;
    margin: 0 auto 2em;
    justify-content: center;
  }

  footer .link__wrap .Inner .Hurf:last-child{
    margin-bottom: 0;
  }

}
@media screen and (max-width: 767px) {
  footer .link__wrap .Inner .Hurf:first-of-type, footer .link__wrap .Inner .Hurf:last-of-type{
      width:100%;
  }
  footer .link__wrap .Inner .Hurf .flex{
    flex-direction: column;
    align-items: center;
  }
  footer .main_container1{
    padding: 1em var(--row-space);
  }
}
  
hr{position: relative;background: #ddd;opacity: 1;margin: var(--col-space) auto;}

hr::after{
  content: '';
  background: var(--blue);
  position: absolute;
  top:0;
  height: 1px;
  width:100px;
  right: var(--col-space);
  left: 50%;
  transform:translateX(-50%);
}

hr + section{
  padding-top: 0 !important;
}

.deck .wrap{
  display: flex;
}
.area{
  overflow: hidden;
}

.deck .full_image{
	z-index:1;
}

.deck .wrap .item{
  width:100vw;
  height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.deck .full_image img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.deck .full_image .text{
	position:absolute;
	right:1.5vw;
	top:10vh;
	width:60vw;
	height:30vh;
}

.deck .full_image .text img{
	object-fit: contain;
}

iframe {
    border: 0;
    margin: auto;
    display: block;
}

@media only screen and (max-width: 1360px) {

  .factory__index{
    display: none;
  }

  p.title {
    font-size: 4.6448529412vw;
  }

  header .header .header_main ul {
    gap: 2.9411764706vw;
  }

  header .header_main{
    margin-top: 0;
  }

  header .title_wrap{
    top: 7.85vh;
  }

  header .header_main{
    margin-top:0;
  }

  .page__fv{
    min-height: 35vh;
  }
  
  .page__fv h1{
    font-size: 1.55rem;
  }

  .top_slider .main_content{
    top: 7vh;
  }
  
  .top_slider .main_content h2 span{
    margin-top: 2.5vh;
  }

  .top_slider .main_content h3 {
    font-size: 4.275vw;
    line-height: 5.1323529412vw;
    color: #100a0c;
    margin-top: 2.2058823529vw;
  }
  .top_slider .instagram_link {
    left: 0.7352941176vw;
    bottom: -1.4705882353vw;
  }
  .top_slider .instagram_link a {
    font-size: 1.3235294118vw;
    line-height: 1.7654411765vw;
  }

  .about_part .main_container1 .about_one .content {
    padding: 1.4705882353vw 0.8823529412vw;
    min-height: 25.7352941176vw;
  }
  .about_part .main_container1 .about_one .content h4 {
    font-size: 2.3529411765vw;
    height: 6.6176470588vw;
  }

  .aboutus_wrap{
  margin: var(--col-space) calc(50% - 50vw);
  width: 100vw;
  }

  .aboutus_wrap::after{
    width:0px;
    height: 65%;
    border: 15px solid #c3cbe3;
    opacity: 0.25;
  }

  .aboutus_wrap .Item{
    width: 100%;
  }

  .about_part .main_container1 .about_one.small{
    width:100%;
  }

  .philosophy_part {
    padding-top: 6.25vw;
    padding-bottom: 6.25vw;
  }
  .philosophy_part .content p.txt2 {
    font-size: 5.2022058824vw;
  }
  .philosophy_part .content p.txt3 {
    font-size: 1.3235294118vw;
    line-height: 2.7933823529vw;
    margin-top: 2.2058823529vw;
  }
  .news_part .main {
    margin-top: 1.4705882353vw;
  }
  .news_part .main .one {
    padding: 2.2058823529vw 3.3088235294vw;
  }
  .news_part .main .one a {
    gap: 2.9411764706vw;
  }

  .news_part .main .more_btn a {
    font-size: 16px;
  }
 
  .more_btn a{
    padding-top: 0;
    font-size: 19px;
  }

  .more_btn a:before {
    width: 35px;
    height: 35px;
    line-height: 35px;
  }
  .products_part {
    padding: 8.8235294118vw 11.1979166667vw 8.8235294118vw 11.3020833333vw;
  }
  .products_part .main {
    margin-top: 3.6764705882vw;
  }
  .products_part::before {
    width: 23.5294117647vw;
  }  

  footer .contact_link .one {
    width: 42.5735294118vw;
    height: 12.5vw;
    border: 0.2205882353vw solid #efe8d9;
  }
  footer .contact_link .one p.txt1 {
    font-size: 1.3235294118vw;
  }
  footer .contact_link .one p.txt2 {
    font-size: 3.1448529412vw;
  }
  footer .contact_link .one p.txt2.phone::before {
    padding-right: 0.8823529412vw;
  }
  footer .main {
    row-gap: 1.8382352941vw;
  }
  footer .main .menu_list a {
    font-size: 1.1764705882vw;
  }
}

@media only screen and (min-width: 768px) and (max-width: 1024px) {

body, p{
  font-size: 1.0rem;
}

.top_slider .main_content{
  top: 4vh;
}
section h2.en__title span.jan{
  margin-top: 1em;
}

.about_part .main_container1{
  flex-wrap: wrap;
}

.about_part .main_container1 .about_one .content, .about_part .main_container1 .about_one{
  width:100%;
}

.top_slider .slick-next{
  right:10px;
}

.top_slider .slick-prev{
  right:80px;
}

.top_slider .slick-next, .top_slider .slick-prev{
  bottom:0;
}

.spilits_part{
  padding-left: var(--row-space);
}

section h3{
  font-size: 1.65rem;
}
.recruit_part .content:nth-of-type(2){
  padding-top: 5vh;
}

.recruit__image, .brand__image, .spilits__image{
  height: 30vh;
}

.factory__box{
  width:95%;
  margin-left: auto;
  margin-right: auto;
}

.factory__box:before{
  right:2em;
}

footer .link__wrap .Inner .Hurf ul.link li{
  width: calc(96% / 2);
  font-size: 0.9rem;
}

footer .link__wrap .Inner .Hurf:first-child{
  flex-wrap: wrap;
}


footer .link__wrap .Inner .Hurf > div:last-child{
  width: 100%;
  margin-top: .5em;
}
}

@media only screen and (max-width: 767px) {

  .sp_menu_btn{
    top: 12px;
    right: 1em;
  }

  header .header .header_main.open .Right .copy{
    display: none;
  }

  header .header .header_main.open{
    display: block;
  }
  
  header .header .header_main.open .Left{
    display: none;
  }

  header .header .header_main.open .Right{
    width:100%;
    height: 100%;
  }

  header .header .header_main.open ul li a {
    font-size: 24px;
    display: block;
    background: #fff;
    padding: .5em;
    border-top: 4px solid #cfffe0;
  }

  header .header .header_main ul li a:after{
    bottom: -5px;
  }

  header .header .header_main.open ul {
    height: 100%;
    flex-direction: column;
    justify-content: center;
    gap: 6.5238095238vw;
  }


  header .show.header_main ul p.logo{
    max-width: 250px;
    margin: 0 auto 0;
  }

  .top_slider .disc{
    margin-top: 1em;
    font-size: 0.9rem;
  }

  .title_wrap{
    max-width: 95%;
    bottom:2vh;
    left:2.5em;
  }

  section h2.en__title span.jan{
    margin-top: .5em;
  }
	.deck .wrap .item{
		justify-content: flex-start;
	}
	
	.deck .full_image .text{
	position:absolute;
	right:2.5vw;
top: 50%;
  transform: translateY(-50%);
	width:90vw;
	height:30vh;
}

  .about_one h3 {
    font-size: calc(var(--h3) / 3);
}

.about_part .short .about_one:last-of-type{
  font-size: 1.0rem;
}

.recruit_part::before{
  width: 60vw;
}

.spilits_part{
  padding-left: var(--row-space);
}

.deck .wrap .item{
  justify-content: flex-start;
  padding:var(--col-space) var(--row-space);
}
	
	.deck .wrap .item.image{
		padding:0;
	}

.recruit__image, .brand__image, .spilits__image{
  height: 30vh;
}

.brand_part .slick-prev:after, .category_part .slick-prev:after{
  right:-5px;
}
.site__title{
  width:90vw;
  bottom:0;
}

  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
  .main_container {
    padding: 0 5%;
  }
  p.title {
    font-size: 6.6666666667vw;
  }
  header .header {
    padding:1em 0;
    height: auto;
  }

  .top_slider .slick-next, .top_slider .slick-prev{
    width: 40px;
    height: 40px;
  }

  .top_slider .slick-next, .top_slider .slick-prev{
    bottom:0;
  }

  .top_slider .slick-prev{
    right:60px;
  }

  .top_slider .slick-next{
    right:15px;
  }

  .header_logo {
    width: 200px;
    margin-top: 0px;
	  right:inherit;
	  left:var(--row-space);
  }

  .header_logo img {
    width:280px;
    left: 1em;
  }
  header .header a.contact_btn {
    display: none;
  }
  header .header .header_main {
    display: none;
  }

  header .header_logo .discription{
    margin-top:1.5vh;
	font-size:12px;
  }

  header .title_wrap{
    display: none;
  }

  .c-scrolldown{
    right: 0;
    width: 65px;
    bottom: 19.5vh;
  }

  .slider-dot-box{
    right: calc(var(--row-space) * 2.8);
  }

  .top_slider .scroll__down{
    bottom:2vh;
    right: calc(var(--row-space) * 1.35);
    color:#ccc;
    font-size: 14px;
  }

  .slider-dot button{
    line-height: 30px;
  }

  .top_slider {
    padding-right: 0;
    padding-left: 0;
    margin-top:0;    
  }
  .top_slider .top_slide_main {
    width: 100vw;
  }
  .top_slider .top_slide_main .slide {
    height:70vh;
  }
  .top_slider .top_slide_main .slide img {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    max-height: 70vh;
  }
  .top_slider .main_content {
    left: inherit;
    right:var(--row-space);
    top: 5vh;
    bottom: inherit;
  }

  .bottom__square{
    width:50%;
  }

  .top_slider .main_content h2{
    color:#fff;
    font-size: 5.1428571429vw;
  }

  .top_slider .main_content h2 span {
    font-size: 7.1428571429vw;
  }
  .top_slider .main_content h3 {
    font-size: 7.1428571429vw;
    line-height: 10.7142857143vw;
    color: #100a0c;
    margin-top: 7.1428571429vw;
    display: flex;
    justify-content: center;
  }
  .top_slider .instagram_link {
    left: 2.380952381vw;
    bottom: 2.380952381vw;
  }
  .top_slider .instagram_link a {
    font-size: 4.2857142857vw;
    line-height: 5.7166666667vw;
  }
  .top_slider .instagram_link a::after {
    padding-top: 2.380952381vw;
  }
  .top_slider .instagram_link a span {
    display: none;
  }
  section h3, .detail_part .title{
    font-size: 19px;
    line-height: 1.8;
  }
  .about_part .Inner::before {
    display: none;
  }

  .show.brand_part_wrap::after{
    width: 70vw;
  }

  .about_part .flex-box.end{
    flex-direction: column-reverse;
  }

  .about_part .main_container1 {
    flex-direction: column;
    row-gap: 11.9047619048vw;
  }
  .about_part .main_container1 .about_one {
    width: 100%;
  }
  .about_part .main_container1 .about_one .content {
    padding: 0 0 11.9047619048vw;
    min-height: auto;
  }
  .about_part .main_container1 .about_one .content h4 {
    font-size: 6.6666666667vw;
    height: 14.2857142857vw;
  }
  .about_part .main_container1 .about_one .content .three{
    margin-top: 5vh;
  }

  .about_part h2.en__title img{
    width:72vw;
    bottom:-2vh;
  }

  .detail_part dl{
    display: block;
  }

  .detail_part dl dt{
    width: 100%;
    justify-content: center;
  }

  .detail_part dl dd{
    width: 100%;
  }

  .brand_part{
    padding-right: 0;
  }

  .brand_part .content:first-child{
    margin-bottom: var(--row-space);
  }

  .brand_part .content:first-child, .brand_part_wrap .content:nth-of-type(2){
    width:calc(100% - var(--row-space));
    max-width:calc(100% - var(--row-space));
  }

  .brand_part_wrap{
    flex-direction: column-reverse;
  }

  .brand_part_wrap .content:nth-of-type(2){
    margin-right:0;
  }

  .brand_part h2.en__title{
    margin-top:5vh;
  }

  .brand_part .slick-next{
    right:20px;
  }

  .brand_part .slick-prev{
    right:50px;
  }

  .category_part .slick-prev{
    left: 20px;
  }

  .category_part .slick-next{
    left: 50px;
  }

  .contact_part h2.en__title span.jan{
    padding: .55em;
  }

  .brand_part .slick-prev, .brand_part .slick-next, .category_part .slick-prev, .category_part .slick-next{
    top:-30px;
  }

  h3.l-border{
    font-size: calc(var(--h3) / 3.5);
  }
  .selif__center{
    font-size: calc(var(--h3) / 2.8);
  }

  .map iframe{
    height:30vh !important;
 }

 .pagetop{
  right: 5px;
 }

  .recruit_part .content, .recruit_part .content:nth-of-type(1), .recruit_part .content:nth-of-type(2){
    padding-top: 0;
    width:100%;
    max-width: 100%;
  }

  .factory__box .txt:before{
    font-size: 38px;
  }

  .factory__box:before{
    right:2em;
  }

  .factory__box span.cat{
    font-size: 0.8rem;
  }

  .factory__box::after {
    width: 25px;
    line-height: 25px;
    height: 25px;
  }

  .brand_scroll_wrap{
    padding-top: 60px;
  }

  .factory__box{
    max-width: 92%;
    margin-left: auto;
    margin-right: auto;
  }

  .news_part h2.en__title img{
    width:82vw;
  }

  .news_part .image__wrap .title__wrap{
    bottom: 10vh;
    position: relative;
    left: 2.5vw;
  }

  .brand_part h2.en__title img{
    top:0;
    width:82vw;
    left:-90%;
  }

  .news_part .image__wrap .images{
    max-width:calc(100% - var(--row-space));
  }

  .news_part .main_container1{
    margin-top:-7vh;
    padding: 0 var(--row-space);
  }

  .philosophy_part {
    padding: 11.9047619048vw 5%;
    flex-direction: column-reverse;
  }
  .philosophy_part .content {
    width: 100%;
  }
  .philosophy_part .content p.txt2 {
    font-size: 11.4285714286vw;
  }
  .philosophy_part .content p.txt3 {
    font-size: 4.2857142857vw;
    line-height: 7.619047619vw;
    margin-top: 7.1428571429vw;
  }

   .news_part .main {
    margin-top: 11.9047619048vw;
    border-top: 0;
  }
  .news_part .main .one {
    padding: 4.7619047619vw 0;
  }
  .news_part .main .one a {
    flex-direction: column;
    gap: 1.9047619048vw;
  }
  .news_part .main .one p.date, .factory__box .date{
    font-size: 3.8095238095vw;
    margin-bottom: 0;
  }
  .news_part .main .one p.txt {
    font-size: 3.8095238095vw;
  }
  .factory__box p.txt{
    font-size: 2.8095238095vw;
  }
  .news_part .main .more_btn {
    margin-top: 9.5238095238vw;
  }
  .news_part .main .more_btn a {
    font-size: 3.8095238095vw;
  }
  .products_part {
    padding: 11.9047619048vw 5%;
    margin-right: 0;
  }
  .products_part p.title {
    text-align: center;
  }
  .products_part .main {
    margin-top: 11.9047619048vw;
    row-gap: 7.1428571429vw;
    -moz-column-gap: 6%;
         column-gap: 6%;
  }
  .products_part .main .one {
    width: 47%;
  }
  .products_part::before {
    display: none;
  }

  .gallery_part .main .one{
     width:75vw;
     margin-top: 0;
  }

  .gallery_part .main{
    display: block;
  }

  .gallery_part .main .one:nth-of-type(2){
    margin-left: 15vw;
    margin-top: 5vh;
  }

  .gallery_part .main .one:nth-of-type(3){
    margin-right: 25vw;
    margin-top: 5vh;
  }

  a.btn__wh{
    font-size:0.75rem;
    padding: 1em .5em;
  }


  .factory__box:nth-of-type(n+2){
    margin-top: 2.5vh;
  }

  .factory__box:not(:last-child){
 margin-top: var(--col-space);

  }
  
  .company_part {
    padding-top: 14.2857142857vw;
    padding-bottom: 14.2857142857vw;
  }
  .company_part .main {
    margin-top: 9.5238095238vw;
  }
  .company_part .main .one {
    padding: 4.7619047619vw 0;
  }
  .company_part .main .one p {
    font-size: 3.8095238095vw;
    text-align: left;
  }
  .company_part .main .one p.txt1 {
    width: 24%;
  }
  .company_part .main .one p.txt3 {
    font-size: 3.3142857143vw;
    line-height: 5.680952381vw;
    padding-left: 0;
  }
  .company_part .main .one div {
    width: 76%;
  }

  footer{
    padding-top: 0;
  }

  footer .contact_link {
    flex-direction: column;
    row-gap: 7.1428571429vw;
  }
  footer .contact_link .one {
    width: 100%;
    height: 28.5714285714vw;
    border: 0.7142857143vw solid #efe8d9;
  }
  footer .contact_link .one p.txt1 {
    font-size: 3.8095238095vw;
  }
  footer .contact_link .one p.txt2 {
    font-size: 8.5714285714vw;
  }
  footer .contact_link .one p.txt2.phone::before {
    padding-right: 2.8571428571vw;
  }

  footer .link__wrap .Inner .Hurf{
    width:100%;
    flex-wrap: wrap;
  }

  footer .link__wrap .Inner .Hurf > div{
    width: 100%;
    margin-top: 1em;
    margin-bottom:0;
    padding: 0;
    text-align: center;
    justify-content: center;
    row-gap: 1vh;
  }

  footer .main .instagram{
    margin:1em auto;
    width:auto;
  }

  footer .main .menu_list {
    display: flex;
    flex-direction: column;
    row-gap: 2.380952381vw;
  }
  footer .main .menu_list a {
    font-size: 3.8095238095vw;
  }
  footer .main .menu_list a::before {
    display: none;
  }
  footer .main p.copyright {
    font-size: 2.3095238095vw;
    margin: auto;
    text-align: center;
  }

  .page__gallery .flex .one, .page__gallery .flex .two{
    width:100%;
  }

  footer .link__wrap .Inner .Hurf ul.link{
    font-size: 0.8rem;
  }

  footer .main_container1{
    text-align: center;
  }

  footer .link__wrap .Inner .Hurf ul.link{
    justify-content: center;
  }

  footer .link__wrap .Inner{
    flex-direction: column-reverse;
  }
  p.copyright{
    text-align: center;
    margin-top: 5vh;
  }

}/*# sourceMappingURL=style.css.map */


/*****************スクロール****************/
.scroll {
  position: absolute;
  width: 350px;
    left: -30px;
  height: 40px;
  bottom: 20%;
  transform:rotate(-90deg);
    font-family: "acumin-pro", sans-serif;
    font-weight: 200;
}

.word {
  position: absolute;
  width: 220px;
  opacity: 0;
}

.letter {
  display: inline-block;
  position: relative;
  float: left;
  transform: translateZ(25px);
  transform-origin: 50% 50% 25px;
}

.letter.out {
  transform: rotateX(90deg);
  transition: transform 0.32s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

.letter.behind {
  transform: rotateX(-90deg);
}

.letter.in {
  transform: rotateX(0deg);
  transition: transform 0.38s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.scroll_down {
  position: absolute;
  width: 170px;
  height: 20px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: cover;
    transition: .2s;
  overflow: hidden;
      bottom: -40px;
}

.scroll_down:after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 3px;
  height: 90px;
  background: linear-gradient(180deg,rgba(#000, 0) 0, rgba(#000, .8) 80%, rgba(#000, .8) 100%);
  }


.scroll_down:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 180px;
  height: 1px;
  background: #ddd;
}

.scroll_down:after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 0px;
  height: 1px;
  background: #000;
}


.scroll_down:after {
  animation: sdl01 1.5s cubic-bezier(1, 0, 0, 1) infinite;
}

@keyframes sdl01 {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
    width: 0px;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
    width: 180px;
  }
  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
    width: 180px;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
    width: 0px;
  }
}

/***********************下層ページ**************************/

header.section-page{
  height: auto;
  min-height: 104px;
  background: #fff;
}

header.section-page .nav__fixed{
  background: rgba(255,255,255,0.95);
}

header.section-page h1{
    font-family: "acumin-pro", sans-serif;
    font-weight: 400;
    font-size: clamp(40px,4.947916666666666vw,5vw);
    margin: 0;
    color:#000;
    text-transform: uppercase;
    padding: 2em var(--row-space) 1em;
}

h1.entry{
    font-family: "acumin-pro", sans-serif;
    font-weight: 100;
    font-size: clamp(40px,4.947916666666666vw,5vw);
    margin: 0;
    color:#000;
    text-transform: uppercase;
    padding: 2em var(--row-space) 1em;
    padding-top: 0;
}

article.sec{
  background: #fff;
  padding:0 var(--row-space) var(--col-space);
}

.performance__wrap{
  max-width: 1080px;
  margin: 0 auto;
  display: flex;
  column-gap: 2%;
  row-gap: 2em;
  flex-wrap: wrap;
  justify-content: center;
}

.performance__wrap .Item{
  width: var(--flex_third_space);
  border-radius: 50%;
  max-height: var(--flex_third_space);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  aspect-ratio: 1/1; 
   transition: all .3s;
}

.performance__wrap .Item h2{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  row-gap: .25em;
  font-family: "acumin-pro", sans-serif;
  font-weight: 200;
  color:#000;
  font-size: clamp(18px,38px,40px);
   text-align: center;
   text-transform:uppercase;
   letter-spacing: 0.029em;
}

.performance__wrap .Item h2 span{
  font-size: 35%;
  display: block;
  font-family:'Noto Sans JP',游ゴシック体, 'Yu Gothic', YuGothic,'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}

.performance .third{
  line-height: 2.0;
}

h2.jp-border{
  padding-bottom: .75em;
  margin-bottom: 1em;
  border-bottom: 1px solid #000;
}

h2.jp-border:nth-of-type(n+2){
  margin-top: var(--row-space);
}

ul.extra{
  max-width: max-content;
  list-style: disc;
  font-size: 1.2rem;
  font-weight: bold;
  padding-left: 0;
  margin: 2em auto var(--col-space);
  list-style-position: inside;
}

ul.extra li{
  margin-top: .5em;
    list-style: disc;
  list-style-position: inside;
}

.flow__wrap{
  max-width: 1000px;
  margin: var(--row-space) auto;
  padding:2em clamp(1em,var(--row-space),4.8vw);
  border: 1px solid #231815;
  margin-top: var(--row-space);
  position: relative;
}

.flow__wrap:last-of-type h3{
  margin-bottom: 0;
}

.flow__wrap:first-of-type{
  margin-top: 0;
}

h2.jp-page{
  margin-bottom: .5em;
  font-weight: bold;
    max-width: 1000px;
    margin-left: auto;
    margin-right: auto;
}

.flow__wrap span.icon.number{
  position: absolute;
  display: block;
  top:.5em;
  font-size: 38px;
  background: #fff;
  padding: 0.15em;
  display: flex;
  align-items: center;
  column-gap: .5em;
  left: -22px;
  font-family: Arial, Helvetica, sans-serif;
}

.flow__wrap span.icon.number::before{
  content: '';
  background: #231815;
  width: 37px;
  height: 1px;
}

.flow__wrap h3{
  font-size: clamp(1.2rem,1.8rem,1.95rem);
  font-weight: bold;
  margin-bottom: .75em;
}

.flow__wrap p{
  font-size: 1.15rem;
}

.link-title .circle.small {
      width: 44px;
    height: 44px;
    border: 0.5px solid rgba(0,0,0,0.95);
    border-radius: 50%;
    z-index: 0;
    align-items: center;
    aspect-ratio: 1 / 1;
    display: flex;
    justify-content: center;
}

.pulse-btn.small::before, .pulse-btn.small::after{
    background: rgb(255 255 255 / 15%);
}

.pulse-btn.small::before{
  border:1px solid rgba(25,25,25,0.45);
}

.pulse-btn.small::after{
  border: none;
}
.link-title .circle__arrow.small {
    display: flex
;
    flex-direction: row-reverse;
    overflow: hidden;
    position: relative;
    width: 1.6875em;
    z-index: 1;
}

.link-title .circle.small .arrow{
  background: url(../images/arrow-bk.svg)no-repeat center;
  background-size: contain;
  width: 15px;
  display: block;
  height: 15px;
  transition: all .3s;
}
.link-title .circle.small:hover .arrow{
  margin-right: -.15em;
}

.link-title a{
  display: flex;
  align-items: center;
  column-gap: .5em;
  color:#000;
}
.link-title a:hover{
text-decoration: underline;
opacity: 0.35;
}
.text__flex{
  display: flex;
  column-gap: .5em;
  align-items: center;
}

.text__flex img{
  display: block;
  max-width: 360px;
  width: 100%;
}

p.mb {
  margin-bottom: 0;
}

.small__text{
  font-size: 0.9rem;
  margin-bottom: 1em;
  margin-top: 1em;
}

/***********************お問い合わせ**************************/

.wpcf7 form.sent .wpcf7-response-output{
	font-size:16px;
}

dl.contact{
  margin: 0;
  display: flex;
  column-gap: 1em;
  row-gap: 0;
}

dl.contact dt{
  padding: 1em 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  width: 20%;
}

dl.contact dt p{
  display: flex;
  align-items: center;
  column-gap: .25em;
}

dl.contact dd{
  margin: 0;
  padding: 1em;
  width: 80%;
}

dl.contact dd p .wpcf7-form-control-wrap, dl.contact dd .flex p{
  display: flex;
  align-items: center;
  column-gap: 5px;
}

#input_short, #zip input[type="text"]{
  width: 31%;
  margin: 0;
}

.text_red{
  color:#d15514;
  font-size: 11px;
}

.contact__Inner{
  max-width: 980px;
  margin: auto;
}

textarea{
  border: none;
  width: 100%;
}

p.Center a{
  color:#9cb1db;
}
.wpcf7-not-valid-tip {
    color: #dc3232;
    font-size: 1em;
    font-weight: normal;
    display: block;
    position: absolute;
    left: 10px;
}
select + .wpcf7-not-valid-tip{
	left:240px;
}
.wpcf7-not-valid-tip{
	font-size:13px !important;
}
/***********************よくある質問**************************/

.faq__wrap{
  max-width: 1100px;
  margin:0 auto 0;
  padding-top: 25vh;
  display: flex;
  flex-wrap: wrap;
  column-gap: 5%;
  align-items: flex-start;
  row-gap: 2em;
}

.faq__wrap .Hurf{
  width: calc(95% / 2);
  position: relative;
  display: flex;
}

.faq__wrap .Hurf a img{
  display: block;
  width: 100%;
  margin: auto;
  min-width: 400px;
}

.faq__wrap .Hurf:nth-of-type(odd){
  margin-top: -25vh;
  justify-content: flex-end;
}

.accordion-js_btn {
  cursor: pointer;
  color: #fff;
  position: relative;
  transition: .3s;
  width: 100%;
  max-width: 70%;
  margin-right: -10%;
}

.accordion-js_btn:hover{
  opacity:0.55;
}

.accordion-js_inner {
  display: none;
  opacity: 0;
    z-index:0;
    right: 0;
    width: 0;
    position: relative;
    transition: all .3s;
}


.accordion-js_btn.open + .accordion-js_inner{
  position: relative;
  opacity: 1;
  display: block;
  max-width: 100%;
  width: 100%;
  min-width: 70%;
}

.Hurf.js-center{
  justify-content: center;
}

dd.birthday select{
  min-width: 150px;
}

/*******************エントリーフォーム************************/

.blue__bg{
  background: #e3e7f4;
  padding: var(--col-space) var(--row-space);
  margin-left: var(--row-space);
  margin-right: var(--row-space);
}

.blue__bg h2{
  margin-top: 1em;
}

 .del {
   color: #f00;
   text-decoration : line-through ;
   font-size: clamp(1.0rem, 1vw, 1vw);
 }
 .del span {
   color: #000;
 }

.bg--gray{
	background:#ededed;
	padding:1em;
	max-width:700px;
	margin:auto;
}

.bg--gray *{
	font-size:0.9rem;
	line-height:1.85;
}