* {
	margin: 0;
	padding: 0
}

:focus {
	outline: 0
}

img {
	border: none
}

html {
	font-size: 62.5%
}

html,
body {
	height: 100%;
	-webkit-text-size-adjust: none
}

ol,
ul {
	list-style: none
}

body {
	background: #253137;
	font: 2rem/1.3 'Open Sans', sans-serif, Arial;
	color: #fff
}

.popup_block {
	background: #253137;
	width: 310px;
	border: 1px solid #313131;
	border-radius: 10px;
	box-shadow: 0 0 5px 0 rgba(255, 255, 255, 1);
	display: inline-block;
	vertical-align: middle;
	overflow: hidden;
	padding: 10px 15px 15px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box
}

.popup_block img {
	width: 100%;
	max-width: 100%;
	height: auto;
	display: block;
	margin-bottom: 5px
}

.popup_block h6 {
	font-size: 1.6rem;
	text-transform: uppercase;
	color: #807D7E;
	margin-bottom: 5px
}

.popup_block p {
	font-size: 1.6rem;
	font-weight: bold;
	color: #fff
}

.popup_block .popup_close,
.popup_block .btn_skip {
	margin: 10px auto 0;
	padding: 18px 0;
	width: 40%
}

.popup_block .btn_skip {
	background: #ff8706;
	border-bottom: 4px solid #cb6c06
}

.overlay {
	background: rgba(0, 0, 0, 0.7);
	position: fixed;
	left: 0;
	top: 0;
	bottom: 0;
	right: 0;
	z-index: 9;
	text-align: center
}

.overlay:before {
	display: inline-block;
	vertical-align: middle;
	height: 100%;
	content: ""
}

.step {
	text-align: center;
	display: none
}

.step p {
	margin-bottom: 2rem
}

.step .grey {
	color: #807D7E;
	font-weight: 600
}

.step .grey span {
	color: #fff;
	font-weight: bold
}

.step:first-child {
	display: block
}

.step:first-child .step_box {
	max-width: 800px
}

.step_header {
	border-bottom: 1px solid #313131;
	text-align: center;
	padding: 1.5rem 0
}

.step_header h2 {
	font-size: 2.5rem;
	font-weight: normal
}

.step_header h2 span {
	font-weight: bold;
	text-transform: uppercase
}

.step_box {
	max-width: 500px;
	margin: 0 auto;
	padding: 30px 10px
}

.timer-box p {
	font-size: 1.6rem
}

.timer {
	font-weight: bold;
	color: #807D7E
}

.question_title {
	font-size: 2.2rem;
	color: #807D7E;
	margin-bottom: 5px;
	font-weight: 600
}

.notice {
	font-style: italic;
	margin-bottom: 15px;
	font-size: 1.4rem;
	font-weight: bold
}

.icon_step {
	display: inline-block;
	margin: 0 auto;
	background: url(../images/sprite.png) no-repeat left bottom;
	width: 72px;
	height: 72px;
	zoom: 0.8
}

.icon_step.icon2 {
	background-position: right bottom
}

.question {
	border: 1px solid #313131;
	padding: 30px;
	max-width: 440px;
	margin: 0 auto
}

.question h2 {
	font-size: 2.2rem;
	margin-bottom: 20px;
	color: #fff;
	font-weight: 600
}

.btns_box {
	text-align: center
}

.btn,
.popup_close,
.btn_skip {
	background: #7FCAC3;
	display: inline-block;
	padding: 1.8rem 4.5rem;
	font-size: 2.4rem;
	color: #fff;
	text-decoration: none;
	border-bottom: 4px solid #5B928D;
	border-radius: 4px;
	margin-left: 10px;
	transition: all 0.2s linear;
	text-transform: capitalize
}

.btns_box a:first-child {
	margin-left: 0
}

.btn:hover,
.btn:active {
	opacity: 0.9
}

.options {
	max-width: 500px;
	margin: 15px auto 0;
	padding-bottom: 30px
}

.options li {
	margin-bottom: 10px;
	padding: 1.2rem 50px;
	cursor: pointer;
	font-weight: 600;
	font-size: 2.2rem;
	text-align: left;
	position: relative;
	border: 1px solid #313131;
	background-color: #101010
}

