@charset "utf-8";

/* --------------------------------------------------- */
/* キャンペーン */
/* --------------------------------------------------- */
body.cp .wrap { background: #fff; }
body.cp main { margin-top: 0; width: 100%; }
body.cp main section { padding-left: 0; padding-right: 0; }
body.cp footer dl dd { vertical-align: bottom; }

/* --------------------------------------------------- */
/* 共通タイトル */
/* --------------------------------------------------- */
.cp .pgtitle {
	padding: 60px 0;
	background-color: #00a000;
}
.cp .pgtitle .inner {
	position: relative;
	margin: 0 auto;
	padding: 40px 50px;
	width: 90%;
	max-width: 960px;
	border: 12px solid #fff;
	box-sizing: border-box;
}
.cp .pgtitle .inner::before {
	content: '';
	position: absolute;
	top: -42px;
	left: -42px;
	display: block;
	width: 72px;
	height: 72px;
	background-color: #00a000;
	background-image: url('../image/cp/plus.png');
	background-repeat: no-repeat;
	background-size: 64px 64px;
	background-position: 50% 50%;
}
.cp .pgtitle h1 {
	color: #fff;
	font-size: 2.4rem;
	font-weight: 500;
	line-height: 1.4;
	text-align: center;
}
.cp .pgtitle h1 span { display: inline-block; }

@media screen and (max-width: 767px) {
	.cp .pgtitle { padding: 40px 0; }
	.cp .pgtitle .inner {
		padding: 30px 25px;
		border: 10px solid #fff;
	}
	.cp .pgtitle .inner::before {
		top: -33px;
		left: -32px;
		width: 56px;
		height: 56px;
		background-size: 48px 48px;
	}
	.cp .pgtitle h1 { font-size: 2.1rem; }
}
@media screen and (max-width: 419px) {
	.cp .pgtitle { padding: 25px 0; }
	.cp .pgtitle .inner {
		padding: 20px 15px;
		border: 8px solid #fff;
	}
	.cp .pgtitle .inner::before {
		top: -28px;
		left: -28px;
		width: 48px;
		height: 48px;
		background-size: 36px 36px;
	}
	.cp .pgtitle h1 { font-size: 1.8rem; }
}

/* --------------------------------------------------- */
/* 共通 */
/* --------------------------------------------------- */
.btn-area {
	margin-top: 2em;
	text-align: center;
}

/* --------------------------------------------------- */
/* フォーム */
/* --------------------------------------------------- */
input::-webkit-input-placeholder { font-size: 1.2rem; }
input:-moz-placeholder { font-size: 1.2rem; }
input::-moz-placeholder { font-size: 1.2rem; }
input:-ms-input-placeholder { font-size: 1.2rem; }
form .selectwrap { position: relative; display: inline-block; width: 94px;vertical-align: top; }
form .selectwrap::after {
	content: '';
	position: absolute;
	top: 15px;
	right: 15px;
	display: block;
	width: 5px;
	height: 5px;
	border-bottom: 1px solid #00a000;
	border-right: 1px solid #00a000;
	transform: rotateZ(45deg);
	pointer-events: none;
}
form select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	display: table;
	padding: 5px 10px;
	width: 100%;
	height: 40px;
	border: 1px;
	border: 0;
	background-color: #fcfcfc;
	font-size: 1.6rem;
	line-height: 30px;
	border-radius: 0;
	box-sizing: border-box;
	cursor: pointer;
	border-bottom: 2px solid #00a000;
	vertical-align: top;
}
form select.frame {
	border: 2px solid #00a000;
}
select::-ms-expand {
	display: none;
}
select:-moz-focusring { 
	color: transparent; 
	text-shadow: 0 0 0 #828c9a;
}
.confirm form .selectwrap::after { display: none; }

