@media screen and (min-width:641px) {
  .onlySP {
      display: none !important;
  }
}
@media screen and (max-width:640px) {
  .onlyPC {
      display: none !important;
  }
}



*:focus {
outline: none;
}
.loading {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 99999;
  background: url("../../images/common/bg-loding.jpg") top left no-repeat;
  background-size: cover;
}
.loading .loadingText {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 324px;
  height:46px;
}

.loaderText {
  width: 380px;
  height:113px;
  position: absolute;
  margin: auto;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}

.loaderText.anime {
  animation: flash 2.0s linear infinite;
}


@keyframes blink{
    0% {opacity:0.4;}
    100% {opacity:1;}
}

.blinking{
    animation:blink 1.2s ease-in-out infinite alternate;
}
@-webkit-keyframes load8 {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@keyframes load8 {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}


@keyframes flash {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
}

@keyframes zoomout {
  0% {
    opacity: 1;
    transform: scale(1, 1);
  }
  100% {
    opacity: 0;
    transform: scale(50, 1) rotate(60deg);
  }
}

@keyframes jumpout {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    margin-top: -400px;
    transform: scale(4);
  }
}

@keyframes katakata {
  0% {
    transform: scale(1, 1);
  }
  25% {
    transform: scale(1.1, 1) rotate(10deg);
  }
  50% {
    transform: scale(1, 1) rotate(0deg);
  }
  75% {
    transform: scale(1.1, 1) rotate(-10deg);
  }
  100% {
    transform: scale(1, 1) rotate(0deg);
  }
}


body {
  line-height: 1;
  background-color: #000000;
  color: black;
  margin: 0;
  padding: 0;
}

#wrapper {
  position: relative;
}

#contents {
  width: 100%;
  overflow: hidden;
  background-color: #000000;
  color: black;
  margin: 0;
  padding: 0;
}

#contents_inner {
  width: 1000px;
  margin: 0 auto;
  padding: 0;
  min-width: 1000px;
  background-color: transparent;
  position: relative;
  
}

.container {
  position: relative;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 11;
  
}

.container .nondisp {
  position: absolute;
  top: 3000px;
}


.cmenu {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 155px;
  padding: 0;
  margin: 0;
  background-color: black;
  background: url("../../images/common/bg_menu.png") center top ;
  background-repeat: repeat-x;
  z-index: 90;
}

@media screen and (max-width:640px) {
  .cmenu {
  display: none;
  }
}


.cmenu .inner {
  width: 1000px;
  margin: auto auto;
  text-align: center;
  padding-top: 12px;
  height: 192px;
  position: relative;
}

.cmenu .inner .menu-wrap {
  display: flex;
  text-align: center;
  margin-bottom: 0;
  justify-content: space-between;
  width: 600px;
  margin-left: 150px;
  margin-right: auto;
  position: relative;
  margin-top: 0;
  padding-top: 10px;
}

.cmenu .inner .menu-wrap .item a {
  display: block;
  text-align: center;
 transition : all 300ms;
}

.cmenu .inner .menu-wrap .item.booklet a {
  margin-top: -5px;
}


.cmenu .inner .menu-wrap .item a:hover {
  opacity: 0.7;
}

.cmenu .inner .menu-wrap .item a:hover {
  opacity: 0.7;
}


.cmenu .inner .copyright {
  text-align: center;
  width: 240px;
  height: 45px;
  position: absolute;
  top:102px;
  left:0;
}
.cmenu .inner .copyright img{
  width: 100%;
}

.cmenu .inner .atention2 {
	position: absolute;
	top:139px;
	left: 440px;
	width: 649px;
	height: 14px;
	z-index: 10000;
}



.cmenu .inner .search {
	position: absolute;
	top:78px;
	left: 420px;
	width: 369px;
	height: 55px;
  background: url("../../images/common/bg_search.png") no-repeat;
}


.cmenu .inner .search .select {
	width: 100px;
	height: 28px;
	font-size: 12px;
	background-color: black;
	color: white;
	border: 0;
    outline: 1px solid #ccc;
    outline-offset: -1px;
	position: absolute;
	top:14px;
	left: 180px;
	cursor: pointer;
    }


.cmenu .inner .search #search_button {
	width: 60px;
	height: 28px;
	font-size: 12px;
	background-color: black;
	border: 1px solid white;
	color: white;
	bottom: 10px;
	position: absolute;
	top:14px;
	left: 290px;
	cursor: pointer;
	}



  .cmenu .inner .dl-btn {
    position: absolute;
	top:78px;
	right: 0;
	width: 194px;
	height:  56px;
  }
  
  .cmenu .inner .dl-btn img{
    width: 100%;
  }
  
.cmenu .inner .dl-btn a:hover {
	opacity: 0.7;
	transition : all 300ms;
}

.cmenu .inner .booklet-btn {
	position: absolute;
	top:15px;
	right: 0;
	width: 239px;
	height:  57px;
}

.cmenu .inner .booklet-btn img{
  width: 100%;
}

.cmenu .inner .booklet-btn a:hover {
	opacity: 0.7;
	transition : all 300ms;
}


.cmenu .inner .atention {
	position: absolute;
	top:135px;
	right: 0;
	width: 649px;
	height: 14px;
}


.cmenu .inner .snsbox {
  position: absolute;
  top: 85px;
  left: 250px;
  width: 150px;
  height: 30px;
  transition: all ease 300ms 0s;
}


.cmenu .inner .snsbox a{
cursor: pointer!important;
opacity: 1;
  transition: all ease 300ms 0s;
}

#snsArea a{
cursor: pointer!important;
}

