/* BASE
======================================================== */
/* main
-------------------------------------------------------- */
* {
	padding: 0; 
	margin: 0;
	box-sizing: border-box;
}

html {
	font-family: 'Montserrat', Arial, sans-serif;
	font-size: 12px;
	line-height: 150%;
	color: #2B3A42;
	text-align: left;
	position: relative;
	min-height: 100%;
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
	overflow-x: hidden;
}

body {
	margin: 0;
	text-rendering: optimizeLegibility;
	text-rendering: geometricPrecision;
	font-smooth: always;
	font-smoothing: antialiased;
	-moz-font-smoothing: antialiased;
	-webkit-font-smoothing: antialiased;
	-webkit-text-size-adjust: 100%;
	background: #F2F2F2;
}

::selection {
	background: #333333;
	color: #fff;
}

:focus {
	outline: 0px;
}

img {
	border: 0;
	max-width: 100%;
	vertical-align: bottom;
	border-style: none;
}

svg:not(:root) {
	overflow: hidden;
}

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
	display: block;
}

button, input, optgroup, select, textarea {
	color: inherit;
	font: inherit;
	margin: 0;
}

optgroup {
	font-weight: bold;
}

input, button {
	border: 0;
	border-radius: 0;
}

input[type="submit"] {
	-webkit-appearance: none;
	-moz-appearance: none;
}

input:focus, button:focus, textarea:focus {
	outline: 0;
}

button {
	overflow: visible;
	text-transform: none;
}

select {
	text-transform: none;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
}

textarea {
	overflow: auto;
	border: 0px;
	width: 100%;
	min-width: 100%;
	max-width: 100%;
	min-height: 180px;
	resize: vertical;
}

li {
	list-style: none;
}

/* text
-------------------------------------------------------- */
h1, h2, h3, h4, h5, h6, p  {
	font-size: 12px;
	line-height: 150%;
	padding: 0;
	margin: 0;
}

b, strong {
	font-weight: bold;
}

em {
	font-style: italic;
}

u {
	text-decoration: underline;
}

a {
	color: #333333;
	text-decoration: underline;
	cursor: pointer;
	background-color: transparent;
	-webkit-text-decoration-skip: objects;
}

a:hover {
	text-decoration: none;
}

a[href^="tel"],
a[href^="sms"] {
  text-decoration: none;
  cursor: default;
}

a[href^="tel"]:before,
a[href^="sms"]:before {
  display: none;
}

/* CUSTOM PROJECT CSS
======================================================== */
/* header
-------------------------------------------------------- */
.header {
	width: 100%;
	background: #fff;
	box-shadow: 0px 0px 32px rgba(0, 0, 0, 0.1);
}

