@charset "UTF-8";

/*===================
reset
====================*/

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


/* HTML5 display-role reset for older browsers */

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

body {
  line-height: 1;
  -webkit-font-smoothing: antialiased;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

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

* {
  outline: none;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
}


/*===================
common
====================*/
html {
    background: #000;
}
body {
  font-family: Scheherazade, "Yu Mincho", "Yu Mincho", Hiragino Mincho pro, Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
}

a, a img {
  transition: .3s all;
}
a:link,a:visited {
  color: #fff
}
a:hover {
  color: #fff
}
div#wrap {
    width: calc(100vw - (100vw - 100%));
    overflow: hidden;
}

*::-webkit-scrollbar{
  display: none;
}
/*===================
load
====================*/

.load {
  width: calc(100vw - (100vw - 100%));
  height: 100vh;
  position: fixed;
  background: #000;
  transition: 1s all;
  top: 0;
  z-index: 10000;
}

.load_img01 {
  width: 60px;
  height: 100px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  display: none;
}

.load_img02 {
  position: absolute;
  width: 231px;
  height: 232px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: none;
}


/*===================
header
====================*/

header {
  width: calc(100vw - (100vw - 100%));
}

.logo {
  width: 27px;
  height: 52px;
  margin: 0 70px;
  cursor:pointer;
  transition:.3s all;
}
.logo:hover {
  opacity:.8;

}

.head_inner1 {
  position: fixed;
  top: 70px;
  width: calc(100vw - (100vw - 100%));
  z-index: 19;
}
.open .head_inner1{
  z-index:999;
}

.head_inner2 {
  position: fixed;
  z-index: 20;
  width: calc(100vw - (100vw - 100%));
  bottom: 79px;
  pointer-events: none;
}

.head_img03 {
  width: 100px;
  margin: 0 70px;
  height: 18px;
  font-size: 16px;
  color: #FFF;
  font-family: 'Scheherazade', serif;
  letter-spacing: 2px;
  float: left;
}

.head_img04 {
  width: 110px;
  float: right;
  padding: 0;
  height: 20px;
  font-size: 16px;
  color: #FFF;
  font-family: 'Scheherazade', serif;
  letter-spacing: 2px;
  margin: 0 60px;
}


/*===================
mv
====================*/

.mv {
  width: calc(100vw - (100vw - 100%));
  height: 100vh;
  overflow: auto;
  position: relative;
  z-index: 2;
  transition: .3s all;
}
.mv.hide {
    opacity: 0;
}
.mv_txt {
  width: 607px;
  height: 292px;
  position: absolute;
  color: #000;
  z-index: 2;
  left: 10%;
  top: 50%;
  transform: translateY(-50%);
  transition: .8s;
}

.mv_txt h1, .mv_txt p, .mv_txt img {
  pointer-events: none;
}

h1 {
  font-size: 80px;
  margin-bottom: 23px;
  line-height: 1.1em;
}

.mv_txt p {
  margin-bottom: 50px;
  margin-left: 20px;
  font-size: 24px;
  letter-spacing: 0.2em
}

.mv_img01 {
  margin-left: 20px;
  display: block;
}

.mv_scroll {
  position: absolute;
  width: 74px;
  height: 64px;
  left: 50%;
  bottom: 35px;
  transform: translateX(-50%);
  z-index: 2;
  transition: .8s all;
  text-align: center;
  color: #FFF;
  cursor: pointer;
}

.mv_scroll_img {
  width: 6px;
  margin: 0 37px 0 auto;
  display: block;
  animation: scroll 2s infinite linear;
}

@keyframes scroll {
  0% {
    transform: translateY(0%);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: translateY(40%);
    opacity: 0;
  }
}

.mv_bg {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -2;
  display: block;
}

.mv_hamon {
  width: calc(100vw - (100vw - 100%));
  height: calc(1340*100vw/750) !important;
  background-image: url(../img/mv.jpg);
  background-position: top center;
  position: absolute;
  transform: rotate3d(0,0,0,0);
}

.mv_img02_box {
  position: fixed;
  top: 220px;
  width: 1944px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 5;
  pointer-events: none;
}

.mv_img02 {
  width: 402px;
  position: absolute;
  left: 1179px;
}

.open+#wrap .mv_txt {
  opacity: 0;
}

.open+#wrap .mv_scroll {
  opacity: 0;
}

.mv_mov {
  width: 239px;
  height: 0px;
  text-align: center;
  line-height: 96px;
  display: block;
  letter-spacing: 4px;
  font-size: 18px;
  margin: 50px 0 0 20px;
  overflow: hidden;
}

.mv_mov img {
  width: 100%
}
.mv_mov img:hover {
  opacity: 0.7
}
.link_ef {
  border: 1px solid #FFF;
  color: #FFF;
  text-decoration: none;
  position: relative;
  box-sizing: content-box;
  transition: .3s all;
  transition-delay: 0s;
  overflow: hidden;
  cursor: pointer;
}

.link_ef:before {
  content: '';
  position: absolute;
  width: 200%;
  height: 300%;
  display: block;
  top: -30px;
  left: 260px;
  background: #FFF;
  transition: .3s all;
  transform: rotate(-30deg);
  pointer-events: none;
}

.link_ef:hover:before {
  left: -150px;
}

.link_ef span {
  position: relative;
  z-index: 2;
  transition: .3s all;
}

.link_ef:hover > span {
  color: #5BD1C5;
}


/*
.link_ef:hover {
  color: #5BD1C5;
  transition-delay: .4s;
}


.link_ef:before {
    content:'';
    position:absolute;
    width:0%;
    height:1px;
    display:block;
    top: -1px;
    left: 0;
    background: #5BD1C5;
    transition: .1s all;
    transition-delay: .3s;
}

.link_ef:after {
    content:'';
    position:absolute;
    width:0%;
    height:1px;
    display:block;
    bottom: -1px;
    right: 0px;
    background: #5BD1C5;
    transition: .1s all;
    transition-delay: .1s;
}
.link_ef span {
    width: 100%;
    height: 100%;
    display: block;
    position: relative;
}

.link_ef span:before {
    content:'';
    position:absolute;
    height:0%;
    width:1px;
    left: -1px;
    bottom:0px;
    background:#5BD1C5;
    transition:.1s all;
    transition-delay:0s;
}

.link_ef span:after {
    content:'';
    position:absolute;
    height:0%;
    width:1px;
    right: -1px;
    top:0;
    background:#5BD1C5;
    transition:.1s all;
    transition-delay:.2s;
}

.link_ef:hover:before{
  width: calc(100% + 1px);
  transition-delay: 0s;

}

.link_ef:hover:after{
  width:calc(100% + 1px);
  transition-delay: .2s;

}

.link_ef:hover span:before{
  height: calc(100% + 1px);
  transition-delay:.3s;

}


.link_ef:hover span:after{
  height: calc(100% + 1px);
  transition-delay:.1s;

}
*/


