@charset "utf-8";

/* -----------------------------------------------------------
    form
-------------------------------------------------------------- */

.page-contact .header {
	position: relative!important;
	/*z-index: -1;*/
}

.underttl-area{
	margin: 0;
}

.h1-area {
    position: absolute!important;
    left: 10px;
    top: -107px;
    z-index: 5;
}

.page-contact .f_contents_bottom .inner{
	text-align: center;
	justify-content: center;
	padding: 0px 0 40px 0;
}

.page-contact #form .form_area {
	padding: 0 0 40px;
}

/* イントロ */
#form .intro-area .inner{
	width: 1000px;
	margin: 0 auto 30px auto;
	position: relative;
}

.intro-img img {
	width: 120px;
	position: absolute;
	right: 10px;
	top: -30px;
	z-index: 3;
}

.intro-txt {
	text-align: center;
	margin: 15px 0 0 0;
}

.intro-txt-head {
	font-size: 1.8rem;
	font-weight: bold;
	color: #f39800;
	text-align: center;
	line-height: 1.5;
	letter-spacing: .05em;
}

.other-wrap {
	margin: 15px auto 0;
	background: #fff;
	width: 880px;
	border-radius: 10px;
}

.other-wrap .hide-up {
	display: none;
}

.other-wrap .hide-up .hide-wrap {
	display: flex!important;
	justify-content: center;
	margin: 20px 0 0 0;
	padding: 0 0 20px;
	width: 880px;
	padding: 20px 10px;
	border-radius: 20px;
}

.other-line {
	padding: 0 20px 0 0;
}

.other-line .other-line-txt {
	text-align: center;
}

.other-line .other-line-txt span {
	background: #11b24e;
	color: #fff;
	border-radius: 30px;
	padding: 3px 15px 5px;
}

.other-line .catch02 {
	line-height: 1.4;
	color: #11b24e;
	font-size: 1.8rem;
	font-weight: bold;
}

.other-line .qr-box img{
	width: 100px;
}

.other-line .id-box .id {
	font-size: 2.2rem;
	display: inline-block;
	padding: 5px 20px;
	background: #e2f9e9;
	margin: 20px 0 0 0;
}

.other-tel {
	color: #a29789;
	cursor: pointer;
	margin: 0 0 0 17px;
}

.other-tel-wrap {
	margin: 0 0 0 20px;
	border-left: 1px solid #ddd;
	padding: 0 0 0 10px;
}

.other-tel-note {
	color: #a29789;
	font-size: 1.8rem;
	font-weight: bold;
	margin: 15px 0;
	height: 50px;
	line-height: 55px;
}

.other-tel .other-tel-time {
	color: #a29789;
	display: block;
	text-align: center;
	font-size: 1.6rem;
	margin: 15px 0 0 0;
}

.other-tel .other-num-txt {
	color: #a29789;
	font: bold 2.7rem/1 'Poppins', sans-serif;
	letter-spacing: .05em;
}

.other-tel .other-num-txt i {
	font-size: 2.1rem;
	margin: 0 8px 5px 0;
}

.other-wrap .friend-box {
	display: flex;
	margin: 10px 0 0 0;
}

.other-wrap .friend-box .box {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin: 0 10px;
}

.other-wrap .menu-icon {
	margin: 0 0 0 10px;
}

.other-wrap .menu-icon span {
	display: block;
	position: relative;
	width: 25px;
	height: 25px;
	background: #f39800;
}

.other-wrap .menu-icon span::before,
.other-wrap .menu-icon span::after {
	background-color: #fff;
	content: "";
	height: 1px;
	position: absolute;
	width: 60%;
	transition: all .3s;
	top: 45%;
	left: 20%;
}

.other-wrap .menu-icon span::before {
	transform: rotate(0deg);
}

.other-wrap .menu-icon span::after {
	transform: rotate(90deg);
}

.other-wrap .tel-active .menu-icon span::after {
	transform: rotate(180deg);
}

.other-wrap .block-ttl {
	align-items: center;
	display: flex;
	justify-content: center;
	padding: 15px 0;
	position: relative;
	z-index: 2;
	background: #fdf1ea;
	border-radius: 10px;
}

.other-mail-wrap {
	margin: 0 0 0 20px;
	border-left: 1px solid #ddd;
	padding: 0 0 0 20px;
}

.other-mail-wrap img{
	width: 40px;
	margin-bottom: 10px;
}

.other-mail-wrap .txt{
	color: #a29789;
}

.page-contact .contents {
    padding: 100px 0 0;
}

