@charset "UTF-8";
/* 
	
CSS form.css */



/*
base #191919
purple : #7c61a7
*/


/*//////////////////


フォーム設定


//////////////////*/

form input[type="text"],
form input[type="tel"],
form input[type="email"],
form input[type="password"] { border: none !important; background: #f7f7f7 !important; line-height: 2; padding: 18px 15px; font-size: 100%; height: 70px; width: 100%; transition: 0.3s; }
form input[type="text"]:focus,
form input[type="tel"]:focus,
form input[type="email"]:focus,
form input[type="password"]:focus { background: #eee!important; }
form input[type="text"]:read-only,
form input[type="tel"]:read-only,
form input[type="email"]:read-only,
form input[type="password"]:read-only { background: #eee!important; }

form input[type="file"] { padding: 3px 5px; font-size: 100%; height: 30px; }
form input[type="file"]:read-only { background: #eee; }

form input[type="checkbox"] { width: 16px; height: 16px; background-color: #fff!important; cursor: pointer; vertical-align: -2px; border:1px solid #ccc; background-size: 16px 16px!important; font-size: 0; transition: 0.3s; margin-right: 5px; }
form input[type="checkbox"].checked,
form input[type="checkbox"]:checked { background-color: #191919!important; border:1px solid #191919; }
form input[type="checkbox"].checked:before,
form input[type="checkbox"]:checked:before,
form input[type="checkbox"].checked:after,
form input[type="checkbox"]:checked:after { content:none!important; }

form input[type="radio"] { width: 18px; height: 18px; border-radius: 50%; background-color: #fff!important; cursor: pointer; vertical-align: -3px; border:1px solid #ccc; background-size: 18px 18px!important; font-size: 0; transition: 0.3s; margin-right: 5px; }
form input[type="radio"].checked,
form input[type="radio"]:checked { background-color: #191919!important; border:1px solid #191919; }
form input[type="radio"].checked:before,
form input[type="radio"]:checked:before,
form input[type="radio"].checked:after,
form input[type="radio"]:checked:after { content:none!important; }
/* form input[type="radio"]:read-only { background-color: #fff!important; border:1px solid #ccc; } */

form select { font-size: 100%; height: 70px; padding: 10px 20px; background: url("../img/common/arr2.svg") no-repeat 90% center, #f7f7f7; border: none !important; background-size: 12px 8px; }
form select.readonly { background: url("../img/common/arr2.svg") no-repeat 95% center, #eee; }

/* form label { font-size: 0.93em; font-weight: bold; } */
form textarea { border: none!important; background: #f7f7f7!important; padding: 18px 15px; font-size: 100%; height: 360px; width: 100%; resize: vertical; display: block; transition: 0.3s; font-family: 'Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;}
form textarea:focus { background: #eee!important; }
form textarea:read-only { background: #eee; }

form .short { width: 300px!important;}
form .middle { width: 500px!important;}
@media screen and (max-width: 767px) {
	form input[type="text"],
	form input[type="tel"],
	form input[type="email"],
	form input[type="password"] { padding: 18px 15px; height: 60px; }
	form select{ height: 60px; padding-left: 15px; padding-right: 15px; }
	form .short { width: 100%!important;}
	form .middle { width: 100%!important;}

	form textarea{ height: 260px; }
}


/* 赤字 */
ul.ermsg { margin: 60px 0 100px; color: #191919; }
ul.ermsg li { padding-left: 1em!important; text-indent: -1em; margin-bottom: 10px; font-weight: bold; }
ul.ermsg li:before { content:"●"!important; color: #ff0000; font-size: 0.7em; margin-right: 0.3em; }
p.ermsg{ color: #BD0A0F; }
.required { color: #fff; background: #191919; font-size: 1.4rem; display: inline-block; margin-left: 10px; line-height: 1; vertical-align: 1px; padding: 5px 10px;  }
@media screen and (max-width: 767px) {
	ul.ermsg { margin: 40px 0; }
	ul.ermsg li {  }
}




.policybox{ margin-top: 60px; }
.policymainbox{overflow-y: auto;height: 270px;padding: 40px 6%;background: #f8f8f8;box-sizing: border-box; margin-bottom: 60px; }
.policymainbox .copy{ text-align: center; }
.policymainbox .list>li{ margin-bottom: 30px; }
.policymainbox .list>li:last-child{ margin-bottom: 0; }
.policymainbox .list>li>ul>li{ margin-top: 20px; }
.policybox .privacycheck{ text-align: center; }
.policybox .privacycheck label{ position: relative; display: inline-block;padding-left: 25px; line-height: 1.8; }
.policybox .privacycheck label a{ text-decoration: underline; }
.policybox .privacycheck label a:hover{ text-decoration: none; opacity: 0.8; }
@media screen and (max-width: 767px) {
	.policymainbox{ margin-bottom: 40px; }
	.policymainbox{padding: 30px 8%; }
	.policymainbox .list>li{ margin-bottom: 20px; }
	.policymainbox .list>li>ul>li{ margin-top: 15px; }
	.policybox .privacycheck{ padding-left: 1.6em!important; text-indent: -1.6em;  }
}
@media screen and (max-width: 500px) {
	.policybox .privacycheck{ text-align: left; }
}

.btnarea{ margin-top: 70px; text-align: center; margin-left: -10px; margin-bottom: -10px; }
.btnarea .btn{font-size: 1.6rem;font-family: 'Red Hat Display', sans-serif;letter-spacing: 0.1em;display: inline-block;background: #191919;color: #fff;border-radius:40px;line-height:68px;max-width: 300px;text-align: center;text-decoration: none!important;position: relative;width: calc(50% - 10px);margin-left: 10px;margin-bottom: 10px;}
.btnarea .btn:hover { background: #f0f0f0; color: #191919; font-size: 1.8rem; }
@media screen and (max-width: 767px) {
	.btnarea{ margin-top: 50px; margin-left:0; }
	.btnarea .btn { font-size: 1.4rem; border-radius:30px; line-height:50px; margin-left:0;  }
}
@media screen and (max-width: 400px) {
	.btnarea .btn { font-size: 1.4rem; border-radius:30px; line-height:50px; width: 100%; box-sizing:border-box;}
}