/*===================
footer
====================*/

footer {
  position: relative;
  z-index: 10;
  width: calc(100vw - (100vw - 100%));
  overflow: hidden;
  height: 390px;
  background: #000;
}

.foot_img01 {
  width: 62px;
  height: 62px;
  float: left;
  transition: .3s all;
}

.foot_img02 {
  width: 62px;
  height: 62px;
  float: right;
  transition: .3s all;
}

.foot_img01:hover, .foot_img02:hover {
  opacity: .7;
}

.foot_inner {
  width: 434px;
  height: 190px;
  position: absolute;
  left: 50%;
  top: 44%;
  transform: translate(-50%, -50%);
  font-family: Hiragino Kaku Gothic Pro;
  text-align: center;
  font-weight: lighter;
}

ul.foot_box01 li {
  display: inline-block;
  font-size: 14px;
  margin: 0 5px;
}

ul.foot_box01 li a {
  color: #FFF;
  text-decoration: none;
  transition: .3s all;
}

ul.foot_box01 li a:hover {
  opacity: .7;
}

ul.foot_box01 {
  margin-bottom: 38px;
}

.foot_box02 {
  width: 147px;
  margin: 0 auto 37px;
  overflow: hidden;
}

p.foot_txt01 {
  color: #95989A;
  font-size: 12px;
  margin-bottom: 8px;
}

p.foot_txt02 {
  color: #95989A;
  font-size: 12px;
}


/*===================
nav
====================*/

.cart {
  width: 44px;
  margin: 0 70px;
  display: inline-block;
  vertical-align: middle;
  position: absolute;
  right: 0;
}
.cart:hover {
  opacity:.8;
}

.menu {
  width: calc(100vw - (100vw - 100%));
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.6);
  z-index: 9999;
  color: #FFF;
  width: 0;
  overflow: hidden;
  transition: .8s all;
  font-family: 'Scheherazade', serif;
  font-size: 64px;
}

.open .menu {
  width: calc(100vw - (100vw - 100%));
}

.menu ul {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 160px;
}

.menu li a {
  transition: .3s all;
  cursor: pointer;
  color: transparent;
  text-decoration: none;
  position:relative;
  display: block;
  padding: 0 .3em;
  background-image: linear-gradient(to right, rgba(255,255,255,1) 50%, rgba(91,209,197,1) 50%);
  background-position: 0 0;
  background-size: 200% auto;
  transition: .5s;
  background-clip: text;
  -webkit-background-clip: text;
}
.menu li a:before {
  /* content:''; */
  display:block;
  width:100%;
  height:100%;
  background:#FFF;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-background-clip: text;
}

.menu li a:hover {
  color: #5BD1C5;
  background-position: -100% 0;
}

.header_hbg {
  width: 43px;
  height: 28px;
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  left: 70px;
  z-index: 99999;
  cursor: pointer;
}
.header_hbg:hover span{
  opacity:.8;
}

.header_hbg span {
  width: 100%;
  height: 2px;
  display: block;
  background: #fff;
  transition: .3s all;
}

.header_hbg span:nth-child(2) {
  margin: 10px 0;
}

.open .header_hbg span {
  transform: rotate(30deg);
  margin: 10px 0 0 0;
}

.open .header_hbg span:nth-child(2) {
  transform: rotate(-30deg);
  margin: -2px 0 0 0;
}

.open .header_hbg span:nth-child(3) {
  opacity: 0;
}


/*===================
sec01
====================*/

.sec01_inner {
  height: 100vh;
  position: relative;
  z-index: 2;
  /* min-height: 914px; */
  width: calc(100vw - (100vw - 100%));
}

.sec01_txtbox01 {
  width: 670px;
  height: 386px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #FFF;
  text-align: center;
  font-weight: normal;
  font-weight: lighter;
  z-index: 2;
  transition: .5s all;

}

.sec01_txtbox02 {
  width: 943px;
  height: 459px;
  position: absolute;
  top: 222px;
  left: 150%;
  transform: translateX(-50%);
  color: #FFF;
  text-align: center;
  font-weight: normal;
  z-index: 2;
  transition: .5s all;
  zoom: 1.01;
}
.sec01_txtbox02_inbox {
    width: 242px;
    height: auto;
    display: inline-block;
    letter-spacing: normal;
    margin: 0 40px;
}

.sec01_txtbox02_inbox:first-child {
    margin-left:0;

}
.sec01_txtbox02_inbox:last-child {
    margin-right:0;
}
.sec01_txtbox02_inbox h3 {
    margin-top: 20px;
    line-height: 1.5em;
    font-family: "YuMincho", "Yu Mincho";
}

.sec01_txtbox02_inbox p {
    line-height: 28px;
    text-align: left;
    letter-spacing: 2px;
    font-family: "YuMincho", "Yu Mincho";
}

.sec01_txtbox02_nav{
  width: 670px;
  height: 58px;
  position: absolute;
  top:700px;
  left:50%;
  transform: translateX(-50%);
  z-index: 2;
}
.chap01{
  position: absolute;
  left:0;
  display: block;
  top: 0;
  cursor: pointer;
  width: 88px;
  height: 58px;
  transition: .5s all;

}
.chap01_1{
  position: absolute;
  top: 0;
}
.chap01_2{
  position: absolute;
  bottom: 0;
  left: 0;
  width: 33px;
  height: 6px;
}
.chap01:hover .chap01_2{
  animation: slide_l 1s linear infinite;
}
@keyframes slide_l {
  0%{
    opacity: 0;
    transform: translateX(0);
  }
  50%{
    opacity: 1;
    transform: translateX(-10px);
  }
  100%{
    opacity: 0;
    transform: translateX(-20px);
  }
}
.chap02{
  position: absolute;
  right:0;
  display: block;
  top: 0;
  cursor: pointer;
  width: 88px;
  height: 58px;
  transition: .5s all;
}
.chap02_1{
  position: absolute;
  top: 0;
}
.chap02_2{
  position: absolute;
  bottom: 0;
  right: 0;
  width: 33px;
  height: 6px;
}
.chap02:hover .chap02_2{
  animation: slide_r 1s linear infinite;
}
@keyframes slide_r {
  0%{
    opacity: 0;
    transform: translateX(0);
  }
  50%{
    opacity: 1;
    transform: translateX(10px);
  }
  100%{
    opacity: 0;
    transform: translateX(20px);
  }
}

.chap01_bar{
  width: 94px;
  height: 8px;
  position: absolute;
  left: 200px;
  top: 22px;
  border: 1px solid #FFF;
  cursor: pointer;
  transition: .5s all;
}
.chap02_bar{
  width: 94px;
  height: 8px;
  position: absolute;
  right: 200px;
  top: 22px;
  border: 1px solid #FFF;
  cursor: pointer;
  transition: .5s all;
}
.chap02_bar:hover{
  background:#FFF;
}

.show_chap01 .chap01{
  opacity: 0;
  pointer-events: none;
}