.options li:after {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 10px;
	margin: auto;
	width: 30px;
	height: 30px;
	background: url(../images/sprite.png) no-repeat 0 -77px
}

.options li.selected {
	background: #101010
}

.options li.selected:after {
	background-position: 0 -39px
}

.age_box {
	border: 1px solid #313131;
	background-color: #101010;
	padding: 30px;
	max-width: 500px;
	margin: 0 auto 15px
}

.age_box .age-label {
	font-size: 22px;
	text-transform: uppercase;
	font-weight: bold;
	color: #fff;
	padding: 0 20px
}

.age_box select {
	font-size: 18px;
	padding: 4px
}

.loader {
	position: relative;
	background: #282828;
	border-radius: 25px;
	padding: 5px;
	box-shadow: inset 0 -1px 1px rgba(255, 255, 255, 0.15);
	max-width: 500px;
	margin: 20px auto 10px
}

.loader span {
	display: block;
	height: 12px;
	border-radius: 20px 8px 8px 20px;
	box-shadow: inset 0 2px 9px rgba(255, 255, 255, 0.3), inset 0 -2px 6px rgba(0, 0, 0, 0.4);
	background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0, #7FCAC3), color-stop(1, #7FCAC3));
	background-image: -webkit-linear-gradient(top, #7FCAC3, #7FCAC3);
	background-image: -moz-linear-gradient(top, #7FCAC3, #7FCAC3);
	background-image: -ms-linear-gradient(top, #7FCAC3, #7FCAC3);
	background-color: #7FCAC3;
	position: relative;
	overflow: hidden
}

.loader span:after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	background-image: -webkit-gradient(linear, 0 0, 100% 100%, color-stop(.25, rgba(255, 255, 255, .2)), color-stop(.25, transparent), color-stop(.5, transparent), color-stop(.5, rgba(255, 255, 255, .2)), color-stop(.75, rgba(255, 255, 255, .2)), color-stop(.75, transparent), to(transparent));
	background-image: -webkit-linear-gradient( -45deg, rgba(255, 255, 255, .2) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .2) 50%, rgba(255, 255, 255, .2) 75%, transparent 75%, transparent);
	background-image: -moz-linear-gradient( -45deg, rgba(255, 255, 255, .2) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .2) 50%, rgba(255, 255, 255, .2) 75%, transparent 75%, transparent);
	background-image: -ms-linear-gradient( -45deg, rgba(255, 255, 255, .2) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .2) 50%, rgba(255, 255, 255, .2) 75%, transparent 75%, transparent);
	z-index: 1;
	background-size: 50px 50px;
	border-radius: 20px 8px 8px 20px;
	overflow: hidden
}

.last_step .step_box {
	text-align: left;
	border: 1px solid #313131;
	background-color: #101010;
	padding: 1.5rem;
	margin: 3rem auto;
	color: #fff
}

.load_item {
	font-size: 1.6rem;
	margin-bottom: 10px;
	display: none;
	font-weight: bold
}

.load_item.first {
	display: block
}

.rules_block h3,
.results h3 {
	font-size: 1.6rem;
	margin-bottom: 2rem;
	color: #807D7E;
	font-weight: 600;
	padding-top: 2.5rem
}

.step p.result_item {
	display: none;
	font-size: 1.6rem;
	color: #fff;
	padding: 0 0 0 45px;
	margin: 0 0 10px 0;
	line-height: 30px;
	position: relative
}

.result_item span {
	font-weight: bold;
	color: #807D7E
}

.step p.result_item:after {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	width: 30px;
	height: 30px;
	background: url(../images/sprite.png) no-repeat 0 0
}

.hidden {
	display: none
}

.rules_block ol {
	margin-left: 40px;
	list-style-type: decimal
}

.rules_block li {
	margin: 1rem 0;
	font-size: 1.6rem
}

.last_step h4 {
	font-weight: 300;
	font-size: 1.4rem;
	font-style: italic
}

.terms {
	font-size: 1.3rem;
	text-align: center;
	background: none;
	padding: 0
}

.final_btn {
	margin: 1.5rem auto
}

@media (max-width: 400px) {
	html {
		font-size: 50%
	}
	body {
		line-height: 1.1
	}
	.step p.result_item {
		line-height: 1.1
	}
	.results {
		margin-top: 2rem
	}
}