:root {
    /* Colors */

    --clr-black: #333333;

    --clr-d-gray: #4c4c4c;

    --clr-l-gray: #a4a3a3;

    --clr-sl-gray: #c9c9c9;

    --clr-white: #ffffff;

    --acc-d-green: #024b3e;

    --acc-green: #06705d;

    --acc-d-card-green: #015147;

    --acc-line-on-bg-green: #356f65;

    --acc-line-green: #bcdad3;

    --acc-l-line-green: #dae9e2;

    --acc-l-green: #85d2c4;

    --acc-purple: #8888db;

    --acc-l-purple: #cac9e5;

    --acc-disabled: #92ada0;

    --acc-error: #eb3b5a;

    --bg-main: #fffefb;

    --bg-l-green: #e9f4f0;

    --bg-l-purple: #ececf6;

    --label-blue: #044a54;

    --label-l-blue: #cbe9ed;

    --label-green: #04541a;

    --label-l-green: #cbeddb;

    --label-purple: #1e0454;

    --lable-l-purple: #eadff5;

    /* Values */

    --def-transition: 0.35s;

    --def-opacity: 0.8;

    /* Sizes */

    --p-inline: 135px;

    --tb-val-xs: 30px;

    --tb-val-s: 40px;

    --tb-val-m: 60px;

    --tb-val-l: 100px;

    --tb-val-xl: 150px;

    --header-comp: 0;

    /* z-index */

    --zi-blur-bg: -2;

    --zi-bg: -1;

    --zi-1: 1;

    --zi-2: 2;

    --zi-3: 3;

    --zi-4: 4;

    --zi-5: 5;

    /* Fonts */

    --def-font: "Manrope", sans-serif;

    --quote-font: "Open Sans", sans-serif;
}

/* Utility classes */

.p-inline {
    padding-inline: var(--p-inline);
}

.p-tb-s {
    padding-block: var(--tb-val-s);
}

.p-t-m {
    padding-top: var(--tb-val-m);
}

.p-tb-xl {
    padding-block: var(--tb-val-xl);
}

.p-t-xl {
    padding-top: var(--tb-val-xl);
}

.p-b-xl {
    padding-bottom: var(--tb-val-xl);
}

.m-t-s {
    margin-top: var(--tb-val-s);
}

.m-t-m {
    margin-top: var(--tb-val-m);
}

.m-t-l {
    margin-top: var(--tb-val-l);
}

.m-tb-xl {
    margin-block: var(--tb-val-xl);
}

.m-t-xl {
    margin-top: var(--tb-val-xl);
}

.m-b-xl {
    margin-bottom: var(--tb-val-xl);
}

.txt-center {
    text-align: center;
}

.m-center {
    margin-inline: auto;
}

.clr-d-gray {
    color: var(--clr-d-gray);
}

@keyframes float {
    0% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(10px);
    }

    100% {
        transform: translateY(0);
    }
}

@font-face {
    font-family: "Manrope";

    src: url("../fonts/Manrope/Manrope-Regular/Manrope-Regular.woff")
            format("woff"),
        url("../fonts/Manrope/Manrope-Regular/Manrope-Regular.woff2")
            format("woff2");

    font-weight: 400;

    font-style: normal;

    font-display: swap;
}

@font-face {
    font-family: "Manrope";

    src: url("../fonts/Manrope/Manrope-SemiBold/Manrope-SemiBold.woff")
            format("woff"),
        url("../fonts/Manrope/Manrope-SemiBold/Manrope-SemiBold.woff2")
            format("woff2");

    font-weight: 600;

    font-style: normal;

    font-display: swap;
}

@font-face {
    font-family: "Manrope";

    src: url("../fonts/Manrope/Manrope-Bold/Manrope-Bold.woff") format("woff"),
        url("../fonts/Manrope/Manrope-Bold/Manrope-Bold.woff2") format("woff2");

    font-weight: 700;

    font-style: normal;

    font-display: swap;
}

@font-face {
    font-family: "Manrope";

    src: url("../fonts/Manrope/Manrope-ExtraBold/Manrope-ExtraBold.woff")
            format("woff"),
        url("../fonts/Manrope/Manrope-ExtraBold/Manrope-ExtraBold.woff2")
            format("woff2");

    font-weight: 800;

    font-style: normal;

    font-display: swap;
}

@font-face {
    font-family: "Open Sans";

    src: url("../fonts/OpenSans/OpenSans-Italic/OpenSans-Italic.woff")
            format("woff"),
        url("../fonts/OpenSans/OpenSans-Italic/OpenSans-Italic.woff2")
            format("woff2");

    font-weight: 400;

    font-style: italic;

    font-display: swap;
}

.btn-def,
.tnp-submit {
    display: flex;

    padding: 16px 32px;

    width: -moz-fit-content;

    width: fit-content;

    font-size: 18px;

    font-weight: 700;

    line-height: 1.3em;

    background-color: transparent;

    border: 1px solid transparent;

    border-radius: 13px;

    transition: var(--def-transition);

    justify-content: center;

    align-items: center;

    gap: 16px;

    cursor: pointer;
}

.btn-def.green,
.tnp-submit.green {
    color: var(--clr-white);

    background-color: var(--acc-green);
}

.btn-def.green:disabled,
.btn-def.green.disabled,
.tnp-submit.green.disabled {
    color: var(--acc-disabled);

    background-color: var(--acc-l-line-green);

    pointer-events: none;
}

.btn-def.green:not(:active):hover,
.btn-def.green:not(:active):focus,
.tnp-submit.green:not(:active):focus {
    background-color: var(--acc-d-green);
}

.btn-def.purple,
.tnp-submit.purple {
    color: var(--clr-white);

    background-color: var(--acc-purple);
}

.btn-def.purple:disabled,
.btn-def.purple.disabled,
.tnp-submit.purple.disabled {
    color: #a1a1d7;

    background-color: #e0e0f2;

    pointer-events: none;
}

.btn-def.purple:hover,
.btn-def.purple:focus,
.tnp-submit.purple:hover,
.tnp-submit.purple:focus {
    background-color: #5d5db8;
}