.show_chap02 .chap02_bar{
  background: #FFF;
  cursor: auto;
}
.show_chap02 .chap02{
  opacity: 0;
  pointer-events: none;
}

.show_chap02 .sec01_txtbox01{
  left:-50%;
}
.show_chap02 .sec01_txtbox02{
  left: 50%;
}
.show_chap01 .chap01_bar{
  background: #FFF;
  cursor: auto;
}

.sec01_txt01 {
  font-size: 20px;
  line-height: 40px;
  margin-bottom: 20px;
}

.sec01_txt02 {
  font-size: 20px;
  line-height: 40px;
  margin-top: 20px;
}

h2 {
  font-size: 32px;
  line-height: 68px;
  letter-spacing: 4px;
}

.sec01_inner:before {
  content: "";
  display: block;
  position: fixed;
  width: calc(100vw - (100vw - 100%));
  height: 100vh;
  background: url(../img/mv_bl.jpg);
  background-position: top;
  z-index: 2;
  top: 0vh;
  opacity: 0;
  transition:.3s all;
  pointer-events: none;
}
.sec01_inner.show:before {
  opacity:1;
}
div#sec01_1 {
  position: relative;
  z-index: 6;
  overflow: hidden;
  background: #000;
  height: 1116px;
}

.sec01_1_bg {
  display: block;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}

.sec01_01_inner {
  position: absolute;
  z-index: 7;
  width: 956px;
  text-align: center;
  height: 666px;
  left: 50%;
  top: 190px;
  transform: translateX(-50%);
  overflow: hidden;
  background: url(../img/sec01_box01.png);
  background-repeat: no-repeat;
}

p.sec01_01_txt01 {
  position: absolute;
  color: #FFF;
  top: 306px;
  text-align: left;
  font-size: 20px;
  line-height: 40px;
  letter-spacing: 2px;
}

p.sec01_01_txt02 {
  position: absolute;
  color: #FFF;
  top: 368px;
  font-family: Yu Gothic;
  font-size: 12px;
  line-height: 24px;
  letter-spacing: .5px;
  text-align: left;
}


/*===================
sec02
====================*/

#sec02 {
  position: relative;
  height: 4324px;
  width: calc(100vw - (100vw - 100%));
  z-index: 7;
  background:#000;
  /* overflow: hidden; */
}

#sec01 {
  overflow: hidden;
  height: 200vh;
  width: calc(100vw - (100vw - 100%));
}

.sec02_bg {
  position: absolute;
  top: 0;
  z-index: 6;
  left: 50%;
  transform: translateX(-50%);
}

.sec02_inner {
  width: 100%;
  margin: 0px auto;
  /* padding: 200px 0; */
  box-sizing: border-box;
}

.sec02_inner_01,.sec02_inner_02,.sec02_inner_03{
  height: 980px;
  position: relative;
  z-index: 10;
}
.sec02_inner_04{
  height: 1384px;
  position: relative;
  z-index: 11;
}
.sec02_bg01,.sec02_bg02,.sec02_bg03,.sec02_bg04{
  position: fixed;
  top:50%;
  left: 50%;
  transform: translate(-50%,-50%);
  display: block;
}
/*
.sec02_inner.showbg01:after{
  background:url(../img/sec02_bg01.png);
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  background-attachment: fixed;
  content:"";
  width: 100vw;
  height: 100vh;
  display: block;
  position: fixed;
  top: 0;
  left: 0;
}
.sec02_inner.showbg02:after{
  background:url(../img/sec02_bg02.png);
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  background-attachment: fixed;
  z-index: 9;
  content:"";
  width: 100vw;
  height: 100vh;
  display: block;
  position: fixed;
  top: 0;
  left: 0;

}
.sec02_inner.showbg03:after{
  background:url(../img/sec02_bg03.png);
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  background-attachment: fixed;
  z-index: 8;
  content:"";
  width: 100vw;
  height: 100vh;
  display: block;
  position: fixed;
  top: 0;
  left: 0;

}
*/

/*
.sec02_inner.showbg04:after{
  height: 1384px;
  position: relative;
  z-index: 7;
  background:url(../img/sec02_bg04.png);
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  background-attachment: fixed;
  content:"";
  width: 100vw;
  height: 100vh;
  display: block;
  position: fixed;
  top: 0;
  left: 0;
}
.sec02_inner_01:after,.sec02_inner_02:after,.sec02_inner_03:after,.sec02_inner_04:after{
  opacity: 0;
  transition: .3s all;
  pointer-events: none;
}
.showbg:after{
  opacity: 1;
}
*/
.sec02_inner_04 .sec02_item {
    height: 307px;
    margin: 0 14px 100px;
}
.sec02_inner_04 .item3 {
    width: 623px;
}
.tax_free:before {
    content: '';
    display: block;
    width: 127px;
    height: 51px;
    position: absolute;
    background: url(../img/tax.svg);
    top: 146px;
    background-repeat: no-repeat;
    background-size: contain;
}
.sec02_inner_04 .sec02_item img {
    width: 216px;
    height: 196px;
}
.sec02_inner_04 .mdl02 img {
    width: 361px;
    height: 328px;
}
.mdl_txt2 p span {
    font-size: 14px;
}

.green {
    font-size: 14px !important;
    color: #5BD1C5;
}

.mdl_txt2 p br + span {
    font-size: 14px !important;
}
.moist{
  width: 956px;
  height: 406px;
  position: relative;
  /* left: 50%; */
  /* transform: translateX(-50%); */
  top:260px;
  margin: 0 auto;
  z-index: 1;
}
.moist_left{
  float: left;
}
.moist img{
  float:right;
}
.moist h3{
  font-size: 70px;
  line-height: 60px;
  color: #5BD1C5;
}
.moist p{
  width: 300px;
  font-size: 18px;
  line-height: 36px;
  letter-spacing: 2px;
  margin-bottom: 70px;
  color: #FFF;
}


.smooth{
  width: 956px;
  height: 406px;
  position: relative;
  /* left: 50%; */
  /* transform: translateX(-50%); */
  top:260px;
  margin: 0 auto;
  z-index: 10;
}
.smooth_right{
  float: right;
}
.smooth img{
  float:left;
}
.smooth h3{
  font-size: 70px;
  line-height: 70px;
  color: #8256AC;
}
.smooth p{
  width: 300px;
  font-size: 18px;
  line-height: 36px;
  letter-spacing: 2px;
  margin-bottom: 70px;
  color: #FFF;
}


.sec02_item {
  width: 268px;
  height: 371px;
  display: inline-block;
  position: relative;
  z-index: 10;
  color: #FFF;
  text-align: center;
  margin: 0 14px 150px;
  cursor: pointer;
}

.sec02_txt01 {
  font-size: 24px;
  /* font-weight: lighter; */
  letter-spacing: 2px;
}

.sec02_item img {
  display: block;
  margin: 0 auto 34px;
  height: 238px;
}

