@charset "utf-8";
/*
html {
    visibility: hidden;
}
html.wf-active,
html.loading-delay {
    visibility: visible;
}
*/
body {
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.5;
	text-align: center;
	color: #000;
}
* {
	-webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

a {
	color: #000;
	outline: none;
	text-decoration: none;
}
img{
	margin: auto;
	max-width: 100%;
	height: auto;
	-webkit-backface-visibility: hidden;
}

input,
textarea{
}
input[type=radio], input[type=checkbox] {
	margin:0 5px 0 0;
	width: auto;
}
small {
	font-size: 75%;
}
.onlysp,
.spOnly{
	display: none;
}
.none{
	display:none;
}
.container {
	width: 90%;
	max-width: 1030px;
	margin: 0 auto;
}
article > section {
	padding: 60px 0;
}

.ttlBox h2,
.fo-nobel {
	font-family: nobel, sans-serif;
	font-weight: 300;
	font-style: normal;
}

/********************************/

header {
	text-align: center;
}

.copyright {
	padding: 15px 10px;
	font-size: 16px;
	color: #666666;
	letter-spacing: .05em;
}


/*contents-----------------------*/
.mainvisual {
	background: url("../img/top/main.png") center center no-repeat;
	background-size: cover;
	height: 955px;
}
.mainvisual.end {
	background-image: url("../img/top/main_end.png");
}
.ttlBox {
	margin-bottom: 40px;
}
.ttlBox h2 {
	font-size: 50px;
	line-height: .9;
	margin-bottom: 10px;
}
#present {
	background: url("../img/top/present_bg.png") center center no-repeat;
	background-size: cover;
}
.presentWrap {
	padding: 40px 5%;
	position: relative;
	background: #fff;
	font-size: 20px;
}
.presentWrap dt {
	font-weight: 600;
	margin-bottom: 10px;
}
.presentWrap::after {
	content: "";
	background: #000;
	width: 96%;
	height: 2px;
	display: block;
	position: absolute;
	left: 0;
	right: 0;
	top: -1px;
	margin: auto;
}
.presentWrap dd {
	font-size: 16px;
}
.presentImg {
	margin: 30px 0;
}
#how {
	padding: 0;
}
.howHead {
	position: relative;
	padding: 60px 0;
	background: #002543;
	color: #fff;
}
.howHead .ttlBox + p {
	margin-bottom: 50px;
	font-size: 22px;
}
.howHead li {
	width: 48%;
}
.howBox {
	background: #fff;
}
.howBox > p {
	background: #1b5672;
	font-size: 22px;
	font-weight: 600;
	letter-spacing: .1em;
	text-indent: .1em;
	padding: 18px 2%;
}
.howBox img {
	width: 104px;
	max-width: none;
	display: block;
	margin-right: 25px;
}
.howBox ul {
	padding: 35px 5%;
	text-align: left;
	color: #000;
	font-size: 22px;
}
.howBox li {
	width: 45%;
}
.howBox li:first-of-type {
	width: 53%;
}
.stepArea {
	padding: 90px 0;
	background: #050c13 url("../img/top/step_bg.png") center center no-repeat;
}
.stepTtl {
	font-size: 33px;
	letter-spacing: .05em;
	text-indent: .05em;
	color: #fff;
	margin-bottom: 50px;
	line-height: 1.1;
	padding-bottom: 50px;
	border-bottom: 1px solid #fff;
	padding: 10px 157px 40px;
	background: url("../img/top/step01.png") left top no-repeat;
}
.followTxt {
	font-size: 22px;
	color: #fff;
	margin-bottom: 50px;
}
.followBox {
	width: 48%;
}
.shop {
	width: 100%;
	color: #fff;
	background: #009aff;
	font-size: 20px;
	padding: 10px;
	margin-bottom: 25px;
}
.followBox dl {
	width: 47.5%;
	background: #fff;
	padding: 20px 5%;
}
.followBox dt {
	margin-bottom: 20px;
}
.followBox img {
	max-height: 61.5px;
}
.followBox a {
	color: #fff;
	display: block;
	padding: 10px 35px;
	margin-top: 25px;
	background: #009aff url("../img/ico_blank02.png") right 25px center no-repeat;
	background-size: auto 10px;
	transition: .1s;
}
.followBox a:hover,.followBox:last-of-type a:hover {
	background-color: #333;
}
.followBox:last-of-type .shop,
.followBox:last-of-type a{
	background-color: #00429f;
}
.followBox .btn a {
	padding: 0;
	background: none;
}
.followBox .btn a:hover {
	background: #333;
}
.infoWrap {
	margin-top: 145px;
	padding: 0 4% 80px;
	border: 3px solid #a0a0a0;
}
.infoWrap h3 {
	font-size: 35px;
	line-height: .9;
	margin: -25px auto 50px;
	background: #fff;
	width: 85%;
	border-radius: 25px;
	padding: 10px;
}
.infoTtl {
	font-size: 28px;
	margin-bottom: 30px;
	color: #fff;
}
.infoTtl span {
	font-size: 19px;
}
.infoTtl h4 {
	font-size: 27px;
}
.infoBox {
	background: #000;
	color: #fff;
	padding: 40px 2%;
	margin-bottom: 40px;
}
.step01Box {
	padding-bottom: 60px;
	margin-bottom: 60px;
	border-bottom: 1px solid #fff;
}
.infoList {
	padding-top: 40px;
}
.infoList figure {
	width: 16%;
}
.infoList figure img {
	max-height: 125px;
	background: #fff;
}
.infoList figcaption {
	font-size: 13.5px;
	letter-spacing: -.05em;
	padding-top: 20px;
}
.remoteImg {
	margin-bottom: 40px;
}
.cpDetail {
	background: #e3e3e3;
	padding: 60px 0;
}
.cpDetail .container {
	max-width: 850px;
}
.outLine {
	background: #fff;
	padding: 50px 5% 35px;
	margin-bottom: 50px;
}
.outLine dt {
	color: #fff;
	background: #000;
	font-size: 18px;
	width: 15%;
	padding: 15px 10px;
	margin-bottom: 12px;
}
.outLine dd {
	width: 85%;
	text-align: left;
	padding-left: 5%;
	margin-bottom: 12px;
	display: flex;
	align-items: center;
}
.kikan {
	font-size: 22px;
	font-weight: 800;
}
.kikan strong {
	font-size: 42px;
	vertical-align: 5px;
	display: inline-block;
	margin-top: -.2em;
}
.cpDetail h3 {
	background: #000;
	color: #fff;
	line-height: 1;
	letter-spacing: .3em;
	text-indent: .3em;
	font-size: 22px;
	padding: 15px 10px;
	margin-bottom: 40px;
}

