@charset "UTF-8";
/*///////////////////////////////////////////////////////////

	お問い合わせフォーム[form18]

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

/* 必須
--------------------------------*/
span.require {
	display: block;
	width: 2em;
	margin: 6px auto;
	padding: 3px 3px 2px;
	border: 1px solid #f00;
	border-radius: 2px;
	color: #f00;
	font-size: 11px;
	text-align: center;
	line-height: 1;
}

/*===================================
	ページ全体
===================================*/
#wrapper.wrapperform18 {
	margin-top: 74px!important;
}
#mainContents {
	position: relative;
	width: 713px!important;
	line-height: 1.25;
	padding: 0 0 10px;
	*background: url(/pub/img/search/main.jpg) no-repeat 50% 0 #fff;/* ie7 */
	*padding-top: 260px;/* ie7 */
}
.form18-mv {
	margin-bottom: 64px;
	img {
		display: block;
	}
}
/* ページ末のバナー群を非表示
-------------------------------*/
#snippet_foot_form_link { display: none !important; }

#snippet_foot_form_link h2#snippet_foot_contactTtl {
	white-space: nowrap;
	overflow: hidden;
	background: url(/gr/mailform/img/bg_form_foot_contactttl.png) no-repeat left bottom #FFF;
}

.pagetitle {
	position: relative;
	padding-bottom: 24px;
	margin-bottom: 32px;
	color: #135F51;
	font-size: 21px;
	font-weight: bold;
}
.pagetitle::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 29px;
	background: url(/public/img/mailform/form18/input/ttl_bg.webp) no-repeat center;
	background-size: contain;
}
/*===================================
	ご依頼の流れ
===================================*/
.form18-flow {
	padding: 32px 48px 40px;
	background-color: #f3f9e8;
}
.form18-flow-next {
	position: relative;
	margin-bottom: 100px;
	width: 100%;
	margin-top: -1px;
}
.form18-flow-next::after {
	content: "";
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	height: 52px;
	background: #f3f9e8;
	z-index: 0;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
}
.form18-flow-hd {
	margin-bottom: 32px;
	font-size: 28px;
	font-weight: bold;
	text-align: center;
	.orange {
		color: #ff8b3d;
		span {
			font-size: 42px;
		}
	}
}
.form18-flow-wrap {
	display: flex;
	justify-content: space-between;
	padding: 32px;
	background-color: #fff;
	img {
		display: block;
		flex-shrink: 0;
	}
}
.form18-flow-wrap_left {
	width: 320px;
}
.form18-flow-wrap_hd {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	height: 40px;
	padding: 0 16px;
	margin-bottom: 42px;
	color: #fff;
	font-size: 22px;
	font-weight: bold;
	background-color: #278145;
	border-radius: 3px;
	.step {
		display: block;
	}
	span {
		margin: 4px 0 0 10px;
	}
}
.form18-flow-wrap_txt {
	font-size: 16px;
	line-height: 1.5;
}
.form18-flow-wrap-next {
	position: relative;
	margin-bottom: 60px;
	width: 100%;
	margin-top: -1px;
}
.form18-flow-wrap-next::after {
	content: "";
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	height: 36px;
	background: #fff;
	z-index: 0;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
}

/*===================================
	フォームエリア
===================================*/
.form18_hd {
	margin-bottom: 32px;
	font-size: 28px;
	font-weight: bold;
	text-align: center;
}
#display_box {
	width: 642px;
	margin: 30px auto 0;
	/*border-top: 1px dotted #ccc;*/
	background: white;
	*position: static;/* ie67 */
}
#display_box form {
	margin: 0 auto 30px;
	color: #333;
	z-index: 0;
}