.tax {
  font-size: 32px;
  letter-spacing: 2px;
}
.tax span {
  font-size: 20px;
}
.sec02_item:after {
  content: '';
  position: absolute;
  background: url(../img/plus.svg);
  width: 90px;
  height: 90px;
  top: 90px;
  left: 50%;
  transform: translateX(-50%);
  opacity: 0;
  transition: .5s all;
  cursor: pointer;
}

.sec02_item:hover:after {
  opacity: 1;
}


/* mdl open */

.sec02_item_mdl {
  position: absolute;
  width: 1100px;
  height: 0;
  background: #000;
  z-index: 100;
  bottom: 0;
  overflow: hidden;
  z-index: 110;
  left: 50%;
  transform: translateX(-50%);
}

.open>img, .open>p {
  /*display: none*/
}

.open .sec02_item_mdl {
  display: block;
  height: 100vh;
  bottom: 0;
  transition: 1s all;
  z-index: 100;
  position: fixed;
  overflow: scroll;
}

.sec02_item.open {
  z-index: 100;
  pointer-events: auto !important;
}

p.mdl_txt {
  font-size: 32px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  letter-spacing: 8px;
  line-height: 2em;
  font-weight: lighter;
  font-family: Scheherazade, Hiragino Mincho pro, Yu Mincho, Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
  width: auto;
  margin: 0;
}

.sec02_item_mdl:before {
  content: none;
  display: block;
  width: 1100px;
  height: 100vh;
  background: #5BD1C5;
  top: 100vh;
  z-index: 50;
  position: absolute;
  transition-delay: 0;
  transition: 0s all;
}

.sec02_item_mdl:after {
  content: "";
  display: block;
  width: 1100px;
  height: 100vh;
  background: #5BD1C5;
  top: 100vh;
  z-index: 100;
  position: absolute;
  transition-delay: 0;
  transition: 0s all;
}

.open .sec02_item_mdl:before {
  top: -100vh;
  transition: 1s all;
  transition-delay: 1s;
}

.open .sec02_item_mdl:after {
  top: -100vh;
  transition: 1s all;
  transition-delay: 1.7s;
}

.z20 {
  z-index: 20 !important;
}

.mdl02 {
  position: relative;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 754px;
  height: auto;
  margin: 0;
  line-height: normal;
  overflow: auto;
  padding-top: 166px;
  min-height: 500px;
}

.sec02_inner_04 .mdl02:after{
    content: '';
    display: block;
    width: 127px;
    height: 51px;
    position: absolute;
    background: url(../img/tax.svg);
    top: 443px;
    background-repeat: no-repeat;
    background-size: contain;
}

.mdl_close {
  width: 39px;
  height: 29px !important;
  position: absolute;
  top: 70px;
  left: 50%;
  transform: translateX(-50%);
  margin: 0;
  cursor: pointer;
  transition:.3s all;
}
.mdl_close:hover {
  opacity:.8;
}

.moist .mdl02 img,.smooth .mdl02 img {
  float: left;
  position: absolute;
  top: 166px;
  width: 336px;
  height: auto;
}

.mdl02 img {
  float: left;
  position: absolute;
  top: 166px;
  height: auto;
}
.mdl02 img[src*=img11], .mdl02 img[src*=img12] .mdl02 img[src*=img14] {
  float: left;
  height: 353px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.mdl_txt2 {
  float: right;
  width: 344px;
  text-align: left;
  margin-top: 0;
}

h3 {
  font-size: 34px;
  margin-bottom: 20px;
}

h3 span {
  font-size: 16px;
}

.mdl_txt2 p {
  font-size: 16px;
  line-height: 32px;
  margin-bottom: 40px;
  width: auto;
}

.mdl_txt2 ul p {
  display: inline-block;
  font-size: 20px;
  color: #AAAAAA;
  margin-right: 9px;
}

.mdl_txt2 ul li {
  display: inline-block;
  font-family: Hiragino Kaku Gothic Pro;
  font-size: 12px;
  padding: 5px 11px;
  background: #AAAAAA;
  border-radius: 20px;
  color: #000;
  margin-right: 0px;
  letter-spacing: 1px;
  font-weight: bold;
}

.mdl_txt2 ul li:last-child {
  margin-right: 0;
}

th {
  font-size: 20px;
  width: 100px;
  line-height: 40px;
  font-weight: bold;
  letter-spacing: 2px;
}

td {
  font-size: 16px;
  line-height: 32px;
  letter-spacing: 2px;
}

table {
  border-top: 1px solid #FFF;
  border-bottom: 1px solid #FFF;
  padding: 20px 0;
}

.tax2 {
  font-size: 32px !important;
  margin-top: 30px;
}

p.tax2 span {
  font-size: 24px !important;
}

.tax2 {
  font-size: 32px !important;
  margin-top: 50px;
  letter-spacing: 4px;
}

.sec02_inner_03 .tax2,.sec02_inner_04 .tax2 {
  font-size: 32px !important;
  margin-top: 30px;
  letter-spacing: 4px;
}


p.tax2 span {
  font-size: 24px !important;
}

.mdl02 input[type=text] {}

.mdl02 input[type="tel"] {
  width: 93px;
  height: 65px;
  text-align: center;
  font-size: 20px;
  border: none;
  padding: 0;
  display: inline-block;
  vertical-align: top;
  letter-spacing: normal;
  margin-right: 1px;
}

.mdl02 button[type="submit"] {
  width: 250px;
  height: 65px;
  font-size: 24px;
  border: none;
  background: #FFF;
  padding: 0;
  display: inline-block;
  vertical-align: top;
  letter-spacing: 2px;
  font-family: Scheherazade;
  transition:.3s all;
  cursor:pointer
}
.mdl02 button:hover{
  opacity:.8;
}

.query {
  letter-spacing: -.4em;
  font-family: "Yu Mincho";
}

.mdl_link {
  width: 100%;
  height: 100px;
  background: #95989A;
  color: #000;
  text-align: center;
  font-family: "Yu mincho";
  box-sizing: border-box;
  padding: 20px;
}

.mdl_link a {
  color: #000;
  transition: .3s all;
  font-family: "Yu Mincho", "Yu Mincho", Hiragino Mincho pro, Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
  font-size: 14px;
}

.mdl_link a:hover {
  color: #333;
}

.mdl_link p {
  margin-bottom: 6px;
  letter-spacing: 0;
  color: #000;
  font-family: Scheherazade, "Yu Mincho", "Yu Mincho", Hiragino Mincho pro, Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
  font-size: 14px;
}

.openend .sec02_item_mdl {
  bottom: 100vh;
  pointer-events: none;
}

.sec02_txt01 span {
  font-size: 16px;
}

div#sec02_01 {
  position: relative;
  z-index: 8;
  height: 1030px;
  background: #000;
}