form input[type=text],
form input[type=email] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	display: inline-block;
	padding: 3px 10px;
	width: 100%;
	background-color: #fcfcfc;
	border: 0;
	border-bottom: 2px solid #00a000;
	border-radius: 0;
	box-sizing: border-box;
	font-size: 1.8rem;
	line-height: 2.0;
}
form input[type=text].frame { border: 2px solid #00a000; }
form textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	display: inline-block;
	line-height: 2.0;
	width: 100%;
	font-size: 1.6rem;
	padding: 2px 10px;
	border: 0;
	border: 1px solid #00a000;
	border-radius: 6px;
	box-sizing: border-box;
}
form textarea { height: 360px; }
form input[type=submit],
input[type=button]  {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	display: inline-block;
	width: 100%;
	max-width: 180px;
	border: 0;
	background-color: #00a000;
	border-radius: 5px;
	color: #fff;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 32px;
	text-align: center;
	transition: all .3s;
	cursor: pointer;
}
form input[type=submit][disabled],
form input[type=button][disabled] { background-color: #ddd; }

form label { display: inline-block; margin-right: 20px; }
form label span { display: inline-block; margin-left: 4px; font-size: 1.6rem; }

@media screen and (min-width: 960px) {
	form input[type=submit]:hover { background-color: #fa9600; }
}
@media screen and (max-width: 767px) {
	form input[type=submit] { font-size: 1.6rem; line-height: 48px; }
	input[type=button] {
		max-width: 160px;
		font-size: 1.4rem;
		line-height: 32px;
	}
}
@media screen and (max-width: 419px) {
	form input[type=email] { font-size: 1.6rem; }
	form input[type=submit] { font-size: 1.4rem; line-height: 42px; }
	form input[type=submit],
	input[type=button] {
		max-width: 140px;
		font-size: 1.4rem;
		line-height: 28px;
	}
	form label span { display: inline-block; margin-left: 4px; font-size: 1.4rem; }
}



/* --------------------------------------------------- */
/* メール登録 */
/* --------------------------------------------------- */
.cp #cpcode .pgtitle {
	padding: 120px 0;
	background-color: #00a000;
}
.cp #cpcode .pgtitle .inner {
	position: relative;
	margin: 0 auto;
	padding: 60px 50px;
	width: 90%;
	max-width: 960px;
	border: 12px solid #fff;
	box-sizing: border-box;
}
.cp #cpcode .pgtitle .inner::before {
	content: '';
	position: absolute;
	top: 42px;
	left: -46px;
	display: block;
	width: 80px;
	height: 80px;
	background-color: #00a000;
	background-image: url('../image/cp/plus.png');
	background-repeat: no-repeat;
	background-size: 72px 72px;
	background-position: 50% 50%;
}
.cp #cpcode .pgtitle dl {
	display: table;
	width: 100%;
}
.cp #cpcode .pgtitle dl dt {
	width: 400px;
	float: left;
}
.cp #cpcode .pgtitle dl dd { margin-left: 400px; }
.cp #cpcode .pgtitle h1 {
	color: #fff;
	font-size: 3.2rem;
	font-weight: 500;
	line-height: 1.4;
	text-align: left;
}
.cp #cpcode .pgtitle h1 span { display: inline-block; }
.cp #cpcode .pgtitle p { color: #fff; font-size: 1.6rem; }

@media screen and (max-width: 959px) {
	.cp #cpcode .pgtitle { padding: 90px 0; }
	.cp #cpcode .pgtitle .inner { padding: 60px 30px 60px 40px; }
	.cp #cpcode .pgtitle dl dt {
		width: 320px;
		float: left;
	}
	.cp #cpcode .pgtitle dl dd { margin-left: 330px; }
	.cp #cpcode .pgtitle h1 { font-size: 2.8rem; }
}
@media screen and (max-width: 767px) {
	.cp #cpcode .pgtitle { padding: 60px 0; }
	.cp #cpcode .pgtitle .inner {
		padding: 40px 25px;
		border: 10px solid #fff;
	}
	.cp #cpcode .pgtitle .inner::before {
		top: -33px;
		left: -32px;
		width: 56px;
		height: 56px;
		background-size: 48px 48px;
	}
	.cp #cpcode .pgtitle dl dt {
		width: 100%;
		
		float: none;
	}
	.cp #cpcode .pgtitle dl dd { margin-left: 0; margin-top: 1.5em; }
	.cp #cpcode .pgtitle h1 { font-size: 2.4rem; text-align: center; }
}
@media screen and (max-width: 419px) {
	.cp #cpcode .pgtitle { padding: 40px 0; }
	.cp #cpcode .pgtitle .inner {
		padding: 25px 15px;
		border: 8px solid #fff;
	}
	.cp #cpcode .pgtitle .inner::before {
		top: -28px;
		left: -28px;
		width: 48px;
		height: 48px;
		background-size: 36px 36px;
	}
	.cp #cpcode .pgtitle h1 { font-size: 2.1rem; }
	.cp #cpcode .pgtitle p { color: #fff; font-size: 1.4rem; }
}


/* --------------------------------------------------- */
/* 流れ */
/* --------------------------------------------------- */
#flow { position: relative; }
#flow::after {
	content: '';
	position: absolute;
	top: 98%;
	left: 50%;
	display: block;
	width: 72px;
	height: 42px;
	background-image: url('../image/cp/ang.png');
	background-repeat: no-repeat;
	background-size: auto 100%;
	background-position: 50% 0;
	transform: translateX(-50%);
}
#flow .inner {
	margin: 0 auto 40px;
	width: 90%;
	max-width: 640px;
}
#flow .inner h2 {
	color: #00a000;
	font-size: 2.8rem;
	font-weight: 700;
	text-align: center;
}
#flow .inner p {
	margin-top: 1em;
	font-size: 1.6rem;
}
#flow ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	margin: 0 auto;
	width: 100%;
	max-width: 1040px;
}
#registmail #flow ul { max-width: 100%; }
#flow ul li {
	position: relative;
	width: 25%;
	box-sizing: border-box;
}
#flow ul dl {
	display: table;
	margin: 0 auto;
	width: 92%;
}
#flow ul dl figure {
	display: table;
	margin: 0 auto;
	padding: 10px;
	width: 80px;
	border: 2px solid #00a000;
	border-radius: 50%;
	box-sizing: border-box;
}
#flow ul dl figure img { width: 100%; height: auto; }
#flow ul dl h3 {
	color: #00a000;
	font-size: 1.6rem;
	font-weight: 500;
	text-align: center;
}
#flow ul dl p {
	font-size: 1.4rem;
	line-height: 1.4;
	text-align: center;
}
#flow ul dl p span { display: inline-block; }
/* ポジション */
#registmail #flow ul li:nth-child(2) dl figure { background-color: #e5f5e5; }
#mailregist #flow ul li:nth-child(2) dl figure { background-color: #e5f5e5; }
#cpcode #flow ul li:first-child dl figure { background-color: #e5f5e5; }
#customer #flow ul li:nth-child(3) dl figure { background-color: #e5f5e5; }
#complete #flow ul li:last-child dl figure { background-color: #e5f5e5; }

