@charset "utf-8";

/* 基本設定 */
html{
	font-size: 62.5%;
}
*, *::before, *::after{
  box-sizing: border-box;
}
body{
  color: #08287F;
	background: #628fb7 url("../img/bg_img.jpg") no-repeat top center;
  background-size: 100% auto;
	line-height: 1.8;
  font-size: 1.9vw;
	font-family: 'Noto Sans CJK JP', 'Noto Sans JP', "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	-webkit-font-smoothing: antialiased; /* Fix for webkit rendering */
  -moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%; /* 文字サイズの自動調整機能のキャンセル */
}
_:lang(x)::-ms-backdrop, body { font-family: "メイリオ", Meiryo, sans-serif; } 

img{
	border: 0;
	vertical-align: top;
}
input ,select{
	position: relative;
	top: 1px;
}
table, th, td{
	border-collapse: collapse;
	border-spacing: 0;
}
ul, li{
	list-style:none;
}
a:link, a:visited{
	color: #08287F;
	text-decoration: none;
	transition: opacity 0.5s;
}
a:hover, a:active{
  opacity: .6;
}
.clearfix::after{
  content: "";
  display: block;
  clear: both;
}
#cover{
  width: 100%;
  height: 100%;
  position: fixed;
  background: #fff;
  top: 0px;
  left: 0px;
  z-index: 10000;
}
#loader{
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 300px;
  height: 250px;
}
#loader img{
  width: 100%;
  height: auto;
}
#wrapper{
	overflow: hidden;
  position: relative;
}
#wrapper .bgBeer{
  position: absolute;
  z-index: 1;
  margin: 50vw auto 0;
  left: 0;
  right: 0;
  width: 58%;
  height: auto;
}
.dd414{
  display: none;
}
.feedin1-no{
  opacity: 0;
	transform: translateY(30px); 
	transition: opacity 1s ease-in 0.1s, transform 1s ease-out 0.1s;
}
.feedin1{
  opacity: 1;
	transform: translateY(0); 
}
@media screen and (max-width: 414px){
  body{
    font-size: 3.8vw;
  }
  #wrapper .bgBeer{
    margin: 73vw auto 0;
    width: 74%;
  }
  #loader{
  width: 150px;
  height: 125px;
  }
  .nn414{ display: none !important; }
  .dd414{ display: block !important; }
}

/* コンテンツ */
main{
	overflow: hidden;
  position: relative;
  z-index: 5;
}
section{
	overflow: hidden;
  position: relative;
  padding: 2vw 0;
  text-align: center;
}
@media screen and (max-width: 414px){
  section{
    padding: 4vw 0;
  }
}

#topPage .open{
  font-size: 220%;
  color: #f00;
  font-weight: 700;
  margin-bottom: 5.4vw;
}
#topPage .open small{
  font-size: 70%;
}
#topPage h1{
  display: block;
  margin: 0 auto 5vw;
  width: 56%;
  height: auto;
}
#topPage h1 img{
  width: 100%;
  height: auto;
}
@media screen and (max-width: 414px){
  #topPage .open{
    font-size: 160%;
    margin-bottom: 7.4vw;
  }
  #topPage h1{
    width: 82%;
  }
}

#bookPage{
  padding-bottom: 8vw;
}
#bookPage .txt1{
  font-size: 240%;
  color: #f00;
  font-weight: 700;
  margin-bottom: 4vw;
}
#bookPage .book{
  margin-bottom: 6vw;
}
#bookPage .book p{
  font-size: 130%;
  font-weight: 500;
  margin-bottom: 1vw;
}
#bookPage .book a{
  display: block;
  border: 2px solid #08287F;
  width: 40vw;
  line-height: 1.2;
  background: rgba(255,255,255,0.6);
  margin: 0 auto;
  padding: 0.8vw 0;
}
#bookPage .book:last-child a{
  line-height: 1.1;
  padding: 1vw 0 0.6vw;
}
#bookPage .book a strong{
  display: block;
  font-size: 180%;
  font-weight: 500;
}
#bookPage .book:last-child a strong{
  font-size: 200%;
}
#bookPage .book a small{
  display: block;
}
@media screen and (max-width: 414px){
  #bookPage{
    padding-bottom: 12vw;
  }
  #bookPage .txt1{
    font-size: 180%;
    font-weight: 600;
  }
  #bookPage .book{
    margin-bottom: 8vw;
  }
  #bookPage .book p{
    margin-bottom: 2vw;
  }
  #bookPage .book a{
    width: 65vw;
    padding: 1.2vw 0 1.5vw;
  }
  #bookPage .book:last-child a{
    padding: 1.7vw 0 1vw;
  }
}