.sec02_01_inner {
  width: 900px;
  height: 585px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.sec02_01_img01 {
  display: block;
  margin: 0 auto 100px;
}

.sec02_01_box01 {
  display: inline-block;
  letter-spacing: -.4em;
}

.sec02_01_box01 div {
  width: 195px;
  height: 247px;
  display: inline-block;
  letter-spacing: normal;
  overflow: hidden;
  position: relative;
  margin: 0 20px;
}

.sec02_01_boximg01 {
  width: 195px;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  transition: .3s all;
}

.sec02_01_box01 div:first-child {
  margin: 0 20px 0 0px;
}

.sec02_01_box01 div:last-child {
  margin: 0 0px 0 20px;
}

.hoverimg {
  opacity: 0;
  z-index: 0;
  transition:.3s all;
}

.sec02_01_box01 div:hover .sec02_01_boximg01 {
  opacity: 0;
}

.sec02_01_box01 div:hover .hoverimg {
  opacity: .7;
}

.link_media {
  position: absolute;
  bottom: 0;
  font-size: 18px;
  color: #FFF;
  text-decoration: none;
  width: 239px;
  height: 96px;
  text-align: center;
  border: #FFF 1px solid;
  line-height: 96px;
  font-family: Scheherazade;
  letter-spacing: 4px;
  left: 50%;
  transform: translateX(-50%);
  margin: 0;
}
#sec02_02 .link_media {bottom: 257px;}
.link_media.sec02_item:after {
  content:none;
}
.sec02_inner .link_media{
  left:auto;
  transform:none;
}

.sec02_01_box01 div p {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #FFF;
  text-decoration: none;
  font-family: Yu Gothic;
  font-size: 12px;
  line-height: 24px;
  text-align: center;
  opacity: 0;
  transition: .3s all;
  z-index: 2;
  pointer-events: none;
  font-weight: bold;
}

.sec02_01_box01 div:hover p {
  opacity: 1;
}


/*===================
sec03
====================*/

#sec03 {
  position: relative;
  z-index: 7;
  height: 100vh;
  width: calc(100vw - (100vw - 100%));
  overflow: hidden;
}

.sec03_inner {
  width: 570px;
  margin: 0 auto;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: left;
  z-index: 9;
}
.sec03_inner h2:after {
    content: '';
    width: 13px;
    height: 13px;
    display: block;
    position: absolute;
    background: url(../img/link_icon.svg);
    right: 170px;
    top: 5px;
}

.sec03_inner h2 {
  color: #FFF;
  text-align: center;
  font-size: 40px;
  line-height: 1em;
  margin-bottom: 44px;
  letter-spacing: 6px;
}

.sec03_inner a {
  color: #FFF;
  text-decoration: none;
  display: inline-block;
  width: 185px;
  margin-bottom: 24px;
  font-weight: lighter;
  transition: .3s all;
  font-family: YuGothic,"Yu Cothic";
}

.sec03_inner a:hover {
  opacity: .7;
}

.sec03_bg {
  /* width: calc(100vw - (100vw - 100%)); */
  height: 130%;
  position: absolute;
  z-index: 8;
  top: 0;
  left: 0;
}


/*===================
MEDIA
====================*/

#m_sec01 {
  position: relative;
  z-index: 8;
  height: 880px;
  background: #303030;
}

.m_sec01_inner {
  width: 900px;
  height: 585px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.m_sec01_boximg01 {
  position: relative;
  display: inline-block;
  letter-spacing: -.4em;
}

.m_sec01_link {
  display: inline-block;
  width: 273px;
  height: 320px;
  overflow: hidden;
  position: relative;
  margin: 0 14px;
  letter-spacing: normal;
}
.m_sec01_link:first-child {
  margin: 0 14px 0 0px;
}
.m_sec01_link:last-child {
  margin: 0 0px 0 14px;
}

a.m_sec01_link p {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 14px;
  color: #FFF;
  text-decoration: none;
  font-family: Yu Gothic;
  opacity: 0;
  z-index: 3;
  line-height: 1.5;
  font-weight: bold;
}

.m_sec01_boximg01 {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  transition: .3s all;
  width: 100%;
}

.m_sec01_link:hover .m_sec01_boximg01 {
  opacity: 0;
}

.m_sec01_link:hover .hoverimg {
  opacity: .7;
}

.m_sec01_link:hover p {
  opacity: 1;
}

.m_sec01_link:before {
  content: '';
  display: block;
  width: calc(100% - 40px);
  height: calc(100% - 40px);
  position: absolute;
  top: 0;
  left: 0;
  margin: 20px;
  box-sizing: border-box;
  border: 1px solid #FFF;
}

.media_ttl {
  color: #FFF;
  text-align: center;
  font-size: 16px;
  letter-spacing: 3px;
  line-height: 40px;
  margin-bottom: 50px;
}

.media_ttl span {
  font-size: 40px;
}

#wrap_media #sec02_01 {
  height: 1810px;
}

#wrap_media .sec02_01_box01 a {
  width: 195px;
  height: 247px;
  display: inline-block;
  letter-spacing: normal;
  overflow: hidden;
  position: relative;
  margin: 0 20px 20px;
}

#wrap_media .sec02_01_box01 a:first-child {
  margin: 0 20px 20px 0px;
}

#wrap_media .sec02_01_box01 a:last-child {
  margin: 0 0px 20px 20px;
}

#wrap_media .sec02_01_box02 {
  width: 623px;
  height: 294px;
  margin: 115px auto 0;
}

#wrap_media table {
  border-top: 1px solid #FFF;
  border-bottom: 1px solid #FFF;
  padding: 40px 0;
  text-align: left;
}
#wrap_media table a {
  text-decoration: none;
}
#wrap_media tr {}

#wrap_media th {
  font-size: 12px;
  width: 156px;
  font-weight: bold;
  line-height: 30px;
  color: #FFF;
  padding-bottom: 20px;
  font-family: "Yu Gothic"
}

#wrap_media td {
  font-size: 12px;
  line-height: 30px;
  letter-spacing: 3px;
  color: #FFF;
  padding-bottom: 20px;
  v font-family: "Yu Gothic"
}

#wrap_media tr:last-child td, #wrap_media tr:last-child th {
  padding: 0;
}

#wrap_media .sec02_01_inner {
  width: 900px;
  height: 585px;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, 0%);
}

.m_sec01_link:nth-child(1) img {
  width: 480px;
}

.m_sec01_link:nth-child(2) img {
  width: 480px;
}

.m_sec01_link:nth-child(3) img {
  width: 316px;
}
#wrap_media .sec02_01_box01 {
  margin-bottom:40px;
}





/*======   company   ======*/



#wrap_comp #sec02_01 {
    height: 100vh;
}

div#wrap_comp h2 {
    color: #FFF;
    text-align: center;
    font-size: 20px;
    line-height: 68px;
    letter-spacing: 4px;
}

#wrap_comp table {
    font-family: "Yu Gothic";
    color: #FFF;
    width: 100%;
    text-align: left;
}

