@charset "utf-8";

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

	--common.css--

	0. BoxModel change

	1. Common setting
		1-1. Reset styles
		1-2. BoxModel styles
		1-3. Text styles
		1-4. Contact styles
		1-5. Heading styles
		1-6. Button styles
		1-7. List styles

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

/*==================================================================
	0. BoxModel change
===================================================================*/
*, *:before, *:after {
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

/*==================================================================
	1. Common setting
===================================================================*/

/* ------------------------------------------------------------------
	1-1. Reset styles
-------------------------------------------------------------------*/
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td {
	margin: 0;
	padding: 0;
}
fieldset {
	border: 0;
}
img {
	border-style: none;
	vertical-align: top;
	max-width: 100%;
	height: auto;
}
ol,ul {
	list-style: none;
}
caption {
	text-align: left;
}
h1,h2,h3,h4,h5,h6 {
	font-size: 100%;
	font-weight: normal;
}
q:before,q:after {
	content: '';
}
abbr,acronym {
	border: 0;
}
table {
	width: 100%;
}
a {
	color: #0000ff;
	text-decoration: underline;
}
img{
	width: 100%;
}

/* ------------------------------------------------------------------
	1-2. BoxModel styles
-------------------------------------------------------------------*/
.pt_0 { padding-top: 0 !important;}
.pt_2 { padding-top: 2% !important;}
.pt_4 { padding-top: 4% !important;}
.pt_6 { padding-top: 6% !important;}
.pt_8 { padding-top: 8% !important;}
.pt_10 { padding-top: 10% !important;}
.pb_0 { padding-bottom: 0 !important;}
.pb_2 { padding-bottom: 2% !important;}
.pb_4 { padding-bottom: 4% !important;}
.pb_6 { padding-bottom: 6% !important;}
.pb_8 { padding-bottom: 8% !important;}
.pb_10 { padding-bottom: 10% !important;}
.mt_0 { margin-top: 0 !important;}
.mt_2 { margin-top: 2% !important;}
.mt_4 { margin-top: 4% !important;}
.mt_6 { margin-top: 6% !important;}
.mt_8 { margin-top: 8% !important;}
.mt_10 { margin-top: 10% !important;}
.mb_0 { margin-bottom: 0 !important;}
.mb_2 { margin-bottom: 2% !important;}
.mb_4 { margin-bottom: 4% !important;}
.mb_6 { margin-bottom: 6% !important;}
.mb_8 { margin-bottom: 8% !important;}
.mb_10 { margin-bottom: 10% !important;}

.bg_base{
	background: #fff;
}
.bg_blue{
	background: #def5ff;
}
.bg_yellow{
	background: #ffe995;
}
.bg_gray{
	background: #ccc;
}
/* ------------------------------------------------------------------
	1-3. Text styles
-------------------------------------------------------------------*/
.f12 { font-size: 0.55em;}
.f14 { font-size: 0.63em;}
.f16 { font-size: 0.72em;}
.f18 { font-size: 0.8em;}
.f20 { font-size: 0.9em;}
.f22 { font-size: 1em;}
.f24 { font-size: 1.1em;}
.f26 { font-size: 1.18em;}
.f28 { font-size: 1.27em;}
.f30 { font-size: 1.4em;}
.lh12 { line-height: 1.2;}
.lh14 { line-height: 1.4;}
.lh16 { line-height: 1.6;}
.lh18 { line-height: 1.8;}
.lh20 { line-height: 2;}

.highlight_box_01 {
	border: 1px solid #dcdcdc;
	background: #efefef;
	padding: 15px;
}

.f_color_base { color: #000;}/* MAIN_COLOR */
.f_color_red { color: #f00;}

/* ------------------------------------------------------------------
	1-4. Contact styles
-------------------------------------------------------------------*/
.contact_area{
	position: fixed;
	background: #fff;
	width: 640px;
	overflow: hidden;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	z-index: 200;
	padding: 8px 0;
}
.contact_btn{
	float: left;
}
.contact_btn_tell{
	width: 62%;
}
.contact_btn_mail{
	width: 17.4%;
	margin-left: 1.6%
}
.contact_btn_line{
	width: 17.4%;
	margin-left: 1.6%
}
@media only screen and (max-width: 640px) {
	.contact_area{
		width: 100%;
		padding: 1% 0;
	}
}




/* ------------------------------------------------------------------
	1-5. Heading styles
-------------------------------------------------------------------*/
.heading {
	margin-bottom: 2%;
	line-height: 1.6;
}

/* 中見出し_1 */
.heading_type_01 {
	background: #ffe995;
	padding: 2%;
}
.heading_type_01 h3 {
	font-size: 1.15em;
	font-weight: bold;
}

/* 中見出し_2 */
.heading_type_02 {
	background: #eee;
	border-top: 1px solid #000;
	border-bottom: 1px dotted #000;
	padding: 2%;
}
/*
.heading_type_02 h3 {
	font-size: 1.15em;
	font-weight: bold;
}
*/
.heading_type_02 h4 {
	font-size: 1em;
	font-weight: bold;
}



/* ------------------------------------------------------------------
	1-6. Button styles
-------------------------------------------------------------------*/
/*
.link_button_area {
	padding: 3% 0;
}
*/
.link_button {
	font-size: 1.3em;
	font-weight: bold;
	text-align: center;
}
.link_button a {
	display: block;
	text-decoration: none;
}

/* ------------------------------------
	四角ボタン（大）
------------------------------------*/
.link_button_01 { }
.link_button_01 a {
	background: #3f0000;
	color: #FFF;
	/*border: 2px solid #000;*/
	border-radius: 100px;
	padding: 4% 0;
}
.link_button_01 a:after {
	font-family: FontAwesome;
	content: "\f101";
	margin: 0 5px;
	font-weight: normal;
}

/* ------------------------------------
	四角ボタン（大：pdf／blank）
------------------------------------*/
/*
.link_button_01.link_button_01_pdf a:before,
.link_button_01.link_button_01_blank a:before {
	display: none;
}
.link_button_01_pdf a:after {
	font-family: FontAwesome;
	content: "\f1c1";
	margin-left: 5px;
	font-weight: normal;
}
.link_button_01_blank a:after {
	font-family: FontAwesome;
	content: "\f08e";
	margin-left: 5px;
	font-weight: normal;
}
*/


/* ------------------------------------
	四角ボタン（小）
------------------------------------*/
/*
.link_button_02 {
	font-size: 14px;
}
.link_button_02 a {
	width: 120px;
	background: #b70149;
	color: #FFF;
	padding: 5px 10px;
}
.link_button_02 a:before {
	font-family: FontAwesome;
	content: "\f0da";
	margin-right: 5px;
}
.link_button_02 a:hover {
	background: #f9d1cb;
	color: #333;
}
.link_button_02_flex { }
.link_button_02_flex a {
	width: auto;
}
*/

/* ------------------------------------
	丸ボタン（大）
------------------------------------*/
/*
.link_button_03 {
	font-size: 16px;
	font-weight: bold;
}
.link_button_03 a {
	width: 300px;
	background: #FFF;
	border: 1px solid #b70149;
	border-radius: 100px;
	-webkit-border-radius: 100px;
	-moz-border-radius: 100px;
	padding: 3px 35px 3px 15px;
	position: relative;
}
.link_button_03 a:after {
	font-family: FontAwesome;
	content: "\f178";
	position: absolute;
	top: 50%;
	right: 15px;
	left: auto;
	bottom: auto;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}
.link_button_03 a:hover {
	background: #b70149;
	color: #FFF;
}
.link_button_03_flex { }
.link_button_03_flex a {
	width: auto;
}
*/

/* ------------------------------------
	丸ボタン（小）
------------------------------------*/
/*
.link_button_04 {
	font-size: 14px;
	font-weight: bold;
}
.link_button_04 a {
	width: 300px;
	background: #FFF;
	border: 1px solid #b70149;
	border-radius: 100px;
	-webkit-border-radius: 100px;
	-moz-border-radius: 100px;
	padding: 0 35px 0 15px;
	position: relative;
}
.link_button_04 a:after {
	font-family: FontAwesome;
	content: "\f178";
	position: absolute;
	top: 50%;
	right: 15px;
	left: auto;
	bottom: auto;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}
.link_button_04 a:hover {
	background: #b70149;
	color: #FFF;
}
.link_button_04_flex { }
.link_button_04_flex a {
	width: auto;
}
*/

/* ------------------------------------------------------------------
	1-7. List styles
-------------------------------------------------------------------*/
/*--------------*/
/*	チェックリスト
/*--------------*/
.check_list { }
.check_list ul {
	padding: 0 0 0 8%;
}
.check_list ul li {
	position: relative;
	font-size: 1.1em;
	line-height: 1.6;
	padding-bottom: 2%;
}
.check_list ul li a {
	color: #000;
	text-decoration: underline;
}
.check_list ul li:before {
	font-family: 'FontAwesome';
	content: '\f046';
	position: absolute;
	top: -5px;
	left: -8%;
	color: #f00;
	font-size: 1.5em;
}



/* ------------------------------------------------------------------
	1-8. Table styles
-------------------------------------------------------------------*/
.th_col2 {
	width: 50%;
}
.th_col3 {
	width: 33.3%;
}
.th_col4 {
	width: 25%;
}
.th_col5 {
	width: 20%;
}
.th_col6 {
	width: 16.7%;
}
.th_col7 {
	width: 14.3%;
}
.th_col8 {
	width: 12.5%;
}
.th_col9 {
	width: 11.1%;
}
.th_col10 {
	width: 10%;
}

.table_01 {
	background: #666666;
}
.table_01 th {
	background: #eee;
	padding: 2%;
}
.table_01 td {
	background: #FFF;
	padding: 2%;
}

.table_02 {
	background: #dcdcdc;
}
.table_02 th {
	background: #faf1f4;
	padding: 10px;
}
.table_02 td {
	background: #FFF;
	padding: 10px;
}

/* 外側罫線ナシバージョン */
.table_03 {
	border-bottom: 1px solid #e5e5e5;
}
.table_03 th {
	border-top: 1px solid #e5e5e5;
	padding: 10px;
}
.table_03 td {
	border-top: 1px solid #e5e5e5;
	padding: 10px;
	word-break: break-all;
}
.table_03 tr:first-child th,
.table_03 tr:first-child td {
	border-top: none;
}

/* ------------------------------------------------------------------
	1-9. Form styles
-------------------------------------------------------------------*/
input[type="text"],
input[type="email"],
input[type="password"],
select,
textarea{
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	outline: none;
	font-family: inherit;
	font-size: 16px;
	line-height: 1.4;
	vertical-align: middle;
	/*
	background: none;
	border: none;
	border-radius: 0;
	*/
}
select::-ms-expand {
	display: none;
}
/*textarea { font-size: inherit;}*/
button{
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background: none;
	border: none;
	border-radius: 0;
	outline: none;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
select:focus,
textarea:focus {
	border: 1px solid #b70149;
	/*box-shadow: 0 0 1px 1px rgba(0,160,233,1);*/
	transition: all 0.5s;
}

/*-------------------------------*/
/*	オートフィル時の背景色を無効に
/*-------------------------------*/
input:-webkit-autofill {
	/* 色はinput要素の背景色（ここでは#fff）にそろえる */
	box-shadow: 0 0 0px 999px #FFF inset;
}

/*-------------------------------*/
/*	placeholder
/*-------------------------------*/
input::-webkit-input-placeholder {
	color: #a2a2a2;
}
input::-moz-placeholder {
	color: #a2a2a2;
	opacity: 1;
}
input:-ms-input-placeholder {
	color: #a2a2a2;
}

/*-------------------------------*/
/*	必須項目
/*-------------------------------*/
.form_subject { }
.form_subject_name {
	float: left;
	display: inline-block;
}
.form_subject_req {
	float: right;
	display: inline-block;
	font-size: 12px;
	background: #fe0000;
	color: #FFF;
	padding: 3px 10px;
}
.form_subject_btn {
	float: right;
	display: inline-block;
}
.form_subject_btn a {
	background: #3399ff;
	padding: 3px 12px;
	border-radius: 3px;
	color: #FFF;
	text-decoration: none;
}
.form_subject_btn a:hover {
	background: #0a5ad3;
}

/*-------------------------------*/
/*	フォームパーツ
/*-------------------------------*/
.form_item {
	margin: 20px 0;
}

/*-------------------------------*/
/*	要素を横に並べる
/*-------------------------------*/
.form_inline {
	vertical-align: middle;
}
.form_inline .form_inline_item {
	display: inline-block;
}
.form_inline .form_inline_item:not(:first-child) {
	margin-left: 5px;
}

/*-------------------------------*/
/*	text
/*-------------------------------*/
.form_text {
	border: 1px solid #dcdcdc;
	background-color: #eee;
	border-radius: 3px;
	padding: 5px;
	width: 100%;
}
.form_text_01 {
	width: 194px;
	margin-right: 5px;
}

/* エラー時 */
.form_text_error {
	border: 1px solid #fe0000;
}

/*-------------------------------*/
/*	textarea
/*-------------------------------*/
.form_textarea {
	border: 1px solid #dcdcdc;
	background-color: #eee;
	border-radius: 3px;
	padding: 5px;
	width: 100%;
	height: 200px;
	overflow: auto;
}

/* エラー時 */
.form_textarea_error {
	border: 1px solid #fe0000;
}

/*-------------------------------*/
/*	select
/*-------------------------------*/
.form_select_wrap{
	position: relative;
}
.form_select_wrap::before{
	/*background-color: #282e70;*/
	display: inline-block;
	font-size: 24px;
	width: 30px;
	height: 100%;
	font-family: fontAwesome;
	content: "\f0d7";
	z-index: 1;
	position: absolute;
	right: 0;
	top: 0;
	color: #333;
	pointer-events: none;
	line-height: 1.4;
	text-align: center;
}
.form_select{
	border: 1px solid #dcdcdc;
	background-color: #eee;
	border-radius: 3px;
	padding: 5px 35px 5px 5px;
	width: 100%;
}
/*
select.form_selectError{
	border: 2px solid #ff0000;
}
*/

/* エラー時 */
.form_select_error {
	border: 1px solid #fe0000;
}

/*-------------------------------*/
/*	checkbox
/*-------------------------------*/
.form_checkbox{
	display: none;
}
.form_checkbox_parts{
	padding-left: 25px;
	position: relative;
	margin-right: 25px;
}
.form_checkbox_parts::before{
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 20px;
	height: 20px;
	border: 1px solid #dcdcdc;
	border-radius: 3px;
}
.form_checkbox:checked + .form_checkbox_parts{
	/*color: #fe0000;*/
}
.form_checkbox:checked + .form_checkbox_parts::after{
	content: "";
	display: block;
	position: absolute;
	top: -2px;
	left: 8px;
	width: 8px;
	height: 16px;
	transform: rotate(40deg);
	border-bottom: 3px solid #b70149;
	border-right: 3px solid #b70149;
}

/*-------------------------------*/
/*	radio
/*-------------------------------*/
.form_radio {
	display: none;
}
.form_radio + label{
	padding-left: 25px;
	position: relative;
	margin-right: 25px;
}
.form_radio + label::before{
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 20px;
	height: 20px;
	border: 1px solid #dcdcdc;
	border-radius: 50%;
}
.form_radio:checked + label{
	/*color: #009a9a;*/
}
.form_radio:checked + label::after{
	content: "";
	display: block;
	position: absolute;
	top: 5px;
	left: 5px;
	width: 10px;
	height: 10px;
	background: #b70149;
	border-radius: 50%;
}

/*-------------------------------*/
/*	button
/*-------------------------------*/
.form_btn {
	display: inline-block;
	position: relative;
	background: #757575;
	color: #FFF;
	padding: 10px 0;
	cursor: pointer;
	-webkit-transition: 0.3s;
	transition: 0.3s;
	font-size: 16px;
	font-weight: bold;
	position: relative;
	/*
	line-height: 1;
	border-radius: 3px;
	*/
}
.form_btn:hover {
	background: #505050;
}
.form_btn:before {
	font-family: FontAwesome;
	content: "\f0da";
	position: absolute;
	top: 50%;
	left: 15px;
	right: auto;
	bottom: auto;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	font-weight: normal;
}

/* オリジナルボタン1 */
.form_btn_01 {
	background: #b70149;
}
.form_btn_01:hover {
	background: #f9d1cb;
	color: #333;
}

/* サイズ固定 */
.form_btn_fix {
	width: 300px;
}

/*-------------------------------*/
/*	同意
/*-------------------------------*/
.form_consent {
	margin-top: 10px;
	font-size: 12px;
}

/*-------------------------------*/
/*	assist
/*-------------------------------*/
.form_assist {
	margin-top: 10px;
	font-size: 12px;
}
.form_assist i {
	margin-right: 3px;
	font-size: 12px;
}

/* エラー時 */
.form_assist_error {
	color: #fe0000;
}

/*-------------------------------*/
/*	住所自動入力ボタン
/*-------------------------------*/
.zip_search {
	display: inline-block;
}
.zip_search a {
	background: #3399fe;
	color: #FFF;
	border-radius: 3px;
	padding: 5px 10px;
	text-decoration: none;
}
.zip_search a:hover {
	background: #0a5ad3;
}

/*-------------------------------*/
/*	フォーム内各種文言
/*-------------------------------*/
.form_info {
	padding: 5px 0;
	margin: 20px 0;
	text-align: center;
}
.form_info_text { }
.form_info_error {
	border: 1px solid #fe0000;
	background: #fededf;
	color: #fe0000;
}
.form_info_finish {
	padding: 60px 0;
	/*
	border: none;
	background: none;
	*/
}

/*-------------------------------*/
/*	jQuery-Validation-Engineのスタイルを上書き
/*-------------------------------*/
/* 吹き出しの色を変える */
.section .formError .formErrorContent,
.section .formError .formErrorArrow div {
	background: #b70149;
}
.section .formError .formErrorArrow .line1,
.section .formError .formErrorArrow .line2 {
	background: #ddd;
}




/* ------------------------------------------------------------------
	1-99. VisualFormattingModel styles
-------------------------------------------------------------------*/
/*
.pc_block{
	display: block !important;
}
.pc_inline{
	display: inline !important;
}
.sp_block{
	display: none !important;
}
.sp_inline{
	display: none !important;
}
*/
.align_left { text-align: left;}
.align_right { text-align: right;}
.align_center { text-align: center;}

/* ------------------------------------
	CLEARFIX
------------------------------------*/
.section_box:after,
.cf:after {
	content: "";
	display: block;
	clear: both;
}
