.stepForm {
	width: 100%;
	margin: 0 auto;
}

.content {
	width: 100%;
	display: none;
}

.sf-steps {
	width: 95%;
	box-sizing: border-box;
	margin: 35px auto;
	text-align: center;
}

.sf-steps>div {
	display: inline-block;
	margin-left: -4px;
	position: relative;
	height: 55px;
	width: 31%;
	background: url("../images/stepBg.png");
	background-repeat: repeat-x;
	background-position: 0 -31px;
}

.sf-steps>div:first-child {
	width: 4.5%;
	background: none;
}

.sf-steps>div>label {
	position: absolute;
	font-family: 'Noto Sans TC', sans-serif;
	top: 40px;
	width: 70px;
	right: 0;
	margin-right: -17px;
	color: #bfbfbf;
	font-size: 14px;
	line-height: 1.2;
	font-weight: 400;
	letter-spacing: -0.5px;
}

.sf-steps>div>span {
	float: right;
	display: block;
	background: #ffffff;
	font-family: 'Roboto', 'Open Sans', sans-serif;
	font-weight: 700;
	color: #bfbfbf;
	font-size: 16px;
	width: 36px;
	line-height: 34px;
	height: 36px;
	text-align: center;
	border: 2px solid #d9d8d7;
	border-radius: 18px;
}

.sf-steps>div.sf-active {
	z-index: 2;
}

.sf-steps>div.sf-active,
.sf-steps>div.sf-check {
	background-position: 0 17px;
}

.sf-steps>div.sf-active span,
.sf-steps>div.sf-active label {
	border-color: #db5759;
	color: #db5759;
	font-weight: 700;
}

.sf-steps>div.sf-check span {
	border-color: #db5759;
	color: #db5759;
}

.sf-steps>div.sf-check span {
	font-size: 0;
	line-height: 0;
	background: #ffffff url("../images/icnChk.jpg");
	background-repeat: no-repeat;
	background-position: 9px 12px;
	background-size: 14px 10px;
}

/*-- //step design --*/

/*-- step content--*/
.cont {
	background: #eeeeee;
	margin: 35px 0;
	padding: 35px 0 15px 0;
	text-align: center;
	font-family: 'Noto Sans TC', sans-serif;
	line-height: 1;
}

.cont p.num {
	font-family: Georgia, "serif";
	font-style: italic;
	font-size: 50px;
	font-weight: 700;
	color: #111111;
	padding: 0 0 5px 0;
}

.cont p.head {
	font-size: 25px;
	font-weight: 700;
	color: #111111;
	padding: 0 0 35px 0;
}

.cont p.title {
	font-size: 17px;
	font-weight: 400;
	color: #666666;
	padding: 0 0 27px 0;
	line-height: 1.5;
	word-break: keep-all;
}

.cont p.title_m {
	display: none;
	font-size: 17px;
	font-weight: 400;
	color: #666666;
	padding: 0 0 27px 0;
	line-height: 1.5;
}

.cont p.title2 {
	font-size: 20px;
	font-weight: 400;
	color: #010101;
	padding: 27px 0;
}

.cont p.title3 {
	width: 100%;
	font-size: 15px;
	font-weight: 400;
	line-height: 1.5;
	color: #333333;
	letter-spacing: -0.5px;
	padding: 10px 0;
}

.cont p.title3_m {
	display: none;
	width: 100%;
	font-size: 15px;
	font-weight: 400;
	line-height: 1.5;
	color: #333333;
	letter-spacing: -0.5px;
	padding: 10px 0;
}

.cont p.title3_m2 {
	display: none;
	width: 100%;
	font-size: 15px;
	font-weight: 500;
	line-height: 1.5;
	color: #333333;
	letter-spacing: -0.5px;
	padding: 10px 0;
}

.cont p.line {
	width: 70%;
	margin: 0 auto 40px;
	height: 1px;
	background: #d6d6d6;
}

.cont .inner {
	padding: 0 20px 45px 20px;
}

/*-- //step content--*/

/*-- input radio style --*/
.inner input[type="radio"],
.inner input[type="checkbox"] {
	display: none;
}

.inner input[type="text"],
.inner input[type="tel"],
.inner select,
.inner input[type="password"] {
	width: 90%;
	padding: 0 6px;
	font-size: 13px;
	height: 30px;
	line-height: 28px;
	background: #ffffff;
	border: 1px solid #d2d7d3;
	border-radius: 5px;
	outline: none;
	color: #333333;
}

.inner .option input[type="radio"]+label {
	padding: 0 0 0 45px;
	color: #111111;
	font-size: 15px;
	font-weight: 400;
	letter-spacing: -0.5px;
	cursor: pointer;
}

