@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');
@font-face {
    font-family: "Actay";
    src: url("../fonts/Actay-Regular.otf") format("opentype");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Actay";
    src: url("../fonts/Actay-RegularItalic.otf") format("opentype");
    font-weight: 400;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: "Actay Wide";
    src: url("../fonts/ActayWide-Bold.otf") format("opentype");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Actay Wide";
    src: url("../fonts/ActayWide-BoldItalic.otf") format("opentype");
    font-weight: 700;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: "Actay Condensed";
    src: url("../fonts/ActayCondensed-Thin.otf") format("opentype");
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Actay Condensed";
    src: url("../fonts/ActayCondensed-ThinItalic.otf") format("opentype");
    font-weight: 100;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: "HS LunaObscura";
    src: url("../fonts/HS_LunaObscura.woff2") format("woff2"),
         url("../fonts/HS_LunaObscura.otf") format("opentype"),
         url("../fonts/HS_LunaObscura.ttf") format("truetype");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

:root {
    --main-blue: #0f324c;
    --accent-orange: #f75f17;
    --neutral-dark: #212529;
    --pure-white: #fff;
    --orange-dark: #e05412;
}
:root {
    --font-family: "Actay", Arial, sans-serif;
    --second-family: "Actay Wide", Arial, sans-serif;
    --third-family: "HS LunaObscura", Arial, sans-serif;
    --font5: "Montserrat", Arial, sans-serif;
}
body {
    font-family: var(--font-family);
}
.text-brand { color: var(--brand-blue); }
.text-dark { color: var(--dark-blue); }
.text-light { color: var(--light-blue); }
.bg-brand { background: var(--brand-blue); }
.bg-dark { background: var(--dark-blue); }
.bg-light { background: var(--light-blue); }
.btn-primary {
    background: var(--brand-blue);
    color: #fff;
}
.btn-primary:hover {
    background: var(--hover-blue);
}
.btn-danger {
    background: var(--hover-red);
    color: #fff;
}
.overlay {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 4999;
    background: rgba(0,0,0,0.55);
    display: none;
}
.content_inject {
    width: 447px;
    max-width: calc(100% - 32px);
    max-height: calc(100% - 32px);
    background: #fff;
    margin: auto;
    box-shadow: 0 0 3px #aaa;
    bottom: 0;
    top: 0;
    right: 0;
    left: 0;
    position: fixed;
    display: none;
    overflow: auto;
    z-index: 5000;
}
.tnx {
    width: 40px;
    height: 40px;
    background: url("/images/tnx.svg");
    margin-bottom: 22px;
}
.content_inject--success {
    width: 407px;
    height: 250px;
}
.content_inject_default {
    padding: 24px;
}
.content_inject_close {
    position: absolute;
    right: 24px;
    top: 31px;
    z-index: 2;
    width: 24px;
    height: 24px;
    border: 0;
    padding: 0;
    background: transparent;
    cursor: pointer;
}
.content_inject_close::before,
.content_inject_close::after {
    content: "";
    position: absolute;
    left: 11px;
    top: 2px;
    width: 2px;
    height: 26px;
    background: var(--main-blue);
    transform: rotate(45deg);
}
.content_inject_close::after {
    transform: rotate(-45deg);
}
.order-form {
    color: var(--neutral-dark);
}
.order-form__title {
    max-width: 320px;
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 30px;
    line-height: 36px;
}
.order-form__manager {
    display: grid;
    grid-template-columns: 76px 1fr;
    gap: 18px;
    align-items: start;
    margin-top: 24px;
}
.order-form__manager img {
    width: 76px;
    height: 88px;
    object-fit: cover;
}
.order-form__manager h3 {
    color: var(--neutral-dark);
    font-family: var(--second-family);
    font-size: 18px;
    line-height: 22px;
}
.order-form__manager strong {
    display: block;
    margin-top: 8px;
    font-weight: 400;
    font-size: 13px;
    line-height: 16px;
}
.order-form__manager p {
    margin-top: 14px;
    font-size: 13px;
    line-height: 16px;
}
.order-form__fields {
    margin-top: 22px;
}
.order-form__field {
    display: block;
}
.order-form__field + .order-form__field {
    margin-top: 18px;
}
.order-form__field span {
    display: block;
    margin-bottom: 8px;
    font-size: 13px;
    line-height: 16px;
}
.order-form .nc-field {
    margin: 0;
}
.order-form input[type="text"],
.order-form input[type="tel"],
.order-form input[type="email"],
.order-form textarea {
    display: block;
    width: 100%;
    border: 1px solid rgba(15, 50, 76, .38);
    border-radius: 3px;
    background: var(--pure-white);
    color: var(--neutral-dark);
    font-family: var(--font-family);
    font-size: 15px;
    line-height: 20px;
}
.order-form input[type="text"],
.order-form input[type="tel"],
.order-form input[type="email"] {
    height: 44px;
    padding: 0 22px;
}
.order-form textarea {
    min-height: 149px;
    padding: 12px;
    resize: vertical;
}
.order-form input::placeholder,
.order-form textarea::placeholder {
    color: #a7b7c8;
    opacity: 1;
}
.order-form input:hover,
.order-form textarea:hover,
.order-form input:focus,
.order-form textarea:focus {
    border-color: var(--accent-orange);
    outline: none;
}
.order-form input:focus,
.order-form textarea:focus {
    box-shadow: 0 0 0 2px rgba(247, 95, 23, .14);
}
.order-form__policy {
    display: grid;
    grid-template-columns: 16px 1fr;
    gap: 8px;
    align-items: start;
    margin-top: 16px;
    font-size: 13px;
    line-height: 16px;
}
.order-form__policy input {
    width: 16px;
    height: 16px;
    margin: 0;
    accent-color: var(--accent-orange);
}
.order-form__policy a {
    color: var(--accent-orange);
}
.order-form__submit {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 48px;
    margin-top: 18px;
    border: 0;
    border-radius: 4px;
    background: var(--accent-orange);
    color: var(--pure-white);
    cursor: pointer;
    font-family: var(--second-family);
    font-size: 14px;
    line-height: 16px;
    transition: background .2s ease;
}
.order-form__submit:hover {
    background: var(--orange-dark);
}
.order-form__submit:disabled {
    opacity: .72;
    cursor: default;
}
.order-form__call {
    margin-top: 26px;
    text-align: center;
}
.order-form__call span {
    display: block;
    font-size: 14px;
    line-height: 18px;
}
.order-form__call a {
    display: block;
    margin-top: 12px;
    color: #000;
    font-family: var(--font5);
    font-weight: 600;
    font-size: 21px;
    line-height: 24px;
}
.order-form__call small {
    display: block;
    margin-top: 12px;
    font-size: 14px;
    line-height: 18px;
}
.order-success {
    padding: 34px 0 10px;
    color: var(--neutral-dark);
    text-align: center;
}
.order-success__title {
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 30px;
    line-height: 36px;
    text-align: left;
}
.order-success__text {
    margin-top: 22px;
    font-size: 15px;
    line-height: 22px;
    text-align: left;
}
.order-success__call {
    margin-top: 34px;
}
.order-success__call span {
    display: block;
    font-size: 14px;
    line-height: 18px;
}
.order-success__call a {
    display: block;
    margin-top: 12px;
    color: #000;
    font-family: var(--second-family);
    font-size: 21px;
    line-height: 24px;
}
.order-success__call small {
    display: block;
    margin-top: 12px;
    font-size: 14px;
    line-height: 18px;
}
.cookies {
    background: #fff;
    position: fixed;
    z-index: 950;
    bottom: 24px;
    left: 0;
    right: 0;
    width: calc(100% - 40px);
    max-width: 1137px;
    box-shadow: none;
}
.cookies-close {
    background: url(/images/close.png);
    width: 14px;
    height: 14px;
    position: absolute;
    right: 16px;
    top: 16px;
    cursor: pointer;
    display: none;
}
.cookies-grid {
    padding: 24px;
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
}
.cookies-text {
    color: var(--neutral-dark);
    font-size: 14px;
    line-height: 20px;
}
.cookies-text a {
    color: var(--accent-orange);
}
.cookies-text a:hover {
    color: var(--orange-dark);
}
.cookies-agree {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 102px;
    min-height: 48px;
    border-radius: 4px;
    padding: 16px;
    background: var(--accent-orange);
    cursor: pointer;
    color: var(--pure-white);
    font-family: var(--second-family);
    font-size: 14px;
    font-weight: 700;
    line-height: 16px;
    transition: background .2s ease;
}
.cookies-agree:hover {
    background: var(--orange-dark);
}

@media (max-width: 849px) {
    .content_inject {
        width: calc(100% - 32px);
        height: auto;
        max-height: calc(100% - 32px);
        overflow: auto;
    }

    .content_inject_default {
        padding: 32px 20px 20px;
    }

    .content_inject_close {
        right: 16px;
        top: 16px;
    }

    .cookies {
        right: auto;
        bottom: 20px;
        left: 20px;
        width: min(367px, calc(100% - 40px));
    }

    .cookies-grid {
        grid-template-columns: 1fr;
        gap: 20px;
        padding: 24px;
    }

    .cookies-agree {
        width: auto;
        justify-self: start;
    }
}

:root {
    --accent-orange: #f75f17;
    --orange-dark: #e05412;
    --main-blue: #0f324c;
    --neutral-dark: #212529;
    --pale-blue: #edf6ff;
    --border-blue: #c5d1db;
    --pure-white: #fff;
}

html {
    scroll-behavior: smooth;
}

body {
    min-width: 320px;
    color: var(--neutral-dark);
    font-family: var(--font-family);
    font-weight: 400;
    font-size: var(--fs16);
    line-height: 1.25;
}

body.menu-open {
    overflow: hidden;
}

a {
    text-decoration: none;
}

h1,
h2,
h3,
p {
    margin: 0;
}

h1,
h2,
h3,
.btn-main,
.header__phone,
.mobile-menu__phone,
.contact-cta__phone a,
.geo__facts strong {
    font-family: var(--font5);
    font-weight: 700;
}

.container {
    max-width: 1180px;
    padding-left: 0;
    padding-right: 0;
}

.link-accent {
    color: var(--accent-orange);
}

.btn {
    min-height: 48px;
    border-radius: 4px;
    padding: 16px;
    font-size: 14px;
    line-height: 15px;
    transition: background .2s ease, color .2s ease, border-color .2s ease;
}

.btn-main {
    min-width: 137px;
    color: var(--pure-white);
}

.btn-primary {
    background: var(--accent-orange);
}

.btn-primary:hover {
    background: var(--orange-dark);
}

.btn-secondary {
    border: 1px solid var(--main-blue);
    background: var(--pure-white);
    color: var(--main-blue);
    font-family: var(--second-family);
    font-weight: 700;
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 900;
    background: var(--pure-white);
}

.header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 30px;
    min-height: 104px;
}

.logo {
    display: grid;
    flex: 0 0 auto;
    justify-items: center;
    width: 112px;
    color: var(--main-blue);
}

.logo__image {
    width: 104px;
    height: auto;
}

.logo__image--light {
    display: none;
}

