@charset "utf-8";
/* CSS Document */

body{ 
	font-size: 1.6rem; 
	text-align: left; 
}




/************
   utility
*************/
#container{
	width: 100%;
}
#header{
	max-width: 1024px;
	margin: 0 auto;
}

#side .leftnavimenu_cool_warm a{ 
	background-image: url("/image/menu/Imenu_warm.png"); 
}
.none{
	display: none;
}
.CP_text{
	margin: 0;
	color: #1a1a1a;
	line-height: 1.5;
}

.CP_list{
	list-style: none;
	text-decoration: none;
	padding-inline-start: 0px;
}
.CP_link{
	text-decoration: none;
}
.CP_img{
	max-width: 100%;
}
.PC_only{
	display: block;
}
.tablet_only{
	display: none;
}
.SP_only{
	display: none;
}
h2,h3,h4{
	text-align: center;
	margin: 0 auto;
}
#side .leftnavimenu_cool_warm a{
	background-image: url(/image/menu/Imenu_cool.png);
}

@media screen and (max-width: 1200px) {
	h2{
		
	}
	.tablet_only{
		display: block;
	}
}
@media screen and (max-width: 1024px){
	#container{
		width: 1024px;
	}
}
@media screen and (max-width: 600px){
	#container{
		width: 100%;
	}
	.PC_only{
		display: none;
	}
	.tablet_only{
		display: none;
	}
	.SP_only{
		display: block;
	}
	#footer #copy small{
		padding: 1.4em 0 0.5em;
	}
	#footer #url{
		padding-bottom: 35px;
	}
	h2.campaign_heading{
		padding: 0 15px;
	}
}
/************
	bg
**************/
.bg_campaign{
	background-image: url("img/background_blue.png");
	background-size: cover;
	width: 100%;
	margin: 0 auto;
}
.bg_summer{
	background-image: url("img/background_cloud4(1920).png");
	background-size: contain;
	width: 100%;
	margin: 0 auto;
}
@media screen and (max-width: 1440px){
	.bg_summer{
		background-image: url("img/background_cloud(1440)2.png");
		background-size: cover;
	}
}
@media screen and (max-width: 1200px){
	.bg_summer{
		background-image: url("img/background_cloud(tablet).png");
		background-size: cover;
	}
}
@media screen and (max-width: 600px){
	.bg_campaign{
		background-image: url("img/background_blue(smart).png");
	}
	.bg_summer{
		background-image: url("img/background_cloud(SP).png");
		background-size: contain;
	}
}
/************
   header
*************/