/*===================================
	フォーム要素フォーマット
===================================*/
.form-container input,
.form-container textarea,
.form-container select {
	margin: 5px;
	padding: 7px 10px;
	border: 1px solid #bbb;
	-webkit-box-shadow: inset 1px 1px 2px rgba(0, 0, 0, 0.1);
	box-shadow: inset 1px 1px 2px rgba(0, 0, 0, 0.1);
	border-radius: 2px;
	font-size: 16px;
	font-family: helvetica, arial, meiryo, sans-serif;
	line-height: 1;
	vertical-align: middle;
}
.form-container input:focus,
.form-container textarea:focus {
	border-color: #ED7020;
	-webkit-box-shadow: 0 0 4px rgba(255, 155, 0, 0.5);
	box-shadow: 0 0 4px rgba(255, 155, 0, 0.5);
	background-color: #fff !important;
}
.form-container select {
	width: auto;
	padding: 3px 10px;
	font-size: 16px;
	line-height: 1;
}
.form-container select option {
	/*font-size: 14px;*/
}
.form-container textarea {
	display: block;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	width: 100%;
	height: 12em;
	margin: 0;
	padding: 10px 15px;
	font-size: 14px;
	line-height: 1.5;
}

/*===================================
	プレースホルダー
===================================*/

/* Google Chrome, Safari, Opera 15+, Android, iOS*/
::-webkit-input-placeholder {
	font-size: 14px;
	color: rgba(0, 0, 0, 0.5);
	line-height: 1;
}
/* Firefox 19+*/
::-moz-placeholder {
	font-size: 14px;
	color: rgba(0, 0, 0, 0.5);
	line-height: 1;
}
/* IE 10+*/
:-ms-input-placeholder {
	font-size: 14px;
	color: rgba(0, 0, 0, 0.5);
	line-height: 1;
}
/* textarea
------------------------------------*/
/* Google Chrome, Safari, Opera 15+, Android, iOS*/
textarea::-webkit-input-placeholder {
	font-size: 14px;
	color: rgba(0, 0, 0, 0.5);
	line-height: 1.5;
}
/* Firefox 19+*/
textarea::-moz-placeholder {
	font-size: 14px;
	color: rgba(0, 0, 0, 0.5);
	line-height: 1.5;
}
/* IE 10+*/
textarea:-ms-input-placeholder {
	font-size: 14px;
	color: rgba(0, 0, 0, 0.5);
	line-height: 1.5;
}
/* 必須項目表記
----------------------------------------- */
#display_box span.required {
	display: table;
	padding: 0px 3px;
	border-radius: 2px;
	border: 1px solid #f00;
	color: #f00;
	font-size: 14px;
	text-align: center;
	line-height: 1;
}
#display_box h3 span.required,
#display_box .question_title span.required {
	display: inline;
}

/* =====================================
	お問い合わせ内容
===================================== */

/* 見出し
--------------------------- */
#display_box form h3 {
	margin-bottom: 10px;
	color: #333;
	font-size: 16px;
	font-weight: bold;
	text-align: center;
}
#display_box form h3 span {
	font-size: 11px;
	font-weight: bold;
}

/* 入力テキストエリア */
#display_box form textarea#vd_text1 {
	display: block;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	min-height: 100px;
	margin: 0 auto;
	padding: 5px;
	*height: 100px;
	font-size: 14px;
}

/* =====================================
	お客様情報の入力
===================================== */

/* 見出し
----------------------------- */
p.question_title {
	margin: 35px auto 10px;
	color: #333;
	font-size: 16px !important;
	font-weight: bold;
	text-align: center;
}

/*------------------------------------------
	フォームテーブル
----------------------------------------- */
#mailform_question02 table {
	width: 100%;
	margin: 0 auto;
	border-collapse: collapse;
	border: 1px solid #D3E7A8;
	border-top: none;
}
#mailform_question02 table + table {
	border-top: none;
}
#mailform_question02 table th,
#mailform_question02 table td {
	padding: 10px 9px 10px 10px;
	border-top: 1px solid #D3E7A8;
	color: #333;
	vertical-align: middle;
}
#mailform_question02 table th {
	width: 108px;
	border-right: 1px solid #D3E7A8;
	background-color: #F3F9E8;
	font-size: 13px;
	font-weight: normal;
	vertical-align: middle;
	text-align: center;
	white-space: normal;
}
#mailform_question02 table td {
	width: calc(100% - 108px);
	padding: 16px 32px;
}
.form18-sample {
	height: 388px;
	padding-right: 14px;
	margin-bottom: 32px;
	overflow-y: scroll;
}
.form18-sample-grid {
	padding: 6px 0 6px 5px;
}
/* 入力注意アイコン列
------------------------------------ */
#mailform_question02 table td.tips_area {
	display: none;
	width: 15px;
	padding-left: 3px !important;
}