.logo__caption {
    margin-top: -2px;
    font-family: var(--third-family);
    font-size: 13px;
    line-height: 14px;
    display: none;
}

.header__descriptor {
    width: 176px;
    margin-left: -10px;
    font-size: 12px;
    line-height: 14px;
}

.header__nav {
    display: flex;
    gap: 24px;
    align-items: center;
    margin-right: auto;
    font-size: 14px;
    line-height: 16px;
    white-space: nowrap;
}

.header__nav-item {
    position: relative;
}

.header__nav-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    min-height: 52px;
    padding: 0 16px;
    white-space: nowrap;
}

.header__nav-item:has(.header-submenu) > .header__nav-link::after {
    content: "";
    flex: 0 0 auto;
    width: 6px;
    height: 6px;
    margin-top: -3px;
    border-right: 1px solid currentColor;
    border-bottom: 1px solid currentColor;
    transform: rotate(45deg);
}

.header-submenu {
    position: absolute;
    left: 0;
    top: 100%;
    z-index: 30;
    min-width: 320px;
    padding: 18px 12px;
    background: #E5F5FF;
    color: var(--neutral-dark);
    opacity: 0;
    pointer-events: none;
    transform: translateY(8px);
    transition: opacity .18s ease, transform .18s ease;
}

.header-submenu::before {
    display: none;
}

.header-submenu a {
    display: block;
    padding: 9px 12px;
    font-size: 14px;
    line-height: 18px;
    white-space: nowrap;
}

.header__nav-item.is-open > .header__nav-link,
.header__nav-item:has(.header-submenu):hover > .header__nav-link,
.header__nav-item:has(.header-submenu):focus-within > .header__nav-link,
.header-submenu a:hover {
    background: #E5F5FF;
}

.header__nav-item.is-open .header-submenu,
.header__nav-item:has(.header-submenu):hover .header-submenu,
.header__nav-item:has(.header-submenu):focus-within .header-submenu {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.header__nav-item.is-open > .header__nav-link::after,
.header__nav-item:has(.header-submenu):hover > .header__nav-link::after,
.header__nav-item:has(.header-submenu):focus-within > .header__nav-link::after {
    margin-top: 3px;
    transform: rotate(225deg);
}

.header__nav a:hover,
.footer__col a:hover,
.link-accent:hover {
    color: var(--orange-dark);
}

.header__nav-link.active {
    position: relative;
    color: var(--accent-orange);
}

.header__nav-link.active::before {
    content: "";
    position: absolute;
    left: 16px;
    right: 0;
    bottom: 8px;
    height: 4px;
    background: var(--accent-orange);
    width: calc(100% - 32px);
}

.header__contacts {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
    font-size: 14px;
    white-space: nowrap;
}

.header__phone {
    color: var(--neutral-dark);
    font-size: 18px;
    line-height: 16px;
}

.menu-toggle {
    display: none;
    position: relative;
    z-index: 1002;
    width: 26px;
    height: 20px;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.menu-toggle span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background: var(--neutral-dark);
    transition: transform .2s ease, top .2s ease, opacity .2s ease, background .2s ease;
}

.menu-toggle span:nth-child(1) { top: 1px; }
.menu-toggle span:nth-child(2) { top: 9px; }
.menu-toggle span:nth-child(3) { top: 17px; }

.menu-open .menu-toggle span {
    background: var(--accent-orange);
}

.menu-open .menu-toggle span:nth-child(1) {
    top: 9px;
    transform: rotate(45deg);
}

.menu-open .menu-toggle span:nth-child(2) {
    opacity: 0;
}

.menu-open .menu-toggle span:nth-child(3) {
    top: 9px;
    transform: rotate(-45deg);
}

.mobile-menu {
    display: none;
}

.hero {
    position: relative;
    overflow: hidden;
    background: var(--neutral-dark);
    color: var(--pure-white);
}

.hero-swiper,
.hero-slide {
    min-height: 500px;
}

.hero-swiper {
    width: 100%;
}

.hero-slide {
    position: relative;
    overflow: hidden;
}

.hero-slide::before {
    content: "";
    position: absolute;
    inset: -56px auto auto -449px;
    width: 1320px;
    height: 616px;
    background: url("../images/hero-pattern.svg") center / contain no-repeat;
    opacity: .42;
    z-index: 1;
}

.hero-slide__media {
    position: absolute;
    inset: 0 0 0 50.5%;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

.hero__inner {
    position: relative;
    z-index: 2;
    min-height: 500px;
    display: flex;
    padding-top: 70px;
}

.hero__content {
    width: 540px;
    padding-top: 0;
}

.hero h1 {
    font-size: 37px;
    line-height: 48px;
}

.hero p {
    margin-top: 16px;
    font-size: 16px;
    line-height: 24px;
}

.hero__actions {
    display: flex;
    gap: 16px;
    margin-top: 24px;
}

.hero__pagination-wrap {
    position: absolute;
    left: 50%;
    bottom: 35px;
    z-index: 5;
    transform: translateX(-50%);
    pointer-events: none;
}

.hero-pagination {
    display: flex;
    gap: 24px;
    width: auto !important;
    pointer-events: auto;
}

.hero-pagination .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
    margin: 0 !important;
    border-radius: 50%;
    background: var(--pure-white);
    opacity: .45;
}

.hero-pagination .swiper-pagination-bullet-active {
    background: var(--accent-orange);
    opacity: 1;
}

.hero__nav {
    position: absolute;
    left: 50%;
    top: 0;
    z-index: 6;
    height: 100%;
    transform: translateX(-50%);
    pointer-events: none;
}

.hero-arrow {
    position: absolute;
    top: 50%;
    width: 40px;
    height: 40px;
    border: 1px solid rgba(255, 255, 255, .35);
    border-radius: 50%;
    background: rgba(33, 37, 41, .35);
    cursor: pointer;
    opacity: 0;
    pointer-events: auto;
    transition: opacity .2s ease, background .2s ease;
}

.hero:hover .hero-arrow {
    opacity: 1;
}

.hero-arrow:hover {
    background: rgba(247, 95, 23, .9);
}

.hero-arrow::before {
    content: "";
    position: absolute;
    left: 15px;
    top: 13px;
    width: 10px;
    height: 10px;
    border-top: 2px solid var(--pure-white);
    border-right: 2px solid var(--pure-white);
}

.hero-arrow--prev {
    left: -72px;
}

.hero-arrow--prev::before {
    transform: rotate(-135deg);
}

.hero-arrow--next {
    right: -72px;
}

.hero-arrow--next::before {
    left: 12px;
    transform: rotate(45deg);
}

.section {
    padding: 64px 0 80px;
}

.section h2,
.contact-cta h2 {
    color: var(--main-blue);
    font-size: 32px;
    line-height: 40px;
}

.catalog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-top: 32px;
}

.catalog-card,
.project-card {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--border-blue);
    background: var(--pure-white);
    color: var(--neutral-dark);
    transition: border-color .2s ease, transform .2s ease;
}

.catalog-card:hover,
.project-card:hover {
    border-color: var(--accent-orange);
    transform: translateY(-2px);
}

.catalog-card img {
    width: 100%;
    height: 167px;
    object-fit: cover;
}

.catalog-card__body {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 16px;
    min-height: 254px;
    padding: 24px;
}

.catalog-card strong {
    color: #000;
    font-family: var(--second-family);
    font-size: 24px;
    line-height: 32px;
}

.catalog-card span span {
    font-size: 16px;
    line-height: 20px;
}

.catalog-card em,
.footer__col .link-accent,
.project-card em {
    margin-top: auto;
    color: var(--accent-orange);
    font-style: normal;
    font-size: 14px;
    line-height: 20px;
}

.catalog-card em::after,
.footer__col .link-accent::after {
    content: "›";
    margin-left: 8px;
}

.section-why {
    background: var(--pale-blue);
}

.why-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 48px 180px;
    margin-top: 48px;
}

.why-item {
    max-width: 510px;
}

.why-item img {
    width: 64px;
    height: 64px;
    object-fit: contain;
    margin-bottom: 16px;
}

.why-item h3 {
    color: var(--neutral-dark);
    font-size: 24px;
    line-height: 32px;
}

.why-item p {
    margin-top: 16px;
    font-size: 16px;
    line-height: 20px;
}

.projects-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-top: 32px;
}

.project-card img {
    width: 100%;
    height: 167px;
    object-fit: cover;
}

.project-card span {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-height: 95px;
    padding: 16px;
}

.project-card strong {
    color: #000;
    font-family: var(--second-family);
    font-size: 16px;
    line-height: 20px;
}

.project-card em {
    color: var(--neutral-dark);
    font-size: 13px;
}

.projects__button {
    display: flex;
    justify-content: center;
    margin-top: 32px;
}

.geo {
    overflow: hidden;
    background: var(--main-blue);
    color: var(--pure-white);
}

.geo__inner {
    position: relative;
    min-height: 645px;
    padding-top: 80px;
    padding-bottom: 80px;
}

.geo__text {
    position: relative;
    z-index: 2;
    width: 380px;
}

.geo h2 {
    font-size: 32px;
    line-height: 40px;
}

.geo__text p {
    margin-top: 32px;
    font-size: 16px;
    line-height: 20px;
}

.geo__map-scroll {
    position: absolute;
    left: 50%;
    top: 0;
    width: 1250px;
    height: 603px;
    transform: translateX(-50%);
    overflow: visible;
}

.geo__map {
    width: 1250px;
    height: 603px;
    max-width: none;
    object-fit: contain;
    opacity: .95;
}

.geo__facts {
    position: absolute;
    right: 0;
    top: 70px;
    display: flex;
    flex-direction: column;
    gap: 32px;
    width: 300px;
    z-index: 2;
}

.geo__facts article {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.geo__facts strong {
    margin-bottom: -8px;
    color: var(--accent-orange);
    font-size: 48px;
    line-height: 56px;
}

.geo__facts span {
    color: var(--accent-orange);
    font-family: var(--second-family);
    font-size: 20px;
    font-weight: 700;
    line-height: 16px;
}

.geo__facts p {
    font-size: 14px;
    line-height: 16px;
}

.clients {
    padding-top: 80px;
    padding-bottom: 80px;
}

.clients__grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 20px;
    margin-top: 32px;
}

.clients-swiper {
    margin-top: 32px;
    overflow: hidden;
}

.clients-swiper .clients__grid {
    display: flex;
    gap: 0;
    margin-top: 0;
    transition-timing-function: linear;
}

.clients-swiper .swiper-slide {
    height: auto;
}

.client-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 95px;
    background: var(--pure-white);
}

.client-logo img {
    max-width: 86%;
    max-height: 104px;
    filter: grayscale(1);
    opacity: .55;
    object-fit: contain;
    transition: filter .2s ease, opacity .2s ease, transform .2s ease;
}

.client-logo:hover img {
    filter: grayscale(0);
    opacity: 1;
    transform: translateY(-2px);
}

.client-logo span {
    color: rgba(33, 37, 41, .42);
    font-family: var(--second-family);
    font-size: 18px;
    font-weight: 700;
    line-height: 24px;
    text-align: center;
    text-transform: uppercase;
}

