@charset "UTF-8";

/*共通
---------------------------------------------------------*/
.contentpage #pagebody {
	margin-bottom: 80px;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.contentpage #pagebody {
	margin-bottom: 40px;
}
.box02.in_box {
	padding: 0;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.contentpage #pagebody {
	margin-bottom: 0;
}
.box02.in_box {
	padding: 0;
}
}



/*導入、個人情報、レイアウト
---------------------------------------------------------*/
.box01 strong {
	font-size: 110%;
}
.must {
	color: #FF0000;
}

.privacy {
	margin-top: 50px;
	background: #eeebe3;
	padding: 30px 4%;
}
.privacy h4 {
	color: #a18d51;
	font-size: 110%;
	font-weight: 500;
	letter-spacing: .1em;
	line-height: 1.6em;
	cursor: pointer;
	text-align: center;
}
.privacy h4 i {
	margin-left: .4em;
}
.privacy .open_box {
	padding-top: 1.0em;
	display: none;
}

.tbl_form {
	width: 100%;
	border-top: 1px solid rgba(217,209,185,0.80);
	margin-bottom: 30px;
}
.tbl_form th,
.tbl_form td {
	text-align: left;
	vertical-align: top;
	box-sizing: border-box;
	border-bottom: 1px solid rgba(217,209,185,0.80);
}
.tbl_form th,
.tbl_form td > div,
.kakunin_box td {
	padding: 1.4em 1.0em;
	box-sizing: border-box;
}
.tbl_form th {
	background: #eeebe3;
	width: 14em;
	font-size: 100%;
	font-weight: 500;
	letter-spacing: normal;
	line-height: 1.6em;
}
.tbl_form td {
	width: calc(100% - 14em);
}
.tbl_form td > div,
.kakunin_box td {
	font-size: 100%;
	letter-spacing: .05em;
	line-height: 1.8em;
}
.tbl_form td dt {
	font-size: 110%;
	font-weight: 500;
	letter-spacing: .2em;
	line-height: 1.4em;
	margin-bottom: .2em;
}
.tbl_form td dd {
	margin-bottom: 1.5em;
}
.tbl_form td dd:last-child {
	margin-bottom: 0;
}
.tbl_form .kakunin {
	margin: 1.5em 0 .5em;
}