@media screen and (min-width: 768px) {
	#flow ul li { border-left: 1px solid #cceccc; }
	#flow ul li:first-child { border-left: 0; }
}
@media screen and (max-width: 767px) {
	#flow::after { height: 32px; }
	#flow .inner { margin: 0 auto 30px; }
	#flow .inner h2 { font-size: 2.4rem; }
	#flow ul { width: 94%; }
	#flow ul li::after {
		content: '▲';
		position: absolute;
		top: 24px;
		left: -4px;
		color: #00a000;
		font-size: 10px;
		transform: rotate(90deg) scale(0.8);
	}
	#flow ul li:first-child::after { display: none; }
	#flow ul dl { width: 98%; }
	#flow ul dl figure {
		padding: 6px;
		width: 64px;
	}
	#flow ul dl p { font-size: 1.2rem; }
}
@media screen and (max-width: 419px) {
	#flow::after { height: 24px; }
	#flow .inner { margin: 0 auto 10px; }
	#flow .inner h2 { font-size: 2.1rem; }
	#flow .inner p { font-size: 1.4rem; }
	#flow ul li::after {
		top: 16px;
		left: -3px;
		transform: rotate(90deg) scale(0.7);
	}
	#flow ul dl figure {
		padding: 6px;
		width: 48px;
		border: 0;
	}
	#flow ul dl h3 { font-size: 1.3rem; }
	#flow ul dl p { font-size: 1.0rem; line-height: 1.2; letter-spacing: 0; }
	#flow ul dl p span { display: block; transform: scale(0.9);}
}


/* --------------------------------------------------- */
/* 運営 */
/* --------------------------------------------------- */
#office .inner {
	margin: 0 auto;
	width: 90%;
	max-width: 420px;
	text-align: center;
}
#office .inner h2 {
	position: relative;
	width: 100%;
	border-top: 1px solid #00a000;
}
#office .inner h2 span {
	display: inline-block;
	padding: 0 1em;
	background-color: #fff;
	transform: translateY(-50%);
	color: #00a000;
	font-size: 1.6rem;
	font-weight: 500;
}
#office .inner h3 {
	font-size: 1.6rem;
	font-weight: 500;
}
#office .inner p { font-size: 1.4rem; font-weight: 500; }
#office .inner p a {
	font-size: 2.4rem;
	 font-weight: 700;
}
#office .inner p span { display: inline-block; }

@media screen and (max-width: 419px) {
	#office .inner h2 span {
		padding: 0 0.5em;
		font-size: 1.4rem;
	}
	#office .inner h3 { font-size: 1.4rem; }
	#office .inner p span { display: block; }
}


/* --------------------------------------------------- */
/* メール入力 */
/* --------------------------------------------------- */
#checkmail { background-color: #f0f9f0; }
#checkmail .inner {
	margin: 0 auto;
	width: 90%;
	max-width: 640px;
}
#checkmail .inner h2 {
	margin-bottom: 1.5em;
	font-size: 2.1rem;
	font-weight: 500;
	text-align: center;
	line-height: 1.6;
}
#checkmail .inner p { font-size: 1.6rem; }
#checkmail .inner p.caution {
	margin-top: 0.5em;
	font-size: 1.3rem;
}
#checkmail .inner p.caution em { color: #00a000; font-weight: 500; }
#checkmail .inputblock {
	position: relative;
	margin: 60px auto 0;
	padding: 60px 5%;
	width: 90%;
	max-width: 960px;
	background-color: #fff;
	border-radius: 5px;
	box-shadow: 2px 2px 20px rgba(0, 0, 0, 0.1);
	box-sizing: border-box;
}
#checkmail .inputblock h2 {
	display: table;
	margin: 0 auto 0.5em;
	padding-left: 72px;
	color: #00a000;
	font-size: 2.4rem;
	font-weight: 500;
	line-height: 64px;
	background-image: url('../image/cp/ic-mail.png');
	background-repeat: no-repeat;
	background-size: auto 100%;
	background-position: 0 50%;
}
#checkmail .inputblock h3 {
	position: absolute;
	top: 15px;
	left: -20px;
	width:  180px;
	border-bottom: 3px solid #00a000;
	color: #00a000;
	font-size: 2.4rem;
	font-weight: 700;
	text-align: center;
}
#checkmail form dl {
	display: table;
	margin: 0 auto;
	width: 100%;
	max-width: 640px;
}
#checkmail form dl dt {
	padding: 30px 0 0 0;
	float: left;
}
#checkmail form dl dd {
	margin-left: 120px;
	padding: 20px 0 0;
}
#checkmail form h4 {
	font-size: 1.6rem;
	font-weight: 500;
}
#checkmail form input[type=submit],
#checkmail form input[type=button] { background-color: #ff9900; }
#checkmail form input[type=submit][disabled],
#checkmail form input[type=button][disabled] { background-color: #ddd; }