.contact-cta {
    position: relative;
    overflow: hidden;
    background: var(--pale-blue);
}

.contact-cta::before {
    content: "";
    position: absolute;
    left: -285px;
    top: -266px;
    width: 1294px;
    height: 649px;
    background: url("../images/blue-pattern.svg") center / contain no-repeat;
    opacity: .1;
}

.contact-cta__inner {
    position: relative;
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: 36px;
    min-height: 191px;
}

.contact-cta p {
    margin-top: 16px;
    font-size: 16px;
    line-height: 20px;
    font-family: var(--font-family);
    font-weight: 400;
}

.contact-cta__phone {
    text-align: right;
}

.contact-cta__phone a {
    display: block;
    color: var(--main-blue);
    font-size: 30px;
    line-height: 32px;
}

.contact-cta__phone p {
    margin-top: 8px;
}

.contact-cta--dark {
    background: var(--main-blue);
    color: var(--pure-white);
}

.contact-cta--dark::before {
    opacity: .18;
}

.contact-cta--dark h2,
.contact-cta--dark p,
.contact-cta--dark .contact-cta__phone a {
    color: var(--pure-white);
}

.site-footer {
    background: var(--neutral-dark);
    color: var(--pure-white);
}

.footer__main {
    position: relative;
    display: grid;
    grid-template-columns: 280px 202px 256px 1fr;
    gap: 23px;
    min-height: 250px;
    padding-top: 60px;
}

.footer__col {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
}

.footer__col h2 {
    margin-bottom: 11px;
    color: var(--pure-white);
    font-family: var(--second-family);
    font-size: 24px;
    line-height: 32px;
}

.footer__col a,
.footer__col p {
    color: rgba(255, 255, 255, .5);
    font-size: 14px;
    line-height: 20px;
}

.footer__contacts {
    gap: 16px;
}

.footer__contacts a {
    color: var(--pure-white);
    font-family: var(--font5);
}
.footer__contacts p {
    font-family: var(--font5);
}
.footer__contacts .link-accent,
.footer__col .link-accent {
    color: var(--accent-orange);
}

.footer-logo {
    justify-self: end;
    align-self: start;
    display: grid;
    justify-items: center;
    width: 187px;

    color: var(--pure-white);
}

.footer-logo img {
    width: 187px;
}

.footer-logo span {
    font-family: var(--third-family);
    font-size: 21px;
    line-height: 24px;
}

.footer__bottom {
    border-top: 1px solid rgba(255, 255, 255, .3);
    margin-top: 35px;
}

.footer__bottom-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 72px;
    font-size: 14px;
    line-height: 20px;
}

.footer__bottom p {
    opacity: .5;
}

.page-index1 .header__nav {
    gap: 20px;
}

.page-index1 .footer__main {
    grid-template-columns: 280px 202px 263px 256px;
    justify-content: space-between;
}

.catalog-page {
    padding: 70px 0 80px;
}

.breadcrumbs {
    display: flex;
    align-items: center;
    gap: 8px;
    color: rgba(33, 37, 41, .42);
    font-size: 14px;
    line-height: 20px;
}

.breadcrumbs a,
.breadcrumbs span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.breadcrumbs a::before,
.breadcrumbs span::before {
    content: "";
    width: 6px;
    height: 6px;
    border-left: 1px solid currentColor;
    border-bottom: 1px solid currentColor;
    transform: rotate(45deg);
}

.catalog-page__head {
    width: 780px;
    max-width: 100%;
    margin-top: 44px;
}

.catalog-page__head h1 {
    color: var(--main-blue);
    font-size: 40px;
    line-height: 48px;
}

.catalog-page__head p {
    margin-top: 40px;
    color: var(--neutral-dark);
    font-size: 18px;
    line-height: 24px;
}

.catalog-page__grid {
    margin-top: 40px;
}

.page-catalog .catalog-card img {
    height: 167px;
}

.page-catalog .catalog-card__body {
    min-height: 254px;
}

.projects-page {
    padding: 70px 0 96px;
}

.projects-page__head {
    margin-top: 36px;
}

.projects-page__head p {
    width: 760px;
}

.project-filters {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    margin-top: 32px;
}

.project-filters strong {
    flex: 0 0 auto;
    padding-top: 8px;
    color: #000;
    font-family: var(--second-family);
    font-size: 16px;
    line-height: 20px;
}

.project-filters__list {
    display: flex;
    display: none;
    flex-wrap: wrap;
    gap: 8px;
}

.project-filters button {
    min-height: 32px;
    border: 1px solid var(--border-blue);
    border-radius: 0;
    padding: 7px 12px;
    background: var(--pure-white);
    color: rgba(33, 37, 41, .5);
    cursor: pointer;
    font-family: var(--font-family);
    font-size: 13px;
    line-height: 16px;
}

.project-filters button.active {
    border-color: var(--accent-orange);
    background: var(--accent-orange);
    color: var(--pure-white);
}

.projects-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-top: 40px;
}

.project-list-card {
    display: flex;
    flex-direction: column;
    min-height: 298px;
    border: 1px solid var(--border-blue);
    background: var(--pure-white);
    color: var(--neutral-dark);
    transition: border-color .2s ease, transform .2s ease;
}

.project-list-card:hover {
    border-color: var(--accent-orange);
    transform: translateY(-2px);
}

.project-list-card img {
    width: 100%;
    height: 172px;
    object-fit: cover;
}

.project-list-card span {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 24px;
}

.project-list-card strong {
    color: #000;
    font-family: var(--second-family);
    font-size: 20px;
    line-height: 28px;
}

.project-list-card em {
    color: var(--neutral-dark);
    font-style: normal;
    font-size: 14px;
    line-height: 20px;
}

.pagination {
    display: flex;
    align-items: center;
    gap: 24px;
    margin-top: 40px;
}

.pagination a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    color: rgba(33, 37, 41, .32);
    font-size: 14px;
    line-height: 20px;
}

.pagination a.active {
    background: var(--accent-orange);
    color: var(--pure-white);
}

.product-hero {
    display: grid;
    grid-template-columns: minmax(0, 57.5%) minmax(420px, 42.5%);
    min-height: 500px;
}

.product-hero__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.product-hero__info {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    padding: 48px 112px 48px 32px;
    background: var(--pale-blue);
}

.product-hero__info .breadcrumbs {
    margin-bottom: 24px;
}

.product-hero h1 {
    color: var(--main-blue);
    font-size: 40px;
    line-height: 48px;
}

.product-hero p {
    margin-top: 28px;
    max-width: 455px;
    font-size: 16px;
    line-height: 22px;
}

.product-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 36px;
    margin-top: 36px;
    max-width: 510px;
}

.product-stats article {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.product-stats strong {
    font-family: var(--font5);
    font-weight: 600;
    font-size: 32px;
    line-height: 175%;
    color: var(--main-blue);
}
.product-stats strong b {
    font-weight: 600;
    font-size: 16px;
    line-height: 16px;
}
.product-stats span {
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 14px;
    line-height: 18px;
}

.product-hero .btn {
    margin-top: 32px;
}

.product-content {
    padding: 80px 0 96px;
}

.product-content__grid {
    display: grid;
    grid-template-columns: minmax(0, 680px) 445px;
    gap: 76px;
    align-items: start;
}

.product-copy {
    display: flex;
    flex-direction: column;
    gap: 56px;
}

.product-copy h2,
.related-projects h2 {
    color: var(--main-blue);
    font-size: 32px;
    line-height: 40px;
}

.product-copy p,
.product-copy li {
    font-size: 16px;
    line-height: 20px;
}

.product-copy p:first-of-type,
.product-copy ul {
    margin-top: 32px;
}

.product-copy p + p {
    margin-top: 0;
}

.product-copy ul {
    padding-left: 20px;
}

.product-side {
    display: flex;
    flex-direction: column;
    gap: 48px;
}

.spec-card {
    padding: 32px;
    background: var(--pale-blue);
}

.spec-card h2 {
    margin-bottom: 28px;
    color: var(--main-blue);
    font-size: 24px;
    line-height: 32px;
}

.spec-card div {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    padding: 10px 0;
    border-bottom: 1px dashed rgba(15, 50, 76, .18);
    font-size: 14px;
    line-height: 18px;
}

.spec-card div:last-child {
    border-bottom: 0;
}

.spec-card span {
    color: rgba(33, 37, 41, .58);
}

.spec-card strong {
    color: var(--neutral-dark);
    font-weight: 400;
}

.expert-card {
    display: grid;
    grid-template-columns: 88px 1fr;
    gap: 18px 20px;
    align-items: start;
    max-width: 420px;
}

.expert-card__photo {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 88px;
    height: 98px;
    background: linear-gradient(180deg, #e8eef4, #b9c5d0);
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 24px;
}

.expert-card__photo-img {
    display: block;
    width: 88px;
    height: 98px;
    object-fit: cover;
}

.expert-card h3 {
    color: var(--neutral-dark);
    font-size: 20px;
    line-height: 22px;
}

.expert-card p {
    margin-top: 10px;
    font-size: 13px;
    line-height: 18px;
}

.expert-card small {
    display: block;
    margin-top: 10px;
    color: rgba(33, 37, 41, .5);
    font-size: 12px;
    line-height: 16px;
}

.expert-card__contacts {
    grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 0;
    padding-right: 170px;
    white-space: nowrap;
}

.expert-card__contacts a {
    color: var(--neutral-dark);
    font-family: var(--font5);
    font-size: 16px;
    line-height: 20px;
    font-weight: 600;
}

.expert-card .btn {
    grid-column: 1 / -1;
    align-self: start;
    justify-self: end;
    min-width: 136px;
    margin-top: -70px;
}

.related-projects {
    position: relative;
    overflow: hidden;
    padding: 80px 0 96px;
    background: var(--pale-blue);
}

.related-projects__wrap {
    position: relative;
    margin-top: 40px;
}

.related-projects-swiper {
    overflow: hidden;
}

.related-projects-swiper .swiper-wrapper {
    align-items: stretch;
}

.related-projects-swiper .swiper-slide {
    display: flex;
    height: auto;
}

.related-projects .project-list-card {
    flex: 1;
    height: 100%;
}

.related-arrow {
    position: absolute;
    top: 50%;
    z-index: 3;
    width: 32px;
    height: 32px;
    border: 0;
    background: rgba(255, 255, 255, .7);
    cursor: pointer;
    transform: translateY(-50%);
}

.related-arrow::before {
    content: "";
    position: absolute;
    left: 12px;
    top: 10px;
    width: 9px;
    height: 9px;
    border-top: 2px solid rgba(15, 50, 76, .25);
    border-right: 2px solid rgba(15, 50, 76, .25);
}

.related-arrow--prev {
    left: -48px;
}

.related-arrow--prev::before {
    transform: rotate(-135deg);
}

.related-arrow--next {
    right: -48px;
}

.related-arrow--next::before {
    left: 9px;
    transform: rotate(45deg);
}

.vacancies-page {
    padding: 70px 0 80px;
}

.vacancies-page__head {
    margin-top: 36px;
}

.vacancies-page__head p {
    margin-top: 28px;
    font-size: 16px;
    line-height: 20px;
}

.vacancies-list {
    margin-top: 28px;
}

.vacancy {
    background: var(--pale-blue);
    border-top: 8px solid var(--neutral-white);
}

.vacancy:first-child {
    border-top: 0;
}

.vacancy.is-open {
    border: 1px solid var(--neutral-dark);
    background: var(--neutral-white);
}

.vacancy__head {
    position: relative;
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 24px;
    width: 100%;
    min-height: 112px;
    border: 0;
    padding: 24px 56px 24px 32px;
    background: transparent;
    color: var(--neutral-dark);
    text-align: left;
    cursor: pointer;
}

.vacancy__head::after {
    content: "";
    position: absolute;
    right: 32px;
    top: 50%;
    width: 8px;
    height: 8px;
    border-right: 2px solid rgba(33, 37, 41, .35);
    border-bottom: 2px solid rgba(33, 37, 41, .35);
    transform: translateY(-65%) rotate(45deg);
    transition: border-color .2s ease, transform .2s ease;
}

.vacancy.is-open .vacancy__head::after {
    border-color: var(--accent-orange);
    transform: translateY(-35%) rotate(225deg);
}

.vacancy__head strong {
    display: block;
    font-family: var(--second-family);
    font-size: 18px;
    line-height: 24px;
}

.vacancy__head em {
    display: block;
    margin-top: 16px;
    font-size: 14px;
    font-style: normal;
    line-height: 20px;
}

.vacancy__head b {
    padding-right: 12px;
    font-family: var(--second-family);
    font-size: 18px;
    line-height: 24px;
    white-space: nowrap;
}

.vacancy__body {
    display: none;
}

.vacancy.is-open .vacancy__body {
    display: block;
}

.vacancy__content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px 70px;
    min-height: 568px;
    padding: 12px 32px 28px 64px;
}

.vacancy__section h2 {
    margin-bottom: 14px;
    color: var(--neutral-dark);
    font-family: var(--second-family);
    font-size: 16px;
    line-height: 20px;
}

.vacancy__section ul {
    padding-left: 18px;
}

.vacancy__section li {
    font-size: 14px;
    line-height: 17px;
}

.vacancy__section:nth-child(3) {
    grid-column: 1 / 2;
}

.vacancy__content .btn {
    grid-column: 2 / 3;
    align-self: end;
    justify-self: end;
}

.contacts-page {
    padding: 70px 0 80px;
}

.contacts-page h1 {
    margin-top: 44px;
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 40px;
    line-height: 48px;
}

.contacts-page__summary {
    display: grid;
    grid-template-columns: 300px 1fr;
    gap: 116px;
    margin-top: 36px;
}

.contacts-page h2,
.commercial-team h2,
.request-section h2 {
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 30px;
    line-height: 36px;
}

.contacts-page__summary h2,
.contacts-page__aside h2 {
    color: var(--neutral-dark);
    font-size: 20px;
    line-height: 24px;
}

.contacts-page__summary p {
    margin-top: 28px;
    font-size: 16px;
    line-height: 22px;
}

.contacts-page__main {
    display: grid;
    grid-template-columns: minmax(0, 790px) 1fr;
    gap: 72px;
    margin-top: 36px;
}

.contacts-page__map {
    width: 100%;
    height: 487px;
    object-fit: cover;
}

.contacts-page__aside {
    padding-top: 2px;
    font-family: var(--font5);
}

.contacts-page__aside section + section {
    margin-top: 37px;
}

.contacts-page__aside a,
.contacts-page__aside p {
    display: block;
    color: var(--neutral-dark);
    font-size: 16px;
    line-height: 22px;
}
.contacts-page__aside a.btn {
    color: #fff !important;
    display: inline-block;
}
.contacts-page__aside h2 {
    margin-bottom: 24px;
}

.contacts-page__aside .link-accent {
    color: var(--accent-orange);
}

.contacts-page__aside .btn {
    margin-top: 52px;
}

.commercial-team {
    padding: 80px 0;
    background: var(--pale-blue);
}

.commercial-team__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 58px;
    margin-top: 44px;
}

