@charset "UTF-8";

/* Main styles
 * ================================================================================= */
.slider-main-visual img {
    width: 100%;
}
.main-firstview {
	position: relative;
	z-index: 10;
}
.main-firstview figcaption {
	position: absolute;
	bottom: 50px;
	left: 20px;
	line-height: 1.4;
	font-size: 12px;
}
.main-firstview .icn-uv:before {
	position: absolute;
	top: 35%;
	left: 4%;
	width: 134px;
	height: 134px;
	content: "";
	background: url(../img/uv.png) no-repeat;
	background-size: 134px auto;
}
.ttl-firstview {
	position: absolute;
    top: 70px;
    left: 0;
    right: 0;
    padding-left: 108px;
    font-size: 28px;
    font-weight: bold;
    letter-spacing: 0;
    font-family: 'M PLUS 1p', sans-serif;
    text-shadow: 0px 0px 6px #ffffff;
}
.ttl-firstview > span {
    font-size: 28px;
    font-weight: bold;
    letter-spacing: 0;
    font-family: 'M PLUS 1p', sans-serif;
    color: #3c74b8;
    text-shadow: 1px 1px 4px #fff;
}
.ttl-firstview:before {
	position: absolute;
    top: 0;
    left: 20px;
    width: 80px;
    padding: 4px 8px;
    border: 1px solid #333;
    content: "日本製";
    font-weight: bold;
    font-size: 20px;
    letter-spacing: 0;
}
.ttl-sub-firstview {
	position: absolute;
    top: 60px;
    left: 20px;
    letter-spacing: 0;
    font-size: 12px;
    margin-top: -10px;
    text-shadow: 1px 1px 0px #fff;
}
.top-sub-wrap {
	position: relative;
	z-index: 0;
	margin-top: -600px;
    padding: 660px 15px 15px 55px;
    background: url(../img/bg-ttl-top.png) repeat-y;
    background-size: 100% auto;
	/*margin-top: 40px;
    padding: 10px 15px 10px 55px;
    background: url(../img/bg-ttl-top.png) repeat-y;
    background-size: 100% auto;*/
}
.top-sub-wrap:before {
	position: absolute;
    z-index: -1;
    bottom: 46px;
	left: 11%;
	width: 60px;
	height: 165px;
	content: "";
	background: url(../img/bg-ttl-top-2.png) no-repeat;
	background-size: auto;
	background-size: 60px auto;
}
.top-sub-wrap > h4 {
	line-height: 1.4;
    font-size: 14px;
    font-weight: bold;
    letter-spacing: -.4px;
    font-family: 'M PLUS 1p';
}
.top-sub-wrap > h3 {
	padding: 5px 0;
    line-height: 1.4;
    margin-top: 5px;
    border-top: 1px solid #333;
    border-bottom: 1px solid #333;
    font-size: 22px;
    font-weight: bold;
    letter-spacing: -.2px;
    font-family: 'M PLUS 1p';
}
.top-sub-wrap > a {
    font-size: 12px;
    letter-spacing: 0;
    font-weight: bold;
    margin-top: 3px;
    display: block;
}
.top-sub-wrap > a > span {
	font-size: 12px;
}
.top-coupon-txt {
	margin-top: 5px;
	font-weight: bold;
	font-size: 16px;
	color: #d1526e;
	font-family: 'M PLUS 1p';
}
.top-coupon-num {
	margin-top: 3px;
	margin-bottom: 4px;
	color: #d1526e;
    font-family: 'M PLUS 1p';
}
.reserve-note {
	line-height: 1.4;
	margin-top: 4px;
    font-size: 10px;
    letter-spacing: 0;
}





.txt-top-reserve {
	width: 100%;
	margin-top: 25px;
	padding: 15px;
	display: flex;
	display: -moz-flex;
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
}
.reserve-date {
	position: relative;
    width: 56px;
    height: 56px;
    line-height: 32px;
    padding: 10px 0;
    border-radius: 50%;
    border: 2px solid #3c74b8;
    color: #3c74b8;
    font-weight: bold;
    font-size: 20px;
    text-align: center;
    letter-spacing: 0;
}
.reserve-date:before {
	position: absolute;
    bottom: -7px;
    right: -9px;
    content: "●";
    color: #3c74b8;
    font-size: 26px;
}
.reserve-date:after {
	position: absolute;
    bottom: -7px;
    right: -3px;
    content: "金";
    font-size: 14px;
    font-weight: bold;
    color: #fff;
}
.txt-top-reserve-r {
	position: relative;
	width: 82%;
	margin-left: 2%;
}
.reserve-time {
	font-size: 18px;
	font-weight: bold;
	color: #3c74b8;
	letter-spacing: 0;
}
.txt-top-reserve-r > a {
	position: absolute;
    top: 1px;
    right: 10px;
    font-size: 16px;
    letter-spacing: 0;
    font-weight: bold;
}
.reserve-txt {
	margin-top: 3px;
	letter-spacing: 0;
	font-size: 20px;
	font-weight: bold;
	color: #3c74b8;
}
.reserve-txt > span {
	display: block;
	margin-top: 2px;
	font-size: 12px;
	color: #333;
}
.icn-firstview-wrap {
	position: absolute;
    bottom: -30px;
    right: 20px;
    display: flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: -webkit-box;
    display: -webkit-flex;
    flex-wrap: wrap;
    width: 180px;
}
.icn-firstview-wrap > li {
	width: 55px;
    height: 55px;
    margin-top: 5px;
    margin-left: 5px;
    border-radius: 50%;
    background-color: #3c74b8;
    color: #fff;
    letter-spacing: 0;
    line-height: 1.2;
    font-size: 12px;
    padding: 7px 0;
    text-align: center;
}