.inner input[type="checkbox"]+label {
	padding: 0 0 0 5px;
	color: #333333;
	font-size: 13px;
	line-height: 2;
	font-weight: 400;
	letter-spacing: -0.5px;
	cursor: pointer;
}

.inner .option input[type="radio"]:first-child+label,
.inner input[type="checkbox"]:first-child+label {
	padding: 0 !important;
}

.inner .option input[type="radio"]+label span {
	display: inline-block;
	width: 15px;
	height: 15px;
	margin: 0 5px 2px 0;
	vertical-align: middle;
	background: url("../images/btnChk.png") left bottom no-repeat;
	background-size: 15px;
	cursor: pointer;
}

.inner .option input[type="radio"]:checked+label span {
	background: url("../images/btnChk.png") left top no-repeat;
	background-size: 15px;
}

.inner input[type="checkbox"]+label span {
	display: inline-block;
	width: 16px;
	height: 15px;
	margin: 0 5px 3px 0;
	vertical-align: middle;
	background: url("../images/btnChk2.png") left bottom no-repeat;
	background-size: 16px;
	cursor: pointer;
}

.inner input[type="checkbox"]:checked+label span {
	background: url("../images/btnChk2.png") left top no-repeat;
	background-size: 16px;
}

.inner .option input[type="text"] {
	width: 90%;
	max-width: 90px;
	text-align: right;
	padding: 0 22px 0 0;
}

.inner .option label input[type="text"]+div.won {
	position: absolute;
	top: 4px;
	right: 8px;
	z-index: 2;
	font-size: 14px;
	color: #333333;
}

.inner .option label {}

/*-- // input radio style --*/
.inner .form-group {
	max-width: 700px;
	margin: 10px auto;
	padding: 0;
	text-align: center;
	/*	border: 1px solid red;*/
}

.inner .form-group label.item {
	display: inline-block;
	width: 30%;
	max-width: 185px;
	text-align: left;
	margin: 0 10px 0 0;
	vertical-align: top;
	line-height: 30px;
	letter-spacing: -0.5px;
	font-size: 14px;
	color: #111111;
    font-weight: bold;
	padding: 0 0 0 15px;
	/*	border: 1px solid red;*/
}

.inner .form-group label.Req {
	background: url("../images/icnReq.jpg") left 13px no-repeat;
	background-size: 8px;
}

.inner .form-group div {
	position: relative;
	display: inline-block;
	width: 67%;
	min-width: 440px;
	text-align: left;
	font-size: 13px;
	color: #333333;
	/*	border: 1px solid blue;*/
}

.inner .form-group div.step3 {
	max-width: 330px;
	min-width: 0 !important;
}

.inner .form-group div .option,
.inner .form-group div .idnumber {
	width: 100% !important;
}

.inner .form-group div .idnumber {
	padding: 5px 0;
}

.inner .form-group div .idnumber span {
	display: inline-block;
	width: 120px;
	line-height: 2;
	color: #666666;
}

.inner .form-group div .idnumber div {
	width: 220px !important;
	min-width: 0 !important;
}

.inner .form-group div p.caution {
	color: #db5759;
	font-size: 13px;
	line-height: 1.5;
	letter-spacing: -1px;
	padding: 5px 0 5px 0;
}

/*
.inner .form-group .adress div {
	position: absolute; top:0; right:0;
	width: 120px !important;
	min-width: 0;
}
*/

.inner .form-group .option input[type="radio"]+label {
	padding: 0 0 0 10px;
	color: #333333;
	font-size: 13px;
	line-height: 30px;
}

.inner .form-group select {
	max-width: 100px;
}

.inner .form-group input[type="text"],
input[type="password"] {
	max-width: 100px;
}

.inner .form-group input[type="tel"] {
	max-width: 70px;
}

.inner .form-group .w80 {
	max-width: 80px !important;
}

.inner .form-group .w120 {
	max-width: 120px !important;
}

.inner .form-group .w200 {
	max-width: 200px !important;
}

.inner .form-group .w300 {
	max-width: 300px !important;
}

.inner .form-group .long {
	width: 100% !important;
	max-width: none !important;
	margin: 5px 0 0 0;
}

.inner .form-group .short {
	max-width: 120px !important;
	margin: 5px 0 0 0;
}

.inner .form-group .select {
	z-index: 0
}

.inner .form-group select {
	vertical-align: -webkit-baseline-top;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background: #ffffff url('../images/select.jpg') no-repeat right center;
	z-index: 1;
}

.inner .form-group select::-ms-expand {
	display: none;
}

.inner .form-group .date select,
.inner .form-group .date input[type="text"] {
	max-width: 70px;
}

.inner .form-group input[type="button"],
.inner .form-group3 input[type="button"] {
	text-align: center;
	font-family: 'Noto Sans TC', sans-serif;
	font-size: 12px;
	color: #ffffff;
	cursor: pointer;
	max-width: 85px;
	border: 0;
	padding: 2px 8px 4px;
	margin: 0 0 0 5px;
	border-radius: 5px;
	letter-spacing: -1px;
}