.manager-card {
    display: grid;
    grid-template-columns: 104px 1fr;
    gap: 20px;
    align-items: start;
}

.manager-card img {
    width: 104px;
    height: 118px;
    object-fit: cover;
}

.manager-card h3 {
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 20px;
    line-height: 22px;
}

.manager-card strong {
    display: block;
    margin-top: 10px;
    color: var(--neutral-dark);
    font-size: 14px;
    line-height: 18px;
}

.manager-card p, .manager-card div {
    margin-top: 0;
    color: rgba(33, 37, 41, .45);
    font-size: 14px;
    line-height: 16px;
    font-family: var(--font5);
}

.request-section {
    position: relative;
    overflow: hidden;
    padding: 80px 0 90px;
    background: var(--neutral-white);
}

.request-section::after {
    content: "";
    position: absolute;
    right: -120px;
    bottom: -220px;
    width: 980px;
    height: 620px;
    background: url("../images/hero-pattern.svg") center / contain no-repeat;
    opacity: .09;
    pointer-events: none;
}

.request-section .container {
    position: relative;
    z-index: 1;
}

.request-form {
    display: grid;
    grid-template-columns: 365px 365px;
    gap: 24px;
    margin-top: 48px;
}

.request-form label {
    display: block;
}

.request-form label + label {
    margin-top: 20px;
}

.request-form label > span {
    display: block;
    margin-bottom: 8px;
    font-size: 14px;
    line-height: 18px;
}

.request-form input,
.request-form textarea {
    display: block;
    width: 100%;
    border: 1px solid rgba(15, 50, 76, .28);
    border-radius: 2px;
    background: rgba(255, 255, 255, .9);
    color: var(--neutral-dark);
    font-family: var(--font-family);
    font-size: 15px;
    line-height: 20px;
}

.request-form input {
    height: 47px;
    padding: 0 14px;
}

.request-form textarea {
    min-height: 186px;
    padding: 14px;
    resize: vertical;
}

.request-form input::placeholder,
.request-form textarea::placeholder {
    color: rgba(33, 37, 41, .35);
}

.request-form__policy {
    display: grid !important;
    grid-template-columns: 18px 1fr;
    gap: 8px;
    align-items: start;
    margin-top: 20px;
}

.request-form__policy input {
    width: 16px;
    height: 16px;
    margin-top: 1px;
}

.request-form__policy span {
    margin: 0;
    color: var(--neutral-dark);
    font-size: 14px;
    line-height: 17px;
}

.request-form__policy a {
    color: var(--accent-orange);
}

.request-form .btn {
    margin-top: 28px;
}

.licenses-page {
    padding: 70px 0 144px;
}

.licenses-page h1 {
    margin-top: 44px;
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 40px;
    line-height: 48px;
}

.licenses-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 58px 30px;
    margin-top: 50px;
}

.license-card {
    display: block;
    color: var(--main-blue);
    text-decoration: none;
}

.license-card__image {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 360px;
}

.license-card__image img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.license-card strong {
    display: block;
    margin-top: 18px;
    font-family: var(--second-family);
    font-size: 18px;
    line-height: 24px;
}

.about-hero {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 500px;
    background: var(--neutral-dark);
}

.about-hero__text {
    position: relative;
    overflow: hidden;
    color: var(--pure-white);
}

.about-hero__text::before {
    content: "";
    position: absolute;
    inset: -130px -120px -80px -40px;
    background: url("../images/hero-pattern.svg") center / contain no-repeat;
    opacity: .18;
}

.about-hero__text .container {
    position: relative;
    z-index: 1;
    max-width: 592px;
    margin-right: 0;
    padding-top: 24px;
}

.breadcrumbs--dark {
    color: rgba(255, 255, 255, .45);
}

.about-hero__copy {
    width: 460px;
    max-width: 100%;
    margin-top: 112px;
}

.about-hero h1 {
    color: var(--pure-white);
    font-family: var(--second-family);
    font-size: 40px;
    line-height: 48px;
}

.about-hero p {
    margin-top: 18px;
    color: var(--pure-white);
    font-family: var(--second-family);
    font-size: 24px;
    line-height: 32px;
}

.about-hero p span {
    color: var(--accent-orange);
}

.about-hero__image {
    width: 100%;
    height: 500px;
    object-fit: cover;
}

.about-company {
    padding: 90px 0 82px;
}

.about-company__grid {
    display: grid;
    grid-template-columns: 590px 1fr;
    gap: 64px;
    align-items: start;
}

.about-gallery {
    position: sticky;
    top: 20px;
}

.about-gallery-main {
    overflow: hidden;
}

.about-gallery-main img {
    width: 100%;
    height: 455px;
    object-fit: cover;
}

.about-gallery__thumbs {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 8px;
}

.about-gallery__thumbs img {
    width: 112px;
    height: 70px;
    object-fit: cover;
    opacity: .45;
}

.about-gallery__thumbs img:nth-child(2) {
    opacity: 1;
}

.about-gallery__arrow {
    position: absolute;
    bottom: 24px;
    z-index: 2;
    width: 28px;
    height: 28px;
    border: 0;
    background: rgba(225, 239, 251, .75);
    cursor: pointer;
}

.about-gallery__arrow::before {
    content: "";
    position: absolute;
    left: 11px;
    top: 9px;
    width: 8px;
    height: 8px;
    border-top: 2px solid rgba(15, 50, 76, .22);
    border-right: 2px solid rgba(15, 50, 76, .22);
}

.about-gallery__arrow--prev {
    left: 0;
}

.about-gallery__arrow--prev::before {
    transform: rotate(-135deg);
}

.about-gallery__arrow--next {
    right: 0;
}

.about-gallery__arrow--next::before {
    left: 8px;
    transform: rotate(45deg);
}

.about-company__content h2,
.history h2,
.about-competencies h2,
.about-clients h2,
.standards h2 {
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 30px;
    line-height: 36px;
}

.about-company__content h3 {
    margin-top: 32px;
    color: var(--neutral-dark);
    font-family: var(--second-family);
    font-size: 18px;
    line-height: 24px;
}

.about-company__content ul,
.about-company__content ol {
    margin-top: 16px;
    padding-left: 18px;
}

.about-company__content li {
    font-size: 14px;
    line-height: 18px;
}

.history {
    padding: 0 0 80px;
}

.history__years {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 40px;
    margin-top: 40px;
}

.history__years strong {
    color: var(--accent-orange);
    font-family: var(--second-family);
    font-size: 26px;
    line-height: 32px;
}

.history__years p {
    margin-top: 18px;
    font-size: 14px;
    line-height: 18px;
}

.history__track {
    display: grid;
    grid-template-columns: repeat(16, 1fr);
    gap: 6px;
    margin-top: 40px;
}

.history__track span {
    height: 32px;
    background: var(--pale-blue);
    clip-path: polygon(0 0, calc(100% - 12px) 0, 100% 50%, calc(100% - 12px) 100%, 0 100%, 12px 50%);
}

.history__track span:nth-child(4),
.history__track span:nth-child(5),
.history__track span:nth-child(6),
.history__track span:nth-child(7),
.history__track span:nth-child(8) {
    background: var(--main-blue);
}