.top-sale-link {
	display: block;
	width: 375px;
	line-height: 1.3;
	margin: 60px auto 0;
	padding: 10px 0;
	letter-spacing: 0;
	text-align: center;
	font-size: 16px;
	font-weight: bold;
	font-family: 'Fredoka One', 'Kosugi Maru', 'Baloo Bhai', cursive;
	color: #fff;
	background: url(../img/bg-top-sale.jpg) no-repeat;
	background-size: 375px auto;
}
.top-sale-link > span {
	display: block;
	font-size: 26px;
	font-weight: bold;
	letter-spacing: -.4px;
	font-family: 'Fredoka One', 'Kosugi Maru', 'Baloo Bhai', cursive;
}
.free-shipping {
	width: 375px;
	margin: 0 auto;
	padding: 10px 0;
	text-align: center;
	font-size: 20px;
	letter-spacing: -.4px;
	color: #fff;
	background-color: #000;
}
.free-shipping > span {
	font-size: 14px;
}
.sec-lead {
	line-height: 1.6;
	margin: 0 15px;
	text-align: justify;
}
.top-lead-list {
	position: relative;
	margin: 20px 10px 0;
	padding: 48px 10px 10px;
	background-color: #f8f5f6;
}
.top-lead-list:before {
	position: absolute;
    top: -16px;
    left: -26px;
    content: "";
    width: 184px;
    height: 72px;
    background: url(../img/ttl-about-mask.png) no-repeat;
    background-size: 184px auto;
}
.top-lead-list > li {
	line-height: 1.4;
	margin-top: 8px;
}
.top-lead-list > li > .fa-heart {
	color: #da5159;
}

/* How To Video */
.howto-video {
	position: relative;
    margin: 10px 10px 0;
    padding-bottom: 56.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden;
}
.howto-video > video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.fa-check-square {
	color: #d1526e;
}


.sec-ttl {
	border-bottom: 1px solid #aaa;
	margin: 15px 0;
	padding: 10px 0;
	position: relative;
	font-size: 18px;
	font-weight: bold;
	color: #333;
}

.sec-ttl:before,
.sec-ttl:after {
	content: '';
	border-right: 20px solid #fff;
	border-top: 14px solid #aaa;
	bottom: -15px;
	position: absolute;
	left: 25px;
}

.sec-ttl:after {
	border-top-color: #fff;
	border-right-color: transparent;
	bottom: -13px;
	left: 26px;
}

/* Pick Up */
.slider-review {
  margin-top: 10px;
}
.slider-review a {
  display: block;
  margin-left: 10px;
}
.slider-review .slick-list {
    padding: 0 15% 0 0;
}
.slider-review a figure {
    letter-spacing: 0;
}
.slider-review a figure img {
    width: 100%;
}
.slider-review a time {
  display: block;
  margin-top: 5px;
  padding: 0 5px;
}
.slider-review a .school-txt {
    line-height: 1.3;
    margin-top: 6px;
    padding: 0 5px;
    font-size: 12px;
}
.slick-dots li button {
    color: #fff !important;
}
.slick-dots li button:before {
    opacity: 1 !important;
    background-color: #fff !important;
    border: 1px solid #929292;
}
.slick-dots .slick-active button:before {
    background-color: #3c74b8 !important;
}