/* 見出し内の※印
------------------------------------ */
#mailform_question02 span.attention_index {
	padding-left: 1px;
	color: #f00;
	font-size: 10px;
	vertical-align: super;
}

/* 住所検索ボタン
------------------------------------ */
#mailform_question02 input.searchAddress {
	-webkit-box-shadow: inset 1px 1px 1px 0 #fff, 1px 1px 2px rgba(0, 0, 0, 0.1);
	box-shadow: inset 1px 1px 1px 0 #fff, 1px 1px 2px rgba(0, 0, 0, 0.1);
}

/* 住所検索ボタン注釈
------------------------------------ */
#mailform_question02 span.searchAddress {
	display: inline-block;
	width: 100px;
	margin-left: 7px;
	padding-left: 1em;
	text-indent: -1em;
	color: #2F7400;
	font-size: 10px;
}
#mailform_question02 span.mailaddress {
	color:#f00;
	font-weight:bold;
	padding:0 6px;
	cursor: pointer;
}
.attention {
	margin-top: 6px;
	font-size: 12px;
}

/* フォーム注釈
----------------------------------------- */
#mailform_attention {
	margin: 30px 0px 20px;
	padding: 10px 15px;
	border-radius: 4px;
	background-color: #f7f7f7;
	font-size: 12px;
}
#mailform_attention ul li {
	padding: 5px 0px 10px 2em;
	font-size: 12px;
	text-indent: -2em;
	line-height: 1.7;
	text-align: justify;
}

/* 確認画面へボタン
----------------------------------------- */
#mailform #form_cont_r p.check {
	margin-bottom: 1px;
	padding: 5px 30px;
	color: #f00;
	background: url("../../img/check.jpg") no-repeat scroll left center #fdd;
}
p.next_order {
	width: 579px;
	margin: 0px auto 10px;
	text-align: center;
}