.history__track span:nth-child(11),
.history__track span:nth-child(12) {
    background: #f7dcd1;
}

.history__track span:nth-child(13) {
    background: #f3ad96;
}

.history__track span:nth-child(14) {
    background: #f18157;
}

.history__track span:nth-child(n+15) {
    background: var(--accent-orange);
}

.about-competencies {
    padding: 72px 0 78px;
    background: var(--pale-blue);
}

.about-competencies__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 70px;
    margin-top: 44px;
}

.about-competencies img {
    width: 26px;
    height: 26px;
    object-fit: contain;
}

.about-competencies h3 {
    margin-top: 28px;
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 18px;
    line-height: 22px;
}

.about-competencies p {
    margin-top: 14px;
    font-size: 14px;
    line-height: 18px;
}

.about-clients {
    overflow: hidden;
    padding: 72px 0 60px;
}

.about-clients__grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 16px;
    margin-top: 36px;
}

.about-client {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 86px;
    border: 1px solid var(--border-blue);
    background: var(--pure-white);
}

.about-client img {
    max-width: 84%;
    max-height: 58px;
    object-fit: contain;
}

.about-client span {
    max-width: 84%;
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 18px;
    line-height: 20px;
    text-align: center;
    text-transform: uppercase;
}

.standards {
    padding: 0 0 84px;
}

.standards p {
    width: 760px;
    max-width: 100%;
    margin-top: 36px;
    font-size: 16px;
    line-height: 22px;
}

.press-kit-page {
    position: relative;
    overflow: hidden;
    min-height: 720px;
    padding: 70px 0 120px;
    background: var(--neutral-white);
}

.press-kit-page::after {
    content: "";
    position: absolute;
    right: -110px;
    bottom: -155px;
    width: 930px;
    height: 585px;
    background: url("../images/hero-pattern.svg") center / contain no-repeat;
    opacity: .1;
    pointer-events: none;
}

.press-kit-page .container {
    position: relative;
    z-index: 1;
}

.press-kit-page__head {
    margin-top: 44px;
}

.press-kit-page__head h1 {
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 40px;
    line-height: 48px;
}

.press-kit-page__head p {
    margin-top: 36px;
    font-size: 18px;
    line-height: 24px;
}

.press-kit-grid {
    display: grid;
    grid-template-columns: repeat(3, 280px);
    gap: 20px;
    margin-top: 36px;
}

.press-kit-card img {
    width: 280px;
    height: 144px;
    object-fit: cover;
}

.press-kit-card h2 {
    margin-top: 14px;
    color: var(--neutral-dark);
    font-family: var(--second-family);
    font-size: 24px;
    line-height: 30px;
}

.press-kit-card a {
    display: inline-block;
    margin-top: 4px;
    color: var(--accent-orange);
    font-size: 14px;
    line-height: 20px;
}

.project-detail-hero {
    display: grid;
    grid-template-columns: minmax(0, 50%) minmax(420px, 50%);
    min-height: 500px;
}

.project-detail-hero > img {
    width: 100%;
    height: 500px;
    object-fit: cover;
}

.project-detail-hero__info {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 48px 112px 48px 40px;
    background: var(--pale-blue);
}

.project-detail-hero__info .breadcrumbs {
    margin-bottom: 48px;
}

.project-detail-hero h1 {
    max-width: 520px;
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 40px;
    line-height: 48px;
}

.project-detail-hero p {
    max-width: 520px;
    margin-top: 32px;
    font-size: 16px;
    line-height: 22px;
}

.project-detail-content {
    padding: 82px 0 46px;
}

.project-detail-content__grid {
    display: grid;
    grid-template-columns: minmax(0, 680px) 360px;
    gap: 120px;
    align-items: start;
}

.project-detail-copy {
    gap: 58px;
}

.project-detail-expert {
    padding-top: 18px;
}

.expert-card__photo-img {
    width: 88px;
    height: 98px;
    object-fit: cover;
}

.project-detail-gallery {
    padding: 0 0 96px;
}

.project-gallery-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    
}

.project-gallery-grid a {
    display: block;
}

.project-gallery-grid img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
}

.project-spec-card {

    margin-top: 64px;
    padding: 36px 40px;
}

.project-spec-card div {
    grid-template-columns: 1fr 520px;
}

.articles-page {
    padding: 70px 0 80px;
}

.articles-page h1 {
    margin-top: 44px;
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 40px;
    line-height: 48px;
}

.article-years {
    display: flex;
    display: none;
    gap: 14px;
    margin-top: 30px;
}

.article-years button {
    min-width: 52px;
    height: 36px;
    border: 1px solid var(--border-blue);
    background: var(--pure-white);
    color: rgba(33, 37, 41, .4);
    cursor: pointer;
    font-family: var(--font-family);
    font-size: 16px;
    line-height: 20px;
}

.article-years button.active {
    border-color: var(--accent-orange);
    background: var(--accent-orange);
    color: var(--pure-white);
}

.articles-list {
    display: flex;
    flex-direction: column;
    gap: 40px;
    margin-top: 34px;
}

.article-row {
    display: grid;
    grid-template-columns: 350px minmax(0, 1fr);
    gap: 24px;
    max-width: 1060px;
}

.article-row__image img {
    width: 350px;
    height: 216px;
    object-fit: cover;
}

.article-row__body time {
    color: rgba(33, 37, 41, .38);
    font-size: 14px;
    line-height: 20px;
}

.article-row__body h2 {
    margin-top: 12px;
}

.article-row__body h2 a {
    color: #000;
    font-family: var(--second-family);
    font-size: 26px;
    line-height: 32px;
}

.article-row__body p {
    max-width: 760px;
    margin-top: 24px;
    font-size: 18px;
    line-height: 24px;
}

.article-row__more {
    display: inline-block;
    margin-top: 20px;
    color: var(--accent-orange);
    font-size: 15px;
    line-height: 20px;
}

.article-row__more::after {
    content: "";
    display: inline-block;
    width: 7px;
    height: 7px;
    margin-left: 8px;
    border-top: 2px solid currentColor;
    border-right: 2px solid currentColor;
    transform: rotate(45deg);
}

.tenders-page {
    padding: 70px 0 78px;
}

.tenders-page__head {
    margin-top: 44px;
}

.tenders-page__head h1 {
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 40px;
    line-height: 48px;
}

.tenders-page__head p {
    margin-top: 36px;
    font-size: 18px;
    line-height: 24px;
}

.tender-panel {
    display: grid;
    grid-template-columns: 1fr 480px;
    margin-top: 36px;
    background: var(--pale-blue);
}

.tender-panel + .tender-panel {
    grid-template-columns: 480px 1fr;
    margin-top: 32px;
}

.tender-panel__content {
    padding: 38px 32px;
}

.tender-panel h2,
.tender-platforms h2 {
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 32px;
    line-height: 40px;
}

.tender-panel p {
    margin-top: 28px;
    max-width: 620px;
    font-size: 18px;
    line-height: 24px;
}

.tender-panel h3 {
    margin-top: 36px;
    color: var(--neutral-dark);
    font-family: var(--second-family);
    font-size: 24px;
    line-height: 30px;
}

.tender-panel ul {
    margin-top: 22px;
}

.tender-panel li {
    position: relative;
    padding-left: 26px;
    font-size: 18px;
    line-height: 30px;
    list-style: none;
}

.tender-panel li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 10px;
    width: 10px;
    height: 6px;
    border-left: 2px solid var(--accent-orange);
    border-bottom: 2px solid var(--accent-orange);
    transform: rotate(-45deg);
}
.about-company__content li {
    position: relative;
    list-style: none;
    padding-left: 26px;
}
.about-company__content li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 3px;
    width: 10px;
    height: 6px;
    border-left: 2px solid var(--accent-orange);
    border-bottom: 2px solid var(--accent-orange);
    transform: rotate(-45deg);
}
.tender-panel img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.tender-panel .btn {
    margin-top: 34px;
}

.tender-platforms {
    margin-top: 72px;
}

.tender-platforms p {
    margin-top: 34px;


    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    line-height: 125%;
    color: var(--neutral-dark);
}

.tender-platforms img {
    display: block;
    width: 100%;
    max-width: 1180px;
    margin-top: 34px;
}

.tender-platforms img + p {
    margin-top: 30px;
}

.not-found {
    position: relative;
    overflow: hidden;
    min-height: 690px;
    padding: 70px 0 72px;
    background: var(--neutral-white);
}
.bgr {
    position: relative;
    overflow: hidden;
}
.not-found::after, .bgr::after {
    content: "";
    position: absolute;
    right: -82px;
    bottom: -132px;
    width: 1331px;
    height: 750px;
    background: url("/images/404-pattern.png") center / contain no-repeat;

    pointer-events: none;
}

.not-found .container {
    position: relative;
    z-index: 1;
}

.not-found__head {
    margin-top: 42px;
}

.not-found__head h1 {
    max-width: 680px;
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 40px;
    font-weight: 700;
    line-height: 48px;
}

.not-found__head p {
    margin-top: 28px;
    font-size: 16px;
    line-height: 22px;
}

.not-found__code {
    margin-top: 34px;
    color: transparent;
    font-family: var(--second-family);
    font-size: 205px;
    font-weight: 700;
    line-height: 0.92;
    text-align: center;
    -webkit-text-stroke: 1px rgba(31, 36, 40, 0.48);
    text-align: center;
}
.not-found__code img {
    margin: 0 auto;
}

.not-found__links {
    display: grid;
    grid-template-columns: repeat(2, minmax(260px, 1fr));
    gap: 24px 150px;
    width: 720px;
    max-width: 100%;
    margin: 24px auto 0;
}

.not-found__links a {
    display: block;
    color: var(--neutral-dark);
    text-decoration: none;
}

.not-found__links strong {
    display: block;
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 20px;
    font-weight: 700;
    line-height: 24px;
}

.not-found__links span {
    display: block;
    margin-top: 4px;
    font-size: 16px;
    line-height: 21px;
}

.not-found__links a:hover strong,
.not-found__links a.accent strong {
    color: var(--accent-orange);
}

.content_inject_close {
    width: 24px;
    height: 24px;
    border: 0;
    padding: 0;
    background: transparent;
    cursor: pointer;
}

