@charset "utf-8";
/* CSS Document */
*{
  font-family: "Gothic Medium BBB",'Noto Sans JP', sans-serif;
  font-weight: 400;
  color:inherit;
  box-sizing:border-box;
}

/* PC tel */
@media screen and (min-width: 768px){
  a[href^="tel"] {
    pointer-events: none;
    cursor: default;
  }
}

@media screen and (min-width: 768px){
  .sp{ display: none}
}
@media screen and (max-width: 767px){
  .pc{ display: none}
}

/**/
/*
@media screen and (max-width: 767px){
  main{
    min-height: calc(100vh - 18.9vw);
  }
}
@media screen and (min-width: 768px){
  main{
    min-height: calc(100vh - 131px);
  }
}
*/
address{ font-style: normal;}

/*---------------------------------

 img

---------------------------------*/
img{ width:100%;}

/*---------------------------------

 a / svg

---------------------------------*/
.svg{
  width: 100%;
  height: auto;
}
a{
  -webkit-tap-highlight-color: rgba(0,0,0,0);
}
.current,
a:hover{
  color: #00FF7F;
}
a:hover .svg path,
a:hover .svg circle{
  color: #00FF7F;
  fill: currentColor;
}
/*
header a:hover .svg path,
header a:hover .svg circle{
  color: #fff;
  fill: currentColor;
}
*/

@media screen and (min-width: 768px){
  a,
  .svg path,
  .svg circle{
    transition:all 300ms;
  }
}

/*---------------------------------

 font

---------------------------------*/
html{
  font-size:62.5%;
  line-height:1.8;
  background:#fff;
}
html *{ color:#000;}
html{
  height: 101%;
}
body{
  height: 100%;
}
#wrap{
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
}
a,span{ font-size: inherit; color: inherit;}
a{ text-decoration: none;}
em{
  font-weight: bold;
  font-style: normal;
}
small{ font-size:100%;}

header a,
[lang="en"]{
  font-family: 'Montserrat', sans-serif;
}

/*---------------------------------

 table

---------------------------------*/
table th,
table td{
  text-align: left;
  vertical-align: top;
  line-height: 1.5;
  padding-top: 1.5em;
  padding-bottom: 1.65em;
}
table th{
  white-space: nowrap;
  letter-spacing: .7em !important;
  padding-right: 1.2em;
}
table td p.m-lh{
  line-height: 2.3;
  margin-top: -.3em;
}
table td p.m-lst{
  line-height: 1.8;
}
@media screen and (min-width: 768px){
  table *{
    font-size: 1.3rem;
  }
}
/*---------------------------------

 b-logo

---------------------------------*/
.b-logo{
  margin: 0;
  width: 34vw;
  line-height:1;
}
@media screen and (min-width: 501px) and (max-width: 767px){
  .b-logo{
    width: 26vw;
  }
}
@media screen and (min-width: 768px){
  .b-logo{
    width: 165px;
    width: 148px;
  }
}
/*---------------------------------

 b-sns

---------------------------------*/
.b-sns{
  display: flex;
  justify-content: space-between;
  width: 38vw;
}
.b-sns li{
  margin: 0;
  width: 8.75vw;
}
.b-sns li a{
  display: block;
  line-height:1;
}

@media screen and (min-width: 501px) and (max-width: 767px){
  .b-sns{
    width:27vw;
  }
  .b-sns li{
    width: 6vw;
  }
}
@media screen and (min-width: 768px){
  .b-sns{
    width:120px;
  }
  .b-sns li{
    width:28px;
  }
}
/*---------------------------------

 b-more

---------------------------------*/
.b-more{
  text-align: center;
  line-height:0;
  margin-top: 10vw;
}
.b-more a,
.b-more p,
input[type="submit"]{
  width: 70%;
  display: inline-block;
  cursor: pointer;
  font-family: 'Montserrat', sans-serif;
  font-weight: 500;
  /*
  font-family: "Public Sans", sans-serif;
  font-weight: 200;
  */
  line-height:1;
  letter-spacing: .08em;
  border: 2px solid #000;
  padding: 1em;
  font-size: 3.4vw;
}
.sec-about .b-more a,
input[type="submit"]{
  font-family: "Gothic Medium BBB",'Noto Sans JP', sans-serif;
  font-weight: 400;
}
.b-more a:hover,
.b-more p:hover,
input[type="submit"]:hover{
  background: #00FF7F;
  border-color: #00FF7F;
  color: #fff;
}
@media screen and (min-width: 501px) and (max-width: 767px){
  .b-more a,
  .b-more p,
  input[type="submit"]{
    font-size: 3.4vw;
  }
}
@media screen and (min-width: 768px){
  .b-more{
    margin-top: 50px;
  }
  .b-more a,
  .b-more p,
  input[type="submit"]{
    width: 290px;
    font-size: 1.5rem;
    padding: 1em;
  }
}