.cmenu .inner .snsbox a:hover{
opacity: 0.8;
}

@media screen and (min-width:641px) {
  .bottom-menu{
  display: none!important;
  }
}


@media screen and (max-width:640px) {  
  
  body {
    line-height: 1;
    background-color:#233080;
    color: white;
    margin: 0;
    padding: 0;
  }
  
  #wrapper {
    position: relative;
  }
  
  #contents {
    width: 100%;
    overflow: hidden;
    background-color: #233080;
    color: white;
  }
  
  #contents_inner {
    width: 640px;
    margin: 0 auto;
    padding: 0;
    min-width: 640px;
    position: relative;
  }
  
  .container {
    position: relative;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 11;
  }
  
  .container .nondisp {
    position: absolute;
    top: 10000px;
  }
  
    
  .bottom-menu {
    position: absolute;
    width: 640px;
    height: 1500px;

    background: url("../../images/common/bg_menu-sp.png") center top no-repeat;
    padding-top: 10px;
    background-color: #233080;
background-image: url(../../images/common/bg_menu-sp.png);
background-repeat: no-repeat;
padding-bottom: 50px;
    
  }
  
  .bottom-menu .menu-items{
    width: 100%;
    display: inherit;
    text-align: center;
  }
  
  .bottom-menu .menu-items .item.top {
    width: 204px;
    height: 93px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 50px;
    margin-top: 80px;
  }
  
  .bottom-menu .menu-items .item.feature {
    width: 176px;
    height: 101px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 46px;
  }
  
  .bottom-menu .menu-items .item.flow {
    width: 388px;
    height: 97px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 46px;
  }
  
  .bottom-menu .menu-items .item.spec {
    width: 431px;
    height: 101px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 46px;
  }

      .bottom-menu .menu-items .item.booklet {
    width: 558px;
    height: 141px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 46px;
  }

  
  a img {
    width: 100%;
  }
  
  .bottom-menu .atention {
    width: 461px;
    height: 54px;
    margin-top: 7vw;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 5vw;
  }
  
  
  .bottom-menu .copyright {
    width: 576px;
    height: 130px;
    margin-top: 5vw;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 5vw;
    padding-bottom: 5vw;
  }
  
  .menubtn {
    position: fixed;
    top: 18px;
    left: 534px;
    width: 84px;
    height: 77px;
    background-image: url(../../images/common/menubtn.png);
    transform: rotate(0deg);
    transition: all ease 600ms;
    z-index: 10000;
  }
  
  .menubtn.doShow {
    transform: rotate(90deg);
  }
  
  .headermenu {
    position: fixed;
    top: 0;
    left: 650px;
    width: 100%;
    height: 10000px;
    background: url("../../images/common/bg_menu-sp.png") center top no-repeat;
    background-color: rgba(0, 0, 0, 0.7);
    transition: all ease 600ms;
    z-index: 1000;
    background-position: 0 100px;
    padding-top: 160px;
   
  }
  
  .headermenu.doShow {
    left: 0;
  }
  
  .headermenu .menu-items .item-2col,
  .headermenu .menu-items .item-2col-2 {
  
    width: 100%;
    display: flex;
  }
  
  .headermenu .menu-items .item-2col .item {
    width: 320px;
    height: 40px;
    display: block;
    text-align: center;
    margin-bottom: 4px;
  }
  
  .headermenu .menu-items .item-2col .item.top {
    width: 135px;
    height: 79px;
    margin-left: auto;
    margin-right: auto;
  }
  
  .headermenu .menu-items .item.top {
    width: 193px;
    height: 92px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 56px;
  }
  
  .headermenu .menu-items .item.feature {
    width: 176px;
    height: 101px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 56px;
  }
  
  .headermenu .menu-items .item.flow {
    width: 388px;
    height: 97px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 56px;
  }
  
  .headermenu .menu-items .item.spec {
    width: 431px;
    height: 101px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 46px;
  }
  
  .headermenu .menu-items .item.booklet {
    width: 558px;
    height: 153px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 56px;
  }
  
  
  .search {
    width: 600px;
    height:  198px;
    background-image: url(../../images/common/bg_search-sp.png);
    margin-bottom: 20px;
    margin-top: 120px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
  }
  
  .search .select {
    width: 260px;
    height: 60px;
    font-size: 2rem;
    background-color: black;
    background-image: url(../../images/common/bg_select.jpg);
    background-size: cover;
    color: white;
    border: 0;
      outline: 1px solid #ccc;
      outline-offset: -1px;
      padding-left: 10px;
      position: absolute;
      top:110px;
      left: 75px;
      }
  
  #search_button {
    width: 140px;
    height: 60px;
    font-size: 2rem;
    background-color: black;
    border: 1px solid white;
    color: white;
    bottom: 10px;
      position: absolute;
      top:110px;
      left: 370px;
    }
  
  select {
  -webkit-appearance: none;/* ベンダープレフィックス(Google Chrome、Safari用) */
  -moz-appearance: none; /* ベンダープレフィックス(Firefox用) */
  appearance: none; /* 標準のスタイルを無効にする */
  }
  ::-ms-expand { /* select要素のデザインを無効にする（IE用） */
  display: none;
  }
  
  .snsbox{
    width: 100%;
    text-align: center;
  }
  
  .bottom-menu .snsbox a {
    display: inline-block;
    width: 100px;
    height: 100px;
    margin-left: 40px;
  }
  
  .bottom-menu a:first-child {
    margin-left: 0;
  }
  
  
  .bottom-menu .snsbox a img{
    width: 100%;
  }
    
}