@media (max-width: 1199px) {
    .container {
        max-width: calc(100% - 32px);
    }

    .header__inner {
        gap: 18px;
    }

    .header__nav {
        gap: 16px;
        font-size: 13px;
    }

    .header__contacts,
    .header__inner > .btn-main {
        display: none;
    }

    .catalog-grid,
    .projects-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .why-grid {
        gap: 48px;
    }

    .clients__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 849px) {
    .container {
        max-width: none;
        padding-left: 16px;
        padding-right: 16px;
    }

    .site-header {
        position: sticky;
        background: var(--pure-white);
        transition: background .2s ease;
    }

    .menu-open .site-header {
        background: var(--neutral-dark);
    }

    .header__inner {
        min-height: 80px;
        gap: 16px;
        padding-top: 16px;
        padding-bottom: 16px;
    }

    .logo {
        width: 80px;
    }

    .logo__image {
        width: 74px;
    }

    .logo__caption {
        font-size: 9px;
        line-height: 10px;
    }

    .menu-open .logo {
        color: var(--pure-white);
    }

    .menu-open .logo__image--dark {
        display: none;
    }

    .menu-open .logo__image--light {
        display: block;
    }

    .header__descriptor {
        width: 98px;
        margin-left: 0;
        margin-right: auto;
        font-size: 9px;
        line-height: 12px;
    }

    .menu-open .header__descriptor {
        color: var(--pure-white);
    }

    .header__nav,
    .header__contacts,
    .header__inner > .btn-main {
        display: none;
    }

    .menu-toggle {
        display: block;
    }

    .mobile-menu {
        display: block;
        position: fixed;
        inset: 80px 0 0;
        z-index: 901;
        overflow: hidden;
        background: var(--neutral-dark);
        color: var(--pure-white);
        opacity: 0;
        pointer-events: none;
        transform: translateY(-8px);
        transition: opacity .2s ease, transform .2s ease;
    }

    .menu-open .mobile-menu {
        opacity: 1;
        pointer-events: auto;
        transform: translateY(0);
    }

    .mobile-menu__bg {
        position: absolute;
        left: -449px;
        top: 11px;
        width: 1516px;
        height: 707px;
        background: url("../images/hero-pattern.svg") center / contain no-repeat;
        opacity: .35;
    }

    .mobile-menu__inner {
        position: relative;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        min-height: auto;
        height: calc(100dvh - 80px);
        padding-top: 40px;
        padding-bottom: 40px;
    }

    .mobile-menu__nav {
        display: flex;
        flex-direction: column;
        gap: 12px;
        font-family: var(--second-family);
        font-size: 24px;
        font-weight: 700;
        line-height: 32px;
    }

    .mobile-menu__item {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
    }

    .mobile-menu__link {
        display: inline-flex;
        align-items: center;
        gap: 8px;
    }

    .mobile-menu__item:has(.mobile-submenu) > .mobile-menu__link::after {
        content: "";
        flex: 0 0 auto;
        width: 8px;
        height: 8px;
        margin-top: -4px;
        border-right: 2px solid currentColor;
        border-bottom: 2px solid currentColor;
        transform: rotate(45deg);
        transition: transform .18s ease, margin .18s ease;
    }

    .mobile-menu__item.is-open > .mobile-menu__link::after {
        margin-top: 4px;
        transform: rotate(225deg);
    }

    .mobile-submenu {
        display: none;
        flex-direction: column;
        gap: 8px;
        padding: 10px 0 4px 16px;
        font-family: var(--font-family);
        font-size: 16px;
        font-weight: 400;
        line-height: 22px;
    }

    .mobile-menu__item.is-open .mobile-submenu {
        display: flex;
    }

    .mobile-menu__bottom {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    .mobile-menu__phone {
        color: var(--pure-white);
        font-size: 24px;
        line-height: 32px;
    }

    .mobile-menu__bottom .btn {
        width: 100%;
        margin-top: 24px;
    }

    .hero-swiper,
    .hero-slide {
        min-height: 610px;
    }

    .hero-slide::before {
        inset: 247px auto auto -201px;
        width: 765px;
        height: 360px;
        opacity: .48;
    }

    .hero-slide__media {
        inset: 0 0 auto;
        height: 250px;
        clip-path: none;
    }

    .hero__inner {
        min-height: 610px;
        align-items: flex-end;
        padding-bottom: 40px;
        padding-top: 0;
    }

    .hero__content {
        width: 100%;
        padding-top: 0;
    }

    .hero h1 {
        font-size: 21px;
        line-height: 32px;
    }

    .hero p {
        font-size: 16px;
        line-height: 24px;
    }

    .hero__actions {
        gap: 16px;
        margin-top: 24px;
    }

    .hero__actions .btn {
        flex: 1 1 0;
        min-width: 0;
        padding-left: 10px;
        padding-right: 10px;
        text-align: center;
    }

    .hero__pagination-wrap {
        bottom: 40px;
    }

    .hero__nav {
        display: none;
    }

    .section {
        padding: 40px 0;
    }

    .section h2,
    .contact-cta h2,
    .geo h2 {
        font-size: 20px;
        line-height: 32px;
    }

    .catalog-grid,
    .projects-grid,
    .why-grid {
        grid-template-columns: 1fr;
        gap: 24px;
        margin-top: 24px;
    }

    .catalog-card img,
    .project-card img {
        height: 145px;
    }

    .catalog-card__body {
        min-height: 0;
        gap: 8px;
        padding: 0 16px 24px;
    }

    .catalog-card {
        gap: 24px;
    }

    .catalog-card strong,
    .project-card strong {
        font-size: 16px;
        line-height: 24px;
    }

    .catalog-card span span,
    .why-item p,
    .project-card em {
        font-size: 13px;
        line-height: 20px;
    }

    .why-item img {
        margin-bottom: 16px;
    }

    .why-item h3 {
        font-size: 16px;
        line-height: 24px;
    }

    .projects-grid .project-card:nth-child(n+2) {
        display: none;
    }

    .projects__button {
        margin-top: 32px;
    }

    .geo__inner {
        min-height: 851px;
        padding-top: 40px;
        padding-bottom: 40px;
    }

    .geo__text {
        width: 100%;
    }

    .geo__text p {
        width: 274px;
        margin-top: 16px;
        font-size: 13px;
        line-height: 20px;
    }

    .geo__map-scroll {
        left: 0;
        right: 0;
        top: 144px;
        width: auto;
        height: 407px;
        transform: none;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .geo__map-scroll::-webkit-scrollbar {
        display: none;
    }

    .geo__map {
        width: 843px;
        height: 407px;
    }

    .geo__facts {
        left: 20px;
        right: auto;
        top: 479px;
        width: 300px;
        gap: 16px;
    }

    .geo__facts strong {
        font-size: 32px;
        line-height: 40px;
    }

    .geo__facts span {
        font-size: 16px;
        line-height: 20px;
    }

    .geo__facts p {
        font-size: 13px;
        line-height: 20px;
    }

    .clients__grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 0;
        margin-top: 24px;
    }

    .clients-swiper {
        margin-top: 24px;
    }

    .clients-swiper .clients__grid {
        margin-top: 0;
    }

    .client-logo {
        height: 55px;
    }

    .client-logo img {
        max-height: 38px;
    }

    .client-logo span {
        font-size: 12px;
        line-height: 16px;
    }

    .contact-cta__inner {
        display: flex;
        flex-direction: column;
        gap: 24px;
        align-items: center;
        min-height: 0;
        padding-top: 40px;
        padding-bottom: 40px;
        text-align: center;
    }

    .contact-cta p {
        margin-top: 8px;
    }

    .contact-cta__phone {
        text-align: center;
    }

    .contact-cta__phone a {
        font-size: 20px;
        line-height: 32px;
    }

    .site-footer {
        padding-top: 40px;
    }

    .footer__main {
        display: flex;
        flex-direction: column;
        gap: 24px;
        min-height: 0;
        padding-top: 0;
        padding-bottom: 24px;
    }

    .footer__col h2 {
        margin-bottom: 0;
        font-size: 20px;
    }

    .footer__col a,
    .footer__col p {
        font-size: 13px;
    }

    .footer-logo {
        align-self: center;
        justify-self: auto;
        width: 123px;
    }

    .footer-logo img {
        width: 114px;
    }

    .footer-logo span {
        font-size: 14px;
        line-height: 16px;
    }

    .footer__bottom-inner {
        flex-direction: column;
        justify-content: center;
        gap: 16px;
        min-height: 112px;
        text-align: center;
        font-size: 13px;
    }

    .catalog-page {
        padding: 40px 0;
    }

    .breadcrumbs {
        font-size: 13px;
    }

    .catalog-page__head {
        margin-top: 32px;
    }

    .catalog-page__head h1 {
        font-size: 28px;
        line-height: 36px;
    }

    .catalog-page__head p {
        margin-top: 24px;
        font-size: 16px;
        line-height: 22px;
    }

    .catalog-page__grid {
        margin-top: 32px;
    }

    .page-catalog .catalog-card__body {
        min-height: 0;
    }

    .projects-page {
        padding: 40px 0;
    }

    .projects-page__head {
        margin-top: 32px;
    }

    .projects-page__head p {
        width: auto;
    }

    .project-filters {
        flex-direction: column;
        gap: 12px;
        margin-top: 24px;
    }

    .project-filters strong {
        padding-top: 0;
    }

    .project-filters__list {
        gap: 8px;
        overflow-x: auto;
        flex-wrap: nowrap;
        width: calc(100vw - 32px);
        padding-bottom: 4px;
        scrollbar-width: none;
    }

    .project-filters__list::-webkit-scrollbar {
        display: none;
    }

    .project-filters button {
        flex: 0 0 auto;
    }

    .projects-list {
        grid-template-columns: 1fr;
        gap: 24px;
        margin-top: 32px;
    }

    .project-list-card {
        min-height: 0;
    }

    .project-list-card img {
        height: 180px;
    }

    .project-list-card span {
        gap: 12px;
        padding: 20px 16px;
    }

    .project-list-card strong {
        font-size: 17px;
        line-height: 24px;
    }

    .pagination {
        gap: 12px;
        margin-top: 32px;
    }

    .product-hero {
        grid-template-columns: 1fr;
    }

    .product-hero__image {
        height: 250px;
    }

    .product-hero__info {
        padding: 32px 16px 40px;
    }

    .product-hero h1 {
        font-size: 28px;
        line-height: 36px;
    }

    .product-hero p {
        margin-top: 20px;
        font-size: 15px;
        line-height: 21px;
    }

    .product-stats {
        grid-template-columns: 1fr;
        gap: 16px;
        margin-top: 28px;
    }

    .product-stats strong {
        font-size: 28px;
        line-height: 32px;
    }

    .product-content {
        padding: 40px 0;
    }

    .product-content__grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .product-copy {
        gap: 40px;
    }

    .product-copy h2,
    .related-projects h2 {
        font-size: 24px;
        line-height: 32px;
    }

    .product-copy p,
    .product-copy li {
        font-size: 15px;
        line-height: 21px;
    }

    .spec-card {
        padding: 24px 16px;
    }

    .spec-card div {
        grid-template-columns: 1fr;
        gap: 6px;
    }

    .expert-card {
        grid-template-columns: 72px 1fr;
    }

    .expert-card__photo {
        width: 72px;
        height: 82px;
    }

    .expert-card__photo-img {
        width: 72px;
        height: 82px;
    }

    .expert-card__contacts,
    .expert-card .btn {
        grid-column: 1 / -1;
    }

    .expert-card__contacts {
        padding-right: 0;
    }

    .expert-card .btn {
        justify-self: start;
        margin-top: 0;
    }

    .related-projects {
        padding: 40px 0;
    }

    .related-projects__wrap {
        margin-top: 24px;
    }

    .related-arrow {
        display: none;
    }

    .vacancies-page {
        padding: 40px 0;
    }

    .vacancies-page__head {
        margin-top: 32px;
    }

    .vacancies-list {
        margin-top: 24px;
    }

    .vacancy__head {
        grid-template-columns: 1fr;
        gap: 14px;
        min-height: 100px;
        padding: 20px 44px 20px 20px;
    }

    .vacancy__head::after {
        right: 20px;
    }

    .vacancy__head strong {
        font-size: 16px;
        line-height: 22px;
    }

    .vacancy__head em {
        margin-top: 10px;
    }

    .vacancy__head b {
        padding-right: 0;
        font-size: 16px;
        line-height: 22px;
        white-space: normal;
    }

    .vacancy__content {
        display: block;
        min-height: 0;
        padding: 4px 20px 24px;
    }

    .vacancy__section + .vacancy__section {
        margin-top: 24px;
    }

    .vacancy__content .btn {
        margin-top: 24px;
    }

    .contacts-page {
        padding: 40px 0;
    }

    .contacts-page h1 {
        margin-top: 32px;
        font-size: 32px;
        line-height: 40px;
    }

    .contacts-page__summary,
    .contacts-page__main {
        grid-template-columns: 1fr;
        gap: 28px;
    }

    .contacts-page__summary {
        margin-top: 28px;
    }

    .contacts-page__summary p {
        margin-top: 16px;
    }

    .contacts-page__main {
        margin-top: 32px;
    }

    .contacts-page__map {
        height: auto;
        aspect-ratio: 790 / 487;
    }

    .contacts-page__aside section + section,
    .contacts-page__aside .btn {
        margin-top: 32px;
    }

    .commercial-team {
        padding: 40px 0;
    }

    .commercial-team__grid {
        grid-template-columns: 1fr;
        gap: 28px;
        margin-top: 28px;
    }

    .manager-card {
        grid-template-columns: 88px 1fr;
        gap: 16px;
    }

    .manager-card img {
        width: 88px;
        height: 100px;
    }

    .request-section {
        padding: 40px 0;
    }

    .request-section::after {
        right: -260px;
        bottom: -130px;
        width: 720px;
        height: 460px;
    }

    .request-section h2 {
        font-size: 28px;
        line-height: 34px;
    }

    .request-form {
        grid-template-columns: 1fr;
        gap: 20px;
        margin-top: 32px;
    }

    .request-form label + label {
        margin-top: 16px;
    }

    .licenses-page {
        padding: 40px 0 64px;
    }

    .licenses-page h1 {
        margin-top: 32px;
        font-size: 30px;
        line-height: 38px;
    }

    .licenses-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 32px 18px;
        margin-top: 32px;
    }

    .license-card__image {
        height: 220px;
    }

    .license-card strong {
        margin-top: 12px;
        font-size: 15px;
        line-height: 20px;
    }

    .about-hero {
        grid-template-columns: 1fr;
    }

    .about-hero__text .container {
        max-width: calc(100% - 32px);
        margin: 0 auto;
        padding-top: 28px;
        padding-bottom: 40px;
    }

    .about-hero__copy {
        margin-top: 64px;
    }

    .about-hero h1 {
        font-size: 32px;
        line-height: 40px;
    }

    .about-hero p {
        font-size: 20px;
        line-height: 28px;
    }

    .about-hero__image {
        height: 320px;
    }

    .about-company {
        padding: 40px 0;
    }

    .about-company__grid {
        grid-template-columns: 1fr;
        gap: 34px;
    }

    .about-gallery {
        position: relative;
        top: auto;
    }

    .about-gallery-main img {
        height: auto;
        aspect-ratio: 590 / 455;
    }

    .about-company__content h2,
    .history h2,
    .about-competencies h2,
    .about-clients h2,
    .standards h2 {
        font-size: 26px;
        line-height: 32px;
    }

    .history {
        padding-bottom: 40px;
    }

    .history__years {
        grid-template-columns: 1fr;
        gap: 24px;
        margin-top: 28px;
    }

    .history__track {
        grid-template-columns: repeat(8, 1fr);
    }

    .about-competencies {
        padding: 40px 0;
    }

    .about-competencies__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 30px 24px;
        margin-top: 30px;
    }

    .about-clients {
        padding: 40px 0;
    }

    .about-clients__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
        margin-top: 28px;
    }

    .about-client {
        height: 76px;
    }

    .about-client span {
        font-size: 13px;
        line-height: 16px;
    }

    .standards {
        padding-bottom: 44px;
    }

    .standards p {
        margin-top: 20px;
    }

    .press-kit-page {
        min-height: 0;
        padding: 40px 0 64px;
    }

    .press-kit-page::after {
        right: -260px;
        bottom: -120px;
        width: 680px;
        height: 430px;
    }

    .press-kit-page__head {
        margin-top: 32px;
    }

    .press-kit-page__head h1 {
        font-size: 32px;
        line-height: 40px;
    }

    .press-kit-page__head p {
        margin-top: 24px;
        font-size: 16px;
        line-height: 22px;
    }

    .press-kit-grid {
        grid-template-columns: 1fr;
        gap: 28px;
        margin-top: 28px;
    }

    .press-kit-card img {
        width: 100%;
        height: auto;
        aspect-ratio: 280 / 144;
    }

    .press-kit-card h2 {
        font-size: 22px;
        line-height: 28px;
    }

    .project-detail-hero {
        grid-template-columns: 1fr;
    }

    .project-detail-hero > img {
        height: 280px;
    }

    .project-detail-hero__info {
        padding: 32px 16px 40px;
    }

    .project-detail-hero__info .breadcrumbs {
        margin-bottom: 28px;
    }

    .project-detail-hero h1 {
        font-size: 28px;
        line-height: 36px;
    }

    .project-detail-hero p {
        margin-top: 20px;
        font-size: 15px;
        line-height: 21px;
    }

    .project-detail-content {
        padding: 40px 0 24px;
    }

    .project-detail-content__grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .project-detail-expert {
        padding-top: 0;
    }

    .expert-card__photo-img {
        width: 72px;
        height: 82px;
    }

    .project-detail-gallery {
        padding-bottom: 40px;
    }

    .project-gallery-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 16px;
    }

    .project-spec-card {
        margin-top: 36px;
        padding: 24px 16px;
    }

    .project-spec-card div {
        grid-template-columns: 1fr;
    }

    .articles-page {
        padding: 40px 0;
    }

    .articles-page h1 {
        margin-top: 32px;
        font-size: 32px;
        line-height: 40px;
    }

    .article-years {
        flex-wrap: wrap;
        gap: 10px;
        margin-top: 24px;
    }

    .articles-list {
        gap: 32px;
        margin-top: 28px;
    }

    .article-row {
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .article-row__image img {
        width: 100%;
        height: auto;
        aspect-ratio: 350 / 216;
    }

    .article-row__body h2 a {
        font-size: 22px;
        line-height: 28px;
    }

    .article-row__body p {
        margin-top: 16px;
        font-size: 16px;
        line-height: 22px;
    }

    .tenders-page {
        padding: 40px 0;
    }

    .tenders-page__head {
        margin-top: 32px;
    }

    .tenders-page__head h1 {
        font-size: 32px;
        line-height: 40px;
    }

    .tenders-page__head p {
        margin-top: 24px;
        font-size: 16px;
        line-height: 22px;
    }

    .tender-panel,
    .tender-panel + .tender-panel {
        grid-template-columns: 1fr;
        margin-top: 28px;
    }

    .tender-panel--left img {
        order: 2;
    }

    .tender-panel__content {
        padding: 28px 20px;
    }

    .tender-panel h2,
    .tender-platforms h2 {
        font-size: 26px;
        line-height: 32px;
    }

    .tender-panel p,
    .tender-platforms p {
        margin-top: 20px;
        font-size: 16px;
        line-height: 22px;
    }

    .tender-panel h3 {
        margin-top: 28px;
        font-size: 20px;
        line-height: 26px;
    }

    .tender-panel li {
        font-size: 16px;
        line-height: 26px;
    }

    .tender-panel img {
        height: auto;
        aspect-ratio: 480 / 360;
    }

    .tender-platforms {
        margin-top: 42px;
    }

    .tender-platforms img {
        margin-top: 24px;
    }

    .not-found {
        min-height: 0;
        padding: 40px 0;
    }

    .not-found::after {
        right: -250px;
        bottom: -90px;
        width: 640px;
        height: 420px;
    }

    .not-found__head {
        margin-top: 32px;
    }

    .not-found__head h1 {
        font-size: 28px;
        line-height: 36px;
    }

    .not-found__head p {
        margin-top: 20px;
    }

    .not-found__code {
        margin-top: 32px;
        font-size: 108px;
    }

    .not-found__links {
        grid-template-columns: 1fr;
        gap: 20px;
        margin-top: 32px;
    }

    .not-found__links strong {
        font-size: 18px;
        line-height: 22px;
    }
}

