html, body {
    height: 100%;
    padding: 0;
    margin: 0;
	background-color: #FBF1EB;
}

.box { 
	max-width: 480px; 
	margin: 0 auto; 
	background-image: url(img/0.png);
	background-position: center top;
	background-repeat: repeat-y;
	background-size: 100% auto;
	
	position: relative;
}
.box.question {
	background-image: url(img/bg2.png);
}

.box.abs > .box-item {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
}

.box.abs > .box-item.box0 { cursor: pointer; }

.box.abs > .boxq > div {
	position: absolute;
	left: 4.444444%;
	right: 4.444444%;
	top: 12.5%;
	bottom: 7.03125%;
}

.boxq > div { border-radius: 16px; background-color: #FFF; }

.box.abs > .boxq > div > div {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
}
.boxq > div > div {
	background-image: url(img/bg4.png);
	background-position: left top;
	background-repeat: no-repeat;
	background-size: 100% auto;
}
.boxq > div > div > div.current {
	font-style: normal;
	font-weight: 600;
	font-size: 24px;
	color: rgba(51, 51, 51, 0.2);	
}
.boxq > div > div > div.current > span { 
	color: #9E1212; 
	font-weight: 700; 
	margin-left: 20px;
	margin-top: 24px;
	padding-top: 6px;
	padding-bottom: 6px;
	display: inline-block;
}
.boxq > div > div > div.current > div.float-end {
	font-family: 'Noto Sans';
	opacity: 1;
	border-radius: 16px;
	padding: 6px 12px;
	background: rgba(255, 255, 255, 0.5);
	
	font-weight: 400;
	font-size: 16px;
	
	color: rgba(98, 36, 0, 0.4);
	
	margin-right: 20px;
	margin-top: 30px;
}
.boxq > div > div > div.title {
	font-family: 'Open Sans';
	font-weight: 700;
	font-size: 16px;
	color: #333;
	padding: 8px 20px;
}

.boxq > div > div > div.option {
	width: 53.658537%;
	max-width: 235px;
	margin-left: 20px;
}
.boxq > div > div > div.option > div { margin-bottom: 12px; cursor: pointer; }

.boxq2 > div > div > div.option { 
	width: calc(100% - 40px);
	max-width: none;
	margin-right: 20px;
}
.boxq2 > div > div > div.option > div { 
	padding: 14px 20px;
	
	border-radius: 24px; 
	border: 1px solid rgba(48, 77, 127, 0.3);
	
	font-family: 'Noto Sans';
	font-weight: 500;
	font-size: 16px;
	
	background-color: #FFF;
}
.boxq2 > div > div > div.option > div.active {
	background-color: #9E1212;
	border: 1px solid #9E1212;
	color: #FFF;
}

.boxq3 > div > div > div.option {
	width: calc(100% - 40px);
	max-width: none;
	margin-right: 20px;
	
	display: flex;
    flex-wrap: wrap;
}

.boxq3 > div > div > div.option > div { width: 50%; max-width: 50%; }
.boxq3 > div > div > div.option > div:nth-child(1) { padding-right: 6px; }
.boxq3 > div > div > div.option > div:nth-child(2) { padding-left: 6px; }

.boxq3 > div > div > div.option > div > div {
	border-radius: 24px; 
	border: 1px solid rgba(48, 77, 127, 0.3);
	
	background-color: #FFF;
	padding: 14px 20px;
	
	box-shadow: 0px 4px 0px 0px rgba(0, 0, 0, 0.15);
}
.boxq3 > div > div > div.option > div > div > img { width: 48px; }

.boxq3 > div > div > div.option > div > div.active { border: 2px solid #9E1212; }

.boxq > div > div > div.nextBtn {
	position: absolute;
	width: 17.073170%;
	max-width: 64px;
	right: 20px;
	bottom: 3.883495%;
}
.boxq > div > div > div.nextBtn.active { cursor: pointer; }

.box.question.last {
	background-image: url(img/bg2.png), url(img/bg2.png);
	background-position: center bottom, center top;
	background-repeat: no-repeat, repeat-y;
	background-size: 100% auto, 100% auto;
}

.box.question.last > img { display: none !important; }
.box-item.last { padding-top: 85px; }

.box-item.last > div {
	margin: 0 .25%;
	padding: 0 6px 6px;
	left: auto;
	right: auto;
	top: auto;
	bottom: auto;
	border-radius: 24px;
	background-color: #FFF;
}

.box-item.last > div > div {
	border-radius: 24px;
	background-image: none;
	background-color: #FFF7F0;

	padding: 0 20px;
}


.signup_form { padding-top: 24px; }

.signup_form > div:nth-child(1) {
	font-family: 'Open Sans';
	font-weight: 700;
	font-size: 22px;
	text-align: center;
	margin-top: 18px;
	margin-bottom: 6px;	
}
.signup_form > div:nth-child(2) {
	font-family: 'Noto Sans';
	font-weight: 500;
	font-size: 16px;
	text-align: center;
	
	margin-bottom: 16px;
}

.signup_form > .form-group { margin-bottom: 14px; }
#cname, #mobile {
	font-family: 'Open Sans';
	font-style: normal;
	font-weight: 400;
	font-size: 16px;
	line-height: 22px;
	
	padding: 1rem;

	background: #FFF;
	border: 1px solid #4DA7FB;
	border-radius: 25px;
}
select#sex, select#addr {
    -moz-appearance: none; /* Firefox */
    -webkit-appearance: none; /* Safari and Chrome */
   
	font-family: 'Open Sans';
	font-style: normal;
	font-weight: 400;
	padding: .75rem;
	line-height: 22px;
	
	padding: 1rem;

	background: url(../../../img/arr_down.png) no-repeat 97% #FFF;
	border: 1px solid #4DA7FB;
	border-radius: 25px;
}
select::-ms-expand { display: none; }
select:required:invalid { color: gray; }
option { color: black; }
option:disabled { color: gray; }