.header__line {
	height: 4px;
	width: 100%;
	background: linear-gradient(90deg, #D11B6A 0%, #FAA437 100%);
}

.header__content {
	min-height: 80px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0 16px;
}

.header__logo__img {
	height: 32px;
}

@media (min-width: 562px) {	
	.header__content {
		min-height: 100px;
		padding: 0 48px;
	}

	.header__logo__img {
		height: auto;
	}
}

/* footer
-------------------------------------------------------- */
.footer {
	position: absolute;
	bottom: 0px;
	left: 0px;
	min-height: 80px;
	width: 100%;
	padding: 0 16px;
}

.footer-hpf {
	height: 80px;
	clear: both;
}

.footer__content {
	min-height: 80px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-top: 1px solid #CCCCCC;
}

.footer__logo__img {
	height: 32px;
}

.footer__info {
	font-size: 12px;
	color: #888888;
}

@media (min-width: 562px) {
	.footer {
		min-height: 110px;
		padding: 0 40px;
	}

	.footer-hpf {
		height: 110px;
	}

	.footer__content {
		min-height: 110px;
	}

	.footer__logo__img {
		height: auto;
	}

	.footer__info {
		font-size: 16px;
	}
}


/* container
-------------------------------------------------------- */
.container {
	width: 100%;
	padding: 0 20px;
	margin-right: auto;
	margin-left: auto;
	margin-top: 42px;
	margin-bottom: 42px;
}

@media (min-width: 562px) {
	.container {
		max-width: 562px;
		margin-top: 80px;
		margin-bottom: 150px;
	}
}

/* button
-------------------------------------------------------- */
.button {
	display: inline-block;
	padding: 15px 24px;
	border: 0px;
	border-radius: 32px;
	font-size: 16px;
	font-weight: bold;
	text-decoration: none;
	color: #fff;
	background: #333333;
	cursor: pointer;
	width: 100%;
	text-transform: uppercase;
}

.button:hover {
	text-decoration: none;
	background: #FAA437;
}

.button--sec {
	color: #333333;
	background: #F2F2F2;
}
.button--sec:hover {
	background: #CCCCCC;
}

/* intro
-------------------------------------------------------- */
.intro {
	padding-bottom: 24px;
}

.intro__text--l {
	font-size: 16px;
}

.intro__headline {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-weight: bold;
	font-size: 32px;
	padding-bottom: 8px;
}

@media (min-width: 562px) {
	.intro__headline {
		font-size: 40px;
	}
}

/*
steps
-------------------------------------------------------- */
.steps {
	display: flex;
	gap: 16px;
	padding-bottom: 24px;
}

/* step
-------------------------------------------------------- */
.step {
	display: flex;
	align-items: center;
	justify-content: left;
	background: #fff;
	padding: 6px;
	border-radius: 36px;
	text-decoration: none;
}
.step__number {
	font-size: 16px;
	font-weight: bold;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 36px;
	min-width: 36px;
	background: #F2F2F2;
	color: #888888;
	border-radius: 36px;
}
.step__text {
	font-size: 12px;
	font-weight: bold;
	padding: 0 10px;
	color: #888888;
	display: none;
}
.step__correct {
	min-height: 36px;
	min-width: 36px;
	background: url("../../images/icon-check-VYtG66r.svg") center center no-repeat;
	background-color: #21C55A;
	border-radius: 36px;
}

.step--active {
	background: #333333;
}
.step--active .step__number {
	color: #fff;
	background: #FAA437;
}
.step--active .step__text {
	display: block;
	color: #fff;
}

@media (min-width: 562px) {
	.step__text {
		display: block;
	}
}

/* fbox
-------------------------------------------------------- */
.fbox {
	background: #fff;
	border-radius: 24px;
	padding: 32px 24px;
}

.fbox__intro {
	padding-bottom: 32px;
	border-bottom: 2px solid #F2F2F2;
	margin-bottom: 32px;
}

.fbox__headline {
	font-weight: bold;
	font-size: 24px;
	padding-bottom: 8px;
}

.fbox__text {
	font-size: 16px;
}

@media (min-width: 562px) {
	.fbox__headline {
		font-size: 32px;
	}
}

/* form styles
-------------------------------------------------------- */
.form {
	display: grid;
	gap: 24px;
}

.label {
	font-size: 16px;
	line-height: 150%;
	color: #333333;
}

input, optgroup, select, textarea {
	font-size: 16px;
	color: #333333;
	width: 100%;
	padding: 14px 16px;
	border: 1px solid #888888;
	border-radius: 12px;
}

.label-set {
	display: flex;
	align-items: start;
	justify-content: left;
	min-height: 18px;
	gap: 8px;
	padding-bottom: 6px;
}

.input-set {
	display: flex;
	align-items: center;
	justify-content: left;
	gap: 12px;
}
.input-set + .input-set {
	margin-top: 8px;
}

.info {
	position: relative;
	top: 4px;
	display: block;
	min-width: 18px;
	min-height: 18px;
	background: url("../../images/icon-info-Zwbi4Aa.svg") top center no-repeat;
}

.error {
	padding-top: 8px;
	font-size: 16px;
	color: #F15100;
}


.fitem--error .label {
	color: #F15100;
}

.fitem--error input, 
.fitem--error select,
.fitem--error textarea {
	border: 1px solid #F15100;
	color: #F1510060;
}

.fitem--error .info {
	background: url("../../images/icon-info-error-4-05y3_.svg") center center no-repeat;
}

.fitem--error .input {
	padding-right: 48px;
	background: url("../../images/icon-error-s3OXsPR.svg") center right 16px no-repeat;
}

.fitem--success .input {
	padding-right: 48px;
	background: url("../../images/icon-success-TwfzBn7.svg") center right 16px no-repeat;
}

/* plus minus button
-------------------------------------------------------- */
.plus-button {
	height: 32px;
	width: 32px;
	min-height: 32px;
	min-width: 32px;
	background: url("../../images/icon-plus-ve4vZfm.svg") center center no-repeat;
	background-color: #F2F2F2;
	border-radius: 32px;
	cursor: pointer;
}

.minus-button {
	height: 32px;
	width: 32px;
	min-height: 32px;
	min-width: 32px;
	background: url("../../images/icon-minus-T8yyVlG.svg") center center no-repeat;
	background-color: #F2F2F2;
	border-radius: 32px;
	cursor: pointer;
}


/* select
-------------------------------------------------------- */
.select {
	position: relative;
	display: inline-block;
	width: 100%;
}
  

.select__arrow {
	position: absolute;
	width: 24px;
	height: 24px;
	background: url("../../images/icon-down-yxL1S8m.svg") center center no-repeat;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	pointer-events: none;
}

/* fcheckbox
-------------------------------------------------------- */
.fcheckbox {
	display: flex;
	user-select: none;
	gap: 8px;
	width: 100%;
	align-items: center;
}

.fcheckbox__input {
	display: none;
}

.checkbox__icon {
	display: inline-block;
	width: 16px;
	height: 16px;
	background: url("../../images/checkbox-EZh2qQP.svg") center center no-repeat;
}

.fcheckbox__input:checked + .fcheckbox__label .checkbox__icon  {
	background: url("../../images/checkbox-on-gBGYeUS.svg") center center no-repeat;
}

.fcheckbox__label {
	display: flex;
	gap: 8px;
	align-items: center;
	width: auto;
}

.fcheckbox__label a {
	font-weight: bold;
}

/* radioset
-------------------------------------------------------- */
.radiosets {
	display: grid;
	gap: 8px;
}

.radioset {
	display: flex;
	justify-content: center;
	align-items: center;
	border-radius: 12px;
	border: 1px solid #888888;
	padding: 0px 16px;
	font-size: 16px;
	width: 100%;
}

.radioset--active {
	border: 1px solid #21C55A;
}

@media (min-width: 562px) {
	.radiosets {
		display: flex;
	}	
}

/* fradio
-------------------------------------------------------- */
.fradio {
	display: flex;
	user-select: none;
	gap: 8px;
	width: 100%;
	align-items: center;
}

.fradio__input {
	display: none;
}

.fradio__icon {
	display: inline-block;
	height: 16px;
	width: 20px;
	background: url("../../images/radio-PeA6rjU.svg") center center no-repeat;
}

.fradio__input:checked + .fradio__label .fradio__icon  {
	background: url("../../images/radio-on-BlWPGKp.svg") center center no-repeat;
}

.fradio__label {
	display: flex;
	gap: 8px;
	width: 100%;
	padding: 22px 0;
	align-items: center;
}

.fradio__label a {
	font-weight: bold;
}

/* fbuttons
-------------------------------------------------------- */
.fbuttons {
	display: flex;
	gap: 12px;
}

/* back button
-------------------------------------------------------- */
.back-button {
	height: 48px;
	width: 48px;
	min-height: 48px;
	min-width: 48px;
	background: url("../../images/icon-left-5rIC2Ep.svg") center center no-repeat;
	background-color: #F2F2F2;
	border-radius: 48px;
}
.back-button:hover {
	background-color: #CCCCCC;
}

.tippy-content {
    text-align: center;
	color: #CCCCCC;
	background: #333333;
	max-width: 180px;
	border-radius: 12px;
	box-shadow: 0px 8px 16px rgba(0, 0, 0, 0.15);
}

/* sitem
-------------------------------------------------------- */
.sitems {
	position: relative;
	display: flex;
	gap: 16px;
}

.sitem {
	position: relative;
	display: none;
}

.sitem--active {
	display: grid;
}

.sitem--active:after {
	content: '';
	position: absolute;
	bottom: -12px;
	left: 12px;
	display: block;
	width: 8px;
	height: 8px;
	background: #FAA437;
	border-radius: 8px;
}

@media (min-width: 562px) {
	.sitem {
		display: grid;
	}
}

/* sitems__menu
-------------------------------------------------------- */
.sitems__menu {
	position: absolute;
	display: none;
	background: #fff;
	border-radius: 12px;
	gap: 14px;
	padding: 4px;
	box-shadow: 0px 0px 32px rgba(0, 0, 0, 0.1);
	top: 28px;
	left: -90px;
}

.sitems__menu--active {
	display: grid;
}

.sitems__menu__item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	padding: 4px;
	font-size: 16px;
	text-decoration: none;
	border-radius: 8px;
	background: #fff;
}

.sitems__menu__item:hover {
	background: #F2F2F2;
}

@media (min-width: 562px) {
	.sitems__menu {
		display: none;
	}
}