/* ボタンレイアウト */
.submit_box {
	width: 100%;
	margin: 60px auto 0;
	text-align: center;
	font-size: 100%;
	letter-spacing: .15em;
	line-height: 2.0em;
}
.submit_box p {
	margin-bottom: 100px;
}
.submit_box ul {
	max-width: 600px;
	margin: 0 auto;
	text-align: center;
}
.submit_box li {
	width: 48%;
	display: inline-block;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.privacy {
	margin-top: 4%;
	padding: 4%;
}
	
.tbl_form {
	margin-bottom: 3%;
}
	
/* ボタンレイアウト */
.submit_box {
	margin-top: 5%;
}
.submit_box p {
	margin-bottom: 8%;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.privacy {
	margin-top: 6%;
	padding: 6% 4%;
}
.privacy .open_box {
	padding-top: .4em;
}
	
.tbl_form tr,
.tbl_form th,
.tbl_form td {
	display: block;
}
.tbl_form th {
	width: 100%;
	padding: 1.0em 3%;
	border-bottom: none;
}
.tbl_form td {
	width: 100%;
}
.tbl_form td > div,
.kakunin_box td {
	padding: 1.0em 3%;
}
.tbl_form .kakunin {
	line-height: 1.6em;
}
	
/* ボタンレイアウト */
.submit_box {
	margin-top: 8%;
	font-size: 100%;
	letter-spacing: .05em;
	line-height: 1.8em;
}
.submit_box p {
	margin-bottom: 10%;
	text-align: left;
	letter-spacing: normal;
}
.submit_box ul {
	display: block;
}
.submit_box li:first-child,
.submit_box li:last-child {
	width: 100%;
	margin-bottom: 10px;
}
}



/* 入力項目デザイン
-----------------------------------------------------------------------------*/
.tbl_form .max_txt {
	width: 100%;
}
.tbl_form .other_col {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: center;
    align-items: center;
	padding-top: .8em;
}
.tbl_form .other_col li:first-child {
	width: 5em;
}
.tbl_form .other_col li:last-child {
	width: calc(100% - 6em);
}
.tbl_form .check_list {
	margin-left: -2.0em;
}
.tbl_form .check_list li {
	float: left;
	margin-left: 2.0em;
}
.tbl_form .check_list2 li {
	width: 48%;
	float: left;
}
.tbl_form .check_list2 li:nth-child(even) {
	float: right;
}
.tbl_form .parts_list {
	margin-left: -3.3333%;
}
.tbl_form .parts_list li {
	float: left;
	width: 30%;
	margin-left: 3.3333%;
}
.tbl_form .parts_list li.large_row {
	width: 63.3333%;
}
.tbl_form .date_box dd ul {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
    -webkit-align-items: center;
    align-items: center;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}
.tbl_form .date_box dd li {
	margin-bottom: .5em;
}
.tbl_form .date_box dd li:first-child {
	margin-right: 1.0em;
}
.tbl_form .date_box dd ul img {
	vertical-align: middle;
}
/********************/
/* テキストボックス */
/********************/
input[type="text"] {
	padding: 12px 5px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	background: #fff;
	outline: none;
	border: solid 1px #ccc;
	border-radius: 0;
	-webkit-appearance: none;
	font-size: 16px;
	letter-spacing: .05em;
}
textarea {
	height: 12em;
	padding: 12px 5px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	background: #fff;
	outline: none;
	border: solid 1px #ccc;
	border-radius: 0;
	-webkit-appearance: none;
	font-size: 16px;
	letter-spacing: .05em;
}
/****************/
/* ラジオボタン */
/****************/
input[type=radio], input[type=checkbox] {
	display: inline-block;
	margin-right: 10px;
}
input[type=radio] + label, input[type=checkbox] + label {
	position: relative;
	display: inline-block;
	cursor: pointer;
	font-weight: 500;
}

@media (min-width: 1px) {
input[type=radio],  input[type=checkbox] {
	/*display: none;*/
	position: absolute;		/* 上に別の要素が乗るようにする */
	z-index: -1;			/* 最背面にする */
	pointer-events: none;	/* クリック無効 */
	visibility: hidden;		/* 非表示 */
	margin: 0;
}
input[type=radio] + label,  input[type=checkbox] + label {
	padding: 0 0 0 30px;
}
input[type=radio] + label::before,  input[type=checkbox] + label::before {
	content: "";
	position: absolute;
	top: 7px;
	left: 0;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	display: block;
	width: 20px;
	height: 20px;
	background: #fff;
}
input[type=radio] + label::before {
	border: #c4c2c2 1px solid;
	border-radius: 30px;
}
input[type=checkbox] + label::before {
	border: #c4c2c2 1px solid;
	border-radius: 0;
}
input[type=radio]:checked + label::after,  input[type=checkbox]:checked + label::after {
	content: "";
	position: absolute;
	top: 12px;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	display: block;
}
input[type=radio]:checked + label::after {
	left: 5px;
	width: 10px;
	height: 10px;
	background: #f29faf;
	border-radius: 8px;
}
input[type=checkbox]:checked + label::after {
	left: 3px;
	width: 16px;
	height: 8px;
	margin-top: -3px;
	border-left: 3px solid #f29faf;
	border-bottom: 3px solid #f29faf;
	-webkit-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
}
/******************/
/* コンボボックス */
/******************/
select {
	margin-top: 5px;
	font-size: 16px;
	letter-spacing: .05em;
	border: 1px solid #E0D9D6;
	background-color: #fff;
}
/**********/
/* ボタン */
/**********/
input[type="submit"], input[type="button"], input[type="reset"] {
	-webkit-appearance: none;
	width: 100%;
	height: 70px;
	border: none;
	cursor: pointer;
	border-radius: 0;
	font-size: 110%;
	color: #fff;
	font-weight: normal;
	letter-spacing: .1em;
	line-height: 1.0em;
}
input[type="submit"] {
	background-color: #f29faf;
}
input[type="button"], input[type="reset"] {
	background-color: #939393;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.tbl_form .other_col {
	display: block;
	padding-top: 0;
}
.tbl_form .other_col li:first-child,
.tbl_form .other_col li:last-child {
	width: 100%;
}
.tbl_form .other_col li:first-child {
	margin-bottom: .4em;
}
.tbl_form .parts_list {
	margin-left: -4%;
}
.tbl_form .parts_list li {
	width: 46%;
	margin-left: 4%;
}
.tbl_form .parts_list li.large_row {
	width: 94%;
}
	
input[type=radio] + label::before,  input[type=checkbox] + label::before {
	top: 5px;
}
input[type=radio]:checked + label::after,  input[type=checkbox]:checked + label::after {
	top: 10px;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.tbl_form .check_list2 li {
	width: 100%;
	float: none;
}
.tbl_form .check_list2 li:nth-child(even) {
	float: none;
}
.tbl_form .check_list {
	margin-left: -1.0em;
}
.tbl_form .check_list li {
	margin-left: 1.0em;
}
.tbl_form .other_col {
	display: block;
	padding-top: 0;
}
.tbl_form .other_col li:first-child,
.tbl_form .other_col li:last-child {
	width: 100%;
}
.tbl_form .other_col li:first-child {
	margin-bottom: .4em;
}
.tbl_form .parts_list {
	margin-left: -4%;
}
.tbl_form .parts_list li {
	width: 46%;
	margin-left: 4%;
}
.tbl_form .parts_list li.large_row {
	width: 94%;
}
/********************/
/* テキストボックス */
/********************/
input[type="text"] {
	padding: 10px 5px;
}
textarea {
	padding: 10px 5px;
}
input[type="submit"], input[type="button"], input[type="reset"] {
	height: 60px;
}
	
input[type=radio] + label::before,  input[type=checkbox] + label::before {
	top: 5px;
}
input[type=radio]:checked + label::after,  input[type=checkbox]:checked + label::after {
	top: 10px;
}
}



/* 確認画面、完了ページ
-----------------------------------------------------------------------------*/
.err_box {
	text-align: center;
	color: #FF0000;
	font-weight: bold;
}
.txt_kakunin {
	text-align: center;
	font-weight: bold;
	margin-bottom: 1.5em;
}

.thanks .txt_strong {
color: #a18d51;
font-size: 120%;
font-weight: 500;
letter-spacing: .1em;
line-height: 1.6em;
margin-bottom: 1.0em;
}

.thanks strong {
	color: #666666;
	font-size: 110%;
	font-weight: bold;
	letter-spacing: .1em;
	line-height: 1.6em;
}
.thanks .btn_link {
	margin-top: 3.0em;
}
.thanks .btn_link a {
	display: inline-block;
	background: #ed778d;
	text-align: center;
	color: #fff;
	font-size: 120%;
	font-weight: bold;
	letter-spacing: .2em;
	line-height: 1.2em;
	padding: 1.5em 2.5em;
	transition: all 1.0s;
}
.thanks .btn_link a:hover {
	transition: all 0.4s;
	opacity: 0.6;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
}
