@charset "UTF-8";

body {
  margin: 0 auto;
  font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color:#3c3a39;
	font-size: 16px;
	-webkit-print-color-adjust: exact;
}

body img {
	max-width: 100%;
	user-select: none;
}

a, a div {
	transition: opacity .3s;
	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
}
a{
	text-decoration:underline;
	color:#0077cc;
}
a:hover, a div:hover { opacity: 0.7; }
.link_txt:hover { opacity: 1; text-decoration: none; }

.floatL>*{
	float: left;
}
.clearfix::after {
  content: "";
  display: block;
  clear: both;
}

.pc_size{display: block;}
.sp_size{display: none;}
.fs-s{font-size: .8em;}
.align-c{text-align: center;}
.margin-c{
  margin-right: auto;
  margin-left: auto;
}
.lh-l{line-height: 1.8em;}

.list_disc{
  margin-left: 1.5em;
}
.list_disc li{
  list-style-type: disc;
}
.list_free{
  display: flex;
}
.list_free_mark{
  margin-right: .5em;
}

.note-txt{
  color: #666666;
  margin-top: 15px;
}
.emp_txt{
  background: #ffff03;
  font-weight: bold;
}

h1{
	color:#E83828;
	font-weight: bold;
	text-align: center;
	font-size:28px;
	padding:60px 0 0;
}

.btn-pagetop { cursor: pointer; position: fixed; z-index: 1000; right: 15px; bottom: 3%; display: none; }
.btn-pagetop img { width: 60px; }


/* header */
header{
	width:100%;
}
.header-bar { 
	max-width: 1200px;
  width: 100%;
}
.header-bar a{
  display: inline-block;
}
.header-bar img {
  width: 300px;
  padding: 10px 15px;
	display: block;
	box-sizing: border-box;
}

/* container */
.container{
	width:100%;
	margin:0 auto;
}
.wrapper{
  width: 92%;
	max-width: 1000px;
	margin: 0 auto;
}
#top_img .close-back{
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#B3000000,endColorstr=#B3000000); 
	background: rgba(0,0,0,0.7);
}


#top_img .close-back img{
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	margin: auto;
	width: 700px;
	max-width:80%;
}

.wrapper_M{
	max-width: 680px;
  margin-right: auto;
  margin-left: auto;
}
.content-item_L{
  margin-top: 70px;
}
.content-item_M{
  margin-top: 50px;
}
.content-item_S{
  margin-top: 20px;
}
.content-item_SS{
  margin-top: 10px;
}

/* top */
#top_img{
	width:100%;
	margin:0 auto;
	display: block;
  background: #22b8d5;
}
#top_img .top_pc{
	background: url("../images/top_pc.png") bottom center no-repeat;
	background-size:100%;
  padding-top: 520px;
  max-width: 1076px;
	margin:0 auto;
}
@media screen and (max-width:1076px){
	#top_img .top_pc{
		padding-top: 51.41%;
	}
}
.top-wrapper{
	position: relative;
}
.period{
  width: 100%;
  background: #333333;
  padding: 20px 0;
}
.period .wrapper{
  width: 100%;
  max-width: 1000px;
}


/***** ボタン *****/
.btn-area02 {
  max-width: 740px;
  margin-left: auto;
  margin-right: auto;
}
.btn-area02 .btn_ttl{
  text-align: center;
  font-size: 30px;
  font-weight: bold;
  margin-bottom: 10px;
}
.btn-area02 ul.btn li{
  display: inline-block;
  margin: 0px 1.5% 80px;
  width: 46.2%;
}

/***** campaign *****/
.campaign{
  background: #fff8e1;
  padding-top: 80px;
  padding-bottom: 80px;/*クローズ時追加*/
}
.campaign .wrapper{
  max-width: 836px;
}
.campaign_box {
  background: #FFF;
  position: relative;
}
.campaign_box::before, .campaign_box::after {
  content: "";
  display: inline-block;
  position: absolute;
  width: 43px;
  height: 38px;
}
.campaign_box::before{
  background: url("../images/rule_deco_top.png") center center no-repeat;
  background-size: cover;
  top: -6px;
  left: -6px;
}
.campaign_box::after{
  background: url("../images/rule_deco_bottom.png") center center no-repeat;
  background-size: cover;
  bottom: -6px;
  right: -6px;
}
.campaign_box_inner{
  padding: 22px;
}
.campaign_product{
  padding-top: 20px;
  margin-top: 20px;
  border-top: 1px dashed #cbcbcb;
}

/***** ポイント *****/
.point{
  padding: 80px 0;
}
.point .wrapper{
  max-width: 836px;
}


/* hoken */
.hoken{
	width:100%;
	background:#ffd5c3;
}
.hoken .tit2{
	display: block;
	margin:0 auto;
	position: relative;
	top: -3px;
}
.hoken_point{
  max-width: 836px;
  margin-left: auto;
  margin-right: auto;
}
.hoken p{
	text-align: center;
	font-size:20px;
	color:#000;
	margin: 60px 0 0 ;
}
.hoken .sub-p{
	font-size: .9em;
	margin-top: 20px;
}
.hoken p.lh{
	margin: 60px 0 0;
}
.hoken p.lh span{
	font-weight: bold;
	border-bottom: solid #FFFFFF 5px;
	padding-bottom: 2px;
  font-size: 1.2em;
}
ul.hoken_banner {
	text-align: center;
	letter-spacing: -0.4em;
}

ul.hoken_banner li{
	display: inline-block;
	width:42%;
	letter-spacing: normal;
	margin: 40px 0 0 0;
}
ul.hoken_banner li:first-child{
	margin: 40px 5% 0 0;
}

/*ul.btn {
	text-align: center;
	letter-spacing: -0.4em;
}
ul.btn li{
	display: inline-block;
	width:35%;
	letter-spacing: normal;
	margin: 40px 0 80px 0;
}

ul.btn li:first-child{
	margin: 60px 5% 80px 0;
}*/

/***** RULR *****/
.relative{
	position: relative;
	top:0;
	left:0;
}
.rule{
	width:100%;
	margin:80px auto 0;
	background:#fff !important;
}
.rule .text_box{
	border:#E83828 solid 3px;
	border-radius: 10px;
	padding:40px ;
	box-sizing: border-box;
	margin:0 0 80px;
}
.text_box .p_ttl{
  font-weight: bold;
  margin-top: 15px;
}
.rule .title{
	color:#E83828;
	font-weight: bold;
	font-size: 2.3em;
	padding:10px;
	box-sizing: border-box;
	top: -100%;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 200px;
  height: 70px;
	position: absolute;
	background: #fff;
	text-align: center
}
.rule span{
	color: #E83828;
}

/* footer */
footer div{
	width:100%;
	background:#2d2d2d;
}

footer div.copy{
	text-align: center;
	box-sizing: border-box;
	padding:8px 0;
	font-size: 16px;
  color: #FFF;
}

.boban{
	text-align: right;
	font-size:10px;
	margin:0 10px 10px 0;
}