.inner input.blue {
	background: #db5759;
	height: 28px;
}

.inner input.del {
	background: #aaaaaa;
	color: #ffffff;
	height: 28px;
}

.inner input.black {
	background: #333333;
	height: 25px;
}

.inner .form-group2 {
	max-width: 600px;
	margin: 10px auto;
	text-align: center;
}

.inner .form-group2 label {
	display: inline-block;
	width: 30%;
	min-width: 190px;
	text-align: left;
	padding: 0 0 0 15px;
	margin: 0 10px 0 0;
	vertical-align: top;
	line-height: 30px;
	letter-spacing: -0.5px;
	font-size: 14px;
	color: #111111;
}

.inner .form-group2 div {
	display: inline-block;
	width: 45%;
	text-align: left;
	color: #333333;
	font-size: 13px;
	background: #e3e3e3;
	padding: 2px 10px 3px 10px;
	margin: 0;
	min-height: 30px;
	line-height: 25px;
	border-radius: 5px;
}

.cont .form-group .sub {
	width: 140px;
	float: right;
	display: block;
	background: url("../images/icnReq.gif") left 4px no-repeat;
	font-size: 16px;
	line-height: 20px;
	font-weight: 400;
	color: #666666;
	text-align: right;
	padding: 0 0 10px 0;
}

.cont .form-group p {
	padding: 0 0 10px 5px;
	color: #666666;
}

.cont .form-group3 {
	width: 90%;
	max-width: 450px;
	margin: 15px auto 0;
	text-align: left;
}

.cont .form-group3 p.allchk {
	padding: 0 0 15px 0;
}

.cont .form-group3 p {
	padding: 0 0 5px 0;
}

.cont .form-group3 p input[type="radio"] {
	display: block !important;
	cursor: pointer;
	margin: 0;
}

.cont .form-group3 p.allchk label {
	font-size: 14px;
	color: #111111;
	font-weight: 400;
}

.cont .form-group3 p label {
	font-size: 13px;
	color: #333333;
}

/*-- button --*/
.btn {
	width: 90%;
	text-align: center;
	margin: 0px auto;
	max-width: 500px;
}

.btn div {
	position: relative;
	background-repeat: no-repeat !important;
	text-align: center;
	font-family: 'Noto Sans TC', sans-serif;
	font-size: 17px;
	color: #ffffff;
	font-weight: 400;
	cursor: pointer;
	width: 48%;
	max-width: 210px;
	height: 70px;
	line-height: 50px;
	padding: 0;
	margin: 15px 0 80px 0;
	border: none;
}

.btn div a {
	color: #ffffff;
}

.btn button {
	position: relative;
	background-repeat: no-repeat !important;
	text-align: center;
	font-family: 'Noto Sans TC', sans-serif;
	font-size: 17px;
	color: #ffffff;
	font-weight: 400;
	cursor: pointer;
	width: 48%;
	max-width: 210px;
	height: 70px;
	line-height: 50px;
	padding: 0;
	margin: 15px 0 80px 0;
	border: none;
}

.btn button:active {
	border: none;
}

.btn .back {
	float: left;
	background: url(../images/btnBack.jpg) no-repeat;
	background-size: 100% 70px;
}

.btn .back .backL {
	float: left;
	width: 24px;
	height: 70px;
	background: url(../images/btnBackL.jpg) no-repeat;
	background-size: 24px 50px;
}

.btn .back .backR {
	float: right;
	width: 24px;
	height: 70px;
	background: url(../images/btnBackR.jpg) no-repeat;
	background-size: 24px 50px;
}


.btn .backGrey {
	float: left;
	background: url(../images/btnBackGrey.jpg) no-repeat;
	background-size: 100% 70px;
}

.btn .backGrey .backGreyL {
	float: left;
	width: 24px;
	height: 70px;
	background: url(../images/btnBackGreyL.jpg) no-repeat;
	background-size: 24px 50px;
}

.btn .backGrey .backGreyR {
	float: right;
	width: 24px;
	height: 70px;
	background: url(../images/btnBackGreyR.jpg) no-repeat;
	background-size: 24px 50px;
}

.btn .next {
	float: right;
	background: url(../images/btnNext.jpg) no-repeat;
	background-size: 100% 70px;
}

.btn .next .nextL {
	float: left;
	width: 24px;
	height: 70px;
	background: url(../images/btnNextL.jpg) no-repeat;
	background-size: 24px 50px;
}

.btn .next .nextR {
	float: right;
	width: 24px;
	height: 70px;
	background: url(../images/btnNextR.jpg) no-repeat;
	background-size: 24px 50px;
}