.cpDetail ol {
	list-style: none;
	text-align: left;
}
.cpDetail li {
	text-indent: -.8em;
	padding-left: .8em;
	margin-bottom: 5px;
}
#step02 .stepTtl {
	background-image: url("../img/top/step02.png");
}
.privacyWrap {
	background: #e6e4dd;
	padding: 50px 8%;
}
.privacyBox {
	padding: 40px 2%;
	margin-bottom: 40px;
	background: #fff;
}
.privacyBox p {
	margin-bottom: 30px;
}
.btn02 a {
	background: #000 url("../img/btn_arrow.png") right 30px center no-repeat;
	background-size: auto 17px;
	padding: 20px 70px;
}

/*entry-----------------------*/
.entryHeader {
	padding-top: 20px;
}
#entry .ttlBox {
	background: #000;
	color: #fff;
	padding: 20px;
	font-size: 20px
}
#entry .ttlBox h1 {
	font-size: 55px;
}
#entry .ttlBox + p {
	font-size: 20px;
	line-height: 2;
}
.clrRed {
	color: #ff0000;
}
.formWrap {
	margin-top: 40px;
	border: 3px solid #000;
	padding: 60px 5%;
	text-align: left;
	font-size: 18px;
}
.formWrap dt,.formWrap dd {
	margin-bottom: 30px;
}
.formWrap dt {
	width: 30%;
	text-align: right;
	position: relative;
}
.formWrap dt.req::after {
	content: "*";
	color: #ff0000;
	position: absolute;
	right: -.7em;
	top: 0;
}
.formWrap dd {
	width: 70%;
	padding-left: 5%;
}
.formWrap label {
	display: inline-block;
	cursor: pointer;
}
.formWrap dd label:not(:first-of-type) {
	margin-left: 15px;
}
.formWrap input[type="text"],
.formWrap input[type="email"],
.formWrap select {
	padding: 5px;
}
.name p {
	margin-right: 15px;
}
.fTel input + small {
	display: inline-block;
	margin-left: 15px;
}
.zip input {
	max-width: 100px;
}
.zip + p {
	margin-top: 10px;
}
.name input[type="text"] {
	width: 100%;
	max-width: 170px;
}
input[name="address"] {
	width: 80%;
}
input[name="email"] {
	width: 100%;
	max-width: 280px;
}
.follow li {
	margin-bottom: 15px;
}
.follow li:last-of-type {
	margin-bottom: 0;
}
.follow label {
	display: inline-block;
	margin-right: 15px;
}
.formTxt {
	border: 2px solid #ff0000;
	padding: 5px 10px;
	position: relative;
	margin-top: 15px;
	display: inline-block;
}
.formTxt::before,.formTxt::after{
	content: "";
	display: block;
	position: absolute;
	left: 20px;
	top: -10px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 10px 10px 10px;
	border-color: transparent transparent #ff0000 transparent;
}
.formTxt::after {
	left: 23px;
	top: -8px;
	border-width: 0 7px 8px 7px;
	border-color: transparent transparent #fff transparent;
}
.shopUse > div:first-of-type {
	margin-bottom: 15px;
}
.shopUse select {
	margin-left: 15px;
}
.mailBtn {
	text-align: center;
	margin-top: 30px;
}
.mailBtn input {
	display: inline-block;
	color: #fff;
	background: #000;
	padding: 15px 100px;
	border: 2px solid #000;
	border-radius: 30px;
	font-size: 18px;
	cursor: pointer;
	transition: .1s;
}
.mailBtn input:hover {
	background: #fff;
	color: #000;
}
.mailBtn .button02 {
	background: #fff;
	color: #000;
	margin-right: 20px;
}
.backBtn {
	margin-top: 40px;
}
.backBtn img {
	max-height: 67px;
}
#thx .formWrap {
	text-align: center;
}
.thxTxt {
	text-align: left;
	display: inline-block;
}











