@charset "shift-jis";


/*--------newsBox----------*/
.newsBox{
	margin: 50px 0 20px;
	border: 1px solid #e83928;
	padding: 10px 15px;
}
.newsBox .ttl{
	font-weight: bold;
	font-size: 16px;
}
@media screen and (max-width: 767px) {
	.newsBox{
		margin: 0 0 20px;
	}
}
/*--------topSec----------*/

.topSec {
  margin: 50px 0;
}
.topSec .txtBox{
	float: left;
	width: 600px;
}
.topSec .infoBox{
	float: right;
	width: 360px;
}
.topSec .infoBox .text-r{
	font-size: 14px;
}
.topSec .contactArea{
	border: 1px solid #ddd;
	padding: 15px 20px;
	margin-bottom: 10px;
}
.topSec .contactArea .notice{
	font-size: 13px;
}
.noticeAbroad{
	font-size: 16px;
	margin: 20px 0 0;
	border-radius: 3px;
	background-color: #f7f7f7;
}
.noticeAbroad .accIn{
	font-size: 14px;
	text-align: left;
	padding: 0 15px 10px;
}
.noticeAbroad .iconPlus{
	display: block;
	padding: 10px 15px;
}
.noticeAbroad .iconPlus:before,
.noticeAbroad .iconPlus:after{
	background-color: #e83928;
	top:20px;
	margin-right: 15px;
}
@media screen and (max-width: 767px) {
	.topSec {
		margin: 0 0 30px;
	}
	.topSec .txtBox,
	.topSec .infoBox{
		float: none;
		width: 100%;
	}
	.topSec .contactArea{
		margin-top: 15px;
		padding: 10px 10px;
	}
	.noticeAbroad .iconPlus{
		padding: 10px;
	}
}
/*--------progressFlow----------*/
.progressFlow{
	overflow: hidden;
  margin: 0 0 70px;
}
.step2 .progressFlow{
	margin-bottom: 0;
}
.progress li {
	width: 40%;
	float: left;
	text-align: center;
	position: relative;
	font-size: 14px;
	box-sizing: border-box;
}
.progress li:first-child,
.progress li:last-child{
	width: 30%;
}
.progress li:first-child{
  padding-right: 90px;
}
.progress li:last-child{
  padding-left: 90px;
}
.progress li:before,
.progress li:after{
	content: "";
	display: block;
	width: 200px;
	border-top: 3px solid #ddd;
	position: absolute;
	top: 16px;
}
.progress li:before {
	left: 0;
}
.progress li:after {
	right: 0;
}
.progress li.current:before,
.progress li.current:after{
	border-top: 3px solid #e83928;
}
.progress li:first-child:before,
.progress li:last-child:after{
	display: none;
}
.progress li .num {
	display: inline-block;
	border: 3px solid #ddd;
	color: #ddd;
  border-radius: 100%;
	font-size: 14px;
	background: #FFF;
	position: relative;
	width: 30px;
	line-height: 30px;
	text-align: center;
	z-index: 5;
	font-weight: bold;
}
.progress li.current .num{
	border: 3px solid #e83928;
	color: #e83928;
}
.progress li .txt{
	display: block;
	margin-top: 5px;
}
@media screen and (max-width: 767px) {
	.progressFlow{
		margin: 30px 0;
	}
	.progress li {
		width: 36%;
		font-size: 13px;
	}
	.progress li:first-child,
	.progress li:last-child{
		width: 32%;
		padding: 0;
	}
	.progress li:first-child:after,
	.progress li:last-child:before{
		width: 60%;
	}
	.progress li:first-child .num{
		margin-right: 15%;
	}
	.progress li:last-child .num{
		margin-left:15%;
	}
	.progress li:before,
	.progress li:after{
		width: 50%;
	}
	.progress li .txt{
		margin-top: 5px;
	}
	.progress li:first-child .txt{
		margin-right: 10%;
	}
	.progress li:last-child .txt{
		margin-left:10%;
	}
}
/*--------warningBox----------*/
.warningBox{
	border: 2px solid #e83928;
	text-align: center;
	width: 480px;
	margin: 50px auto 0;
	padding: 20px 10px;
	font-weight: bold;
	color: #e83928;
	box-sizing: border-box;
}
@media screen and (max-width: 767px) {
	.warningBox{
		text-align: left;
		width: 100%;
		margin-top: 30px;
		padding: 10px;
	}
}

/*--------formArea----------*/
.form{
	margin-bottom: 80px;
}
.formTable{
	width: 100%;
	box-sizing: border-box;
  border: 1px solid #E5E5E5;
  font-size: 16px;
}
.formTable tr {
  border-bottom: 1px solid #E5E5E5;
}
.step1 .formTable #areaHide{
	display: none;
}
.formTable th {
  width: 33%;
  padding: 20px 20px;
	vertical-align: top;
	background-color: #f7f7f7;
	text-align: left;
}
.formTable .ttl{
  font-size: 16px;
	font-weight: bold;
}
.formTable td {
  font-size: 16px;
  padding: 20px 20px;
  vertical-align: middle;
}
.formTable td .sec{
	margin-bottom: 20px;
}
.formTable td .sec:last-child{
	margin-bottom: 0;
}
.formTable td .w70 {
  width: 70%;
}
.formTable td .w100 {
  width: 100%;
}
.formTable td .ttl{
	margin-bottom: 5px;
	padding-right: 0!important;
}
.formTable .ttl .note{
	font-size: 14px;
	font-weight: normal;
}
.step2 .formTable .ttl .note{
	display: none;
}
/* 必須項目 */

