@charset "utf-8";

/* #cont1 .cont */
#cont1 .cont{
  text-align:left;
}
#cont1 .cont h2{
  font-size:28px;
  letter-spacing:0.3em;
}

#cont1 .tbl{
  width:100%;
  border-top:1px solid #ccc;
}
#cont1  .tbl tr{
  border-bottom:1px solid #ccc;
}
#cont1 .tbl th,
#cont1 .tbl td{
  padding:1.8em 0.5em;
  vertical-align:top;
  letter-spacing:0.05em;
}
#cont1 .tbl th{
  width:6em;
  font-weight:normal;
}

@media screen and (max-width:768px){
  #cont1 .cont h2{
    font-size:4.8vw;
  }
  
  #cont1 .tbl th,
  #cont1 .tbl td{
    padding:1.5em 0.3em;
    font-size:3vw;
  }
  #cont1 .tbl th{
    width:5em;
  }
}



/* #cont1_1 */
#cont1_1{
}
#cont1_1 .cont_wrapper{
  margin-top:1em;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
#cont1_1 .cont_wrapper .tbl{
  width:48%;
}
#cont1_1 .cont_wrapper .tbl td{
  height:3em;
}
#cont1_1 .cont_wrapper .tbl td.free{
  height:auto;
}
#cont1_1 .cont_wrapper .tbl td .link{
  text-decoration:underline;
}

@media screen and (max-width:768px){
  #cont1_1 .cont_wrapper{
    margin-top:0.5em;
    display: block;
  }
  #cont1_1 .cont_wrapper .tbl{
    width:100%;
  }
  #cont1_1 .cont_wrapper .tbl:last-child{
    border-top:none;
  }
  #cont1_1 .cont_wrapper .tbl td{
    height:auto;
  }
}


/* #cont1_2 */
#cont1_2{
}
#cont1_2 .tbl{
  margin-top:1em;
}
#cont1_2 .tbl th,
#cont1_2 .tbl td{
  padding:1.2em 0.5em;
}
#cont1_2 .btn_wrapper{
  margin-top:50px;
  position:relative;
}
#cont1_2 .btn_wrapper .blue_btn{
  position:absolute;
  right:0;
  transform:translateX(30%);
}

@media screen and (max-width:1024px){
  #cont1_2 .btn_wrapper .blue_btn{
    transform:none;
  }
}

@media screen and (max-width:768px){
  #cont1_2 .tbl th,
  #cont1_2 .tbl td{
    padding:1em 0.3em;
  }
  #cont1_2 .btn_wrapper .blue_btn{
    position:static;
    right:auto;
    margin:auto;
  }
}


/* #cont1_3 */
#cont1_3{
}
#cont1_3 .update{
  display:block;
  transform:translateY(-100%);
}
#cont1_3 .map area{
  border:none;
  outline:none;
  cursor:pointer;
}


/* #overlay */
html.overlay{
	overflow:hidden;
	height:100%;
}
#overlay{
	position:fixed;
	width:100%;
	height:100vh;
	top:0;
	left:0;
	z-index:102;
	background-color:rgba(0,0,0,0.5);
	display:none;
}
#overlay .cont_wrapper{
  width:100%;
  height:100%;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
}
#overlay .cont_wrapper .bg_white{
  max-width:820px;
  width:90%;
  padding:30px;
  position:relative;
}
#overlay .cont_wrapper .bg_white .close{
  width:1.5em;
  line-height:1.5;
  font-size:24px;
  text-align:center;
  position:absolute;
  right:10px;
  top:10px;
  cursor:pointer;
}
#overlay .cont_wrapper .bg_white .shop_wrapper > li{
  display:none;
}
#overlay .cont_wrapper .bg_white .shop_wrapper > li .flex{
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
#overlay .cont_wrapper .bg_white .shop_wrapper > li .flex figure{
  width:48%;
}
#overlay .cont_wrapper .bg_white .shop_wrapper > li .flex .info{
  width:49%;
  text-align:left;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-flex-direction: column;
  flex-direction: column;
}
#overlay .cont_wrapper .bg_white .shop_wrapper > li .flex .info dl dt{
  line-height:1.6;
  margin-bottom:0.3em;
  font-size:22px;
  font-weight:bold;
}
#overlay .cont_wrapper .bg_white .shop_wrapper > li .flex .info ul li{
  line-height:1.5;
}

@media screen and (max-width:768px){
  #overlay{
  }
  #overlay .cont_wrapper .bg_white{
    max-width:300px;
    padding:30px 20px 20px;
  }
  #overlay .cont_wrapper .bg_white .close{
    font-size:21px;
    right:3px;
    top:3px;
  }
  #overlay .cont_wrapper .bg_white .shop_wrapper > li .flex{
    display: block;
  }
  #overlay .cont_wrapper .bg_white .shop_wrapper > li .flex figure{
    width:auto;
  }
  #overlay .cont_wrapper .bg_white .shop_wrapper > li .flex .info{
    width:auto;
    display: block;
    margin-top:0.5em;
    font-size:14px;
  }
  #overlay .cont_wrapper .bg_white .shop_wrapper > li .flex .info dl dt{
    font-size:18px;
  }
  #overlay .cont_wrapper .bg_white .shop_wrapper > li .flex .info ul{
    margin-top:2em;
  }
}