#wrap_comp th {
    width: 220px;
    line-height: 40px;
    font-weight: bold;
    letter-spacing: 2px;
    font-size: 14px;
}
#wrap_comp td{
    font-size: 14px;
    line-height: 32px;
    letter-spacing: 2px;
}

#wrap_comp .sec02_01_inner {
    width: 700px;
    height: 260px;
}

/*======   guideline   ======*/

@media screen and (max-width: 768px){
  #wrap_guide #sec02_01 {
    height: calc(2510*100vw/1920);
  }
}


div#wrap_guide h2 {
    color: #FFF;
    text-align: center;
    font-size: 20px;
    line-height: 68px;
    letter-spacing: 4px;
}

#wrap_guide table {
    font-family: "Yu Gothic";
    color: #FFF;
    width: 100%;
    text-align: left;
}

#wrap_guide th {
    width: 220px;
    line-height: 40px;
    font-weight: bold;
    letter-spacing: 2px;
    font-size: 14px;
}
#wrap_guide td{
    font-size: 14px;
    line-height: 32px;
    letter-spacing: 2px;
}

#wrap_guide .sec02_01_inner {
    width: 700px;
    height: auto;
}
#wrap_guide .sec02_01_inner a{
color:#FFF;
text-decoration:none;
transition:.3s all;
}
#wrap_guide .sec02_01_inner a:hover{
opacity:.8;}

.fixed {
  position: fixed;
}

/*  colorbox */
/*
    Colorbox Core Style:
    The following CSS is consistent between example themes and should not be altered.
*/
#colorbox, #cboxOverlay, #cboxWrapper{position:absolute; top:0; left:0; z-index:9999; overflow:hidden; -webkit-transform: translate3d(0,0,0);}
#cboxWrapper {max-width:none;}
#cboxOverlay{position:fixed; width:100%; height:100%;}
#cboxMiddleLeft, #cboxBottomLeft{clear:left;}
#cboxContent{position:relative;}
#cboxLoadedContent{overflow:auto; -webkit-overflow-scrolling: touch;}
#cboxTitle{margin:0;}
#cboxLoadingOverlay, #cboxLoadingGraphic{position:absolute; top:0; left:0; width:100%; height:100%;}
#cboxPrevious, #cboxNext, #cboxClose, #cboxSlideshow{cursor:pointer;}
.cboxPhoto{float:left; margin:auto; border:0; display:block; max-width:none; -ms-interpolation-mode:bicubic;}
.cboxIframe{width:100%; height:100%; display:block; border:0; padding:0; margin:0;}
#colorbox, #cboxContent, #cboxLoadedContent{box-sizing:content-box; -moz-box-sizing:content-box; -webkit-box-sizing:content-box;}

/*
    User Style:
    Change the following styles to modify the appearance of Colorbox.  They are
    ordered & tabbed in a way that represents the nesting of the generated HTML.
*/
#cboxOverlay{background:#000; opacity: 0.9; filter: alpha(opacity = 90);}
#colorbox{outline:0;}
    #cboxContent{margin-top:20px;background:#000;}
        .cboxIframe{background:#fff;}
        #cboxError{padding:50px; border:1px solid #ccc;}
        #cboxLoadedContent{border:5px solid #000; background:#fff;}
        #cboxTitle{position:absolute; top:-20px; left:0; color:#ccc;}
        #cboxCurrent{position:absolute; top:-20px; right:0px; color:#ccc;}
        #cboxLoadingGraphic{background:url(../img/loading.gif) no-repeat center center;}

        /* these elements are buttons, and may need to have additional styles reset to avoid unwanted base styles */
        #cboxPrevious, #cboxNext, #cboxSlideshow, #cboxClose {border:0; padding:0; margin:0; overflow:visible; width:auto; background:none; }

        /* avoid outlines on :active (mouseclick), but preserve outlines on :focus (tabbed navigating) */
        #cboxPrevious:active, #cboxNext:active, #cboxSlideshow:active, #cboxClose:active {outline:0;}

        #cboxSlideshow{position:absolute; top:-20px; right:90px; color:#fff;}
        #cboxPrevious{position:absolute; top:50%; left:5px; margin-top:-32px; background:url(../img/controls.png) no-repeat top left; width:28px; height:65px; text-indent:-9999px;}
        #cboxPrevious:hover{background-position:bottom left;}
        #cboxNext{position:absolute; top:50%; right:5px; margin-top:-32px; background:url(../img/controls.png) no-repeat top right; width:28px; height:65px; text-indent:-9999px;}
        #cboxNext:hover{background-position:bottom right;}
        #cboxClose{position:absolute; top:5px; right:5px; display:block; background:url(../img/controls.png) no-repeat top center; width:38px; height:19px; text-indent:-9999px;}
        #cboxClose:hover{background-position:bottom center;}

#cboxOverlay + div {
  display: none;
}

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {

  .menu li a {
    transition: .3s all;
    cursor: pointer;
    color: transparent;
    text-decoration: none;
    position:relative;
    display: block;
    padding: 0 .3em;
    background: none;
    background-position: 0 0;
    background-size: 200% auto;
    transition: .5s;
    color:#FFF;
  }
  .menu li a:before {
    content:none;
  }

  .menu li a:hover {
    color: #5BD1C5;
  }

}