#conceptPage figure{
  display: flex;
  position: relative;
  justify-content: center;
  align-items: center;
  width: 72%;
  margin: 0 auto 3vw;
  flex-direction: row-reverse;
}
#conceptPage figure:nth-child(3n){
  flex-direction: row;
}
#conceptPage figure figcaption{
  width: 56%;
  height: auto;
}
#conceptPage figure figcaption .copy{
  width: 100%;
  height: auto;
}
#conceptPage figure .photo{
  width: 44%;
  height: auto;
}
#conceptPage p{
  display: block;
  margin-bottom: 8vw;
}
#conceptPage p small{
  display: inline-block;
  line-height: 1.8;
  font-size: 70%;
}
@media screen and (max-width: 414px){
  #conceptPage figure{
    display: block;
    width: 90%;
  }
  #conceptPage figure figcaption{
    width: 74%;
    margin: 0 auto;
  }
  #conceptPage figure .photo{
    width: 100%;
  }
  #conceptPage p{
    width: 80%;
    margin: 0 auto 12vw;
  }
  #conceptPage p small{
    padding-top: 1vw;
  }
}

#infoPage{
  margin-bottom: 4vw;
}
#infoPage h4{
  font-size: 130%;
  font-weight: 500;
  margin-bottom: 3vw;
}
#infoPage ul{
  position: relative;
  width: 70%;
  margin: auto;
}
#infoPage ul li{
  position: relative;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 5vw;
}
#infoPage ul li img{
  width: 12vw;
  height: auto;
}
#infoPage ul li p{
  flex-grow: 2;
  background: rgba(255,255,255,0.5);
  text-align: left;
  font-size: 90%;
  padding: 1vw;
  line-height: 1.4;
}
#infoPage ul li p small{
  font-size: 70%;
}
@media screen and (max-width: 414px){
  #infoPage{
    margin-bottom: 8vw;
  }
  #infoPage h4{
    margin-bottom: 6vw;
  }
  #infoPage ul{
    width: 88%;
  }
  #infoPage ul li{
    display: block;
    position: relative;
    margin-bottom: 8vw;
  }
  #infoPage ul li img{
    width: 32vw;
    float: left;
    margin-right: 5vw;
  }
  #infoPage ul li p{
    padding: 4vw 3vw 4vw 5vw;
    font-size: 100%;
    line-height: 1.7;
  }
  #infoPage ul li p span{
    display: inline;
  }
}

