/*!
Theme Name: velario
Theme URI: http://underscores.me/
Author: Mateusz Krzak
Author URI: https://interaktiva.eu/
Description: Description
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: velario
*/
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
	 ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
	line-height: 1.15;
	-webkit-text-size-adjust: 100%;
}

/* Sections
	 ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
	margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
	display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

/* Grouping content
	 ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
	box-sizing: content-box;
	height: 0;
	overflow: visible;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
	font-family: monospace, monospace;
	font-size: 1em;
}

/* Text-level semantics
	 ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
	background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
	border-bottom: none;
	text-decoration: underline;
	text-decoration: underline dotted;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
	font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
	font-family: monospace, monospace;
	font-size: 1em;
}

/**
 * Add the correct font size in all browsers.
 */
small {
	font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

/* Embedded content
	 ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
	border-style: none;
}

/* Forms
	 ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
	font-family: inherit;
	font-size: 100%;
	line-height: 1.15;
	margin: 0;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
	overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
	text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
	-webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
	outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
	padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *		`fieldset` elements in all browsers.
 */
legend {
	box-sizing: border-box;
	color: inherit;
	display: table;
	max-width: 100%;
	padding: 0;
	white-space: normal;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
	vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
	overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
	box-sizing: border-box;
	padding: 0;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
	-webkit-appearance: textfield;
	outline-offset: -2px;
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}

/* Interactive
	 ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
	display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
	display: list-item;
}

/* Misc
	 ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
	display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
	display: none;
}

/* Inherit box-sizing to more easily change it's value on a component level.
@link http://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
*,
*::before,
*::after {
	box-sizing: inherit;
}

html {
	box-sizing: border-box;
}

html {
	font-size: 16px;
	overflow-x: hidden;
}

body {
	font-family: 'DM Sans', sans-serif;
	color: #434f63;
}

a {
	color: #434f63;
	text-decoration: none;
}

a:hover, a:focus {
	text-decoration: underline;
	color: #434f63;
}

.container {
	max-width: 1470px;
	margin: 0 auto;
	padding: 0 50px;
}

@media (min-width: 1600px) {
	.container {
		padding: 0 20px;
	}
}

.container-full {
	width: 100%;
	padding: 0 100px;
}

img {
	max-width: 100%;
	height: auto;
}

button,
input,
.btn {
	font-family: 'DM Sans', sans-serif;
	font-weight: 500;
}

.apply-accent-bg, .our-goal, .benefits, .features {
	position: relative;
	z-index: 1;
}

.apply-accent-bg::before, .our-goal::before, .benefits::before, .features::before {
	content: '';
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	background-color: #f9fbfd;
	position: absolute;
	z-index: -1;
	height: calc(100% + 2px);
	width: 100vw;
}

h1,
h2,
h3,
h4,
h5,
h6,
.spanHighlight {
	font-weight: 600;
}

h1 span,
h2 span,
h3 span,
h4 span,
h5 span,
h6 span,
.spanHighlight span {
	background: #d2e2ff;
	border-radius: 8px;
	padding: 0 15px;
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
}

h1 {
	font-size: 30px;
	line-height: 1.6;
	color: #202733;
}

@media (min-width: 1000px) {
	h1 {
		font-size: 52px;
		line-height: 68px;
	}
}

h2 {
	font-size: 30px;
	line-height: 1.3;
}

@media (min-width: 1000px) {
	h2 {
		font-size: 40px;
	}
}

h4 {
	font-size: 20px;
}

.large-text {
	font-size: 20px;
	font-weight: bold;
	line-height: 1;
}

.btn {
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	padding: 20px 40px;
	background: #202733;
	color: #ffffff;
	border-radius: 64px;
	border: 0;
	transition: background 0.2s ease, color 0.2s ease;
	cursor: pointer;
}

.btn:hover, .btn:focus {
	background: #d2e2ff;
	color: #434f63;
	text-decoration: none;
	outline: none;
}

.menu-toggle {
	position: relative;
	background: none;
	border: none;
	width: 50px;
	height: 50px;
	cursor: pointer;
	padding: 10px;
	border-radius: 5px;
	transition: background-color 0.3s ease;
}

.menu-toggle::before, .menu-toggle::after {
	content: '';
	position: absolute;
	left: 10px;
	width: 30px;
	height: 3px;
	background-color: #333;
	transition: all 0.3s ease;
	border-radius: 2px;
}

.menu-toggle::before {
	top: 15px;
	box-shadow: 0 10px 0 #333;
}

.menu-toggle::after {
	top: 35px;
}

.menu-toggle[aria-expanded='true']::before {
	transform: rotate(45deg);
	top: 25px;
	box-shadow: 0 0 0 #333;
}

.menu-toggle[aria-expanded='true']::after {
	transform: rotate(-45deg);
	top: 25px;
}

.main-navigation .nav-menu {
	display: flex;
	flex-direction: column;
	gap: 10px;
	list-style-type: none;
	padding: 20px;
	margin: 0;
}

.menu-toggle,
.main-navigation.toggled ul {
	display: flex;
	visibility: visible;
	background: #fff;
}

@media screen and (min-width: 1000px) {
	.menu-toggle {
		display: none;
	}
	.main-navigation .nav-menu {
		display: flex;
		flex-direction: row;
		gap: 50px;
		padding: 0;
	}
}

.header {
	z-index: 100;
	position: relative;
	padding: 20px 0 5px;
}

@media screen and (min-width: 1000px) {
	.header {
		padding: 34px 0;
	}
}

.header--has-hero {
	background-color: #ebf1f8;
	padding-bottom: 64px;
}

.header--has-hero .menu-toggle,
.header--has-hero .main-navigation.toggled ul {
	background-color: #ebf1f8;
}

.header-hero {
	display: flex;
	flex-direction: column;
	gap: 32px;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding-top: 24px;
}

@media (min-width: 768px) {
	.header-hero {
		padding-top: 40px;
	}
}

.header-hero__title, .header-hero__content {
	margin: 0;
}

.header-hero__title {
	font-size: 30px;
}

@media (min-width: 1000px) {
	.header-hero__title {
		font-size: 40px;
	}
}

.header-hero__content {
	font-weight: 600;
	font-size: 18px;
}

@media (max-width: 1000px) {
	.header .menu {
		position: absolute;
		top: 100%;
		left: 0;
		width: 100%;
		background: #fff;
		visibility: hidden;
	}
	.header .menu a {
		display: block;
		padding: 10px 0;
	}
}

.main-navigation {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	position: relative;
}

.main-navigation-logo {
	margin-right: 20px;
}

.main-navigation-logo__image {
	height: 32px;
	object-fit: contain;
}

.hero {
	padding-top: 42px;
	padding-bottom: 40px;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 3;
}

@media (min-width: 1000px) {
	.hero {
		padding-top: 90px;
		padding-bottom: 90px;
	}
}

.hero::after {
	content: '';
	width: 100vw;
	height: 350px;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
	background-color: #f9fbfd;
	position: absolute;
	z-index: -1;
}

.hero.container {
	max-width: 1140px;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

.hero__title {
	margin: 0 0 16px;
}

.hero__caption {
	font-weight: 600;
	font-size: 16px;
	line-height: 23px;
	margin: 0 0 40px;
}

@media (min-width: 1000px) {
	.hero__caption {
		margin: 0 0 48px;
		font-size: 18px;
	}
}

.hero__image {
	position: relative;
	width: 100%;
	padding-bottom: 54%;
	overflow: hidden;
	margin-top: 60px;
	border-radius: 10px;
	filter: drop-shadow(0px 10px 80px rgba(32, 39, 51, 0.1));
}

@media (min-width: 1000px) {
	.hero__image {
		border-radius: 50px;
	}
}

.hero__image::before {
	content: '';
	background: #ffffff;
	border: 8px solid #ffffff;
	box-shadow: 0px 2px 16px rgba(32, 39, 51, 0.1);
	border-radius: 10px;
	width: 100%;
	height: 100%;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	position: absolute;
}

@media (min-width: 1000px) {
	.hero__image::before {
		border: 24px solid #ffffff;
		box-shadow: 0px 2px 16px rgba(32, 39, 51, 0.1);
		border-radius: 20px;
	}
}

.hero__image-img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top;
	overflow: hidden;
	border: 8px solid #ffffff;
	border-radius: 10px;
}

@media (min-width: 1000px) {
	.hero__image-img {
		border: 24px solid #ffffff;
		border-radius: 40px;
	}
}

.our-goal {
	padding-top: 20px;
	padding-bottom: 40px;
	text-align: center;
	position: relative;
}

@media (min-width: 1000px) {
	.our-goal {
		padding-top: 100px;
		padding-bottom: 10px;
	}
}

.our-goal::before {
	content: '';
	z-index: -2;
}

.our-goal::after {
	content: '';
	z-index: -1;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	height: 100%;
	background: url("images/logo-bg.png") no-repeat center center/contain;
	max-width: 600px;
	max-height: 550px;
}

@media (min-width: 1000px) {
	.our-goal::after {
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
	}
}

.our-goal.container {
	max-width: 850px;
}

.our-goal__title {
	margin: 0 0 24px;
}

.benefits {
	padding-top: 40px;
	padding-bottom: 40px;
	position: relative;
}

@media (min-width: 1000px) {
	.benefits {
		padding-top: 100px;
		padding-bottom: 100px;
	}
}

.benefits.container {
	max-width: 1140px;
	text-align: center;
}

.benefits__header {
	max-width: 850px;
	margin: 0 auto 56px;
}

.benefits__header-content > p:first-of-type {
	margin-top: 0;
}

.benefits__header-content > p:last-of-type {
	margin-bottom: 0;
}

.benefits-list {
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	grid-gap: 20px;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: center;
	gap: 32px 20px;
}

.benefits-list__item {
	display: flex;
	flex-direction: column;
	text-align: center;
	align-items: center;
	flex: 0 0 calc(50% - 15px);
}

@media (min-width: 1000px) {
	.benefits-list__item {
		flex: 0 0 calc(25% - 15px);
	}
}

.benefits-list__item-icon {
	width: 64px;
	height: 64px;
	object-fit: contain;
	object-position: top center;
}

.benefits-list__item-title {
	margin: 36px 0 8px;
}

.benefits__caption {
	margin: 56px 0 0;
	font-weight: 600;
	font-size: 18px;
}

.features {
	position: relative;
	padding-top: 40px;
	padding-bottom: 40px;
}

@media (min-width: 1000px) {
	.features {
		padding-top: 100px;
		padding-bottom: 100px;
	}
}

.features-section {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	align-items: center;
	grid-gap: 15px;
}

@media (min-width: 1000px) {
	.features-section {
		margin-bottom: 100px;
		grid-gap: 42px;
	}
}

.features-section:last-child {
	margin-bottom: 0;
}

.features-section-image {
	order: 2;
}

.features-section-content {
	display: flex;
	flex-direction: column;
	max-width: 700px;
}

.features-section-content__title {
	margin: 0 0 24px;
	text-align: center;
}

@media (min-width: 1000px) {
	.features-section-content__title {
		text-align: left;
	}
}

.features-section-content__link {
	align-self: center;
	margin-top: 24px;
}

@media (min-width: 1000px) {
	.features-section-content__link {
		align-self: flex-start;
	}
}

.features-section-list {
	margin: 0;
	padding: 0;
	list-style-type: none;
}

.features-section-list__item {
	padding-bottom: 16px;
	margin-bottom: 16px;
	border-bottom: 1px solid #afbec6;
	position: relative;
	padding-left: 28px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.features-section-list__item::before {
	content: '';
	width: 16px;
	height: 16px;
	background: url("images/icon-checked.svg") no-repeat center center/contain;
	position: absolute;
	top: 0;
	left: 0;
}

.features-section-list__item strong {
	color: #202733;
	font-weight: 600;
	font-size: 18px;
}

.features-section-list__item span {
	color: #434f63;
}

.features-section-list__item:last-child {
	border-bottom: none;
	padding-bottom: 0;
	margin-bottom: 0;
}

@media (min-width: 1000px) {
	.features-section:nth-child(2n) .features-section-image {
		order: -1;
		padding-right: 100px;
	}
}

.trust-us {
	padding-top: 60px;
	padding-bottom: 50px;
}

@media (min-width: 1000px) {
	.trust-us {
		padding-top: 100px;
		padding-bottom: 100px;
	}
}

.trust-us__title {
	text-align: center;
	margin: 0 0 40px;
}

.trust-us__slider-item {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	padding: 32px 24px;
	gap: 16px;
	background: #f9fbfd;
	border-radius: 16px;
}

.trust-us__slider-item p:first-of-type {
	margin-top: 0;
}

.trust-us__slider-item strong {
	font-size: 14px;
	font-weight: 500;
}

.trust-us .splide__arrow {
	width: 40px;
	height: 40px;
	border: 0;
	padding: 0;
	background-color: transparent;
}

.trust-us .splide__arrow svg {
	height: 40px;
	width: 40px;
	border: 0;
}

@media (min-width: 1000px) {
	.trust-us__slider {
		padding: 0 73px;
	}
}

.splide__arrow--prev {
	left: 0;
}

.splide__arrow--prev svg {
	transform: none;
}

.splide__arrow--next {
	right: 0;
}

.splide__pagination {
	bottom: -2rem;
}

.splide__pagination li {
	margin-right: 10px;
}

.splide__pagination li:last-child {
	margin-right: 0;
}

.splide__pagination__page {
	opacity: 1;
	background-color: #e8efff;
	margin: 0;
}

.splide__pagination__page.is-active {
	background-color: #202733;
	transform: none;
}

.faq {
	padding-top: 40px;
	padding-bottom: 40px;
}

@media (min-width: 1000px) {
	.faq {
		padding-top: 80px;
		padding-bottom: 80px;
	}
}

.faq__title {
	margin: 0 0 40px;
	text-align: center;
}

.faq.container {
	max-width: 850px;
}

.faq-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
	list-style-type: none;
	padding: 0;
	margin: 0;
}

.faq-item {
	background-color: #f9fbfd;
	border-radius: 24px;
	overflow: hidden;
	text-align: left;
}

.faq-item__button {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	text-align: left;
	font-weight: 600;
	font-size: 18px;
	padding: 24px 72px 24px 32px;
	background: transparent;
	border: 0;
	font-weight: 600;
	cursor: pointer;
	position: relative;
	width: 100%;
}

.faq-item__button::after {
	content: '';
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: 24px;
	width: 24px;
	height: 24px;
	background: url("images/icon-arrow.svg") no-repeat center center/contain;
	transition: transform 0.3s ease-in-out;
}

.faq-item__content {
	padding: 0 32px;
	border-top: 1px solid #afbec6;
	overflow: hidden;
	transition: all 0.3s ease;
	opacity: 0;
	max-height: 0;
}

.faq-item.active .faq-item__content {
	max-height: 650px;
	opacity: 1;
	padding: 24px 32px;
}

.faq-item.active .faq-item__button::after {
	transform: translateY(-50%) rotate(180deg);
}

.cta-banner-box {
	padding: 64px 16px;
	background: radial-gradient(38.11% 129.97% at 32.24% 103.05%, #ebf1f8 0%, #f9fbfd 100%);
	border-radius: 40px;
	overflow: hidden;
}

@media (min-width: 1000px) {
	.cta-banner-box {
		padding: 100px 30px;
	}
}

.cta-banner-wrapper {
	max-width: 850px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 24px;
}

.cta-banner__title {
	margin: 0;
}

.cta-banner p:first-of-type {
	margin-top: 0;
}

.cta-banner p:last-of-type {
	margin-bottom: 0;
}

.timeline {
	margin-top: 100px;
	position: relative;
}

.timeline-progress {
	position: absolute;
	top: 0;
	left: 83px;
	width: 3px;
	background-color: #000;
	height: 130px;
	transition: height 0.3s ease-in-out;
}

@media (min-width: 1000px) {
	.timeline-progress {
		left: 123px;
	}
}

.timeline-items {
	max-width: 900px;
	position: relative;
	margin: 0 auto;
}

.timeline-item {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
}

.timeline-item__icon {
	flex-shrink: 0;
	width: 40px;
}

@media (min-width: 1000px) {
	.timeline-item__icon {
		width: 80px;
	}
}

.timeline-item__icon-image {
	width: 100%;
	max-width: 80px;
	object-fit: contain;
	object-position: cen;
}

.timeline-item__icon, .timeline-item__content {
	padding: 10px 0;
}

@media (min-width: 1000px) {
	.timeline-item__icon, .timeline-item__content {
		padding: 55px 0;
	}
}

.timeline-item__break {
	margin: 0 44px;
	border-left: 1px solid #202733;
}

.timeline-item__content-number {
	border-radius: 50%;
	background: #202733;
	color: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 600;
	width: 45px;
	height: 45px;
	font-size: 32px;
}

@media (min-width: 1000px) {
	.timeline-item__content-number {
		width: 64px;
		height: 64px;
		font-size: 40px;
	}
}

.timeline-item__content-title {
	margin: 16px 0;
}

.timeline-item__content-text {
	color: #434f63;
	margin: 0;
}

.form {
	padding-top: 64px;
	padding-bottom: 40px;
}

@media (min-width: 1000px) {
	.form {
		margin-top: 80px;
		margin-bottom: 100px;
	}
}

.form.container {
	max-width: 850px;
}

.form__title {
	text-align: center;
	margin: 0 0 24px;
}

.form__field {
	display: flex;
	flex-direction: column;
	margin-bottom: 16px;
}

.form__label {
	font-weight: 700;
	font-size: 16px;
	line-height: 21px;
	color: #202733;
	padding: 0 40px;
	margin-bottom: 5px;
}

input[type='text'],
input[type='email'],
input[type='password'],
input[type='number'],
input[type='tel'],
input[type='search'],
input[type='url'],
textarea,
input[type='date'] {
	padding: 20px 40px;
	background: #f9fbfd;
	border-radius: 64px;
	font-weight: 400;
	font-size: 16px;
	line-height: 21px;
	color: #afbec6;
	border: 0;
	width: 100%;
}

@media (min-width: 1000px) {
	.social-block {
		margin-top: 100px;
		margin-bottom: 100px;
	}
}

.social-block-wrapper {
	padding: 96px 30px;
	background: #f9fbfd;
	border-radius: 40px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.social-block__title {
	margin: 0 0 32px;
	text-align: center;
}

@media (min-width: 1000px) {
	.social-block__title {
		text-align: left;
	}
}

.social-block__list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 20px;
	list-style-type: none;
	padding: 0;
}

.social-block__list-link {
	opacity: 0.5;
	transition: opacity 0.3s ease-in-out;
}

.social-block__list-link:hover {
	opacity: 1;
}

.social-block__list-icon {
	width: 24px;
	height: 24px;
	object-fit: contain;
}

.logo-motto {
	margin-top: 80px;
	margin-bottom: 40px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

@media (min-width: 1000px) {
	.logo-motto {
		margin-top: 150px;
		margin-bottom: 100px;
	}
}

.logo-motto__image {
	width: 112px;
	object-fit: contain;
	object-position: center;
	margin-bottom: 40px;
}

.logo-motto__text {
	font-weight: 600;
	font-size: 32px;
	line-height: 42px;
	text-align: center;
	color: #202733;
}

.packages {
	padding-top: 20px;
}

.packages.container {
	max-width: 1550px;
}

@media (min-width: 768px) {
	.packages-wrapper {
		background: #202733;
		border-radius: 32px;
		padding: 20px 11px 11px;
	}
}

.header-tab {
	display: flex;
	justify-content: center;
	flex-direction: column;
	gap: 15px;
	margin-bottom: 20px;
}

@media (min-width: 768px) {
	.header-tab {
		flex-direction: row;
	}
}

.tab {
	font-weight: 600;
	font-size: 20px;
	background: #f9fbfd;
	color: #1e293b;
	text-align: center;
	padding: 12px 24px;
	border-radius: 25px;
	cursor: pointer;
	transition: all 0.3s ease;
	border: 1px solid #fff;
}

@media (max-width: 768px) {
	.tab {
		padding: 20px 40px;
	}
}

@media (min-width: 768px) {
	.tab {
		background: transparent;
		color: #ffffff;
	}
}

.tab.active {
	background: #202733;
	color: #f9fbfd;
}

@media (min-width: 768px) {
	.tab.active {
		background: #f9fbfd;
		color: #1e293b;
	}
}

.billing-toggle {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 15px;
	padding: 10px 0 30px;
}

@media (min-width: 768px) {
	.billing-toggle {
		color: #202733;
		background-color: #ebf1f8;
		padding: 30px 0;
		font-weight: 500;
		font-size: 18px;
		border-top-left-radius: 24px;
		border-top-right-radius: 24px;
	}
}

.toggle-switch {
	width: 50px;
	height: 28px;
	background: #334155;
	border-radius: 14px;
	position: relative;
	cursor: pointer;
}

.toggle-switch::after {
	content: '';
	position: absolute;
	width: 24px;
	height: 24px;
	background: white;
	border-radius: 50%;
	top: 2px;
	left: 2px;
	transition: all 0.3s ease;
}

.toggle-switch.active::after {
	left: 24px;
}

.billing-yearly {
	font-weight: 600;
	color: #334155;
}

.billing-yearly__discount {
	margin-left: 3px;
}

.packages-plan-title {
	font-weight: 300;
	font-size: 32px;
	line-height: 42px;
	color: #202733;
	margin: 0 0 24px;
}

@media (min-width: 768px) {
	.packages-plan-title .packages-plan-price {
		display: none;
	}
}

.packages-plan-list {
	padding: 0;
	list-style: none;
	margin: 0;
}

.packages-plan-list__item {
	position: relative;
	padding-left: 28px;
	margin-bottom: 8px;
}

.packages-plan-list__item:last-child {
	margin-bottom: 0;
}

.packages-plan-list__item::before {
	content: '';
	width: 16px;
	height: 16px;
	background: url("images/icon-checked.svg") no-repeat center center/contain;
	position: absolute;
	top: 0;
	left: 0;
}

.packages-plan-list__item--excluded::before {
	background: url("images/icon-exclude.svg") no-repeat center center/contain;
}

.packages-plan-price-display {
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid #f1f5f9;
}

.packages-plan-price {
	display: flex;
	align-items: baseline;
	gap: 8px;
	flex-wrap: wrap;
}

.packages-price-current {
	font-size: 24px;
	font-weight: 700;
	color: #1e293b;
}

.packages-feature {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	margin-bottom: 12px;
	font-size: 13px;
	color: #64748b;
	line-height: 1.4;
}

.packages-selected-package {
	width: 100%;
	padding: 24px 20px;
	background: #ebf1f8;
	border-radius: 16px;
	position: relative;
}

@media (min-width: 768px) {
	.packages-selected-package {
		max-width: 400px;
		padding: 40px 32px;
	}
}

.packages-package-header {
	font-weight: 600;
	font-size: 20px;
	line-height: 26px;
	color: #202733;
	text-transform: uppercase;
	margin-bottom: 24px;
}

.packages-package-title {
	font-weight: 300;
	font-size: 32px;
	line-height: 42px;
	color: #202733;
}

.packages-package-price {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 8px;
	margin-bottom: 24px;
}

.packages-price-main {
	font-size: 32px;
	font-weight: 600;
	color: #1e293b;
}

.packages-price-period {
	font-size: 14px;
	color: #94a3b8;
	text-decoration: line-through;
}

.packages-price-discount {
	background: #3070f0;
	border-radius: 64px;
	color: #ffffff;
	font-weight: 300;
	font-size: 14px;
	line-height: 23px;
	padding: 2px 5px;
}

@media (min-width: 768px) {
	.packages-price-discount {
		padding: 4px 8px;
		font-weight: 500;
		font-size: 18px;
		line-height: 23px;
	}
}

.packages-package-details {
	margin-bottom: 15px;
}

.packages-detail-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 8px 0;
	color: #202733;
	font-size: 14px;
}

.packages-quantity-controls {
	display: flex;
	align-items: center;
	gap: 10px;
	background-color: #fff;
	padding: 7px 5px;
	border: 1px solid #83919a;
	border-radius: 40px;
}

.packages-quantity-controls span {
	width: 20px;
	text-align: center;
}

.packages-quantity-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	font-size: 16px;
	color: #202733;
	background-color: transparent;
	border: 0;
}

.packages-quantity-btn:hover {
	border-color: #3b82f6;
	color: #3b82f6;
}

.packages-buy-button {
	padding: 14px 28px;
	background: #202733;
	border-radius: 64px;
	font-weight: 500;
	font-size: 18px;
	line-height: 23px;
	text-align: center;
	color: #ffffff;
	width: 100%;
	cursor: pointer;
}

.packages-buy-button:hover {
	background: #000;
}

.packages-category-wrapper {
	display: none;
}

@media (min-width: 768px) {
	.packages-category-wrapper {
		background-color: #ebf1f8;
		padding: 0 11px 11px;
		border-radius: 0 0 24px 24px;
	}
}

.packages-category-wrapper.active {
	display: block;
}

.packages-select-button {
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	padding: 13px 28px;
	border: 1.5px solid #202733;
	border-radius: 64px;
	font-weight: 500;
	font-size: 18px;
	line-height: 23px;
	color: #fff;
	background-color: #202733;
	cursor: pointer;
	transition: all 0.3s ease;
	margin-top: 30px;
	min-width: 190px;
}

.packages-select-button.active, .packages-select-button:hover {
	background-color: transparent;
	color: #202733;
}

@media (min-width: 768px) {
	.packages-main-content {
		display: flex;
		flex-direction: row;
	}
}

@media (min-width: 768px) {
	.packages-main-content-options {
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
		flex-grow: 1;
		background-color: #ffffff;
		border: 1px solid #b8cef6;
		border-radius: 16px;
	}
}

.packages-price-sale {
	text-decoration: line-through;
}

.packages-plan-card {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: flex-start;
	flex-grow: 1;
	background-color: #ffffff;
	border: 1px solid #b8cef6;
	border-radius: 16px;
	padding: 24px 20px;
	margin-bottom: 16px;
	font-size: 14px;
}

@media (min-width: 768px) {
	.packages-plan-card {
		border: 0;
		border-right: 1px solid #e2e8f0;
		padding: 40px 32px;
		margin-bottom: 0;
	}
	.packages-plan-card:not(:last-child) {
		border-bottom-right-radius: 0;
		border-top-right-radius: 0;
	}
}

.packages-plan-card:last-child {
	border-right: none;
}

.packages-package-additional,
.packages-plan-information {
	list-style-type: none;
	padding: 0;
}

.packages-plan-information {
	margin: 38px 0 0;
}

.packages-plan-information__item {
	display: flex;
	flex-direction: row;
	align-items: center;
	margin-bottom: 8px;
	font-weight: bold;
}

.packages-plan-information__item span > span {
	font-weight: 300;
}

.packages-plan-information__item:last-child {
	margin-bottom: 0;
}

.packages-plan-information__item img {
	margin-right: 12px;
	width: 16px;
	object-fit: contain;
}

.packages-package-additional {
	margin-bottom: 50px;
	font-size: 14px;
}

.packages-package-additional li {
	margin-bottom: 7px;
}

.packages-package-additional li:last-child {
	margin-bottom: 0;
}

.packages-vat-info {
	font-style: normal;
	font-weight: 400;
	font-size: 16px;
	line-height: 21px;
	color: #83919a;
	position: absolute;
	bottom: 1rem;
	left: 3rem;
	display: none;
}

@media (min-width: 768px) {
	.packages-vat-info {
		display: block;
	}
}

.large-paragraph {
	margin-top: 50px;
	margin-bottom: 40px;
}

.large-paragraph__content {
	color: #202733;
	text-align: center;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	font-size: 35px;
}

@media (min-width: 1024px) {
	.large-paragraph__content {
		font-size: 52px;
	}
}

.cta-image {
	margin-top: 70px;
}

@media (min-width: 1024px) {
	.cta-image {
		margin-top: 100px;
	}
}

.cta-image-wrapper {
	background: radial-gradient(38.11% 129.97% at 32.24% 103.05%, #ebf1f8 0%, #f9fbfd 100%);
	border-radius: 40px;
	position: relative;
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

@media (min-width: 768px) {
	.cta-image-wrapper {
		padding: 0 0 0 25px;
		flex-direction: row;
		justify-content: space-between;
	}
}

@media (min-width: 1024px) {
	.cta-image-wrapper {
		padding: 0 0 0 100px;
	}
}

.cta-image-wrapper__background {
	z-index: 1;
	object-fit: cover;
	object-position: top left;
}

.cta-image-content {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 24px;
	position: relative;
	z-index: 2;
	flex-shrink: 0;
	padding: 64px 16px 40px;
}

@media (min-width: 768px) {
	.cta-image-content {
		max-width: 500px;
		padding: 50px 0;
		align-items: flex-start;
	}
}

@media (min-width: 1024px) {
	.cta-image-content {
		max-width: 610px;
		padding: 100px 0;
	}
}

.cta-image-content__text {
	font-weight: 600;
	font-size: 18px;
	margin: 0;
}

.error-404 {
	padding-top: 64px;
	padding-bottom: 40px;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-height: 60vh;
}

@media (min-width: 1000px) {
	.error-404 {
		padding-top: 90px;
		padding-bottom: 90px;
		min-height: 70vh;
	}
}

.error-404.container {
	max-width: 1140px;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

.error-404__content {
	max-width: 600px;
	margin: 0 auto;
}

.error-404__title {
	font-size: 120px;
	line-height: 1;
	font-weight: 700;
	color: #202733;
	margin: 0 0 16px;
}

@media (min-width: 1000px) {
	.error-404__title {
		font-size: 160px;
	}
}

.error-404__subtitle {
	font-size: 30px;
	line-height: 1.3;
	font-weight: 600;
	color: #202733;
	margin: 0 0 24px;
}

@media (min-width: 1000px) {
	.error-404__subtitle {
		font-size: 40px;
		margin: 0 0 32px;
	}
}

.error-404__description {
	font-size: 16px;
	line-height: 1.6;
	font-weight: 400;
	color: #afbec6;
	margin: 0 0 40px;
}

@media (min-width: 1000px) {
	.error-404__description {
		font-size: 18px;
		margin: 0 0 48px;
	}
}

.error-404__button {
	display: inline-flex;
	padding: 20px 40px;
	background: #202733;
	color: #ffffff;
	border-radius: 64px;
	border: 0;
	text-decoration: none;
	font-weight: 600;
	font-size: 16px;
	line-height: 21px;
	transition: all 0.2s ease;
	cursor: pointer;
}

.error-404__button:hover, .error-404__button:focus {
	background: #d2e2ff;
	color: #202733;
	text-decoration: none;
	outline: none;
	transform: translateY(-2px);
}

.content-section {
	padding-top: 40px;
	padding-bottom: 40px;
}

@media (min-width: 1000px) {
	.content-section {
		padding-top: 80px;
		padding-bottom: 80px;
	}
}

.footer {
	margin-top: 80px;
	padding-top: 40px;
	position: relative;
	z-index: 1;
	background-color: #f9fbfd;
}

@media (min-width: 768px) {
	.footer {
		margin-top: 120px;
		padding-top: 64px;
	}
}

.footer::after {
	content: '';
	width: 405px;
	height: 100%;
	object-fit: contain;
	right: 0;
	top: 0;
	position: absolute;
	background: url("images/logo-dark-bg.png") no-repeat center right/contain;
	z-index: 2;
	display: none;
}

@media (min-width: 768px) {
	.footer::after {
		display: block;
	}
}

.footer-main, .footer-bottom {
	position: relative;
	z-index: 3;
}

.footer-main {
	border-bottom: 1px solid #afbec6;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding-bottom: 34px;
}

@media (min-width: 768px) {
	.footer-main {
		padding-bottom: 64px;
		flex-direction: row;
		align-items: flex-start;
	}
}

.footer-main-logo {
	width: 130px;
	height: auto;
	object-fit: contain;
	margin-bottom: 23px;
}

@media (min-width: 768px) {
	.footer-main-logo {
		margin-right: 160px;
		margin-bottom: 0;
	}
}

.footer-main-boxes {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
	grid-gap: 20px;
	flex-grow: 1;
	text-align: center;
}

@media (min-width: 768px) {
	.footer-main-boxes {
		text-align: left;
	}
}

.footer-main-box__title {
	font-size: 18px;
	font-weight: 600;
	margin: 0 0 16px;
}

.footer-main-box__list {
	display: flex;
	flex-direction: column;
	gap: 16px;
	font-weight: 400;
	list-style-type: none;
	padding: 0;
	margin: 0;
}

.footer-bottom {
	padding: 20px 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: #434f63;
	gap: 15px;
}

@media (min-width: 768px) {
	.footer-bottom {
		display: flex;
		flex-direction: row;
		justify-content: space-between;
		gap: 40px;
	}
}

.footer-bottom p {
	margin-top: 0;
	margin-bottom: 0;
}

.footer-bottom__language select {
	margin-left: 6px;
	border: 0;
	background: transparent;
	font-weight: 400;
}

.footer-bottom__social {
	margin: 0;
	padding: 0;
	list-style-type: none;
	display: flex;
	flex-direction: row;
	gap: 20px;
}

.footer-bottom__social img {
	width: 24px;
	object-fit: contain;
}

.alignleft {
	/*rtl:ignore*/
	float: left;
	/*rtl:ignore*/
	margin-right: 1.5em;
	margin-bottom: 1.5em;
}

.alignright {
	/*rtl:ignore*/
	float: right;
	/*rtl:ignore*/
	margin-left: 1.5em;
	margin-bottom: 1.5em;
}

.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 1.5em;
}

/* Text meant only for screen readers. */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: #fff;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	clip-path: none;
	color: #000;
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

/* Do not show the outline on the skip link target. */
#primary[tabindex='-1']:focus {
	outline: 0;
}

/*# sourceMappingURL=style.css.map */