@charset "UTF-8";
body {
  font-family: "Shippori Mincho", "Hiragino Mincho ProN", "游明朝", "YuMincho", "HGS明朝E", serif; 
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  color: #000000;
  -webkit-text-size-adjust: 100%;
  word-wrap: break-word;
  font-size: 16px;
  letter-spacing: 0.04em;
}
@media only screen and (max-width: 1024px) {
  body {
    font-size: 15px;
  }
}

* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

img {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
}
@media only screen and (max-width: 1024px) {
  img {
    border: 0;
    max-width: 100%;
    height: auto;
  }
}

a {
/*  color: #000000; */
  color: #00F;
  text-decoration: none;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
a:hover {
  opacity: 0.7;
}
a img {
  border: none;
}

i {
  padding: 0 5px;
}

ul {
  letter-spacing: -1em;
}
ul li {
  letter-spacing: 0;
  list-style: none;
}

.pc {
  display: block;
}
@media only screen and (max-width: 1024px) {
  .pc {
    display: none;
  }
}

.tablet {
  display: none;
}
@media only screen and (max-width: 1024px) {
  .tablet {
    display: block;
  }
}
@media only screen and (max-width: 600px) {
  .tablet {
    display: none;
  }
}

.sp {
  display: none;
}
@media only screen and (max-width: 1024px) {
  .sp {
    display: block;
  }
}

.ssp {
  display: none;
}
@media only screen and (max-width: 600px) {
  .ssp {
    display: block;
  }
}

/*PC改行加える*/
.br-pc {
  display: inherit;
}
@media only screen and (max-width: 1024px) {
  .br-pc {
    display: none;
  }
}

/*PC改行無効*/
.br_sp {
  display: none;
}
@media only screen and (max-width: 1024px) {
  .br_sp {
    display: block;
  }
}

.br_ssp {
  display: none;
}
@media only screen and (max-width: 600px) {
  .br_ssp {
    display: block;
  }
}

/*ズームイン表示*/
.zoomin {
  -webkit-transition: 0.8s;
  transition: 0.8s;
  transform: scale(0, 0);
  -webkit-transform: scale(0, 0);
}

.mv01 {
  transform: scale(1, 1);
  -webkit-transform: scale(1, 1);
}

/*フェードイン表示*/
.fadein {
  -webkit-transition: 0.8s;
  transition: 0.8s;
  opacity: 0;
}

.fadein:not(:target) {
  opacity: 1\9 ;
  /*IE9対策*/
}

.mv02 {
  opacity: 1;
}

/*移動＋フェードイン表示*/
.fadeup {
  -webkit-transition: 0.8s;
  transition: 0.8s;
  opacity: 0;
  transform: translate(0, 60px);
  -webkit-transform: translate(0, 60px);
}

.fadeup:not(:target) {
  opacity: 1\9 ;
  /*IE9対策*/
}

.mv07 {
  opacity: 1;
  transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
}

@media print {
  .zoomin, .fadein, .fadeup {
    opacity: 1;
  }
}
/************************************

wrapper

************************************/
.wrapper {
  max-width: 800px;
  width: 90%;
  margin: 0 auto;
  text-align:center;
}
.wrapper::after {
  content: "";
  display: block;
  clear: both;
}
@media only screen and (max-width: 600px) {
  .wrapper {
    width: 84%;
  }
}

/************************************

.list(flexbox)

************************************/


h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
  letter-spacing: 0.06em;
}