@media screen and (max-width: 767px) {
	#checkmail .inner h2 { font-size: 1.8rem; }
	#checkmail .inputblock {
		margin: 40px auto 0;
		padding: 60px 5% 40px;
		box-shadow: 2px 2px 20px rgba(0, 0, 0, 0.1);
	}
	#checkmail .inputblock h2 {
		margin: 0 auto 0.5em;
		padding-left: 52px;
		font-size: 1.8rem;
		line-height: 48px;
	}
	#checkmail .inputblock h3 {
		top: 12px;
		left: -10px;
		width: 120px;
		border-bottom: 3px solid #00a000;
		font-size: 1.8rem;
	}
	#checkmail form dl dt {
		padding: 20px 0 0 0;
		float: left;
	}
	#checkmail form dl dd {
		margin-left: 60px;
		padding: 10px 0 0;
	}
	#checkmail form h4 { font-size: 1.4rem; }

}
@media screen and (max-width: 419px) {
	#checkmail .inner h2 {
		margin-bottom: 1.0em;
		font-size: 1.6rem;
	}
	#checkmail .inner p { font-size: 1.4rem; }
	#checkmail .inner p.caution {
		margin-top: 0.8em;
		font-size: 1.2rem;
	}
	#checkmail .inputblock {
		margin: 30px auto 0;
		padding: 50px 5% 20px;
		box-shadow: 2px 2px 12px rgba(0, 0, 0, 0.1);
	}
	#checkmail .inputblock h2 {
		margin: 0 auto;
		padding-left: 40px;
		font-size: 1.6rem;
		line-height: 36px;
	}
	#checkmail .inputblock h3 {
		top: 10px;
		left: -6px;
		width: 100px;
		border-bottom: 2px solid #00a000;
		font-size: 1.6rem;
	}
	#checkmail form dl dt { float: none; }
	#checkmail form dl dd {
		margin-left: 0;
		padding: 0 0 0;
	}
	#checkmail form h4 { font-size: 1.2rem; color: #555; }
	#checkmail form .btn-area { margin-top: 1.0em; }
	#checkmail form input[type=email] { font-size: 1.6rem; }
	#checkmail form input[type=submit],
	#checkmail form input[type=button] {
		max-width: 140px;
		line-height: 28px;
	}
}


/* --------------------------------------------------- */
/* メール登録完了 */
/* --------------------------------------------------- */
#mailcomplete { background-color: #f0f9f0; }
#mailcomplete .inner {
	margin: 0 auto;
	width: 90%;
	max-width: 640px;
}
#mailcomplete .inner h2 {
	margin-bottom: 1.5em;
	font-size: 2.1rem;
	font-weight: 500;
	text-align: center;
	line-height: 1.6;
}
#mailcomplete .inner h3 {
	position: relative;
	display: table;
	margin: 0 auto 1.5em;
	padding-left: 32px;
	text-align: center;
}
#mailcomplete .inner h3::before {
	content: '!';
	position: absolute;
	top: 50%;
	left: 0;
	display: block;
	width: 24px;
	background-color: #d00;
	border-radius: 50%;
	color: #fff;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 24px;
	transform: translateY(-50%);
}
#mailcomplete .inner h3 span { color: #d00; font-size: 1.6rem; font-weight: 700; }
#mailcomplete .inner .registed {
	margin-top: 1.5em;
	padding: 12px 12px;
	background-color: #fff;
	border-radius: 5px;
}
#mailcomplete .inner .registed h4 {
	color: #00a000; 
	font-size: 1.2rem;
	font-weight: 700;
}
#mailcomplete .inner h5 {
	margin: 2em 0 0.5em;
	font-size: 1.4rem;
	font-weight: 700;
}
#mailcomplete .inner p { font-size: 1.6rem; }
#mailcomplete .inner p.caution {
	font-size: 1.3rem;
}
#mailcomplete .inner p.caution em { color: #00a000; font-weight: 500; }

@media screen and (max-width: 767px) {
	#mailcomplete .inner h2 { font-size: 1.8rem; }
}
@media screen and (max-width: 419px) {
	#mailcomplete .inner h2 {
		margin-bottom: 1.0em;
		font-size: 1.6rem;
	}
	#mailcomplete .inner h3 {
		margin: 0 auto 1.0em;
		padding-left: 24px;
	}
	#mailcomplete .inner h3::before {
		width: 20px;
		font-size: 1.6rem;
		line-height: 20px;
	}
	#mailcomplete .inner h3 span { font-size: 1.4rem; }
	#mailcomplete .inner p { font-size: 1.4rem; }
	#mailcomplete .inner p.caution { font-size: 1.2rem; }
}