#sysPage{
  margin-bottom: 4vw;
}
#sysPage h4{
  font-size: 130%;
  font-weight: 500;
  margin-bottom: 3vw;
}
#sysPage .system{
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
#sysPage .system b{
  font-size: 200%;
  font-weight: 500;
  color: #f00;
  text-shadow:
    #fff 2px 0px 2px, #fff -2px 0px 2px,
    #fff 0px -2px 2px, #fff -2px 0px 2px,
    #fff 2px 2px 2px, #fff -2px 2px 2px,
    #fff 2px -2px 2px, #fff -2px -2px 2px,
    #fff 1px 2px 2px, #fff -1px 2px 2px,
    #fff 1px -2px 2px, #fff -1px -2px 2px,
    #fff 2px 1px 2px, #fff -2px 1px 2px,
    #fff 2px -1px 2px, #fff -2px -1px 2px,
    #fff 1px 1px 2px, #fff -1px 1px 2px,
    #fff 1px -1px 2px, #fff -1px -1px 2px;
}
#sysPage .system span{
  display: inline-block;
  font-weight: 600;
  letter-spacing: 0.1vw;
  color: #E00;
  border: 2px solid #f00;
  margin-left: 2vw;
  line-height: 1;
  padding: 0.4vw 1vw 0.3vw;
  background: rgba(255,255,255,0.8);
}
#sysPage table{
  margin: 0 auto 2vw;
}
#sysPage table th{
  padding-right: 2vw;
}
#sysPage table th span{
  display: block;
  border: 2px solid #FFF;
  background: #e00;
  color: #FFF;
  border-radius: 0.7vw;
  line-height: 1;
  padding: 0.4vw 1vw 0.3vw;
}
#sysPage table td{
  padding: 0.3vw 0.5vw;
  font-weight: 600;
  text-align: left;
  color: #f00;
  text-shadow:
    #fff 1px 1px 2px, #fff -1px 1px 2px,
    #fff 1px -1px 2px, #fff -1px -1px 2px,
    #fff 1px 1px 2px, #fff -1px 1px 2px,
    #fff 1px -1px 2px, #fff -1px -1px 2px,
    #fff 1px 1px 2px, #fff -1px 1px 2px,
    #fff 1px -1px 2px, #fff -1px -1px 2px,
    #fff 1px 1px 2px, #fff -1px 1px 2px,
    #fff 1px -1px 2px, #fff -1px -1px 2px;
}
#sysPage table td strong{
  position: relative;
  display: inline-block;
  top: 0.4vw;
  font-size: 200%;
  font-weight: 500;
  letter-spacing: 0.1vw;
  margin-right: 0.2vw;
}
#sysPage table td span{
  display: block;
  position: relative;
  font-size: 60%;
  float: right;
  line-height: 1.2;
  margin: auto;
  transform: translateY(75%);
  border: 2px solid #F00;
  margin-left: 1vw;
  background: rgba(255,255,255,0.8);
  padding: 0.1vw 1vw;
  border-radius: 0.5vw;
  text-align: center;
  color: #08287F;
  text-shadow: none;
}
#sysPage table td .red{
  position: relative;
  top: 0.2vw;
  display: block;
  text-align: center;
  font-size: 140%;
  color: #f00;
  text-shadow:
    #fff 1px 1px 2px, #fff -1px 1px 2px,
    #fff 1px -1px 2px, #fff -1px -1px 2px,
    #fff 1px 1px 2px, #fff -1px 1px 2px,
    #fff 1px -1px 2px, #fff -1px -1px 2px,
    #fff 1px 1px 2px, #fff -1px 1px 2px,
    #fff 1px -1px 2px, #fff -1px -1px 2px,
    #fff 1px 1px 2px, #fff -1px 1px 2px,
    #fff 1px -1px 2px, #fff -1px -1px 2px;
}
#sysPage p.small{
  font-size: 70%;
}
#sysPage .plan{
  width: 40%;
  height: auto;
  margin: 3vw auto;
}
#sysPage .plan img{
  width: 100%;
  height: auto;
}
@media screen and (max-width: 414px){
  #sysPage .system{
    display: block;
    margin-bottom: 2vw;
  }
  #sysPage .system b{
    display: block;
  }
  #sysPage .system span{
    color: #E00;
    letter-spacing: 0.2vw;
    margin-left: 0;
    padding: 0.8vw 3vw 0.7vw 3.2vw;
  }
  #sysPage table th{
    padding-right: 4vw;
  }
  #sysPage table th span{
    border-radius: 1vw;
    padding: 0.7vw 2vw 0.8vw;
  }
  #sysPage table td strong{
    top: 0.6vw;
    font-size: 230%;
    margin-right: 0.4vw;
  }
  #sysPage table td span{
    font-size: 70%;
    transform: translateY(75%);
    margin-left: 2vw;
    padding: 0.2vw 3vw;
    border-radius: 0.8vw;
  }
  #sysPage table td .red{
    top: 0.3vw;
    font-size: 160%;
  }
  #sysPage .plan{
    width: 70%;
    margin: 5vw auto;
  }
}