/*---------------------------------

 header

---------------------------------*/
.b-nav{
  position: fixed;
  z-index: 100;
  right: 0;
  top: 0;
  background: #fff;
  height: 110vh;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.b-nav::-webkit-scrollbar{
  display:none;
}
.b-nav li,
.b-nav a{
  display: block;
  line-height: 1;
}
.b-nav .b-lst li,
.b-nav .b-lst a{
  width: 100%;
}
.b-nav .b-prt > a{
  width: auto;
}
.b-nav a{
  font-family: 'Montserrat', sans-serif;
  font-weight: 500;
  letter-spacing: .1em
}
/*
.b-nav .b-cld a:hover::before{
  background: #00FF7F;
}
*/
.b-nav .b-cld{
  width: 100%;
}
.b-nav .b-cld a{
  position: relative;
  /*padding-left: 1.5em;*/
}
.b-nav .b-cld a::before{
  content:"> ";
  /*display: block;
  position: absolute;
  left: 0;
  top: 50%;*/
  /*transform: translateY(-50%) rotate(-45deg) skew(3deg,3deg); */
  /*width: .85em;
  height: 2px;
  width: .5em;
  height: .5em;
  background: #000;
  border-bottom: 1px solid;
  border-right: 1px solid;*/
}

@media screen and (max-width: 767px){
  header{
    text-align: center;
  }
  .b-nav{
    width: 100%;
    padding: 4vw 0 40vw 0;
  }
  .b-nav .b-logo{
    width: 100%;
    border-bottom: 2px solid #000;
    padding-bottom: 4.5vw;
  }
  .b-nav .b-logo a,
  .b-nav .b-logo div{
    width: 34vw;
    margin: auto;
  }
  .b-nav nav{
    display: inline-block;
    margin-top: 8vw;
  }
  .b-nav .b-lst{
    text-align: left;
    /*margin-left: -6em;*/
  }
  .b-nav .b-lst > li{
    margin-bottom: 5.5vw;
  }
  .b-nav .b-lst > li.b-prt{
    margin-bottom: 6.5vw;
  }
  .b-nav .b-lst > li:last-of-type{
    margin-bottom: 7vw;
  }
  .b-nav .b-lst > li a{
    font-size: 5.4vw;
  }
  .b-nav .b-cld{
    padding: 6vw 0 0;
  }
  .b-nav .b-cld > li a{
    font-size: 3.6vw;
  }
  .b-nav .b-cld > li+li{
    margin-top: 1.8em;
  }
}
@media screen and (min-width: 768px){
  header .b-logo{
    display: none;
  }
  .b-nav{
    /* width: 320px; */
    border-left: 2px solid #000;
  }
  .b-nav nav{
    padding: 120px 50px 150px;
  }
  .b-nav .b-logo{
    margin-bottom: 55px;
  }
  .b-nav .b-lst > li{
    margin-bottom: 25px;
  }
  .b-nav .b-lst > li a{
    font-size: 2rem;
  }
  .b-nav .b-cld{
    padding: 20px 0 15px;
  }
  .b-nav .b-cld a::before{
    transition: all 300ms;
  }
  .b-nav .b-cld > li a{
    font-size: 1.5rem;
  }
  .b-nav .b-cld > li+li{
    margin-top:1.5em;
  }
}

/*---------------------------------

 MENU / open

---------------------------------*/
.b-nav,
#MENU span{
  transition: all 200ms ease;
}
.b-nav{
  opacity: 0;
  pointer-events: none;
}
.b-nav.open{
  opacity: 100;
  overflow-y: scroll;
  pointer-events: auto;
}
#MENU{
  position: fixed;
  z-index: 101;
  cursor: pointer;
  width: 9vw;
  height: 8vw;
  top: 4.6vw;
  right: 6vw;
}
#MENU span{
  display: block;
  width: 100%;
  background:#000;
  position: absolute;
  left:0;
  height: 3px;
}
#MENU span:nth-child(1){
  top: 13%;
}
#MENU span:nth-child(2){
  top: 50%;
}
#MENU span:nth-child(3){
  top: 87%;
}
#MENU.close span:nth-child(1){
  top: 50%;
  transform: rotate( 45deg );
}
#MENU.close span:nth-child(2){
  opacity: 0;
  transform: scaleX(0);
}
#MENU.close span:nth-child(3){
  top: 50%;
  transform: rotate( -45deg );
}
@media screen and (min-width: 501px) and (max-width: 767px){
  #MENU{
    width: 6vw;
    height: 6vw;
    top: 4vw;
    right: 3.5vw;
  }
}
@media screen and (min-width: 768px){
  #MENU{
    width: 45px;
    height: 40px;
    top: 45px;
    right: 40px;
  }
  #MENU span{
    height: 4px;
  }
}

