@charset "UTF-8";



/*アンカーリンク
---------------------------------------------------------*/
.anc_list {
	display: -webkit-flex;
	display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}
.anc_list li {
	margin-top: 2%;
	width: 32%;
	margin-right: 2%;
	box-sizing: border-box;
	border: solid 1px #d3d3d3;
	border-radius: 8px;
	text-align: center;
	position: relative;
background: rgb(250,248,251);
background: -moz-linear-gradient(top,  rgba(250,248,251,1) 0%, rgba(255,255,255,1) 100%);
background: -webkit-linear-gradient(top,  rgba(250,248,251,1) 0%,rgba(255,255,255,1) 100%);
background: linear-gradient(to bottom,  rgba(250,248,251,1) 0%,rgba(255,255,255,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#faf8fb', endColorstr='#ffffff',GradientType=0 );
	-webkit-transition: border-color 1.0s;
	-moz-transition: border-color 1.0s;
	transition: border-color 1.0s;
}
.anc_list li:hover {
	-webkit-transition: border-color 0.4s;
	-moz-transition: border-color 0.4s;
	transition: border-color 0.4s;
	border-color: #985d00;
}
.anc_list li:nth-child(3n) {
	margin-right: 0;
}
.anc_list li:nth-child(1),
.anc_list li:nth-child(2),
.anc_list li:nth-child(3) {
	margin-top: 0;
}
.anc_list li::before {
	font-family: 'fontello';
	content: '\e806';	/*矢印*/
	color: #a7a5aa;
	position: absolute;
	margin: auto;
	left: 0;
	right: 0;
	bottom: .4em;
}

.anc_list li a {
	display: block;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-style: normal;
	font-size: 130%;
	letter-spacing: .15em;
	line-height: 1.2em;
	padding: 4.2em 0 1.6em;
	position: relative;
}
.anc_list li a span {
	font-size: 80%;
	letter-spacing: .1em;
}
.anc_list li a::after {
	content: "";	/*アイコン*/
	position: absolute;
	width: 100%;
	height: 3.2em;
	left: 0;
	top: .5em;
	background: url("../images/contact/icon1@2x.png") no-repeat center center;
	background-size: contain;
}
.anc_list li.icon2 a::after {background-image: url("../images/contact/icon2@2x.png");}
.anc_list li.icon3 a::after {background-image: url("../images/contact/icon3@2x.png");}
.anc_list li.icon4 a::after {background-image: url("../images/contact/icon4@2x.png");}
.anc_list li.icon5 a::after {background-image: url("../images/contact/icon5@2x.png");}
.anc_list li.icon6 a::after {background-image: url("../images/contact/icon6@2x.png");}

.faq .right_bnr {
	position: fixed;
	z-index: 1;
	right: 0;
	bottom: 15%;
	width: 5%;
	max-width: 90px;
}
.faq .right_bnr a {
	display: block;
background: rgb(188,155,130);
background: -moz-linear-gradient(top,  rgba(188,155,130,1) 0%, rgba(208,186,170,1) 100%);
background: -webkit-linear-gradient(top,  rgba(188,155,130,1) 0%,rgba(208,186,170,1) 100%);
background: linear-gradient(to bottom,  rgba(188,155,130,1) 0%,rgba(208,186,170,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#bc9b82', endColorstr='#d0baaa',GradientType=0 );
	padding: 30px 30%;
	border-radius: 8px 0 0 8px;
	text-align: center;
	box-shadow: 0px 0px 16px -6px rgba(0,0,0,0.6);
}
.faq .right_bnr img {
	display: block;
}

/* 1100px以下
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 1100px) {
.anc_list li a {
	font-size: 120%;
	letter-spacing: .05em;
}
.anc_list li a span {
	letter-spacing: .05em;
}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.anc_list li {
	margin-top: 1.1%;
	width: 32.6%;
	margin-right: 01.1%;
}
.anc_list li a {
	font-size: 110%;
	letter-spacing: .05em;
}
.anc_list li a span {
	letter-spacing: .05em;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.anc_list {
    -webkit-justify-content: space-between;
    justify-content: space-between;
}
.anc_list li {
	margin-top: 2% !important;
	width: 49%;
	margin-right: 0;
}
.anc_list li:nth-child(1),
.anc_list li:nth-child(2) {
	margin-top: 0 !important;
}
.anc_list li::before {
	bottom: 0;
}
	
.anc_list li a {
	font-size: 100%;
	letter-spacing: normal;
	padding: 3.0em 0 1.4em;
}
.anc_list li a span {
	font-size: 80%;
	letter-spacing: normal;
	padding-left: .2em;
}
.anc_list li a::after {
	height: 2.5em;	/*アイコン*/
	top: .3em;
}
	
.faq .right_bnr {
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	width: 60%;
	max-width: 100%;
}
.faq .right_bnr a {
background: rgb(188,155,130);
background: -moz-linear-gradient(top,  rgba(188,155,130,1) 0%, rgba(208,186,170,1) 100%);
background: -webkit-linear-gradient(top,  rgba(188,155,130,1) 0%,rgba(208,186,170,1) 100%);
background: linear-gradient(to bottom,  rgba(188,155,130,1) 0%,rgba(208,186,170,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#bc9b82', endColorstr='#d0baaa',GradientType=0 );
	padding: 6% 20% 8%;
	border-radius: 8px 8px 0 0;
}
}



/*QA
---------------------------------------------------------*/
.faq .com_index3 {
	margin-bottom: 40px;
}

.qa_list {
	border-bottom: solid 1px #cbcbcb;
}
.qa_list > dt {
	cursor: pointer;
	border-top: solid 1px #cbcbcb;
	font-size: 105%;
	font-weight: bold;
	letter-spacing: normal;
	line-height: 1.6em;
	padding: 1.8em 0 1.6em;
	padding-left: 100px;	/*揃える1*/
	padding-right: 5em;		/*揃える2*/
	position: relative;
}
.qa_list > dt:first-of-type {
	border-top: none;
}
.qa_list > dt.active::after {background-image: url("../images/close@2x.png");}
.qa_list > dt::after {
	content: "";	/*プラス・マイナス*/
	position: absolute;
	width: 5em;	/*揃える2*/
	height: 100%;
	right: 0;
	top: 0;
	background: url("../images/open@2x.png") no-repeat center center;
	background-size: 1.6em auto;
}
.qa_list > dd {
	display: none;	/*初期表示*/
	background: #faf6f3;
	padding: 1.8em 0;
	padding-left: 100px;	/*揃える1*/
	padding-right: 3%;
	position: relative;
}
.qa_list > dt::before,
.qa_list > dd::before {
	content: "";
	position: absolute;
	width: 100px;	/*揃える1*/
	height: 40px;
	left: 0;
}
.qa_list > dt::before {
	top: 1.4em;
	background: url("../images/q@2x.png") no-repeat center center;
	background-size: contain;
}
.qa_list > dd::before {
	top: 1.8em;
	background: url("../images/a@2x.png") no-repeat center center;
	background-size: contain;
}
.qa_list > dd > small {
	display: block;
	margin-top: .5em;
	font-size: 80%;
	line-height: 1.6em;
}
.qa_list .img_graph {
	margin-top: 1.0em;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.faq .com_index3 {
	margin-bottom: 2%;
}

.qa_list > dt {
	padding: 1.5em 0 1.2em;
	padding-left: 80px;		/*揃える1*/
	padding-right: 4em;		/*揃える2*/
}
.qa_list > dt::after {
	width: 4em;	/*揃える2*/
}
.qa_list > dd {
	padding: 1.5em 0;
	padding-left: 80px;	/*揃える1*/
}
.qa_list > dt::before,
.qa_list > dd::before {
	width: 80px;	/*揃える1*/
}
.qa_list > dt::before {
	top: .9em;
}
.qa_list > dd::before {
	top: 1.5em;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.faq .com_index3 {
	margin-bottom: 3%;
}

.qa_list > dt {
	font-size: 100%;
	padding: .8em 0;
	padding-left: 12vw;	/*揃える1*/
	padding-right: 1.5em;		/*揃える2*/
}
.qa_list > dt::after {
	width: 1.5em;	/*揃える2*/
	background-size: 1.2em auto;
}
.qa_list > dd {
	padding: 1.0em 0;
	padding-left: 12vw;	/*揃える1*/
	padding-right: 4%;
}
.qa_list > dt::before,
.qa_list > dd::before {
	width: 12vw;	/*揃える1*/
	height: 7vw;
}
.qa_list > dt::before {
	top: .8em;
}
.qa_list > dd::before {
	top: 1.0em;
}
}



/*お問い合わせ
---------------------------------------------------------*/
/*
.contact .flt_box .form_box {
	float: right;
	width: 74%;
	max-width: 900px;
}
*/
.contact .flt_box .s_contact {
	float: left;
	width: 23%;
	max-width: 240px;
	box-sizing: border-box;
	background: #fff;
	box-shadow: 0px 0px 16px -6px rgba(0,0,0,0.3);
	padding: 2px;
	text-align: center;
}

/*フォームテーブル*/
.form_box .required {
	color: #d95d50;
	font-weight: normal;
}
.form_box .tbl_txt {
	text-align: right;
	margin-bottom: .5em;
}
.kakunin .form_box .tbl_txt {
	text-align: left;
}
.form_box .tbl_form {
	width: 100%;
	table-layout: fixed;
	border-collapse: collapse;
	border-top: solid 1px #cbcbcb;
}
.form_box .tbl_form tr {
	border-bottom: solid 1px #cbcbcb;
}
.form_box .tbl_form tr:nth-child(odd) {
	background: rgba(241,238,242,0.3);
}
.form_box .tbl_form tr:nth-child(even) {
	background: #fff;
}

.form_box .tbl_form th,
.form_box .tbl_form td {
	text-align: left;
}
.form_box .tbl_form th {
	width: 25%;
	padding: 40px 3%;
	padding-right: 0;
	vertical-align: top;
	font-size: 105%;
	font-weight:  bold;
	letter-spacing: .1em;
	line-height: 1.4em;
}
.form_box .tbl_form td {
	width: 75%;
	padding: 30px 3%;
	vertical-align: middle;
	font-size: 16px;
	line-height: 1.6em;
}

/*サイドお問い合わせ*/
.contact .s_contact dt {
	background: #5c370b;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-style: normal;
	color: #fff;
	line-height: 1.4em;
	padding: .6em 0;
}
.contact .s_contact dd div {
	padding: 10px 5px;
	border-bottom: dashed 1px #ccc;
}
.contact .s_contact dd p {
	padding: 10px 0;
	color: #555;
	font-size: 90%;
	line-height: 1.4em;
}
.contact .s_contact dd .txt_small {
	font-size: 80%;
	letter-spacing: normal;
	line-height: 1.4em;
}
.contact .s_contact dd p small {
	font-size: 90%;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.contact .flt_box .form_box {
	float: none;
	width: 100%;
	max-width: 100%;
}
.contact .flt_box .s_contact {
	float: none;
	width: 100%;
	max-width: 100%;
	margin-top: 8%;
	display: -webkit-flex;
	display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}
.contact .s_contact dl {
	/*width: 33%;*/
	width: 49.7%;
}

/*フォームテーブル*/
.form_box .tbl_form th {
	padding: 4% 3%;
	font-size: 100%;
}
.form_box .tbl_form td {
	padding: 3%;
}

/*サイドお問い合わせ*/
.contact .s_contact dt {
	position: relative;
	padding: 0;
	height: 4.0em;
}
.contact .s_contact dt span {
	display: block;
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
.contact .s_contact dd div {
	padding: 0;
	position: relative;
	height: 70px;
}
.contact .s_contact dd div img {
	display: block;
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.contact .flt_box .form_box {
	float: none;
	width: 100%;
	max-width: 100%;
}
.contact .flt_box .s_contact {
	margin-top: 14%;
	float: none;
	width: 100%;
	max-width: 100%;
}

/*フォームテーブル*/
.form_box .tbl_form tr,
.form_box .tbl_form th,
.form_box .tbl_form td {
	width: 100%;
	display: block;
	box-sizing: border-box;
}

.form_box .tbl_form th {
	padding: .8em 3%;
	font-size: 100%;
}
.form_box .tbl_form td {
	padding: 0 3% 1.0em;
}

/*サイドお問い合わせ*/
.contact .s_contact dd {
	padding: 0 10px;
}
.contact .s_contact dd .txt_small {
	font-size: 90%;
}
.contact .s_contact dd p small {
	font-size: 100%;
}
}



/*入力項目デザイン
-----------------------------------------------------------------------------*/
/********************/
/* テキストボックス */
/********************/
.form_box input[type="text"] {
	width: 100%;
	padding: .8em .5em;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	background: #fff;
	font-size: 16px;
	letter-spacing: .05em;
	outline: none;
	border: solid 1px #d9d9d9;
	border-radius: 0;
	-webkit-appearance: none;
}
.form_box textarea {
	width: 100%;
	height: 12em;
	padding: .8em .5em;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	background: #fff;
	font-size: 16px;
	letter-spacing: .05em;
	outline: none;
	border: solid 1px #d9d9d9;
	border-radius: 0;
	-webkit-appearance: none;
}

/****************/
/* ラジオボタン */
/****************/
.form_box input[type=radio], .form_box input[type=checkbox] {
	display: inline-block;
	font-size: 16px;
	letter-spacing: normal;
}
.form_box input[type=radio] + label, .form_box input[type=checkbox] + label {
	position: relative;
	display: inline-block;
	font-size: 16px;
	cursor: pointer;
}

@media (min-width: 1px) {
.form_box input[type=radio], .form_box input[type=checkbox] {
	/*display: none;*/
	position: absolute;		/* 上に別の要素が乗るようにする */
	z-index: -1;			/* 最背面にする */
	pointer-events: none;	/* クリック無効 */
	visibility: hidden;		/* 非表示 */
	margin: 0;
}
.form_box input[type=radio] + label, .form_box input[type=checkbox] + label {
	padding: 0 0 0 1.8em;
}
.form_box input[type=radio] + label::before, .form_box input[type=checkbox] + label::before {
	content: "";
	position: absolute;
	left: 0;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	display: block;
	width: 22px;
	height: 22px;
	background: #fff;
	border: #ccc 1px solid;
}
.form_box input[type=radio] + label::before {
	top: 0;
	border-radius: 50%;
}
.form_box input[type=checkbox] + label::before {
	top: 0;
	border-radius: 0;
}
.form_box input[type=radio]:checked + label::after, .form_box input[type=checkbox]:checked + label::after {
	content: "";
	position: absolute;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	display: block;
}
.form_box input[type=radio]:checked + label::after {
	left: 5px;
	top: 5px;
	margin: auto;
	width: 12px;
	height: 12px;
	background: #d95d50;
	border-radius: 50%;
}
.form_box input[type=checkbox]:checked + label::after {
	top: 0;
	left: 2px;
	width: 20px;
	height: 12px;
	border-left: 3px solid #d95d50;
	border-bottom: 3px solid #d95d50;
	-webkit-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
}

/****************/
/* セレクトボックス */
/****************/
.form_box select {
  /* デフォルトのスタイルを解除 */
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  /* スタイル */
  display: inline-block;
  cursor: pointer;
  font-size: 16px;
  line-height: 1.4em;
  width: 100%;
  max-width: 300px;
  padding: 0.6em 1.5em 0.6em .8em; /* 文字周りの余白 */
  border-radius: 0;
  background-color: #fff;
  border: solid 1px #ccc;
  /* 三角マークを作る */
  background-image: linear-gradient(45deg, transparent 50%, rgba(0,0,0,0.4) 50%),  linear-gradient(135deg, rgba(0,0,0,0.4) 50%, transparent 50%);
  background-size: 8px 8px, 8px 8px;
  background-position: calc(100% - 18px) 50%, calc(100% - 10px) 50%;
  background-repeat: no-repeat;
}
/* フォーカス時 */
.form_box select:focus {
  outline: 0;
}
/* IEでデフォルトの矢印を消す */
.form_box select::-ms-expand {
  display: none;
}
/**********/
/* ボタン */
/**********/
.form_box input[type="submit"], .form_box input[type="button"], .form_box input[type="reset"] {
	-webkit-appearance: none;
	width: 100%;
	height: 4em;
	border: none;
	cursor: pointer;
	color: #fff;
	font-size: 110%;
	font-weight: normal;
	letter-spacing: .1em;
	line-height: 1.0em;
	background-color: #999;
}
.form_box input[type="submit"] {
	background-color: #b6a293;
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 480px) {
.tbl_form,
.form_box input,
.form_box label,
.form_box select {
	font-size: 16px !important;
}
}



/*入力項目レイアウト
---------------------------------------------------------*/
.form_box .tbl_form .sub_txt_l {
	margin-right: .5em;
}
.form_box .tbl_form .sub_txt_r {
	margin-left: .5em;
}
/*名前*/
.form_box .tbl_form .name_txt {
	display: -webkit-flex;
	display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}
.form_box .tbl_form .name_txt li {
	width: 49%;
}
.form_box .tbl_form .name_txt li input {
	width: calc(100% - 3em);
}
/*メール確認*/
.form_box .tbl_form .mail_txt {
	font-size: 90%;
	letter-spacing: .1em;
	line-height: 1.4em;
	margin: 1.5em 0 .5em;
}

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

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
/*名前*/
.form_box .tbl_form .name_txt {
	display: block;
}
.form_box .tbl_form .name_txt li {
	width: 100%;
}
.form_box .tbl_form .name_txt li:first-child {
	margin-bottom: 1.0em;
}
.form_box .tbl_form .name_txt li input {
	width: calc(100% - 3em);
}
/*メール確認*/
.form_box .tbl_form .mail_txt {
	letter-spacing: .05em;
}
}



/* ドメイン設定
-----------------------------------------------------------------------*/
.form_box .mobile_attention {
	margin-top: 40px;
	box-sizing: border-box;
	border: solid 1px #b6a293;
	padding: 20px 4%;
	font-size: 1.0rem;
}
.form_box .mobile_attention .open_trigger {
	text-align: center;
	color: #91735c;
	font-weight: bold;
	letter-spacing: .15em;
	line-height: 1.4em;
	cursor: pointer;
}
.form_box .mobile_attention .open_trigger span {
	display: block;
	position: relative;
	padding: 0 2.0em;
}
.form_box .mobile_attention .open_trigger span::before {
	content: "";
	position: absolute;
	width: 1.6em;
	height: 1.6em;
	right: 0;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	background: url("../images/open@2x.png") no-repeat center center;
	background-size: contain;
}
.form_box .mobile_attention .open_trigger.active span {
	content: '\e80c';
}
.form_box .mobile_attention .open_box {
	padding-top: 1.5em;
	display: none;
	font-size: 90%;
	line-height: 1.6em;
}
.form_box .mobile_attention ul {
	margin-top: 1.0em;
}
.form_box .mobile_attention li {
	margin-top: 5px;
	padding-left: 15px;
	float: left;
	margin-right: 20px;
	position: relative;
	line-height: 1.2em;
}
.form_box .mobile_attention li::before {
	position: absolute;
	left: 0;
	top: 50%;
    transform: translateY(-50%) rotate(45deg);
	content: "";
	vertical-align: middle;
	width: 4px;
	height: 4px;
	border-top: 1px solid #666;
	border-right: 1px solid #666;
}
.form_box .mobile_attention a:hover {
	text-decoration: underline;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.form_box .mobile_attention {
	margin-top: 4%;
	padding: 4%;
}
.form_box .mobile_attention .open_trigger {
	letter-spacing: normal;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.form_box .mobile_attention {
	margin-top: 6%;
	padding: 4%;
}
.form_box .mobile_attention .open_trigger {
	letter-spacing: .05em;
}
.form_box .mobile_attention .open_trigger span {
	padding: 0;
}
}



/* ボタンレイアウト
-----------------------------------------------------------------------*/
.form_box .submit_box {
	margin-top: 60px;
	text-align: center;
}
.form_box .submit_box p {
	margin-bottom: 60px;
}
.form_box .submit_box ul{
	width: 100%;
	max-width: 600px;
	margin: 0 auto;
}
.form_box .submit_box li {
	width: 48%;
	display: inline-block;
	margin: 0 0.5%;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.form_box .submit_box {
	margin-top: 5%;
}
.form_box .submit_box p {
	margin-bottom: 5%;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.form_box .submit_box {
	margin-top: 6%;
	text-align: left;
}
.form_box .submit_box p {
	margin-bottom: 6%;
}
.form_box .submit_box ul{
	max-width: 100%;
}
.form_box .submit_box li {
	display: block;
	margin: 3% 0;
}
.form_box .submit_box li:first-child {
	width: 100% !important;
	max-width: 100% !important;
}
.form_box .submit_box li:last-child {
	width: 100% !important;
	max-width: 100% !important;
}
}