/* --------------------------------------------------- */
/* コード入力 */
/* --------------------------------------------------- */
#checkcode { background-color: #f0f9f0; }
#checkcode .inner {
	margin: 0 auto;
	width: 90%;
	max-width: 640px;
}
#checkcode .inner h2 {
	font-size: 2.1rem;
	font-weight: 500;
	text-align: center;
	line-height: 1.6;
}
#checkcode .inner h2 span { display: inline-block; }
#checkcode .inputblock {
	position: relative;
	margin: 60px auto 0;
	padding: 60px 5%;
	width: 90%;
	max-width: 960px;
	background-color: #fff;
	border-radius: 5px;
	box-shadow: 2px 2px 20px rgba(0, 0, 0, 0.1);
	box-sizing: border-box;
}
#checkcode .inputblock h2 {
	display: table;
	margin: 0 auto 0.5em;
	padding-left: 72px;
	color: #00a000;
	font-size: 2.4rem;
	font-weight: 500;
	line-height: 64px;
	background-image: url('../image/cp/ic-code.png');
	background-repeat: no-repeat;
	background-size: auto 100%;
	background-position: 0 50%;
}
#checkcode .inputblock h3 {
	position: absolute;
	top: 15px;
	left: -20px;
	width:  180px;
	border-bottom: 3px solid #00a000;
	color: #00a000;
	font-size: 2.4rem;
	font-weight: 700;
	text-align: center;
}
#checkcode form dl {
	display: table;
	margin: 0 auto;
	width: 100%;
	max-width: 640px;
}
#checkcode form dl dt {
	padding: 30px 0 0 0;
	float: left;
}
#checkcode form dl dd {
	margin-left: 120px;
	padding: 20px 0 0;
}
#checkcode form h4 {
	font-size: 1.6rem;
	font-weight: 500;
}
#checkcode form input[type=submit],
#checkcode form input[type=button] { background-color: #ff9900; }
#checkcode form input[type=submit][disabled],
#checkcode form input[type=button][disabled] { background-color: #ddd; }


@media screen and (max-width: 767px) {
	#checkcode .inner h2 { font-size: 1.8rem; }
	#checkcode .inputblock {
		margin: 40px auto 0;
		padding: 60px 5% 40px;
		box-shadow: 2px 2px 20px rgba(0, 0, 0, 0.1);
	}
	#checkcode .inputblock h2 {
		margin: 0 auto 0.5em;
		padding-left: 52px;
		font-size: 1.8rem;
		line-height: 48px;
	}
	#checkcode .inputblock h3 {
		top: 12px;
		left: -10px;
		width: 120px;
		border-bottom: 3px solid #00a000;
		font-size: 1.8rem;
	}
	#checkcode form dl dt {
		padding: 20px 0 0 0;
		float: left;
	}
	#checkcode form dl dd {
		margin-left: 90px;
		padding: 10px 0 0;
	}
	#checkcode form h4 { font-size: 1.4rem; }

}
@media screen and (max-width: 419px) {
	#checkcode .inner h2 { font-size: 1.6rem; }
	#checkcode .inputblock {
		margin: 30px auto 0;
		padding: 50px 5% 20px;
		box-shadow: 2px 2px 12px rgba(0, 0, 0, 0.1);
	}
	#checkcode .inputblock h2 {
		margin: 0 auto;
		padding-left: 40px;
		font-size: 1.6rem;
		line-height: 36px;
	}
	#checkcode .inputblock h3 {
		top: 10px;
		left: -6px;
		width: 100px;
		border-bottom: 2px solid #00a000;
		font-size: 1.6rem;
	}
	#checkcode form dl dt { float: none; }
	#checkcode form dl dd {
		margin-left: 0;
		padding: 0 0 0;
	}
	#checkcode form h4 { font-size: 1.2rem; color: #555; }
	#checkcode form .btn-area { margin-top: 1.0em; }
	#checkcode form input[type=text] { font-size: 1.6rem; }
	#checkcode form input[type=submit],
	#checkcode form input[type=button] {
		max-width: 140px;
		line-height: 28px;
	}
}

/* エラー表示 */
/* --------------------------------------------------- */
#error {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 888;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.5);
	transition: all .5s;
}
#error .msgblock {
	position: absolute;
	top: 50%;
	left: 50%;
	display: block;
	padding: 25px 4%;
	width: 86%;
	max-width: 480px;
	background-color: #fff;
	border-radius: 5px;
	box-sizing: border-box;
	box-shadow: 3px 3px 15px rgba(0, 0, 0, 0.15);
	transform: translate(-50%, -50%);
}
#error .msgblock button {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	display: table;
	margin: 1.0em auto 0;
	width: 100%;
	max-width: 100px;
	border: 0;
	background-color: #00a000;
	border-radius: 5px;
	color: #fff;
	font-size: 1.3rem;
	font-weight: 700;
	line-height: 21px;
	text-align: center;
	transition: all .3s;
	cursor: pointer;

}