/*===================================
	モダール
===================================*/
#form18-vue-app .question {
	display: block;
	height: 22px;
	width: 22px;
	margin: 4px auto 0;
	background: url(/public/img/mailform/form18/input/icon_question.svg) no-repeat center;
	background-size: contain;
	text-indent: -9999px;
}
.modal-overlay {
	position: fixed;
	top: 0px;
	left: 0px;
	z-index: 40;
	height: 100vh;
	width: 100vw;
  background-color: rgba(0,0,0,0.5);
}
.modal-content {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 40;
	display: flex;
	width: 484px;
	max-height: calc(100vh - 32px);
	min-height: 30vh;
	flex-direction: column;
	overflow-y: auto;
	border-radius: 10px;
	border: 1px solid #bbb;
	background-color: #fff;
}
.modal-content  {
	.modal-header {
		position: sticky;
		top: 0px;
		display: flex;
		flex-shrink: 0;
		justify-content: flex-end;
		--tw-bg-opacity: 1;
		background-color: #fff;
		box-shadow: 0px 1px 6px 0px rgba(0, 0, 0, 0.3);
	}
	.modal-header-inner {
		flex-grow: 1;
    padding: 0;
    display: flex;
    justify-content: center;
    flex-direction: column;
    line-height: 1.2;
	}
	.close-button {
		position: absolute;
    right: 0px;
    top: 0px;
		display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 2rem;
    height: 2rem;
    padding: 1.5rem;
    color: #4b5563;
		background-color: transparent;
		border: 0;
    font-size: 1.125rem;
    line-height: 1.75rem;
		cursor: pointer;
	}
	.modal-main {
		display: flex;
    justify-content: space-between;
		height: 100%;
    padding: 32px 32px 20px;
    flex-grow: 1;
		img {
			width: 100%;
		}
		.main-inner {
			p {
				font-size: 20px;
				font-weight: bold;
				text-align: center;
				margin-bottom: 16px;
			}
			ol {
				margin-top: 4px;
				font-size: 16px;
				line-height: 1.5;
			}
		}
	}
	footer {
		position: sticky;
    bottom: 0px;
    display: flex;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
		padding: 0 32px 40px;
		border: none;
		background-color: #fff;
		button {
			display: flex;
			height: 56px;
			width: 100%;
			align-items: center;
			justify-content: center;
			border-radius: 9999px;
			border: 1px solid #000;
			font-size: 16px;
			background: url(/image/common/icon/icon_prev_black.svg) left calc(16 / 16 * 1rem) center no-repeat #fff;
			background-size: calc(var(--icon-next-w) / 16 * 1rem) auto;
		}
	}
}
/* ====================================================
	確認画面ボタンまわり
====================================================*/
.box_additive {
	margin-top: 37px;
	text-align: center;
}
.box_additive .lead {
	margin-bottom: 40px;
}
.box_additive .omission {
	margin: 0 0 36px 60px;
}
/*--------------------------------
	確認ボタン
--------------------------------*/
.box_additive .btn_submit {
	margin-bottom: 40px;
	text-align: center;
}
.box_additive .btn_submit a {
	display: inline-block;
	*display: inline; /* IE7 */
	*zoom: 1; /* IE7 */
	padding: 16px 108px 19px 120px;
	border-radius: 3px;
	background-color: #8dc21f;
	box-shadow: 1px 1px 3px 0px rgba(0, 0, 0, 0.2);
	text-align: center;
}
.box_additive .btn_submit a img {
	vertical-align: middle;
}

/*------------------------------------------
	セキュリティ表示エリア
----------------------------------------- */
#popform_footer {
  width: 640px;
  margin: 40px auto 0;
  border-top: 1px solid #ccc;
}
#popform_footer div {
  float: left;
  padding-top: 10px;
}
#popform_footer .pmark,
#popform_footer .secom {
  width:95px;
}
#popform_footer .secom input {
	padding: 0;
	border: none;
	-webkit-box-shadow: none;
	box-shadow: none;
}
#popform_footer .pmark p,
#popform_footer .secom p {
  text-align: center;
}
#popform_footer .context {
  width: 450px;
}
#popform_footer .context p {
  font-size: 12px;
  padding-top: 10px;
}


/*-------------------------------------
	確認画面
------------------------------------ */

/* 未入力要素リスト
---------------------------------*/
#mailform #mailform_errorlist {
	margin: 0 50px 30px;
}
#mailform #mailform_errorlist p.check {
	margin-bottom: 1px;
	padding: 5px 5px 5px 30px;
	background: #fdd url(/pub/img/contact/check.jpg) no-repeat 0 50% ;
	color: #f00;
	text-align: left;
}

div#mailform_confirm {
	width:642px;
	margin:30px auto 0;
}
dl#mailform_answers {
	border:1px solid #cdcdcd;
	margin:0 auto 48px;
	padding:36px;
}
dl#mailform_answers dt,dl#mailform_answers dd {
	padding:6px;
}
dl#mailform_answers dt {
	color:#717171;
	font-weight:bold;
	float:left;
	width:120px;
}
dl#mailform_answers dd {
	border:1px dotted #cdcdcd;
	margin-bottom:24px;
	margin-left:132px;
	color:#343434;
	line-height:1.5;
}
#mainContents h1 {
	text-indent: 0;
}

#mailform div#form_cont_r p.context {
  padding: 30px 30px 0;
}

#mailform p.btn {
	padding: 20px;
	text-align: center;
}
#mailform p.btn input {
	margin: 0;
	padding: 0;
	border: none;
	-webkit-box-shadow: none;
	box-shadow: none;
	border-radius: 0;
}

.form18-radio-label {
	font-weight: normal!important;
}