/************************************

header

************************************/
header {
  width: 100vw;
  position: relative;
  z-index: 1;
  /* Dots */
}
@media print {
  header {
    position: relative;
  }
}
@media screen and (max-width: 1024px) and (orientation: landscape) {
  header {
    /* 横向きの場合のスタイル */
    width: 100%;
  
  }
}
@media screen and (max-width: 1024px) and (orientation: portrait) {
  header {
    /* 縦向きの場合のスタイル */
    width: 100%;
  }
}
@media only screen and (max-width: 600px) {
  header {
    width: 100%;
  }
}
header .mainslide {
  position: absolute;
  z-index: -1;
  width: 100vw;
  height: 100vh;
}
@media screen and (max-width: 1024px) and (orientation: landscape) {
  header .mainslide {
    /* 横向きの場合のスタイル */
    width: 100%;
    height: 100vh;
  }
}
@media screen and (max-width: 1024px) and (orientation: portrait) {
  header .mainslide {
    /* 縦向きの場合のスタイル */
    width: 100%;
    height: 100vw;
  }
}
@media only screen and (max-width: 600px) {
  header .mainslide {
    width: 100%;
    height: 100vh;
  }
}
header .mainslide .image {
  width: 100vw;
  height: 100vh;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
@media screen and (max-width: 1024px) and (orientation: landscape) {
  header .mainslide .image {
    /* 横向きの場合のスタイル */
    width: 100%;
    height: 100vh;
  }
}
@media screen and (max-width: 1024px) and (orientation: portrait) {
  header .mainslide .image {
    /* 縦向きの場合のスタイル */
    width: 100%;
    height: 70vw;
  }
}
@media only screen and (max-width: 600px) {
  header .mainslide .image {
    width: 100%;
    height: 100vh;
  }
}
header .mainslide .image.image1 {
  background-image: url("../images/mainimage1.jpg");
}
@media only screen and (-webkit-min-device-pixel-ratio: 1.5), (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 1.5dppx) {
  header .mainslide .image.image1 {
    background-image: url("../images/mainimage1@2x.jpg");
  }
}
@media only screen and (max-width: 600px) {
  header .mainslide .image.image1 {
    background-image: url("../images/mainimage1-sp@2x.jpg");
  }
}
header .mainslide .image.image2 {
  background-image: url("../images/mainimage2.jpg");
}
@media only screen and (-webkit-min-device-pixel-ratio: 1.5), (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 1.5dppx) {
  header .mainslide .image.image2 {
    background-image: url("../images/mainimage2@2x.jpg");
  }
}
@media only screen and (max-width: 600px) {
  header .mainslide .image.image2 {
    background-image: url("../images/mainimage2-sp@2x.jpg");
  }
}
header .slick-current {
  -webkit-animation-name: mainslide_mv;
          animation-name: mainslide_mv;
  -webkit-animation-duration: 7s;
          animation-duration: 7s;
  -webkit-animation-timing-function: ease;
          animation-timing-function: ease;
}
@-webkit-keyframes mainslide_mv {
  from {
    -webkit-transform: scale(1.08);
            transform: scale(1.08);
  }
  to {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@keyframes mainslide_mv {
  from {
    -webkit-transform: scale(1.08);
            transform: scale(1.08);
  }
  to {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
header .slick-dotted.slick-slider {
  margin-bottom: 0px;
}
header .slick-dots {
  bottom: 25px;
}
header .slick-dots li button:before {
  font-size: 14px;
  color: #fff;
}
header .slick-dots li.slick-active button:before {
  color: #fff;
}
header .text {
  max-width: 1100px;
  width: 90%;
  margin: 0 auto 0;
  padding-top: 16vh;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  color: #fff;
}
@media only screen and (max-width: 1024px) {
  header .text {
    width: auto;
    padding-top: 10vw;
  }
}
@media only screen and (max-width: 600px) {
  header .text {
    padding-top: 20vw;
  }
}
header .text a {
  color: #fff;
}
header .text a:hover {
  opacity: 1;
}
header .text .title {
  width: 42px;
  height: 100%;
}
@media only screen and (max-width: 600px) {
  header .text .title {
    width: 30px;
  }
}
header .text .title a {
  display: block;
}
header .text .title a:hover {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}
header .text .title h1 {
  display: inline-block;
}
header .text .title h2 {
  display: inline-block;
  font-size: 17px;
  margin: 20px 0 0;
}
@media only screen and (max-width: 1024px) {
  header .text .title h2 {
    font-size: 15px;
  }
}
header .text nav {
  margin: 80px 80px 0 0;
}
@media only screen and (max-width: 600px) {
  header .text nav {
    margin: 10vw 15vw 0 0;
  }
}
header .text nav li {
  font-size: 18px;
  letter-spacing: 0.03em;
  margin: 0 30px;
}
@media only screen and (max-width: 600px) {
  header .text nav li {
    margin: 0 5vw;
    font-size: 16px;
  }
}
header .text nav li:nth-child(2) {
  -webkit-transition-delay: 0.1s;
          transition-delay: 0.1s;
}
header .text nav li:nth-child(3) {
  -webkit-transition-delay: 0.2s;
          transition-delay: 0.2s;
}
header .text nav li:nth-child(4) {
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
}
header .text nav li:nth-child(5) {
  -webkit-transition-delay: 0.4s;
          transition-delay: 0.4s;
}
header .text nav a {
  display: block;
  position: relative;
}
header .text nav a::before {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  margin: auto;
  width: 1px;
  height: 0;
  background-color: #fff;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  content: "";
}
header .text nav a:hover {
  padding-top: 30px;
}
header .text nav a:hover::before {
  height: 20px;
}

/************************************

main

************************************/
main {
  display: block;
}
main section {
  margin-bottom: 200px;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 1024px) {
  main section {
    margin-bottom: 150px;
  }
}

.main_mainimage {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: calc((100% - 1100px) / 2 + 910px);
}
@media only screen and (max-width: 1230px) {
  .main_mainimage {
    width: calc(5% + 90% - 80px - 9%);
  }
}
@media only screen and (max-width: 1024px) {
  .main_mainimage {
    width: calc(5% + 90% - 65px - 7.2%);
  }
}
@media only screen and (max-width: 600px) {
  .main_mainimage {
    position: relative;
    width: 100%;
    z-index: 1;
    margin: 0 0 50px;
  }
}
.main_mainimage img {
  width: 100%;
}
.main_mainimage.img_r {
  left: auto;
  right: 0;
}

.main_mainimage_bk {
  background-color: #000000;
  color: #fff;
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 2000px;
  padding-top: 540px;
}
@media only screen and (max-width: 1024px) {
  .main_mainimage_bk {
    background-size: 1024px;
    padding-top: 300px;
  }
}
.main_mainimage_bk a {
  color: #fff;
}

.main_container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.midashi {
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  position: relative;
  z-index: 1;
  width: 80px;
}
@media only screen and (max-width: 1024px) {
  .midashi {
    width: 65px;
  }
}
@media only screen and (max-width: 600px) {
  .midashi {
    -webkit-writing-mode: horizontal-tb;
    -ms-writing-mode: lr-tb;
    writing-mode: horizontal-tb;
    width: 100%;
  }
}
.midashi h2 {
  font-size: 16px;
}
@media only screen and (max-width: 600px) {
  .midashi h2 {
    padding-top: 24px;
  }
}
@media only screen and (max-width: 1024px) {
  .midashi h2 .eng {
    font-size: 45px;
  }
}
@media only screen and (max-width: 600px) {
  .midashi h2 .eng {
    top: 0px;
    font-size: 36px;
  }
}

.main_contents {
  width: calc(100% - 80px - 10%);
  margin: 0 0 0 10%;
}
@media only screen and (max-width: 1024px) {
  .main_contents {
    width: calc(100% - 65px - 8%);
    margin: 0 0 0 8%;
  }
}
@media only screen and (max-width: 600px) {
  .main_contents {
    width: 100%;
    margin: 40px 0 0;
  }
}
.main_contents.img_on {
  padding-top: 55vw;
}
@media only screen and (min-width: 1500px) {
  .main_contents.img_on {
    padding-top: 45vw;
  }
}
@media only screen and (max-width: 600px) {
  .main_contents.img_on {
    padding-top: 0;
  }
}

.m_right .midashi {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
@media only screen and (max-width: 600px) {
  .m_right .midashi {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}
.m_right .main_contents {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  margin: 0 10% 0 0;
}
@media only screen and (max-width: 1024px) {
  .m_right .main_contents {
    margin: 0 8% 0 0;
  }
}
@media only screen and (max-width: 600px) {
  .m_right .main_contents {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    margin: 40px 0 0;
  }
}





#about .text_only {
  width: 100%;
  margin: 0 0 150px;
  display: block;
}
#about .text_only h2{
margin:30px auto;
font-weight:bold;
}

@media only screen and (max-width: 1024px) {
  #about .text_only {
    margin: 0 0 100px;
  }
#about .text_only h2{
font-size:18px;
margin:30px auto;
font-weight:bold;
}
}
#about .text_only.about1 {
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  height: 480px;
}
@media only screen and (max-width: 600px) {
  #about .text_only.about1 {
    -webkit-writing-mode: horizontal-tb;
    -ms-writing-mode: lr-tb;
    writing-mode: horizontal-tb;
    height: auto;
  }
}
@media only screen and (max-width: 1024px) {
  #about .text_only.about1 .br-pc {
    display: block;
  }
}
@media only screen and (max-width: 600px) {
  #about .text_only.about1 .br-pc {
    display: none;
  }
}
#about .text_only p {
  text-align: left;