.btn-send {
	padding: 14px;
	background-color: #9E1212;
	border-radius: 27px;
	color: #FFF;
	font-family: 'Open Sans';
	font-size: 20px;
	font-weight: 700;
	text-align: center;
	letter-spacing: .25rem;
	border: none !important;
    outline: none !important;
}
.btn-send:hover { color: #FF2; }
.btn-send:focus, .btn-send:visited, .btn-send:active { background-color: #9E1212; color: #FFF; border: none !important; outline: none !important; }
button::-moz-focus-inner, input[type=button]::-moz-focus-inner { border: none !important; }

.signup_form > .form-group:last-child {
	margin-top: 22px;
	padding-bottom: 32px;
	border-bottom: 1px solid rgba(51, 51, 51, 0.2)
}

.multi-course > div:nth-child(1), .environment > div:nth-child(1) { padding-top: 24px; padding-bottom: 12px; }
.multi-course > div:nth-child(1) > img, .environment > div:nth-child(1) > img {
	width: 65.555555%;
	max-width: 315px;
}

.multi-course > div:nth-child(2) { padding: 0 20px; }

.multi-course > div:nth-child(2) > span { 
	display: inline-block; 
	text-indent: 15px;
	
	font-family: 'Noto Sans';
	font-weight: 700;
	font-size: 17px;
	text-align: left;
	
	color: #333;
	
	background: url(img/circle.png) left center no-repeat;
	
	margin-right: 20px;
	padding-bottom: 4px;
}

.multi-course > div.row, .environment > div.row { margin-left: 0; margin-right: 0; }
.multi-course > div.row > div, .environment > div.row > div { padding: 3px 3px; }

.environment { padding-bottom: 40px; }

.logo { padding: 25px 0; }

.box.answer { 
	background-image: url(img/bg2.png); 
	
	--min-padding-top: 71.111111;
	--max-padding-top: 106.666666;
	--padding-top: calc(
		(var(--min-padding-top) * 1px) + 
		(var(--max-padding-top) - var(--min-padding-top)) * 
		((100cqw - 320px) / (480 - 320))
	);
	padding-top: clamp(var(--min-padding-top) * 1px, var(--padding-top), var(--max-padding-top) * 1px);	
}
.box.answer > .box-item {
	width: 91.111112%;
	padding-left: 6.097560%;
	padding-right: 6.097560%;
	border-radius: 24px;
	border: 6px solid #FFF;
	background-color: #F8ECE5;
}

.box.answer > .box-item > div:nth-child(1) {
	font-family: 'Open Sans';
	font-weight: 700;
	font-size: 24px;
	text-align: center;
	color: #9E1212;
	padding-bottom: 8px;
	padding-top: 32px;
	border-bottom: 1px solid rgba(51, 51, 51, 0.2);
}

.box.answer > .box-item > div:nth-child(2) {
	font-family: 'Open Sans';
	font-weight: 700;
	font-size: 14px;
	text-align: center;
	padding-top: 8px;
}

.correctAns {
	line-height: 50px;
	color: #9E1212;
	font-family: Noto Sans;
	font-weight: 500;
	font-size: 16px;
}

.boxqf { padding: 20px 0; border-bottom: 1px solid rgba(51, 51, 51, 0.2) }
.boxqf:last-child { border-bottom: 0; }

.boxqf > div.current {
	font-style: normal;
	font-weight: 600;
	font-size: 24px;
	color: rgba(51, 51, 51, 0.2);	
}
.boxqf > div.current > span { 
	color: #9E1212; 
	font-weight: 700; 
	padding-top: 6px;
	padding-bottom: 6px;
	display: inline-block;
}
.boxqf > div.current > div.float-end {
	font-family: 'Noto Sans';
	opacity: 1;
	border-radius: 16px;
	padding: 6px 12px;
	background: rgba(255, 255, 255, 0.5);
	
	font-weight: 400;
	font-size: 16px;
	
	color: rgba(98, 36, 0, 0.4);
	
	margin-top: 6px;
}
.boxqf > div.title {
	font-family: 'Open Sans';
	font-weight: 700;
	font-size: 16px;
	color: #333;
	padding: 8px 0;
}

.boxqf > .option > div  { margin-bottom: 12px; }
.boxqf > .option > div > img { width: 53.658536%; max-width: 235px; }

.boxqf2 > div.option { 
	max-width: none;
}
.boxqf2 > div.option > div { 
	padding: 14px 20px;
	
	border-radius: 24px; 
	border: 1px solid rgba(48, 77, 127, 0.3);
	
	font-family: 'Noto Sans';
	font-weight: 500;
	font-size: 16px;
	
	background-color: #FFF;
	
	position: relative;
}

.boxqf2 > div.option > div > div {
	position: absolute; 
	right: 20px;
	top: 0;
	width: 50px;
	text-align: right;
}

.boxqf3 > div.option {
	display: flex;
    flex-wrap: wrap;
}

.boxqf3 > div.option > div { width: 50%; max-width: 50%; }
.boxqf3 > div.option > div:nth-child(1) { padding-right: 6px; }
.boxqf3 > div.option > div:nth-child(2) { padding-left: 6px; }

.boxqf3 > div.option > div > div {
	border-radius: 24px; 
	border: 1px solid rgba(48, 77, 127, 0.3);
	
	background-color: #FFF;
	padding: 14px 20px;
	
	box-shadow: 0px 4px 0px 0px rgba(0, 0, 0, 0.15);
}
.boxqf3 > div.option > div > div > span { line-height: normal !important; }
.boxqf3 > div.option > div > div > img { width: 48px; }

.logof { padding: 25px 0; }

.opacity-40 { opacity: .4 !important; }

@media only screen and (max-width: 374px) {
	.signup_form > div:nth-child(2) { font-size: 20px; }
	.signup_form > div:nth-child(2) { font-size: 14px; }
	
	.boxqf2 > div.option > div { font-size: 14px; }
	.correctAns { font-size: 14px; line-height: normal; }
	.boxqf3 > div.option > div > div > img { width: 36px; }
}

@media only screen and (min-width: 480px) {
	.boxq > div > div > div.current > div.float-end { font-size: 20px; }
	.boxq > div > div > div.title { font-size: 20px; padding: 12px 24px; }
	.boxq > div > div > div.option > div { margin-bottom: 16px; }
	
	.boxq2 > div > div > div.option > div { font-size: 20px; }
	
	.box-item.last { padding-top: 113px; }
	.box-item.last > div { padding: 8px 8px; }
	
	.box-item.last > div > div { background-size: 65px auto; }
	
	.signup_form > div:nth-child(1) { font-size: 26px; }
	.signup_form > div:nth-child(2) { font-size: 20px; }
	
	.multi-course > div:nth-child(1), .environment > div:nth-child(1) { padding-top: 32px; padding-bottom: 20px; }
	
	.multi-course > div:nth-child(2) { padding: 0 25px; }
	.multi-course > div:nth-child(2) > span { font-size: 20px; margin-right: 25px; padding-bottom: 5.33125px; }
	
	.environment { padding-bottom: 53px; }
}