/*   perfect scroll  */
/* perfect-scrollbar v0.7.1 */
.ps {
  -ms-touch-action: auto;
  touch-action: auto;
  overflow: hidden !important;
  -ms-overflow-style: none; }
  @supports (-ms-overflow-style: none) {
    .ps {
      overflow: auto !important; } }
  @media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
    .ps {
      overflow: auto !important; } }
  .ps.ps--active-x > .ps__scrollbar-x-rail,
  .ps.ps--active-y > .ps__scrollbar-y-rail {
    display: block;
    background-color: transparent; }
  .ps.ps--in-scrolling.ps--x > .ps__scrollbar-x-rail {
    background-color: #eee;
    opacity: 0.9; }
    .ps.ps--in-scrolling.ps--x > .ps__scrollbar-x-rail > .ps__scrollbar-x {
      background-color: #999;
      height: 11px; }
  .ps.ps--in-scrolling.ps--y > .ps__scrollbar-y-rail {
    background-color: #eee;
    opacity: 0.9; }
    .ps.ps--in-scrolling.ps--y > .ps__scrollbar-y-rail > .ps__scrollbar-y {
      background-color: #999;
      width: 11px; }
  .ps > .ps__scrollbar-x-rail {
    display: none;
    position: absolute;
    /* please don't change 'position' */
    opacity: 0;
    -webkit-transition: background-color .2s linear, opacity .2s linear;
    -o-transition: background-color .2s linear, opacity .2s linear;
    -moz-transition: background-color .2s linear, opacity .2s linear;
    transition: background-color .2s linear, opacity .2s linear;
    bottom: 0px;
    /* there must be 'bottom' for ps__scrollbar-x-rail */
    height: 15px; }
    .ps > .ps__scrollbar-x-rail > .ps__scrollbar-x {
      position: absolute;
      /* please don't change 'position' */
      background-color: #aaa;
      -webkit-border-radius: 6px;
      -moz-border-radius: 6px;
      border-radius: 6px;
      -webkit-transition: background-color .2s linear, height .2s linear, width .2s ease-in-out, -webkit-border-radius .2s ease-in-out;
      transition: background-color .2s linear, height .2s linear, width .2s ease-in-out, -webkit-border-radius .2s ease-in-out;
      -o-transition: background-color .2s linear, height .2s linear, width .2s ease-in-out, border-radius .2s ease-in-out;
      -moz-transition: background-color .2s linear, height .2s linear, width .2s ease-in-out, border-radius .2s ease-in-out, -moz-border-radius .2s ease-in-out;
      transition: background-color .2s linear, height .2s linear, width .2s ease-in-out, border-radius .2s ease-in-out;
      transition: background-color .2s linear, height .2s linear, width .2s ease-in-out, border-radius .2s ease-in-out, -webkit-border-radius .2s ease-in-out, -moz-border-radius .2s ease-in-out;
      bottom: 2px;
      /* there must be 'bottom' for ps__scrollbar-x */
      height: 6px; }
    .ps > .ps__scrollbar-x-rail:hover > .ps__scrollbar-x, .ps > .ps__scrollbar-x-rail:active > .ps__scrollbar-x {
      height: 11px; }
  .ps > .ps__scrollbar-y-rail {
    display: none;
    position: absolute;
    /* please don't change 'position' */
    opacity: 0;
    -webkit-transition: background-color .2s linear, opacity .2s linear;
    -o-transition: background-color .2s linear, opacity .2s linear;
    -moz-transition: background-color .2s linear, opacity .2s linear;
    transition: background-color .2s linear, opacity .2s linear;
    right: 0;
    /* there must be 'right' for ps__scrollbar-y-rail */
    width: 15px; }
    .ps > .ps__scrollbar-y-rail > .ps__scrollbar-y {
      position: absolute;
      /* please don't change 'position' */
      background-color: #aaa;
      -webkit-border-radius: 6px;
      -moz-border-radius: 6px;
      border-radius: 6px;
      -webkit-transition: background-color .2s linear, height .2s linear, width .2s ease-in-out, -webkit-border-radius .2s ease-in-out;
      transition: background-color .2s linear, height .2s linear, width .2s ease-in-out, -webkit-border-radius .2s ease-in-out;
      -o-transition: background-color .2s linear, height .2s linear, width .2s ease-in-out, border-radius .2s ease-in-out;
      -moz-transition: background-color .2s linear, height .2s linear, width .2s ease-in-out, border-radius .2s ease-in-out, -moz-border-radius .2s ease-in-out;
      transition: background-color .2s linear, height .2s linear, width .2s ease-in-out, border-radius .2s ease-in-out;
      transition: background-color .2s linear, height .2s linear, width .2s ease-in-out, border-radius .2s ease-in-out, -webkit-border-radius .2s ease-in-out, -moz-border-radius .2s ease-in-out;
      right: 2px;
      /* there must be 'right' for ps__scrollbar-y */
      width: 6px; }
    .ps > .ps__scrollbar-y-rail:hover > .ps__scrollbar-y, .ps > .ps__scrollbar-y-rail:active > .ps__scrollbar-y {
      width: 11px; }
  .ps:hover.ps--in-scrolling.ps--x > .ps__scrollbar-x-rail {
    background-color: #eee;
    opacity: 0.9; }
    .ps:hover.ps--in-scrolling.ps--x > .ps__scrollbar-x-rail > .ps__scrollbar-x {
      background-color: #999;
      height: 11px; }
  .ps:hover.ps--in-scrolling.ps--y > .ps__scrollbar-y-rail {
    background-color: #eee;
    opacity: 0.9; }
    .ps:hover.ps--in-scrolling.ps--y > .ps__scrollbar-y-rail > .ps__scrollbar-y {
      background-color: #999;
      width: 11px; }
  .ps:hover > .ps__scrollbar-x-rail,
  .ps:hover > .ps__scrollbar-y-rail {
    opacity: 0.6; }
  .ps:hover > .ps__scrollbar-x-rail:hover {
    background-color: #eee;
    opacity: 0.9; }
    .ps:hover > .ps__scrollbar-x-rail:hover > .ps__scrollbar-x {
      background-color: #999; }
  .ps:hover > .ps__scrollbar-y-rail:hover {
    background-color: #eee;
    opacity: 0.9; }
    .ps:hover > .ps__scrollbar-y-rail:hover > .ps__scrollbar-y {
      background-color: #999; }


@media screen and (max-height:692px){
  .sec02_item_mdl {
      position: relative;
      width: 1100px;
      height: 0;
      background: #000;
      z-index: 100;
      bottom: 0;
      overflow: scroll;
      z-index: 110;
      left: 50%;
      transform: translateX(-50%);
  }
  .mdl02 {
    position: relative;
    top: 0;
    left: 50%;
    transform: translate(-50%, 0%);
    width: 754px;
    height: 692px;
    margin: 100px 0;
}

}
/*20170719追記*/
.item_ttl01,.item_ttl02,.item_ttl03 {
    display: block;
    position: relative;
    z-index: 7;
    width: 623px;
    height: 24px;
    margin: 0 auto 85px;
}

.item_ttl01,.item_ttl02,.item_ttl03 {
    display: block;
    position: relative;
    z-index: 7;
    width: 623px;
    height: 24px;
    margin: 0 auto 85px;
    padding-top: 251px;
}

.new:before {
    content: "NEW";
    width: 82px;
    height: 82px;
    display: block;
    position: absolute;
    background: #5BD1C5;
    border-radius: 82px;
    top: -40px;
    left: 50px;
    font-size: 18px;
    font-family: YuGothic ,"Yu Gothic";
    line-height: 82px;
    font-weight: bold;
    color: #000;
}
.item3{
  width: 900px;
  margin: 0 auto;
}
#sec02_02{
  height: 1134px;
  position: relative;
  z-index: 10;
  background: #000;
}
.sec02_02_ttl{
  width: 623px;
  display: block;
  margin: 0 auto 90px;

}
.photos {
    position: absolute;
    top:130px;
    line-height: 0;
    -webkit-column-count: 8;
    -webkit-column-gap: 0px;
    -moz-column-count: 8;
    -moz-column-gap: 0px;
    column-count: 8;
    column-gap: 10px;
    animation: slide 24s linear infinite;
    width: 1920px;
}
.photos img {
    width: 230px !important;
    height: auto !important;
    /* display: block; */
    margin-bottom: 10px;
    opacity: .4;
    transition:.3s all;
}

.photos img:hover {
  opacity:1;
}
.photos + .photos{
  left: 1920px;
  margin-left: 10px;
}
@keyframes slide {
  0%{
    transform: translateX(0);
  }
  100%{
    transform: translateX(-1920px);
  }

}



.mdl_slct {
    display: block;
    width: 100%;
    height: 65px;
    border-radius: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    box-sizing: border-box;
    padding: 0 20px;
    font-size: 16px;
    color: #95989A;
    position:relative;
    background-image: url(../img/slct_bg.svg);
    background-repeat: no-repeat;
    background-size: 24px;
    background-position: center right 20px;
    border: none;
    margin-bottom: 1px;
    background-color: #FFF;
}
.mdl_tbl {
    position: relative;
}

.mdl_tbl p {
    position: absolute;
    display: block;
    width: 135px;
    height: 34px;
    font-size: 20px;
    background: #FFF;
    border-radius: 34px;
    text-align: center;
    color: #000;
    line-height: 36px;
    box-sizing: border-box;
    padding-left: 16px;
    letter-spacing: 0;
    top: -17px;
    left: 0;
    cursor: pointer;
    transition:.3s all;
}
.mdl_tbl p:hover {
  background:#AAA;

}
.mdl_tbl p.open:hover {
  background:#FFF;

}
.mdl_tbl p:before {
    content:'';
    position:absolute;
    width:11px;
    height:1px;
    background:#000;
    top:50%;
    transform:translateY(-50%);
    left:8px;
}
.mdl_tbl p:after {
    content:'';
    position:absolute;
    width:1px;
    height:11px;
    background:#000;
    top:50%;
    transform:translateY(-50%);
    left: 13px;
    transition: .3s all;
}
.mdl_tbl p.open:after {
    transform: translateY(-50%) rotate(90deg);
    opacity: 0;
}
.mdl_tbl_inner {
    height: 1px;
    width: 100%;
    overflow: hidden;
    transition: .3s all;
}
.open + .mdl_tbl_inner {
    height: 190px;
}

.mdl02 h3 {
    font-size: 34px;
    line-height: 24px;
    color: #FFF;
}

.mdl02 + .mdl02 {
    margin-bottom: 200px;
}

.bunner {
    position: fixed;
    bottom: -3px;
    right: -3px;
    z-index: 20;
    transition:.3s all;
    display: block;

}

.bunner:hover{
    opacity:.8;
}

/*しん追記*/

br.sp{
  display: none;
}
@include desktop{
  .pc_only{
    display: block;
  }
  .sp_only{
    display: none;
  }
}
@include smartphone{
  .pc_only{
    display: none;
  }
  .sp_only{
    display: block;
  }
}

/*================================================================================================
header
================================================================================================*/
header.top{
  @include desktop{
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    position: absolute;
    top: 40px;
    left: 40px;
    z-index: 10;
  }//desktop
  @include smartphone{
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    padding: sp(40) sp(40) 0;
    z-index: 10;
    .logo{
      width: sp(240);
    }
  }//sp
}//header
/*================================================================================================
nav_btn
================================================================================================*/
.nav_btn{
  @include desktop{
    display: none;
  }
  @include smartphone{
    display: block;
    width: sp(56);
    height: sp(24);
    position: fixed;
    top: sp(40);
    right: sp(40);
    z-index: 11;
    span{
      display: block;
      width: 100%;
      height: 1px;
      background: #FFF;
      position: absolute;
      transition: transform .3s;
      &:first-child{
        top: 0;
        left: 0;
      }
      &:last-child{
        bottom: 0;
        left: 0;
      }
    }
    &.open{
      span{
        display: block;
        width: 100%;
        height: 1px;
        background: #FFF;
        position: absolute;
        &:first-child{
          top: 0;
          left: 0;
          transform: rotate(45deg) translate(1vw , 1vw)
        }
        &:last-child{
          bottom: 0;
          left: 0;
          transform: rotate(-45deg) translate(1vw , -1vw);
        }
      }
    }
  }//sp
}//nav_btn
/*================================================================================================
nav
================================================================================================*/
.header_nav{
  @include desktop{
    position: absolute;
    top: 40px;
    right: 40px;
    width: 287px;
    z-index: 10;
    .inner{
      .nav_list{
        width: 100%;
        font-size: 14px;
        font-weight: 500;
        display: inline-flex;
        justify-content: space-between;
        li{
          a{
            padding: 16px 0;
            color: #FFF;
            position: relative;
            &:after{
              content: '';
              display: block;
              width: 0;
              height: 1px;
              position: absolute;
              bottom: 0;
              left: 0;
              background: #FFFFFF;
              transition: .3s width;
            }
            &:hover{
              &:after{
                width: 100%;
              }
            }
            &.nav_link_01{
              &.open{
                &:after{
                  width: 100%;
                }
              }
            }
          }//a
          .sub_menu{
            width: 287px;
            height: 76px;
            line-height: 76px;
            margin: 0 auto;
            background: #FFF;
            margin-top: 48px;
            position: absolute;
            display: none;
            overflow: visible;
            &:before{
              display: block;
              content: '';
              width: 0;
              height: 0;
              position: absolute;
              top: -18px;
              left: 36px;
              border: 9px solid transparent;
              border-left: #FFF solid 9px;
              border-bottom: #FFF solid 9px;
            }
            li{
              float: left;
              width: 33.3333%;
              text-align: center;
              a{
                font-size: 14px;
                color: #000;
                text-align: center;
                transition: .3s color;
                &:after{
                  content: none;
                }
                &:hover{
                  color: #00C984;
                }
              }//a
            }//li
          }//sub_menu
        }//li
      }//nav_list
    }//inner
  }//desktop
  @include smartphone{
    position: fixed;
    width: 100%;
    height: 100vh;
    background: rgba(0,0,0,.8);
    z-index: 10;
    display: none;
    overflow-y: visible;
    .inner{
      width: 100%;
      height: auto;
      -webkit-box-sizing: border-box;
      -moz-box-sizing: border-box;
      box-sizing: border-box;
      padding: sp(170) 0;

      .nav_list{
        width: 100%;
        font-size: 14px;
        font-weight: 500;
        display: block;
        li{
          text-align: center;
          a{
            color: #FFF;
            font-size: sp(64);
            line-height: sp(160);
            letter-spacing: 1px;
            &.nav_link_01{
              &.open{
                border-bottom: 1px solid #FFF;
              }
            }
          }//a
          .sub_menu{
            width: sp(480);
            margin: 0 auto;
            background: #FFF;
            margin-top: sp(48);
            position: relative;
            display: none;
            &:before{
              display: block;
              content: '';
              width: sp(0);
              height: sp(0);
              position: absolute;
              top: sp(-55);
              left: 50%;
              transform: translateX(-50%);
              border: sp(27) solid transparent;
              border-left: #FFF solid sp(27);
              border-bottom: #FFF solid sp(27);
            }
            li{
              a{
                font-size: sp(48);
                color: #000;
              }
            }
          }
        }//li
      }//nav_list
    }//inner
  }//sp
}