/************
   about
*************/
.about_wrapper{
	margin: -10px auto 0;
	padding: 10px 0 40px;
	font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif; 
}
.box_wrapper{
	max-width: 1260px;
	margin: -50px auto 0;
}
.about_box{
	padding: 40px 0 30px;
	margin: 0 auto 80px;
	width: 100%;
	background: repeating-linear-gradient(45deg, #ffeb00, #ffeb00 5px, white 5px, white 10px);
	text-align: center;
	position: relative;
}
.about_box::before{
	content: "";
	position: absolute;
	background-color: #fff;
	width: calc(100% - 40px);
	height: calc(100% - 40px);
	top: 20px;
	left: 20px;
	z-index: 8;
}
.about_inner{
	content: "";
	z-index: 10;
	position: relative;
}
.about_text{
	display: block;
	font-family: ab-kirigirisu, sans-serif;
	font-weight: 400;
	font-style: normal;
	color: #48b4fe;
	font-size: 48px;
	letter-spacing: -0.1em;
	line-height: 1.3;
	z-index: 10;
	padding-bottom: 20px;
}
.about_text>span{
	font-size: 72px;
	color: #ffeb00;
	position: relative;
	-webkit-text-stroke: 1px #48b4fe;
	letter-spacing: -0.2em;
	z-index: 10;
	line-height: 1.5;
}
.about_text>.type{
	letter-spacing: -0.1em;
	padding-right: 10px;
}
.period_text{
	font-size: 24px;
	font-weight: 700;
	padding-bottom: 30px;
	
}
.caution_box{
	padding-bottom: 15px;
	width: 50%;
	margin: 0 auto;
	text-align: left;
}
.caution_text{
	display: block;
	padding-bottom: 15px;
	position: relative;
}
.caution_text:last-of-type{
	padding-bottom: 0;
}
.caution_text::before{
	content: "";
	display: block;
	position: absolute;
	background-color: #1a1a1a;
	color: #1a1a1a;
	left: -16px;
	width: 6px;
	height: 6px;
	top: 25%;
	border-radius: 100%;
	transform: translate(0,-50%);
}
.caution_text.caution_bottom::before{
	top: 20%;
}
.caution_text>span{
	font-weight: 700;
	text-decoration: underline;
}
.treat_wrap{
	margin: 0 auto;
	box-sizing: border-box;
	background: repeating-linear-gradient(45deg, #ffeb00, #ffeb00 5px, white 5px, white 10px);
	background-color: #ffeb00;
	max-width: 1260px;
	position: relative;
}
.treat_wrap::before{
	position: absolute;
	content: "";
	background-color: #ffeb00;
	width: calc(100% - 40px);
	height: calc(100% - 40px);
	top: 20px;
	left: 20px;
	z-index: 8;
}
.lineup{
	position: relative;
	z-index: 10;
	padding-top: 60px;
}
.treat_area{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
}

.treat_box{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	padding: 40px 0 40px 60px;
	box-sizing: border-box;
	align-items: center;
	width: 100%;
	position: relative;
	z-index: 10;
}
.treat_box.treat_last{
	justify-content: space-around;
	padding: 40px 0 40px 20px;
}
.treat_last .treat_img{
	width: 34%;
}
.treat_box.treat_first::before{
	content: "";
	position: absolute;
	right: 0;
	width: 2px;
	height: 300px;
	background-color: #fff;
	top: 50%;
	transform: translate(0, -50%);
}
h4{
	padding-bottom: 15px;
}
.treat_img{
	width: 35%;
	box-sizing: border-box;
	z-index: 15;
}
.treat_title{
	height: 40px;
	margin: 0 auto 0 0;
}
.treat_info{
	width: 65%;
	box-sizing: border-box;
	padding: 0 40px 0 20px;
}
.treat_info.info_right{
	width: calc(65% - 20px);
	padding: 0 40px 0 0px;
}
.info_box{
	padding-top: 40px;
}
.info_list{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	text-align: left;
	margin: 0;
	padding-bottom: 10px;
}
.info_list>dt{
	width: 100px;
	font-weight: 700;
	line-height: 1.5;
	font-size: 18px;
}
.info_list>dd{
	margin: 0;
	line-height: 1.5;
	transform: translate(0, 2px);
}


@media screen and (max-width: 1440px){
	.box_wrapper{
		max-width: 80%;
	}
	.treat_wrap{
		max-width: 80%;
	}
	.treat_box{
		padding: 40px 0px 60px 60px;
	}
	.treat_box.treat_last{
		padding: 40px 0px 60px 20px;
	}
	.treat_title{
		height: 36px;
	}
	.box_wrapper{
		margin: -20px auto 0;
	}
}
@media screen and (max-width: 1200px){
	.box_wrapper{
		max-width: 90%;
	}
	.lineup>img{
		height: 80px;
	}
	.treat_box{
		padding: 40px 0px 40px 50px;
	}
	.treat_box.treat_last{
		padding: 40px 0px 40px 20px;
	}
	.treat_last .treat_img{
		width: 39%;
	}
	.treat_wrap{
		max-width: 90%;
	}
	.treat_img{
		width: 40%;
	}
	.treat_info{
		width: 60%;
		padding: 0 30px 0 20px;
	}
	.treat_info.info_right{
		width: calc(60% - 20px);
		padding: 0 30px 0 0px
	}
	.treat_title{
		height: 32px;
	}
	.about_text{
		font-size: 40px;
		letter-spacing: -0.15em;
	}
	.about_text>span{
		font-size: 64px;
	}
	.about_inner{
		padding: 0 20px;;
	}
	.caution_box{
		width: 65%;
	}
	.caution_text::before{
		top: 28%;
	}
	.caution_text.caution_bottom::before{
		top: 23%;
	}
	.info_box{
		padding-top: 30px;
	}
	.info_list{
		display: block;
	}
	.info_list>dt{
		width: 90px;
		font-weight: 700;
	}
	.info_list>dd{
		margin: 0;
	}
}
@media screen and (max-width: 600px){
	h4{
		padding-bottom: 0;
	}
	.about_wrapper{
		padding: 80px 0 80px;
	}
	.box_wrapper{
		max-width: 100%;
		width: 100%;
		box-sizing: border-box;
		padding: 50px 20px 0;
		margin: 0 auto;
	}
	.about_box::before{
		top: 10px;
		left: 10px;
		width: calc(100% - 20px);
		height: calc(100% - 20px);
	}
	.about_inner{
		display: block;
		margin: 0 auto;
		width: calc(100% - 30px);
		padding: 0 10px;;
	}
	.about_text{
		font-size: 30px;
		line-height: 1.5;
	}
	.about_text>span{
		font-size: 54px;
		-webkit-text-stroke: 1px #48b4fe;
		line-height: 1;
	}
	.caution_box{
		width: 100%;
		padding: 0 10px 0 20px;
		box-sizing: border-box;
		font-size: 14px;
	}
	.caution_text::before{
		width: 4px;
		height: 4px;
		top: 18%;
		left: -10px;
	}
	.caution_text.caution_bottom::before{
		top: 15%;
		left: -10px;
	}
	.lineup{
		padding: 60px 30px 0;
	}
	.lineup>img{
		height: auto;
	}
	.treat_box{
		padding: 40px 20px 0px;
		display: block;
		text-align: center;
		margin: 0 auto;
	}
	.treat_box.treat_last{
		padding: 40px 20px;
	}
	.SP_treat{
		margin: 0 auto;
		padding-bottom: 20px;
	}
	.treat_img{
		width: 50%;
	}
	.treat_title{
		height: 36px;
		margin: 0 auto;
	}
	.treat_text{
		text-align: left;
	}
	.treat_area{
		display: block;
		max-width: 100%;
		width: 100%;
		box-sizing: border-box;
		padding: 0 20px;
	}
	.treat_box.treat_first::before{
		display: none;
	}
	.info_box{
		padding-top: 20px;
	}
	.treat_info{
		width: 100%;
		padding: 10px 0px 0;
	}
	.treat_info.info_right{
		width: 100%;
		padding: 0 0px;
	}
	.info_list{
		text-align: center;
	}
	.info_list>dt{
		width: 100%;	
	}
	.info_list>dd{
		margin: 0;
	}
}
/************
   pick up
*************/
.PickUp_wrapper{
	margin: 0 auto;
	padding: 0px 0 80px;
	font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif; 
}
.product_area{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	margin: -60px auto 0;
	width: 1200px;
	justify-content: space-between;
	box-sizing: border-box;
}
.product_link{
	display: block;
	width: 380px;
	box-sizing: border-box;
	text-align: center;
	margin: 0 auto 10px;
}
.product_list.link_first{
	
}
.product_link:hover{
	opacity: 0.7;
	transition: all 0.1s;
}
.product_img{
	height: 300px;
}
.product_info{
	width: 90%;
	display: block;
	text-align: center;
	border-radius: 20px;
	background-repeat: no-repeat;
	margin: 0 auto;
	background-position: center;
	padding: 0 20px;
	box-sizing: border-box;
	height: 140px;
	position: relative;
}
.product_info.product_cloud{
	background-image: url("img/item_cloud2.png");
	background-size: contain;
}
.product_info.product_white{
	background-color: #fff;
}
.product_info:hover{
	opacity: 0.7;
	transition: all 0.1s;
}
.product_box{
	width: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -40%);
}
.product_name{
	text-decoration: none;
	color: #49b5fe;
	font-size: 20px;
	font-weight: 700;
	padding: 0px 0 10px;
	line-height: 1;
}
.product_price{
	font-size: 16px;
	color: #49b5fe;
	line-height: 1.2;
}
.product_price>span, .product_tax{
	font-size: 14px;
	color: #49b5fe;
	font-weight: 400;
}
@media screen and (max-width: 1440px){
	.product_area{
		width: 1080px;
		margin: -20px auto 0;
	}
	.product_link{
		width: 330px;
	}
	.product_img{
		height: 260px;
	}
	.product_info{
		width: 100%;
	}
	.product_name{
		font-size: 20px;
	}
}
@media screen and (max-width: 1200px){
	.product_area{
		width: 900px;
	}
	.product_link{
		width: 280px;
	}
	.product_name{
		font-size: 18px;
		padding-bottom: 10px;
	}
	.product_price{
		font-size: 14px;
	}
	.product_price>span, .product_tax{
		font-size: 12px;
	}
	.product_info{
		padding: 20px 20px 15px;
	}
}
@media screen and (max-width: 600px){
	.product_area{
		width: 100%;
		display: block;
		box-sizing: border-box;
		margin: 0 auto;
		padding: 40px 20px 0;
	}
	.product_name{
		font-size: 20px;
	}
	.product_link{
		width: 100%;
		padding: 0 0 5px;
	}
	.product_list{
		padding-bottom: 40px;
	}
	.product_list:last-of-type{
		padding-bottom: 0;
	}
}