/* --------------------------------------------------- */
/* 有効期限切れ */
/* --------------------------------------------------- */
#timeout { background-color: #f0f9f0; }
#timeout .inner {
	margin: 0 auto;
	width: 90%;
	max-width: 640px;
}
#timeout .inner h2 {
	margin-bottom: 1.5em;
	font-size: 2.1rem;
	font-weight: 500;
	text-align: center;
	line-height: 1.6;
}
#timeout .inner h2 span { display: inline-block; }
#timeout .inner h3 {
	position: relative;
	display: table;
	margin: 0 auto 1.5em;
	padding-left: 32px;
	text-align: center;
}
#timeout .inner h3::before {
	content: '!';
	position: absolute;
	top: 50%;
	left: 0;
	display: block;
	width: 24px;
	background-color: #d00;
	border-radius: 50%;
	color: #fff;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 24px;
	transform: translateY(-50%);
}
#timeout .inner h3 span { color: #d00; font-size: 1.6rem; font-weight: 700; }
#timeout .inner p { font-size: 1.6rem; }
#timeout .inner p.caution {
	margin-top: 1.5em;
	font-size: 1.3rem;
}

@media screen and (max-width: 767px) {
	#timeout .inner h2 { font-size: 1.8rem; }
}
@media screen and (max-width: 419px) {
	#timeout .inner h2 {
		margin-bottom: 1.0em;
		font-size: 1.6rem;
	}
	#timeout .inner h3 {
		margin: 0 auto 1.0em;
		padding-left: 24px;
	}
	#timeout .inner h3::before {
		width: 20px;
		font-size: 1.6rem;
		line-height: 20px;
	}
	#timeout .inner h3 span { font-size: 1.4rem; }
	#timeout .inner p { font-size: 1.4rem; }
	#timeout .inner p.caution { font-size: 1.2rem; }
}


/* --------------------------------------------------- */
/* お客様情報 */
/* --------------------------------------------------- */
#entry { background-color: #f0f9f0; }
#entry .inner {
	margin: 0 auto;
	width: 90%;
	max-width: 640px;
}
#entry .inner h2 {
	margin-bottom: 1.5em;
	font-size: 2.1rem;
	font-weight: 500;
	text-align: center;
	line-height: 1.6;
}
#entry .inner h2 span { display: inline-block; }
#entry .inner p { font-size: 1.6rem; }
#entry .inner p.caution {
	margin-top: 0.5em;
	font-size: 1.3rem;
}
#entry .inner p.caution em { color: #00a000; font-weight: 500; }
#entry .inputblock {
	position: relative;
	margin: 60px auto 0;
	padding: 60px 5%;
	width: 90%;
	max-width: 960px;
	background-color: #fff;
	border-radius: 5px;
	box-shadow: 2px 2px 20px rgba(0, 0, 0, 0.1);
	box-sizing: border-box;
}
#entry .inputblock h2 {
	display: table;
	margin: 0 auto 0.5em;
	padding-left: 72px;
	color: #00a000;
	font-size: 2.4rem;
	font-weight: 500;
	line-height: 64px;
	background-image: url('../image/cp/ic-edit.png');
	background-repeat: no-repeat;
	background-size: auto 100%;
	background-position: 0 50%;
}
#entry .inputblock h3 {
	position: absolute;
	top: 15px;
	left: -20px;
	width:  180px;
	border-bottom: 3px solid #00a000;
	color: #00a000;
	font-size: 2.4rem;
	font-weight: 700;
	text-align: center;
}
#entry form dl {
	display: table;
	margin: 0 auto;
	width: 100%;
	max-width: 800px;
}
#entry form dl dt {
	padding: 40px 0 0 0;
	float: left;
}
#entry form dl dd {
	margin-left: 180px;
	padding: 30px 0 0;
}
#entry form h4 {
	font-size: 1.6rem;
	font-weight: 500;
}
#entry form h4.required::after {
	content: '必須';
	display: inline-block;
	margin: 0 0 0 6px;
	padding: 0 0.5em;
	background-color: #ff9900;
	border-radius: 3px;
	color: #fff;
	font-size: 1.0rem;
	line-height: 1.4;
}
#entry form h5 {
	position: relative;
	margin-top: 3em;
	padding-left: 18px;
	font-size: 1.4rem;
}
#entry form h5::before {
	content: '';
	position: absolute;
	top: 6px;
	left: 0;
	display: block;
	width: 12px;
	height: 12px;
	background-color: #00a000;
	border-radius: 50%;
}
#entry form h5 a { color: #00a000; font-weight: 500; }
#entry form input[type=submit],
#entry form input[type=button] { background-color: #ff9900; }
#entry form input[type=submit][disabled],
#entry form input[type=button][disabled] { background-color: #ddd; }
#entry form dl dd > div.parallel { padding: 10px 0; }