.link-info {
	position: relative;
	box-sizing: border-box;
	display: block;
    width: 100%;
    line-height: 1.2;
    margin: 40px auto 0;
    padding: 20px;
	background-color: #dde8ea;
}
.link-info > span {
	display: block;
	font-size: 18px;
	font-weight: bold;
}
.link-info:before {
	position: absolute;
    top: calc(50% - 7px);
    right: 15px;
    width: 14px;
    height: 14px;
    content: "";
    border-top: 2px solid #666;
    border-right: 2px solid #666;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

/* Line Up */
.top-link-sec {
	position: relative;
	margin-top: 40px;
}
.top-link-sec > figure {
	position: relative;
}
.top-link-sec figcaption {
	position: absolute;
	bottom: 10px;
	right: 10px;
	font-size: 12px;
	letter-spacing: 0;
}
.top-link-sec img {
	width: 100%;
}
.top-link-sec .top-link-inner {
	position: absolute;
	bottom: 20px;
	left: 0;
	display: block;
	width: 250px;
	padding: 12px 10px 10px;
	font-size: 16px;
	font-weight: bold;
	color: #fff;
	background-color: #000;
}
.top-link-sec .top-link-inner:before {
	position: absolute;
    top: calc(50% - 7px);
    right: 10px;
    width: 14px;
    height: 14px;
    content: "";
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.top-link-txt {
	line-height: 1.4;
	margin: 10px 10px 0;
}
.sec-wrap-beige {
	position: relative;
	margin-top: 40px;
	padding: 1px 10px 30px;
	background-color: #f8f5f6;
}
.top-news-link {
	position: absolute;
	top: 40px;
	right: 10px;
	text-decoration: underline;
}
.top-news-list > li {
	margin-top: 30px;
}
.top-news-list > li > a {
	display: block;
	line-height: 1.4;
	margin-top: 10px;
	text-decoration: underline;
}
.top-concept-img {
	position: absolute !important;
	bottom: -20px;
	left: 10px;
	width: 200px;
}
.top-concept-img > img {
	width: 100%;
}
.top-brand-img {
	margin-top: 30px;
}
.top-brand-img > img {
	width: 100%;
}

/* FAQ */
.sec-faq-wrap {
	padding: 15px;
}
.faq-main-view > h3 {
    line-height: 1.4;
    margin-top: 5px;
    padding-left: 10px;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: -.2px;
}
.faq-list {
	margin-top: 40px;
}
.faq-list > li {
	margin-top: 20px;
}
.faq-list > li h4 {
	position: relative;
	line-height: 1.4;
	padding-left: 20px;
}
.faq-list > li h4:before {
	position: absolute;
	top: -2px;
	left: 0;
	font-size: 16px;
	font-weight: bold;
	color: #3c74b8;
	content: "Q:";
}
.faq-list > li p {
	position: relative;
	line-height: 1.4;
	margin-top: 10px;
	padding-left: 20px;
}
.faq-list > li p:before {
	position: absolute;
	top: -2px;
	left: 0;
	font-size: 16px;
	font-weight: bold;
	color: #d1526e;
	content: "A:";
}
.img-info {
	margin-top: 30px;
}
.img-info > img {
	width: 100%;
}







@media (min-width: 737px) {
	.dn-pc {
		display: none !important;
	}
	.dn-sp {
		display: block;
	}

	.page-wrapper {
		margin: 0 auto;
		overflow: hidden;
	}
	.slider-box {
	    margin: -150px auto 0;
	}
	.slider-main-visual .caption {
		bottom: 35%;
	}
	.slick-slider .slick-prev,
	.slick-slider .slick-next {
		top: 35%;
	}
	.works-list {
		margin-top: 15%;
	}
	.main-firstview > h1 {
	    top: 145px;
	    font-size: 36px;
	}
	.main-firstview > p {
	    width: 560px;
	    margin: 0 auto;
	    top: 250px;
	    font-size: 74px;
	}
	.main-firstview > p:before {
	    top: -80px;
	    right: 0;
	    width: 100px;
	    height: 100px;
	    background: url(../img/txt-top-main.png) no-repeat;
	    background-size: 100px auto;
	}
	.ttl-sub-firstview {
	    top: 80px;
	    font-size: 16px;
	}
	.ttl-firstview {
	    top: 100px;
	    padding-left: 126px;
	    font-size: 36px;
	}
	.ttl-firstview > span {
	    font-size: 36px;
	}
	.ttl-firstview:before {
		top: 2px;
		width: 98px;
		font-size: 26px;
	}
	.top-sub-wrap {
		padding: 650px 15px 15px 13%;
	}
	.top-sub-wrap:before {
	    bottom: 112px;
	    left: 11%;
	    width: 100px;
	    height: 175px;
	    content: "";
	    background: url(../img/bg-ttl-top-2.png) no-repeat;
	    background-size: 100px auto;
	}
	.top-sub-wrap > h4 {
		font-size: 20px;
	}
	.top-sub-wrap > h3 {
	    font-size: 34px;
	}
	.top-sub-wrap > a {
	    font-size: 24px;
	}
	.top-sale-link {
		margin: 100px auto 0;
	}
	.txt-top-reserve-r {
	    width: 88%;
	}
	.txt-top-reserve-r > a {
	    top: 20px;
	    right: 0;
	    font-size: 20px;
	}
	.reserve-txt {
		font-size: 24px;
	}
	.reserve-note {
		font-size: 13px;
	}
	.sec-faq-wrap {
		padding: 10%;
	}
}



