@charset "UTF-8";

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 100;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 200;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 300;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 400;
}

html {
  font-size: 15px;
  font-family: 'Oswald', "Yu Gothic", sans-serif;
}

html,body {
  margin: 0;
  height: 0;
}

@media only screen and (max-width: 768px) {
  body {
    min-width: auto;
  }
}

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

a {
  color: inherit;
  text-decoration: none;
}

ul {
  padding: 0;
  list-style: none;
}

/* view
==================================================*/
#visual {
  width: 100%;
  height: 77vh;
  overflow: hidden;
}
.vwraper {
  display: -ms-flex;
  display: flex;
  margin: 0;
  width: 100%;
  height: 100%;
}

.vwraper__li {
  display: -ms-flex;
  display: flex;
  -ms-align-items: center;
  align-items: center;
	-ms-justify-content: center;
  justify-content: center;
  width: 50%;
  position: relative;
  transition: all 0.5s ease;
}

.vwraper__li__skew {
  display: block;
  position: absolute;
  width: 120%;
  height: 100%;
  transform: scaleX(1) scaleY(1) scaleZ(1) skewX(14deg);
  transform-origin: 50% 50%;
  transition: all 0.5s ease;
  z-index: 10;
  overflow: hidden;
}

.vwraper__li__skew:hover,
.vwraper__li__skew.hover {
  transform: scaleX(1.05) scaleY(1.05) scaleZ(1) skewX(14deg);
  filter: brightness(110%);
}

.vwraper__li__skew.s-left {
  right: 0;
}

.vwraper__li__skew.s-right {
  left: 0;
}

.vwraper__li a {
  font-size: 4.2vw;
  font-weight: 400;
  color: #fff;
  position: relative;
  z-index: 30;
}

.vwraper__li a span {
  display: block;
  text-align: center;
}

.vwraper__li a .headline-en {
  font-size: 4.2vw;
}

.vwraper__li a .headline-ja {
  font-size: 1.8vw;
}

figure.visualimg {
  margin: 0 -25%;
  padding: 0;
  display: block;
  position: absolute;
  width: 150%;
  height: 100%;
  transform: scale(1) skewX(-14deg);
  transition: .5s ease;
  z-index: 1;
}

#yurakuchar {
  position: absolute;
  top: 0;
  left: calc(50% - 8.5vw);
  background: url('../images/YURAKUGROUP.png') center no-repeat;
  background-size: contain;
  width: 17vw;
  height: 77vh;
  text-align: center;
  transition: all 0.5s ease;
  z-index: 100;
}
/*
==================================================*/

.banner-wrap {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: center;
  width: 80%;
  margin: 1.0vw auto;
}

.banner-wrap__li {
  margin: 1.2vw;
}

.banner-wrap__li a {
  opacity: 1;
  transition: .3s ease;
}

.banner-wrap__li a:hover {
  opacity: .7;
}

/* footer
==================================================*/
.footer-navi {
  margin: 1.5vh auto;
  display: -ms-flex;
  display: flex;
  -ms-justify-content: center;
  justify-content: center;
  -ms-align-items: center;
  align-items: center;
}

.footer-navi__li {
  margin: 1.5vh 1.5vw;
}

.divider {
  display: block;
  width: 1px;
  height: 1em;
  background: #555;
}

.footer-navi__li a {
  display: block;
  padding: 1vh 1vw;
}

.copyright {
  background: #f1f1f1;
  text-align: center;
  font-size: 80%;
  padding: .5em .7em;
}