@media screen and (max-width: 767px) {
	#entry .inner h2 { font-size: 1.8rem; }
	#entry .inputblock {
		margin: 40px auto 0;
		padding: 60px 5% 40px;
		box-shadow: 2px 2px 20px rgba(0, 0, 0, 0.1);
	}
	#entry .inputblock h2 {
		margin: 0 auto 0.5em;
		padding-left: 52px;
		font-size: 1.8rem;
		line-height: 48px;
	}
	#entry .inputblock h3 {
		top: 12px;
		left: -10px;
		width: 120px;
		border-bottom: 3px solid #00a000;
		font-size: 1.8rem;
	}
	#entry form dl dt {
		padding: 20px 0 0 0;
		float: left;
	}
	#entry form dl dd {
		margin-left: 160px;
		padding: 10px 0 0;
	}
	#entry form h4 { font-size: 1.4rem; }
	#entry form h5 { margin-top: 2em; }
}
@media screen and (max-width: 639px) {
	#entry form dl dt { float: none; }
	#entry form dl dd {
		margin-left: 0;
		padding: 0 0 0;
	}
}
@media screen and (max-width: 419px) {
	#entry .inner h2 {
		margin-bottom: 1.0em;
		font-size: 1.6rem;
	}
	#entry .inner p { font-size: 1.4rem; }
	#entry .inner p.caution {
		margin-top: 0.8em;
		font-size: 1.2rem;
	}
	#entry .inputblock {
		margin: 30px auto 0;
		padding: 50px 5% 20px;
		box-shadow: 2px 2px 12px rgba(0, 0, 0, 0.1);
	}
	#entry .inputblock h2 {
		margin: 0 auto;
		padding-left: 40px;
		font-size: 1.6rem;
		line-height: 36px;
	}
	#entry .inputblock h3 {
		top: 10px;
		left: -6px;
		width: 100px;
		border-bottom: 2px solid #00a000;
		font-size: 1.6rem;
	}
	#entry form h4 { font-size: 1.2rem; color: #555; }
	#entry form .btn-area { margin-top: 1.0em; }
	#entry form input[type=email] { font-size: 1.6rem; }
	#entry form input[type=submit],
	#entry form input[type=button] {
		max-width: 140px;
		line-height: 28px;
	}
}


/* 契約番号 */
#entry form .certificate p {
	width: 100%;
	margin-bottom: 0.5em;
	font-size: 1.2rem;
}
#entry form .certificate input[type=text] {
	border: 2px solid #00a000;
}
#entry form .certificate input:nth-child(2) { width: 42px; }
#entry form .certificate input:nth-child(4) { width: 54px; }
#entry form .certificate input:nth-child(6) { width: 90px; }
#entry form .certificate input:nth-child(8) { width: 32px; }
#entry form .certificate span {
	display: inline-block;
	padding: 0 0 0 0.2em;
	font-size: 1.8rem;
	font-weight: 500;
}
@media screen and (max-width: 419px) {
	#entry form .certificate input:nth-child(2) { width: 40px; }
	#entry form .certificate input:nth-child(4) { width: 52px; }
	#entry form .certificate input:nth-child(6) { width: 80px; }
	#entry form .certificate span { font-size: 1.6rem; }
}
/* 日付 */
	@media screen and (max-width: 419px) {
		#entry form .selectwrap:nth-child(2),
		#entry form .selectwrap:nth-child(3) {
			width: 72px;
		}
	}
	/* 名前 */
	#entry form .shimei { display: table; width: 100%; }
#entry form .shimei div { display: inline-block; width: 50%; float: left; }
#entry form .shimei span {
	display: inline-block;
	font-size: 1.2rem;
	text-align: center;
}
#entry form .shimei input { display: inline-block;width: calc(100% - 32px); }

/* 電話番号 */
#entry form .phone p {
	display: block;
	margin-top: 0.5em;
	font-size: 1.2rem;
}
#entry form .phone input { max-width: 240px; }
/* 支社名 */
#entry form .branch input { max-width: 240px; }
/* 担当者 */
#entry form .salesman { display: table; width: 100%; }
#entry form .salesman div { display: inline-block; width: 50%;}
#entry form .salesman  span {
	display: inline-block;
	width: 48px;
	font-size: 1.2rem;
	text-align: center;
}
#entry form .salesman input { width: calc(100% - 54px); }

/* QUO */
#entry .quo {
	margin-top: 20px;
	padding: 20px 4%;
	background-color: #f9f9f9;
}
#entry form .quo h3 {
	font-size: 1.4rem;
	font-weight: 500;
}
#entry form .quo p {
	position: relative;
	padding-left: 16px;
	font-size: 1.2rem;
}
#entry form .quo p::before {
	content: '●';
	position: absolute;
	top: 0;
	left: 0;
}
#entry form .quo p em { color: #d00; }
#entry form .quo p a { color: #00a000; text-decoration: underline; }
@media screen and (max-width: 419px) {
	#entry form .quo h4 {
		color: #111;
		font-size: 1.3rem;
	}
	#entry form .quo p {
		margin-top: 1em;
		font-size: 1.1rem;
	}
}


/* 住所 */
#entry form .zip span { margin-right: 4px; }
#entry form .zip input { max-width: 100px; }
#entry form .state input { max-width: 140px; }
/* メール */
#entry form .sended p { color: #00a000;	font-size: 1.8rem; }
#entry form .sended p.note { margin-top: 0.3em; color: #111; font-size: 1.2rem; }
#entry form .sended p.note a { color: #00a000; text-decoration: underline; }

