* {
  margin: 0;
  padding: 0;
  height: 100%; }

html, body {
  height: 100%; }

html {
  font-size: 62.5%; }

body {
  margin: 0;
  padding: 0;
  background: #FFF;
  font-family: sans-serif; }

p, h1, h2, h3, h4, h5, h6, ul, ol, dl, dt, dd, div, section, li, table, th, td, tr, form, iframe {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  vertical-align: bottom; }

li {
  list-style-type: none; }

img {
  vertical-align: bottom;
  width: 100%;
  height: auto;
  line-height: 0;
  font-size: 0; }

.pc_hidden {
  display: none; }

.sp_hidden {
  display: block; }

.ld-overlay {
  position: fixed;
  color: #CCC;
  font-size: 12px;
  letter-spacing: 0.4pt;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: #333;
  z-index: 1000;
  overflow: hidden; }

.loader,
.loader:before,
.loader:after {
  border-radius: 50%;
  width: 2.5em;
  height: 2.5em;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation: load7 1.8s infinite ease-in-out;
  animation: load7 1.8s infinite ease-in-out; }

.loader {
  color: #c3a2be;
  font-size: 10px;
  margin: auto;
  position: relative;
  text-indent: -9999em;
  -webkit-transform: translateZ(0);
  -ms-transform: translateZ(0);
  transform: translateZ(0) scale(0.5);
  -webkit-animation-delay: -0.16s;
  animation-delay: -0.16s; }

.loader:before,
.loader:after {
  content: '';
  position: absolute;
  top: 0; }

.loader:before {
  left: -3.5em;
  -webkit-animation-delay: -0.32s;
  animation-delay: -0.32s; }

.loader:after {
  left: 3.5em; }

@-webkit-keyframes load7 {
  0%,
  80%,
  100% {
    box-shadow: 0 2.5em 0 -1.3em; }
  40% {
    box-shadow: 0 2.5em 0 0; } }
@keyframes load7 {
  0%,
  80%,
  100% {
    box-shadow: 0 2.5em 0 -1.3em; }
  40% {
    box-shadow: 0 2.5em 0 0; } }
.logo {
  position: absolute;
  top: 10px;
  left: 10px;
  width: 60%; }

#gnav {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: #FFF;
  height: 100%;
  z-index: 1100; }
  #gnav .gnav-btns {
    display: flex;
    height: 100%;
    padding: 50px 0;
    flex-direction: column;
    justify-content: space-between;
    align-items: center; }
    #gnav .gnav-btns li a,
    #gnav .gnav-btns li span {
      display: block;
      transition: all 0.2s; }
      #gnav .gnav-btns li a img,
      #gnav .gnav-btns li span img {
        height: 55px;
        width: auto; }
    #gnav .gnav-btns li.navbtn0 {
      background: url("../../../about/images/gnav/gnav_btn0_hover.png") no-repeat left top;
      background-size: 100% auto; }
    #gnav .gnav-btns li.navbtn1 {
      background: url("../../../about/images/gnav/gnav_btn1_hover.png") no-repeat left top;
      background-size: 100% auto; }
    #gnav .gnav-btns li.navbtn2 {
      background: url("../../../about/images/gnav/gnav_btn2_hover.png") no-repeat left top;
      background-size: 100% auto; }
    #gnav .gnav-btns li.navbtn3 {
      background: url("../../../about/images/gnav/gnav_btn3_hover.png") no-repeat left top;
      background-size: 100% auto; }
    #gnav .gnav-btns li.navbtn4 {
      background: url("../../../about/images/gnav/gnav_btn4_hover.png") no-repeat left top;
      background-size: 100% auto; }
    #gnav .gnav-btns li.navbtn5 {
      background: url("../../../about/images/gnav/gnav_btn5_hover.png") no-repeat left top;
      background-size: 100% auto; }
    #gnav .gnav-btns li.navbtn6 {
      background: url("../../../about/images/gnav/gnav_btn6_hover.png") no-repeat left top;
      background-size: 100% auto; }
    #gnav .gnav-btns li.current {
      position: relative; }
      #gnav .gnav-btns li.current::after {
        content: '';
        display: block;
        position: absolute;
        left: 0;
        bottom: -2px;
        height: 4px;
        width: 100%;
        background: #F00; }
    #gnav .gnav-btns li.btn-sns {
      display: flex; }
      #gnav .gnav-btns li.btn-sns a {
        display: flex;
        width: 50%; }

#gallery {
  opacity: 0;
  position: relative;
  height: 100%;
  padding-bottom: 45px;
  overflow: hidden; }

.gallery-close {
  display: none;
  position: absolute;
  top: 0;
  right: 0;
  width: 130px;
  height: 115px;
  background: url("../../../about/images/gallery/gallery_btn_close.png") no-repeat left top;
  background-size: 130px 115px;
  z-index: 1002;
  transition: transform 0.2s; }
  .gallery-close:hover {
    transform: rotateZ(90deg); }