@media screen and (max-width: 768px) {
	
	/* イントロ */
	#form .intro-area {
		padding: 0 20px;
		display: block;
		margin: 0 0 15px;
	}
	
	#form .intro-area.cmn-bg-orange {
		background: transparent;
	}
	
	#form .intro-area .inner {
		width: 100%;
		padding: 0;
		margin: 0 auto 10px auto;
	}
	
	.intro-txt-head {
		font-size: 1.6rem;
		text-align: left;
		letter-spacing: .03em;
	}
	
	.other-wrap {
		display: block;
		width: 100%;
		padding: 0;
		margin: 15px 0 0 0;
		border-radius: 10px;
	}
	
	.other-wrap .block-ttl {
		background: #fdf1ea;
		padding: 5px 0;
	}
	
	.intro-img img {
		width: 80px;
		position: absolute;
		right: -20px;
		top: 45px;
	}
	
	.other-line img {
		width: 130px;
	}
	
	.other-wrap .friend-box {
		display: none;
	}
	
	.other-line {
		display: block;
		margin: 15px 0 0;
	}
	
	.other-line .catch02 {
		font-size: 1.5rem;
	}
	
	.other-tel-wrap {
		border-top: 1px solid #ddd;
		border-left: none;
		margin: 15px 0 30px 0;
	}
	
	.other-tel {
		display: flex;
		flex-direction: column;
		width: 100%;
		margin: 0;
	}
	
	.other-tel-note {
		font-size: 1.5rem;
		margin: 20px 0 15px 0;
		height: auto;
		line-height: unset;
	}
	
	.other-tel .other-num-txt {
		font-size: 2.5rem;
	}
	
	.other-tel .other-num-txt i {
		font-size: 2rem;
	}
	
	.other-tel .other-tel-time {
		margin: 10px 0 0 0;
	}
	
	.other-wrap .hide-up .hide-wrap {
		display: block!important;
		z-index: 2;
		position: relative;
		margin: 10px 0 0 0;
		padding: 0;
		width: 100%;
	}
	
	.other-wrap .block-ttl p{
		font-size: 1.4rem;
		line-height: 1.3;
	}
	
	.other-mail-wrap {
		margin: 0 0 30px 0px;
		border-left: none;
		border-top: 1px solid #ddd;
		padding: 0 0 0 0px;
	}
	.page-contact .contents {
		padding: 10px 0;
	}
	
	.page-contact .header{
		position: absolute!important;
	}
}

/* aboutarea */
#form #top .about-area {
	padding: 0;
	margin: -20px auto 0;
}
#form #top .about-area .about-detail-area {
    background: none;
    padding: 0 0 20px;
}
#form #top .about-detail-area .title-block,
#form #top .about-detail-area .btn{
	display: none!important;
}

@media screen and (max-width: 768px) {
	
	/* aboutarea */
	#form #top .about-area {
		padding: 0 20px;
		margin: 0 auto 0;
	}
	#form #top .about-area .about-detail-area {
		padding: 0 0 0;
	}
	
	#form #top .about-area .block-wrapper .block{
		margin: 0 0 90px;
	}
	
}



/* お問い合わせテキスト */
#form .contact-area-txt {
	text-align: center;
	font-size: 1.8rem;
	line-height: 1.6;
}
#form .contact-area-title {
	text-align: center;
	font-size: 2.2rem;
	font-weight: 500;
	line-height: 1.6;
	padding: 0 0 30px;
}

@media screen and (max-width: 768px) {
	
	#form .contact-area-txt {
		text-align: left;
		font-size: 1.7rem;
		line-height: 1.7;
		padding: 0 20px;
	}
	#form .contact-area-title {
		font-size: 2rem;
		padding: 0 0 15px;
	}
	
}


/* 電話エリア */
#form .contact-tel-area {
	background: #ecf7ed;
	padding: 40px 0;
	margin: 60px 0;
}
#form .contact-tel-area .box-wrapper {
	display: flex;
	justify-content: space-between;
}

#form .contact-tel-area .box-wrapper li {
	width: 230px;
	background: #fff;
	border-radius: 10px;
	box-shadow: #ddd 1px 1px 20px;
	text-align: center;
	padding: 20px;
}
#form .contact-tel-area .box-wrapper li:last-of-type {
	margin-right: 0;
}

#form .contact-tel-area .box-wrapper .name {
	padding: 0 0 10px;
	color: #33b371;
	font-size: 2rem;
	line-height: 1.5;
}
#form .contact-tel-area .box-wrapper .tel {
	font-size: 2.6rem;
	font-weight: 500;
	line-height: 1.2;
}
#form .contact-tel-area .box-wrapper .tel i {
	font-size: 1.6rem;
	margin: 0 8px 0 0;
	vertical-align: middle;
}
#form .contact-tel-area .box-wrapper .time {
	line-height: 1.6;
	font-size: 1.4rem;
	margin: 15px 0 0;
}