/*---------------------------------

 footer

---------------------------------*/
footer{
  text-align: center;
  padding:1.5em 0 2em;
  margin-top: 10vw;
  line-height:0;
  background: #707070;
  background: #fff;
}
footer.m-top{
  margin-top: 0;
}
footer *{
  line-height: 1;
}
footer .b-sns{
  margin:0 auto;
  margin-bottom: 2vw;
}
footer small{
  display: inline-block;
  font-family: 'EB Garamond', serif;
  letter-spacing: .05em;
  padding-top: .5em;
  /*color: #fff;*/
}
@media screen and (min-width: 501px) and (max-width: 767px){
  footer small{
    font-size: 2.3vw;
  }
}
@media screen and (min-width: 768px){
  footer{
    margin-top: auto;
    margin-bottom: 0;
    text-align: left;
    padding-left: 50px;
    padding-top: 95px;
  }
  footer .b-sns{
    margin-bottom: 2px;
  }
  footer small{
    font-size: 1.2rem;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px){
  footer{
    padding-left: 30px;
  }
}
/*---------------------------------

 b-pagenation

---------------------------------*/
.b-pagenation .container{
  display: flex;
  justify-content: center;
  position: relative;
}
.b-pagenation{
  font-family: 'Montserrat', sans-serif;
  font-weight: 500;
  /*
  font-family: "Public Sans", sans-serif;
  font-weight: 200;
  */
  line-height: 1;
}

.b-pagenation span,
.b-pagenation a{
  display: flex;
  justify-content: center;
  align-items: center;
}
/*
.b-pagenation a.prev,
.b-pagenation a.next{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.b-pagenation a.prev{
  left: 0;
}
.b-pagenation a.next{
  right: 0;
}
**/
.b-pagenation a.prev::before,
.b-pagenation a.next::before{
  font-size: .8em;
}
/* .b-pagenation a:not(.prev):not(.next){
  width: 1.5em;
  height: 1.5em;
  border-radius: 50%;
  background: #fff;
  border: 1px solid #000;
  color: #000;
} */
/*.b-pagenation a:not(.prev):not(.next):hover{
  border-color: #00FF7F;
  background: #00FF7F;
  color: #fff;
}*/
.b-pagenation span,
.b-pagenation a{
  margin:0 1.2em;
  font-family: "Public Sans", sans-serif;
  font-weight: 300;
}
.b-pagenation a.prev,
.b-pagenation a.next{
  font-family: 'Montserrat', sans-serif;
  font-weight: 500;
  position: absolute:
}
.b-pagenation a.prev{
  margin-right: 2em;
  margin-left: -5.5em;
}
.b-pagenation a.next{
  margin-left: 2em;
  margin-right: -5.5em;
}
@media screen and (max-width: 767px){
  .b-pagenation{
    margin-top: 5vw;
  }
  .b-pagenation .container{
    width: 90vw !important;
  }
  .b-pagenation *{
    font-size: 3vw;
    font-size: 13px;
  }
}
@media screen and (min-width: 768px){
  .b-pagenation{
    margin-top: 50px;
  }
  .b-pagenation *{
    font-size: 1.5rem;
  }
  .b-pagenation a:not(.prev):not(.next){
    transition: all 300ms;
  }
}

/*---------------------------------

 pageTop

---------------------------------*/
.b-pageTop{
  opacity: 0;
  position: fixed;
  transition:all 300ms;
  pointer-events: none;
  width: 10vw;
  right: 3.5vw;
  bottom: 7.5vw;
  z-index: 55;
}
.b-pageTop *{
  line-height: 1;
}
.b-pageTop.scrollin{
  pointer-events: auto;
}
.b-pageTop a{
  display: block;
  position: relative;
}
.b-pageTop .normal,
.b-pageTop .hover{
  transition: all 300ms;
}
.b-pageTop .hover{
  position: absolute;
  opacity: 0;
  left: 0;
  top:0;
}
@media screen and (min-width: 501px) and (max-width: 767px){
  .b-pageTop{
    width: 7.5vw;
    right: 3vw;
    bottom: 7.5vw;
  }
}
@media screen and (min-width: 768px){
  .b-pageTop{
    width: 50px;
    right: 38px;
    bottom: 70px;
  }
  .b-pageTop a:hover .normal{
    opacity: 0;
  }
  .b-pageTop a:hover .hover{
    opacity: 1;
  }
}
/*---------------------------------

 sec

---------------------------------*/
.sec{
  position: relative;
  background: #fff;
}

.b-secHeader{
  width: 100%;
  left:0;
  top:0;
  z-index: 50;
  pointer-events: none;
}
.b-secHeader .inner{
  display: flex;
  text-align: center;
  align-items: center;
  position: relative;
}
.b-secHeader .b-ttls,
.b-secHeader .b-logo{
  pointer-events: auto;
}
.b-secHeader .b-logo a{
  display: block;
  line-height: 1;
}
.b-secHeader h1.b-ttls,
.b-pst.m-single h1.b-ttls{
  font-weight: 500;
  letter-spacing: .15em;
  line-height: 1.5;
  font-size: 1.8rem;
}
.sec-works .b-secHeader h1.b-ttls{
  font-size: 1.4rem;
}
@media screen and (max-width: 767px){
  .b-secHeader .inner{
    padding: 4vw 0;
  }
  .b-secHeader .b-logo{
    margin: 0 auto;
  }
  .b-pst.m-single h1.b-ttls,
  .b-pst h1.b-ttls.m-workscat{
    text-align: center;
    font-size: 3.8vw;
    padding: 3vw 5vw 8vw;
  }
  .b-pst h1.b-ttls.m-workscat{
    font-family: 'Montserrat', sans-serif;
    font-weight: 500;
    letter-spacing: .1em;
  }
}
@media screen and (min-width: 501px) and (max-width: 767px){
  .b-secHeader .inner{
    padding: 4vw 0;
  }
  .b-pst.m-single h1.b-ttls{
    font-size: 3vw;
  }
}
@media screen and (min-width: 768px){
  .b-secHeader .inner{
    height: 128px;
    transition: .3s all;
  }
  .b-secHeader .b-logo{
    position: absolute;
    left: 50px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 1
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px){
  .b-secHeader .b-logo{
    width: 130px;
    left: 30px;
  }
}
.sec .container{
  width: 80%;
  max-width: 1500px;
  margin:auto;
}
@media screen and (max-width: 767px){
  .sec .container{
    width: 100%;
  }
}
@media screen and (min-width: 768px){
  .b-secHeader{
    background: rgba(255,255,255,.90);
  }
}

/* b-side ------------*/
.b-side{
  position: fixed;
  z-index: 51;
  display: none;
  min-height:500px;
}
.m-HOME .b-side{
  position: absolute;
}
.b-side *{
  display: inline-block;
  font-family: 'Montserrat', sans-serif;
  font-weight: 500;
  text-transform: uppercase;
  line-height:1;
  letter-spacing: .08em;
  color: #00FF7F;
  margin:0;
}
.b-side .b-pankuzu{
  transform: rotate(90deg) translateY(-4em);
  transform-origin: left top;
  white-space: nowrap;
}
.b-side .b-pageCldName{
 transform: translateY(-.15em)
}
.b-side .b-pageCldName::before{ 
  content:">";
  display: inline-block;
  transform: translateY(.1em);
  margin-right:.4em;
  margin-left: .1em;
}
.b-side .b-pageCldName span+span::before{
  content: ",";
  margin-right: .3em;
}
@media screen and (min-width: 768px){
  .b-side{
    display: block;
    width: 60px;
    top: 126px;
    right: 33px;
  }
  .b-side .b-pageName,
  .b-side .b-pageName a,
  .b-side .b-pageCldName::before{
    font-size: 1.9rem;
  }
  .b-side .b-pageCldName span{
    font-size: 1.2rem;
  }
}
.b-secHeader.fixed,
.b-side.fixed{
  position: fixed;
}

/* .b-secHeader theTop */
@media screen and (min-width: 768px){
  .b-secHeader.fixed.theTop .inner{
    height: 100px;
  }
  main:not(.m-HOME) .b-secHeader.fixed.theTop .inner{
    height: 128px;
  }
  main:not(.m-HOME) .b-secHeader.fixed .inner{
    height: 100px;
    height: 75px;
  }
}


/*---------------------------------

 form

---------------------------------*/
input[type="text"],
input[type="email"],
textarea{
  border: 1px solid #666;
  padding: .8em .8em;
}
input[type="text"]:focus,
input[type="email"]:focus,
textarea:focus{
  background: #FFFDDB;
}
input[type="submit"]{
  background: #000;
  color: #fff;
  letter-spacing: 1em;
  text-indent: .8em;
  /*padding: .3em 1.5em .45em;
  width: 15em;*/
  
}
input[type="submit"][name="submitBack"]{
  background: #999;
  margin-right: .5em;
}
input[type="submit"]:hover{
  background: #00FF7F;
}
@media screen and (max-width: 768px){
  input[type="submit"]{
    width: 83%;
    font-size: 3.4vw !important;
  }
}
@media screen and (min-width: 768px){
  input[type="submit"]{
    font-size: 1.5rem !important;
  }
}

/*---------------------------------

 animation

---------------------------------*/
.m-transY,
.sec-works .b-pstLst,
.sec-media .b-pstLst{
  transition: all 800ms ease;
  transform: translateY(8vw) !important;
  opacity: 0 !important;
}
@media screen and (min-width: 768px){
  .m-transY,
  .sec-works .b-pstLst,
  .sec-media .b-pstLst{
    transform: translateY(50px) !important;
    opacity: 0 !important;
  }
}
.transY,
.sec-works .b-pstLst.transY,
.sec-media .b-pstLst.transY{
  transform: translateY(0) !important;
  opacity: 1 !important;
}
.scrollin{
  opacity: 100;
}



/*-------------------------------
    404
-------------------------------*/
.sec-404{
  height: 89vh;
}
.ttl-404{
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
}
@media screen and (max-width: 767px){
  .sec-404{
    padding: 15vw 5vw 50vw;
  }
  .ttl-404{
    font-size: 7vw;
  }
  .body-404{
    font-size: 4.5vw;
    margin: 1em 0;
  }
  .sec-404 p{
    font-size: 3.4vw;
  }
}
@media screen and (min-width: 768px){
  .sec-404{
    padding: 100px;
  }
  .ttl-404{
    font-size: 28px;
  }
  .body-404{
    font-size: 18px;
    margin: 1em 0;
  }
  .sec-404 p{
    font-size: 14px;
  }
}