.formTable .requiredWrap .ttl{
	position: relative;
	padding-right: 40px
}
.form .icon_require {
	display: block;
	position: absolute;
	top: 2px;
	right: 0;
  background-color: #e83928;
  color: #FFF;
	line-height: 1.2;
  font-size: 14px;
  padding: 3px 7px 2px;
	border-radius: 3px;
}
.form .icon_require.done {
  background-color: #888;
}
.form td.error {
  background-color: #fcebe9;
}
/* エラー吹き出し*/
.error-balloon p{
	color: #e83928;
	font-size: 12px;
	border: 1px solid #e83928;
	background-color: #fff;
	padding: 3px 6px;
	margin: 0 0 8px 0;
	border-radius: 3px;
	position: relative;
	display: inline-block;
}
.error-balloon span {
	border-color: #e83928 transparent transparent;
	border-style: solid;
	border-width: 5px 5px 0;
	bottom: -5px;
	content: "";
	display: block;
	left: 40px;
	position: absolute;
}
.error-balloon span:before {
	border-color: #fff transparent transparent;
	border-style: solid;
	border-width: 4px 4px 0;
	bottom: 1px;
	content: "";
	display: block;
	left: -4px;
	position: absolute;
}
@media screen and (max-width: 767px) {
	.form{
		margin-bottom: 30px;
	}
	.formTable,
	.formTable tbody,
	.formTable tr,
	.formTable th,
	.formTable td{
		box-sizing: border-box;
		width: 100%;
		display: block;
	}
	.formTable tr:last-child {
		border-bottom:0;
	}
	/*.formTable #areaHide{
  	border-top: 1px solid #E5E5E5;
	}*/
	.formTable th,
	.formTable td {
		padding: 10px 8px;
	}
	.formTable td .w70 {
		width: 100%;
	}
}
/*--------input装飾----------*/

/* 入力項目 */
.form input[type="text"],
.form input[type="email"],
.form input[type="tel"],
.form textarea {
	box-sizing: border-box;
	min-width: 100px;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 3px 3px 3px 3px;
  font-size: 16px;
	padding: 10px 6px;
	box-shadow: 0;
	-webkit-appearance: none; 
}
.form .drop{
	box-sizing: border-box;
	min-width: 200px;
	padding: 10px 30px 10px 10px;
	font-size: 16px;
	line-height: 1.2;
  border: 1px solid #CCCCCC;
	-webkit-appearance: none;
	-moz-appearance:none;
	appearance:none;
  border-radius: 3px;
	position: relative;
	background: #fff url(/lifecare/img/contact/icon_selectbox.png) no-repeat right 10px center;
	background-size: 10px auto;
	cursor: pointer;
}
select::-ms-expand {
    display: none;
}
.form input[type="text"]:focus,
.form input[type="email"]:focus,
.form input[type="tel"]:focus,
textarea:focus {
  background-color: #FFF9DE;
}
::-webkit-input-placeholder {
  color:#999;
}
:-moz-placeholder {
  color:#999;
}

/*radioボタン*/
.radioList li{
	font-size: 16px;
	position: relative;
	margin-bottom: 5px;
}
.radioList.clm2 li{
	float: left;
	width: 48%;
}
.radioList.clm2 li:nth-child(2n){
	float: right;
}
.radioList li:last-child{
	margin-bottom: 0;
}
.radioList li input[type=radio]{
	opacity: 0;
	position: absolute;
	top:0;
	left: 0;
}
.radioList li input[type=radio] + .radioBtn{
	background-image: url(/lifecare/img/contact/rb_off.png);
	background-repeat: no-repeat;
	background-position: left center;
	background-size: 20px auto;
	padding:2px 0 2px 30px;
	display: inline-block;
	cursor: pointer;
	line-height: 1.5;
}
.radioList li input[type=radio]:checked + .radioBtn{
	background-image: url(/lifecare/img/contact/rb_on.png);
}


@media screen and (max-width: 767px) {
	/* 入力項目 */
	.form input[type="text"],
	.form input[type="email"],
	.form input[type="tel"],
	.form textarea {
		min-width: 70px;
	}
	.form .drop{
		width: 100%;
	}
	/*radioボタン*/
	.radioList.clm2 li,
	.radioList.clm2 li:nth-child(2n){
		float: none;
		width: 100%;
	}
	::-webkit-input-placeholder {
		font-size: 14px;
	}
	:-moz-placeholder {
		font-size: 14px;
	}
}