@media screen and (max-width: 768px) {
	
	/* 電話エリア */
	#form .contact-tel-area {
		padding: 30px 20px 15px;
		margin: 30px 0;
	}
	#form .contact-tel-area .box-wrapper {
		display: block;
	}

	#form .contact-tel-area .box-wrapper li ,
	#form .contact-tel-area .box-wrapper li:last-of-type{
		width: auto;
		padding: 15px;
		margin: 0 0 15px;
	}

	#form .contact-tel-area .box-wrapper .name {
		padding: 0 0 5px;
		font-size: 2rem;
	}
	#form .contact-tel-area .box-wrapper .tel {
		font-size: 2.4rem;
	}
	#form .contact-tel-area .box-wrapper .time {
		margin: 10px 0 0;
	}
	
}


/*
#form .page_title_area {
	background: url(../img/gray_bg.png)repeat;
}
*/

#form .form_area {
	padding: 0 0 120px;
}

#form .form_area.complete {
	padding: 40px 0 0;
}

#form .form_area .tel_area {
	margin: 30px 0 0 0;
	padding: 30px;
	text-align: center;
	border: 1px #F58A00 solid;
}

#form .form_area .tel_area .txt {
	font-size: 2.0rem;
	font-weight: bold;
	color: #F48A00;
}

#form .form_area .tel_area .tel_txt {
	margin: 8px 0 0 0;
	font-size: 3.0rem;
	font-weight: bold;
	font-family: Arial, Helvetica, "sans-serif";
}

#form .form_area .tel_area .tel_txt img {
	width: 24px;
	vertical-align: top;
	margin: 4px 5px 0 0;
}

#form .form_area .tel_area .tel_time {
	margin: 10px 0 0 0;
	font-size: 1.2rem;
}

#form .form_area .mail_title {
	font-size: 2.0rem;
	font-weight: bold;
	color: #F48A00;
	padding: 60px 0 20px 0;
}

#form .form_area .mail_title img {
	width: 26px;
	vertical-align: middle;
	margin: 0 5px 0 0;
}

#form .form_area.complete .back-link {
	text-align: center;
	padding: 0 0 100px;
	position: relative;
}
#form .form_area.complete .back-link a{
	color: #333;
}

#form .form_area.complete .back-link a::before {
	display: inline-block;
	content: "\f105";
	font-weight: 900;
	font-family: 'Font Awesome 6 Free';
	padding: 0 5px 0 0;
	color: #f39800;
}

@media screen and (max-width: 768px) {
	#form .form_area {
		padding: 0 0 70px;
	}
	#form .form_area.complete {
		padding: 30px 20px 20px;
	}
	#form .form_area .tel_area {
		margin: 20px 20px 0 20px;
		padding: 20px;
		text-align: center;
	}
	#form .form_area .tel_area .txt {
		font-size: 1.6rem;
	}
	#form .form_area .tel_area .tel_txt {
		font-size: 2.6rem;
		color: #444;
	}
	#form .form_area .tel_area .tel_txt img {
		width: 22px;
		margin: 2px 5px 0 0;
	}
	#form .form_area .tel_area .tel_time {
		margin: 10px 0 0 0;
	}
	#form .form_area .mail_title {
		font-size: 1.8rem;
		padding: 30px 20px 20px 20px;
	}
	#form .form_area .mail_title img {
		width: 22px;
		margin: 0 5px 0 0;
	}
	#form .form_area.complete .back-link {
		padding: 30px 0 30px 0;
	}
}


/* -----------------------------------------------------------
    input
-------------------------------------------------------------- */

.form_area input[type="text"],
.form_area input[type="email"],
.form_area input[type="tel"],
.form_area input[type="number"],
.form_area input[type="password"],
.form_area select,
.form_area textarea {
	border: 1px solid #DDD;
	padding: 15px;
	font-size: 1.6rem;
	font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color: #333;
	letter-spacing: 0.03em;
	background: #fff;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

.form_area input[type="text"]:focus,
.form_area input[type="email"]:focus,
.form_area input[type="tel"]:focus,
.form_area input[type="number"]:focus,
.form_area input[type="password"]:focus,
.form_area select:focus,
.form_area textarea:focus {
	border: 1px solid #3972B7;
}

.form_area input[type="number"] {
	-moz-appearance: textfield;
}

.form_area input[type="number"]::-webkit-outer-spin-button,
.form_area input[type="number"]::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

.form_area select {
	width: 45%;
	padding: 5px;
	margin: 0 0 0 10px;
	background: #fff url(../img/icon_arrow_under.png) no-repeat 95% 50%;
	background-size: 20px auto;
}

.form_area td.area select {
	width: 40%;
	padding: 10px;
	margin: 0 0 0 0;
	background: #fff url(../img/icon_arrow_under.png) no-repeat 95% 50%;
	background-size: 20px auto;
}

.form_area select:hover {
	cursor: pointer;
}

.form_area option {
	padding: 5px 15px;
}

.form_area select option selected {
	color: #999;
}

.form_area textarea {
	width: 100%;
}

.form_area input[type="radio"],
.form_area input[type="checkbox"] {
	vertical-align: -1px;
	margin: 0 12px 0 0;
	font-family: "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
	border-radius: 0;
}

.form_area label:hover {
	cursor: pointer;
}

.form_area label.label_first {
	display: inline-block;
	margin: 0 40px 0 0;
}




/* -----------------------------------------------------------
    button / submit
-------------------------------------------------------------- */

input[type="submit"],
input[type="button"] {
	display: block;
	font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	letter-spacing: 0.08em;
	margin: 0 auto;
	transition: 0.5s;
	border: none;
	outline: none;
	appearance: none;
	color: #FFF;
	font-size: 1.9rem;
	font-weight: bold;
	width: 330px;
	padding: 28px 30px 31px;
	text-align: center;
	line-height: 1;
	border-radius: 3px;
}

#form input[type="submit"],
#form input[type="button"] {
	min-width: 300px;
}

