body{
	background: url("../img/gift/bg.jpg") repeat center top;
}
#key {
	background: url("../img/gift/key-bg.jpg") no-repeat center/cover;
}
.btn-fixed{
	position: fixed;
	right: 0;
	bottom: 100px;
	z-index: 5;
}
.key_ttl {
	position: absolute;
	bottom: 75px;
	right: -64px;
}
#footer .logo1{
	padding-top: 58px;
}
#lead{
	background: url("../img/gift/s1_bg.jpg") no-repeat center top / cover;
	padding: 129px 110px 141px 0;
	color: #fff;
}
#lead .box-text{
	width: 543px;
	margin-left: auto;
}
#lead .box-text .text{
	margin: 55px 0 0 20px;
}
#mizutaki {
	padding-bottom: 98px;
}
#mizutaki .wrap:before{
	content: "";
	position: absolute;
	top: 0;
	right: -262px;
	background: url("../img/gift/s2_decobg.png") no-repeat left top;
	height: 1199px;
	width: 1056px;
}
#mizutaki .wrap:after{
	content: "";
	position: absolute;
    bottom: -68px;
    left: -232px;
	background: url("../img/gift/s2_deco.png") no-repeat left top;
	height: 595px;
	width: 737px;
}
#mizutaki  .row1{
	padding-top: 50px;
	position: relative;
	z-index: 1;
	padding-bottom: 26px;
}
#mizutaki  .row1 h2{
	float: right;
	margin-right: 33px;
}
#mizutaki  .row1 .photo{
	float: left;
    margin-left: -145px;
    margin-top: 54px;
	width: 576px;
}
#mizutaki  .row2 .photo{
	float: right;
	margin-right: -173px;
	width: 749px;
}
#mizutaki  .row2 dl{
	width: 508px;
	float: left;
	position: relative;
	z-index: 1;
    margin-left: -76px;
    padding-top: 36px;
}
#mizutaki  .row2 dl dd{
	margin: 36px 7px 0 12px;
	line-height: 40px;
}
#history{
	max-width: 1376px;
	width: 100%;
	margin: 0 auto;
	background: url("../img/gift/s3_bg.jpg") no-repeat center top / cover;
	color: #e6e3db;
	box-sizing: border-box;
	padding: 75px 90px 86px 0;
}
#history .box-txt{
	width: 495px;
	margin-left: auto;
}
#history .box-txt .text{
    margin-top: 33px;
    line-height: 40px;
    margin-left: 8px;
}
#reason{
	background: url("../img/gift/s4_bg.jpg") no-repeat center top / cover;
	padding: 79px 0 107px;
	margin-top: 131px;
	box-shadow: 0px 0px 6.79px 0.21px rgba(0, 0, 0, 0.5);
}
#reason h2{
	text-align: center;
	margin-bottom:89px;
}
#reason .wrap:before{
	content: "";
	position: absolute;
	top: 0;
	right: -260px;
	background: url("../img/gift/s4_decobg.png") no-repeat left top;
	height: 843px;
	width: 1187px;
}
#reason dl{
	margin-bottom: 42px;
	position: relative;
	z-index: 1;
	margin-left: -21px;
}
#reason dl dt{
	display: flex;
	font-weight: 600;
	line-height: 54px;
	font-size: 30px;
}
#reason dl dd{
    margin-left: 20px;
    margin-top: 7px
}
#reason h3{
	text-align: center;
    margin-bottom: 39px;
    margin-top: 119px;
}
#reason ul{
	display: flex;
	justify-content: center;
}
#reason ul li{
	margin: 0 10px;
}
#cart{
	background: url("../img/gift/s5_bg.png") repeat center top;
	padding: 71px 0 50px;
}
#cart .box{
	max-width: 1600px;
	width: 100%;
	margin: 0 auto;
	box-sizing: border-box;
	padding: 0 102px 0 33px;
}
#cart .box .box-text{
	width: 460px;
	position: relative;
	padding: 81px 0 113px;
	color: #000;
	float: right;
}
#cart .box .box-text dl{
	position: relative;
	z-index: 1;
}
#cart .box .box-text dl dt{
	font-weight: 600;
	font-size: 40px;
	line-height: 70px;
	border-bottom: 1px solid #261b1a;
	text-align: center;
	padding:  0 10px ;
}
#cart .box .box-text dl dt span{
	font-size: 30px;
}
#cart .box .box-text dl dt small{
	font-size: 26px;
}
#cart .box .box-text dl dd{
	margin-top: 5px;
	border-top: 3px solid #261b1a;
	text-align: center;
	font-size: 40px;
	line-height: 70px;
	font-weight: 600;
	padding-top: 13px;
}
#cart .box .box-text dl dd span{
	font-size: 30px;
}
#cart .box .box-text ul{
	position: relative;
	margin-top: 10px;
	margin: 31px 10px 48px 35px;
}
#cart .box .box-text .s5-btn{
	position: relative;
	z-index: 1;
	text-align: center;
}
#cart .box .box-text:before{
	content: "";
	position: absolute;
	background: url("../img/gift/s5_bg_txt.png") no-repeat left top / 100% 100%;
    top: -24px;
    left: -125px;
    right: -115px;
	bottom: 0;
}
#cart .box .slider-fade{
	position: relative;
	z-index: 1;
	float: left;
	width: calc(100% - 524px);
}
#cart .box .slider-fade .img-js{
	border: 6px solid #8f7f3d;
	box-sizing: border-box;
}
#cart .box .slider-fade .slick-dots {
    display: block;
    width: 100%;
    padding: 0;
    margin: 32px 0 0;
    list-style: none;
    text-align: center;
    line-height: 0;
	box-sizing: border-box;
}
#cart .box .slider-fade .slick-dots li {
    position: relative;
    display: inline-block;
    margin: 0 12px;
    padding: 0;
    cursor: pointer;
}
#cart .box .slider-fade .slick-dots li button {
    font-size: 0;
    line-height: 0;
    display: block;
    width: 211px;
    height: 148px;
    cursor: pointer;
    color: transparent;
    border: none;
    outline: none;
    border-radius: 0;
    background: url("../img/gift/s5_thum01.jpg") no-repeat center / cover;
}
#cart .box .slider-fade .slick-dots li button:before{
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	opacity: 0;
	border: 6px solid #a90707;
	transition: all 0.3s;
}
#cart .box .slider-fade .slick-dots li:nth-child(2) button{
	background-image: url("../img/gift/s5_thum02.jpg");
}
#cart .box .slider-fade .slick-dots li:nth-child(3) button{
	background-image: url("../img/gift/s5_thum03.jpg");
}