/*--------個別エリア----------*/
/*-名前-*/
.form .nameWrap{
	display: inline-block;
	margin-right: 15px;
}
.form .nameWrap:last-child{
	margin-right: 0;
}
.form .nameWrap .name{
	text-align: right;
	display: inline-block;
	width: 2em;
	margin-right: 10px;
}
/*-郵便番号-*/
.form .zipWrap{
	display: inline-block;
	margin-right: 5px;
}
.form .zipBtn{
	display: inline-block;
}
.form .zipSearch{
	display: inline-block;
	padding: 8px 12px;
	background-color: #eee;
	border: 1px solid #aaa;
	font-size: 14px;
	border-radius: 5px;
	cursor: pointer;
}
.form .zipSearch:hover{
	color: #333;
	background-color: #ddd;
}
/*-電話番号-*/
.form .telWrap{
	display: inline-block;
	margin:0 3px;
}
.form .telWrap:first-child{
	margin-left: 0;
}
.form .telWrap:last-child{
	margin-right: 0;
}
/*-アンケート-*/
#ErrorQuestionnaire .radioList.clm2 li.w100{
	width: 100%;
}
#ErrorQuestionnaire .radioList.clm2 li.w100 input[type=text]{
	margin-left: 20px;
}
@media screen and (max-width: 767px) {
	.form .nameWrap{
		width: 48%;
		margin-right: 2%;
	}
	.form .nameWrap .name{
		width: 30px;
		margin-right: 3px;
		font-size: 15px;
	}
	.form .nameWrap input{
		width: calc(100% - 33px);
	}
	#ErrorQuestionnaire .radioList.clm2 li.w100 input[type=text]{
		margin: 5px 0 0 0;
	}
}

/* 確認ボタン */
.form .txtConfirm{
	text-align: center;
	font-size: 18px;
}
.step1 .txtConfirm{
	font-weight: bold;
	color: #e83928;
}
#submitBtn{
	margin: 40px 0 50px;
	text-align: center;
}
#submitBtn .errorBox p{
	color: #e83928;
	margin-bottom: 10px;
}
#submitBtn .btnError,
#submitBtn .btnNext,
#submitBtn .btnBack,
#submitBtn .btnSubmit{
	display: block;
	margin: auto;
	width: 400px;
	text-align: center;
	background-color: #e83928;
	transition: 0.3s ease-in-out;
	color: #FFF;
	line-height: 60px;
	font-size: 20px;
	border-radius: 30px;
}
#submitBtn .btnNext:hover,
#submitBtn .btnBack:hover,
#submitBtn .btnSubmit:hover{
	color: #fff;
	opacity: 0.8;
}
#submitBtn .nextBox{
	display: none;
}
#submitBtn .btnError,
#submitBtn .btnBack{
	background-color: #aaa;
}
#submitBtn .backBox,
#submitBtn .submitBox{
	display: inline-block;
}
#submitBtn .backBox{
	margin-right: 20px;
}
@media screen and (max-width: 767px) {
	#submitBtn .btnError,
	#submitBtn .btnNext,
	#submitBtn .btnBack,
	#submitBtn .btnSubmit{
		width: 100%;
		line-height: 50px;
	}
	#submitBtn .backBox,
	#submitBtn .submitBox{
		display: block;
	}
	#submitBtn .backBox{
		margin: 0 0 15px 0;
	}
}

/* エラーリスト */
ul.error {
  background-color: #fcebe9;
  border: 1px solid #e72407;
  padding: 15px 20px;
  font-size: 15px;
  margin-bottom: 40px;
}
ul.error li{
	margin-bottom: 3px;
}
ul.error li:last-child{
	margin-bottom: 0;
}
ul.error li a {
  color: #CC1800;
  text-decoration: underline;
}
ul.error li a:visited {
  text-decoration: underline;
}
ul.error li a:hover {
  text-decoration: none;
}
@media screen and (max-width: 767px) {
	ul.error {
		padding: 10px;
	}
}

/* 個人情報保護方針 */
.privacy_policy {
  background-color: #F9F9F9;
  border: 1px solid #E5E5E5;
	margin: 20px 0 0;
}
.privacy_policy .privacyTtl {
	font-size: 22px;
	font-weight: bold;
	margin-bottom: 15px;
}
.privacyIn {
  padding: 30px;
	font-size: 14px;
}
.privacyIn .sttl {
    font-weight: bold;
    padding-bottom: 5px;
    font-size:16px;
}
.privacyIn .txt {
	font-size: 14px;
	margin-bottom: 20px;
}
.privacyIn .txt:last-child {
	margin-bottom: 0;
}

@media screen and (max-width: 767px) {
	.privacy_policy h2 {
		font-size: 18px;
	}
	.privacyIn {
		padding: 10px;
	}
}

/*--------completeBox----------*/
#completeBox{
	text-align: center;
	margin-bottom: 80px;
}
#completeBox .ttl{
	font-size: 24px;
	font-weight: bold;
	color: #e83928;
	margin-bottom: 30px;
}
#completeBox .btnRed{
	margin-top: 40px;
	width: 400px;
	font-size: 20px;
}
@media screen and (max-width: 767px) {
	#completeBox .btnRed{
		margin-top: 30px;
		width: 100%;
		font-size: 18px;
	}
	#completeBox p{
		text-align: left;
	}
	
}