@charset "utf-8";

/*--------------------------*/

.cnt img{
    width: 100%;
    display: block;
    line-height: 0;
    font-size: 0;
}

#wrapper{
    padding-bottom: 0;
  position: relative;
}
  

@media screen and (min-width: 768px) {
#wrapper{
  background-color: black;
  background-image: url("../img/pc-bg.jpg");
  background-position: top center;
  background-repeat: no-repeat;
  background-size: 100%;
  position: relative;

}
}

#wrapper .sideL{
  display: none;

}




@media screen and (min-width: 1100px) {
#wrapper .sideL{
    display: block;
    width:  12%;
   position:fixed;
  left: 8%;
  top: 50%;
  transform: translateX(-50%) translateY(-50%);

}
}

@media screen and (min-width: 1420px) {
#wrapper .sideL{
    display: block;
    width: 18%;
   position:fixed;
  left: 14%;
  top: 50%;
  transform: translateX(-50%) translateY(-50%);

}
}



#wrapper .sideR{
  display: none;

}


@media screen and (min-width: 1100px) {
#wrapper .sideR{
    display: block;
      background-image: url("../img/bg-menu.png");
      background-size: cover;
    width: 11%;
    padding: 2%;
   position:fixed;
  right: 8%;
  top: 50%;
  transform: translateX(50%) translateY(-50%);

}
}

@media screen and (min-width: 1420px) {
#wrapper .sideR{
    display: block;
      background-image: url("../img/bg-menu.png");
      background-size: cover;
    width: 16%;
    padding: 2%;
   position:fixed;
  right: 12%;
  top: 50%;
  transform: translateX(50%) translateY(-50%);

}
}



@media screen and (min-width: 1100px) {
#wrapper .sideR ul li{
    width: 40%;
    margin-bottom: 10px;
    margin-left: auto;
    margin-right: auto;
}
}

@media screen and (min-width: 1420px) {
#wrapper .sideR ul li{
    width: 40%;
    margin-bottom: 30px;
    margin-left: auto;
    margin-right: auto;
}
}

#wrapper .sideR ul li:last-child{
    margin-bottom: 0;
}


#wrapper .sideR  img{
    width: 100%;
}


#wrapper .sideL img{
    width: 100%;
}

#wrapper .sideR ul li.com{
    opacity: 0.4;
}



.wrap{width: 100%;
    height: 100%;
    position: relative;
    background-image: url("../img/bg.webp");
    background-size: 100%;
    background-position: top center;
    background-size: cover;

}

@media screen and (min-width: 768px) {
 .wrap{
		width:750px;
    height: 100%;
		margin: auto;
		max-width: 750px;
}
}

.cnt{
	width: 100%;
	margin: 0;
	padding: 0;
	position: relative;
}

.cnt img{
    width: 100%;
    display: block;
    line-height: 0;
    font-size: 0;
}



.cnt .btn1{
	width: 77.34%;
	margin: auto;
	position: absolute;
	top:62%;
	left:  11.33%;
}

.cnt .btn2{
	width: 77.34%;
	margin: auto;
	position: absolute;
	top:24%;
	left:  11.33%;
}

.cnt .btn3{
	width: 77.34%;
	margin: auto;
	position: absolute;
	top:46%;
	left:  11.33%;
}

.cnt .btn4{
	width: 77.34%;
	margin: auto;
	position: absolute;
	top:68%;
	left: 11.33%;
}

.cnt .btn1 a,
.cnt .btn2 a,
.cnt .btn3 a,
.cnt .btn4 a{
    transition: all ease 300ms 0s;
}

.cnt .btn1 a:hover,
.cnt .btn2 a:hover,
.cnt .btn3 a:hover,
.cnt .btn4 a:hover {
    opacity: 0.8;
}

.cnt.acbox1{
	margin: 0;
    background-image: url("../img/cnt3.jpg");
    background-repeat: repeat-y;
    background-size: 100%;
    background-position: top center;
	width: 100%;
    padding-top: 30px;
}

.cnt.acbox1 .inner{
	width: 77.34%;
	margin-left: 11.33%;
}

.cnt.acbox1 .inner .acobox{
	padding-bottom: 15px;
}


.cnt.acbox1 .inner .frexbox{
    display: flex;
    flex-wrap: wrap;
    border-bottom: 1px solid #E8E8E8;
    padding-bottom: 30px;
    font-weight: bold;
    font-size: 3vw;
    line-height: 1.7;
    padding-top: 10px;
}

@media screen and (min-width: 768px) {
.cnt.acbox1 .inner .frexbox{
    display: flex;
    flex-wrap: wrap;
    border-bottom: 1px solid #E8E8E8;
    padding-bottom: 30px;
    font-size: 1.7em;
    line-height: 1.7;
    padding-top: 10px;
}
}



.cnt.acbox1 .inner .frexbox.bbnone{
    border-bottom: none;
}

.cnt.acbox1 .inner .frexbox .left{
    width: 20%;
}

.cnt.acbox1 .inner .frexbox .right{
    width:70%;
}

.cnt.acbox1 .inner .frexbox .right a{
    color: #574DC6;
    text-decoration: none;
    word-break: break-all;
}

.cnt.acbox1 .inner .frexbox .right a{
    text-decoration: underline
}



.backtotop a, .closewin a {
  background-color: transparent;
    width: 15vw;
    padding: 0;
}

@media screen and (min-width: 768px) {
.backtotop a, .closewin a {
  background-color: transparent;
    width: 80px;
    padding: 0;
}
}

.backtotop {
  z-index: 100;
    right: -4vw;
    bottom: 15vw;
}

@media screen and (min-width: 768px) {
.backtotop {
  z-index: 100;
    right: 20px;
    bottom: 20px;
    width: 80px;
}
}

.backtotop a img{
	width: 100%;
}

@media screen and (min-width: 768px) {
.headmenu {
  display: none;
}
}

@media screen and (max-width: 768px) {

.headmenu {
    display: block;
  height: 15vw;
  width: 15vw;
  position: fixed;
  top: 3vw;
  left:80vw;
}
}
/* ===============================================
ハンバーガーボタンのスタイリング
=============================================== */
input[type="checkbox"] {
  opacity: 0;
  visibility: hidden;
  position: absolute;
}
.hamburger {
  display: block;
  width: 15vw;
  height: 15vw;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
}
.hamburger span{
    width: 15vw;
    height: 15vw;
    background-image: url("../img/hmenu.png");
    background-size: cover;
  position: absolute;
  display: block;
  content: "";
  transition: all 0.5s;
}
input[type="checkbox"]:checked + .hamburger span {
  background-color: transparent;
}
input[type="checkbox"]:checked + .hamburger span {
  top: 0;
  transform: rotate(90deg);
}


/* ===============================================
メニューのスタイリング
=============================================== */
.nav {
  position: fixed;
  width: 100%;
  height: 100vh;
  top: 80px;
  right: -120%;
    background-image: url("../img/bg-menu.png");
    background-size: cover;
  padding: 50px 0;
  border-top: 1px solid #fff;
  transition: all 0.5s;
}
.nav__item  {
  display: block;
  transition: all 0.3s;
  margin: auto;
  text-align: center;
  width: 50%;
  margin-bottom: 30px;
}

.nav__item.com {
  opacity: 0.4;
}


.nav__item  img{width: 100%;}
input[type="checkbox"]:checked ~ .nav {
  right: 0;
}