.btn-def.border,
.tnp-submit.border {
    color: var(--clr-black);

    border-color: var(--clr-sl-gray);
}

.btn-def.border:disabled,
.btn-def.border.disabled,
.tnp-submit.border:disabled,
.tnp-submit.border.disabled {
    color: var(--acc-disabled);

    border-color: var(--acc-l-line-green);

    pointer-events: none;
}

.btn-def.border:not(:active):hover,
.btn-def.border:not(:active):focus,
.tnp-submit.border:not(:active):hover,
.tnp-submit.border:not(:active):focus {
    color: var(--acc-d-green);

    background-color: var(--acc-l-green);

    border-color: transparent;
}

.btn-link {
    display: flex;

    font-size: 18px;

    font-weight: 700;

    line-height: 1.3em;

    color: var(--acc-green);

    align-items: center;

    gap: 10px;

    cursor: pointer;
}

.btn-link:disabled,
.btn-link.disabled {
    color: var(--acc-disabled);
}

.btn-link:disabled:after,
.btn-link.disabled:after {
    filter: grayscale(1);

    opacity: 0.5;
}

.btn-link:hover:after,
.btn-link:focus:after {
    transform: translateX(10px);
}

.btn-link:after {
    content: "";

    width: 24px;

    height: 24px;

    background-color: var(--acc-green);

    -webkit-mask-image: url("../images/general/icon/arrow-r-icon.svg");

    mask-image: url("../images/general/icon/arrow-r-icon.svg");

    -webkit-mask-size: 100% auto;

    mask-size: 100% auto;

    transition: var(--def-transition);
}

.btn-link-sm {
    position: relative;

    padding-bottom: 2px;

    color: var(--acc-green);
}

.btn-link-sm:hover:before,
.btn-link-sm:focus:before {
    left: auto;

    right: 0;

    width: 0;
}

.btn-link-sm:before {
    content: "";

    display: block;

    position: absolute;

    left: 0;

    bottom: 0;

    width: 100%;

    height: 1px;

    background-color: var(--acc-green);

    transition: var(--def-transition);
}

.btn-icon {
    display: flex;

    padding: 16px;

    width: -moz-fit-content;

    width: fit-content;

    background-color: transparent;

    border: 1px solid transparent;

    border-radius: 13px;

    transition: var(--def-transition);

    cursor: pointer;
}

.btn-icon.splide__arrow {
    position: relative;

    top: auto;

    left: auto;

    right: auto;

    height: auto;

    opacity: 1;
}

.btn-icon.green {
    background-color: var(--acc-green);
}

.btn-icon.green svg {
    fill: var(--clr-white);
}

.btn-icon.green:hover {
    opacity: 1;
}

.btn-icon.border {
    border-color: rgba(255, 255, 255, 0.7);
}

.btn-icon.border svg {
    fill: var(--clr-white);

    opacity: 0.7;
}

.btn-icon:disabled,
.btn-icon.disabled {
    background-color: transparent;

    border-color: var(--acc-line-green);

    pointer-events: none;
}

.btn-icon:disabled svg,
.btn-icon.disabled svg {
    fill: var(--acc-disabled);
}

.btn-icon svg {
    margin: auto;

    width: 24px;

    height: 24px;
}

.btn-line {
    position: relative;

    padding-bottom: 2px;

    font-weight: 400;

    line-height: 1.5em;

    color: var(--clr-white);

    transition: var(--def-transition);

    opacity: 0.7;

    overflow: hidden;
}

.btn-line:hover,
.btn-line:focus {
    opacity: 1;
}

.btn-line:hover:before,
.btn-line:focus:before {
    transform: translateX(0);
}

.btn-line:before {
    content: "";

    display: block;

    position: absolute;

    left: 0;

    bottom: 0;

    width: 100%;

    height: 1px;

    background-color: var(--clr-white);

    transition: var(--def-transition);

    transform: translateX(-105%);
}

.btn-line.gray {
    color: var(--clr-d-gray);

    opacity: 1;
}

.btn-line.gray:before {
    background-color: var(--clr-d-gray);
}

.btn-menu {
    display: none;

    padding: 12px;

    width: -moz-fit-content;

    width: fit-content;

    background-color: transparent;

    border: 1px solid var(--acc-line-green);

    border-radius: 13px;
}

.btn-menu.active span:nth-child(2) {
    width: 0;
}

.btn-menu.active span:nth-child(1),
.btn-menu.active span:nth-child(3) {
    margin-top: -1px;

    top: 50%;

    bottom: auto;
}

.btn-menu.active span:nth-child(1) {
    transform: rotate(45deg);
}

.btn-menu.active span:nth-child(3) {
    transform: rotate(-45deg);
}

.btn-menu-container {
    position: relative;

    width: 20px;

    height: 20px;
}

.btn-menu span {
    display: block;

    position: absolute;

    right: 0;

    width: 100%;

    height: 3px;

    background-color: var(--acc-green);

    border-radius: 2px;

    transition: var(--def-transition);

    will-change: transform;
}

.btn-menu span:nth-child(1) {
    top: 1px;
}

.btn-menu span:nth-child(2) {
    margin-top: -2px;

    top: 50%;

    width: 50%;
}

.btn-menu span:nth-child(3) {
    bottom: 1px;
}

.social {
    display: flex;

    list-style: none;

    align-items: center;

    gap: 20px;
}

.pagination {
    display: flex;

    justify-content: center;

    align-items: center;

    gap: 10px;
}

.pagination-wrap {
    display: flex;

    align-items: center;

    gap: 10px;
}

.pagination-btn,
.pagination-delimer,
.page-numbers {
    display: flex;

    width: 58px;

    height: 58px;

    font-size: 18px;

    font-weight: 700;

    color: var(--acc-d-green);

    justify-content: center;

    align-items: center;
}

.page-numbers.dots {
    border: none;
}

.pagination-btn,
.page-numbers {
    background-color: transparent;

    border: 1px solid var(--acc-line-green);

    border-radius: 13px;

    transition: var(--def-transition);
}