.article-detail {
    padding: 24px 0 0;
}

.article-detail__breadcrumbs {
    display: flex;
    align-items: center;
    gap: 8px;
    color: rgba(33, 37, 41, .42);
    font-size: 13px;
    line-height: 16px;
    white-space: nowrap;
}

.article-detail__breadcrumbs a,
.article-detail__breadcrumbs span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.article-detail__breadcrumbs a::before,
.article-detail__breadcrumbs span::before {
    content: "";
    width: 6px;
    height: 6px;
    border-left: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg);
}

.article-detail__breadcrumbs a:hover {
    color: var(--accent-orange);
}

.article-detail__grid {
    display: grid;
    grid-template-columns: 680px 480px;
    gap: 20px;
    margin-top: 68px;
}

.article-detail__content time,
.related-article time {
    display: block;
    color: #979797;
    font-size: 13px;
    line-height: 20px;
}

.article-detail__content h1 {
    margin-top: 16px;
    color: var(--main-blue);
    font-size: 40px;
    line-height: 48px;
}

.article-detail__copy {
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin-top: 32px;
    font-size: 16px;
    line-height: 20px;
}

.article-detail__gallery {
    display: grid;
    grid-template-columns: 237px 218px;
    gap: 20px 25px;
    padding-top: 28px;
    align-self: start;
}

.article-detail__image {
    width: 100%;
    height: 210px;
    object-fit: cover;
}

.article-detail__image--wide {
    grid-column: 1 / -1;
    height: 292px;
}
.article-detail__image--wide img {
    height: 100% !important;
}
.article-detail__related {
    padding: 80px 0 80px;
}

.article-detail__related h2 {
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 32px;
    font-weight: 700;
    line-height: 40px;
}

.article-detail__related-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-top: 32px;
}

.related-article {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    min-width: 0;
}

.related-article h3 {
    color: #000;
    font-size: 20px;
    line-height: 28px;
}

.related-article h3 a:hover {
    color: var(--accent-orange);
}

.related-article p {
    display: -webkit-box;
    min-height: 60px;
    overflow: hidden;
    color: var(--neutral-dark);
    font-size: 16px;
    line-height: 20px;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.related-article__more {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--accent-orange);
    font-size: 14px;
    line-height: 20px;
}

.related-article__more::after {
    content: "›";
    font-size: 18px;
    line-height: 1;
}

.related-article__more:hover {
    color: var(--orange-dark);
}