#form input[type="submit"][disabled] {
	color: #fff;
	background: #e4e4e4;
	border-radius: 40px;
}

input[type="submit"] {
	background: #f39800;
}

input[type="submit"].submit_gray,
input[type="button"].submit_gray {
	color: #333;
	width: 330px;
	background: #EEE;
	padding: 28px 30px 31px;
	text-align: center;
}

input[type="button"]:hover {
	cursor: pointer;
	background: #CCC;
}

input[type="submit"]:hover {
	cursor: pointer;
	background: #ffb438;
}


/*		送信ボタン		*/

.form_btn_area {
	padding: 60px 0 0 0;
	text-align: center;
}

.form_btn_area .fl {
	float: left;
}

.form_btn_area .fr {
	float: right;
}

.form_btn_area .confirm .clearfix {
	display: flex;
	justify-content: center;
	width: 750px;
}

.form_btn_txt {
	margin: 0 0 40px;
}

.error_message {
	text-align: center;
	padding: 130px 0 40px;
	line-height: 1.8;
}

.submit_btn {
	background: #ebc118;
}


/* -----------------------------------------------------------
    フォーム共通
-------------------------------------------------------------- */

.form_toptxt {
	line-height: 1.8;
	text-align: center;
}

.form_toptxt.s {
	font-size: 1.3rem;
}

.back_btn {
	margin: -65px 0 0;
	width: 21%;
	font-size: 1.4rem;
	text-align: center;
	background: url(../img/icon_arrow_left.png) no-repeat 10% 49%;
	background-size: 7px 13px;
}

.back_btn a {
	display: block;
	padding: 20px 0;
	border: 1px solid #666;
}

.attention {
	margin: 10px 0;
	line-height: 1.6;
}


/* -----------------------------------------------------------
    入力画面共通  /  table
-------------------------------------------------------------- */

.form-title{
	font-size: 2.0rem;
    font-weight: 500;
	text-align: center;
    width: 100%;
    background: var(--main);
    color: #fff;
    padding: 10px 20px;
    border-radius: 3px;
    margin: 50px 0 40px;
}

.form_table {
	margin: 20px 0 0;
	width: 100%;
	border-collapse: collapse;
	border-top: 1px solid #ddd;
	letter-spacing: 0.05em;
	line-height: 2;
}

.form_table.style2 {
	border-top: none;
	margin-top: 0px;
}

.form_table tr {
	border-bottom: 1px solid #ddd;
}

.form_table th {
	width: 35%;
	padding: 30px 50px;
	text-align: left;
	font-weight: bold;
	vertical-align: top;
}

.form_th_title {
	display: inline-block;
	padding: 5px 0 0;
}

.form_th_notes {
	float: right;
	display: inline-block;
	margin: 5px 0 0;
	padding: 3px 12px;
	font-size: 1.3rem;
	font-weight: bold;
	color: #fff;
	background: #E94647;
}

.form_table td {
	padding: 30px 30px 30px 0;
	text-align: left;
	vertical-align: top;
}

.form_table .none td {
	text-align: center;
	font-size: 1.7rem;
	font-weight: 500;
}

.form_table input[type="text"],
.form_table input[type="password"],
.form_table input[type="tel"],
.form_table input[type="email"],
.form_table select {
	width: 80%;
}

.form_table input[type="number"] {
	width: 30%;
}

/*		郵便番号		*/

.form_area input[type="number"].input_zip {
	width: 30%;
	margin: 0 0 0 10px;
}

.zip_btn {
	width: 30%;
	margin: 15px 0 0;
	text-align: center;
}