.gallery-panel {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  padding: 0;
  height: 100%;
  overflow: hidden;
  background: #0FF;
  font-size: 0;
  line-height: 0; }
  .gallery-panel .panel {
    width: 50%;
    margin: 0;
    height: 20%;
    text-indent: -9999px; }
  .gallery-panel .p1 {
    background: url("../../../about/images/gallery/gallery_p1.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p2 {
    background: url("../../../about/images/gallery/gallery_p2.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p3 {
    background: url("../../../about/images/gallery/gallery_p3.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p4 {
    background: url("../../../about/images/gallery/gallery_p4.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p5 {
    background: url("../../../about/images/gallery/gallery_p5.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p6 {
    background: url("../../../about/images/gallery/gallery_p6.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p7 {
    background: url("../../../about/images/gallery/gallery_p7.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p8 {
    background: url("../../../about/images/gallery/gallery_p8.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p9 {
    background: url("../../../about/images/gallery/gallery_p9.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p10 {
    background: url("../../../about/images/gallery/gallery_p10.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p11 {
    background: url("../../../about/images/gallery/gallery_p11.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p12 {
    background: url("../../../about/images/gallery/gallery_p12.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p13 {
    background: url("../../../about/images/gallery/gallery_p13.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p14 {
    background: url("../../../about/images/gallery/gallery_p14.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p15 {
    background: url("../../../about/images/gallery/gallery_p15.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p16 {
    background: url("../../../about/images/gallery/gallery_p16.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p17 {
    background: url("../../../about/images/gallery/gallery_p17.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p18 {
    background: url("../../../about/images/gallery/gallery_p18.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p19 {
    background: url("../../../about/images/gallery/gallery_p19.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .p20 {
    background: url("../../../about/images/gallery/gallery_p20.jpg") no-repeat center center;
    background-size: cover; }
  .gallery-panel .btn {
    position: absolute;
    width: 50%;
    height: 20%;
    z-index: 1001;
    display: none;
    transition: all 0.32s; }
    .gallery-panel .btn-inner {
      display: flex;
      flex-wrap: wrap;
      width: 100%;
      height: 100%;
      position: relative; }
      .gallery-panel .btn-inner::after {
        content: '';
        display: block;
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
        background: #FFF;
        z-index: 1000; }
    .gallery-panel .btn.btn1 {
      top: 20%;
      left: 0; }
      .gallery-panel .btn.btn1 .catch {
        height: 100%;
        background: #de0740 url("../../../about/images/gallery/gallery_t1.png") no-repeat center center;
        background-size: 100% auto; }
        .gallery-panel .btn.btn1 .catch img {
          opacity: 0; }
    .gallery-panel .btn.btn2 {
      top: 60%;
      left: 0; }
      .gallery-panel .btn.btn2 .catch {
        height: 100%;
        background: #de0740 url("../../../about/images/gallery/gallery_t2.png") no-repeat center center;
        background-size: 100% auto; }
        .gallery-panel .btn.btn2 .catch img {
          opacity: 0; }
    .gallery-panel .btn.btn3 {
      top: 60%;
      left: 50%; }
      .gallery-panel .btn.btn3 .catch {
        height: 100%;
        background: #de0740 url("../../../about/images/gallery/gallery_t3.png") no-repeat center center;
        background-size: 100% auto; }
        .gallery-panel .btn.btn3 .catch img {
          opacity: 0; }
    .gallery-panel .btn.btn4 {
      top: 0;
      left: 0; }
      .gallery-panel .btn.btn4 .catch {
        height: 100%;
        background: #de0740 url("../../../about/images/gallery/gallery_t4.png") no-repeat center center;
        background-size: 100% auto; }
        .gallery-panel .btn.btn4 .catch img {
          opacity: 0; }
    .gallery-panel .btn.btn5 {
      top: 40%;
      left: 50%; }
      .gallery-panel .btn.btn5 .catch {
        height: 100%;
        background: #de0740 url("../../../about/images/gallery/gallery_t5.png") no-repeat center center;
        background-size: 100% auto; }
        .gallery-panel .btn.btn5 .catch img {
          opacity: 0; }
    .gallery-panel .btn.btn6 {
      bottom: 0;
      left: 0; }
      .gallery-panel .btn.btn6 .catch {
        height: 100%;
        background: #de0740 url("../../../about/images/gallery/gallery_t6.png") no-repeat center center;
        background-size: 100% auto; }
        .gallery-panel .btn.btn6 .catch img {
          opacity: 0; }
    .gallery-panel .btn.btn7 {
      bottom: 0;
      left: 50%; }
      .gallery-panel .btn.btn7 .catch {
        height: 100%;
        background: #de0740 url("../../../about/images/gallery/gallery_t7.png") no-repeat center center;
        background-size: 100% auto; }
        .gallery-panel .btn.btn7 .catch img {
          opacity: 0; }
.gallery-slider {
  display: none;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1010;
  overflow: hidden; }
  .gallery-slider-inner {
    position: relative;
    width: 700%;
    height: 100%;
    transition: all 0.4s; }
    .gallery-slider-inner .slide:nth-child(1) {
      position: absolute;
      top: 0;
      left: 0; }
    .gallery-slider-inner .slide:nth-child(2) {
      position: absolute;
      top: 0;
      left: 100vw; }
    .gallery-slider-inner .slide:nth-child(3) {
      position: absolute;
      top: 0;
      left: 200vw; }
    .gallery-slider-inner .slide:nth-child(4) {
      position: absolute;
      top: 0;
      left: 300vw; }
    .gallery-slider-inner .slide:nth-child(5) {
      position: absolute;
      top: 0;
      left: 400vw; }
    .gallery-slider-inner .slide:nth-child(6) {
      position: absolute;
      top: 0;
      left: 500vw; }
    .gallery-slider-inner .slide:nth-child(7) {
      position: absolute;
      top: 0;
      left: 600vw; }
  .gallery-slider-close {
    position: absolute;
    top: 0;
    left: 0;
    width: 100px;
    height: 100px;
    background: yellow;
    z-index: 2003; }
  .gallery-slider .slide {
    position: absolute;
    width: 100vw;
    height: 100%;
    background: #000;
    z-index: 2002;
    display: flex;
    align-items: center;
    justify-content: center; }
    .gallery-slider .slide-inner {
      position: relative;
      display: flex;
      flex-direction: column-reverse;
      align-items: center;
      justify-content: center;
      width: 100%; }
      .gallery-slider .slide-inner .photo {
        width: 100%;
        /*background: url("../../../about/images/gallery/gallery_p2.jpg") no-repeat center center;
        background-size: cover;*/
        /*img {
        	display: none;
        	opacity: 0;
        }*/ }
      .gallery-slider .slide-inner .catch {
        width: 100%;
        background: #de0740;
        display: flex;
        align-items: center;
        /*background: url("../../../about/images/gallery/gallery_t1.png") no-repeat center center;
        background-size: cover;*/
        /*img {
        	display: none;
        	opacity: 0;
        }*/ }
    .gallery-slider .slide-next {
      position: absolute;
      top: 50%;
      right: 0;
      margin-top: -60px;
      width: 120px;
      height: 70px;
      text-indent: -9999px;
      background: url("../../../about/images/gallery/slider_arrow.png") no-repeat left top;
      background-size: 120px auto;
      transition: transform 0.2s; }
      .gallery-slider .slide-next:hover {
        cursor: pointer;
        transform: translateX(10px); }
    .gallery-slider .slide-close {
      position: absolute;
      top: 0;
      left: 0;
      width: 60px;
      height: 60px;
      text-indent: -9999px;
      background: url("../../../about/images/gallery/slider_close.png") no-repeat left top;
      background-size: 60px 60px;
      transition: transform 0.2s; }
      .gallery-slider .slide-close:hover {
        cursor: pointer;
        transform: rotateZ(90deg); }
.gallery-controla {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background: #222222;
  height: 45px;
  z-index: 1020; }
  .gallery-controla ul {
    display: flex;
    width: 210px;
    height: 45px;
    align-items: center;
    margin: 0 auto; }
    .gallery-controla ul li {
      position: relative;
      width: 30px;
      height: 45px;
      text-indent: -9999px; }
      .gallery-controla ul li::after {
        content: '';
        display: block;
        width: 7px;
        height: 7px;
        background: #e10741;
        border-radius: 7px;
        position: absolute;
        top: 50%;
        left: 50%;
        margin: -3px 0 0 -3px; }
      .gallery-controla ul li.current::after {
        background: #FFF; }

.btn.current .btn-inner::after {
  -webkit-animation-name: fadeOutGlow;
  animation-name: fadeOutGlow;
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
  -webkit-animation-delay: 0s;
  animation-delay: 0s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both; }

/*.btn.current {
  -webkit-animation-name: fadeCurrent;
  animation-name: fadeCurrent;
  -webkit-animation-duration: 0.4s;
  animation-duration: 0.4s;
	-webkit-animation-delay: 0s;
  animation-delay: 0s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}*/
@-webkit-keyframes fadeIn {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }
@keyframes fadeIn {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }
@-webkit-keyframes fadeOut {
  from {
    opacity: 1; }
  to {
    opacity: 0; } }
@keyframes fadeOut {
  from {
    opacity: 1; }
  to {
    opacity: 0; } }
@-webkit-keyframes fadeOutGlow {
  from {
    box-shadow: 0 0 20px 5px rgba(255, 255, 255, 0.5);
    opacity: 1; }
  to {
    box-shadow: none;
    opacity: 0; } }
@keyframes fadeOutGlow {
  from {
    box-shadow: 0 0 20px 5px rgba(255, 255, 255, 0.5);
    opacity: 1; }
  to {
    box-shadow: none;
    opacity: 0; } }
@-webkit-keyframes fadeCurrent {
  from {
    transform: scale(1);
    box-shadow: none; }
  to {
    transform: scale(1.08);
    box-shadow: 0 0 10px 5px rgba(255, 255, 255, 0.5); } }
@keyframes fadeCurrent {
  from {
    transform: scale(1);
    box-shadow: none; }
  to {
    transform: scale(1.08);
    box-shadow: 0 0 10px 5px rgba(255, 255, 255, 0.5); } }