/*ieハック*/
@media screen\0  {
	.howBox > p {
		padding-bottom: 10px;
	}
	.shop {
		padding-bottom: 3px;
	}
	.stepTtl {
		padding-top: 20px;
	}
	.followBox a {
		padding: 12px 35px 8px;
	}
	.outLine dt,.cpDetail h2 {
		padding: 19px 10px 11px;
	}
	.cpDetail h3 {
		padding-bottom: 7px;
	}
	.formTxt {
		padding: 7px 10px 0;
	}
}

/*********************************/
/* タブレット用のスタイル記述 */
/*********************************/
@media screen and (max-width: 1600px) {
	.mainvisual {
		height: 55vw;
	}
}
@media screen and (max-width: 900px) {
	.stepTtl {
		font-size: 3vw;
		background-size: 20%;
		text-align: left;
		padding: 10px 0 5% 22%;
	}
}
/*********************************/
/* スマートフォン用のスタイル記述 */
/*********************************/
@media screen and (max-width: 620px) {

	body {
		font-size: 12px;
	}
	article > section {
		padding: 40px 0;
	}
	
	
	/*cont---------------------------*/
	.mainvisual {
		background: none;
		height: auto;
	}
	.ttlBox {
		margin-bottom: 20px;
	}
	.ttlBox h2 {
		font-size: 23px;
	}
	.presentWrap {
		padding: 30px 5%;
	}
	.presentWrap p,.presentWrap dd {
		font-size: 12px;
		text-align: left;
	}
	.presentWrap dt {
		font-size: 15px;
	}
	.howHead {
		padding: 40px 0;
	}
	.howBox > p {
		padding: 12px 5px;
		font-size: 14px;
	}
	.howBox img {
		width: 55px;
		margin-right: 10px;
	}
	.howHead ul {
		display: block;
		font-size: 12px;
		padding: 20px 5% 5px;
	}
	.howHead li,.howBox li:first-of-type {
		width: 100%;
		margin-bottom: 15px;
	}
	.stepArea {
		padding: 40px 0;
	}
	.stepTtl {
		font-size: 16px;
		padding: 45px 0 5%;
		margin-bottom: 30px;
		background-position: top center;
		background-size: auto 30px;
		text-align: center;
	}
	.step01Txt {
		font-size: 5.2vw;
		margin-bottom: 30px;
	}
	.followTxt {
		font-size: 15px;
		margin-bottom: 30px;
	}
	.followBox {
		width: 100%;
	}
	.followLinks {
		display: block;
	}
	.followBox {
		flex-wrap: wrap;
	}
	.followBox:last-of-type {
		margin-top: 30px;
	}
	.shop {
		font-size: 15px;
		margin-bottom: 6px;
	}
	.followBox > dl {
		width: 49%;
		margin-bottom: 10px;
		padding: 15px 8px;
	}
	.followBox dt {
		margin-bottom: 10px;
		font-size: 12px;
		line-height: 1.2;
	}
	.followBox a {
		margin: 15px auto 0;
	}
	.followBox img {
		max-height: 40px;
	}
	.followBox a {
		background-position: right 14px center;
		background-size: auto 7px;
		padding: 12px 0;
		font-size: 10px;
		max-width: 172px;
	}
	.infoWrap {
		margin-top: 70px;
		padding-bottom: 40px;
	}
	.infoWrap h3 {
		font-size: 16px;
		margin:-17px auto 30px;
		width: 90%;
	}
	.infoTtl {
		font-size: 5vw;
	}
	.infoTtl span {
		font-size: 4vw;
		line-height: 1;
	}
	.infoBox {
		padding: 30px 5% 15px;
		margin-bottom: 30px;
	}
	.infoBox > p {
		text-align: left;
	}
	.infoList {
		padding-top: 20px;
		flex-wrap: wrap;
	}
	.infoList figure {
		width: 32%;
		margin-bottom: 15px;
	}
	.infoList figcaption {
		font-size: 2vw;
		padding-top: 8px;
	}
	.remoteImg {
		margin-bottom: 30px;
	}
	.cpDetail {
		margin-top: 0;
	}
	.outLine {
		padding: 30px 5%;
	}
	.outLine .d-flex {
		display: block;
	}
	.outLine dt,.outLine dd {
		width: 100%;
	}
	.outLine dt {
		font-size: 14px;
		padding: 5px;
	}
	.kikan {
		font-size: 14px;
	}
	.kikan strong {
		font-size: 26px;
	}
	.cpDetail h3 {
		padding: 10px;
		font-size: 14px;
		margin-bottom: 15px;
	}
	.btn img {
		max-height: 40px;
	}
	.cpDetail {
		padding: 40px 0;
	}
	.step01Box {
		padding-bottom: 30px;
		margin-bottom: 30px;
	}
	.cpDetail .container {
		width: 90%;
	}
	.cpDetail li {
		font-size: 12px;
	}
	#step02 .stepTtl + p {
		font-size: 18px;
		margin-bottom: 20px
	}
	.privacyWrap {
		padding: 30px 5%;
	}
	.privacyBox {
		padding: 20px 5%;
		margin-bottom: 20px;
	}
	.privacyBox p {
		text-align: left;
		font-size: 12px;
		margin-bottom: 15px;
	}
	.privacyBox a img {
		max-height: 65px;
	}
	.step01Ttl {
		font-size: 14px;
	}
	.step01Ttl h3 {
		font-size: 20px;
		text-indent: -.5em;
	}
	.step01Box .step01Txt {
		font-size: 4.2vw;
	}
	
	
	/*entry----------------*/
	.entryHeader {
		padding-top: 10px;
	}
	.entryHeader img {
		max-height: 40px;
	}
	#entryForm {
		padding-top: 0;
	}
	#entry .ttlBox h1 {
		font-size: 20px;
	}
	#entry .ttlBox {
		padding: 10px 10px 8px 10px;
		font-size: 14px;
		margin-top: 20px;
	}
	#entry .ttlBox + p {
		line-height: 1.6;
		font-size: 12px;
	}
	.formWrap {
		padding: 40px 5%;
		margin-top: 30px;
		font-size: 14px;
	}
	.formWrap dl {
		display: block;
	}
	.formWrap dt {
		background: #f1f1f1;
		padding: 5px 15px 5px 10px;
		text-align: left;
		display: inline-block;
		width: auto;
		margin-bottom: 15px;
	}
	.formWrap dt.req::after {
		right: 3px;
	}
	.formWrap dd {
		width: 100%;
		padding-left: 0;
		border-bottom: 1px solid #666;
		padding-bottom: 20px;
		margin-bottom: 20px;
	}
	.fTel input + small {
		margin-left: 0;
	}
	.flwTxt {
		width: 100%;
		margin-top: 5px;
	}
	.follow label {
		border: 1px solid #ddd;
		padding: 5px 12px;
		border-radius: 25px;
	}
	.account {
		display: block;
		margin-top: 5px;
		font-size: 12px;
	}
	input[type=radio], input[type=checkbox] {
		vertical-align: -1px;
	}
	.zip input {
		width: 35%;
	}
	.fTel input[type="text"],
	input[type="email"],
	input[name="address"] {
		width: 100%;
	}
	.mailBtn input {
		font-size: 15px;
		padding: 10px 50px;
	}
	#confirm .mailBtn {
		display: block;
	}
	#confirm .mailBtn input {
		width: 100%!important;
	}
	.mailBtn .button02 {
		margin-right: 0;
		margin-bottom: 20px;
	}
	.formid,.follow {
		display: flex;
		flex-wrap: wrap;
	}
	.formid > div,.follow > div {
		width: 100%;
		order: -1;
	}
	.formTxt {
		margin: 0 0 20px 0;
		display: block;
	}
	.formTxt::before, .formTxt::after {
		top: inherit;
		bottom: -10px;
		border-width: 10px 10px 0 10px;
    border-color: #ff0000 transparent transparent transparent;
	}
	.formTxt::after {
    left: 23px;
    top: inherit;
		bottom: -8px;
    border-width: 8px 7px 0 7px;
    border-color: #fff transparent transparent transparent;
}
	
	
	/***footer***/
	.copyright {
		font-size: 10px;
	}
	.bnrBox,
	.bnr_L,
	.bnr_R {
		display: block;
		width: 100%;
	}
	.f_bnrWrap02 {
		padding: 40px 5%;
	}
	.f_bnrWrap02 .bnrBox > div {
		width: 100%;
	}
	.f_bnrWrap02 .bnrBox > div:first-of-type {
		margin-bottom: 15px;
	}
/*全体レイアウト
------------------------------------------------*/
.onlypc{display:none;}
.onlysp{display: block;}

}