@media (max-width: 1199px) {
    .article-detail__grid {
        grid-template-columns: minmax(0, 1fr) 40%;
        gap: 24px;
    }

    .article-detail__gallery {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 16px;
    }

    .article-detail__image {
        height: auto;
        aspect-ratio: 1 / 1;
    }

    .article-detail__image--wide {
        aspect-ratio: 480 / 292;
        height: auto;
    }
}

@media (max-width: 849px) {
    .article-detail {
        padding-top: 24px;
    }

    .article-detail__breadcrumbs {
        overflow-x: auto;
        padding-bottom: 4px;
        scrollbar-width: none;
    }

    .article-detail__breadcrumbs::-webkit-scrollbar {
        display: none;
    }

    .article-detail__grid {
        grid-template-columns: 1fr;
        gap: 32px;
        margin-top: 32px;
    }

    .article-detail__content h1 {
        margin-top: 12px;
        font-size: 28px;
        line-height: 36px;
    }

    .article-detail__copy {
        gap: 16px;
        margin-top: 24px;
        font-size: 15px;
        line-height: 21px;
    }

    .article-detail__gallery {
        gap: 12px;
        padding-top: 0;
    }

    .article-detail__related {
        padding: 40px 0;
    }

    .article-detail__related h2 {
        font-size: 24px;
        line-height: 32px;
    }

    .article-detail__related-grid {
        grid-template-columns: 1fr;
        gap: 28px;
        margin-top: 24px;
    }

    .related-article {
        gap: 12px;
    }

    .related-article h3 {
        font-size: 18px;
        line-height: 26px;
    }

    .related-article p {
        min-height: 0;
        font-size: 15px;
        line-height: 21px;
    }
}

.documents-page {
    position: relative;
    overflow: hidden;
    min-height: 630px;
    padding: 24px 0 80px;
    background: var(--pure-white);
}

.documents-page__inner {
    position: relative;
    z-index: 2;
}

.documents-page__breadcrumbs {
    display: flex;
    align-items: center;
    gap: 8px;
    color: rgba(33, 37, 41, .42);
    font-size: 13px;
    line-height: 16px;
}

.documents-page__breadcrumbs a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.documents-page__breadcrumbs a::before {
    content: "";
    width: 6px;
    height: 6px;
    border-left: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg);
}

.documents-page__breadcrumbs a:hover {
    color: var(--accent-orange);
}

.documents-page h1 {
    margin-top: 36px;
    color: var(--main-blue);
    font-size: 40px;
    line-height: 48px;
}

.documents-page__list {
    display: flex;
    flex-direction: column;
    gap: 34px;
    width: 100%;
    max-width: 100%;
    margin-top: 50px;
    margin-left: 64px;
}

.documents-page__item {
    display: grid;
    grid-template-columns: 26px 1fr;
    gap: 16px;
    align-items: start;
    color: var(--neutral-dark);
}

.documents-page__item:hover strong {
    color: var(--accent-orange);
}

.documents-page__icon {
    position: relative;
    width: 26px;
    height: 32px;
    background: var(--main-blue);
}

.documents-page__icon::before,
.documents-page__icon::after {
    content: "";
    position: absolute;
    left: 7px;
    right: 6px;
    height: 2px;
    background: var(--pure-white);
}

.documents-page__icon::before {
    top: 11px;
    box-shadow: 0 5px 0 var(--pure-white);
}

.documents-page__icon::after {
    top: 21px;
    right: 11px;
}

.documents-page__text {
    display: flex;
    flex-direction: column;
    gap: 9px;
    padding-top: 3px;
}

.documents-page__text strong {
    color: var(--main-blue);
    font-family: var(--second-family);
    font-size: 20px;
    font-weight: 700;
    line-height: 24px;
    transition: color .2s ease;
}

.documents-page__text span {
    font-size: 13px;
    line-height: 16px;
}

.documents-page__mark {
    position: absolute;
    right: -150px;
    bottom: -138px;
    z-index: 1;
    color: transparent;
    font-family: var(--second-family);
    font-size: 630px;
    font-weight: 700;
    line-height: .72;
    letter-spacing: 0;
    opacity: .08;
    -webkit-text-stroke: 3px var(--main-blue);
    text-stroke: 3px var(--main-blue);
    pointer-events: none;
}

@media (max-width: 1199px) {
    .documents-page {
        min-height: 560px;
    }

    .documents-page__mark {
        right: -260px;
        bottom: -70px;
        font-size: 500px;
    }
}

@media (max-width: 849px) {
    .documents-page {
        min-height: 0;
        padding: 24px 0 48px;
    }

    .documents-page h1 {
        margin-top: 32px;
        font-size: 32px;
        line-height: 40px;
    }

    .documents-page__list {
        gap: 24px;
        margin-top: 32px;
        margin-left: 0;
    }

    .documents-page__item {
        grid-template-columns: 26px 1fr;
        gap: 14px;
    }

    .documents-page__text strong {
        font-size: 17px;
        line-height: 23px;
    }

    .documents-page__mark {
        right: -180px;
        bottom: -35px;
        font-size: 330px;
        opacity: .06;
    }
}
.partners-logos {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 34px 58px;
    justify-content: center;
}

.partners-logos__item {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 1 180px;
    min-height: 72px;
    color: inherit;
    transition: opacity .2s ease, transform .2s ease;
}

.partners-logos__item:hover {
    opacity: .72;
    transform: translateY(-2px);
}

.partners-logos__item img {
    display: block;
    max-width: 100%;
    max-height: 64px;
    object-fit: contain;
}

@media (max-width: 849px) {
    .partners-logos {
        gap: 24px 28px;
    }

    .partners-logos__item {
        flex-basis: calc(50% - 14px);
        min-height: 56px;
    }

    .partners-logos__item img {
        max-height: 48px;
    }
}

/* Hover states from Figma UI kit */
.btn,
.header__nav-link,
.header-submenu a,
.mobile-menu__link,
.mobile-submenu a,
.footer__col a,
.link-accent,
.catalog-card,
.project-card,
.project-list-card,
.license-card,
.press-kit-card,
.article-row__body h2 a,
.article-row__more,
.related-article h3 a,
.related-article__more,
.documents-page__breadcrumbs a,
.documents-page__item,
.project-filters button,
.article-years button,
.pagination a,
.vacancy__head,
.request-form input,
.request-form textarea,
.request-form select,
.about-client,
.contact-links,
.project-gallery-grid a,
.partners-logos__item {
    transition:
        background .2s ease,
        border-color .2s ease,
        color .2s ease,
        opacity .2s ease,
        transform .2s ease,
        box-shadow .2s ease;
}

.btn-primary:hover,
.btn-main:hover {
    background: var(--orange-dark);
    color: var(--pure-white);
}

.btn-secondary:hover {
    border-color: var(--accent-orange);
    background: #ffe5d9;
    color: var(--accent-orange);
}

.btn-secondary:active {
    border-color: var(--main-blue);
    background: #e6e6e6;
    color: var(--main-blue);
}

.header__nav a:hover, .contact-links:hover,
.header__nav-item:has(.header-submenu):hover > .header__nav-link,
.header__nav-item:has(.header-submenu):focus-within > .header__nav-link,
.mobile-menu__link:hover,
.mobile-submenu a:hover {
    color: var(--accent-orange);
}

.header__nav-link:active,
.mobile-menu__link:active {
    color: var(--orange-dark);
}

.header-submenu a:hover {
    background: transparent;
    color: var(--accent-orange);
}

.footer__col a:hover,
.footer__bottom a:hover,
.link-accent:hover,
.article-row__more:hover,
.related-article__more:hover,
.press-kit-card a:hover,
.documents-page__breadcrumbs a:hover {
    color: var(--orange-dark);
}

.catalog-card:hover,
.project-card:hover,
.project-list-card:hover,
.press-kit-card:hover,
.related-article:hover {
    border-color: var(--accent-orange);
    background: #fff7f2;
    transform: translateY(-2px);
}

.catalog-card:hover strong,
.project-card:hover strong,
.project-list-card:hover strong,
.press-kit-card:hover h2,
.article-row__body h2 a:hover,
.related-article h3 a:hover,
.license-card:hover strong,
.documents-page__item:hover strong {
    color: var(--accent-orange);
}

.catalog-card:hover em,
.project-card:hover em,
.project-list-card:hover em {
    color: var(--orange-dark);
}

.license-card:hover {
    color: var(--accent-orange);
}

.license-card:hover .license-card__image img,
.project-gallery-grid a:hover img,
.article-row__image:hover img,
.press-kit-card:hover img {
    transform: translateY(-2px);
}

.license-card__image img,
.project-gallery-grid img,
.article-row__image img,
.press-kit-card img {
    transition: transform .2s ease;
}

.project-filters button:hover,
.article-years button:hover {
    border-color: var(--neutral-dark);
    color: var(--neutral-dark);
}

.project-filters button.active:hover,
.article-years button.active:hover {
    border-color: var(--orange-dark);
    background: var(--orange-dark);
    color: var(--pure-white);
}

.pagination a:hover {
    background: #dbe4ec;
    color: var(--neutral-dark);
}

.pagination a.active:hover {
    background: var(--orange-dark);
    color: var(--pure-white);
}

.vacancy:hover,
.vacancy__head:hover {
    border-color: var(--accent-orange);
}

.vacancy__head:hover strong {
    color: var(--accent-orange);
}

.request-form input:hover,
.request-form textarea:hover,
.request-form select:hover {
    border-color: var(--accent-orange);
}

.request-form input:focus,
.request-form textarea:focus,
.request-form select:focus {
    border-color: var(--accent-orange);
    outline: none;
    box-shadow: 0 0 0 2px rgba(247, 95, 23, .14);
}

.about-client:hover {
    border-color: var(--accent-orange);
    transform: translateY(-2px);
}

.about-gallery__arrow:hover,
.related-arrow:hover,
.hero-arrow:hover {
    background: var(--accent-orange);
}

.about-gallery__arrow:hover::before,
.related-arrow:hover::before {
    border-color: var(--pure-white);
}

.cookies-close:hover,
.menu-toggle:hover span {
    opacity: .72;
}

.partners-logos__item:hover {
    opacity: .72;
    transform: translateY(-2px);
}

/* Breadcrumbs nowrap fix */
.breadcrumbs {
    flex-wrap: nowrap;
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
}

.breadcrumbs a,
.breadcrumbs span {
    flex: 0 0 auto;
    min-width: 0;
    max-width: 100%;
    white-space: nowrap;
}

.breadcrumbs a:last-child,
.breadcrumbs span:last-child {
    flex: 1 1 auto;
    overflow: hidden;
    text-overflow: ellipsis;
}

.project-detail-hero__info .breadcrumbs {
    width: 100%;
    margin-bottom: 32px;
}

/* Breadcrumbs hover states */
.breadcrumbs a,
.breadcrumbs span {
    transition: color .2s ease;
}

.breadcrumbs a:hover,
.breadcrumbs a:hover::before {
    color: var(--neutral-dark);
}

.breadcrumbs a:active,
.breadcrumbs a:active::before,
.breadcrumbs a.active,
.breadcrumbs a.active::before,
.breadcrumbs span,
.breadcrumbs span::before {
    color: var(--accent-orange);
}