#cart .box .slider-fade .slick-dots li.slick-active button:before{
	opacity: 1;
}
#cart .box .slider-fade .slick-dots li button:hover, .slick-dots li button:focus {
    opacity: 0.8;
}
#other{
	padding: 85px 0 134px;
}
#other .row1 .box-text{
	float: left;
	width: 475px;
	margin-left: -64px;
}
#other .row1 .box-text h2{
	margin-left: -90px;
}
#other .row1 .box-text .text{
	width: 461px;
    margin: 39px 0 52px 0;
    line-height: 40px;
    text-align: justify;
}
#other .row1 .photo{
	float: right;
	margin-right: -220px;
	margin-top: 40px;
}
#other .banner{
	text-align: center;
	margin-top: 128px;
}
#flow {
	background: url("../img/gift/bg_patten.jpg") repeat center top;
	padding: 160px 0 179px;
	color: #000;
}
#flow .box1{
	max-width: 1200px;
	margin: 0 auto;
	width: 100%;
	box-sizing: border-box;
	border: 5px solid #260b06;
	padding: 57px 0 47px;
	position: relative;
	text-align: center;
}
#flow .box1 h3{
	position: absolute;
	top: -45px;
	left: 50%;
	transform: translateX(-50%);
}
#flow .box1 .txt{
	font-weight: 600;
	font-size: 30px;
	line-height: 80px;
}
#flow .box1  .s8-btn{
	margin: 0 0 30px;
}
#flow .box1 .box-tel .tel-txt{
	font-size: 33px;
	font-weight: 600;
	line-height: 80px;
}
#flow .box1 .box-tel .tel-txt span{
	display: block;
    font-size: 20px;
    line-height: 35px;
    margin-bottom: 10px;
}
#flow .box2{
	max-width: 1200px;
	margin: 179px auto 0;
	width: 100%;
	box-sizing: border-box;
	border: 5px solid #260b06;
	padding: 120px 0 107px;
	position: relative;
	text-align: center;
}
#flow .box2 h3{
	position: absolute;
	top: -30px;
	left: 50%;
	transform: translateX(-50%);
}
#flow .box2 dl{
	width: 923px;
	margin-left: 54px;
	text-align: left;
}
#flow .box2 dl dt{
	display: flex;
	position: relative;
	font-size: 26px;
    line-height: 74px;
	font-weight: 600;
}
#flow .box2 dl dt:before{
	content: "";
	position: absolute;
    bottom: -6px;
    left: 21px;
	right: 0;
	border-bottom: 3px solid #000;
}
#flow .box2 dl dt span:first-of-type{
	font-weight: 600;
	font-size: 60px;
	line-height: 1;
	display: inline-block;
	margin-right: 25px;
}
#flow .box2 dl dd{
    display: flex;
    margin: 50px 0 0 48px;
    font-size: 20px;
    line-height: 40px;
}
#flow .box2 dl + dl{
	margin-top: 52px;
}
#flow .box2 dl dd span:first-of-type{
	font-weight: 600;
	font-size: 40px;
	line-height: 1;
	display: inline-block;
	margin-right: 20px;
}
@media only screen and (max-width: 1400px){
	#cart .box .slider-fade .slick-dots{
		padding-left: 0;
	}
	#cart .box .slider-fade .slick-dots li{
		margin: 0 7px;
	}
}
@media only screen and (max-width: 1360px) and (min-width: 768px){
	#cart .box{
		padding: 0;
	}
	#cart .box .slider-fade{
		width: calc(100% - 470px);
	}
	#cart .box .slider-fade .slick-dots li button{
		width: 179px;
	}
}