/*  line-height: 3.5; */
}
@media only screen and (max-width: 1024px) {
  #about .text_only p {
/*    line-height: 6vw; */
  }
}
@media only screen and (max-width: 600px) {
  #about .text_only p {
/*    line-height: 11vw; */
  }
}
#about .textimg {
  margin: 0 0 150px 0;
  width: 100%;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media only screen and (max-width: 1024px) {
  #about .textimg {
    margin: 0 0 100px;
  }
}
#about .textimg .text {
  width: 38%;
  margin: 0 0 0 7%;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
@media only screen and (max-width: 600px) {
  #about .textimg .text {
    width: 100%;
    text-align: center;
    margin: 0;
  }
}
#about .textimg .text p {
  margin-top: 100px;
  text-align: left;
  line-height: 3.5;
}
@media only screen and (max-width: 1024px) {
  #about .textimg .text p {
    line-height: 5vw;
    margin-top: 0px;
  }
}
@media only screen and (max-width: 600px) {
  #about .textimg .text p {
    line-height: 11vw;
  }
}
#about .textimg .image {
  width: 55%;
  margin: 0 0 0;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
@media only screen and (max-width: 600px) {
  #about .textimg .image {
    width: 100%;
    margin: 0 0 60px;
  }
}
#about .click_content {
  margin-top: 80px;
}
#about .click_content .waku {
  width: 44%;
  margin: 30px 3%;
}
@media only screen and (max-width: 600px) {
  #about .click_content .waku {
    width: 94%;
  }
}
#about .click_content .photo {
  margin: 0 0 30px;
}
#about .click_content p {
  line-height: 1.7;
  font-size: 15px;
  margin: 0;
}



/*!!!! このcssはsass（sass/同名の.scssファイル）からコンパイルされています。修正時はこのcssを直接いじらないようにお願いします  */
/*# sourceMappingURL=maps/common.css.map */