.zip_btn a {
	display: block;
	padding: 10px 0;
	color: #fff;
	background: #7FB2AA;
}

/*シャッターのサイズ*/
.size-item-txt {
	min-width: 50px;
	display: inline-block;
	text-align: center;
	background: #a29789;
	padding: 3px 10px;
	color: #fff;
	font-weight: bold;
	margin: 0 5px;
}

/*メーカー*/
.item-mfr td ul{
	display: flex;
	flex-wrap: wrap;
}
.item-mfr td li {
	margin: 0 30px 10px 0;
}

/*修理交換箇所*/
.resume-item-txt {
	margin-right: 5px;
}
.resume-item-txt em {
	font-weight: bold;
	background: #FCE69B;
	padding: 0 5px;
}
.confirm .resume-item {
	display: flex;
}
.confirm .resume-item .resume-item-img {
	width: 150px;
	height: 130px;
}
.confirm .resume-item .resume-item-img img{
	max-width: 100%;
	max-height: 100%;
}


/*		お問い合わせ		*/

.radio_list {}

.radio_list li {
	line-height: 2.4;
}


/*		注釈		*/

.form_td_notes {
	display: inline-block;
	font-size: 1.4rem;
	color: #286bea;
}

.form_td_notes02 {
	margin: 15px 0;
	font-size: 1.5rem;
	color: #286bea;
}

.form_td_notes03 {
	margin: 15px 0 0;
	font-size: 1.4rem;
}

.form_td_notes04 {
	margin: 7px 0 15px;
	font-size: 1.4rem;
}

/*シャッター新設枠　js用*/
.type01_control {
	border-top: none;
	margin-top: 0;
}

/*シャッター修理枠　js用*/
.type02_control {
	border-top: none;
	margin-top: 0;
}

/*最後の枠　js用*/
.form_table.last {
	border-top: none;
	margin-top: 0;
}


/* -----------------------------------------------------------
    確認画面共通
-------------------------------------------------------------- */

.form_table.confirm {}

.form_table.confirm th {
	width: 30%;
}


/*		写真添付		*/

.form_table .form_photo {
	margin: 10px 0 0;
}

.form_table .form_photo img {
	width: 300px;
}

.form_btn_area.confirm .btn-wrap {
	display: flex;
	width: 800px;
	justify-content: center;
	margin: 0 auto;
}

.form_btn_area.confirm .btn-wrap input {
	margin: 0 30px;
}

.caution {
	font-size: 1.5rem;
	color: #E94647;
	margin: 40px 20px 0 20px;
	text-align: center;
	line-height: 1.8;
}


/* -----------------------------------------------------------
    完了画面共通
-------------------------------------------------------------- */

.form_area .complete_title {
	font-size: 2.4rem;
	font-weight: bold;
	text-align: center;
	line-height: 1.6;
	padding: 0 0 10px;
}

.form_area .complete_txt {
	margin: 30px 0 50px;
	line-height: 1.8;
	text-align: center;
}

.form_area .back_link {
	margin: 60px 0 20px;
	text-align: center;
	font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}


/* -----------------------------------------------------------
    SP
-------------------------------------------------------------- */

