HTML {
	-webkit-font-smoothing: antialiased;
   -moz-osx-font-smoothing: grayscale;
}

BODY {
	margin: 0;
	padding: 0;
}

/* заголовки, кнопки */
.h2 {
	margin: 0;
	font-size: 48px;
	line-height: 52px;
	font-weight: 700;
	color: #FFF;
}
.h3 {
	margin: 0 0 25px;
	font-size: 30px;
	line-height: 36px;
	font-weight: 700;
	color: #55bcc2;
}
.section--result {
	margin-bottom: 20px;
}
.section--result .h3 {
	color: #FFF;
	font-size: 42px;
	line-height: 48px;
}
.ts-subtitle {
	font-style: italic;
	font-size: 24px;
}
.ts-button {
	display: inline-block;
	background-color: #e96a51;
	padding: 0 30px;
	height: 60px;
	line-height: 60px;
	white-space: nowrap;
	border: none;
	-webkit-appearance: none;
	appearance: none;
	cursor: pointer;
	color: #FFF;
	font-size: 24px;
	text-transform: uppercase;
	letter-spacing: 3px;
	text-align: center;
}
	.ts-button:hover,
	.ts-cart-link:hover .ts-button {
		background-color: #ec826d;
	}
	.ts-button:focus {
		outline: none;
	}
	.ts-button[disabled] {
		cursor: not-allowed;
		pointer-events: none;
		opacity: .35;
	}

.ts-wrapper {
	max-width: 760px;
	margin: 0 auto;
 	font-family: 'PT Sans', sans-serif;
 	font-weight: 400;
    font-style: normal;
}
	.ts-container {
		position: relative;
	}
	.ts-head {
		position: relative;
		max-width: 760px;
		height: 400px;
		text-align: center;
	}
	.ts-title {
		position: relative;
		display: inline-block;
		vertical-align: top;
		padding: 0 40px;
		height: 60px;
		line-height: 60px;
		white-space: nowrap;
		text-transform: uppercase;
		background-color: #55bcc2;
		color: #ebebeb;
		font-size: 24px;
		letter-spacing: 2px;
	}
	.ts-image {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
		background-repeat: no-repeat;
		background-size: cover;
		background-position: 50% 50%;
	}
	.ts-body {
		background-color: #fbf4e9;
	}
		.ts-first-screen .ts-body {
			padding: 60px 20px;
			text-align: center;
		}
		.section--result .ts-body {
			padding: 60px;
			background-color: #55bcc2;
		}
		.section--result .ts-body p {
			font-size: 28px;
			color: #FFF;
			font-style: italic;
		}
		.ts-body {
			padding: 44px 60px 66px;
			text-align: left;
		}
	.ts-question {
		position: relative;
		opacity: 0;
		-webkit-transition: opacity .5s ease;
				transition: opacity .5s ease;
	}
		.ts-question.loaded {
			opacity: 1;
			-webkit-transition: opacity .5s ease;
					transition: opacity .5s ease;
		}
	.ts-first-screen .ts-body {
		background-color: #55bcc2;
		color: #FFF;
	}
	.ts-button-wrapper {
		margin-top: 35px;
		text-align: center;
	}
	.ts-cart .ts-button-wrapper {
		margin: 0;
		text-align: left;
	}
.ts-answer {
	margin: 0 0 25px;
}
	.ts-input-hidden {
		position: absolute;
		left: -9999px;
		visibility: none;
	}
	.ts-label {
		position: relative;
		display: block;
		padding-left: 40px;
		cursor: pointer;
	}
	.ts-label::before {
		position: absolute;
		left: 0;
		top: 5px;
		width: 22px;
		height: 22px;
		border-radius: 50%;
		background-color: #55bcc2;
		content: "";
	}
	.ts-input-hidden:checked ~ .ts-label::after {
		position: absolute;
		left: 5px;
		top: 10px;
		width: 12px;
		height: 12px;
		border-radius: 50%;
		content: "";
		background-color: #FFF;
	}
	.ts-label-text {
		font-size: 24px;
		font-style: italic;
		color: #464646;
	}
		.ts-answer:hover .ts-label-text,
		.ts-input-hidden:checked ~ .ts-label .ts-label-text {
			color: #000000;
		}