/* 同意 */
#entry form .approval {
	margin: 30px auto 0;
	max-width: 480px;
}
#entry form .approval label { display: table; width: 100%; }
#entry form .approval label input { margin-top: 8px; float: left; }
#entry form .approval label p { margin-left: 30px; font-size: 1.6rem; }
@media screen and (max-width: 419px) {
	#entry form .approval { margin: 20px auto 0; }
	#entry form .approval label input { margin-top: 6px; }
	#entry form .approval label p { margin-left: 20px; font-size: 1.3rem; }
}
/* 個人情報 */
#entry .privacy {
	margin-top: 30px;
	padding: 30px 4%;
	background-color: #f9f9f9;
}
#entry form .privacy h4 {
	font-size: 1.4rem;
	font-weight: 500;
	text-align: center;
}
#entry form .privacy p {
	margin-top: 1em;
	font-size: 1.3rem;
}
@media screen and (max-width: 419px) {
	#entry .privacy {
		margin-top: 20px;
		padding: 20px 4%;
	}
	#entry form .privacy h4 {
		color: #111;
		font-size: 1.3rem;
	}
	#entry form .privacy p {
		margin-top: 1em;
		font-size: 1.1rem;
	}
}

/* モーダル */
#entry a.modal-link i {
	display: inline-block;
	width: 1.5em;
	height: 1.6em;
	vertical-align: middle;
	background-image: url('../image/cp/ic-zoom.png');
	background-repeat: no-repeat;
	background-size: 86% auto;
	background-position: 50% 50%;
}


/* --------------------------------------------------- */
/* 確認画面 */
/* --------------------------------------------------- */
#entry form.comfirm dl dt { padding: 35px 0 0 0; }
#entry form.comfirm dl dd {
	margin-left: 0;
	padding: 30px 0 20px 180px;
	border-bottom: 1px solid #cceccc;
}
#entry form.comfirm dl dd > div {
	min-height: 24px;
	box-sizing: border-box;
}
#entry form.comfirm h4 {
	font-size: 1.4rem;
	font-weight: 500;
}
#entry form.comfirm dl dd p {
	display: inline-block;
	font-size: 1.8rem;
	line-height: 1.8;
}

/* 担当社 */
#entry form.comfirm dl dd p.sales { margin-right: 15px; }
/* 住所 */
#entry form.comfirm dl dd p.zip { display: block; }

/* ボタン */
#entry form.comfirm input[type=button].hisback { background-color: #999; }
#entry form.comfirm input[type=submit],
#entry form.comfirm input[type=button] { margin: 0 4px; }



@media screen and (max-width: 767px) {
	#entry form.comfirm dl dt {
		padding: 20px 0 0 0;
		float: left;
	}
	#entry form.comfirm dl dd {
		margin-left: 0;
		padding: 20px 0 15px 110px;
	}
	#entry form.comfirm dl dd > div {
		min-height: 32px;
		box-sizing: border-box;
	}
	#entry form.comfirm h4 { color: #666; font-size: 1.3rem; }
	#entry form.comfirm dl dd p {
		font-size: 1.6rem;
		line-height: 1.6;
	}
	#entry form.comfirm input[type=submit],
	#entry form.comfirm input[type=button] { max-width: 140px; }
}
@media screen and (max-width: 419px) {
	#entry form.comfirm dl dt { padding: 15px 0 0 0; float: none; }
	#entry form.comfirm dl dd { padding: 0 0 15px 16px; }
	#entry form.comfirm dl dd > div { min-height: 0; }
	#entry form.comfirm h4 { color: #777; font-size: 1.2rem; }
	#entry form.comfirm h5 { margin-top: 2em; }
	#entry form.comfirm dl dd p {
		font-size: 1.6rem;
		line-height: 1.4;
	}
	#entry form.comfirm input[type=submit],
	#entry form.comfirm input[type=button] { margin: 0 2px; max-width: 110px; }
}


/* --------------------------------------------------- */
/* お申し込み完了 */
/* --------------------------------------------------- */
#thanks { background-color: #f0f9f0; }
#thanks .inner {
	margin: 0 auto;
	width: 90%;
	max-width: 640px;
}
#thanks .inner h2 {
	margin-bottom: 1.5em;
	color: #00a000;
	font-size: 2.4rem;
	font-weight: 500;
	text-align: center;
	line-height: 1.6;
}
#thanks .inner h3 {
	margin-bottom: 1.0em;
	background-color: #fff;
	border-radius: 32px;
	color: #00a000;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 64px;
	text-align: center;
}
#thanks .inner h3 br { display: none; }
#thanks .inner p { font-size: 1.6rem; }
#thanks form input[type=submit],
#thanks input[type=button]  { font-size: 1.6rem; }

@media screen and (max-width: 767px) {
	#thanks .inner h2 { font-size: 2.1rem; }
	#thanks .inner h3 { font-size: 1.6rem; }
}
@media screen and (max-width: 419px) {
	#thanks .inner h2 {
		margin-bottom: 1.0em;
		font-size: 1.8rem;
	}
	#thanks .inner h3 {
		margin-bottom: 1.0em;
		padding: 8px 0;
		border-radius: 32px;
		line-height: 24px;
	}
	#thanks .inner h3 br { display: inline; }
	#thanks .inner p { font-size: 1.4rem; }
	#thanks form input[type=submit],
	#thanks input[type=button]  { font-size: 1.4rem; }
}