@media screen and (max-width:768px) {
	#page_top {
		bottom: 30px;
	}
	/* -----------------------------------------------------------
		input
	-------------------------------------------------------------- */
	.form_area input[type="text"],
	.form_area input[type="tel"],
	.form_area input[type="password"],
	.form_area input[type="email"],
	.form_area input[type="number"],
	.form_area select,
	.form_area textarea {
		padding: 15px;
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
		font-size: 1.6rem;
		-webkit-appearance: none;
		border-radius: 0;
	}
	.form_area input[type="text"],
	.form_area input[type="email"],
	.form_area input[type="number"],
	.form_area input[type="tel"],
	.form_area input[type="password"],
	.form_area select,
	.form_area textarea {
		width: 100%;
	}
	.form_area select {
		padding: 10px 15px;
		background: #fff url(../img/icon_arrow_under.png) no-repeat 95% 50%;
		background-size: 18px auto
	}
	.form_area td.area select {
		width: 100%;
		padding: 10px 15px;
		background: #fff url(../img/icon_arrow_under.png) no-repeat 95% 50%;
		background-size: 18px auto
	}
	.form_area input[type="radio"],
	.form_area input[type="checkbox"] {}
	/* -----------------------------------------------------------
		button / submit
	-------------------------------------------------------------- */
	.btn {}
	.btn.back_btn {
		top: 0;
	}
	.btn.back_btn a {
		display: inline-block;
		width: auto;
		padding: 10px 5px 10px 20px;
		border: none;
		font-size: 1.6rem;
		text-align: left;
		background: #fff url(../img/icon_arrow03.png) no-repeat 0 50%;
		background-size: 11px 11px;
	}
	.form_area input[type="submit"] {
		display: block;
		width: 100%;
		max-width: 300px;
		padding: 25px 10px;
		font-size: 1.80rem;
		box-sizing: border-box;
		box-shadow: 2px 2px 3px #DDD;
	}
	#form input[type="submit"],
	#form input[type="button"] {
		min-width: inherit;
	}
	input[type="submit"].submit_gray,
	input[type="button"].submit_gray {
		width: 100%;
		font-size: 1.4rem;
		padding: 10px 10px;
	}
	.form_btn_area {
		padding: 0 20px;
		text-align: left;
	}
	.page-contact.input .form_btn_area {
		margin: 30px auto;
	}
	.form_btn_txt {
		margin: 0 0 20px;
		line-height: 1.8;
		/*
		text-align: center;
		*/
		text-align: left;
	}
	.submit_org {}
	.submit_gray {
		font-size: 1.4rem;
		box-shadow: 2px 2px 3px #DDD;
	}
	.submit_magenta {}
	.submit_green {}
	.form_btn_area .fl,
	.form_btn_area .fr {
		float: none;
	}
	.form_btn_area .fr {
		margin: 30px 0 0 0;
	}
	.error_message {
		text-align: left;
		padding: 30px 0 20px;
	}
	/* -----------------------------------------------------------
		フォーム共通
	-------------------------------------------------------------- */
	.form_toptxt {
		padding: 0 20px 0;
		line-height: 1.8;
		text-align: left;
	}
	.form_toptxt.s {
		padding: 0 0 0 0;
		font-size: 1.3rem;
	}
	/* -----------------------------------------------------------
		入力画面共通  /  table
	-------------------------------------------------------------- */
	.form_table {
		margin: 20px 0 0;
	}
	.page-contact.input .form_table {
		margin: 10px 0 0;
	}
	.top-txt {
		font-size: 1.5rem;
	}
	.form_table tr {
		border: none;
	}
	.form_table th {
		display: block;
		width: 100%;
		padding: 15px 15px;
		text-align: left;
		vertical-align: middle;
		border-top: 1px #ddd solid;
	}
	.form_table tr:first-of-type th {
		border-top: none;
	}
	.form_table tr:last-child td {
		border-bottom: 1px solid #ddd;
	}
	.form_table td {
		display: block;
		width: 100%;
		border: none;
		padding: 0 20px 20px 20px;
		text-align: left;
		vertical-align: top;
	}
	.form_table td .size-item {
		display: flex;
		align-items: center;
	}
	.form_table td .size-item input {
		max-width: 200px;
		
	}
	.size-item-txt {
		flex-shrink: 0;
		min-width: 70px;
		margin: 0 5px 5px 5px;
	}
	.form_th_title {
		padding: 0;
	}
	.form_table th .form_th_notes {
		float: none;
		display: inline-block;
		margin: -5px 0 0 10px;
		padding: 2px 10px;
		font-size: 1.2rem;
		font-weight: bold;
		background: #E94647;
	}
	.form_table.rec th .form_th_notes {
		background: #66CCC0;
	}
	.form_table input[type="text"],
	.form_table input[type="password"],
	.form_table input[type="tel"],
	.form_table input[type="email"],
	.form_table select {
		width: 100%;
	}
	.form_table input[type="number"] {
		width: 100%;
	}
	/*		生年月日		*/
	.form_area input[type="text"].birth {
		width: 50%;
	}
	/*		郵便番号		*/
	.form_area input[type="text"].input_zip,
	.form_area input[type="number"].input_zip {
		width: 50%;
		margin: 0 10px 0 10px;
	}
	/*		年齢		*/
	.form_area input[type="number"].input_old {
		width: 40%;
		margin: 0 10px 0 0;
	}
	/*		お問い合わせ		*/
	.radio_list {}
	.radio_list li {
		line-height: 1.8;
	}
	.radio_list label {
		display: block;
		padding: 5px;
	}
	/*		注釈		*/
	.form_td_notes {
		display: inline-block;
		margin: 10px 0 0;
		font-size: 1.4rem;
	}
	.form_td_notes02 {
		margin: 10px 0;
		font-size: 1.4rem;
	}
	.form_td_notes03 {
		margin: 10px 0 0;
		font-size: 1.4rem;
	}
	.item-mfr td li {
		margin: 0 15px 10px 0;
		font-size: 1.6rem;
	}
	
	.item-mfr td li input[type="radio"] {
		margin-right: 2px;
	}
	
	/* -----------------------------------------------------------
		確認画面
	-------------------------------------------------------------- */
	.form_btn_area.confirm .btn-wrap{
		flex-direction: column-reverse;
		justify-content: center;
		width: 100%;
	}
	
	/*最後の枠　js用*/
	.form_table.last {
		margin-bottom: 20px;
	}
	
	.form_btn_area.confirm .btn-wrap input {
		max-width: 300px;
		margin: 0 auto 20px;
		padding: 25px 10px;
	}
	
	.caution {
		text-align: left;
	}

	/* -----------------------------------------------------------
		完了画面共通
	-------------------------------------------------------------- */
	.form_area .complete_title {
		font-size: 2.0rem;
		padding: 0 0 0;
	}
	.form_area .complete_txt {
		margin: 20px 0 15px;
		text-align: left;
	}
	.form_area .back_link {
		margin: 30px 0 20px;
		text-align: left;
	}
}