.pagination-btn.active,
.page-numbers.current {
    background-color: var(--acc-l-green);

    pointer-events: none;
}

.pagination-btn:hover,
.pagination-btn:focus,
.page-numbers:hover,
.page-numbers:focus {
    border-color: var(--acc-green);
}

.pagination-val {
    display: none;

    padding: 16px;

    width: 100%;

    font-size: 18px;

    font-weight: 700;

    line-height: 26px;

    background-color: var(--bg-l-green);

    border-radius: 13px;

    justify-content: center;

    align-items: center;

    gap: 10px;
}

.pagination-val-all:before {
    content: "/";

    display: inline-block;

    margin-right: 10px;
}

.pagination .prev {
    margin-right: 20px;
}

.pagination .next {
    margin-left: 20px;
}

.crumbs {
    display: flex;

    position: relative;

    margin-top: 10px;

    padding-inline: var(--p-inline);

    padding-bottom: 10px;

    list-style: none;

    align-items: center;

    overflow-y: hidden;

    overflow-x: auto;

    scrollbar-width: thin;

    gap: 15px;

    z-index: var(--zi-1);
}

.crumbs li {
    display: flex;

    align-items: center;

    gap: 15px;
}

.crumbs li:after {
    content: "";

    display: block;

    width: 14px;

    height: 10px;

    background-image: url("../images/general/icon/crumbs-icon.svg");

    background-size: 100% auto;

    background-position: center center;

    background-repeat: no-repeat;
}

.crumbs li:last-child:after {
    display: none;
}

.crumbs li:last-child .crumbs-link {
    color: var(--acc-green);

    pointer-events: none;

    cursor: default;
}

.crumbs-link {
    font-size: 16px;

    font-weight: 400;

    color: var(--clr-black);

    white-space: nowrap;

    /* transition: var(--def-transition); */
}

.crumbs-link:hover,
.crumbs-link:focus {
    color: var(--acc-green);
}

@supports selector(*:focus-visible) {
    .btn-def.green:not(:active):focus,
    .tnp-submit.green:not(:active):focus {
        background-color: var(--acc-green);
    }

    .btn-def.green:not(:active):hover,
    .btn-def.green:not(:active):focus-visible,
    .tnp-submit.green:not(:active):hover,
    .tnp-submit.green:not(:active):focus-visible {
        background-color: var(--acc-d-green);
    }

    .btn-def.purple:focus,
    .tnp-submit.purple:focus {
        background-color: var(--acc-purple);
    }

    .btn-def.purple:hover,
    .btn-def.purple:focus-visible,
    .tnp-submit.purple:hover,
    .tnp-submit.purple:focus-visible {
        background-color: #5d5db8;
    }

    .btn-def.border:not(:active):focus,
    .tnp-submit.border:not(:active):focus {
        color: var(--acc-black);

        background-color: transparent;

        border-color: var(--acc-l-line-green);
    }

    .btn-def.border:not(:active):hover,
    .btn-def.border:not(:active):focus-visible,
    .tnp-submit.border:not(:active):hover,
    .tnp-submit.border:not(:active):focus-visible {
        color: var(--acc-d-green);

        background-color: var(--acc-l-green);

        border-color: transparent;
    }

    .btn-link:focus:after {
        transform: translateX(0);
    }

    .btn-link:hover:after,
    .btn-link:focus-visible:after {
        transform: translateX(10px);
    }

    .btn-link-sm:focus:before {
        left: 0;

        right: auto;

        width: 100%;
    }

    .btn-link-sm:hover:before,
    .btn-link-sm:focus-visible:before {
        left: auto;

        right: 0;

        width: 0;
    }

    .btn-line:focus {
        opacity: 0.7;
    }

    .btn-line:focus:before {
        transform: translateX(-105%);
    }

    .btn-line:hover,
    .btn-line:focus-visible {
        opacity: 1;
    }

    .btn-line:hover:before,
    .btn-line:focus-visible:before {
        transform: translateX(0);
    }

    .pagination-btn:focus {
        border-color: var(--acc-line-green);
    }

    .pagination-btn:hover,
    .pagination-btn:focus-visible {
        border-color: var(--acc-green);
    }

    .crumbs-link:focus {
        color: var(--clr-black);
    }

    .crumbs-link:hover,
    .crumbs-link:focus-visible {
        color: var(--acc-green);
    }
}

*,
body,
html {
    margin: 0;

    padding: 0;

    box-sizing: border-box;
}

html,
body {
    min-width: 320px;
}

html {
    height: 100%;

    font-family: var(--def-font);

    font-size: 16px;

    line-height: 1.15;

    -webkit-text-size-adjust: 100%;

    scroll-behavior: smooth;
}

body {
    height: 100%;

    color: var(--clr-black);

    -webkit-font-smoothing: antialiased;

    background-color: var(--bg-main);

    /* scroll-behavior: smooth; */

    /* text-rendering: optimizeSpeed; */
}