#shopPage{
  text-align: center;
}
#shopPage .inner{
  background: rgba(255,255,255,0.6);
  color: #333;
  display: inline-block;
  margin: 0 auto;
  max-width: 70%;
  padding: 3vw 4vw;
}
#shopPage h4{
  font-weight: 500;
  margin-bottom: 2vw;
  letter-spacing: 0.5vw;
}
#shopPage dl{
  font-size: 70%;
  text-align: left;
  display: flex;
  flex-wrap: wrap;
}
#shopPage dl dt{
  width: 15%;
  border-bottom: 1px dashed #eee;
  padding: 0.8vw;
}
#shopPage dl dt small{
  font-size: 80%;
}
#shopPage dl dd{
  width: 85%;
  border-bottom: 1px dashed #eee;
  padding: 0.8vw;
}
#shopPage dl dt:first-child,
#shopPage dl dd:nth-child(2){
  border-top: 1px dashed #eee;
}
#shopPage dl dd small{
  font-size: 80%;
}
#shopPage dl dd span.red{
  color: #f00;
}
#shopPage dl dt.dt1l{
  width: 100%;
  border-bottom: none;
  padding-bottom: 0;
}
#shopPage dl dd.dd1l{
  width: 100%;
  padding: 0.2vw 0.8vw 0.8vw 1.6vw;
}
@media screen and (max-width: 414px){
  #shopPage .inner{
    max-width: 88%;
    padding: 5vw 4vw;
  }
  #shopPage h4{
    margin-bottom: 3vw;
  }
  #shopPage dl{
  }
  #shopPage dl dt{
    width: 22%;
    border-bottom: 1px dashed #eee;
    padding: 1.6vw 0.8vw;
  }
  #shopPage dl dt small{
    display: block;
  }
  #shopPage dl dd{
    width: 78%;
    border-bottom: 1px dashed #eee;
    padding: 1.6vw 0.8vw;
  }
  #shopPage dl dd small{
    display: inline-block;
    line-height: 1.6;
  }
  #shopPage dl dt.dt1l{
    width: 100%;
    border-bottom: none;
    padding-bottom: 0;
  }
  #shopPage dl dd.dd1l{
    width: 100%;
    padding: 0.2vw 0.8vw 0.8vw 1.6vw;
  }
}

/* フッター */
#footer{
	overflow: hidden;
  position: relative;
  padding-bottom: 2vw;
}
#footer .cpr{
  text-align: center;
  font-size: 70%;
}

@media screen and (max-width: 414px){
  /* フッター */
  #footer{
    padding-bottom: 4vw;
  }
  #footer .cpr{
    font-size: 60%;
  }
}

#rinji{
  width: 80%;
  background: rgba(255,255,255,0.8);
  margin: 8vw auto 3vw;
  padding: 3vw 0;
}
#rinji .ttl{
  padding-top: 2vw;
  font-size: 100%;
}
#rinji .txt{
  font-size: 100%;
}
#rinji .txt small{
  font-size: 80%;
}
#rinji .txt span{
  letter-spacing: 0.4vw;
}
#rinji .txt b{
  display: block;
  font-weight: 500;
  padding: 2vw 0 0.5vw;
  font-size: 110%;
}
#rinji a{
  display: inline-block;
  background: #FFCC00;
  font-weight: 600;
  border-radius: 2vw;
  padding: 0.5vw 5vw;
  box-shadow: 1px 1px 1px 1px rgba(0,0,0,0.2);
  margin: 1vw 0 1vw 0;
}
#rinji a.beer{
  background: #00A0D1;
}
#rinji a:hover{
  box-shadow: none;
}
@media screen and (max-width: 414px){
  #rinji{
    padding: 6vw 0;
  }
  #rinji .ttl{
    padding: 3vw 0 2vw;
  }
  #rinji .txt b{
    line-height: 1.4;
    font-size: 120%;
    padding: 5vw 0 1.5vw;
  }
  #rinji a{
    border-radius: 4vw;
    padding: 3vw 8vw;
    margin: 2vw 0 2vw 0;
    line-height: 1.3;
  }
}