.copy {
	padding: 0 0 40px;
	font-size: 1.2rem;
}


/* -----------------------------------------------------------
    order
-------------------------------------------------------------- */

.order_table {
	width: 100%;
	border-collapse: collapse;
	margin: 30px auto;
}

.order_table th {
	background-color: #999;
	border: solid 1px #ddd;
	padding: 10px;
	color: #fff;
}

.form_area .order_table input {
	border: none;
}

.form_area .order_table input:focus {
	border: none;
	background: #EFF5F9;
}

.order_table .sample {
	background: #f0f0f0;
}

.order_table .sample td:nth-of-type(2),
.order_table .sample td:nth-of-type(3) {
	padding: 15px;
}

.order_table td {
	border-bottom: solid 1px #ddd;
	border-right: solid 1px #ddd;
}

.order_table td:first-of-type {
	width: 60px;
	text-align: center;
	border-left: solid 1px #ddd;
}

.order_table td:nth-of-type(2) {
	width: 580px;
}

.order_table td:nth-of-type(3) {
	width: 140px;
}

.order_table input {
	width: 100%;
}
#form {
	position:relative;
	z-index:0 !important;
}
#form .g-recaptcha-response {
	position:relative;
	z-index:10 !important;
}

@media screen and (max-width:768px) {
	.order_table {
		width: auto;
		margin: 20px -20px 0;
	}
}
/*LINEコンテンツ追加*/

#line .bread-h1-wrap {
	padding-bottom: 30px;
}

#line .line-ttl {
	align-items: center;
	font-size: 3.3rem;
	font-weight: bold;
	line-height: 1.5;
	letter-spacing: .05rem;
	margin: 0 0 50px 0;
	display: flex;
	justify-content: center;
	color: #06c755;
}

#line .line-ttl .sub-txt {
	padding: 8px 12px 11px 20px;
	display: inline-block;
	color: #fff;
	background: #06c755;
	font-size: 1.8rem;
	vertical-align: text-top;
	margin: 0 20px 0 0;
	border-radius: 60px;
	letter-spacing: .08em;
}


#line .main-area {
    position: relative;
	border: 3px solid #06c755;
    background: #fff;
    border-radius: 10px;
    padding: 50px 40px;
}

#line .main-area {
	position: relative;
	background: #fff;
	border-radius: 10px;
	padding: 50px 40px;
	margin: 0 0 50px;
}

#line .main-flex {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

#line .main-flex .friend-box {
	padding: 20px 30px;
	background: #e2f9e9;
	border-radius: 10px;
	width: 45%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	
}

#line .main-flex .friend-box .friend-txt {
	font-size: 2.0rem;
	display: flex;
	gap: 20px;
	padding: 0 0 15px 0;
	border-bottom: 6px dotted #06C755;
	line-height: 1.4;
	align-items: center;
	width: 100%;
	justify-content: center;
	letter-spacing: .03em;
}

#line .main-flex .friend-box .friend-txt img{
	display: inline-block;
	vertical-align: middle;
}

#line .main-flex .friend-box .id-box {
	margin: 15px 0 0 0;
	text-align: center;
}

#line .main-flex .friend-box .qr-box {
	text-align: center;
	width: 40%;
	margin: 15px 0 0;
}

#line .main-flex .friend-box .qr-box .txt {
	font-size: 2.4rem;
	display: inline-block;
	margin: 0;
}

#line .main-flex .friend-box .qr-box img {
	width: 130px;
	height: 130px;
	object-fit: cover;
}

#line .main-flex .friend-box .id-box .txt {
	font-size: 2.4rem;
	display: inline-block;
	margin: 0 0 10px 0;
}

#line .main-flex .friend-box .id-box .id {
	font-size: 2.6rem;
	display: inline-block;
	padding: 5px 20px 8px 20px;
	background: #fff;
	text-align: center;
	letter-spacing: .03em;
}

#line .main-flex .point-box {
	width: 50%;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	position: relative;
}