body.hide-scroll {
    overflow: hidden;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

main {
    display: block;
}

a {
    text-decoration: none;

    outline: none;
}

a:not([class]) {
    -webkit-text-decoration-skip: ink;

    text-decoration-skip-ink: auto;
}

img {
    display: block;

    max-width: 100%;

    height: auto;
}

input,
textarea,
select,
button {
    font: inherit;

    border-radius: 0;

    -webkit-appearance: none;

    -moz-appearance: none;

    appearance: none;

    outline: none;

    -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
}

audio,
canvas,
iframe,
img,
svg,
video,
textarea {
    vertical-align: middle;
}

fieldset {
    border: 0;
}

section {
    position: relative;
}

.visually-hidden {
    position: absolute;

    margin: -1px;

    padding: 0;

    width: 1px;

    height: 1px;

    border: 0;

    white-space: nowrap;

    -webkit-clip-path: inset(100%);

    clip-path: inset(100%);

    clip: rect(0 0 0 0);

    overflow: hidden;
}

.wrapper {
    display: flex;

    flex-direction: column;

    height: 100%;
}

.content {
    position: relative;

    flex: 1 0 auto;

    overflow: hidden;
}

.content:before,
.content:after {
    content: "";

    display: block;

    position: absolute;

    z-index: var(--zi-blur-bg);
}

.content:before {
    top: 23%;

    left: -42%;

    width: 67.14vw;

    height: 57.19vw;

    background: radial-gradient(
        50% 50% at 50% 50%,
        #6ce4ce 0%,
        rgba(108, 228, 206, 0) 100%
    );

    transform: rotate(90deg);

    opacity: 0.3;
}

.content:after {
    bottom: 15%;

    right: -35%;

    width: 61.41vw;

    height: 55.73vw;

    background: radial-gradient(
        50% 50% at 50% 50%,
        #7585fe 0%,
        rgba(117, 133, 254, 0) 100%
    );

    transform: rotate(-20deg);

    opacity: 0.1;
}

.logo {
    display: inline-block;

    transition: var(--def-transition);
}

.logo:hover,
.logo:focus {
    opacity: var(--def-opacity);
}

.logo-icon {
    width: 100%;

    max-width: 136px;
    max-height: 35px;
}

.container {
    position: relative;

    margin-left: auto;

    margin-right: auto;

    padding-inline: var(--p-inline);

    width: 100%;

    max-width: 100%;
}

/* General styles */

.section-heading-sm {
    font-size: 25px;

    font-weight: 700;

    line-height: 1.3em;
}

.section-heading-m {
    font-size: 35px;

    font-weight: 700;

    line-height: 1.3em;
}

.section-heading-l {
    font-size: 50px;

    font-weight: 700;

    line-height: 1.3em;
}

.section-heading-xl {
    font-size: 60px;

    font-weight: 700;

    line-height: 1.3em;
}

.section-desc {
    margin-top: var(--tb-val-xs);

    font-size: 24px;

    font-weight: 400;

    line-height: 1.5em;
}

.section-desc + .section-desc {
    margin-top: 20px;
}

.section-text {
    font-size: 20px;

    font-weight: 400;

    line-height: 1.5em;
}

/* Custom list */

.custom-list {
    display: grid;

    margin-top: var(--tb-val-s);

    list-style: none;

    gap: 25px;
}

.custom-list li {
    position: relative;

    padding-left: 55px;
}

.custom-list li:before {
    content: "";

    display: block;

    position: absolute;

    top: 0;

    left: 0;

    width: 30px;

    height: 30px;

    background-size: 100% auto;

    background-position: center center;

    background-repeat: no-repeat;
}

/* Custom form & inputs */

.custom-form {
    display: grid;

    grid-template-columns: repeat(2, 1fr);

    gap: 20px;
}

.custom-form > *.f-width {
    grid-column: 1/-1;
}

.custom-form-btn {
    margin-top: 20px;

    width: 100%;
}

.modal-content .custom-form {
    margin-top: var(--tb-val-s);
}

.custom-input.border .custom-input-field {
    border-color: var(--acc-l-line-green);
}

.custom-input.error .custom-input-title {
    color: var(--acc-error);
}

.custom-input.error .custom-input-field {
    border-color: var(--acc-error);
}

.custom-input-title {
    font-size: 16px;

    font-weight: 700;

    line-height: 1.5em;

    color: var(--clr-d-gray);
}

.custom-input-field {
    display: block;

    margin-top: 5px;

    padding: 15px 20px;

    width: 100%;

    font-size: 18px;

    font-weight: 400;

    line-height: 1.38em;

    background-color: var(--bg-main);

    border: 1px solid transparent;

    border-radius: 15px;
}

.custom-input-field::-moz-placeholder {
    color: var(--clr-l-gray);
}

.custom-input-field::placeholder {
    color: var(--clr-l-gray);
}

.custom-input-textarea-field {
    height: 132px;

    resize: vertical;
}

.sub-container {
    padding: var(--tb-val-m) var(--p-inline);

    color: var(--clr-white);

    text-align: center;

    background-color: var(--acc-purple);

    background-image: url("../images/content/sub/sub-bg.png");

    background-size: 100% auto;

    background-position: top center;

    background-repeat: no-repeat;

    border-radius: 30px;
}

.sub-form {
    display: flex;

    margin-top: var(--tb-val-xs);

    margin-inline: auto;

    padding: 1px;

    padding-left: 30px;

    max-width: 650px;

    background-color: var(--bg-main);

    border: 1px solid transparent;

    border-radius: 15px;

    align-items: center;

    gap: 20px;
}

.sub-form.error {
    border-color: var(--acc-error);
}

.sub-input,
.tnp-email {
    width: 100%;

    font-size: 18px;

    font-weight: 400;

    line-height: 1.3em;

    color: var(--clr-black);

    background-color: transparent;

    border: 0;
}

.sub-input::-moz-placeholder,
.tnp-email::-moz-placeholder {
    color: var(--clr-l-gray);
}

.sub-input::placeholder,
.tnp-email::placeholder {
    color: var(--clr-l-gray);
}

/* For on scroll animation */

.fade-in {
    transition: 1s;

    opacity: 0.1;
}

.fade-in.appear {
    opacity: 1;
}

.header {
    display: flex;

    position: relative;

    padding: 25px var(--p-inline);

    transition: var(--def-transition);

    justify-content: space-between;

    align-items: center;

    flex: 0 0 auto;

    gap: 16px;

    z-index: var(--zi-4);
}

.header:not(.inside) + * {
    padding-top: var(--header-comp);
}

.header.fixed {
    position: fixed;

    top: 0;

    left: 0;

    width: 100%;

    background-color: var(--bg-l-green);
}

.header.menu-open {
    background-color: var(--bg-l-green);
}

.header-nav-bg {
    display: none;

    position: fixed;

    bottom: 0;

    left: 0;

    width: 100%;

    height: calc(100% - var(--menu-comp));

    background-color: var(--clr-black);

    transition: var(--def-transition);

    opacity: 0.4;

    z-index: -1;
}

.header-nav-list {
    display: flex;

    list-style: none;

    align-items: center;

    gap: var(--tb-val-m);
}

.header-nav-link {
    font-size: 18px;

    font-weight: 600;

    line-height: 1.3em;

    color: var(--acc-black);

    transition: var(--def-transition);
}

.header-nav-link:hover,
.header-nav-link:focus-within,
.header-nav-link:focus {
    color: var(--acc-green);
}

.header-nav-dd {
    position: relative;
}

.header-nav-dd.active .header-nav-dd-btn {
    transform: rotate(180deg);
}

.header-nav-dd-head {
    display: flex;

    align-items: center;

    gap: 5px;
}

.header-nav-dd-btn {
    display: none;

    width: -moz-fit-content;

    width: fit-content;

    background-color: transparent;

    border: 0;

    transition: var(--def-transition);
}

.header-nav-dd-container {
    position: absolute;

    padding-top: 20px;

    top: 100%;

    left: -30px;

    width: -moz-max-content;

    width: max-content;

    /* transition: var(--def-transition); */

    visibility: hidden;

    pointer-events: none;

    transform: translateY(-10%);

    opacity: 0;
}

.header-nav-dd-list {
    display: grid;

    padding: 30px;

    width: 100%;

    background-color: var(--bg-main);

    box-shadow: 0px 4px 10px rgba(51, 51, 51, 0.1);

    border: 1px solid var(--acc-l-line-green);

    border-radius: 10px;

    list-style: none;

    gap: 20px;
}

.header-nav-dd-link {
    display: flex;

    font-size: 16px;

    font-weight: 400;

    line-height: 1.5em;

    color: var(--clr-black);

    transition: var(--def-transition);

    align-items: center;

    gap: 10px;
}

.header-nav-dd-link:hover,
.header-nav-dd-link:focus {
    color: var(--acc-green);
}

.header-nav-dd-link:hover:after,
.header-nav-dd-link:focus:after {
    transform: translateX(0);

    opacity: 1;
}

.header-nav-dd-link:after {
    content: "";

    display: block;

    width: 24px;

    height: 24px;

    background-image: url("../images/general/icon/arrow-r-icon.svg");

    background-size: 100% auto;

    background-position: center center;

    background-repeat: no-repeat;

    transition: var(--def-transition);

    transform: translateX(-10px);

    opacity: 0;
}

@supports selector(*:focus-visible) {
    .header-nav-link:focus {
        color: var(--acc-black);
    }

    .header-nav-link:hover,
    .header-nav-link:focus-within,
    .header-nav-link:focus-visible {
        color: var(--acc-green);
    }

    .header-nav-dd-link:focus {
        color: var(--acc-black);
    }

    .header-nav-dd-link:focus:after {
        transform: translateX(-10px);

        opacity: 0;
    }

    .header-nav-dd-link:hover,
    .header-nav-dd-link:focus-visible {
        color: var(--acc-green);
    }

    .header-nav-dd-link:hover:after,
    .header-nav-dd-link:focus-visible:after {
        transform: translateX(0);

        opacity: 1;
    }
}

.footer {
    color: var(--clr-white);

    background-color: var(--acc-d-green);

    flex: 0 0 auto;
}

.footer-top {
    display: grid;

    grid-template-columns: 1fr 2.92fr 1fr;
}

.footer-el {
    padding-block: var(--tb-val-m);
}

.footer-el:first-child {
    padding-right: 57px;
}

.footer-social {
    margin-top: 40px;
}

.footer-nav {
    border-left: 1px solid var(--acc-line-on-bg-green);

    border-right: 1px solid var(--acc-line-on-bg-green);
}

.footer-nav-list {
    display: grid;

    margin-top: var(--tb-val-xs);

    grid-template-columns: repeat(2, max-content);

    justify-content: space-between;

    gap: 20px;

    list-style: none;
}

.footer-nav-el {
    padding-block: 50px;

    padding-inline: 20px;
}

.footer-nav-el + .footer-nav-el {
    border-top: 1px solid var(--acc-line-on-bg-green);
}

.footer-nav-el-container {
    margin-inline: auto;

    width: 100%;

    max-width: 560px;
}

.footer-nav-wrap {
    display: flex;

    justify-content: space-between;

    align-items: center;

    gap: 20px;
}

.footer-link {
    display: block;

    width: -moz-fit-content;

    width: fit-content;

    color: var(--clr-white);

    transition: 0.2s ease;
}

.footer-link span {
    display: block;

    width: -moz-fit-content;

    width: fit-content;

    transition: 0.2s ease;
}

.footer-link:not(.big) {
    opacity: 0.7;
}

.footer-link:not(.big):hover,
.footer-link:not(.big):focus {
    opacity: 1;
}

.footer-link.big:hover,
.footer-link.big:focus {
    color: var(--acc-l-green);
}

.footer-contact {
    padding-left: 20px;
}

.footer-contact-el {
    display: flex;

    margin-left: auto;

    max-width: 194px;

    font-style: normal;

    flex-flow: column;

    gap: 20px;
}

.footer-contact-el + .footer-contact-el {
    margin-top: 30px;
}

.footer-contact-text {
    opacity: 0.7;
}

.footer-bottom {
    display: flex;

    padding-block: 30px;

    font-size: 16px;

    font-weight: 400;

    line-height: 1.5em;

    letter-spacing: 0.03em;

    color: rgba(255, 255, 255, 0.7);

    border-top: 1px solid var(--acc-line-on-bg-green);

    justify-content: space-between;

    align-items: center;

    gap: 20px;
}

.footer-bottom-wrap {
    display: flex;

    gap: 60px;
}

.footer-bottom-link {
    font-size: inherit;
}

.footer-watermark a {
    font-weight: 700;

    color: inherit;

    transition: var(--def-transition);
}

.footer-watermark a:hover,
.footer-watermark a:focus {
    color: var(--acc-l-green);
}

@supports selector(*:focus-visible) {
    .footer-link:not(.big):focus {
        opacity: 0.7;
    }

    @media (hover: hover) {
        .footer-link:not(.big):focus span {
            transform: translateX(0);
        }
    }

    .footer-link:not(.big):hover,
    .footer-link:not(.big):focus-visible {
        opacity: 1;
    }

    @media (hover: hover) {
        .footer-link:not(.big):hover span,
        .footer-link:not(.big):focus-visible span {
            transform: translateX(15px);
        }
    }

    .footer-link.big:focus {
        color: var(--clr-white);
    }

    .footer-link.big:hover,
    .footer-link.big:focus-visible {
        color: var(--acc-l-green);
    }

    .footer-watermark a:focus {
        color: inherit;
    }

    .footer-watermark a:hover,
    .footer-watermark a:focus-visible {
        color: var(--acc-l-green);
    }
}

.modal {
    display: none;

    position: fixed;

    top: 0;

    left: 0;

    width: 100%;

    height: 100%;

    transition: var(--def-transition);

    opacity: 0;

    visibility: hidden;

    overflow-y: auto;

    z-index: 1000;
}

.modal.active {
    display: block;

    visibility: visible;
}

.modal-container {
    display: flex;

    position: relative;

    padding: 60px var(--p-inline);

    min-height: 100%;

    justify-content: center;

    align-items: center;
}

.modal-bg {
    position: absolute;

    top: 0;

    left: 0;

    right: 0;

    bottom: 0;

    width: 100%;

    height: 100%;

    background-color: rgba(0, 0, 0, 0.5);

    z-index: 0;
}

.wpcf7-spinner {
    display: none;
}
.wpcf7-response-output {
    grid-column: 1 / span 2;
    margin: 0 !important;
}

.modal-content {
    position: relative;

    margin: 0 auto;

    padding: 90px 60px 60px;

    width: 100%;

    max-width: 815px;

    background-color: var(--bg-main);

    border-radius: 30px;

    overflow: hidden;
}

.modal-close-btn {
    display: block;

    position: absolute;

    top: 30px;

    right: 30px;

    width: 32px;

    height: 32px;

    background-color: transparent;

    background-image: url("../images/general/icon/cross-icon.svg");

    background-size: 100% auto;

    background-position: center center;

    background-repeat: no-repeat;

    border: 0;

    transition: var(--def-transition);

    cursor: pointer;
}

.modal-close-btn:hover,
.modal-close-btn:focus {
    opacity: var(--def-opacity);
}

.modal-img {
    margin-inline: auto;
}

.modal-heading {
    text-align: center;
}

.modal-text {
    margin-top: 20px;

    margin-inline: auto;

    max-width: 375px;

    text-align: center;
}

.modal-btn {
    margin-top: var(--tb-val-s);

    margin-inline: auto;
}

@media (hover: none) and (min-width: 1025px) {
    .header-nav-dd.active .header-nav-dd-container {
        visibility: visible;

        pointer-events: all;

        transform: translateY(0);

        opacity: 1;
    }
}

@media screen and (max-width: 1600px) {
    :root {
        --tb-val-l: 90px;

        --tb-val-xl: 140px;
    }

    .btn-def,
    .tnp-submit {
        font-size: 16px;
    }

    .section-heading-sm {
        font-size: 23px;
    }

    .section-heading-m {
        font-size: 31px;
    }

    .section-heading-l {
        font-size: 42px;
    }

    .section-heading-xl {
        font-size: 51px;
    }

    .section-desc {
        font-size: 22px;
    }

    .section-hero-info {
        max-width: 890px;
    }

    .header-nav-link {
        font-size: 16px;
    }
}

@media screen and (max-width: 1440px) {
    :root {
        --p-inline: 95px;

        --tb-val-xs: 20px;

        --tb-val-s: 30px;

        --tb-val-m: 50px;

        --tb-val-xl: 130px;
    }

    .btn-link {
        font-size: 16px;
    }

    .crumbs-link {
        font-size: 14px;
    }

    .section-heading-sm {
        font-size: 21px;
    }

    .section-heading-m {
        font-size: 27px;
    }

    .section-heading-l {
        font-size: 36px;
    }

    .section-heading-xl {
        font-size: 43px;
    }

    .section-desc {
        font-size: 20px;
    }

    .section-text {
        font-size: 18px;
    }

    .section-hero.big .section-hero-container {
        padding-top: 70px;
    }

    .section-hero-desc {
        margin-top: 30px;
    }

    .section-hero-btns {
        margin-top: 60px;
    }

    .section-hero-half-container {
        padding-top: 68px;
    }

    .section-hero-half-info {
        max-width: 509px;
    }

    .section-hero-half-media {
        margin-right: 60px;

        max-width: 446px;
    }

    .section-hero-half-media-bg {
        max-width: 360px;
    }

    .section-hero-half-media-ball.one {
        left: 120px;

        max-width: 108px;
    }

    .section-hero-half-media-ball.two {
        max-width: 248px;
    }

    .custom-form-btn {
        margin-top: 10px;
    }

    .custom-input-title {
        font-size: 14px;
    }

    .custom-input-field {
        font-size: 16px;
    }

    .sub-input,
    .tnp-email {
        font-size: 16px;
    }

    .header {
        padding-block: 16px;
    }

    .header-logo {
        max-width: 117px;
    }

    .footer-top {
        grid-template-columns: auto 1.6fr 1fr;
    }

    .footer-nav-el {
        padding-block: 40px;
    }

    .footer-nav-el-container {
        max-width: 500px;
    }

    .footer-contact-el {
        margin-inline: auto;
    }

    .footer-bottom {
        font-size: 14px;
    }
}

@media screen and (max-width: 1280px) {
    :root {
        --tb-val-l: 70px;

        --tb-val-xl: 120px;
    }

    .btn-def,
    .tnp-submit {
        font-size: 14px;
    }

    .section-heading-sm {
        font-size: 19px;
    }

    .section-heading-m {
        font-size: 23px;
    }

    .section-heading-l {
        font-size: 30px;
    }

    .section-heading-xl {
        font-size: 35px;
    }
}

@media screen and (max-width: 1024px) {
    :root {
        --p-inline: 40px;

        --tb-val-xs: 16px;

        --tb-val-s: 24px;

        --tb-val-m: 32px;

        --tb-val-l: 48px;

        --tb-val-xl: 90px;
    }

    .btn-def,
    .tnp-submit {
        padding: 13px 24px;
    }

    .btn-link {
        font-size: 14px;
    }

    .btn-link:after {
        width: 20px;

        height: 20px;
    }

    .btn-icon:not(.pagination-nav) {
        padding: 12px;
    }

    .btn-menu {
        display: flex;
    }

    .pagination {
        gap: 32px;
    }

    .pagination-wrap {
        display: none;
    }

    .pagination-val {
        display: flex;
    }

    .crumbs {
        margin-top: 8px;
    }

    .crumbs-link {
        font-size: 12px;
    }

    .content:before {
        top: 18%;
    }

    .section-heading-sm {
        font-size: 17px;
    }

    .section-heading-m {
        font-size: 21px;
    }

    .section-heading-l {
        font-size: 27px;
    }

    .section-heading-xl {
        font-size: 33px;
    }

    .section-desc {
        font-size: 18px;
    }

    .section-text {
        font-size: 16px;
    }

    .section-hero.big .section-hero-container {
        padding-block: 176px 242px;
    }

    .section-hero-info {
        max-width: 512px;
    }

    .section-hero-desc {
        margin-top: 16px;
    }

    .section-hero-btns {
        margin-top: 32px;
    }

    .section-hero-half-container {
        display: grid;

        padding-top: 48px;

        grid-template-columns: repeat(2, 1fr);
    }

    .section-hero-half-media {
        margin-right: 0;
    }

    .section-hero-half-media-bg {
        max-width: 270px;
    }

    .section-hero-half-media-ball.one {
        left: 89px;

        max-width: 81px;
    }

    .section-hero-half-media-ball.two {
        max-width: 187px;
    }

    .custom-list {
        gap: 16px;
    }

    .custom-list li {
        padding-left: 36px;
    }

    .custom-list li:before {
        width: 24px;

        height: 24px;
    }

    .custom-form-btn {
        margin-top: 4px;
    }

    .custom-input-field {
        padding: 13px 16px;

        font-size: 15px;
    }

    .sub-container {
        padding-block: 90px;

        background-image: url("../images/content/sub/sub-tablet-bg.png");

        background-size: cover;
    }

    .sub-form {
        padding-left: 16px;

        max-width: 512px;
    }

    .sub-input,
    .tnp-email {
        font-size: 15px;
    }

    .header {
        padding-block: 10px;

        justify-content: flex-start;

        isolation: isolate;
    }

    .header-logo {
        margin-right: auto;
    }

    .header-nav {
        --menu-comp: 0;

        display: none;

        position: fixed;

        margin-inline: calc(var(--p-inline) * -1);

        top: var(--menu-comp);

        width: 100%;

        height: calc(100% - var(--menu-comp));

        overflow-y: auto;
    }

    .header-nav.active {
        display: block;
    }

    .header-nav.appear .header-nav-bg {
        opacity: 0.4;
    }

    .header-nav.appear .header-nav-list {
        transition-delay: 0.35s;

        transform: translateY(0);

        opacity: 1;
    }

    .header-nav-bg {
        display: block;

        opacity: 0;
    }

    .header-nav-list {
        position: relative;

        padding: 30px var(--p-inline) 40px;

        background-color: var(--bg-l-green);

        border-top: 1px solid var(--acc-line-green);

        align-items: flex-start;

        flex-flow: column;

        transform: translateY(-10%);

        opacity: 0;

        transition: var(--def-transition);

        overflow: hidden;
    }

    .header-nav-list:before {
        content: "";

        display: block;

        position: absolute;

        right: -20px;

        bottom: -20px;

        width: 155px;

        height: 123px;

        background-image: url("../images/general/menu-bg.png");

        background-size: 100% auto;

        background-position: bottom right;

        background-repeat: no-repeat;
    }

    .header-nav-list li {
        width: 100%;

        text-align: left;
    }

    .header-nav-dd-head {
        justify-content: space-between;

        gap: 20px;
    }

    .header-nav-dd-btn {
        display: block;
    }

    .header-nav-dd-container {
        position: relative;

        padding: 0;

        top: auto;

        left: auto;

        width: 100%;

        max-height: 0;

        transform: translateY(0);

        overflow: hidden;
    }

    .header-nav-dd-container.open {
        visibility: visible;

        pointer-events: all;

        opacity: 1;
    }

    .header-nav-dd-list {
        padding: 24px 0 0 24px;

        background-color: transparent;

        box-shadow: none;

        border: 0;

        gap: 16px;
    }

    .header-nav-dd-link {
        font-size: 14px;

        font-weight: 700;
    }

    .footer-top {
        padding-block: var(--tb-val-m);

        grid-template-columns: 1fr;

        gap: 32px;
    }

    .footer-el {
        display: grid;

        padding: 0;

        grid-template-columns: repeat(2, 1fr);

        gap: 24px 16px;
    }

    .footer-el:first-child {
        padding-right: 0;
    }

    .footer-social {
        margin-top: 0;

        margin-left: auto;
    }

    .footer-nav {
        border: 0;
    }

    .footer-nav-list {
        margin-top: 24px;

        grid-template-columns: repeat(2, 1fr);

        gap: 16px;
    }

    .footer-nav-el {
        padding: 0;

        padding-block: 24px;
    }

    .footer-nav-el:first-child {
        padding-top: 0;
    }

    .footer-nav-el + .footer-nav-el {
        border-bottom: 1px solid var(--acc-line-on-bg-green);
    }

    .footer-nav-el-container {
        max-width: 100%;
    }

    .footer-contact-el {
        margin: 0;

        max-width: 100%;

        gap: 12px;
    }

    .footer-contact-el + .footer-contact-el {
        margin: 0;
    }

    .footer-contact-text br {
        display: none;
    }

    .footer-bottom-wrap {
        gap: 32px;
    }

    .modal-content {
        padding: 80px 50px 50px;
    }
}

.captcha.error .g-recaptcha > div{    
    border: 1px solid var(--acc-error);
}

@media screen and (max-width: 768px) {
    .footer-bottom {
        display: grid;

        padding-block: 16px;

        font-size: 12px;

        gap: 12px;
    }

    .g-recaptcha {
        max-width: 150px;
    }
}

@media screen and (max-width: 552px) {
    :root {
        --p-inline: 16px;

        --tb-val-xl: 80px;
    }

    .content:before,
    .content:after {
        display: none;
    }

    .section-heading-sm {
        font-size: 15px;
    }

    .section-heading-m {
        font-size: 19px;
    }

    .section-heading-l {
        font-size: 25px;
    }

    .section-heading-xl {
        font-size: 27px;
    }

    .section-desc {
        font-size: 16px;
    }

    .section-text {
        font-size: 14px;
    }

    .section-hero.big .section-hero-container {
        padding-block: 60px 80px;
    }

    .section-hero br:not(.dh) {
        display: none;
    }

    .section-hero-btns {
        gap: 16px;
    }

    .section-hero-half-container {
        padding-top: 32px;

        grid-template-columns: 1fr;

        gap: 40px;
    }

    .section-hero-half-info {
        max-width: 100%;
    }

    .section-hero-half-media-bg {
        margin-left: 50px;

        max-width: 192px;
    }

    .section-hero-half-media-ball.one {
        left: 113px;

        max-width: 58px;
    }

    .section-hero-half-media-ball.two {
        max-width: 133px;
    }

    .custom-form {
        grid-template-columns: 1fr;

        gap: 16px;
    }

    .custom-form-btn {
        margin-top: 8px;
    }

    .sub-container {
        margin-inline: calc(var(--p-inline) * -1);

        padding-block: 80px;
    }

    .sub-btn {
        padding: 11px 24px;

        font-size: 0;

        gap: 0;
    }

    .sub-btn:before {
        content: "";

        display: block;

        width: 20px;

        height: 20px;

        background-image: url("../images/general/icon/send-icon.svg");

        background-size: 100% auto;

        background-position: center center;

        background-repeat: no-repeat;
    }

    .header-logo {
        max-width: 120px;
    }

    .header-phone {
        padding: 12px;

        font-size: 0;

        gap: 0;
    }

    .header-phone:before {
        content: "";

        display: block;

        width: 20px;

        height: 20px;

        background-image: url("../images/general/icon/phone-icon.svg");

        background-size: 100% auto;

        background-position: center center;

        background-repeat: no-repeat;
    }

    .footer-contact {
        grid-template-columns: 1fr;
    }

    .modal-content {
        padding: 64px 16px 16px;
    }

    .modal-close-btn {
        top: 16px;

        right: 16px;
    }

    .modal-img {
        max-width: 200px;
    }

    .modal-text {
        max-width: 310px;
    }

    .modal-btn {
        width: 100%;
    }

    .wpcf7-response-output {
        grid-column: 1 / span 1;
        margin: 0 !important;
    }
}

@media (hover: hover) {
    .btn-icon.green:hover,
    .btn-icon.green:focus {
        background-color: var(--acc-d-green);
    }

    .btn-icon.border:hover,
    .btn-icon.border:focus {
        background-color: var(--acc-l-green);

        border-color: transparent;
    }

    .btn-icon.border:hover svg,
    .btn-icon.border:focus svg {
        fill: var(--acc-d-green);

        opacity: 1;
    }

    @supports selector(*:focus-visible) {
        .btn-icon.green:focus {
            background-color: var(--acc-green);
        }

        .btn-icon.green:hover,
        .btn-icon.green:focus-visible {
            background-color: var(--acc-d-green);
        }

        .btn-icon.border:focus {
            background-color: transparent;

            border-color: rgba(255, 255, 255, 0.7);
        }

        .btn-icon.border:focus svg {
            fill: var(--clr-white);

            opacity: 0.7;
        }

        .btn-icon.border:hover,
        .btn-icon.border:focus-visible {
            background-color: var(--acc-l-green);

            border-color: transparent;
        }

        .btn-icon.border:hover svg,
        .btn-icon.border:focus-visible svg {
            fill: var(--acc-d-green);

            opacity: 1;
        }
    }

    .header-nav-dd:hover .header-nav-dd-container,
    .header-nav-dd:focus-within .header-nav-dd-container {
        visibility: visible;

        pointer-events: all;

        transform: translateY(0);

        opacity: 1;
    }

    .footer-link:not(.big):hover span,
    .footer-link:not(.big):focus span {
        transform: translateX(15px);
    }
}

@media (hover: none) {
    .header-nav-dd-btn {
        display: block;
    }
}

.status {
    max-width: 650px;

    display: block;

    margin: 0 auto;
}

.cookie-banner {
    position: fixed;

    background: #fffefb;

    border: 1px solid #bcdad3;

    border-radius: 30px;

    padding: 40px;

    z-index: 5;

    bottom: 20px;

    right: 135px;

    display: flex;

    flex-direction: column;

    gap: 30px;

    font-weight: 400;

    font-size: 16px;

    line-height: 150%;

    letter-spacing: 0.03em;

    color: #333333;

    max-width: 588px;
}

.cookie-banner > a {
    background: #06705d;

    border-radius: 13px;

    font-weight: 700;

    font-size: 18px;

    line-height: 25px;

    color: #ffffff;

    display: flex;

    justify-content: center;

    align-items: center;

    padding: 16px;

    transition: all 0.5s ease;
}

.cookie-banner > a:hover {
    transition: all 0.5s ease;

    background: #024b3e;
}

.cookie-banner p a {
    color: #06705d;

    transition: all 0.5s ease;
}

.cookie-banner p a:hover {
    color: #024b3e;

    transition: all 0.5s ease;
}

@media (max-width: 992px) {
    .cookie-banner {
        padding: 24px;

        right: 16px;

        gap: 16px;

        max-width: none;

        margin-left: 16px;
    }
}

@media (max-width: 768px) {
    .cookie-banner {
        font-size: 14px;

        line-height: 20px;
    }
}