.tsButtonClear {
	width: 100%;
	box-sizing: border-box;
}

/* картинки */
.ts-cart {
	position: relative;
	max-width: 760px;
	height: 400px;
	margin: 20px 0;
}
	.ts-cart-link {
		display: block;
		position: relative;
		width: 100%;
		height: 100%;
		text-decoration: none;
		border: 0;
	}
	.ts-cart-image {
		position: absolute;
		left: 0;
		top: 0;
		right: 0;
		bottom: 0;
		background-repeat: no-repeat;
		background-position: 50% 50%;
		background-size: cover;
	}
	.ts-cart-body {
		position: relative;
		display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
		width: 50%;
		height: 400px;
		box-sizing: border-box;
		padding: 60px 40px 50px 60px;
		background-color: rgba(85, 188, 194, .7);
	}
	.ts-cart-body .h4 {
		margin: 0;
		font-weight: 700;
		color: #FFF;
		font-size: 30px;
		line-height: 36px;
	}

@media (max-width: 1040px) {
	.ts-head {
		height: 300px;
	}
	.ts-title,
	.ts-button {
		height: 50px;
		line-height: 50px;
		font-size: 18px;
	}
	.ts-body,
	.ts-first-screen .ts-body {
		padding: 40px 50px;
	}
	.h2 {
		margin: 0 0 10px;
		font-size: 36px;
		line-height: 44px;
	}
	.ts-subtitle {
		font-size: 20px;
	}
	.h3 {
		font-size: 22px;
		line-height: 28px;
	}
	.ts-label-text {
		font-size: 20px;
	}
	.section--result .h3 {
		font-size: 34px;
		line-height: 40px;
	}
	.section--result .ts-body p {
		font-size: 22px;
	}
}


@media (max-width: 776px) {
	.ts-head {
		height: 192px;
	}
	.h2 {
		margin: 0 0 10px;
		font-size: 30px;
		line-height: 38px;
	}
	.ts-subtitle {
		font-size: 18px;
	}
	.ts-question .ts-body {
		padding: 30px 34px 35px;
	}
	.h3 {
		font-size: 18px;
		line-height: 24px;
	}
	.ts-label-text {
		font-size: 16px;
	}
	.ts-label {
		padding-left: 28px;
	}
	.ts-label::before {
		width: 13px;
		height: 13px;
		top: 3px;
	}
	.ts-input-hidden:checked ~ .ts-label::after {
		width: 7px;
		height: 7px;
		left: 3px;
		top: 6px;
	}
	.section--result .ts-body {
		padding: 30px 20px;
	}
	.section--result .h3 {
		font-size: 30px;
		line-height: 36px;
	}
	.section--result .ts-body p {
		font-size: 18px;
	}
	.ts-cart-body {
		width: 100%;
    	position: absolute;
    	bottom: 0;
    	top: auto;
    	padding: 20px;
    	display: block;
    	height: auto;
	}
	.ts-cart-body .h4 {
		font-size: 18px;
		line-height: 24px;
		margin: 0 0 20px;
	}
	.ts-cart .ts-button {
		background-color: transparent;
    	height: auto;
    	padding: 0;
    	line-height: 1;
    	text-transform: capitalize;
    	letter-spacing: 1px;
    	font-style: italic;
    	font-size: 18px;
    	text-decoration: underline;
	}
	.ts-cart .ts-button:hover,
	.ts-cart:hover .ts-button {
		background-color: transparent;
		opacity: 1;
		text-decoration: none;
	}
}

@media (max-width: 480px) {
	.ts-body, .ts-first-screen .ts-body {
		padding: 40px 20px;
	}
	.ts-question .ts-body {
		padding: 30px 20px 35px;
	}
}