#line .main-flex .point-box:after {
	content: "";
	display: inline-block;
	background: url("../img/cmn-man.png") center / cover, no-repeat;
	width: 154px;
	height: 173px;
	right: 40px;
	bottom: 0;
	position: absolute;
}

#line .main-flex .point-box .txt {
	width: 100%;
	font-size: 2.0rem;
	font-weight: bold;
	line-height: 1.8;
	letter-spacing: .03em;
}

#line .main-flex .point-box .point-flex {
	display: flex;
	justify-content: flex-start;
	gap: 20px;
}

#line .main-flex .point-box .point-flex .point-txt {
	width: 170px;
	height: 170px;
	position: relative;
	background: #e2f9e9;
	border-radius: 100%;
	display: inline-block;
}

#line .main-flex .point-box .point-flex .point-txt span {
	color: #06c755;
	line-height: 1.7;
	font-size: 1.8rem;
	font-weight: bold;
	position: absolute;
	display: inline-block;
	width:100%;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	text-align: center;
}

#line .add_btn {
    text-align: center;
    margin: 50px auto 0;
}

#line .add_btn a {
    width: 100%;
    max-width: 400px;
    padding: 20px 10px;
    color: #fff;
    font-size: 2.4rem;
    font-weight: bold;
    background: #24C404;
	box-shadow: 0 5px 0 0 #05923e;
    border-radius: 50px;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
}

#line .add_btn a::before {
    content: "";
    background: url(../img/line-icon.png) no-repeat center center / contain;
    display: inline-block;
    width: 40px;
    height: 40px;
    margin: 0 10px 0 0;
    vertical-align: middle;
}

#line .add_btn a:hover {
    box-shadow: none;
}

@media screen and (max-width:768px) {
	
	#form .form_area.complete.line-area{
		background: #EBF6E8;
		padding: 0px 20px 20px;
	}
	
	#line .bread-h1-wrap {
		padding-bottom: 0;
	}
	
	#line .line-ttl {
		font-size: 2.2rem;
		display: block;
		margin: 0 auto 10px auto;
		text-align: center;
	}
	
	#line .line-ttl .sub-txt {
		padding: 5px 12px 6px 20px;
		font-size: 1.5rem;
		margin: 0 auto 10px;
	}
	
	#line .main-wrap {
		padding: 30px 20px;
	}
	
	#line .main-area {
		padding: 25px 15px;
		margin: 40px auto 0;
	}
	
	#line .main-flex .point-box::after {
		width: 28%;
		height: initial;
		object-fit: cover;
		aspect-ratio: 201 / 223;
		right: -35px;
		bottom: 10px;
		max-width: 135px;
	}
	
	#line .main-flex {
		flex-direction: column-reverse;
	}
	
	#line .main-flex .point-box .point-flex {
		gap: 10px;
		margin: 20px 0;
	}
	
	#line .main-flex .point-box {
		width: 100%;
	}
	
	#line .main-flex .point-box .txt {
		font-size: 1.6rem;
		font-weight: 500;
		line-height: 1.8;
		margin: 10px 0 0 0;
	}
	
	#line .main-flex .point-box .point-flex .point-txt {
		width: 130px;
		height: 130px;
	}
	
	#line .main-flex .point-box .point-flex .point-txt span {
		line-height: 1.7;
		font-size: 1.4rem;
	}
	
	#line .main-flex .friend-box {
		padding: 25px 10px 30px 10px;
		width: 100%;
		justify-content: space-between;
	}
	
	#line .main-flex .friend-box .friend-txt {
		font-size: 1.7rem;
		display: flex;
		gap: 10px;
		padding: 0 0 10px 0;
		line-height: 1.4;
		margin: 0 0 5px 0;
	}
	
	#line .main-flex .friend-box .friend-txt img {
		width: 40px;
		margin: 0;
	}
	
	#line .main-flex .friend-box .id-box {
		margin: 10px 0 0 0;
		width: 48%;
		text-align: center;
	}
	
	#line .main-flex .friend-box .id-box .txt {
		font-size: 1.8rem;
		margin: 0 auto 8px;
		text-align: center;
		display: block;
	}
	
	#line .main-flex .friend-box .id-box .id {
		font-size: 1.8rem;
        padding: 2px 12px 4px;
    }
	
	#line .main-flex .friend-box .qr-box {
		width: 48%;
		margin: 10px 0 0 0;
	}
	
	#line .main-flex .friend-box .qr-box .txt {
		font-size: 1.8rem;
		text-align: center;
		margin: 0 auto 8px;
	}
	
	#line .main-flex .friend-box .qr-box img {
		width: 140px;
		height: auto;
	}
	
	#line .add_btn {
        margin: 25px auto 10px;
    }
	
	#line .add_btn a {
        width: 100%;
        padding: 15px 10px;
        font-size: 2.2rem;
    }
}